2023-07-25 01:49:29 +00:00
|
|
|
#![deny(coinductive_overlap_in_coherence)]
|
|
|
|
|
|
|
|
use std::borrow::Borrow;
|
|
|
|
use std::cmp::Ordering;
|
|
|
|
use std::marker::PhantomData;
|
|
|
|
|
|
|
|
#[derive(PartialEq, Default)]
|
|
|
|
pub(crate) struct Interval<T>(PhantomData<T>);
|
|
|
|
|
|
|
|
// This impl overlaps with the `derive` unless we reject the nested
|
|
|
|
// `Interval<?1>: PartialOrd<Interval<?1>>` candidate which results
|
2023-07-25 09:19:42 -07:00
|
|
|
// in a - currently inductive - cycle.
|
2023-07-25 01:49:29 +00:00
|
|
|
impl<T, Q> PartialEq<Q> for Interval<T>
|
2023-07-30 21:46:04 +00:00
|
|
|
//~^ ERROR implementations of `PartialEq<Interval<_>>` for `Interval<_>` will conflict in the future
|
2023-07-25 01:49:29 +00:00
|
|
|
//~| WARN this was previously accepted by the compiler but is being phased out
|
|
|
|
where
|
|
|
|
T: Borrow<Q>,
|
|
|
|
Q: ?Sized + PartialOrd,
|
|
|
|
{
|
|
|
|
fn eq(&self, _: &Q) -> bool {
|
|
|
|
true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T, Q> PartialOrd<Q> for Interval<T>
|
|
|
|
where
|
|
|
|
T: Borrow<Q>,
|
|
|
|
Q: ?Sized + PartialOrd,
|
|
|
|
{
|
|
|
|
fn partial_cmp(&self, _: &Q) -> Option<Ordering> {
|
|
|
|
None
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|