diff options
-rw-r--r-- | src/Print.ml | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/src/Print.ml b/src/Print.ml index 2ae88836..1ad2f5cb 100644 --- a/src/Print.ml +++ b/src/Print.ml @@ -248,8 +248,32 @@ module Values = struct | Bottom -> "⊥" | Assumed av -> ( match av with Box bv -> "@Box(" ^ typed_value_to_string fmt bv ^ ")") - | Borrow bc -> "" (* TODO *) - | Loan lc -> "" (* TODO *) + | Borrow bc -> borrow_content_to_string fmt bc + | Loan lc -> loan_content_to_string fmt lc | Symbolic sp -> symbolic_proj_comp_to_string (value_to_rtype_formatter fmt) sp + + and borrow_content_to_string (fmt : value_formatter) (bc : borrow_content) : + string = + match bc with + | SharedBorrow bid -> "⌊shared@" ^ BorrowId.to_string bid ^ "⌋" + | MutBorrow (bid, tv) -> + "&mut@" ^ BorrowId.to_string bid ^ " (" + ^ typed_value_to_string fmt tv + ^ ")" + | InactivatedMutBorrow bid -> + "⌊inactivated_mut@" ^ BorrowId.to_string bid ^ "⌋" + + and loan_content_to_string (fmt : value_formatter) (lc : loan_content) : + string = + match lc with + | SharedLoan (loans, v) -> + let loans = + BorrowId.Set.fold + (fun lid loans -> BorrowId.to_string lid :: loans) + loans [] + in + let loans = String.concat ", " (List.rev loans) in + "@shared_loan({" ^ loans ^ "}, " ^ typed_value_to_string fmt v ^ ")" + | MutLoan bid -> "⌊mut@" ^ BorrowId.to_string bid ^ "⌋" end |