distance.hpp

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

HPP
65
字号
/*=============================================================================    Copyright (c) 2001-2006 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(FUSION_DISTANCE_09172005_0730)#define FUSION_DISTANCE_09172005_0730#include <boost/mpl/int.hpp>#include <boost/mpl/if.hpp>#include <boost/mpl/eval_if.hpp>#include <boost/mpl/next.hpp>#include <boost/mpl/identity.hpp>#include <boost/fusion/iterator/next.hpp>#include <boost/fusion/iterator/equal_to.hpp>namespace boost { namespace fusion { namespace distance_detail{    // Default distance implementation, linear    // search for the Last iterator.    template <typename First, typename Last>    struct linear_distance;    template <typename First, typename Last>    struct next_distance    {        typedef typename             mpl::next<                typename linear_distance<                    typename result_of::next<First>::type                  , Last                >::type            >::type         type;    };    template <typename First, typename Last>    struct linear_distance        : mpl::eval_if<            result_of::equal_to<First, Last>          , mpl::identity<mpl::int_<0> >          , next_distance<First, Last>        >::type    {        typedef typename            mpl::eval_if<                result_of::equal_to<First, Last>              , mpl::identity<mpl::int_<0> >              , next_distance<First, Last>            >::type        type;        static type        call(First const&, Last const&)        {            return type();        }    };}}}#endif

⌨️ 快捷键说明

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