15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier
95a83710eSEric Fiselier // <array>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // const T* data() const;
125a83710eSEric Fiselier
135a83710eSEric Fiselier #include <array>
145a83710eSEric Fiselier #include <cassert>
15c019b30aSLouis Dionne #include <cstddef> // for std::max_align_t
16*3cd4531bSNikolas Klauser #include <cstdint>
175a83710eSEric Fiselier
18020b623aSMarshall Clow #include "test_macros.h"
19020b623aSMarshall Clow
20db49965aSMarshall Clow struct NoDefault {
NoDefaultNoDefault2177b9abfcSLouis Dionne TEST_CONSTEXPR NoDefault(int) { }
22db49965aSMarshall Clow };
23db49965aSMarshall Clow
2498f77828SJoerg Sonnenberger #if TEST_STD_VER < 11
2598f77828SJoerg Sonnenberger struct natural_alignment {
2698f77828SJoerg Sonnenberger long t1;
2798f77828SJoerg Sonnenberger long long t2;
2898f77828SJoerg Sonnenberger double t3;
2998f77828SJoerg Sonnenberger long double t4;
3098f77828SJoerg Sonnenberger };
3198f77828SJoerg Sonnenberger #endif
3298f77828SJoerg Sonnenberger
tests()3377b9abfcSLouis Dionne TEST_CONSTEXPR_CXX17 bool tests()
345a83710eSEric Fiselier {
355a83710eSEric Fiselier {
365a83710eSEric Fiselier typedef double T;
375a83710eSEric Fiselier typedef std::array<T, 3> C;
385a83710eSEric Fiselier const C c = {1, 2, 3.5};
39ff94bd1bSKonstantin Boyarinov ASSERT_NOEXCEPT(c.data());
405a83710eSEric Fiselier const T* p = c.data();
415a83710eSEric Fiselier assert(p[0] == 1);
425a83710eSEric Fiselier assert(p[1] == 2);
435a83710eSEric Fiselier assert(p[2] == 3.5);
445a83710eSEric Fiselier }
455a83710eSEric Fiselier {
465a83710eSEric Fiselier typedef double T;
475a83710eSEric Fiselier typedef std::array<T, 0> C;
485a83710eSEric Fiselier const C c = {};
49ff94bd1bSKonstantin Boyarinov ASSERT_NOEXCEPT(c.data());
505a83710eSEric Fiselier const T* p = c.data();
517265ff92SLouis Dionne (void)p;
525a83710eSEric Fiselier }
5359cdf90aSEric Fiselier {
5459cdf90aSEric Fiselier typedef NoDefault T;
5559cdf90aSEric Fiselier typedef std::array<T, 0> C;
5659cdf90aSEric Fiselier const C c = {};
57ff94bd1bSKonstantin Boyarinov ASSERT_NOEXCEPT(c.data());
5859cdf90aSEric Fiselier const T* p = c.data();
597265ff92SLouis Dionne (void)p;
6059cdf90aSEric Fiselier }
6159cdf90aSEric Fiselier {
6277b9abfcSLouis Dionne std::array<int, 5> const c = {0, 1, 2, 3, 4};
6377b9abfcSLouis Dionne assert(c.data() == &c[0]);
6477b9abfcSLouis Dionne assert(*c.data() == c[0]);
6577b9abfcSLouis Dionne }
6677b9abfcSLouis Dionne
6777b9abfcSLouis Dionne return true;
6877b9abfcSLouis Dionne }
6977b9abfcSLouis Dionne
main(int,char **)7077b9abfcSLouis Dionne int main(int, char**)
7177b9abfcSLouis Dionne {
7277b9abfcSLouis Dionne tests();
7377b9abfcSLouis Dionne #if TEST_STD_VER >= 17
7477b9abfcSLouis Dionne static_assert(tests(), "");
7577b9abfcSLouis Dionne #endif
7677b9abfcSLouis Dionne
7777b9abfcSLouis Dionne // Test the alignment of data()
7877b9abfcSLouis Dionne {
7998f77828SJoerg Sonnenberger #if TEST_STD_VER < 11
8098f77828SJoerg Sonnenberger typedef natural_alignment T;
8198f77828SJoerg Sonnenberger #else
8259cdf90aSEric Fiselier typedef std::max_align_t T;
8398f77828SJoerg Sonnenberger #endif
8459cdf90aSEric Fiselier typedef std::array<T, 0> C;
8559cdf90aSEric Fiselier const C c = {};
8659cdf90aSEric Fiselier const T* p = c.data();
8759cdf90aSEric Fiselier std::uintptr_t pint = reinterpret_cast<std::uintptr_t>(p);
8898f77828SJoerg Sonnenberger assert(pint % TEST_ALIGNOF(T) == 0);
8959cdf90aSEric Fiselier }
902df59c50SJF Bastien
912df59c50SJF Bastien return 0;
925a83710eSEric Fiselier }
93