libstdc++
Exceptions
Collaboration diagram for Exceptions:

Classes

class  __cxxabiv1::__forced_unwind
 
struct  __gnu_cxx::forced_error
 
class  __gnu_cxx::recursive_init_error
 
class  std::__exception_ptr::exception_ptr
 
class  std::bad_alloc
 
class  std::bad_cast
 
class  std::bad_exception
 
class  std::bad_function_call
 
class  std::bad_typeid
 
class  std::bad_weak_ptr
 
class  std::domain_error
 
class  std::exception
 
class  std::experimental::fundamentals_v1::bad_any_cast
 
class  std::experimental::fundamentals_v1::bad_optional_access
 
class  std::future_error
 
class  std::invalid_argument
 
class  std::ios_base::failure
 
class  std::length_error
 
class  std::logic_error
 
class  std::nested_exception
 
class  std::out_of_range
 
class  std::overflow_error
 
class  std::range_error
 
class  std::regex_error
 
class  std::runtime_error
 
class  std::system_error
 
class  std::underflow_error
 

Macros

#define __cpp_lib_uncaught_exceptions
 

Typedefs

template<typename _Tp >
using std::__rethrow_if_nested_cond = typename enable_if< __and_< is_polymorphic< _Tp >, __or_< __not_< is_base_of< nested_exception, _Tp >>, is_convertible< _Tp *, nested_exception * >>>::value >::type
 
typedef void(* std::terminate_handler) ()
 
typedef void(* std::unexpected_handler) ()
 

Functions

template<typename _Ex >
__rethrow_if_nested_cond< _Ex > std::__rethrow_if_nested_impl (const _Ex *__ptr)
 
void std::__rethrow_if_nested_impl (const void *)
 
template<typename _Tp >
void std::__throw_with_nested_impl (_Tp &&__t, true_type)
 
template<typename _Tp >
void std::__throw_with_nested_impl (_Tp &&__t, false_type)
 
void __gnu_cxx::__verbose_terminate_handler ()
 
template<typename _Ex >
exception_ptr std::copy_exception (_Ex __ex) noexcept 1
 
exception_ptr std::current_exception () noexcept
 
terminate_handler std::get_terminate () noexcept
 
unexpected_handler std::get_unexpected () noexcept
 
template<typename _Ex >
exception_ptr std::make_exception_ptr (_Ex __ex) noexcept
 
void std::rethrow_exception (exception_ptr) __attribute__((__noreturn__))
 
template<typename _Ex >
void std::rethrow_if_nested (const _Ex &__ex)
 
terminate_handler std::set_terminate (terminate_handler) noexcept
 
unexpected_handler std::set_unexpected (unexpected_handler) noexcept
 
void std::terminate () noexcept __attribute__((__noreturn__))
 
template<typename _Tp >
void std::throw_with_nested (_Tp &&__t)
 
bool std::uncaught_exception () noexcept __attribute__((__pure__))
 
int std::uncaught_exceptions () noexcept __attribute__((__pure__))
 
void std::unexpected () __attribute__((__noreturn__))
 

Detailed Description

Classes and functions for reporting errors via exception classes.

Typedef Documentation

typedef void(* std::terminate_handler) ()

If you write a replacement terminate handler, it must be of this type.

Definition at line 89 of file exception.

typedef void(* std::unexpected_handler) ()

If you write a replacement unexpected handler, it must be of this type.

Definition at line 92 of file exception.

Function Documentation

void __gnu_cxx::__verbose_terminate_handler ( )

A replacement for the standard terminate_handler which prints more information about the terminating exception (if any) on stderr.

Call

to use. For more info, see http://gcc.gnu.org/onlinedocs/libstdc++/manual/bk01pt02ch06s02.html

In 3.4 and later, this is on by default.

template<typename _Ex >
exception_ptr std::copy_exception ( _Ex  __ex)
noexcept

Obtain an exception_ptr pointing to a copy of the supplied object. This function is deprecated, use std::make_exception_ptr instead.

Definition at line 197 of file exception_ptr.h.

Referenced by std::make_exception_ptr().

exception_ptr std::current_exception ( )
noexcept

Obtain an exception_ptr to the currently handled exception. If there is none, or the currently handled exception is foreign, return the null value.

Referenced by std::make_exception_ptr().

terminate_handler std::get_terminate ( )
noexcept

Return the current terminate handler.

unexpected_handler std::get_unexpected ( )
noexcept

Return the current unexpected handler.

template<typename _Ex >
exception_ptr std::make_exception_ptr ( _Ex  __ex)
noexcept

Obtain an exception_ptr pointing to a copy of the supplied object.

Definition at line 171 of file exception_ptr.h.

References std::copy_exception(), and std::current_exception().

void std::rethrow_exception ( exception_ptr  )

Throw the object pointed to by the exception_ptr.

template<typename _Ex >
void std::rethrow_if_nested ( const _Ex &  __ex)
inline

If __ex is derived from nested_exception, __ex.rethrow_nested().

Definition at line 153 of file nested_exception.h.

References std::__addressof().

terminate_handler std::set_terminate ( terminate_handler  )
noexcept

Takes a new handler function as an argument, returns the old function.

unexpected_handler std::set_unexpected ( unexpected_handler  )
noexcept

Takes a new handler function as an argument, returns the old function.

void std::terminate ( )
noexcept

The runtime will call this function if exception handling must be abandoned for any reason. It can also be called by the user.

template<typename _Tp >
void std::throw_with_nested ( _Tp &&  __t)
inline

If __t is derived from nested_exception, throws __t. Else, throws an implementation-defined object derived from both.

Definition at line 116 of file nested_exception.h.

bool std::uncaught_exception ( )
noexcept

[18.6.4]/1: 'Returns true after completing evaluation of a throw-expression until either completing initialization of the exception-declaration in the matching handler or entering unexpected() due to the throw; or after entering terminate() for any reason other than an explicit call to terminate(). [Note: This includes stack unwinding [15.2]. end note]'

2: 'When uncaught_exception() is true, throwing an exception can result in a call of terminate() (15.5.1).'

int std::uncaught_exceptions ( )
noexcept

The number of uncaught exceptions.

void std::unexpected ( )

The runtime will call this function if an exception is thrown which violates the function's exception specification.