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

📄 lit.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_LIT_APR_18_2006_1125PM)#define BOOST_SPIRIT_LIT_APR_18_2006_1125PM#include <boost/spirit/home/qi/domain.hpp>#include <boost/spirit/home/qi/skip.hpp>#include <boost/spirit/home/qi/detail/string_parse.hpp>#include <boost/spirit/home/support/char_class.hpp>#include <boost/spirit/home/support/modifier.hpp>#include <boost/spirit/home/support/unused.hpp>#include <boost/spirit/home/support/detail/to_narrow.hpp>#include <boost/fusion/include/at.hpp>#include <boost/fusion/include/value_at.hpp>#include <boost/fusion/include/vector.hpp>#include <boost/type_traits/remove_reference.hpp>#include <string>namespace boost { namespace spirit { namespace qi{    ///////////////////////////////////////////////////////////////////////////    // parse literal strings    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct literal_string    {        template <typename Component, typename Context, typename Iterator>        struct attribute        {            typedef unused_type type;   // literal parsers have no attribute        };        template <            typename Component          , typename Iterator, typename Context          , typename Skipper, typename Attribute>        static bool parse(            Component const& component          , Iterator& first, Iterator const& last          , Context& /*context*/, Skipper const& skipper          , Attribute& attr)        {            qi::skip(first, last, skipper);            return detail::string_parse(                fusion::at_c<0>(component.elements)              , first              , last              , attr            );        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return std::string("\"")                + spirit::detail::to_narrow_string(                    fusion::at_c<0>(component.elements))                + std::string("\"")            ;        }    };    ///////////////////////////////////////////////////////////////////////////    // parse lazy strings    ///////////////////////////////////////////////////////////////////////////    struct lazy_string    {        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 Iterator, typename Context          , typename Skipper, typename Attribute>        static bool parse(            Component const& component          , Iterator& first, Iterator const& last          , Context& context, Skipper const& skipper          , Attribute& attr)        {            qi::skip(first, last, skipper);            return detail::string_parse(                fusion::at_c<0>(component.elements)(unused, context)              , first              , last              , attr            );        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return std::string("\"")                + spirit::detail::to_narrow_string(                    fusion::at_c<0>(component.elements)(unused, ctx))                + std::string("\"")            ;        }    };    ///////////////////////////////////////////////////////////////////////////    // no_case literal_string version    ///////////////////////////////////////////////////////////////////////////    template <typename Char>    struct no_case_literal_string    {        template <typename Component, typename Context, typename Iterator>        struct attribute        {            typedef unused_type type;   // literal parsers have no attribute        };        template <            typename Component          , typename Iterator, typename Context          , typename Skipper, typename Attribute>        static bool parse(            Component const& component          , Iterator& first, Iterator const& last          , Context& /*context*/, Skipper const& skipper          , Attribute& attr)        {            qi::skip(first, last, skipper);            return detail::string_parse(                fusion::at_c<0>(component.elements)              , fusion::at_c<1>(component.elements)              , first              , last              , attr            );        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            return std::string("case-insensitive \"")                + spirit::detail::to_narrow_string(                    fusion::at_c<0>(component.elements))                + std::string("\"")            ;        }    };}}}namespace boost { namespace spirit { namespace traits{    ///////////////////////////////////////////////////////////////////////////    // no_case_literal_string generator    ///////////////////////////////////////////////////////////////////////////    template <        typename Domain, typename Elements, typename Modifier, typename Char    >    struct make_modified_component<        Domain, qi::literal_string<Char>, Elements, Modifier      , typename enable_if<            is_member_of_modifier<Modifier, spirit::char_class::no_case_base_tag>        >::type    >    {        typedef std::basic_string<Char> string_type;        typedef fusion::vector<string_type, string_type> vector_type;        typedef            component<qi::domain, qi::no_case_literal_string<Char>, vector_type>        type;        static type        call(Elements const& elements)        {            typedef typename Modifier::char_set char_set;            Char const* in = fusion::at_c<0>(elements);            string_type lo(in);            string_type hi(in);            typename string_type::iterator loi = lo.begin();            typename string_type::iterator hii = hi.begin();            for (; loi != lo.end(); ++loi, ++hii, ++in)            {                *loi = char_set::tolower(*loi);                *hii = char_set::toupper(*hii);            }            return type(vector_type(lo, hi));        }    };}}}#endif

⌨️ 快捷键说明

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