/****************************************************************************** * Icinga 2 * * Copyright (C) 2012-2018 Icinga Development Team (https://www.icinga.com/) * * * * This program is free software; you can redistribute it and/or * * modify it under the terms of the GNU General Public License * * as published by the Free Software Foundation; either version 2 * * of the License, or (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the Free Software Foundation * * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. * ******************************************************************************/ #ifndef EXCEPTION_H #define EXCEPTION_H #include "base/i2-base.hpp" #include "base/string.hpp" #include "base/stacktrace.hpp" #include "base/context.hpp" #include "base/utility.hpp" #include "base/debuginfo.hpp" #include "base/dictionary.hpp" #include "base/configobject.hpp" #include #include #include #include #include #ifdef _WIN32 # include #endif /* _WIN32 */ namespace icinga { class user_error : virtual public std::exception, virtual public boost::exception { }; /* * @ingroup base */ class ScriptError : virtual public user_error { public: ScriptError(String message); ScriptError(String message, DebugInfo di, bool incompleteExpr = false); ~ScriptError() throw() = default; const char *what(void) const throw() final; DebugInfo GetDebugInfo() const; bool IsIncompleteExpression() const; bool IsHandledByDebugger() const; void SetHandledByDebugger(bool handled); private: String m_Message; DebugInfo m_DebugInfo; bool m_IncompleteExpr; bool m_HandledByDebugger; }; /* * @ingroup base */ class ValidationError : virtual public user_error { public: ValidationError(const ConfigObject::Ptr& object, const std::vector& attributePath, const String& message); ~ValidationError() throw() override; const char *what() const throw() override; ConfigObject::Ptr GetObject() const; std::vector GetAttributePath() const; String GetMessage() const; void SetDebugHint(const Dictionary::Ptr& dhint); Dictionary::Ptr GetDebugHint() const; private: ConfigObject::Ptr m_Object; std::vector m_AttributePath; String m_Message; String m_What; Dictionary::Ptr m_DebugHint; }; StackTrace *GetLastExceptionStack(); void SetLastExceptionStack(const StackTrace& trace); ContextTrace *GetLastExceptionContext(); void SetLastExceptionContext(const ContextTrace& context); void RethrowUncaughtException(); typedef boost::error_info StackTraceErrorInfo; std::string to_string(const StackTraceErrorInfo&); typedef boost::error_info ContextTraceErrorInfo; std::string to_string(const ContextTraceErrorInfo& e); String DiagnosticInformation(const std::exception& ex, bool verbose = true, StackTrace *stack = nullptr, ContextTrace *context = nullptr); String DiagnosticInformation(const boost::exception_ptr& eptr, bool verbose = true); class posix_error : virtual public std::exception, virtual public boost::exception { public: ~posix_error() throw() override; const char *what(void) const throw() final; private: mutable char *m_Message{nullptr}; }; #ifdef _WIN32 class win32_error : virtual public std::exception, virtual public boost::exception { }; struct errinfo_win32_error_; typedef boost::error_info errinfo_win32_error; std::string to_string(const errinfo_win32_error& e); #endif /* _WIN32 */ struct errinfo_getaddrinfo_error_; typedef boost::error_info errinfo_getaddrinfo_error; std::string to_string(const errinfo_getaddrinfo_error& e); struct errinfo_message_; typedef boost::error_info errinfo_message; } #endif /* EXCEPTION_H */