aboutsummaryrefslogtreecommitdiff
path: root/src/vec.rs
diff options
context:
space:
mode:
authorJeff Vander Stoep <jeffv@google.com>2023-04-11 09:36:49 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2023-04-11 09:36:49 +0000
commit4b65af3a6cade5590e77fb4bf332037b13218119 (patch)
tree1900296c4c4cc8dbc1dcc832ee0e0fcbdcceb88b /src/vec.rs
parentb1457495c5f4967f72a614f92c0fd5ff36011a41 (diff)
parent4746a47f1b6bd33dc7a4ede2a0cc32a0542cfdf1 (diff)
downloadrayon-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.rs9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/vec.rs b/src/vec.rs
index c804b0f..7892f53 100644
--- a/src/vec.rs
+++ b/src/vec.rs
@@ -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) };
}
}