rust/tests/ui/coherence/negative-coherence-considering-regions.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

30 lines
755 B
Rust
Raw Normal View History

2023-07-19 17:28:40 +00:00
// revisions: any_lt static_lt
//[static_lt] known-bug: unknown
2023-07-19 17:28:40 +00:00
2023-10-17 23:04:06 +00:00
// This fails because we currently perform negative coherence in coherence mode.
// This means that when looking for a negative predicate, we also assemble a
// coherence-unknowable predicate. Since confirming the negative impl has region
// obligations, we don't prefer the impl over the unknowable predicate
// unconditionally and instead flounder.
2023-07-19 17:28:40 +00:00
#![feature(negative_impls)]
#![feature(with_negative_coherence)]
trait Foo {}
impl<T> !Foo for &'static T {}
trait Bar {}
impl<T> Bar for T where T: Foo {}
#[cfg(any_lt)]
impl<T> Bar for &T {}
//[any_lt]~^ ERROR conflicting implementations of trait `Bar` for type `&_`
#[cfg(static_lt)]
impl<T> Bar for &'static T {}
fn main() {}