summaryrefslogtreecommitdiffstats
path: root/src/test/ui/nll/issue-31567.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:19:13 +0000
commit218caa410aa38c29984be31a5229b9fa717560ee (patch)
treec54bd55eeb6e4c508940a30e94c0032fbd45d677 /src/test/ui/nll/issue-31567.rs
parentReleasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff)
downloadrustc-218caa410aa38c29984be31a5229b9fa717560ee.tar.xz
rustc-218caa410aa38c29984be31a5229b9fa717560ee.zip
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/nll/issue-31567.rs')
-rw-r--r--src/test/ui/nll/issue-31567.rs25
1 files changed, 0 insertions, 25 deletions
diff --git a/src/test/ui/nll/issue-31567.rs b/src/test/ui/nll/issue-31567.rs
deleted file mode 100644
index 623954e6d..000000000
--- a/src/test/ui/nll/issue-31567.rs
+++ /dev/null
@@ -1,25 +0,0 @@
-// Regression test for #31567: cached results of projections were
-// causing region relations not to be enforced at all the places where
-// they have to be enforced.
-
-struct VecWrapper<'a>(&'a mut S);
-
-struct S(Box<u32>);
-
-fn get_dangling<'a>(v: VecWrapper<'a>) -> &'a u32 {
- let s_inner: &'a S = &*v.0; //~ ERROR borrow may still be in use when destructor runs [E0713]
- &s_inner.0
-}
-
-impl<'a> Drop for VecWrapper<'a> {
- fn drop(&mut self) {
- *self.0 = S(Box::new(0));
- }
-}
-
-fn main() {
- let mut s = S(Box::new(11));
- let vw = VecWrapper(&mut s);
- let dangling = get_dangling(vw);
- println!("{}", dangling);
-}