diff options
author | Jonathan Wakely <jwakely@redhat.com> | 2025-03-21 22:49:44 +0000 |
---|---|---|
committer | Jonathan Wakely <redi@gcc.gnu.org> | 2025-03-24 11:34:49 +0000 |
commit | 75df481fcc381d6aaefdbe2ef1d66927e30b5743 (patch) | |
tree | 2be9a2780c2e6535cd6021df809c6f3ba0b26580 /gcc | |
parent | beec790e2b5d55058c4323731ccffd07c203fd71 (diff) | |
download | gcc-75df481fcc381d6aaefdbe2ef1d66927e30b5743.zip gcc-75df481fcc381d6aaefdbe2ef1d66927e30b5743.tar.gz gcc-75df481fcc381d6aaefdbe2ef1d66927e30b5743.tar.bz2 |
libstdc++: Ensure that std::vector<bool> allocator has bool value_type
This is the subject of LWG 4228 which notes that libstdc++ doesn't
enforce this requirement. That's just a bug because I forgot to add it
to vector<bool> when adding it elsewhere.
For consistency with the other containers we should not allow incorrect
allocator types for strict -std=c++NN modes, but it is very late to make
that change for GCC 15 so this only enables the assertion for C++20
(where it's required). For GCC 16 we can enable it for strict modes too.
libstdc++-v3/ChangeLog:
* include/bits/stl_bvector.h (vector<bool, A>): Enforce the
C++20 requirement that the allocator's value_type matches the
container.
* testsuite/23_containers/vector/bool/cons/from_range.cc: Fix
incorrect allocator type.
Reviewed-by: Tomasz KamiĆski <tkaminsk@redhat.com>
Diffstat (limited to 'gcc')
0 files changed, 0 insertions, 0 deletions