xref: /xnu-11417.101.15/tests/bounded_ptr_src/arith.add.cpp (revision e3723e1f17661b24996789d8afc084c0c3303b26)
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