summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/Print.ml113
-rw-r--r--src/Values.ml8
2 files changed, 110 insertions, 11 deletions
diff --git a/src/Print.ml b/src/Print.ml
index 47350324..1555afc4 100644
--- a/src/Print.ml
+++ b/src/Print.ml
@@ -262,22 +262,121 @@ module Values = struct
match lc with
| SharedLoan (loans, v) ->
let loans = BorrowId.set_to_string loans in
- "@shared_loan({" ^ loans ^ "}, " ^ typed_value_to_string fmt v ^ ")"
+ "@shared_loan(" ^ loans ^ ", " ^ typed_value_to_string fmt v ^ ")"
| MutLoan bid -> "⌊mut@" ^ BorrowId.to_string bid ^ "⌋"
+ let symbolic_value_proj_to_string (fmt : value_formatter)
+ (sv : symbolic_value) (rty : rty) : string =
+ symbolic_value_id_to_string sv.sv_id
+ ^ " : "
+ ^ ty_to_string (value_to_rtype_formatter fmt) sv.sv_ty
+ ^ " <: "
+ ^ ty_to_string (value_to_rtype_formatter fmt) rty
+
let rec abstract_shared_borrows_to_string (fmt : value_formatter)
(abs : abstract_shared_borrows) : string =
match abs with
| AsbSet bs -> BorrowId.set_to_string bs
| AsbProjReborrows (sv, rty) ->
- "{"
- ^ symbolic_value_id_to_string sv.sv_id
- ^ " : "
- ^ ty_to_string (value_to_rtype_formatter fmt) sv.sv_ty
- ^ " <: "
- ^ ty_to_string (value_to_rtype_formatter fmt) rty
+ "{" ^ symbolic_value_proj_to_string fmt sv rty ^ "}"
| AsbUnion (asb1, asb2) ->
abstract_shared_borrows_to_string fmt asb1
^ " U "
^ abstract_shared_borrows_to_string fmt asb2
+
+ let rec typed_avalue_to_string (fmt : value_formatter) (v : typed_avalue) :
+ string =
+ match v.avalue with
+ | AConcrete cv -> constant_value_to_string cv
+ | AAdt av ->
+ let adt_ident =
+ match av.avariant_id with
+ | Some vid -> fmt.type_def_id_variant_id_to_string av.adef_id vid
+ | None -> fmt.type_def_id_to_string av.adef_id
+ in
+ let field_values = FieldId.vector_to_list av.afield_values in
+ if List.length field_values > 0 then
+ let field_values =
+ String.concat " "
+ (List.map (typed_avalue_to_string fmt) field_values)
+ in
+ adt_ident ^ " " ^ field_values
+ else adt_ident
+ | ATuple values ->
+ let values = FieldId.vector_to_list values in
+ let values =
+ String.concat ", " (List.map (typed_avalue_to_string fmt) values)
+ in
+ "(" ^ values ^ ")"
+ | ABottom -> "⊥"
+ | ALoan lc -> aloan_content_to_string fmt lc
+ | ABorrow bc -> aborrow_content_to_string fmt bc
+ | AAssumed av -> (
+ match av with ABox bv -> "@Box(" ^ typed_avalue_to_string fmt bv ^ ")")
+ | AProj pv -> aproj_to_string fmt pv
+
+ and aloan_content_to_string (fmt : value_formatter) (lc : aloan_content) :
+ string =
+ match lc with
+ | AMutLoan (bid, av) ->
+ "⌊mut@" ^ BorrowId.to_string bid ^ ", "
+ ^ typed_avalue_to_string fmt av
+ ^ "⌋"
+ | ASharedLoan (loans, v, av) ->
+ let loans = BorrowId.set_to_string loans in
+ "@shared_loan(" ^ loans ^ ", "
+ ^ typed_value_to_string fmt v
+ ^ ", "
+ ^ typed_avalue_to_string fmt av
+ ^ ")"
+ | AEndedMutLoan ml ->
+ "@ended_mut_loan{ given_back="
+ ^ typed_value_to_string fmt ml.given_back
+ ^ "; child="
+ ^ typed_avalue_to_string fmt ml.child
+ ^ " }"
+ | AEndedSharedLoan (v, av) ->
+ "@ended_shared_loan("
+ ^ typed_value_to_string fmt v
+ ^ ", "
+ ^ typed_avalue_to_string fmt av
+ ^ ")"
+ | AIgnoredMutLoan (bid, av) ->
+ "@ignored_mut_loan(" ^ BorrowId.to_string bid ^ ", "
+ ^ typed_avalue_to_string fmt av
+ ^ ")"
+ | AIgnoredSharedLoan asb ->
+ "@ignored_shared_loan("
+ ^ abstract_shared_borrows_to_string fmt asb
+ ^ ")"
+
+ and aborrow_content_to_string (fmt : value_formatter) (bc : aborrow_content) :
+ string =
+ match bc with
+ | AMutBorrow (bid, av) ->
+ "&mut@" ^ BorrowId.to_string bid ^ " ("
+ ^ typed_avalue_to_string fmt av
+ ^ ")"
+ | ASharedBorrow bid -> "⌊shared@" ^ BorrowId.to_string bid ^ "⌋"
+ | AIgnoredMutBorrow av ->
+ "@ignored_mut_borrow(" ^ typed_avalue_to_string fmt av ^ ")"
+ | AEndedIgnoredMutLoan ml ->
+ "@ended_ignored_mut_borrow{ given_back="
+ ^ typed_avalue_to_string fmt ml.given_back
+ ^ "; child: "
+ ^ typed_avalue_to_string fmt ml.child
+ ^ "}"
+ | AIgnoredSharedBorrow sb ->
+ "@ignored_shared_borrow("
+ ^ abstract_shared_borrows_to_string fmt sb
+ ^ ")"
+
+ and aproj_to_string (fmt : value_formatter) (pv : aproj) : string =
+ match pv with
+ | AProjLoans sv ->
+ "proj_loans ("
+ ^ symbolic_value_to_string (value_to_rtype_formatter fmt) sv
+ ^ ")"
+ | AProjBorrows (sv, rty) ->
+ "proj_borrows (" ^ symbolic_value_proj_to_string fmt sv rty ^ ")"
end
diff --git a/src/Values.ml b/src/Values.ml
index 5ebc97b0..d63ace85 100644
--- a/src/Values.ml
+++ b/src/Values.ml
@@ -146,9 +146,9 @@ and aadt_value = {
and aloan_content =
| AMutLoan of BorrowId.id * typed_avalue
- | ASharedLoan of BorrowId.Set.t * value * typed_avalue
- | AEndedMutLoan of value * typed_avalue (* TODO: given_back, child *)
- | AEndedSharedLoan of value * typed_avalue
+ | ASharedLoan of BorrowId.Set.t * typed_value * typed_avalue
+ | AEndedMutLoan of { given_back : typed_value; child : typed_avalue }
+ | AEndedSharedLoan of typed_value * typed_avalue
| AIgnoredMutLoan of BorrowId.id * typed_avalue
| AIgnoredSharedLoan of abstract_shared_borrows
@@ -159,7 +159,7 @@ and aborrow_content =
| AMutBorrow of BorrowId.id * typed_avalue
| ASharedBorrow of BorrowId.id
| AIgnoredMutBorrow of typed_avalue
- | AEndedIgnoredMutLoan of typed_avalue * typed_avalue (* TODO: given back, child *)
+ | AEndedIgnoredMutLoan of { given_back : typed_avalue; child : typed_avalue }
| AIgnoredSharedBorrow of abstract_shared_borrows
and aassumed_value = ABox of typed_avalue