2015-05-11 17:02:56 -04:00
|
|
|
// 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
|
2018-05-06 22:57:49 +01:00
|
|
|
// 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<u32>` pending #48214
|
2015-05-11 17:02:56 -04:00
|
|
|
|
|
|
|
trait Foo<X,Y>: Bar<X> {
|
|
|
|
}
|
|
|
|
|
|
|
|
trait Bar<X> { }
|
|
|
|
|
2015-12-15 04:31:58 -05:00
|
|
|
// We don't always check where clauses for sanity, but in this case
|
|
|
|
// wfcheck does report an error here:
|
2021-11-13 23:56:22 +01:00
|
|
|
fn vacuous<A>()
|
|
|
|
where i32: Foo<u32, A> //~ ERROR the trait bound `i32: Bar<u32>` is not satisfied
|
2015-05-11 17:02:56 -04:00
|
|
|
{
|
2015-12-15 04:31:58 -05:00
|
|
|
// ... 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.
|
2015-05-11 17:02:56 -04:00
|
|
|
require::<i32, u32>();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn require<A,B>()
|
|
|
|
where A: Bar<B>
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
require::<i32, u32>();
|
|
|
|
}
|