1 //===----------------------------------------------------------------------===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 9 // <array> 10 11 // T *data(); 12 13 #include <array> 14 #include <cassert> 15 #include <cstddef> // for std::max_align_t 16 17 #include "test_macros.h" 18 19 struct NoDefault { 20 TEST_CONSTEXPR NoDefault(int) { } 21 }; 22 23 #if TEST_STD_VER < 11 24 struct natural_alignment { 25 long t1; 26 long long t2; 27 double t3; 28 long double t4; 29 }; 30 #endif 31 32 TEST_CONSTEXPR_CXX17 bool tests() 33 { 34 { 35 typedef double T; 36 typedef std::array<T, 3> C; 37 C c = {1, 2, 3.5}; 38 ASSERT_NOEXCEPT(c.data()); 39 T* p = c.data(); 40 assert(p[0] == 1); 41 assert(p[1] == 2); 42 assert(p[2] == 3.5); 43 } 44 { 45 typedef double T; 46 typedef std::array<T, 0> C; 47 C c = {}; 48 ASSERT_NOEXCEPT(c.data()); 49 T* p = c.data(); 50 (void)p; 51 } 52 { 53 typedef double T; 54 typedef std::array<const T, 0> C; 55 C c = {{}}; 56 ASSERT_NOEXCEPT(c.data()); 57 const T* p = c.data(); 58 (void)p; 59 static_assert((std::is_same<decltype(c.data()), const T*>::value), ""); 60 } 61 { 62 typedef NoDefault T; 63 typedef std::array<T, 0> C; 64 C c = {}; 65 ASSERT_NOEXCEPT(c.data()); 66 T* p = c.data(); 67 (void)p; 68 } 69 { 70 std::array<int, 5> c = {0, 1, 2, 3, 4}; 71 assert(c.data() == &c[0]); 72 assert(*c.data() == c[0]); 73 } 74 75 return true; 76 } 77 78 int main(int, char**) 79 { 80 tests(); 81 #if TEST_STD_VER >= 17 82 static_assert(tests(), ""); 83 #endif 84 85 // Test the alignment of data() 86 { 87 #if TEST_STD_VER < 11 88 typedef natural_alignment T; 89 #else 90 typedef std::max_align_t T; 91 #endif 92 typedef std::array<T, 0> C; 93 const C c = {}; 94 const T* p = c.data(); 95 std::uintptr_t pint = reinterpret_cast<std::uintptr_t>(p); 96 assert(pint % TEST_ALIGNOF(T) == 0); 97 } 98 return 0; 99 } 100