Struct Vm

Source
pub struct Vm<'a, Aux = ()>
where Aux: 'a,
{ pub auxiliary_data: Aux, pub max_instr: u64, pub remaining_iters: u64, pub runtime_data: Pin<Box<RuntimeData>>, /* private fields */ }
Expand description

Cao-Lang bytecode interpreter. Aux is an auxiliary runtime structure passed to custom functions.

Fields§

§auxiliary_data: Aux§max_instr: u64

Number of instructions run will execute before returning Timeout

§remaining_iters: u64§runtime_data: Pin<Box<RuntimeData>>

Implementations§

Source§

impl<'a, Aux> Vm<'a, Aux>

Source

pub fn new(auxiliary_data: Aux) -> Result<Self, ExecutionErrorPayload>
where Aux: 'static,

Source

pub fn register_native_stdlib(&mut self) -> Result<(), ExecutionErrorPayload>
where Aux: 'static,

Source

pub fn insert_value( &mut self, value: &OwnedValue, ) -> Result<Value, ExecutionErrorPayload>

Inserts the given value into the VM’s runtime memory. Returns the inserted [Value]

Source

pub fn init_native_function( &mut self, handle: Handle, ) -> Result<ObjectGcGuard, ExecutionErrorPayload>

Source

pub fn init_function( &mut self, handle: Handle, arity: u32, ) -> Result<ObjectGcGuard, ExecutionErrorPayload>

Source

pub fn init_closure( &mut self, handle: Handle, arity: u32, ) -> Result<ObjectGcGuard, ExecutionErrorPayload>

Source

pub fn init_upvalue( &mut self, location: *mut Value, ) -> Result<ObjectGcGuard, ExecutionErrorPayload>

Source

pub fn clear(&mut self)

Source

pub fn read_var_by_name(&self, name: &str, vars: &Variables) -> Option<Value>

Source

pub fn read_var(&self, name: VariableId) -> Option<Value>

Source

pub fn with_max_iter(self, max_iter: u64) -> Self

Source

pub fn get_aux(&self) -> &Aux

Source

pub fn get_aux_mut(&mut self) -> &mut Aux

Source

pub fn unwrap_aux(self) -> Aux

Source

pub fn register_native_function<S, C>( &mut self, name: S, f: C, ) -> Result<(), ExecutionErrorPayload>
where S: AsRef<str>, C: VmFunction<Aux> + 'static,

Register a native function for use by Cao-Lang programs

Source

pub fn stack_push<S>(&mut self, value: S) -> Result<(), ExecutionErrorPayload>
where S: Into<Value>,

Source

pub fn stack_pop(&mut self) -> Value

Source

pub fn get_table( &self, value: Value, ) -> Result<&CaoLangTable, ExecutionErrorPayload>

Source

pub fn get_table_mut( &self, value: Value, ) -> Result<&mut CaoLangTable, ExecutionErrorPayload>

Source

pub fn init_table(&mut self) -> Result<ObjectGcGuard, ExecutionErrorPayload>

Initializes a new FieldTable in this VM instance

Source

pub fn init_string( &mut self, payload: &str, ) -> Result<ObjectGcGuard, ExecutionErrorPayload>

Initializes a new string owned by this VM instance

Source

pub fn run_function( &mut self, val: Value, ) -> Result<Value, ExecutionErrorPayload>

Panics if no current program has been set

Source

pub fn run(&mut self, program: &CaoCompiledProgram) -> ExecutionResult<()>

This mostly assumes that program is valid, produced by the compiler. As such running non-compiler emitted programs is very un-safe

Auto Trait Implementations§

§

impl<'a, Aux> Freeze for Vm<'a, Aux>
where Aux: Freeze,

§

impl<'a, Aux = ()> !RefUnwindSafe for Vm<'a, Aux>

§

impl<'a, Aux = ()> !Send for Vm<'a, Aux>

§

impl<'a, Aux = ()> !Sync for Vm<'a, Aux>

§

impl<'a, Aux> Unpin for Vm<'a, Aux>
where Aux: Unpin,

§

impl<'a, Aux = ()> !UnwindSafe for Vm<'a, Aux>

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

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

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

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, 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.
Source§

impl<T> WithSubscriber for T

Source§

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
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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