@hashgraphonline/standards-sdk 0.0.107 → 0.0.108-canary.0

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.
Files changed (86) hide show
  1. package/dist/es/standards-sdk.es15.js +1 -1
  2. package/dist/es/standards-sdk.es18.js +2 -2
  3. package/dist/es/standards-sdk.es19.js +411 -52
  4. package/dist/es/standards-sdk.es19.js.map +1 -1
  5. package/dist/es/standards-sdk.es21.js +2 -2
  6. package/dist/es/standards-sdk.es24.js +10 -10
  7. package/dist/es/standards-sdk.es26.js +1 -1
  8. package/dist/es/standards-sdk.es31.js +5 -36
  9. package/dist/es/standards-sdk.es31.js.map +1 -1
  10. package/dist/es/standards-sdk.es32.js +36 -48
  11. package/dist/es/standards-sdk.es32.js.map +1 -1
  12. package/dist/es/standards-sdk.es33.js +48 -5
  13. package/dist/es/standards-sdk.es33.js.map +1 -1
  14. package/dist/es/standards-sdk.es34.js +1 -1
  15. package/dist/es/standards-sdk.es36.js +22 -100
  16. package/dist/es/standards-sdk.es36.js.map +1 -1
  17. package/dist/es/standards-sdk.es37.js +174 -2
  18. package/dist/es/standards-sdk.es37.js.map +1 -1
  19. package/dist/es/standards-sdk.es38.js +90 -15
  20. package/dist/es/standards-sdk.es38.js.map +1 -1
  21. package/dist/es/standards-sdk.es39.js +190 -404
  22. package/dist/es/standards-sdk.es39.js.map +1 -1
  23. package/dist/es/standards-sdk.es40.js +437 -2281
  24. package/dist/es/standards-sdk.es40.js.map +1 -1
  25. package/dist/es/standards-sdk.es41.js +20 -159
  26. package/dist/es/standards-sdk.es41.js.map +1 -1
  27. package/dist/es/standards-sdk.es42.js +137 -21
  28. package/dist/es/standards-sdk.es42.js.map +1 -1
  29. package/dist/es/standards-sdk.es43.js +13 -169
  30. package/dist/es/standards-sdk.es43.js.map +1 -1
  31. package/dist/es/standards-sdk.es44.js +21 -83
  32. package/dist/es/standards-sdk.es44.js.map +1 -1
  33. package/dist/es/standards-sdk.es45.js +25 -191
  34. package/dist/es/standards-sdk.es45.js.map +1 -1
  35. package/dist/es/standards-sdk.es46.js +15 -432
  36. package/dist/es/standards-sdk.es46.js.map +1 -1
  37. package/dist/es/standards-sdk.es47.js +34 -15
  38. package/dist/es/standards-sdk.es47.js.map +1 -1
  39. package/dist/es/standards-sdk.es48.js +10 -131
  40. package/dist/es/standards-sdk.es48.js.map +1 -1
  41. package/dist/es/standards-sdk.es49.js +53 -10
  42. package/dist/es/standards-sdk.es49.js.map +1 -1
  43. package/dist/es/standards-sdk.es50.js +1281 -21
  44. package/dist/es/standards-sdk.es50.js.map +1 -1
  45. package/dist/es/standards-sdk.es51.js +144 -25
  46. package/dist/es/standards-sdk.es51.js.map +1 -1
  47. package/dist/es/standards-sdk.es52.js +80 -17
  48. package/dist/es/standards-sdk.es52.js.map +1 -1
  49. package/dist/es/standards-sdk.es53.js +27 -39
  50. package/dist/es/standards-sdk.es53.js.map +1 -1
  51. package/dist/es/standards-sdk.es54.js +5 -17
  52. package/dist/es/standards-sdk.es54.js.map +1 -1
  53. package/dist/es/standards-sdk.es55.js +149 -51
  54. package/dist/es/standards-sdk.es55.js.map +1 -1
  55. package/dist/es/standards-sdk.es56.js +629 -1125
  56. package/dist/es/standards-sdk.es56.js.map +1 -1
  57. package/dist/es/standards-sdk.es57.js +127 -132
  58. package/dist/es/standards-sdk.es57.js.map +1 -1
  59. package/dist/es/standards-sdk.es58.js +96 -79
  60. package/dist/es/standards-sdk.es58.js.map +1 -1
  61. package/dist/es/standards-sdk.es59.js +2 -32
  62. package/dist/es/standards-sdk.es59.js.map +1 -1
  63. package/dist/es/standards-sdk.es60.js +15 -5
  64. package/dist/es/standards-sdk.es60.js.map +1 -1
  65. package/dist/es/standards-sdk.es61.js +401 -151
  66. package/dist/es/standards-sdk.es61.js.map +1 -1
  67. package/dist/es/standards-sdk.es62.js +24 -790
  68. package/dist/es/standards-sdk.es62.js.map +1 -1
  69. package/dist/es/standards-sdk.es63.js +23 -140
  70. package/dist/es/standards-sdk.es63.js.map +1 -1
  71. package/dist/es/standards-sdk.es64.js +34 -23
  72. package/dist/es/standards-sdk.es64.js.map +1 -1
  73. package/dist/es/standards-sdk.es65.js +19 -24
  74. package/dist/es/standards-sdk.es65.js.map +1 -1
  75. package/dist/es/standards-sdk.es66.js +2282 -38
  76. package/dist/es/standards-sdk.es66.js.map +1 -1
  77. package/dist/es/standards-sdk.es67.js +159 -16
  78. package/dist/es/standards-sdk.es67.js.map +1 -1
  79. package/dist/es/standards-sdk.es79.js +1 -1
  80. package/dist/es/utils/transaction-parser.d.ts +78 -5
  81. package/dist/es/utils/transaction-parser.d.ts.map +1 -1
  82. package/dist/umd/standards-sdk.umd.js +1 -1
  83. package/dist/umd/standards-sdk.umd.js.map +1 -1
  84. package/dist/umd/utils/transaction-parser.d.ts +78 -5
  85. package/dist/umd/utils/transaction-parser.d.ts.map +1 -1
  86. package/package.json +3 -3
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es53.js","sources":["../../node_modules/ethers/lib.esm/abi/coders/number.js"],"sourcesContent":["import { defineProperties, fromTwos, getBigInt, mask, toTwos } from \"../../utils/index.js\";\nimport { Typed } from \"../typed.js\";\nimport { Coder, WordSize } from \"./abstract-coder.js\";\nconst BN_0 = BigInt(0);\nconst BN_1 = BigInt(1);\nconst BN_MAX_UINT256 = BigInt(\"0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff\");\n/**\n * @_ignore\n */\nexport class NumberCoder extends Coder {\n size;\n signed;\n constructor(size, signed, localName) {\n const name = ((signed ? \"int\" : \"uint\") + (size * 8));\n super(name, name, localName, false);\n defineProperties(this, { size, signed }, { size: \"number\", signed: \"boolean\" });\n }\n defaultValue() {\n return 0;\n }\n encode(writer, _value) {\n let value = getBigInt(Typed.dereference(_value, this.type));\n // Check bounds are safe for encoding\n let maxUintValue = mask(BN_MAX_UINT256, WordSize * 8);\n if (this.signed) {\n let bounds = mask(maxUintValue, (this.size * 8) - 1);\n if (value > bounds || value < -(bounds + BN_1)) {\n this._throwError(\"value out-of-bounds\", _value);\n }\n value = toTwos(value, 8 * WordSize);\n }\n else if (value < BN_0 || value > mask(maxUintValue, this.size * 8)) {\n this._throwError(\"value out-of-bounds\", _value);\n }\n return writer.writeValue(value);\n }\n decode(reader) {\n let value = mask(reader.readValue(), this.size * 8);\n if (this.signed) {\n value = fromTwos(value, this.size * 8);\n }\n return value;\n }\n}\n//# sourceMappingURL=number.js.map"],"names":[],"mappings":";;;;;;;AAGA,MAAM,OAAO,OAAO,CAAC;AACrB,MAAM,OAAO,OAAO,CAAC;AACrB,MAAM,iBAAiB,OAAO,oEAAoE;AAI3F,MAAM,oBAAoB,MAAM;AAAA,EAGnC,YAAY,MAAM,QAAQ,WAAW;AACjC,UAAM,QAAS,SAAS,QAAQ,UAAW,OAAO;AAClD,UAAM,MAAM,MAAM,WAAW,KAAK;AAJtC;AACA;AAII,qBAAiB,MAAM,EAAE,MAAM,OAAM,GAAI,EAAE,MAAM,UAAU,QAAQ,WAAW;AAAA,EACtF;AAAA,EACI,eAAe;AACX,WAAO;AAAA,EACf;AAAA,EACI,OAAO,QAAQ,QAAQ;AACnB,QAAI,QAAQ,UAAU,MAAM,YAAY,QAAQ,KAAK,IAAI,CAAC;AAE1D,QAAI,eAAe,KAAK,gBAAgB,WAAW,CAAC;AACpD,QAAI,KAAK,QAAQ;AACb,UAAI,SAAS,KAAK,cAAe,KAAK,OAAO,IAAK,CAAC;AACnD,UAAI,QAAQ,UAAU,QAAQ,EAAE,SAAS,OAAO;AAC5C,aAAK,YAAY,uBAAuB,MAAM;AAAA,MAC9D;AACY,cAAQ,OAAO,OAAO,IAAI,QAAQ;AAAA,IAC9C,WACiB,QAAQ,QAAQ,QAAQ,KAAK,cAAc,KAAK,OAAO,CAAC,GAAG;AAChE,WAAK,YAAY,uBAAuB,MAAM;AAAA,IAC1D;AACQ,WAAO,OAAO,WAAW,KAAK;AAAA,EACtC;AAAA,EACI,OAAO,QAAQ;AACX,QAAI,QAAQ,KAAK,OAAO,UAAS,GAAI,KAAK,OAAO,CAAC;AAClD,QAAI,KAAK,QAAQ;AACb,cAAQ,SAAS,OAAO,KAAK,OAAO,CAAC;AAAA,IACjD;AACQ,WAAO;AAAA,EACf;AACA;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es53.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,21 +1,9 @@
1
- import { toUtf8Bytes, toUtf8String } from "./standards-sdk.es63.js";
2
- import { Typed } from "./standards-sdk.es62.js";
3
- import { DynamicBytesCoder } from "./standards-sdk.es50.js";
4
- class StringCoder extends DynamicBytesCoder {
5
- constructor(localName) {
6
- super("string", localName);
7
- }
8
- defaultValue() {
9
- return "";
10
- }
11
- encode(writer, _value) {
12
- return super.encode(writer, toUtf8Bytes(Typed.dereference(_value, "string")));
13
- }
14
- decode(reader) {
15
- return toUtf8String(super.decode(reader));
16
- }
1
+ import { keccak256 } from "./standards-sdk.es36.js";
2
+ import { toUtf8Bytes } from "./standards-sdk.es57.js";
3
+ function id(value) {
4
+ return keccak256(toUtf8Bytes(value));
17
5
  }
18
6
  export {
19
- StringCoder
7
+ id
20
8
  };
21
9
  //# sourceMappingURL=standards-sdk.es54.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es54.js","sources":["../../node_modules/ethers/lib.esm/abi/coders/string.js"],"sourcesContent":["import { toUtf8Bytes, toUtf8String } from \"../../utils/utf8.js\";\nimport { Typed } from \"../typed.js\";\nimport { DynamicBytesCoder } from \"./bytes.js\";\n/**\n * @_ignore\n */\nexport class StringCoder extends DynamicBytesCoder {\n constructor(localName) {\n super(\"string\", localName);\n }\n defaultValue() {\n return \"\";\n }\n encode(writer, _value) {\n return super.encode(writer, toUtf8Bytes(Typed.dereference(_value, \"string\")));\n }\n decode(reader) {\n return toUtf8String(super.decode(reader));\n }\n}\n//# sourceMappingURL=string.js.map"],"names":[],"mappings":";;;AAMO,MAAM,oBAAoB,kBAAkB;AAAA,EAC/C,YAAY,WAAW;AACnB,UAAM,UAAU,SAAS;AAAA,EACjC;AAAA,EACI,eAAe;AACX,WAAO;AAAA,EACf;AAAA,EACI,OAAO,QAAQ,QAAQ;AACnB,WAAO,MAAM,OAAO,QAAQ,YAAY,MAAM,YAAY,QAAQ,QAAQ,CAAC,CAAC;AAAA,EACpF;AAAA,EACI,OAAO,QAAQ;AACX,WAAO,aAAa,MAAM,OAAO,MAAM,CAAC;AAAA,EAChD;AACA;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es54.js","sources":["../../node_modules/ethers/lib.esm/hash/id.js"],"sourcesContent":["import { keccak256 } from \"../crypto/index.js\";\nimport { toUtf8Bytes } from \"../utils/index.js\";\n/**\n * A simple hashing function which operates on UTF-8 strings to\n * compute an 32-byte identifier.\n *\n * This simply computes the [UTF-8 bytes](toUtf8Bytes) and computes\n * the [[keccak256]].\n *\n * @example:\n * id(\"hello world\")\n * //_result:\n */\nexport function id(value) {\n return keccak256(toUtf8Bytes(value));\n}\n//# sourceMappingURL=id.js.map"],"names":[],"mappings":";;AAaO,SAAS,GAAG,OAAO;AACtB,SAAO,UAAU,YAAY,KAAK,CAAC;AACvC;","x_google_ignoreList":[0]}
@@ -1,64 +1,162 @@
1
- var __defProp = Object.defineProperty;
2
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
- import { defineProperties } from "./standards-sdk.es59.js";
5
- import { Typed } from "./standards-sdk.es62.js";
6
- import { Coder } from "./standards-sdk.es46.js";
7
- import { pack, unpack } from "./standards-sdk.es48.js";
8
- class TupleCoder extends Coder {
9
- constructor(coders, localName) {
10
- let dynamic = false;
11
- const types = [];
12
- coders.forEach((coder) => {
13
- if (coder.dynamic) {
14
- dynamic = true;
15
- }
16
- types.push(coder.type);
17
- });
18
- const type = "tuple(" + types.join(",") + ")";
19
- super("tuple", type, localName, dynamic);
20
- __publicField(this, "coders");
21
- defineProperties(this, { coders: Object.freeze(coders.slice()) });
1
+ import { assertArgument, assert } from "./standards-sdk.es51.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);
22
16
  }
23
- defaultValue() {
24
- const values = [];
25
- this.coders.forEach((coder) => {
26
- values.push(coder.defaultValue());
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
27
29
  });
28
- const uniqueNames = this.coders.reduce((accum, coder) => {
29
- const name = coder.localName;
30
- if (name) {
31
- if (!accum[name]) {
32
- accum[name] = 0;
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");
33
58
  }
34
- accum[name]++;
35
- }
36
- return accum;
37
- }, {});
38
- this.coders.forEach((coder, index) => {
39
- let name = coder.localName;
40
- if (!name || uniqueNames[name] !== 1) {
41
- return;
42
- }
43
- if (name === "length") {
44
- name = "_length";
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);
45
65
  }
46
- if (values[name] != null) {
47
- return;
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);
48
107
  }
49
- values[name] = values[index];
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
50
127
  });
51
- return Object.freeze(values);
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([]);
52
138
  }
53
- encode(writer, _value) {
54
- const value = Typed.dereference(_value, "tuple");
55
- return pack(writer, this.coders, value);
139
+ let hex = value.toString(16);
140
+ if (hex.length % 2) {
141
+ hex = "0" + hex;
56
142
  }
57
- decode(reader) {
58
- return unpack(reader, this.coders);
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);
59
147
  }
148
+ return result;
60
149
  }
61
150
  export {
62
- TupleCoder
151
+ fromTwos,
152
+ getBigInt,
153
+ getNumber,
154
+ getUint,
155
+ mask,
156
+ toBeArray,
157
+ toBeHex,
158
+ toBigInt,
159
+ toNumber,
160
+ toTwos
63
161
  };
64
162
  //# sourceMappingURL=standards-sdk.es55.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es55.js","sources":["../../node_modules/ethers/lib.esm/abi/coders/tuple.js"],"sourcesContent":["import { defineProperties } from \"../../utils/properties.js\";\nimport { Typed } from \"../typed.js\";\nimport { Coder } from \"./abstract-coder.js\";\nimport { pack, unpack } from \"./array.js\";\n/**\n * @_ignore\n */\nexport class TupleCoder extends Coder {\n coders;\n constructor(coders, localName) {\n let dynamic = false;\n const types = [];\n coders.forEach((coder) => {\n if (coder.dynamic) {\n dynamic = true;\n }\n types.push(coder.type);\n });\n const type = (\"tuple(\" + types.join(\",\") + \")\");\n super(\"tuple\", type, localName, dynamic);\n defineProperties(this, { coders: Object.freeze(coders.slice()) });\n }\n defaultValue() {\n const values = [];\n this.coders.forEach((coder) => {\n values.push(coder.defaultValue());\n });\n // We only output named properties for uniquely named coders\n const uniqueNames = this.coders.reduce((accum, coder) => {\n const name = coder.localName;\n if (name) {\n if (!accum[name]) {\n accum[name] = 0;\n }\n accum[name]++;\n }\n return accum;\n }, {});\n // Add named values\n this.coders.forEach((coder, index) => {\n let name = coder.localName;\n if (!name || uniqueNames[name] !== 1) {\n return;\n }\n if (name === \"length\") {\n name = \"_length\";\n }\n if (values[name] != null) {\n return;\n }\n values[name] = values[index];\n });\n return Object.freeze(values);\n }\n encode(writer, _value) {\n const value = Typed.dereference(_value, \"tuple\");\n return pack(writer, this.coders, value);\n }\n decode(reader) {\n return unpack(reader, this.coders);\n }\n}\n//# sourceMappingURL=tuple.js.map"],"names":[],"mappings":";;;;;;;AAOO,MAAM,mBAAmB,MAAM;AAAA,EAElC,YAAY,QAAQ,WAAW;AAC3B,QAAI,UAAU;AACd,UAAM,QAAQ,CAAE;AAChB,WAAO,QAAQ,CAAC,UAAU;AACtB,UAAI,MAAM,SAAS;AACf,kBAAU;AAAA,MAC1B;AACY,YAAM,KAAK,MAAM,IAAI;AAAA,IACjC,CAAS;AACD,UAAM,OAAQ,WAAW,MAAM,KAAK,GAAG,IAAI;AAC3C,UAAM,SAAS,MAAM,WAAW,OAAO;AAX3C;AAYI,qBAAiB,MAAM,EAAE,QAAQ,OAAO,OAAO,OAAO,MAAO,CAAA,GAAG;AAAA,EACxE;AAAA,EACI,eAAe;AACX,UAAM,SAAS,CAAE;AACjB,SAAK,OAAO,QAAQ,CAAC,UAAU;AAC3B,aAAO,KAAK,MAAM,cAAc;AAAA,IAC5C,CAAS;AAED,UAAM,cAAc,KAAK,OAAO,OAAO,CAAC,OAAO,UAAU;AACrD,YAAM,OAAO,MAAM;AACnB,UAAI,MAAM;AACN,YAAI,CAAC,MAAM,IAAI,GAAG;AACd,gBAAM,IAAI,IAAI;AAAA,QAClC;AACgB,cAAM,IAAI;AAAA,MAC1B;AACY,aAAO;AAAA,IACV,GAAE,EAAE;AAEL,SAAK,OAAO,QAAQ,CAAC,OAAO,UAAU;AAClC,UAAI,OAAO,MAAM;AACjB,UAAI,CAAC,QAAQ,YAAY,IAAI,MAAM,GAAG;AAClC;AAAA,MAChB;AACY,UAAI,SAAS,UAAU;AACnB,eAAO;AAAA,MACvB;AACY,UAAI,OAAO,IAAI,KAAK,MAAM;AACtB;AAAA,MAChB;AACY,aAAO,IAAI,IAAI,OAAO,KAAK;AAAA,IACvC,CAAS;AACD,WAAO,OAAO,OAAO,MAAM;AAAA,EACnC;AAAA,EACI,OAAO,QAAQ,QAAQ;AACnB,UAAM,QAAQ,MAAM,YAAY,QAAQ,OAAO;AAC/C,WAAO,KAAK,QAAQ,KAAK,QAAQ,KAAK;AAAA,EAC9C;AAAA,EACI,OAAO,QAAQ;AACX,WAAO,OAAO,QAAQ,KAAK,MAAM;AAAA,EACzC;AACA;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es55.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]}