diff options
| author | Jorge Aparicio <jorge@japaric.io> | 2018-08-23 16:29:01 +0200 |
|---|---|---|
| committer | Jorge Aparicio <jorge@japaric.io> | 2018-09-22 21:01:21 +0200 |
| commit | af101fdc331b6f607ed645d86a0f12bc7a2cbc5c (patch) | |
| tree | 790c876f988f40f955618720ba1e68c17cf1ab02 /src/libcore/slice | |
| parent | a6d011a98668cf672db2de8aae42f3654df4787f (diff) | |
| download | rust-af101fdc331b6f607ed645d86a0f12bc7a2cbc5c.tar.gz rust-af101fdc331b6f607ed645d86a0f12bc7a2cbc5c.zip | |
address Mark-Simulacrum comments
Diffstat (limited to 'src/libcore/slice')
| -rw-r--r-- | src/libcore/slice/rotate.rs | 7 | ||||
| -rw-r--r-- | src/libcore/slice/sort.rs | 8 |
2 files changed, 6 insertions, 9 deletions
diff --git a/src/libcore/slice/rotate.rs b/src/libcore/slice/rotate.rs index affe525ae46..07153735300 100644 --- a/src/libcore/slice/rotate.rs +++ b/src/libcore/slice/rotate.rs @@ -26,9 +26,6 @@ union RawArray<T> { } impl<T> RawArray<T> { - fn ptr(&self) -> *mut T { - unsafe { &self.typed as *const T as *mut T } - } fn cap() -> usize { if mem::size_of::<T>() == 0 { usize::max_value() @@ -85,8 +82,8 @@ pub unsafe fn ptr_rotate<T>(mut left: usize, mid: *mut T, mut right: usize) { } } - let rawarray = MaybeUninit::<RawArray<T>>::uninitialized(); - let buf = rawarray.get_ref().ptr(); + let mut rawarray = MaybeUninit::<RawArray<T>>::uninitialized(); + let buf = &mut (*rawarray.as_mut_ptr()).typed as *mut [T; 2] as *mut T; let dim = mid.sub(left).add(right); if left <= right { diff --git a/src/libcore/slice/sort.rs b/src/libcore/slice/sort.rs index cf0c5d876ab..affe84fbef9 100644 --- a/src/libcore/slice/sort.rs +++ b/src/libcore/slice/sort.rs @@ -272,8 +272,8 @@ fn partition_in_blocks<T, F>(v: &mut [T], pivot: &T, is_less: &mut F) -> usize if start_l == end_l { // Trace `block_l` elements from the left side. - start_l = unsafe { offsets_l.get_mut().as_mut_ptr() }; - end_l = unsafe { offsets_l.get_mut().as_mut_ptr() }; + start_l = offsets_l.as_mut_ptr() as *mut u8; + end_l = offsets_l.as_mut_ptr() as *mut u8; let mut elem = l; for i in 0..block_l { @@ -288,8 +288,8 @@ fn partition_in_blocks<T, F>(v: &mut [T], pivot: &T, is_less: &mut F) -> usize if start_r == end_r { // Trace `block_r` elements from the right side. - start_r = unsafe { offsets_r.get_mut().as_mut_ptr() }; - end_r = unsafe { offsets_r.get_mut().as_mut_ptr() }; + start_r = offsets_r.as_mut_ptr() as *mut u8; + end_r = offsets_r.as_mut_ptr() as *mut u8; let mut elem = r; for i in 0..block_r { |
