1 .. Distributed under the Boost
2 .. Software License, Version 1.0. (See accompanying
3 .. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
5 .. Version 1.4 of this ReStructuredText document corresponds to
6 n1530_, the paper accepted by the LWG for TR1.
8 .. Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003.
15 , class Value = use_default
16 , class CategoryOrTraversal = use_default
17 , class Reference = use_default
18 , class Difference = use_default
20 class iterator_adaptor
21 : public iterator_facade<Derived, *V'*, *C'*, *R'*, *D'*> // see details__
23 friend class iterator_core_access;
26 explicit iterator_adaptor(Base const& iter);
27 typedef Base base_type;
28 Base const& base() const;
30 typedef iterator_adaptor iterator_adaptor\_;
31 Base const& base_reference() const;
32 Base& base_reference();
33 private: // Core iterator interface for iterator_facade.
34 typename iterator_adaptor::reference dereference() const;
37 class OtherDerived, class OtherIterator, class V, class C, class R, class D
39 bool equal(iterator_adaptor<OtherDerived, OtherIterator, V, C, R, D> const& x) const;
41 void advance(typename iterator_adaptor::difference_type n);
46 class OtherDerived, class OtherIterator, class V, class C, class R, class D
48 typename iterator_adaptor::difference_type distance_to(
49 iterator_adaptor<OtherDerived, OtherIterator, V, C, R, D> const& y) const;
52 Base m_iterator; // exposition only
59 ``iterator_adaptor`` requirements
60 ---------------------------------
62 ``static_cast<Derived*>(iterator_adaptor*)`` shall be well-formed.
63 The ``Base`` argument shall be Assignable and Copy Constructible.
68 ``iterator_adaptor`` base class parameters
69 ------------------------------------------
71 The *V'*, *C'*, *R'*, and *D'* parameters of the ``iterator_facade``
72 used as a base class in the summary of ``iterator_adaptor``
73 above are defined as follows:
77 *V'* = if (Value is use_default)
78 return iterator_traits<Base>::value_type
82 *C'* = if (CategoryOrTraversal is use_default)
83 return iterator_traversal<Base>::type
85 return CategoryOrTraversal
87 *R'* = if (Reference is use_default)
88 if (Value is use_default)
89 return iterator_traits<Base>::reference
95 *D'* = if (Difference is use_default)
96 return iterator_traits<Base>::difference_type
100 .. ``iterator_adaptor`` models
101 ---------------------------
103 In order for ``Derived`` to model the iterator concepts corresponding
104 to ``iterator_traits<Derived>::iterator_category``, the expressions
105 involving ``m_iterator`` in the specifications of those private member
106 functions of ``iterator_adaptor`` that may be called by
107 ``iterator_facade<Derived, V, C, R, D>`` in evaluating any valid
108 expression involving ``Derived`` in those concepts' requirements.
110 .. The above is confusing and needs a rewrite. -JGS
111 .. That's why it's removed. We're embracing inheritance, remember?
113 ``iterator_adaptor`` public operations
114 --------------------------------------
116 ``iterator_adaptor();``
118 :Requires: The ``Base`` type must be Default Constructible.
119 :Returns: An instance of ``iterator_adaptor`` with
120 ``m_iterator`` default constructed.
123 ``explicit iterator_adaptor(Base const& iter);``
125 :Returns: An instance of ``iterator_adaptor`` with
126 ``m_iterator`` copy constructed from ``iter``.
128 ``Base const& base() const;``
130 :Returns: ``m_iterator``
132 ``iterator_adaptor`` protected member functions
133 -----------------------------------------------
135 ``Base const& base_reference() const;``
137 :Returns: A const reference to ``m_iterator``.
140 ``Base& base_reference();``
142 :Returns: A non-const reference to ``m_iterator``.
145 ``iterator_adaptor`` private member functions
146 ---------------------------------------------
148 ``typename iterator_adaptor::reference dereference() const;``
150 :Returns: ``*m_iterator``
155 class OtherDerived, class OtherIterator, class V, class C, class R, class D
157 bool equal(iterator_adaptor<OtherDerived, OtherIterator, V, C, R, D> const& x) const;
159 :Returns: ``m_iterator == x.base()``
162 ``void advance(typename iterator_adaptor::difference_type n);``
164 :Effects: ``m_iterator += n;``
166 ``void increment();``
168 :Effects: ``++m_iterator;``
170 ``void decrement();``
172 :Effects: ``--m_iterator;``
177 class OtherDerived, class OtherIterator, class V, class C, class R, class D
179 typename iterator_adaptor::difference_type distance_to(
180 iterator_adaptor<OtherDerived, OtherIterator, V, C, R, D> const& y) const;
182 :Returns: ``y.base() - m_iterator``