diff options
author | Paul Rigge <rigge@google.com> | 2024-02-28 11:38:24 -0800 |
---|---|---|
committer | Copybara-Service <copybara-worker@google.com> | 2024-02-28 11:39:10 -0800 |
commit | b7372748dcdc35f40c12742cb57947a409e7f0b7 (patch) | |
tree | ef41be8ed2a3a83e5eed22c198b9564d34f46462 /absl | |
parent | 953cec754aca513df7163abb8859c6b81dc9b202 (diff) |
Rework casting in raw_hash_set's `IsFull()`.
Instead of casting an int to the enum type where the int does not have an associated enum value, cast the enum to its underlying type. This should be no functional change but make some linters happier.
PiperOrigin-RevId: 611172311
Change-Id: I9ae10f8fa2029014236f60a90ee2ab2273c66fa5
Diffstat (limited to 'absl')
-rw-r--r-- | absl/container/internal/raw_hash_set.h | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/absl/container/internal/raw_hash_set.h b/absl/container/internal/raw_hash_set.h index 7b33de63..07ff79af 100644 --- a/absl/container/internal/raw_hash_set.h +++ b/absl/container/internal/raw_hash_set.h @@ -571,7 +571,9 @@ inline h2_t H2(size_t hash) { return hash & 0x7F; } // Helpers for checking the state of a control byte. inline bool IsEmpty(ctrl_t c) { return c == ctrl_t::kEmpty; } -inline bool IsFull(ctrl_t c) { return c >= static_cast<ctrl_t>(0); } +inline bool IsFull(ctrl_t c) { + return static_cast<std::underlying_type_t<ctrl_t>>(c) >= 0; +} inline bool IsDeleted(ctrl_t c) { return c == ctrl_t::kDeleted; } inline bool IsEmptyOrDeleted(ctrl_t c) { return c < ctrl_t::kSentinel; } |