From 218caa410aa38c29984be31a5229b9fa717560ee Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:19:13 +0200 Subject: Merging upstream version 1.68.2+dfsg1. Signed-off-by: Daniel Baumann --- tests/ui/issues/issue-9382.rs | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 tests/ui/issues/issue-9382.rs (limited to 'tests/ui/issues/issue-9382.rs') diff --git a/tests/ui/issues/issue-9382.rs b/tests/ui/issues/issue-9382.rs new file mode 100644 index 000000000..65718343f --- /dev/null +++ b/tests/ui/issues/issue-9382.rs @@ -0,0 +1,40 @@ +// pretty-expanded FIXME #23616 + + +// run-pass +#![allow(dead_code)] + +// Tests for a previous bug that occurred due to an interaction +// between struct field initialization and the auto-coercion +// from a vector to a slice. The drop glue was being invoked on +// the temporary slice with a wrong type, triggering an LLVM assert. + + +struct Thing1<'a> { + baz: &'a [Box], + bar: Box, +} + +struct Thing2<'a> { + baz: &'a [Box], + bar: u64, +} + +pub fn main() { + let _t1_fixed = Thing1 { + baz: &[], + bar: Box::new(32), + }; + Thing1 { + baz: &Vec::new(), + bar: Box::new(32), + }; + let _t2_fixed = Thing2 { + baz: &[], + bar: 32, + }; + Thing2 { + baz: &Vec::new(), + bar: 32, + }; +} -- cgit v1.2.3