2024-04-11 21:15:34 +08:00
|
|
|
#![feature(coroutines, coroutine_trait, stmt_expr_attributes)]
|
2018-01-12 02:50:01 +08:00
|
|
|
|
|
|
|
use std::cell::RefCell;
|
2023-10-20 00:06:43 +08:00
|
|
|
use std::ops::Coroutine;
|
2018-10-05 02:49:38 +08:00
|
|
|
use std::pin::Pin;
|
2018-01-12 02:50:01 +08:00
|
|
|
|
2018-04-16 18:41:32 +08:00
|
|
|
fn main() {
|
2018-05-25 18:36:58 +08:00
|
|
|
let (mut gen, cell);
|
2018-01-12 02:50:01 +08:00
|
|
|
cell = Box::new(RefCell::new(0));
|
|
|
|
let ref_ = Box::leak(Box::new(Some(cell.borrow_mut())));
|
2018-04-16 18:41:32 +08:00
|
|
|
//~^ ERROR `*cell` does not live long enough [E0597]
|
2018-01-12 02:50:01 +08:00
|
|
|
// the upvar is the non-dropck `&mut Option<Ref<'a, i32>>`.
|
2024-04-11 21:15:34 +08:00
|
|
|
gen = #[coroutine]
|
|
|
|
|| {
|
2023-10-20 05:46:28 +08:00
|
|
|
// but the coroutine can use it to drop a `Ref<'a, i32>`.
|
2018-01-12 02:50:01 +08:00
|
|
|
let _d = ref_.take(); //~ ERROR `ref_` does not live long enough
|
|
|
|
yield;
|
|
|
|
};
|
2020-01-26 03:03:10 +08:00
|
|
|
Pin::new(&mut gen).resume(());
|
2018-01-12 02:50:01 +08:00
|
|
|
// drops the RefCell and then the Ref, leading to use-after-free
|
|
|
|
}
|