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