Struct mm0_util::Modifiers[][src]

pub struct Modifiers { /* fields omitted */ }

Visibility and sort modifiers for Sort statements and Declarations.

Implementations

impl Modifiers[src]

pub const PURE: Modifiers[src]

The pure sort modifier, used to indicate that term constructors can not target this sort.

pub const STRICT: Modifiers[src]

The strict sort modifier, used to indicate that bound variables (in the sense of [LocalKind::is_bound]) of this sort are not allowed.

pub const PROVABLE: Modifiers[src]

The provable sort modifier, used to indicate that this sort can appear as the sort of hypotheses and conclusions of axiom and theorem declarations.

pub const FREE: Modifiers[src]

The free sort modifier, used to indicate that dummy variables of this sort (in def and theorem) are not allowed.

pub const PUB: Modifiers[src]

The pub visibility modifier, used on theorem to indicate that a theorem appears in the specification file (otherwise the theorem is only usable in the proof file).

pub const ABSTRACT: Modifiers[src]

The abstract visibility modifier, used on def to indicate that the definition should not be supplied in the specification file.

pub const LOCAL: Modifiers[src]

The local visibility modifier, the opposite of pub and used on def, because defs have default public visibility. A local def will not appear in the specification file at all.

pub const fn empty() -> Modifiers[src]

Returns an empty set of flags

pub const fn all() -> Modifiers[src]

Returns the set containing all flags.

pub const fn bits(&self) -> u8[src]

Returns the raw value of the flags currently stored.

pub fn from_bits(bits: u8) -> Option<Modifiers>[src]

Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.

pub const fn from_bits_truncate(bits: u8) -> Modifiers[src]

Convert from underlying bit representation, dropping any bits that do not correspond to flags.

pub const unsafe fn from_bits_unchecked(bits: u8) -> Modifiers[src]

Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).

pub const fn is_empty(&self) -> bool[src]

Returns true if no flags are currently stored.

pub const fn is_all(&self) -> bool[src]

Returns true if all flags are currently set.

pub const fn intersects(&self, other: Modifiers) -> bool[src]

Returns true if there are flags common to both self and other.

pub const fn contains(&self, other: Modifiers) -> bool[src]

Returns true all of the flags in other are contained within self.

pub fn insert(&mut self, other: Modifiers)[src]

Inserts the specified flags in-place.

pub fn remove(&mut self, other: Modifiers)[src]

Removes the specified flags in-place.

pub fn toggle(&mut self, other: Modifiers)[src]

Toggles the specified flags in-place.

pub fn set(&mut self, other: Modifiers, value: bool)[src]

Inserts or removes the specified flags depending on the passed value.

impl Modifiers[src]

pub const NONE: Modifiers[src]

The null modifier set. Modifiers are represented as bitfields, so this is the same as 0.

#[must_use]
pub fn new(bits: u8) -> Self
[src]

Construct a Modifiers from a byte.

#[must_use]
pub fn sort_data() -> Modifiers
[src]

The set of all valid sort modifiers. One can check if a modifier set is valid for a sort using sort_data().contains(m).

#[must_use]
pub fn from_name(s: &[u8]) -> Modifiers
[src]

Parses a string into a singleton Modifiers, or NONE if the string is not valid.

Trait Implementations

impl Binary for Modifiers[src]

impl BitAnd<Modifiers> for Modifiers[src]

type Output = Modifiers

The resulting type after applying the & operator.

fn bitand(self, other: Modifiers) -> Modifiers[src]

Returns the intersection between the two sets of flags.

impl BitAndAssign<Modifiers> for Modifiers[src]

fn bitand_assign(&mut self, other: Modifiers)[src]

Disables all flags disabled in the set.

impl BitOr<Modifiers> for Modifiers[src]

type Output = Modifiers

The resulting type after applying the | operator.

fn bitor(self, other: Modifiers) -> Modifiers[src]

Returns the union of the two sets of flags.

impl BitOrAssign<Modifiers> for Modifiers[src]

fn bitor_assign(&mut self, other: Modifiers)[src]

Adds the set of flags.

impl BitXor<Modifiers> for Modifiers[src]

type Output = Modifiers

The resulting type after applying the ^ operator.

fn bitxor(self, other: Modifiers) -> Modifiers[src]

Returns the left flags, but with all the right flags toggled.

impl BitXorAssign<Modifiers> for Modifiers[src]

fn bitxor_assign(&mut self, other: Modifiers)[src]

Toggles the set of flags.

impl Clone for Modifiers[src]

impl Copy for Modifiers[src]

impl Debug for Modifiers[src]

impl DeepSizeOf for Modifiers[src]

impl Display for Modifiers[src]

impl Eq for Modifiers[src]

impl Extend<Modifiers> for Modifiers[src]

impl FromIterator<Modifiers> for Modifiers[src]

impl Hash for Modifiers[src]

impl LowerHex for Modifiers[src]

impl Not for Modifiers[src]

type Output = Modifiers

The resulting type after applying the ! operator.

fn not(self) -> Modifiers[src]

Returns the complement of this set of flags.

impl Octal for Modifiers[src]

impl Ord for Modifiers[src]

impl PartialEq<Modifiers> for Modifiers[src]

impl PartialOrd<Modifiers> for Modifiers[src]

impl StructuralEq for Modifiers[src]

impl StructuralPartialEq for Modifiers[src]

impl Sub<Modifiers> for Modifiers[src]

type Output = Modifiers

The resulting type after applying the - operator.

fn sub(self, other: Modifiers) -> Modifiers[src]

Returns the set difference of the two sets of flags.

impl SubAssign<Modifiers> for Modifiers[src]

fn sub_assign(&mut self, other: Modifiers)[src]

Disables all flags enabled in the set.

impl UpperHex for Modifiers[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Erased for T

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T> ToString for T where
    T: Display + ?Sized
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.