@hashgraphonline/standards-sdk 0.0.101 → 0.0.103
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/es/services/mirror-node.d.ts +102 -1
- package/dist/es/services/mirror-node.d.ts.map +1 -1
- package/dist/es/services/types.d.ts +53 -0
- package/dist/es/services/types.d.ts.map +1 -1
- package/dist/es/standards-sdk.es19.js.map +1 -1
- package/dist/es/standards-sdk.es21.js +508 -47
- package/dist/es/standards-sdk.es21.js.map +1 -1
- package/dist/es/standards-sdk.es24.js +10 -10
- package/dist/es/standards-sdk.es26.js +1 -1
- package/dist/es/standards-sdk.es28.js +1 -1
- package/dist/es/standards-sdk.es29.js +3 -3
- package/dist/es/standards-sdk.es33.js +2 -2
- package/dist/es/standards-sdk.es34.js +1 -1
- package/dist/es/standards-sdk.es35.js +2 -101
- package/dist/es/standards-sdk.es35.js.map +1 -1
- package/dist/es/standards-sdk.es36.js +195 -2
- package/dist/es/standards-sdk.es36.js.map +1 -1
- package/dist/es/standards-sdk.es37.js +437 -15
- package/dist/es/standards-sdk.es37.js.map +1 -1
- package/dist/es/standards-sdk.es38.js +20 -404
- package/dist/es/standards-sdk.es38.js.map +1 -1
- package/dist/es/standards-sdk.es39.js +139 -2
- package/dist/es/standards-sdk.es39.js.map +1 -1
- package/dist/es/standards-sdk.es40.js +18 -2282
- package/dist/es/standards-sdk.es40.js.map +1 -1
- package/dist/es/standards-sdk.es41.js +21 -156
- package/dist/es/standards-sdk.es41.js.map +1 -1
- package/dist/es/standards-sdk.es42.js +25 -80
- package/dist/es/standards-sdk.es42.js.map +1 -1
- package/dist/es/standards-sdk.es43.js +20 -22
- package/dist/es/standards-sdk.es43.js.map +1 -1
- package/dist/es/standards-sdk.es44.js +38 -142
- package/dist/es/standards-sdk.es44.js.map +1 -1
- package/dist/es/standards-sdk.es45.js +13 -86
- package/dist/es/standards-sdk.es45.js.map +1 -1
- package/dist/es/standards-sdk.es46.js +56 -190
- package/dist/es/standards-sdk.es46.js.map +1 -1
- package/dist/es/standards-sdk.es47.js +1207 -356
- package/dist/es/standards-sdk.es47.js.map +1 -1
- package/dist/es/standards-sdk.es48.js +144 -21
- package/dist/es/standards-sdk.es48.js.map +1 -1
- package/dist/es/standards-sdk.es49.js +82 -130
- package/dist/es/standards-sdk.es49.js.map +1 -1
- package/dist/es/standards-sdk.es50.js +79 -13
- package/dist/es/standards-sdk.es50.js.map +1 -1
- package/dist/es/standards-sdk.es51.js +28 -25
- package/dist/es/standards-sdk.es51.js.map +1 -1
- package/dist/es/standards-sdk.es52.js +5 -28
- package/dist/es/standards-sdk.es52.js.map +1 -1
- package/dist/es/standards-sdk.es53.js +155 -17
- package/dist/es/standards-sdk.es53.js.map +1 -1
- package/dist/es/standards-sdk.es54.js +22 -43
- package/dist/es/standards-sdk.es54.js.map +1 -1
- package/dist/es/standards-sdk.es55.js +788 -13
- package/dist/es/standards-sdk.es55.js.map +1 -1
- package/dist/es/standards-sdk.es56.js +136 -54
- package/dist/es/standards-sdk.es56.js.map +1 -1
- package/dist/es/standards-sdk.es57.js +174 -1289
- package/dist/es/standards-sdk.es57.js.map +1 -1
- package/dist/es/standards-sdk.es58.js +97 -28
- package/dist/es/standards-sdk.es58.js.map +1 -1
- package/dist/es/standards-sdk.es59.js +2 -6
- package/dist/es/standards-sdk.es59.js.map +1 -1
- package/dist/es/standards-sdk.es60.js +15 -158
- package/dist/es/standards-sdk.es60.js.map +1 -1
- package/dist/es/standards-sdk.es61.js +402 -786
- package/dist/es/standards-sdk.es61.js.map +1 -1
- package/dist/es/standards-sdk.es62.js +16 -169
- package/dist/es/standards-sdk.es62.js.map +1 -1
- package/dist/es/standards-sdk.es63.js +22 -138
- package/dist/es/standards-sdk.es63.js.map +1 -1
- package/dist/es/standards-sdk.es64.js +24 -19
- package/dist/es/standards-sdk.es64.js.map +1 -1
- package/dist/es/standards-sdk.es65.js +34 -23
- package/dist/es/standards-sdk.es65.js.map +1 -1
- package/dist/es/standards-sdk.es66.js +2282 -26
- package/dist/es/standards-sdk.es66.js.map +1 -1
- package/dist/es/standards-sdk.es67.js +163 -37
- package/dist/es/standards-sdk.es67.js.map +1 -1
- package/dist/es/standards-sdk.es69.js +7133 -1
- package/dist/es/standards-sdk.es69.js.map +1 -1
- package/dist/es/standards-sdk.es70.js +9 -7135
- package/dist/es/standards-sdk.es70.js.map +1 -1
- package/dist/es/standards-sdk.es71.js +10 -9
- package/dist/es/standards-sdk.es71.js.map +1 -1
- package/dist/es/standards-sdk.es72.js +16 -9
- package/dist/es/standards-sdk.es72.js.map +1 -1
- package/dist/es/standards-sdk.es73.js +4 -16
- package/dist/es/standards-sdk.es73.js.map +1 -1
- package/dist/es/standards-sdk.es74.js +8 -5
- package/dist/es/standards-sdk.es74.js.map +1 -1
- package/dist/es/standards-sdk.es75.js +418 -8
- package/dist/es/standards-sdk.es75.js.map +1 -1
- package/dist/es/standards-sdk.es76.js +2 -419
- package/dist/es/standards-sdk.es76.js.map +1 -1
- package/dist/es/standards-sdk.es77.js +120 -2
- package/dist/es/standards-sdk.es77.js.map +1 -1
- package/dist/es/standards-sdk.es78.js +3 -119
- package/dist/es/standards-sdk.es78.js.map +1 -1
- package/dist/es/standards-sdk.es79.js +1 -1
- package/dist/umd/services/mirror-node.d.ts +102 -1
- package/dist/umd/services/mirror-node.d.ts.map +1 -1
- package/dist/umd/services/types.d.ts +53 -0
- package/dist/umd/services/types.d.ts.map +1 -1
- package/dist/umd/standards-sdk.umd.js +12 -12
- package/dist/umd/standards-sdk.umd.js.map +1 -1
- package/package.json +2 -2
|
@@ -9,433 +9,1284 @@ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read fr
|
|
|
9
9
|
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
10
10
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
11
11
|
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
12
|
-
var
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
12
|
+
var __privateWrapper = (obj, member, setter, getter) => ({
|
|
13
|
+
set _(value) {
|
|
14
|
+
__privateSet(obj, member, value, setter);
|
|
15
|
+
},
|
|
16
|
+
get _() {
|
|
17
|
+
return __privateGet(obj, member, getter);
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
var _offset, _tokens, _TokenString_instances, subTokenString_fn, _ParamType_instances, walkAsync_fn;
|
|
21
|
+
import { assertPrivate, assert, assertArgument } from "./standards-sdk.es48.js";
|
|
22
|
+
import { defineProperties } from "./standards-sdk.es51.js";
|
|
23
|
+
import { id } from "./standards-sdk.es52.js";
|
|
24
|
+
import { getNumber, getBigInt } from "./standards-sdk.es53.js";
|
|
25
|
+
function setify(items) {
|
|
26
|
+
const result = /* @__PURE__ */ new Set();
|
|
27
|
+
items.forEach((k) => result.add(k));
|
|
28
|
+
return Object.freeze(result);
|
|
29
|
+
}
|
|
30
|
+
const _kwVisibDeploy = "external public payable override";
|
|
31
|
+
const KwVisibDeploy = setify(_kwVisibDeploy.split(" "));
|
|
32
|
+
const _kwVisib = "constant external internal payable private public pure view override";
|
|
33
|
+
const KwVisib = setify(_kwVisib.split(" "));
|
|
34
|
+
const _kwTypes = "constructor error event fallback function receive struct";
|
|
35
|
+
const KwTypes = setify(_kwTypes.split(" "));
|
|
36
|
+
const _kwModifiers = "calldata memory storage payable indexed";
|
|
37
|
+
const KwModifiers = setify(_kwModifiers.split(" "));
|
|
38
|
+
const _kwOther = "tuple returns";
|
|
39
|
+
const _keywords = [_kwTypes, _kwModifiers, _kwOther, _kwVisib].join(" ");
|
|
40
|
+
const Keywords = setify(_keywords.split(" "));
|
|
41
|
+
const SimpleTokens = {
|
|
42
|
+
"(": "OPEN_PAREN",
|
|
43
|
+
")": "CLOSE_PAREN",
|
|
44
|
+
"[": "OPEN_BRACKET",
|
|
45
|
+
"]": "CLOSE_BRACKET",
|
|
46
|
+
",": "COMMA",
|
|
47
|
+
"@": "AT"
|
|
48
|
+
};
|
|
49
|
+
const regexWhitespacePrefix = new RegExp("^(\\s*)");
|
|
50
|
+
const regexNumberPrefix = new RegExp("^([0-9]+)");
|
|
51
|
+
const regexIdPrefix = new RegExp("^([a-zA-Z$_][a-zA-Z0-9$_]*)");
|
|
52
|
+
const regexId = new RegExp("^([a-zA-Z$_][a-zA-Z0-9$_]*)$");
|
|
53
|
+
const regexType = new RegExp("^(address|bool|bytes([0-9]*)|string|u?int([0-9]*))$");
|
|
54
|
+
const _TokenString = class _TokenString {
|
|
55
|
+
constructor(tokens) {
|
|
56
|
+
__privateAdd(this, _TokenString_instances);
|
|
57
|
+
__privateAdd(this, _offset);
|
|
58
|
+
__privateAdd(this, _tokens);
|
|
59
|
+
__privateSet(this, _offset, 0);
|
|
60
|
+
__privateSet(this, _tokens, tokens.slice());
|
|
61
|
+
}
|
|
62
|
+
get offset() {
|
|
63
|
+
return __privateGet(this, _offset);
|
|
64
|
+
}
|
|
65
|
+
get length() {
|
|
66
|
+
return __privateGet(this, _tokens).length - __privateGet(this, _offset);
|
|
67
|
+
}
|
|
68
|
+
clone() {
|
|
69
|
+
return new _TokenString(__privateGet(this, _tokens));
|
|
70
|
+
}
|
|
71
|
+
reset() {
|
|
72
|
+
__privateSet(this, _offset, 0);
|
|
73
|
+
}
|
|
74
|
+
// Pops and returns the value of the next token, if it is a keyword in allowed; throws if out of tokens
|
|
75
|
+
popKeyword(allowed) {
|
|
76
|
+
const top = this.peek();
|
|
77
|
+
if (top.type !== "KEYWORD" || !allowed.has(top.text)) {
|
|
78
|
+
throw new Error(`expected keyword ${top.text}`);
|
|
79
|
+
}
|
|
80
|
+
return this.pop().text;
|
|
81
|
+
}
|
|
82
|
+
// Pops and returns the value of the next token if it is `type`; throws if out of tokens
|
|
83
|
+
popType(type) {
|
|
84
|
+
if (this.peek().type !== type) {
|
|
85
|
+
const top = this.peek();
|
|
86
|
+
throw new Error(`expected ${type}; got ${top.type} ${JSON.stringify(top.text)}`);
|
|
87
|
+
}
|
|
88
|
+
return this.pop().text;
|
|
89
|
+
}
|
|
90
|
+
// Pops and returns a "(" TOKENS ")"
|
|
91
|
+
popParen() {
|
|
92
|
+
const top = this.peek();
|
|
93
|
+
if (top.type !== "OPEN_PAREN") {
|
|
94
|
+
throw new Error("bad start");
|
|
95
|
+
}
|
|
96
|
+
const result = __privateMethod(this, _TokenString_instances, subTokenString_fn).call(this, __privateGet(this, _offset) + 1, top.match + 1);
|
|
97
|
+
__privateSet(this, _offset, top.match + 1);
|
|
98
|
+
return result;
|
|
99
|
+
}
|
|
100
|
+
// Pops and returns the items within "(" ITEM1 "," ITEM2 "," ... ")"
|
|
101
|
+
popParams() {
|
|
102
|
+
const top = this.peek();
|
|
103
|
+
if (top.type !== "OPEN_PAREN") {
|
|
104
|
+
throw new Error("bad start");
|
|
105
|
+
}
|
|
106
|
+
const result = [];
|
|
107
|
+
while (__privateGet(this, _offset) < top.match - 1) {
|
|
108
|
+
const link = this.peek().linkNext;
|
|
109
|
+
result.push(__privateMethod(this, _TokenString_instances, subTokenString_fn).call(this, __privateGet(this, _offset) + 1, link));
|
|
110
|
+
__privateSet(this, _offset, link);
|
|
111
|
+
}
|
|
112
|
+
__privateSet(this, _offset, top.match + 1);
|
|
113
|
+
return result;
|
|
114
|
+
}
|
|
115
|
+
// Returns the top Token, throwing if out of tokens
|
|
116
|
+
peek() {
|
|
117
|
+
if (__privateGet(this, _offset) >= __privateGet(this, _tokens).length) {
|
|
118
|
+
throw new Error("out-of-bounds");
|
|
119
|
+
}
|
|
120
|
+
return __privateGet(this, _tokens)[__privateGet(this, _offset)];
|
|
121
|
+
}
|
|
122
|
+
// Returns the next value, if it is a keyword in `allowed`
|
|
123
|
+
peekKeyword(allowed) {
|
|
124
|
+
const top = this.peekType("KEYWORD");
|
|
125
|
+
return top != null && allowed.has(top) ? top : null;
|
|
126
|
+
}
|
|
127
|
+
// Returns the value of the next token if it is `type`
|
|
128
|
+
peekType(type) {
|
|
129
|
+
if (this.length === 0) {
|
|
130
|
+
return null;
|
|
131
|
+
}
|
|
132
|
+
const top = this.peek();
|
|
133
|
+
return top.type === type ? top.text : null;
|
|
134
|
+
}
|
|
135
|
+
// Returns the next token; throws if out of tokens
|
|
136
|
+
pop() {
|
|
137
|
+
const result = this.peek();
|
|
138
|
+
__privateWrapper(this, _offset)._++;
|
|
139
|
+
return result;
|
|
140
|
+
}
|
|
141
|
+
toString() {
|
|
142
|
+
const tokens = [];
|
|
143
|
+
for (let i = __privateGet(this, _offset); i < __privateGet(this, _tokens).length; i++) {
|
|
144
|
+
const token = __privateGet(this, _tokens)[i];
|
|
145
|
+
tokens.push(`${token.type}:${token.text}`);
|
|
146
|
+
}
|
|
147
|
+
return `<TokenString ${tokens.join(" ")}>`;
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
_offset = new WeakMap();
|
|
151
|
+
_tokens = new WeakMap();
|
|
152
|
+
_TokenString_instances = new WeakSet();
|
|
153
|
+
subTokenString_fn = function(from = 0, to = 0) {
|
|
154
|
+
return new _TokenString(__privateGet(this, _tokens).slice(from, to).map((t) => {
|
|
155
|
+
return Object.freeze(Object.assign({}, t, {
|
|
156
|
+
match: t.match - from,
|
|
157
|
+
linkBack: t.linkBack - from,
|
|
158
|
+
linkNext: t.linkNext - from
|
|
159
|
+
}));
|
|
160
|
+
}));
|
|
161
|
+
};
|
|
162
|
+
let TokenString = _TokenString;
|
|
163
|
+
function lex(text) {
|
|
164
|
+
const tokens = [];
|
|
165
|
+
const throwError = (message) => {
|
|
166
|
+
const token = offset < text.length ? JSON.stringify(text[offset]) : "$EOI";
|
|
167
|
+
throw new Error(`invalid token ${token} at ${offset}: ${message}`);
|
|
168
|
+
};
|
|
169
|
+
let brackets = [];
|
|
170
|
+
let commas = [];
|
|
171
|
+
let offset = 0;
|
|
172
|
+
while (offset < text.length) {
|
|
173
|
+
let cur = text.substring(offset);
|
|
174
|
+
let match = cur.match(regexWhitespacePrefix);
|
|
175
|
+
if (match) {
|
|
176
|
+
offset += match[1].length;
|
|
177
|
+
cur = text.substring(offset);
|
|
178
|
+
}
|
|
179
|
+
const token = { depth: brackets.length, linkBack: -1, linkNext: -1, match: -1, type: "", text: "", offset, value: -1 };
|
|
180
|
+
tokens.push(token);
|
|
181
|
+
let type = SimpleTokens[cur[0]] || "";
|
|
182
|
+
if (type) {
|
|
183
|
+
token.type = type;
|
|
184
|
+
token.text = cur[0];
|
|
185
|
+
offset++;
|
|
186
|
+
if (type === "OPEN_PAREN") {
|
|
187
|
+
brackets.push(tokens.length - 1);
|
|
188
|
+
commas.push(tokens.length - 1);
|
|
189
|
+
} else if (type == "CLOSE_PAREN") {
|
|
190
|
+
if (brackets.length === 0) {
|
|
191
|
+
throwError("no matching open bracket");
|
|
192
|
+
}
|
|
193
|
+
token.match = brackets.pop();
|
|
194
|
+
tokens[token.match].match = tokens.length - 1;
|
|
195
|
+
token.depth--;
|
|
196
|
+
token.linkBack = commas.pop();
|
|
197
|
+
tokens[token.linkBack].linkNext = tokens.length - 1;
|
|
198
|
+
} else if (type === "COMMA") {
|
|
199
|
+
token.linkBack = commas.pop();
|
|
200
|
+
tokens[token.linkBack].linkNext = tokens.length - 1;
|
|
201
|
+
commas.push(tokens.length - 1);
|
|
202
|
+
} else if (type === "OPEN_BRACKET") {
|
|
203
|
+
token.type = "BRACKET";
|
|
204
|
+
} else if (type === "CLOSE_BRACKET") {
|
|
205
|
+
let suffix = tokens.pop().text;
|
|
206
|
+
if (tokens.length > 0 && tokens[tokens.length - 1].type === "NUMBER") {
|
|
207
|
+
const value = tokens.pop().text;
|
|
208
|
+
suffix = value + suffix;
|
|
209
|
+
tokens[tokens.length - 1].value = getNumber(value);
|
|
210
|
+
}
|
|
211
|
+
if (tokens.length === 0 || tokens[tokens.length - 1].type !== "BRACKET") {
|
|
212
|
+
throw new Error("missing opening bracket");
|
|
213
|
+
}
|
|
214
|
+
tokens[tokens.length - 1].text += suffix;
|
|
215
|
+
}
|
|
216
|
+
continue;
|
|
217
|
+
}
|
|
218
|
+
match = cur.match(regexIdPrefix);
|
|
219
|
+
if (match) {
|
|
220
|
+
token.text = match[1];
|
|
221
|
+
offset += token.text.length;
|
|
222
|
+
if (Keywords.has(token.text)) {
|
|
223
|
+
token.type = "KEYWORD";
|
|
224
|
+
continue;
|
|
225
|
+
}
|
|
226
|
+
if (token.text.match(regexType)) {
|
|
227
|
+
token.type = "TYPE";
|
|
228
|
+
continue;
|
|
229
|
+
}
|
|
230
|
+
token.type = "ID";
|
|
231
|
+
continue;
|
|
232
|
+
}
|
|
233
|
+
match = cur.match(regexNumberPrefix);
|
|
234
|
+
if (match) {
|
|
235
|
+
token.text = match[1];
|
|
236
|
+
token.type = "NUMBER";
|
|
237
|
+
offset += token.text.length;
|
|
238
|
+
continue;
|
|
239
|
+
}
|
|
240
|
+
throw new Error(`unexpected token ${JSON.stringify(cur[0])} at position ${offset}`);
|
|
241
|
+
}
|
|
242
|
+
return new TokenString(tokens.map((t) => Object.freeze(t)));
|
|
24
243
|
}
|
|
25
|
-
function
|
|
26
|
-
|
|
244
|
+
function allowSingle(set, allowed) {
|
|
245
|
+
let included = [];
|
|
246
|
+
for (const key in allowed.keys()) {
|
|
247
|
+
if (set.has(key)) {
|
|
248
|
+
included.push(key);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
if (included.length > 1) {
|
|
252
|
+
throw new Error(`conflicting types: ${included.join(", ")}`);
|
|
253
|
+
}
|
|
27
254
|
}
|
|
28
|
-
function
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
255
|
+
function consumeName(type, tokens) {
|
|
256
|
+
if (tokens.peekKeyword(KwTypes)) {
|
|
257
|
+
const keyword = tokens.pop().text;
|
|
258
|
+
if (keyword !== type) {
|
|
259
|
+
throw new Error(`expected ${type}, got ${keyword}`);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
return tokens.popType("ID");
|
|
32
263
|
}
|
|
33
|
-
function
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
264
|
+
function consumeKeywords(tokens, allowed) {
|
|
265
|
+
const keywords = /* @__PURE__ */ new Set();
|
|
266
|
+
while (true) {
|
|
267
|
+
const keyword = tokens.peekType("KEYWORD");
|
|
268
|
+
if (keyword == null || allowed && !allowed.has(keyword)) {
|
|
269
|
+
break;
|
|
270
|
+
}
|
|
271
|
+
tokens.pop();
|
|
272
|
+
if (keywords.has(keyword)) {
|
|
273
|
+
throw new Error(`duplicate keywords: ${JSON.stringify(keyword)}`);
|
|
274
|
+
}
|
|
275
|
+
keywords.add(keyword);
|
|
41
276
|
}
|
|
42
|
-
return
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
277
|
+
return Object.freeze(keywords);
|
|
278
|
+
}
|
|
279
|
+
function consumeMutability(tokens) {
|
|
280
|
+
let modifiers = consumeKeywords(tokens, KwVisib);
|
|
281
|
+
allowSingle(modifiers, setify("constant payable nonpayable".split(" ")));
|
|
282
|
+
allowSingle(modifiers, setify("pure view payable nonpayable".split(" ")));
|
|
283
|
+
if (modifiers.has("view")) {
|
|
284
|
+
return "view";
|
|
285
|
+
}
|
|
286
|
+
if (modifiers.has("pure")) {
|
|
287
|
+
return "pure";
|
|
288
|
+
}
|
|
289
|
+
if (modifiers.has("payable")) {
|
|
290
|
+
return "payable";
|
|
291
|
+
}
|
|
292
|
+
if (modifiers.has("nonpayable")) {
|
|
293
|
+
return "nonpayable";
|
|
294
|
+
}
|
|
295
|
+
if (modifiers.has("constant")) {
|
|
296
|
+
return "view";
|
|
297
|
+
}
|
|
298
|
+
return "nonpayable";
|
|
299
|
+
}
|
|
300
|
+
function consumeParams(tokens, allowIndexed) {
|
|
301
|
+
return tokens.popParams().map((t) => ParamType.from(t, allowIndexed));
|
|
302
|
+
}
|
|
303
|
+
function consumeGas(tokens) {
|
|
304
|
+
if (tokens.peekType("AT")) {
|
|
305
|
+
tokens.pop();
|
|
306
|
+
if (tokens.peekType("NUMBER")) {
|
|
307
|
+
return getBigInt(tokens.pop().text);
|
|
49
308
|
}
|
|
50
|
-
|
|
51
|
-
}
|
|
309
|
+
throw new Error("invalid gas");
|
|
310
|
+
}
|
|
311
|
+
return null;
|
|
312
|
+
}
|
|
313
|
+
function consumeEoi(tokens) {
|
|
314
|
+
if (tokens.length) {
|
|
315
|
+
throw new Error(`unexpected tokens at offset ${tokens.offset}: ${tokens.toString()}`);
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
const regexArrayType = new RegExp(/^(.*)\[([0-9]*)\]$/);
|
|
319
|
+
function verifyBasicType(type) {
|
|
320
|
+
const match = type.match(regexType);
|
|
321
|
+
assertArgument(match, "invalid type", "type", type);
|
|
322
|
+
if (type === "uint") {
|
|
323
|
+
return "uint256";
|
|
324
|
+
}
|
|
325
|
+
if (type === "int") {
|
|
326
|
+
return "int256";
|
|
327
|
+
}
|
|
328
|
+
if (match[2]) {
|
|
329
|
+
const length = parseInt(match[2]);
|
|
330
|
+
assertArgument(length !== 0 && length <= 32, "invalid bytes length", "type", type);
|
|
331
|
+
} else if (match[3]) {
|
|
332
|
+
const size = parseInt(match[3]);
|
|
333
|
+
assertArgument(size !== 0 && size <= 256 && size % 8 === 0, "invalid numeric width", "type", type);
|
|
334
|
+
}
|
|
335
|
+
return type;
|
|
52
336
|
}
|
|
53
|
-
const
|
|
337
|
+
const _guard = {};
|
|
338
|
+
const internal = Symbol.for("_ethers_internal");
|
|
339
|
+
const ParamTypeInternal = "_ParamTypeInternal";
|
|
340
|
+
const ErrorFragmentInternal = "_ErrorInternal";
|
|
341
|
+
const EventFragmentInternal = "_EventInternal";
|
|
342
|
+
const ConstructorFragmentInternal = "_ConstructorInternal";
|
|
343
|
+
const FallbackFragmentInternal = "_FallbackInternal";
|
|
344
|
+
const FunctionFragmentInternal = "_FunctionInternal";
|
|
345
|
+
const StructFragmentInternal = "_StructInternal";
|
|
346
|
+
const _ParamType = class _ParamType {
|
|
54
347
|
/**
|
|
55
348
|
* @private
|
|
56
349
|
*/
|
|
57
|
-
constructor(
|
|
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
|
-
|
|
350
|
+
constructor(guard, name, type, baseType, indexed, components, arrayLength, arrayChildren) {
|
|
351
|
+
__privateAdd(this, _ParamType_instances);
|
|
352
|
+
/**
|
|
353
|
+
* The local name of the parameter (or ``""`` if unbound)
|
|
354
|
+
*/
|
|
355
|
+
__publicField(this, "name");
|
|
356
|
+
/**
|
|
357
|
+
* The fully qualified type (e.g. ``"address"``, ``"tuple(address)"``,
|
|
358
|
+
* ``"uint256[3][]"``)
|
|
359
|
+
*/
|
|
360
|
+
__publicField(this, "type");
|
|
361
|
+
/**
|
|
362
|
+
* The base type (e.g. ``"address"``, ``"tuple"``, ``"array"``)
|
|
363
|
+
*/
|
|
364
|
+
__publicField(this, "baseType");
|
|
365
|
+
/**
|
|
366
|
+
* True if the parameters is indexed.
|
|
367
|
+
*
|
|
368
|
+
* For non-indexable types this is ``null``.
|
|
369
|
+
*/
|
|
370
|
+
__publicField(this, "indexed");
|
|
371
|
+
/**
|
|
372
|
+
* The components for the tuple.
|
|
373
|
+
*
|
|
374
|
+
* For non-tuple types this is ``null``.
|
|
375
|
+
*/
|
|
376
|
+
__publicField(this, "components");
|
|
377
|
+
/**
|
|
378
|
+
* The array length, or ``-1`` for dynamic-lengthed arrays.
|
|
379
|
+
*
|
|
380
|
+
* For non-array types this is ``null``.
|
|
381
|
+
*/
|
|
382
|
+
__publicField(this, "arrayLength");
|
|
383
|
+
/**
|
|
384
|
+
* The type of each child in the array.
|
|
385
|
+
*
|
|
386
|
+
* For non-array types this is ``null``.
|
|
387
|
+
*/
|
|
388
|
+
__publicField(this, "arrayChildren");
|
|
389
|
+
assertPrivate(guard, _guard, "ParamType");
|
|
390
|
+
Object.defineProperty(this, internal, { value: ParamTypeInternal });
|
|
391
|
+
if (components) {
|
|
392
|
+
components = Object.freeze(components.slice());
|
|
393
|
+
}
|
|
394
|
+
if (baseType === "array") {
|
|
395
|
+
if (arrayLength == null || arrayChildren == null) {
|
|
396
|
+
throw new Error("");
|
|
85
397
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
if (
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
if (!wrap) {
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
Object.freeze(this);
|
|
96
|
-
const proxy = new Proxy(this, {
|
|
97
|
-
get: (target, prop, receiver) => {
|
|
98
|
-
if (typeof prop === "string") {
|
|
99
|
-
if (prop.match(/^[0-9]+$/)) {
|
|
100
|
-
const index = getNumber(prop, "%index");
|
|
101
|
-
if (index < 0 || index >= this.length) {
|
|
102
|
-
throw new RangeError("out of result range");
|
|
103
|
-
}
|
|
104
|
-
const item = target[index];
|
|
105
|
-
if (item instanceof Error) {
|
|
106
|
-
throwError(`index ${index}`, item);
|
|
107
|
-
}
|
|
108
|
-
return item;
|
|
109
|
-
}
|
|
110
|
-
if (passProperties.indexOf(prop) >= 0) {
|
|
111
|
-
return Reflect.get(target, prop, receiver);
|
|
112
|
-
}
|
|
113
|
-
const value = target[prop];
|
|
114
|
-
if (value instanceof Function) {
|
|
115
|
-
return function(...args2) {
|
|
116
|
-
return value.apply(this === receiver ? target : this, args2);
|
|
117
|
-
};
|
|
118
|
-
} else if (!(prop in target)) {
|
|
119
|
-
return target.getValue.apply(this === receiver ? target : this, [prop]);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
return Reflect.get(target, prop, receiver);
|
|
398
|
+
} else if (arrayLength != null || arrayChildren != null) {
|
|
399
|
+
throw new Error("");
|
|
400
|
+
}
|
|
401
|
+
if (baseType === "tuple") {
|
|
402
|
+
if (components == null) {
|
|
403
|
+
throw new Error("");
|
|
123
404
|
}
|
|
405
|
+
} else if (components != null) {
|
|
406
|
+
throw new Error("");
|
|
407
|
+
}
|
|
408
|
+
defineProperties(this, {
|
|
409
|
+
name,
|
|
410
|
+
type,
|
|
411
|
+
baseType,
|
|
412
|
+
indexed,
|
|
413
|
+
components,
|
|
414
|
+
arrayLength,
|
|
415
|
+
arrayChildren
|
|
124
416
|
});
|
|
125
|
-
setNames(proxy, getNames(this));
|
|
126
|
-
return proxy;
|
|
127
417
|
}
|
|
128
418
|
/**
|
|
129
|
-
*
|
|
130
|
-
*
|
|
419
|
+
* Return a string representation of this type.
|
|
420
|
+
*
|
|
421
|
+
* For example,
|
|
422
|
+
*
|
|
423
|
+
* ``sighash" => "(uint256,address)"``
|
|
131
424
|
*
|
|
132
|
-
*
|
|
133
|
-
*
|
|
425
|
+
* ``"minimal" => "tuple(uint256,address) indexed"``
|
|
426
|
+
*
|
|
427
|
+
* ``"full" => "tuple(uint256 foo, address bar) indexed baz"``
|
|
134
428
|
*/
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
429
|
+
format(format) {
|
|
430
|
+
if (format == null) {
|
|
431
|
+
format = "sighash";
|
|
432
|
+
}
|
|
433
|
+
if (format === "json") {
|
|
434
|
+
const name = this.name || "";
|
|
435
|
+
if (this.isArray()) {
|
|
436
|
+
const result3 = JSON.parse(this.arrayChildren.format("json"));
|
|
437
|
+
result3.name = name;
|
|
438
|
+
result3.type += `[${this.arrayLength < 0 ? "" : String(this.arrayLength)}]`;
|
|
439
|
+
return JSON.stringify(result3);
|
|
140
440
|
}
|
|
141
|
-
|
|
142
|
-
|
|
441
|
+
const result2 = {
|
|
442
|
+
type: this.baseType === "tuple" ? "tuple" : this.type,
|
|
443
|
+
name
|
|
444
|
+
};
|
|
445
|
+
if (typeof this.indexed === "boolean") {
|
|
446
|
+
result2.indexed = this.indexed;
|
|
143
447
|
}
|
|
144
|
-
|
|
145
|
-
|
|
448
|
+
if (this.isTuple()) {
|
|
449
|
+
result2.components = this.components.map((c) => JSON.parse(c.format(format)));
|
|
450
|
+
}
|
|
451
|
+
return JSON.stringify(result2);
|
|
452
|
+
}
|
|
453
|
+
let result = "";
|
|
454
|
+
if (this.isArray()) {
|
|
455
|
+
result += this.arrayChildren.format(format);
|
|
456
|
+
result += `[${this.arrayLength < 0 ? "" : String(this.arrayLength)}]`;
|
|
457
|
+
} else {
|
|
458
|
+
if (this.isTuple()) {
|
|
459
|
+
result += "(" + this.components.map((comp) => comp.format(format)).join(format === "full" ? ", " : ",") + ")";
|
|
460
|
+
} else {
|
|
461
|
+
result += this.type;
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
if (format !== "sighash") {
|
|
465
|
+
if (this.indexed === true) {
|
|
466
|
+
result += " indexed";
|
|
467
|
+
}
|
|
468
|
+
if (format === "full" && this.name) {
|
|
469
|
+
result += " " + this.name;
|
|
470
|
+
}
|
|
471
|
+
}
|
|
146
472
|
return result;
|
|
147
473
|
}
|
|
148
474
|
/**
|
|
149
|
-
* Returns
|
|
150
|
-
* %%deep%%, any children which are Result objects are also
|
|
151
|
-
* converted to an Object.
|
|
475
|
+
* Returns true if %%this%% is an Array type.
|
|
152
476
|
*
|
|
153
|
-
* This
|
|
154
|
-
*
|
|
155
|
-
*/
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
477
|
+
* This provides a type gaurd ensuring that [[arrayChildren]]
|
|
478
|
+
* and [[arrayLength]] are non-null.
|
|
479
|
+
*/
|
|
480
|
+
isArray() {
|
|
481
|
+
return this.baseType === "array";
|
|
482
|
+
}
|
|
483
|
+
/**
|
|
484
|
+
* Returns true if %%this%% is a Tuple type.
|
|
485
|
+
*
|
|
486
|
+
* This provides a type gaurd ensuring that [[components]]
|
|
487
|
+
* is non-null.
|
|
488
|
+
*/
|
|
489
|
+
isTuple() {
|
|
490
|
+
return this.baseType === "tuple";
|
|
491
|
+
}
|
|
492
|
+
/**
|
|
493
|
+
* Returns true if %%this%% is an Indexable type.
|
|
494
|
+
*
|
|
495
|
+
* This provides a type gaurd ensuring that [[indexed]]
|
|
496
|
+
* is non-null.
|
|
497
|
+
*/
|
|
498
|
+
isIndexable() {
|
|
499
|
+
return this.indexed != null;
|
|
164
500
|
}
|
|
165
501
|
/**
|
|
166
|
-
*
|
|
502
|
+
* Walks the **ParamType** with %%value%%, calling %%process%%
|
|
503
|
+
* on each type, destructing the %%value%% recursively.
|
|
167
504
|
*/
|
|
168
|
-
|
|
169
|
-
if (
|
|
170
|
-
|
|
505
|
+
walk(value, process) {
|
|
506
|
+
if (this.isArray()) {
|
|
507
|
+
if (!Array.isArray(value)) {
|
|
508
|
+
throw new Error("invalid array value");
|
|
509
|
+
}
|
|
510
|
+
if (this.arrayLength !== -1 && value.length !== this.arrayLength) {
|
|
511
|
+
throw new Error("array is wrong length");
|
|
512
|
+
}
|
|
513
|
+
const _this = this;
|
|
514
|
+
return value.map((v) => _this.arrayChildren.walk(v, process));
|
|
171
515
|
}
|
|
172
|
-
if (
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
516
|
+
if (this.isTuple()) {
|
|
517
|
+
if (!Array.isArray(value)) {
|
|
518
|
+
throw new Error("invalid tuple value");
|
|
519
|
+
}
|
|
520
|
+
if (value.length !== this.components.length) {
|
|
521
|
+
throw new Error("array is wrong length");
|
|
176
522
|
}
|
|
523
|
+
const _this = this;
|
|
524
|
+
return value.map((v, i) => _this.components[i].walk(v, process));
|
|
177
525
|
}
|
|
178
|
-
|
|
179
|
-
|
|
526
|
+
return process(this.type, value);
|
|
527
|
+
}
|
|
528
|
+
/**
|
|
529
|
+
* Walks the **ParamType** with %%value%%, asynchronously calling
|
|
530
|
+
* %%process%% on each type, destructing the %%value%% recursively.
|
|
531
|
+
*
|
|
532
|
+
* This can be used to resolve ENS names by walking and resolving each
|
|
533
|
+
* ``"address"`` type.
|
|
534
|
+
*/
|
|
535
|
+
async walkAsync(value, process) {
|
|
536
|
+
const promises = [];
|
|
537
|
+
const result = [value];
|
|
538
|
+
__privateMethod(this, _ParamType_instances, walkAsync_fn).call(this, promises, value, process, (value2) => {
|
|
539
|
+
result[0] = value2;
|
|
540
|
+
});
|
|
541
|
+
if (promises.length) {
|
|
542
|
+
await Promise.all(promises);
|
|
180
543
|
}
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
544
|
+
return result[0];
|
|
545
|
+
}
|
|
546
|
+
/**
|
|
547
|
+
* Creates a new **ParamType** for %%obj%%.
|
|
548
|
+
*
|
|
549
|
+
* If %%allowIndexed%% then the ``indexed`` keyword is permitted,
|
|
550
|
+
* otherwise the ``indexed`` keyword will throw an error.
|
|
551
|
+
*/
|
|
552
|
+
static from(obj, allowIndexed) {
|
|
553
|
+
if (_ParamType.isParamType(obj)) {
|
|
554
|
+
return obj;
|
|
555
|
+
}
|
|
556
|
+
if (typeof obj === "string") {
|
|
557
|
+
try {
|
|
558
|
+
return _ParamType.from(lex(obj), allowIndexed);
|
|
559
|
+
} catch (error) {
|
|
560
|
+
assertArgument(false, "invalid param type", "obj", obj);
|
|
561
|
+
}
|
|
562
|
+
} else if (obj instanceof TokenString) {
|
|
563
|
+
let type2 = "", baseType = "";
|
|
564
|
+
let comps = null;
|
|
565
|
+
if (consumeKeywords(obj, setify(["tuple"])).has("tuple") || obj.peekType("OPEN_PAREN")) {
|
|
566
|
+
baseType = "tuple";
|
|
567
|
+
comps = obj.popParams().map((t) => _ParamType.from(t));
|
|
568
|
+
type2 = `tuple(${comps.map((c) => c.format()).join(",")})`;
|
|
569
|
+
} else {
|
|
570
|
+
type2 = verifyBasicType(obj.popType("TYPE"));
|
|
571
|
+
baseType = type2;
|
|
572
|
+
}
|
|
573
|
+
let arrayChildren = null;
|
|
574
|
+
let arrayLength = null;
|
|
575
|
+
while (obj.length && obj.peekType("BRACKET")) {
|
|
576
|
+
const bracket = obj.pop();
|
|
577
|
+
arrayChildren = new _ParamType(_guard, "", type2, baseType, null, comps, arrayLength, arrayChildren);
|
|
578
|
+
arrayLength = bracket.value;
|
|
579
|
+
type2 += bracket.text;
|
|
580
|
+
baseType = "array";
|
|
581
|
+
comps = null;
|
|
582
|
+
}
|
|
583
|
+
let indexed2 = null;
|
|
584
|
+
const keywords = consumeKeywords(obj, KwModifiers);
|
|
585
|
+
if (keywords.has("indexed")) {
|
|
586
|
+
if (!allowIndexed) {
|
|
587
|
+
throw new Error("");
|
|
588
|
+
}
|
|
589
|
+
indexed2 = true;
|
|
590
|
+
}
|
|
591
|
+
const name2 = obj.peekType("ID") ? obj.pop().text : "";
|
|
592
|
+
if (obj.length) {
|
|
593
|
+
throw new Error("leftover tokens");
|
|
185
594
|
}
|
|
595
|
+
return new _ParamType(_guard, name2, type2, baseType, indexed2, comps, arrayLength, arrayChildren);
|
|
186
596
|
}
|
|
187
|
-
|
|
188
|
-
|
|
597
|
+
const name = obj.name;
|
|
598
|
+
assertArgument(!name || typeof name === "string" && name.match(regexId), "invalid name", "obj.name", name);
|
|
599
|
+
let indexed = obj.indexed;
|
|
600
|
+
if (indexed != null) {
|
|
601
|
+
assertArgument(allowIndexed, "parameter cannot be indexed", "obj.indexed", obj.indexed);
|
|
602
|
+
indexed = !!indexed;
|
|
189
603
|
}
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
604
|
+
let type = obj.type;
|
|
605
|
+
let arrayMatch = type.match(regexArrayType);
|
|
606
|
+
if (arrayMatch) {
|
|
607
|
+
const arrayLength = parseInt(arrayMatch[2] || "-1");
|
|
608
|
+
const arrayChildren = _ParamType.from({
|
|
609
|
+
type: arrayMatch[1],
|
|
610
|
+
components: obj.components
|
|
611
|
+
});
|
|
612
|
+
return new _ParamType(_guard, name || "", type, "array", indexed, null, arrayLength, arrayChildren);
|
|
613
|
+
}
|
|
614
|
+
if (type === "tuple" || type.startsWith(
|
|
615
|
+
"tuple("
|
|
616
|
+
/* fix: ) */
|
|
617
|
+
) || type.startsWith(
|
|
618
|
+
"("
|
|
619
|
+
/* fix: ) */
|
|
620
|
+
)) {
|
|
621
|
+
const comps = obj.components != null ? obj.components.map((c) => _ParamType.from(c)) : null;
|
|
622
|
+
const tuple = new _ParamType(_guard, name || "", type, "tuple", indexed, comps, null, null);
|
|
623
|
+
return tuple;
|
|
195
624
|
}
|
|
196
|
-
|
|
625
|
+
type = verifyBasicType(obj.type);
|
|
626
|
+
return new _ParamType(_guard, name || "", type, type, indexed, null, null, null);
|
|
197
627
|
}
|
|
198
628
|
/**
|
|
199
|
-
*
|
|
629
|
+
* Returns true if %%value%% is a **ParamType**.
|
|
200
630
|
*/
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
631
|
+
static isParamType(value) {
|
|
632
|
+
return value && value[internal] === ParamTypeInternal;
|
|
633
|
+
}
|
|
634
|
+
};
|
|
635
|
+
_ParamType_instances = new WeakSet();
|
|
636
|
+
walkAsync_fn = function(promises, value, process, setValue) {
|
|
637
|
+
if (this.isArray()) {
|
|
638
|
+
if (!Array.isArray(value)) {
|
|
639
|
+
throw new Error("invalid array value");
|
|
640
|
+
}
|
|
641
|
+
if (this.arrayLength !== -1 && value.length !== this.arrayLength) {
|
|
642
|
+
throw new Error("array is wrong length");
|
|
643
|
+
}
|
|
644
|
+
const childType = this.arrayChildren;
|
|
645
|
+
const result2 = value.slice();
|
|
646
|
+
result2.forEach((value2, index) => {
|
|
647
|
+
var _a;
|
|
648
|
+
__privateMethod(_a = childType, _ParamType_instances, walkAsync_fn).call(_a, promises, value2, process, (value3) => {
|
|
649
|
+
result2[index] = value3;
|
|
650
|
+
});
|
|
651
|
+
});
|
|
652
|
+
setValue(result2);
|
|
653
|
+
return;
|
|
654
|
+
}
|
|
655
|
+
if (this.isTuple()) {
|
|
656
|
+
const components = this.components;
|
|
657
|
+
let result2;
|
|
658
|
+
if (Array.isArray(value)) {
|
|
659
|
+
result2 = value.slice();
|
|
660
|
+
} else {
|
|
661
|
+
if (value == null || typeof value !== "object") {
|
|
662
|
+
throw new Error("invalid tuple value");
|
|
663
|
+
}
|
|
664
|
+
result2 = components.map((param) => {
|
|
665
|
+
if (!param.name) {
|
|
666
|
+
throw new Error("cannot use object value with unnamed components");
|
|
667
|
+
}
|
|
668
|
+
if (!(param.name in value)) {
|
|
669
|
+
throw new Error(`missing value for component ${param.name}`);
|
|
670
|
+
}
|
|
671
|
+
return value[param.name];
|
|
672
|
+
});
|
|
673
|
+
}
|
|
674
|
+
if (result2.length !== this.components.length) {
|
|
675
|
+
throw new Error("array is wrong length");
|
|
676
|
+
}
|
|
677
|
+
result2.forEach((value2, index) => {
|
|
678
|
+
var _a;
|
|
679
|
+
__privateMethod(_a = components[index], _ParamType_instances, walkAsync_fn).call(_a, promises, value2, process, (value3) => {
|
|
680
|
+
result2[index] = value3;
|
|
681
|
+
});
|
|
682
|
+
});
|
|
683
|
+
setValue(result2);
|
|
684
|
+
return;
|
|
685
|
+
}
|
|
686
|
+
const result = process(this.type, value);
|
|
687
|
+
if (result.then) {
|
|
688
|
+
promises.push(async function() {
|
|
689
|
+
setValue(await result);
|
|
690
|
+
}());
|
|
691
|
+
} else {
|
|
692
|
+
setValue(result);
|
|
693
|
+
}
|
|
694
|
+
};
|
|
695
|
+
let ParamType = _ParamType;
|
|
696
|
+
class Fragment {
|
|
697
|
+
/**
|
|
698
|
+
* @private
|
|
699
|
+
*/
|
|
700
|
+
constructor(guard, type, inputs) {
|
|
701
|
+
/**
|
|
702
|
+
* The type of the fragment.
|
|
703
|
+
*/
|
|
704
|
+
__publicField(this, "type");
|
|
705
|
+
/**
|
|
706
|
+
* The inputs for the fragment.
|
|
707
|
+
*/
|
|
708
|
+
__publicField(this, "inputs");
|
|
709
|
+
assertPrivate(guard, _guard, "Fragment");
|
|
710
|
+
inputs = Object.freeze(inputs.slice());
|
|
711
|
+
defineProperties(this, { type, inputs });
|
|
712
|
+
}
|
|
713
|
+
/**
|
|
714
|
+
* Creates a new **Fragment** for %%obj%%, wich can be any supported
|
|
715
|
+
* ABI frgament type.
|
|
716
|
+
*/
|
|
717
|
+
static from(obj) {
|
|
718
|
+
if (typeof obj === "string") {
|
|
719
|
+
try {
|
|
720
|
+
Fragment.from(JSON.parse(obj));
|
|
721
|
+
} catch (e) {
|
|
722
|
+
}
|
|
723
|
+
return Fragment.from(lex(obj));
|
|
724
|
+
}
|
|
725
|
+
if (obj instanceof TokenString) {
|
|
726
|
+
const type = obj.peekKeyword(KwTypes);
|
|
727
|
+
switch (type) {
|
|
728
|
+
case "constructor":
|
|
729
|
+
return ConstructorFragment.from(obj);
|
|
730
|
+
case "error":
|
|
731
|
+
return ErrorFragment.from(obj);
|
|
732
|
+
case "event":
|
|
733
|
+
return EventFragment.from(obj);
|
|
734
|
+
case "fallback":
|
|
735
|
+
case "receive":
|
|
736
|
+
return FallbackFragment.from(obj);
|
|
737
|
+
case "function":
|
|
738
|
+
return FunctionFragment.from(obj);
|
|
739
|
+
case "struct":
|
|
740
|
+
return StructFragment.from(obj);
|
|
208
741
|
}
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
742
|
+
} else if (typeof obj === "object") {
|
|
743
|
+
switch (obj.type) {
|
|
744
|
+
case "constructor":
|
|
745
|
+
return ConstructorFragment.from(obj);
|
|
746
|
+
case "error":
|
|
747
|
+
return ErrorFragment.from(obj);
|
|
748
|
+
case "event":
|
|
749
|
+
return EventFragment.from(obj);
|
|
750
|
+
case "fallback":
|
|
751
|
+
case "receive":
|
|
752
|
+
return FallbackFragment.from(obj);
|
|
753
|
+
case "function":
|
|
754
|
+
return FunctionFragment.from(obj);
|
|
755
|
+
case "struct":
|
|
756
|
+
return StructFragment.from(obj);
|
|
212
757
|
}
|
|
758
|
+
assert(false, `unsupported type: ${obj.type}`, "UNSUPPORTED_OPERATION", {
|
|
759
|
+
operation: "Fragment.from"
|
|
760
|
+
});
|
|
213
761
|
}
|
|
214
|
-
|
|
762
|
+
assertArgument(false, "unsupported frgament object", "obj", obj);
|
|
763
|
+
}
|
|
764
|
+
/**
|
|
765
|
+
* Returns true if %%value%% is a [[ConstructorFragment]].
|
|
766
|
+
*/
|
|
767
|
+
static isConstructor(value) {
|
|
768
|
+
return ConstructorFragment.isFragment(value);
|
|
769
|
+
}
|
|
770
|
+
/**
|
|
771
|
+
* Returns true if %%value%% is an [[ErrorFragment]].
|
|
772
|
+
*/
|
|
773
|
+
static isError(value) {
|
|
774
|
+
return ErrorFragment.isFragment(value);
|
|
775
|
+
}
|
|
776
|
+
/**
|
|
777
|
+
* Returns true if %%value%% is an [[EventFragment]].
|
|
778
|
+
*/
|
|
779
|
+
static isEvent(value) {
|
|
780
|
+
return EventFragment.isFragment(value);
|
|
781
|
+
}
|
|
782
|
+
/**
|
|
783
|
+
* Returns true if %%value%% is a [[FunctionFragment]].
|
|
784
|
+
*/
|
|
785
|
+
static isFunction(value) {
|
|
786
|
+
return FunctionFragment.isFragment(value);
|
|
787
|
+
}
|
|
788
|
+
/**
|
|
789
|
+
* Returns true if %%value%% is a [[StructFragment]].
|
|
790
|
+
*/
|
|
791
|
+
static isStruct(value) {
|
|
792
|
+
return StructFragment.isFragment(value);
|
|
793
|
+
}
|
|
794
|
+
}
|
|
795
|
+
class NamedFragment extends Fragment {
|
|
796
|
+
/**
|
|
797
|
+
* @private
|
|
798
|
+
*/
|
|
799
|
+
constructor(guard, type, name, inputs) {
|
|
800
|
+
super(guard, type, inputs);
|
|
801
|
+
/**
|
|
802
|
+
* The name of the fragment.
|
|
803
|
+
*/
|
|
804
|
+
__publicField(this, "name");
|
|
805
|
+
assertArgument(typeof name === "string" && name.match(regexId), "invalid identifier", "name", name);
|
|
806
|
+
inputs = Object.freeze(inputs.slice());
|
|
807
|
+
defineProperties(this, { name });
|
|
808
|
+
}
|
|
809
|
+
}
|
|
810
|
+
function joinParams(format, params) {
|
|
811
|
+
return "(" + params.map((p) => p.format(format)).join(format === "full" ? ", " : ",") + ")";
|
|
812
|
+
}
|
|
813
|
+
class ErrorFragment extends NamedFragment {
|
|
814
|
+
/**
|
|
815
|
+
* @private
|
|
816
|
+
*/
|
|
817
|
+
constructor(guard, name, inputs) {
|
|
818
|
+
super(guard, "error", name, inputs);
|
|
819
|
+
Object.defineProperty(this, internal, { value: ErrorFragmentInternal });
|
|
820
|
+
}
|
|
821
|
+
/**
|
|
822
|
+
* The Custom Error selector.
|
|
823
|
+
*/
|
|
824
|
+
get selector() {
|
|
825
|
+
return id(this.format("sighash")).substring(0, 10);
|
|
215
826
|
}
|
|
216
827
|
/**
|
|
217
|
-
*
|
|
828
|
+
* Returns a string representation of this fragment as %%format%%.
|
|
218
829
|
*/
|
|
219
|
-
|
|
830
|
+
format(format) {
|
|
831
|
+
if (format == null) {
|
|
832
|
+
format = "sighash";
|
|
833
|
+
}
|
|
834
|
+
if (format === "json") {
|
|
835
|
+
return JSON.stringify({
|
|
836
|
+
type: "error",
|
|
837
|
+
name: this.name,
|
|
838
|
+
inputs: this.inputs.map((input) => JSON.parse(input.format(format)))
|
|
839
|
+
});
|
|
840
|
+
}
|
|
220
841
|
const result = [];
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
if (item instanceof Error) {
|
|
224
|
-
throwError(`index ${i}`, item);
|
|
225
|
-
}
|
|
226
|
-
result.push(callback.call(thisArg, item, i, this));
|
|
842
|
+
if (format !== "sighash") {
|
|
843
|
+
result.push("error");
|
|
227
844
|
}
|
|
228
|
-
|
|
845
|
+
result.push(this.name + joinParams(format, this.inputs));
|
|
846
|
+
return result.join(" ");
|
|
229
847
|
}
|
|
230
848
|
/**
|
|
231
|
-
* Returns
|
|
232
|
-
*
|
|
233
|
-
* Since it is possible to have a key whose name conflicts with
|
|
234
|
-
* a method on a [[Result]] or its superclass Array, or any
|
|
235
|
-
* JavaScript keyword, this ensures all named values are still
|
|
236
|
-
* accessible by name.
|
|
849
|
+
* Returns a new **ErrorFragment** for %%obj%%.
|
|
237
850
|
*/
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
return void 0;
|
|
851
|
+
static from(obj) {
|
|
852
|
+
if (ErrorFragment.isFragment(obj)) {
|
|
853
|
+
return obj;
|
|
242
854
|
}
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
855
|
+
if (typeof obj === "string") {
|
|
856
|
+
return ErrorFragment.from(lex(obj));
|
|
857
|
+
} else if (obj instanceof TokenString) {
|
|
858
|
+
const name = consumeName("error", obj);
|
|
859
|
+
const inputs = consumeParams(obj);
|
|
860
|
+
consumeEoi(obj);
|
|
861
|
+
return new ErrorFragment(_guard, name, inputs);
|
|
246
862
|
}
|
|
247
|
-
return
|
|
863
|
+
return new ErrorFragment(_guard, obj.name, obj.inputs ? obj.inputs.map(ParamType.from) : []);
|
|
248
864
|
}
|
|
249
865
|
/**
|
|
250
|
-
*
|
|
251
|
-
*
|
|
866
|
+
* Returns ``true`` and provides a type guard if %%value%% is an
|
|
867
|
+
* **ErrorFragment**.
|
|
252
868
|
*/
|
|
253
|
-
static
|
|
254
|
-
return
|
|
869
|
+
static isFragment(value) {
|
|
870
|
+
return value && value[internal] === ErrorFragmentInternal;
|
|
255
871
|
}
|
|
256
|
-
};
|
|
257
|
-
_names = new WeakMap();
|
|
258
|
-
let Result = _Result;
|
|
259
|
-
function getValue(value) {
|
|
260
|
-
let bytes = toBeArray(value);
|
|
261
|
-
assert(bytes.length <= WordSize, "value out-of-bounds", "BUFFER_OVERRUN", { buffer: bytes, length: WordSize, offset: bytes.length });
|
|
262
|
-
if (bytes.length !== WordSize) {
|
|
263
|
-
bytes = getBytesCopy(concat([Padding.slice(bytes.length % WordSize), bytes]));
|
|
264
|
-
}
|
|
265
|
-
return bytes;
|
|
266
872
|
}
|
|
267
|
-
class
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
// - Dynamic: bytes, string, address[], tuple(boolean[]), etc.
|
|
280
|
-
// - Not Dynamic: address, uint256, boolean[3], tuple(address, uint8)
|
|
281
|
-
__publicField(this, "dynamic");
|
|
282
|
-
defineProperties(this, { name, type, localName, dynamic }, {
|
|
283
|
-
name: "string",
|
|
284
|
-
type: "string",
|
|
285
|
-
localName: "string",
|
|
286
|
-
dynamic: "boolean"
|
|
287
|
-
});
|
|
873
|
+
class EventFragment extends NamedFragment {
|
|
874
|
+
/**
|
|
875
|
+
* @private
|
|
876
|
+
*/
|
|
877
|
+
constructor(guard, name, inputs, anonymous) {
|
|
878
|
+
super(guard, "event", name, inputs);
|
|
879
|
+
/**
|
|
880
|
+
* Whether this event is anonymous.
|
|
881
|
+
*/
|
|
882
|
+
__publicField(this, "anonymous");
|
|
883
|
+
Object.defineProperty(this, internal, { value: EventFragmentInternal });
|
|
884
|
+
defineProperties(this, { anonymous });
|
|
288
885
|
}
|
|
289
|
-
|
|
290
|
-
|
|
886
|
+
/**
|
|
887
|
+
* The Event topic hash.
|
|
888
|
+
*/
|
|
889
|
+
get topicHash() {
|
|
890
|
+
return id(this.format("sighash"));
|
|
291
891
|
}
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
892
|
+
/**
|
|
893
|
+
* Returns a string representation of this event as %%format%%.
|
|
894
|
+
*/
|
|
895
|
+
format(format) {
|
|
896
|
+
if (format == null) {
|
|
897
|
+
format = "sighash";
|
|
898
|
+
}
|
|
899
|
+
if (format === "json") {
|
|
900
|
+
return JSON.stringify({
|
|
901
|
+
type: "event",
|
|
902
|
+
anonymous: this.anonymous,
|
|
903
|
+
name: this.name,
|
|
904
|
+
inputs: this.inputs.map((i) => JSON.parse(i.format(format)))
|
|
905
|
+
});
|
|
906
|
+
}
|
|
907
|
+
const result = [];
|
|
908
|
+
if (format !== "sighash") {
|
|
909
|
+
result.push("event");
|
|
910
|
+
}
|
|
911
|
+
result.push(this.name + joinParams(format, this.inputs));
|
|
912
|
+
if (format !== "sighash" && this.anonymous) {
|
|
913
|
+
result.push("anonymous");
|
|
914
|
+
}
|
|
915
|
+
return result.join(" ");
|
|
304
916
|
}
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
}
|
|
917
|
+
/**
|
|
918
|
+
* Return the topic hash for an event with %%name%% and %%params%%.
|
|
919
|
+
*/
|
|
920
|
+
static getTopicHash(name, params) {
|
|
921
|
+
params = (params || []).map((p) => ParamType.from(p));
|
|
922
|
+
const fragment = new EventFragment(_guard, name, params, false);
|
|
923
|
+
return fragment.topicHash;
|
|
924
|
+
}
|
|
925
|
+
/**
|
|
926
|
+
* Returns a new **EventFragment** for %%obj%%.
|
|
927
|
+
*/
|
|
928
|
+
static from(obj) {
|
|
929
|
+
if (EventFragment.isFragment(obj)) {
|
|
930
|
+
return obj;
|
|
931
|
+
}
|
|
932
|
+
if (typeof obj === "string") {
|
|
933
|
+
try {
|
|
934
|
+
return EventFragment.from(lex(obj));
|
|
935
|
+
} catch (error) {
|
|
936
|
+
assertArgument(false, "invalid event fragment", "obj", obj);
|
|
937
|
+
}
|
|
938
|
+
} else if (obj instanceof TokenString) {
|
|
939
|
+
const name = consumeName("event", obj);
|
|
940
|
+
const inputs = consumeParams(obj, true);
|
|
941
|
+
const anonymous = !!consumeKeywords(obj, setify(["anonymous"])).has("anonymous");
|
|
942
|
+
consumeEoi(obj);
|
|
943
|
+
return new EventFragment(_guard, name, inputs, anonymous);
|
|
944
|
+
}
|
|
945
|
+
return new EventFragment(_guard, obj.name, obj.inputs ? obj.inputs.map((p) => ParamType.from(p, true)) : [], !!obj.anonymous);
|
|
946
|
+
}
|
|
947
|
+
/**
|
|
948
|
+
* Returns ``true`` and provides a type guard if %%value%% is an
|
|
949
|
+
* **EventFragment**.
|
|
950
|
+
*/
|
|
951
|
+
static isFragment(value) {
|
|
952
|
+
return value && value[internal] === EventFragmentInternal;
|
|
333
953
|
}
|
|
334
954
|
}
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
__privateAdd(this, _data2);
|
|
352
|
-
__privateAdd(this, _offset);
|
|
353
|
-
__privateAdd(this, _bytesRead);
|
|
354
|
-
__privateAdd(this, _parent);
|
|
355
|
-
__privateAdd(this, _maxInflation);
|
|
356
|
-
defineProperties(this, { allowLoose: !!allowLoose });
|
|
357
|
-
__privateSet(this, _data2, getBytesCopy(data));
|
|
358
|
-
__privateSet(this, _bytesRead, 0);
|
|
359
|
-
__privateSet(this, _parent, null);
|
|
360
|
-
__privateSet(this, _maxInflation, maxInflation != null ? maxInflation : 1024);
|
|
361
|
-
__privateSet(this, _offset, 0);
|
|
955
|
+
class ConstructorFragment extends Fragment {
|
|
956
|
+
/**
|
|
957
|
+
* @private
|
|
958
|
+
*/
|
|
959
|
+
constructor(guard, type, inputs, payable, gas) {
|
|
960
|
+
super(guard, type, inputs);
|
|
961
|
+
/**
|
|
962
|
+
* Whether the constructor can receive an endowment.
|
|
963
|
+
*/
|
|
964
|
+
__publicField(this, "payable");
|
|
965
|
+
/**
|
|
966
|
+
* The recommended gas limit for deployment or ``null``.
|
|
967
|
+
*/
|
|
968
|
+
__publicField(this, "gas");
|
|
969
|
+
Object.defineProperty(this, internal, { value: ConstructorFragmentInternal });
|
|
970
|
+
defineProperties(this, { payable, gas });
|
|
362
971
|
}
|
|
363
|
-
|
|
364
|
-
|
|
972
|
+
/**
|
|
973
|
+
* Returns a string representation of this constructor as %%format%%.
|
|
974
|
+
*/
|
|
975
|
+
format(format) {
|
|
976
|
+
assert(format != null && format !== "sighash", "cannot format a constructor for sighash", "UNSUPPORTED_OPERATION", { operation: "format(sighash)" });
|
|
977
|
+
if (format === "json") {
|
|
978
|
+
return JSON.stringify({
|
|
979
|
+
type: "constructor",
|
|
980
|
+
stateMutability: this.payable ? "payable" : "undefined",
|
|
981
|
+
payable: this.payable,
|
|
982
|
+
gas: this.gas != null ? this.gas : void 0,
|
|
983
|
+
inputs: this.inputs.map((i) => JSON.parse(i.format(format)))
|
|
984
|
+
});
|
|
985
|
+
}
|
|
986
|
+
const result = [`constructor${joinParams(format, this.inputs)}`];
|
|
987
|
+
if (this.payable) {
|
|
988
|
+
result.push("payable");
|
|
989
|
+
}
|
|
990
|
+
if (this.gas != null) {
|
|
991
|
+
result.push(`@${this.gas.toString()}`);
|
|
992
|
+
}
|
|
993
|
+
return result.join(" ");
|
|
365
994
|
}
|
|
366
|
-
|
|
367
|
-
|
|
995
|
+
/**
|
|
996
|
+
* Returns a new **ConstructorFragment** for %%obj%%.
|
|
997
|
+
*/
|
|
998
|
+
static from(obj) {
|
|
999
|
+
if (ConstructorFragment.isFragment(obj)) {
|
|
1000
|
+
return obj;
|
|
1001
|
+
}
|
|
1002
|
+
if (typeof obj === "string") {
|
|
1003
|
+
try {
|
|
1004
|
+
return ConstructorFragment.from(lex(obj));
|
|
1005
|
+
} catch (error) {
|
|
1006
|
+
assertArgument(false, "invalid constuctor fragment", "obj", obj);
|
|
1007
|
+
}
|
|
1008
|
+
} else if (obj instanceof TokenString) {
|
|
1009
|
+
consumeKeywords(obj, setify(["constructor"]));
|
|
1010
|
+
const inputs = consumeParams(obj);
|
|
1011
|
+
const payable = !!consumeKeywords(obj, KwVisibDeploy).has("payable");
|
|
1012
|
+
const gas = consumeGas(obj);
|
|
1013
|
+
consumeEoi(obj);
|
|
1014
|
+
return new ConstructorFragment(_guard, "constructor", inputs, payable, gas);
|
|
1015
|
+
}
|
|
1016
|
+
return new ConstructorFragment(_guard, "constructor", obj.inputs ? obj.inputs.map(ParamType.from) : [], !!obj.payable, obj.gas != null ? obj.gas : null);
|
|
368
1017
|
}
|
|
369
|
-
|
|
370
|
-
|
|
1018
|
+
/**
|
|
1019
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1020
|
+
* **ConstructorFragment**.
|
|
1021
|
+
*/
|
|
1022
|
+
static isFragment(value) {
|
|
1023
|
+
return value && value[internal] === ConstructorFragmentInternal;
|
|
1024
|
+
}
|
|
1025
|
+
}
|
|
1026
|
+
class FallbackFragment extends Fragment {
|
|
1027
|
+
constructor(guard, inputs, payable) {
|
|
1028
|
+
super(guard, "fallback", inputs);
|
|
1029
|
+
/**
|
|
1030
|
+
* If the function can be sent value during invocation.
|
|
1031
|
+
*/
|
|
1032
|
+
__publicField(this, "payable");
|
|
1033
|
+
Object.defineProperty(this, internal, { value: FallbackFragmentInternal });
|
|
1034
|
+
defineProperties(this, { payable });
|
|
371
1035
|
}
|
|
372
|
-
|
|
373
|
-
|
|
1036
|
+
/**
|
|
1037
|
+
* Returns a string representation of this fallback as %%format%%.
|
|
1038
|
+
*/
|
|
1039
|
+
format(format) {
|
|
1040
|
+
const type = this.inputs.length === 0 ? "receive" : "fallback";
|
|
1041
|
+
if (format === "json") {
|
|
1042
|
+
const stateMutability = this.payable ? "payable" : "nonpayable";
|
|
1043
|
+
return JSON.stringify({ type, stateMutability });
|
|
1044
|
+
}
|
|
1045
|
+
return `${type}()${this.payable ? " payable" : ""}`;
|
|
374
1046
|
}
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
1047
|
+
/**
|
|
1048
|
+
* Returns a new **FallbackFragment** for %%obj%%.
|
|
1049
|
+
*/
|
|
1050
|
+
static from(obj) {
|
|
1051
|
+
if (FallbackFragment.isFragment(obj)) {
|
|
1052
|
+
return obj;
|
|
1053
|
+
}
|
|
1054
|
+
if (typeof obj === "string") {
|
|
1055
|
+
try {
|
|
1056
|
+
return FallbackFragment.from(lex(obj));
|
|
1057
|
+
} catch (error) {
|
|
1058
|
+
assertArgument(false, "invalid fallback fragment", "obj", obj);
|
|
1059
|
+
}
|
|
1060
|
+
} else if (obj instanceof TokenString) {
|
|
1061
|
+
const errorObj = obj.toString();
|
|
1062
|
+
const topIsValid = obj.peekKeyword(setify(["fallback", "receive"]));
|
|
1063
|
+
assertArgument(topIsValid, "type must be fallback or receive", "obj", errorObj);
|
|
1064
|
+
const type = obj.popKeyword(setify(["fallback", "receive"]));
|
|
1065
|
+
if (type === "receive") {
|
|
1066
|
+
const inputs2 = consumeParams(obj);
|
|
1067
|
+
assertArgument(inputs2.length === 0, `receive cannot have arguments`, "obj.inputs", inputs2);
|
|
1068
|
+
consumeKeywords(obj, setify(["payable"]));
|
|
1069
|
+
consumeEoi(obj);
|
|
1070
|
+
return new FallbackFragment(_guard, [], true);
|
|
1071
|
+
}
|
|
1072
|
+
let inputs = consumeParams(obj);
|
|
1073
|
+
if (inputs.length) {
|
|
1074
|
+
assertArgument(inputs.length === 1 && inputs[0].type === "bytes", "invalid fallback inputs", "obj.inputs", inputs.map((i) => i.format("minimal")).join(", "));
|
|
1075
|
+
} else {
|
|
1076
|
+
inputs = [ParamType.from("bytes")];
|
|
1077
|
+
}
|
|
1078
|
+
const mutability = consumeMutability(obj);
|
|
1079
|
+
assertArgument(mutability === "nonpayable" || mutability === "payable", "fallback cannot be constants", "obj.stateMutability", mutability);
|
|
1080
|
+
if (consumeKeywords(obj, setify(["returns"])).has("returns")) {
|
|
1081
|
+
const outputs = consumeParams(obj);
|
|
1082
|
+
assertArgument(outputs.length === 1 && outputs[0].type === "bytes", "invalid fallback outputs", "obj.outputs", outputs.map((i) => i.format("minimal")).join(", "));
|
|
1083
|
+
}
|
|
1084
|
+
consumeEoi(obj);
|
|
1085
|
+
return new FallbackFragment(_guard, inputs, mutability === "payable");
|
|
1086
|
+
}
|
|
1087
|
+
if (obj.type === "receive") {
|
|
1088
|
+
return new FallbackFragment(_guard, [], true);
|
|
1089
|
+
}
|
|
1090
|
+
if (obj.type === "fallback") {
|
|
1091
|
+
const inputs = [ParamType.from("bytes")];
|
|
1092
|
+
const payable = obj.stateMutability === "payable";
|
|
1093
|
+
return new FallbackFragment(_guard, inputs, payable);
|
|
1094
|
+
}
|
|
1095
|
+
assertArgument(false, "invalid fallback description", "obj", obj);
|
|
380
1096
|
}
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
return
|
|
1097
|
+
/**
|
|
1098
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1099
|
+
* **FallbackFragment**.
|
|
1100
|
+
*/
|
|
1101
|
+
static isFragment(value) {
|
|
1102
|
+
return value && value[internal] === FallbackFragmentInternal;
|
|
387
1103
|
}
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
1104
|
+
}
|
|
1105
|
+
class FunctionFragment extends NamedFragment {
|
|
1106
|
+
/**
|
|
1107
|
+
* @private
|
|
1108
|
+
*/
|
|
1109
|
+
constructor(guard, name, stateMutability, inputs, outputs, gas) {
|
|
1110
|
+
super(guard, "function", name, inputs);
|
|
1111
|
+
/**
|
|
1112
|
+
* If the function is constant (e.g. ``pure`` or ``view`` functions).
|
|
1113
|
+
*/
|
|
1114
|
+
__publicField(this, "constant");
|
|
1115
|
+
/**
|
|
1116
|
+
* The returned types for the result of calling this function.
|
|
1117
|
+
*/
|
|
1118
|
+
__publicField(this, "outputs");
|
|
1119
|
+
/**
|
|
1120
|
+
* The state mutability (e.g. ``payable``, ``nonpayable``, ``view``
|
|
1121
|
+
* or ``pure``)
|
|
1122
|
+
*/
|
|
1123
|
+
__publicField(this, "stateMutability");
|
|
1124
|
+
/**
|
|
1125
|
+
* If the function can be sent value during invocation.
|
|
1126
|
+
*/
|
|
1127
|
+
__publicField(this, "payable");
|
|
1128
|
+
/**
|
|
1129
|
+
* The recommended gas limit to send when calling this function.
|
|
1130
|
+
*/
|
|
1131
|
+
__publicField(this, "gas");
|
|
1132
|
+
Object.defineProperty(this, internal, { value: FunctionFragmentInternal });
|
|
1133
|
+
outputs = Object.freeze(outputs.slice());
|
|
1134
|
+
const constant = stateMutability === "view" || stateMutability === "pure";
|
|
1135
|
+
const payable = stateMutability === "payable";
|
|
1136
|
+
defineProperties(this, { constant, gas, outputs, payable, stateMutability });
|
|
391
1137
|
}
|
|
392
|
-
|
|
393
|
-
|
|
1138
|
+
/**
|
|
1139
|
+
* The Function selector.
|
|
1140
|
+
*/
|
|
1141
|
+
get selector() {
|
|
1142
|
+
return id(this.format("sighash")).substring(0, 10);
|
|
394
1143
|
}
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
info: {
|
|
413
|
-
bytesRead: __privateGet(this, _bytesRead),
|
|
414
|
-
dataLength: this.dataLength
|
|
415
|
-
}
|
|
416
|
-
});
|
|
417
|
-
};
|
|
418
|
-
peekBytes_fn = function(offset, length, loose) {
|
|
419
|
-
let alignedLength = Math.ceil(length / WordSize) * WordSize;
|
|
420
|
-
if (__privateGet(this, _offset) + alignedLength > __privateGet(this, _data2).length) {
|
|
421
|
-
if (this.allowLoose && loose && __privateGet(this, _offset) + length <= __privateGet(this, _data2).length) {
|
|
422
|
-
alignedLength = length;
|
|
423
|
-
} else {
|
|
424
|
-
assert(false, "data out-of-bounds", "BUFFER_OVERRUN", {
|
|
425
|
-
buffer: getBytesCopy(__privateGet(this, _data2)),
|
|
426
|
-
length: __privateGet(this, _data2).length,
|
|
427
|
-
offset: __privateGet(this, _offset) + alignedLength
|
|
1144
|
+
/**
|
|
1145
|
+
* Returns a string representation of this function as %%format%%.
|
|
1146
|
+
*/
|
|
1147
|
+
format(format) {
|
|
1148
|
+
if (format == null) {
|
|
1149
|
+
format = "sighash";
|
|
1150
|
+
}
|
|
1151
|
+
if (format === "json") {
|
|
1152
|
+
return JSON.stringify({
|
|
1153
|
+
type: "function",
|
|
1154
|
+
name: this.name,
|
|
1155
|
+
constant: this.constant,
|
|
1156
|
+
stateMutability: this.stateMutability !== "nonpayable" ? this.stateMutability : void 0,
|
|
1157
|
+
payable: this.payable,
|
|
1158
|
+
gas: this.gas != null ? this.gas : void 0,
|
|
1159
|
+
inputs: this.inputs.map((i) => JSON.parse(i.format(format))),
|
|
1160
|
+
outputs: this.outputs.map((o) => JSON.parse(o.format(format)))
|
|
428
1161
|
});
|
|
429
1162
|
}
|
|
1163
|
+
const result = [];
|
|
1164
|
+
if (format !== "sighash") {
|
|
1165
|
+
result.push("function");
|
|
1166
|
+
}
|
|
1167
|
+
result.push(this.name + joinParams(format, this.inputs));
|
|
1168
|
+
if (format !== "sighash") {
|
|
1169
|
+
if (this.stateMutability !== "nonpayable") {
|
|
1170
|
+
result.push(this.stateMutability);
|
|
1171
|
+
}
|
|
1172
|
+
if (this.outputs && this.outputs.length) {
|
|
1173
|
+
result.push("returns");
|
|
1174
|
+
result.push(joinParams(format, this.outputs));
|
|
1175
|
+
}
|
|
1176
|
+
if (this.gas != null) {
|
|
1177
|
+
result.push(`@${this.gas.toString()}`);
|
|
1178
|
+
}
|
|
1179
|
+
}
|
|
1180
|
+
return result.join(" ");
|
|
430
1181
|
}
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
1182
|
+
/**
|
|
1183
|
+
* Return the selector for a function with %%name%% and %%params%%.
|
|
1184
|
+
*/
|
|
1185
|
+
static getSelector(name, params) {
|
|
1186
|
+
params = (params || []).map((p) => ParamType.from(p));
|
|
1187
|
+
const fragment = new FunctionFragment(_guard, name, "view", params, [], null);
|
|
1188
|
+
return fragment.selector;
|
|
1189
|
+
}
|
|
1190
|
+
/**
|
|
1191
|
+
* Returns a new **FunctionFragment** for %%obj%%.
|
|
1192
|
+
*/
|
|
1193
|
+
static from(obj) {
|
|
1194
|
+
if (FunctionFragment.isFragment(obj)) {
|
|
1195
|
+
return obj;
|
|
1196
|
+
}
|
|
1197
|
+
if (typeof obj === "string") {
|
|
1198
|
+
try {
|
|
1199
|
+
return FunctionFragment.from(lex(obj));
|
|
1200
|
+
} catch (error) {
|
|
1201
|
+
assertArgument(false, "invalid function fragment", "obj", obj);
|
|
1202
|
+
}
|
|
1203
|
+
} else if (obj instanceof TokenString) {
|
|
1204
|
+
const name = consumeName("function", obj);
|
|
1205
|
+
const inputs = consumeParams(obj);
|
|
1206
|
+
const mutability = consumeMutability(obj);
|
|
1207
|
+
let outputs = [];
|
|
1208
|
+
if (consumeKeywords(obj, setify(["returns"])).has("returns")) {
|
|
1209
|
+
outputs = consumeParams(obj);
|
|
1210
|
+
}
|
|
1211
|
+
const gas = consumeGas(obj);
|
|
1212
|
+
consumeEoi(obj);
|
|
1213
|
+
return new FunctionFragment(_guard, name, mutability, inputs, outputs, gas);
|
|
1214
|
+
}
|
|
1215
|
+
let stateMutability = obj.stateMutability;
|
|
1216
|
+
if (stateMutability == null) {
|
|
1217
|
+
stateMutability = "payable";
|
|
1218
|
+
if (typeof obj.constant === "boolean") {
|
|
1219
|
+
stateMutability = "view";
|
|
1220
|
+
if (!obj.constant) {
|
|
1221
|
+
stateMutability = "payable";
|
|
1222
|
+
if (typeof obj.payable === "boolean" && !obj.payable) {
|
|
1223
|
+
stateMutability = "nonpayable";
|
|
1224
|
+
}
|
|
1225
|
+
}
|
|
1226
|
+
} else if (typeof obj.payable === "boolean" && !obj.payable) {
|
|
1227
|
+
stateMutability = "nonpayable";
|
|
1228
|
+
}
|
|
1229
|
+
}
|
|
1230
|
+
return new FunctionFragment(_guard, obj.name, stateMutability, obj.inputs ? obj.inputs.map(ParamType.from) : [], obj.outputs ? obj.outputs.map(ParamType.from) : [], obj.gas != null ? obj.gas : null);
|
|
1231
|
+
}
|
|
1232
|
+
/**
|
|
1233
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1234
|
+
* **FunctionFragment**.
|
|
1235
|
+
*/
|
|
1236
|
+
static isFragment(value) {
|
|
1237
|
+
return value && value[internal] === FunctionFragmentInternal;
|
|
1238
|
+
}
|
|
1239
|
+
}
|
|
1240
|
+
class StructFragment extends NamedFragment {
|
|
1241
|
+
/**
|
|
1242
|
+
* @private
|
|
1243
|
+
*/
|
|
1244
|
+
constructor(guard, name, inputs) {
|
|
1245
|
+
super(guard, "struct", name, inputs);
|
|
1246
|
+
Object.defineProperty(this, internal, { value: StructFragmentInternal });
|
|
1247
|
+
}
|
|
1248
|
+
/**
|
|
1249
|
+
* Returns a string representation of this struct as %%format%%.
|
|
1250
|
+
*/
|
|
1251
|
+
format() {
|
|
1252
|
+
throw new Error("@TODO");
|
|
1253
|
+
}
|
|
1254
|
+
/**
|
|
1255
|
+
* Returns a new **StructFragment** for %%obj%%.
|
|
1256
|
+
*/
|
|
1257
|
+
static from(obj) {
|
|
1258
|
+
if (typeof obj === "string") {
|
|
1259
|
+
try {
|
|
1260
|
+
return StructFragment.from(lex(obj));
|
|
1261
|
+
} catch (error) {
|
|
1262
|
+
assertArgument(false, "invalid struct fragment", "obj", obj);
|
|
1263
|
+
}
|
|
1264
|
+
} else if (obj instanceof TokenString) {
|
|
1265
|
+
const name = consumeName("struct", obj);
|
|
1266
|
+
const inputs = consumeParams(obj);
|
|
1267
|
+
consumeEoi(obj);
|
|
1268
|
+
return new StructFragment(_guard, name, inputs);
|
|
1269
|
+
}
|
|
1270
|
+
return new StructFragment(_guard, obj.name, obj.inputs ? obj.inputs.map(ParamType.from) : []);
|
|
1271
|
+
}
|
|
1272
|
+
// @TODO: fix this return type
|
|
1273
|
+
/**
|
|
1274
|
+
* Returns ``true`` and provides a type guard if %%value%% is a
|
|
1275
|
+
* **StructFragment**.
|
|
1276
|
+
*/
|
|
1277
|
+
static isFragment(value) {
|
|
1278
|
+
return value && value[internal] === StructFragmentInternal;
|
|
1279
|
+
}
|
|
1280
|
+
}
|
|
434
1281
|
export {
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
1282
|
+
ConstructorFragment,
|
|
1283
|
+
ErrorFragment,
|
|
1284
|
+
EventFragment,
|
|
1285
|
+
FallbackFragment,
|
|
1286
|
+
Fragment,
|
|
1287
|
+
FunctionFragment,
|
|
1288
|
+
NamedFragment,
|
|
1289
|
+
ParamType,
|
|
1290
|
+
StructFragment
|
|
440
1291
|
};
|
|
441
1292
|
//# sourceMappingURL=standards-sdk.es47.js.map
|