summaryrefslogtreecommitdiffstats
path: root/tests/ui/drop/dynamic-drop.rs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--tests/ui/drop/dynamic-drop.rs18
1 files changed, 18 insertions, 0 deletions
diff --git a/tests/ui/drop/dynamic-drop.rs b/tests/ui/drop/dynamic-drop.rs
index 9e51d3ada..caef6358e 100644
--- a/tests/ui/drop/dynamic-drop.rs
+++ b/tests/ui/drop/dynamic-drop.rs
@@ -2,6 +2,7 @@
// needs-unwind
#![feature(generators, generator_trait)]
+#![feature(if_let_guard)]
#![allow(unused_assignments)]
#![allow(unused_variables)]
@@ -332,6 +333,16 @@ fn move_ref_pattern(a: &Allocator) {
let (ref _a, ref mut _b, _c, mut _d) = tup;
}
+fn if_let_guard(a: &Allocator, c: bool, d: i32) {
+ let foo = if c { Some(a.alloc()) } else { None };
+
+ match d == 0 {
+ false if let Some(a) = foo => { let b = a; }
+ true if let true = { drop(foo.unwrap_or_else(|| a.alloc())); d == 1 } => {}
+ _ => {}
+ }
+}
+
fn panic_after_return(a: &Allocator) -> Ptr<'_> {
// Panic in the drop of `p` or `q` can leak
let exceptions = vec![8, 9];
@@ -497,6 +508,13 @@ fn main() {
run_test(|a| move_ref_pattern(a));
+ run_test(|a| if_let_guard(a, true, 0));
+ run_test(|a| if_let_guard(a, true, 1));
+ run_test(|a| if_let_guard(a, true, 2));
+ run_test(|a| if_let_guard(a, false, 0));
+ run_test(|a| if_let_guard(a, false, 1));
+ run_test(|a| if_let_guard(a, false, 2));
+
run_test(|a| {
panic_after_return(a);
});