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

📄 char.hpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 HPP
字号:
/*=============================================================================    Copyright (c) 2001-2007 Joel de Guzman    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_CHAR_APR_16_2006_1051AM)#define BOOST_SPIRIT_CHAR_APR_16_2006_1051AM#include <boost/spirit/home/qi/char/char_parser.hpp>#include <boost/spirit/home/qi/char/detail/get_char.hpp>#include <boost/spirit/home/qi/domain.hpp>#include <boost/fusion/include/at.hpp>#include <boost/fusion/include/value_at.hpp>#include <boost/fusion/include/vector.hpp>#include <boost/spirit/home/support/modifier.hpp>#include <boost/spirit/home/support/char_class.hpp>#include <boost/spirit/home/support/detail/to_narrow.hpp>#include <boost/utility/enable_if.hpp>#include <boost/type_traits/remove_reference.hpp>#include <boost/foreach.hpp>#include <boost/mpl/print.hpp>namespace boost { namespace spirit { namespace qi{    ///////////////////////////////////////////////////////////////////////////    // parse any character    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct any_char : char_parser<any_char<Char>, Char>    {        template <typename Component, typename CharParam, typename Context>        static bool test(Component const&, CharParam, Context&)        {            return true;        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return "any-char";        }    };    ///////////////////////////////////////////////////////////////////////////    // parse a single character    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct literal_char : char_parser<literal_char<Char>, Char>    {        template <typename Component, typename Context, typename Iterator>        struct attribute        {            typedef unused_type type;   // literal parsers have no attribute        };        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context&)        {            return detail::get_char(fusion::at_c<0>(component.elements)) == ch;        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return std::string("'")                + spirit::detail::to_narrow_char(                    detail::get_char(fusion::at_c<0>(component.elements)))                + '\'';        }    };    ///////////////////////////////////////////////////////////////////////////    // parse a character set    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct char_set : char_parser<char_set<Char>, Char>    {        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context&)        {            return component.ptr->test(ch);        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return "char-set";        }    };    ///////////////////////////////////////////////////////////////////////////    // parse a lazy character    ///////////////////////////////////////////////////////////////////////////    struct lazy_char : char_parser<lazy_char>    {        template <typename Component, typename Context, typename Iterator>        struct attribute        {            typedef typename                result_of::subject<Component>::type            subject_type;            typedef typename                remove_reference<                    typename boost::result_of<subject_type(unused_type, Context)>::type                >::type            type;        };        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context& context)        {            return fusion::at_c<0>(component.elements)(unused, context) == ch;        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return std::string("'")                + spirit::detail::to_narrow_char(                    fusion::at_c<0>(component.elements)(unused, ctx))                + '\'';        }    };    ///////////////////////////////////////////////////////////////////////////    // parse a character range    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct char_range : char_parser<char_range<Char>, Char>    {        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context&)        {            return                !(ch < fusion::at_c<0>(component.elements)) &&                !(fusion::at_c<1>(component.elements) < ch);        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            std::string result;            result += std::string("'") + fusion::at_c<0>(component.elements) + '\'';            result += "...";            result += std::string("'") + fusion::at_c<1>(component.elements) + '\'';            return result;        }    };    ///////////////////////////////////////////////////////////////////////////    // parse a lazy character range    ///////////////////////////////////////////////////////////////////////////    struct lazy_char_range : char_parser<lazy_char_range>    {        template <typename Component, typename Context, typename Iterator>        struct attribute        {            typedef typename                result_of::subject<Component>::type            subject_type;            typedef typename                remove_reference<                    typename boost::result_of<subject_type(unused_type, Context)>::type                >::type            type;        };        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context& context)        {            return                !(ch < fusion::at_c<0>(component.elements)(unused, context)) &&                !(fusion::at_c<1>(component.elements)(unused, context) < ch);        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return "char-range";        }    };    ///////////////////////////////////////////////////////////////////////////    // no_case literal_char version    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct no_case_literal_char : char_parser<no_case_literal_char<Char>, Char>    {        template <typename Component, typename Context, typename Iterator>        struct attribute        {            typedef unused_type type;   // literal parsers have no attribute        };        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context&)        {            return detail::get_char(fusion::at_c<0>(component.elements)) == ch                || detail::get_char(fusion::at_c<1>(component.elements)) == ch            ;        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            std::string result;            result += std::string("'")                + spirit::detail::to_narrow_char(                    detail::get_char(fusion::at_c<0>(component.elements))) + '\'';            result += " or ";            result += std::string("'") +                spirit::detail::to_narrow_char(                    detail::get_char(fusion::at_c<1>(component.elements))) + '\'';            return result;        }    };    ///////////////////////////////////////////////////////////////////////////    // no_case char_range version    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct no_case_char_range : char_parser<no_case_char_range<Char>, Char>    {        template <typename Component, typename CharParam, typename Context>        static bool test(Component const& component, CharParam ch, Context&)        {            return                (!(ch < fusion::at_c<0>(component.elements)) &&                 !(fusion::at_c<1>(component.elements) < ch))            ||  (!(ch < fusion::at_c<2>(component.elements)) &&                 !(fusion::at_c<3>(component.elements) < ch))            ;        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            std::string result;            result += std::string("'") + fusion::at_c<0>(component.elements) + '\'';            result += "...";            result += std::string("'") + fusion::at_c<1>(component.elements) + '\'';            result += " or ";            result += std::string("'") + fusion::at_c<2>(component.elements) + '\'';            result += "...";            result += std::string("'") + fusion::at_c<3>(component.elements) + '\'';            return result;        }    };    template <typename Char, typename Elements>    struct char_set_component;}}}namespace boost { namespace spirit { namespace traits{    ///////////////////////////////////////////////////////////////////////////    // char_set_component generator    ///////////////////////////////////////////////////////////////////////////    template <typename Char, typename Elements, typename Modifier>    struct make_component<qi::domain, qi::char_set<Char>, Elements, Modifier      , typename disable_if<            is_member_of_modifier<Modifier, spirit::char_class::no_case_base_tag>        >::type    > : mpl::identity<qi::char_set_component<Char, Elements> >    {        static qi::char_set_component<Char, Elements>        call(Elements const& elements)        {            return qi::char_set_component<Char, Elements>(                fusion::at_c<0>(elements));        }    };    ///////////////////////////////////////////////////////////////////////////    // no_case char_set_component generator    ///////////////////////////////////////////////////////////////////////////    template <        typename Domain, typename Elements, typename Modifier, typename Char    >    struct make_modified_component<        Domain, qi::char_set<Char>, Elements, Modifier      , typename enable_if<            is_member_of_modifier<Modifier, spirit::char_class::no_case_base_tag>        >::type    >    {        typedef qi::char_set_component<Char, Elements> type;        typedef typename Modifier::char_set char_set;        static type        call(Elements const& elements)        {            return qi::char_set_component<Char, Elements>(                fusion::at_c<0>(elements), char_set());        }    };    ///////////////////////////////////////////////////////////////////////////    // no_case_literal_char generator    ///////////////////////////////////////////////////////////////////////////    template <        typename Domain, typename Elements, typename Modifier, typename Char    >    struct make_modified_component<        Domain, qi::literal_char<Char>, Elements, Modifier      , typename enable_if<            is_member_of_modifier<Modifier, spirit::char_class::no_case_base_tag>        >::type    >    {        typedef fusion::vector<Char, Char> vector_type;        typedef            component<qi::domain, qi::no_case_literal_char<Char>, vector_type>        type;        static type        call(Elements const& elements)        {            typedef typename Modifier::char_set char_set;            Char ch = qi::detail::get_char(fusion::at_c<0>(elements));            vector_type v(                char_set::tolower(ch)              , char_set::toupper(ch)            );            return type(v);        }    };    ///////////////////////////////////////////////////////////////////////////    // no_case_char_range generator    ///////////////////////////////////////////////////////////////////////////    template <        typename Domain, typename Elements, typename Modifier, typename Char    >    struct make_modified_component<        Domain, qi::char_range<Char>, Elements, Modifier      , typename enable_if<            is_member_of_modifier<Modifier, spirit::char_class::no_case_base_tag>        >::type    >    {        typedef fusion::vector<Char, Char, Char, Char> vector_type;        typedef            component<qi::domain, qi::no_case_char_range<Char>, vector_type>        type;        static type        call(Elements const& elements)        {            typedef typename Modifier::char_set char_set;            Char first = fusion::at_c<0>(elements);            Char last = fusion::at_c<1>(elements);            vector_type v(                char_set::tolower(first)              , char_set::tolower(last)              , char_set::toupper(first)              , char_set::toupper(last)            );            return type(v);        }    };}}}#endif

⌨️ 快捷键说明

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