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 // T *data();
125a83710eSEric Fiselier 
135a83710eSEric Fiselier #include <array>
145a83710eSEric Fiselier #include <cassert>
15c019b30aSLouis Dionne #include <cstddef>       // for std::max_align_t
16c019b30aSLouis Dionne 
1759cdf90aSEric Fiselier #include "test_macros.h"
185a83710eSEric Fiselier 
19b4e2e7a2SEric Fiselier // std::array is explicitly allowed to be initialized with A a = { init-list };.
20b4e2e7a2SEric Fiselier // Disable the missing braces warning for this reason.
21b4e2e7a2SEric Fiselier #include "disable_missing_braces_warning.h"
222decfad7SEric Fiselier 
23db49965aSMarshall Clow struct NoDefault {
2477b9abfcSLouis Dionne     TEST_CONSTEXPR NoDefault(int) { }
25db49965aSMarshall Clow };
26db49965aSMarshall Clow 
2798f77828SJoerg Sonnenberger #if TEST_STD_VER < 11
2898f77828SJoerg Sonnenberger struct natural_alignment {
2998f77828SJoerg Sonnenberger     long t1;
3098f77828SJoerg Sonnenberger     long long t2;
3198f77828SJoerg Sonnenberger     double t3;
3298f77828SJoerg Sonnenberger     long double t4;
3398f77828SJoerg Sonnenberger };
3498f77828SJoerg Sonnenberger #endif
35db49965aSMarshall Clow 
3677b9abfcSLouis Dionne TEST_CONSTEXPR_CXX17 bool tests()
375a83710eSEric Fiselier {
385a83710eSEric Fiselier     {
395a83710eSEric Fiselier         typedef double T;
405a83710eSEric Fiselier         typedef std::array<T, 3> C;
415a83710eSEric Fiselier         C c = {1, 2, 3.5};
425a83710eSEric Fiselier         T* p = c.data();
435a83710eSEric Fiselier         assert(p[0] == 1);
445a83710eSEric Fiselier         assert(p[1] == 2);
455a83710eSEric Fiselier         assert(p[2] == 3.5);
465a83710eSEric Fiselier     }
475a83710eSEric Fiselier     {
485a83710eSEric Fiselier         typedef double T;
495a83710eSEric Fiselier         typedef std::array<T, 0> C;
505a83710eSEric Fiselier         C c = {};
515a83710eSEric Fiselier         T* p = c.data();
52*7265ff92SLouis Dionne         (void)p;
5359cdf90aSEric Fiselier     }
5459cdf90aSEric Fiselier     {
5559cdf90aSEric Fiselier         typedef double T;
5659cdf90aSEric Fiselier         typedef std::array<const T, 0> C;
5759cdf90aSEric Fiselier         C c = {{}};
5859cdf90aSEric Fiselier         const T* p = c.data();
59*7265ff92SLouis Dionne         (void)p;
6059cdf90aSEric Fiselier         static_assert((std::is_same<decltype(c.data()), const T*>::value), "");
6177b9abfcSLouis Dionne     }
6277b9abfcSLouis Dionne     {
6377b9abfcSLouis Dionne         typedef NoDefault T;
6477b9abfcSLouis Dionne         typedef std::array<T, 0> C;
6577b9abfcSLouis Dionne         C c = {};
6677b9abfcSLouis Dionne         T* p = c.data();
67*7265ff92SLouis Dionne         (void)p;
6859cdf90aSEric Fiselier     }
6959cdf90aSEric Fiselier     {
7077b9abfcSLouis Dionne         std::array<int, 5> c = {0, 1, 2, 3, 4};
7177b9abfcSLouis Dionne         assert(c.data() == &c[0]);
7277b9abfcSLouis Dionne         assert(*c.data() == c[0]);
7377b9abfcSLouis Dionne     }
7477b9abfcSLouis Dionne 
7577b9abfcSLouis Dionne     return true;
7677b9abfcSLouis Dionne }
7777b9abfcSLouis Dionne 
7877b9abfcSLouis Dionne int main(int, char**)
7977b9abfcSLouis Dionne {
8077b9abfcSLouis Dionne     tests();
8177b9abfcSLouis Dionne #if TEST_STD_VER >= 17
8277b9abfcSLouis Dionne     static_assert(tests(), "");
8377b9abfcSLouis Dionne #endif
8477b9abfcSLouis Dionne 
8577b9abfcSLouis Dionne     // Test the alignment of data()
8677b9abfcSLouis Dionne     {
8798f77828SJoerg Sonnenberger #if TEST_STD_VER < 11
8898f77828SJoerg Sonnenberger         typedef natural_alignment T;
8998f77828SJoerg Sonnenberger #else
9059cdf90aSEric Fiselier         typedef std::max_align_t T;
9198f77828SJoerg Sonnenberger #endif
9259cdf90aSEric Fiselier         typedef std::array<T, 0> C;
9359cdf90aSEric Fiselier         const C c = {};
9459cdf90aSEric Fiselier         const T* p = c.data();
9559cdf90aSEric Fiselier         std::uintptr_t pint = reinterpret_cast<std::uintptr_t>(p);
9698f77828SJoerg Sonnenberger         assert(pint % TEST_ALIGNOF(T) == 0);
9759cdf90aSEric Fiselier     }
982df59c50SJF Bastien     return 0;
995a83710eSEric Fiselier }
100