EvalContext

Struct EvalContext 

Source
pub struct EvalContext { /* private fields */ }
Expand description

Evaluation context for a REPL session

Manages session state, execution tiers, and caching.

§Architecture

Uses Arc<Mutex<>> for components that need shared mutable state:

  • ArtifactCache: Shared persistent cache across clones
  • CachedCompiler: Shared compilation state
  • SubprocessExecutor: Single subprocess per session (not cloned)
  • SessionDir: Shared session directory

Implementations§

Source§

impl EvalContext

Source

pub fn new(session_id: SessionId, mode: ReplMode) -> Self

Create a new evaluation context

§Examples
use oxur_repl::eval::EvalContext;
use oxur_repl::protocol::{ReplMode, SessionId};

let ctx = EvalContext::new(SessionId::new("session-1"), ReplMode::Lisp);
Source

pub fn with_compilation(session_id: SessionId, mode: ReplMode) -> Result<Self>

Create a new evaluation context with full compilation pipeline

Initializes all Tier 2/3 components for actual compilation and execution.

§Errors

Returns error if:

  • Session directory cannot be created
  • Artifact cache cannot be initialized
  • Subprocess cannot be spawned
Source

pub fn session_id(&self) -> &SessionId

Get the session ID

Source

pub fn mode(&self) -> ReplMode

Get the evaluation mode

Source

pub fn stats(&self) -> (u64, u64, u64)

Get execution statistics (legacy method for backward compatibility)

Returns (tier1_count, tier2_count, cache_hits) Note: tier2_count includes both CachedLoaded and JustInTime tiers for backward compatibility

Source

pub fn stats_collector(&self) -> Arc<Mutex<EvalMetrics>>

Get the statistics collector

Returns a shared reference to the stats collector for detailed metrics access.

Source

pub fn usage_metrics(&self) -> Arc<Mutex<UsageMetrics>>

Get the usage metrics collector

Returns a shared reference to the usage metrics collector for command frequency tracking.

Source

pub fn clone_to(&self, new_session_id: SessionId) -> Self

Clone this context into a new session

Creates a new context with a different session ID but the same cache and state. Resets execution statistics.

Note: Shared components (Arc<Mutex<>>) are cloned (reference counted), so they share state across clones.

Source

pub async fn eval(&mut self, code: impl AsRef<str>) -> Result<EvalResult>

Evaluate code in this context

Uses tiered execution strategy:

  • Tier 1 (Calculator): Simple arithmetic literals only
  • Tier 2 (Cached Compilation): Everything else
  • Hybrid: Calculator variables accessible in compiled code
§Errors

Returns EvalError if evaluation fails due to:

  • SyntaxError: Invalid syntax in the input code
  • TypeError: Type mismatch or invalid type operations
  • RuntimeError: Runtime errors during execution
  • CompilationError: Failed to compile to executable code
  • UnsupportedOperation: Operation not supported in current tier
Source

pub fn clear_cache(&mut self)

Clear the compilation cache

Source

pub fn cache_size(&self) -> usize

Get cache size

Source

pub fn session_dir_stats(&self) -> Option<DirStats>

Get session directory statistics

Returns information about files and disk usage in the session’s temporary directory. Returns None if the session directory is not initialized.

Source

pub fn artifact_cache_stats(&self) -> Option<CacheStats>

Get artifact cache statistics

Returns detailed statistics about the global artifact cache including entry count, total size, and oldest/newest entries. Returns None if artifact cache is not initialized.

Source

pub fn subprocess_stats(&self) -> Option<SubprocessMetricsSnapshot>

Get subprocess metrics snapshot.

Returns metrics about the subprocess executor including restart count, uptime, and last restart reason.

Source

pub fn infer_types(&self, code: impl AsRef<str>) -> Vec<(String, String, bool)>

Infer types from Rust code

Parses the provided Rust code and extracts type information for all variable declarations. This can be used to implement the :type REPL command.

§Arguments
  • code - Rust source code to analyze
§Returns

Vector of (variable_name, type_info) pairs

§Examples
use oxur_repl::eval::EvalContext;
use oxur_repl::protocol::{ReplMode, SessionId};

let ctx = EvalContext::new(SessionId::new("test"), ReplMode::Lisp);

let code = r#"
    fn main() {
        let x: i32 = 42;
        let y = "hello";
    }
"#;

let types = ctx.infer_types(code);
assert_eq!(types.len(), 2);
Source

pub fn register_variable_type( &mut self, name: impl Into<String>, type_name: impl Into<String>, is_mutable: bool, )

