2018-09-06 14:41:12 +02:00
|
|
|
// run-pass
|
2021-12-03 15:32:51 +00:00
|
|
|
// needs-unwind
|
2018-09-06 14:41:12 +02:00
|
|
|
|
2017-10-22 20:01:00 -07:00
|
|
|
|
2017-07-07 16:12:44 -07:00
|
|
|
#![feature(generators, generator_trait)]
|
|
|
|
|
|
|
|
use std::ops::Generator;
|
|
|
|
use std::panic;
|
2018-10-04 20:49:38 +02:00
|
|
|
use std::pin::Pin;
|
2019-01-26 09:14:49 -07:00
|
|
|
use std::sync::atomic::{AtomicUsize, Ordering};
|
2017-07-07 16:12:44 -07:00
|
|
|
|
2019-01-26 09:14:49 -07:00
|
|
|
static A: AtomicUsize = AtomicUsize::new(0);
|
2017-07-07 16:12:44 -07:00
|
|
|
|
|
|
|
struct B;
|
|
|
|
|
|
|
|
impl Drop for B {
|
|
|
|
fn drop(&mut self) {
|
|
|
|
A.fetch_add(1, Ordering::SeqCst);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-09 13:56:19 -07:00
|
|
|
fn bool_true() -> bool {
|
|
|
|
true
|
|
|
|
}
|
|
|
|
|
2017-07-07 16:12:44 -07:00
|
|
|
fn main() {
|
|
|
|
let b = B;
|
|
|
|
let mut foo = || {
|
2017-08-09 13:56:19 -07:00
|
|
|
if bool_true() {
|
2017-07-07 16:12:44 -07:00
|
|
|
panic!();
|
|
|
|
}
|
|
|
|
drop(b);
|
|
|
|
yield;
|
|
|
|
};
|
|
|
|
|
|
|
|
assert_eq!(A.load(Ordering::SeqCst), 0);
|
|
|
|
let res = panic::catch_unwind(panic::AssertUnwindSafe(|| {
|
2020-01-25 20:03:10 +01:00
|
|
|
Pin::new(&mut foo).resume(())
|
2017-07-07 16:12:44 -07:00
|
|
|
}));
|
|
|
|
assert!(res.is_err());
|
|
|
|
assert_eq!(A.load(Ordering::SeqCst), 1);
|
|
|
|
|
|
|
|
let mut foo = || {
|
2017-08-09 13:56:19 -07:00
|
|
|
if bool_true() {
|
2017-07-07 16:12:44 -07:00
|
|
|
panic!();
|
|
|
|
}
|
|
|
|
drop(B);
|
|
|
|
yield;
|
|
|
|
};
|
|
|
|
|
|
|
|
assert_eq!(A.load(Ordering::SeqCst), 1);
|
|
|
|
let res = panic::catch_unwind(panic::AssertUnwindSafe(|| {
|
2020-01-25 20:03:10 +01:00
|
|
|
Pin::new(&mut foo).resume(())
|
2017-07-07 16:12:44 -07:00
|
|
|
}));
|
|
|
|
assert!(res.is_err());
|
|
|
|
assert_eq!(A.load(Ordering::SeqCst), 1);
|
|
|
|
}
|