| 
									
										
										
										
											2006-09-11 22:08:18 +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)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | .. Version 1.3 of this ReStructuredText document corresponds to
 | 
					
						
							|  |  |  |    n1530_, the paper accepted by the LWG for TR1.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-11-01 21:23:47 +00:00
										 |  |  | .. Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003. 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | .. parsed-literal::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <
 | 
					
						
							|  |  |  |       class Derived
 | 
					
						
							|  |  |  |     , class Value
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |     , class CategoryOrTraversal
 | 
					
						
							|  |  |  |     , class Reference  = Value&
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  |     , class Difference = ptrdiff_t
 | 
					
						
							|  |  |  |   >
 | 
					
						
							|  |  |  |   class iterator_facade {
 | 
					
						
							| 
									
										
										
										
											2004-07-16 19:58:03 +00:00
										 |  |  |    public:
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |       typedef remove_const<Value>::type value_type;
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  |       typedef Reference reference;
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |       typedef Value\* pointer;
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  |       typedef Difference difference_type;
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |       typedef /* see below__ \*/ iterator_category;
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       reference operator\*() const;
 | 
					
						
							|  |  |  |       /* see below__ \*/ operator->() const;
 | 
					
						
							|  |  |  |       /* see below__ \*/ operator[](difference_type n) const;
 | 
					
						
							|  |  |  |       Derived& operator++();
 | 
					
						
							|  |  |  |       Derived operator++(int);
 | 
					
						
							|  |  |  |       Derived& operator--();
 | 
					
						
							|  |  |  |       Derived operator--(int);
 | 
					
						
							|  |  |  |       Derived& operator+=(difference_type n);
 | 
					
						
							|  |  |  |       Derived& operator-=(difference_type n);
 | 
					
						
							|  |  |  |       Derived operator-(difference_type n) const;
 | 
					
						
							| 
									
										
										
										
											2004-07-16 19:58:03 +00:00
										 |  |  |    protected:
 | 
					
						
							|  |  |  |       typedef iterator_facade iterator_facade\_;
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  |   };
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Comparison operators
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type // exposition
 | 
					
						
							|  |  |  |   operator ==(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator !=(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator <(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |              iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator <=(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator >(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |              iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator >=(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Iterator difference
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   /* see below__ \*/
 | 
					
						
							|  |  |  |   operator-(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |             iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Iterator addition
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   template <class Dr, class V, class TC, class R, class D>
 | 
					
						
							|  |  |  |   Derived operator+ (iterator_facade<Dr,V,TC,R,D> const&,
 | 
					
						
							|  |  |  |                      typename Derived::difference_type n);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr, class V, class TC, class R, class D>
 | 
					
						
							|  |  |  |   Derived operator+ (typename Derived::difference_type n,
 | 
					
						
							|  |  |  |                      iterator_facade<Dr,V,TC,R,D> const&);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-14 19:57:11 +00:00
										 |  |  | __ `iterator category`_
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | __ `operator arrow`_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | __ brackets_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | __ minus_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-14 19:57:11 +00:00
										 |  |  | .. _`iterator category`:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-14 23:23:54 +00:00
										 |  |  | The ``iterator_category`` member of ``iterator_facade`` is
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. parsed-literal::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   *iterator-category*\ (CategoryOrTraversal, value_type, reference)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | where *iterator-category* is defined as follows:
 | 
					
						
							| 
									
										
										
										
											2004-01-14 19:57:11 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. include:: facade_iterator_category.rst
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | The ``enable_if_interoperable`` template used above is for exposition
 | 
					
						
							| 
									
										
										
										
											2004-01-18 14:52:21 +00:00
										 |  |  | purposes.  The member operators should only be in an overload set
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | provided the derived types ``Dr1`` and ``Dr2`` are interoperable, 
 | 
					
						
							|  |  |  | meaning that at least one of the types is convertible to the other.  The
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | ``enable_if_interoperable`` approach uses SFINAE to take the operators
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | out of the overload set when the types are not interoperable.  
 | 
					
						
							|  |  |  | The operators should behave *as-if* ``enable_if_interoperable``
 | 
					
						
							|  |  |  | were defined to be::
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <bool, typename> enable_if_interoperable_impl
 | 
					
						
							|  |  |  |   {};
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template <typename T> enable_if_interoperable_impl<true,T>
 | 
					
						
							|  |  |  |   { typedef T type; };
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   template<typename Dr1, typename Dr2, typename T>
 | 
					
						
							|  |  |  |   struct enable_if_interoperable
 | 
					
						
							|  |  |  |     : enable_if_interoperable_impl<
 | 
					
						
							|  |  |  |           is_convertible<Dr1,Dr2>::value || is_convertible<Dr2,Dr1>::value
 | 
					
						
							|  |  |  |         , T
 | 
					
						
							|  |  |  |       >
 | 
					
						
							|  |  |  |   {};
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-12 16:05:15 +00:00
										 |  |  | ``iterator_facade`` Requirements
 | 
					
						
							| 
									
										
										
										
											2004-01-12 18:02:50 +00:00
										 |  |  | --------------------------------
 | 
					
						
							| 
									
										
										
										
											2003-09-22 19:55:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | The following table describes the typical valid expressions on
 | 
					
						
							|  |  |  | ``iterator_facade``\ 's ``Derived`` parameter, depending on the
 | 
					
						
							|  |  |  | iterator concept(s) it will model.  The operations in the first
 | 
					
						
							|  |  |  | column must be made accessible to member functions of class
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | ``iterator_core_access``.  In addition,
 | 
					
						
							|  |  |  | ``static_cast<Derived*>(iterator_facade*)`` shall be well-formed.
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | In the table below, ``F`` is ``iterator_facade<X,V,C,R,D>``, ``a`` is an
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | object of type ``X``, ``b`` and ``c`` are objects of type ``const X``,
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | ``n`` is an object of ``F::difference_type``, ``y`` is a constant
 | 
					
						
							|  |  |  | object of a single pass iterator type interoperable with ``X``, and ``z``
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | is a constant object of a random access traversal iterator type
 | 
					
						
							|  |  |  | interoperable with ``X``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-12 02:49:55 +00:00
										 |  |  | .. _`core operations`:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-12 16:05:15 +00:00
										 |  |  | .. topic:: ``iterator_facade`` Core Operations
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							|  |  |  |    |Expression          |Return Type           |Assertion/Note           |Used to implement Iterator |
 | 
					
						
							|  |  |  |    |                    |                      |                         |Concept(s)                 |
 | 
					
						
							|  |  |  |    +====================+======================+=========================+===========================+
 | 
					
						
							|  |  |  |    |``c.dereference()`` |``F::reference``      |                         |Readable Iterator, Writable|
 | 
					
						
							|  |  |  |    |                    |                      |                         |Iterator                   |
 | 
					
						
							|  |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							|  |  |  |    |``c.equal(y)``      |convertible to bool   |true iff ``c`` and ``y`` |Single Pass Iterator       |
 | 
					
						
							|  |  |  |    |                    |                      |refer to the same        |                           |
 | 
					
						
							|  |  |  |    |                    |                      |position.                |                           |
 | 
					
						
							|  |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							|  |  |  |    |``a.increment()``   |unused                |                         |Incrementable Iterator     |
 | 
					
						
							|  |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							|  |  |  |    |``a.decrement()``   |unused                |                         |Bidirectional Traversal    |
 | 
					
						
							|  |  |  |    |                    |                      |                         |Iterator                   |
 | 
					
						
							|  |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							|  |  |  |    |``a.advance(n)``    |unused                |                         |Random Access Traversal    |
 | 
					
						
							|  |  |  |    |                    |                      |                         |Iterator                   |
 | 
					
						
							|  |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							|  |  |  |    |``c.distance_to(z)``|convertible to        |equivalent to            |Random Access Traversal    |
 | 
					
						
							|  |  |  |    |                    |``F::difference_type``|``distance(c, X(z))``.   |Iterator                   |
 | 
					
						
							|  |  |  |    +--------------------+----------------------+-------------------------+---------------------------+
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ``iterator_facade`` operations
 | 
					
						
							| 
									
										
										
										
											2004-01-12 18:02:50 +00:00
										 |  |  | ------------------------------
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | The operations in this section are described in terms of operations on
 | 
					
						
							|  |  |  | the core interface of ``Derived`` which may be inaccessible
 | 
					
						
							|  |  |  | (i.e. private).  The implementation should access these operations
 | 
					
						
							|  |  |  | through member functions of class ``iterator_core_access``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``reference operator*() const;``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Returns: ``static_cast<Derived const*>(this)->dereference()``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``operator->() const;`` (see below__)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | __ `operator arrow`_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | :Returns: If ``reference`` is a reference type, an object
 | 
					
						
							|  |  |  |   of type ``pointer`` equal to::
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     &static_cast<Derived const*>(this)->dereference()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |   Otherwise returns an object of unspecified type such that, 
 | 
					
						
							|  |  |  |   ``(*static_cast<Derived const*>(this))->m`` is equivalent to ``(w = **static_cast<Derived const*>(this),
 | 
					
						
							|  |  |  |   w.m)`` for some temporary object ``w`` of type ``value_type``.
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. _brackets:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | *unspecified* ``operator[](difference_type n) const;``
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-11 00:03:09 +00:00
										 |  |  | :Returns: an object convertible to ``value_type``. For constant
 | 
					
						
							|  |  |  |      objects ``v`` of type ``value_type``, and ``n`` of type
 | 
					
						
							| 
									
										
										
										
											2004-01-14 17:15:32 +00:00
										 |  |  |      ``difference_type``, ``(*this)[n] = v`` is equivalent to
 | 
					
						
							|  |  |  |      ``*(*this + n) = v``, and ``static_cast<value_type
 | 
					
						
							| 
									
										
										
										
											2004-01-11 00:03:09 +00:00
										 |  |  |      const&>((*this)[n])`` is equivalent to
 | 
					
						
							| 
									
										
										
										
											2004-01-14 17:15:32 +00:00
										 |  |  |      ``static_cast<value_type const&>(*(*this + n))``
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``Derived& operator++();``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects:  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static_cast<Derived*>(this)->increment();
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |     return *static_cast<Derived*>(this);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ``Derived operator++(int);``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Derived tmp(static_cast<Derived const*>(this));
 | 
					
						
							|  |  |  |     ++*this;
 | 
					
						
							|  |  |  |     return tmp;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``Derived& operator--();``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       static_cast<Derived*>(this)->decrement();
 | 
					
						
							| 
									
										
										
										
											2004-01-19 18:52:48 +00:00
										 |  |  |       return *static_cast<Derived*>(this);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``Derived operator--(int);``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Derived tmp(static_cast<Derived const*>(this));
 | 
					
						
							|  |  |  |     --*this;
 | 
					
						
							|  |  |  |     return tmp;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``Derived& operator+=(difference_type n);``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       static_cast<Derived*>(this)->advance(n);
 | 
					
						
							| 
									
										
										
										
											2004-01-19 18:52:48 +00:00
										 |  |  |       return *static_cast<Derived*>(this);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``Derived& operator-=(difference_type n);``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects: | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  |  
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       static_cast<Derived*>(this)->advance(-n);
 | 
					
						
							| 
									
										
										
										
											2004-01-19 18:52:48 +00:00
										 |  |  |       return *static_cast<Derived*>(this);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``Derived operator-(difference_type n) const;``
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-24 05:02:46 +00:00
										 |  |  | :Effects: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |     Derived tmp(static_cast<Derived const*>(this));
 | 
					
						
							|  |  |  |     return tmp -= n;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr, class V, class TC, class R, class D>
 | 
					
						
							|  |  |  |   Derived operator+ (iterator_facade<Dr,V,TC,R,D> const&,
 | 
					
						
							|  |  |  |                      typename Derived::difference_type n);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr, class V, class TC, class R, class D>
 | 
					
						
							|  |  |  |   Derived operator+ (typename Derived::difference_type n,
 | 
					
						
							|  |  |  |                      iterator_facade<Dr,V,TC,R,D> const&);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Effects: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Derived tmp(static_cast<Derived const*>(this));
 | 
					
						
							|  |  |  |     return tmp += n;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							|  |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator ==(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``((Dr1 const&)lhs).equal((Dr2 const&)rhs)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``((Dr2 const&)rhs).equal((Dr1 const&)lhs)``.
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							|  |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator !=(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``!((Dr1 const&)lhs).equal((Dr2 const&)rhs)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``!((Dr2 const&)rhs).equal((Dr1 const&)lhs)``.
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | ::
 | 
					
						
							| 
									
										
										
										
											2003-08-05 16:36:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							|  |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator <(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |              iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``((Dr1 const&)lhs).distance_to((Dr2 const&)rhs) < 0``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) > 0``.
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							|  |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator <=(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``((Dr1 const&)lhs).distance_to((Dr2 const&)rhs) <= 0``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) >= 0``.
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							|  |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator >(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |              iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``((Dr1 const&)lhs).distance_to((Dr2 const&)rhs) > 0``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) < 0``.
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							|  |  |  |   typename enable_if_interoperable<Dr1,Dr2,bool>::type
 | 
					
						
							|  |  |  |   operator >=(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |               iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``((Dr1 const&)lhs).distance_to((Dr2 const&)rhs) >= 0``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) <= 0``.
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. _minus:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   template <class Dr1, class V1, class TC1, class R1, class D1,
 | 
					
						
							|  |  |  |             class Dr2, class V2, class TC2, class R2, class D2>
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  |   typename enable_if_interoperable<Dr1,Dr2,difference>::type
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  |   operator -(iterator_facade<Dr1,V1,TC1,R1,D1> const& lhs,
 | 
					
						
							|  |  |  |              iterator_facade<Dr2,V2,TC2,R2,D2> const& rhs);
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  | :Return Type: 
 | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    then 
 | 
					
						
							|  |  |  |     ``difference`` shall be
 | 
					
						
							|  |  |  |     ``iterator_traits<Dr1>::difference_type``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Otherwise 
 | 
					
						
							|  |  |  |     ``difference`` shall be ``iterator_traits<Dr2>::difference_type``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :Returns:  | 
					
						
							|  |  |  |   if ``is_convertible<Dr2,Dr1>::value``
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   then 
 | 
					
						
							|  |  |  |     ``-((Dr1 const&)lhs).distance_to((Dr2 const&)rhs)``.
 | 
					
						
							| 
									
										
										
										
											2004-01-15 04:31:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-27 03:19:34 +00:00
										 |  |  |   Otherwise, 
 | 
					
						
							|  |  |  |     ``((Dr2 const&)rhs).distance_to((Dr1 const&)lhs)``.
 |