FastLED
3.9.15
Loading...
Searching...
No Matches
◆
try_emplace()
[1/2]
template<typename
Key
, typename T, typename
Hash
= Hash<Key>, typename KeyEqual = EqualTo<Key>, int INLINED_COUNT = FASTLED_HASHMAP_INLINED_COUNT>
template<typename... Args>
pair
<
iterator
, bool >
fl::unordered_map
<
Key
, T,
Hash
, KeyEqual, INLINED_COUNT >::try_emplace
(
const
Key
&
k
,
Args &&...
args
)
inline
Definition at line
489
of file
unordered_map.h
.
489
{
490
const
bool
will_rehash
=
needs_rehash
();
491
if
(
will_rehash
) {
492
if
(
_tombstones
>
_size
) {
493
rehash_inline_no_resize
();
494
}
else
{
495
rehash_internal
(
_buckets
.size() * 2);
496
}
497
}
498
fl::size
idx
;
499
bool
is_new
;
500
fl::pair<fl::size, bool>
p
=
find_slot
(
k
);
501
idx
=
p
.first;
502
is_new
=
p
.second;
503
if
(
is_new
) {
504
// Key doesn't exist, construct in place
505
_buckets
[
idx
].key =
k
;
506
_buckets
[
idx
].value =
T
(
fl::forward<Args>
(
args
)...);
507
mark_occupied
(
idx
);
508
++
_size
;
509
}
510
// If not new, key already exists - don't construct value, just return existing iterator
511
return
{
iterator
(
this
,
idx
),
is_new
};
512
}
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::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