1 //===----------------------------------------------------------------------===//
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
7 //===----------------------------------------------------------------------===//
11 // const T* data() const;
15 #include <cstddef> // for std::max_align_t
18 #include "test_macros.h"
21 TEST_CONSTEXPR
NoDefault(int) { }
25 struct natural_alignment
{
33 TEST_CONSTEXPR_CXX17
bool tests()
37 typedef std::array
<T
, 3> C
;
38 const C c
= {1, 2, 3.5};
39 ASSERT_NOEXCEPT(c
.data());
40 const T
* p
= c
.data();
47 typedef std::array
<T
, 0> C
;
49 ASSERT_NOEXCEPT(c
.data());
50 const T
* p
= c
.data();
55 typedef std::array
<T
, 0> C
;
57 ASSERT_NOEXCEPT(c
.data());
58 const T
* p
= c
.data();
62 std::array
<int, 5> const c
= {0, 1, 2, 3, 4};
63 assert(c
.data() == &c
[0]);
64 assert(*c
.data() == c
[0]);
73 #if TEST_STD_VER >= 17
74 static_assert(tests(), "");
77 // Test the alignment of data()
80 typedef natural_alignment T
;
82 typedef std::max_align_t T
;
84 typedef std::array
<T
, 0> C
;
86 const T
* p
= c
.data();
87 std::uintptr_t pint
= reinterpret_cast<std::uintptr_t>(p
);
88 assert(pint
% TEST_ALIGNOF(T
) == 0);