diff options
author | Son Ho | 2022-01-27 10:52:57 +0100 |
---|---|---|
committer | Son Ho | 2022-01-27 10:52:57 +0100 |
commit | 2c9f43840c7c2721d8fab9981ecac9cc0e6fafd5 (patch) | |
tree | 8950eb9824ce5c7a3acc7dff6bb8d8a1ca453c33 /src | |
parent | 5e71d58da8b232cc53989f45c35f5017ae57cc77 (diff) |
Fix a small issue in translate_back_ty
Diffstat (limited to 'src')
-rw-r--r-- | src/CfimAstUtils.ml | 2 | ||||
-rw-r--r-- | src/SymbolicToPure.ml | 76 |
2 files changed, 28 insertions, 50 deletions
diff --git a/src/CfimAstUtils.ml b/src/CfimAstUtils.ml index 430678f1..8ef74bef 100644 --- a/src/CfimAstUtils.ml +++ b/src/CfimAstUtils.ml @@ -21,6 +21,8 @@ let fun_def_has_loops (fd : fun_def) : bool = statement_has_loops fd.body (** Small utility: list the transitive parents of a region var group. We don't do that in an efficient manner, but it doesn't matter. + + TODO: rename to "list_ancestors_..." *) let rec list_parent_region_groups (sg : fun_sig) (gid : T.RegionGroupId.id) : T.RegionGroupId.Set.t = diff --git a/src/SymbolicToPure.ml b/src/SymbolicToPure.ml index 41df82f6..884c7c8f 100644 --- a/src/SymbolicToPure.ml +++ b/src/SymbolicToPure.ml @@ -168,8 +168,8 @@ end module RegularFunIdMap = Collections.MakeMap (RegularFunIdOrderedType) type type_context = { - types_infos : TA.type_infos; cfim_type_defs : T.type_def TypeDefId.Map.t; + types_infos : TA.type_infos; (* TODO: rename to type_infos *) } type fun_context = { @@ -210,52 +210,6 @@ type bs_ctx = { } (** Body synthesis context *) -type fs_ctx = { - fun_def : A.fun_def; - bid : T.RegionGroupId.id option; - type_context : type_context; - fun_context : fun_context; - forward_inputs : var list; - (** The input parameters for the forward function *) - backward_inputs : var list T.RegionGroupId.Map.t; - (** The input parameters for the backward functions *) - backward_outputs : var list T.RegionGroupId.Map.t; - (** The variables that the backward functions will output *) -} -(** Function synthesis context - - TODO: remove - *) - -let fs_ctx_to_bs_ctx (fs_ctx : fs_ctx) : bs_ctx = - let { - fun_def; - bid; - type_context; - fun_context; - forward_inputs; - backward_inputs; - backward_outputs; - } = - fs_ctx - in - let sv_to_var = V.SymbolicValueId.Map.empty in - let var_counter = VarId.generator_zero in - let calls = V.FunCallId.Map.empty in - let abstractions = V.AbstractionId.Map.empty in - { - bid; - sv_to_var; - var_counter; - type_context; - fun_context; - forward_inputs; - backward_inputs; - backward_outputs; - calls; - abstractions; - } - let get_instantiated_fun_sig (fun_id : A.fun_id) (back_id : T.RegionGroupId.id option) (tys : ty list) (ctx : bs_ctx) : inst_fun_sig = @@ -415,7 +369,10 @@ let rec translate_back_ty (types_infos : TA.type_infos) | T.AdtId _ | Assumed _ -> (* Don't accept ADTs (which are not tuples) with borrows for now *) assert (not (TypesUtils.ty_has_borrows types_infos ty)); - None + if inside_mut then + let tys_t = List.filter_map translate tys in + Some (Adt (type_id, tys_t)) + else None | T.Tuple -> ( (* Tuples can contain borrows (which we eliminated) *) let tys_t = List.filter_map translate tys in @@ -450,6 +407,7 @@ let ctx_translate_back_ty (ctx : bs_ctx) (keep_region : 'r -> bool) let types_infos = ctx.type_context.types_infos in translate_back_ty types_infos keep_region inside_mut ty +(** List the ancestors of an abstraction *) let list_ancestor_abstractions_ids (ctx : bs_ctx) (abs : V.abs) : V.AbstractionId.id list = (* We could do something more "elegant" without references, but it is @@ -462,7 +420,7 @@ let list_ancestor_abstractions_ids (ctx : bs_ctx) (abs : V.abs) : let abs = V.AbstractionId.Map.find abs_id ctx.abstractions in List.iter gather abs.original_parents) in - gather abs.abs_id; + List.iter gather abs.original_parents; let ids = !abs_set in (* List the ancestors, in the proper order *) let call_info = V.FunCallId.Map.find abs.call_id ctx.calls in @@ -535,7 +493,7 @@ let translate_fun_sig (types_infos : TA.type_infos) (sg : A.fun_sig) * The outputs are the borrows inside the regions of the abstractions * and which are present in the input values. For instance, see: * ``` - * fn f<'a>(x : 'a mut u32) -> ...; + * fn f<'a>(x : &'a mut u32) -> ...; * ``` * Upon ending the abstraction for 'a, we give back the borrow which * was consumed through the `x` parameter. @@ -936,6 +894,10 @@ and translate_function_call (call : S.call) (e : S.expression) (ctx : bs_ctx) : and translate_end_abstraction (abs : V.abs) (e : S.expression) (ctx : bs_ctx) : expression = + log#ldebug + (lazy + ("translate_end_abstraction: abstraction kind: " + ^ V.show_abs_kind abs.kind)); match abs.kind with | V.SynthInput -> (* When we end an input abstraction, this input abstraction gets back @@ -1021,6 +983,12 @@ and translate_end_abstraction (abs : V.abs) (e : S.expression) (ctx : bs_ctx) : List.iter (fun (x, ty) -> assert ((x : typed_rvalue).ty = ty)) (List.combine inputs inst_sg.inputs); + log#ldebug + (lazy + ("\n- outputs: " + ^ string_of_int (List.length outputs) + ^ "\n- expected outputs: " + ^ string_of_int (List.length inst_sg.outputs))); List.iter (fun (x, ty) -> assert ((x : typed_lvalue).ty = ty)) (List.combine outputs inst_sg.outputs); @@ -1197,6 +1165,14 @@ and translate_expansion (sv : V.symbolic_value) (exp : S.expansion) let translate_fun_def (def : A.fun_def) (ctx : bs_ctx) (body : S.expression) : fun_def = let bid = ctx.bid in + log#ldebug + (lazy + ("SymbolicToPure.translate_fun_def: " + ^ Print.name_to_string def.A.name + ^ " (" + ^ Print.option_to_string T.RegionGroupId.to_string bid + ^ ")")); + (* Translate the function *) let def_id = def.A.def_id in let basename = def.name in |