mirror of
https://github.com/fergalmoran/ladybird.git
synced 2026-04-05 04:06:08 +00:00
AK: Remove a redundant double find-call in HashMap::ensure
If the value was found there's no reason to search for it again.
This commit is contained in:
13
AK/HashMap.h
13
AK/HashMap.h
@@ -134,8 +134,10 @@ public:
|
||||
V& ensure(const K& key)
|
||||
{
|
||||
auto it = find(key);
|
||||
if (it == end())
|
||||
set(key, V());
|
||||
if (it != end())
|
||||
return it->value;
|
||||
auto result = set(key, V());
|
||||
VERIFY(result == HashSetResult::InsertedNewEntry);
|
||||
return find(key)->value;
|
||||
}
|
||||
|
||||
@@ -143,9 +145,10 @@ public:
|
||||
V& ensure(K const& key, Callback initialization_callback)
|
||||
{
|
||||
auto it = find(key);
|
||||
if (it == end()) {
|
||||
set(key, initialization_callback());
|
||||
}
|
||||
if (it != end())
|
||||
return it->value;
|
||||
auto result = set(key, initialization_callback());
|
||||
VERIFY(result == HashSetResult::InsertedNewEntry);
|
||||
return find(key)->value;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user