mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-23 07:36:33 +11:00
Implement insert correctly
This commit is contained in:
parent
24b61f51fe
commit
c7db20c1df
1 changed files with 18 additions and 2 deletions
|
@ -102,7 +102,23 @@ impl<K, V> HashMap<K, V>
|
|||
where
|
||||
K: Eq + Hash,
|
||||
{
|
||||
pub fn insert(&mut self, key: K, value: V) -> &mut V {
|
||||
pub fn insert(&mut self, key: K, value: V) -> Option<V> {
|
||||
let hash = self.hash(&key);
|
||||
|
||||
if let Some(location) = self.nodes.get_location(&key, hash) {
|
||||
Some(self.nodes.replace_at_location(location, key, value))
|
||||
} else {
|
||||
if self.nodes.capacity() * 85 / 100 <= self.len() {
|
||||
self.resize(self.nodes.capacity() * 2);
|
||||
}
|
||||
|
||||
self.nodes.insert_new(key, value, hash);
|
||||
|
||||
None
|
||||
}
|
||||
}
|
||||
|
||||
fn insert_and_get(&mut self, key: K, value: V) -> &'_ mut V {
|
||||
let hash = self.hash(&key);
|
||||
|
||||
let location = if let Some(location) = self.nodes.get_location(&key, hash) {
|
||||
|
@ -254,7 +270,7 @@ impl<'a, K: 'a, V: 'a> VacantEntry<'a, K, V> {
|
|||
where
|
||||
K: Hash + Eq,
|
||||
{
|
||||
self.map.insert(self.key, value)
|
||||
self.map.insert_and_get(self.key, value)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue