1 // (C) Copyright Jeremy Siek 2002.
2 // Distributed under the Boost Software License, Version 1.0. (See
3 // accompanying file LICENSE_1_0.txt or copy at
4 // http://www.boost.org/LICENSE_1_0.txt)
6 #ifndef BOOST_ITERATOR_CONCEPTS_HPP
7 #define BOOST_ITERATOR_CONCEPTS_HPP
9 #include <boost/concept_check.hpp>
10 #include <boost/iterator/iterator_categories.hpp>
12 #include <boost/type_traits/is_same.hpp>
13 #include <boost/type_traits/is_integral.hpp>
15 #include <boost/mpl/bool.hpp>
16 #include <boost/mpl/if.hpp>
17 #include <boost/mpl/and.hpp>
18 #include <boost/mpl/or.hpp>
20 #include <boost/static_assert.hpp>
22 // Use boost/limits to work around missing limits headers on some compilers
23 #include <boost/limits.hpp>
24 #include <boost/config.hpp>
29 #include <boost/concept/detail/concept_def.hpp>
31 namespace boost_concepts
33 // Used a different namespace here (instead of "boost") so that the
34 // concept descriptions do not take for granted the names in
37 //===========================================================================
38 // Iterator Access Concepts
40 BOOST_concept(ReadableIterator,(Iterator))
41 : boost::Assignable<Iterator>
42 , boost::CopyConstructible<Iterator>
45 typedef BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::value_type value_type;
46 typedef BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::reference reference;
48 BOOST_CONCEPT_USAGE(ReadableIterator)
52 boost::ignore_unused_variable_warning(v);
60 , typename ValueType = BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::value_type
62 struct WritableIterator
63 : boost::CopyConstructible<Iterator>
65 BOOST_CONCEPT_USAGE(WritableIterator)
76 , typename ValueType = BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::value_type
78 struct WritableIteratorConcept : WritableIterator<Iterator,ValueType> {};
80 BOOST_concept(SwappableIterator,(Iterator))
82 BOOST_CONCEPT_USAGE(SwappableIterator)
84 std::iter_swap(i1, i2);
91 BOOST_concept(LvalueIterator,(Iterator))
93 typedef typename std::iterator_traits<Iterator>::value_type value_type;
95 BOOST_CONCEPT_USAGE(LvalueIterator)
97 value_type& r = const_cast<value_type&>(*i);
98 boost::ignore_unused_variable_warning(r);
105 //===========================================================================
106 // Iterator Traversal Concepts
108 BOOST_concept(IncrementableIterator,(Iterator))
109 : boost::Assignable<Iterator>
110 , boost::CopyConstructible<Iterator>
112 typedef typename boost::iterator_traversal<Iterator>::type traversal_category;
114 BOOST_CONCEPT_ASSERT((
117 , boost::incrementable_traversal_tag
120 BOOST_CONCEPT_USAGE(IncrementableIterator)
129 BOOST_concept(SinglePassIterator,(Iterator))
130 : IncrementableIterator<Iterator>
131 , boost::EqualityComparable<Iterator>
134 BOOST_CONCEPT_ASSERT((
136 BOOST_DEDUCED_TYPENAME SinglePassIterator::traversal_category
137 , boost::single_pass_traversal_tag
141 BOOST_concept(ForwardTraversal,(Iterator))
142 : SinglePassIterator<Iterator>
143 , boost::DefaultConstructible<Iterator>
145 typedef typename std::iterator_traits<Iterator>::difference_type difference_type;
147 BOOST_MPL_ASSERT((boost::is_integral<difference_type>));
148 BOOST_MPL_ASSERT_RELATION(std::numeric_limits<difference_type>::is_signed, ==, true);
150 BOOST_CONCEPT_ASSERT((
152 BOOST_DEDUCED_TYPENAME ForwardTraversal::traversal_category
153 , boost::forward_traversal_tag
157 BOOST_concept(BidirectionalTraversal,(Iterator))
158 : ForwardTraversal<Iterator>
160 BOOST_CONCEPT_ASSERT((
162 BOOST_DEDUCED_TYPENAME BidirectionalTraversal::traversal_category
163 , boost::bidirectional_traversal_tag
166 BOOST_CONCEPT_USAGE(BidirectionalTraversal)
175 BOOST_concept(RandomAccessTraversal,(Iterator))
176 : BidirectionalTraversal<Iterator>
178 BOOST_CONCEPT_ASSERT((
180 BOOST_DEDUCED_TYPENAME RandomAccessTraversal::traversal_category
181 , boost::random_access_traversal_tag
184 BOOST_CONCEPT_USAGE(RandomAccessTraversal)
195 typename BidirectionalTraversal<Iterator>::difference_type n;
199 //===========================================================================
200 // Iterator Interoperability
204 template <typename Iterator1, typename Iterator2>
205 void interop_single_pass_constraints(Iterator1 const& i1, Iterator2 const& i2)
213 boost::ignore_unused_variable_warning(b);
216 template <typename Iterator1, typename Iterator2>
217 void interop_rand_access_constraints(
218 Iterator1 const& i1, Iterator2 const& i2,
219 boost::random_access_traversal_tag, boost::random_access_traversal_tag)
222 typename std::iterator_traits<Iterator2>::difference_type n;
234 boost::ignore_unused_variable_warning(b);
235 boost::ignore_unused_variable_warning(n);
238 template <typename Iterator1, typename Iterator2>
239 void interop_rand_access_constraints(
240 Iterator1 const&, Iterator2 const&,
241 boost::single_pass_traversal_tag, boost::single_pass_traversal_tag)
244 } // namespace detail
246 BOOST_concept(InteroperableIterator,(Iterator)(ConstIterator))
249 typedef typename boost::iterators::pure_iterator_traversal<Iterator>::type traversal_category;
250 typedef typename boost::iterators::pure_iterator_traversal<ConstIterator>::type const_traversal_category;
253 BOOST_CONCEPT_ASSERT((SinglePassIterator<Iterator>));
254 BOOST_CONCEPT_ASSERT((SinglePassIterator<ConstIterator>));
256 BOOST_CONCEPT_USAGE(InteroperableIterator)
258 detail::interop_single_pass_constraints(i, ci);
259 detail::interop_rand_access_constraints(i, ci, traversal_category(), const_traversal_category());
269 } // namespace boost_concepts
271 #include <boost/concept/detail/concept_undef.hpp>
273 #endif // BOOST_ITERATOR_CONCEPTS_HPP