diff options
author | Son Ho | 2022-12-17 07:15:07 +0100 |
---|---|---|
committer | Son HO | 2023-02-03 11:21:46 +0100 |
commit | cb00bfbbbe4e392b9854f407d602987e1596add9 (patch) | |
tree | 04a942c990bb0dd84cae0fedaaeb2014fcf0cffb | |
parent | d585060e227921e9f650f5dbcd308bf492d13583 (diff) |
Fix a minor issue with [translate_end_abstraction_loop]
-rw-r--r-- | compiler/SymbolicToPure.ml | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/compiler/SymbolicToPure.ml b/compiler/SymbolicToPure.ml index 3488b334..b5cb3a4d 100644 --- a/compiler/SymbolicToPure.ml +++ b/compiler/SymbolicToPure.ml @@ -1791,9 +1791,13 @@ and translate_end_abstraction_loop (ectx : C.eval_ctx) (abs : V.abs) let loop_info = LoopId.Map.find loop_id ctx.loops in let type_args = loop_info.type_args in let fwd_inputs = Option.get loop_info.forward_inputs in - (* Retrieve the values consumed upon ending the loans inside this - * abstraction: those give us the remaining input values *) - let back_inputs = abs_to_consumed ctx ectx abs in + (* Retrieve the additional backward inputs. Note that those are actually + the backward inputs of the function we are synthesizing (and that we + need to *transmit* to the loop backward function): they are not the + values consumed upon ending the abstraction (i.e., we don't use + [abs_to_consumed]) *) + let back_inputs = T.RegionGroupId.Map.find rg_id ctx.backward_inputs in + let back_inputs = List.map mk_texpression_from_var back_inputs in (* If the function is stateful: * - add the state input argument * - generate a fresh state variable for the returned state |