summaryrefslogtreecommitdiffstats
path: root/tests/ui/drop/dynamic-drop.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
commitc23a457e72abe608715ac76f076f47dc42af07a5 (patch)
tree2772049aaf84b5c9d0ed12ec8d86812f7a7904b6 /tests/ui/drop/dynamic-drop.rs
parentReleasing progress-linux version 1.73.0+dfsg1-1~progress7.99u1. (diff)
downloadrustc-c23a457e72abe608715ac76f076f47dc42af07a5.tar.xz
rustc-c23a457e72abe608715ac76f076f47dc42af07a5.zip
Merging upstream version 1.74.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
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);
});