map_tie.hpp

来自「Boost provides free peer-reviewed portab」· HPP 代码 · 共 111 行

HPP
111
字号
/*=============================================================================    Copyright (c) 2001-2006 Joel de Guzman    Copyright (c) 2006 Dan Marsden    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)==============================================================================*/#ifndef BOOST_PP_IS_ITERATING#if !defined(FUSION_MAP_TIE_20060814_1116)#define FUSION_MAP_TIE_20060814_1116#include <boost/preprocessor/iterate.hpp>#include <boost/preprocessor/repetition/enum_params.hpp>#include <boost/preprocessor/repetition/enum_binary_params.hpp>#include <boost/preprocessor/repetition/enum_params_with_a_default.hpp>#include <boost/preprocessor/repetition/repeat_from_to.hpp>#include <boost/fusion/container/map/map.hpp>#include <boost/fusion/container/map/limits.hpp>#include <boost/fusion/support/pair.hpp>#include <boost/fusion/container/generation/pair_tie.hpp>#include <boost/type_traits/add_reference.hpp>namespace boost { namespace fusion{    struct void_;            namespace result_of    {        template <            BOOST_PP_ENUM_PARAMS_WITH_A_DEFAULT(                FUSION_MAX_MAP_SIZE, typename K, void_)          , BOOST_PP_ENUM_PARAMS_WITH_A_DEFAULT(                FUSION_MAX_MAP_SIZE, typename D, void_)          , typename Extra = void_        >        struct map_tie;                    template <>        struct map_tie<>        {            typedef map<> type;        };    }        inline map<>    map_tie()    {        return map<>();    }#define BOOST_FUSION_TIED_PAIR(z, n, data)                                                          \    fusion::pair<                                                                                   \        BOOST_PP_CAT(K, n)                                                                          \      , typename add_reference<BOOST_PP_CAT(D, n)>::type>#define BOOST_FUSION_PAIR_TIE(z, n, data)                                      \    fusion::pair_tie<BOOST_PP_CAT(K, n)>(BOOST_PP_CAT(_, n))                   \#define BOOST_PP_FILENAME_1 <boost/fusion/container/generation/map_tie.hpp>#define BOOST_PP_ITERATION_LIMITS (1, FUSION_MAX_MAP_SIZE)#include BOOST_PP_ITERATE()#undef BOOST_FUSION_PAIR#undef BOOST_FUSION_MAKE_PAIR}}#endif#else // defined(BOOST_PP_IS_ITERATING)///////////////////////////////////////////////////////////////////////////////////  Preprocessor vertical repetition code/////////////////////////////////////////////////////////////////////////////////#define N BOOST_PP_ITERATION()    namespace result_of    {        template <            BOOST_PP_ENUM_PARAMS(N, typename K)          , BOOST_PP_ENUM_PARAMS(N, typename D)        >#if defined(BOOST_NO_PARTIAL_SPECIALIZATION_IMPLICIT_DEFAULT_ARGS)        #define TEXT(z, n, text) , text        struct map_tie<BOOST_PP_ENUM_PARAMS(N, K), BOOST_PP_ENUM_PARAMS(N, D) BOOST_PP_REPEAT_FROM_TO(N, FUSION_MAX_MAP_SIZE, TEXT, void_) BOOST_PP_REPEAT_FROM_TO(BOOST_PP_DEC(N), FUSION_MAX_MAP_SIZE, TEXT, void_)>        #undef TEXT#else        struct map_tie<BOOST_PP_ENUM_PARAMS(N, K), BOOST_PP_ENUM_PARAMS(N, D)>#endif        {            typedef map<BOOST_PP_ENUM(N, BOOST_FUSION_TIED_PAIR, _)> type;        };    }    template <        BOOST_PP_ENUM_PARAMS(N, typename K)      , BOOST_PP_ENUM_PARAMS(N, typename D)    >    inline map<BOOST_PP_ENUM(N, BOOST_FUSION_TIED_PAIR, _)>    map_tie(BOOST_PP_ENUM_BINARY_PARAMS(N, D, & _))    {        return map<BOOST_PP_ENUM(N, BOOST_FUSION_TIED_PAIR, _)>(            BOOST_PP_ENUM(N, BOOST_FUSION_PAIR_TIE, _));    }#undef N#endif // defined(BOOST_PP_IS_ITERATING)

⌨️ 快捷键说明

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