2 // Copyright 2005-2010 Daniel James.
3 // Distributed under the Boost Software License, Version 1.0. (See accompanying
4 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6 #if !defined(BOOST_UNORDERED_TEST_HELPERS_INPUT_ITERATOR_HEADER)
7 #define BOOST_UNORDERED_TEST_HELPERS_INPUT_ITERATOR_HEADER
9 #include <boost/config.hpp>
10 #include <boost/iterator/iterator_traits.hpp>
14 template <class Iterator> struct proxy
16 typedef BOOST_DEDUCED_TYPENAME Iterator::value_type value_type;
18 explicit proxy(value_type const& v) : v_(v) {}
19 proxy(proxy const& x) : v_(x.v_) {}
20 operator value_type const&() const { return v_; }
25 proxy& operator=(proxy const&);
28 template <class Iterator>
29 struct input_iterator_adaptor
30 : public std::iterator<std::input_iterator_tag,
31 BOOST_DEDUCED_TYPENAME boost::iterator_value<Iterator>::type,
33 BOOST_DEDUCED_TYPENAME boost::iterator_pointer<Iterator>::type,
36 typedef BOOST_DEDUCED_TYPENAME boost::iterator_value<Iterator>::type
39 input_iterator_adaptor() : base_() {}
40 explicit input_iterator_adaptor(Iterator& it) : base_(&it) {}
41 proxy<Iterator> operator*() const { return proxy<Iterator>(**base_); }
42 value_type* operator->() const { return &**base_; }
43 input_iterator_adaptor& operator++()
48 // input_iterator_adaptor operator++(int) {
50 bool operator==(input_iterator_adaptor const& x) const
52 return *base_ == *x.base_;
54 bool operator!=(input_iterator_adaptor const& x) const
56 return *base_ != *x.base_;
63 template <class Iterator>
64 input_iterator_adaptor<Iterator> input_iterator(Iterator& it)
66 return input_iterator_adaptor<Iterator>(it);
69 template <class Iterator>
70 struct copy_iterator_adaptor
71 : public std::iterator<
72 BOOST_DEDUCED_TYPENAME boost::iterator_category<Iterator>::type,
73 BOOST_DEDUCED_TYPENAME boost::iterator_value<Iterator>::type,
74 BOOST_DEDUCED_TYPENAME boost::iterator_difference<Iterator>::type,
75 BOOST_DEDUCED_TYPENAME boost::iterator_pointer<Iterator>::type,
78 typedef BOOST_DEDUCED_TYPENAME boost::iterator_value<Iterator>::type
80 typedef BOOST_DEDUCED_TYPENAME boost::iterator_difference<Iterator>::type
83 copy_iterator_adaptor() : base_() {}
84 explicit copy_iterator_adaptor(Iterator const& it) : base_(it) {}
85 value_type operator*() const { return *base_; }
86 value_type* operator->() const { return &*base_; }
87 value_type operator[](difference_type d) { return base_[d]; }
88 copy_iterator_adaptor& operator++()
93 copy_iterator_adaptor operator++(int)
95 copy_iterator_adaptor tmp(*this);
99 copy_iterator_adaptor& operator--()
104 copy_iterator_adaptor operator--(int)
106 copy_iterator_adaptor tmp(*this);
110 copy_iterator_adaptor operator+=(difference_type x)
115 copy_iterator_adaptor operator-=(difference_type x)
120 copy_iterator_adaptor operator+(difference_type n)
122 return copy_iterator_adaptor(base_ + n);
124 copy_iterator_adaptor operator-(difference_type n)
126 return copy_iterator_adaptor(base_ - n);
128 friend copy_iterator_adaptor operator+(
129 difference_type n, copy_iterator_adaptor x)
133 difference_type operator-(copy_iterator_adaptor const& other)
135 return base_ - other.base_;
137 bool operator==(copy_iterator_adaptor const& x) const
139 return base_ == x.base_;
141 bool operator!=(copy_iterator_adaptor const& x) const
143 return base_ != x.base_;
145 bool operator<(copy_iterator_adaptor const& x) const
147 return base_ < x.base_;
149 bool operator>(copy_iterator_adaptor const& x) const
151 return base_ > x.base_;
153 bool operator<=(copy_iterator_adaptor const& x) const
155 return base_ <= x.base_;
157 bool operator>=(copy_iterator_adaptor const& x) const
159 return base_ >= x.base_;
166 template <class Iterator>
167 copy_iterator_adaptor<Iterator> copy_iterator(Iterator const& it)
169 return copy_iterator_adaptor<Iterator>(it);