@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,162 +1,412 @@
1
- import { assertArgument, assert } from "./standards-sdk.es57.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];
1
+ import process$1 from "./standards-sdk.es67.js";
2
+ var pathBrowserify;
3
+ var hasRequiredPathBrowserify;
4
+ function requirePathBrowserify() {
5
+ if (hasRequiredPathBrowserify) return pathBrowserify;
6
+ hasRequiredPathBrowserify = 1;
7
+ function assertPath(path) {
8
+ if (typeof path !== "string") {
9
+ throw new TypeError("Path must be a string. Received " + JSON.stringify(path));
85
10
  }
86
- return BigInt(result);
87
11
  }
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);
12
+ function normalizeStringPosix(path, allowAboveRoot) {
13
+ var res = "";
14
+ var lastSegmentLength = 0;
15
+ var lastSlash = -1;
16
+ var dots = 0;
17
+ var code;
18
+ for (var i = 0; i <= path.length; ++i) {
19
+ if (i < path.length)
20
+ code = path.charCodeAt(i);
21
+ else if (code === 47)
22
+ break;
23
+ else
24
+ code = 47;
25
+ if (code === 47) {
26
+ if (lastSlash === i - 1 || dots === 1) ;
27
+ else if (lastSlash !== i - 1 && dots === 2) {
28
+ if (res.length < 2 || lastSegmentLength !== 2 || res.charCodeAt(res.length - 1) !== 46 || res.charCodeAt(res.length - 2) !== 46) {
29
+ if (res.length > 2) {
30
+ var lastSlashIndex = res.lastIndexOf("/");
31
+ if (lastSlashIndex !== res.length - 1) {
32
+ if (lastSlashIndex === -1) {
33
+ res = "";
34
+ lastSegmentLength = 0;
35
+ } else {
36
+ res = res.slice(0, lastSlashIndex);
37
+ lastSegmentLength = res.length - 1 - res.lastIndexOf("/");
38
+ }
39
+ lastSlash = i;
40
+ dots = 0;
41
+ continue;
42
+ }
43
+ } else if (res.length === 2 || res.length === 1) {
44
+ res = "";
45
+ lastSegmentLength = 0;
46
+ lastSlash = i;
47
+ dots = 0;
48
+ continue;
49
+ }
50
+ }
51
+ if (allowAboveRoot) {
52
+ if (res.length > 0)
53
+ res += "/..";
54
+ else
55
+ res = "..";
56
+ lastSegmentLength = 2;
57
+ }
58
+ } else {
59
+ if (res.length > 0)
60
+ res += "/" + path.slice(lastSlash + 1, i);
61
+ else
62
+ res = path.slice(lastSlash + 1, i);
63
+ lastSegmentLength = i - lastSlash - 1;
64
+ }
65
+ lastSlash = i;
66
+ dots = 0;
67
+ } else if (code === 46 && dots !== -1) {
68
+ ++dots;
69
+ } else {
70
+ dots = -1;
107
71
  }
72
+ }
73
+ return res;
108
74
  }
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;
75
+ function _format(sep, pathObject) {
76
+ var dir = pathObject.dir || pathObject.root;
77
+ var base = pathObject.base || (pathObject.name || "") + (pathObject.ext || "");
78
+ if (!dir) {
79
+ return base;
120
80
  }
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;
81
+ if (dir === pathObject.root) {
82
+ return dir + base;
130
83
  }
84
+ return dir + sep + base;
131
85
  }
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;
86
+ var posix = {
87
+ // path.resolve([from ...], to)
88
+ resolve: function resolve() {
89
+ var resolvedPath = "";
90
+ var resolvedAbsolute = false;
91
+ var cwd;
92
+ for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {
93
+ var path;
94
+ if (i >= 0)
95
+ path = arguments[i];
96
+ else {
97
+ if (cwd === void 0)
98
+ cwd = process$1.cwd();
99
+ path = cwd;
100
+ }
101
+ assertPath(path);
102
+ if (path.length === 0) {
103
+ continue;
104
+ }
105
+ resolvedPath = path + "/" + resolvedPath;
106
+ resolvedAbsolute = path.charCodeAt(0) === 47;
107
+ }
108
+ resolvedPath = normalizeStringPosix(resolvedPath, !resolvedAbsolute);
109
+ if (resolvedAbsolute) {
110
+ if (resolvedPath.length > 0)
111
+ return "/" + resolvedPath;
112
+ else
113
+ return "/";
114
+ } else if (resolvedPath.length > 0) {
115
+ return resolvedPath;
116
+ } else {
117
+ return ".";
118
+ }
119
+ },
120
+ normalize: function normalize(path) {
121
+ assertPath(path);
122
+ if (path.length === 0) return ".";
123
+ var isAbsolute = path.charCodeAt(0) === 47;
124
+ var trailingSeparator = path.charCodeAt(path.length - 1) === 47;
125
+ path = normalizeStringPosix(path, !isAbsolute);
126
+ if (path.length === 0 && !isAbsolute) path = ".";
127
+ if (path.length > 0 && trailingSeparator) path += "/";
128
+ if (isAbsolute) return "/" + path;
129
+ return path;
130
+ },
131
+ isAbsolute: function isAbsolute(path) {
132
+ assertPath(path);
133
+ return path.length > 0 && path.charCodeAt(0) === 47;
134
+ },
135
+ join: function join() {
136
+ if (arguments.length === 0)
137
+ return ".";
138
+ var joined;
139
+ for (var i = 0; i < arguments.length; ++i) {
140
+ var arg = arguments[i];
141
+ assertPath(arg);
142
+ if (arg.length > 0) {
143
+ if (joined === void 0)
144
+ joined = arg;
145
+ else
146
+ joined += "/" + arg;
147
+ }
148
+ }
149
+ if (joined === void 0)
150
+ return ".";
151
+ return posix.normalize(joined);
152
+ },
153
+ relative: function relative(from, to) {
154
+ assertPath(from);
155
+ assertPath(to);
156
+ if (from === to) return "";
157
+ from = posix.resolve(from);
158
+ to = posix.resolve(to);
159
+ if (from === to) return "";
160
+ var fromStart = 1;
161
+ for (; fromStart < from.length; ++fromStart) {
162
+ if (from.charCodeAt(fromStart) !== 47)
163
+ break;
164
+ }
165
+ var fromEnd = from.length;
166
+ var fromLen = fromEnd - fromStart;
167
+ var toStart = 1;
168
+ for (; toStart < to.length; ++toStart) {
169
+ if (to.charCodeAt(toStart) !== 47)
170
+ break;
171
+ }
172
+ var toEnd = to.length;
173
+ var toLen = toEnd - toStart;
174
+ var length = fromLen < toLen ? fromLen : toLen;
175
+ var lastCommonSep = -1;
176
+ var i = 0;
177
+ for (; i <= length; ++i) {
178
+ if (i === length) {
179
+ if (toLen > length) {
180
+ if (to.charCodeAt(toStart + i) === 47) {
181
+ return to.slice(toStart + i + 1);
182
+ } else if (i === 0) {
183
+ return to.slice(toStart + i);
184
+ }
185
+ } else if (fromLen > length) {
186
+ if (from.charCodeAt(fromStart + i) === 47) {
187
+ lastCommonSep = i;
188
+ } else if (i === 0) {
189
+ lastCommonSep = 0;
190
+ }
191
+ }
192
+ break;
193
+ }
194
+ var fromCode = from.charCodeAt(fromStart + i);
195
+ var toCode = to.charCodeAt(toStart + i);
196
+ if (fromCode !== toCode)
197
+ break;
198
+ else if (fromCode === 47)
199
+ lastCommonSep = i;
200
+ }
201
+ var out = "";
202
+ for (i = fromStart + lastCommonSep + 1; i <= fromEnd; ++i) {
203
+ if (i === fromEnd || from.charCodeAt(i) === 47) {
204
+ if (out.length === 0)
205
+ out += "..";
206
+ else
207
+ out += "/..";
208
+ }
209
+ }
210
+ if (out.length > 0)
211
+ return out + to.slice(toStart + lastCommonSep);
212
+ else {
213
+ toStart += lastCommonSep;
214
+ if (to.charCodeAt(toStart) === 47)
215
+ ++toStart;
216
+ return to.slice(toStart);
217
+ }
218
+ },
219
+ _makeLong: function _makeLong(path) {
220
+ return path;
221
+ },
222
+ dirname: function dirname(path) {
223
+ assertPath(path);
224
+ if (path.length === 0) return ".";
225
+ var code = path.charCodeAt(0);
226
+ var hasRoot = code === 47;
227
+ var end = -1;
228
+ var matchedSlash = true;
229
+ for (var i = path.length - 1; i >= 1; --i) {
230
+ code = path.charCodeAt(i);
231
+ if (code === 47) {
232
+ if (!matchedSlash) {
233
+ end = i;
234
+ break;
235
+ }
236
+ } else {
237
+ matchedSlash = false;
238
+ }
239
+ }
240
+ if (end === -1) return hasRoot ? "/" : ".";
241
+ if (hasRoot && end === 1) return "//";
242
+ return path.slice(0, end);
243
+ },
244
+ basename: function basename(path, ext) {
245
+ if (ext !== void 0 && typeof ext !== "string") throw new TypeError('"ext" argument must be a string');
246
+ assertPath(path);
247
+ var start = 0;
248
+ var end = -1;
249
+ var matchedSlash = true;
250
+ var i;
251
+ if (ext !== void 0 && ext.length > 0 && ext.length <= path.length) {
252
+ if (ext.length === path.length && ext === path) return "";
253
+ var extIdx = ext.length - 1;
254
+ var firstNonSlashEnd = -1;
255
+ for (i = path.length - 1; i >= 0; --i) {
256
+ var code = path.charCodeAt(i);
257
+ if (code === 47) {
258
+ if (!matchedSlash) {
259
+ start = i + 1;
260
+ break;
261
+ }
262
+ } else {
263
+ if (firstNonSlashEnd === -1) {
264
+ matchedSlash = false;
265
+ firstNonSlashEnd = i + 1;
266
+ }
267
+ if (extIdx >= 0) {
268
+ if (code === ext.charCodeAt(extIdx)) {
269
+ if (--extIdx === -1) {
270
+ end = i;
271
+ }
272
+ } else {
273
+ extIdx = -1;
274
+ end = firstNonSlashEnd;
275
+ }
276
+ }
277
+ }
278
+ }
279
+ if (start === end) end = firstNonSlashEnd;
280
+ else if (end === -1) end = path.length;
281
+ return path.slice(start, end);
282
+ } else {
283
+ for (i = path.length - 1; i >= 0; --i) {
284
+ if (path.charCodeAt(i) === 47) {
285
+ if (!matchedSlash) {
286
+ start = i + 1;
287
+ break;
288
+ }
289
+ } else if (end === -1) {
290
+ matchedSlash = false;
291
+ end = i + 1;
292
+ }
293
+ }
294
+ if (end === -1) return "";
295
+ return path.slice(start, end);
296
+ }
297
+ },
298
+ extname: function extname(path) {
299
+ assertPath(path);
300
+ var startDot = -1;
301
+ var startPart = 0;
302
+ var end = -1;
303
+ var matchedSlash = true;
304
+ var preDotState = 0;
305
+ for (var i = path.length - 1; i >= 0; --i) {
306
+ var code = path.charCodeAt(i);
307
+ if (code === 47) {
308
+ if (!matchedSlash) {
309
+ startPart = i + 1;
310
+ break;
311
+ }
312
+ continue;
313
+ }
314
+ if (end === -1) {
315
+ matchedSlash = false;
316
+ end = i + 1;
317
+ }
318
+ if (code === 46) {
319
+ if (startDot === -1)
320
+ startDot = i;
321
+ else if (preDotState !== 1)
322
+ preDotState = 1;
323
+ } else if (startDot !== -1) {
324
+ preDotState = -1;
325
+ }
326
+ }
327
+ if (startDot === -1 || end === -1 || // We saw a non-dot character immediately before the dot
328
+ preDotState === 0 || // The (right-most) trimmed path component is exactly '..'
329
+ preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {
330
+ return "";
331
+ }
332
+ return path.slice(startDot, end);
333
+ },
334
+ format: function format(pathObject) {
335
+ if (pathObject === null || typeof pathObject !== "object") {
336
+ throw new TypeError('The "pathObject" argument must be of type Object. Received type ' + typeof pathObject);
337
+ }
338
+ return _format("/", pathObject);
339
+ },
340
+ parse: function parse(path) {
341
+ assertPath(path);
342
+ var ret = { root: "", dir: "", base: "", ext: "", name: "" };
343
+ if (path.length === 0) return ret;
344
+ var code = path.charCodeAt(0);
345
+ var isAbsolute = code === 47;
346
+ var start;
347
+ if (isAbsolute) {
348
+ ret.root = "/";
349
+ start = 1;
350
+ } else {
351
+ start = 0;
352
+ }
353
+ var startDot = -1;
354
+ var startPart = 0;
355
+ var end = -1;
356
+ var matchedSlash = true;
357
+ var i = path.length - 1;
358
+ var preDotState = 0;
359
+ for (; i >= start; --i) {
360
+ code = path.charCodeAt(i);
361
+ if (code === 47) {
362
+ if (!matchedSlash) {
363
+ startPart = i + 1;
364
+ break;
365
+ }
366
+ continue;
367
+ }
368
+ if (end === -1) {
369
+ matchedSlash = false;
370
+ end = i + 1;
371
+ }
372
+ if (code === 46) {
373
+ if (startDot === -1) startDot = i;
374
+ else if (preDotState !== 1) preDotState = 1;
375
+ } else if (startDot !== -1) {
376
+ preDotState = -1;
377
+ }
378
+ }
379
+ if (startDot === -1 || end === -1 || // We saw a non-dot character immediately before the dot
380
+ preDotState === 0 || // The (right-most) trimmed path component is exactly '..'
381
+ preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {
382
+ if (end !== -1) {
383
+ if (startPart === 0 && isAbsolute) ret.base = ret.name = path.slice(1, end);
384
+ else ret.base = ret.name = path.slice(startPart, end);
385
+ }
386
+ } else {
387
+ if (startPart === 0 && isAbsolute) {
388
+ ret.name = path.slice(1, startDot);
389
+ ret.base = path.slice(1, end);
390
+ } else {
391
+ ret.name = path.slice(startPart, startDot);
392
+ ret.base = path.slice(startPart, end);
393
+ }
394
+ ret.ext = path.slice(startDot, end);
395
+ }
396
+ if (startPart > 0) ret.dir = path.slice(0, startPart - 1);
397
+ else if (isAbsolute) ret.dir = "/";
398
+ return ret;
399
+ },
400
+ sep: "/",
401
+ delimiter: ":",
402
+ win32: null,
403
+ posix: null
404
+ };
405
+ posix.posix = posix;
406
+ pathBrowserify = posix;
407
+ return pathBrowserify;
149
408
  }
150
409
  export {
151
- fromTwos,
152
- getBigInt,
153
- getNumber,
154
- getUint,
155
- mask,
156
- toBeArray,
157
- toBeHex,
158
- toBigInt,
159
- toNumber,
160
- toTwos
410
+ requirePathBrowserify as __require
161
411
  };
162
412
  //# sourceMappingURL=standards-sdk.es61.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es61.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.es61.js","sources":["../../node_modules/path-browserify/index.js"],"sourcesContent":["// 'path' module extracted from Node.js v8.11.1 (only the posix part)\n// transplited with Babel\n\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nfunction assertPath(path) {\n if (typeof path !== 'string') {\n throw new TypeError('Path must be a string. Received ' + JSON.stringify(path));\n }\n}\n\n// Resolves . and .. elements in a path with directory names\nfunction normalizeStringPosix(path, allowAboveRoot) {\n var res = '';\n var lastSegmentLength = 0;\n var lastSlash = -1;\n var dots = 0;\n var code;\n for (var i = 0; i <= path.length; ++i) {\n if (i < path.length)\n code = path.charCodeAt(i);\n else if (code === 47 /*/*/)\n break;\n else\n code = 47 /*/*/;\n if (code === 47 /*/*/) {\n if (lastSlash === i - 1 || dots === 1) {\n // NOOP\n } else if (lastSlash !== i - 1 && dots === 2) {\n if (res.length < 2 || lastSegmentLength !== 2 || res.charCodeAt(res.length - 1) !== 46 /*.*/ || res.charCodeAt(res.length - 2) !== 46 /*.*/) {\n if (res.length > 2) {\n var lastSlashIndex = res.lastIndexOf('/');\n if (lastSlashIndex !== res.length - 1) {\n if (lastSlashIndex === -1) {\n res = '';\n lastSegmentLength = 0;\n } else {\n res = res.slice(0, lastSlashIndex);\n lastSegmentLength = res.length - 1 - res.lastIndexOf('/');\n }\n lastSlash = i;\n dots = 0;\n continue;\n }\n } else if (res.length === 2 || res.length === 1) {\n res = '';\n lastSegmentLength = 0;\n lastSlash = i;\n dots = 0;\n continue;\n }\n }\n if (allowAboveRoot) {\n if (res.length > 0)\n res += '/..';\n else\n res = '..';\n lastSegmentLength = 2;\n }\n } else {\n if (res.length > 0)\n res += '/' + path.slice(lastSlash + 1, i);\n else\n res = path.slice(lastSlash + 1, i);\n lastSegmentLength = i - lastSlash - 1;\n }\n lastSlash = i;\n dots = 0;\n } else if (code === 46 /*.*/ && dots !== -1) {\n ++dots;\n } else {\n dots = -1;\n }\n }\n return res;\n}\n\nfunction _format(sep, pathObject) {\n var dir = pathObject.dir || pathObject.root;\n var base = pathObject.base || (pathObject.name || '') + (pathObject.ext || '');\n if (!dir) {\n return base;\n }\n if (dir === pathObject.root) {\n return dir + base;\n }\n return dir + sep + base;\n}\n\nvar posix = {\n // path.resolve([from ...], to)\n resolve: function resolve() {\n var resolvedPath = '';\n var resolvedAbsolute = false;\n var cwd;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path;\n if (i >= 0)\n path = arguments[i];\n else {\n if (cwd === undefined)\n cwd = process.cwd();\n path = cwd;\n }\n\n assertPath(path);\n\n // Skip empty entries\n if (path.length === 0) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charCodeAt(0) === 47 /*/*/;\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeStringPosix(resolvedPath, !resolvedAbsolute);\n\n if (resolvedAbsolute) {\n if (resolvedPath.length > 0)\n return '/' + resolvedPath;\n else\n return '/';\n } else if (resolvedPath.length > 0) {\n return resolvedPath;\n } else {\n return '.';\n }\n },\n\n normalize: function normalize(path) {\n assertPath(path);\n\n if (path.length === 0) return '.';\n\n var isAbsolute = path.charCodeAt(0) === 47 /*/*/;\n var trailingSeparator = path.charCodeAt(path.length - 1) === 47 /*/*/;\n\n // Normalize the path\n path = normalizeStringPosix(path, !isAbsolute);\n\n if (path.length === 0 && !isAbsolute) path = '.';\n if (path.length > 0 && trailingSeparator) path += '/';\n\n if (isAbsolute) return '/' + path;\n return path;\n },\n\n isAbsolute: function isAbsolute(path) {\n assertPath(path);\n return path.length > 0 && path.charCodeAt(0) === 47 /*/*/;\n },\n\n join: function join() {\n if (arguments.length === 0)\n return '.';\n var joined;\n for (var i = 0; i < arguments.length; ++i) {\n var arg = arguments[i];\n assertPath(arg);\n if (arg.length > 0) {\n if (joined === undefined)\n joined = arg;\n else\n joined += '/' + arg;\n }\n }\n if (joined === undefined)\n return '.';\n return posix.normalize(joined);\n },\n\n relative: function relative(from, to) {\n assertPath(from);\n assertPath(to);\n\n if (from === to) return '';\n\n from = posix.resolve(from);\n to = posix.resolve(to);\n\n if (from === to) return '';\n\n // Trim any leading backslashes\n var fromStart = 1;\n for (; fromStart < from.length; ++fromStart) {\n if (from.charCodeAt(fromStart) !== 47 /*/*/)\n break;\n }\n var fromEnd = from.length;\n var fromLen = fromEnd - fromStart;\n\n // Trim any leading backslashes\n var toStart = 1;\n for (; toStart < to.length; ++toStart) {\n if (to.charCodeAt(toStart) !== 47 /*/*/)\n break;\n }\n var toEnd = to.length;\n var toLen = toEnd - toStart;\n\n // Compare paths to find the longest common path from root\n var length = fromLen < toLen ? fromLen : toLen;\n var lastCommonSep = -1;\n var i = 0;\n for (; i <= length; ++i) {\n if (i === length) {\n if (toLen > length) {\n if (to.charCodeAt(toStart + i) === 47 /*/*/) {\n // We get here if `from` is the exact base path for `to`.\n // For example: from='/foo/bar'; to='/foo/bar/baz'\n return to.slice(toStart + i + 1);\n } else if (i === 0) {\n // We get here if `from` is the root\n // For example: from='/'; to='/foo'\n return to.slice(toStart + i);\n }\n } else if (fromLen > length) {\n if (from.charCodeAt(fromStart + i) === 47 /*/*/) {\n // We get here if `to` is the exact base path for `from`.\n // For example: from='/foo/bar/baz'; to='/foo/bar'\n lastCommonSep = i;\n } else if (i === 0) {\n // We get here if `to` is the root.\n // For example: from='/foo'; to='/'\n lastCommonSep = 0;\n }\n }\n break;\n }\n var fromCode = from.charCodeAt(fromStart + i);\n var toCode = to.charCodeAt(toStart + i);\n if (fromCode !== toCode)\n break;\n else if (fromCode === 47 /*/*/)\n lastCommonSep = i;\n }\n\n var out = '';\n // Generate the relative path based on the path difference between `to`\n // and `from`\n for (i = fromStart + lastCommonSep + 1; i <= fromEnd; ++i) {\n if (i === fromEnd || from.charCodeAt(i) === 47 /*/*/) {\n if (out.length === 0)\n out += '..';\n else\n out += '/..';\n }\n }\n\n // Lastly, append the rest of the destination (`to`) path that comes after\n // the common path parts\n if (out.length > 0)\n return out + to.slice(toStart + lastCommonSep);\n else {\n toStart += lastCommonSep;\n if (to.charCodeAt(toStart) === 47 /*/*/)\n ++toStart;\n return to.slice(toStart);\n }\n },\n\n _makeLong: function _makeLong(path) {\n return path;\n },\n\n dirname: function dirname(path) {\n assertPath(path);\n if (path.length === 0) return '.';\n var code = path.charCodeAt(0);\n var hasRoot = code === 47 /*/*/;\n var end = -1;\n var matchedSlash = true;\n for (var i = path.length - 1; i >= 1; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n } else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n\n if (end === -1) return hasRoot ? '/' : '.';\n if (hasRoot && end === 1) return '//';\n return path.slice(0, end);\n },\n\n basename: function basename(path, ext) {\n if (ext !== undefined && typeof ext !== 'string') throw new TypeError('\"ext\" argument must be a string');\n assertPath(path);\n\n var start = 0;\n var end = -1;\n var matchedSlash = true;\n var i;\n\n if (ext !== undefined && ext.length > 0 && ext.length <= path.length) {\n if (ext.length === path.length && ext === path) return '';\n var extIdx = ext.length - 1;\n var firstNonSlashEnd = -1;\n for (i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else {\n if (firstNonSlashEnd === -1) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching\n matchedSlash = false;\n firstNonSlashEnd = i + 1;\n }\n if (extIdx >= 0) {\n // Try to match the explicit extension\n if (code === ext.charCodeAt(extIdx)) {\n if (--extIdx === -1) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = i;\n }\n } else {\n // Extension does not match, so our result is the entire path\n // component\n extIdx = -1;\n end = firstNonSlashEnd;\n }\n }\n }\n }\n\n if (start === end) end = firstNonSlashEnd;else if (end === -1) end = path.length;\n return path.slice(start, end);\n } else {\n for (i = path.length - 1; i >= 0; --i) {\n if (path.charCodeAt(i) === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n\n if (end === -1) return '';\n return path.slice(start, end);\n }\n },\n\n extname: function extname(path) {\n assertPath(path);\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n for (var i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1)\n startDot = i;\n else if (preDotState !== 1)\n preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n return '';\n }\n return path.slice(startDot, end);\n },\n\n format: function format(pathObject) {\n if (pathObject === null || typeof pathObject !== 'object') {\n throw new TypeError('The \"pathObject\" argument must be of type Object. Received type ' + typeof pathObject);\n }\n return _format('/', pathObject);\n },\n\n parse: function parse(path) {\n assertPath(path);\n\n var ret = { root: '', dir: '', base: '', ext: '', name: '' };\n if (path.length === 0) return ret;\n var code = path.charCodeAt(0);\n var isAbsolute = code === 47 /*/*/;\n var start;\n if (isAbsolute) {\n ret.root = '/';\n start = 1;\n } else {\n start = 0;\n }\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n var i = path.length - 1;\n\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n\n // Get non-dir info\n for (; i >= start; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) startDot = i;else if (preDotState !== 1) preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n if (end !== -1) {\n if (startPart === 0 && isAbsolute) ret.base = ret.name = path.slice(1, end);else ret.base = ret.name = path.slice(startPart, end);\n }\n } else {\n if (startPart === 0 && isAbsolute) {\n ret.name = path.slice(1, startDot);\n ret.base = path.slice(1, end);\n } else {\n ret.name = path.slice(startPart, startDot);\n ret.base = path.slice(startPart, end);\n }\n ret.ext = path.slice(startDot, end);\n }\n\n if (startPart > 0) ret.dir = path.slice(0, startPart - 1);else if (isAbsolute) ret.dir = '/';\n\n return ret;\n },\n\n sep: '/',\n delimiter: ':',\n win32: null,\n posix: null\n};\n\nposix.posix = posix;\n\nmodule.exports = posix;\n"],"names":["process"],"mappings":";;;;;;AA0BA,WAAS,WAAW,MAAM;AACxB,QAAI,OAAO,SAAS,UAAU;AAC5B,YAAM,IAAI,UAAU,qCAAqC,KAAK,UAAU,IAAI,CAAC;AAAA,IACjF;AAAA,EACA;AAGA,WAAS,qBAAqB,MAAM,gBAAgB;AAClD,QAAI,MAAM;AACV,QAAI,oBAAoB;AACxB,QAAI,YAAY;AAChB,QAAI,OAAO;AACX,QAAI;AACJ,aAAS,IAAI,GAAG,KAAK,KAAK,QAAQ,EAAE,GAAG;AACrC,UAAI,IAAI,KAAK;AACX,eAAO,KAAK,WAAW,CAAC;AAAA,eACjB,SAAS;AAChB;AAAA;AAEA,eAAO;AACT,UAAI,SAAS,IAAU;AACrB,YAAI,cAAc,IAAI,KAAK,SAAS,EAAG;AAAA,iBAE5B,cAAc,IAAI,KAAK,SAAS,GAAG;AAC5C,cAAI,IAAI,SAAS,KAAK,sBAAsB,KAAK,IAAI,WAAW,IAAI,SAAS,CAAC,MAAM,MAAY,IAAI,WAAW,IAAI,SAAS,CAAC,MAAM,IAAU;AAC3I,gBAAI,IAAI,SAAS,GAAG;AAClB,kBAAI,iBAAiB,IAAI,YAAY,GAAG;AACxC,kBAAI,mBAAmB,IAAI,SAAS,GAAG;AACrC,oBAAI,mBAAmB,IAAI;AACzB,wBAAM;AACN,sCAAoB;AAAA,gBACpC,OAAqB;AACL,wBAAM,IAAI,MAAM,GAAG,cAAc;AACjC,sCAAoB,IAAI,SAAS,IAAI,IAAI,YAAY,GAAG;AAAA,gBACxE;AACc,4BAAY;AACZ,uBAAO;AACP;AAAA,cACd;AAAA,YACA,WAAqB,IAAI,WAAW,KAAK,IAAI,WAAW,GAAG;AAC/C,oBAAM;AACN,kCAAoB;AACpB,0BAAY;AACZ,qBAAO;AACP;AAAA,YACZ;AAAA,UACA;AACQ,cAAI,gBAAgB;AAClB,gBAAI,IAAI,SAAS;AACf,qBAAO;AAAA;AAEP,oBAAM;AACR,gCAAoB;AAAA,UAC9B;AAAA,QACA,OAAa;AACL,cAAI,IAAI,SAAS;AACf,mBAAO,MAAM,KAAK,MAAM,YAAY,GAAG,CAAC;AAAA;AAExC,kBAAM,KAAK,MAAM,YAAY,GAAG,CAAC;AACnC,8BAAoB,IAAI,YAAY;AAAA,QAC5C;AACM,oBAAY;AACZ,eAAO;AAAA,MACR,WAAU,SAAS,MAAY,SAAS,IAAI;AAC3C,UAAE;AAAA,MACR,OAAW;AACL,eAAO;AAAA,MACb;AAAA,IACA;AACE,WAAO;AAAA,EACT;AAEA,WAAS,QAAQ,KAAK,YAAY;AAChC,QAAI,MAAM,WAAW,OAAO,WAAW;AACvC,QAAI,OAAO,WAAW,SAAS,WAAW,QAAQ,OAAO,WAAW,OAAO;AAC3E,QAAI,CAAC,KAAK;AACR,aAAO;AAAA,IACX;AACE,QAAI,QAAQ,WAAW,MAAM;AAC3B,aAAO,MAAM;AAAA,IACjB;AACE,WAAO,MAAM,MAAM;AAAA,EACrB;AAEA,MAAI,QAAQ;AAAA;AAAA,IAEV,SAAS,SAAS,UAAU;AAC1B,UAAI,eAAe;AACnB,UAAI,mBAAmB;AACvB,UAAI;AAEJ,eAAS,IAAI,UAAU,SAAS,GAAG,KAAK,MAAM,CAAC,kBAAkB,KAAK;AACpE,YAAI;AACJ,YAAI,KAAK;AACP,iBAAO,UAAU,CAAC;AAAA,aACf;AACH,cAAI,QAAQ;AACV,kBAAMA,UAAQ,IAAK;AACrB,iBAAO;AAAA,QACf;AAEM,mBAAW,IAAI;AAGf,YAAI,KAAK,WAAW,GAAG;AACrB;AAAA,QACR;AAEM,uBAAe,OAAO,MAAM;AAC5B,2BAAmB,KAAK,WAAW,CAAC,MAAM;AAAA,MAChD;AAMI,qBAAe,qBAAqB,cAAc,CAAC,gBAAgB;AAEnE,UAAI,kBAAkB;AACpB,YAAI,aAAa,SAAS;AACxB,iBAAO,MAAM;AAAA;AAEb,iBAAO;AAAA,MACf,WAAe,aAAa,SAAS,GAAG;AAClC,eAAO;AAAA,MACb,OAAW;AACL,eAAO;AAAA,MACb;AAAA,IACG;AAAA,IAED,WAAW,SAAS,UAAU,MAAM;AAClC,iBAAW,IAAI;AAEf,UAAI,KAAK,WAAW,EAAG,QAAO;AAE9B,UAAI,aAAa,KAAK,WAAW,CAAC,MAAM;AACxC,UAAI,oBAAoB,KAAK,WAAW,KAAK,SAAS,CAAC,MAAM;AAG7D,aAAO,qBAAqB,MAAM,CAAC,UAAU;AAE7C,UAAI,KAAK,WAAW,KAAK,CAAC,WAAY,QAAO;AAC7C,UAAI,KAAK,SAAS,KAAK,kBAAmB,SAAQ;AAElD,UAAI,WAAY,QAAO,MAAM;AAC7B,aAAO;AAAA,IACR;AAAA,IAED,YAAY,SAAS,WAAW,MAAM;AACpC,iBAAW,IAAI;AACf,aAAO,KAAK,SAAS,KAAK,KAAK,WAAW,CAAC,MAAM;AAAA,IAClD;AAAA,IAED,MAAM,SAAS,OAAO;AACpB,UAAI,UAAU,WAAW;AACvB,eAAO;AACT,UAAI;AACJ,eAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,EAAE,GAAG;AACzC,YAAI,MAAM,UAAU,CAAC;AACrB,mBAAW,GAAG;AACd,YAAI,IAAI,SAAS,GAAG;AAClB,cAAI,WAAW;AACb,qBAAS;AAAA;AAET,sBAAU,MAAM;AAAA,QAC1B;AAAA,MACA;AACI,UAAI,WAAW;AACb,eAAO;AACT,aAAO,MAAM,UAAU,MAAM;AAAA,IAC9B;AAAA,IAED,UAAU,SAAS,SAAS,MAAM,IAAI;AACpC,iBAAW,IAAI;AACf,iBAAW,EAAE;AAEb,UAAI,SAAS,GAAI,QAAO;AAExB,aAAO,MAAM,QAAQ,IAAI;AACzB,WAAK,MAAM,QAAQ,EAAE;AAErB,UAAI,SAAS,GAAI,QAAO;AAGxB,UAAI,YAAY;AAChB,aAAO,YAAY,KAAK,QAAQ,EAAE,WAAW;AAC3C,YAAI,KAAK,WAAW,SAAS,MAAM;AACjC;AAAA,MACR;AACI,UAAI,UAAU,KAAK;AACnB,UAAI,UAAU,UAAU;AAGxB,UAAI,UAAU;AACd,aAAO,UAAU,GAAG,QAAQ,EAAE,SAAS;AACrC,YAAI,GAAG,WAAW,OAAO,MAAM;AAC7B;AAAA,MACR;AACI,UAAI,QAAQ,GAAG;AACf,UAAI,QAAQ,QAAQ;AAGpB,UAAI,SAAS,UAAU,QAAQ,UAAU;AACzC,UAAI,gBAAgB;AACpB,UAAI,IAAI;AACR,aAAO,KAAK,QAAQ,EAAE,GAAG;AACvB,YAAI,MAAM,QAAQ;AAChB,cAAI,QAAQ,QAAQ;AAClB,gBAAI,GAAG,WAAW,UAAU,CAAC,MAAM,IAAU;AAG3C,qBAAO,GAAG,MAAM,UAAU,IAAI,CAAC;AAAA,YAC3C,WAAqB,MAAM,GAAG;AAGlB,qBAAO,GAAG,MAAM,UAAU,CAAC;AAAA,YACvC;AAAA,UACA,WAAmB,UAAU,QAAQ;AAC3B,gBAAI,KAAK,WAAW,YAAY,CAAC,MAAM,IAAU;AAG/C,8BAAgB;AAAA,YAC5B,WAAqB,MAAM,GAAG;AAGlB,8BAAgB;AAAA,YAC5B;AAAA,UACA;AACQ;AAAA,QACR;AACM,YAAI,WAAW,KAAK,WAAW,YAAY,CAAC;AAC5C,YAAI,SAAS,GAAG,WAAW,UAAU,CAAC;AACtC,YAAI,aAAa;AACf;AAAA,iBACO,aAAa;AACpB,0BAAgB;AAAA,MACxB;AAEI,UAAI,MAAM;AAGV,WAAK,IAAI,YAAY,gBAAgB,GAAG,KAAK,SAAS,EAAE,GAAG;AACzD,YAAI,MAAM,WAAW,KAAK,WAAW,CAAC,MAAM,IAAU;AACpD,cAAI,IAAI,WAAW;AACjB,mBAAO;AAAA;AAEP,mBAAO;AAAA,QACjB;AAAA,MACA;AAII,UAAI,IAAI,SAAS;AACf,eAAO,MAAM,GAAG,MAAM,UAAU,aAAa;AAAA,WAC1C;AACH,mBAAW;AACX,YAAI,GAAG,WAAW,OAAO,MAAM;AAC7B,YAAE;AACJ,eAAO,GAAG,MAAM,OAAO;AAAA,MAC7B;AAAA,IACG;AAAA,IAED,WAAW,SAAS,UAAU,MAAM;AAClC,aAAO;AAAA,IACR;AAAA,IAED,SAAS,SAAS,QAAQ,MAAM;AAC9B,iBAAW,IAAI;AACf,UAAI,KAAK,WAAW,EAAG,QAAO;AAC9B,UAAI,OAAO,KAAK,WAAW,CAAC;AAC5B,UAAI,UAAU,SAAS;AACvB,UAAI,MAAM;AACV,UAAI,eAAe;AACnB,eAAS,IAAI,KAAK,SAAS,GAAG,KAAK,GAAG,EAAE,GAAG;AACzC,eAAO,KAAK,WAAW,CAAC;AACxB,YAAI,SAAS,IAAU;AACnB,cAAI,CAAC,cAAc;AACjB,kBAAM;AACN;AAAA,UACZ;AAAA,QACA,OAAe;AAEP,yBAAe;AAAA,QACvB;AAAA,MACA;AAEI,UAAI,QAAQ,GAAI,QAAO,UAAU,MAAM;AACvC,UAAI,WAAW,QAAQ,EAAG,QAAO;AACjC,aAAO,KAAK,MAAM,GAAG,GAAG;AAAA,IACzB;AAAA,IAED,UAAU,SAAS,SAAS,MAAM,KAAK;AACrC,UAAI,QAAQ,UAAa,OAAO,QAAQ,SAAU,OAAM,IAAI,UAAU,iCAAiC;AACvG,iBAAW,IAAI;AAEf,UAAI,QAAQ;AACZ,UAAI,MAAM;AACV,UAAI,eAAe;AACnB,UAAI;AAEJ,UAAI,QAAQ,UAAa,IAAI,SAAS,KAAK,IAAI,UAAU,KAAK,QAAQ;AACpE,YAAI,IAAI,WAAW,KAAK,UAAU,QAAQ,KAAM,QAAO;AACvD,YAAI,SAAS,IAAI,SAAS;AAC1B,YAAI,mBAAmB;AACvB,aAAK,IAAI,KAAK,SAAS,GAAG,KAAK,GAAG,EAAE,GAAG;AACrC,cAAI,OAAO,KAAK,WAAW,CAAC;AAC5B,cAAI,SAAS,IAAU;AAGnB,gBAAI,CAAC,cAAc;AACjB,sBAAQ,IAAI;AACZ;AAAA,YACd;AAAA,UACA,OAAiB;AACP,gBAAI,qBAAqB,IAAI;AAG3B,6BAAe;AACf,iCAAmB,IAAI;AAAA,YACnC;AACU,gBAAI,UAAU,GAAG;AAEf,kBAAI,SAAS,IAAI,WAAW,MAAM,GAAG;AACnC,oBAAI,EAAE,WAAW,IAAI;AAGnB,wBAAM;AAAA,gBACtB;AAAA,cACA,OAAmB;AAGL,yBAAS;AACT,sBAAM;AAAA,cACpB;AAAA,YACA;AAAA,UACA;AAAA,QACA;AAEM,YAAI,UAAU,IAAK,OAAM;AAAA,iBAA0B,QAAQ,GAAI,OAAM,KAAK;AAC1E,eAAO,KAAK,MAAM,OAAO,GAAG;AAAA,MAClC,OAAW;AACL,aAAK,IAAI,KAAK,SAAS,GAAG,KAAK,GAAG,EAAE,GAAG;AACrC,cAAI,KAAK,WAAW,CAAC,MAAM,IAAU;AAGjC,gBAAI,CAAC,cAAc;AACjB,sBAAQ,IAAI;AACZ;AAAA,YACd;AAAA,UACA,WAAqB,QAAQ,IAAI;AAGvB,2BAAe;AACf,kBAAM,IAAI;AAAA,UACpB;AAAA,QACA;AAEM,YAAI,QAAQ,GAAI,QAAO;AACvB,eAAO,KAAK,MAAM,OAAO,GAAG;AAAA,MAClC;AAAA,IACG;AAAA,IAED,SAAS,SAAS,QAAQ,MAAM;AAC9B,iBAAW,IAAI;AACf,UAAI,WAAW;AACf,UAAI,YAAY;AAChB,UAAI,MAAM;AACV,UAAI,eAAe;AAGnB,UAAI,cAAc;AAClB,eAAS,IAAI,KAAK,SAAS,GAAG,KAAK,GAAG,EAAE,GAAG;AACzC,YAAI,OAAO,KAAK,WAAW,CAAC;AAC5B,YAAI,SAAS,IAAU;AAGnB,cAAI,CAAC,cAAc;AACjB,wBAAY,IAAI;AAChB;AAAA,UACZ;AACU;AAAA,QACV;AACM,YAAI,QAAQ,IAAI;AAGd,yBAAe;AACf,gBAAM,IAAI;AAAA,QAClB;AACM,YAAI,SAAS,IAAU;AAEnB,cAAI,aAAa;AACf,uBAAW;AAAA,mBACJ,gBAAgB;AACvB,0BAAc;AAAA,QAC1B,WAAiB,aAAa,IAAI;AAG1B,wBAAc;AAAA,QACtB;AAAA,MACA;AAEI,UAAI,aAAa,MAAM,QAAQ;AAAA,MAE3B,gBAAgB;AAAA,MAEhB,gBAAgB,KAAK,aAAa,MAAM,KAAK,aAAa,YAAY,GAAG;AAC3E,eAAO;AAAA,MACb;AACI,aAAO,KAAK,MAAM,UAAU,GAAG;AAAA,IAChC;AAAA,IAED,QAAQ,SAAS,OAAO,YAAY;AAClC,UAAI,eAAe,QAAQ,OAAO,eAAe,UAAU;AACzD,cAAM,IAAI,UAAU,qEAAqE,OAAO,UAAU;AAAA,MAChH;AACI,aAAO,QAAQ,KAAK,UAAU;AAAA,IAC/B;AAAA,IAED,OAAO,SAAS,MAAM,MAAM;AAC1B,iBAAW,IAAI;AAEf,UAAI,MAAM,EAAE,MAAM,IAAI,KAAK,IAAI,MAAM,IAAI,KAAK,IAAI,MAAM,GAAI;AAC5D,UAAI,KAAK,WAAW,EAAG,QAAO;AAC9B,UAAI,OAAO,KAAK,WAAW,CAAC;AAC5B,UAAI,aAAa,SAAS;AAC1B,UAAI;AACJ,UAAI,YAAY;AACd,YAAI,OAAO;AACX,gBAAQ;AAAA,MACd,OAAW;AACL,gBAAQ;AAAA,MACd;AACI,UAAI,WAAW;AACf,UAAI,YAAY;AAChB,UAAI,MAAM;AACV,UAAI,eAAe;AACnB,UAAI,IAAI,KAAK,SAAS;AAItB,UAAI,cAAc;AAGlB,aAAO,KAAK,OAAO,EAAE,GAAG;AACtB,eAAO,KAAK,WAAW,CAAC;AACxB,YAAI,SAAS,IAAU;AAGnB,cAAI,CAAC,cAAc;AACjB,wBAAY,IAAI;AAChB;AAAA,UACZ;AACU;AAAA,QACV;AACM,YAAI,QAAQ,IAAI;AAGd,yBAAe;AACf,gBAAM,IAAI;AAAA,QAClB;AACM,YAAI,SAAS,IAAU;AAEnB,cAAI,aAAa,GAAI,YAAW;AAAA,mBAAW,gBAAgB,EAAG,eAAc;AAAA,QACtF,WAAmB,aAAa,IAAI;AAG5B,wBAAc;AAAA,QACtB;AAAA,MACA;AAEI,UAAI,aAAa,MAAM,QAAQ;AAAA,MAE/B,gBAAgB;AAAA,MAEhB,gBAAgB,KAAK,aAAa,MAAM,KAAK,aAAa,YAAY,GAAG;AACvE,YAAI,QAAQ,IAAI;AACd,cAAI,cAAc,KAAK,WAAY,KAAI,OAAO,IAAI,OAAO,KAAK,MAAM,GAAG,GAAG;AAAA,cAAO,KAAI,OAAO,IAAI,OAAO,KAAK,MAAM,WAAW,GAAG;AAAA,QACxI;AAAA,MACA,OAAW;AACL,YAAI,cAAc,KAAK,YAAY;AACjC,cAAI,OAAO,KAAK,MAAM,GAAG,QAAQ;AACjC,cAAI,OAAO,KAAK,MAAM,GAAG,GAAG;AAAA,QACpC,OAAa;AACL,cAAI,OAAO,KAAK,MAAM,WAAW,QAAQ;AACzC,cAAI,OAAO,KAAK,MAAM,WAAW,GAAG;AAAA,QAC5C;AACM,YAAI,MAAM,KAAK,MAAM,UAAU,GAAG;AAAA,MACxC;AAEI,UAAI,YAAY,EAAG,KAAI,MAAM,KAAK,MAAM,GAAG,YAAY,CAAC;AAAA,eAAW,WAAY,KAAI,MAAM;AAEzF,aAAO;AAAA,IACR;AAAA,IAED,KAAK;AAAA,IACL,WAAW;AAAA,IACX,OAAO;AAAA,IACP,OAAO;AAAA,EACR;AAED,QAAM,QAAQ;AAEd,mBAAiB;;;","x_google_ignoreList":[0]}