67 lines
1.9 KiB
Plaintext
67 lines
1.9 KiB
Plaintext
/*=============================================================================
|
|
Copyright (c) 2001-2011 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/fusion/support/config.hpp>
|
|
#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;
|
|
|
|
BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
|
|
static type
|
|
call(First const&, Last const&)
|
|
{
|
|
return type();
|
|
}
|
|
};
|
|
|
|
}}}
|
|
|
|
#endif
|