build_deque.hpp 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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/iterator/equal_to.hpp>
  9. #include <boost/fusion/iterator/next.hpp>
  10. #include <boost/fusion/iterator/value_of.hpp>
  11. #include <boost/fusion/iterator/deref.hpp>
  12. #include <boost/fusion/sequence/intrinsic/begin.hpp>
  13. #include <boost/fusion/sequence/intrinsic/end.hpp>
  14. #include <boost/fusion/container/deque/front_extended_deque.hpp>
  15. namespace boost { namespace fusion { namespace detail
  16. {
  17. template <typename First, typename Last
  18. , bool is_empty = result_of::equal_to<First, Last>::value>
  19. struct build_deque;
  20. template <typename First, typename Last>
  21. struct build_deque<First, Last, true>
  22. {
  23. typedef deque<> type;
  24. static type
  25. call(First const&, Last const&)
  26. {
  27. return type();
  28. }
  29. };
  30. template <typename T, typename Rest>
  31. struct push_front_deque;
  32. template <typename T, typename ...Rest>
  33. struct push_front_deque<T, deque<Rest...>>
  34. {
  35. typedef deque<T, Rest...> type;
  36. static type
  37. call(T const& first, deque<Rest...> const& rest)
  38. {
  39. return type(front_extended_deque<deque<Rest...>, T>(rest, first));
  40. }
  41. };
  42. template <typename First, typename Last>
  43. struct build_deque<First, Last, false>
  44. {
  45. typedef
  46. build_deque<typename result_of::next<First>::type, Last>
  47. next_build_deque;
  48. typedef push_front_deque<
  49. typename result_of::value_of<First>::type
  50. , typename next_build_deque::type>
  51. push_front;
  52. typedef typename push_front::type type;
  53. static type
  54. call(First const& f, Last const& l)
  55. {
  56. typename result_of::value_of<First>::type v = *f;
  57. return push_front::call(
  58. v, next_build_deque::call(fusion::next(f), l));
  59. }
  60. };
  61. }}}
  62. #endif