3 // Copyright Neil Groves 2010. Use, modification and
4 // distribution is subject to the Boost Software License, Version
5 // 1.0. (See accompanying file LICENSE_1_0.txt or copy at
6 // http://www.boost.org/LICENSE_1_0.txt)
8 // For more information, see http://www.boost.org/libs/range/
10 #ifndef BOOST_RANGE_DETAIL_ANY_ITERATOR_INTERFACE_HPP_INCLUDED
11 #define BOOST_RANGE_DETAIL_ANY_ITERATOR_INTERFACE_HPP_INCLUDED
13 #include <boost/range/detail/any_iterator_buffer.hpp>
14 #include <boost/iterator/iterator_categories.hpp>
15 #include <boost/type_traits/add_const.hpp>
16 #include <boost/type_traits/add_reference.hpp>
17 #include <boost/type_traits/is_reference.hpp>
18 #include <boost/type_traits/remove_const.hpp>
19 #include <boost/type_traits/remove_reference.hpp>
23 namespace range_detail
26 struct const_reference_type_generator
28 typedef typename mpl::if_<
29 typename is_reference<T>::type,
31 typename remove_reference<T>::type
38 struct mutable_reference_type_generator
40 typedef typename mpl::if_<
42 typename is_const<T>::type,
43 typename mpl::not_<typename is_reference<T>::type>::type
46 typename add_reference<T>::type
54 struct any_incrementable_iterator_interface
56 typedef typename mutable_reference_type_generator<
60 typedef typename const_reference_type_generator<
62 >::type const_reference;
64 typedef typename remove_const<
65 typename remove_reference<Reference>::type
66 >::type reference_as_value_type;
68 typedef Buffer buffer_type;
70 virtual ~any_incrementable_iterator_interface() {}
72 virtual any_incrementable_iterator_interface*
73 clone(buffer_type& buffer) const = 0;
75 virtual any_incrementable_iterator_interface<const_reference, Buffer>*
76 clone_const_ref(buffer_type& buffer) const = 0;
78 virtual any_incrementable_iterator_interface<reference_as_value_type, Buffer>*
79 clone_reference_as_value(buffer_type& buffer) const = 0;
81 virtual void increment() = 0;
88 struct any_single_pass_iterator_interface
89 : any_incrementable_iterator_interface<Reference, Buffer>
91 typedef typename any_incrementable_iterator_interface<Reference, Buffer>::reference reference;
92 typedef typename any_incrementable_iterator_interface<Reference, Buffer>::const_reference const_reference;
93 typedef typename any_incrementable_iterator_interface<Reference, Buffer>::buffer_type buffer_type;
94 typedef typename any_incrementable_iterator_interface<Reference, Buffer>::reference_as_value_type reference_as_value_type;
96 virtual any_single_pass_iterator_interface*
97 clone(buffer_type& buffer) const = 0;
99 virtual any_single_pass_iterator_interface<const_reference, Buffer>*
100 clone_const_ref(buffer_type& buffer) const = 0;
102 virtual any_single_pass_iterator_interface<reference_as_value_type, Buffer>*
103 clone_reference_as_value(buffer_type& buffer) const = 0;
105 virtual reference dereference() const = 0;
107 virtual bool equal(const any_single_pass_iterator_interface& other) const = 0;
114 struct any_forward_iterator_interface
115 : any_single_pass_iterator_interface<Reference, Buffer>
117 typedef typename any_single_pass_iterator_interface<Reference, Buffer>::reference reference;
118 typedef typename any_single_pass_iterator_interface<Reference, Buffer>::const_reference const_reference;
119 typedef typename any_single_pass_iterator_interface<Reference, Buffer>::buffer_type buffer_type;
120 typedef typename any_single_pass_iterator_interface<Reference, Buffer>::reference_as_value_type reference_as_value_type;
122 virtual any_forward_iterator_interface*
123 clone(buffer_type& buffer) const = 0;
125 virtual any_forward_iterator_interface<const_reference, Buffer>*
126 clone_const_ref(buffer_type& buffer) const = 0;
128 virtual any_forward_iterator_interface<reference_as_value_type, Buffer>*
129 clone_reference_as_value(buffer_type& buffer) const = 0;
136 struct any_bidirectional_iterator_interface
137 : any_forward_iterator_interface<Reference, Buffer>
139 typedef typename any_forward_iterator_interface<Reference, Buffer>::reference reference;
140 typedef typename any_forward_iterator_interface<Reference, Buffer>::const_reference const_reference;
141 typedef typename any_forward_iterator_interface<Reference, Buffer>::buffer_type buffer_type;
142 typedef typename any_forward_iterator_interface<Reference, Buffer>::reference_as_value_type reference_as_value_type;
144 virtual any_bidirectional_iterator_interface*
145 clone(buffer_type& buffer) const = 0;
147 virtual any_bidirectional_iterator_interface<const_reference, Buffer>*
148 clone_const_ref(buffer_type& buffer) const = 0;
150 virtual any_bidirectional_iterator_interface<reference_as_value_type, Buffer>*
151 clone_reference_as_value(buffer_type& buffer) const = 0;
153 virtual void decrement() = 0;
161 struct any_random_access_iterator_interface
162 : any_bidirectional_iterator_interface<
167 typedef typename any_bidirectional_iterator_interface<Reference, Buffer>::reference reference;
168 typedef typename any_bidirectional_iterator_interface<Reference, Buffer>::const_reference const_reference;
169 typedef typename any_bidirectional_iterator_interface<Reference, Buffer>::buffer_type buffer_type;
170 typedef typename any_bidirectional_iterator_interface<Reference, Buffer>::reference_as_value_type reference_as_value_type;
171 typedef Difference difference_type;
173 virtual any_random_access_iterator_interface*
174 clone(buffer_type& buffer) const = 0;
176 virtual any_random_access_iterator_interface<const_reference, Difference, Buffer>*
177 clone_const_ref(buffer_type& buffer) const = 0;
179 virtual any_random_access_iterator_interface<reference_as_value_type, Difference, Buffer>*
180 clone_reference_as_value(buffer_type& buffer) const = 0;
182 virtual void advance(Difference offset) = 0;
184 virtual Difference distance_to(const any_random_access_iterator_interface& other) const = 0;
193 struct any_iterator_interface_type_generator;
200 struct any_iterator_interface_type_generator<
201 incrementable_traversal_tag
207 typedef any_incrementable_iterator_interface<Reference, Buffer> type;
215 struct any_iterator_interface_type_generator<
216 single_pass_traversal_tag
222 typedef any_single_pass_iterator_interface<Reference, Buffer> type;
230 struct any_iterator_interface_type_generator<
231 forward_traversal_tag
237 typedef any_forward_iterator_interface<Reference, Buffer> type;
245 struct any_iterator_interface_type_generator<
246 bidirectional_traversal_tag
252 typedef any_bidirectional_iterator_interface<Reference, Buffer> type;
260 struct any_iterator_interface_type_generator<
261 random_access_traversal_tag
267 typedef any_random_access_iterator_interface<
274 } // namespace range_detail
277 #endif // include guard