]> AND Private Git Repository - canny.git/blob - stc/exp/ml_stc_linux_make_v1.0/include/boost/iterator/iterator_categories.hpp
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
9a0be36cce37137be2c1a5ebf523dee195a13dc2
[canny.git] / stc / exp / ml_stc_linux_make_v1.0 / include / boost / iterator / iterator_categories.hpp
1 // (C) Copyright Jeremy Siek 2002.\r
2 // Distributed under the Boost Software License, Version 1.0. (See\r
3 // accompanying file LICENSE_1_0.txt or copy at\r
4 // http://www.boost.org/LICENSE_1_0.txt)\r
5 \r
6 #ifndef BOOST_ITERATOR_CATEGORIES_HPP\r
7 # define BOOST_ITERATOR_CATEGORIES_HPP\r
8 \r
9 # include <boost/config.hpp>\r
10 # include <boost/detail/iterator.hpp>\r
11 # include <boost/iterator/detail/config_def.hpp>\r
12 \r
13 # include <boost/detail/workaround.hpp>\r
14 \r
15 # include <boost/mpl/eval_if.hpp>\r
16 # include <boost/mpl/identity.hpp>\r
17 # include <boost/mpl/placeholders.hpp>\r
18 # include <boost/mpl/aux_/lambda_support.hpp>\r
19 \r
20 # include <boost/type_traits/is_convertible.hpp>\r
21 \r
22 # include <boost/static_assert.hpp>\r
23 \r
24 namespace boost {\r
25 \r
26 //\r
27 // Traversal Categories\r
28 //\r
29 \r
30 struct no_traversal_tag {};\r
31 \r
32 struct incrementable_traversal_tag \r
33   : no_traversal_tag\r
34 {\r
35 //     incrementable_traversal_tag() {}\r
36 //     incrementable_traversal_tag(std::output_iterator_tag const&) {};\r
37 };\r
38   \r
39 struct single_pass_traversal_tag\r
40   : incrementable_traversal_tag\r
41 {\r
42 //     single_pass_traversal_tag() {}\r
43 //     single_pass_traversal_tag(std::input_iterator_tag const&) {};\r
44 };\r
45   \r
46 struct forward_traversal_tag\r
47   : single_pass_traversal_tag\r
48 {\r
49 //     forward_traversal_tag() {}\r
50 //     forward_traversal_tag(std::forward_iterator_tag const&) {};\r
51 };\r
52   \r
53 struct bidirectional_traversal_tag\r
54   : forward_traversal_tag\r
55 {\r
56 //     bidirectional_traversal_tag() {};\r
57 //     bidirectional_traversal_tag(std::bidirectional_iterator_tag const&) {};\r
58 };\r
59   \r
60 struct random_access_traversal_tag\r
61   : bidirectional_traversal_tag\r
62 {\r
63 //     random_access_traversal_tag() {};\r
64 //     random_access_traversal_tag(std::random_access_iterator_tag const&) {};\r
65 };\r
66 \r
67 namespace detail\r
68 {  \r
69   //\r
70   // Convert a "strictly old-style" iterator category to a traversal\r
71   // tag.  This is broken out into a separate metafunction to reduce\r
72   // the cost of instantiating iterator_category_to_traversal, below,\r
73   // for new-style types.\r
74   //\r
75   template <class Cat>\r
76   struct old_category_to_traversal\r
77     : mpl::eval_if<\r
78           is_convertible<Cat,std::random_access_iterator_tag>\r
79         , mpl::identity<random_access_traversal_tag>\r
80         , mpl::eval_if<\r
81               is_convertible<Cat,std::bidirectional_iterator_tag>\r
82             , mpl::identity<bidirectional_traversal_tag>\r
83             , mpl::eval_if<\r
84                   is_convertible<Cat,std::forward_iterator_tag>\r
85                 , mpl::identity<forward_traversal_tag>\r
86                 , mpl::eval_if<\r
87                       is_convertible<Cat,std::input_iterator_tag>\r
88                     , mpl::identity<single_pass_traversal_tag>\r
89                     , mpl::eval_if<\r
90                           is_convertible<Cat,std::output_iterator_tag>\r
91                         , mpl::identity<incrementable_traversal_tag>\r
92                         , void\r
93                       >\r
94                   >\r
95               >\r
96           >\r
97       >\r
98   {};\r
99 \r
100 # if BOOST_WORKAROUND(BOOST_MSVC, < 1300)\r
101   template <>\r
102   struct old_category_to_traversal<int>\r
103   {\r
104       typedef int type;\r
105   };\r
106 # endif\r
107 \r
108   template <class Traversal>\r
109   struct pure_traversal_tag\r
110     : mpl::eval_if<\r
111           is_convertible<Traversal,random_access_traversal_tag>\r
112         , mpl::identity<random_access_traversal_tag>\r
113         , mpl::eval_if<\r
114               is_convertible<Traversal,bidirectional_traversal_tag>\r
115             , mpl::identity<bidirectional_traversal_tag>\r
116             , mpl::eval_if<\r
117                   is_convertible<Traversal,forward_traversal_tag>\r
118                 , mpl::identity<forward_traversal_tag>\r
119                 , mpl::eval_if<\r
120                       is_convertible<Traversal,single_pass_traversal_tag>\r
121                     , mpl::identity<single_pass_traversal_tag>\r
122                     , mpl::eval_if<\r
123                           is_convertible<Traversal,incrementable_traversal_tag>\r
124                         , mpl::identity<incrementable_traversal_tag>\r
125                         , void\r
126                       >\r
127                   >\r
128               >\r
129           >\r
130       >\r
131   {\r
132   };\r
133   \r
134 # if BOOST_WORKAROUND(BOOST_MSVC, < 1300)\r
135   template <>\r
136   struct pure_traversal_tag<int>\r
137   {\r
138       typedef int type;\r
139   };\r
140 # endif\r
141 \r
142 } // namespace detail\r
143 \r
144 \r
145 //\r
146 // Convert an iterator category into a traversal tag\r
147 //\r
148 template <class Cat>\r
149 struct iterator_category_to_traversal\r
150   : mpl::eval_if< // if already convertible to a traversal tag, we're done.\r
151         is_convertible<Cat,incrementable_traversal_tag>\r
152       , mpl::identity<Cat>\r
153       , boost::detail::old_category_to_traversal<Cat>\r
154     >\r
155 {};\r
156 \r
157 // Trait to get an iterator's traversal category\r
158 template <class Iterator = mpl::_1>\r
159 struct iterator_traversal\r
160   : iterator_category_to_traversal<\r
161         typename boost::detail::iterator_traits<Iterator>::iterator_category\r
162     >\r
163 {};\r
164 \r
165 # ifdef BOOST_MPL_CFG_NO_FULL_LAMBDA_SUPPORT\r
166 // Hack because BOOST_MPL_AUX_LAMBDA_SUPPORT doesn't seem to work\r
167 // out well.  Instantiating the nested apply template also\r
168 // requires instantiating iterator_traits on the\r
169 // placeholder. Instead we just specialize it as a metafunction\r
170 // class.\r
171 template <>\r
172 struct iterator_traversal<mpl::_1>\r
173 {\r
174     template <class T>\r
175     struct apply : iterator_traversal<T>\r
176     {};\r
177 };\r
178 template <>\r
179 struct iterator_traversal<mpl::_>\r
180   : iterator_traversal<mpl::_1>\r
181 {};\r
182 # endif\r
183 \r
184 } // namespace boost\r
185 \r
186 #include <boost/iterator/detail/config_undef.hpp>\r
187 \r
188 #endif // BOOST_ITERATOR_CATEGORIES_HPP\r