Struct Ruleset
pub struct Ruleset(/* private fields */);Implementations§
§impl Ruleset
impl Ruleset
pub const fn bits(&self) -> u64
pub const fn bits(&self) -> u64
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
pub const fn from_bits(bits: u64) -> Option<Ruleset>
pub const fn from_bits(bits: u64) -> Option<Ruleset>
Convert from a bits value.
This method will return None if any unknown bits are set.
pub const fn from_bits_truncate(bits: u64) -> Ruleset
pub const fn from_bits_truncate(bits: u64) -> Ruleset
Convert from a bits value, unsetting any unknown bits.
pub const fn from_bits_retain(bits: u64) -> Ruleset
pub const fn from_bits_retain(bits: u64) -> Ruleset
Convert from a bits value exactly.
pub fn from_name(name: &str) -> Option<Ruleset>
pub fn from_name(name: &str) -> Option<Ruleset>
Get a flags value with the bits of a flag with the given name set.
This method will return None if name is empty or doesn’t
correspond to any named flag.
pub const fn intersects(&self, other: Ruleset) -> bool
pub const fn intersects(&self, other: Ruleset) -> bool
Whether any set bits in other are also set in self.
pub const fn contains(&self, other: Ruleset) -> bool
pub const fn contains(&self, other: Ruleset) -> bool
Whether all set bits in other are also set in self.
pub fn remove(&mut self, other: Ruleset)
pub fn remove(&mut self, other: Ruleset)
The intersection of self with the complement of other (&!).
This method is not equivalent to self & !other when other has unknown bits set.
remove won’t truncate other, but the ! operator will.
pub fn set(&mut self, other: Ruleset, value: bool)
pub fn set(&mut self, other: Ruleset, value: bool)
Call insert when value is true or remove when value is false.
pub const fn intersection(self, other: Ruleset) -> Ruleset
pub const fn intersection(self, other: Ruleset) -> Ruleset
The bitwise and (&) of the bits in self and other.
pub const fn union(self, other: Ruleset) -> Ruleset
pub const fn union(self, other: Ruleset) -> Ruleset
The bitwise or (|) of the bits in self and other.
pub const fn difference(self, other: Ruleset) -> Ruleset
pub const fn difference(self, other: Ruleset) -> Ruleset
The intersection of self with the complement of other (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.
pub const fn symmetric_difference(self, other: Ruleset) -> Ruleset
pub const fn symmetric_difference(self, other: Ruleset) -> Ruleset
The bitwise exclusive-or (^) of the bits in self and other.
pub const fn complement(self) -> Ruleset
pub const fn complement(self) -> Ruleset
The bitwise negation (!) of the bits in self, truncating the result.
§impl Ruleset
impl Ruleset
pub const fn iter(&self) -> Iter<Ruleset>
pub const fn iter(&self) -> Iter<Ruleset>
Yield a set of contained flags values.
Each yielded flags value will correspond to a defined named flag. Any unknown bits will be yielded together as a final flags value.
pub const fn iter_names(&self) -> IterNames<Ruleset>
pub const fn iter_names(&self) -> IterNames<Ruleset>
Yield a set of contained named flags values.
This method is like iter, except only yields bits in contained named flags.
Any unknown bits, or bits not corresponding to a contained flag will not be yielded.
Trait Implementations§
§impl BitAndAssign for Ruleset
impl BitAndAssign for Ruleset
§fn bitand_assign(&mut self, other: Ruleset)
fn bitand_assign(&mut self, other: Ruleset)
The bitwise and (&) of the bits in self and other.
§impl BitOrAssign for Ruleset
impl BitOrAssign for Ruleset
§fn bitor_assign(&mut self, other: Ruleset)
fn bitor_assign(&mut self, other: Ruleset)
The bitwise or (|) of the bits in self and other.
§impl BitXorAssign for Ruleset
impl BitXorAssign for Ruleset
§fn bitxor_assign(&mut self, other: Ruleset)
fn bitxor_assign(&mut self, other: Ruleset)
The bitwise exclusive-or (^) of the bits in self and other.
§impl<'de> Deserialize<'de> for Ruleset
impl<'de> Deserialize<'de> for Ruleset
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<Ruleset, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<Ruleset, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
§impl Extend<Ruleset> for Ruleset
impl Extend<Ruleset> for Ruleset
§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = Ruleset>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = Ruleset>,
The bitwise or (|) of the bits in each flags value.
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one)§impl Flags for Ruleset
impl Flags for Ruleset
§fn from_bits_retain(bits: u64) -> Ruleset
fn from_bits_retain(bits: u64) -> Ruleset
§fn known_bits(&self) -> Self::Bits
fn known_bits(&self) -> Self::Bits
§fn unknown_bits(&self) -> Self::Bits
fn unknown_bits(&self) -> Self::Bits
§fn contains_unknown_bits(&self) -> bool
fn contains_unknown_bits(&self) -> bool
true if any unknown bits are set.§fn from_bits_truncate(bits: Self::Bits) -> Self
fn from_bits_truncate(bits: Self::Bits) -> Self
§fn from_name(name: &str) -> Option<Self>
fn from_name(name: &str) -> Option<Self>
§fn iter_names(&self) -> IterNames<Self>
fn iter_names(&self) -> IterNames<Self>
§fn iter_defined_names() -> IterDefinedNames<Self>
fn iter_defined_names() -> IterDefinedNames<Self>
Self::FLAGS].§fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
other are also set in self.§fn contains(&self, other: Self) -> boolwhere
Self: Sized,
fn contains(&self, other: Self) -> boolwhere
Self: Sized,
other are also set in self.§fn insert(&mut self, other: Self)where
Self: Sized,
fn insert(&mut self, other: Self)where
Self: Sized,
|) of the bits in self and other.§fn toggle(&mut self, other: Self)where
Self: Sized,
fn toggle(&mut self, other: Self)where
Self: Sized,
^) of the bits in self and other.§fn set(&mut self, other: Self, value: bool)where
Self: Sized,
fn set(&mut self, other: Self, value: bool)where
Self: Sized,
Flags::insert] when value is true or [Flags::remove] when value is false.§fn intersection(self, other: Self) -> Self
fn intersection(self, other: Self) -> Self
&) of the bits in self and other.§fn difference(self, other: Self) -> Self
fn difference(self, other: Self) -> Self
§fn symmetric_difference(self, other: Self) -> Self
fn symmetric_difference(self, other: Self) -> Self
^) of the bits in self and other.§fn complement(self) -> Self
fn complement(self) -> Self
!) of the bits in self, truncating the result.§impl FromIterator<Ruleset> for Ruleset
impl FromIterator<Ruleset> for Ruleset
§fn from_iter<T>(iterator: T) -> Rulesetwhere
T: IntoIterator<Item = Ruleset>,
fn from_iter<T>(iterator: T) -> Rulesetwhere
T: IntoIterator<Item = Ruleset>,
The bitwise or (|) of the bits in each flags value.
§impl IntoIterator for Ruleset
impl IntoIterator for Ruleset
§impl Ord for Ruleset
impl Ord for Ruleset
§impl PartialOrd for Ruleset
impl PartialOrd for Ruleset
§impl Serialize for Ruleset
impl Serialize for Ruleset
§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
§impl Sub for Ruleset
impl Sub for Ruleset
§impl SubAssign for Ruleset
impl SubAssign for Ruleset
§fn sub_assign(&mut self, other: Ruleset)
fn sub_assign(&mut self, other: Ruleset)
The intersection of self with the complement of other (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.