gcc/
[official-gcc.git] / libstdc++-v3 / libsupc++ / exception.h
blob3f1111d3e4b3e4b5270194966b33c79cb43fa96f
1 // Exception Handling support header for -*- C++ -*-
3 // Copyright (C) 2016-2018 Free Software Foundation, Inc.
4 //
5 // This file is part of GCC.
6 //
7 // GCC is free software; you can redistribute it and/or modify
8 // it under the terms of the GNU General Public License as published by
9 // the Free Software Foundation; either version 3, or (at your option)
10 // any later version.
12 // GCC is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
17 // Under Section 7 of GPL version 3, you are granted additional
18 // permissions described in the GCC Runtime Library Exception, version
19 // 3.1, as published by the Free Software Foundation.
21 // You should have received a copy of the GNU General Public License and
22 // a copy of the GCC Runtime Library Exception along with this program;
23 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
24 // <http://www.gnu.org/licenses/>.
26 /** @file bits/exception.h
27 * This is an internal header file, included by other library headers.
28 * Do not attempt to use it directly.
31 #ifndef __EXCEPTION_H
32 #define __EXCEPTION_H 1
34 #pragma GCC system_header
36 #pragma GCC visibility push(default)
38 #include <bits/c++config.h>
40 extern "C++" {
42 namespace std
44 /**
45 * @defgroup exceptions Exceptions
46 * @ingroup diagnostics
48 * Classes and functions for reporting errors via exception classes.
49 * @{
52 /**
53 * @brief Base class for all library exceptions.
55 * This is the base class for all exceptions thrown by the standard
56 * library, and by certain language expressions. You are free to derive
57 * your own %exception classes, or use a different hierarchy, or to
58 * throw non-class data (e.g., fundamental types).
60 class exception
62 public:
63 exception() _GLIBCXX_USE_NOEXCEPT { }
64 virtual ~exception() _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_USE_NOEXCEPT;
66 /** Returns a C-style character string describing the general cause
67 * of the current error. */
68 virtual const char*
69 what() const _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_USE_NOEXCEPT;
72 } // namespace std
76 #pragma GCC visibility pop
78 #endif