Context

Struct Context 

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

Context for evaluation of a resolved µcad file.

The context is used to store the current state of the evaluation.

A context consists of the following members:

  • A symbol table (SymbolTable) with symbols stored by QualifiedName and a Stack.
  • A diagnostic handler (DiagHandler) that accumulates evaluation errors for later output.
  • One output channel (Output) where __builtin::print writes it’s output to while evaluation.

All these internal structures can be accessed by several implemented traits.

Implementations§

Source§

impl Context

Source

pub fn new( root: Identifier, symbols: SymbolMap, sources: Sources, output: Box<dyn Output>, ) -> Self

Create a new context from a source file.

§Arguments
  • root: Root symbol.
  • builtin: The builtin library.
  • search_paths: Paths to search for external libraries (e.g. the standard library).
  • output: Output channel to use.
Source

pub fn current_symbol(&self) -> Symbol

Current symbol, panics if there no current symbol.

Source

pub fn from_source( root: impl AsRef<Path> + Debug, builtin: Symbol, search_paths: &[PathBuf], ) -> EvalResult<Self>

Create a new context from a source file.

§Arguments
  • root: Path to the root file to load.
  • builtin: The builtin library.
  • search_paths: Paths to search for external libraries (e.g. the standard library).
Source

pub fn output(&self) -> Option<String>

Access captured output.

Source

pub fn print(&mut self, what: String)

Print for __builtin::print.

Source

pub fn locate(&self, referrer: &impl SrcReferrer) -> EvalResult<String>

Get the source code location of the given referrer as string (e.g. /path/to/file.µcad:52:1).

Source

pub fn source_code(&self, referrer: &impl SrcReferrer) -> EvalResult<String>

Get the original source code of the given referrer.

Source

pub fn eval(&mut self) -> EvalResult<Model>

Evaluate context into a value.

Source

pub fn root(&self) -> &Symbol

Peek into root node for testing.

Source

pub fn scope<T>( &mut self, stack_frame: StackFrame, f: impl FnOnce(&mut Context) -> T, ) -> T

Run the closure f within the given stack_frame.

Source

pub fn set_importers(&mut self, importers: ImporterRegistry)

Set importers.

Source

pub fn exporters(&self) -> &ExporterRegistry

All registered exporters.

Source

pub fn set_exporters(&mut self, exporters: ExporterRegistry)

Set exporters.

Source

pub fn search_paths(&self) -> &Vec<PathBuf>

Return search paths of this context.

Source

pub fn get_property(&self, id: &Identifier) -> EvalResult<Value>

Get property from current model.

Source

pub fn init_property(&self, id: Identifier, value: Value) -> EvalResult<()>

Initialize a property.

Returns error if there is no model or the property has been initialized before.

Source

pub fn is_init(&mut self) -> bool

Return if the current frame is an init frame.

Source§

impl Context

Source

pub fn use_symbol( &mut self, visibility: Visibility, name: &QualifiedName, id: Option<Identifier>, ) -> EvalResult<Symbol>

use symbol in context

Source

pub fn use_symbols_of( &mut self, visibility: Visibility, name: &QualifiedName, ) -> EvalResult<Symbol>

use all symbols of given module in context

Trait Implementations§

Source§

impl Default for Context

Source§

fn default() -> Self

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

impl Diag for Context

Source§

fn fmt_diagnosis(&self, f: &mut dyn Write) -> Result

Pretty print all errors.
Source§

fn error_count(&self) -> u32

Return number of occurred errors.
Source§

fn error_lines(&self) -> HashSet<usize>

Return all lines with errors
Source§

fn warning_lines(&self) -> HashSet<usize>

Return all lines with warnings
Source§

fn write_diagnosis(&self, w: &mut dyn Write) -> Result<()>

Pretty write all errors into a file.
Source§

fn diagnosis(&self) -> String

Get pretty printed errors as string.
Source§

fn has_errors(&self) -> bool

Returns true if there are errors.
Source§

impl Display for Context

Source§

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

Formats the value using the given formatter. Read more
Source§

impl ExporterAccess for Context

Source§

