summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSon Ho2021-12-07 16:53:45 +0100
committerSon Ho2021-12-07 16:53:45 +0100
commit54c48b00f70343a46575890c262f28c09e00e043 (patch)
tree21f20c47907ba8d7928326bdd349046e594d3d57
parentb9afd4e2e8737497825408b015b4467fdb0adecf (diff)
Rewrite lookup_loan_opt with visitors
-rw-r--r--src/Interpreter.ml27
1 files changed, 8 insertions, 19 deletions
diff --git a/src/Interpreter.ml b/src/Interpreter.ml
index 9787af65..d97ab5a8 100644
--- a/src/Interpreter.ml
+++ b/src/Interpreter.ml
@@ -118,12 +118,15 @@ let loans_in_value (v : V.typed_value) : bool =
false
with Found -> true
-(** Lookup a loan content in a value *)
-let lookup_loan_in_value (ek : exploration_kind) (l : V.BorrowId.id)
- (v : V.typed_value) : V.loan_content option =
+(** Lookup a loan content.
+
+ The loan is referred to by a borrow id.
+ *)
+let lookup_loan_opt (ek : exploration_kind) (l : V.BorrowId.id) (env : C.env) :
+ V.loan_content option =
let obj =
object
- inherit [_] V.iter_typed_value as super
+ inherit [_] C.iter_env_concrete as super
method! visit_MutBorrow env bid mv =
if ek.enter_mut_borrows then super#visit_MutBorrow env bid mv else ()
@@ -147,27 +150,13 @@ let lookup_loan_in_value (ek : exploration_kind) (l : V.BorrowId.id)
in
(* We use exceptions *)
try
- obj#visit_typed_value () v;
+ obj#visit_env () env;
None
with FoundLoanContent lc -> Some lc
(** Lookup a loan content.
The loan is referred to by a borrow id.
- *)
-let lookup_loan_opt (ek : exploration_kind) (l : V.BorrowId.id) (env : C.env) :
- V.loan_content option =
- let lookup_loan_in_env_value (ev : C.env_value) : V.loan_content option =
- match ev with
- | C.Var (_, v) -> lookup_loan_in_value ek l v
- | C.Abs _ -> raise Unimplemented (* TODO *)
- | C.Frame -> None
- in
- List.find_map lookup_loan_in_env_value env
-
-(** Lookup a loan content.
-
- The loan is referred to by a borrow id.
Raises an exception if no loan was found.
*)
let lookup_loan (ek : exploration_kind) (l : V.BorrowId.id) (env : C.env) :