summaryrefslogtreecommitdiff
path: root/absl/container
diff options
context:
space:
mode:
authorGravatar Derek Mauro <dmauro@google.com>2022-08-31 13:44:00 -0700
committerGravatar Copybara-Service <copybara-worker@google.com>2022-08-31 13:44:42 -0700
commit43d3c7a4e290ee96684735daf7b1d528c30a7943 (patch)
treeba10e3e2dcb71ff4a5bd6cc3e51c39efac377fe2 /absl/container
parent6a262fdaddb6cd7df7ddc8472a1cc61cc64a01db (diff)
InlinedVector: Correct the computation of max_size()
Corrects the computation of max_size(), so that it accounts for the size of the objects. PiperOrigin-RevId: 471343778 Change-Id: I68e222cefaa0295b8d8c38d00308a29df4165e81
Diffstat (limited to 'absl/container')
-rw-r--r--absl/container/inlined_vector.h5
-rw-r--r--absl/container/inlined_vector_test.cc1
2 files changed, 4 insertions, 2 deletions
diff --git a/absl/container/inlined_vector.h b/absl/container/inlined_vector.h
index bc1c4a77..42121228 100644
--- a/absl/container/inlined_vector.h
+++ b/absl/container/inlined_vector.h
@@ -275,8 +275,9 @@ class InlinedVector {
size_type max_size() const noexcept {
// One bit of the size storage is used to indicate whether the inlined
// vector contains allocated memory. As a result, the maximum size that the
- // inlined vector can express is half of the max for `size_type`.
- return (std::numeric_limits<size_type>::max)() / 2;
+ // inlined vector can express is half of the max for
+ // AllocatorTraits<A>::max_size();
+ return AllocatorTraits<A>::max_size(storage_.GetAllocator()) / 2;
}
// `InlinedVector::capacity()`
diff --git a/absl/container/inlined_vector_test.cc b/absl/container/inlined_vector_test.cc
index 4c1ba04a..0e528113 100644
--- a/absl/container/inlined_vector_test.cc
+++ b/absl/container/inlined_vector_test.cc
@@ -255,6 +255,7 @@ TEST(IntVec, Hardened) {
#if !defined(NDEBUG) || ABSL_OPTION_HARDENED
EXPECT_DEATH_IF_SUPPORTED(v[10], "");
EXPECT_DEATH_IF_SUPPORTED(v[-1], "");
+ EXPECT_DEATH_IF_SUPPORTED(v.resize(v.max_size() + 1), "");
#endif
}