1*bb611c8fSApple OSS Distributions //
2*bb611c8fSApple OSS Distributions // Tests for
3*bb611c8fSApple OSS Distributions //  T* data();
4*bb611c8fSApple OSS Distributions //  T const* data() const;
5*bb611c8fSApple OSS Distributions //
6*bb611c8fSApple OSS Distributions 
7*bb611c8fSApple OSS Distributions #include <libkern/c++/bounded_array.h>
8*bb611c8fSApple OSS Distributions #include "test_policy.h"
9*bb611c8fSApple OSS Distributions #include <darwintest.h>
10*bb611c8fSApple OSS Distributions #include <type_traits>
11*bb611c8fSApple OSS Distributions 
12*bb611c8fSApple OSS Distributions struct T { int i; };
13*bb611c8fSApple OSS Distributions inline bool
14*bb611c8fSApple OSS Distributions operator==(T const& a, T const& b)
15*bb611c8fSApple OSS Distributions {
16*bb611c8fSApple OSS Distributions 	return a.i == b.i;
17*bb611c8fSApple OSS Distributions }
18*bb611c8fSApple OSS Distributions 
19*bb611c8fSApple OSS Distributions template <typename T>
20*bb611c8fSApple OSS Distributions static void
21*bb611c8fSApple OSS Distributions tests()
22*bb611c8fSApple OSS Distributions {
23*bb611c8fSApple OSS Distributions 	{
24*bb611c8fSApple OSS Distributions 		test_bounded_array<T, 5> array = {T{0}, T{1}, T{2}, T{3}, T{4}};
25*bb611c8fSApple OSS Distributions 		T* data = array.data();
26*bb611c8fSApple OSS Distributions 		CHECK(data != nullptr);
27*bb611c8fSApple OSS Distributions 		CHECK(data[0] == T{0});
28*bb611c8fSApple OSS Distributions 		CHECK(data[1] == T{1});
29*bb611c8fSApple OSS Distributions 		CHECK(data[2] == T{2});
30*bb611c8fSApple OSS Distributions 		CHECK(data[3] == T{3});
31*bb611c8fSApple OSS Distributions 		CHECK(data[4] == T{4});
32*bb611c8fSApple OSS Distributions 	}
33*bb611c8fSApple OSS Distributions 	{
34*bb611c8fSApple OSS Distributions 		test_bounded_array<T, 5> const array = {T{0}, T{1}, T{2}, T{3}, T{4}};
35*bb611c8fSApple OSS Distributions 		T const* data = array.data();
36*bb611c8fSApple OSS Distributions 		CHECK(data != nullptr);
37*bb611c8fSApple OSS Distributions 		CHECK(data[0] == T{0});
38*bb611c8fSApple OSS Distributions 		CHECK(data[1] == T{1});
39*bb611c8fSApple OSS Distributions 		CHECK(data[2] == T{2});
40*bb611c8fSApple OSS Distributions 		CHECK(data[3] == T{3});
41*bb611c8fSApple OSS Distributions 		CHECK(data[4] == T{4});
42*bb611c8fSApple OSS Distributions 	}
43*bb611c8fSApple OSS Distributions 
44*bb611c8fSApple OSS Distributions 	{
45*bb611c8fSApple OSS Distributions 		test_bounded_array<T, 0> array = {};
46*bb611c8fSApple OSS Distributions 		T* data = array.data();
47*bb611c8fSApple OSS Distributions 		CHECK(data != nullptr);
48*bb611c8fSApple OSS Distributions 	}
49*bb611c8fSApple OSS Distributions 	{
50*bb611c8fSApple OSS Distributions 		test_bounded_array<T, 0> const array = {};
51*bb611c8fSApple OSS Distributions 		T const* data = array.data();
52*bb611c8fSApple OSS Distributions 		CHECK(data != nullptr);
53*bb611c8fSApple OSS Distributions 	}
54*bb611c8fSApple OSS Distributions }
55*bb611c8fSApple OSS Distributions 
56*bb611c8fSApple OSS Distributions T_DECL(data, "bounded_array.data") {
57*bb611c8fSApple OSS Distributions 	tests<T>();
58*bb611c8fSApple OSS Distributions }
59