diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:19:13 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:19:13 +0000 |
commit | 218caa410aa38c29984be31a5229b9fa717560ee (patch) | |
tree | c54bd55eeb6e4c508940a30e94c0032fbd45d677 /src/test/ui/lub-glb/old-lub-glb-hr-noteq1.rs | |
parent | Releasing progress-linux version 1.67.1+dfsg1-1~progress7.99u1. (diff) | |
download | rustc-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/lub-glb/old-lub-glb-hr-noteq1.rs')
-rw-r--r-- | src/test/ui/lub-glb/old-lub-glb-hr-noteq1.rs | 29 |
1 files changed, 0 insertions, 29 deletions
diff --git a/src/test/ui/lub-glb/old-lub-glb-hr-noteq1.rs b/src/test/ui/lub-glb/old-lub-glb-hr-noteq1.rs deleted file mode 100644 index 589119abb..000000000 --- a/src/test/ui/lub-glb/old-lub-glb-hr-noteq1.rs +++ /dev/null @@ -1,29 +0,0 @@ -// Test taking the LUB of two function types that are not equatable but where one is more -// general than the other. Test the case where the more general type (`x`) is the first -// match arm specifically. - -// revisions: leak noleak -//[noleak] compile-flags:-Zno-leak-check - -fn foo(x: for<'a, 'b> fn(&'a u8, &'b u8) -> &'a u8, y: for<'a> fn(&'a u8, &'a u8) -> &'a u8) { - // The two types above are not equivalent. With the older LUB/GLB - // algorithm, this may have worked (I don't remember), but now it - // doesn't because we require equality. - let z = match 22 { - 0 => x, - _ => y, - //[leak]~^ ERROR `match` arms have incompatible types - //[noleak]~^^ ERROR mismatched types - }; -} - -fn foo_cast(x: for<'a, 'b> fn(&'a u8, &'b u8) -> &'a u8, y: for<'a> fn(&'a u8, &'a u8) -> &'a u8) { - // But we can *upcast* explicitly the type of `x` and figure - // things out: - let z = match 22 { - 0 => x as for<'a> fn(&'a u8, &'a u8) -> &'a u8, - _ => y, - }; -} - -fn main() {} |