2019-06-23 17:26:12 +02:00
|
|
|
// This should fail even without validation
|
|
|
|
// compile-flags: -Zmiri-disable-validation
|
2019-05-29 19:35:47 +02:00
|
|
|
#![feature(weak_into_raw)]
|
|
|
|
|
|
|
|
use std::rc::{Rc, Weak};
|
|
|
|
use std::ptr;
|
|
|
|
|
2020-04-20 10:04:17 +02:00
|
|
|
/// Taken from the `Weak::as_ptr` doctest.
|
2019-05-29 19:35:47 +02:00
|
|
|
fn main() {
|
|
|
|
let strong = Rc::new(Box::new(42));
|
|
|
|
let weak = Rc::downgrade(&strong);
|
|
|
|
// Both point to the same object
|
2020-04-20 10:04:17 +02:00
|
|
|
assert!(ptr::eq(&*strong, Weak::as_ptr(&weak)));
|
2019-05-29 19:35:47 +02:00
|
|
|
// The strong here keeps it alive, so we can still access the object.
|
2020-04-20 10:04:17 +02:00
|
|
|
assert_eq!(42, **unsafe { &*Weak::as_ptr(&weak) });
|
2019-05-29 19:35:47 +02:00
|
|
|
|
|
|
|
drop(strong);
|
|
|
|
// But not any more. We can do Weak::as_raw(&weak), but accessing the pointer would lead to
|
|
|
|
// undefined behaviour.
|
2020-04-20 10:04:17 +02:00
|
|
|
assert_eq!(42, **unsafe { &*Weak::as_ptr(&weak) }); //~ ERROR dereferenced after this allocation got freed
|
2019-05-29 19:35:47 +02:00
|
|
|
}
|