about summary refs log tree commit diff
path: root/tests/ui/issues/issue-68696-catch-during-unwind.rs
blob: 655879e186929fea7b00f5ac415cac31b2f271b5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// Checks that catch_unwind can be used if unwinding is already in progress.
// Used to fail when standard library had been compiled with debug assertions,
// due to incorrect assumption that a current thread is not panicking when
// entering the catch_unwind.
//
//@ run-pass
//@ ignore-backends: gcc

use std::panic::catch_unwind;

#[allow(dead_code)]
#[derive(Default)]
struct Guard;

impl Drop for Guard {
    fn drop(&mut self) {
        let _ = catch_unwind(|| {});
    }
}

fn main() {
    #[cfg(panic = "unwind")]
    let _ = catch_unwind(|| {
        let _guard = Guard::default();
        panic!();
    });
}