Trait wasmtime_environ::__core::cmp::PartialEq
1.0.0 · source · pub trait PartialEq<Rhs = Self>where
Rhs: ?Sized,{
// Required method
fn eq(&self, other: &Rhs) -> bool;
// Provided method
fn ne(&self, other: &Rhs) -> bool { ... }
}
Expand description
Trait for comparisons using the equality operator.
Implementing this trait for types provides the ==
and !=
operators for
those types.
x.eq(y)
can also be written x == y
, and x.ne(y)
can be written x != y
.
We use the easier-to-read infix notation in the remainder of this documentation.
This trait allows for comparisons using the equality operator, for types
that do not have a full equivalence relation. For example, in floating point
numbers NaN != NaN
, so floating point types implement PartialEq
but not
Eq
. Formally speaking, when Rhs == Self
, this trait corresponds
to a partial equivalence relation.
Implementations must ensure that eq
and ne
are consistent with each other:
a != b
if and only if!(a == b)
.
The default implementation of ne
provides this consistency and is almost
always sufficient. It should not be overridden without very good reason.
If PartialOrd
or Ord
are also implemented for Self
and Rhs
, their methods must also
be consistent with PartialEq
(see the documentation of those traits for the exact
requirements). It’s easy to accidentally make them disagree by deriving some of the traits and
manually implementing others.
The equality relation ==
must satisfy the following conditions
(for all a
, b
, c
of type A
, B
, C
):
-
Symmetry: if
A: PartialEq<B>
andB: PartialEq<A>
, thena == b
impliesb == a
; and -
Transitivity: if
A: PartialEq<B>
andB: PartialEq<C>
andA: PartialEq<C>
, thena == b
andb == c
impliesa == c
. This must also work for longer chains, such as whenA: PartialEq<B>
,B: PartialEq<C>
,C: PartialEq<D>
, andA: PartialEq<D>
all exist.
Note that the B: PartialEq<A>
(symmetric) and A: PartialEq<C>
(transitive) impls are not forced to exist, but these requirements apply
whenever they do exist.
Violating these requirements is a logic error. The behavior resulting from a logic error is not
specified, but users of the trait must ensure that such logic errors do not result in
undefined behavior. This means that unsafe
code must not rely on the correctness of these
methods.
§Cross-crate considerations
Upholding the requirements stated above can become tricky when one crate implements PartialEq
for a type of another crate (i.e., to allow comparing one of its own types with a type from the
standard library). The recommendation is to never implement this trait for a foreign type. In
other words, such a crate should do impl PartialEq<ForeignType> for LocalType
, but it should
not do impl PartialEq<LocalType> for ForeignType
.
This avoids the problem of transitive chains that criss-cross crate boundaries: for all local
types T
, you may assume that no other crate will add impl
s that allow comparing T == U
. In
other words, if other crates add impl
s that allow building longer transitive chains U1 == ... == T == V1 == ...
, then all the types that appear to the right of T
must be types that the
crate defining T
already knows about. This rules out transitive chains where downstream crates
can add new impl
s that “stitch together” comparisons of foreign types in ways that violate
transitivity.
Not having such foreign impl
s also avoids forward compatibility issues where one crate adding
more PartialEq
implementations can cause build failures in downstream crates.
§Derivable
This trait can be used with #[derive]
. When derive
d on structs, two
instances are equal if all fields are equal, and not equal if any fields
are not equal. When derive
d on enums, two instances are equal if they
are the same variant and all fields are equal.
§How can I implement PartialEq
?
An example implementation for a domain in which two books are considered the same book if their ISBN matches, even if the formats differ:
enum BookFormat {
Paperback,
Hardback,
Ebook,
}
struct Book {
isbn: i32,
format: BookFormat,
}
impl PartialEq for Book {
fn eq(&self, other: &Self) -> bool {
self.isbn == other.isbn
}
}
let b1 = Book { isbn: 3, format: BookFormat::Paperback };
let b2 = Book { isbn: 3, format: BookFormat::Ebook };
let b3 = Book { isbn: 10, format: BookFormat::Paperback };
assert!(b1 == b2);
assert!(b1 != b3);
§How can I compare two different types?
The type you can compare with is controlled by PartialEq
’s type parameter.
For example, let’s tweak our previous code a bit:
// The derive implements <BookFormat> == <BookFormat> comparisons
#[derive(PartialEq)]
enum BookFormat {
Paperback,
Hardback,
Ebook,
}
struct Book {
isbn: i32,
format: BookFormat,
}
// Implement <Book> == <BookFormat> comparisons
impl PartialEq<BookFormat> for Book {
fn eq(&self, other: &BookFormat) -> bool {
self.format == *other
}
}
// Implement <BookFormat> == <Book> comparisons
impl PartialEq<Book> for BookFormat {
fn eq(&self, other: &Book) -> bool {
*self == other.format
}
}
let b1 = Book { isbn: 3, format: BookFormat::Paperback };
assert!(b1 == BookFormat::Paperback);
assert!(BookFormat::Ebook != b1);
By changing impl PartialEq for Book
to impl PartialEq<BookFormat> for Book
,
we allow BookFormat
s to be compared with Book
s.
A comparison like the one above, which ignores some fields of the struct,
can be dangerous. It can easily lead to an unintended violation of the
requirements for a partial equivalence relation. For example, if we kept
the above implementation of PartialEq<Book>
for BookFormat
and added an
implementation of PartialEq<Book>
for Book
(either via a #[derive]
or
via the manual implementation from the first example) then the result would
violate transitivity:
#[derive(PartialEq)]
enum BookFormat {
Paperback,
Hardback,
Ebook,
}
#[derive(PartialEq)]
struct Book {
isbn: i32,
format: BookFormat,
}
impl PartialEq<BookFormat> for Book {
fn eq(&self, other: &BookFormat) -> bool {
self.format == *other
}
}
impl PartialEq<Book> for BookFormat {
fn eq(&self, other: &Book) -> bool {
*self == other.format
}
}
fn main() {
let b1 = Book { isbn: 1, format: BookFormat::Paperback };
let b2 = Book { isbn: 2, format: BookFormat::Paperback };
assert!(b1 == BookFormat::Paperback);
assert!(BookFormat::Paperback == b2);
// The following should hold by transitivity but doesn't.
assert!(b1 == b2); // <-- PANICS
}
§Examples
let x: u32 = 0;
let y: u32 = 1;
assert_eq!(x == y, false);
assert_eq!(x.eq(&y), false);
Required Methods§
Provided Methods§
Implementors§
impl PartialEq for ConstOp
impl PartialEq for EngineOrModuleTypeIndex
impl PartialEq for EntityIndex
impl PartialEq for Trap
impl PartialEq for VMGcKind
impl PartialEq for WasmCompositeType
impl PartialEq for WasmHeapTopType
impl PartialEq for WasmHeapType
impl PartialEq for WasmStorageType
impl PartialEq for WasmValType
impl PartialEq for LibCall
impl PartialEq for BlockType
impl PartialEq for CanonicalOption
impl PartialEq for ComdatSymbolKind
impl PartialEq for ComponentExternalKind
impl PartialEq for ComponentOuterAliasKind
impl PartialEq for ComponentTypeRef
impl PartialEq for ComponentValType
impl PartialEq for CompositeType
impl PartialEq for Encoding
impl PartialEq for ExternalKind
impl PartialEq for FrameKind
impl PartialEq for HeapType
impl PartialEq for InstantiationArgKind
impl PartialEq for wasmtime_environ::wasmparser::Ordering
impl PartialEq for OuterAliasKind
impl PartialEq for PrimitiveValType
impl PartialEq for RelocAddendKind
impl PartialEq for RelocationType
impl PartialEq for StorageType
impl PartialEq for TypeBounds
impl PartialEq for UnpackedIndex
impl PartialEq for ValType
impl PartialEq for ComponentNameKind<'_>
impl PartialEq for AnyTypeId
impl PartialEq for ComponentAnyTypeId
impl PartialEq for ComponentCoreTypeId
impl PartialEq for AsciiChar
impl PartialEq for Infallible
impl PartialEq for wasmtime_environ::__core::fmt::Alignment
impl PartialEq for IpAddr
impl PartialEq for Ipv6MulticastScope
impl PartialEq for SocketAddr
impl PartialEq for FpCategory
impl PartialEq for IntErrorKind
impl PartialEq for SearchStep
impl PartialEq for wasmtime_environ::__core::sync::atomic::Ordering
impl PartialEq for wasmtime_environ::__core::cmp::Ordering
impl PartialEq for TryReserveErrorKind
impl PartialEq for hashbrown::TryReserveError
impl PartialEq for AddressSize
impl PartialEq for object::common::Architecture
impl PartialEq for object::common::BinaryFormat
impl PartialEq for ComdatKind
impl PartialEq for FileFlags
impl PartialEq for RelocationEncoding
impl PartialEq for RelocationFlags
impl PartialEq for RelocationKind
impl PartialEq for SectionFlags
impl PartialEq for SectionKind
impl PartialEq for object::common::SegmentFlags
impl PartialEq for SubArchitecture
impl PartialEq for SymbolKind
impl PartialEq for SymbolScope
impl PartialEq for object::endian::Endianness
impl PartialEq for CompressionFormat
impl PartialEq for FileKind
impl PartialEq for ObjectKind
impl PartialEq for RelocationTarget
impl PartialEq for SymbolSection
impl PartialEq for Op
impl PartialEq for CDataModel
impl PartialEq for Size
impl PartialEq for ParseError
impl PartialEq for Aarch64Architecture
impl PartialEq for target_lexicon::targets::Architecture
impl PartialEq for ArmArchitecture
impl PartialEq for target_lexicon::targets::BinaryFormat
impl PartialEq for CustomVendor
impl PartialEq for Environment
impl PartialEq for Mips32Architecture
impl PartialEq for Mips64Architecture
impl PartialEq for OperatingSystem
impl PartialEq for Riscv32Architecture
impl PartialEq for Riscv64Architecture
impl PartialEq for Vendor
impl PartialEq for X86_32Architecture
impl PartialEq for CallingConvention
impl PartialEq for target_lexicon::triple::Endianness
impl PartialEq for PointerWidth
impl PartialEq for bool
impl PartialEq for char
impl PartialEq for f16
impl PartialEq for f32
impl PartialEq for f64
impl PartialEq for f128
impl PartialEq for i8
impl PartialEq for i16
impl PartialEq for i32
impl PartialEq for i64
impl PartialEq for i128
impl PartialEq for isize
impl PartialEq for !
impl PartialEq for str
impl PartialEq for u8
impl PartialEq for u16
impl PartialEq for u32
impl PartialEq for u64
impl PartialEq for u128
impl PartialEq for ()
impl PartialEq for usize
impl PartialEq for String
impl PartialEq for BuiltinFunctionIndex
impl PartialEq for CallIndirectSiteIndex
impl PartialEq for ConstExpr
impl PartialEq for DataIndex
impl PartialEq for DefinedFuncIndex
impl PartialEq for DefinedGlobalIndex
impl PartialEq for DefinedMemoryIndex
impl PartialEq for DefinedTableIndex
impl PartialEq for ElemIndex
impl PartialEq for EngineInternedRecGroupIndex
impl PartialEq for FilePos
impl PartialEq for FuncIndex
impl PartialEq for FuncRefIndex
impl PartialEq for Global
impl PartialEq for GlobalIndex
impl PartialEq for InstructionAddressMap
impl PartialEq for Memory
impl PartialEq for MemoryIndex
impl PartialEq for ModuleInternedRecGroupIndex
impl PartialEq for ModuleInternedTypeIndex
impl PartialEq for OwnedMemoryIndex
impl PartialEq for RecGroupRelativeTypeIndex
impl PartialEq for StaticModuleIndex
impl PartialEq for Table
impl PartialEq for TableIndex
impl PartialEq for Tag
impl PartialEq for TagIndex
impl PartialEq for TrapInformation
impl PartialEq for TypeIndex
impl PartialEq for WasmArrayType
impl PartialEq for WasmFieldType
impl PartialEq for WasmFuncType
impl PartialEq for WasmRecGroup
impl PartialEq for WasmRefType
impl PartialEq for WasmStructType
impl PartialEq for WasmSubType
impl PartialEq for ComponentName
impl PartialEq for KebabStr
impl PartialEq for KebabString
impl PartialEq for ArrayType
impl PartialEq for FieldType
impl PartialEq for FuncType
impl PartialEq for GlobalType
impl PartialEq for Ieee32
impl PartialEq for Ieee64
impl PartialEq for MemoryType
impl PartialEq for PackedIndex
impl PartialEq for RecGroup
impl PartialEq for RefType
impl PartialEq for RelocationEntry
impl PartialEq for wasmtime_environ::wasmparser::SegmentFlags
impl PartialEq for StructType
impl PartialEq for SubType
impl PartialEq for wasmtime_environ::wasmparser::SymbolFlags
impl PartialEq for TableType
impl PartialEq for V128
impl PartialEq for ValidatorId
impl PartialEq for AliasableResourceId
impl PartialEq for ComponentCoreInstanceTypeId
impl PartialEq for ComponentCoreModuleTypeId
impl PartialEq for ComponentDefinedTypeId
impl PartialEq for ComponentFuncTypeId
impl PartialEq for ComponentInstanceTypeId
impl PartialEq for ComponentTypeId
impl PartialEq for ComponentValueTypeId
impl PartialEq for CoreTypeId
impl PartialEq for RecGroupId
impl PartialEq for ResourceId
impl PartialEq for AllocError
impl PartialEq for Layout
impl PartialEq for LayoutError
impl PartialEq for TypeId
impl PartialEq for CpuidResult
impl PartialEq for CharTryFromError
impl PartialEq for DecodeUtf16Error
impl PartialEq for ParseCharError
impl PartialEq for TryFromCharError
impl PartialEq for CStr
impl PartialEq for FromBytesUntilNulError
impl PartialEq for FromBytesWithNulError
impl PartialEq for wasmtime_environ::__core::fmt::Error
impl PartialEq for PhantomPinned
impl PartialEq for Assume
impl PartialEq for AddrParseError
impl PartialEq for Ipv4Addr
impl PartialEq for Ipv6Addr
impl PartialEq for SocketAddrV4
impl PartialEq for SocketAddrV6
impl PartialEq for ParseFloatError
impl PartialEq for ParseIntError
impl PartialEq for TryFromIntError
impl PartialEq for RangeFull
impl PartialEq for wasmtime_environ::__core::ptr::Alignment
impl PartialEq for ParseBoolError
impl PartialEq for Utf8Error
impl PartialEq for RawWaker
impl PartialEq for RawWakerVTable
impl PartialEq for Duration
impl PartialEq for TryFromFloatSecsError
impl PartialEq for UnorderedKeyError
impl PartialEq for alloc::collections::TryReserveError
impl PartialEq for CString
impl PartialEq for FromVecWithNulError
impl PartialEq for IntoStringError
impl PartialEq for NulError
impl PartialEq for FromUtf8Error
impl PartialEq for indexmap::TryReserveError
impl PartialEq for BigEndian
impl PartialEq for LittleEndian
impl PartialEq for CompressedFileRange
impl PartialEq for object::read::Error
impl PartialEq for SectionIndex
impl PartialEq for SymbolIndex
impl PartialEq for BuildMetadata
impl PartialEq for Comparator
impl PartialEq for Prerelease
impl PartialEq for Version
impl PartialEq for VersionReq
impl PartialEq for IgnoredAny
impl PartialEq for serde::de::value::Error
impl PartialEq for DefaultToHost
impl PartialEq for DefaultToUnknown
impl PartialEq for Triple
impl PartialEq<IpAddr> for Ipv4Addr
impl PartialEq<IpAddr> for Ipv6Addr
impl PartialEq<KebabStr> for KebabString
impl PartialEq<KebabString> for KebabStr
impl PartialEq<Ipv4Addr> for IpAddr
impl PartialEq<Ipv6Addr> for IpAddr
impl<'a> PartialEq for FlagValue<'a>
impl<'a> PartialEq for ComponentDefinedType<'a>
impl<'a> PartialEq for Unexpected<'a>
impl<'a> PartialEq for DependencyName<'a>
impl<'a> PartialEq for HashName<'a>
impl<'a> PartialEq for InterfaceName<'a>
impl<'a> PartialEq for ResourceFunc<'a>
impl<'a> PartialEq for UrlName<'a>
impl<'a> PartialEq for VariantCase<'a>
impl<'a> PartialEq for Location<'a>
impl<'a> PartialEq for Utf8Chunk<'a>
impl<'a, 'b> PartialEq<&'a str> for String
impl<'a, 'b> PartialEq<&'b str> for Cow<'a, str>
impl<'a, 'b> PartialEq<Cow<'a, str>> for &'b str
impl<'a, 'b> PartialEq<Cow<'a, str>> for str
impl<'a, 'b> PartialEq<Cow<'a, str>> for String
impl<'a, 'b> PartialEq<str> for Cow<'a, str>
impl<'a, 'b> PartialEq<str> for String
impl<'a, 'b> PartialEq<String> for &'a str
impl<'a, 'b> PartialEq<String> for Cow<'a, str>
impl<'a, 'b> PartialEq<String> for str
impl<'a, 'b, B, C> PartialEq<Cow<'b, C>> for Cow<'a, B>
impl<'data> PartialEq for CodeView<'data>
impl<'data> PartialEq for CompressedData<'data>
impl<'data> PartialEq for Export<'data>
impl<'data> PartialEq for Import<'data>
impl<'data> PartialEq for ObjectMapEntry<'data>
impl<'data> PartialEq for SymbolMapName<'data>
impl<'data> PartialEq for Bytes<'data>
impl<A, B> PartialEq<&B> for &A
impl<A, B> PartialEq<&B> for &mut A
impl<A, B> PartialEq<&mut B> for &A
impl<A, B> PartialEq<&mut B> for &mut A
impl<A, B> PartialEq<SmallVec<B>> for SmallVec<A>
impl<B, C> PartialEq for ControlFlow<B, C>
impl<Dyn> PartialEq for DynMetadata<Dyn>where
Dyn: ?Sized,
impl<E> PartialEq for I16<E>
impl<E> PartialEq for I32<E>
impl<E> PartialEq for I64<E>
impl<E> PartialEq for U16<E>
impl<E> PartialEq for U32<E>
impl<E> PartialEq for U64<E>
impl<E> PartialEq for I16Bytes<E>
impl<E> PartialEq for I32Bytes<E>
impl<E> PartialEq for I64Bytes<E>
impl<E> PartialEq for U16Bytes<E>
impl<E> PartialEq for U32Bytes<E>
impl<E> PartialEq for U64Bytes<E>
impl<F> PartialEq for Fwhere
F: FnPtr,
impl<H> PartialEq for BuildHasherDefault<H>
impl<Idx> PartialEq for Range<Idx>where
Idx: PartialEq,
impl<Idx> PartialEq for RangeFrom<Idx>where
Idx: PartialEq,
impl<Idx> PartialEq for RangeInclusive<Idx>where
Idx: PartialEq,
impl<Idx> PartialEq for RangeTo<Idx>where
Idx: PartialEq,
impl<Idx> PartialEq for RangeToInclusive<Idx>where
Idx: PartialEq,
impl<K, V1, S1, V2, S2> PartialEq<IndexMap<K, V2, S2>> for IndexMap<K, V1, S1>
impl<K, V> PartialEq for PrimaryMap<K, V>
impl<K, V> PartialEq for SecondaryMap<K, V>
impl<K, V> PartialEq for indexmap::map::slice::Slice<K, V>
impl<K, V, A> PartialEq for BTreeMap<K, V, A>
impl<K, V, S, A> PartialEq for HashMap<K, V, S, A>
impl<Ptr, Q> PartialEq<Pin<Q>> for Pin<Ptr>
impl<Section, Symbol> PartialEq for object::common::SymbolFlags<Section, Symbol>
impl<T> PartialEq for Bound<T>where
T: PartialEq,
impl<T> PartialEq for Option<T>where
T: PartialEq,
impl<T> PartialEq for Poll<T>where
T: PartialEq,
impl<T> PartialEq for *const Twhere
T: ?Sized,
impl<T> PartialEq for *mut Twhere
T: ?Sized,
impl<T> PartialEq for (T₁, T₂, …, Tₙ)
This trait is implemented for tuples up to twelve items long.