Enum muse_lang::runtime::value::Value

source ·
pub enum Value {
    Primitive(Primitive),
    Symbol(SymbolRef),
    Dynamic(AnyDynamic),
}
Expand description

A Muse virtual machine value.

Variants§

§

Primitive(Primitive)

§

Symbol(SymbolRef)

A symbol.

§

Dynamic(AnyDynamic)

A dynamically allocated, garbage collected type.

Implementations§

source§

impl Value

source

pub const TRUE: Self = _

source

pub const FALSE: Self = _

source

pub const NIL: Self = _

source

pub const ZERO: Self = _

source

pub fn upgrade(&self, guard: &CollectionGuard<'_>) -> Option<RootedValue>

Returns this value with any garbage collected values upgraded to root references.

source

pub fn dynamic<'guard, T>( value: T, guard: &impl AsRef<CollectionGuard<'guard>>, ) -> Self
where T: DynamicValue + Trace,

Moves value into the virtual machine.

source

pub const fn is_nil(&self) -> bool

Returns true if this value is nil.

source

pub fn as_primitive(&self) -> Option<Primitive>

Returns this value as an i64, if possible.

source

pub fn as_i64(&self) -> Option<i64>

Returns this value as an i64, if possible.

source

pub fn as_u64(&self) -> Option<u64>

Returns this value as an u64, if possible.

source

pub fn as_u32(&self) -> Option<u32>

Returns this value as an u32, if possible.

source

pub fn as_u16(&self) -> Option<u16>

Returns this value as an u16, if possible.

source

pub fn as_usize(&self) -> Option<usize>

Returns this value as an usize, if possible.

source

pub fn as_f64(&self) -> Option<f64>

Returns this value as an f64, if possible.

source

pub fn to_i64(&self) -> Option<i64>

Converts this value to an i64, if possible.

source

pub fn to_u64(&self) -> Option<u64>

Converts this value to an u64, if possible.

source

pub fn to_u32(&self) -> Option<u32>

Converts this value to an u32, if possible.

source

pub fn to_usize(&self) -> Option<usize>

Converts this value to an usize, if possible.

source

pub fn to_f64(&self) -> Option<f64>

Converts this value to an f64, if possible.

source

pub fn as_symbol_ref(&self) -> Option<&SymbolRef>

Returns this value as a SymbolRef, if possible.

source

