mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-26 16:54:01 +00:00
aef0f4024a
And suggest adding the `#[coroutine]` to the closure
68 lines
1.3 KiB
Rust
68 lines
1.3 KiB
Rust
//@ run-pass
|
|
|
|
//@ revisions: default nomiropt
|
|
//@[nomiropt]compile-flags: -Z mir-opt-level=0
|
|
|
|
#![feature(coroutines, coroutine_trait, stmt_expr_attributes)]
|
|
#![allow(dropping_copy_types)]
|
|
|
|
use std::ops::Coroutine;
|
|
use std::pin::Pin;
|
|
use std::sync::atomic::{AtomicUsize, Ordering};
|
|
|
|
static A: AtomicUsize = AtomicUsize::new(0);
|
|
|
|
struct B;
|
|
|
|
impl Drop for B {
|
|
fn drop(&mut self) {
|
|
A.fetch_add(1, Ordering::SeqCst);
|
|
}
|
|
}
|
|
|
|
fn main() {
|
|
t1();
|
|
t2();
|
|
t3();
|
|
}
|
|
|
|
fn t1() {
|
|
let b = B;
|
|
let mut foo = #[coroutine] || {
|
|
yield;
|
|
drop(b);
|
|
};
|
|
|
|
let n = A.load(Ordering::SeqCst);
|
|
drop(Pin::new(&mut foo).resume(()));
|
|
assert_eq!(A.load(Ordering::SeqCst), n);
|
|
drop(foo);
|
|
assert_eq!(A.load(Ordering::SeqCst), n + 1);
|
|
}
|
|
|
|
fn t2() {
|
|
let b = B;
|
|
let mut foo = #[coroutine] || {
|
|
yield b;
|
|
};
|
|
|
|
let n = A.load(Ordering::SeqCst);
|
|
drop(Pin::new(&mut foo).resume(()));
|
|
assert_eq!(A.load(Ordering::SeqCst), n + 1);
|
|
drop(foo);
|
|
assert_eq!(A.load(Ordering::SeqCst), n + 1);
|
|
}
|
|
|
|
fn t3() {
|
|
let b = B;
|
|
let foo = #[coroutine] || {
|
|
yield;
|
|
drop(b);
|
|
};
|
|
|
|
let n = A.load(Ordering::SeqCst);
|
|
assert_eq!(A.load(Ordering::SeqCst), n);
|
|
drop(foo);
|
|
assert_eq!(A.load(Ordering::SeqCst), n + 1);
|
|
}
|