Auto merge of #116167 - RalfJung:structural-eq, r=lcnr
remove StructuralEq trait The documentation given for the trait is outdated: *all* function pointers implement `PartialEq` and `Eq` these days. So the `StructuralEq` trait doesn't really seem to have any reason to exist any more. One side-effect of this PR is that we allow matching on some consts that do not implement `Eq`. However, we already allowed matching on floats and consts containing floats, so this is not new, it is just allowed in more cases now. IMO it makes no sense at all to allow float matching but also sometimes require an `Eq` instance. If we want to require `Eq` we should adjust https://github.com/rust-lang/rust/pull/115893 to check for `Eq`, and rule out float matching for good. Fixes https://github.com/rust-lang/rust/issues/115881
This commit is contained in:
commit
e8d600fd23
@ -104,9 +104,6 @@ unsafe impl<T: ?Sized> Freeze for &mut T {}
|
|||||||
#[lang = "structural_peq"]
|
#[lang = "structural_peq"]
|
||||||
pub trait StructuralPartialEq {}
|
pub trait StructuralPartialEq {}
|
||||||
|
|
||||||
#[lang = "structural_teq"]
|
|
||||||
pub trait StructuralEq {}
|
|
||||||
|
|
||||||
#[lang = "not"]
|
#[lang = "not"]
|
||||||
pub trait Not {
|
pub trait Not {
|
||||||
type Output;
|
type Output;
|
||||||
|
Loading…
Reference in New Issue
Block a user