Skip to content

Commit

Permalink
Merge pull request #175 from cuviper/or_insert_with_key
Browse files Browse the repository at this point in the history
add Entry::or_insert_with_key like Rust 1.50
  • Loading branch information
cuviper authored Mar 1, 2021
2 parents ddc2088 + eebb54c commit 1f1e049
Showing 1 changed file with 18 additions and 0 deletions.
18 changes: 18 additions & 0 deletions src/map/core.rs
Original file line number Diff line number Diff line change
Expand Up @@ -470,6 +470,24 @@ impl<'a, K, V> Entry<'a, K, V> {
}
}

/// Inserts the result of the `call` function with a reference to the entry's key if it is
/// vacant, and returns a mutable reference to the new value. Otherwise a mutable reference to
/// an already existent value is returned.
///
/// Computes in **O(1)** time (amortized average).
pub fn or_insert_with_key<F>(self, call: F) -> &'a mut V
where
F: FnOnce(&K) -> V,
{
match self {
Entry::Occupied(entry) => entry.into_mut(),
Entry::Vacant(entry) => {
let value = call(&entry.key);
entry.insert(value)
}
}
}

/// Gets a reference to the entry's key, either within the map if occupied,
/// or else the new key that was used to find the entry.
pub fn key(&self) -> &K {
Expand Down

0 comments on commit 1f1e049

Please # to comment.