File: next_prior_test.cpp

package info (click to toggle)
boost1.83 1.83.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 545,632 kB
  • sloc: cpp: 3,857,086; xml: 125,552; ansic: 34,414; python: 25,887; asm: 5,276; sh: 4,799; ada: 1,681; makefile: 1,629; perl: 1,212; pascal: 1,139; sql: 810; yacc: 478; ruby: 102; lisp: 24; csh: 6
file content (112 lines) | stat: -rw-r--r-- 4,236 bytes parent folder | download | duplicates (13)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
// Boost test program for next() and prior() utilities.

// Copyright 2003 Daniel Walker.  Use, modification, and distribution
// are subject to the Boost Software License, Version 1.0. (See
// accompanying file LICENSE_1_0.txt or a copy at
// http://www.boost.org/LICENSE_1_0.txt.)

// See http://www.boost.org/libs/utility for documentation.

// Revision History 13 Dec 2003 Initial Version (Daniel Walker)

// next() and prior() are replacements for operator+ and operator- for
// non-random-access iterators. The semantics of these operators are
// such that after executing j = i + n, std::distance(i, j) equals
// n. Tests are provided to ensure next() has the same
// result. Parallel tests are provided for prior(). The tests call
// next() and prior() several times. next() and prior() are very
// simple functions, though, and it would be very strange if these
// tests were to fail.

#include <boost/core/lightweight_test.hpp>

#include <list>
#include <vector>

#include <boost/next_prior.hpp>

template<class RandomAccessIterator, class ForwardIterator>
bool plus_one_test(RandomAccessIterator first, RandomAccessIterator last, ForwardIterator first2)
{
    RandomAccessIterator i = first;
    ForwardIterator j = first2;
    while(i != last)
        i = i + 1, j = boost::next(j);
    return std::distance(first, i) == std::distance(first2, j);
}

template<class RandomAccessIterator, class ForwardIterator>
bool plus_n_test(RandomAccessIterator first, RandomAccessIterator last, ForwardIterator first2)
{
    RandomAccessIterator i = first;
    ForwardIterator j = first2;
    for(int n = 0; i != last; ++n)
        i = first + n, j = boost::next(first2, n);
    return std::distance(first, i) == std::distance(first2, j);
}

template<class RandomAccessIterator, class BidirectionalIterator>
bool minus_one_test(RandomAccessIterator first, RandomAccessIterator last, BidirectionalIterator last2)
{
    RandomAccessIterator i = last;
    BidirectionalIterator j = last2;
    while(i != first)
        i = i - 1, j = boost::prior(j);
    return std::distance(i, last) == std::distance(j, last2);
}

template<class RandomAccessIterator, class BidirectionalIterator>
bool minus_n_test(RandomAccessIterator first, RandomAccessIterator last, BidirectionalIterator last2)
{
    RandomAccessIterator i = last;
    BidirectionalIterator j = last2;
    for(int n = 0; i != first; ++n)
        i = last - n, j = boost::prior(last2, n);
    return std::distance(i, last) == std::distance(j, last2);
}

template<class Iterator, class Distance>
bool minus_n_unsigned_test(Iterator first, Iterator last, Distance size)
{
    Iterator i = boost::prior(last, size);
    return i == first;
}

int main(int, char*[])
{
    std::vector<int> x(8);
    std::list<int> y(x.begin(), x.end());

    // Tests with iterators
    BOOST_TEST(plus_one_test(x.begin(), x.end(), y.begin()));
    BOOST_TEST(plus_n_test(x.begin(), x.end(), y.begin()));
    BOOST_TEST(minus_one_test(x.begin(), x.end(), y.end()));
    BOOST_TEST(minus_n_test(x.begin(), x.end(), y.end()));
    BOOST_TEST(minus_n_unsigned_test(x.begin(), x.end(), x.size()));
    BOOST_TEST(minus_n_unsigned_test(y.begin(), y.end(), y.size()));

    BOOST_TEST(plus_one_test(x.rbegin(), x.rend(), y.begin()));
    BOOST_TEST(plus_n_test(x.rbegin(), x.rend(), y.begin()));
    BOOST_TEST(minus_one_test(x.rbegin(), x.rend(), y.end()));
    BOOST_TEST(minus_n_test(x.rbegin(), x.rend(), y.end()));
    BOOST_TEST(minus_n_unsigned_test(x.rbegin(), x.rend(), x.size()));
    BOOST_TEST(minus_n_unsigned_test(x.rbegin(), x.rend(), y.size()));

    // Test with pointers
    std::vector<int> z(x.size());
    int* p = &z[0];
    BOOST_TEST(plus_one_test(x.begin(), x.end(), p));
    BOOST_TEST(plus_n_test(x.begin(), x.end(), p));
    BOOST_TEST(minus_one_test(x.begin(), x.end(), p + z.size()));
    BOOST_TEST(minus_n_test(x.begin(), x.end(), p + z.size()));
    BOOST_TEST(minus_n_unsigned_test(p, p + z.size(), z.size()));

    // Tests with integers
    BOOST_TEST(boost::next(5) == 6);
    BOOST_TEST(boost::next(5, 7) == 12);
    BOOST_TEST(boost::prior(5) == 4);
    BOOST_TEST(boost::prior(5, 7) == -2);
    BOOST_TEST(boost::prior(5, 7u) == -2);

    return boost::report_errors();
}