fn exporter_by_id(&self, id: &Id) -> Result<Rc<dyn Exporter>, ExportError>

Get exporter by id.
Source§

fn exporter_by_filename( &self, filename: &Path, ) -> Result<Rc<dyn Exporter>, ExportError>

Get exporter by filename.
Source§

fn find_exporter( &self, filename: &Path, id: &Option<Id>, ) -> Result<Rc<dyn Exporter>, ExportError>

Find an exporter by filename, or by id.
Source§

impl GetSourceByHash for Context

Source§

fn get_by_hash(&self, hash: u64) -> ResolveResult<Rc<SourceFile>>

Find a project file by it’s hash value.
Source§

impl Grant<AssignmentStatement> for Context

Source§

fn grant(&mut self, statement: &AssignmentStatement) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<Attribute> for Context

Source§

fn grant(&mut self, statement: &Attribute) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<ExpressionStatement> for Context

Source§

fn grant(&mut self, statement: &ExpressionStatement) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<FunctionDefinition> for Context

Source§

fn grant(&mut self, statement: &FunctionDefinition) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<IfStatement> for Context

Source§

fn grant(&mut self, statement: &IfStatement) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<InitDefinition> for Context

Source§

fn grant(&mut self, statement: &InitDefinition) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<Marker> for Context

Source§

fn grant(&mut self, statement: &Marker) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<ModuleDefinition> for Context

Source§

fn grant(&mut self, statement: &ModuleDefinition) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<ReturnStatement> for Context

Source§

fn grant(&mut self, statement: &ReturnStatement) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<UseStatement> for Context

Source§

fn grant(&mut self, statement: &UseStatement) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl Grant<WorkbenchDefinition> for Context

Source§

fn grant(&mut self, statement: &WorkbenchDefinition) -> EvalResult<()>

Check if given statement T is granted within the current context
Source§

impl ImporterRegistryAccess for Context

Source§

type Error = EvalError

Error type.
Source§

fn import( &mut self, arg_map: &Tuple, search_paths: &[PathBuf], ) -> Result<Value, Self::Error>

Import a value from an argument map
Source§

impl Locals for Context

Source§

fn set_local_value(&mut self, id: Identifier, value: Value) -> EvalResult<()>

Set/add a named local value to current locals.
Source§

fn get_local_value(&self, id: &Identifier) -> EvalResult<Value>

Get a named local value from locals.
Source§

fn open(&mut self, frame: StackFrame)

Don’t use this function directly.
Source§

fn close(&mut self)

Close scope (stack pop).
Source§

fn fetch(&self, id: &Identifier) -> EvalResult<Symbol>

Fetch a local variable from current stack frame.
Source§

fn get_model(&self) -> EvalResult<Model>

Get a property value from current model.
Source§

fn current_name(&self) -> QualifiedName

Return qualified name of current module or workbench.
Source§

impl Lookup for Context

Source§

fn lookup(&mut self, name: &QualifiedName) -> EvalResult<Symbol>

Lookup for local or global symbol by qualified name. Read more
Source§

impl PushDiag for Context

Source§

fn push_diag(&mut self, diag: Diagnostic) -> EvalResult<()>

Push a diagnostic message (must be implemented).
Source§

fn trace(&mut self, src: &impl SrcReferrer, message: String)

Push new trace message.
Source§

fn info(&mut self, src: &impl SrcReferrer, message: String)

Push new informative message.
Source§

fn warning( &mut self, src: &impl SrcReferrer, error: impl Error + 'static, ) -> EvalResult<()>

Push new warning.
Source§

fn error( &mut self, src: &impl SrcReferrer, error: impl Error + 'static, ) -> EvalResult<()>

Push new error.

Auto Trait Implementations§

§

impl Freeze for Context

§

impl !RefUnwindSafe for Context

§

impl !Send for Context

§

impl !Sync for Context

§

impl Unpin for Context

§

impl !UnwindSafe for Context

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> 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> 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> ToCompactString for T
where T: Display,

Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.
Source§

impl<G1, G2> Within<G2> for G1
where G2: Contains<G1>,

Source§

fn is_within(&self, b: &G2) -> bool