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 //
5*e3723e1fSApple OSS Distributions
6*e3723e1fSApple OSS Distributions #include <libkern/c++/bounded_ptr.h>
7*e3723e1fSApple OSS Distributions #include "test_utils.h"
8*e3723e1fSApple OSS Distributions #include <array>
9*e3723e1fSApple OSS Distributions #include <cstddef>
10*e3723e1fSApple OSS Distributions #include <darwintest.h>
11*e3723e1fSApple OSS Distributions #include <darwintest_utils.h>
12*e3723e1fSApple OSS Distributions
13*e3723e1fSApple OSS Distributions #define _assert(...) T_ASSERT_TRUE((__VA_ARGS__), # __VA_ARGS__)
14*e3723e1fSApple OSS Distributions
15*e3723e1fSApple OSS Distributions struct T {
16*e3723e1fSApple OSS Distributions int i;
17*e3723e1fSApple OSS Distributions };
18*e3723e1fSApple OSS Distributions
19*e3723e1fSApple OSS Distributions template <typename T, typename QualT>
20*e3723e1fSApple OSS Distributions static void
tests()21*e3723e1fSApple OSS Distributions tests()
22*e3723e1fSApple OSS Distributions {
23*e3723e1fSApple OSS Distributions std::array<T, 5> array = {T{0}, T{1}, T{2}, T{3}, T{4}};
24*e3723e1fSApple OSS Distributions
25*e3723e1fSApple OSS Distributions // Subtract positive offsets
26*e3723e1fSApple OSS Distributions // T{0} T{1} T{2} T{3} T{4} <one-past-last>
27*e3723e1fSApple OSS Distributions // ^ ^
28*e3723e1fSApple OSS Distributions // | |
29*e3723e1fSApple OSS Distributions // begin end,ptr
30*e3723e1fSApple OSS Distributions {
31*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.end(), array.begin(), array.end());
32*e3723e1fSApple OSS Distributions
33*e3723e1fSApple OSS Distributions {
34*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - static_cast<std::ptrdiff_t>(0);
35*e3723e1fSApple OSS Distributions _assert(ptr == array.end());
36*e3723e1fSApple OSS Distributions }
37*e3723e1fSApple OSS Distributions {
38*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - 1;
39*e3723e1fSApple OSS Distributions _assert(&*res == &array[4]);
40*e3723e1fSApple OSS Distributions }
41*e3723e1fSApple OSS Distributions {
42*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - 2;
43*e3723e1fSApple OSS Distributions _assert(&*res == &array[3]);
44*e3723e1fSApple OSS Distributions }
45*e3723e1fSApple OSS Distributions {
46*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - 3;
47*e3723e1fSApple OSS Distributions _assert(&*res == &array[2]);
48*e3723e1fSApple OSS Distributions }
49*e3723e1fSApple OSS Distributions {
50*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - 4;
51*e3723e1fSApple OSS Distributions _assert(&*res == &array[1]);
52*e3723e1fSApple OSS Distributions }
53*e3723e1fSApple OSS Distributions {
54*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - 5;
55*e3723e1fSApple OSS Distributions _assert(&*res == &array[0]);
56*e3723e1fSApple OSS Distributions }
57*e3723e1fSApple OSS Distributions }
58*e3723e1fSApple OSS Distributions
59*e3723e1fSApple OSS Distributions // Subtract negative offsets
60*e3723e1fSApple OSS Distributions // T{0} T{1} T{2} T{3} T{4} <one-past-last>
61*e3723e1fSApple OSS Distributions // ^ ^
62*e3723e1fSApple OSS Distributions // | |
63*e3723e1fSApple OSS Distributions // begin,ptr end
64*e3723e1fSApple OSS Distributions {
65*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin(), array.begin(), array.end());
66*e3723e1fSApple OSS Distributions
67*e3723e1fSApple OSS Distributions {
68*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - static_cast<std::ptrdiff_t>(0);
69*e3723e1fSApple OSS Distributions _assert(&*res == &array[0]);
70*e3723e1fSApple OSS Distributions }
71*e3723e1fSApple OSS Distributions {
72*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - -1;
73*e3723e1fSApple OSS Distributions _assert(&*res == &array[1]);
74*e3723e1fSApple OSS Distributions }
75*e3723e1fSApple OSS Distributions {
76*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - -2;
77*e3723e1fSApple OSS Distributions _assert(&*res == &array[2]);
78*e3723e1fSApple OSS Distributions }
79*e3723e1fSApple OSS Distributions {
80*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - -3;
81*e3723e1fSApple OSS Distributions _assert(&*res == &array[3]);
82*e3723e1fSApple OSS Distributions }
83*e3723e1fSApple OSS Distributions {
84*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - -4;
85*e3723e1fSApple OSS Distributions _assert(&*res == &array[4]);
86*e3723e1fSApple OSS Distributions }
87*e3723e1fSApple OSS Distributions {
88*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> res = ptr - -5;
89*e3723e1fSApple OSS Distributions _assert(res == array.end());
90*e3723e1fSApple OSS Distributions }
91*e3723e1fSApple OSS Distributions }
92*e3723e1fSApple OSS Distributions
93*e3723e1fSApple OSS Distributions // Make sure the original pointer isn't modified
94*e3723e1fSApple OSS Distributions {
95*e3723e1fSApple OSS Distributions test_bounded_ptr<QualT> const ptr(array.begin() + 4, array.begin(), array.end());
96*e3723e1fSApple OSS Distributions (void)(ptr - 2);
97*e3723e1fSApple OSS Distributions _assert(&*ptr == &array[4]);
98*e3723e1fSApple OSS Distributions }
99*e3723e1fSApple OSS Distributions }
100*e3723e1fSApple OSS Distributions
101*e3723e1fSApple OSS Distributions T_DECL(arith_subtract, "bounded_ptr.arith.subtract", T_META_TAG_VM_PREFERRED) {
102*e3723e1fSApple OSS Distributions tests<T, T>();
103*e3723e1fSApple OSS Distributions tests<T, T const>();
104*e3723e1fSApple OSS Distributions tests<T, T volatile>();
105*e3723e1fSApple OSS Distributions tests<T, T const volatile>();
106*e3723e1fSApple OSS Distributions }
107