2024-02-16 20:02:50 +00:00
|
|
|
//@ run-pass
|
2018-09-25 23:51:35 +02:00
|
|
|
#![allow(dead_code)]
|
2016-12-25 18:44:19 +02:00
|
|
|
// Check that drop elaboration clears the "master" discriminant
|
|
|
|
// drop flag even if it protects no fields.
|
|
|
|
|
|
|
|
struct Good(usize);
|
|
|
|
impl Drop for Good {
|
|
|
|
#[inline(never)]
|
|
|
|
fn drop(&mut self) {
|
|
|
|
println!("dropping Good({})", self.0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Void;
|
|
|
|
impl Drop for Void {
|
|
|
|
#[inline(never)]
|
|
|
|
fn drop(&mut self) {
|
|
|
|
panic!("Suddenly, a Void appears.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
enum E {
|
|
|
|
Never(Void),
|
|
|
|
Fine(Good)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut go = true;
|
|
|
|
|
|
|
|
loop {
|
|
|
|
let next;
|
|
|
|
match go {
|
|
|
|
true => next = E::Fine(Good(123)),
|
|
|
|
false => return,
|
|
|
|
}
|
|
|
|
|
|
|
|
match next {
|
|
|
|
E::Never(_) => return,
|
|
|
|
E::Fine(_good) => go = false,
|
|
|
|
}
|
|
|
|
|
|
|
|
// `next` is dropped and StorageDead'd here. We must reset the
|
|
|
|
// discriminant's drop flag to avoid random variants being
|
|
|
|
// dropped.
|
|
|
|
}
|
|
|
|
}
|