Enum MemoryValue

Source
pub enum MemoryValue<F> {
    Field(F),
    U1(bool),
    U8(u8),
    U16(u16),
    U32(u32),
    U64(u64),
    U128(u128),
}
Expand description

A single typed value in the Brillig VM’s memory.

Memory in the VM is strongly typed and can represent either a native field element or an integer of a specific bit width. This enum encapsulates all supported in-memory types and allows conversion between representations.

Variants§

§

Field(F)

§

U1(bool)

§

U8(u8)

§

U16(u16)

§

U32(u32)

§

U64(u64)

§

U128(u128)

Implementations§

Source§

impl<F: Display> MemoryValue<F>

Source

pub fn new_field(value: F) -> Self

Builds a field-typed memory value.

Source

pub fn new_integer(value: u128, bit_size: IntegerBitSize) -> Self

Builds an integer-typed memory value.

Source

pub fn bit_size(&self) -> BitSize

Source

pub fn to_u32(&self) -> u32

Expects a U32 value and converts it into usize, otherwise panics.

Primarily a convenience method for using values in memory operations as pointers, sizes and offsets.

Source§

impl<F: AcirField> MemoryValue<F>

Source

pub fn new_from_field(value: F, bit_size: BitSize) -> Self

Builds a memory value from a field element, either field or integer type.

If the bit size indicates an integer type, the value is downcast to fit into the specified size.

Source

pub fn new_checked(value: F, bit_size: BitSize) -> Option<Self>

Builds a memory value from a field element, checking that the value is within the bit size, otherwise returns None.

Source

pub fn to_field(&self) -> F

Converts the memory value to a field element, independent of its type.

Source

pub fn to_u128(&self) -> Result<u128, MemoryTypeError>

Converts the memory value to U128, if the value is an integer.

Source

pub fn expect_field(self) -> Result<F, MemoryTypeError>

Extracts the field element from the memory value, if it is typed as field element.

Source

pub(crate) fn expect_u1(self) -> Result<bool, MemoryTypeError>

Source

pub(crate) fn expect_u8(self) -> Result<u8, MemoryTypeError>

Source

pub(crate) fn expect_u16(self) -> Result<u16, MemoryTypeError>

Source

pub(crate) fn expect_u32(self) -> Result<u32, MemoryTypeError>

Source

pub(crate) fn expect_u64(self) -> Result<u64, MemoryTypeError>

Source

pub(crate) fn expect_u128(self) -> Result<u128, MemoryTypeError>

Trait Implementations§

Source§

impl<F: Clone> Clone for MemoryValue<F>

Source§

fn clone(&self) -> MemoryValue<F>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<F: Debug> Debug for MemoryValue<F>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<F: AcirField> Default for MemoryValue<F>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<F: Display> Display for MemoryValue<F>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<F: AcirField> From<bool> for MemoryValue<F>

Source§

fn from(value: bool) -> Self

Converts to this type from the input type.
Source§

impl<F: AcirField> From<u128> for MemoryValue<F>

Source§

fn from(value: u128) -> Self

Converts to this type from the input type.
Source§

impl<F: AcirField> From<u32> for MemoryValue<F>

Source§

fn from(value: u32) -> Self

Converts to this type from the input type.
Source§

impl<F: AcirField> From<u64> for MemoryValue<F>

Source§

fn from(value: u64) -> Self

Converts to this type from the input type.
Source§

impl<F: AcirField> From<u8> for MemoryValue<F>

Source§

fn from(value: u8) -> Self

Converts to this type from the input type.
Source§

impl<F: Ord> Ord for MemoryValue<F>

Source§

fn cmp(&self, other: &MemoryValue<F>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<F: PartialEq> PartialEq for MemoryValue<F>

Source§

fn eq(&self, other: &MemoryValue<F>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<F: PartialOrd> PartialOrd for MemoryValue<F>

Source§

fn partial_cmp(&self, other: &MemoryValue<F>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<F: AcirField> TryFrom<MemoryValue<F>> for bool

Source§

type Error = MemoryTypeError

The type returned in the event of a conversion error.
Source§

fn try_from(memory_value: MemoryValue<F>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<F: AcirField> TryFrom<MemoryValue<F>> for u128

Source§

type Error = MemoryTypeError

The type returned in the event of a conversion error.
Source§

fn try_from(memory_value: MemoryValue<F>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<F: AcirField> TryFrom<MemoryValue<F>> for u32

Source§

type Error = MemoryTypeError

The type returned in the event of a conversion error.
Source§

fn try_from(memory_value: MemoryValue<F>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<F: AcirField> TryFrom<MemoryValue<F>> for u64

Source§

type Error = MemoryTypeError

The type returned in the event of a conversion error.
Source§

fn try_from(memory_value: MemoryValue<F>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<F: AcirField> TryFrom<MemoryValue<F>> for u8

Source§

type Error = MemoryTypeError

The type returned in the event of a conversion error.
Source§

fn try_from(memory_value: MemoryValue<F>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<F: Copy> Copy for MemoryValue<F>

Source§

impl<F: Eq> Eq for MemoryValue<F>

Source§

impl<F> StructuralPartialEq for MemoryValue<F>

Auto Trait Implementations§

§

impl<F> Freeze for MemoryValue<F>
where F: Freeze,

§

impl<F> RefUnwindSafe for MemoryValue<F>
where F: RefUnwindSafe,

§

impl<F> Send for MemoryValue<F>
where F: Send,

§

impl<F> Sync for MemoryValue<F>
where F: Sync,

§

impl<F> Unpin for MemoryValue<F>
where F: Unpin,

§

impl<F> UnwindSafe for MemoryValue<F>
where F: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V