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