pub fn as_symbol(&self, guard: &CollectionGuard<'_>) -> Option<Symbol>

Returns this value as a Symbol, if possible.

source

pub fn as_any_dynamic(&self) -> Option<AnyDynamic>

Returns this value as an AnyDynamic, if possible.

source

pub fn as_dynamic<T>(&self) -> Option<Dynamic<T>>
where T: DynamicValue + Trace,

Returns this value as a Dynamic<T>, if this value contains a T.

source

pub fn as_rooted<T>(&self, guard: &CollectionGuard<'_>) -> Option<Rooted<T>>
where T: DynamicValue + Trace,

Returns this value as a Rooted<T>, if this value contains a T.

source

pub fn as_downcast_ref<'guard, T>( &self, guard: &'guard CollectionGuard<'_>, ) -> Option<&'guard T>
where T: DynamicValue + Trace,

Returns this value as a&T, if this value contains a T.

source

pub fn truthy(&self, vm: &mut VmContext<'_, '_>) -> bool

Returns true if this value should be considered true in a boolean expression.

source

pub fn call( &self, vm: &mut VmContext<'_, '_>, arity: impl Into<Arity>, ) -> Result<Value, Fault>

Invokes this value as a function.

source

pub fn invoke( &self, vm: &mut VmContext<'_, '_>, name: &SymbolRef, arity: impl Into<Arity>, ) -> Result<Value, Fault>

Invokes name on this value.

source

pub fn add( &self, vm: &mut VmContext<'_, '_>, rhs: &Self, ) -> Result<Value, Fault>

Adds self to rhs.

source

pub fn sub( &self, vm: &mut VmContext<'_, '_>, rhs: &Self, ) -> Result<Value, Fault>

Subtracts rhs from self.

source

pub fn mul( &self, vm: &mut VmContext<'_, '_>, rhs: &Self, ) -> Result<Value, Fault>

Multiplies self by rhs.

source

pub fn pow( &self, vm: &mut VmContext<'_, '_>, exp: &Self, ) -> Result<Value, Fault>

Raises self to the rhs power.

source

pub fn div( &self, vm: &mut VmContext<'_, '_>, rhs: &Self, ) -> Result<Value, Fault>

Divides self by rhs.

source

pub fn idiv( &self, vm: &mut VmContext<'_, '_>, rhs: &Self, ) -> Result<Value, Fault>

Divides self by rhs, using whole numbers.

source

pub fn rem( &self, vm: &mut VmContext<'_, '_>, rhs: &Self, ) -> Result<Value, Fault>

Calcualtes the remainder of dividing self by rhs using whole numbers.

source

pub fn not(&self, vm: &mut VmContext<'_, '_>) -> Result<Self, Fault>

Returns the inverse of Self::truthy.

source

pub fn negate(&self, vm: &mut VmContext<'_, '_>) -> Result<Self, Fault>

Negates this value.

source

pub fn bitwise_not(&self, vm: &mut VmContext<'_, '_>) -> Result<Self, Fault>

Returns the bitwise not of this value.

source

pub fn bitwise_and( &self, vm: &mut VmContext<'_, '_>, rhs: &Value, ) -> Result<Self, Fault>

Returns the bitwise and of self and rhs.

source

pub fn bitwise_or( &self, vm: &mut VmContext<'_, '_>, rhs: &Value, ) -> Result<Self, Fault>

Returns the bitwise or of self and rhs.

source

pub fn bitwise_xor( &self, vm: &mut VmContext<'_, '_>, rhs: &Value, ) -> Result<Self, Fault>

Returns the bitwise xor of self and rhs.

source

pub fn shift_left( &self, vm: &mut VmContext<'_, '_>, rhs: &Value, ) -> Result<Self, Fault>

Returns the bitwise shift left of self by rhs.

source

pub fn shift_right( &self, vm: &mut VmContext<'_, '_>, rhs: &Value, ) -> Result<Self, Fault>

Returns the shift right of self by rhs.

source

pub fn to_string(&self, vm: &mut VmContext<'_, '_>) -> Result<SymbolRef, Fault>

Returns this value as a shared string reference.

source

pub fn map_str<R>( &self, vm: &mut VmContext<'_, '_>, map: impl FnOnce(&mut VmContext<'_, '_>, &str) -> R, ) -> Result<R, Fault>

Maps the contents of this value as a str, if possible.

source

pub fn hash_into(&self, vm: &mut VmContext<'_, '_>, hasher: &mut ValueHasher)

Hashes this value into hasher.

source

pub fn hash(&self, vm: &mut VmContext<'_, '_>) -> u64

Calculates the hash of this value.

source

pub fn equals( &self, vm: ContextOrGuard<'_, '_, '_>, other: &Self, ) -> Result<bool, Fault>

Returns true if self and other are equivalent values.

source

pub fn matches( &self, vm: &mut VmContext<'_, '_>, other: &Self, ) -> Result<bool, Fault>

Returns true if self matches other.

source

pub fn total_cmp( &self, vm: &mut VmContext<'_, '_>, other: &Self, ) -> Result<Ordering, Fault>

Returns an ordering of self and other that takes into account both the type of data and the value itself.

source

pub fn take(&mut self) -> Value

Take the contents of this value, leaving nil behind.

source

pub fn deep_clone(&self, guard: &CollectionGuard<'_>) -> Option<Value>

Perform a deep-clone on the contents of this value.

Not all types are able to be deeply cloned. Unsupported types will result in None.

source

pub fn format(&self, context: &mut VmContext<'_, '_>, f: impl Write) -> Result

Formats this value for display into f.

Trait Implementations§

source§

impl Clone for Value

source§

fn clone(&self) -> Value

Returns a copy 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 Debug for Value

source§

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

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

impl Default for Value

source§

fn default() -> Self

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

impl From<&Symbol> for Value

source§

fn from(value: &Symbol) -> Self

Converts to this type from the input type.
source§

impl From<&SymbolRef> for Value

source§

fn from(value: &SymbolRef) -> Self

Converts to this type from the input type.
source§

impl From<Symbol> for Value

source§

fn from(value: Symbol) -> Self

Converts to this type from the input type.
source§

impl From<SymbolRef> for Value

source§

fn from(value: SymbolRef) -> Self

Converts to this type from the input type.
source§

impl From<bool> for Value

source§

fn from(value: bool) -> Self

Converts to this type from the input type.
source§

impl From<f32> for Value

source§

fn from(value: f32) -> Self

Converts to this type from the input type.
source§

impl From<f64> for Value

source§

fn from(value: f64) -> Self

Converts to this type from the input type.
source§

impl From<i16> for Value

source§

fn from(value: i16) -> Self

Converts to this type from the input type.
source§

impl From<i32> for Value

source§

fn from(value: i32) -> Self

Converts to this type from the input type.
source§

impl From<i64> for Value

source§

fn from(value: i64) -> Self

Converts to this type from the input type.
source§

impl From<i8> for Value

source§

fn from(value: i8) -> Self

Converts to this type from the input type.
source§

impl From<u16> for Value

source§

fn from(value: u16) -> Self

Converts to this type from the input type.
source§

impl From<u32> for Value

source§

fn from(value: u32) -> Self

Converts to this type from the input type.
source§

impl From<u64> for Value

source§

fn from(value: u64) -> Self

Converts to this type from the input type.
source§

impl From<u8> for Value

source§

fn from(value: u8) -> Self

Converts to this type from the input type.
source§

impl FromIterator<Value> for List

source§

fn from_iter<T: IntoIterator<Item = Value>>(iter: T) -> Self

Creates a value from an iterator. Read more
source§

impl PartialEq for Value

source§

fn eq(&self, other: &Self) -> 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 Trace for Value

source§

const MAY_CONTAIN_REFERENCES: bool = true

If true, this type may contain references and should have its trace() function invoked during the collector’s “mark” phase.
source§

fn trace(&self, tracer: &mut Tracer<'_>)

Traces all refrences that this value references. Read more
source§

impl TryFrom<i128> for Value

§

type Error = Fault

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

fn try_from(value: i128) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<isize> for Value

§

type Error = Fault

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

fn try_from(value: isize) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<u128> for Value

§

type Error = Fault

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

fn try_from(value: u128) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<usize> for Value

§

type Error = Fault

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

fn try_from(value: usize) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl Copy for Value

Auto Trait Implementations§

§

impl Freeze for Value

§

impl RefUnwindSafe for Value

§

impl Send for Value

§

impl Sync for Value

§

impl Unpin for Value

§

impl UnwindSafe for Value

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
§

impl<A> Cast for A

§

fn cast<To>(self) -> To
where To: CastFrom<A>,

Casts self to the To type. This may be a lossy operation.
§

impl<A> CastFrom<A> for A

§

fn from_cast(from: A) -> A

Returns from as Self.
§

impl<A, B> CastInto<A> for B
where A: CastFrom<B>,

§

fn cast_into(self) -> A

Returns self as To.
source§

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

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

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

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

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

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

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> ToOwned for T
where T: Clone,

§

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, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more