Skip to main content

EvalContext

Struct EvalContext 

Source
pub struct EvalContext {
Show 19 fields pub module_cache: RefCell<BTreeMap<PathBuf, BTreeMap<String, Value>>>, pub current_file: RefCell<Vec<PathBuf>>, pub module_exports: RefCell<Vec<Option<Vec<String>>>>, pub module_load_stack: RefCell<Vec<PathBuf>>, pub call_stack: RefCell<Vec<CallFrame>>, pub span_table: RefCell<HashMap<usize, Span>>, pub eval_depth: Cell<usize>, pub max_eval_depth: Cell<usize>, pub eval_step_limit: Cell<usize>, pub eval_steps: Cell<usize>, pub eval_deadline: Cell<Option<Instant>>, pub sandbox: Sandbox, pub user_context: RefCell<Vec<BTreeMap<Value, Value>>>, pub hidden_context: RefCell<Vec<BTreeMap<Value, Value>>>, pub context_stacks: RefCell<BTreeMap<Value, Vec<Value>>>, pub eval_fn: Cell<Option<EvalCallbackFn>>, pub call_fn: Cell<Option<CallCallbackFn>>, pub interactive: Cell<bool>, pub vm_backend: Cell<bool>,
}

Fields§

§module_cache: RefCell<BTreeMap<PathBuf, BTreeMap<String, Value>>>§current_file: RefCell<Vec<PathBuf>>§module_exports: RefCell<Vec<Option<Vec<String>>>>§module_load_stack: RefCell<Vec<PathBuf>>§call_stack: RefCell<Vec<CallFrame>>§span_table: RefCell<HashMap<usize, Span>>§eval_depth: Cell<usize>§max_eval_depth: Cell<usize>§eval_step_limit: Cell<usize>§eval_steps: Cell<usize>§eval_deadline: Cell<Option<Instant>>

Optional wall-clock deadline for evaluation. When set, both the tree-walker and the bytecode VM periodically check whether the current time has passed this instant and, if so, abort with an error. Used by the notebook engine to bound how long a single cell evaluation can run.

§sandbox: Sandbox§user_context: RefCell<Vec<BTreeMap<Value, Value>>>§hidden_context: RefCell<Vec<BTreeMap<Value, Value>>>§context_stacks: RefCell<BTreeMap<Value, Vec<Value>>>§eval_fn: Cell<Option<EvalCallbackFn>>§call_fn: Cell<Option<CallCallbackFn>>§interactive: Cell<bool>§vm_backend: Cell<bool>

Whether the bytecode VM is the active backend. When true, (load ...) compiles and runs the loaded file’s body on the VM (so async/channels work in loaded files and the code runs at VM speed); when false (the tree-walker, e.g. --tw), the body is tree-walked. Defaults to false so embedders that never set it keep the tree-walker path. NOTE: import is always tree-walked regardless (its module isolation needs lexical env capture the VM does not yet provide — see docs/plans/2026-06-16-vm-module-loading.md).

Implementations§

Source§

impl EvalContext

Source

pub fn new() -> Self

Source

pub fn new_with_sandbox(sandbox: Sandbox) -> Self

Source

pub fn set_vm_backend(&self, on: bool)

Mark whether the bytecode VM is the active backend (see vm_backend).

Source

pub fn vm_backend(&self) -> bool

Whether the bytecode VM is the active backend.

Source

pub fn push_file_path(&self, path: PathBuf)

Source

pub fn pop_file_path(&self)

Source

pub fn current_file_dir(&self) -> Option<PathBuf>

Source

pub fn current_file_path(&self) -> Option<PathBuf>

Source

pub fn get_cached_module( &self, path: &PathBuf, ) -> Option<BTreeMap<String, Value>>

Source

pub fn cache_module(&self, path: PathBuf, exports: BTreeMap<String, Value>)

Source

pub fn set_module_exports(&self, names: Vec<String>)

Source

pub fn clear_module_exports(&self)

Source

pub fn take_module_exports(&self) -> Option<Vec<String>>

Source

pub fn begin_module_load(&self, path: &PathBuf) -> Result<(), SemaError>

Source

pub fn end_module_load(&self, path: &PathBuf)

Source

pub fn push_call_frame(&self, frame: CallFrame)

Source

pub fn call_stack_depth(&self) -> usize

Source

pub fn truncate_call_stack(&self, depth: usize)

Source

pub fn capture_stack_trace(&self) -> StackTrace

Source

pub fn merge_span_table(&self, spans: SpanMap)

Source

pub fn lookup_span(&self, ptr: usize) -> Option<Span>

Source

pub fn set_eval_step_limit(&self, limit: usize)

Source

pub fn set_eval_deadline(&self, deadline: Option<Instant>)

Set a wall-clock deadline after which evaluation should abort. Passing None clears any existing deadline.

Source

pub fn deadline_exceeded(&self) -> bool

Returns true if a deadline is set and has been exceeded.

Source

pub fn check_deadline(&self) -> Result<(), SemaError>

Returns an eval error if a deadline is set and exceeded; otherwise Ok(()).

Source

pub fn context_get(&self, key: &Value) -> Option<Value>

Source

pub fn context_set(&self, key: Value, value: Value)

Source

pub fn context_has(&self, key: &Value) -> bool

Source

pub fn context_remove(&self, key: &Value) -> Option<Value>

Source

pub fn context_all(&self) -> BTreeMap<Value, Value>

Source

pub fn context_push_frame(&self)

Source

pub fn context_push_frame_with(&self, bindings: BTreeMap<Value, Value>)

Source

pub fn context_pop_frame(&self)

Source

pub fn context_clear(&self)

Source

pub fn hidden_get(&self, key: &Value) -> Option<Value>

Source

pub fn hidden_set(&self, key: Value, value: Value)

Source

pub fn hidden_has(&self, key: &Value) -> bool

Source

pub fn hidden_push_frame(&self)

Source

pub fn hidden_pop_frame(&self)

Source

pub fn context_stack_push(&self, key: Value, value: Value)

Source

pub fn context_stack_get(&self, key: &Value) -> Vec<Value>

Source

pub fn context_stack_pop(&self, key: &Value) -> Option<Value>

Trait Implementations§

Source§

impl Default for EvalContext

Source§

fn default() -> Self

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

Auto Trait Implementations§

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