#include <OpenMS/CONCEPT/Exception.h>
Public Member Functions | |
Constructors and Destructors | |
BaseException () noexcept | |
Default constructor. More... | |
BaseException (const char *file, int line, const char *function) noexcept | |
Constructor. More... | |
BaseException (const char *file, int line, const char *function, const std::string &name, const std::string &message) noexcept | |
Constructor. More... | |
BaseException (const BaseException &exception) noexcept | |
Copy constructor. More... | |
virtual | ~BaseException () noexcept |
Destructor. More... | |
Accessors | |
const char * | getName () const noexcept |
Returns the name of the exception. More... | |
virtual const char * | what () const noexcept |
Returns the error message of the exception. More... | |
int | getLine () const noexcept |
Returns the line number where it occurred. More... | |
const char * | getFile () const noexcept |
Returns the file where it occurred. More... | |
const char * | getFunction () const noexcept |
Returns the function where it occurred. More... | |
const char * | getMessage () const noexcept |
Returns the message. More... | |
void | setMessage (const std::string &message) noexcept |
Modify the exception's error message. More... | |
Protected Attributes | |
const char * | file_ |
The source file the exception was thrown in. More... | |
int | line_ |
The line number the exception was thrown in. More... | |
const char * | function_ |
The source file the exception was thrown in. More... | |
std::string | name_ |
The name of the exception. More... | |
std::string | what_ |
A more detailed description of the exception's cause. More... | |
Exception base class.
This class is intended as a base class for all other exceptions.
Each exception class should define a constructor taking a filename (string), line (int) and function name (string) as first arguments. This information is usually printed in case of an uncaught exception.
To support this feature, each throw directive should look as follows:
__FILE__ and __LINE__ are built-in preprocessor macros that hold the desired information.
OPENMS_PRETTY_FUNCTION is replaced by the GNU G++ compiler with the demangled name of the current function. (For other compilers it is defined as "<unknown>" in config.h.)
OpenMS provides its own Exception::GlobalExceptionHandler::terminate() handler. This handler extracts as much information as possible from the exception, prints it to cerr , and finally calls exits the program cleanly (with exit code 1). This can be rather inconvenient for debugging, since you are told where the exception was thrown, but in general you do not know anything about the context. Therefore terminate() can also create a core dump. Using a debugger (e.g. dbx or gdb) you can then create a stack traceback. To create a core dump, you should set the environment variable OPENMS_DUMP_CORE to any (non empty) value.
|
noexcept |
Default constructor.
|
noexcept |
Constructor.
|
noexcept |
Constructor.
|
noexcept |
Copy constructor.
|
virtualnoexcept |
Destructor.
|
noexcept |
Returns the file where it occurred.
Referenced by main().
|
noexcept |
Returns the function where it occurred.
|
noexcept |
Returns the line number where it occurred.
Referenced by main().
|
noexcept |
Returns the message.
Referenced by QApplicationTOPP::notify().
|
noexcept |
Returns the name of the exception.
Referenced by QApplicationTOPP::notify().
|
noexcept |
Modify the exception's error message.
|
virtualnoexcept |
Returns the error message of the exception.
Referenced by TOPPViewBase::addDataFile(), TOPPViewBase::annotateWithID(), TOPPViewBase::copyLayer(), TOPPViewBase::fileChanged_(), main(), TOPPViewBase::metadataFileDialog(), and TOPPViewBase::showSpectrumGenerationDialog().
|
protected |
The source file the exception was thrown in.
|
protected |
The source file the exception was thrown in.
|
protected |
The line number the exception was thrown in.
|
protected |
The name of the exception.
|
protected |
A more detailed description of the exception's cause.
OpenMS / TOPP release 2.3.0 | Documentation generated on Tue Jan 9 2018 18:22:14 using doxygen 1.8.13 |