/*============================================================================= Copyright (c) 2005-2012 Joel de Guzman Copyright (c) 2005-2006 Dan Marsden 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_DEQUE_26112006_1649) #define BOOST_FUSION_DEQUE_26112006_1649 #include /////////////////////////////////////////////////////////////////////////////// // With no decltype and variadics, we will use the C++03 version /////////////////////////////////////////////////////////////////////////////// #if (defined(BOOST_NO_DECLTYPE) \ || defined(BOOST_NO_VARIADIC_TEMPLATES) \ || defined(BOOST_NO_RVALUE_REFERENCES)) # include #else # if !defined(BOOST_FUSION_HAS_CPP11_DEQUE) # define BOOST_FUSION_HAS_CPP11_DEQUE # endif /////////////////////////////////////////////////////////////////////////////// // C++11 interface /////////////////////////////////////////////////////////////////////////////// #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace fusion { struct deque_tag; template struct deque : detail::nil_keyed_element { }; template struct deque : detail::deque_keyed_values::type , sequence_base> { typedef deque_tag fusion_tag; typedef bidirectional_traversal_tag category; typedef typename detail::deque_keyed_values::type base; typedef mpl::int_<(sizeof ...(Tail) + 1)> size; typedef mpl::int_ next_up; typedef mpl::int_::type::value> next_down; typedef mpl::false_ is_view; deque() {} template deque(deque const& seq) : base(seq) {} explicit deque(typename detail::call_param::type head , typename detail::call_param::type... tail) : base(detail::deque_keyed_values::call(head, tail...)) {} template explicit deque(Sequence const& seq , typename disable_if >::type* /*dummy*/ = 0) : base(base::from_iterator(fusion::begin(seq))) {} template deque& operator=(deque const& rhs) { base::operator=(rhs); return *this; } template deque& operator=(T const& rhs) { base::operator=(rhs); return *this; } }; }} #endif #endif