Skip to content

Commit 83e75ac

Browse files
authored
Rollup merge of #75195 - ssomers:btree_split_up_into_kv_mut, r=Mark-Simulacrum
BTreeMap: purge innocent use of into_kv_mut Replace the use of `into_kv_mut` into more precise calls. This makes more sense if you know that the single remaining use of `into_kv_mut` is in fact evil and can be trialled in court (#75200) and sent to a correction facility (#73971). No real performance difference reported (but functions that might benefit a tiny constant bit like `BTreeMap::get_mut` aren't benchmarked): ``` benchcmp old new --threshold 5 name old ns/iter new ns/iter diff ns/iter diff % speedup btree::map::clone_fat_100 63,073 59,256 -3,817 -6.05% x 1.06 btree::map::iter_100 3,514 3,235 -279 -7.94% x 1.09 ```
2 parents 5b61230 + 3a02e06 commit 83e75ac

File tree

2 files changed

+19
-9
lines changed

2 files changed

+19
-9
lines changed

library/alloc/src/collections/btree/map.rs

+3-3
Original file line numberDiff line numberDiff line change
@@ -245,7 +245,7 @@ where
245245
fn replace(&mut self, key: K) -> Option<K> {
246246
let root = Self::ensure_is_owned(&mut self.root);
247247
match search::search_tree::<marker::Mut<'_>, K, (), K>(root.node_as_mut(), &key) {
248-
Found(handle) => Some(mem::replace(handle.into_kv_mut().0, key)),
248+
Found(handle) => Some(mem::replace(handle.into_key_mut(), key)),
249249
GoDown(handle) => {
250250
VacantEntry { key, handle, length: &mut self.length, _marker: PhantomData }
251251
.insert(());
@@ -811,7 +811,7 @@ impl<K: Ord, V> BTreeMap<K, V> {
811811
{
812812
let root_node = self.root.as_mut()?.node_as_mut();
813813
match search::search_tree(root_node, key) {
814-
Found(handle) => Some(handle.into_kv_mut().1),
814+
Found(handle) => Some(handle.into_val_mut()),
815815
GoDown(_) => None,
816816
}
817817
}
@@ -2748,7 +2748,7 @@ impl<'a, K: Ord, V> OccupiedEntry<'a, K, V> {
27482748
/// ```
27492749
#[stable(feature = "rust1", since = "1.0.0")]
27502750
pub fn into_mut(self) -> &'a mut V {
2751-
self.handle.into_kv_mut().1
2751+
self.handle.into_val_mut()
27522752
}
27532753

27542754
/// Sets the value of the entry with the `OccupiedEntry`'s key,

library/alloc/src/collections/btree/node.rs

+16-6
Original file line numberDiff line numberDiff line change
@@ -1067,6 +1067,16 @@ impl<'a, K: 'a, V: 'a, NodeType> Handle<NodeRef<marker::Immut<'a>, K, V, NodeTyp
10671067
}
10681068

10691069
impl<'a, K: 'a, V: 'a, NodeType> Handle<NodeRef<marker::Mut<'a>, K, V, NodeType>, marker::KV> {
1070+
pub fn into_key_mut(self) -> &'a mut K {
1071+
let keys = self.node.into_key_slice_mut();
1072+
unsafe { keys.get_unchecked_mut(self.idx) }
1073+
}
1074+
1075+
pub fn into_val_mut(self) -> &'a mut V {
1076+
let vals = self.node.into_val_slice_mut();
1077+
unsafe { vals.get_unchecked_mut(self.idx) }
1078+
}
1079+
10701080
pub fn into_kv_mut(self) -> (&'a mut K, &'a mut V) {
10711081
unsafe {
10721082
let (keys, vals) = self.node.into_slices_mut();
@@ -1261,8 +1271,8 @@ impl<'a, K, V> Handle<NodeRef<marker::Mut<'a>, K, V, marker::Internal>, marker::
12611271
unsafe {
12621272
let (k, v, edge) = self.reborrow_mut().left_edge().descend().pop();
12631273

1264-
let k = mem::replace(self.reborrow_mut().into_kv_mut().0, k);
1265-
let v = mem::replace(self.reborrow_mut().into_kv_mut().1, v);
1274+
let k = mem::replace(self.kv_mut().0, k);
1275+
let v = mem::replace(self.kv_mut().1, v);
12661276

12671277
match self.reborrow_mut().right_edge().descend().force() {
12681278
ForceResult::Leaf(mut leaf) => leaf.push_front(k, v),
@@ -1278,8 +1288,8 @@ impl<'a, K, V> Handle<NodeRef<marker::Mut<'a>, K, V, marker::Internal>, marker::
12781288
unsafe {
12791289
let (k, v, edge) = self.reborrow_mut().right_edge().descend().pop_front();
12801290

1281-
let k = mem::replace(self.reborrow_mut().into_kv_mut().0, k);
1282-
let v = mem::replace(self.reborrow_mut().into_kv_mut().1, v);
1291+
let k = mem::replace(self.kv_mut().0, k);
1292+
let v = mem::replace(self.kv_mut().1, v);
12831293

12841294
match self.reborrow_mut().left_edge().descend().force() {
12851295
ForceResult::Leaf(mut leaf) => leaf.push(k, v),
@@ -1307,7 +1317,7 @@ impl<'a, K, V> Handle<NodeRef<marker::Mut<'a>, K, V, marker::Internal>, marker::
13071317
let left_kv = left_node.reborrow_mut().into_kv_pointers_mut();
13081318
let right_kv = right_node.reborrow_mut().into_kv_pointers_mut();
13091319
let parent_kv = {
1310-
let kv = self.reborrow_mut().into_kv_mut();
1320+
let kv = self.kv_mut();
13111321
(kv.0 as *mut K, kv.1 as *mut V)
13121322
};
13131323

@@ -1364,7 +1374,7 @@ impl<'a, K, V> Handle<NodeRef<marker::Mut<'a>, K, V, marker::Internal>, marker::
13641374
let left_kv = left_node.reborrow_mut().into_kv_pointers_mut();
13651375
let right_kv = right_node.reborrow_mut().into_kv_pointers_mut();
13661376
let parent_kv = {
1367-
let kv = self.reborrow_mut().into_kv_mut();
1377+
let kv = self.kv_mut();
13681378
(kv.0 as *mut K, kv.1 as *mut V)
13691379
};
13701380

0 commit comments

Comments
 (0)