404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.218.124.105: ~ $
// class template regex -*- C++ -*-

// Copyright (C) 2013-2017 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_automaton.tcc
 *  This is an internal header file, included by other library headers.
 *  Do not attempt to use it directly. @headername{regex}
 */

namespace std _GLIBCXX_VISIBILITY(default)
{
namespace __detail
{
_GLIBCXX_BEGIN_NAMESPACE_VERSION

#ifdef _GLIBCXX_DEBUG
  inline std::ostream&
  _State_base::_M_print(std::ostream& ostr) const
  {
    switch (_M_opcode)
    {
      case _S_opcode_alternative:
      case _S_opcode_repeat:
	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_backref:
	ostr << "backref next=" << _M_next << " index=" << _M_backref_index;
	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_base::_M_dot(std::ostream& __ostr, _StateIdT __id) const
  {
    switch (_M_opcode)
    {
      case _S_opcode_alternative:
      case _S_opcode_repeat:
	__ostr << __id << " [label=\"" << __id << "\\nALT\"];\n"
	       << __id << " -> " << _M_next
	       << " [label=\"next\", tailport=\"s\"];\n"
	       << __id << " -> " << _M_alt
	       << " [label=\"alt\", tailport=\"n\"];\n";
	break;
      case _S_opcode_backref:
	__ostr << __id << " [label=\"" << __id << "\\nBACKREF "
	       << _M_subexpr << "\"];\n"
	       << __id << " -> " << _M_next << " [label=\"<match>\"];\n";
	break;
      case _S_opcode_line_begin_assertion:
	__ostr << __id << " [label=\"" << __id << "\\nLINE_BEGIN \"];\n"
	       << __id << " -> " << _M_next << " [label=\"epsilon\"];\n";
	break;
      case _S_opcode_line_end_assertion:
	__ostr << __id << " [label=\"" << __id << "\\nLINE_END \"];\n"
	       << __id << " -> " << _M_next << " [label=\"epsilon\"];\n";
	break;
      case _S_opcode_word_boundary:
	__ostr << __id << " [label=\"" << __id << "\\nWORD_BOUNDRY "
	       << _M_neg << "\"];\n"
	       << __id << " -> " << _M_next << " [label=\"epsilon\"];\n";
	break;
      case _S_opcode_subexpr_lookahead:
	__ostr << __id << " [label=\"" << __id << "\\nLOOK_AHEAD\"];\n"
	       << __id << " -> " << _M_next
	       << " [label=\"epsilon\", tailport=\"s\"];\n"
	       << __id << " -> " << _M_alt
	       << " [label=\"<assert>\", 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_dummy:
	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:
	_GLIBCXX_DEBUG_ASSERT(false);
	break;
    }
    return __ostr;
  }

  template<typename _TraitsT>
    std::ostream&
    _NFA<_TraitsT>::_M_dot(std::ostream& __ostr) const
    {
      __ostr << "digraph _Nfa {\n"
		"  rankdir=LR;\n";
      for (size_t __i = 0; __i < this->size(); ++__i)
	(*this)[__i]._M_dot(__ostr, __i);
      __ostr << "}\n";
      return __ostr;
    }
#endif

  template<typename _TraitsT>
    _StateIdT
    _NFA<_TraitsT>::_M_insert_backref(size_t __index)
    {
      if (this->_M_flags & regex_constants::__polynomial)
	__throw_regex_error(regex_constants::error_complexity,
			    "Unexpected back-reference in polynomial mode.");
      // To figure out whether a backref is valid, a stack is used to store
      // unfinished sub-expressions. For example, when parsing
      // "(a(b)(c\\1(d)))" at '\\1', _M_subexpr_count is 3, indicating that 3
      // sub expressions are parsed or partially parsed(in the stack), aka,
      // "(a..", "(b)" and "(c..").
      // _M_paren_stack is {1, 3}, for incomplete "(a.." and "(c..". At this
      // time, "\\2" is valid, but "\\1" and "\\3" are not.
      if (__index >= _M_subexpr_count)
	__throw_regex_error(
	  regex_constants::error_backref,
	  "Back-reference index exceeds current sub-expression count.");
      for (auto __it : this->_M_paren_stack)
	if (__index == __it)
	  __throw_regex_error(
	    regex_constants::error_backref,
	    "Back-reference referred to an opened sub-expression.");
      this->_M_has_backref = true;
      _StateT __tmp(_S_opcode_backref);
      __tmp._M_backref_index = __index;
      return _M_insert_state(std::move(__tmp));
    }

  template<typename _TraitsT>
    void
    _NFA<_TraitsT>::_M_eliminate_dummy()
    {
      for (auto& __it : *this)
	{
	  while (__it._M_next >= 0 && (*this)[__it._M_next]._M_opcode()
		 == _S_opcode_dummy)
	    __it._M_next = (*this)[__it._M_next]._M_next;
	  if (__it._M_has_alt())
	    while (__it._M_alt >= 0 && (*this)[__it._M_alt]._M_opcode()
		   == _S_opcode_dummy)
	      __it._M_alt = (*this)[__it._M_alt]._M_next;
	}
    }

  // Just apply DFS on the sequence and re-link their links.
  template<typename _TraitsT>
    _StateSeq<_TraitsT>
    _StateSeq<_TraitsT>::_M_clone()
    {
      std::map<_StateIdT, _StateIdT> __m;
      std::stack<_StateIdT> __stack;
      __stack.push(_M_start);
      while (!__stack.empty())
	{
	  auto __u = __stack.top();
	  __stack.pop();
	  auto __dup = _M_nfa[__u];
	  // _M_insert_state() never return -1
	  auto __id = _M_nfa._M_insert_state(std::move(__dup));
	  __m[__u] = __id;
	  if (__dup._M_has_alt())
	    if (__dup._M_alt != _S_invalid_state_id
		&& __m.count(__dup._M_alt) == 0)
	      __stack.push(__dup._M_alt);
	  if (__u == _M_end)
	    continue;
	  if (__dup._M_next != _S_invalid_state_id
	      && __m.count(__dup._M_next) == 0)
	    __stack.push(__dup._M_next);
	}
      for (auto __it : __m)
	{
	  auto __v = __it.second;
	  auto& __ref = _M_nfa[__v];
	  if (__ref._M_next != _S_invalid_state_id)
	    {
	      __glibcxx_assert(__m.count(__ref._M_next) > 0);
	      __ref._M_next = __m[__ref._M_next];
	    }
	  if (__ref._M_has_alt())
	    if (__ref._M_alt != _S_invalid_state_id)
	      {
		__glibcxx_assert(__m.count(__ref._M_alt) > 0);
		__ref._M_alt = __m[__ref._M_alt];
	      }
	}
      return _StateSeq(_M_nfa, __m[_M_start], __m[_M_end]);
    }

_GLIBCXX_END_NAMESPACE_VERSION
} // namespace __detail
} // namespace

Filemanager

Name Type Size Permission Actions
algorithmfwd.h File 21.23 KB 0644
alloc_traits.h File 19.13 KB 0644
allocated_ptr.h File 3.43 KB 0644
allocator.h File 6.73 KB 0644
atomic_base.h File 23.28 KB 0644
atomic_futex.h File 9.35 KB 0644
atomic_lockfree_defines.h File 2.2 KB 0644
basic_ios.h File 15.7 KB 0644
basic_ios.tcc File 5.94 KB 0644
basic_string.h File 235.15 KB 0644
basic_string.tcc File 52.5 KB 0644
boost_concept_check.h File 26.41 KB 0644
c++0x_warning.h File 1.44 KB 0644
char_traits.h File 20.26 KB 0644
codecvt.h File 20.8 KB 0644
concept_check.h File 3.34 KB 0644
cpp_type_traits.h File 9.37 KB 0644
cxxabi_forced.h File 1.77 KB 0644
cxxabi_init_exception.h File 2.17 KB 0644
deque.tcc File 33.26 KB 0644
enable_special_members.h File 12.1 KB 0644
exception.h File 2.23 KB 0644
exception_defines.h File 1.61 KB 0644
exception_ptr.h File 6.31 KB 0644
forward_list.h File 47.5 KB 0644
forward_list.tcc File 14.68 KB 0644
fstream.tcc File 32.14 KB 0644
functexcept.h File 3.18 KB 0644
functional_hash.h File 8 KB 0644
gslice.h File 5.39 KB 0644
gslice_array.h File 7.59 KB 0644
hash_bytes.h File 2.1 KB 0644
hashtable.h File 71.56 KB 0644
hashtable_policy.h File 65.47 KB 0644
indirect_array.h File 7.68 KB 0644
invoke.h File 3.57 KB 0644
ios_base.h File 30.22 KB 0644
istream.tcc File 30.36 KB 0644
list.tcc File 15.54 KB 0644
locale_classes.h File 24.31 KB 0644
locale_classes.tcc File 8.18 KB 0644
locale_conv.h File 15.7 KB 0644
locale_facets.h File 89.98 KB 0644
locale_facets.tcc File 38.64 KB 0644
locale_facets_nonio.h File 67.33 KB 0644
locale_facets_nonio.tcc File 44.46 KB 0644
localefwd.h File 5.51 KB 0644
mask_array.h File 7.42 KB 0644
memoryfwd.h File 2.36 KB 0644
move.h File 6.5 KB 0644
nested_exception.h File 4.66 KB 0644
node_handle.h File 7.97 KB 0644
ostream.tcc File 12.03 KB 0644
ostream_insert.h File 3.91 KB 0644
parse_numbers.h File 7.84 KB 0644
postypes.h File 8.02 KB 0644
predefined_ops.h File 8.87 KB 0644
ptr_traits.h File 4.75 KB 0644
quoted_string.h File 4.47 KB 0644
random.h File 171.19 KB 0644
random.tcc File 103.08 KB 0644
range_access.h File 9.75 KB 0644
refwrap.h File 13.48 KB 0644
regex.h File 95.9 KB 0644
regex.tcc File 16.1 KB 0644
regex_automaton.h File 10.47 KB 0644
regex_automaton.tcc File 7.65 KB 0644
regex_compiler.h File 16.79 KB 0644
regex_compiler.tcc File 18.46 KB 0644
regex_constants.h File 14.36 KB 0644
regex_error.h File 4.85 KB 0644
regex_executor.h File 7.31 KB 0644
regex_executor.tcc File 16.91 KB 0644
regex_scanner.h File 6.92 KB 0644
regex_scanner.tcc File 14.66 KB 0644
shared_ptr.h File 22.37 KB 0644
shared_ptr_atomic.h File 9.54 KB 0644
shared_ptr_base.h File 52.54 KB 0644
slice_array.h File 9.13 KB 0644
specfun.h File 44.03 KB 0644
sstream.tcc File 9.88 KB 0644
std_abs.h File 3.21 KB 0644
std_function.h File 23.41 KB 0644
std_mutex.h File 9.08 KB 0644
stl_algo.h File 208.85 KB 0644
stl_algobase.h File 49.22 KB 0644
stl_bvector.h File 33.03 KB 0644
stl_construct.h File 7.22 KB 0644
stl_deque.h File 75.95 KB 0644
stl_function.h File 32.5 KB 0644
stl_heap.h File 19.73 KB 0644
stl_iterator.h File 40.77 KB 0644
stl_iterator_base_funcs.h File 7.88 KB 0644
stl_iterator_base_types.h File 8.48 KB 0644
stl_list.h File 63.65 KB 0644
stl_map.h File 50.02 KB 0644
stl_multimap.h File 39 KB 0644
stl_multiset.h File 33.26 KB 0644
stl_numeric.h File 13.51 KB 0644
stl_pair.h File 18.21 KB 0644
stl_queue.h File 21.61 KB 0644
stl_raw_storage_iter.h File 3.74 KB 0644
stl_relops.h File 4.49 KB 0644
stl_set.h File 33.63 KB 0644
stl_stack.h File 11.18 KB 0644
stl_tempbuf.h File 8.15 KB 0644
stl_tree.h File 73.07 KB 0644
stl_uninitialized.h File 27 KB 0644
stl_vector.h File 54.33 KB 0644
stream_iterator.h File 6.5 KB 0644
streambuf.tcc File 4.81 KB 0644
streambuf_iterator.h File 12.33 KB 0644
string_view.tcc File 6.48 KB 0644
stringfwd.h File 2.55 KB 0644
uniform_int_dist.h File 9.91 KB 0644
unique_ptr.h File 24.88 KB 0644
unordered_map.h File 67.04 KB 0644
unordered_set.h File 52.56 KB 0644
uses_allocator.h File 6.23 KB 0644
valarray_after.h File 22.12 KB 0644
valarray_array.h File 21.3 KB 0644
valarray_array.tcc File 7.08 KB 0644
valarray_before.h File 18.08 KB 0644
vector.tcc File 26.95 KB 0644