diff options
| author | Ulrik Sverdrup <bluss@users.noreply.github.com> | 2015-07-28 19:54:13 +0200 |
|---|---|---|
| committer | Ulrik Sverdrup <bluss@users.noreply.github.com> | 2015-07-28 22:04:25 +0200 |
| commit | 73d4330ff8fd0ee0aa88739393d1ab5b46fe5e9a (patch) | |
| tree | 465c16ed306fd394e1eb390635a224a1fbc6181d | |
| parent | 1b28ffa5216c845d1cef6b0cb3e5ac7db12025d0 (diff) | |
| download | rust-73d4330ff8fd0ee0aa88739393d1ab5b46fe5e9a.tar.gz rust-73d4330ff8fd0ee0aa88739393d1ab5b46fe5e9a.zip | |
Use raw pointers to avoid aliasing violation in split_at_mut
Fixes #27357
| -rw-r--r-- | src/libcore/slice.rs | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/src/libcore/slice.rs b/src/libcore/slice.rs index 00e7ff3c4df..9b9c61dd6e5 100644 --- a/src/libcore/slice.rs +++ b/src/libcore/slice.rs @@ -288,11 +288,12 @@ impl<T> SliceExt for [T] { #[inline] fn split_at_mut(&mut self, mid: usize) -> (&mut [T], &mut [T]) { + let len = self.len(); + let ptr = self.as_mut_ptr(); + assert!(mid <= len); unsafe { - let self2: &mut [T] = mem::transmute_copy(&self); - - (ops::IndexMut::index_mut(self, ops::RangeTo { end: mid } ), - ops::IndexMut::index_mut(self2, ops::RangeFrom { start: mid } )) + (from_raw_parts_mut(ptr, mid), + from_raw_parts_mut(ptr.offset(mid as isize), len - mid)) } } |
