2018-11-09 10:53:28 +01:00
|
|
|
// We *can* have aliasing &RefCell<T> and &mut T, but we cannot read through the former.
|
|
|
|
// Else we couldn't optimize based on the assumption that `xref` below is truly unique.
|
2022-07-08 16:08:32 +00:00
|
|
|
//@normalize-stderr-test: "0x[0-9a-fA-F]+" -> "$$HEX"
|
2018-11-09 10:53:28 +01:00
|
|
|
|
|
|
|
use std::cell::RefCell;
|
|
|
|
use std::{mem, ptr};
|
|
|
|
|
2022-04-30 11:07:36 -07:00
|
|
|
#[rustfmt::skip] // rustfmt bug: https://github.com/rust-lang/rustfmt/issues/5391
|
2018-11-09 10:53:28 +01:00
|
|
|
fn main() {
|
|
|
|
let rc = RefCell::new(0);
|
|
|
|
let mut refmut = rc.borrow_mut();
|
|
|
|
let xref: &mut i32 = &mut *refmut;
|
2019-02-16 01:43:56 +00:00
|
|
|
let xshr = &rc; // creating this is ok
|
2018-11-09 10:53:28 +01:00
|
|
|
let _val = *xref; // we can even still use our mutable reference
|
|
|
|
mem::forget(unsafe { ptr::read(xshr) }); // but after reading through the shared ref
|
|
|
|
let _val = *xref; // the mutable one is dead and gone
|
2022-07-13 18:59:33 -04:00
|
|
|
//~^ ERROR: /read access .* tag does not exist in the borrow stack/
|
2018-11-09 10:53:28 +01:00
|
|
|
}
|