summaryrefslogtreecommitdiffstats
path: root/libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp
diff options
context:
space:
mode:
authorEric Fiselier <eric@efcs.ca>2018-02-04 01:03:08 +0000
committerEric Fiselier <eric@efcs.ca>2018-02-04 01:03:08 +0000
commitafeda5c251f9a4696ab9178ecc6d4be7af72c105 (patch)
treef49c0a1be7b9f7fa4694596d7bd34f775ca19669 /libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp
parentfc5bd023dd9654c09267c287c3d26ddceeaf4161 (diff)
downloadbcm5719-llvm-afeda5c251f9a4696ab9178ecc6d4be7af72c105.tar.gz
bcm5719-llvm-afeda5c251f9a4696ab9178ecc6d4be7af72c105.zip
[libc++] Fix PR35491 - std::array of zero-size doesn't work with non-default constructible types.
Summary: This patch fixes llvm.org/PR35491 and LWG2157 (https://cplusplus.github.io/LWG/issue2157) The fix attempts to maintain ABI compatibility by replacing the array with a instance of `aligned_storage`. Reviewers: mclow.lists, EricWF Reviewed By: EricWF Subscribers: lichray, cfe-commits Differential Revision: https://reviews.llvm.org/D41223 llvm-svn: 324182
Diffstat (limited to 'libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp')
-rw-r--r--libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp b/libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp
index 5be082eeb84..f10d51580dd 100644
--- a/libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp
+++ b/libcxx/test/std/containers/sequences/array/array.data/data_const.pass.cpp
@@ -38,6 +38,16 @@ int main()
const T* p = c.data();
(void)p; // to placate scan-build
}
+ {
+ struct NoDefault {
+ NoDefault(int) {}
+ };
+ typedef NoDefault T;
+ typedef std::array<T, 0> C;
+ const C c = {};
+ const T* p = c.data();
+ assert(p != nullptr);
+ }
#if TEST_STD_VER > 14
{
typedef std::array<int, 5> C;
OpenPOWER on IntegriCloud