[]Struct hlvm_runtime::number::Status

pub struct Status { /* fields omitted */ }

The status of the floating point context. Instead of faulting after every operation errors are added to this status. User code can check and/or clear the status fully or partially at specific points to check the validity of the computation. Each thread gets its own status. The status is initially empty.

Examples

assert_eq!(d128::get_status(), Status::empty());
let _ = d128!(1) / &d128!(0);
assert!(d128::get_status().contains(decimal::Status::DIVISION_BY_ZERO));
let _ = d128!(0) / &d128!(0);
assert!(d128::get_status().contains(decimal::Status::DIVISION_UNDEFINED));
// The previous status flag was not cleared!
assert!(d128::get_status().contains(decimal::Status::DIVISION_BY_ZERO));

Methods

impl Status

pub const CONVERSION_SYNTAX: Status

Conversion syntax error.

pub const DIVISION_BY_ZERO: Status

Division by zero.

pub const DIVISION_IMPOSSIBLE: Status

Division impossible.

pub const DIVISION_UNDEFINED: Status

Division undefined.

pub const INEXACT: Status

The result is inexact.

pub const INVALID_OPERATION: Status

An invalid operation was requested.

pub const OVERFLOW: Status

Overflow.

pub const UNDERFLOW: Status

Underflow.

pub fn empty() -> Status

Returns an empty set of flags.

pub fn all() -> Status

Returns the set containing all flags.

pub fn bits(&self) -> u32

Returns the raw value of the flags currently stored.

pub fn from_bits(bits: u32) -> Option<Status>

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

pub fn from_bits_truncate(bits: u32) -> Status

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

pub fn is_empty(&self) -> bool

Returns true if no flags are currently stored.

pub fn is_all(&self) -> bool

Returns true if all flags are currently set.

pub fn intersects(&self, other: Status) -> bool

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

pub fn contains(&self, other: Status) -> bool

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

pub fn insert(&mut self, other: Status)

Inserts the specified flags in-place.

pub fn remove(&mut self, other: Status)

Removes the specified flags in-place.

pub fn toggle(&mut self, other: Status)

Toggles the specified flags in-place.

pub fn set(&mut self, other: Status, value: bool)

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

Trait Implementations

impl Binary for Status

impl Copy for Status

impl Clone for Status

default fn clone_from(&mut self, source: &Self)
1.0.0
[src]

Performs copy-assignment from source. Read more

impl Extend<Status> for Status

impl BitOrAssign<Status> for Status

fn bitor_assign(&mut self, other: Status)

Adds the set of flags.

impl BitAndAssign<Status> for Status

fn bitand_assign(&mut self, other: Status)

Disables all flags disabled in the set.

impl Hash for Status

default fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl BitOr<Status> for Status

type Output = Status

The resulting type after applying the | operator.

fn bitor(self, other: Status) -> Status

Returns the union of the two sets of flags.

impl BitXor<Status> for Status

type Output = Status

The resulting type after applying the ^ operator.

fn bitxor(self, other: Status) -> Status

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

impl PartialEq<Status> for Status

impl SubAssign<Status> for Status

fn sub_assign(&mut self, other: Status)

Disables all flags enabled in the set.

impl BitXorAssign<Status> for Status

fn bitxor_assign(&mut self, other: Status)

Toggles the set of flags.

impl Octal for Status

impl Not for Status

type Output = Status

The resulting type after applying the ! operator.

fn not(self) -> Status

Returns the complement of this set of flags.

impl UpperHex for Status

impl Ord for Status

default fn max(self, other: Self) -> Self
1.21.0
[src]

Compares and returns the maximum of two values. Read more

default fn min(self, other: Self) -> Self
1.21.0
[src]

Compares and returns the minimum of two values. Read more

default fn clamp(self, min: Self, max: Self) -> Self[src]

🔬 This is a nightly-only experimental API. (clamp)

Restrict a value to a certain interval. Read more

impl LowerHex for Status

impl BitAnd<Status> for Status

type Output = Status

The resulting type after applying the & operator.

fn bitand(self, other: Status) -> Status

Returns the intersection between the two sets of flags.

impl FromIterator<Status> for Status

impl Sub<Status> for Status

type Output = Status

The resulting type after applying the - operator.

fn sub(self, other: Status) -> Status

Returns the set difference of the two sets of flags.

impl Eq for Status

impl PartialOrd<Status> for Status

impl Debug for Status

Auto Trait Implementations

impl Send for Status

impl Sync for Status

Blanket Implementations

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

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

type Owned = T

impl<T> From for T[src]

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

type Error = Infallible

The type returned in the event of a conversion error.

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

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

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

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

The type returned in the event of a conversion error.

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