os-rust/tests/ui/coroutine/yield-while-ref-reborrowed.rs
Oli Scherer aef0f4024a Error on using yield without also using #[coroutine] on the closure
And suggest adding the `#[coroutine]` to the closure
2024-04-24 08:05:29 +00:00

43 lines
1 KiB
Rust

#![feature(coroutines, coroutine_trait, stmt_expr_attributes)]
use std::cell::Cell;
use std::ops::{Coroutine, CoroutineState};
use std::pin::Pin;
fn reborrow_shared_ref(x: &i32) {
// This is OK -- we have a borrow live over the yield, but it's of
// data that outlives the coroutine.
let mut b = #[coroutine]
move || {
let a = &*x;
yield ();
println!("{}", a);
};
Pin::new(&mut b).resume(());
}
fn reborrow_mutable_ref(x: &mut i32) {
// This is OK -- we have a borrow live over the yield, but it's of
// data that outlives the coroutine.
let mut b = #[coroutine]
move || {
let a = &mut *x;
yield ();
println!("{}", a);
};
Pin::new(&mut b).resume(());
}
fn reborrow_mutable_ref_2(x: &mut i32) {
// ...but not OK to go on using `x`.
let mut b = #[coroutine]
|| {
let a = &mut *x;
yield ();
println!("{}", a);
};
println!("{}", x); //~ ERROR
Pin::new(&mut b).resume(());
}
fn main() {}