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