Skip to content

Commit

Permalink
Merge pull request #10 from camlspotter/jun@step-record
Browse files Browse the repository at this point in the history
Uses a record type for Michelson.step
  • Loading branch information
westpaddy authored Feb 15, 2024
2 parents 1cd9afa + b44a78d commit bb8ad2e
Show file tree
Hide file tree
Showing 9 changed files with 110 additions and 98 deletions.
26 changes: 11 additions & 15 deletions examples/auction.tzw
Original file line number Diff line number Diff line change
Expand Up @@ -24,24 +24,20 @@ scope Preambles

type or 'a 'b = Left 'a | Right 'b

type step = (address, address, address, mutez)
type step =
{ source: address;
sender: address;
self: address;
amount: mutez
}

function mk_step (source : address) (sender : address) (self : address) (amount : mutez) : step =
(source, sender, self, amount)
{ source= source;
sender= sender;
self= self;
amount= amount }

function source (st : step) : address =
match st with x, _, _, _ -> x end

function sender (st : step) : address =
match st with _, x, _, _ -> x end

function self (st : step) : address =
match st with _, _, x, _ -> x end

function amount (st : step) : mutez =
match st with _, _, _, x -> x end

predicate st_wf (st : step) =
predicate step_wf (st : step) =
st.amount >= 0

function sum_of : map address mutez -> mutez
Expand Down
26 changes: 11 additions & 15 deletions examples/boomerang.tzw
Original file line number Diff line number Diff line change
Expand Up @@ -24,24 +24,20 @@ scope Preambles

type or 'a 'b = Left 'a | Right 'b

type step = (address, address, address, mutez)
type step =
{ source: address;
sender: address;
self: address;
amount: mutez
}

function mk_step (source : address) (sender : address) (self : address) (amount : mutez) : step =
(source, sender, self, amount)
{ source= source;
sender= sender;
self= self;
amount= amount }

function source (st : step) : address =
match st with x, _, _, _ -> x end

function sender (st : step) : address =
match st with _, x, _, _ -> x end

function self (st : step) : address =
match st with _, _, x, _ -> x end

function amount (st : step) : mutez =
match st with _, _, _, x -> x end

predicate st_wf (st : step) =
predicate step_wf (st : step) =
st.amount >= 0

end
Expand Down
26 changes: 11 additions & 15 deletions examples/boomerang_acc.tzw
Original file line number Diff line number Diff line change
Expand Up @@ -24,24 +24,20 @@ scope Preambles

type or 'a 'b = Left 'a | Right 'b

type step = (address, address, address, mutez)
type step =
{ source: address;
sender: address;
self: address;
amount: mutez
}

function mk_step (source : address) (sender : address) (self : address) (amount : mutez) : step =
(source, sender, self, amount)
{ source= source;
sender= sender;
self= self;
amount= amount }

function source (st : step) : address =
match st with x, _, _, _ -> x end

function sender (st : step) : address =
match st with _, x, _, _ -> x end

function self (st : step) : address =
match st with _, _, x, _ -> x end

function amount (st : step) : mutez =
match st with _, _, _, x -> x end

predicate st_wf (st : step) =
predicate step_wf (st : step) =
st.amount >= 0

end
Expand Down
26 changes: 11 additions & 15 deletions examples/dexter2/liquidity.tzw
Original file line number Diff line number Diff line change
Expand Up @@ -24,24 +24,20 @@ scope Preambles

type or 'a 'b = Left 'a | Right 'b

type step = (address, address, address, mutez)
type step =
{ source: address;
sender: address;
self: address;
amount: mutez
}

function mk_step (source : address) (sender : address) (self : address) (amount : mutez) : step =
(source, sender, self, amount)

function source (st : step) : address =
match st with x, _, _, _ -> x end

function sender (st : step) : address =
match st with _, x, _, _ -> x end

function self (st : step) : address =
match st with _, _, x, _ -> x end

