build_deque.hpp 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*=============================================================================
  2. Copyright (c) 2005-2013 Joel de Guzman
  3. Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. ==============================================================================*/
  6. #if !defined(BOOST_FUSION_BUILD_DEQUE_02032013_1921)
  7. #define BOOST_FUSION_BUILD_DEQUE_02032013_1921
  8. #include <boost/fusion/support/config.hpp>
  9. #include <boost/fusion/iterator/equal_to.hpp>
  10. #include <boost/fusion/iterator/next.hpp>
  11. #include <boost/fusion/iterator/value_of.hpp>
  12. #include <boost/fusion/iterator/deref.hpp>
  13. #include <boost/fusion/sequence/intrinsic/begin.hpp>
  14. #include <boost/fusion/sequence/intrinsic/end.hpp>
  15. #include <boost/fusion/container/deque/front_extended_deque.hpp>
  16. namespace boost { namespace fusion { namespace detail
  17. {
  18. template <typename First, typename Last
  19. , bool is_empty = result_of::equal_to<First, Last>::value>
  20. struct build_deque;
  21. template <typename First, typename Last>
  22. struct build_deque<First, Last, true>
  23. {
  24. typedef deque<> type;
  25. BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
  26. static type
  27. call(First const&, Last const&)
  28. {
  29. return type();
  30. }
  31. };
  32. template <typename T, typename Rest>
  33. struct push_front_deque;
  34. template <typename T, typename ...Rest>
  35. struct push_front_deque<T, deque<Rest...>>
  36. {
  37. typedef deque<T, Rest...> type;
  38. BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED
  39. static type
  40. call(T const& first, deque<Rest...> const& rest)
  41. {
  42. return type(front_extended_deque<deque<Rest...>, T>(rest, first));
  43. }
  44. };
  45. template <typename First, typename Last>
  46. struct build_deque<First, Last, false>
  47. {
  48. typedef
  49. build_deque<typename result_of::next<First>::type, Last>
  50. next_build_deque;
  51. typedef push_front_deque<
  52. typename result_of::value_of<First>::type
  53. , typename next_build_deque::type>
  54. push_front;
  55. typedef typename push_front::type type;
  56. BOOST_CXX14_CONSTEXPR BOOST_FUSION_GPU_ENABLED
  57. static type
  58. call(First const& f, Last const& l)
  59. {
  60. typename result_of::value_of<First>::type v = *f;
  61. return push_front::call(
  62. v, next_build_deque::call(fusion::next(f), l));
  63. }
  64. };
  65. }}}
  66. #endif