mirror of git://gcc.gnu.org/git/gcc.git
Makefile.am (sources): Add regex.cc.
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. From-SVN: r170038
This commit is contained in:
parent
b3a2810309
commit
cedf52d247
|
|
@ -1,3 +1,32 @@
|
||||||
|
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>
|
2011-02-10 Jonathan Wakely <jwakely.gcc@gmail.com>
|
||||||
|
|
||||||
PR libstdc++/47662
|
PR libstdc++/47662
|
||||||
|
|
|
||||||
|
|
@ -60,60 +60,60 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
};
|
};
|
||||||
|
|
||||||
/** The expression contained an invalid collating element name. */
|
/** 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. */
|
/** 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
|
* The expression contained an invalid escaped character, or a trailing
|
||||||
* escape.
|
* 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. */
|
/** 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 ]. */
|
/** 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 ). */
|
/** 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 } */
|
/** 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. */
|
/** 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,
|
* The expression contained an invalid character range,
|
||||||
* such as [b-a] in most encodings.
|
* 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
|
* There was insufficient memory to convert the expression into a
|
||||||
* finite state machine.
|
* 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.
|
* 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
|
* The complexity of an attempted match against a regular expression
|
||||||
* exceeded a pre-set level.
|
* 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
|
* There was insufficient memory to determine whether the
|
||||||
* regular expression could match the specified character sequence.
|
* 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
|
_GLIBCXX_END_NAMESPACE_VERSION
|
||||||
|
|
@ -128,9 +128,10 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
*
|
*
|
||||||
* The regular expression library throws objects of this class on error.
|
* The regular expression library throws objects of this class on error.
|
||||||
*/
|
*/
|
||||||
class regex_error
|
class regex_error : public std::runtime_error
|
||||||
: public std::runtime_error
|
|
||||||
{
|
{
|
||||||
|
regex_constants::error_type _M_code;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* @brief Constructs a regex_error object.
|
* @brief Constructs a regex_error object.
|
||||||
|
|
@ -138,9 +139,9 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
* @param ecode the regex error code.
|
* @param ecode the regex error code.
|
||||||
*/
|
*/
|
||||||
explicit
|
explicit
|
||||||
regex_error(regex_constants::error_type __ecode)
|
regex_error(regex_constants::error_type __ecode);
|
||||||
: std::runtime_error("regex_error"), _M_code(__ecode)
|
|
||||||
{ }
|
virtual ~regex_error() throw();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Gets the regex error code.
|
* @brief Gets the regex error code.
|
||||||
|
|
@ -150,9 +151,6 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
regex_constants::error_type
|
regex_constants::error_type
|
||||||
code() const
|
code() const
|
||||||
{ return _M_code; }
|
{ return _M_code; }
|
||||||
|
|
||||||
protected:
|
|
||||||
regex_constants::error_type _M_code;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -210,6 +210,7 @@ sources = \
|
||||||
misc-inst.cc \
|
misc-inst.cc \
|
||||||
ostream-inst.cc \
|
ostream-inst.cc \
|
||||||
placeholders.cc \
|
placeholders.cc \
|
||||||
|
regex.cc \
|
||||||
sstream-inst.cc \
|
sstream-inst.cc \
|
||||||
streambuf-inst.cc \
|
streambuf-inst.cc \
|
||||||
streambuf.cc \
|
streambuf.cc \
|
||||||
|
|
@ -352,6 +353,11 @@ future.lo: future.cc
|
||||||
future.o: future.cc
|
future.o: future.cc
|
||||||
$(CXXCOMPILE) -std=gnu++0x -c $<
|
$(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
|
debug.lo: debug.cc
|
||||||
$(LTCXXCOMPILE) -std=gnu++0x -c $<
|
$(LTCXXCOMPILE) -std=gnu++0x -c $<
|
||||||
debug.o: debug.cc
|
debug.o: debug.cc
|
||||||
|
|
|
||||||
|
|
@ -110,11 +110,11 @@ am__objects_5 = atomic.lo bitmap_allocator.lo pool_allocator.lo \
|
||||||
strstream.lo system_error.lo tree.lo allocator-inst.lo \
|
strstream.lo system_error.lo tree.lo allocator-inst.lo \
|
||||||
concept-inst.lo fstream-inst.lo ext-inst.lo ios-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 \
|
iostream-inst.lo istream-inst.lo istream.lo locale-inst.lo \
|
||||||
misc-inst.lo ostream-inst.lo placeholders.lo sstream-inst.lo \
|
misc-inst.lo ostream-inst.lo placeholders.lo regex.lo \
|
||||||
streambuf-inst.lo streambuf.lo string-inst.lo valarray-inst.lo \
|
sstream-inst.lo streambuf-inst.lo streambuf.lo string-inst.lo \
|
||||||
wlocale-inst.lo wstring-inst.lo mutex.lo condition_variable.lo \
|
valarray-inst.lo wlocale-inst.lo wstring-inst.lo mutex.lo \
|
||||||
chrono.lo thread.lo future.lo $(am__objects_1) \
|
condition_variable.lo chrono.lo thread.lo future.lo \
|
||||||
$(am__objects_4)
|
$(am__objects_1) $(am__objects_4)
|
||||||
am_libstdc___la_OBJECTS = $(am__objects_5)
|
am_libstdc___la_OBJECTS = $(am__objects_5)
|
||||||
libstdc___la_OBJECTS = $(am_libstdc___la_OBJECTS)
|
libstdc___la_OBJECTS = $(am_libstdc___la_OBJECTS)
|
||||||
DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
|
DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)
|
||||||
|
|
@ -427,6 +427,7 @@ sources = \
|
||||||
misc-inst.cc \
|
misc-inst.cc \
|
||||||
ostream-inst.cc \
|
ostream-inst.cc \
|
||||||
placeholders.cc \
|
placeholders.cc \
|
||||||
|
regex.cc \
|
||||||
sstream-inst.cc \
|
sstream-inst.cc \
|
||||||
streambuf-inst.cc \
|
streambuf-inst.cc \
|
||||||
streambuf.cc \
|
streambuf.cc \
|
||||||
|
|
@ -941,6 +942,11 @@ future.lo: future.cc
|
||||||
future.o: future.cc
|
future.o: future.cc
|
||||||
$(CXXCOMPILE) -std=gnu++0x -c $<
|
$(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
|
debug.lo: debug.cc
|
||||||
$(LTCXXCOMPILE) -std=gnu++0x -c $<
|
$(LTCXXCOMPILE) -std=gnu++0x -c $<
|
||||||
debug.o: debug.cc
|
debug.o: debug.cc
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,38 @@
|
||||||
|
// 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
|
||||||
Loading…
Reference in New Issue