rust/tests/ui/rfc-2632-const-trait-impl/call-generic-method-dup-bound.rs

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

32 lines
621 B
Rust
Raw Normal View History

2023-04-16 06:12:37 -05:00
// known-bug: #110395
2020-11-22 08:51:05 -06:00
#![feature(const_trait_impl)]
struct S;
impl const PartialEq for S {
fn eq(&self, _: &S) -> bool {
true
}
fn ne(&self, other: &S) -> bool {
!self.eq(other)
}
2020-11-22 08:51:05 -06:00
}
2021-08-25 09:30:09 -05:00
// This duplicate bound should not result in ambiguities. It should be equivalent to a single ~const
2020-11-22 08:51:05 -06:00
// bound.
const fn equals_self<T: PartialEq + ~const PartialEq>(t: &T) -> bool {
2020-11-22 08:51:05 -06:00
*t == *t
}
trait A: PartialEq {}
impl<T: PartialEq> A for T {}
const fn equals_self2<T: A + ~const PartialEq>(t: &T) -> bool {
*t == *t
}
pub const EQ: bool = equals_self(&S) && equals_self2(&S);
2020-11-22 08:51:05 -06:00
fn main() {}