LSST Applications g063fba187b+cac8b7c890,g0f08755f38+6aee506743,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g1a2382251a+b4475c5878,g1dcb35cd9c+8f9bc1652e,g20f6ffc8e0+6aee506743,g217e2c1bcf+73dee94bd0,g28da252d5a+1f19c529b9,g2bbee38e9b+3f2625acfc,g2bc492864f+3f2625acfc,g3156d2b45e+6e55a43351,g32e5bea42b+1bb94961c2,g347aa1857d+3f2625acfc,g35bb328faa+a8ce1bb630,g3a166c0a6a+3f2625acfc,g3e281a1b8c+c5dd892a6c,g3e8969e208+a8ce1bb630,g414038480c+5927e1bc1e,g41af890bb2+8a9e676b2a,g7af13505b9+809c143d88,g80478fca09+6ef8b1810f,g82479be7b0+f568feb641,g858d7b2824+6aee506743,g89c8672015+f4add4ffd5,g9125e01d80+a8ce1bb630,ga5288a1d22+2903d499ea,gb58c049af0+d64f4d3760,gc28159a63d+3f2625acfc,gcab2d0539d+b12535109e,gcf0d15dbbd+46a3f46ba9,gda6a2b7d83+46a3f46ba9,gdaeeff99f8+1711a396fd,ge79ae78c31+3f2625acfc,gef2f8181fd+0a71e47438,gf0baf85859+c1f95f4921,gfa517265be+6aee506743,gfa999e8aa5+17cd334064,w.2024.51
LSST Data Management Base Package
|
Provides consistent interface for LSST exceptions. More...
#include <Exception.h>
Public Member Functions | |
Exception (char const *file, int line, char const *func, std::string const &message) | |
Standard constructor, intended for C++ use via the LSST_EXCEPT() macro. | |
Exception (std::string const &message) | |
Message-only constructor, intended for use from Python only. | |
virtual | ~Exception (void) noexcept |
void | addMessage (char const *file, int line, char const *func, std::string const &message) |
Add a tracepoint and a message to an exception before rethrowing it (access via LSST_EXCEPT_ADD). | |
Traceback const & | getTraceback (void) const noexcept |
Retrieve the list of tracepoints associated with an exception. | |
virtual std::ostream & | addToStream (std::ostream &stream) const |
Add a text representation of this exception, including its traceback with messages, to a stream. | |
virtual char const * | what (void) const noexcept |
Return a character string summarizing this exception. | |
virtual char const * | getType (void) const noexcept |
Return the fully-specified C++ type of a pointer to the exception. | |
virtual Exception * | clone (void) const |
Return a copy of the exception as an Exception pointer. | |
T | what (T... args) |
Provides consistent interface for LSST exceptions.
All exceptions defined by the LSST Stack are derived from this class. Code should not throw or catch Exception directly, but should instead be written in terms of the appropriate subclasses (e.g., catch RuntimeError to handle all unknown errors).
In Python, this exception inherits from builtins.Exception
.
Definition at line 107 of file Exception.h.
Exception::Exception | ( | char const * | file, |
int | line, | ||
char const * | func, | ||
std::string const & | message ) |
Standard constructor, intended for C++ use via the LSST_EXCEPT() macro.
[in] | file | Filename (automatically passed in by macro). |
[in] | line | Line number (automatically passed in by macro). |
[in] | func | Function name (automatically passed in by macro). |
[in] | message | Informational string attached to exception. |
Definition at line 42 of file Exception.cc.
|
explicit |
Message-only constructor, intended for use from Python only.
While this constructor can be called from C++, it's better to use the LSST_EXCEPT macro there, which stores file/line/function information as well. In Python, however, that information is stored outside the exception, so we don't want to duplicate it, and hence this constructor is invoked instead.
[in] | message | Informational string attached to exception. |
Definition at line 45 of file Exception.cc.
|
virtualnoexcept |
Definition at line 47 of file Exception.cc.
void Exception::addMessage | ( | char const * | file, |
int | line, | ||
char const * | func, | ||
std::string const & | message ) |
Add a tracepoint and a message to an exception before rethrowing it (access via LSST_EXCEPT_ADD).
[in] | file | Filename (automatically passed in by macro). |
[in] | line | Line number (automatically passed in by macro). |
[in] | func | Function name (automatically passed in by macro). |
[in] | message | Additional message to associate with this rethrow. |
Definition at line 49 of file Exception.cc.
|
virtual |
Add a text representation of this exception, including its traceback with messages, to a stream.
[in] | stream | Reference to an output stream. |
Definition at line 81 of file Exception.cc.
|
virtual |
Return a copy of the exception as an Exception pointer.
Can be overridden by derived classes that add data or methods.
Reimplemented in lsst::meas::base::MeasurementError.
Definition at line 103 of file Exception.cc.
|
noexcept |
Retrieve the list of tracepoints associated with an exception.
Definition at line 79 of file Exception.cc.
|
virtualnoexcept |
Return the fully-specified C++ type of a pointer to the exception.
This is overridden by derived classes (automatically if the LSST_EXCEPTION_TYPE macro is used). It is used by the Python interface.
Reimplemented in lsst::meas::base::MeasurementError.
Definition at line 101 of file Exception.cc.
|
virtualnoexcept |
Return a character string summarizing this exception.
This combines all the messages added to the exception, but not the type or traceback (use the stream operator to get this more detailed information).
Not allowed to throw any exceptions.
Definition at line 99 of file Exception.cc.