@hashgraphonline/standards-sdk 0.0.108-canary.1 → 0.0.109

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 (245) hide show
  1. package/dist/es/standards-sdk.es100.js +13 -21
  2. package/dist/es/standards-sdk.es100.js.map +1 -1
  3. package/dist/es/standards-sdk.es101.js +36 -13
  4. package/dist/es/standards-sdk.es101.js.map +1 -1
  5. package/dist/es/standards-sdk.es102.js +10 -36
  6. package/dist/es/standards-sdk.es102.js.map +1 -1
  7. package/dist/es/standards-sdk.es103.js +53 -10
  8. package/dist/es/standards-sdk.es103.js.map +1 -1
  9. package/dist/es/standards-sdk.es104.js +1275 -47
  10. package/dist/es/standards-sdk.es104.js.map +1 -1
  11. package/dist/es/standards-sdk.es105.js +120 -1261
  12. package/dist/es/standards-sdk.es105.js.map +1 -1
  13. package/dist/es/standards-sdk.es106.js +86 -27
  14. package/dist/es/standards-sdk.es106.js.map +1 -1
  15. package/dist/es/standards-sdk.es107.js +83 -5
  16. package/dist/es/standards-sdk.es107.js.map +1 -1
  17. package/dist/es/standards-sdk.es108.js +26 -153
  18. package/dist/es/standards-sdk.es108.js.map +1 -1
  19. package/dist/es/standards-sdk.es109.js +5 -792
  20. package/dist/es/standards-sdk.es109.js.map +1 -1
  21. package/dist/es/standards-sdk.es110.js +145 -160
  22. package/dist/es/standards-sdk.es110.js.map +1 -1
  23. package/dist/es/standards-sdk.es111.js +21 -141
  24. package/dist/es/standards-sdk.es111.js.map +1 -1
  25. package/dist/es/standards-sdk.es112.js +793 -3
  26. package/dist/es/standards-sdk.es112.js.map +1 -1
  27. package/dist/es/standards-sdk.es113.js +2282 -2
  28. package/dist/es/standards-sdk.es113.js.map +1 -1
  29. package/dist/es/standards-sdk.es114.js +174 -2
  30. package/dist/es/standards-sdk.es114.js.map +1 -1
  31. package/dist/es/standards-sdk.es115.js +142 -33
  32. package/dist/es/standards-sdk.es115.js.map +1 -1
  33. package/dist/es/standards-sdk.es116.js +3 -33
  34. package/dist/es/standards-sdk.es116.js.map +1 -1
  35. package/dist/es/standards-sdk.es117.js +2 -9
  36. package/dist/es/standards-sdk.es117.js.map +1 -1
  37. package/dist/es/standards-sdk.es118.js +2 -34
  38. package/dist/es/standards-sdk.es118.js.map +1 -1
  39. package/dist/es/standards-sdk.es119.js +33 -20
  40. package/dist/es/standards-sdk.es119.js.map +1 -1
  41. package/dist/es/standards-sdk.es120.js +32 -26
  42. package/dist/es/standards-sdk.es120.js.map +1 -1
  43. package/dist/es/standards-sdk.es121.js +9 -26
  44. package/dist/es/standards-sdk.es121.js.map +1 -1
  45. package/dist/es/standards-sdk.es122.js +33 -37
  46. package/dist/es/standards-sdk.es122.js.map +1 -1
  47. package/dist/es/standards-sdk.es123.js +20 -100
  48. package/dist/es/standards-sdk.es123.js.map +1 -1
  49. package/dist/es/standards-sdk.es124.js +27 -2
  50. package/dist/es/standards-sdk.es124.js.map +1 -1
  51. package/dist/es/standards-sdk.es125.js +25 -15
  52. package/dist/es/standards-sdk.es125.js.map +1 -1
  53. package/dist/es/standards-sdk.es126.js +36 -407
  54. package/dist/es/standards-sdk.es126.js.map +1 -1
  55. package/dist/es/standards-sdk.es127.js +7136 -2282
  56. package/dist/es/standards-sdk.es127.js.map +1 -1
  57. package/dist/es/standards-sdk.es128.js +9 -7135
  58. package/dist/es/standards-sdk.es128.js.map +1 -1
  59. package/dist/es/standards-sdk.es129.js +10 -9
  60. package/dist/es/standards-sdk.es129.js.map +1 -1
  61. package/dist/es/standards-sdk.es13.js +3 -3
  62. package/dist/es/standards-sdk.es130.js +16 -9
  63. package/dist/es/standards-sdk.es130.js.map +1 -1
  64. package/dist/es/standards-sdk.es131.js +4 -16
  65. package/dist/es/standards-sdk.es131.js.map +1 -1
  66. package/dist/es/standards-sdk.es132.js +8 -5
  67. package/dist/es/standards-sdk.es132.js.map +1 -1
  68. package/dist/es/standards-sdk.es133.js +41 -8
  69. package/dist/es/standards-sdk.es133.js.map +1 -1
  70. package/dist/es/standards-sdk.es15.js +1 -1
  71. package/dist/es/standards-sdk.es18.js +2 -2
  72. package/dist/es/standards-sdk.es19.js +82 -8
  73. package/dist/es/standards-sdk.es19.js.map +1 -1
  74. package/dist/es/standards-sdk.es20.js +2 -2
  75. package/dist/es/standards-sdk.es21.js +3 -3
  76. package/dist/es/standards-sdk.es24.js +1694 -966
  77. package/dist/es/standards-sdk.es24.js.map +1 -1
  78. package/dist/es/standards-sdk.es25.js +7190 -5
  79. package/dist/es/standards-sdk.es25.js.map +1 -1
  80. package/dist/es/standards-sdk.es26.js +3 -36
  81. package/dist/es/standards-sdk.es26.js.map +1 -1
  82. package/dist/es/standards-sdk.es27.js +8 -47
  83. package/dist/es/standards-sdk.es27.js.map +1 -1
  84. package/dist/es/standards-sdk.es28.js +2 -1769
  85. package/dist/es/standards-sdk.es28.js.map +1 -1
  86. package/dist/es/standards-sdk.es29.js +4148 -481
  87. package/dist/es/standards-sdk.es29.js.map +1 -1
  88. package/dist/es/standards-sdk.es30.js +1023 -91
  89. package/dist/es/standards-sdk.es30.js.map +1 -1
  90. package/dist/es/standards-sdk.es31.js +5 -66
  91. package/dist/es/standards-sdk.es31.js.map +1 -1
  92. package/dist/es/standards-sdk.es32.js +36 -64
  93. package/dist/es/standards-sdk.es32.js.map +1 -1
  94. package/dist/es/standards-sdk.es33.js +47 -26
  95. package/dist/es/standards-sdk.es33.js.map +1 -1
  96. package/dist/es/standards-sdk.es34.js +495 -5
  97. package/dist/es/standards-sdk.es34.js.map +1 -1
  98. package/dist/es/standards-sdk.es35.js +108 -9
  99. package/dist/es/standards-sdk.es35.js.map +1 -1
  100. package/dist/es/standards-sdk.es36.js +52 -7176
  101. package/dist/es/standards-sdk.es36.js.map +1 -1
  102. package/dist/es/standards-sdk.es37.js +257 -3
  103. package/dist/es/standards-sdk.es37.js.map +1 -1
  104. package/dist/es/standards-sdk.es38.js +172 -8
  105. package/dist/es/standards-sdk.es38.js.map +1 -1
  106. package/dist/es/standards-sdk.es39.js +11 -2
  107. package/dist/es/standards-sdk.es39.js.map +1 -1
  108. package/dist/es/standards-sdk.es4.js +1 -1
  109. package/dist/es/standards-sdk.es40.js +8 -4166
  110. package/dist/es/standards-sdk.es40.js.map +1 -1
  111. package/dist/es/standards-sdk.es44.js +3 -363
  112. package/dist/es/standards-sdk.es44.js.map +1 -1
  113. package/dist/es/standards-sdk.es45.js +362 -4
  114. package/dist/es/standards-sdk.es45.js.map +1 -1
  115. package/dist/es/standards-sdk.es46.js +5 -178
  116. package/dist/es/standards-sdk.es46.js.map +1 -1
  117. package/dist/es/standards-sdk.es47.js +171 -73
  118. package/dist/es/standards-sdk.es47.js.map +1 -1
  119. package/dist/es/standards-sdk.es48.js +74 -107
  120. package/dist/es/standards-sdk.es48.js.map +1 -1
  121. package/dist/es/standards-sdk.es49.js +107 -45
  122. package/dist/es/standards-sdk.es49.js.map +1 -1
  123. package/dist/es/standards-sdk.es5.js +1 -1
  124. package/dist/es/standards-sdk.es50.js +51 -9
  125. package/dist/es/standards-sdk.es50.js.map +1 -1
  126. package/dist/es/standards-sdk.es51.js +9 -96
  127. package/dist/es/standards-sdk.es51.js.map +1 -1
  128. package/dist/es/standards-sdk.es52.js +96 -3
  129. package/dist/es/standards-sdk.es52.js.map +1 -1
  130. package/dist/es/standards-sdk.es53.js +4 -2
  131. package/dist/es/standards-sdk.es53.js.map +1 -1
  132. package/dist/es/standards-sdk.es54.js +2 -113
  133. package/dist/es/standards-sdk.es54.js.map +1 -1
  134. package/dist/es/standards-sdk.es55.js +109 -70
  135. package/dist/es/standards-sdk.es55.js.map +1 -1
  136. package/dist/es/standards-sdk.es56.js +73 -5
  137. package/dist/es/standards-sdk.es56.js.map +1 -1
  138. package/dist/es/standards-sdk.es57.js +5 -4
  139. package/dist/es/standards-sdk.es57.js.map +1 -1
  140. package/dist/es/standards-sdk.es58.js +4 -220
  141. package/dist/es/standards-sdk.es58.js.map +1 -1
  142. package/dist/es/standards-sdk.es59.js +214 -51
  143. package/dist/es/standards-sdk.es59.js.map +1 -1
  144. package/dist/es/standards-sdk.es60.js +56 -67
  145. package/dist/es/standards-sdk.es60.js.map +1 -1
  146. package/dist/es/standards-sdk.es61.js +69 -4
  147. package/dist/es/standards-sdk.es61.js.map +1 -1
  148. package/dist/es/standards-sdk.es62.js +3 -42
  149. package/dist/es/standards-sdk.es62.js.map +1 -1
  150. package/dist/es/standards-sdk.es63.js +164 -3
  151. package/dist/es/standards-sdk.es63.js.map +1 -1
  152. package/dist/es/standards-sdk.es64.js +27 -159
  153. package/dist/es/standards-sdk.es64.js.map +1 -1
  154. package/dist/es/standards-sdk.es65.js +57 -26
  155. package/dist/es/standards-sdk.es65.js.map +1 -1
  156. package/dist/es/standards-sdk.es66.js +45 -58
  157. package/dist/es/standards-sdk.es66.js.map +1 -1
  158. package/dist/es/standards-sdk.es67.js +8 -48
  159. package/dist/es/standards-sdk.es67.js.map +1 -1
  160. package/dist/es/standards-sdk.es68.js +63 -8
  161. package/dist/es/standards-sdk.es68.js.map +1 -1
  162. package/dist/es/standards-sdk.es69.js +5 -64
  163. package/dist/es/standards-sdk.es69.js.map +1 -1
  164. package/dist/es/standards-sdk.es7.js +4 -4
  165. package/dist/es/standards-sdk.es70.js +15 -6
  166. package/dist/es/standards-sdk.es70.js.map +1 -1
  167. package/dist/es/standards-sdk.es71.js +7 -15
  168. package/dist/es/standards-sdk.es71.js.map +1 -1
  169. package/dist/es/standards-sdk.es72.js +44 -6
  170. package/dist/es/standards-sdk.es72.js.map +1 -1
  171. package/dist/es/standards-sdk.es73.js +2 -45
  172. package/dist/es/standards-sdk.es73.js.map +1 -1
  173. package/dist/es/standards-sdk.es74.js +136 -2
  174. package/dist/es/standards-sdk.es74.js.map +1 -1
  175. package/dist/es/standards-sdk.es75.js +163 -127
  176. package/dist/es/standards-sdk.es75.js.map +1 -1
  177. package/dist/es/standards-sdk.es76.js +2 -172
  178. package/dist/es/standards-sdk.es76.js.map +1 -1
  179. package/dist/es/standards-sdk.es77.js +13 -2
  180. package/dist/es/standards-sdk.es77.js.map +1 -1
  181. package/dist/es/standards-sdk.es78.js +13 -13
  182. package/dist/es/standards-sdk.es78.js.map +1 -1
  183. package/dist/es/standards-sdk.es79.js +101 -13
  184. package/dist/es/standards-sdk.es79.js.map +1 -1
  185. package/dist/es/standards-sdk.es8.js +3 -3
  186. package/dist/es/standards-sdk.es80.js +2 -32
  187. package/dist/es/standards-sdk.es80.js.map +1 -1
  188. package/dist/es/standards-sdk.es81.js +15 -14
  189. package/dist/es/standards-sdk.es81.js.map +1 -1
  190. package/dist/es/standards-sdk.es82.js +408 -3
  191. package/dist/es/standards-sdk.es82.js.map +1 -1
  192. package/dist/es/standards-sdk.es83.js +31 -3
  193. package/dist/es/standards-sdk.es83.js.map +1 -1
  194. package/dist/es/standards-sdk.es84.js +14 -15
  195. package/dist/es/standards-sdk.es84.js.map +1 -1
  196. package/dist/es/standards-sdk.es85.js +3 -4
  197. package/dist/es/standards-sdk.es85.js.map +1 -1
  198. package/dist/es/standards-sdk.es86.js +4 -39
  199. package/dist/es/standards-sdk.es86.js.map +1 -1
  200. package/dist/es/standards-sdk.es87.js +15 -39
  201. package/dist/es/standards-sdk.es87.js.map +1 -1
  202. package/dist/es/standards-sdk.es88.js +5 -37
  203. package/dist/es/standards-sdk.es88.js.map +1 -1
  204. package/dist/es/standards-sdk.es89.js +37 -76
  205. package/dist/es/standards-sdk.es89.js.map +1 -1
  206. package/dist/es/standards-sdk.es9.js +1 -1
  207. package/dist/es/standards-sdk.es90.js +36 -80
  208. package/dist/es/standards-sdk.es90.js.map +1 -1
  209. package/dist/es/standards-sdk.es91.js +35 -21
  210. package/dist/es/standards-sdk.es91.js.map +1 -1
  211. package/dist/es/standards-sdk.es92.js +68 -138
  212. package/dist/es/standards-sdk.es92.js.map +1 -1
  213. package/dist/es/standards-sdk.es93.js +185 -81
  214. package/dist/es/standards-sdk.es93.js.map +1 -1
  215. package/dist/es/standards-sdk.es94.js +406 -163
  216. package/dist/es/standards-sdk.es94.js.map +1 -1
  217. package/dist/es/standards-sdk.es95.js +19 -432
  218. package/dist/es/standards-sdk.es95.js.map +1 -1
  219. package/dist/es/standards-sdk.es96.js +130 -16
  220. package/dist/es/standards-sdk.es96.js.map +1 -1
  221. package/dist/es/standards-sdk.es97.js +10 -131
  222. package/dist/es/standards-sdk.es97.js.map +1 -1
  223. package/dist/es/standards-sdk.es98.js +22 -11
  224. package/dist/es/standards-sdk.es98.js.map +1 -1
  225. package/dist/es/standards-sdk.es99.js +22 -22
  226. package/dist/es/standards-sdk.es99.js.map +1 -1
  227. package/dist/es/utils/parsers/crypto-parser.d.ts +5 -1
  228. package/dist/es/utils/parsers/crypto-parser.d.ts.map +1 -1
  229. package/dist/es/utils/parsers/scs-parser.d.ts +4 -1
  230. package/dist/es/utils/parsers/scs-parser.d.ts.map +1 -1
  231. package/dist/es/utils/parsers/util-parser.d.ts.map +1 -1
  232. package/dist/es/utils/transaction-parser-types.d.ts +91 -0
  233. package/dist/es/utils/transaction-parser-types.d.ts.map +1 -1
  234. package/dist/es/utils/transaction-parser.d.ts.map +1 -1
  235. package/dist/umd/standards-sdk.umd.js +11 -11
  236. package/dist/umd/standards-sdk.umd.js.map +1 -1
  237. package/dist/umd/utils/parsers/crypto-parser.d.ts +5 -1
  238. package/dist/umd/utils/parsers/crypto-parser.d.ts.map +1 -1
  239. package/dist/umd/utils/parsers/scs-parser.d.ts +4 -1
  240. package/dist/umd/utils/parsers/scs-parser.d.ts.map +1 -1
  241. package/dist/umd/utils/parsers/util-parser.d.ts.map +1 -1
  242. package/dist/umd/utils/transaction-parser-types.d.ts +91 -0
  243. package/dist/umd/utils/transaction-parser-types.d.ts.map +1 -1
  244. package/dist/umd/utils/transaction-parser.d.ts.map +1 -1
  245. package/package.json +1 -1
@@ -1,162 +1,35 @@
1
- import { assertArgument, assert } from "./standards-sdk.es92.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");
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":
6
+ return;
7
+ case "bigint":
8
+ case "boolean":
9
+ case "number":
10
+ case "string":
11
+ if (typeof value === type) {
12
+ return;
58
13
  }
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
14
  }
86
- return BigInt(result);
87
15
  }
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;
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);
130
28
  }
29
+ Object.defineProperty(target, key, { enumerable: true, value, writable: false });
131
30
  }
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;
149
31
  }
150
32
  export {
151
- fromTwos,
152
- getBigInt,
153
- getNumber,
154
- getUint,
155
- mask,
156
- toBeArray,
157
- toBeHex,
158
- toBigInt,
159
- toNumber,
160
- toTwos
33
+ defineProperties
161
34
  };
162
35
  //# sourceMappingURL=standards-sdk.es108.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es108.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
+ {"version":3,"file":"standards-sdk.es108.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]}