Skip to content

Commit

Permalink
Add more debug capacity validation checks on moves.
Browse files Browse the repository at this point in the history
PiperOrigin-RevId: 708037486
Change-Id: I2868a3de5e7ec9341d06450caf86706d61988721
  • Loading branch information
ezbr authored and copybara-github committed Dec 19, 2024
1 parent cd9dd42 commit 50292b7
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 5 deletions.
11 changes: 6 additions & 5 deletions absl/container/internal/raw_hash_set.h
Original file line number Diff line number Diff line change
Expand Up @@ -2823,9 +2823,10 @@ class raw_hash_set {
// `that` must be left valid. If Hash is std::function<Key>, moving it
// would create a nullptr functor that cannot be called.
// Note: we avoid using exchange for better generated code.
settings_(PolicyTraits::transfer_uses_memcpy() || !that.is_full_soo()
? std::move(that.common())
: CommonFields{full_soo_tag_t{}},
settings_((that.AssertNotDebugCapacity(),
PolicyTraits::transfer_uses_memcpy() || !that.is_full_soo()
? std::move(that.common())
: CommonFields{full_soo_tag_t{}}),
that.hash_ref(), that.eq_ref(), that.alloc_ref()) {
if (!PolicyTraits::transfer_uses_memcpy() && that.is_full_soo()) {
transfer(soo_slot(), that.soo_slot());
Expand All @@ -2837,6 +2838,7 @@ class raw_hash_set {
raw_hash_set(raw_hash_set&& that, const allocator_type& a)
: settings_(CommonFields::CreateDefault<SooEnabled()>(), that.hash_ref(),
that.eq_ref(), a) {
that.AssertNotDebugCapacity();
if (a == that.alloc_ref()) {
swap_common(that);
annotate_for_bug_detection_on_move(that);
Expand All @@ -2863,8 +2865,7 @@ class raw_hash_set {
absl::allocator_traits<allocator_type>::is_always_equal::value &&
std::is_nothrow_move_assignable<hasher>::value &&
std::is_nothrow_move_assignable<key_equal>::value) {
// TODO(sbenza): We should only use the operations from the noexcept clause
// to make sure we actually adhere to that contract.
that.AssertNotDebugCapacity();
// NOLINTNEXTLINE: not returning *this for performance.
return move_assign(
std::move(that),
Expand Down
2 changes: 2 additions & 0 deletions absl/container/internal/raw_hash_set_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -3715,6 +3715,8 @@ TEST(Table, MovedFromCallsFail) {
EXPECT_DEATH_IF_SUPPORTED(t1.end(), "moved-from");
// NOLINTNEXTLINE(bugprone-use-after-move)
EXPECT_DEATH_IF_SUPPORTED(t1.size(), "moved-from");
// NOLINTNEXTLINE(bugprone-use-after-move)
EXPECT_DEATH_IF_SUPPORTED(IntTable{std::move(t1)}, "moved-from");
}
{
ABSL_ATTRIBUTE_UNUSED IntTable t1;
Expand Down

0 comments on commit 50292b7

Please sign in to comment.