More unsafe where needed

This commit is contained in:
Gwilym Inzani 2023-05-09 22:43:06 +01:00
parent f530276638
commit 7873f9ed5c
3 changed files with 31 additions and 25 deletions

View file

@ -314,7 +314,13 @@ where
let hash = self.hash(&key); let hash = self.hash(&key);
if let Some(location) = self.nodes.location(&key, hash) { if let Some(location) = self.nodes.location(&key, hash) {
Some(self.nodes.replace_at_location(location, key, value)) Some(
// SAFETY: location is valid due to the above
unsafe {
self.nodes
.replace_at_location_unchecked(location, key, value)
},
)
} else { } else {
if self.nodes.capacity() <= self.len() { if self.nodes.capacity() <= self.len() {
self.resize(self.nodes.backing_vec_size() * 2); self.resize(self.nodes.backing_vec_size() * 2);
@ -330,7 +336,11 @@ where
let hash = self.hash(&key); let hash = self.hash(&key);
let location = if let Some(location) = self.nodes.location(&key, hash) { let location = if let Some(location) = self.nodes.location(&key, hash) {
self.nodes.replace_at_location(location, key, value); // SAFETY: location is valid due to the above
unsafe {
self.nodes
.replace_at_location_unchecked(location, key, value);
}
location location
} else { } else {
if self.nodes.capacity() <= self.len() { if self.nodes.capacity() <= self.len() {
@ -340,7 +350,12 @@ where
self.nodes.insert_new(key, value, hash) self.nodes.insert_new(key, value, hash)
}; };
self.nodes.node_at_mut(location).value_mut().unwrap() // SAFETY: location is always valid
unsafe {
self.nodes
.node_at_unchecked_mut(location)
.value_mut_unchecked()
}
} }
/// Returns `true` if the map contains a value for the specified key. /// Returns `true` if the map contains a value for the specified key.

View file

@ -38,17 +38,6 @@ impl<K, V> Node<K, V> {
self.value.assume_init_ref() self.value.assume_init_ref()
} }
pub(crate) fn value_mut(&mut self) -> Option<&mut V> {
if self.has_value() {
Some(
// SAFETY: has a value
unsafe { self.value_mut_unchecked() },
)
} else {
None
}
}
pub(crate) unsafe fn value_mut_unchecked(&mut self) -> &mut V { pub(crate) unsafe fn value_mut_unchecked(&mut self) -> &mut V {
self.value.assume_init_mut() self.value.assume_init_mut()
} }
@ -114,16 +103,11 @@ impl<K, V> Node<K, V> {
old_value.assume_init() old_value.assume_init()
} }
pub(crate) fn replace(&mut self, key: K, value: V) -> (K, V) { pub(crate) unsafe fn replace_unchecked(&mut self, key: K, value: V) -> (K, V) {
if self.has_value() { let old_key = mem::replace(&mut self.key, MaybeUninit::new(key));
let old_key = mem::replace(&mut self.key, MaybeUninit::new(key)); let old_value = mem::replace(&mut self.value, MaybeUninit::new(value));
let old_value = mem::replace(&mut self.value, MaybeUninit::new(value));
// SAFETY: has a value (old_key.assume_init(), old_value.assume_init())
unsafe { (old_key.assume_init(), old_value.assume_init()) }
} else {
panic!("Cannot replace an uninitialised node");
}
} }
pub(crate) fn increment_distance(&mut self) { pub(crate) fn increment_distance(&mut self) {

View file

@ -164,8 +164,15 @@ impl<K, V, ALLOCATOR: ClonableAllocator> NodeStorage<K, V, ALLOCATOR> {
new_node_storage new_node_storage
} }
pub(crate) fn replace_at_location(&mut self, location: usize, key: K, value: V) -> V { pub(crate) unsafe fn replace_at_location_unchecked(
self.nodes[location].replace(key, value).1 &mut self,
location: usize,
key: K,
value: V,
) -> V {
self.node_at_unchecked_mut(location)
.replace_unchecked(key, value)
.1
} }
pub(crate) fn iter_mut(&mut self) -> impl Iterator<Item = &mut Node<K, V>> { pub(crate) fn iter_mut(&mut self) -> impl Iterator<Item = &mut Node<K, V>> {