2021-05-13 09:42:25 -05:00
|
|
|
// revisions: mirunsafeck thirunsafeck
|
|
|
|
// [thirunsafeck]compile-flags: -Z thir-unsafeck
|
|
|
|
|
2017-04-07 18:25:40 -05:00
|
|
|
#![feature(untagged_unions)]
|
|
|
|
#![allow(unused)]
|
|
|
|
|
2019-07-03 05:35:02 -05:00
|
|
|
use std::ops::{Deref, DerefMut};
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct MockBox<T> {
|
|
|
|
value: [T; 1],
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> MockBox<T> {
|
|
|
|
fn new(value: T) -> Self { MockBox { value: [value] } }
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> Deref for MockBox<T> {
|
|
|
|
type Target = T;
|
|
|
|
fn deref(&self) -> &T { &self.value[0] }
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> DerefMut for MockBox<T> {
|
|
|
|
fn deref_mut(&mut self) -> &mut T { &mut self.value[0] }
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct MockVec<T> {
|
|
|
|
value: [T; 0],
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> MockVec<T> {
|
|
|
|
fn new() -> Self { MockVec { value: [] } }
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> Deref for MockVec<T> {
|
|
|
|
type Target = [T];
|
|
|
|
fn deref(&self) -> &[T] { &self.value }
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> DerefMut for MockVec<T> {
|
|
|
|
fn deref_mut(&mut self) -> &mut [T] { &mut self.value }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-04-07 18:25:40 -05:00
|
|
|
union U {
|
2019-07-03 05:35:02 -05:00
|
|
|
x: ((MockVec<u8>, MockVec<u8>), MockVec<u8>),
|
|
|
|
y: MockBox<MockVec<u8>>,
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
2018-11-04 11:36:30 -06:00
|
|
|
fn use_borrow<T>(_: &T) {}
|
|
|
|
|
2017-04-07 18:25:40 -05:00
|
|
|
unsafe fn parent_sibling_borrow() {
|
2019-07-03 05:35:02 -05:00
|
|
|
let mut u = U { x: ((MockVec::new(), MockVec::new()), MockVec::new()) };
|
2017-04-07 18:25:40 -05:00
|
|
|
let a = &mut u.x.0;
|
2019-04-22 02:40:08 -05:00
|
|
|
let b = &u.y; //~ ERROR cannot borrow `u` (via `u.y`)
|
2018-11-04 11:36:30 -06:00
|
|
|
use_borrow(a);
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn parent_sibling_move() {
|
2019-07-03 05:35:02 -05:00
|
|
|
let u = U { x: ((MockVec::new(), MockVec::new()), MockVec::new()) };
|
2017-04-07 18:25:40 -05:00
|
|
|
let a = u.x.0;
|
2019-04-22 02:40:08 -05:00
|
|
|
let b = u.y; //~ ERROR use of moved value: `u`
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn grandparent_sibling_borrow() {
|
2019-07-03 05:35:02 -05:00
|
|
|
let mut u = U { x: ((MockVec::new(), MockVec::new()), MockVec::new()) };
|
2017-04-07 18:25:40 -05:00
|
|
|
let a = &mut (u.x.0).0;
|
2019-04-22 02:40:08 -05:00
|
|
|
let b = &u.y; //~ ERROR cannot borrow `u` (via `u.y`)
|
2018-11-04 11:36:30 -06:00
|
|
|
use_borrow(a);
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn grandparent_sibling_move() {
|
2019-07-03 05:35:02 -05:00
|
|
|
let u = U { x: ((MockVec::new(), MockVec::new()), MockVec::new()) };
|
2017-04-07 18:25:40 -05:00
|
|
|
let a = (u.x.0).0;
|
2019-04-22 02:40:08 -05:00
|
|
|
let b = u.y; //~ ERROR use of moved value: `u`
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn deref_sibling_borrow() {
|
2019-07-03 05:35:02 -05:00
|
|
|
let mut u = U { y: MockBox::default() };
|
2017-04-07 18:25:40 -05:00
|
|
|
let a = &mut *u.y;
|
2018-11-04 11:36:30 -06:00
|
|
|
let b = &u.x; //~ ERROR cannot borrow `u` (via `u.x`)
|
|
|
|
use_borrow(a);
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn deref_sibling_move() {
|
2019-07-03 05:35:02 -05:00
|
|
|
let u = U { x: ((MockVec::new(), MockVec::new()), MockVec::new()) };
|
|
|
|
// No way to test deref-move without Box in union
|
|
|
|
// let a = *u.y;
|
|
|
|
// let b = u.x; ERROR use of moved value: `u`
|
2017-04-07 18:25:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn main() {}
|