2018-05-09 15:54:45 +02:00
|
|
|
// ignore-test validation_op is disabled
|
|
|
|
|
2017-08-09 18:01:10 -07:00
|
|
|
#![allow(unused_variables)]
|
|
|
|
|
|
|
|
mod safe {
|
|
|
|
use std::slice::from_raw_parts_mut;
|
|
|
|
|
|
|
|
pub fn split_at_mut<T>(self_: &mut [T], mid: usize) -> (&mut [T], &mut [T]) {
|
|
|
|
let len = self_.len();
|
|
|
|
let ptr = self_.as_mut_ptr();
|
|
|
|
|
|
|
|
unsafe {
|
|
|
|
assert!(mid <= len);
|
|
|
|
|
|
|
|
(from_raw_parts_mut(ptr, len - mid), // BUG: should be "mid" instead of "len - mid"
|
|
|
|
from_raw_parts_mut(ptr.offset(mid as isize), len - mid))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut array = [1,2,3,4];
|
|
|
|
let _x = safe::split_at_mut(&mut array, 0); //~ ERROR: in conflict with lock WriteLock
|
|
|
|
}
|