diff options
author | Jeff Vander Stoep <jeffv@google.com> | 2023-04-11 09:36:49 +0000 |
---|---|---|
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2023-04-11 09:36:49 +0000 |
commit | 4b65af3a6cade5590e77fb4bf332037b13218119 (patch) | |
tree | 1900296c4c4cc8dbc1dcc832ee0e0fcbdcceb88b /src/vec.rs | |
parent | b1457495c5f4967f72a614f92c0fd5ff36011a41 (diff) | |
parent | 4746a47f1b6bd33dc7a4ede2a0cc32a0542cfdf1 (diff) | |
download | rayon-4b65af3a6cade5590e77fb4bf332037b13218119.tar.gz |
Upgrade rayon to 1.7.0 am: a452597528 am: 72c30a8931 am: 4746a47f1bandroid14-dev
Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/rayon/+/2520000
Change-Id: Idb18c7a7c6e9fb96e06a872bb00a49ff2b46779e
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'src/vec.rs')
-rw-r--r-- | src/vec.rs | 9 |
1 files changed, 5 insertions, 4 deletions
@@ -225,8 +225,9 @@ impl<'data, T: 'data + Send> Producer for DrainProducer<'data, T> { impl<'data, T: 'data + Send> Drop for DrainProducer<'data, T> { fn drop(&mut self) { - // use `Drop for [T]` - unsafe { ptr::drop_in_place(self.slice) }; + // extract the slice so we can use `Drop for [T]` + let slice_ptr: *mut [T] = mem::take::<&'data mut [T]>(&mut self.slice); + unsafe { ptr::drop_in_place::<[T]>(slice_ptr) }; } } @@ -276,7 +277,7 @@ impl<'data, T: 'data> iter::FusedIterator for SliceDrain<'data, T> {} impl<'data, T: 'data> Drop for SliceDrain<'data, T> { fn drop(&mut self) { // extract the iterator so we can use `Drop for [T]` - let iter = mem::replace(&mut self.iter, [].iter_mut()); - unsafe { ptr::drop_in_place(iter.into_slice()) }; + let slice_ptr: *mut [T] = mem::replace(&mut self.iter, [].iter_mut()).into_slice(); + unsafe { ptr::drop_in_place::<[T]>(slice_ptr) }; } } |