• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 
2 // NO INCLUDE GUARDS, THE HEADER IS INTENDED FOR MULTIPLE INCLUSION
3 
4 #if defined(BOOST_PP_IS_ITERATING)
5 
6 // Copyright Aleksey Gurtovoy 2000-2004
7 //
8 // Distributed under the Boost Software License, Version 1.0.
9 // (See accompanying file LICENSE_1_0.txt or copy at
10 // http://www.boost.org/LICENSE_1_0.txt)
11 //
12 // See http://www.boost.org/libs/mpl for documentation.
13 
14 // $Id$
15 // $Date$
16 // $Revision$
17 
18 #include <boost/preprocessor/enum_params.hpp>
19 #include <boost/preprocessor/enum_shifted_params.hpp>
20 #include <boost/preprocessor/comma_if.hpp>
21 #include <boost/preprocessor/repeat.hpp>
22 #include <boost/preprocessor/dec.hpp>
23 #include <boost/preprocessor/cat.hpp>
24 
25 #define i_ BOOST_PP_FRAME_ITERATION(1)
26 
27 #if defined(BOOST_MPL_CFG_TYPEOF_BASED_SEQUENCES)
28 
29 #   define AUX778076_VECTOR_TAIL(vector, i_, T) \
30     BOOST_PP_CAT(vector,i_)< \
31           BOOST_PP_ENUM_PARAMS(i_, T) \
32         > \
33     /**/
34 
35 #if i_ > 0
36 template<
37       BOOST_PP_ENUM_PARAMS(i_, typename T)
38     >
BOOST_PP_CAT(vector,i_)39 struct BOOST_PP_CAT(vector,i_)
40     : v_item<
41           BOOST_PP_CAT(T,BOOST_PP_DEC(i_))
42         , AUX778076_VECTOR_TAIL(vector,BOOST_PP_DEC(i_),T)
43         >
44 {
45     typedef BOOST_PP_CAT(vector,i_) type;
46 };
47 #endif
48 
49 #   undef AUX778076_VECTOR_TAIL
50 
51 #else // "brute force" implementation
52 
53 #   if i_ > 0
54 
55 template<
56       BOOST_PP_ENUM_PARAMS(i_, typename T)
57     >
BOOST_PP_CAT(vector,i_)58 struct BOOST_PP_CAT(vector,i_)
59 {
60     typedef aux::vector_tag<i_> tag;
61     typedef BOOST_PP_CAT(vector,i_) type;
62 
63 #   define AUX778076_VECTOR_ITEM(unused, i_, unused2) \
64     typedef BOOST_PP_CAT(T,i_) BOOST_PP_CAT(item,i_); \
65     /**/
66 
67     BOOST_PP_REPEAT(i_, AUX778076_VECTOR_ITEM, unused)
68 #   undef AUX778076_VECTOR_ITEM
69     typedef void_ BOOST_PP_CAT(item,i_);
70     typedef BOOST_PP_CAT(T,BOOST_PP_DEC(i_)) back;
71 
72     // Borland forces us to use 'type' here (instead of the class name)
73     typedef v_iter<type,0> begin;
74     typedef v_iter<type,i_> end;
75 };
76 
77 template<>
78 struct push_front_impl< aux::vector_tag<BOOST_PP_DEC(i_)> >
79 {
80     template< typename Vector, typename T > struct apply
81     {
82         typedef BOOST_PP_CAT(vector,i_)<
83               T
84               BOOST_PP_COMMA_IF(BOOST_PP_DEC(i_))
85               BOOST_PP_ENUM_PARAMS(BOOST_PP_DEC(i_), typename Vector::item)
86             > type;
87     };
88 };
89 
90 template<>
91 struct pop_front_impl< aux::vector_tag<i_> >
92 {
93     template< typename Vector > struct apply
94     {
95         typedef BOOST_PP_CAT(vector,BOOST_PP_DEC(i_))<
96               BOOST_PP_ENUM_SHIFTED_PARAMS(i_, typename Vector::item)
97             > type;
98     };
99 };
100 
101 
102 template<>
103 struct push_back_impl< aux::vector_tag<BOOST_PP_DEC(i_)> >
104 {
105     template< typename Vector, typename T > struct apply
106     {
107         typedef BOOST_PP_CAT(vector,i_)<
108               BOOST_PP_ENUM_PARAMS(BOOST_PP_DEC(i_), typename Vector::item)
109               BOOST_PP_COMMA_IF(BOOST_PP_DEC(i_))
110               T
111             > type;
112     };
113 };
114 
115 template<>
116 struct pop_back_impl< aux::vector_tag<i_> >
117 {
118     template< typename Vector > struct apply
119     {
120         typedef BOOST_PP_CAT(vector,BOOST_PP_DEC(i_))<
121               BOOST_PP_ENUM_PARAMS(BOOST_PP_DEC(i_), typename Vector::item)
122             > type;
123     };
124 };
125 
126 #   endif // i_ > 0
127 
128 #   if !defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) \
129     && !defined(BOOST_MPL_CFG_NO_NONTYPE_TEMPLATE_PARTIAL_SPEC)
130 
131 template< typename V >
132 struct v_at<V,i_>
133 {
134     typedef typename V::BOOST_PP_CAT(item,i_) type;
135 };
136 
137 #   else
138 
139 namespace aux {
140 template<> struct v_at_impl<i_>
141 {
142     template< typename V_ > struct result_
143     {
144         typedef typename V_::BOOST_PP_CAT(item,i_) type;
145     };
146 };
147 }
148 
149 template<>
150 struct at_impl< aux::vector_tag<i_> >
151 {
152     template< typename V_, typename N > struct apply
153     {
154         typedef typename aux::v_at_impl<BOOST_MPL_AUX_VALUE_WKND(N)::value>
155             ::template result_<V_>::type type;
156     };
157 };
158 
159 #if i_ > 0
160 template<>
161 struct front_impl< aux::vector_tag<i_> >
162 {
163     template< typename Vector > struct apply
164     {
165         typedef typename Vector::item0 type;
166     };
167 };
168 
169 template<>
170 struct back_impl< aux::vector_tag<i_> >
171 {
172     template< typename Vector > struct apply
173     {
174         typedef typename Vector::back type;
175     };
176 };
177 
178 template<>
179 struct empty_impl< aux::vector_tag<i_> >
180 {
181     template< typename Vector > struct apply
182         : false_
183     {
184     };
185 };
186 #endif
187 
188 template<>
189 struct size_impl< aux::vector_tag<i_> >
190 {
191     template< typename Vector > struct apply
192         : long_<i_>
193     {
194     };
195 };
196 
197 template<>
198 struct O1_size_impl< aux::vector_tag<i_> >
199     : size_impl< aux::vector_tag<i_> >
200 {
201 };
202 
203 template<>
204 struct clear_impl< aux::vector_tag<i_> >
205 {
206     template< typename Vector > struct apply
207     {
208         typedef vector0<> type;
209     };
210 };
211 
212 #   endif // BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
213 
214 #endif // BOOST_MPL_CFG_TYPEOF_BASED_SEQUENCES
215 
216 #undef i_
217 
218 #endif // BOOST_PP_IS_ITERATING
219