1*5e3eaea3SApple OSS Distributions // 2*5e3eaea3SApple OSS Distributions // Tests for 3*5e3eaea3SApple OSS Distributions // T* data() const; 4*5e3eaea3SApple OSS Distributions // 5*5e3eaea3SApple OSS Distributions 6*5e3eaea3SApple OSS Distributions #include <libkern/c++/bounded_array_ref.h> 7*5e3eaea3SApple OSS Distributions #include "test_policy.h" 8*5e3eaea3SApple OSS Distributions #include <cstddef> 9*5e3eaea3SApple OSS Distributions #include <darwintest.h> 10*5e3eaea3SApple OSS Distributions #include <darwintest_utils.h> 11*5e3eaea3SApple OSS Distributions 12*5e3eaea3SApple OSS Distributions struct T { int i; }; 13*5e3eaea3SApple OSS Distributions 14*5e3eaea3SApple OSS Distributions template <typename T> 15*5e3eaea3SApple OSS Distributions static void tests()16*5e3eaea3SApple OSS Distributionstests() 17*5e3eaea3SApple OSS Distributions { 18*5e3eaea3SApple OSS Distributions T array[5] = {T{0}, T{1}, T{2}, T{3}, T{4}}; 19*5e3eaea3SApple OSS Distributions 20*5e3eaea3SApple OSS Distributions { 21*5e3eaea3SApple OSS Distributions test_bounded_array_ref<T> const view(&array[0], static_cast<std::size_t>(0)); 22*5e3eaea3SApple OSS Distributions T* data = view.data(); 23*5e3eaea3SApple OSS Distributions CHECK(data == &array[0]); 24*5e3eaea3SApple OSS Distributions } 25*5e3eaea3SApple OSS Distributions { 26*5e3eaea3SApple OSS Distributions test_bounded_array_ref<T> const view(&array[0], 1); 27*5e3eaea3SApple OSS Distributions T* data = view.data(); 28*5e3eaea3SApple OSS Distributions CHECK(data == &array[0]); 29*5e3eaea3SApple OSS Distributions } 30*5e3eaea3SApple OSS Distributions 31*5e3eaea3SApple OSS Distributions { 32*5e3eaea3SApple OSS Distributions test_bounded_array_ref<T> const view(&array[1], 2); 33*5e3eaea3SApple OSS Distributions T* data = view.data(); 34*5e3eaea3SApple OSS Distributions CHECK(data == &array[1]); 35*5e3eaea3SApple OSS Distributions } 36*5e3eaea3SApple OSS Distributions { 37*5e3eaea3SApple OSS Distributions test_bounded_array_ref<T> const view(&array[2], 2); 38*5e3eaea3SApple OSS Distributions T* data = view.data(); 39*5e3eaea3SApple OSS Distributions CHECK(data == &array[2]); 40*5e3eaea3SApple OSS Distributions } 41*5e3eaea3SApple OSS Distributions } 42*5e3eaea3SApple OSS Distributions 43*5e3eaea3SApple OSS Distributions T_DECL(data, "bounded_array_ref.data") { 44*5e3eaea3SApple OSS Distributions tests<T>(); 45*5e3eaea3SApple OSS Distributions tests<T const>(); 46*5e3eaea3SApple OSS Distributions } 47