| 
									
										
										
										
											2006-08-06 20:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-21 20:23:37 +00:00
										 |  |  | // Copyright 2005-2010 Daniel James.
 | 
					
						
							| 
									
										
										
										
											2006-08-06 20:42:45 +00:00
										 |  |  | // Distributed under the Boost Software License, Version 1.0. (See accompanying
 | 
					
						
							|  |  |  | // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if !defined(BOOST_UNORDERED_TEST_HELPERS_INPUT_ITERATOR_HEADER)
 | 
					
						
							|  |  |  | #define BOOST_UNORDERED_TEST_HELPERS_INPUT_ITERATOR_HEADER
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-23 17:53:59 +00:00
										 |  |  | #include <boost/config.hpp>
 | 
					
						
							| 
									
										
										
										
											2016-05-26 09:23:01 +01:00
										 |  |  | #include <iterator>
 | 
					
						
							| 
									
										
										
										
											2006-08-06 20:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | namespace test { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   template <class Iterator> struct proxy | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2018-01-27 09:39:59 +00:00
										 |  |  |     typedef typename Iterator::value_type value_type; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     explicit proxy(value_type const& v) : v_(v) {} | 
					
						
							|  |  |  |     proxy(proxy const& x) : v_(x.v_) {} | 
					
						
							|  |  |  |     operator value_type const&() const { return v_; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     value_type v_; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     proxy& operator=(proxy const&); | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-28 11:44:57 +00:00
										 |  |  |   template <class Iterator> struct input_iterator_adaptor | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2018-01-27 09:39:59 +00:00
										 |  |  |     typedef typename std::iterator_traits<Iterator>::value_type value_type; | 
					
						
							|  |  |  |     typedef typename std::iterator_traits<Iterator>::pointer pointer; | 
					
						
							| 
									
										
										
										
											2017-12-28 12:00:59 +01:00
										 |  |  |     typedef proxy<Iterator> reference; | 
					
						
							|  |  |  |     typedef std::ptrdiff_t difference_type; | 
					
						
							|  |  |  |     typedef std::input_iterator_tag iterator_category; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     input_iterator_adaptor() : base_() {} | 
					
						
							|  |  |  |     explicit input_iterator_adaptor(Iterator& it) : base_(&it) {} | 
					
						
							|  |  |  |     proxy<Iterator> operator*() const { return proxy<Iterator>(**base_); } | 
					
						
							|  |  |  |     value_type* operator->() const { return &**base_; } | 
					
						
							|  |  |  |     input_iterator_adaptor& operator++() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       ++*base_; | 
					
						
							|  |  |  |       return *this; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     // input_iterator_adaptor operator++(int) {
 | 
					
						
							|  |  |  |     //}
 | 
					
						
							|  |  |  |     bool operator==(input_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return *base_ == *x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator!=(input_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return *base_ != *x.base_; | 
					
						
							| 
									
										
										
										
											2010-10-21 20:23:37 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |   private: | 
					
						
							|  |  |  |     Iterator* base_; | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   template <class Iterator> | 
					
						
							|  |  |  |   input_iterator_adaptor<Iterator> input_iterator(Iterator& it) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     return input_iterator_adaptor<Iterator>(it); | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2006-08-06 20:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-28 11:44:57 +00:00
										 |  |  |   template <class Iterator> struct copy_iterator_adaptor | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2018-01-27 09:39:59 +00:00
										 |  |  |     typedef typename std::iterator_traits<Iterator>::value_type value_type; | 
					
						
							|  |  |  |     typedef | 
					
						
							|  |  |  |       typename std::iterator_traits<Iterator>::difference_type difference_type; | 
					
						
							|  |  |  |     typedef typename std::iterator_traits<Iterator>::iterator_category | 
					
						
							|  |  |  |       iterator_category; | 
					
						
							|  |  |  |     typedef typename std::iterator_traits<Iterator>::pointer pointer; | 
					
						
							| 
									
										
										
										
											2017-12-28 12:00:59 +01:00
										 |  |  |     typedef proxy<Iterator> reference; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     copy_iterator_adaptor() : base_() {} | 
					
						
							|  |  |  |     explicit copy_iterator_adaptor(Iterator const& it) : base_(it) {} | 
					
						
							|  |  |  |     value_type operator*() const { return *base_; } | 
					
						
							|  |  |  |     value_type* operator->() const { return &*base_; } | 
					
						
							|  |  |  |     value_type operator[](difference_type d) { return base_[d]; } | 
					
						
							|  |  |  |     copy_iterator_adaptor& operator++() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       ++base_; | 
					
						
							|  |  |  |       return *this; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor operator++(int) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       copy_iterator_adaptor tmp(*this); | 
					
						
							|  |  |  |       ++base_; | 
					
						
							|  |  |  |       return tmp; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor& operator--() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       --base_; | 
					
						
							|  |  |  |       return *this; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor operator--(int) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       copy_iterator_adaptor tmp(*this); | 
					
						
							|  |  |  |       --base_; | 
					
						
							|  |  |  |       return tmp; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor operator+=(difference_type x) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       base_ += x; | 
					
						
							|  |  |  |       return *this; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor operator-=(difference_type x) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       base_ -= x; | 
					
						
							|  |  |  |       return *this; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor operator+(difference_type n) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return copy_iterator_adaptor(base_ + n); | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     copy_iterator_adaptor operator-(difference_type n) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return copy_iterator_adaptor(base_ - n); | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     friend copy_iterator_adaptor operator+( | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       difference_type n, copy_iterator_adaptor x) | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return x + n; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     difference_type operator-(copy_iterator_adaptor const& other) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ - other.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator==(copy_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ == x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator!=(copy_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ != x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator<(copy_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ < x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator>(copy_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ > x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator<=(copy_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ <= x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     bool operator>=(copy_iterator_adaptor const& x) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |       return base_ >= x.base_; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2006-08-06 20:42:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |   private: | 
					
						
							|  |  |  |     Iterator base_; | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   template <class Iterator> | 
					
						
							|  |  |  |   copy_iterator_adaptor<Iterator> copy_iterator(Iterator const& it) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  |     return copy_iterator_adaptor<Iterator>(it); | 
					
						
							| 
									
										
										
										
											2017-06-11 20:55:59 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-02-19 13:05:17 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |