|
dune-common 2.12-git
|

Files | |
| file | exceptions.hh |
| A few common exception classes. | |
Classes | |
| class | Dune::Exception |
| Base class for Dune-Exceptions. More... | |
| struct | Dune::ExceptionHook |
| Base class to add a hook to the Dune::Exception. More... | |
| class | Dune::ExceptionStream< E > |
| Class for extending a Dune::Exception with a stream interface. More... | |
| class | Dune::IOError |
| Default exception class for I/O errors. More... | |
| class | Dune::MathError |
| Default exception class for mathematical errors. More... | |
| class | Dune::RangeError |
| Default exception class for range errors. More... | |
| class | Dune::NotImplemented |
| Default exception for dummy implementations. More... | |
| class | Dune::SystemError |
| Default exception class for OS errors. More... | |
| class | Dune::OutOfMemoryError |
| Default exception if memory allocation fails. More... | |
| class | Dune::InvalidStateException |
| Default exception if a function was called while the object is not in a valid state for that function. More... | |
| class | Dune::ParallelError |
| Default exception if an error in the parallel communication of the program occurred. More... | |
Macros | |
| #define | DUNE_THROW(E, ...) throw Dune::ExceptionStream(E()) << THROWSPEC(E) __VA_OPT__(<<) __VA_ARGS__ |
Functions | |
| Dune::Exception::Exception () | |
| void | Dune::Exception::message (const std::string &msg) |
| store string in internal message buffer | |
| const char * | Dune::Exception::what () const noexcept override |
| output internal message buffer | |
| static void | Dune::Exception::registerHook (ExceptionHook *hook) |
| add a functor which is called before a Dune::Exception is emitted (see Dune::ExceptionHook) | |
| static void | Dune::Exception::clearHook () |
| remove all hooks | |
| virtual | Dune::ExceptionHook::~ExceptionHook () |
| virtual void | Dune::ExceptionHook::operator() ()=0 |
| std::ostream & | Dune::operator<< (std::ostream &stream, const Exception &e) |
| Dune::ExceptionStream< E >::ExceptionStream (const E &other) | |
| Dune::ExceptionStream< E >::ExceptionStream (E &&other) | |
Detailed Description
The Dune-exceptions are designed to allow a simple derivation of subclasses and to accept a text written in the '<<' syntax.
Example of usage:
- See also
- exceptions.hh for detailed info
Macro Definition Documentation
◆ DUNE_THROW
| #define DUNE_THROW | ( | E, | |
| ... | |||
| ) | throw Dune::ExceptionStream(E()) << THROWSPEC(E) __VA_OPT__(<<) __VA_ARGS__ |
Macro to throw an exception
- Parameters
-
E exception class derived from Dune::Exception m reason for this exception in ostream-notation
Example:
DUNE_THROW automatically adds information about the exception thrown to the text.
- Note
- you can add a hook to be called before a Dune::Exception is emitted, e.g. to add additional information to the exception, or to invoke a debugger during parallel debugging. (see Dune::ExceptionHook)
Function Documentation
◆ clearHook()
|
static |
remove all hooks
◆ Exception()
| Dune::Exception::Exception | ( | ) |
◆ ExceptionStream() [1/2]
|
inline |
◆ ExceptionStream() [2/2]
|
inline |
◆ message()
| void Dune::Exception::message | ( | const std::string & | msg | ) |
store string in internal message buffer
◆ operator()()
|
pure virtual |
◆ operator<<()
|
inline |
◆ registerHook()
|
static |
add a functor which is called before a Dune::Exception is emitted (see Dune::ExceptionHook)
- See also
- Dune::ExceptionHook
◆ what()
|
overridenoexcept |
output internal message buffer
◆ ~ExceptionHook()
|
inlinevirtual |
Friends
◆ operator<< [1/6]
requires (requires(std::ostringstream& oss, T t) { oss << t; } and not std::is_integral_v<T>)
|
friend |
Stream operator for r-value ExceptionStream and lvalue-reference.
◆ operator<< [2/6]
|
friend |
Stream operator for r-value ExceptionStream and io manipulator.
◆ operator<< [3/6]
requires std::is_integral_v<T>
|
friend |
Stream operator for r-value ExceptionStream and integral values.
◆ operator<< [4/6]
requires (requires(std::ostringstream& oss, T t) { oss << t; } and not std::is_integral_v<T>)
|
friend |
Stream operator for l-value ExceptionStream and lvalue-reference.
◆ operator<< [5/6]
|
friend |
Stream operator for l-value ExceptionStream and io manipulator.
◆ operator<< [6/6]
requires std::is_integral_v<T>
|
friend |
Stream operator for l-value ExceptionStream and integral values.
This is needed to support passing a static const members. The other overload leads to ODR use which requires that there is a namespace scope definition of the variable (which does often not exist).
Legal Statements / Impressum | Hosted by TU Dresden & Uni Heidelberg | Generated by
1.9.8