Register a variable’s type information

Manually register type information for a variable. This is useful for tracking types across REPL evaluations.

§Arguments
  • name - Variable name
  • type_name - Type as a string (e.g., “i32”, “String”)
  • is_mutable - Whether the variable is mutable
§Examples
use oxur_repl::eval::EvalContext;
use oxur_repl::protocol::{ReplMode, SessionId};

let mut ctx = EvalContext::new(SessionId::new("test"), ReplMode::Lisp);
ctx.register_variable_type("x", "i32", false);

let type_name = ctx.get_variable_type("x");
assert_eq!(type_name, Some("i32".to_string()));
Source

pub fn get_variable_type(&self, name: impl AsRef<str>) -> Option<String>

Get the type of a variable

Returns the type name for a previously registered variable.

§Arguments
  • name - Variable name
§Returns

Some(type_name) if variable is tracked, None otherwise

§Examples
use oxur_repl::eval::EvalContext;
use oxur_repl::protocol::{ReplMode, SessionId};

let mut ctx = EvalContext::new(SessionId::new("test"), ReplMode::Lisp);
ctx.register_variable_type("x", "i32", false);

assert_eq!(ctx.get_variable_type("x"), Some("i32".to_string()));
assert_eq!(ctx.get_variable_type("y"), None);
Source

pub fn get_all_variable_types(&self) -> Vec<(String, String, bool)>

Get all tracked variables with their types

Returns a list of all variables currently tracked by the type inference engine along with their type information.

§Returns

Vector of (variable_name, type_name, is_mutable) tuples

§Examples
use oxur_repl::eval::EvalContext;
use oxur_repl::protocol::{ReplMode, SessionId};

let mut ctx = EvalContext::new(SessionId::new("test"), ReplMode::Lisp);
ctx.register_variable_type("x", "i32", false);
ctx.register_variable_type("y", "String", true);

let vars = ctx.get_all_variable_types();
assert_eq!(vars.len(), 2);
Source

pub fn clear_type_information(&mut self)

Clear all tracked type information

Removes all tracked variable types from the type inference engine. Useful when starting a new REPL session or resetting state.

§Examples
use oxur_repl::eval::EvalContext;
use oxur_repl::protocol::{ReplMode, SessionId};

let mut ctx = EvalContext::new(SessionId::new("test"), ReplMode::Lisp);
ctx.register_variable_type("x", "i32", false);
assert_eq!(ctx.get_all_variable_types().len(), 1);

ctx.clear_type_information();
assert_eq!(ctx.get_all_variable_types().len(), 0);

Trait Implementations§

Source§

impl Clone for EvalContext

Source§

fn clone(&self) -> EvalContext

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 Debug for EvalContext

Source§

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

Formats the value using the given formatter. 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> 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
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> Paint for T
where T: ?Sized,

Source§

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 primary(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Primary].

§Example
println!("{}", value.primary());
Source§

fn fixed(&self, color: u8) -> Painted<&T>

Returns self with the fg() set to [Color :: Fixed].

§Example
println!("{}", value.fixed(color));
Source§

fn rgb(&self, r: u8, g: u8, b: u8) -> Painted<&T>

Returns self with the fg() set to [Color :: Rgb].

§Example
println!("{}", value.rgb(r, g, b));
Source§

fn black(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Black].

§Example
println!("{}", value.black());
Source§

fn red(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Red].

§Example
println!("{}", value.red());
Source§

fn green(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Green].

§Example
println!("{}", value.green());
Source§

fn yellow(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Yellow].

§Example
println!("{}", value.yellow());
Source§

fn blue(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Blue].

§Example
println!("{}", value.blue());
Source§

fn magenta(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Magenta].

§Example
println!("{}", value.magenta());
Source§

fn cyan(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: Cyan].

§Example
println!("{}", value.cyan());
Source§

fn white(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: White].

§Example
println!("{}", value.white());
Source§

fn bright_black(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightBlack].

§Example
println!("{}", value.bright_black());
Source§

fn bright_red(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightRed].

§Example
println!("{}", value.bright_red());
Source§

fn bright_green(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightGreen].

§Example
println!("{}", value.bright_green());
Source§

fn bright_yellow(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightYellow].

§Example
println!("{}", value.bright_yellow());
Source§

fn bright_blue(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightBlue].

§Example
println!("{}", value.bright_blue());
Source§

fn bright_magenta(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightMagenta].

§Example
println!("{}", value.bright_magenta());
Source§

fn bright_cyan(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightCyan].

§Example
println!("{}", value.bright_cyan());
Source§

