diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/Interpreter.ml | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/src/Interpreter.ml b/src/Interpreter.ml index e0ded437..4b2a303c 100644 --- a/src/Interpreter.ml +++ b/src/Interpreter.ml @@ -908,11 +908,15 @@ let rec end_borrow_in_env (config : C.config) (io : inner_outer) * we shouldn't need to end outer borrows if io=Inner, so we just * add the following assertion *) assert (io = Outer); + (* Note that we might get there with `allowed_abs <> None`: we might + * be trying to end a borrow inside an abstraction, but which is actually + * inside another borrow *) let allowed_abs' = None in let env = end_borrows_in_env config io allowed_abs' bids env in (* Retry to end the borrow *) end_borrow_in_env config io allowed_abs l env | OuterBorrows (Borrow bid) -> + (* See the comments for the previous case *) assert (io = Outer); let allowed_abs' = None in let env = end_borrow_in_env config io allowed_abs' bid env in @@ -923,6 +927,7 @@ let rec end_borrow_in_env (config : C.config) (io : inner_outer) * loan is inside the same abstraction. If this is the case, we end * the borrow without ending the abstraction. If not, we need to * end the whole abstraction *) + (* Note that we can lookup the loan anywhere *) let ek = { enter_shared_loans = true; @@ -939,16 +944,18 @@ let rec end_borrow_in_env (config : C.config) (io : inner_outer) assert (Option.is_none (lookup_borrow_opt ek l env)); env) else - (* Not the same abstraction: we need to end the whole abstraction *) + (* Not the same abstraction: we need to end the whole abstraction. + * By doing that we should have ended the target borrow (see the + * below sanity check) *) let env = end_abstraction_in_env config abs_id env in - (* Sanity check *) + (* Sanity check: we ended the target borrow *) assert (Option.is_none (lookup_borrow_opt ek l env)); env | Var _, _ -> (* The loan is not inside the same abstraction (actually inside * a non-abstraction value): we need to end the whole abstraction *) let env = end_abstraction_in_env config abs_id env in - (* Sanity check *) + (* Sanity check: we ended the target borrow *) assert (Option.is_none (lookup_borrow_opt ek l env)); env)) | Ok (env, None) -> |