diff --git a/assembly/src/assembler/context.rs b/assembly/src/assembler/context.rs index 4c119d4104..2f3452bc72 100644 --- a/assembly/src/assembler/context.rs +++ b/assembly/src/assembler/context.rs @@ -432,18 +432,7 @@ impl ModuleContext { /// This also updates module callset to include the callset of the newly compiled procedure. pub fn complete_proc(&mut self, code: CodeBlock) { let proc_context = self.proc_stack.pop().expect("no procedures"); - - // build an ID for the procedure as follows: - // - for exported procedures: hash("module_path::proc_name") - // - for internal procedures: hash("module_path::proc_index") - let proc_id = if proc_context.is_export { - ProcedureId::from_name(&proc_context.name, &self.path) - } else { - let proc_idx = self.compiled_procs.len() as u16; - ProcedureId::from_index(proc_idx, &self.path) - }; - - let proc = proc_context.into_procedure(proc_id, code); + let proc = proc_context.into_procedure(code); self.callset.append(proc.callset()); self.compiled_procs.push(proc); } @@ -560,7 +549,7 @@ impl ProcedureContext { &self.name } - pub fn into_procedure(self, id: ProcedureId, code_root: CodeBlock) -> NamedProcedure { + pub fn into_procedure(self, code_root: CodeBlock) -> NamedProcedure { let Self { name, is_export, @@ -568,6 +557,6 @@ impl ProcedureContext { callset, } = self; - NamedProcedure::new(id, name, is_export, num_locals as u32, code_root, callset) + NamedProcedure::new(name, is_export, num_locals as u32, code_root, callset) } } diff --git a/assembly/src/assembler/mod.rs b/assembly/src/assembler/mod.rs index 68ca9ffae0..8dbd584fb0 100644 --- a/assembly/src/assembler/mod.rs +++ b/assembly/src/assembler/mod.rs @@ -90,7 +90,7 @@ impl Assembler { // compile the kernel; this adds all exported kernel procedures to the procedure cache let mut context = AssemblyContext::for_module(true); let kernel = Module::kernel(module); - self.compile_module(&kernel, &mut context)?; + self.compile_module(&kernel.ast, Some(&kernel.path), &mut context)?; // convert the context into Kernel; this builds the kernel from hashes of procedures // exported form the kernel module @@ -186,38 +186,48 @@ impl Assembler { /// - If a lock to the [ProcedureCache] can not be attained. pub fn compile_module( &self, - module: &Module, + module: &ModuleAst, + path: Option<&LibraryPath>, context: &mut AssemblyContext, ) -> Result, AssemblyError> { // a variable to track MAST roots of all procedures exported from this module let mut proc_roots = Vec::new(); - context.begin_module(&module.path, &module.ast)?; + context.begin_module(path.unwrap_or(&LibraryPath::anon_path()), module)?; // process all re-exported procedures - for reexporteed_proc in module.ast.reexported_procs().iter() { + for reexporteed_proc in module.reexported_procs().iter() { // make sure the re-exported procedure is loaded into the procedure cache let ref_proc_id = reexporteed_proc.proc_id(); self.ensure_procedure_is_in_cache(&ref_proc_id, context).map_err(|_| { AssemblyError::ReExportedProcModuleNotFound(reexporteed_proc.clone()) })?; - // build procedure ID for the alias, and add it to the procedure cache - let proc_name = reexporteed_proc.name(); - let alias_proc_id = ProcedureId::from_name(proc_name, &module.path); - let proc_mast_root = self - .proc_cache - .try_borrow_mut() - .map_err(|_| AssemblyError::InvalidCacheLock)? - .insert_proc_alias(alias_proc_id, ref_proc_id)?; + // if the library path is provided, build procedure ID for the alias and add it to the + // procedure cache + let proc_mast_root = if let Some(path) = path { + let proc_name = reexporteed_proc.name(); + let alias_proc_id = ProcedureId::from_name(proc_name, path); + self.proc_cache + .try_borrow_mut() + .map_err(|_| AssemblyError::InvalidCacheLock)? + .insert_proc_alias(alias_proc_id, ref_proc_id)? + } else { + self.proc_cache + .try_borrow_mut() + .map_err(|_| AssemblyError::InvalidCacheLock)? + .get_proc_root_by_id(&ref_proc_id) + .expect("procedure ID not in cache") + }; // add the MAST root of the re-exported procedure to the set of procedures exported // from this module proc_roots.push(proc_mast_root); } - // compile all local procedures in the module; once the compilation is complete, we get - // all compiled procedures (and their combined callset) from the context - for proc_ast in module.ast.procs().iter() { + // compile all local (internal end exported) procedures in the module; once the compilation + // is complete, we get all compiled procedures (and their combined callset) from the + // context + for proc_ast in module.procs().iter() { self.compile_procedure(proc_ast, context)?; } let (module_procs, module_callset) = context.complete_module(); @@ -227,17 +237,20 @@ impl Assembler { // - a procedure is exported from the module, or // - a procedure is present in the combined callset - i.e., it is an internal procedure // which has been invoked via a local call instruction. - for proc in module_procs.into_iter() { + for (proc_index, proc) in module_procs.into_iter().enumerate() { if proc.is_export() { proc_roots.push(proc.mast_root()); } if proc.is_export() || module_callset.contains(&proc.mast_root()) { + // build the procedure ID if this module has the library path + let proc_id = build_procedure_id(path, &proc, proc_index); + // this is safe because we fail if the cache is borrowed. self.proc_cache .try_borrow_mut() .map_err(|_| AssemblyError::InvalidCacheLock)? - .insert(proc)?; + .insert(proc, proc_id)?; } } @@ -372,7 +385,7 @@ impl Assembler { let proc_name = context.get_imported_procedure_name(proc_id); AssemblyError::imported_proc_module_not_found(proc_id, proc_name) })?; - self.compile_module(module, context)?; + self.compile_module(&module.ast, Some(&module.path), context)?; // if the procedure is still not in cache, then there was some error if !self.proc_cache.borrow().contains_id(proc_id) { return Err(AssemblyError::imported_proc_not_found_in_module( @@ -480,3 +493,22 @@ fn combine_spans(spans: &mut Vec) -> CodeBlock { }); CodeBlock::new_span_with_decorators(ops, decorators) } + +/// Builds a procedure ID based on the provided parameters. +/// +/// Returns [ProcedureId] if `path` is provided, [None] otherwise. +fn build_procedure_id( + path: Option<&LibraryPath>, + proc: &NamedProcedure, + proc_index: usize, +) -> Option { + let mut proc_id = None; + if let Some(path) = path { + if proc.is_export() { + proc_id = Some(ProcedureId::from_name(proc.name(), path)); + } else { + proc_id = Some(ProcedureId::from_index(proc_index as u16, path)) + } + } + proc_id +} diff --git a/assembly/src/assembler/procedure_cache.rs b/assembly/src/assembler/procedure_cache.rs index f6a4931064..3caa49a1c5 100644 --- a/assembly/src/assembler/procedure_cache.rs +++ b/assembly/src/assembler/procedure_cache.rs @@ -42,6 +42,11 @@ impl ProcedureCache { self.procedures.get(mast_root) } + /// Returns a MAST root ([RpoDigest]) reference corresponding to the provided [ProcedureId]. + pub fn get_proc_root_by_id(&self, id: &ProcedureId) -> Option { + self.proc_id_map.get(id).cloned() + } + /// Returns true if the [ProcedureCache] contains a [Procedure] for the specified /// [ProcedureId]. pub fn contains_id(&self, id: &ProcedureId) -> bool { @@ -58,10 +63,14 @@ impl ProcedureCache { /// - A procedure with the same ID is already in the cache. /// - A procedure with the same MAST root but conflicting procedure metadata exists in the /// cache. - pub fn insert(&mut self, proc: NamedProcedure) -> Result<(), AssemblyError> { + pub fn insert( + &mut self, + proc: NamedProcedure, + id: Option, + ) -> Result<(), AssemblyError> { // if a procedure with the same id is already in the cache, return an error - if self.contains_id(proc.id()) { - return Err(AssemblyError::duplicate_proc_id(proc.id())); + if id.is_some_and(|id| self.contains_id(&id)) { + return Err(AssemblyError::duplicate_proc_id(&id.unwrap())); } // If the entry is `Vacant` then insert the Procedure. If the procedure with the same MAST @@ -72,12 +81,16 @@ impl ProcedureCache { if proc.num_locals() != cached_proc.num_locals() { Err(AssemblyError::conflicting_num_locals(proc.name())) } else { - self.proc_id_map.insert(*proc.id(), proc.mast_root()); + if let Some(id) = id { + self.proc_id_map.insert(id, proc.mast_root()); + } Ok(()) } } Entry::Vacant(entry) => { - self.proc_id_map.insert(*proc.id(), proc.mast_root()); + if let Some(id) = id { + self.proc_id_map.insert(id, proc.mast_root()); + } entry.insert(proc.into_inner()); Ok(()) } diff --git a/assembly/src/ast/mod.rs b/assembly/src/ast/mod.rs index ae7321d9fb..f423d1b6f1 100644 --- a/assembly/src/ast/mod.rs +++ b/assembly/src/ast/mod.rs @@ -384,8 +384,7 @@ impl fmt::Display for ProgramAst { /// An abstract syntax tree of a Miden module. /// /// A module AST consists of a list of procedure ASTs, a list of re-exported procedures, a list of -/// imports, a map from procedure ids to procedure names for imported procedures used in the module, -/// and module documentation. Local procedures could be internal or exported. +/// imports, and module documentation. Local procedures could be internal or exported. #[derive(Debug, Clone, PartialEq, Eq)] pub struct ModuleAst { local_procs: Vec, diff --git a/assembly/src/library/path.rs b/assembly/src/library/path.rs index 590d6596e8..600d81d435 100644 --- a/assembly/src/library/path.rs +++ b/assembly/src/library/path.rs @@ -32,6 +32,9 @@ impl LibraryPath { /// Path for an executable module. pub const EXEC_PATH: &'static str = "#exec"; + /// Path for a module without library path. + pub const ANON_PATH: &'static str = "#anon"; + // CONSTRUCTORS // -------------------------------------------------------------------------------------------- @@ -72,6 +75,14 @@ impl LibraryPath { } } + /// Returns a path for a module without library path. + pub fn anon_path() -> Self { + Self { + path: Self::ANON_PATH.into(), + num_components: 1, + } + } + // PUBLIC ACCESSORS // -------------------------------------------------------------------------------------------- diff --git a/assembly/src/procedures/mod.rs b/assembly/src/procedures/mod.rs index 01ede682a9..5a6591da9d 100644 --- a/assembly/src/procedures/mod.rs +++ b/assembly/src/procedures/mod.rs @@ -54,13 +54,10 @@ impl Procedure { /// /// Procedure metadata includes: /// - Procedure name. -/// - Procedure ID which is computed as a hash of the procedure's fully qualified path. /// - A boolean flag indicating whether the procedure is exported from a module. -/// - Number of procedure locals available to the procedure. /// - A set of MAST roots of procedures which are invoked from this procedure. #[derive(Clone, Debug)] pub struct NamedProcedure { - id: ProcedureId, name: ProcedureName, is_export: bool, procedure: Procedure, @@ -71,7 +68,6 @@ impl NamedProcedure { // -------------------------------------------------------------------------------------------- /// Returns a new [Procedure] instantiated with the specified properties. pub fn new( - id: ProcedureId, name: ProcedureName, is_export: bool, num_locals: u32, @@ -79,7 +75,6 @@ impl NamedProcedure { callset: CallSet, ) -> Self { NamedProcedure { - id, name, is_export, procedure: Procedure { @@ -93,11 +88,6 @@ impl NamedProcedure { // PUBLIC ACCESSORS // -------------------------------------------------------------------------------------------- - /// Returns ID of this procedure. - pub fn id(&self) -> &ProcedureId { - &self.id - } - /// Returns a label of this procedure. pub fn name(&self) -> &ProcedureName { &self.name diff --git a/assembly/src/tests.rs b/assembly/src/tests.rs index 498715018e..ae439fdda3 100644 --- a/assembly/src/tests.rs +++ b/assembly/src/tests.rs @@ -9,7 +9,7 @@ use core::slice::Iter; #[test] fn simple_instructions() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin push.0 assertz end"; let program = assembler.compile(source).unwrap(); let expected = "\ @@ -37,7 +37,7 @@ fn simple_instructions() { #[test] fn empty_program() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin end"; let program = assembler.compile(source).unwrap(); let expected = "begin span noop end end"; @@ -46,7 +46,7 @@ fn empty_program() { #[test] fn empty_if() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin if.true end end"; let program = assembler.compile(source).unwrap(); let expected = "begin if.true span noop end else span noop end end end"; @@ -55,7 +55,7 @@ fn empty_if() { #[test] fn empty_while() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin while.true end end"; let program = assembler.compile(source).unwrap(); let expected = "begin while.true span noop end end end"; @@ -64,7 +64,7 @@ fn empty_while() { #[test] fn empty_repeat() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin repeat.5 end end"; let program = assembler.compile(source).unwrap(); let expected = "begin span noop noop noop noop noop end end"; @@ -73,7 +73,7 @@ fn empty_repeat() { #[test] fn single_span() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin push.1 push.2 add end"; let program = assembler.compile(source).unwrap(); let expected = "begin span pad incr push(2) add end end"; @@ -82,7 +82,7 @@ fn single_span() { #[test] fn span_and_simple_if() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // if with else let source = "begin push.2 push.3 if.true add else mul end end"; @@ -115,7 +115,7 @@ fn span_and_simple_if() { #[test] fn simple_main_call() { // instantiate assembler - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // compile account module let account_path = LibraryPath::new("context::account").unwrap(); @@ -131,23 +131,88 @@ fn simple_main_call() { ", ) .unwrap(); - let account_module = Module::new(account_path, account_code); let _method_roots = assembler - .compile_module(&account_module, &mut super::AssemblyContext::for_module(false)) + .compile_module(&account_code, Some(&account_path), &mut AssemblyContext::for_module(false)) .unwrap(); // compile note 1 program let note_1 = ProgramAst::parse("use.context::account begin call.account::account_method_1 end").unwrap(); let _note_1_root = assembler - .compile_in_context(¬e_1, &mut super::AssemblyContext::for_program(Some(¬e_1))) + .compile_in_context(¬e_1, &mut AssemblyContext::for_program(Some(¬e_1))) .unwrap(); // compile note 2 program let note_2 = ProgramAst::parse("use.context::account begin call.account::account_method_2 end").unwrap(); let _note_2_root = assembler - .compile_in_context(¬e_2, &mut super::AssemblyContext::for_program(Some(¬e_2))) + .compile_in_context(¬e_2, &mut AssemblyContext::for_program(Some(¬e_2))) + .unwrap(); +} + +#[test] +fn call_without_path() { + // instantiate assembler + let assembler = Assembler::default(); + + // compile first module + let account_code1 = ModuleAst::parse( + "\ + export.account_method_1 + push.2.1 add + end + + export.account_method_2 + push.3.1 sub + end + ", + ) + .unwrap(); + assembler + .compile_module(&account_code1, None, &mut AssemblyContext::for_module(false)) + .unwrap(); + + //--------------------------------------------------------------------------------------------- + + // compile second module + let account_code2 = ModuleAst::parse( + "\ + export.account_method_1 + push.2.2 add + end + + export.account_method_2 + push.4.1 sub + end + ", + ) + .unwrap(); + assembler + .compile_module(&account_code2, None, &mut AssemblyContext::for_module(false)) + .unwrap(); + + //--------------------------------------------------------------------------------------------- + + // compile program in which functions from different modules but with equal names are called + let source = ProgramAst::parse( + "begin + # call the account_method_1 from the first module (account_code1) + call.0x81e0b1afdbd431e4c9d4b86599b82c3852ecf507ae318b71c099cdeba0169068 + + # call the account_method_2 from the first module (account_code1) + call.0x1bc375fc794af6637af3f428286bf6ac1a24617640ed29f8bc533f48316c6d75 + + # call the account_method_1 from the second module (account_code2) + call.0xcfadd74886ea075d15826a4f59fb4db3a10cde6e6e953603cba96b4dcbb94321 + + # call the account_method_2 from the second module (account_code2) + call.0x1976bf72d457bd567036d3648b7e3f3c22eca4096936931e59796ec05c0ecb10 + end", + ) + .unwrap(); + + assembler + .compile_in_context(&source, &mut AssemblyContext::for_program(Some(&source))) .unwrap(); } @@ -156,7 +221,7 @@ fn simple_main_call() { #[test] fn simple_constant() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.TEST_CONSTANT=7 \ begin \ push.TEST_CONSTANT \ @@ -174,7 +239,7 @@ fn simple_constant() { #[test] fn multiple_constants_push() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.CONSTANT_1=21 \ const.CONSTANT_2=44 \ begin \ @@ -192,7 +257,7 @@ fn multiple_constants_push() { #[test] fn constant_numeric_expression() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.TEST_CONSTANT=11-2+4*(12-(10+1))+9+8//4*2 \ begin \ push.TEST_CONSTANT \ @@ -210,7 +275,7 @@ fn constant_numeric_expression() { #[test] fn constant_alphanumeric_expression() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.TEST_CONSTANT_1=(18-1+10)*6-((13+7)*2) \ const.TEST_CONSTANT_2=11-2+4*(12-(10+1))+9 const.TEST_CONSTANT_3=(TEST_CONSTANT_1-(TEST_CONSTANT_2+10))//5+3 @@ -230,7 +295,7 @@ fn constant_alphanumeric_expression() { #[test] fn constant_field_division() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.TEST_CONSTANT=(17//4)/4*(1//2)+2 \ begin \ push.TEST_CONSTANT \ @@ -248,7 +313,7 @@ fn constant_field_division() { #[test] fn constant_err_const_not_initialized() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.TEST_CONSTANT=5+A \ begin \ push.TEST_CONSTANT \ @@ -262,7 +327,7 @@ fn constant_err_const_not_initialized() { #[test] fn constant_err_div_by_zero() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.TEST_CONSTANT=5/0 \ begin \ push.TEST_CONSTANT \ @@ -286,7 +351,7 @@ fn constant_err_div_by_zero() { #[test] fn constants_must_be_uppercase() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.constant_1=12 \ begin \ push.constant_1 \ @@ -300,7 +365,7 @@ fn constants_must_be_uppercase() { #[test] fn duplicate_constant_name() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.CONSTANT=12 \ const.CONSTANT=14 \ begin \ @@ -315,7 +380,7 @@ fn duplicate_constant_name() { #[test] fn constant_must_be_valid_felt() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.CONSTANT=1122INVALID \ begin \ push.CONSTANT \ @@ -330,7 +395,7 @@ fn constant_must_be_valid_felt() { #[test] fn constant_must_be_within_valid_felt_range() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "const.CONSTANT=18446744073709551615 \ begin \ push.CONSTANT \ @@ -346,7 +411,7 @@ fn constant_must_be_within_valid_felt_range() { #[test] fn constants_defined_in_global_scope() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = " begin \ const.CONSTANT=12 @@ -361,7 +426,7 @@ fn constants_defined_in_global_scope() { #[test] fn constant_not_found() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = " begin \ push.CONSTANT \ @@ -375,7 +440,7 @@ fn constant_not_found() { #[test] fn mem_operations_with_constants() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // Define constant values const PROC_LOC_STORE_PTR: u64 = 0; @@ -495,7 +560,7 @@ fn const_conversion_failed_to_u16() { end " ); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let result = assembler.compile(source); assert!(result.is_err()); let err = result.err().unwrap(); @@ -518,7 +583,7 @@ fn const_conversion_failed_to_u32() { end " ); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let result = assembler.compile(source); assert!(result.is_err()); let err = result.err().unwrap(); @@ -542,7 +607,7 @@ fn assert_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -564,7 +629,7 @@ fn assertz_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -586,7 +651,7 @@ fn assert_eq_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -608,7 +673,7 @@ fn assert_eqw_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -634,7 +699,7 @@ fn u32assert_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -656,7 +721,7 @@ fn u32assert2_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -678,7 +743,7 @@ fn u32assertw_with_code() { end " .to_string(); - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let program = assembler.compile(source).unwrap(); let expected = "\ @@ -697,7 +762,7 @@ fn u32assertw_with_code() { #[test] fn nested_control_blocks() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // if with else let source = "begin \ @@ -738,7 +803,7 @@ fn nested_control_blocks() { #[test] fn program_with_one_procedure() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "proc.foo push.3 push.7 mul end begin push.2 push.3 add exec.foo end"; let program = assembler.compile(source).unwrap(); let expected = "begin span push(2) push(3) add push(3) push(7) mul end end"; @@ -747,7 +812,7 @@ fn program_with_one_procedure() { #[test] fn program_with_one_empty_procedure() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "proc.foo end begin exec.foo end"; let program = assembler.compile(source).unwrap(); let expected = "begin span noop end end"; @@ -756,7 +821,7 @@ fn program_with_one_empty_procedure() { #[test] fn program_with_nested_procedure() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "\ proc.foo push.3 push.7 mul end \ proc.bar push.5 exec.foo add end \ @@ -771,7 +836,7 @@ fn program_with_nested_procedure() { #[test] fn program_with_proc_locals() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "\ proc.foo.1 \ loc_store.0 \ @@ -801,7 +866,7 @@ fn program_with_proc_locals() { #[test] fn program_with_exported_procedure() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "export.foo push.3 push.7 mul end begin push.2 push.3 add exec.foo end"; assert!(assembler.compile(source).is_err()); } @@ -811,7 +876,7 @@ fn program_with_exported_procedure() { #[test] fn program_with_incorrect_mast_root_length() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin call.0x1234 end"; let result = assembler.compile(source); let err = result.err().unwrap(); @@ -821,7 +886,7 @@ fn program_with_incorrect_mast_root_length() { #[test] fn program_with_invalid_mast_root_chars() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin call.0xc2545da99d3a1f3f38d957c7893c44d78998d8ea8b11aba7e22c8c2b2a21xyzb end"; let result = assembler.compile(source); @@ -833,7 +898,7 @@ fn program_with_invalid_mast_root_chars() { #[test] fn program_with_invalid_rpo_digest_call() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin call.0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff end"; let result = assembler.compile(source); @@ -845,7 +910,7 @@ fn program_with_invalid_rpo_digest_call() { #[test] fn program_with_phantom_mast_call() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin call.0xc2545da99d3a1f3f38d957c7893c44d78998d8ea8b11aba7e22c8c2b2a213dae end"; @@ -887,7 +952,7 @@ fn program_with_one_import_and_hex_call() { let modules = vec![Module { path, ast }]; let library = DummyLibrary::new(namespace, modules); - let assembler = super::Assembler::default().with_library(&library).unwrap(); + let assembler = Assembler::default().with_library(&library).unwrap(); let source = format!( r#" use.{NAMESPACE}::{MODULE} @@ -947,7 +1012,7 @@ fn program_with_two_imported_procs_with_same_mast_root() { let modules = vec![Module { path, ast }]; let library = DummyLibrary::new(namespace, modules); - let assembler = super::Assembler::default().with_library(&library).unwrap(); + let assembler = Assembler::default().with_library(&library).unwrap(); let source = format!( r#" use.{NAMESPACE}::{MODULE} @@ -1020,7 +1085,7 @@ fn program_with_reexported_proc_in_same_library() { ast: ref_ast, }, ]; - let assembler = super::Assembler::default() + let assembler = Assembler::default() .with_library(&DummyLibrary::new(namespace, modules)) .unwrap(); let source = format!( @@ -1090,7 +1155,7 @@ fn program_with_reexported_proc_in_another_library() { }]; let dummy_library_1 = DummyLibrary::new(namespace, modules); let dummy_library_2 = DummyLibrary::new(ref_namespace, ref_modules); - let assembler = super::Assembler::default() + let assembler = Assembler::default() .with_libraries([&dummy_library_1, &dummy_library_2].into_iter()) .unwrap(); let source = format!( @@ -1116,7 +1181,7 @@ fn program_with_reexported_proc_in_another_library() { // when the re-exported proc is part of a different library and the library is not passed to // the assembler it should fail - let assembler = super::Assembler::default().with_library(&dummy_library_1).unwrap(); + let assembler = Assembler::default().with_library(&dummy_library_1).unwrap(); let source = format!( r#" use.{NAMESPACE}::{MODULE} @@ -1153,7 +1218,7 @@ fn module_alias() { let modules = vec![Module { path, ast }]; let library = DummyLibrary::new(namespace, modules); - let assembler = super::Assembler::default().with_library(&library).unwrap(); + let assembler = Assembler::default().with_library(&library).unwrap(); let source = " use.dummy::math::u64->bigint @@ -1217,7 +1282,7 @@ fn module_alias() { #[test] fn program_with_import_errors() { // --- non-existent import ------------------------------------------------ - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "\ use.std::math::u512 begin \ @@ -1227,7 +1292,7 @@ fn program_with_import_errors() { assert!(assembler.compile(source).is_err()); // --- non-existent procedure in import ----------------------------------- - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "\ use.std::math::u256 begin \ @@ -1245,7 +1310,7 @@ fn program_with_import_errors() { #[test] fn comment_simple() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin # simple comment \n push.1 push.2 add end"; let program = assembler.compile(source).unwrap(); let expected = "begin span pad incr push(2) add end end"; @@ -1254,7 +1319,7 @@ fn comment_simple() { #[test] fn comment_in_nested_control_blocks() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // if with else let source = "begin \ @@ -1294,7 +1359,7 @@ fn comment_in_nested_control_blocks() { #[test] fn comment_before_program() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = " # starting comment \n begin push.1 push.2 add end"; let program = assembler.compile(source).unwrap(); let expected = "begin span pad incr push(2) add end end"; @@ -1303,7 +1368,7 @@ fn comment_before_program() { #[test] fn comment_after_program() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin push.1 push.2 add end # closing comment"; let program = assembler.compile(source).unwrap(); let expected = "begin span pad incr push(2) add end end"; @@ -1315,7 +1380,7 @@ fn comment_after_program() { #[test] fn invalid_program() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = ""; let program = assembler.compile(source); assert!(program.is_err()); @@ -1394,7 +1459,7 @@ fn invalid_proc() { #[test] fn invalid_if_else() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // --- unmatched if --------------------------------------------------------------------------- let source = "begin push.1 add if.true mul"; @@ -1436,7 +1501,7 @@ fn invalid_if_else() { #[test] fn invalid_repeat() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); // unmatched repeat let source = "begin push.1 add repeat.10 mul"; @@ -1460,7 +1525,7 @@ fn invalid_repeat() { #[test] fn invalid_while() { - let assembler = super::Assembler::default(); + let assembler = Assembler::default(); let source = "begin push.1 add while mul end end"; let program = assembler.compile(source);