fn bright_white(&self) -> Painted<&T>

Returns self with the fg() set to [Color :: BrightWhite].

§Example
println!("{}", value.bright_white());
Source§

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>

Returns self with the bg() set to [Color :: Primary].

§Example
println!("{}", value.on_primary());
Source§

fn on_fixed(&self, color: u8) -> Painted<&T>

Returns self with the bg() set to [Color :: Fixed].

§Example
println!("{}", value.on_fixed(color));
Source§

fn on_rgb(&self, r: u8, g: u8, b: u8) -> Painted<&T>

Returns self with the bg() set to [Color :: Rgb].

§Example
println!("{}", value.on_rgb(r, g, b));
Source§

fn on_black(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Black].

§Example
println!("{}", value.on_black());
Source§

fn on_red(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Red].

§Example
println!("{}", value.on_red());
Source§

fn on_green(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Green].

§Example
println!("{}", value.on_green());
Source§

fn on_yellow(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Yellow].

§Example
println!("{}", value.on_yellow());
Source§

fn on_blue(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Blue].

§Example
println!("{}", value.on_blue());
Source§

fn on_magenta(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Magenta].

§Example
println!("{}", value.on_magenta());
Source§

fn on_cyan(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: Cyan].

§Example
println!("{}", value.on_cyan());
Source§

fn on_white(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: White].

§Example
println!("{}", value.on_white());
Source§

fn on_bright_black(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightBlack].

§Example
println!("{}", value.on_bright_black());
Source§

fn on_bright_red(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightRed].

§Example
println!("{}", value.on_bright_red());
Source§

fn on_bright_green(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightGreen].

§Example
println!("{}", value.on_bright_green());
Source§

fn on_bright_yellow(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightYellow].

§Example
println!("{}", value.on_bright_yellow());
Source§

fn on_bright_blue(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightBlue].

§Example
println!("{}", value.on_bright_blue());
Source§

fn on_bright_magenta(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightMagenta].

§Example
println!("{}", value.on_bright_magenta());
Source§

fn on_bright_cyan(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightCyan].

§Example
println!("{}", value.on_bright_cyan());
Source§

fn on_bright_white(&self) -> Painted<&T>

Returns self with the bg() set to [Color :: BrightWhite].

§Example
println!("{}", value.on_bright_white());
Source§

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 bold(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Bold].

§Example
println!("{}", value.bold());
Source§

fn dim(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Dim].

§Example
println!("{}", value.dim());
Source§

fn italic(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Italic].

§Example
println!("{}", value.italic());
Source§

fn underline(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Underline].

§Example
println!("{}", value.underline());

Returns self with the attr() set to [Attribute :: Blink].

§Example
println!("{}", value.blink());

Returns self with the attr() set to [Attribute :: RapidBlink].

§Example
println!("{}", value.rapid_blink());
Source§

fn invert(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Invert].

§Example
println!("{}", value.invert());
Source§

fn conceal(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Conceal].

§Example
println!("{}", value.conceal());
Source§

fn strike(&self) -> Painted<&T>

Returns self with the attr() set to [Attribute :: Strike].

§Example
println!("{}", value.strike());
Source§

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 mask(&self) -> Painted<&T>

Returns self with the quirk() set to [Quirk :: Mask].

§Example
println!("{}", value.mask());
Source§

fn wrap(&self) -> Painted<&T>

Returns self with the quirk() set to [Quirk :: Wrap].

§Example
println!("{}", value.wrap());
Source§

fn linger(&self) -> Painted<&T>

Returns self with the quirk() set to [Quirk :: Linger].

§Example
println!("{}", value.linger());
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.

Returns self with the quirk() set to [Quirk :: Clear].

§Example
println!("{}", value.clear());
Source§

fn resetting(&self) -> Painted<&T>

Returns self with the quirk() set to [Quirk :: Resetting].

§Example
println!("{}", value.resetting());
Source§

fn bright(&self) -> Painted<&T>

Returns self with the quirk() set to [Quirk :: Bright].

§Example
println!("{}", value.bright());
Source§

fn on_bright(&self) -> Painted<&T>

Returns self with the quirk() set to [Quirk :: OnBright].

§Example
println!("{}", value.on_bright());
Source§

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

fn new(self) -> Painted<Self>
where Self: Sized,

Create a new Painted with a default Style. Read more
Source§

fn paint<S>(&self, style: S) -> Painted<&Self>
where S: Into<Style>,

Apply a style wholesale to self. Any previous style is replaced. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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, 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.