From 64d98f8ee037282c35007b64c2649055c56af1db Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:19:03 +0200 Subject: Merging upstream version 1.68.2+dfsg1. Signed-off-by: Daniel Baumann --- src/test/ui/cross/cross-fn-cache-hole.rs | 31 ------------------------------- 1 file changed, 31 deletions(-) delete mode 100644 src/test/ui/cross/cross-fn-cache-hole.rs (limited to 'src/test/ui/cross/cross-fn-cache-hole.rs') diff --git a/src/test/ui/cross/cross-fn-cache-hole.rs b/src/test/ui/cross/cross-fn-cache-hole.rs deleted file mode 100644 index c38a5001a..000000000 --- a/src/test/ui/cross/cross-fn-cache-hole.rs +++ /dev/null @@ -1,31 +0,0 @@ -// Check that when there are vacuous predicates in the environment -// (which make a fn uncallable) we don't erroneously cache those and -// then consider them satisfied elsewhere. The current technique for -// doing this is to not use global caches when there is a chance that -// the environment contains such a predicate. -// We still error for `i32: Bar` pending #48214 - -trait Foo: Bar { -} - -trait Bar { } - -// We don't always check where clauses for sanity, but in this case -// wfcheck does report an error here: -fn vacuous() - where i32: Foo //~ ERROR the trait bound `i32: Bar` is not satisfied -{ - // ... the original intention was to check that we don't use that - // vacuous where clause (which could never be satisfied) to accept - // the following line and then mess up calls elsewhere. - require::(); -} - -fn require() - where A: Bar -{ -} - -fn main() { - require::(); -} -- cgit v1.2.3