util/IntrusiveHashSet: rename "slot" to "bucket"

This commit is contained in:
Max Kellermann 2022-11-21 09:13:58 +01:00
parent 3239fce5c1
commit d0d095cbcd

View File

@ -109,7 +109,7 @@ class IntrusiveHashSet {
[[no_unique_address]] [[no_unique_address]]
Equal equal; Equal equal;
struct SlotHookTraits { struct BucketHookTraits {
template<typename U> template<typename U>
using HashSetHook = typename HookTraits::template Hook<U>; using HashSetHook = typename HookTraits::template Hook<U>;
@ -130,10 +130,10 @@ class IntrusiveHashSet {
} }
}; };
using Slot = IntrusiveList<T, SlotHookTraits>; using Bucket = IntrusiveList<T, BucketHookTraits>;
std::array<Slot, table_size> table; std::array<Bucket, table_size> table;
using slot_iterator = typename Slot::iterator; using bucket_iterator = typename Bucket::iterator;
public: public:
using value_type = T; using value_type = T;
@ -164,8 +164,8 @@ public:
if constexpr (constant_time_size) if constexpr (constant_time_size)
return size() == 0; return size() == 0;
else else
return std::all_of(table.begin(), table.end(), [](const auto &slot){ return std::all_of(table.begin(), table.end(), [](const auto &bucket){
return slot.empty(); return bucket.empty();
}); });
} }
@ -174,8 +174,8 @@ public:
if constexpr (constant_time_size) if constexpr (constant_time_size)
return counter; return counter;
else else
return std::accumulate(table.begin(), table.end(), size_type{}, [](std::size_t n, const auto &slot){ return std::accumulate(table.begin(), table.end(), size_type{}, [](std::size_t n, const auto &bucket){
return n + slot.size(); return n + bucket.size();
}); });
} }
@ -202,53 +202,53 @@ public:
} }
[[nodiscard]] [[nodiscard]]
static constexpr slot_iterator iterator_to(reference item) noexcept { static constexpr bucket_iterator iterator_to(reference item) noexcept {
return Slot::iterator_to(item); return Bucket::iterator_to(item);
} }
[[nodiscard]] [[gnu::pure]] [[nodiscard]] [[gnu::pure]]
constexpr std::pair<slot_iterator, bool> insert_check(const auto &key) noexcept { constexpr std::pair<bucket_iterator, bool> insert_check(const auto &key) noexcept {
auto &slot = GetSlot(key); auto &bucket = GetBucket(key);
for (auto &i : slot) for (auto &i : bucket)
if (equal(key, i)) if (equal(key, i))
return {slot.iterator_to(i), false}; return {bucket.iterator_to(i), false};
return {slot.begin(), true}; return {bucket.begin(), true};
} }
constexpr void insert(slot_iterator slot, reference item) noexcept { constexpr void insert(bucket_iterator bucket, reference item) noexcept {
++counter; ++counter;
GetSlot(item).insert(slot, item); GetBucket(item).insert(bucket, item);
} }
constexpr void insert(reference item) noexcept { constexpr void insert(reference item) noexcept {
++counter; ++counter;
GetSlot(item).push_front(item); GetBucket(item).push_front(item);
} }
constexpr slot_iterator erase(slot_iterator i) noexcept { constexpr bucket_iterator erase(bucket_iterator i) noexcept {
--counter; --counter;
return GetSlot(*i).erase(i); return GetBucket(*i).erase(i);
} }
constexpr slot_iterator erase_and_dispose(slot_iterator i, constexpr bucket_iterator erase_and_dispose(bucket_iterator i,
auto &&disposer) noexcept { auto &&disposer) noexcept {
auto result = erase(i); auto result = erase(i);
disposer(&*i); disposer(&*i);
return result; return result;
} }
[[nodiscard]] [[gnu::pure]] [[nodiscard]] [[gnu::pure]]
constexpr slot_iterator find(const auto &key) noexcept { constexpr bucket_iterator find(const auto &key) noexcept {
auto &slot = GetSlot(key); auto &bucket = GetBucket(key);
for (auto &i : slot) for (auto &i : bucket)
if (equal(key, i)) if (equal(key, i))
return slot.iterator_to(i); return bucket.iterator_to(i);
return end(); return end();
} }
constexpr slot_iterator end() noexcept { constexpr bucket_iterator end() noexcept {
return table.front().end(); return table.front().end();
} }
@ -268,7 +268,7 @@ private:
template<typename K> template<typename K>
[[gnu::pure]] [[gnu::pure]]
[[nodiscard]] [[nodiscard]]
constexpr auto &GetSlot(K &&key) noexcept { constexpr auto &GetBucket(K &&key) noexcept {
const auto h = hash(std::forward<K>(key)); const auto h = hash(std::forward<K>(key));
return table[h % table_size]; return table[h % table_size];
} }