53dc5044ed
2010-11-02 Paolo Carlini <paolo.carlini@oracle.com> * include/tr1_impl/cinttypes: Remove, move contents to C++0x and TR1 headers. * include/tr1_impl/cstdlib: Likewise. * include/tr1_impl/cstdio: Likewise. * include/tr1_impl/cctype: Likewise. * include/tr1_impl/boost_sp_counted_base.h: Likewise. * include/tr1_impl/cmath: Likewise. * include/tr1_impl/cfenv: Likewise. * include/tr1_impl/utility: Likewise. * include/tr1_impl/complex: Likewise. * include/tr1_impl/cwchar: Likewise. * include/tr1_impl/type_traits: Likewise. * include/tr1_impl/cstdint: Likewise. * include/tr1_impl/regex: Likewise. * include/tr1_impl/array: Likewise. * include/tr1_impl/cwctype: Likewise. * include/Makefile.am: Adjust. * include/Makefile.in: Regenerate. * src/condition_variable.cc: Adjust; consistently use _GLIBCXX_BEGIN_NAMESPACE and _GLIBCXX_END_NAMESPACE. * src/mutex.cc: Likewise. * src/future.cc: Likewise. * src/atomic.cc: Likewise. * src/chrono.cc: Likewise. * src/thread.cc: Likewise. * include/std/tuple: Likewise. * include/std/utility: Likewise. * include/std/thread: Likewise.: Likewise. * include/std/type_traits: Likewise. * include/std/memory: Likewise. * include/std/future: Likewise. * include/std/ratio: Likewise. * include/std/chrono: Likewise. * include/std/condition_variable: Likewise. * include/std/mutex: Likewise. * include/std/functional: Likewise. * include/std/complex: Likewise. * include/std/typeindex: Likewise. * include/std/array: Likewise. * include/bits/regex_compiler.h: Likewise. * include/bits/regex_grep_matcher.tcc: Likewise. * include/bits/regex_grep_matcher.h: Likewise. * include/bits/regex_constants.h: Likewise. * include/bits/regex_cursor.h: Likewise. * include/bits/regex_nfa.tcc: Likewise. * include/bits/shared_ptr_base.h: Likewise. * include/bits/regex_nfa.h: Likewise. * include/bits/random.tcc: Likewise. * include/bits/regex.h: Likewise. * include/bits/random.h: Likewise. * include/bits/regex_error.h: Likewise. * include/c_global/cinttypes: Likewise. * include/c_global/cstdlib: Likewise. * include/c_global/cstdio: Likewise. * include/c_global/cctype: Likewise. * include/c_global/cmath: Likewise. * include/c_global/cfenv: Likewise. * include/c_global/cwchar: Likewise. * include/c_global/cstdint: Likewise. * include/c_global/cwctype: Likewise. * include/tr1/shared_ptr.h: Likewise. * include/tr1/cinttypes: Likewise. * include/tr1/cstdio: Likewise. * include/tr1/cfenv: Likewise. * include/tr1/utility: Likewise. * include/tr1/cwchar: Likewise. * include/tr1/type_traits: Likewise. * include/tr1/memory: Likewise. * include/tr1/cstdint: Likewise. * include/tr1/regex: Likewise. * include/tr1/cwctype: Likewise. * include/tr1/cstdlib: Likewise. * include/tr1/cctype: Likewise. * include/tr1/cmath: Likewise. * include/tr1/complex: Likewise. * include/tr1/array: Likewise. * include/c_compatibility/fenv.h: Likewise. * include/c_compatibility/stdint.h: Likewise. * include/c_compatibility/inttypes.h: Likewise. * testsuite/tr1/2_general_utilities/shared_ptr/cons/43820.cc: Adjust dg-error line numbers. * testsuite/20_util/duration/requirements/typedefs_neg1.cc: Likewise. * testsuite/20_util/duration/requirements/typedefs_neg2.cc: Likewise. * testsuite/20_util/duration/requirements/typedefs_neg3.cc: Likewise. * testsuite/20_util/make_signed/requirements/typedefs_neg.cc: Likewise. * testsuite/20_util/make_unsigned/requirements/ typedefs_neg.cc: Likewise. * testsuite/20_util/declval/requirements/1_neg.cc: Likewise. * testsuite/20_util/shared_ptr/cons/43820.cc: Likewise. * testsuite/20_util/weak_ptr/comparison/cmp_neg.cc: Likewise. From-SVN: r166211
171 lines
4.6 KiB
C++
171 lines
4.6 KiB
C++
// class template regex -*- C++ -*-
|
|
|
|
// Copyright (C) 2010 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/>.
|
|
|
|
/**
|
|
* @file bits/regex_nfa.tcc
|
|
*/
|
|
#include <regex>
|
|
|
|
_GLIBCXX_BEGIN_NAMESPACE(std)
|
|
|
|
namespace __regex
|
|
{
|
|
#ifdef _GLIBCXX_DEBUG
|
|
inline std::ostream& _State::
|
|
_M_print(std::ostream& ostr) const
|
|
{
|
|
switch (_M_opcode)
|
|
{
|
|
case _S_opcode_alternative:
|
|
ostr << "alt next=" << _M_next << " alt=" << _M_alt;
|
|
break;
|
|
case _S_opcode_subexpr_begin:
|
|
ostr << "subexpr begin next=" << _M_next << " index=" << _M_subexpr;
|
|
break;
|
|
case _S_opcode_subexpr_end:
|
|
ostr << "subexpr end next=" << _M_next << " index=" << _M_subexpr;
|
|
break;
|
|
case _S_opcode_match:
|
|
ostr << "match next=" << _M_next;
|
|
break;
|
|
case _S_opcode_accept:
|
|
ostr << "accept next=" << _M_next;
|
|
break;
|
|
default:
|
|
ostr << "unknown next=" << _M_next;
|
|
break;
|
|
}
|
|
return ostr;
|
|
}
|
|
|
|
// Prints graphviz dot commands for state.
|
|
inline std::ostream& _State::
|
|
_M_dot(std::ostream& __ostr, _StateIdT __id) const
|
|
{
|
|
switch (_M_opcode)
|
|
{
|
|
case _S_opcode_alternative:
|
|
__ostr << __id << " [label=\"" << __id << "\\nALT\"];\n"
|
|
<< __id << " -> " << _M_next
|
|
<< " [label=\"epsilon\", tailport=\"s\"];\n"
|
|
<< __id << " -> " << _M_alt
|
|
<< " [label=\"epsilon\", tailport=\"n\"];\n";
|
|
break;
|
|
case _S_opcode_subexpr_begin:
|
|
__ostr << __id << " [label=\"" << __id << "\\nSBEGIN "
|
|
<< _M_subexpr << "\"];\n"
|
|
<< __id << " -> " << _M_next << " [label=\"epsilon\"];\n";
|
|
break;
|
|
case _S_opcode_subexpr_end:
|
|
__ostr << __id << " [label=\"" << __id << "\\nSEND "
|
|
<< _M_subexpr << "\"];\n"
|
|
<< __id << " -> " << _M_next << " [label=\"epsilon\"];\n";
|
|
break;
|
|
case _S_opcode_match:
|
|
__ostr << __id << " [label=\"" << __id << "\\nMATCH\"];\n"
|
|
<< __id << " -> " << _M_next << " [label=\"<match>\"];\n";
|
|
break;
|
|
case _S_opcode_accept:
|
|
__ostr << __id << " [label=\"" << __id << "\\nACC\"];\n" ;
|
|
break;
|
|
default:
|
|
__ostr << __id << " [label=\"" << __id << "\\nUNK\"];\n"
|
|
<< __id << " -> " << _M_next << " [label=\"?\"];\n";
|
|
break;
|
|
}
|
|
return __ostr;
|
|
}
|
|
|
|
inline std::ostream& _Nfa::
|
|
_M_dot(std::ostream& __ostr) const
|
|
{
|
|
__ostr << "digraph _Nfa {\n"
|
|
<< " rankdir=LR;\n";
|
|
for (unsigned int __i = 0; __i < this->size(); ++__i)
|
|
{ this->at(__i)._M_dot(__ostr, __i); }
|
|
__ostr << "}\n";
|
|
return __ostr;
|
|
}
|
|
#endif
|
|
|
|
inline _StateSeq& _StateSeq::
|
|
operator=(const _StateSeq& __rhs)
|
|
{
|
|
_M_start = __rhs._M_start;
|
|
_M_end1 = __rhs._M_end1;
|
|
_M_end2 = __rhs._M_end2;
|
|
return *this;
|
|
}
|
|
|
|
inline void _StateSeq::
|
|
_M_push_back(_StateIdT __id)
|
|
{
|
|
if (_M_end1 != _S_invalid_state_id)
|
|
_M_nfa[_M_end1]._M_next = __id;
|
|
_M_end1 = __id;
|
|
}
|
|
|
|
inline void _StateSeq::
|
|
_M_append(_StateIdT __id)
|
|
{
|
|
if (_M_end2 != _S_invalid_state_id)
|
|
{
|
|
if (_M_end2 == _M_end1)
|
|
_M_nfa[_M_end2]._M_alt = __id;
|
|
else
|
|
_M_nfa[_M_end2]._M_next = __id;
|
|
_M_end2 = _S_invalid_state_id;
|
|
}
|
|
if (_M_end1 != _S_invalid_state_id)
|
|
_M_nfa[_M_end1]._M_next = __id;
|
|
_M_end1 = __id;
|
|
}
|
|
|
|
inline void _StateSeq::
|
|
_M_append(_StateSeq& __rhs)
|
|
{
|
|
if (_M_end2 != _S_invalid_state_id)
|
|
{
|
|
if (_M_end2 == _M_end1)
|
|
_M_nfa[_M_end2]._M_alt = __rhs._M_start;
|
|
else
|
|
_M_nfa[_M_end2]._M_next = __rhs._M_start;
|
|
_M_end2 = _S_invalid_state_id;
|
|
}
|
|
if (__rhs._M_end2 != _S_invalid_state_id)
|
|
_M_end2 = __rhs._M_end2;
|
|
if (_M_end1 != _S_invalid_state_id)
|
|
_M_nfa[_M_end1]._M_next = __rhs._M_start;
|
|
_M_end1 = __rhs._M_end1;
|
|
}
|
|
|
|
// @todo implement this function.
|
|
inline _StateIdT _StateSeq::
|
|
_M_clone()
|
|
{ return 0; }
|
|
|
|
} // namespace __regex
|
|
|
|
_GLIBCXX_END_NAMESPACE
|