From 698f8c2f01ea549d77d7dc3338a12e04c11057b9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:02:58 +0200 Subject: Adding upstream version 1.64.0+dfsg1. Signed-off-by: Daniel Baumann --- .../region-invariant-static-error-reporting.rs | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 src/test/ui/regions/region-invariant-static-error-reporting.rs (limited to 'src/test/ui/regions/region-invariant-static-error-reporting.rs') diff --git a/src/test/ui/regions/region-invariant-static-error-reporting.rs b/src/test/ui/regions/region-invariant-static-error-reporting.rs new file mode 100644 index 000000000..c8288b592 --- /dev/null +++ b/src/test/ui/regions/region-invariant-static-error-reporting.rs @@ -0,0 +1,21 @@ +// This test checks that the error messages you get for this example +// at least mention `'a` and `'static`. The precise messages can drift +// over time, but this test used to exhibit some pretty bogus messages +// that were not remotely helpful. + +// error-pattern:argument requires that `'a` must outlive `'static` + +struct Invariant<'a>(Option<&'a mut &'a mut ()>); + +fn mk_static() -> Invariant<'static> { Invariant(None) } + +fn unify<'a>(x: Option>, f: fn(Invariant<'a>)) { + let bad = if x.is_some() { + x.unwrap() //~ ERROR borrowed data escapes outside of function [E0521] + } else { + mk_static() + }; + f(bad); +} + +fn main() {} -- cgit v1.2.3