1*fdd8201dSApple OSS Distributions //
2*fdd8201dSApple OSS Distributions // Tests for
3*fdd8201dSApple OSS Distributions // friend bounded_ptr operator+(bounded_ptr p, std::ptrdiff_t n);
4*fdd8201dSApple OSS Distributions // friend bounded_ptr operator+(std::ptrdiff_t n, bounded_ptr p);
5*fdd8201dSApple OSS Distributions //
6*fdd8201dSApple OSS Distributions // The heavy lifting is done in operator+=, so we only check basic functioning.
7*fdd8201dSApple OSS Distributions //
8*fdd8201dSApple OSS Distributions
9*fdd8201dSApple OSS Distributions #include <libkern/c++/bounded_ptr.h>
10*fdd8201dSApple OSS Distributions #include <array>
11*fdd8201dSApple OSS Distributions #include <darwintest.h>
12*fdd8201dSApple OSS Distributions #include <darwintest_utils.h>
13*fdd8201dSApple OSS Distributions #include "test_utils.h"
14*fdd8201dSApple OSS Distributions
15*fdd8201dSApple OSS Distributions #define _assert(...) T_ASSERT_TRUE((__VA_ARGS__), # __VA_ARGS__)
16*fdd8201dSApple OSS Distributions
17*fdd8201dSApple OSS Distributions struct T {
18*fdd8201dSApple OSS Distributions int i;
19*fdd8201dSApple OSS Distributions };
20*fdd8201dSApple OSS Distributions
21*fdd8201dSApple OSS Distributions template <typename T, typename QualT>
22*fdd8201dSApple OSS Distributions static void
tests()23*fdd8201dSApple OSS Distributions tests()
24*fdd8201dSApple OSS Distributions {
25*fdd8201dSApple OSS Distributions std::array<T, 5> array = {T{0}, T{1}, T{2}, T{3}, T{4}};
26*fdd8201dSApple OSS Distributions
27*fdd8201dSApple OSS Distributions // Add positive offsets
28*fdd8201dSApple OSS Distributions // T{0} T{1} T{2} T{3} T{4} <one-past-last>
29*fdd8201dSApple OSS Distributions // ^ ^
30*fdd8201dSApple OSS Distributions // | |
31*fdd8201dSApple OSS Distributions // begin, ptr end
32*fdd8201dSApple OSS Distributions {
33*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin(), array.begin(), array.end());
34*fdd8201dSApple OSS Distributions
35*fdd8201dSApple OSS Distributions {
36*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 0;
37*fdd8201dSApple OSS Distributions _assert(&*res == &array[0]);
38*fdd8201dSApple OSS Distributions }
39*fdd8201dSApple OSS Distributions {
40*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 1;
41*fdd8201dSApple OSS Distributions _assert(&*res == &array[1]);
42*fdd8201dSApple OSS Distributions }
43*fdd8201dSApple OSS Distributions {
44*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 2;
45*fdd8201dSApple OSS Distributions _assert(&*res == &array[2]);
46*fdd8201dSApple OSS Distributions }
47*fdd8201dSApple OSS Distributions {
48*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 3;
49*fdd8201dSApple OSS Distributions _assert(&*res == &array[3]);
50*fdd8201dSApple OSS Distributions }
51*fdd8201dSApple OSS Distributions {
52*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 4;
53*fdd8201dSApple OSS Distributions _assert(&*res == &array[4]);
54*fdd8201dSApple OSS Distributions }
55*fdd8201dSApple OSS Distributions {
56*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 5;
57*fdd8201dSApple OSS Distributions _assert(res == array.end());
58*fdd8201dSApple OSS Distributions }
59*fdd8201dSApple OSS Distributions }
60*fdd8201dSApple OSS Distributions
61*fdd8201dSApple OSS Distributions // Add negative offsets
62*fdd8201dSApple OSS Distributions // T{0} T{1} T{2} T{3} T{4} <one-past-last>
63*fdd8201dSApple OSS Distributions // ^ ^
64*fdd8201dSApple OSS Distributions // | |
65*fdd8201dSApple OSS Distributions // begin end,ptr
66*fdd8201dSApple OSS Distributions {
67*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.end(), array.begin(), array.end());
68*fdd8201dSApple OSS Distributions
69*fdd8201dSApple OSS Distributions {
70*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + 0;
71*fdd8201dSApple OSS Distributions _assert(res == array.end());
72*fdd8201dSApple OSS Distributions }
73*fdd8201dSApple OSS Distributions {
74*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + -1;
75*fdd8201dSApple OSS Distributions _assert(&*res == &array[4]);
76*fdd8201dSApple OSS Distributions }
77*fdd8201dSApple OSS Distributions {
78*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + -2;
79*fdd8201dSApple OSS Distributions _assert(&*res == &array[3]);
80*fdd8201dSApple OSS Distributions }
81*fdd8201dSApple OSS Distributions {
82*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + -3;
83*fdd8201dSApple OSS Distributions _assert(&*res == &array[2]);
84*fdd8201dSApple OSS Distributions }
85*fdd8201dSApple OSS Distributions {
86*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + -4;
87*fdd8201dSApple OSS Distributions _assert(&*res == &array[1]);
88*fdd8201dSApple OSS Distributions }
89*fdd8201dSApple OSS Distributions {
90*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = ptr + -5;
91*fdd8201dSApple OSS Distributions _assert(&*res == &array[0]);
92*fdd8201dSApple OSS Distributions }
93*fdd8201dSApple OSS Distributions }
94*fdd8201dSApple OSS Distributions
95*fdd8201dSApple OSS Distributions // Make sure the original pointer isn't modified
96*fdd8201dSApple OSS Distributions {
97*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin() + 1, array.begin(), array.end());
98*fdd8201dSApple OSS Distributions (void)(ptr + 3);
99*fdd8201dSApple OSS Distributions _assert(&*ptr == &array[1]);
100*fdd8201dSApple OSS Distributions }
101*fdd8201dSApple OSS Distributions
102*fdd8201dSApple OSS Distributions // Make sure the operator is commutative
103*fdd8201dSApple OSS Distributions {
104*fdd8201dSApple OSS Distributions {
105*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin(), array.begin(), array.end());
106*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = 0 + ptr;
107*fdd8201dSApple OSS Distributions _assert(&*res == &array[0]);
108*fdd8201dSApple OSS Distributions }
109*fdd8201dSApple OSS Distributions {
110*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin(), array.begin(), array.end());
111*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = 3 + ptr;
112*fdd8201dSApple OSS Distributions _assert(&*res == &array[3]);
113*fdd8201dSApple OSS Distributions }
114*fdd8201dSApple OSS Distributions {
115*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin() + 3, array.begin(), array.end());
116*fdd8201dSApple OSS Distributions test_bounded_ptr<QualT> res = -2 + ptr;
117*fdd8201dSApple OSS Distributions _assert(&*res == &array[1]);
118*fdd8201dSApple OSS Distributions }
119*fdd8201dSApple OSS Distributions }
120*fdd8201dSApple OSS Distributions }
121*fdd8201dSApple OSS Distributions
122*fdd8201dSApple OSS Distributions T_DECL(arith_add, "bounded_ptr.arith.add") {
123*fdd8201dSApple OSS Distributions tests<T, T>();
124*fdd8201dSApple OSS Distributions tests<T, T const>();
125*fdd8201dSApple OSS Distributions tests<T, T volatile>();
126*fdd8201dSApple OSS Distributions tests<T, T const volatile>();
127*fdd8201dSApple OSS Distributions }
128