mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-11 07:21:51 +00:00
Auto merge of #44278 - Binero:master, r=BurntSushi
Allow replacing HashMap entries This is an obvious API hole. At the moment the only way to retrieve an entry from a `HashMap` is to get an entry to it, remove it, and then insert a new entry. This PR allows entries to be replaced.
This commit is contained in:
commit
3c96d40d32
@ -2191,6 +2191,36 @@ impl<'a, K, V> OccupiedEntry<'a, K, V> {
|
|||||||
fn take_key(&mut self) -> Option<K> {
|
fn take_key(&mut self) -> Option<K> {
|
||||||
self.key.take()
|
self.key.take()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Replaces the entry, returning the old key and value.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// #![feature(map_entry_replace)]
|
||||||
|
/// use std::collections::HashMap;
|
||||||
|
/// use std::collections::hash_map::Entry;
|
||||||
|
///
|
||||||
|
/// let mut map: HashMap<String, u32> = HashMap::new();
|
||||||
|
/// map.insert("poneyland".to_string(), 15);
|
||||||
|
///
|
||||||
|
/// if let Entry::Occupied(entry) = map.entry("poneyland".to_string()) {
|
||||||
|
/// let (old_key, old_value): (String, u32) = entry.replace(16);
|
||||||
|
/// assert_eq!(old_key, "poneyland");
|
||||||
|
/// assert_eq!(old_value, 15);
|
||||||
|
/// }
|
||||||
|
///
|
||||||
|
/// assert_eq!(map.get("poneyland"), Some(&16));
|
||||||
|
/// ```
|
||||||
|
#[unstable(feature = "map_entry_replace", issue = "44286")]
|
||||||
|
pub fn replace(mut self, value: V) -> (K, V) {
|
||||||
|
let (old_key, old_value) = self.elem.read_mut();
|
||||||
|
|
||||||
|
let old_key = mem::replace(old_key, self.key.unwrap());
|
||||||
|
let old_value = mem::replace(old_value, value);
|
||||||
|
|
||||||
|
(old_key, old_value)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, K: 'a, V: 'a> VacantEntry<'a, K, V> {
|
impl<'a, K: 'a, V: 'a> VacantEntry<'a, K, V> {
|
||||||
|
Loading…
Reference in New Issue
Block a user