From dfe62dcf8bcefc523b466e127c3edc4dc2756629 Mon Sep 17 00:00:00 2001 From: crupest Date: Sun, 6 Oct 2024 13:57:39 +0800 Subject: Rename common to base. --- include/cru/base/Exception.h | 60 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 include/cru/base/Exception.h (limited to 'include/cru/base/Exception.h') diff --git a/include/cru/base/Exception.h b/include/cru/base/Exception.h new file mode 100644 index 00000000..609fd2c9 --- /dev/null +++ b/include/cru/base/Exception.h @@ -0,0 +1,60 @@ +#pragma once +#include "String.h" + +#include +#include + +namespace cru { +#ifdef _MSC_VER +#pragma warning(disable : 4275) +#endif +class CRU_BASE_API Exception : public std::exception { + public: + explicit Exception(String message = {}, + std::unique_ptr inner = nullptr); + + ~Exception() override; + + public: + String GetMessage() const { return message_; } + + std::exception* GetInner() const noexcept { return inner_.get(); } + + const char* what() const noexcept override; + + protected: + void SetMessage(String message) { message_ = std::move(message); } + + void AppendMessage(StringView additional_message); + void AppendMessage(std::optional additional_message); + + private: + String message_; + mutable std::string utf8_message_; + std::unique_ptr inner_; +}; + +class CRU_BASE_API TextEncodeException : public Exception { + public: + using Exception::Exception; +}; + +class ErrnoException : public Exception { + public: + /** + * @brief will retrieve errno automatically. + */ + explicit ErrnoException(String message = {}); + ErrnoException(String message, int errno_code); + + CRU_DELETE_COPY(ErrnoException) + CRU_DELETE_MOVE(ErrnoException) + + ~ErrnoException() override = default; + + int GetErrnoCode() const { return errno_code_; } + + private: + int errno_code_; +}; +} // namespace cru -- cgit v1.2.3