diff options
| author | Sidney Congard | 2022-06-30 14:54:15 +0200 | 
|---|---|---|
| committer | Sidney Congard | 2022-06-30 14:54:15 +0200 | 
| commit | fdbbb82ff89b1d5141ec63bc2385936da3de3616 (patch) | |
| tree | d48e3fa933280e8a275d2cfdab8f126e920e5f13 /src/InterpreterBorrows.ml | |
| parent | 47691de8fe3dc32a29663d4d8343eb415ce1d81e (diff) | |
| parent | 4f33892c81cdaf6aefaad9b7cef1456dcfead67c (diff) | |
Merge branch 'main' of github.com:Kachoc/aeneas into constants-v2
Complete the constants extraction by making all functions fail
Diffstat (limited to '')
| -rw-r--r-- | src/InterpreterBorrows.ml | 22 | 
1 files changed, 19 insertions, 3 deletions
| diff --git a/src/InterpreterBorrows.ml b/src/InterpreterBorrows.ml index f5f3a8fa..a13ac786 100644 --- a/src/InterpreterBorrows.ml +++ b/src/InterpreterBorrows.ml @@ -985,6 +985,9 @@ and end_abstraction (config : C.config) (chain : borrow_or_abs_ids)    (* Lookup the abstraction *)    let abs = C.ctx_lookup_abs ctx abs_id in +  (* Check that we can end the abstraction *) +  assert abs.can_end; +    (* End the parent abstractions first *)    let cc = end_abstractions config chain abs.parents in    let cc = @@ -1439,12 +1442,22 @@ let end_outer_borrows config : V.BorrowId.Set.t -> cm_fun =      - it mustn't contain [Bottom]      - it mustn't contain inactivated borrows      TODO: this kind of checks should be put in an auxiliary helper, because -    they are redundant +    they are redundant. + +    The loan to update mustn't be a borrowed value.   *)  let promote_shared_loan_to_mut_loan (l : V.BorrowId.id)      (cf : V.typed_value -> m_fun) : m_fun =   fun ctx -> -  (* Lookup the shared loan *) +  (* Debug *) +  log#ldebug +    (lazy +      ("promote_shared_loan_to_mut_loan:\n- loan: " ^ V.BorrowId.to_string l +     ^ "\n- context:\n" ^ eval_ctx_to_string ctx ^ "\n")); +  (* Lookup the shared loan - note that we can't promote a shared loan +   * in a shared value, but we can do it in a mutably borrowed value. +   * This is important because we can do: `let y = &two-phase ( *x );` +   *)    let ek =      { enter_shared_loans = false; enter_mut_borrows = true; enter_abs = false }    in @@ -1545,7 +1558,10 @@ let rec activate_inactivated_mut_borrow (config : C.config) (l : V.BorrowId.id)               the borrow we want to promote *)            let bids = V.BorrowId.Set.remove l bids in            let cc = end_outer_borrows config bids in -          (* Promote the loan *) +          (* Promote the loan - TODO: this will fail if the value contains +           * any loans. In practice, it shouldn't, but we could also +           * look for loans inside the value and end them before promoting +           * the borrow. *)            let cc = comp cc (promote_shared_loan_to_mut_loan l) in            (* Promote the borrow - the value should have been checked by               [promote_shared_loan_to_mut_loan] | 
