pub struct Module { /* private fields */ }
Expand description
The abstract syntax tree for a single Miden Assembly module.
All module kinds share this AST representation, as they are largely identical. However, the ModuleKind dictates how the parsed module is semantically analyzed and validated.
Implementations§
Source§impl Module
Constants
impl Module
Constants
Sourcepub const FILE_EXTENSION: &'static str = "masm"
pub const FILE_EXTENSION: &'static str = "masm"
File extension for a Assembly Module.
Sourcepub const ROOT_FILENAME: &'static str = "mod.masm"
pub const ROOT_FILENAME: &'static str = "mod.masm"
File name of the root module.
Source§impl Module
Construction
impl Module
Construction
Sourcepub fn new(kind: ModuleKind, path: LibraryPath) -> Module
pub fn new(kind: ModuleKind, path: LibraryPath) -> Module
Creates a new Module with the specified kind
and fully-qualified path, e.g.
std::math::u64
.
Sourcepub fn new_kernel() -> Module
pub fn new_kernel() -> Module
An alias for creating the default, but empty, #kernel
Module.
Sourcepub fn new_executable() -> Module
pub fn new_executable() -> Module
An alias for creating the default, but empty, #exec
Module.
Sourcepub fn with_span(self, span: SourceSpan) -> Module
pub fn with_span(self, span: SourceSpan) -> Module
Specifies the source span in the source file in which this module was defined, that covers the full definition of this module.
Sourcepub fn set_path(&mut self, path: LibraryPath)
pub fn set_path(&mut self, path: LibraryPath)
Sets the LibraryPath for this module
Sourcepub fn set_namespace(&mut self, ns: LibraryNamespace)
pub fn set_namespace(&mut self, ns: LibraryNamespace)
Sets the LibraryNamespace for this module
Sourcepub fn set_span(&mut self, span: SourceSpan)
pub fn set_span(&mut self, span: SourceSpan)
Like Module::with_span, but does not require ownership of the Module.
Sourcepub fn define_procedure(
&mut self,
export: Export,
) -> Result<(), SemanticAnalysisError>
pub fn define_procedure( &mut self, export: Export, ) -> Result<(), SemanticAnalysisError>
Defines a procedure, raising an error if the procedure is invalid, or conflicts with a previous definition
Sourcepub fn define_import(
&mut self,
import: Import,
) -> Result<(), SemanticAnalysisError>
pub fn define_import( &mut self, import: Import, ) -> Result<(), SemanticAnalysisError>
Defines an import, raising an error if the import is invalid, or conflicts with a previous definition.
Source§impl Module
Parsing
impl Module
Parsing
Sourcepub fn parse(
name: LibraryPath,
kind: ModuleKind,
source_file: Arc<SourceFile>,
) -> Result<Box<Module>, Report>
pub fn parse( name: LibraryPath, kind: ModuleKind, source_file: Arc<SourceFile>, ) -> Result<Box<Module>, Report>
Parse a Module, name
, of the given ModuleKind, from source_file
.
Sourcepub fn parser(kind: ModuleKind) -> ModuleParser
pub fn parser(kind: ModuleKind) -> ModuleParser
Get a ModuleParser for parsing modules of the provided ModuleKind
Source§impl Module
Metadata
impl Module
Metadata
Sourcepub fn name(&self) -> &str
pub fn name(&self) -> &str
Get the name of this specific module, i.e. the last component of the LibraryPath that
represents the fully-qualified name of the module, e.g. u64
in std::math::u64
Sourcepub fn path(&self) -> &LibraryPath
pub fn path(&self) -> &LibraryPath
Get the fully-qualified name of this module, e.g. std::math::u64
Sourcepub fn namespace(&self) -> &LibraryNamespace
pub fn namespace(&self) -> &LibraryNamespace
Get the namespace of this module, e.g. std
in std::math::u64
Sourcepub fn is_in_namespace(&self, namespace: &LibraryNamespace) -> bool
pub fn is_in_namespace(&self, namespace: &LibraryNamespace) -> bool
Returns true if this module belongs to the provided namespace.
Sourcepub fn docs(&self) -> Option<Span<&str>>
pub fn docs(&self) -> Option<Span<&str>>
Get the module documentation for this module, if it was present in the source code the module was parsed from
Sourcepub fn kind(&self) -> ModuleKind
pub fn kind(&self) -> ModuleKind
Get the type of module this represents:
See ModuleKind for details on the different types of modules.
Sourcepub fn is_executable(&self) -> bool
pub fn is_executable(&self) -> bool
Returns true if this module is an executable module.
Sourcepub fn has_entrypoint(&self) -> bool
pub fn has_entrypoint(&self) -> bool
Returns true if this module has an entrypoint procedure defined,
i.e. a begin
..end
block.
Sourcepub fn procedures(&self) -> Iter<'_, Export> ⓘ
pub fn procedures(&self) -> Iter<'_, Export> ⓘ
Get an iterator over the procedures defined in this module.
The entity returned is an Export, which abstracts over locally-defined procedures and re-exported procedures from imported modules.
Sourcepub fn procedures_mut(&mut self) -> IterMut<'_, Export> ⓘ
pub fn procedures_mut(&mut self) -> IterMut<'_, Export> ⓘ
Same as Module::procedures, but returns mutable references.
Sourcepub fn exported_procedures(
&self,
) -> impl Iterator<Item = (ProcedureIndex, QualifiedProcedureName)>
pub fn exported_procedures( &self, ) -> impl Iterator<Item = (ProcedureIndex, QualifiedProcedureName)>
Returns procedures exported from this module.
Each exported procedure is represented by its local procedure index and a fully qualified name.
Sourcepub fn imports(&self) -> Iter<'_, Import> ⓘ
pub fn imports(&self) -> Iter<'_, Import> ⓘ
Get an iterator over the imports declared in this module.
See Import for details on what information is available for imports.
Sourcepub fn imports_mut(&mut self) -> IterMut<'_, Import> ⓘ
pub fn imports_mut(&mut self) -> IterMut<'_, Import> ⓘ
Same as Self::imports, but returns mutable references to each import.
Sourcepub fn dependencies(&self) -> impl Iterator<Item = &LibraryNamespace>
pub fn dependencies(&self) -> impl Iterator<Item = &LibraryNamespace>
Get an iterator over the “dependencies” of a module, i.e. what library namespaces we expect to find imported procedures in.
For example, if we have imported std::math::u64
, then we would expect to find a library
on disk named std.masl
, although that isn’t a strict requirement. This notion of
dependencies may go away with future packaging-related changed.
Sourcepub fn get(&self, index: ProcedureIndex) -> Option<&Export>
pub fn get(&self, index: ProcedureIndex) -> Option<&Export>
Get the procedure at index
in this module’s procedure table.
The procedure returned may be either a locally-defined procedure, or a re-exported procedure. See Export for details.
Sourcepub fn index_of<F>(&self, predicate: F) -> Option<ProcedureIndex>
pub fn index_of<F>(&self, predicate: F) -> Option<ProcedureIndex>
Get the ProcedureIndex for the first procedure in this module’s procedure table which
returns true for predicate
.
Sourcepub fn index_of_name(&self, name: &ProcedureName) -> Option<ProcedureIndex>
pub fn index_of_name(&self, name: &ProcedureName) -> Option<ProcedureIndex>
Get the ProcedureIndex for the procedure whose name is name
in this module’s procedure
table, if that procedure is exported.
Non-exported procedures can be retrieved by using Module::index_of.
Sourcepub fn resolve(&self, name: &ProcedureName) -> Option<ResolvedProcedure>
pub fn resolve(&self, name: &ProcedureName) -> Option<ResolvedProcedure>
Resolves name
to a procedure within the local scope of this module
Sourcepub fn resolver(&self) -> LocalNameResolver
pub fn resolver(&self) -> LocalNameResolver
Construct a search structure that can resolve procedure names local to this module
Sourcepub fn resolve_import(&self, module_name: &Ident) -> Option<&Import>
pub fn resolve_import(&self, module_name: &Ident) -> Option<&Import>
Resolves module_name
to an Import within the context of this module
Sourcepub fn resolve_import_mut(&mut self, module_name: &Ident) -> Option<&mut Import>
pub fn resolve_import_mut(&mut self, module_name: &Ident) -> Option<&mut Import>
Same as Module::resolve_import, but returns a mutable reference to the Import
Sourcepub fn import_paths(&self) -> impl Iterator<Item = &LibraryPath>
pub fn import_paths(&self) -> impl Iterator<Item = &LibraryPath>
Return an iterator over the paths of all imports in this module
Trait Implementations§
Source§impl Compile for &Module
impl Compile for &Module
Source§fn compile_with_options(
self,
source_manager: &dyn SourceManager,
options: Options,
) -> Result<Box<Module>, Report>
fn compile_with_options( self, source_manager: &dyn SourceManager, options: Options, ) -> Result<Box<Module>, Report>
Source§impl Compile for Box<Module>
impl Compile for Box<Module>
Source§fn compile_with_options(
self,
_source_manager: &dyn SourceManager,
options: Options,
) -> Result<Box<Module>, Report>
fn compile_with_options( self, _source_manager: &dyn SourceManager, options: Options, ) -> Result<Box<Module>, Report>
Source§impl Compile for Module
impl Compile for Module
Source§fn compile_with_options(
self,
source_manager: &dyn SourceManager,
options: Options,
) -> Result<Box<Module>, Report>
fn compile_with_options( self, source_manager: &dyn SourceManager, options: Options, ) -> Result<Box<Module>, Report>
Source§impl Display for Module
Pretty-printed representation of this module as Miden Assembly text format
impl Display for Module
Pretty-printed representation of this module as Miden Assembly text format
NOTE: Delegates to the crate::prettier::PrettyPrint implementation internally
Source§impl Index<ProcedureIndex> for Module
impl Index<ProcedureIndex> for Module
Source§impl IndexMut<ProcedureIndex> for Module
impl IndexMut<ProcedureIndex> for Module
Source§fn index_mut(
&mut self,
index: ProcedureIndex,
) -> &mut <Module as Index<ProcedureIndex>>::Output
fn index_mut( &mut self, index: ProcedureIndex, ) -> &mut <Module as Index<ProcedureIndex>>::Output
container[index]
) operation. Read moreSource§impl PrettyPrint for Module
The pretty-printer for Module
impl PrettyPrint for Module
The pretty-printer for Module
Source§fn to_pretty_string(&self) -> String
fn to_pretty_string(&self) -> String
Source§fn pretty_print(&self, f: &mut Formatter<'_>) -> Result<(), Error>
fn pretty_print(&self, f: &mut Formatter<'_>) -> Result<(), Error>
impl Eq for Module
Auto Trait Implementations§
impl Freeze for Module
impl RefUnwindSafe for Module
impl Send for Module
impl Sync for Module
impl Unpin for Module
impl UnwindSafe for Module
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<D> OwoColorize for D
impl<D> OwoColorize for D
Source§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
Source§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
Source§fn black(&self) -> FgColorDisplay<'_, Black, Self>
fn black(&self) -> FgColorDisplay<'_, Black, Self>
Source§fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
Source§fn red(&self) -> FgColorDisplay<'_, Red, Self>
fn red(&self) -> FgColorDisplay<'_, Red, Self>
Source§fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
Source§fn green(&self) -> FgColorDisplay<'_, Green, Self>
fn green(&self) -> FgColorDisplay<'_, Green, Self>
Source§fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
Source§fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
Source§fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
Source§fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
Source§fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
Source§fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
Source§fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
Source§fn white(&self) -> FgColorDisplay<'_, White, Self>
fn white(&self) -> FgColorDisplay<'_, White, Self>
Source§fn on_white(&self) -> BgColorDisplay<'_, White, Self>
fn on_white(&self) -> BgColorDisplay<'_, White, Self>
Source§fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
Source§fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
Source§fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
Source§fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
Source§fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
Source§fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
Source§fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
Source§fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
Source§fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
Source§fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
Source§fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
Source§fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
Source§fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
Source§fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
Source§fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
Source§fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
Source§fn bold(&self) -> BoldDisplay<'_, Self>
fn bold(&self) -> BoldDisplay<'_, Self>
Source§fn dimmed(&self) -> DimDisplay<'_, Self>
fn dimmed(&self) -> DimDisplay<'_, Self>
Source§fn italic(&self) -> ItalicDisplay<'_, Self>
fn italic(&self) -> ItalicDisplay<'_, Self>
Source§fn underline(&self) -> UnderlineDisplay<'_, Self>
fn underline(&self) -> UnderlineDisplay<'_, Self>
Source§fn blink(&self) -> BlinkDisplay<'_, Self>
fn blink(&self) -> BlinkDisplay<'_, Self>
Source§fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
Source§fn reversed(&self) -> ReversedDisplay<'_, Self>
fn reversed(&self) -> ReversedDisplay<'_, Self>
Source§fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
Source§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg
or
a color-specific method, such as OwoColorize::green
, Read moreSource§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg
or
a color-specific method, such as OwoColorize::on_yellow
, Read more