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

📄 alternative.hpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 HPP
字号:
//  Copyright (c) 2001-2008 Hartmut Kaiser//  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(SPIRIT_KARMA_ALTERNATIVE_MAR_01_2007_1117AM)#define SPIRIT_KARMA_ALTERNATIVE_MAR_01_2007_1117AM#if defined(_MSC_VER) && (_MSC_VER >= 1020)#pragma once      // MS compatible compilers support #pragma once#endif#include <boost/spirit/home/karma/operator/detail/alternative.hpp>#include <boost/spirit/home/support/attribute_transform.hpp>#include <boost/spirit/home/support/as_variant.hpp>#include <boost/spirit/home/support/detail/what_function.hpp>#include <boost/spirit/home/support/algorithm/any.hpp>#include <boost/spirit/home/support/unused.hpp>#include <boost/fusion/include/for_each.hpp>#include <boost/fusion/include/mpl.hpp>#include <boost/fusion/include/transform.hpp>#include <boost/variant.hpp>#include <boost/mpl/vector.hpp>#include <boost/mpl/end.hpp>#include <boost/mpl/insert_range.hpp>#include <boost/mpl/transform_view.hpp>namespace boost { namespace spirit { namespace karma{    struct alternative    {        template <typename T>        struct transform_child : mpl::identity<T> {};        template <typename All, typename Filtered>        struct build_container        {            // Ok, now make a variant over the attribute_sequence. It's            // a pity that make_variant_over does not support forward MPL            // sequences. We use our own conversion metaprogram (as_variant).            typedef typename                as_variant<Filtered>::type            type;        };        template <typename Component, typename Context, typename Iterator>        struct attribute :            build_fusion_sequence<alternative, Component, Iterator, Context>        {        };        template <typename Component, typename OutputIterator,            typename Context, typename Delimiter, typename Parameter>        static bool        generate(Component const& component, OutputIterator& sink,            Context& ctx, Delimiter const& d, Parameter const& param)        {            typedef detail::alternative_generate_functor<                OutputIterator, Context, Delimiter, Parameter            > functor;            // f return true if *any* of the parser succeeds            functor f (sink, ctx, d, param);            return fusion::any(component.elements, f);        }        template <typename Component, typename Context>        static std::string what(Component const& component, Context const& ctx)        {            std::string result = "alternatives[";            fusion::for_each(component.elements,                spirit::detail::what_function<Context>(result), ctx);            result += "]";            return result;        }    };}}}#endif

⌨️ 快捷键说明

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