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

28 lines
623 B
Rust
Raw Normal View History

2020-11-22 08:51:05 -06:00
// check-pass
#![feature(const_trait_impl)]
#![feature(const_fn_trait_bound)]
2020-11-22 08:51:05 -06:00
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.
2021-08-27 02:12:40 -05:00
// const fn equals_self<T: PartialEq + ~const PartialEq>(t: &T) -> bool {
// FIXME(fee1-dead)^ why should the order matter here?
const fn equals_self<T: ~const PartialEq + PartialEq>(t: &T) -> bool {
2020-11-22 08:51:05 -06:00
*t == *t
}
pub const EQ: bool = equals_self(&S);
fn main() {}