pub struct Machine {
pub prog: Program,
pub closures: ClosureStorage,
pub heap: HeapStorage,
pub ext_fun_table: Vec<(Symbol, ExtFunType)>,
pub ext_cls_table: Vec<(Symbol, ExtClsType)>,
pub arrays: ArrayStorage,
/* private fields */
}Expand description
Fields§
§prog: Program§closures: ClosureStorage§heap: HeapStorage§ext_fun_table: Vec<(Symbol, ExtFunType)>§ext_cls_table: Vec<(Symbol, ExtClsType)>§arrays: ArrayStorageImplementations§
Source§impl Machine
impl Machine
Sourcepub fn drop_closure(&mut self, id: ClosureIdx)
pub fn drop_closure(&mut self, id: ClosureIdx)
Drop a closure by decrementing its reference count. When refcount reaches 0, recursively drops captured closures and removes the closure.
Sourcepub fn new(
prog: Program,
extfns: impl Iterator<Item = ExtFunInfo>,
extcls: impl Iterator<Item = Box<dyn MachineFunction>>,
) -> Self
pub fn new( prog: Program, extfns: impl Iterator<Item = ExtFunInfo>, extcls: impl Iterator<Item = Box<dyn MachineFunction>>, ) -> Self
Create a new VM from a compiled Program and external functions.
Sourcepub fn new_resume(&self, prog: Program) -> Self
pub fn new_resume(&self, prog: Program) -> Self
Create a new VM instance with the new program, preserving the current state as possible.
pub fn clear_stack(&mut self)
pub fn get_stack(&self, offset: i64) -> RawVal
pub fn get_stack_range( &self, offset: i64, word_size: TypeSize, ) -> (Range<usize>, &[RawVal])
pub fn get_stack_range_mut( &mut self, offset: i64, word_size: TypeSize, ) -> (Range<usize>, &mut [RawVal])
pub fn set_stack(&mut self, offset: i64, v: RawVal)
pub fn set_stack_range(&mut self, offset: i64, vs: &[RawVal])
pub fn get_top_n(&self, n: usize) -> &[RawVal] ⓘ
Sourcepub fn get_current_ext_call_nargs(&self) -> u8
pub fn get_current_ext_call_nargs(&self) -> u8
Number of argument words for the currently executing external function call.
pub fn get_current_ext_call_idx(&self) -> Option<usize>
Sourcepub fn get_closure_idx_from_heap(&self, heap_idx: HeapIdx) -> ClosureIdx
pub fn get_closure_idx_from_heap(&self, heap_idx: HeapIdx) -> ClosureIdx
Extract the ClosureIdx stored inside a heap-allocated closure object.
During the migration period the heap object wraps a single ClosureIdx
in data[0]. External callers (e.g. the scheduler plugin) can use this
to obtain the underlying closure index from a HeapIdx value that lives
on the VM stack.
pub fn get_open_upvalue( &self, upper_base: usize, ov: OpenUpValue, ) -> (Range<usize>, &[RawVal])
pub fn get_closure(&self, idx: ClosureIdx) -> &Closure
pub fn get_as<T>(v: RawVal) -> T
pub fn get_as_array<T>(v: &[RawVal]) -> &[T]
pub fn to_value<T>(v: T) -> RawVal
Sourcepub fn wrap_extern_cls(&mut self, extcls: ExtClsInfo) -> ClosureIdx
pub fn wrap_extern_cls(&mut self, extcls: ExtClsInfo) -> ClosureIdx
This API is used for defining higher-order external function that returns some external rust closure. Because the native closure cannot be called with CallCls directly, the vm appends an additional function the program, that wraps external closure call with an internal closure.
Sourcepub fn execute(
&mut self,
func_i: usize,
cls_i: Option<ClosureIdx>,
) -> ReturnCode
pub fn execute( &mut self, func_i: usize, cls_i: Option<ClosureIdx>, ) -> ReturnCode
Execute a function within the VM.
func_i is an index into the program’s function table and cls_i is an
optional closure that provides the environment for the call.
The returned ReturnCode is the number of values pushed on the stack
as a result of the call.
pub fn install_extern_fn(&mut self, name: Symbol, f: ExtFunType) -> usize
pub fn install_extern_cls(&mut self, name: Symbol, f: ExtClsType) -> usize
Sourcepub fn alloc_code(&mut self, expr: ExprNodeId) -> RawVal
pub fn alloc_code(&mut self, expr: ExprNodeId) -> RawVal
Store a code value (AST fragment) and return a RawVal index.
The returned value can later be passed to [get_code] to recover the
original ExprNodeId.
Sourcepub fn get_code(&self, val: RawVal) -> ExprNodeId
pub fn get_code(&self, val: RawVal) -> ExprNodeId
Retrieve a previously stored code value by its RawVal index.
Sourcepub fn try_get_code(&self, val: RawVal) -> Option<ExprNodeId>
pub fn try_get_code(&self, val: RawVal) -> Option<ExprNodeId>
Try retrieving a previously stored code value by its RawVal index.
pub fn execute_idx(&mut self, idx: usize) -> ReturnCode
pub fn execute_entry(&mut self, entry: &str) -> ReturnCode
pub fn execute_main(&mut self) -> ReturnCode
Trait Implementations§
Source§impl RuntimePrimitives for Machine
impl RuntimePrimitives for Machine
type HeapRef = DefaultKey
type ArrayRef = u64
type StateOffset = U24
type TypeId = u8
fn heap_alloc(&mut self, size_words: WordSize) -> Self::HeapRef
fn heap_retain(&mut self, obj: Self::HeapRef)
fn heap_release(&mut self, obj: Self::HeapRef)
fn heap_load( &mut self, dst: &mut [Word], obj: Self::HeapRef, size_words: WordSize, )
fn heap_store(&mut self, obj: Self::HeapRef, src: &[Word], size_words: WordSize)
fn box_alloc(&mut self, src: &[Word], size_words: WordSize) -> Self::HeapRef
fn box_load( &mut self, dst: &mut [Word], obj: Self::HeapRef, size_words: WordSize, )
fn box_clone(&mut self, obj: Self::HeapRef)
fn box_release(&mut self, obj: Self::HeapRef)
fn box_store(&mut self, obj: Self::HeapRef, src: &[Word], size_words: WordSize)
fn usersum_clone( &mut self, value: &mut [Word], size_words: WordSize, type_id: Self::TypeId, )
fn usersum_release( &mut self, value: &mut [Word], size_words: WordSize, type_id: Self::TypeId, )
fn closure_make( &mut self, _fn_index: Word, _upvalue_count: WordSize, _state_size: WordSize, ) -> Self::HeapRef
fn closure_close(&mut self, obj: Self::HeapRef)
fn closure_call( &mut self, _obj: Self::HeapRef, _args: &[Word], _nargs_words: WordSize, _ret: &mut [Word], _nret_words: WordSize, )
fn state_push(&mut self, offset: Self::StateOffset)
fn state_pop(&mut self, offset: Self::StateOffset)
fn state_get(&mut self, dst: &mut [Word], size_words: WordSize)
fn state_set(&mut self, src: &[Word], size_words: WordSize)
fn state_delay( &mut self, dst: &mut [Word], src: &[Word], time: &[Word], max_len: Word, )
fn state_mem(&mut self, dst: &mut [Word], src: &[Word])
fn array_alloc( &mut self, len: Word, elem_size_words: WordSize, ) -> Self::ArrayRef
fn array_get_elem( &mut self, dst: &mut [Word], arr: Self::ArrayRef, index: Word, elem_size_words: WordSize, )
fn array_set_elem( &mut self, arr: Self::ArrayRef, index: Word, src: &[Word], elem_size_words: WordSize, )
fn runtime_get_now(&mut self) -> Word
fn runtime_get_samplerate(&mut self) -> Word
Auto Trait Implementations§
impl Freeze for Machine
impl !RefUnwindSafe for Machine
impl !Send for Machine
impl !Sync for Machine
impl Unpin for Machine
impl UnsafeUnpin for Machine
impl !UnwindSafe for Machine
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);