Skip to content

Commit

Permalink
motoko-san: pass the correct context in dec_field'
Browse files Browse the repository at this point in the history
  • Loading branch information
DK318 committed Jun 21, 2024
1 parent 2b874b2 commit e344c84
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 25 deletions.
34 changes: 17 additions & 17 deletions src/viper/trans.ml
Original file line number Diff line number Diff line change
Expand Up @@ -336,7 +336,7 @@ and dec_field' ctxt d =
match d.M.dec.it with
(* type declarations*)
| M.(TypD (typ_id, typ_binds, {note = T.Variant cons;_})) ->
ctxt, None, None, fun _ ->
ctxt, None, None, fun ctxt ->
let adt_param tb = id tb.it.M.var in
let adt_con con = begin
{ con_name = !!! Source.no_region con.T.lab;
Expand All @@ -356,21 +356,21 @@ and dec_field' ctxt d =
{ ctxt with ids = Env.add f.it (Method, note) ctxt.ids },
None, (* no perm *)
None, (* no init *)
fun ctxt' ->
fun ctxt ->
let open Either in
let self_id = !!! (Source.no_region) "$Self" in
let method_args = args p in
let method_args' = List.map (fun (id, t) -> id, tr_typ ctxt' t) method_args in
let ctxt'' = { ctxt'
let method_args' = List.map (fun (id, t) -> id, tr_typ ctxt t) method_args in
let ctxt = { ctxt
with self = Some self_id.it;
ids = List.fold_left (fun env (id, t) -> Env.add id.it (Local, t) env) ctxt.ids method_args }
in
let stmts = stmt ctxt'' e in
let stmts = stmt ctxt e in
let _, stmts = extract_concurrency stmts in
let pres, stmts' = List.partition_map (function { it = PreconditionS exp; _ } -> Left exp | s -> Right s) (snd stmts.it) in
let posts, stmts' = List.partition_map (function { it = PostconditionS exp; _ } -> Left exp | s -> Right s) stmts' in
let arg_preds = local_access_preds ctxt'' in
let ret_preds, ret = rets ctxt'' t_opt in
let arg_preds = local_access_preds ctxt in
let ret_preds, ret = rets ctxt t_opt in
let pres = arg_preds @ pres in
let posts = arg_preds @ ret_preds @ posts in
let stmts'' = stmts' @ [!!! Source.no_region (LabelS(!!! (Source.no_region) "$Ret"))] in
Expand All @@ -383,21 +383,21 @@ and dec_field' ctxt d =
{ ctxt with ids = Env.add f.it (Method, note) ctxt.ids },
None, (* no perm *)
None, (* no init *)
fun ctxt' ->
fun ctxt ->
let open Either in
let self_id = !!! (Source.no_region) "$Self" in
let method_args = args p in
let method_args' = List.map (fun (id, t) -> id, tr_typ ctxt' t) method_args in
let ctxt'' = { ctxt'
let method_args' = List.map (fun (id, t) -> id, tr_typ ctxt t) method_args in
let ctxt = { ctxt
with self = Some self_id.it;
ids = List.fold_left (fun env (id, t) -> Env.add id.it (Local, t) env) ctxt.ids method_args }
in
let stmts = stmt ctxt'' e in
let stmts = stmt ctxt e in
let _, stmts = extract_concurrency stmts in
let pres, stmts' = List.partition_map (function { it = PreconditionS exp; _ } -> Left exp | s -> Right s) (snd stmts.it) in
let posts, stmts' = List.partition_map (function { it = PostconditionS exp; _ } -> Left exp | s -> Right s) stmts' in
let arg_preds = local_access_preds ctxt'' in
let ret_preds, ret = rets ctxt'' t_opt in
let arg_preds = local_access_preds ctxt in
let ret_preds, ret = rets ctxt t_opt in
let pres = arg_preds @ pres in
let posts = arg_preds @ ret_preds @ posts in
let stmts'' = stmts' @ [!!! Source.no_region (LabelS(!!! (Source.no_region) "$Ret"))] in
Expand All @@ -418,16 +418,16 @@ and dec_field' ctxt d =
Some (fun ctxt' -> (* init *)
let at = span x.at e.at in
assign_stmts ctxt' at (LValueFld (fldacc ctxt')) e),
(fun ctxt' ->
(FieldI(id x, tr_typ ctxt' t),
(fun ctxt ->
(FieldI(id x, tr_typ ctxt t),
NoInfo))
(* invariants *)
| M.(ExpD { it = AssertE (Invariant, e); at; _ }) ->
ctxt,
None, (* no perm *)
None, (* no init *)
fun ctxt' ->
(InvariantI (Printf.sprintf "invariant_%d" at.left.line, exp { ctxt' with self = Some "$Self" } e), NoInfo)
fun ctxt ->
(InvariantI (Printf.sprintf "invariant_%d" at.left.line, exp { ctxt with self = Some "$Self" } e), NoInfo)
| _ ->
unsupported d.M.dec.at (Arrange.dec d.M.dec)

Expand Down
8 changes: 4 additions & 4 deletions test/viper/ok/reverse.tc.ok
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
reverse.mo:32.13-32.23: warning [M0155], operator may trap for inferred type
reverse.mo:34.13-34.23: warning [M0155], operator may trap for inferred type
Nat
reverse.mo:37.35-37.47: warning [M0155], operator may trap for inferred type
reverse.mo:39.35-39.47: warning [M0155], operator may trap for inferred type
Nat
reverse.mo:37.35-37.51: warning [M0155], operator may trap for inferred type
reverse.mo:39.35-39.51: warning [M0155], operator may trap for inferred type
Nat
reverse.mo:26.9-26.10: warning [M0194], unused identifier b (delete or rename to wildcard `_` or `_b`)
reverse.mo:28.9-28.10: warning [M0194], unused identifier b (delete or rename to wildcard `_` or `_b`)
1 change: 1 addition & 0 deletions test/viper/ok/reverse.vpr.ok
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ method reverseArray$Nat($Self: Ref, a: Array)

requires $Perm($Self)
requires $array_acc(a, $int, write)
requires ($size(($Self).xarray) == 5)
ensures $Perm($Self)
ensures $array_acc(a, $int, write)
ensures ($size(a) == old($size(a)))
Expand Down
8 changes: 4 additions & 4 deletions test/viper/ok/reverse.vpr.stderr.ok
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
reverse.mo:32.13-32.23: warning [M0155], operator may trap for inferred type
reverse.mo:34.13-34.23: warning [M0155], operator may trap for inferred type
Nat
reverse.mo:37.35-37.47: warning [M0155], operator may trap for inferred type
reverse.mo:39.35-39.47: warning [M0155], operator may trap for inferred type
Nat
reverse.mo:37.35-37.51: warning [M0155], operator may trap for inferred type
reverse.mo:39.35-39.51: warning [M0155], operator may trap for inferred type
Nat
reverse.mo:26.9-26.10: warning [M0194], unused identifier b (delete or rename to wildcard `_` or `_b`)
reverse.mo:28.9-28.10: warning [M0194], unused identifier b (delete or rename to wildcard `_` or `_b`)
2 changes: 2 additions & 0 deletions test/viper/reverse.mo
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,8 @@ actor Reverse {
};

private func reverseArray<T>(a : [var T]) : () {
assert:func xarray.size() == 5;

assert:return a.size() == (old (a.size()));
assert:return Prim.forall<Nat>(
func (k : Nat) = (0 <= k and k < a.size()) implies a[k] == (old (a[a.size() - 1 - k])));
Expand Down

0 comments on commit e344c84

Please sign in to comment.