FastLED 3.9.15
Loading...
Searching...
No Matches

◆ insert_or_assign() [1/2]

template<typename Key, typename T, typename Hash = Hash<Key>, typename KeyEqual = EqualTo<Key>, int INLINED_COUNT = FASTLED_HASHMAP_INLINED_COUNT>
pair< iterator, bool > fl::unordered_map< Key, T, Hash, KeyEqual, INLINED_COUNT >::insert_or_assign ( const Key & key,
T && value )
inline

Definition at line 415 of file unordered_map.h.

415 {
416 const bool will_rehash = needs_rehash();
417 if (will_rehash) {
418 if (_tombstones > _size) {
420 } else {
421 rehash_internal(_buckets.size() * 2);
422 }
423 }
425 bool is_new;
427 idx = p.first;
428 is_new = p.second;
429 if (is_new) {
430 _buckets[idx].key = key;
431 _buckets[idx].value = fl::move(value);
433 ++_size;
434 } else {
435 FASTLED_ASSERT(idx != npos(), "unordered_map::insert_or_assign: invalid index");
436 _buckets[idx].value = fl::move(value);
437 }
438 return {iterator(this, idx), is_new};
439 }
static fl::size npos()
void mark_occupied(fl::size idx)
FL_DISABLE_WARNING_PUSH FL_DISABLE_WARNING_NULL_DEREFERENCE void rehash_inline_no_resize()
fl::vector_inlined< Entry, INLINED_COUNT > _buckets
pair< fl::size, bool > find_slot(const Key &key) const
bool needs_rehash() const
void rehash_internal(fl::size new_cap)
constexpr remove_reference< T >::type && move(T &&t) FL_NOEXCEPT
Definition s16x16x4.h:28