boost/fusion/container/map/detail/build_map.hpp
/*=============================================================================
Copyright (c) 2005-2013 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_FUSION_BUILD_MAP_02042013_1448)
#define BOOST_FUSION_BUILD_MAP_02042013_1448
#include <boost/fusion/support/config.hpp>
#include <boost/fusion/iterator/equal_to.hpp>
#include <boost/fusion/iterator/next.hpp>
#include <boost/fusion/iterator/value_of.hpp>
#include <boost/fusion/iterator/deref.hpp>
#include <boost/fusion/sequence/intrinsic/begin.hpp>
#include <boost/fusion/sequence/intrinsic/end.hpp>
#include <boost/fusion/container/map/map.hpp>
#include <boost/fusion/algorithm/transformation/push_front.hpp>
namespace boost { namespace fusion { namespace detail
{
template <typename First, typename Last, bool is_assoc
, bool is_empty = result_of::equal_to<First, Last>::value
>
struct build_map;
template <typename First, typename Last, bool is_assoc>
struct build_map<First, Last, is_assoc, true>
{
typedef map<> type;
BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
static type
call(First const&, Last const&)
{
return type();
}
};
template <typename T, typename Rest>
struct push_front_map;
template <typename T, typename ...Rest>
struct push_front_map<T, map<Rest...>>
{
typedef map<T, Rest...> type;
BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
static type
call(T const& first, map<Rest...> const& rest)
{
return type(push_front(rest, first));
}
};
template <typename First, typename Last, bool is_assoc>
struct build_map<First, Last, is_assoc, false>
{
typedef
build_map<typename result_of::next<First>::type, Last, is_assoc>
next_build_map;
typedef push_front_map<
typename pair_from<First, is_assoc>::type
, typename next_build_map::type>
push_front;
typedef typename push_front::type type;
BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
static type
call(First const& f, Last const& l)
{
return push_front::call(
pair_from<First, is_assoc>::call(f)
, next_build_map::call(fusion::next(f), l));
}
};
}}}
#endif