Merged trunk at revision 161680 into branch.
[official-gcc.git] / libstdc++-v3 / include / bits / regex_error.h
blob56bfae4cc660dcbaf0ee4acdac365d023bf5d7af
1 // class template regex -*- C++ -*-
3 // Copyright (C) 2010 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your option)
9 // any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // Under Section 7 of GPL version 3, you are granted additional
17 // permissions described in the GCC Runtime Library Exception, version
18 // 3.1, as published by the Free Software Foundation.
20 // You should have received a copy of the GNU General Public License and
21 // a copy of the GCC Runtime Library Exception along with this program;
22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23 // <http://www.gnu.org/licenses/>.
25 /**
26 * @file bits/regex_error
27 * @brief Error and exception objects for the std regex library.
29 * This is an internal header file, included by other library headers.
30 * You should not attempt to use it directly.
33 namespace std
36 namespace regex_constants
38 /**
39 * @name 5.3 Error Types
41 //@{
43 enum error_type
45 _S_error_collate,
46 _S_error_ctype,
47 _S_error_escape,
48 _S_error_backref,
49 _S_error_brack,
50 _S_error_paren,
51 _S_error_brace,
52 _S_error_badbrace,
53 _S_error_range,
54 _S_error_space,
55 _S_error_badrepeat,
56 _S_error_complexity,
57 _S_error_stack,
58 _S_error_last
61 /** The expression contained an invalid collating element name. */
62 static const error_type error_collate(_S_error_collate);
64 /** The expression contained an invalid character class name. */
65 static const error_type error_ctype(_S_error_ctype);
67 /**
68 * The expression contained an invalid escaped character, or a trailing
69 * escape.
71 static const error_type error_escape(_S_error_escape);
73 /** The expression contained an invalid back reference. */
74 static const error_type error_backref(_S_error_backref);
76 /** The expression contained mismatched [ and ]. */
77 static const error_type error_brack(_S_error_brack);
79 /** The expression contained mismatched ( and ). */
80 static const error_type error_paren(_S_error_paren);
82 /** The expression contained mismatched { and } */
83 static const error_type error_brace(_S_error_brace);
85 /** The expression contained an invalid range in a {} expression. */
86 static const error_type error_badbrace(_S_error_badbrace);
88 /**
89 * The expression contained an invalid character range,
90 * such as [b-a] in most encodings.
92 static const error_type error_range(_S_error_range);
94 /**
95 * There was insufficient memory to convert the expression into a
96 * finite state machine.
98 static const error_type error_space(_S_error_space);
101 * One of <em>*?+{<em> was not preceded by a valid regular expression.
103 static const error_type error_badrepeat(_S_error_badrepeat);
106 * The complexity of an attempted match against a regular expression
107 * exceeded a pre-set level.
109 static const error_type error_complexity(_S_error_complexity);
112 * There was insufficient memory to determine whether the
113 * regular expression could match the specified character sequence.
115 static const error_type error_stack(_S_error_stack);
117 //@}
120 // [7.8] Class regex_error
122 * @brief A regular expression exception class.
123 * @ingroup exceptions
125 * The regular expression library throws objects of this class on error.
127 class regex_error
128 : public std::runtime_error
130 public:
132 * @brief Constructs a regex_error object.
134 * @param ecode the regex error code.
136 explicit
137 regex_error(regex_constants::error_type __ecode)
138 : std::runtime_error("regex_error"), _M_code(__ecode)
142 * @brief Gets the regex error code.
144 * @returns the regex error code.
146 regex_constants::error_type
147 code() const
148 { return _M_code; }
150 protected:
151 regex_constants::error_type _M_code;
155 inline void
156 __throw_regex_error(regex_constants::error_type __ecode)
157 { throw regex_error(__ecode); }
159 } // namespace std