diff options
| author | Alan Egerton <eggyal@gmail.com> | 2022-06-08 12:08:00 +0100 |
|---|---|---|
| committer | Alan Egerton <eggyal@gmail.com> | 2022-06-08 12:14:49 +0100 |
| commit | 9208c08a771199e49aa1bff0e80354124eddbe5f (patch) | |
| tree | cddc5b1d7416e228eac0af80d7c1330c05ce33c5 | |
| parent | e45d9973b2665897a768312e971b82cc62633103 (diff) | |
| download | rust-9208c08a771199e49aa1bff0e80354124eddbe5f.tar.gz rust-9208c08a771199e49aa1bff0e80354124eddbe5f.zip | |
Use liballoc's specialised in-place vec collection
liballoc already specialises in-place vector collection, so manually reimplementing it in `IdFunctor::try_map_id` was superfluous.
| -rw-r--r-- | compiler/rustc_data_structures/src/functor.rs | 36 |
1 files changed, 2 insertions, 34 deletions
diff --git a/compiler/rustc_data_structures/src/functor.rs b/compiler/rustc_data_structures/src/functor.rs index a3d3f988344..84cb417dd89 100644 --- a/compiler/rustc_data_structures/src/functor.rs +++ b/compiler/rustc_data_structures/src/functor.rs @@ -34,43 +34,11 @@ impl<T> IdFunctor for Vec<T> { type Inner = T; #[inline] - fn try_map_id<F, E>(self, mut f: F) -> Result<Self, E> + fn try_map_id<F, E>(self, f: F) -> Result<Self, E> where F: FnMut(Self::Inner) -> Result<Self::Inner, E>, { - struct HoleVec<T> { - vec: Vec<mem::ManuallyDrop<T>>, - hole: Option<usize>, - } - - impl<T> Drop for HoleVec<T> { - fn drop(&mut self) { - unsafe { - for (index, slot) in self.vec.iter_mut().enumerate() { - if self.hole != Some(index) { - mem::ManuallyDrop::drop(slot); - } - } - } - } - } - - unsafe { - let (ptr, length, capacity) = self.into_raw_parts(); - let vec = Vec::from_raw_parts(ptr.cast(), length, capacity); - let mut hole_vec = HoleVec { vec, hole: None }; - - for (index, slot) in hole_vec.vec.iter_mut().enumerate() { - hole_vec.hole = Some(index); - let original = mem::ManuallyDrop::take(slot); - let mapped = f(original)?; - *slot = mem::ManuallyDrop::new(mapped); - hole_vec.hole = None; - } - - mem::forget(hole_vec); - Ok(Vec::from_raw_parts(ptr, length, capacity)) - } + self.into_iter().map(f).collect() } } |
