diff options
Diffstat (limited to 'frontend')
-rw-r--r-- | frontend/trans.icl | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/frontend/trans.icl b/frontend/trans.icl index 0fa632f..f451d87 100644 --- a/frontend/trans.icl +++ b/frontend/trans.icl @@ -1533,8 +1533,7 @@ generateFunction app_symb fd=:{fun_body = TransformedBody {tb_args,tb_rhs},fun_i (all_attr_vars2, ti_type_heaps) = accAttrVarHeap (getAttrVars (fresh_arg_types, fresh_result_type)) ti_type_heaps - all_attr_vars - = [ attr_var \\ TA_Var attr_var <- [fresh_attr_vars.[i] \\ i<-[0..size used_attr_vars-1] | used_attr_vars.[i]]] + all_attr_vars = get_used_attr_vars 0 used_attr_vars fresh_attr_vars # (all_fresh_type_vars, ti_type_heaps) = accTypeVarHeap (getTypeVars (fresh_arg_types, fresh_result_type)) ti_type_heaps new_fun_type @@ -1850,6 +1849,17 @@ where = var_heap = (n_args1,n_args2n,var_heap) + get_used_attr_vars :: !Int !{#Bool} !{!TypeAttribute} -> [AttributeVar] + get_used_attr_vars attr_var_n used_attr_vars fresh_attr_vars + | attr_var_n<size used_attr_vars + | used_attr_vars.[attr_var_n] + # (TA_Var used_attr_var) = fresh_attr_vars.[attr_var_n] + #! used_attr_var = used_attr_var + #! used_attr_vars = get_used_attr_vars (attr_var_n+1) used_attr_vars fresh_attr_vars + = [used_attr_var : used_attr_vars] + = get_used_attr_vars (attr_var_n+1) used_attr_vars fresh_attr_vars + = [] + // get_producer_type retrieves the type of symbol get_producer_type :: !SymbIdent !.ReadOnlyTI !*{#FunDef} !*FunctionHeap -> (!SymbolType,!*{#FunDef},!*FunctionHeap) get_producer_type {symb_kind=SK_Function {glob_module, glob_object}} ro fun_defs fun_heap |