100db7afdSDavid E. O'Brien // Standard exception classes -*- C++ -*-
200db7afdSDavid E. O'Brien
3*f8a1b7d9SAlexander Kabaev // Copyright (C) 2001, 2002, 2005 Free Software Foundation, Inc.
400db7afdSDavid E. O'Brien //
500db7afdSDavid E. O'Brien // This file is part of the GNU ISO C++ Library. This library is free
600db7afdSDavid E. O'Brien // software; you can redistribute it and/or modify it under the
700db7afdSDavid E. O'Brien // terms of the GNU General Public License as published by the
800db7afdSDavid E. O'Brien // Free Software Foundation; either version 2, or (at your option)
900db7afdSDavid E. O'Brien // any later version.
1000db7afdSDavid E. O'Brien
1100db7afdSDavid E. O'Brien // This library is distributed in the hope that it will be useful,
1200db7afdSDavid E. O'Brien // but WITHOUT ANY WARRANTY; without even the implied warranty of
1300db7afdSDavid E. O'Brien // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1400db7afdSDavid E. O'Brien // GNU General Public License for more details.
1500db7afdSDavid E. O'Brien
1600db7afdSDavid E. O'Brien // You should have received a copy of the GNU General Public License along
1700db7afdSDavid E. O'Brien // with this library; see the file COPYING. If not, write to the Free
18*f8a1b7d9SAlexander Kabaev // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
1900db7afdSDavid E. O'Brien // USA.
2000db7afdSDavid E. O'Brien
2100db7afdSDavid E. O'Brien // As a special exception, you may use this file as part of a free software
2200db7afdSDavid E. O'Brien // library without restriction. Specifically, if other files instantiate
2300db7afdSDavid E. O'Brien // templates or use macros or inline functions from this file, or you compile
2400db7afdSDavid E. O'Brien // this file and link it with other files to produce an executable, this
2500db7afdSDavid E. O'Brien // file does not by itself cause the resulting executable to be covered by
2600db7afdSDavid E. O'Brien // the GNU General Public License. This exception does not however
2700db7afdSDavid E. O'Brien // invalidate any other reasons why the executable file might be covered by
2800db7afdSDavid E. O'Brien // the GNU General Public License.
2900db7afdSDavid E. O'Brien
30*f8a1b7d9SAlexander Kabaev /** @file stdexcept
31*f8a1b7d9SAlexander Kabaev * This is a Standard C++ Library header.
32*f8a1b7d9SAlexander Kabaev */
33*f8a1b7d9SAlexander Kabaev
3400db7afdSDavid E. O'Brien //
3500db7afdSDavid E. O'Brien // ISO C++ 19.1 Exception classes
3600db7afdSDavid E. O'Brien //
3700db7afdSDavid E. O'Brien
38ffeaf689SAlexander Kabaev #ifndef _GLIBCXX_STDEXCEPT
39ffeaf689SAlexander Kabaev #define _GLIBCXX_STDEXCEPT 1
4000db7afdSDavid E. O'Brien
4100db7afdSDavid E. O'Brien #pragma GCC system_header
4200db7afdSDavid E. O'Brien
4300db7afdSDavid E. O'Brien #include <exception>
4400db7afdSDavid E. O'Brien #include <string>
4500db7afdSDavid E. O'Brien
_GLIBCXX_BEGIN_NAMESPACE(std)46*f8a1b7d9SAlexander Kabaev _GLIBCXX_BEGIN_NAMESPACE(std)
47*f8a1b7d9SAlexander Kabaev
4800db7afdSDavid E. O'Brien /** Logic errors represent problems in the internal logic of a program;
4900db7afdSDavid E. O'Brien * in theory, these are preventable, and even detectable before the
5000db7afdSDavid E. O'Brien * program runs (e.g., violations of class invariants).
5100db7afdSDavid E. O'Brien * @brief One of two subclasses of exception.
5200db7afdSDavid E. O'Brien */
5300db7afdSDavid E. O'Brien class logic_error : public exception
5400db7afdSDavid E. O'Brien {
5500db7afdSDavid E. O'Brien string _M_msg;
5600db7afdSDavid E. O'Brien
5700db7afdSDavid E. O'Brien public:
5800db7afdSDavid E. O'Brien /** Takes a character string describing the error. */
5900db7afdSDavid E. O'Brien explicit
6000db7afdSDavid E. O'Brien logic_error(const string& __arg);
6100db7afdSDavid E. O'Brien
6200db7afdSDavid E. O'Brien virtual
6300db7afdSDavid E. O'Brien ~logic_error() throw();
6400db7afdSDavid E. O'Brien
6500db7afdSDavid E. O'Brien /** Returns a C-style character string describing the general cause of
6600db7afdSDavid E. O'Brien * the current error (the same string passed to the ctor). */
6700db7afdSDavid E. O'Brien virtual const char*
6800db7afdSDavid E. O'Brien what() const throw();
6900db7afdSDavid E. O'Brien };
7000db7afdSDavid E. O'Brien
7100db7afdSDavid E. O'Brien /** Thrown by the library, or by you, to report domain errors (domain in
7200db7afdSDavid E. O'Brien * the mathmatical sense). */
7300db7afdSDavid E. O'Brien class domain_error : public logic_error
7400db7afdSDavid E. O'Brien {
7500db7afdSDavid E. O'Brien public:
7600db7afdSDavid E. O'Brien explicit domain_error(const string& __arg);
7700db7afdSDavid E. O'Brien };
7800db7afdSDavid E. O'Brien
7900db7afdSDavid E. O'Brien /** Thrown to report invalid arguments to functions. */
8000db7afdSDavid E. O'Brien class invalid_argument : public logic_error
8100db7afdSDavid E. O'Brien {
8200db7afdSDavid E. O'Brien public:
8300db7afdSDavid E. O'Brien explicit invalid_argument(const string& __arg);
8400db7afdSDavid E. O'Brien };
8500db7afdSDavid E. O'Brien
8600db7afdSDavid E. O'Brien /** Thrown when an object is constructed that would exceed its maximum
8700db7afdSDavid E. O'Brien * permitted size (e.g., a basic_string instance). */
8800db7afdSDavid E. O'Brien class length_error : public logic_error
8900db7afdSDavid E. O'Brien {
9000db7afdSDavid E. O'Brien public:
9100db7afdSDavid E. O'Brien explicit length_error(const string& __arg);
9200db7afdSDavid E. O'Brien };
9300db7afdSDavid E. O'Brien
9400db7afdSDavid E. O'Brien /** This represents an argument whose value is not within the expected
9500db7afdSDavid E. O'Brien * range (e.g., boundary checks in basic_string). */
9600db7afdSDavid E. O'Brien class out_of_range : public logic_error
9700db7afdSDavid E. O'Brien {
9800db7afdSDavid E. O'Brien public:
9900db7afdSDavid E. O'Brien explicit out_of_range(const string& __arg);
10000db7afdSDavid E. O'Brien };
10100db7afdSDavid E. O'Brien
10200db7afdSDavid E. O'Brien /** Runtime errors represent problems outside the scope of a program;
10300db7afdSDavid E. O'Brien * they cannot be easily predicted and can generally only be caught as
10400db7afdSDavid E. O'Brien * the program executes.
10500db7afdSDavid E. O'Brien * @brief One of two subclasses of exception.
10600db7afdSDavid E. O'Brien */
10700db7afdSDavid E. O'Brien class runtime_error : public exception
10800db7afdSDavid E. O'Brien {
10900db7afdSDavid E. O'Brien string _M_msg;
11000db7afdSDavid E. O'Brien
11100db7afdSDavid E. O'Brien public:
11200db7afdSDavid E. O'Brien /** Takes a character string describing the error. */
11300db7afdSDavid E. O'Brien explicit
11400db7afdSDavid E. O'Brien runtime_error(const string& __arg);
11500db7afdSDavid E. O'Brien
11600db7afdSDavid E. O'Brien virtual
11700db7afdSDavid E. O'Brien ~runtime_error() throw();
11800db7afdSDavid E. O'Brien
11900db7afdSDavid E. O'Brien /** Returns a C-style character string describing the general cause of
12000db7afdSDavid E. O'Brien * the current error (the same string passed to the ctor). */
12100db7afdSDavid E. O'Brien virtual const char*
12200db7afdSDavid E. O'Brien what() const throw();
12300db7afdSDavid E. O'Brien };
12400db7afdSDavid E. O'Brien
12500db7afdSDavid E. O'Brien /** Thrown to indicate range errors in internal computations. */
12600db7afdSDavid E. O'Brien class range_error : public runtime_error
12700db7afdSDavid E. O'Brien {
12800db7afdSDavid E. O'Brien public:
12900db7afdSDavid E. O'Brien explicit range_error(const string& __arg);
13000db7afdSDavid E. O'Brien };
13100db7afdSDavid E. O'Brien
13200db7afdSDavid E. O'Brien /** Thrown to indicate arithmetic overflow. */
13300db7afdSDavid E. O'Brien class overflow_error : public runtime_error
13400db7afdSDavid E. O'Brien {
13500db7afdSDavid E. O'Brien public:
13600db7afdSDavid E. O'Brien explicit overflow_error(const string& __arg);
13700db7afdSDavid E. O'Brien };
13800db7afdSDavid E. O'Brien
13900db7afdSDavid E. O'Brien /** Thrown to indicate arithmetic underflow. */
14000db7afdSDavid E. O'Brien class underflow_error : public runtime_error
14100db7afdSDavid E. O'Brien {
14200db7afdSDavid E. O'Brien public:
14300db7afdSDavid E. O'Brien explicit underflow_error(const string& __arg);
14400db7afdSDavid E. O'Brien };
145*f8a1b7d9SAlexander Kabaev
146*f8a1b7d9SAlexander Kabaev _GLIBCXX_END_NAMESPACE
14700db7afdSDavid E. O'Brien
148ffeaf689SAlexander Kabaev #endif /* _GLIBCXX_STDEXCEPT */
149