parser_names.hpp

来自「CGAL is a collaborative effort of severa」· HPP 代码 · 共 251 行

HPP
251
字号
/*=============================================================================    Copyright (c) 2001-2003 Joel de Guzman    Copyright (c) 2002-2003 Hartmut Kaiser    http://spirit.sourceforge.net/    Use, modification and distribution is subject to the Boost Software    License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at    http://www.boost.org/LICENSE_1_0.txt)=============================================================================*/#if !defined(BOOST_SPIRIT_PARSER_NAMES_HPP)#define BOOST_SPIRIT_PARSER_NAMES_HPP#if defined(BOOST_SPIRIT_DEBUG)//////////////////////////////////#include <boost/spirit/core.hpp>namespace boost { namespace spirit {///////////////////////////////////////////////////////////////////////////////////  Declaration of helper functions, which return the name of a concrete//  parser instance. The functions are specialized on the parser types. The//  functions declared in this file are for the predefined parser types from//  the Spirit core library only, so additional functions might be provided as//  needed.//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////  from actions.hpp    template <typename ParserT, typename ActionT>    std::string    parser_name(action<ParserT, ActionT> const& p);/////////////////////////////////////////////////////////////////////////////////  from directives.hpp    template <typename ParserT>    std::string    parser_name(contiguous<ParserT> const& p);    template <typename ParserT>    std::string    parser_name(inhibit_case<ParserT> const& p);    template <typename A, typename B>    std::string    parser_name(longest_alternative<A, B> const& p);    template <typename A, typename B>    std::string    parser_name(shortest_alternative<A, B> const& p);/////////////////////////////////////////////////////////////////////////////////  from grammar.hpp    template <typename DerivedT, typename ContextT>    std::string    parser_name(grammar<DerivedT, ContextT> const& p);/////////////////////////////////////////////////////////////////////////////////  from numerics.hpp    template <typename T, int Radix, unsigned MinDigits, int MaxDigits>    std::string    parser_name(uint_parser<T, Radix, MinDigits, MaxDigits> const& p);    template <typename T, int Radix, unsigned MinDigits, int MaxDigits>    std::string    parser_name(int_parser<T, Radix, MinDigits, MaxDigits> const& p);    template <typename T, typename RealPoliciesT>    std::string    parser_name(real_parser<T, RealPoliciesT> const& p);/////////////////////////////////////////////////////////////////////////////////  from operators.hpp    template <typename A, typename B>    std::string    parser_name(sequence<A, B> const& p);    template <typename A, typename B>    std::string    parser_name(sequential_or<A, B> const& p);    template <typename A, typename B>    std::string    parser_name(alternative<A, B> const& p);    template <typename A, typename B>    std::string    parser_name(intersection<A, B> const& p);    template <typename A, typename B>    std::string    parser_name(difference<A, B> const& p);    template <typename A, typename B>    std::string    parser_name(exclusive_or<A, B> const& p);    template <typename S>    std::string    parser_name(optional<S> const& p);    template <typename S>    std::string    parser_name(kleene_star<S> const& p);    template <typename S>    std::string    parser_name(positive<S> const& p);/////////////////////////////////////////////////////////////////////////////////  from parser.hpp    template <typename DerivedT>    std::string    parser_name(parser<DerivedT> const& p);/////////////////////////////////////////////////////////////////////////////////  from primitives.hpp    template <typename DerivedT>    std::string    parser_name(char_parser<DerivedT> const &p);    template <typename CharT>    std::string    parser_name(chlit<CharT> const &p);    template <typename CharT>    std::string    parser_name(range<CharT> const &p);    template <typename IteratorT>    std::string    parser_name(chseq<IteratorT> const &p);    template <typename IteratorT>    std::string    parser_name(strlit<IteratorT> const &p);    std::string    parser_name(nothing_parser const &p);    std::string    parser_name(epsilon_parser const &p);    std::string    parser_name(anychar_parser const &p);    std::string    parser_name(alnum_parser const &p);    std::string    parser_name(alpha_parser const &p);    std::string    parser_name(cntrl_parser const &p);    std::string    parser_name(digit_parser const &p);    std::string    parser_name(graph_parser const &p);    std::string    parser_name(lower_parser const &p);    std::string    parser_name(print_parser const &p);    std::string    parser_name(punct_parser const &p);    std::string    parser_name(blank_parser const &p);    std::string    parser_name(space_parser const &p);    std::string    parser_name(upper_parser const &p);    std::string    parser_name(xdigit_parser const &p);    std::string    parser_name(eol_parser const &p);    std::string    parser_name(end_parser const &p);/////////////////////////////////////////////////////////////////////////////////  from rule.hpp    template<typename T0, typename T1, typename T2>    std::string    parser_name(rule<T0, T1, T2> const& p);/////////////////////////////////////////////////////////////////////////////////  from subrule.hpp    template <typename FirstT, typename RestT>    std::string    parser_name(subrule_list<FirstT, RestT> const &p);    template <int ID, typename DefT, typename ContextT>    std::string    parser_name(subrule_parser<ID, DefT, ContextT> const &p);    template <int ID, typename ContextT>    std::string    parser_name(subrule<ID, ContextT> const &p);/////////////////////////////////////////////////////////////////////////////////  from chset.hpp///////////////////////////////////////////////////////////////////////////////////  Decide, if a node is to be traced or not/////////////////////////////////////////////////////////////////////////////////    template<        typename DerivedT, typename EmbedT,         typename T0, typename T1, typename T2    >    bool    trace_parser(impl::rule_base<DerivedT, EmbedT, T0, T1, T2>         const& p);    template <typename DerivedT, typename ContextT>    bool    trace_parser(grammar<DerivedT, ContextT> const& p);    template <int ID, typename ContextT>    bool    trace_parser(subrule<ID, ContextT> const& p);    template <typename ParserT, typename ActorTupleT>    struct init_closure_parser;    template <typename ParserT, typename ActorTupleT>    bool    trace_parser(init_closure_parser<ParserT, ActorTupleT> const& p);///////////////////////////////////////////////////////////////////////////////}} // namespace boost::spirit//////////////////////////////////#include <boost/spirit/debug/impl/parser_names.ipp>#endif // defined(BOOST_SPIRIT_DEBUG)#endif // !defined(BOOST_SPIRIT_PARSER_NAMES_HPP)

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?