FastLED
3.9.15
Loading...
Searching...
No Matches
◆
insert_or_assign()
[2/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
(
Key
&&
key
,
T &&
value
)
inline
Definition at line
442
of file
unordered_map.h
.
442
{
443
const
bool
will_rehash
=
needs_rehash
();
444
if
(
will_rehash
) {
445
if
(
_tombstones
>
_size
) {
446
rehash_inline_no_resize
();
447
}
else
{
448
rehash_internal
(
_buckets
.size() * 2);
449
}
450
}
451
fl::size
idx
;
452
bool
is_new
;
453
fl::pair<fl::size, bool>
p
=
find_slot
(
key
);
454
idx
=
p
.first;
455
is_new
=
p
.second;
456
if
(
is_new
) {
457
_buckets
[
idx
].key =
fl::move
(
key
);
458
_buckets
[
idx
].value =
fl::move
(
value
);
459
mark_occupied
(
idx
);
460
++
_size
;
461
}
else
{
462
FASTLED_ASSERT
(
idx
!=
npos
(),
"unordered_map::insert_or_assign: invalid index"
);
463
_buckets
[
idx
].value =
fl::move
(
value
);
464
}
465
return
{
iterator
(
this
,
idx
),
is_new
};
466
}
fl::unordered_map::npos
static fl::size npos()
Definition
unordered_map.h:804
fl::unordered_map::mark_occupied
void mark_occupied(fl::size idx)
Definition
unordered_map.h:817
fl::unordered_map::rehash_inline_no_resize
FL_DISABLE_WARNING_PUSH FL_DISABLE_WARNING_NULL_DEREFERENCE void rehash_inline_no_resize()
Definition
unordered_map.h:1009
fl::unordered_map::_buckets
fl::vector_inlined< Entry, INLINED_COUNT > _buckets
Definition
unordered_map.h:1117
fl::unordered_map::_size
fl::size _size
Definition
unordered_map.h:1118
fl::unordered_map::find_slot
pair< fl::size, bool > find_slot(const Key &key) const
Definition
unordered_map.h:849
fl::unordered_map::needs_rehash
bool needs_rehash() const
Definition
unordered_map.h:318
fl::unordered_map::rehash_internal
void rehash_internal(fl::size new_cap)
Definition
unordered_map.h:984
fl::unordered_map::_tombstones
fl::size _tombstones
Definition
unordered_map.h:1119
fl::unordered_map
Definition
unordered_map.h:58
fl::fl::move
constexpr remove_reference< T >::type && move(T &&t) FL_NOEXCEPT
Definition
s16x16x4.h:28
fl::unordered_map::iterator
Definition
unordered_map.h:187
fl
unordered_map
Generated on Tue Jun 16 2026 00:07:07 for FastLED by
1.13.2