function amount (st : step) : mutez =
match st with _, _, _, x -> x end
{ source= source;
sender= sender;
self= self;
amount= amount }

predicate st_wf (st : step) =
predicate step_wf (st : step) =
st.amount >= 0

function sum_of : map address (option nat) -> nat
Expand Down
61 changes: 46 additions & 15 deletions lib/gen_mlw.ml
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ type desc = {
let ctx_ty_ident = ident "ctx"
let ctx_wf_ident = ident "ctx_wf"
let step_ty_ident = ident "step"
let step_wf_ident = ident "st_wf"
let step_wf_ident = ident "step_wf"
let spec_ident = ident "spec"
let addr_ident = ident "addr"
let param_wf_ident = ident "param_wf"
Expand Down Expand Up @@ -152,7 +152,9 @@ module E = struct
let mk_bin (e1 : expr) (o : string) (e2 : expr) : expr =
expr @@ Einnfix (e1, ident @@ Ident.op_infix o, e2)

let mk_tuple (el : expr list) : expr = expr @@ Etuple el
let _mk_tuple (el : expr list) : expr = expr @@ Etuple el

let mk_record (el : (qualid * expr) list) : expr = expr @@ Erecord el

let mk_proj (e : expr) (m : int) (n : int) : expr =
assert (m > 0 && m > n);
Expand Down Expand Up @@ -185,7 +187,10 @@ end

module Step_constant = struct
let mk source sender self amount : expr =
E.mk_tuple [ source; sender; self; amount ]
E.mk_record [ qualid ["source"], source;
qualid ["sender"], sender;
qualid ["self"], self;
qualid ["amount"], amount ]

let source st : expr = eapp (qualid [ "source" ]) [ st ]
let sender st : expr = eapp (qualid [ "sender" ]) [ st ]
Expand Down Expand Up @@ -240,7 +245,7 @@ module Generator (D : Desc) = struct
let qid_param_wf_of (c : contract) : qualid = qid_of c param_wf_ident
let qid_storage_wf_of (c : contract) : qualid = qid_of c storage_wf_ident
let call_ctx_wf (ctx : expr) : expr = eapp (qid ctx_wf_ident) [ ctx ]
let call_st_wf (st : expr) : expr = eapp (qid step_wf_ident) [ st ]
let call_step_wf (st : expr) : expr = eapp (qid step_wf_ident) [ st ]
let call_inv_pre (ctx : expr) : expr = eapp (qualid [ "inv_pre" ]) [ ctx ]

let call_inv_post (ctx : expr) (ctx' : expr) : expr =
Expand Down Expand Up @@ -320,7 +325,7 @@ module Generator (D : Desc) = struct
is_contract_of contract @@ Step_constant.self
@@ E.var_of_binder st;
call_ctx_wf @@ E.var_of_binder ctx;
call_st_wf @@ E.var_of_binder st;
call_step_wf @@ E.var_of_binder st;
call_param_wf_of contract @@ E.var_of_binder gparam;
call_pre_of contract @@ E.var_of_binder ctx;
];
Expand Down Expand Up @@ -466,7 +471,7 @@ module Generator (D : Desc) = struct
E.mk_if (E.mk_any @@ Sort.pty_of_sort Sort.S_bool) (E.var_of_binder ctx)
@@ let+ st =
E.mk_any
~ensure:(T.of_expr @@ call_st_wf @@ E.mk_var @@ ident "result")
~ensure:(T.of_expr @@ call_step_wf @@ E.mk_var @@ ident "result")
step_pty
in
let+ p = E.mk_any gparam_pty in
Expand Down Expand Up @@ -927,15 +932,41 @@ let convert_mlw (tzw : Tzw.t) =
let module G = Generator (struct
let desc = { d_contracts; d_whyml = [] }
end) in
let ty_defs = Dtype [gen_gparam epp; G.operation_ty_def] in
return
@@ Modules [ ident "Top",
tzw.tzw_preambles
@ (ty_defs :: ds)
@ [ G.ctx_ty_def; G.ctx_wf_def ]
@ tzw.tzw_postambles @ invariants
@ [ Drec (G.unknown_func_def :: G.func_def) ]
]

let decls =
List.concat
[
(* contents of [scope Preambles] *)
tzw.tzw_preambles;

[Dtype [
(* type gparam = .. *)
gen_gparam epp;

(* with operation = .. *)
G.operation_ty_def
]];

(* Scope Contract .. end *)
ds;

(* type ctx = .. *)
[G.ctx_ty_def];

(* predicate ctx_wf (ctx: ctx) = .. *)
[G.ctx_wf_def];

(* contents of [scope Postambles] *)
tzw.tzw_postambles;

(* inv_pre, inv_post, contract_pre, contract_post *)
invariants;

(* let rec ghost unknown g c .. *)
[ Drec (G.unknown_func_def :: G.func_def) ]
]
in
return @@ Modules [ ident "Top", decls ]

(* let file desc = *)
(* let module G = Generator (struct *)
Expand Down
33 changes: 15 additions & 18 deletions stdlib/michelson.mlw
Original file line number Diff line number Diff line change
Expand Up @@ -106,23 +106,20 @@ module Michelson

type or 'a 'b = Left 'a | Right 'b

type step = (address, address, address, Mutez.t)

function mk_step (source : address) (sender : address) (self : address) (amount : Mutez.t) : step =
(source, sender, self, amount)

function source (st : step) : address =
match st with x, _, _, _ -> x end

function sender (st : step) : address =
match st with _, x, _, _ -> x end

function self (st : step) : address =
match st with _, _, x, _ -> x end

function amount (st : step) : Mutez.t =
match st with _, _, _, x -> x end

predicate st_wf (st : step) = true
type step =
{ source : address;
sender : address;
self : address;
amount : mutez
}

function mk_step (source : address) (sender : address) (self : address) (amount : mutez) : step =
{ source= source;
sender= sender;
self= self;
amount= amount
}

predicate step_wf (st : step) = true

end
4 changes: 2 additions & 2 deletions test/auction.mlw
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@ let rec ghost unknown (g : int) (c : ctx) : ctx
else
if any bool then c
else
let st = any step ensures { st_wf result } in
let st = any step ensures { step_wf result } in
let dst = st.self in
let p = any param in
assume
Expand All @@ -135,7 +135,7 @@ let rec ghost unknown (g : int) (c : ctx) : ctx

with ghost auction_func (g : int) (st : step) (p : auction_param) (c : ctx) : ctx
requires { st.self = auction }
requires { st_wf st }
requires { step_wf st }
requires { ctx_wf c }
ensures { ctx_wf result }
requires { auction_sigma_pre st c }
Expand Down
4 changes: 2 additions & 2 deletions test/boomerang.mlw
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ let rec ghost unknown (g : int) (c : ctx) : ctx
else
if any bool then c
else
let st = any step ensures { st_wf result } in
let st = any step ensures { step_wf result } in
let dst = st.self in
let p = any param in
assume
Expand All @@ -74,7 +74,7 @@ let rec ghost unknown (g : int) (c : ctx) : ctx

with ghost boomerang_func (g : int) (st : step) (p : unit) (c : ctx) : ctx
requires { st.self = boomerang }
requires { st_wf st }
requires { step_wf st }
requires { ctx_wf c }
ensures { ctx_wf result }
requires { c.ledger[st.self] >= st.amount }
Expand Down
2 changes: 1 addition & 1 deletion test/dexter.mlw
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ let rec ghost unknown (g : int) (c : ctx) : ctx
else
if any bool then c
else
let st = any step ensures { st_wf result } in
let st = any step ensures { step_wf result } in
let dst = st.self in
let p = any param in
assume
Expand Down

0 comments on commit bb8ad2e

Please sign in to comment.