summaryrefslogtreecommitdiff
path: root/compiler/Print.ml
diff options
context:
space:
mode:
authorSon Ho2024-06-05 11:17:37 +0200
committerSon Ho2024-06-05 11:17:37 +0200
commit967c1aa8bd47e76905baeda5b9d41167af664942 (patch)
tree2f8b8bd9d6ddef3e56d3c840690e94d9322a963a /compiler/Print.ml
parent7e50cacd736fc85930bd22689fb7e2b61ddda794 (diff)
parentc708fc2556806abc95cd2ca173a94a5fb49d034d (diff)
Merge branch 'main' into son/clean-synthesis
Diffstat (limited to '')
-rw-r--r--compiler/Print.ml19
1 files changed, 15 insertions, 4 deletions
diff --git a/compiler/Print.ml b/compiler/Print.ml
index f7f1f54b..7495d6bf 100644
--- a/compiler/Print.ml
+++ b/compiler/Print.ml
@@ -148,6 +148,13 @@ module Values = struct
| AEndedProjBorrows _mv -> "_"
| AIgnoredProjBorrows -> "_"
+ (** Wrap a value inside its marker, if there is one *)
+ let add_proj_marker (pm : proj_marker) (s : string) : string =
+ match pm with
+ | PNone -> s
+ | PLeft -> "|" ^ s ^ "|"
+ | PRight -> "︙" ^ s ^ "︙"
+
let rec typed_avalue_to_string ?(span : Meta.span option = None)
(env : fmt_env) (v : typed_avalue) : string =
match v.value with
@@ -197,17 +204,19 @@ module Values = struct
and aloan_content_to_string ?(span : Meta.span option = None) (env : fmt_env)
(lc : aloan_content) : string =
match lc with
- | AMutLoan (bid, av) ->
+ | AMutLoan (pm, bid, av) ->
"@mut_loan(" ^ BorrowId.to_string bid ^ ", "
^ typed_avalue_to_string ~span env av
^ ")"
- | ASharedLoan (loans, v, av) ->
+ |> add_proj_marker pm
+ | ASharedLoan (pm, loans, v, av) ->
let loans = BorrowId.Set.to_string None loans in
"@shared_loan(" ^ loans ^ ", "
^ typed_value_to_string ~span env v
^ ", "
^ typed_avalue_to_string ~span env av
^ ")"
+ |> add_proj_marker pm
| AEndedMutLoan ml ->
"@ended_mut_loan{"
^ typed_avalue_to_string ~span env ml.child
@@ -238,11 +247,13 @@ module Values = struct
and aborrow_content_to_string ?(span : Meta.span option = None)
(env : fmt_env) (bc : aborrow_content) : string =
match bc with
- | AMutBorrow (bid, av) ->
+ | AMutBorrow (pm, bid, av) ->
"mb@" ^ BorrowId.to_string bid ^ " ("
^ typed_avalue_to_string ~span env av
^ ")"
- | ASharedBorrow bid -> "sb@" ^ BorrowId.to_string bid
+ |> add_proj_marker pm
+ | ASharedBorrow (pm, bid) ->
+ "sb@" ^ BorrowId.to_string bid |> add_proj_marker pm
| AIgnoredMutBorrow (opt_bid, av) ->
"@ignored_mut_borrow("
^ option_to_string BorrowId.to_string opt_bid