| Index: third_party/boost/boost/mpl/vector/aux_/numbered.hpp
|
| diff --git a/third_party/boost/boost/mpl/vector/aux_/numbered.hpp b/third_party/boost/boost/mpl/vector/aux_/numbered.hpp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..24ed9ec1158adaa31377f07bdc0fffa0b4ec1b3f
|
| --- /dev/null
|
| +++ b/third_party/boost/boost/mpl/vector/aux_/numbered.hpp
|
| @@ -0,0 +1,218 @@
|
| +
|
| +// NO INCLUDE GUARDS, THE HEADER IS INTENDED FOR MULTIPLE INCLUSION
|
| +
|
| +#if defined(BOOST_PP_IS_ITERATING)
|
| +
|
| +// Copyright Aleksey Gurtovoy 2000-2004
|
| +//
|
| +// 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)
|
| +//
|
| +// See http://www.boost.org/libs/mpl for documentation.
|
| +
|
| +// $Source$
|
| +// $Date: 2004-09-02 11:41:37 -0400 (Thu, 02 Sep 2004) $
|
| +// $Revision: 24874 $
|
| +
|
| +#include <boost/preprocessor/enum_params.hpp>
|
| +#include <boost/preprocessor/enum_shifted_params.hpp>
|
| +#include <boost/preprocessor/comma_if.hpp>
|
| +#include <boost/preprocessor/repeat.hpp>
|
| +#include <boost/preprocessor/dec.hpp>
|
| +#include <boost/preprocessor/cat.hpp>
|
| +
|
| +#define i_ BOOST_PP_FRAME_ITERATION(1)
|
| +
|
| +#if defined(BOOST_MPL_CFG_TYPEOF_BASED_SEQUENCES)
|
| +
|
| +# define AUX778076_VECTOR_TAIL(vector, i_, T) \
|
| + BOOST_PP_CAT(vector,i_)< \
|
| + BOOST_PP_ENUM_PARAMS(i_, T) \
|
| + > \
|
| + /**/
|
| +
|
| +#if i_ > 0
|
| +template<
|
| + BOOST_PP_ENUM_PARAMS(i_, typename T)
|
| + >
|
| +struct BOOST_PP_CAT(vector,i_)
|
| + : v_item<
|
| + BOOST_PP_CAT(T,BOOST_PP_DEC(i_))
|
| + , AUX778076_VECTOR_TAIL(vector,BOOST_PP_DEC(i_),T)
|
| + >
|
| +{
|
| + typedef BOOST_PP_CAT(vector,i_) type;
|
| +};
|
| +#endif
|
| +
|
| +# undef AUX778076_VECTOR_TAIL
|
| +
|
| +#else // "brute force" implementation
|
| +
|
| +# if i_ > 0
|
| +
|
| +template<
|
| + BOOST_PP_ENUM_PARAMS(i_, typename T)
|
| + >
|
| +struct BOOST_PP_CAT(vector,i_)
|
| +{
|
| + typedef aux::vector_tag<i_> tag;
|
| + typedef BOOST_PP_CAT(vector,i_) type;
|
| +
|
| +# define AUX778076_VECTOR_ITEM(unused, i_, unused2) \
|
| + typedef BOOST_PP_CAT(T,i_) BOOST_PP_CAT(item,i_); \
|
| + /**/
|
| +
|
| + BOOST_PP_REPEAT(i_, AUX778076_VECTOR_ITEM, unused)
|
| +# undef AUX778076_VECTOR_ITEM
|
| + typedef void_ BOOST_PP_CAT(item,i_);
|
| + typedef BOOST_PP_CAT(T,BOOST_PP_DEC(i_)) back;
|
| +
|
| + // Borland forces us to use 'type' here (instead of the class name)
|
| + typedef v_iter<type,0> begin;
|
| + typedef v_iter<type,i_> end;
|
| +};
|
| +
|
| +template<>
|
| +struct push_front_impl< aux::vector_tag<BOOST_PP_DEC(i_)> >
|
| +{
|
| + template< typename Vector, typename T > struct apply
|
| + {
|
| + typedef BOOST_PP_CAT(vector,i_)<
|
| + T
|
| + BOOST_PP_COMMA_IF(BOOST_PP_DEC(i_))
|
| + BOOST_PP_ENUM_PARAMS(BOOST_PP_DEC(i_), typename Vector::item)
|
| + > type;
|
| + };
|
| +};
|
| +
|
| +template<>
|
| +struct pop_front_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + {
|
| + typedef BOOST_PP_CAT(vector,BOOST_PP_DEC(i_))<
|
| + BOOST_PP_ENUM_SHIFTED_PARAMS(i_, typename Vector::item)
|
| + > type;
|
| + };
|
| +};
|
| +
|
| +
|
| +template<>
|
| +struct push_back_impl< aux::vector_tag<BOOST_PP_DEC(i_)> >
|
| +{
|
| + template< typename Vector, typename T > struct apply
|
| + {
|
| + typedef BOOST_PP_CAT(vector,i_)<
|
| + BOOST_PP_ENUM_PARAMS(BOOST_PP_DEC(i_), typename Vector::item)
|
| + BOOST_PP_COMMA_IF(BOOST_PP_DEC(i_))
|
| + T
|
| + > type;
|
| + };
|
| +};
|
| +
|
| +template<>
|
| +struct pop_back_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + {
|
| + typedef BOOST_PP_CAT(vector,BOOST_PP_DEC(i_))<
|
| + BOOST_PP_ENUM_PARAMS(BOOST_PP_DEC(i_), typename Vector::item)
|
| + > type;
|
| + };
|
| +};
|
| +
|
| +# endif // i_ > 0
|
| +
|
| +# if !defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) \
|
| + && !defined(BOOST_MPL_CFG_NO_NONTYPE_TEMPLATE_PARTIAL_SPEC)
|
| +
|
| +template< typename V >
|
| +struct v_at<V,i_>
|
| +{
|
| + typedef typename V::BOOST_PP_CAT(item,i_) type;
|
| +};
|
| +
|
| +# else
|
| +
|
| +namespace aux {
|
| +template<> struct v_at_impl<i_>
|
| +{
|
| + template< typename V_ > struct result_
|
| + {
|
| + typedef typename V_::BOOST_PP_CAT(item,i_) type;
|
| + };
|
| +};
|
| +}
|
| +
|
| +template<>
|
| +struct at_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename V_, typename N > struct apply
|
| + {
|
| + typedef typename aux::v_at_impl<BOOST_MPL_AUX_VALUE_WKND(N)::value>
|
| + ::template result_<V_>::type type;
|
| + };
|
| +};
|
| +
|
| +#if i_ > 0
|
| +template<>
|
| +struct front_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + {
|
| + typedef typename Vector::item0 type;
|
| + };
|
| +};
|
| +
|
| +template<>
|
| +struct back_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + {
|
| + typedef typename Vector::back type;
|
| + };
|
| +};
|
| +
|
| +template<>
|
| +struct empty_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + : false_
|
| + {
|
| + };
|
| +};
|
| +#endif
|
| +
|
| +template<>
|
| +struct size_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + : long_<i_>
|
| + {
|
| + };
|
| +};
|
| +
|
| +template<>
|
| +struct O1_size_impl< aux::vector_tag<i_> >
|
| + : size_impl< aux::vector_tag<i_> >
|
| +{
|
| +};
|
| +
|
| +template<>
|
| +struct clear_impl< aux::vector_tag<i_> >
|
| +{
|
| + template< typename Vector > struct apply
|
| + {
|
| + typedef vector0<> type;
|
| + };
|
| +};
|
| +
|
| +# endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
| +
|
| +#endif // BOOST_MPL_CFG_TYPEOF_BASED_SEQUENCES
|
| +
|
| +#undef i_
|
| +
|
| +#endif // BOOST_PP_IS_ITERATING
|
|
|