Struct koto_runtime::KotoVmSettings

source ·
pub struct KotoVmSettings {
    pub run_import_tests: bool,
    pub execution_limit: Option<Duration>,
    pub module_imported_callback: Option<Box<dyn ModuleImportedCallback>>,
    pub stdin: Ptr<dyn KotoFile>,
    pub stdout: Ptr<dyn KotoFile>,
    pub stderr: Ptr<dyn KotoFile>,
}
Expand description

The configurable settings that should be used by the Koto runtime

Fields§

§run_import_tests: bool

Whether or not tests should be run when importing modules

§execution_limit: Option<Duration>

An optional duration that limits how long execution is allowed to take.

If the limit is reached without execution ending, then a Timeout error will be returned.

The VM will check against the execution deadline periodically, with an interval of roughly one tenth of the overall limit’s duration.

The check is performed between VM instructions, so external functions will still be able to block execution.

§module_imported_callback: Option<Box<dyn ModuleImportedCallback>>

An optional callback that is called whenever a module is imported by the runtime

This allows you to track the runtime’s dependencies, which might be useful if you want to reload the script when one of its dependencies has changed.

§stdin: Ptr<dyn KotoFile>

The runtime’s stdin

§stdout: Ptr<dyn KotoFile>

The runtime’s stdout

§stderr: Ptr<dyn KotoFile>

The runtime’s stderr

Trait Implementations§

source§

impl Default for KotoVmSettings

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> Downcast for T
where T: Any,

source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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>,

§

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.