⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 meta_grammar.hpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 HPP
字号:
//  Copyright (c) 2001-2007 Joel de Guzman//  Copyright (c) 2001-2008 Hartmut Kaiser////  Distributed under 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_KARMA_META_GRAMMAR_FEB_21_2007_0742AM)#define BOOST_SPIRIT_KARMA_META_GRAMMAR_FEB_21_2007_0742AM#if defined(_MSC_VER) && (_MSC_VER >= 1020)#pragma once      // MS compatible compilers support #pragma once#endif#include <boost/spirit/home/karma/domain.hpp>#include <boost/spirit/home/support/placeholders.hpp>#include <boost/spirit/home/support/meta_grammar.hpp>#include <boost/spirit/home/support/char_class.hpp>#include <boost/utility/enable_if.hpp>#include <boost/mpl/bool.hpp>namespace boost { namespace spirit{    ///////////////////////////////////////////////////////////////////////////    // test if a tag is a character literal type    ///////////////////////////////////////////////////////////////////////////    template <typename CharSet>    struct is_char_tag<            spirit::char_class::key<CharSet, char_class::tag::space>,            karma::domain        >      : mpl::true_    {};}}namespace boost { namespace spirit { namespace karma{    ///////////////////////////////////////////////////////////////////////////    // forward declarations    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct any_char;    template <typename Char>    struct literal_char;    struct lazy_char;    template <typename Tag, typename Char>    struct any_space_char;    template <typename Tag, typename Char>    struct literal_space_char;    struct char_meta_grammar;    template <typename Expr, typename Enable>    struct is_valid_expr;    template <typename Expr, typename Enable>    struct expr_transform;    ///////////////////////////////////////////////////////////////////////////    // get the director of a character literal type    ///////////////////////////////////////////////////////////////////////////    template <typename Tag, typename T>    struct extract_literal_char_director;    template <typename T>    struct extract_literal_char_director<tag::char_, T>    {        typedef literal_char<T> type;    };    template <typename T>    struct extract_literal_char_director<tag::wchar, T>    {        typedef literal_char<wchar_t> type;    };    template <typename T>    struct extract_literal_char_director<tag::lit, T>    {        typedef literal_char<T> type;    };    template <typename T>    struct extract_literal_char_director<tag::wlit, T>    {        typedef literal_char<wchar_t> type;    };    template <typename CharSet, typename T>    struct extract_literal_char_director<        spirit::char_class::key<CharSet, char_class::tag::space>, T    >    {        typedef            spirit::char_class::key<CharSet, char_class::tag::space>        key_type;        typedef literal_space_char<key_type, T> type;    };    ///////////////////////////////////////////////////////////////////////////    // get the director of a plain character type    ///////////////////////////////////////////////////////////////////////////    template <typename Tag>    struct extract_any_char_director;    template <>    struct extract_any_char_director<tag::char_>    {        typedef any_char<char> type;    };    template <>    struct extract_any_char_director<tag::wchar>    {        typedef any_char<wchar_t> type;    };    template <typename CharSet>    struct extract_any_char_director<        spirit::char_class::key<CharSet, char_class::tag::space>    >    {        typedef typename CharSet::char_type char_type;        typedef            spirit::char_class::key<CharSet, char_class::tag::space>        key_type;        typedef any_space_char<key_type, char_type> type;    };    ///////////////////////////////////////////////////////////////////////////    // char generator meta-grammars    ///////////////////////////////////////////////////////////////////////////    // literals: 'x', L'x'    struct char_literal_meta_grammar      : proto::or_<            meta_grammar::terminal_rule<                karma::domain, char, literal_char<char>             >,            meta_grammar::terminal_rule<                karma::domain, wchar_t, literal_char<wchar_t>             >        >    {    };    // literals: 'x', L'x'    struct basic_char_literal_meta_grammar      : proto::or_<            proto::terminal<char>,            proto::terminal<wchar_t>        >    {    };    // char_, wchar, space    // char_('x'), char_(L'x'), wchar('x'), wchar(L'x'), space(' ')    struct char_meta_grammar1      : proto::or_<            // char_, wchar, space            meta_grammar::compose_empty<                proto::if_<                    is_char_tag<proto::_arg, karma::domain>()                >,                karma::domain,                mpl::identity<extract_any_char_director<mpl::_> >            >,            // char_('x'), wchar(L'x'), space(' ')            meta_grammar::compose_function1_eval<                proto::function<                    proto::if_<                        is_char_tag<proto::_arg, karma::domain>()                    >,                    basic_char_literal_meta_grammar                >,                karma::domain,                mpl::identity<extract_literal_char_director<mpl::_, mpl::_> >            >,            // lit('x'), wlit('x')            meta_grammar::compose_function1_eval<                proto::function<                    proto::if_<                        is_lit_tag<proto::_arg, karma::domain>()                    >,                    basic_char_literal_meta_grammar                >,                karma::domain,                mpl::identity<extract_literal_char_director<mpl::_, mpl::_> >            >,            // char_(val('y'))            meta_grammar::function1_rule<                karma::domain, tag::char_, lazy_char            >        >    {    };    // main char_meta_grammar    struct char_meta_grammar      : proto::or_<            char_literal_meta_grammar,            char_meta_grammar1        >    {    };    ///////////////////////////////////////////////////////////////////////////    //  These specializations non-intrusively hook into the Karma meta-grammar.    //  (see karma/meta_grammar.hpp)    ///////////////////////////////////////////////////////////////////////////    template <typename Expr>    struct is_valid_expr<Expr,        typename enable_if<proto::matches<Expr, char_meta_grammar> >::type>      : mpl::true_    {    };    template <typename Expr>    struct expr_transform<Expr,        typename enable_if<proto::matches<Expr, char_meta_grammar> >::type>      : mpl::identity<char_meta_grammar>    {    };}}}#endif

⌨️ 快捷键说明

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