+2011-02-10 Benjamin Kosnik <bkoz@redhat.com>
+
+ * src/Makefile.am (sources): Add regex.cc.
+ * src/Makefile.in: Regenerate.
+ * src/regex.cc: New.
+ * include/bits/regex_error.h (error_type): Use constexpr.
+ (regex_error): Move ctor and dtor out of line.
+
+ * testsuite/28_regex/03_requirements: To...
+ * testsuite/28_regex/requirements: ... this.
+ * testsuite/28_regex/04_header: To...
+ * testsuite/28_regex/headers: ... this.
+ * testsuite/28_regex/05_constants: To...
+ * testsuite/28_regex/constants: ... this.
+ * testsuite/28_regex/06_exception_type: To...
+ * testsuite/28_regex/regex_error: ... this.
+ * testsuite/28_regex/07_traits: To...
+ * testsuite/28_regex/traits: ... this.
+ * testsuite/28_regex/08_basic_regex: To...
+ * testsuite/28_regex/basic_regex: ... this.
+ * testsuite/28_regex/09_sub_match: To...
+ * testsuite/28_regex/sub_match: ... this.
+ * testsuite/28_regex/10_match_results: To...
+ * testsuite/28_regex/match_results: ... this.
+ * testsuite/28_regex/11_algorithms: To...
+ * testsuite/28_regex/algorithms: ... this.
+ * testsuite/28_regex/12_iterators: To...
+ * testsuite/28_regex/iterators: ... this.
+
2011-02-10 Jonathan Wakely <jwakely.gcc@gmail.com>
PR libstdc++/47662
};
/** The expression contained an invalid collating element name. */
- static const error_type error_collate(_S_error_collate);
+ static constexpr error_type error_collate(_S_error_collate);
/** The expression contained an invalid character class name. */
- static const error_type error_ctype(_S_error_ctype);
+ static constexpr error_type error_ctype(_S_error_ctype);
/**
* The expression contained an invalid escaped character, or a trailing
* escape.
*/
- static const error_type error_escape(_S_error_escape);
+ static constexpr error_type error_escape(_S_error_escape);
/** The expression contained an invalid back reference. */
- static const error_type error_backref(_S_error_backref);
+ static constexpr error_type error_backref(_S_error_backref);
/** The expression contained mismatched [ and ]. */
- static const error_type error_brack(_S_error_brack);
+ static constexpr error_type error_brack(_S_error_brack);
/** The expression contained mismatched ( and ). */
- static const error_type error_paren(_S_error_paren);
+ static constexpr error_type error_paren(_S_error_paren);
/** The expression contained mismatched { and } */
- static const error_type error_brace(_S_error_brace);
+ static constexpr error_type error_brace(_S_error_brace);
/** The expression contained an invalid range in a {} expression. */
- static const error_type error_badbrace(_S_error_badbrace);
+ static constexpr error_type error_badbrace(_S_error_badbrace);
/**
* The expression contained an invalid character range,
* such as [b-a] in most encodings.
*/
- static const error_type error_range(_S_error_range);
+ static constexpr error_type error_range(_S_error_range);
/**
* There was insufficient memory to convert the expression into a
* finite state machine.
*/
- static const error_type error_space(_S_error_space);
+ static constexpr error_type error_space(_S_error_space);
/**
* One of <em>*?+{<em> was not preceded by a valid regular expression.
*/
- static const error_type error_badrepeat(_S_error_badrepeat);
+ static constexpr error_type error_badrepeat(_S_error_badrepeat);
/**
* The complexity of an attempted match against a regular expression
* exceeded a pre-set level.
*/
- static const error_type error_complexity(_S_error_complexity);
+ static constexpr error_type error_complexity(_S_error_complexity);
/**
* There was insufficient memory to determine whether the
* regular expression could match the specified character sequence.
*/
- static const error_type error_stack(_S_error_stack);
+ static constexpr error_type error_stack(_S_error_stack);
//@}
_GLIBCXX_END_NAMESPACE_VERSION
*
* The regular expression library throws objects of this class on error.
*/
- class regex_error
- : public std::runtime_error
+ class regex_error : public std::runtime_error
{
+ regex_constants::error_type _M_code;
+
public:
/**
* @brief Constructs a regex_error object.
* @param ecode the regex error code.
*/
explicit
- regex_error(regex_constants::error_type __ecode)
- : std::runtime_error("regex_error"), _M_code(__ecode)
- { }
+ regex_error(regex_constants::error_type __ecode);
+
+ virtual ~regex_error() throw();
/**
* @brief Gets the regex error code.
regex_constants::error_type
code() const
{ return _M_code; }
-
- protected:
- regex_constants::error_type _M_code;
};
misc-inst.cc \
ostream-inst.cc \
placeholders.cc \
+ regex.cc \
sstream-inst.cc \
streambuf-inst.cc \
streambuf.cc \
future.o: future.cc
$(CXXCOMPILE) -std=gnu++0x -c $<
+regex.lo: regex.cc
+ $(LTCXXCOMPILE) -std=gnu++0x -c $<
+regex.o: regex.cc
+ $(CXXCOMPILE) -std=gnu++0x -c $<
+
debug.lo: debug.cc
$(LTCXXCOMPILE) -std=gnu++0x -c $<
debug.o: debug.cc
strstream.lo system_error.lo tree.lo allocator-inst.lo \
concept-inst.lo fstream-inst.lo ext-inst.lo ios-inst.lo \
iostream-inst.lo istream-inst.lo istream.lo locale-inst.lo \
- misc-inst.lo ostream-inst.lo placeholders.lo sstream-inst.lo \
- streambuf-inst.lo streambuf.lo string-inst.lo valarray-inst.lo \
- wlocale-inst.lo wstring-inst.lo mutex.lo condition_variable.lo \
- chrono.lo thread.lo future.lo $(am__objects_1) \
- $(am__objects_4)
+ misc-inst.lo ostream-inst.lo placeholders.lo regex.lo \
+ sstream-inst.lo streambuf-inst.lo streambuf.lo string-inst.lo \
+ valarray-inst.lo wlocale-inst.lo wstring-inst.lo mutex.lo \
+ condition_variable.lo chrono.lo thread.lo future.lo \
+ $(am__objects_1) $(am__objects_4)
am_libstdc___la_OBJECTS = $(am__objects_5)
libstdc___la_OBJECTS = $(am_libstdc___la_OBJECTS)
DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
misc-inst.cc \
ostream-inst.cc \
placeholders.cc \
+ regex.cc \
sstream-inst.cc \
streambuf-inst.cc \
streambuf.cc \
future.o: future.cc
$(CXXCOMPILE) -std=gnu++0x -c $<
+regex.lo: regex.cc
+ $(LTCXXCOMPILE) -std=gnu++0x -c $<
+regex.o: regex.cc
+ $(CXXCOMPILE) -std=gnu++0x -c $<
+
debug.lo: debug.cc
$(LTCXXCOMPILE) -std=gnu++0x -c $<
debug.o: debug.cc
--- /dev/null
+// regex -*- C++ -*-
+
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+#include <regex>
+
+namespace std _GLIBCXX_VISIBILITY(default)
+{
+_GLIBCXX_BEGIN_NAMESPACE_VERSION
+
+ regex_error::regex_error(regex_constants::error_type __ecode)
+ : std::runtime_error("regex_error"), _M_code(__ecode)
+ { }
+
+ regex_error::~regex_error() throw() { }
+
+_GLIBCXX_END_NAMESPACE_VERSION
+} // namespace std