-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathDexter2FA12ExtractLIGO.v
127 lines (98 loc) · 4.6 KB
/
Dexter2FA12ExtractLIGO.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
(** Extraction of Dexter 2 to CameLIGO *)
From Coq Require Import List.
From Coq Require Import String.
From MetaCoq.Template Require Import All.
From ConCert.Extraction Require Import Common.
From ConCert.Extraction Require Import CameLIGOPretty.
From ConCert.Extraction Require Import CameLIGOExtract.
From ConCert.Execution Require Import Serializable.
From ConCert.Execution Require Import Blockchain.
From ConCert.Execution Require Import ResultMonad.
From ConCert.Examples.Dexter2 Require Dexter2FA12.
From ConCert.Examples.Dexter2 Require Import Dexter2CommonExtract.
From ConCert.Utils Require Import StringExtra.
Local Open Scope string_scope.
(** * Extracting Liquidity Token *)
Module Dexter2LqtExtraction.
(** Serialization plays no role in the extraction result. Therefore, we define instances
using the opaque ascription of module types to speed up the extraction *)
Module DLqtSInstancesOpaque : Dexter2FA12.Dexter2LqtSerializable := Dexter2FA12.D2LqtSInstances.
Module DEX2LQTExtract := Dexter2FA12.Dexter2Lqt DLqtSInstancesOpaque.
Open Scope Z_scope.
Import DEX2LQTExtract.
Import Dexter2FA12.
Section D2LqtE.
Context `{ChainBase}.
Definition extra_ignore :=
[ <%% @Serializable %%>
; <%% @DLqtSInstancesOpaque.setup_serializable %%>
; <%% unit_serializable %%> ].
Definition TT_Dexter2_Lqt :=
[ remap <%% @mk_callback %%> "mk_callback"
; remap <%% non_zero_amount %%> "(fun (x : tez) -> 0tez < x)"
; remap <%% @update_allowance %%> "Map.update"
; remap <%% @find_allowance %%> "Map.find_opt"
; remap <%% @empty_allowance %%> "Map.empty"
].
(** We redefine the init function, because in the Tezos blockchain
there is no concept of initialization function. However, it's common
to provide a function that computes a valid initial storage that can
be used for deployment. *)
Definition init (setup : Setup) : result State Error :=
Ok {|
tokens := ContractCommon.AddressMap.add setup.(lqt_provider)
setup.(initial_pool)
ContractCommon.AddressMap.empty;
allowances := empty_allowance;
admin := setup.(admin_);
total_supply := setup.(initial_pool);
|}.
(** We prove that the "new" init function, which does not use [chain] and [ctx],
computes the same result as the contract's init *)
Lemma init_total_no_context_use chain ctx setup :
Dexter2FA12.DEX2LQT.init_lqt chain ctx setup = init setup.
Proof. reflexivity. Qed.
Definition receive_ (chain : Chain)
(ctx : ContractCallContext)
(state : State)
(maybe_msg : option Dexter2FA12.Msg)
: result (list ActionBody * State) Error :=
match DEX2LQTExtract.receive_lqt chain ctx state maybe_msg with
| Ok x => Ok (x.2, x.1)
| Err e => Err e
end.
Definition TT_remap_all :=
(TT_remap_dexter2_arith ++ TT_remap_dexter2 ++ TT_Dexter2_Lqt)%list.
Definition LIGO_DEXTER2LQT_MODULE : CameLIGOMod Msg ContractCallContext Setup State ActionBody Error :=
{| (* a name for the definition with the extracted code *)
lmd_module_name := "cameLIGO_dexter2lqt" ;
(* definitions of operations on pairs and ints *)
lmd_prelude := CameLIGOPrelude ++ nl ++ nl ++
<$ call_to_token_ligo;
"";
mk_callback_ligo;
"";
natural_to_mutez_ligo;
"";
subNatTruncated_ligo $>;
(* initial storage *)
lmd_init := init ;
(* NOTE: printed as local [let]-bound definitions in the init *)
lmd_init_prelude := "";
lmd_receive_prelude := "";
(* the main functionality *)
lmd_receive := receive_ ;
(* code for the entry point *)
lmd_entry_point := print_default_entry_point <%% @State %%>
<%% @receive_ %%>
<%% @Msg %%>
|}.
Time MetaCoq Run
(CameLIGO_prepare_extraction TT_inlines_dexter2 TT_remap_all
TT_rename_ctors_default extra_ignore "cctx_instance" LIGO_DEXTER2LQT_MODULE).
Time Definition cameLIGO_dexter2lqt := Eval vm_compute in cameLIGO_dexter2lqt_prepared.
(** We redirect the extraction result for later processing and compiling with the CameLIGO compiler *)
Redirect "cameligo-extract/dexter2fa12.mligo"
MetaCoq Run (tmMsg (s_to_bs cameLIGO_dexter2lqt)).
End D2LqtE.
End Dexter2LqtExtraction.