4
31 -1<< constant wc_undef
8
{ wcid@ 2dup <> swap wc_undef <> and
9
abort"workchain_id already set to another value"
10
wcid! } : setworkchain
11
{ globalid@ 2dup <> swap and
12
abort"global_id already set to another value"
13
dup 0= abort"global_id cannot be zero"
14
globalid! } : setglobalid
16
<b b> constant empty_cell
18
variable @default-subwallet-id
19
@default-subwallet-id 0!
20
{ @default-subwallet-id @ } : default-subwallet-id
21
{ @default-subwallet-id ! } : default-subwallet-id!
23
// b x --> b' ( serializes a Gram amount )
24
{ -1 { 1+ 2dup 8 * ufits } until
25
rot over 4 u, -rot 8 * u, } : Gram,
27
// workchain-id -- wc-zero-state
28
{ <b x{9023afe2} s, globalid@ 32 i, 0 8 i, swap 32 i, 1 63 << 64 u,
29
0 64 i, now 32 u, 0 64 i, -1 32 i, <b 0 67 u, b> ref, 0 1 u,
31
<b 0 128 10 + 1+ 1+ u, b> ref, 0 1 u, b>
32
dup isShardState? not abort"invalid ShardState created"
37
{ <b swap 1 u, over ref, b> <s swap hash rot 256 udict!+
38
0= abort"duplicate library in collection" } : lib+
39
{ 0 lib+ } : private_lib
40
{ 1 lib+ } : public_lib
42
{ (configdict) 0= abort"Configuration dictionary is empty" } : configdict
44
// version capabilities --
45
{ <b x{c4} s, rot 32 u, swap 64 u, b> 8 config! } : config.version!
47
2 constant capCreateStats
48
4 constant capBounceMsgBody
49
8 constant capReportVersion
50
16 constant capSplitMergeTransactions
51
32 constant capShortDequeue
53
// max-validators masterchain-validators min-validators --
54
{ swap rot <b swap 16 u, swap 16 u, swap 16 u, b> 16 config! } : config.validator_num!
56
// min-stake max-stake min-total-stake max-factor --
57
{ 4 0 reverse <b swap Gram, swap Gram, swap Gram, swap 32 u, b>
59
} : config.validator_stake_limits!
61
// elected-for elections-begin-before elections-end-before stakes-frozen
62
{ 4 0 reverse <b { swap 32 u, } 4 times b> 15 config! } : config.election_params!
64
variable validator-dict
65
dictnew 0 validator-dict 2!
66
variable validators-weight
69
{ validator-dict @ second } : validator#
70
{ dup 0<= abort"validator weight must be non-negative"
71
64 ufits not abort"validator weight must fit into 64 bits"
73
// ( val-pubkey weight -- c )
75
over Blen 32 <> abort"validator public key must be 32 bytes long"
76
<b x{538e81278a} s, rot B, swap 64 u, b>
77
} : serialize-validator
78
// ( val-pubkey adnl weight -- c )
80
over 256 ufits not abort"adnl address must fit into 256 bits"
81
rot dup Blen 32 <> abort"validator public key must be 32 bytes long"
82
<b x{738e81278a} s, swap B, swap 64 u, swap 256 u, b>
83
} : serialize-adnl-validator
84
// ( weight val-cell -- )
85
{ swap validators-weight +!
86
<s validator-dict 2@ dup 1+ 3 -roll swap
87
16 udict!+ 0= abort"cannot add validator"
88
swap validator-dict 2!
90
// val-pubkey weight --
91
{ tuck serialize-validator register-validator } : add-validator
92
// val-pubkey adnl-addr weight --
93
{ -rot 2 pick serialize-adnl-validator register-validator
95
// since-ut until-ut main-val-cnt-or-0 --
96
{ ?dup 0= { validator# } if
97
validator# 0= abort"no initial validators defined"
98
rot <b x{12} s, swap 32 u, rot 32 u, validator# 16 u, swap 16 u,
99
validators-weight @ 64 u, validator-dict @ first dict, b>
101
} : config.validators!
103
variable workchain-dict
104
// root-hash file-hash enable-utime actual-min-split min-split max-split workchain-id --
105
{ <b x{a6} s, 5 roll 32 u, 4 roll 8 u, 3 roll 8 u, rot 8 u, x{e000} s,
106
3 roll 256 u, rot 256 u, 0 32 u, x{1} s, -1 32 i, 0 64 u, b>
107
dup isWorkchainDescr? not abort"invalid WorkchainDescr created"
108
<s swap workchain-dict @ 32 idict!+ 0= abort"cannot add workchain"
112
{ workchain-dict @ dict>s s>c 12 config! } : config.workchains!
115
// special-smc-addr --
116
{ x{} swap special-dict @ 256 udict! not abort"cannot add a new special smart contract"
119
{ special-dict @ dict>s s>c 31 config! } : config.special!
121
// ( l -- D ) Converts a list of parameter indices into a dictionary
122
{ dictnew { swap uncons -rot <b swap rot 32 b>idict! not abort"cannot add parameter index" over null?
124
} : param-list-to-dict
125
{ param-list-to-dict 9 config! } : config.mandatory_params!
126
{ param-list-to-dict 10 config! } : config.critical_params!
128
// min_tot_rounds max_tot_rounds min_wins max_losses min_store_sec max_store_sec bit_price cell_price --
129
{ 8 untuple 8 0 reverse <b x{36} s, { swap 8 u, } 4 times { swap 32 u, } 4 times b> } : cfg-prop-setup
130
// normal-prop-params critical-prop-params --
131
{ swap cfg-prop-setup swap cfg-prop-setup <b x{91} s, rot ref, swap ref, b> } : make-proposals-setup
132
{ make-proposals-setup 11 config! } : config.param_proposals_setup!
134
// deposit bit_pps cell_pps
135
{ 3 0 reverse <b x{1a} s, swap Gram, swap Gram, swap Gram, b> } : create-complaint-pricing
136
{ create-complaint-pricing 13 config! } : config.complaint_prices!
138
// bit-pps cell-pps mc-bit-pps mc-cell-pps --
139
{ <b x{cc} s, 0 32 u, 4 roll 64 u, 3 roll 64 u, rot 64 u, swap 64 u,
140
0 dictnew 32 b>udict! 0= abort"cannot create storage prices dictionary"
141
<b swap <s s, b> 18 config!
142
} : config.storage_prices!
145
{ bl word (number) ?dup 0= abort"not a valid 2^16-based fraction"
146
1- { sg*/ } { sg* } cond
150
// gas_price gas_limit spec_limit gas_credit block_gas_limit freeze_due_limit delete_due_limit b -- c
151
{ 7 1 reverse x{de} s, { swap 64 u, } 7 times b>
152
} : make-gas-prices-basic
153
// gas_price ... delete_due_limit flat_gas_limit flat_gas_rate -- c
154
{ 2dup or { <b x{d1} s, rot 64 u, swap 64 u, } { 2drop <b } cond
155
make-gas-prices-basic
157
{ make-gas-prices 20 config! } : config.mc_gas_prices!
158
{ make-gas-prices 21 config! } : config.gas_prices!
160
// lump_price bit_price cell_price ihr_factor first_frac next_frac
161
{ 6 0 reverse <b x{ea} s, swap 64 u, swap 64 u, swap 64 u, swap 32 u, swap 16 u, swap 16 u, b>
162
} : make-msg-fwd-prices
163
{ make-msg-fwd-prices 24 config! } : config.mc_fwd_prices!
164
{ make-msg-fwd-prices 25 config! } : config.fwd_prices!
166
// mc-cc-lifetime sh-cc-lifetime sh-val-lifetime sh-val-num mc-shuffle
167
{ 4 1 reverse <b x{c201_} s, swap 1 i, swap 32 u, swap 32 u, swap 32 u, swap 32 u, b>
168
} : make-catchain-params
169
{ make-catchain-params 28 config! } : config.catchain_params!
170
// round-candidates next-cand-delay-ms consensus-timeout-ms fast-attempts attempt-duration cc-max-deps max-block-size max-collated-size new-cc-ids
171
{ 8 1 reverse <b x{d701_} s, swap 1 i, swap 8 u, { swap 32 u, } 7 times b> } : make-vsession-params
172
{ make-vsession-params 29 config! } : config.consensus_params!
174
// b [underload soft hard] -- b'
175
{ untriple 3 roll x{c3} s, 3 roll 32 u, rot 32 u, swap 32 u, } : param_limits,
176
// bytes-limits gas-limits lt-limits -- c
177
{ <b x{5d} s, 3 roll param_limits, rot param_limits, swap param_limits, b>
179
{ make-block-limits 22 config! } : config.mc_block_limits!
180
{ make-block-limits 23 config! } : config.block_limits!
182
// mc-block-create-fee bc-block-create-fee
183
{ <b x{6b} s, rot Gram, swap Gram, b> } : make-block-create-fees
184
{ make-block-create-fees 14 config! } : config.block_create_fees!
186
{ <b swap 256 u, b> } : make-smc-addr-cell
187
{ make-smc-addr-cell 0 config! } : config.config_smc!
188
{ make-smc-addr-cell 1 config! } : config.elector_smc!
189
{ make-smc-addr-cell 2 config! } : config.minter_smc!
190
{ make-smc-addr-cell 3 config! } : config.collector_smc!
192
{ <b swap dict, b> 7 config! } : config.to_mint!
194
1000000000 constant Gram
195
1000000 constant mGram
202
{ Gram swap */r } : Gram*/
203
{ mGram swap */r } : mGram*/
204
{ uGram swap */r } : uGram*/
207
// GR$.17 is equivalent to 170000000
208
{ bl word (number) ?dup 0= abort"not a valid Gram amount"
209
1- { Gram swap */r } { Gram * } cond
222
{ 1000 swap */r } : */K
223
{ 1000000 swap */r } : */M
224
{ 1000000000 swap */r } : */G
226
0 constant recv_internal
227
-1 constant recv_external
228
-2 constant run_ticktock
229
-3 constant split_prepare
230
-4 constant split_install
232
// public key conversion
235
// restricted wallet creation
237
// same as in new-wallet-v3.fif
238
"wallet-v3-code.fif" include
241
"auto/wallet-code.fif" include =: WCode0
242
"auto/restricted-wallet-code.fif" include =: RWCode1
243
"auto/restricted-wallet2-code.fif" include =: RWCode2
244
"auto/restricted-wallet3-code.fif" include =: RWCode3
247
{ over ."Key " pubkey>$ type ." -> "
249
<b 1 32 u, 3 roll 256 u, b> // data
256
Masterchain swap 6 .Addr cr
260
{ over ."W0 Key " pubkey>$ type space dup .GR ." -> "
262
<b 0 32 u, default-subwallet-id 32 u, 3 roll 256 u, b> // data
266
Masterchain swap 6 .Addr cr
270
{ <b rot Gram, swap rot 32 b>idict! not abort"cannot add value"
273
{ 365 * days* } : years*
276
over 31 -1<< rdict-entry
277
over 3/4 */ 91 days* rdict-entry
278
over 1/2 */ 183 days* rdict-entry
279
swap 1/4 */ 365 days* rdict-entry
280
0 548 days* rdict-entry
283
over 31 -1<< rdict-entry
284
over .9 */ 0 rdict-entry
285
over .6775 */ 1 years* rdict-entry
286
over .445 */ 2 years* rdict-entry
287
swap .2225 */ 3 years* rdict-entry
288
0 4 years* 86400 + rdict-entry
292
{ 'make-rdict @ execute } : make-rdict
294
variable rwallet-start-at rwallet-start-at 0!
295
now 86400 / 1+ 86400 * rwallet-start-at !
298
{ over ."Key " pubkey>$ type ." -> "
300
<b 1 32 u, 3 pick 256 u, rwallet-start-at @ 32 u,
301
3 roll make-rdict dict, b> // data
308
Masterchain swap 6 .Addr cr
311
variable rwallet-init-pubkey
315
<b 0 32 u, default-subwallet-id 32 u,
316
rwallet-init-pubkey @ 256 u,
321
0 0 0 register_smc // compute address only
322
} : precompute-wallet3-addr
326
// pubkey amount 'rdict --
327
{ 'make-rdict ! over precompute-wallet3-addr w3-addr !
328
over ."RW3 Key " pubkey>$ type space dup .GR ." -> "
330
<b 1 32 u, default-subwallet-id 32 u, 3 roll 256 u, rwallet-start-at @ 32 u,
331
2 pick make-rdict dict, b> // data
337
6 // mode: create+setaddr
339
Masterchain swap 6 .Addr cr
340
} : create-wallet3-internal
342
{ ' make-rdict1 create-wallet3-internal } : create-wallet3
343
{ ' make-rdict2 create-wallet3-internal } : create-wallet3b
346
{ over ."Key " pubkey>$ type space dup .GR ." -> "
348
<b 1 32 u, 3 roll 256 u, b> // data
355
Masterchain swap 6 .Addr cr
358
{ dup tlb-type-lookup { nip } { "unknown TLB type " swap $+ abort } cond } : $>tlb
359
{ bl word $>tlb 1 'nop } ::_ tlb:
360
{ <b swap vmcont, b> <s tlb:VmCont tlb-dump-as } : vmcont.