annotate DEPENDENCIES/generic/include/boost/iterator/iterator_concepts.hpp @ 125:34e428693f5d vext

Vext -> Repoint
author Chris Cannam
date Thu, 14 Jun 2018 11:15:39 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 // (C) Copyright Jeremy Siek 2002.
Chris@16 2 // Distributed under the Boost Software License, Version 1.0. (See
Chris@16 3 // accompanying file LICENSE_1_0.txt or copy at
Chris@16 4 // http://www.boost.org/LICENSE_1_0.txt)
Chris@16 5
Chris@16 6 #ifndef BOOST_ITERATOR_CONCEPTS_HPP
Chris@16 7 #define BOOST_ITERATOR_CONCEPTS_HPP
Chris@16 8
Chris@16 9 #include <boost/concept_check.hpp>
Chris@16 10 #include <boost/iterator/iterator_categories.hpp>
Chris@16 11
Chris@16 12 // Use boost::detail::iterator_traits to work around some MSVC/Dinkumware problems.
Chris@16 13 #include <boost/detail/iterator.hpp>
Chris@16 14
Chris@16 15 #include <boost/type_traits/is_same.hpp>
Chris@16 16 #include <boost/type_traits/is_integral.hpp>
Chris@16 17
Chris@16 18 #include <boost/mpl/bool.hpp>
Chris@16 19 #include <boost/mpl/if.hpp>
Chris@16 20 #include <boost/mpl/and.hpp>
Chris@16 21 #include <boost/mpl/or.hpp>
Chris@16 22
Chris@16 23 #include <boost/static_assert.hpp>
Chris@16 24
Chris@16 25 // Use boost/limits to work around missing limits headers on some compilers
Chris@16 26 #include <boost/limits.hpp>
Chris@16 27 #include <boost/config.hpp>
Chris@16 28
Chris@16 29 #include <algorithm>
Chris@16 30
Chris@16 31 #include <boost/concept/detail/concept_def.hpp>
Chris@16 32
Chris@16 33 namespace boost_concepts
Chris@16 34 {
Chris@16 35 // Used a different namespace here (instead of "boost") so that the
Chris@16 36 // concept descriptions do not take for granted the names in
Chris@16 37 // namespace boost.
Chris@16 38
Chris@16 39 //===========================================================================
Chris@16 40 // Iterator Access Concepts
Chris@16 41
Chris@16 42 BOOST_concept(ReadableIterator,(Iterator))
Chris@16 43 : boost::Assignable<Iterator>
Chris@16 44 , boost::CopyConstructible<Iterator>
Chris@16 45
Chris@16 46 {
Chris@16 47 typedef BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::value_type value_type;
Chris@16 48 typedef BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::reference reference;
Chris@16 49
Chris@16 50 BOOST_CONCEPT_USAGE(ReadableIterator)
Chris@16 51 {
Chris@16 52
Chris@16 53 value_type v = *i;
Chris@16 54 boost::ignore_unused_variable_warning(v);
Chris@16 55 }
Chris@16 56 private:
Chris@16 57 Iterator i;
Chris@16 58 };
Chris@101 59
Chris@16 60 template <
Chris@16 61 typename Iterator
Chris@16 62 , typename ValueType = BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::value_type
Chris@16 63 >
Chris@16 64 struct WritableIterator
Chris@16 65 : boost::CopyConstructible<Iterator>
Chris@16 66 {
Chris@16 67 BOOST_CONCEPT_USAGE(WritableIterator)
Chris@16 68 {
Chris@16 69 *i = v;
Chris@16 70 }
Chris@16 71 private:
Chris@16 72 ValueType v;
Chris@16 73 Iterator i;
Chris@16 74 };
Chris@16 75
Chris@16 76 template <
Chris@16 77 typename Iterator
Chris@16 78 , typename ValueType = BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::value_type
Chris@16 79 >
Chris@16 80 struct WritableIteratorConcept : WritableIterator<Iterator,ValueType> {};
Chris@101 81
Chris@16 82 BOOST_concept(SwappableIterator,(Iterator))
Chris@16 83 {
Chris@16 84 BOOST_CONCEPT_USAGE(SwappableIterator)
Chris@16 85 {
Chris@16 86 std::iter_swap(i1, i2);
Chris@16 87 }
Chris@16 88 private:
Chris@16 89 Iterator i1;
Chris@16 90 Iterator i2;
Chris@16 91 };
Chris@16 92
Chris@16 93 BOOST_concept(LvalueIterator,(Iterator))
Chris@16 94 {
Chris@16 95 typedef typename boost::detail::iterator_traits<Iterator>::value_type value_type;
Chris@101 96
Chris@16 97 BOOST_CONCEPT_USAGE(LvalueIterator)
Chris@16 98 {
Chris@16 99 value_type& r = const_cast<value_type&>(*i);
Chris@16 100 boost::ignore_unused_variable_warning(r);
Chris@16 101 }
Chris@16 102 private:
Chris@16 103 Iterator i;
Chris@16 104 };
Chris@16 105
Chris@101 106
Chris@16 107 //===========================================================================
Chris@16 108 // Iterator Traversal Concepts
Chris@16 109
Chris@16 110 BOOST_concept(IncrementableIterator,(Iterator))
Chris@16 111 : boost::Assignable<Iterator>
Chris@16 112 , boost::CopyConstructible<Iterator>
Chris@16 113 {
Chris@16 114 typedef typename boost::iterator_traversal<Iterator>::type traversal_category;
Chris@16 115
Chris@16 116 BOOST_CONCEPT_ASSERT((
Chris@16 117 boost::Convertible<
Chris@16 118 traversal_category
Chris@16 119 , boost::incrementable_traversal_tag
Chris@16 120 >));
Chris@16 121
Chris@16 122 BOOST_CONCEPT_USAGE(IncrementableIterator)
Chris@16 123 {
Chris@16 124 ++i;
Chris@16 125 (void)i++;
Chris@16 126 }
Chris@16 127 private:
Chris@16 128 Iterator i;
Chris@16 129 };
Chris@16 130
Chris@16 131 BOOST_concept(SinglePassIterator,(Iterator))
Chris@16 132 : IncrementableIterator<Iterator>
Chris@16 133 , boost::EqualityComparable<Iterator>
Chris@16 134
Chris@16 135 {
Chris@16 136 BOOST_CONCEPT_ASSERT((
Chris@16 137 boost::Convertible<
Chris@16 138 BOOST_DEDUCED_TYPENAME SinglePassIterator::traversal_category
Chris@16 139 , boost::single_pass_traversal_tag
Chris@16 140 > ));
Chris@16 141 };
Chris@16 142
Chris@16 143 BOOST_concept(ForwardTraversal,(Iterator))
Chris@16 144 : SinglePassIterator<Iterator>
Chris@16 145 , boost::DefaultConstructible<Iterator>
Chris@16 146 {
Chris@16 147 typedef typename boost::detail::iterator_traits<Iterator>::difference_type difference_type;
Chris@101 148
Chris@16 149 BOOST_MPL_ASSERT((boost::is_integral<difference_type>));
Chris@16 150 BOOST_MPL_ASSERT_RELATION(std::numeric_limits<difference_type>::is_signed, ==, true);
Chris@16 151
Chris@16 152 BOOST_CONCEPT_ASSERT((
Chris@16 153 boost::Convertible<
Chris@16 154 BOOST_DEDUCED_TYPENAME ForwardTraversal::traversal_category
Chris@16 155 , boost::forward_traversal_tag
Chris@16 156 > ));
Chris@16 157 };
Chris@101 158
Chris@16 159 BOOST_concept(BidirectionalTraversal,(Iterator))
Chris@16 160 : ForwardTraversal<Iterator>
Chris@16 161 {
Chris@16 162 BOOST_CONCEPT_ASSERT((
Chris@16 163 boost::Convertible<
Chris@16 164 BOOST_DEDUCED_TYPENAME BidirectionalTraversal::traversal_category
Chris@16 165 , boost::bidirectional_traversal_tag
Chris@16 166 > ));
Chris@16 167
Chris@16 168 BOOST_CONCEPT_USAGE(BidirectionalTraversal)
Chris@16 169 {
Chris@16 170 --i;
Chris@16 171 (void)i--;
Chris@16 172 }
Chris@16 173 private:
Chris@16 174 Iterator i;
Chris@16 175 };
Chris@16 176
Chris@16 177 BOOST_concept(RandomAccessTraversal,(Iterator))
Chris@16 178 : BidirectionalTraversal<Iterator>
Chris@16 179 {
Chris@16 180 BOOST_CONCEPT_ASSERT((
Chris@16 181 boost::Convertible<
Chris@16 182 BOOST_DEDUCED_TYPENAME RandomAccessTraversal::traversal_category
Chris@16 183 , boost::random_access_traversal_tag
Chris@16 184 > ));
Chris@16 185
Chris@16 186 BOOST_CONCEPT_USAGE(RandomAccessTraversal)
Chris@16 187 {
Chris@16 188 i += n;
Chris@16 189 i = i + n;
Chris@16 190 i = n + i;
Chris@16 191 i -= n;
Chris@16 192 i = i - n;
Chris@16 193 n = i - j;
Chris@16 194 }
Chris@101 195
Chris@16 196 private:
Chris@16 197 typename BidirectionalTraversal<Iterator>::difference_type n;
Chris@16 198 Iterator i, j;
Chris@16 199 };
Chris@16 200
Chris@16 201 //===========================================================================
Chris@101 202 // Iterator Interoperability
Chris@16 203
Chris@16 204 namespace detail
Chris@16 205 {
Chris@16 206 template <typename Iterator1, typename Iterator2>
Chris@16 207 void interop_single_pass_constraints(Iterator1 const& i1, Iterator2 const& i2)
Chris@16 208 {
Chris@16 209 bool b;
Chris@16 210 b = i1 == i2;
Chris@16 211 b = i1 != i2;
Chris@16 212
Chris@16 213 b = i2 == i1;
Chris@16 214 b = i2 != i1;
Chris@16 215 boost::ignore_unused_variable_warning(b);
Chris@16 216 }
Chris@16 217
Chris@16 218 template <typename Iterator1, typename Iterator2>
Chris@16 219 void interop_rand_access_constraints(
Chris@16 220 Iterator1 const& i1, Iterator2 const& i2,
Chris@16 221 boost::random_access_traversal_tag, boost::random_access_traversal_tag)
Chris@16 222 {
Chris@16 223 bool b;
Chris@16 224 typename boost::detail::iterator_traits<Iterator2>::difference_type n;
Chris@16 225 b = i1 < i2;
Chris@16 226 b = i1 <= i2;
Chris@16 227 b = i1 > i2;
Chris@16 228 b = i1 >= i2;
Chris@16 229 n = i1 - i2;
Chris@16 230
Chris@16 231 b = i2 < i1;
Chris@16 232 b = i2 <= i1;
Chris@16 233 b = i2 > i1;
Chris@16 234 b = i2 >= i1;
Chris@16 235 n = i2 - i1;
Chris@16 236 boost::ignore_unused_variable_warning(b);
Chris@16 237 boost::ignore_unused_variable_warning(n);
Chris@16 238 }
Chris@16 239
Chris@16 240 template <typename Iterator1, typename Iterator2>
Chris@16 241 void interop_rand_access_constraints(
Chris@16 242 Iterator1 const&, Iterator2 const&,
Chris@16 243 boost::single_pass_traversal_tag, boost::single_pass_traversal_tag)
Chris@16 244 { }
Chris@16 245
Chris@16 246 } // namespace detail
Chris@16 247
Chris@16 248 BOOST_concept(InteroperableIterator,(Iterator)(ConstIterator))
Chris@16 249 {
Chris@16 250 private:
Chris@101 251 typedef typename boost::iterators::pure_iterator_traversal<Iterator>::type traversal_category;
Chris@101 252 typedef typename boost::iterators::pure_iterator_traversal<ConstIterator>::type const_traversal_category;
Chris@16 253
Chris@101 254 public:
Chris@16 255 BOOST_CONCEPT_ASSERT((SinglePassIterator<Iterator>));
Chris@16 256 BOOST_CONCEPT_ASSERT((SinglePassIterator<ConstIterator>));
Chris@16 257
Chris@16 258 BOOST_CONCEPT_USAGE(InteroperableIterator)
Chris@16 259 {
Chris@16 260 detail::interop_single_pass_constraints(i, ci);
Chris@16 261 detail::interop_rand_access_constraints(i, ci, traversal_category(), const_traversal_category());
Chris@16 262
Chris@16 263 ci = i;
Chris@16 264 }
Chris@101 265
Chris@16 266 private:
Chris@16 267 Iterator i;
Chris@16 268 ConstIterator ci;
Chris@16 269 };
Chris@16 270
Chris@16 271 } // namespace boost_concepts
Chris@16 272
Chris@16 273 #include <boost/concept/detail/concept_undef.hpp>
Chris@16 274
Chris@16 275 #endif // BOOST_ITERATOR_CONCEPTS_HPP