@hashgraphonline/standards-sdk 0.0.54 → 0.0.56
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/hcs-10/browser.d.ts +1 -1
- package/dist/es/hcs-10/browser.d.ts.map +1 -1
- package/dist/es/hcs-10/sdk.d.ts +1 -1
- package/dist/es/hcs-10/sdk.d.ts.map +1 -1
- package/dist/es/standards-sdk.es10.js +2 -2
- package/dist/es/standards-sdk.es10.js.map +1 -1
- package/dist/es/standards-sdk.es100.js +3 -5
- package/dist/es/standards-sdk.es100.js.map +1 -1
- package/dist/es/standards-sdk.es101.js +13 -156
- package/dist/es/standards-sdk.es101.js.map +1 -1
- package/dist/es/standards-sdk.es102.js +4 -22
- package/dist/es/standards-sdk.es102.js.map +1 -1
- package/dist/es/standards-sdk.es103.js +37 -791
- package/dist/es/standards-sdk.es103.js.map +1 -1
- package/dist/es/standards-sdk.es104.js +36 -170
- package/dist/es/standards-sdk.es104.js.map +1 -1
- package/dist/es/standards-sdk.es105.js +34 -140
- package/dist/es/standards-sdk.es105.js.map +1 -1
- package/dist/es/standards-sdk.es106.js +75 -31
- package/dist/es/standards-sdk.es106.js.map +1 -1
- package/dist/es/standards-sdk.es107.js +3 -33
- package/dist/es/standards-sdk.es107.js.map +1 -1
- package/dist/es/standards-sdk.es108.js +2 -9
- package/dist/es/standards-sdk.es108.js.map +1 -1
- package/dist/es/standards-sdk.es109.js +2 -34
- package/dist/es/standards-sdk.es109.js.map +1 -1
- package/dist/es/standards-sdk.es110.js +33 -20
- package/dist/es/standards-sdk.es110.js.map +1 -1
- package/dist/es/standards-sdk.es111.js +32 -26
- package/dist/es/standards-sdk.es111.js.map +1 -1
- package/dist/es/standards-sdk.es112.js +9 -26
- package/dist/es/standards-sdk.es112.js.map +1 -1
- package/dist/es/standards-sdk.es113.js +33 -37
- package/dist/es/standards-sdk.es113.js.map +1 -1
- package/dist/es/standards-sdk.es13.js +1 -1
- package/dist/es/standards-sdk.es16.js +1 -1
- package/dist/es/standards-sdk.es17.js +2 -2
- package/dist/es/standards-sdk.es20.js +1 -1
- package/dist/es/standards-sdk.es22.js +10 -10
- package/dist/es/standards-sdk.es23.js +36 -6627
- package/dist/es/standards-sdk.es23.js.map +1 -1
- package/dist/es/standards-sdk.es24.js +48 -36
- package/dist/es/standards-sdk.es24.js.map +1 -1
- package/dist/es/standards-sdk.es25.js +5 -48
- package/dist/es/standards-sdk.es25.js.map +1 -1
- package/dist/es/standards-sdk.es26.js +6627 -2
- package/dist/es/standards-sdk.es26.js.map +1 -1
- package/dist/es/standards-sdk.es27.js +2 -5
- package/dist/es/standards-sdk.es27.js.map +1 -1
- package/dist/es/standards-sdk.es28.js +87 -405
- package/dist/es/standards-sdk.es28.js.map +1 -1
- package/dist/es/standards-sdk.es29.js +2 -2
- package/dist/es/standards-sdk.es30.js +15 -119
- package/dist/es/standards-sdk.es30.js.map +1 -1
- package/dist/es/standards-sdk.es31.js +409 -3
- package/dist/es/standards-sdk.es31.js.map +1 -1
- package/dist/es/standards-sdk.es32.js +399 -144
- package/dist/es/standards-sdk.es32.js.map +1 -1
- package/dist/es/standards-sdk.es33.js +2 -101
- package/dist/es/standards-sdk.es33.js.map +1 -1
- package/dist/es/standards-sdk.es34.js +120 -2
- package/dist/es/standards-sdk.es34.js.map +1 -1
- package/dist/es/standards-sdk.es35.js +2282 -16
- package/dist/es/standards-sdk.es35.js.map +1 -1
- package/dist/es/standards-sdk.es36.js +155 -400
- package/dist/es/standards-sdk.es36.js.map +1 -1
- package/dist/es/standards-sdk.es37.js +2 -4
- package/dist/es/standards-sdk.es37.js.map +1 -1
- package/dist/es/standards-sdk.es38.js +4 -2282
- package/dist/es/standards-sdk.es38.js.map +1 -1
- package/dist/es/standards-sdk.es39.js +68 -348
- package/dist/es/standards-sdk.es39.js.map +1 -1
- package/dist/es/standards-sdk.es40.js +22 -5
- package/dist/es/standards-sdk.es40.js.map +1 -1
- package/dist/es/standards-sdk.es41.js +135 -166
- package/dist/es/standards-sdk.es41.js.map +1 -1
- package/dist/es/standards-sdk.es42.js +82 -72
- package/dist/es/standards-sdk.es42.js.map +1 -1
- package/dist/es/standards-sdk.es43.js +165 -105
- package/dist/es/standards-sdk.es43.js.map +1 -1
- package/dist/es/standards-sdk.es44.js +5 -51
- package/dist/es/standards-sdk.es44.js.map +1 -1
- package/dist/es/standards-sdk.es45.js +142 -9
- package/dist/es/standards-sdk.es45.js.map +1 -1
- package/dist/es/standards-sdk.es46.js +26 -91
- package/dist/es/standards-sdk.es46.js.map +1 -1
- package/dist/es/standards-sdk.es47.js +158 -3
- package/dist/es/standards-sdk.es47.js.map +1 -1
- package/dist/es/standards-sdk.es48.js +195 -2
- package/dist/es/standards-sdk.es48.js.map +1 -1
- package/dist/es/standards-sdk.es49.js +423 -98
- package/dist/es/standards-sdk.es49.js.map +1 -1
- package/dist/es/standards-sdk.es5.js +4 -4
- package/dist/es/standards-sdk.es5.js.map +1 -1
- package/dist/es/standards-sdk.es50.js +22 -71
- package/dist/es/standards-sdk.es50.js.map +1 -1
- package/dist/es/standards-sdk.es51.js +138 -5
- package/dist/es/standards-sdk.es51.js.map +1 -1
- package/dist/es/standards-sdk.es52.js +17 -4
- package/dist/es/standards-sdk.es52.js.map +1 -1
- package/dist/es/standards-sdk.es53.js +21 -213
- package/dist/es/standards-sdk.es53.js.map +1 -1
- package/dist/es/standards-sdk.es54.js +27 -56
- package/dist/es/standards-sdk.es54.js.map +1 -1
- package/dist/es/standards-sdk.es55.js +21 -69
- package/dist/es/standards-sdk.es55.js.map +1 -1
- package/dist/es/standards-sdk.es56.js +38 -26
- package/dist/es/standards-sdk.es56.js.map +1 -1
- package/dist/es/standards-sdk.es57.js +13 -58
- package/dist/es/standards-sdk.es57.js.map +1 -1
- package/dist/es/standards-sdk.es58.js +57 -46
- package/dist/es/standards-sdk.es58.js.map +1 -1
- package/dist/es/standards-sdk.es59.js +1287 -8
- package/dist/es/standards-sdk.es59.js.map +1 -1
- package/dist/es/standards-sdk.es60.js +787 -59
- package/dist/es/standards-sdk.es60.js.map +1 -1
- package/dist/es/standards-sdk.es61.js +363 -5
- package/dist/es/standards-sdk.es61.js.map +1 -1
- package/dist/es/standards-sdk.es62.js +5 -14
- package/dist/es/standards-sdk.es62.js.map +1 -1
- package/dist/es/standards-sdk.es63.js +179 -7
- package/dist/es/standards-sdk.es63.js.map +1 -1
- package/dist/es/standards-sdk.es64.js +78 -42
- package/dist/es/standards-sdk.es64.js.map +1 -1
- package/dist/es/standards-sdk.es65.js +114 -2
- package/dist/es/standards-sdk.es65.js.map +1 -1
- package/dist/es/standards-sdk.es66.js +51 -135
- package/dist/es/standards-sdk.es66.js.map +1 -1
- package/dist/es/standards-sdk.es67.js +9 -171
- package/dist/es/standards-sdk.es67.js.map +1 -1
- package/dist/es/standards-sdk.es68.js +97 -13
- package/dist/es/standards-sdk.es68.js.map +1 -1
- package/dist/es/standards-sdk.es69.js +4 -13
- package/dist/es/standards-sdk.es69.js.map +1 -1
- package/dist/es/standards-sdk.es70.js +2 -2
- package/dist/es/standards-sdk.es70.js.map +1 -1
- package/dist/es/standards-sdk.es71.js +111 -30
- package/dist/es/standards-sdk.es71.js.map +1 -1
- package/dist/es/standards-sdk.es72.js +73 -14
- package/dist/es/standards-sdk.es72.js.map +1 -1
- package/dist/es/standards-sdk.es73.js +5 -3
- package/dist/es/standards-sdk.es73.js.map +1 -1
- package/dist/es/standards-sdk.es74.js +4 -3
- package/dist/es/standards-sdk.es74.js.map +1 -1
- package/dist/es/standards-sdk.es75.js +219 -14
- package/dist/es/standards-sdk.es75.js.map +1 -1
- package/dist/es/standards-sdk.es76.js +58 -5
- package/dist/es/standards-sdk.es76.js.map +1 -1
- package/dist/es/standards-sdk.es77.js +68 -38
- package/dist/es/standards-sdk.es77.js.map +1 -1
- package/dist/es/standards-sdk.es78.js +3 -40
- package/dist/es/standards-sdk.es78.js.map +1 -1
- package/dist/es/standards-sdk.es79.js +26 -36
- package/dist/es/standards-sdk.es79.js.map +1 -1
- package/dist/es/standards-sdk.es8.js +2 -2
- package/dist/es/standards-sdk.es80.js +25 -77
- package/dist/es/standards-sdk.es80.js.map +1 -1
- package/dist/es/standards-sdk.es81.js +38 -3
- package/dist/es/standards-sdk.es81.js.map +1 -1
- package/dist/es/standards-sdk.es82.js +21 -2
- package/dist/es/standards-sdk.es82.js.map +1 -1
- package/dist/es/standards-sdk.es83.js +32 -2
- package/dist/es/standards-sdk.es83.js.map +1 -1
- package/dist/es/standards-sdk.es84.js +44 -176
- package/dist/es/standards-sdk.es84.js.map +1 -1
- package/dist/es/standards-sdk.es85.js +47 -435
- package/dist/es/standards-sdk.es85.js.map +1 -1
- package/dist/es/standards-sdk.es86.js +9 -24
- package/dist/es/standards-sdk.es86.js.map +1 -1
- package/dist/es/standards-sdk.es87.js +57 -131
- package/dist/es/standards-sdk.es87.js.map +1 -1
- package/dist/es/standards-sdk.es88.js +6 -18
- package/dist/es/standards-sdk.es88.js.map +1 -1
- package/dist/es/standards-sdk.es89.js +14 -28
- package/dist/es/standards-sdk.es89.js.map +1 -1
- package/dist/es/standards-sdk.es9.js +1 -1
- package/dist/es/standards-sdk.es90.js +7 -29
- package/dist/es/standards-sdk.es90.js.map +1 -1
- package/dist/es/standards-sdk.es91.js +44 -20
- package/dist/es/standards-sdk.es91.js.map +1 -1
- package/dist/es/standards-sdk.es92.js +2 -44
- package/dist/es/standards-sdk.es92.js.map +1 -1
- package/dist/es/standards-sdk.es93.js +136 -18
- package/dist/es/standards-sdk.es93.js.map +1 -1
- package/dist/es/standards-sdk.es94.js +165 -54
- package/dist/es/standards-sdk.es94.js.map +1 -1
- package/dist/es/standards-sdk.es95.js +11 -1287
- package/dist/es/standards-sdk.es95.js.map +1 -1
- package/dist/es/standards-sdk.es96.js +13 -148
- package/dist/es/standards-sdk.es96.js.map +1 -1
- package/dist/es/standards-sdk.es97.js +29 -88
- package/dist/es/standards-sdk.es97.js.map +1 -1
- package/dist/es/standards-sdk.es98.js +14 -83
- package/dist/es/standards-sdk.es98.js.map +1 -1
- package/dist/es/standards-sdk.es99.js +3 -31
- package/dist/es/standards-sdk.es99.js.map +1 -1
- package/dist/umd/hcs-10/browser.d.ts +1 -1
- package/dist/umd/hcs-10/browser.d.ts.map +1 -1
- package/dist/umd/hcs-10/sdk.d.ts +1 -1
- package/dist/umd/hcs-10/sdk.d.ts.map +1 -1
- package/dist/umd/standards-sdk.umd.js +1 -1
- package/dist/umd/standards-sdk.umd.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,100 +1,35 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
}
|
|
7
|
-
let resolvePromise;
|
|
8
|
-
this.promise = new Promise(function promiseExecutor(resolve) {
|
|
9
|
-
resolvePromise = resolve;
|
|
10
|
-
});
|
|
11
|
-
const token = this;
|
|
12
|
-
this.promise.then((cancel) => {
|
|
13
|
-
if (!token._listeners) return;
|
|
14
|
-
let i = token._listeners.length;
|
|
15
|
-
while (i-- > 0) {
|
|
16
|
-
token._listeners[i](cancel);
|
|
17
|
-
}
|
|
18
|
-
token._listeners = null;
|
|
19
|
-
});
|
|
20
|
-
this.promise.then = (onfulfilled) => {
|
|
21
|
-
let _resolve;
|
|
22
|
-
const promise = new Promise((resolve) => {
|
|
23
|
-
token.subscribe(resolve);
|
|
24
|
-
_resolve = resolve;
|
|
25
|
-
}).then(onfulfilled);
|
|
26
|
-
promise.cancel = function reject() {
|
|
27
|
-
token.unsubscribe(_resolve);
|
|
28
|
-
};
|
|
29
|
-
return promise;
|
|
30
|
-
};
|
|
31
|
-
executor(function cancel(message, config, request) {
|
|
32
|
-
if (token.reason) {
|
|
1
|
+
function checkType(value, type, name) {
|
|
2
|
+
const types = type.split("|").map((t) => t.trim());
|
|
3
|
+
for (let i = 0; i < types.length; i++) {
|
|
4
|
+
switch (type) {
|
|
5
|
+
case "any":
|
|
33
6
|
return;
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
*/
|
|
42
|
-
throwIfRequested() {
|
|
43
|
-
if (this.reason) {
|
|
44
|
-
throw this.reason;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Subscribe to the cancel signal
|
|
49
|
-
*/
|
|
50
|
-
subscribe(listener) {
|
|
51
|
-
if (this.reason) {
|
|
52
|
-
listener(this.reason);
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
if (this._listeners) {
|
|
56
|
-
this._listeners.push(listener);
|
|
57
|
-
} else {
|
|
58
|
-
this._listeners = [listener];
|
|
7
|
+
case "bigint":
|
|
8
|
+
case "boolean":
|
|
9
|
+
case "number":
|
|
10
|
+
case "string":
|
|
11
|
+
if (typeof value === type) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
59
14
|
}
|
|
60
15
|
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
16
|
+
const error = new Error(`invalid value for type ${type}`);
|
|
17
|
+
error.code = "INVALID_ARGUMENT";
|
|
18
|
+
error.argument = `value.${name}`;
|
|
19
|
+
error.value = value;
|
|
20
|
+
throw error;
|
|
21
|
+
}
|
|
22
|
+
function defineProperties(target, values, types) {
|
|
23
|
+
for (let key in values) {
|
|
24
|
+
let value = values[key];
|
|
25
|
+
const type = types ? types[key] : null;
|
|
26
|
+
if (type) {
|
|
27
|
+
checkType(value, type, key);
|
|
71
28
|
}
|
|
72
|
-
|
|
73
|
-
toAbortSignal() {
|
|
74
|
-
const controller = new AbortController();
|
|
75
|
-
const abort = (err) => {
|
|
76
|
-
controller.abort(err);
|
|
77
|
-
};
|
|
78
|
-
this.subscribe(abort);
|
|
79
|
-
controller.signal.unsubscribe = () => this.unsubscribe(abort);
|
|
80
|
-
return controller.signal;
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Returns an object that contains a new `CancelToken` and a function that, when called,
|
|
84
|
-
* cancels the `CancelToken`.
|
|
85
|
-
*/
|
|
86
|
-
static source() {
|
|
87
|
-
let cancel;
|
|
88
|
-
const token = new CancelToken(function executor(c) {
|
|
89
|
-
cancel = c;
|
|
90
|
-
});
|
|
91
|
-
return {
|
|
92
|
-
token,
|
|
93
|
-
cancel
|
|
94
|
-
};
|
|
29
|
+
Object.defineProperty(target, key, { enumerable: true, value, writable: false });
|
|
95
30
|
}
|
|
96
31
|
}
|
|
97
32
|
export {
|
|
98
|
-
|
|
33
|
+
defineProperties
|
|
99
34
|
};
|
|
100
35
|
//# sourceMappingURL=standards-sdk.es46.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es46.js","sources":["../../node_modules/
|
|
1
|
+
{"version":3,"file":"standards-sdk.es46.js","sources":["../../node_modules/ethers/lib.esm/utils/properties.js"],"sourcesContent":["/**\n * Property helper functions.\n *\n * @_subsection api/utils:Properties [about-properties]\n */\nfunction checkType(value, type, name) {\n const types = type.split(\"|\").map(t => t.trim());\n for (let i = 0; i < types.length; i++) {\n switch (type) {\n case \"any\":\n return;\n case \"bigint\":\n case \"boolean\":\n case \"number\":\n case \"string\":\n if (typeof (value) === type) {\n return;\n }\n }\n }\n const error = new Error(`invalid value for type ${type}`);\n error.code = \"INVALID_ARGUMENT\";\n error.argument = `value.${name}`;\n error.value = value;\n throw error;\n}\n/**\n * Resolves to a new object that is a copy of %%value%%, but with all\n * values resolved.\n */\nexport async function resolveProperties(value) {\n const keys = Object.keys(value);\n const results = await Promise.all(keys.map((k) => Promise.resolve(value[k])));\n return results.reduce((accum, v, index) => {\n accum[keys[index]] = v;\n return accum;\n }, {});\n}\n/**\n * Assigns the %%values%% to %%target%% as read-only values.\n *\n * It %%types%% is specified, the values are checked.\n */\nexport function defineProperties(target, values, types) {\n for (let key in values) {\n let value = values[key];\n const type = (types ? types[key] : null);\n if (type) {\n checkType(value, type, key);\n }\n Object.defineProperty(target, key, { enumerable: true, value, writable: false });\n }\n}\n//# sourceMappingURL=properties.js.map"],"names":[],"mappings":"AAKA,SAAS,UAAU,OAAO,MAAM,MAAM;AAClC,QAAM,QAAQ,KAAK,MAAM,GAAG,EAAE,IAAI,OAAK,EAAE,MAAM;AAC/C,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACnC,YAAQ,MAAI;AAAA,MACR,KAAK;AACD;AAAA,MACJ,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACD,YAAI,OAAQ,UAAW,MAAM;AACzB;AAAA,QACpB;AAAA,IACA;AAAA,EACA;AACI,QAAM,QAAQ,IAAI,MAAM,0BAA0B,IAAI,EAAE;AACxD,QAAM,OAAO;AACb,QAAM,WAAW,SAAS,IAAI;AAC9B,QAAM,QAAQ;AACd,QAAM;AACV;AAkBO,SAAS,iBAAiB,QAAQ,QAAQ,OAAO;AACpD,WAAS,OAAO,QAAQ;AACpB,QAAI,QAAQ,OAAO,GAAG;AACtB,UAAM,OAAQ,QAAQ,MAAM,GAAG,IAAI;AACnC,QAAI,MAAM;AACN,gBAAU,OAAO,MAAM,GAAG;AAAA,IACtC;AACQ,WAAO,eAAe,QAAQ,KAAK,EAAE,YAAY,MAAM,OAAO,UAAU,OAAO;AAAA,EACvF;AACA;","x_google_ignoreList":[0]}
|
|
@@ -1,7 +1,162 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { assertArgument, assert } from "./standards-sdk.es41.js";
|
|
2
|
+
const BN_0 = BigInt(0);
|
|
3
|
+
const BN_1 = BigInt(1);
|
|
4
|
+
const maxValue = 9007199254740991;
|
|
5
|
+
function fromTwos(_value, _width) {
|
|
6
|
+
const value = getUint(_value, "value");
|
|
7
|
+
const width = BigInt(getNumber(_width, "width"));
|
|
8
|
+
assert(value >> width === BN_0, "overflow", "NUMERIC_FAULT", {
|
|
9
|
+
operation: "fromTwos",
|
|
10
|
+
fault: "overflow",
|
|
11
|
+
value: _value
|
|
12
|
+
});
|
|
13
|
+
if (value >> width - BN_1) {
|
|
14
|
+
const mask2 = (BN_1 << width) - BN_1;
|
|
15
|
+
return -((~value & mask2) + BN_1);
|
|
16
|
+
}
|
|
17
|
+
return value;
|
|
18
|
+
}
|
|
19
|
+
function toTwos(_value, _width) {
|
|
20
|
+
let value = getBigInt(_value, "value");
|
|
21
|
+
const width = BigInt(getNumber(_width, "width"));
|
|
22
|
+
const limit = BN_1 << width - BN_1;
|
|
23
|
+
if (value < BN_0) {
|
|
24
|
+
value = -value;
|
|
25
|
+
assert(value <= limit, "too low", "NUMERIC_FAULT", {
|
|
26
|
+
operation: "toTwos",
|
|
27
|
+
fault: "overflow",
|
|
28
|
+
value: _value
|
|
29
|
+
});
|
|
30
|
+
const mask2 = (BN_1 << width) - BN_1;
|
|
31
|
+
return (~value & mask2) + BN_1;
|
|
32
|
+
} else {
|
|
33
|
+
assert(value < limit, "too high", "NUMERIC_FAULT", {
|
|
34
|
+
operation: "toTwos",
|
|
35
|
+
fault: "overflow",
|
|
36
|
+
value: _value
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
return value;
|
|
40
|
+
}
|
|
41
|
+
function mask(_value, _bits) {
|
|
42
|
+
const value = getUint(_value, "value");
|
|
43
|
+
const bits = BigInt(getNumber(_bits, "bits"));
|
|
44
|
+
return value & (BN_1 << bits) - BN_1;
|
|
45
|
+
}
|
|
46
|
+
function getBigInt(value, name) {
|
|
47
|
+
switch (typeof value) {
|
|
48
|
+
case "bigint":
|
|
49
|
+
return value;
|
|
50
|
+
case "number":
|
|
51
|
+
assertArgument(Number.isInteger(value), "underflow", name || "value", value);
|
|
52
|
+
assertArgument(value >= -9007199254740991 && value <= maxValue, "overflow", name || "value", value);
|
|
53
|
+
return BigInt(value);
|
|
54
|
+
case "string":
|
|
55
|
+
try {
|
|
56
|
+
if (value === "") {
|
|
57
|
+
throw new Error("empty string");
|
|
58
|
+
}
|
|
59
|
+
if (value[0] === "-" && value[1] !== "-") {
|
|
60
|
+
return -BigInt(value.substring(1));
|
|
61
|
+
}
|
|
62
|
+
return BigInt(value);
|
|
63
|
+
} catch (e) {
|
|
64
|
+
assertArgument(false, `invalid BigNumberish string: ${e.message}`, name || "value", value);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
assertArgument(false, "invalid BigNumberish value", name || "value", value);
|
|
68
|
+
}
|
|
69
|
+
function getUint(value, name) {
|
|
70
|
+
const result = getBigInt(value, name);
|
|
71
|
+
assert(result >= BN_0, "unsigned value cannot be negative", "NUMERIC_FAULT", {
|
|
72
|
+
fault: "overflow",
|
|
73
|
+
operation: "getUint",
|
|
74
|
+
value
|
|
75
|
+
});
|
|
76
|
+
return result;
|
|
77
|
+
}
|
|
78
|
+
const Nibbles = "0123456789abcdef";
|
|
79
|
+
function toBigInt(value) {
|
|
80
|
+
if (value instanceof Uint8Array) {
|
|
81
|
+
let result = "0x0";
|
|
82
|
+
for (const v of value) {
|
|
83
|
+
result += Nibbles[v >> 4];
|
|
84
|
+
result += Nibbles[v & 15];
|
|
85
|
+
}
|
|
86
|
+
return BigInt(result);
|
|
87
|
+
}
|
|
88
|
+
return getBigInt(value);
|
|
89
|
+
}
|
|
90
|
+
function getNumber(value, name) {
|
|
91
|
+
switch (typeof value) {
|
|
92
|
+
case "bigint":
|
|
93
|
+
assertArgument(value >= -9007199254740991 && value <= maxValue, "overflow", name || "value", value);
|
|
94
|
+
return Number(value);
|
|
95
|
+
case "number":
|
|
96
|
+
assertArgument(Number.isInteger(value), "underflow", name || "value", value);
|
|
97
|
+
assertArgument(value >= -9007199254740991 && value <= maxValue, "overflow", name || "value", value);
|
|
98
|
+
return value;
|
|
99
|
+
case "string":
|
|
100
|
+
try {
|
|
101
|
+
if (value === "") {
|
|
102
|
+
throw new Error("empty string");
|
|
103
|
+
}
|
|
104
|
+
return getNumber(BigInt(value), name);
|
|
105
|
+
} catch (e) {
|
|
106
|
+
assertArgument(false, `invalid numeric string: ${e.message}`, name || "value", value);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
assertArgument(false, "invalid numeric value", name || "value", value);
|
|
110
|
+
}
|
|
111
|
+
function toNumber(value) {
|
|
112
|
+
return getNumber(toBigInt(value));
|
|
113
|
+
}
|
|
114
|
+
function toBeHex(_value, _width) {
|
|
115
|
+
const value = getUint(_value, "value");
|
|
116
|
+
let result = value.toString(16);
|
|
117
|
+
if (_width == null) {
|
|
118
|
+
if (result.length % 2) {
|
|
119
|
+
result = "0" + result;
|
|
120
|
+
}
|
|
121
|
+
} else {
|
|
122
|
+
const width = getNumber(_width, "width");
|
|
123
|
+
assert(width * 2 >= result.length, `value exceeds width (${width} bytes)`, "NUMERIC_FAULT", {
|
|
124
|
+
operation: "toBeHex",
|
|
125
|
+
fault: "overflow",
|
|
126
|
+
value: _value
|
|
127
|
+
});
|
|
128
|
+
while (result.length < width * 2) {
|
|
129
|
+
result = "0" + result;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return "0x" + result;
|
|
133
|
+
}
|
|
134
|
+
function toBeArray(_value) {
|
|
135
|
+
const value = getUint(_value, "value");
|
|
136
|
+
if (value === BN_0) {
|
|
137
|
+
return new Uint8Array([]);
|
|
138
|
+
}
|
|
139
|
+
let hex = value.toString(16);
|
|
140
|
+
if (hex.length % 2) {
|
|
141
|
+
hex = "0" + hex;
|
|
142
|
+
}
|
|
143
|
+
const result = new Uint8Array(hex.length / 2);
|
|
144
|
+
for (let i = 0; i < result.length; i++) {
|
|
145
|
+
const offset = i * 2;
|
|
146
|
+
result[i] = parseInt(hex.substring(offset, offset + 2), 16);
|
|
147
|
+
}
|
|
148
|
+
return result;
|
|
3
149
|
}
|
|
4
150
|
export {
|
|
5
|
-
|
|
151
|
+
fromTwos,
|
|
152
|
+
getBigInt,
|
|
153
|
+
getNumber,
|
|
154
|
+
getUint,
|
|
155
|
+
mask,
|
|
156
|
+
toBeArray,
|
|
157
|
+
toBeHex,
|
|
158
|
+
toBigInt,
|
|
159
|
+
toNumber,
|
|
160
|
+
toTwos
|
|
6
161
|
};
|
|
7
162
|
//# sourceMappingURL=standards-sdk.es47.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es47.js","sources":["../../node_modules/axios/lib/cancel/isCancel.js"],"sourcesContent":["'use strict';\n\nexport default function isCancel(value) {\n return !!(value && value.__CANCEL__);\n}\n"],"names":[],"mappings":"AAEe,SAAS,SAAS,OAAO;AACtC,SAAO,CAAC,EAAE,SAAS,MAAM;AAC3B;","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es47.js","sources":["../../node_modules/ethers/lib.esm/utils/maths.js"],"sourcesContent":["/**\n * Some mathematic operations.\n *\n * @_subsection: api/utils:Math Helpers [about-maths]\n */\nimport { hexlify, isBytesLike } from \"./data.js\";\nimport { assert, assertArgument } from \"./errors.js\";\nconst BN_0 = BigInt(0);\nconst BN_1 = BigInt(1);\n//const BN_Max256 = (BN_1 << BigInt(256)) - BN_1;\n// IEEE 754 support 53-bits of mantissa\nconst maxValue = 0x1fffffffffffff;\n/**\n * Convert %%value%% from a twos-compliment representation of %%width%%\n * bits to its value.\n *\n * If the highest bit is ``1``, the result will be negative.\n */\nexport function fromTwos(_value, _width) {\n const value = getUint(_value, \"value\");\n const width = BigInt(getNumber(_width, \"width\"));\n assert((value >> width) === BN_0, \"overflow\", \"NUMERIC_FAULT\", {\n operation: \"fromTwos\", fault: \"overflow\", value: _value\n });\n // Top bit set; treat as a negative value\n if (value >> (width - BN_1)) {\n const mask = (BN_1 << width) - BN_1;\n return -(((~value) & mask) + BN_1);\n }\n return value;\n}\n/**\n * Convert %%value%% to a twos-compliment representation of\n * %%width%% bits.\n *\n * The result will always be positive.\n */\nexport function toTwos(_value, _width) {\n let value = getBigInt(_value, \"value\");\n const width = BigInt(getNumber(_width, \"width\"));\n const limit = (BN_1 << (width - BN_1));\n if (value < BN_0) {\n value = -value;\n assert(value <= limit, \"too low\", \"NUMERIC_FAULT\", {\n operation: \"toTwos\", fault: \"overflow\", value: _value\n });\n const mask = (BN_1 << width) - BN_1;\n return ((~value) & mask) + BN_1;\n }\n else {\n assert(value < limit, \"too high\", \"NUMERIC_FAULT\", {\n operation: \"toTwos\", fault: \"overflow\", value: _value\n });\n }\n return value;\n}\n/**\n * Mask %%value%% with a bitmask of %%bits%% ones.\n */\nexport function mask(_value, _bits) {\n const value = getUint(_value, \"value\");\n const bits = BigInt(getNumber(_bits, \"bits\"));\n return value & ((BN_1 << bits) - BN_1);\n}\n/**\n * Gets a BigInt from %%value%%. If it is an invalid value for\n * a BigInt, then an ArgumentError will be thrown for %%name%%.\n */\nexport function getBigInt(value, name) {\n switch (typeof (value)) {\n case \"bigint\": return value;\n case \"number\":\n assertArgument(Number.isInteger(value), \"underflow\", name || \"value\", value);\n assertArgument(value >= -maxValue && value <= maxValue, \"overflow\", name || \"value\", value);\n return BigInt(value);\n case \"string\":\n try {\n if (value === \"\") {\n throw new Error(\"empty string\");\n }\n if (value[0] === \"-\" && value[1] !== \"-\") {\n return -BigInt(value.substring(1));\n }\n return BigInt(value);\n }\n catch (e) {\n assertArgument(false, `invalid BigNumberish string: ${e.message}`, name || \"value\", value);\n }\n }\n assertArgument(false, \"invalid BigNumberish value\", name || \"value\", value);\n}\n/**\n * Returns %%value%% as a bigint, validating it is valid as a bigint\n * value and that it is positive.\n */\nexport function getUint(value, name) {\n const result = getBigInt(value, name);\n assert(result >= BN_0, \"unsigned value cannot be negative\", \"NUMERIC_FAULT\", {\n fault: \"overflow\", operation: \"getUint\", value\n });\n return result;\n}\nconst Nibbles = \"0123456789abcdef\";\n/*\n * Converts %%value%% to a BigInt. If %%value%% is a Uint8Array, it\n * is treated as Big Endian data.\n */\nexport function toBigInt(value) {\n if (value instanceof Uint8Array) {\n let result = \"0x0\";\n for (const v of value) {\n result += Nibbles[v >> 4];\n result += Nibbles[v & 0x0f];\n }\n return BigInt(result);\n }\n return getBigInt(value);\n}\n/**\n * Gets a //number// from %%value%%. If it is an invalid value for\n * a //number//, then an ArgumentError will be thrown for %%name%%.\n */\nexport function getNumber(value, name) {\n switch (typeof (value)) {\n case \"bigint\":\n assertArgument(value >= -maxValue && value <= maxValue, \"overflow\", name || \"value\", value);\n return Number(value);\n case \"number\":\n assertArgument(Number.isInteger(value), \"underflow\", name || \"value\", value);\n assertArgument(value >= -maxValue && value <= maxValue, \"overflow\", name || \"value\", value);\n return value;\n case \"string\":\n try {\n if (value === \"\") {\n throw new Error(\"empty string\");\n }\n return getNumber(BigInt(value), name);\n }\n catch (e) {\n assertArgument(false, `invalid numeric string: ${e.message}`, name || \"value\", value);\n }\n }\n assertArgument(false, \"invalid numeric value\", name || \"value\", value);\n}\n/**\n * Converts %%value%% to a number. If %%value%% is a Uint8Array, it\n * is treated as Big Endian data. Throws if the value is not safe.\n */\nexport function toNumber(value) {\n return getNumber(toBigInt(value));\n}\n/**\n * Converts %%value%% to a Big Endian hexstring, optionally padded to\n * %%width%% bytes.\n */\nexport function toBeHex(_value, _width) {\n const value = getUint(_value, \"value\");\n let result = value.toString(16);\n if (_width == null) {\n // Ensure the value is of even length\n if (result.length % 2) {\n result = \"0\" + result;\n }\n }\n else {\n const width = getNumber(_width, \"width\");\n assert(width * 2 >= result.length, `value exceeds width (${width} bytes)`, \"NUMERIC_FAULT\", {\n operation: \"toBeHex\",\n fault: \"overflow\",\n value: _value\n });\n // Pad the value to the required width\n while (result.length < (width * 2)) {\n result = \"0\" + result;\n }\n }\n return \"0x\" + result;\n}\n/**\n * Converts %%value%% to a Big Endian Uint8Array.\n */\nexport function toBeArray(_value) {\n const value = getUint(_value, \"value\");\n if (value === BN_0) {\n return new Uint8Array([]);\n }\n let hex = value.toString(16);\n if (hex.length % 2) {\n hex = \"0\" + hex;\n }\n const result = new Uint8Array(hex.length / 2);\n for (let i = 0; i < result.length; i++) {\n const offset = i * 2;\n result[i] = parseInt(hex.substring(offset, offset + 2), 16);\n }\n return result;\n}\n/**\n * Returns a [[HexString]] for %%value%% safe to use as a //Quantity//.\n *\n * A //Quantity// does not have and leading 0 values unless the value is\n * the literal value `0x0`. This is most commonly used for JSSON-RPC\n * numeric values.\n */\nexport function toQuantity(value) {\n let result = hexlify(isBytesLike(value) ? value : toBeArray(value)).substring(2);\n while (result.startsWith(\"0\")) {\n result = result.substring(1);\n }\n if (result === \"\") {\n result = \"0\";\n }\n return \"0x\" + result;\n}\n//# sourceMappingURL=maths.js.map"],"names":["mask"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -1,5 +1,198 @@
|
|
|
1
|
-
|
|
1
|
+
var __typeError = (msg) => {
|
|
2
|
+
throw TypeError(msg);
|
|
3
|
+
};
|
|
4
|
+
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
5
|
+
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);
|
|
6
|
+
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
7
|
+
var _AbiCoder_instances, getCoder_fn;
|
|
8
|
+
import { Writer, Reader } from "./standards-sdk.es49.js";
|
|
9
|
+
import { AddressCoder } from "./standards-sdk.es50.js";
|
|
10
|
+
import { ArrayCoder } from "./standards-sdk.es51.js";
|
|
11
|
+
import { BooleanCoder } from "./standards-sdk.es52.js";
|
|
12
|
+
import { BytesCoder } from "./standards-sdk.es53.js";
|
|
13
|
+
import { FixedBytesCoder } from "./standards-sdk.es54.js";
|
|
14
|
+
import { NullCoder } from "./standards-sdk.es55.js";
|
|
15
|
+
import { NumberCoder } from "./standards-sdk.es56.js";
|
|
16
|
+
import { StringCoder } from "./standards-sdk.es57.js";
|
|
17
|
+
import { TupleCoder } from "./standards-sdk.es58.js";
|
|
18
|
+
import { ParamType } from "./standards-sdk.es59.js";
|
|
19
|
+
import { assertArgument, assertArgumentCount, makeError } from "./standards-sdk.es41.js";
|
|
20
|
+
import { getBytes, hexlify } from "./standards-sdk.es42.js";
|
|
21
|
+
import { getAddress } from "./standards-sdk.es39.js";
|
|
22
|
+
const PanicReasons = /* @__PURE__ */ new Map();
|
|
23
|
+
PanicReasons.set(0, "GENERIC_PANIC");
|
|
24
|
+
PanicReasons.set(1, "ASSERT_FALSE");
|
|
25
|
+
PanicReasons.set(17, "OVERFLOW");
|
|
26
|
+
PanicReasons.set(18, "DIVIDE_BY_ZERO");
|
|
27
|
+
PanicReasons.set(33, "ENUM_RANGE_ERROR");
|
|
28
|
+
PanicReasons.set(34, "BAD_STORAGE_DATA");
|
|
29
|
+
PanicReasons.set(49, "STACK_UNDERFLOW");
|
|
30
|
+
PanicReasons.set(50, "ARRAY_RANGE_ERROR");
|
|
31
|
+
PanicReasons.set(65, "OUT_OF_MEMORY");
|
|
32
|
+
PanicReasons.set(81, "UNINITIALIZED_FUNCTION_CALL");
|
|
33
|
+
const paramTypeBytes = new RegExp(/^bytes([0-9]*)$/);
|
|
34
|
+
const paramTypeNumber = new RegExp(/^(u?int)([0-9]*)$/);
|
|
35
|
+
let defaultCoder = null;
|
|
36
|
+
let defaultMaxInflation = 1024;
|
|
37
|
+
function getBuiltinCallException(action, tx, data, abiCoder) {
|
|
38
|
+
let message = "missing revert data";
|
|
39
|
+
let reason = null;
|
|
40
|
+
const invocation = null;
|
|
41
|
+
let revert = null;
|
|
42
|
+
if (data) {
|
|
43
|
+
message = "execution reverted";
|
|
44
|
+
const bytes = getBytes(data);
|
|
45
|
+
data = hexlify(data);
|
|
46
|
+
if (bytes.length === 0) {
|
|
47
|
+
message += " (no data present; likely require(false) occurred";
|
|
48
|
+
reason = "require(false)";
|
|
49
|
+
} else if (bytes.length % 32 !== 4) {
|
|
50
|
+
message += " (could not decode reason; invalid data length)";
|
|
51
|
+
} else if (hexlify(bytes.slice(0, 4)) === "0x08c379a0") {
|
|
52
|
+
try {
|
|
53
|
+
reason = abiCoder.decode(["string"], bytes.slice(4))[0];
|
|
54
|
+
revert = {
|
|
55
|
+
signature: "Error(string)",
|
|
56
|
+
name: "Error",
|
|
57
|
+
args: [reason]
|
|
58
|
+
};
|
|
59
|
+
message += `: ${JSON.stringify(reason)}`;
|
|
60
|
+
} catch (error) {
|
|
61
|
+
message += " (could not decode reason; invalid string data)";
|
|
62
|
+
}
|
|
63
|
+
} else if (hexlify(bytes.slice(0, 4)) === "0x4e487b71") {
|
|
64
|
+
try {
|
|
65
|
+
const code = Number(abiCoder.decode(["uint256"], bytes.slice(4))[0]);
|
|
66
|
+
revert = {
|
|
67
|
+
signature: "Panic(uint256)",
|
|
68
|
+
name: "Panic",
|
|
69
|
+
args: [code]
|
|
70
|
+
};
|
|
71
|
+
reason = `Panic due to ${PanicReasons.get(code) || "UNKNOWN"}(${code})`;
|
|
72
|
+
message += `: ${reason}`;
|
|
73
|
+
} catch (error) {
|
|
74
|
+
message += " (could not decode panic code)";
|
|
75
|
+
}
|
|
76
|
+
} else {
|
|
77
|
+
message += " (unknown custom error)";
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
const transaction = {
|
|
81
|
+
to: tx.to ? getAddress(tx.to) : null,
|
|
82
|
+
data: tx.data || "0x"
|
|
83
|
+
};
|
|
84
|
+
if (tx.from) {
|
|
85
|
+
transaction.from = getAddress(tx.from);
|
|
86
|
+
}
|
|
87
|
+
return makeError(message, "CALL_EXCEPTION", {
|
|
88
|
+
action,
|
|
89
|
+
data,
|
|
90
|
+
reason,
|
|
91
|
+
transaction,
|
|
92
|
+
invocation,
|
|
93
|
+
revert
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
const _AbiCoder = class _AbiCoder {
|
|
97
|
+
constructor() {
|
|
98
|
+
__privateAdd(this, _AbiCoder_instances);
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Get the default values for the given %%types%%.
|
|
102
|
+
*
|
|
103
|
+
* For example, a ``uint`` is by default ``0`` and ``bool``
|
|
104
|
+
* is by default ``false``.
|
|
105
|
+
*/
|
|
106
|
+
getDefaultValue(types) {
|
|
107
|
+
const coders = types.map((type) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, ParamType.from(type)));
|
|
108
|
+
const coder = new TupleCoder(coders, "_");
|
|
109
|
+
return coder.defaultValue();
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Encode the %%values%% as the %%types%% into ABI data.
|
|
113
|
+
*
|
|
114
|
+
* @returns DataHexstring
|
|
115
|
+
*/
|
|
116
|
+
encode(types, values) {
|
|
117
|
+
assertArgumentCount(values.length, types.length, "types/values length mismatch");
|
|
118
|
+
const coders = types.map((type) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, ParamType.from(type)));
|
|
119
|
+
const coder = new TupleCoder(coders, "_");
|
|
120
|
+
const writer = new Writer();
|
|
121
|
+
coder.encode(writer, values);
|
|
122
|
+
return writer.data;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Decode the ABI %%data%% as the %%types%% into values.
|
|
126
|
+
*
|
|
127
|
+
* If %%loose%% decoding is enabled, then strict padding is
|
|
128
|
+
* not enforced. Some older versions of Solidity incorrectly
|
|
129
|
+
* padded event data emitted from ``external`` functions.
|
|
130
|
+
*/
|
|
131
|
+
decode(types, data, loose) {
|
|
132
|
+
const coders = types.map((type) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, ParamType.from(type)));
|
|
133
|
+
const coder = new TupleCoder(coders, "_");
|
|
134
|
+
return coder.decode(new Reader(data, loose, defaultMaxInflation));
|
|
135
|
+
}
|
|
136
|
+
static _setDefaultMaxInflation(value) {
|
|
137
|
+
assertArgument(typeof value === "number" && Number.isInteger(value), "invalid defaultMaxInflation factor", "value", value);
|
|
138
|
+
defaultMaxInflation = value;
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Returns the shared singleton instance of a default [[AbiCoder]].
|
|
142
|
+
*
|
|
143
|
+
* On the first call, the instance is created internally.
|
|
144
|
+
*/
|
|
145
|
+
static defaultAbiCoder() {
|
|
146
|
+
if (defaultCoder == null) {
|
|
147
|
+
defaultCoder = new _AbiCoder();
|
|
148
|
+
}
|
|
149
|
+
return defaultCoder;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Returns an ethers-compatible [[CallExceptionError]] Error for the given
|
|
153
|
+
* result %%data%% for the [[CallExceptionAction]] %%action%% against
|
|
154
|
+
* the Transaction %%tx%%.
|
|
155
|
+
*/
|
|
156
|
+
static getBuiltinCallException(action, tx, data) {
|
|
157
|
+
return getBuiltinCallException(action, tx, data, _AbiCoder.defaultAbiCoder());
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
_AbiCoder_instances = new WeakSet();
|
|
161
|
+
getCoder_fn = function(param) {
|
|
162
|
+
if (param.isArray()) {
|
|
163
|
+
return new ArrayCoder(__privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, param.arrayChildren), param.arrayLength, param.name);
|
|
164
|
+
}
|
|
165
|
+
if (param.isTuple()) {
|
|
166
|
+
return new TupleCoder(param.components.map((c) => __privateMethod(this, _AbiCoder_instances, getCoder_fn).call(this, c)), param.name);
|
|
167
|
+
}
|
|
168
|
+
switch (param.baseType) {
|
|
169
|
+
case "address":
|
|
170
|
+
return new AddressCoder(param.name);
|
|
171
|
+
case "bool":
|
|
172
|
+
return new BooleanCoder(param.name);
|
|
173
|
+
case "string":
|
|
174
|
+
return new StringCoder(param.name);
|
|
175
|
+
case "bytes":
|
|
176
|
+
return new BytesCoder(param.name);
|
|
177
|
+
case "":
|
|
178
|
+
return new NullCoder(param.name);
|
|
179
|
+
}
|
|
180
|
+
let match = param.type.match(paramTypeNumber);
|
|
181
|
+
if (match) {
|
|
182
|
+
let size = parseInt(match[2] || "256");
|
|
183
|
+
assertArgument(size !== 0 && size <= 256 && size % 8 === 0, "invalid " + match[1] + " bit length", "param", param);
|
|
184
|
+
return new NumberCoder(size / 8, match[1] === "int", param.name);
|
|
185
|
+
}
|
|
186
|
+
match = param.type.match(paramTypeBytes);
|
|
187
|
+
if (match) {
|
|
188
|
+
let size = parseInt(match[1]);
|
|
189
|
+
assertArgument(size !== 0 && size <= 32, "invalid bytes length", "param", param);
|
|
190
|
+
return new FixedBytesCoder(size, param.name);
|
|
191
|
+
}
|
|
192
|
+
assertArgument(false, "invalid type", "type", param.type);
|
|
193
|
+
};
|
|
194
|
+
let AbiCoder = _AbiCoder;
|
|
2
195
|
export {
|
|
3
|
-
|
|
196
|
+
AbiCoder
|
|
4
197
|
};
|
|
5
198
|
//# sourceMappingURL=standards-sdk.es48.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"standards-sdk.es48.js","sources":["../../node_modules/axios/lib/env/data.js"],"sourcesContent":["export const VERSION = \"1.8.4\";"],"names":[],"mappings":"AAAY,MAAC,UAAU;","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"standards-sdk.es48.js","sources":["../../node_modules/ethers/lib.esm/abi/abi-coder.js"],"sourcesContent":["/**\n * When sending values to or receiving values from a [[Contract]], the\n * data is generally encoded using the [ABI standard](link-solc-abi).\n *\n * The AbiCoder provides a utility to encode values to ABI data and\n * decode values from ABI data.\n *\n * Most of the time, developers should favour the [[Contract]] class,\n * which further abstracts a lot of the finer details of ABI data.\n *\n * @_section api/abi/abi-coder:ABI Encoding\n */\n// See: https://github.com/ethereum/wiki/wiki/Ethereum-Contract-ABI\nimport { assertArgumentCount, assertArgument } from \"../utils/index.js\";\nimport { Reader, Writer } from \"./coders/abstract-coder.js\";\nimport { AddressCoder } from \"./coders/address.js\";\nimport { ArrayCoder } from \"./coders/array.js\";\nimport { BooleanCoder } from \"./coders/boolean.js\";\nimport { BytesCoder } from \"./coders/bytes.js\";\nimport { FixedBytesCoder } from \"./coders/fixed-bytes.js\";\nimport { NullCoder } from \"./coders/null.js\";\nimport { NumberCoder } from \"./coders/number.js\";\nimport { StringCoder } from \"./coders/string.js\";\nimport { TupleCoder } from \"./coders/tuple.js\";\nimport { ParamType } from \"./fragments.js\";\nimport { getAddress } from \"../address/index.js\";\nimport { getBytes, hexlify, makeError } from \"../utils/index.js\";\n// https://docs.soliditylang.org/en/v0.8.17/control-structures.html\nconst PanicReasons = new Map();\nPanicReasons.set(0x00, \"GENERIC_PANIC\");\nPanicReasons.set(0x01, \"ASSERT_FALSE\");\nPanicReasons.set(0x11, \"OVERFLOW\");\nPanicReasons.set(0x12, \"DIVIDE_BY_ZERO\");\nPanicReasons.set(0x21, \"ENUM_RANGE_ERROR\");\nPanicReasons.set(0x22, \"BAD_STORAGE_DATA\");\nPanicReasons.set(0x31, \"STACK_UNDERFLOW\");\nPanicReasons.set(0x32, \"ARRAY_RANGE_ERROR\");\nPanicReasons.set(0x41, \"OUT_OF_MEMORY\");\nPanicReasons.set(0x51, \"UNINITIALIZED_FUNCTION_CALL\");\nconst paramTypeBytes = new RegExp(/^bytes([0-9]*)$/);\nconst paramTypeNumber = new RegExp(/^(u?int)([0-9]*)$/);\nlet defaultCoder = null;\nlet defaultMaxInflation = 1024;\nfunction getBuiltinCallException(action, tx, data, abiCoder) {\n let message = \"missing revert data\";\n let reason = null;\n const invocation = null;\n let revert = null;\n if (data) {\n message = \"execution reverted\";\n const bytes = getBytes(data);\n data = hexlify(data);\n if (bytes.length === 0) {\n message += \" (no data present; likely require(false) occurred\";\n reason = \"require(false)\";\n }\n else if (bytes.length % 32 !== 4) {\n message += \" (could not decode reason; invalid data length)\";\n }\n else if (hexlify(bytes.slice(0, 4)) === \"0x08c379a0\") {\n // Error(string)\n try {\n reason = abiCoder.decode([\"string\"], bytes.slice(4))[0];\n revert = {\n signature: \"Error(string)\",\n name: \"Error\",\n args: [reason]\n };\n message += `: ${JSON.stringify(reason)}`;\n }\n catch (error) {\n message += \" (could not decode reason; invalid string data)\";\n }\n }\n else if (hexlify(bytes.slice(0, 4)) === \"0x4e487b71\") {\n // Panic(uint256)\n try {\n const code = Number(abiCoder.decode([\"uint256\"], bytes.slice(4))[0]);\n revert = {\n signature: \"Panic(uint256)\",\n name: \"Panic\",\n args: [code]\n };\n reason = `Panic due to ${PanicReasons.get(code) || \"UNKNOWN\"}(${code})`;\n message += `: ${reason}`;\n }\n catch (error) {\n message += \" (could not decode panic code)\";\n }\n }\n else {\n message += \" (unknown custom error)\";\n }\n }\n const transaction = {\n to: (tx.to ? getAddress(tx.to) : null),\n data: (tx.data || \"0x\")\n };\n if (tx.from) {\n transaction.from = getAddress(tx.from);\n }\n return makeError(message, \"CALL_EXCEPTION\", {\n action, data, reason, transaction, invocation, revert\n });\n}\n/**\n * The **AbiCoder** is a low-level class responsible for encoding JavaScript\n * values into binary data and decoding binary data into JavaScript values.\n */\nexport class AbiCoder {\n #getCoder(param) {\n if (param.isArray()) {\n return new ArrayCoder(this.#getCoder(param.arrayChildren), param.arrayLength, param.name);\n }\n if (param.isTuple()) {\n return new TupleCoder(param.components.map((c) => this.#getCoder(c)), param.name);\n }\n switch (param.baseType) {\n case \"address\":\n return new AddressCoder(param.name);\n case \"bool\":\n return new BooleanCoder(param.name);\n case \"string\":\n return new StringCoder(param.name);\n case \"bytes\":\n return new BytesCoder(param.name);\n case \"\":\n return new NullCoder(param.name);\n }\n // u?int[0-9]*\n let match = param.type.match(paramTypeNumber);\n if (match) {\n let size = parseInt(match[2] || \"256\");\n assertArgument(size !== 0 && size <= 256 && (size % 8) === 0, \"invalid \" + match[1] + \" bit length\", \"param\", param);\n return new NumberCoder(size / 8, (match[1] === \"int\"), param.name);\n }\n // bytes[0-9]+\n match = param.type.match(paramTypeBytes);\n if (match) {\n let size = parseInt(match[1]);\n assertArgument(size !== 0 && size <= 32, \"invalid bytes length\", \"param\", param);\n return new FixedBytesCoder(size, param.name);\n }\n assertArgument(false, \"invalid type\", \"type\", param.type);\n }\n /**\n * Get the default values for the given %%types%%.\n *\n * For example, a ``uint`` is by default ``0`` and ``bool``\n * is by default ``false``.\n */\n getDefaultValue(types) {\n const coders = types.map((type) => this.#getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n return coder.defaultValue();\n }\n /**\n * Encode the %%values%% as the %%types%% into ABI data.\n *\n * @returns DataHexstring\n */\n encode(types, values) {\n assertArgumentCount(values.length, types.length, \"types/values length mismatch\");\n const coders = types.map((type) => this.#getCoder(ParamType.from(type)));\n const coder = (new TupleCoder(coders, \"_\"));\n const writer = new Writer();\n coder.encode(writer, values);\n return writer.data;\n }\n /**\n * Decode the ABI %%data%% as the %%types%% into values.\n *\n * If %%loose%% decoding is enabled, then strict padding is\n * not enforced. Some older versions of Solidity incorrectly\n * padded event data emitted from ``external`` functions.\n */\n decode(types, data, loose) {\n const coders = types.map((type) => this.#getCoder(ParamType.from(type)));\n const coder = new TupleCoder(coders, \"_\");\n return coder.decode(new Reader(data, loose, defaultMaxInflation));\n }\n static _setDefaultMaxInflation(value) {\n assertArgument(typeof (value) === \"number\" && Number.isInteger(value), \"invalid defaultMaxInflation factor\", \"value\", value);\n defaultMaxInflation = value;\n }\n /**\n * Returns the shared singleton instance of a default [[AbiCoder]].\n *\n * On the first call, the instance is created internally.\n */\n static defaultAbiCoder() {\n if (defaultCoder == null) {\n defaultCoder = new AbiCoder();\n }\n return defaultCoder;\n }\n /**\n * Returns an ethers-compatible [[CallExceptionError]] Error for the given\n * result %%data%% for the [[CallExceptionAction]] %%action%% against\n * the Transaction %%tx%%.\n */\n static getBuiltinCallException(action, tx, data) {\n return getBuiltinCallException(action, tx, data, AbiCoder.defaultAbiCoder());\n }\n}\n//# sourceMappingURL=abi-coder.js.map"],"names":[],"mappings":"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","x_google_ignoreList":[0]}
|