util/IntrusiveHashSet: rename "slot" to "bucket"
This commit is contained in:
parent
3239fce5c1
commit
d0d095cbcd
@ -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];
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user