mirror of
https://github.com/boostorg/iterator.git
synced 2025-05-11 21:43:54 +00:00
93 lines
2.1 KiB
ReStructuredText
93 lines
2.1 KiB
ReStructuredText
::
|
|
|
|
template <
|
|
class Incrementable
|
|
, class CategoryOrTraversal = use_default
|
|
, class Difference = use_default
|
|
>
|
|
class counting_iterator
|
|
{
|
|
public:
|
|
counting_iterator();
|
|
counting_iterator(counting_iterator const& rhs);
|
|
explicit counting_iterator(Incrementable x);
|
|
Incrementable base() const;
|
|
private:
|
|
Incrementable current; // exposition
|
|
};
|
|
|
|
|
|
[*Note:* implementers are encouraged to provide an implementation of
|
|
``distance_to`` and a ``difference_type`` that avoids overflows in
|
|
the cases when the ``Incrementable`` type is a numeric type.]
|
|
|
|
``counting_iterator`` requirements
|
|
----------------------------------
|
|
|
|
The ``Incrementable`` type must be Default Constructible, Copy
|
|
Constructible, and Assignable. The default distance is
|
|
an implementation defined signed integral type.
|
|
|
|
|
|
``counting_iterator`` models
|
|
----------------------------
|
|
|
|
``counting_iterator`` models Readable Lvalue Iterator.
|
|
|
|
Furthermore, if you wish to create a counting iterator that is a Forward
|
|
Traversal Iterator, then the following expressions must be valid::
|
|
|
|
Incrementable i, j;
|
|
++i // pre-increment
|
|
i == j // operator equal
|
|
|
|
If you wish to create a counting iterator that is a
|
|
Bidirectional Traversal Iterator, then pre-decrement is also required::
|
|
|
|
--i
|
|
|
|
If you wish to create a counting iterator that is a Random Access
|
|
Traversal Iterator, then these additional expressions are also
|
|
required::
|
|
|
|
counting_iterator::difference_type n;
|
|
i += n
|
|
n = i - j
|
|
i < j
|
|
|
|
|
|
|
|
|
|
``counting_iterator`` operations
|
|
--------------------------------
|
|
|
|
``counting_iterator();``
|
|
|
|
:Returns: A default constructed instance of ``counting_iterator``.
|
|
|
|
|
|
``counting_iterator(counting_iterator const& rhs);``
|
|
|
|
:Returns: An instance of ``counting_iterator`` that is a copy of ``rhs``.
|
|
|
|
|
|
|
|
``explicit counting_iterator(Incrementable x);``
|
|
|
|
:Returns: An instance of ``counting_iterator`` with ``current``
|
|
constructed from ``x``.
|
|
|
|
|
|
``reference operator*() const;``
|
|
|
|
:Returns: ``current``
|
|
|
|
|
|
``counting_iterator& operator++();``
|
|
|
|
:Effects: ``++current``
|
|
|
|
|
|
``Incrementable base() const;``
|
|
|
|
:Returns: ``current`` |