Struct stc_ts_file_analyzer::analyzer::generic::inference::InferencePriority
source · [−]pub struct InferencePriority {
bits: i32,
}
Fields
bits: i32
Implementations
sourceimpl InferencePriority
impl InferencePriority
pub const None: Self = _
sourcepub const NakedTypeVariable: Self = _
pub const NakedTypeVariable: Self = _
Naked type variable in union or intersection type
sourcepub const SpeculativeTuple: Self = _
pub const SpeculativeTuple: Self = _
Speculative tuple inference
sourcepub const SubstituteSource: Self = _
pub const SubstituteSource: Self = _
Source of inference originated within a substitution type’s substitute
sourcepub const HomomorphicMappedType: Self = _
pub const HomomorphicMappedType: Self = _
Reverse inference for homomorphic mapped type
sourcepub const PartialHomomorphicMappedType: Self = _
pub const PartialHomomorphicMappedType: Self = _
Partial reverse inference for homomorphic mapped type
sourcepub const MappedTypeConstraint: Self = _
pub const MappedTypeConstraint: Self = _
Reverse inference for mapped type
sourcepub const ContravariantConditional: Self = _
pub const ContravariantConditional: Self = _
Conditional type in contravariant position
sourcepub const ReturnType: Self = _
pub const ReturnType: Self = _
Inference made from return type of generic function
sourcepub const LiteralKeyof: Self = _
pub const LiteralKeyof: Self = _
Inference made from a string literal to a keyof T
sourcepub const NoConstraints: Self = _
pub const NoConstraints: Self = _
Don’t infer from constraints of instantiable types
sourcepub const AlwaysStrict: Self = _
pub const AlwaysStrict: Self = _
Always use strict rules for contravariant inferences
sourcepub const Circularity: Self = _
pub const Circularity: Self = _
Inference circularity (value less than all other priorities)
sourcepub const PriorityImpliesCombination: Self = _
pub const PriorityImpliesCombination: Self = _
These priorities imply that the resulting type should be a combination of all candidates
sourcepub const fn from_bits(bits: i32) -> Option<Self>
pub const fn from_bits(bits: i32) -> Option<Self>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
sourcepub const fn from_bits_truncate(bits: i32) -> Self
pub const fn from_bits_truncate(bits: i32) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const unsafe fn from_bits_unchecked(bits: i32) -> Self
pub const unsafe fn from_bits_unchecked(bits: i32) -> Self
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
Safety
The caller of the bitflags!
macro can chose to allow or
disallow extra bits for their bitflags type.
The caller of from_bits_unchecked()
has to ensure that
all bits correspond to a defined flag or that extra bits
are valid for this bitflags type.
sourcepub const fn intersects(&self, other: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Returns true
if there are flags common to both self
and other
.
sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Returns true
if all of the flags in other
are contained within self
.
sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Inserts or removes the specified flags depending on the passed value.
sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
Returns the intersection between the flags in self
and
other
.
Specifically, the returned set contains only the flags which are
present in both self
and other
.
This is equivalent to using the &
operator (e.g.
ops::BitAnd
), as in flags & other
.
sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
Returns the union of between the flags in self
and other
.
Specifically, the returned set contains all flags which are
present in either self
or other
, including any which are
present in both (see Self::symmetric_difference
if that
is undesirable).
This is equivalent to using the |
operator (e.g.
ops::BitOr
), as in flags | other
.
sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
Returns the difference between the flags in self
and other
.
Specifically, the returned set contains all flags present in
self
, except for the ones present in other
.
It is also conceptually equivalent to the “bit-clear” operation:
flags & !other
(and this syntax is also supported).
This is equivalent to using the -
operator (e.g.
ops::Sub
), as in flags - other
.
sourcepub const fn symmetric_difference(self, other: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
Returns the symmetric difference between the flags
in self
and other
.
Specifically, the returned set contains the flags present which
are present in self
or other
, but that are not present in
both. Equivalently, it contains the flags present in exactly
one of the sets self
and other
.
This is equivalent to using the ^
operator (e.g.
ops::BitXor
), as in flags ^ other
.
sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
Returns the complement of this set of flags.
Specifically, the returned set contains all the flags which are
not set in self
, but which are allowed for this type.
Alternatively, it can be thought of as the set difference
between Self::all()
and self
(e.g. Self::all() - self
)
This is equivalent to using the !
operator (e.g.
ops::Not
), as in !flags
.
Trait Implementations
sourceimpl Binary for InferencePriority
impl Binary for InferencePriority
sourceimpl BitAnd<InferencePriority> for InferencePriority
impl BitAnd<InferencePriority> for InferencePriority
type Output = InferencePriority
type Output = InferencePriority
&
operator.sourceimpl BitAndAssign<InferencePriority> for InferencePriority
impl BitAndAssign<InferencePriority> for InferencePriority
sourcefn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
sourceimpl BitOr<InferencePriority> for InferencePriority
impl BitOr<InferencePriority> for InferencePriority
sourcefn bitor(self, other: InferencePriority) -> Self
fn bitor(self, other: InferencePriority) -> Self
Returns the union of the two sets of flags.
type Output = InferencePriority
type Output = InferencePriority
|
operator.sourceimpl BitOrAssign<InferencePriority> for InferencePriority
impl BitOrAssign<InferencePriority> for InferencePriority
sourcefn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
sourceimpl BitXor<InferencePriority> for InferencePriority
impl BitXor<InferencePriority> for InferencePriority
sourcefn bitxor(self, other: Self) -> Self
fn bitxor(self, other: Self) -> Self
Returns the left flags, but with all the right flags toggled.
type Output = InferencePriority
type Output = InferencePriority
^
operator.sourceimpl BitXorAssign<InferencePriority> for InferencePriority
impl BitXorAssign<InferencePriority> for InferencePriority
sourcefn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
sourceimpl Clone for InferencePriority
impl Clone for InferencePriority
sourcefn clone(&self) -> InferencePriority
fn clone(&self) -> InferencePriority
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresourceimpl Debug for InferencePriority
impl Debug for InferencePriority
sourceimpl Default for InferencePriority
impl Default for InferencePriority
sourceimpl Extend<InferencePriority> for InferencePriority
impl Extend<InferencePriority> for InferencePriority
sourcefn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
sourcefn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
)sourcefn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one
)sourceimpl FromIterator<InferencePriority> for InferencePriority
impl FromIterator<InferencePriority> for InferencePriority
sourcefn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
sourceimpl Hash for InferencePriority
impl Hash for InferencePriority
sourceimpl LowerHex for InferencePriority
impl LowerHex for InferencePriority
sourceimpl Not for InferencePriority
impl Not for InferencePriority
type Output = InferencePriority
type Output = InferencePriority
!
operator.sourceimpl Octal for InferencePriority
impl Octal for InferencePriority
sourceimpl Ord for InferencePriority
impl Ord for InferencePriority
sourcefn cmp(&self, other: &InferencePriority) -> Ordering
fn cmp(&self, other: &InferencePriority) -> Ordering
1.21.0 · sourcefn max(self, other: Self) -> Self
fn max(self, other: Self) -> Self
1.21.0 · sourcefn min(self, other: Self) -> Self
fn min(self, other: Self) -> Self
1.50.0 · sourcefn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
sourceimpl PartialEq<InferencePriority> for InferencePriority
impl PartialEq<InferencePriority> for InferencePriority
sourcefn eq(&self, other: &InferencePriority) -> bool
fn eq(&self, other: &InferencePriority) -> bool
sourceimpl PartialOrd<InferencePriority> for InferencePriority
impl PartialOrd<InferencePriority> for InferencePriority
sourcefn partial_cmp(&self, other: &InferencePriority) -> Option<Ordering>
fn partial_cmp(&self, other: &InferencePriority) -> Option<Ordering>
1.0.0 · sourcefn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read moresourceimpl Sub<InferencePriority> for InferencePriority
impl Sub<InferencePriority> for InferencePriority
type Output = InferencePriority
type Output = InferencePriority
-
operator.sourceimpl SubAssign<InferencePriority> for InferencePriority
impl SubAssign<InferencePriority> for InferencePriority
sourcefn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.
sourceimpl UpperHex for InferencePriority
impl UpperHex for InferencePriority
impl Copy for InferencePriority
impl Eq for InferencePriority
impl StructuralEq for InferencePriority
impl StructuralPartialEq for InferencePriority
Auto Trait Implementations
impl RefUnwindSafe for InferencePriority
impl Send for InferencePriority
impl Sync for InferencePriority
impl Unpin for InferencePriority
impl UnwindSafe for InferencePriority
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
sourceimpl<T> CallHasher for Twhere
T: Hash + ?Sized,
impl<T> CallHasher for Twhere
T: Hash + ?Sized,
sourceimpl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
sourcefn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.