summaryrefslogtreecommitdiffstats
path: root/libcxx/test/std/containers/sequences/array/begin.pass.cpp
diff options
context:
space:
mode:
authorEric Fiselier <eric@efcs.ca>2018-02-07 21:06:13 +0000
committerEric Fiselier <eric@efcs.ca>2018-02-07 21:06:13 +0000
commit59cdf90ac8bea16abbb9d637c5124e69d2c75c09 (patch)
tree7e83250085a292fb115644f4f755585e7a13e354 /libcxx/test/std/containers/sequences/array/begin.pass.cpp
parentb57409f2b64e96e34c2ee716ecbd74c6c102696a (diff)
downloadbcm5719-llvm-59cdf90ac8bea16abbb9d637c5124e69d2c75c09.tar.gz
bcm5719-llvm-59cdf90ac8bea16abbb9d637c5124e69d2c75c09.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: 324526
Diffstat (limited to 'libcxx/test/std/containers/sequences/array/begin.pass.cpp')
-rw-r--r--libcxx/test/std/containers/sequences/array/begin.pass.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/libcxx/test/std/containers/sequences/array/begin.pass.cpp b/libcxx/test/std/containers/sequences/array/begin.pass.cpp
index b12ffc851b8..282a947fefe 100644
--- a/libcxx/test/std/containers/sequences/array/begin.pass.cpp
+++ b/libcxx/test/std/containers/sequences/array/begin.pass.cpp
@@ -18,6 +18,7 @@
// Disable the missing braces warning for this reason.
#include "disable_missing_braces_warning.h"
+
int main()
{
{
@@ -31,4 +32,13 @@ int main()
*i = 5.5;
assert(c[0] == 5.5);
}
+ {
+ struct NoDefault {
+ NoDefault(int) {}
+ };
+ typedef NoDefault T;
+ typedef std::array<T, 0> C;
+ C c = {};
+ assert(c.begin() == c.end());
+ }
}
OpenPOWER on IntegriCloud