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.
Paths
| Differential D41223
[libc++] Fix PR35491 - std::array of zero-size doesn't work with non-default constructible types. ClosedPublic Authored by EricWF on Dec 13 2017, 10:45 PM.
Details
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.
Diff Detail
Event TimelineComment Actions I'm wondering if it's not a better idea to have an explicit specialization for size == 0 template <class T> class array<T, 0> { // and so on. }; Comment Actions BTW, this is https://cplusplus.github.io/LWG/issue2157 , so please update www accordingly, and also test {{}} cases. Comment Actions
I think that's probably more work than it's worth. I think we should change the primary template to support the bare minimum number of operations, and then let the rest of the operations blow up if users attempt to use them.
The www pages will get updated when the issue is actually accepted, which it currently isn't.
I don't agree those cases are valid. That initialization syntax suggests there is something in the zero-sized array which is default constructible - or that users should be able to control construction of. I disagree with that.
Comment Actions
Nevermind, I see STL is insisting that case be handled. I'll add tests and then complain to him later. This revision is now accepted and ready to land.Feb 3 2018, 5:03 PM Closed by commit rCXX324182: [libc++] Fix PR35491 - std::array of zero-size doesn't work with non-default… (authored by EricWF). · Explain WhyFeb 3 2018, 5:04 PM This revision was automatically updated to reflect the committed changes. This revision is now accepted and ready to land.Feb 7 2018, 1:04 PM Closed by commit rCXX324526: [libc++] Fix PR35491 - std::array of zero-size doesn't work with non-default… (authored by EricWF). · Explain WhyFeb 7 2018, 1:08 PM Closed by commit rL324526: [libc++] Fix PR35491 - std::array of zero-size doesn't work with non-default… (authored by EricWF). · Explain Why This revision was automatically updated to reflect the committed changes. This revision was automatically updated to reflect the committed changes. Comment Actions The lack of _LIBCPP_CONSTEXPR_AFTER_CXX14 on the array<T, 0> specialization's begin(), end(), and other methods seems to be a bug: https://stackoverflow.com/questions/60462569/empty-stdarrayt-0-doesnt-have-constexpr-begin Comment Actions
That bug is llvm.org/PR40124. There are good reasons why it hasn't been fixed yet.
Revision Contents
Diff 133288 libcxx/trunk/include/__config
libcxx/trunk/include/array
libcxx/trunk/test/libcxx/containers/sequences/array/array.zero/db_back.pass.cpp
libcxx/trunk/test/libcxx/containers/sequences/array/array.zero/db_front.pass.cpp
libcxx/trunk/test/libcxx/containers/sequences/array/array.zero/db_indexing.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/array.cons/default.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/array.cons/implicit_copy.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/array.data/data.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/array.data/data_const.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/array.fill/fill.fail.cpp
libcxx/trunk/test/std/containers/sequences/array/array.swap/swap.fail.cpp
libcxx/trunk/test/std/containers/sequences/array/at.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/begin.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/compare.fail.cpp
libcxx/trunk/test/std/containers/sequences/array/compare.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/empty.fail.cpp
libcxx/trunk/test/std/containers/sequences/array/front_back.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/indexing.pass.cpp
libcxx/trunk/test/std/containers/sequences/array/size_and_alignment.pass.cpp
|