summaryrefslogtreecommitdiffstats
path: root/src/test/ui/consts/control-flow/drop-fail.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/consts/control-flow/drop-fail.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/consts/control-flow/drop-fail.rs')
-rw-r--r--src/test/ui/consts/control-flow/drop-fail.rs62
1 files changed, 62 insertions, 0 deletions
diff --git a/src/test/ui/consts/control-flow/drop-fail.rs b/src/test/ui/consts/control-flow/drop-fail.rs
new file mode 100644
index 000000000..efa5a11c9
--- /dev/null
+++ b/src/test/ui/consts/control-flow/drop-fail.rs
@@ -0,0 +1,62 @@
+// revisions: stock precise
+
+#![cfg_attr(precise, feature(const_precise_live_drops))]
+
+// `x` is *not* always moved into the final value and may be dropped inside the initializer.
+const _: Option<Vec<i32>> = {
+ let y: Option<Vec<i32>> = None;
+ let x = Some(Vec::new());
+ //[stock,precise]~^ ERROR destructors cannot be evaluated at compile-time
+
+ if true {
+ x
+ } else {
+ y
+ }
+};
+
+// We only clear `NeedsDrop` if a local is moved from in entirely. This is a shortcoming of the
+// existing analysis.
+const _: Vec<i32> = {
+ let vec_tuple = (Vec::new(),);
+ //[stock]~^ ERROR destructors cannot be evaluated at compile-time
+
+ vec_tuple.0
+};
+
+// This applies to single-field enum variants as well.
+const _: Vec<i32> = {
+ let x: Result<_, Vec<i32>> = Ok(Vec::new());
+ //[stock]~^ ERROR destructors cannot be evaluated at compile-time
+
+ match x {
+ Ok(x) | Err(x) => x,
+ }
+};
+
+const _: Option<Vec<i32>> = {
+ let mut some = Some(Vec::new());
+ let mut tmp = None;
+ //[stock,precise]~^ ERROR destructors cannot be evaluated at compile-time
+
+ let mut i = 0;
+ while i < 10 {
+ tmp = some;
+ some = None;
+
+ // We can escape the loop with `Some` still in `tmp`,
+ // which would require that it be dropped at the end of the block.
+ if i > 100 {
+ break;
+ }
+
+ some = tmp;
+ tmp = None;
+
+ i += 1;
+ }
+
+ some
+};
+
+fn main() {}