rust/src/test/ui/consts/control-flow/drop-fail.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

63 lines
1.4 KiB
Rust
Raw Normal View History

// 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,
}
};
2019-12-10 23:24:46 -06:00
const _: Option<Vec<i32>> = {
let mut some = Some(Vec::new());
let mut tmp = None;
//[stock,precise]~^ ERROR destructors cannot be evaluated at compile-time
2019-12-10 23:24:46 -06:00
let mut i = 0;
while i < 10 {
tmp = some;
some = None;
2019-12-11 12:20:50 -06:00
// We can escape the loop with `Some` still in `tmp`,
// which would require that it be dropped at the end of the block.
2019-12-10 23:24:46 -06:00
if i > 100 {
break;
}
some = tmp;
tmp = None;
i += 1;
}
some
};
fn main() {}