aboutsummaryrefslogtreecommitdiff
path: root/frontend/check.icl
diff options
context:
space:
mode:
Diffstat (limited to 'frontend/check.icl')
-rw-r--r--frontend/check.icl51
1 files changed, 17 insertions, 34 deletions
diff --git a/frontend/check.icl b/frontend/check.icl
index 31d3ebf..89e6ccb 100644
--- a/frontend/check.icl
+++ b/frontend/check.icl
@@ -796,7 +796,7 @@ checkFunction mod_index fun_index def_level fun_defs
fi_properties = (if ef_is_macro_fun FI_IsMacroFun 0) bitor (has_type fun_type)
fun_info = { fun_def.fun_info & fi_calls = es_calls, fi_def_level = def_level, fi_free_vars = free_vars, fi_dynamics = es_dynamics,
fi_properties = fi_properties }
- fun_defs = { es_fun_defs & [fun_index] = { fun_def & fun_body = fun_body, fun_index = fun_index, fun_info = fun_info, fun_type = fun_type}}
+ fun_defs = { es_fun_defs & [fun_index] = { fun_def & fun_body = fun_body, fun_info = fun_info, fun_type = fun_type}}
(fun_defs, cs_symbol_table) = remove_calls_from_symbol_table fun_index def_level es_calls fun_defs cs.cs_symbol_table
= (fun_defs,
{ e_info & ef_type_defs = ef_type_defs, ef_modules = ef_modules },
@@ -1367,23 +1367,15 @@ checkDclModules imports_of_icl_mod dcl_modules icl_functions heaps cs=:{cs_symbo
get_ident (ID_Instance class_ident instance_ident _) = instance_ident
get_symbol imp_decl ident=:{id_info} (expl_imp_symbols_accu, nr_of_expl_imp_symbols, expl_imp_indices_accu, cs_symbol_table)
- # (ste, cs_symbol_table)
- = readPtr id_info cs_symbol_table
+ # (ste, cs_symbol_table) = readPtr id_info cs_symbol_table
= case ste.ste_kind of
STE_ExplImpSymbol expl_imp_symbols_nr
- # ini
- = { ini_symbol_nr = expl_imp_symbols_nr, ini_imp_decl = imp_decl }
- -> (expl_imp_symbols_accu, nr_of_expl_imp_symbols,
- [ini:expl_imp_indices_accu], cs_symbol_table)
+ # ini = { ini_symbol_nr = expl_imp_symbols_nr, ini_imp_decl = imp_decl }
+ -> (expl_imp_symbols_accu, nr_of_expl_imp_symbols, [ini:expl_imp_indices_accu], cs_symbol_table)
STE_Empty
- # cs_symbol_table
- = writePtr id_info { ste & ste_kind = STE_ExplImpSymbol nr_of_expl_imp_symbols, ste_previous = ste }
- cs_symbol_table
- ini
- = { ini_symbol_nr = nr_of_expl_imp_symbols, ini_imp_decl = imp_decl }
- -> ([ident:expl_imp_symbols_accu], nr_of_expl_imp_symbols+1,
- [ini:expl_imp_indices_accu], cs_symbol_table)
-
+ # cs_symbol_table = writePtr id_info { ste & ste_kind = STE_ExplImpSymbol nr_of_expl_imp_symbols, ste_previous = ste } cs_symbol_table
+ ini = { ini_symbol_nr = nr_of_expl_imp_symbols, ini_imp_decl = imp_decl }
+ -> ([ident:expl_imp_symbols_accu], nr_of_expl_imp_symbols+1,[ini:expl_imp_indices_accu], cs_symbol_table)
checkDclComponent :: !{![Int]} !{![Int]} ![[(Index, Position, [ImportNrAndIdents])]] ![Int]
!(!Int, !*ExplImpInfos, !*{# DclModule}, !*{# FunDef}, !*Heaps,!*CheckState)
@@ -2020,13 +2012,13 @@ check_module2 mod_name mod_imported_objects mod_imports mod_type icl_global_func
# {ft_type,ft_specials = SP_FunIndex decl_index} = dcl_fun_types.[spec_index]
icl_index = conversion_table.[decl_index]
(icl_fun, icl_functions) = icl_functions![icl_index]
- (new_fun_def, heaps) = build_function next_fun_index icl_fun ft_type heaps
+ (new_fun_def, heaps) = build_function next_fun_index icl_fun icl_index ft_type heaps
(new_fun_defs, funs_index_heaps)
= collect_specialized_functions (inc spec_index) last_index dcl_fun_types conversion_table (icl_functions, inc next_fun_index, heaps)
= ([new_fun_def : new_fun_defs], funs_index_heaps)
= ([], (icl_functions, next_fun_index, heaps))
- build_function new_fun_index fun_def=:{fun_symb, fun_index, fun_arity, fun_body = CheckedBody {cb_args}, fun_info} fun_type
+ build_function new_fun_index fun_def=:{fun_symb, fun_arity, fun_body = CheckedBody {cb_args}, fun_info} fun_index fun_type
(var_heap, type_var_heap, expr_heap)
# (tb_args, var_heap) = mapSt new_free_var cb_args var_heap
(app_args, expr_heap) = mapSt new_bound_var tb_args expr_heap
@@ -2035,7 +2027,7 @@ check_module2 mod_name mod_imported_objects mod_imports mod_type icl_global_func
symb_kind = SK_Function { glob_module = main_dcl_module_n, glob_object = fun_index }},
app_args = app_args,
app_info_ptr = app_info_ptr }
- = ({ fun_def & fun_index=new_fun_index, fun_body = TransformedBody {tb_args = tb_args, tb_rhs = tb_rhs}, fun_type = Yes fun_type,
+ = ({ fun_def & fun_body = TransformedBody {tb_args = tb_args, tb_rhs = tb_rhs}, fun_type = Yes fun_type,
fun_info = { EmptyFunInfo & fi_calls = [ { fc_index = fun_index, fc_level = cGlobalScope }] }},
(var_heap, type_var_heap, expr_heap))
@@ -2234,18 +2226,15 @@ initialDclModule ({mod_name, mod_defs=mod_defs=:{def_funtypes,def_macros}, mod_t
, dcl_is_cashed = False
}
-addImportedSymbolsToSymbolTable importing_mod opt_macro_range modules_in_component_set imports_ikh
- dcl_modules cs
+addImportedSymbolsToSymbolTable importing_mod opt_macro_range modules_in_component_set imports_ikh dcl_modules cs
#! nr_of_dcl_modules
= size dcl_modules
- # {si_explicit, si_implicit}
- = ikhSearch` importing_mod imports_ikh
+ # {si_explicit, si_implicit} = ikhSearch` importing_mod imports_ikh
(decls_accu, visited_modules, dcl_modules, cs)
= foldSt (add_impl_imported_symbols_with_new_error_pos opt_macro_range importing_mod
modules_in_component_set imports_ikh)
si_implicit ([], bitvectCreate nr_of_dcl_modules, dcl_modules, cs)
- = foldSt (add_expl_imported_symbols_with_new_error_pos opt_macro_range importing_mod) si_explicit
- (decls_accu, dcl_modules, cs)
+ = foldSt (add_expl_imported_symbols_with_new_error_pos opt_macro_range importing_mod) si_explicit (decls_accu, dcl_modules, cs)
where
add_impl_imported_symbols_with_new_error_pos opt_macro_range importing_mod modules_in_component_set imports_ikh
(mod_index, position) (decls_accu, visited_modules, dcl_modules, cs)
@@ -2287,14 +2276,9 @@ addImportedSymbolsToSymbolTable importing_mod opt_macro_range modules_in_compone
si_implicit
(decls_accu, visited_modules, dcl_modules, cs)
-
- add_expl_imported_symbols_with_new_error_pos opt_macro_range importing_mod (decls, position)
- (decls_accu, dcl_modules, cs)
- # cs
- = pushErrorAdmin (newPosition import_ident position) cs
- (decls_accu, dcl_modules, cs)
- = foldSt (add_expl_imp_declaration opt_macro_range importing_mod) decls
- (decls_accu, dcl_modules, cs)
+ add_expl_imported_symbols_with_new_error_pos opt_macro_range importing_mod (decls, position) (decls_accu, dcl_modules, cs)
+ # cs = pushErrorAdmin (newPosition import_ident position) cs
+ (decls_accu, dcl_modules, cs) = foldSt (add_expl_imp_declaration opt_macro_range importing_mod) decls (decls_accu, dcl_modules, cs)
= (decls_accu, dcl_modules, popErrorAdmin cs)
add_declaration opt_dcl_macro_range importing_mod declaration (decls_accu, cs)
@@ -2616,8 +2600,7 @@ checkDclModule dcl_imported_module_numbers super_components imports_ikh componen
dcl_macros = mod_defs.def_macros
cs = addGlobalDefinitionsToSymbolTable dcl_defined cs
(dcls_import_list, modules, cs)
- = addImportedSymbolsToSymbolTable mod_index No modules_in_component_set
- imports_ikh modules cs
+ = addImportedSymbolsToSymbolTable mod_index No modules_in_component_set imports_ikh modules cs
dcls_import
= { el \\ el<-dcls_import_list }
cs = { cs & cs_x.x_needed_modules = 0 }