/* * Copyright (C) 2012 Open Source Robotics Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * Author: Nathan Koenig * Date: 07 May 2007 */ #ifndef _GAZEBO_EXCEPTION_HH_ #define _GAZEBO_EXCEPTION_HH_ #include #include #include #include "gazebo/util/system.hh" namespace gazebo { namespace common { /// \addtogroup gazebo_common /// \{ /// \brief This macro logs an error to the throw stream and throws /// an exception that contains the file name and line number. #define gzthrow(msg) {std::ostringstream throwStream;\ throwStream << msg << std::endl << std::flush;\ throw gazebo::common::Exception(__FILE__, __LINE__, throwStream.str()); } /// \class Exception Exception.hh common/common.hh /// \brief Class for generating exceptions class GZ_COMMON_VISIBLE Exception { /// \brief Constructor public: Exception(); /// \brief Default constructor /// \param[in] _file File name /// \param[in] _line Line number where the error occurred /// \param[in] _msg Error message public: Exception(const char *_file, int _line, std::string _msg); /// \brief Destructor public: virtual ~Exception(); /// \brief Return the error function /// \return The error function name public: std::string GetErrorFile() const; /// \brief Return the error string /// \return The error string public: std::string GetErrorStr() const; /// \brief Print the exception to std out. public: void Print() const; /// \brief The error function private: std::string file; /// \brief Line the error occured on private: int line; /// \brief The error string private: std::string str; /// \brief stream insertion operator for Gazebo Error /// \param[in] _out the output stream /// \param[in] _err the exception public: friend std::ostream &operator<<(std::ostream &_out, const gazebo::common::Exception &_err) { return _out << _err.GetErrorStr(); } }; /// \class InternalError Exception.hh common/common.hh /// \brief Class for generating Internal Gazebo Errors: /// those errors which should never happend and /// represent programming bugs. class GZ_COMMON_VISIBLE InternalError : public Exception { /// \brief Constructor public: InternalError(); /// \brief Default constructor /// \param[in] _file File name /// \param[in] _line Line number where the error occurred /// \param[in] _msg Error message public: InternalError(const char *_file, int _line, const std::string &_msg); /// \brief Destructor public: virtual ~InternalError(); }; /// \class AssertionInternalError Exception.hh common/common.hh /// \brief Class for generating Exceptions which come from /// gazebo assertions. They include information about the /// assertion expression violated, function where problem /// appeared and assertion debug message. class GZ_COMMON_VISIBLE AssertionInternalError : public InternalError { /// \brief Constructor for assertions /// \param[in] _file File name /// \param[in] _line Line number where the error occurred /// \param[in] _expr Assertion expression failed resulting in an /// internal error /// \param[in] _function Function where assertion failed /// \param[in] _msg Function where assertion failed public: AssertionInternalError(const char *_file, int _line, const std::string &_expr, const std::string &_function, const std::string &_msg = ""); /// \brief Destructor public: virtual ~AssertionInternalError(); }; /// \} } } #endif