From ffd7ade2035eb92c77421ca7dcde4cf40c863c7b Mon Sep 17 00:00:00 2001 From: The8472 Date: Tue, 13 Jul 2021 23:13:27 +0200 Subject: fix issues pointed out in review --- library/alloc/src/vec/into_iter.rs | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) (limited to 'library/alloc/src') diff --git a/library/alloc/src/vec/into_iter.rs b/library/alloc/src/vec/into_iter.rs index eae9ad076dc..8a2d254a834 100644 --- a/library/alloc/src/vec/into_iter.rs +++ b/library/alloc/src/vec/into_iter.rs @@ -164,18 +164,19 @@ impl Iterator for IntoIter { #[inline] fn advance_by(&mut self, n: usize) -> Result<(), usize> { let step_size = self.len().min(n); + let to_drop = ptr::slice_from_raw_parts_mut(self.ptr as *mut T, step_size); if mem::size_of::() == 0 { // SAFETY: due to unchecked casts of unsigned amounts to signed offsets the wraparound // effectively results in unsigned pointers representing positions 0..usize::MAX, // which is valid for ZSTs. self.ptr = unsafe { arith_offset(self.ptr as *const i8, step_size as isize) as *mut T } } else { - let to_drop = ptr::slice_from_raw_parts_mut(self.ptr as *mut T, step_size); // SAFETY: the min() above ensures that step_size is in bounds - unsafe { - self.ptr = self.ptr.add(step_size); - ptr::drop_in_place(to_drop); - } + self.ptr = unsafe { self.ptr.add(step_size) }; + } + // SAFETY: the min() above ensures that step_size is in bounds + unsafe { + ptr::drop_in_place(to_drop); } if step_size < n { return Err(step_size); @@ -237,11 +238,11 @@ impl DoubleEndedIterator for IntoIter { } else { // SAFETY: same as for advance_by() self.end = unsafe { self.end.offset(step_size.wrapping_neg() as isize) }; - let to_drop = ptr::slice_from_raw_parts_mut(self.end as *mut T, step_size); - // SAFETY: same as for advance_by() - unsafe { - ptr::drop_in_place(to_drop); - } + } + let to_drop = ptr::slice_from_raw_parts_mut(self.end as *mut T, step_size); + // SAFETY: same as for advance_by() + unsafe { + ptr::drop_in_place(to_drop); } if step_size < n { return Err(step_size); -- cgit 1.4.1-3-g733a5