From cd9798d01fab3ce4ab29621176b1292ec9c66347 Mon Sep 17 00:00:00 2001 From: Gwilym Kuiper Date: Sat, 19 Mar 2022 22:04:53 +0000 Subject: [PATCH] Move the implementation of get_location to NodeStorage --- agb/src/hash_map.rs | 21 +++++++-------------- 1 file changed, 7 insertions(+), 14 deletions(-) diff --git a/agb/src/hash_map.rs b/agb/src/hash_map.rs index 999427b0..b8e6a474 100644 --- a/agb/src/hash_map.rs +++ b/agb/src/hash_map.rs @@ -207,15 +207,6 @@ const fn fast_mod(len: usize, hash: HashType) -> usize { (hash as usize) & (len - 1) } -impl HashMap -where - K: Eq, -{ - fn get_location(&self, key: &K, hash: HashType) -> Option { - self.nodes.get_location(key, hash) - } -} - impl HashMap where K: Eq + Hash, @@ -223,7 +214,7 @@ where pub fn insert(&mut self, key: K, value: V) -> Option { let hash = self.hash(&key); - if let Some(location) = self.get_location(&key, hash) { + if let Some(location) = self.nodes.get_location(&key, hash) { let old_node = self.nodes.nodes[location].take().unwrap(); let (new_node, old_value) = old_node.with_new_key_value(key, value); self.nodes.nodes[location] = Some(new_node); @@ -242,14 +233,15 @@ where pub fn get(&self, key: &K) -> Option<&V> { let hash = self.hash(key); - self.get_location(key, hash) + self.nodes + .get_location(key, hash) .map(|location| &self.nodes.nodes[location].as_ref().unwrap().value) } pub fn get_mut(&mut self, key: &K) -> Option<&mut V> { let hash = self.hash(key); - if let Some(location) = self.get_location(key, hash) { + if let Some(location) = self.nodes.get_location(key, hash) { Some(&mut self.nodes.nodes[location].as_mut().unwrap().value) } else { None @@ -259,7 +251,8 @@ where pub fn remove(&mut self, key: &K) -> Option { let hash = self.hash(key); - self.get_location(key, hash) + self.nodes + .get_location(key, hash) .map(|location| self.nodes.remove_from_location(location)) } } @@ -362,7 +355,7 @@ where { pub fn entry(&mut self, key: K) -> Entry<'_, K, V> { let hash = self.hash(&key); - let location = self.get_location(&key, hash); + let location = self.nodes.get_location(&key, hash); if let Some(location) = location { Entry::Occupied(OccupiedEntry {