wadis 1.0.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.
package/dist/index.cjs ADDED
@@ -0,0 +1,4771 @@
1
+ 'use strict';
2
+
3
+ var net = require('net');
4
+ var Redis = require('ioredis');
5
+
6
+ var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
7
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
8
+
9
+ var Redis__default = /*#__PURE__*/_interopDefault(Redis);
10
+
11
+ // build/redis.js
12
+ async function Module(moduleArg = {}) {
13
+ var moduleRtn;
14
+ var Module2 = moduleArg;
15
+ var ENVIRONMENT_IS_NODE = true;
16
+ {
17
+ const { createRequire } = await import('module');
18
+ var require2 = createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('index.cjs', document.baseURI).href)));
19
+ }
20
+ var arguments_ = [];
21
+ var thisProgram = "./this.program";
22
+ var quit_ = (status, toThrow) => {
23
+ throw toThrow;
24
+ };
25
+ var _scriptName = (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('index.cjs', document.baseURI).href));
26
+ var scriptDirectory = "";
27
+ function locateFile(path) {
28
+ if (Module2["locateFile"]) {
29
+ return Module2["locateFile"](path, scriptDirectory);
30
+ }
31
+ return scriptDirectory + path;
32
+ }
33
+ var readAsync, readBinary;
34
+ {
35
+ var nodeVersion = process.versions.node;
36
+ var numericVersion = nodeVersion.split(".").slice(0, 3);
37
+ numericVersion = numericVersion[0] * 1e4 + numericVersion[1] * 100 + numericVersion[2].split("-")[0] * 1;
38
+ if (numericVersion < 16e4) {
39
+ throw new Error("This emscripten-generated code requires node v16.0.0 (detected v" + nodeVersion + ")");
40
+ }
41
+ var fs = require2("fs");
42
+ if (_scriptName.startsWith("file:")) {
43
+ scriptDirectory = require2("path").dirname(require2("url").fileURLToPath(_scriptName)) + "/";
44
+ }
45
+ readBinary = (filename) => {
46
+ filename = isFileURI(filename) ? new URL(filename) : filename;
47
+ var ret = fs.readFileSync(filename);
48
+ assert(Buffer.isBuffer(ret));
49
+ return ret;
50
+ };
51
+ readAsync = async (filename, binary = true) => {
52
+ filename = isFileURI(filename) ? new URL(filename) : filename;
53
+ var ret = fs.readFileSync(filename, binary ? void 0 : "utf8");
54
+ assert(binary ? Buffer.isBuffer(ret) : typeof ret == "string");
55
+ return ret;
56
+ };
57
+ if (process.argv.length > 1) {
58
+ thisProgram = process.argv[1].replace(/\\/g, "/");
59
+ }
60
+ arguments_ = process.argv.slice(2);
61
+ quit_ = (status, toThrow) => {
62
+ process.exitCode = status;
63
+ throw toThrow;
64
+ };
65
+ }
66
+ var out = console.log.bind(console);
67
+ var err = console.error.bind(console);
68
+ assert(true, "web environment detected but not enabled at build time. Add `web` to `-sENVIRONMENT` to enable.");
69
+ assert(true, "worker environment detected but not enabled at build time. Add `worker` to `-sENVIRONMENT` to enable.");
70
+ assert(true, "shell environment detected but not enabled at build time. Add `shell` to `-sENVIRONMENT` to enable.");
71
+ var wasmBinary;
72
+ if (typeof WebAssembly != "object") {
73
+ err("no native wasm support detected");
74
+ }
75
+ var ABORT = false;
76
+ var EXITSTATUS;
77
+ function assert(condition, text) {
78
+ if (!condition) {
79
+ abort("Assertion failed" + (text ? ": " + text : ""));
80
+ }
81
+ }
82
+ var isFileURI = (filename) => filename.startsWith("file://");
83
+ function writeStackCookie() {
84
+ var max = _emscripten_stack_get_end();
85
+ assert((max & 3) == 0);
86
+ if (max == 0) {
87
+ max += 4;
88
+ }
89
+ HEAPU32[max >> 2] = 34821223;
90
+ HEAPU32[max + 4 >> 2] = 2310721022;
91
+ HEAPU32[0 >> 2] = 1668509029;
92
+ }
93
+ function checkStackCookie() {
94
+ if (ABORT) return;
95
+ var max = _emscripten_stack_get_end();
96
+ if (max == 0) {
97
+ max += 4;
98
+ }
99
+ var cookie1 = HEAPU32[max >> 2];
100
+ var cookie2 = HEAPU32[max + 4 >> 2];
101
+ if (cookie1 != 34821223 || cookie2 != 2310721022) {
102
+ abort(`Stack overflow! Stack cookie has been overwritten at ${ptrToString(max)}, expected hex dwords 0x89BACDFE and 0x2135467, but received ${ptrToString(cookie2)} ${ptrToString(cookie1)}`);
103
+ }
104
+ if (HEAPU32[0 >> 2] != 1668509029) {
105
+ abort("Runtime error: The application has corrupted its heap memory area (address zero)!");
106
+ }
107
+ }
108
+ (() => {
109
+ var h16 = new Int16Array(1);
110
+ var h8 = new Int8Array(h16.buffer);
111
+ h16[0] = 25459;
112
+ if (h8[0] !== 115 || h8[1] !== 99) abort("Runtime error: expected the system to be little-endian! (Run with -sSUPPORT_BIG_ENDIAN to bypass)");
113
+ })();
114
+ function consumedModuleProp(prop) {
115
+ if (!Object.getOwnPropertyDescriptor(Module2, prop)) {
116
+ Object.defineProperty(Module2, prop, { configurable: true, set() {
117
+ abort(`Attempt to set \`Module.${prop}\` after it has already been processed. This can happen, for example, when code is injected via '--post-js' rather than '--pre-js'`);
118
+ } });
119
+ }
120
+ }
121
+ function makeInvalidEarlyAccess(name) {
122
+ return () => assert(false, `call to '${name}' via reference taken before Wasm module initialization`);
123
+ }
124
+ function ignoredModuleProp(prop) {
125
+ if (Object.getOwnPropertyDescriptor(Module2, prop)) {
126
+ abort(`\`Module.${prop}\` was supplied but \`${prop}\` not included in INCOMING_MODULE_JS_API`);
127
+ }
128
+ }
129
+ function isExportedByForceFilesystem(name) {
130
+ return name === "FS_createPath" || name === "FS_createDataFile" || name === "FS_createPreloadedFile" || name === "FS_preloadFile" || name === "FS_unlink" || name === "addRunDependency" || name === "FS_createLazyFile" || name === "FS_createDevice" || name === "removeRunDependency";
131
+ }
132
+ function missingLibrarySymbol(sym) {
133
+ unexportedRuntimeSymbol(sym);
134
+ }
135
+ function unexportedRuntimeSymbol(sym) {
136
+ if (!Object.getOwnPropertyDescriptor(Module2, sym)) {
137
+ Object.defineProperty(Module2, sym, { configurable: true, get() {
138
+ var msg = `'${sym}' was not exported. add it to EXPORTED_RUNTIME_METHODS (see the Emscripten FAQ)`;
139
+ if (isExportedByForceFilesystem(sym)) {
140
+ msg += ". Alternatively, forcing filesystem support (-sFORCE_FILESYSTEM) can export this for you";
141
+ }
142
+ abort(msg);
143
+ } });
144
+ }
145
+ }
146
+ var readyPromiseResolve, readyPromiseReject;
147
+ var wasmMemory;
148
+ var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;
149
+ var HEAP64;
150
+ var runtimeInitialized = false;
151
+ function updateMemoryViews() {
152
+ var b = wasmMemory.buffer;
153
+ Module2["HEAP8"] = HEAP8 = new Int8Array(b);
154
+ HEAP16 = new Int16Array(b);
155
+ Module2["HEAPU8"] = HEAPU8 = new Uint8Array(b);
156
+ HEAPU16 = new Uint16Array(b);
157
+ HEAP32 = new Int32Array(b);
158
+ HEAPU32 = new Uint32Array(b);
159
+ HEAPF32 = new Float32Array(b);
160
+ HEAPF64 = new Float64Array(b);
161
+ HEAP64 = new BigInt64Array(b);
162
+ new BigUint64Array(b);
163
+ }
164
+ assert(typeof Int32Array != "undefined" && typeof Float64Array !== "undefined" && Int32Array.prototype.subarray != void 0 && Int32Array.prototype.set != void 0, "JS engine does not provide full typed array support");
165
+ function preRun() {
166
+ if (Module2["preRun"]) {
167
+ if (typeof Module2["preRun"] == "function") Module2["preRun"] = [Module2["preRun"]];
168
+ while (Module2["preRun"].length) {
169
+ addOnPreRun(Module2["preRun"].shift());
170
+ }
171
+ }
172
+ consumedModuleProp("preRun");
173
+ callRuntimeCallbacks(onPreRuns);
174
+ }
175
+ function initRuntime() {
176
+ assert(!runtimeInitialized);
177
+ runtimeInitialized = true;
178
+ checkStackCookie();
179
+ if (!Module2["noFSInit"] && !FS.initialized) FS.init();
180
+ SOCKFS.root = FS.mount(SOCKFS, {}, null);
181
+ PIPEFS.root = FS.mount(PIPEFS, {}, null);
182
+ wasmExports["__wasm_call_ctors"]();
183
+ FS.ignorePermissions = false;
184
+ }
185
+ function postRun() {
186
+ checkStackCookie();
187
+ if (Module2["postRun"]) {
188
+ if (typeof Module2["postRun"] == "function") Module2["postRun"] = [Module2["postRun"]];
189
+ while (Module2["postRun"].length) {
190
+ addOnPostRun(Module2["postRun"].shift());
191
+ }
192
+ }
193
+ consumedModuleProp("postRun");
194
+ callRuntimeCallbacks(onPostRuns);
195
+ }
196
+ function abort(what) {
197
+ Module2["onAbort"]?.(what);
198
+ what = "Aborted(" + what + ")";
199
+ err(what);
200
+ ABORT = true;
201
+ var e = new WebAssembly.RuntimeError(what);
202
+ readyPromiseReject?.(e);
203
+ throw e;
204
+ }
205
+ function createExportWrapper(name, nargs) {
206
+ return (...args) => {
207
+ assert(runtimeInitialized, `native function \`${name}\` called before runtime initialization`);
208
+ var f = wasmExports[name];
209
+ assert(f, `exported native function \`${name}\` not found`);
210
+ assert(args.length <= nargs, `native function \`${name}\` called with ${args.length} args but expects ${nargs}`);
211
+ return f(...args);
212
+ };
213
+ }
214
+ var wasmBinaryFile;
215
+ function findWasmBinary() {
216
+ if (Module2["locateFile"]) {
217
+ return locateFile("redis.wasm");
218
+ }
219
+ return new URL("redis.wasm", (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('index.cjs', document.baseURI).href))).href;
220
+ }
221
+ function getBinarySync(file) {
222
+ if (file == wasmBinaryFile && wasmBinary) {
223
+ return new Uint8Array(wasmBinary);
224
+ }
225
+ if (readBinary) {
226
+ return readBinary(file);
227
+ }
228
+ throw "both async and sync fetching of the wasm failed";
229
+ }
230
+ async function getWasmBinary(binaryFile) {
231
+ if (!wasmBinary) {
232
+ try {
233
+ var response = await readAsync(binaryFile);
234
+ return new Uint8Array(response);
235
+ } catch {
236
+ }
237
+ }
238
+ return getBinarySync(binaryFile);
239
+ }
240
+ async function instantiateArrayBuffer(binaryFile, imports) {
241
+ try {
242
+ var binary = await getWasmBinary(binaryFile);
243
+ var instance = await WebAssembly.instantiate(binary, imports);
244
+ return instance;
245
+ } catch (reason) {
246
+ err(`failed to asynchronously prepare wasm: ${reason}`);
247
+ if (isFileURI(binaryFile)) {
248
+ err(`warning: Loading from a file URI (${binaryFile}) is not supported in most browsers. See https://emscripten.org/docs/getting_started/FAQ.html#how-do-i-run-a-local-webserver-for-testing-why-does-my-program-stall-in-downloading-or-preparing`);
249
+ }
250
+ abort(reason);
251
+ }
252
+ }
253
+ async function instantiateAsync(binary, binaryFile, imports) {
254
+ return instantiateArrayBuffer(binaryFile, imports);
255
+ }
256
+ function getWasmImports() {
257
+ return { env: wasmImports, wasi_snapshot_preview1: wasmImports };
258
+ }
259
+ async function createWasm() {
260
+ function receiveInstance(instance, module) {
261
+ wasmExports = instance.exports;
262
+ wasmMemory = wasmExports["memory"];
263
+ Module2["wasmMemory"] = wasmMemory;
264
+ assert(wasmMemory, "memory not found in wasm exports");
265
+ updateMemoryViews();
266
+ wasmTable = wasmExports["__indirect_function_table"];
267
+ assert(wasmTable, "table not found in wasm exports");
268
+ assignWasmExports(wasmExports);
269
+ return wasmExports;
270
+ }
271
+ var trueModule = Module2;
272
+ function receiveInstantiationResult(result2) {
273
+ assert(Module2 === trueModule, "the Module object should not be replaced during async compilation - perhaps the order of HTML elements is wrong?");
274
+ trueModule = null;
275
+ return receiveInstance(result2["instance"]);
276
+ }
277
+ var info = getWasmImports();
278
+ if (Module2["instantiateWasm"]) {
279
+ return new Promise((resolve, reject) => {
280
+ try {
281
+ Module2["instantiateWasm"](info, (mod, inst) => {
282
+ resolve(receiveInstance(mod, inst));
283
+ });
284
+ } catch (e) {
285
+ err(`Module.instantiateWasm callback failed with error: ${e}`);
286
+ reject(e);
287
+ }
288
+ });
289
+ }
290
+ wasmBinaryFile ??= findWasmBinary();
291
+ var result = await instantiateAsync(wasmBinary, wasmBinaryFile, info);
292
+ var exports = receiveInstantiationResult(result);
293
+ return exports;
294
+ }
295
+ class ExitStatus {
296
+ name = "ExitStatus";
297
+ constructor(status) {
298
+ this.message = `Program terminated with exit(${status})`;
299
+ this.status = status;
300
+ }
301
+ }
302
+ var callRuntimeCallbacks = (callbacks) => {
303
+ while (callbacks.length > 0) {
304
+ callbacks.shift()(Module2);
305
+ }
306
+ };
307
+ var onPostRuns = [];
308
+ var addOnPostRun = (cb) => onPostRuns.push(cb);
309
+ var onPreRuns = [];
310
+ var addOnPreRun = (cb) => onPreRuns.push(cb);
311
+ function getValue(ptr, type = "i8") {
312
+ if (type.endsWith("*")) type = "*";
313
+ switch (type) {
314
+ case "i1":
315
+ return HEAP8[ptr];
316
+ case "i8":
317
+ return HEAP8[ptr];
318
+ case "i16":
319
+ return HEAP16[ptr >> 1];
320
+ case "i32":
321
+ return HEAP32[ptr >> 2];
322
+ case "i64":
323
+ return HEAP64[ptr >> 3];
324
+ case "float":
325
+ return HEAPF32[ptr >> 2];
326
+ case "double":
327
+ return HEAPF64[ptr >> 3];
328
+ case "*":
329
+ return HEAPU32[ptr >> 2];
330
+ default:
331
+ abort(`invalid type for getValue: ${type}`);
332
+ }
333
+ }
334
+ var noExitRuntime = true;
335
+ var ptrToString = (ptr) => {
336
+ assert(typeof ptr === "number");
337
+ ptr >>>= 0;
338
+ return "0x" + ptr.toString(16).padStart(8, "0");
339
+ };
340
+ function setValue(ptr, value, type = "i8") {
341
+ if (type.endsWith("*")) type = "*";
342
+ switch (type) {
343
+ case "i1":
344
+ HEAP8[ptr] = value;
345
+ break;
346
+ case "i8":
347
+ HEAP8[ptr] = value;
348
+ break;
349
+ case "i16":
350
+ HEAP16[ptr >> 1] = value;
351
+ break;
352
+ case "i32":
353
+ HEAP32[ptr >> 2] = value;
354
+ break;
355
+ case "i64":
356
+ HEAP64[ptr >> 3] = BigInt(value);
357
+ break;
358
+ case "float":
359
+ HEAPF32[ptr >> 2] = value;
360
+ break;
361
+ case "double":
362
+ HEAPF64[ptr >> 3] = value;
363
+ break;
364
+ case "*":
365
+ HEAPU32[ptr >> 2] = value;
366
+ break;
367
+ default:
368
+ abort(`invalid type for setValue: ${type}`);
369
+ }
370
+ }
371
+ var stackRestore = (val) => __emscripten_stack_restore(val);
372
+ var stackSave = () => _emscripten_stack_get_current();
373
+ var warnOnce = (text) => {
374
+ warnOnce.shown ||= {};
375
+ if (!warnOnce.shown[text]) {
376
+ warnOnce.shown[text] = 1;
377
+ text = "warning: " + text;
378
+ err(text);
379
+ }
380
+ };
381
+ var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder() : void 0;
382
+ var findStringEnd = (heapOrArray, idx, maxBytesToRead, ignoreNul) => {
383
+ var maxIdx = idx + maxBytesToRead;
384
+ while (heapOrArray[idx] && !(idx >= maxIdx)) ++idx;
385
+ return idx;
386
+ };
387
+ var UTF8ArrayToString = (heapOrArray, idx = 0, maxBytesToRead, ignoreNul) => {
388
+ var endPtr = findStringEnd(heapOrArray, idx, maxBytesToRead);
389
+ if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
390
+ return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
391
+ }
392
+ var str = "";
393
+ while (idx < endPtr) {
394
+ var u0 = heapOrArray[idx++];
395
+ if (!(u0 & 128)) {
396
+ str += String.fromCharCode(u0);
397
+ continue;
398
+ }
399
+ var u1 = heapOrArray[idx++] & 63;
400
+ if ((u0 & 224) == 192) {
401
+ str += String.fromCharCode((u0 & 31) << 6 | u1);
402
+ continue;
403
+ }
404
+ var u2 = heapOrArray[idx++] & 63;
405
+ if ((u0 & 240) == 224) {
406
+ u0 = (u0 & 15) << 12 | u1 << 6 | u2;
407
+ } else {
408
+ if ((u0 & 248) != 240) warnOnce("Invalid UTF-8 leading byte " + ptrToString(u0) + " encountered when deserializing a UTF-8 string in wasm memory to a JS string!");
409
+ u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
410
+ }
411
+ if (u0 < 65536) {
412
+ str += String.fromCharCode(u0);
413
+ } else {
414
+ var ch = u0 - 65536;
415
+ str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
416
+ }
417
+ }
418
+ return str;
419
+ };
420
+ var UTF8ToString = (ptr, maxBytesToRead, ignoreNul) => {
421
+ assert(typeof ptr == "number", `UTF8ToString expects a number (got ${typeof ptr})`);
422
+ return ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
423
+ };
424
+ var ___assert_fail = (condition, filename, line, func) => abort(`Assertion failed: ${UTF8ToString(condition)}, at: ` + [filename ? UTF8ToString(filename) : "unknown filename", line, func ? UTF8ToString(func) : "unknown function"]);
425
+ var wasmTableMirror = [];
426
+ var wasmTable;
427
+ var getWasmTableEntry = (funcPtr) => {
428
+ var func = wasmTableMirror[funcPtr];
429
+ if (!func) {
430
+ wasmTableMirror[funcPtr] = func = wasmTable.get(funcPtr);
431
+ }
432
+ assert(wasmTable.get(funcPtr) == func, "JavaScript-side Wasm function table mirror is out of date!");
433
+ return func;
434
+ };
435
+ var ___call_sighandler = (fp, sig) => getWasmTableEntry(fp)(sig);
436
+ var PATH = { isAbs: (path) => path.charAt(0) === "/", splitPath: (filename) => {
437
+ var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;
438
+ return splitPathRe.exec(filename).slice(1);
439
+ }, normalizeArray: (parts, allowAboveRoot) => {
440
+ var up = 0;
441
+ for (var i = parts.length - 1; i >= 0; i--) {
442
+ var last = parts[i];
443
+ if (last === ".") {
444
+ parts.splice(i, 1);
445
+ } else if (last === "..") {
446
+ parts.splice(i, 1);
447
+ up++;
448
+ } else if (up) {
449
+ parts.splice(i, 1);
450
+ up--;
451
+ }
452
+ }
453
+ if (allowAboveRoot) {
454
+ for (; up; up--) {
455
+ parts.unshift("..");
456
+ }
457
+ }
458
+ return parts;
459
+ }, normalize: (path) => {
460
+ var isAbsolute = PATH.isAbs(path), trailingSlash = path.slice(-1) === "/";
461
+ path = PATH.normalizeArray(path.split("/").filter((p) => !!p), !isAbsolute).join("/");
462
+ if (!path && !isAbsolute) {
463
+ path = ".";
464
+ }
465
+ if (path && trailingSlash) {
466
+ path += "/";
467
+ }
468
+ return (isAbsolute ? "/" : "") + path;
469
+ }, dirname: (path) => {
470
+ var result = PATH.splitPath(path), root = result[0], dir = result[1];
471
+ if (!root && !dir) {
472
+ return ".";
473
+ }
474
+ if (dir) {
475
+ dir = dir.slice(0, -1);
476
+ }
477
+ return root + dir;
478
+ }, basename: (path) => path && path.match(/([^\/]+|\/)\/*$/)[1], join: (...paths) => PATH.normalize(paths.join("/")), join2: (l, r) => PATH.normalize(l + "/" + r) };
479
+ var initRandomFill = () => {
480
+ {
481
+ var nodeCrypto = require2("crypto");
482
+ return (view) => nodeCrypto.randomFillSync(view);
483
+ }
484
+ };
485
+ var randomFill = (view) => {
486
+ (randomFill = initRandomFill())(view);
487
+ };
488
+ var PATH_FS = { resolve: (...args) => {
489
+ var resolvedPath = "", resolvedAbsolute = false;
490
+ for (var i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {
491
+ var path = i >= 0 ? args[i] : FS.cwd();
492
+ if (typeof path != "string") {
493
+ throw new TypeError("Arguments to path.resolve must be strings");
494
+ } else if (!path) {
495
+ return "";
496
+ }
497
+ resolvedPath = path + "/" + resolvedPath;
498
+ resolvedAbsolute = PATH.isAbs(path);
499
+ }
500
+ resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter((p) => !!p), !resolvedAbsolute).join("/");
501
+ return (resolvedAbsolute ? "/" : "") + resolvedPath || ".";
502
+ }, relative: (from, to) => {
503
+ from = PATH_FS.resolve(from).slice(1);
504
+ to = PATH_FS.resolve(to).slice(1);
505
+ function trim(arr) {
506
+ var start = 0;
507
+ for (; start < arr.length; start++) {
508
+ if (arr[start] !== "") break;
509
+ }
510
+ var end = arr.length - 1;
511
+ for (; end >= 0; end--) {
512
+ if (arr[end] !== "") break;
513
+ }
514
+ if (start > end) return [];
515
+ return arr.slice(start, end - start + 1);
516
+ }
517
+ var fromParts = trim(from.split("/"));
518
+ var toParts = trim(to.split("/"));
519
+ var length = Math.min(fromParts.length, toParts.length);
520
+ var samePartsLength = length;
521
+ for (var i = 0; i < length; i++) {
522
+ if (fromParts[i] !== toParts[i]) {
523
+ samePartsLength = i;
524
+ break;
525
+ }
526
+ }
527
+ var outputParts = [];
528
+ for (var i = samePartsLength; i < fromParts.length; i++) {
529
+ outputParts.push("..");
530
+ }
531
+ outputParts = outputParts.concat(toParts.slice(samePartsLength));
532
+ return outputParts.join("/");
533
+ } };
534
+ var FS_stdin_getChar_buffer = [];
535
+ var lengthBytesUTF8 = (str) => {
536
+ var len = 0;
537
+ for (var i = 0; i < str.length; ++i) {
538
+ var c = str.charCodeAt(i);
539
+ if (c <= 127) {
540
+ len++;
541
+ } else if (c <= 2047) {
542
+ len += 2;
543
+ } else if (c >= 55296 && c <= 57343) {
544
+ len += 4;
545
+ ++i;
546
+ } else {
547
+ len += 3;
548
+ }
549
+ }
550
+ return len;
551
+ };
552
+ var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => {
553
+ assert(typeof str === "string", `stringToUTF8Array expects a string (got ${typeof str})`);
554
+ if (!(maxBytesToWrite > 0)) return 0;
555
+ var startIdx = outIdx;
556
+ var endIdx = outIdx + maxBytesToWrite - 1;
557
+ for (var i = 0; i < str.length; ++i) {
558
+ var u = str.codePointAt(i);
559
+ if (u <= 127) {
560
+ if (outIdx >= endIdx) break;
561
+ heap[outIdx++] = u;
562
+ } else if (u <= 2047) {
563
+ if (outIdx + 1 >= endIdx) break;
564
+ heap[outIdx++] = 192 | u >> 6;
565
+ heap[outIdx++] = 128 | u & 63;
566
+ } else if (u <= 65535) {
567
+ if (outIdx + 2 >= endIdx) break;
568
+ heap[outIdx++] = 224 | u >> 12;
569
+ heap[outIdx++] = 128 | u >> 6 & 63;
570
+ heap[outIdx++] = 128 | u & 63;
571
+ } else {
572
+ if (outIdx + 3 >= endIdx) break;
573
+ if (u > 1114111) warnOnce("Invalid Unicode code point " + ptrToString(u) + " encountered when serializing a JS string to a UTF-8 string in wasm memory! (Valid unicode code points should be in range 0-0x10FFFF).");
574
+ heap[outIdx++] = 240 | u >> 18;
575
+ heap[outIdx++] = 128 | u >> 12 & 63;
576
+ heap[outIdx++] = 128 | u >> 6 & 63;
577
+ heap[outIdx++] = 128 | u & 63;
578
+ i++;
579
+ }
580
+ }
581
+ heap[outIdx] = 0;
582
+ return outIdx - startIdx;
583
+ };
584
+ var intArrayFromString = (stringy, dontAddNull, length) => {
585
+ var len = lengthBytesUTF8(stringy) + 1;
586
+ var u8array = new Array(len);
587
+ var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length);
588
+ u8array.length = numBytesWritten;
589
+ return u8array;
590
+ };
591
+ var FS_stdin_getChar = () => {
592
+ if (!FS_stdin_getChar_buffer.length) {
593
+ var result = null;
594
+ {
595
+ var BUFSIZE = 256;
596
+ var buf = Buffer.alloc(BUFSIZE);
597
+ var bytesRead = 0;
598
+ var fd = process.stdin.fd;
599
+ try {
600
+ bytesRead = fs.readSync(fd, buf, 0, BUFSIZE);
601
+ } catch (e) {
602
+ if (e.toString().includes("EOF")) bytesRead = 0;
603
+ else throw e;
604
+ }
605
+ if (bytesRead > 0) {
606
+ result = buf.slice(0, bytesRead).toString("utf-8");
607
+ }
608
+ }
609
+ if (!result) {
610
+ return null;
611
+ }
612
+ FS_stdin_getChar_buffer = intArrayFromString(result);
613
+ }
614
+ return FS_stdin_getChar_buffer.shift();
615
+ };
616
+ var TTY = { ttys: [], init() {
617
+ }, shutdown() {
618
+ }, register(dev, ops) {
619
+ TTY.ttys[dev] = { input: [], output: [], ops };
620
+ FS.registerDevice(dev, TTY.stream_ops);
621
+ }, stream_ops: { open(stream) {
622
+ var tty = TTY.ttys[stream.node.rdev];
623
+ if (!tty) {
624
+ throw new FS.ErrnoError(43);
625
+ }
626
+ stream.tty = tty;
627
+ stream.seekable = false;
628
+ }, close(stream) {
629
+ stream.tty.ops.fsync(stream.tty);
630
+ }, fsync(stream) {
631
+ stream.tty.ops.fsync(stream.tty);
632
+ }, read(stream, buffer, offset, length, pos) {
633
+ if (!stream.tty || !stream.tty.ops.get_char) {
634
+ throw new FS.ErrnoError(60);
635
+ }
636
+ var bytesRead = 0;
637
+ for (var i = 0; i < length; i++) {
638
+ var result;
639
+ try {
640
+ result = stream.tty.ops.get_char(stream.tty);
641
+ } catch (e) {
642
+ throw new FS.ErrnoError(29);
643
+ }
644
+ if (result === void 0 && bytesRead === 0) {
645
+ throw new FS.ErrnoError(6);
646
+ }
647
+ if (result === null || result === void 0) break;
648
+ bytesRead++;
649
+ buffer[offset + i] = result;
650
+ }
651
+ if (bytesRead) {
652
+ stream.node.atime = Date.now();
653
+ }
654
+ return bytesRead;
655
+ }, write(stream, buffer, offset, length, pos) {
656
+ if (!stream.tty || !stream.tty.ops.put_char) {
657
+ throw new FS.ErrnoError(60);
658
+ }
659
+ try {
660
+ for (var i = 0; i < length; i++) {
661
+ stream.tty.ops.put_char(stream.tty, buffer[offset + i]);
662
+ }
663
+ } catch (e) {
664
+ throw new FS.ErrnoError(29);
665
+ }
666
+ if (length) {
667
+ stream.node.mtime = stream.node.ctime = Date.now();
668
+ }
669
+ return i;
670
+ } }, default_tty_ops: { get_char(tty) {
671
+ return FS_stdin_getChar();
672
+ }, put_char(tty, val) {
673
+ if (val === null || val === 10) {
674
+ out(UTF8ArrayToString(tty.output));
675
+ tty.output = [];
676
+ } else {
677
+ if (val != 0) tty.output.push(val);
678
+ }
679
+ }, fsync(tty) {
680
+ if (tty.output?.length > 0) {
681
+ out(UTF8ArrayToString(tty.output));
682
+ tty.output = [];
683
+ }
684
+ }, ioctl_tcgets(tty) {
685
+ return { c_iflag: 25856, c_oflag: 5, c_cflag: 191, c_lflag: 35387, c_cc: [3, 28, 127, 21, 4, 0, 1, 0, 17, 19, 26, 0, 18, 15, 23, 22, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] };
686
+ }, ioctl_tcsets(tty, optional_actions, data) {
687
+ return 0;
688
+ }, ioctl_tiocgwinsz(tty) {
689
+ return [24, 80];
690
+ } }, default_tty1_ops: { put_char(tty, val) {
691
+ if (val === null || val === 10) {
692
+ err(UTF8ArrayToString(tty.output));
693
+ tty.output = [];
694
+ } else {
695
+ if (val != 0) tty.output.push(val);
696
+ }
697
+ }, fsync(tty) {
698
+ if (tty.output?.length > 0) {
699
+ err(UTF8ArrayToString(tty.output));
700
+ tty.output = [];
701
+ }
702
+ } } };
703
+ var zeroMemory = (ptr, size) => HEAPU8.fill(0, ptr, ptr + size);
704
+ var alignMemory = (size, alignment) => {
705
+ assert(alignment, "alignment argument is required");
706
+ return Math.ceil(size / alignment) * alignment;
707
+ };
708
+ var mmapAlloc = (size) => {
709
+ size = alignMemory(size, 65536);
710
+ var ptr = _emscripten_builtin_memalign(65536, size);
711
+ if (ptr) zeroMemory(ptr, size);
712
+ return ptr;
713
+ };
714
+ var MEMFS = { ops_table: null, mount(mount) {
715
+ return MEMFS.createNode(null, "/", 16895, 0);
716
+ }, createNode(parent, name, mode, dev) {
717
+ if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
718
+ throw new FS.ErrnoError(63);
719
+ }
720
+ MEMFS.ops_table ||= { dir: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr, lookup: MEMFS.node_ops.lookup, mknod: MEMFS.node_ops.mknod, rename: MEMFS.node_ops.rename, unlink: MEMFS.node_ops.unlink, rmdir: MEMFS.node_ops.rmdir, readdir: MEMFS.node_ops.readdir, symlink: MEMFS.node_ops.symlink }, stream: { llseek: MEMFS.stream_ops.llseek } }, file: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr }, stream: { llseek: MEMFS.stream_ops.llseek, read: MEMFS.stream_ops.read, write: MEMFS.stream_ops.write, mmap: MEMFS.stream_ops.mmap, msync: MEMFS.stream_ops.msync } }, link: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr, readlink: MEMFS.node_ops.readlink }, stream: {} }, chrdev: { node: { getattr: MEMFS.node_ops.getattr, setattr: MEMFS.node_ops.setattr }, stream: FS.chrdev_stream_ops } };
721
+ var node = FS.createNode(parent, name, mode, dev);
722
+ if (FS.isDir(node.mode)) {
723
+ node.node_ops = MEMFS.ops_table.dir.node;
724
+ node.stream_ops = MEMFS.ops_table.dir.stream;
725
+ node.contents = {};
726
+ } else if (FS.isFile(node.mode)) {
727
+ node.node_ops = MEMFS.ops_table.file.node;
728
+ node.stream_ops = MEMFS.ops_table.file.stream;
729
+ node.usedBytes = 0;
730
+ node.contents = null;
731
+ } else if (FS.isLink(node.mode)) {
732
+ node.node_ops = MEMFS.ops_table.link.node;
733
+ node.stream_ops = MEMFS.ops_table.link.stream;
734
+ } else if (FS.isChrdev(node.mode)) {
735
+ node.node_ops = MEMFS.ops_table.chrdev.node;
736
+ node.stream_ops = MEMFS.ops_table.chrdev.stream;
737
+ }
738
+ node.atime = node.mtime = node.ctime = Date.now();
739
+ if (parent) {
740
+ parent.contents[name] = node;
741
+ parent.atime = parent.mtime = parent.ctime = node.atime;
742
+ }
743
+ return node;
744
+ }, getFileDataAsTypedArray(node) {
745
+ if (!node.contents) return new Uint8Array(0);
746
+ if (node.contents.subarray) return node.contents.subarray(0, node.usedBytes);
747
+ return new Uint8Array(node.contents);
748
+ }, expandFileStorage(node, newCapacity) {
749
+ var prevCapacity = node.contents ? node.contents.length : 0;
750
+ if (prevCapacity >= newCapacity) return;
751
+ var CAPACITY_DOUBLING_MAX = 1024 * 1024;
752
+ newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) >>> 0);
753
+ if (prevCapacity != 0) newCapacity = Math.max(newCapacity, 256);
754
+ var oldContents = node.contents;
755
+ node.contents = new Uint8Array(newCapacity);
756
+ if (node.usedBytes > 0) node.contents.set(oldContents.subarray(0, node.usedBytes), 0);
757
+ }, resizeFileStorage(node, newSize) {
758
+ if (node.usedBytes == newSize) return;
759
+ if (newSize == 0) {
760
+ node.contents = null;
761
+ node.usedBytes = 0;
762
+ } else {
763
+ var oldContents = node.contents;
764
+ node.contents = new Uint8Array(newSize);
765
+ if (oldContents) {
766
+ node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)));
767
+ }
768
+ node.usedBytes = newSize;
769
+ }
770
+ }, node_ops: { getattr(node) {
771
+ var attr = {};
772
+ attr.dev = FS.isChrdev(node.mode) ? node.id : 1;
773
+ attr.ino = node.id;
774
+ attr.mode = node.mode;
775
+ attr.nlink = 1;
776
+ attr.uid = 0;
777
+ attr.gid = 0;
778
+ attr.rdev = node.rdev;
779
+ if (FS.isDir(node.mode)) {
780
+ attr.size = 4096;
781
+ } else if (FS.isFile(node.mode)) {
782
+ attr.size = node.usedBytes;
783
+ } else if (FS.isLink(node.mode)) {
784
+ attr.size = node.link.length;
785
+ } else {
786
+ attr.size = 0;
787
+ }
788
+ attr.atime = new Date(node.atime);
789
+ attr.mtime = new Date(node.mtime);
790
+ attr.ctime = new Date(node.ctime);
791
+ attr.blksize = 4096;
792
+ attr.blocks = Math.ceil(attr.size / attr.blksize);
793
+ return attr;
794
+ }, setattr(node, attr) {
795
+ for (const key of ["mode", "atime", "mtime", "ctime"]) {
796
+ if (attr[key] != null) {
797
+ node[key] = attr[key];
798
+ }
799
+ }
800
+ if (attr.size !== void 0) {
801
+ MEMFS.resizeFileStorage(node, attr.size);
802
+ }
803
+ }, lookup(parent, name) {
804
+ throw new FS.ErrnoError(44);
805
+ }, mknod(parent, name, mode, dev) {
806
+ return MEMFS.createNode(parent, name, mode, dev);
807
+ }, rename(old_node, new_dir, new_name) {
808
+ var new_node;
809
+ try {
810
+ new_node = FS.lookupNode(new_dir, new_name);
811
+ } catch (e) {
812
+ }
813
+ if (new_node) {
814
+ if (FS.isDir(old_node.mode)) {
815
+ for (var i in new_node.contents) {
816
+ throw new FS.ErrnoError(55);
817
+ }
818
+ }
819
+ FS.hashRemoveNode(new_node);
820
+ }
821
+ delete old_node.parent.contents[old_node.name];
822
+ new_dir.contents[new_name] = old_node;
823
+ old_node.name = new_name;
824
+ new_dir.ctime = new_dir.mtime = old_node.parent.ctime = old_node.parent.mtime = Date.now();
825
+ }, unlink(parent, name) {
826
+ delete parent.contents[name];
827
+ parent.ctime = parent.mtime = Date.now();
828
+ }, rmdir(parent, name) {
829
+ var node = FS.lookupNode(parent, name);
830
+ for (var i in node.contents) {
831
+ throw new FS.ErrnoError(55);
832
+ }
833
+ delete parent.contents[name];
834
+ parent.ctime = parent.mtime = Date.now();
835
+ }, readdir(node) {
836
+ return [".", "..", ...Object.keys(node.contents)];
837
+ }, symlink(parent, newname, oldpath) {
838
+ var node = MEMFS.createNode(parent, newname, 511 | 40960, 0);
839
+ node.link = oldpath;
840
+ return node;
841
+ }, readlink(node) {
842
+ if (!FS.isLink(node.mode)) {
843
+ throw new FS.ErrnoError(28);
844
+ }
845
+ return node.link;
846
+ } }, stream_ops: { read(stream, buffer, offset, length, position) {
847
+ var contents = stream.node.contents;
848
+ if (position >= stream.node.usedBytes) return 0;
849
+ var size = Math.min(stream.node.usedBytes - position, length);
850
+ assert(size >= 0);
851
+ if (size > 8 && contents.subarray) {
852
+ buffer.set(contents.subarray(position, position + size), offset);
853
+ } else {
854
+ for (var i = 0; i < size; i++) buffer[offset + i] = contents[position + i];
855
+ }
856
+ return size;
857
+ }, write(stream, buffer, offset, length, position, canOwn) {
858
+ assert(!(buffer instanceof ArrayBuffer));
859
+ if (buffer.buffer === HEAP8.buffer) {
860
+ canOwn = false;
861
+ }
862
+ if (!length) return 0;
863
+ var node = stream.node;
864
+ node.mtime = node.ctime = Date.now();
865
+ if (buffer.subarray && (!node.contents || node.contents.subarray)) {
866
+ if (canOwn) {
867
+ assert(position === 0, "canOwn must imply no weird position inside the file");
868
+ node.contents = buffer.subarray(offset, offset + length);
869
+ node.usedBytes = length;
870
+ return length;
871
+ } else if (node.usedBytes === 0 && position === 0) {
872
+ node.contents = buffer.slice(offset, offset + length);
873
+ node.usedBytes = length;
874
+ return length;
875
+ } else if (position + length <= node.usedBytes) {
876
+ node.contents.set(buffer.subarray(offset, offset + length), position);
877
+ return length;
878
+ }
879
+ }
880
+ MEMFS.expandFileStorage(node, position + length);
881
+ if (node.contents.subarray && buffer.subarray) {
882
+ node.contents.set(buffer.subarray(offset, offset + length), position);
883
+ } else {
884
+ for (var i = 0; i < length; i++) {
885
+ node.contents[position + i] = buffer[offset + i];
886
+ }
887
+ }
888
+ node.usedBytes = Math.max(node.usedBytes, position + length);
889
+ return length;
890
+ }, llseek(stream, offset, whence) {
891
+ var position = offset;
892
+ if (whence === 1) {
893
+ position += stream.position;
894
+ } else if (whence === 2) {
895
+ if (FS.isFile(stream.node.mode)) {
896
+ position += stream.node.usedBytes;
897
+ }
898
+ }
899
+ if (position < 0) {
900
+ throw new FS.ErrnoError(28);
901
+ }
902
+ return position;
903
+ }, mmap(stream, length, position, prot, flags) {
904
+ if (!FS.isFile(stream.node.mode)) {
905
+ throw new FS.ErrnoError(43);
906
+ }
907
+ var ptr;
908
+ var allocated;
909
+ var contents = stream.node.contents;
910
+ if (!(flags & 2) && contents && contents.buffer === HEAP8.buffer) {
911
+ allocated = false;
912
+ ptr = contents.byteOffset;
913
+ } else {
914
+ allocated = true;
915
+ ptr = mmapAlloc(length);
916
+ if (!ptr) {
917
+ throw new FS.ErrnoError(48);
918
+ }
919
+ if (contents) {
920
+ if (position > 0 || position + length < contents.length) {
921
+ if (contents.subarray) {
922
+ contents = contents.subarray(position, position + length);
923
+ } else {
924
+ contents = Array.prototype.slice.call(contents, position, position + length);
925
+ }
926
+ }
927
+ HEAP8.set(contents, ptr);
928
+ }
929
+ }
930
+ return { ptr, allocated };
931
+ }, msync(stream, buffer, offset, length, mmapFlags) {
932
+ MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false);
933
+ return 0;
934
+ } } };
935
+ var FS_modeStringToFlags = (str) => {
936
+ var flagModes = { r: 0, "r+": 2, w: 512 | 64 | 1, "w+": 512 | 64 | 2, a: 1024 | 64 | 1, "a+": 1024 | 64 | 2 };
937
+ var flags = flagModes[str];
938
+ if (typeof flags == "undefined") {
939
+ throw new Error(`Unknown file open mode: ${str}`);
940
+ }
941
+ return flags;
942
+ };
943
+ var FS_getMode = (canRead, canWrite) => {
944
+ var mode = 0;
945
+ if (canRead) mode |= 292 | 73;
946
+ if (canWrite) mode |= 146;
947
+ return mode;
948
+ };
949
+ var strError = (errno) => UTF8ToString(_strerror(errno));
950
+ var ERRNO_CODES = { EPERM: 63, ENOENT: 44, ESRCH: 71, EINTR: 27, EIO: 29, ENXIO: 60, E2BIG: 1, ENOEXEC: 45, EBADF: 8, ECHILD: 12, EAGAIN: 6, EWOULDBLOCK: 6, ENOMEM: 48, EACCES: 2, EFAULT: 21, ENOTBLK: 105, EBUSY: 10, EEXIST: 20, EXDEV: 75, ENODEV: 43, ENOTDIR: 54, EISDIR: 31, EINVAL: 28, ENFILE: 41, EMFILE: 33, ENOTTY: 59, ETXTBSY: 74, EFBIG: 22, ENOSPC: 51, ESPIPE: 70, EROFS: 69, EMLINK: 34, EPIPE: 64, EDOM: 18, ERANGE: 68, ENOMSG: 49, EIDRM: 24, ECHRNG: 106, EL2NSYNC: 156, EL3HLT: 107, EL3RST: 108, ELNRNG: 109, EUNATCH: 110, ENOCSI: 111, EL2HLT: 112, EDEADLK: 16, ENOLCK: 46, EBADE: 113, EBADR: 114, EXFULL: 115, ENOANO: 104, EBADRQC: 103, EBADSLT: 102, EDEADLOCK: 16, EBFONT: 101, ENOSTR: 100, ENODATA: 116, ETIME: 117, ENOSR: 118, ENONET: 119, ENOPKG: 120, EREMOTE: 121, ENOLINK: 47, EADV: 122, ESRMNT: 123, ECOMM: 124, EPROTO: 65, EMULTIHOP: 36, EDOTDOT: 125, EBADMSG: 9, ENOTUNIQ: 126, EBADFD: 127, EREMCHG: 128, ELIBACC: 129, ELIBBAD: 130, ELIBSCN: 131, ELIBMAX: 132, ELIBEXEC: 133, ENOSYS: 52, ENOTEMPTY: 55, ENAMETOOLONG: 37, ELOOP: 32, EOPNOTSUPP: 138, EPFNOSUPPORT: 139, ECONNRESET: 15, ENOBUFS: 42, EAFNOSUPPORT: 5, EPROTOTYPE: 67, ENOTSOCK: 57, ENOPROTOOPT: 50, ESHUTDOWN: 140, ECONNREFUSED: 14, EADDRINUSE: 3, ECONNABORTED: 13, ENETUNREACH: 40, ENETDOWN: 38, ETIMEDOUT: 73, EHOSTDOWN: 142, EHOSTUNREACH: 23, EINPROGRESS: 26, EALREADY: 7, EDESTADDRREQ: 17, EMSGSIZE: 35, EPROTONOSUPPORT: 66, ESOCKTNOSUPPORT: 137, EADDRNOTAVAIL: 4, ENETRESET: 39, EISCONN: 30, ENOTCONN: 53, ETOOMANYREFS: 141, EUSERS: 136, EDQUOT: 19, ESTALE: 72, ENOTSUP: 138, ENOMEDIUM: 148, EILSEQ: 25, EOVERFLOW: 61, ECANCELED: 11, ENOTRECOVERABLE: 56, EOWNERDEAD: 62, ESTRPIPE: 135 };
951
+ var asyncLoad = async (url) => {
952
+ var arrayBuffer = await readAsync(url);
953
+ assert(arrayBuffer, `Loading data file "${url}" failed (no arrayBuffer).`);
954
+ return new Uint8Array(arrayBuffer);
955
+ };
956
+ var FS_createDataFile = (...args) => FS.createDataFile(...args);
957
+ var getUniqueRunDependency = (id) => {
958
+ var orig = id;
959
+ while (1) {
960
+ if (!runDependencyTracking[id]) return id;
961
+ id = orig + Math.random();
962
+ }
963
+ };
964
+ var runDependencies = 0;
965
+ var dependenciesFulfilled = null;
966
+ var runDependencyTracking = {};
967
+ var runDependencyWatcher = null;
968
+ var removeRunDependency = (id) => {
969
+ runDependencies--;
970
+ Module2["monitorRunDependencies"]?.(runDependencies);
971
+ assert(id, "removeRunDependency requires an ID");
972
+ assert(runDependencyTracking[id]);
973
+ delete runDependencyTracking[id];
974
+ if (runDependencies == 0) {
975
+ if (runDependencyWatcher !== null) {
976
+ clearInterval(runDependencyWatcher);
977
+ runDependencyWatcher = null;
978
+ }
979
+ if (dependenciesFulfilled) {
980
+ var callback = dependenciesFulfilled;
981
+ dependenciesFulfilled = null;
982
+ callback();
983
+ }
984
+ }
985
+ };
986
+ var addRunDependency = (id) => {
987
+ runDependencies++;
988
+ Module2["monitorRunDependencies"]?.(runDependencies);
989
+ assert(id, "addRunDependency requires an ID");
990
+ assert(!runDependencyTracking[id]);
991
+ runDependencyTracking[id] = 1;
992
+ if (runDependencyWatcher === null && typeof setInterval != "undefined") {
993
+ runDependencyWatcher = setInterval(() => {
994
+ if (ABORT) {
995
+ clearInterval(runDependencyWatcher);
996
+ runDependencyWatcher = null;
997
+ return;
998
+ }
999
+ var shown = false;
1000
+ for (var dep in runDependencyTracking) {
1001
+ if (!shown) {
1002
+ shown = true;
1003
+ err("still waiting on run dependencies:");
1004
+ }
1005
+ err(`dependency: ${dep}`);
1006
+ }
1007
+ if (shown) {
1008
+ err("(end of list)");
1009
+ }
1010
+ }, 1e4);
1011
+ runDependencyWatcher.unref?.();
1012
+ }
1013
+ };
1014
+ var preloadPlugins = [];
1015
+ var FS_handledByPreloadPlugin = async (byteArray, fullname) => {
1016
+ if (typeof Browser != "undefined") Browser.init();
1017
+ for (var plugin of preloadPlugins) {
1018
+ if (plugin["canHandle"](fullname)) {
1019
+ assert(plugin["handle"].constructor.name === "AsyncFunction", "Filesystem plugin handlers must be async functions (See #24914)");
1020
+ return plugin["handle"](byteArray, fullname);
1021
+ }
1022
+ }
1023
+ return byteArray;
1024
+ };
1025
+ var FS_preloadFile = async (parent, name, url, canRead, canWrite, dontCreateFile, canOwn, preFinish) => {
1026
+ var fullname = name ? PATH_FS.resolve(PATH.join2(parent, name)) : parent;
1027
+ var dep = getUniqueRunDependency(`cp ${fullname}`);
1028
+ addRunDependency(dep);
1029
+ try {
1030
+ var byteArray = url;
1031
+ if (typeof url == "string") {
1032
+ byteArray = await asyncLoad(url);
1033
+ }
1034
+ byteArray = await FS_handledByPreloadPlugin(byteArray, fullname);
1035
+ preFinish?.();
1036
+ if (!dontCreateFile) {
1037
+ FS_createDataFile(parent, name, byteArray, canRead, canWrite, canOwn);
1038
+ }
1039
+ } finally {
1040
+ removeRunDependency(dep);
1041
+ }
1042
+ };
1043
+ var FS_createPreloadedFile = (parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) => {
1044
+ FS_preloadFile(parent, name, url, canRead, canWrite, dontCreateFile, canOwn, preFinish).then(onload).catch(onerror);
1045
+ };
1046
+ var FS = { root: null, mounts: [], devices: {}, streams: [], nextInode: 1, nameTable: null, currentPath: "/", initialized: false, ignorePermissions: true, filesystems: null, syncFSRequests: 0, readFiles: {}, ErrnoError: class extends Error {
1047
+ name = "ErrnoError";
1048
+ constructor(errno) {
1049
+ super(runtimeInitialized ? strError(errno) : "");
1050
+ this.errno = errno;
1051
+ for (var key in ERRNO_CODES) {
1052
+ if (ERRNO_CODES[key] === errno) {
1053
+ this.code = key;
1054
+ break;
1055
+ }
1056
+ }
1057
+ }
1058
+ }, FSStream: class {
1059
+ shared = {};
1060
+ get object() {
1061
+ return this.node;
1062
+ }
1063
+ set object(val) {
1064
+ this.node = val;
1065
+ }
1066
+ get isRead() {
1067
+ return (this.flags & 2097155) !== 1;
1068
+ }
1069
+ get isWrite() {
1070
+ return (this.flags & 2097155) !== 0;
1071
+ }
1072
+ get isAppend() {
1073
+ return this.flags & 1024;
1074
+ }
1075
+ get flags() {
1076
+ return this.shared.flags;
1077
+ }
1078
+ set flags(val) {
1079
+ this.shared.flags = val;
1080
+ }
1081
+ get position() {
1082
+ return this.shared.position;
1083
+ }
1084
+ set position(val) {
1085
+ this.shared.position = val;
1086
+ }
1087
+ }, FSNode: class {
1088
+ node_ops = {};
1089
+ stream_ops = {};
1090
+ readMode = 292 | 73;
1091
+ writeMode = 146;
1092
+ mounted = null;
1093
+ constructor(parent, name, mode, rdev) {
1094
+ if (!parent) {
1095
+ parent = this;
1096
+ }
1097
+ this.parent = parent;
1098
+ this.mount = parent.mount;
1099
+ this.id = FS.nextInode++;
1100
+ this.name = name;
1101
+ this.mode = mode;
1102
+ this.rdev = rdev;
1103
+ this.atime = this.mtime = this.ctime = Date.now();
1104
+ }
1105
+ get read() {
1106
+ return (this.mode & this.readMode) === this.readMode;
1107
+ }
1108
+ set read(val) {
1109
+ val ? this.mode |= this.readMode : this.mode &= ~this.readMode;
1110
+ }
1111
+ get write() {
1112
+ return (this.mode & this.writeMode) === this.writeMode;
1113
+ }
1114
+ set write(val) {
1115
+ val ? this.mode |= this.writeMode : this.mode &= ~this.writeMode;
1116
+ }
1117
+ get isFolder() {
1118
+ return FS.isDir(this.mode);
1119
+ }
1120
+ get isDevice() {
1121
+ return FS.isChrdev(this.mode);
1122
+ }
1123
+ }, lookupPath(path, opts = {}) {
1124
+ if (!path) {
1125
+ throw new FS.ErrnoError(44);
1126
+ }
1127
+ opts.follow_mount ??= true;
1128
+ if (!PATH.isAbs(path)) {
1129
+ path = FS.cwd() + "/" + path;
1130
+ }
1131
+ linkloop: for (var nlinks = 0; nlinks < 40; nlinks++) {
1132
+ var parts = path.split("/").filter((p) => !!p);
1133
+ var current = FS.root;
1134
+ var current_path = "/";
1135
+ for (var i = 0; i < parts.length; i++) {
1136
+ var islast = i === parts.length - 1;
1137
+ if (islast && opts.parent) {
1138
+ break;
1139
+ }
1140
+ if (parts[i] === ".") {
1141
+ continue;
1142
+ }
1143
+ if (parts[i] === "..") {
1144
+ current_path = PATH.dirname(current_path);
1145
+ if (FS.isRoot(current)) {
1146
+ path = current_path + "/" + parts.slice(i + 1).join("/");
1147
+ nlinks--;
1148
+ continue linkloop;
1149
+ } else {
1150
+ current = current.parent;
1151
+ }
1152
+ continue;
1153
+ }
1154
+ current_path = PATH.join2(current_path, parts[i]);
1155
+ try {
1156
+ current = FS.lookupNode(current, parts[i]);
1157
+ } catch (e) {
1158
+ if (e?.errno === 44 && islast && opts.noent_okay) {
1159
+ return { path: current_path };
1160
+ }
1161
+ throw e;
1162
+ }
1163
+ if (FS.isMountpoint(current) && (!islast || opts.follow_mount)) {
1164
+ current = current.mounted.root;
1165
+ }
1166
+ if (FS.isLink(current.mode) && (!islast || opts.follow)) {
1167
+ if (!current.node_ops.readlink) {
1168
+ throw new FS.ErrnoError(52);
1169
+ }
1170
+ var link = current.node_ops.readlink(current);
1171
+ if (!PATH.isAbs(link)) {
1172
+ link = PATH.dirname(current_path) + "/" + link;
1173
+ }
1174
+ path = link + "/" + parts.slice(i + 1).join("/");
1175
+ continue linkloop;
1176
+ }
1177
+ }
1178
+ return { path: current_path, node: current };
1179
+ }
1180
+ throw new FS.ErrnoError(32);
1181
+ }, getPath(node) {
1182
+ var path;
1183
+ while (true) {
1184
+ if (FS.isRoot(node)) {
1185
+ var mount = node.mount.mountpoint;
1186
+ if (!path) return mount;
1187
+ return mount[mount.length - 1] !== "/" ? `${mount}/${path}` : mount + path;
1188
+ }
1189
+ path = path ? `${node.name}/${path}` : node.name;
1190
+ node = node.parent;
1191
+ }
1192
+ }, hashName(parentid, name) {
1193
+ var hash = 0;
1194
+ for (var i = 0; i < name.length; i++) {
1195
+ hash = (hash << 5) - hash + name.charCodeAt(i) | 0;
1196
+ }
1197
+ return (parentid + hash >>> 0) % FS.nameTable.length;
1198
+ }, hashAddNode(node) {
1199
+ var hash = FS.hashName(node.parent.id, node.name);
1200
+ node.name_next = FS.nameTable[hash];
1201
+ FS.nameTable[hash] = node;
1202
+ }, hashRemoveNode(node) {
1203
+ var hash = FS.hashName(node.parent.id, node.name);
1204
+ if (FS.nameTable[hash] === node) {
1205
+ FS.nameTable[hash] = node.name_next;
1206
+ } else {
1207
+ var current = FS.nameTable[hash];
1208
+ while (current) {
1209
+ if (current.name_next === node) {
1210
+ current.name_next = node.name_next;
1211
+ break;
1212
+ }
1213
+ current = current.name_next;
1214
+ }
1215
+ }
1216
+ }, lookupNode(parent, name) {
1217
+ var errCode = FS.mayLookup(parent);
1218
+ if (errCode) {
1219
+ throw new FS.ErrnoError(errCode);
1220
+ }
1221
+ var hash = FS.hashName(parent.id, name);
1222
+ for (var node = FS.nameTable[hash]; node; node = node.name_next) {
1223
+ var nodeName = node.name;
1224
+ if (node.parent.id === parent.id && nodeName === name) {
1225
+ return node;
1226
+ }
1227
+ }
1228
+ return FS.lookup(parent, name);
1229
+ }, createNode(parent, name, mode, rdev) {
1230
+ assert(typeof parent == "object");
1231
+ var node = new FS.FSNode(parent, name, mode, rdev);
1232
+ FS.hashAddNode(node);
1233
+ return node;
1234
+ }, destroyNode(node) {
1235
+ FS.hashRemoveNode(node);
1236
+ }, isRoot(node) {
1237
+ return node === node.parent;
1238
+ }, isMountpoint(node) {
1239
+ return !!node.mounted;
1240
+ }, isFile(mode) {
1241
+ return (mode & 61440) === 32768;
1242
+ }, isDir(mode) {
1243
+ return (mode & 61440) === 16384;
1244
+ }, isLink(mode) {
1245
+ return (mode & 61440) === 40960;
1246
+ }, isChrdev(mode) {
1247
+ return (mode & 61440) === 8192;
1248
+ }, isBlkdev(mode) {
1249
+ return (mode & 61440) === 24576;
1250
+ }, isFIFO(mode) {
1251
+ return (mode & 61440) === 4096;
1252
+ }, isSocket(mode) {
1253
+ return (mode & 49152) === 49152;
1254
+ }, flagsToPermissionString(flag) {
1255
+ var perms = ["r", "w", "rw"][flag & 3];
1256
+ if (flag & 512) {
1257
+ perms += "w";
1258
+ }
1259
+ return perms;
1260
+ }, nodePermissions(node, perms) {
1261
+ if (FS.ignorePermissions) {
1262
+ return 0;
1263
+ }
1264
+ if (perms.includes("r") && !(node.mode & 292)) {
1265
+ return 2;
1266
+ } else if (perms.includes("w") && !(node.mode & 146)) {
1267
+ return 2;
1268
+ } else if (perms.includes("x") && !(node.mode & 73)) {
1269
+ return 2;
1270
+ }
1271
+ return 0;
1272
+ }, mayLookup(dir) {
1273
+ if (!FS.isDir(dir.mode)) return 54;
1274
+ var errCode = FS.nodePermissions(dir, "x");
1275
+ if (errCode) return errCode;
1276
+ if (!dir.node_ops.lookup) return 2;
1277
+ return 0;
1278
+ }, mayCreate(dir, name) {
1279
+ if (!FS.isDir(dir.mode)) {
1280
+ return 54;
1281
+ }
1282
+ try {
1283
+ var node = FS.lookupNode(dir, name);
1284
+ return 20;
1285
+ } catch (e) {
1286
+ }
1287
+ return FS.nodePermissions(dir, "wx");
1288
+ }, mayDelete(dir, name, isdir) {
1289
+ var node;
1290
+ try {
1291
+ node = FS.lookupNode(dir, name);
1292
+ } catch (e) {
1293
+ return e.errno;
1294
+ }
1295
+ var errCode = FS.nodePermissions(dir, "wx");
1296
+ if (errCode) {
1297
+ return errCode;
1298
+ }
1299
+ if (isdir) {
1300
+ if (!FS.isDir(node.mode)) {
1301
+ return 54;
1302
+ }
1303
+ if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
1304
+ return 10;
1305
+ }
1306
+ } else {
1307
+ if (FS.isDir(node.mode)) {
1308
+ return 31;
1309
+ }
1310
+ }
1311
+ return 0;
1312
+ }, mayOpen(node, flags) {
1313
+ if (!node) {
1314
+ return 44;
1315
+ }
1316
+ if (FS.isLink(node.mode)) {
1317
+ return 32;
1318
+ } else if (FS.isDir(node.mode)) {
1319
+ if (FS.flagsToPermissionString(flags) !== "r" || flags & (512 | 64)) {
1320
+ return 31;
1321
+ }
1322
+ }
1323
+ return FS.nodePermissions(node, FS.flagsToPermissionString(flags));
1324
+ }, checkOpExists(op, err2) {
1325
+ if (!op) {
1326
+ throw new FS.ErrnoError(err2);
1327
+ }
1328
+ return op;
1329
+ }, MAX_OPEN_FDS: 4096, nextfd() {
1330
+ for (var fd = 0; fd <= FS.MAX_OPEN_FDS; fd++) {
1331
+ if (!FS.streams[fd]) {
1332
+ return fd;
1333
+ }
1334
+ }
1335
+ throw new FS.ErrnoError(33);
1336
+ }, getStreamChecked(fd) {
1337
+ var stream = FS.getStream(fd);
1338
+ if (!stream) {
1339
+ throw new FS.ErrnoError(8);
1340
+ }
1341
+ return stream;
1342
+ }, getStream: (fd) => FS.streams[fd], createStream(stream, fd = -1) {
1343
+ assert(fd >= -1);
1344
+ stream = Object.assign(new FS.FSStream(), stream);
1345
+ if (fd == -1) {
1346
+ fd = FS.nextfd();
1347
+ }
1348
+ stream.fd = fd;
1349
+ FS.streams[fd] = stream;
1350
+ return stream;
1351
+ }, closeStream(fd) {
1352
+ FS.streams[fd] = null;
1353
+ }, dupStream(origStream, fd = -1) {
1354
+ var stream = FS.createStream(origStream, fd);
1355
+ stream.stream_ops?.dup?.(stream);
1356
+ return stream;
1357
+ }, doSetAttr(stream, node, attr) {
1358
+ var setattr = stream?.stream_ops.setattr;
1359
+ var arg = setattr ? stream : node;
1360
+ setattr ??= node.node_ops.setattr;
1361
+ FS.checkOpExists(setattr, 63);
1362
+ setattr(arg, attr);
1363
+ }, chrdev_stream_ops: { open(stream) {
1364
+ var device = FS.getDevice(stream.node.rdev);
1365
+ stream.stream_ops = device.stream_ops;
1366
+ stream.stream_ops.open?.(stream);
1367
+ }, llseek() {
1368
+ throw new FS.ErrnoError(70);
1369
+ } }, major: (dev) => dev >> 8, minor: (dev) => dev & 255, makedev: (ma, mi) => ma << 8 | mi, registerDevice(dev, ops) {
1370
+ FS.devices[dev] = { stream_ops: ops };
1371
+ }, getDevice: (dev) => FS.devices[dev], getMounts(mount) {
1372
+ var mounts = [];
1373
+ var check = [mount];
1374
+ while (check.length) {
1375
+ var m = check.pop();
1376
+ mounts.push(m);
1377
+ check.push(...m.mounts);
1378
+ }
1379
+ return mounts;
1380
+ }, syncfs(populate, callback) {
1381
+ if (typeof populate == "function") {
1382
+ callback = populate;
1383
+ populate = false;
1384
+ }
1385
+ FS.syncFSRequests++;
1386
+ if (FS.syncFSRequests > 1) {
1387
+ err(`warning: ${FS.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);
1388
+ }
1389
+ var mounts = FS.getMounts(FS.root.mount);
1390
+ var completed = 0;
1391
+ function doCallback(errCode) {
1392
+ assert(FS.syncFSRequests > 0);
1393
+ FS.syncFSRequests--;
1394
+ return callback(errCode);
1395
+ }
1396
+ function done(errCode) {
1397
+ if (errCode) {
1398
+ if (!done.errored) {
1399
+ done.errored = true;
1400
+ return doCallback(errCode);
1401
+ }
1402
+ return;
1403
+ }
1404
+ if (++completed >= mounts.length) {
1405
+ doCallback(null);
1406
+ }
1407
+ }
1408
+ mounts.forEach((mount) => {
1409
+ if (!mount.type.syncfs) {
1410
+ return done(null);
1411
+ }
1412
+ mount.type.syncfs(mount, populate, done);
1413
+ });
1414
+ }, mount(type, opts, mountpoint) {
1415
+ if (typeof type == "string") {
1416
+ throw type;
1417
+ }
1418
+ var root = mountpoint === "/";
1419
+ var pseudo = !mountpoint;
1420
+ var node;
1421
+ if (root && FS.root) {
1422
+ throw new FS.ErrnoError(10);
1423
+ } else if (!root && !pseudo) {
1424
+ var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
1425
+ mountpoint = lookup.path;
1426
+ node = lookup.node;
1427
+ if (FS.isMountpoint(node)) {
1428
+ throw new FS.ErrnoError(10);
1429
+ }
1430
+ if (!FS.isDir(node.mode)) {
1431
+ throw new FS.ErrnoError(54);
1432
+ }
1433
+ }
1434
+ var mount = { type, opts, mountpoint, mounts: [] };
1435
+ var mountRoot = type.mount(mount);
1436
+ mountRoot.mount = mount;
1437
+ mount.root = mountRoot;
1438
+ if (root) {
1439
+ FS.root = mountRoot;
1440
+ } else if (node) {
1441
+ node.mounted = mount;
1442
+ if (node.mount) {
1443
+ node.mount.mounts.push(mount);
1444
+ }
1445
+ }
1446
+ return mountRoot;
1447
+ }, unmount(mountpoint) {
1448
+ var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
1449
+ if (!FS.isMountpoint(lookup.node)) {
1450
+ throw new FS.ErrnoError(28);
1451
+ }
1452
+ var node = lookup.node;
1453
+ var mount = node.mounted;
1454
+ var mounts = FS.getMounts(mount);
1455
+ Object.keys(FS.nameTable).forEach((hash) => {
1456
+ var current = FS.nameTable[hash];
1457
+ while (current) {
1458
+ var next = current.name_next;
1459
+ if (mounts.includes(current.mount)) {
1460
+ FS.destroyNode(current);
1461
+ }
1462
+ current = next;
1463
+ }
1464
+ });
1465
+ node.mounted = null;
1466
+ var idx = node.mount.mounts.indexOf(mount);
1467
+ assert(idx !== -1);
1468
+ node.mount.mounts.splice(idx, 1);
1469
+ }, lookup(parent, name) {
1470
+ return parent.node_ops.lookup(parent, name);
1471
+ }, mknod(path, mode, dev) {
1472
+ var lookup = FS.lookupPath(path, { parent: true });
1473
+ var parent = lookup.node;
1474
+ var name = PATH.basename(path);
1475
+ if (!name) {
1476
+ throw new FS.ErrnoError(28);
1477
+ }
1478
+ if (name === "." || name === "..") {
1479
+ throw new FS.ErrnoError(20);
1480
+ }
1481
+ var errCode = FS.mayCreate(parent, name);
1482
+ if (errCode) {
1483
+ throw new FS.ErrnoError(errCode);
1484
+ }
1485
+ if (!parent.node_ops.mknod) {
1486
+ throw new FS.ErrnoError(63);
1487
+ }
1488
+ return parent.node_ops.mknod(parent, name, mode, dev);
1489
+ }, statfs(path) {
1490
+ return FS.statfsNode(FS.lookupPath(path, { follow: true }).node);
1491
+ }, statfsStream(stream) {
1492
+ return FS.statfsNode(stream.node);
1493
+ }, statfsNode(node) {
1494
+ var rtn = { bsize: 4096, frsize: 4096, blocks: 1e6, bfree: 5e5, bavail: 5e5, files: FS.nextInode, ffree: FS.nextInode - 1, fsid: 42, flags: 2, namelen: 255 };
1495
+ if (node.node_ops.statfs) {
1496
+ Object.assign(rtn, node.node_ops.statfs(node.mount.opts.root));
1497
+ }
1498
+ return rtn;
1499
+ }, create(path, mode = 438) {
1500
+ mode &= 4095;
1501
+ mode |= 32768;
1502
+ return FS.mknod(path, mode, 0);
1503
+ }, mkdir(path, mode = 511) {
1504
+ mode &= 511 | 512;
1505
+ mode |= 16384;
1506
+ return FS.mknod(path, mode, 0);
1507
+ }, mkdirTree(path, mode) {
1508
+ var dirs = path.split("/");
1509
+ var d = "";
1510
+ for (var dir of dirs) {
1511
+ if (!dir) continue;
1512
+ if (d || PATH.isAbs(path)) d += "/";
1513
+ d += dir;
1514
+ try {
1515
+ FS.mkdir(d, mode);
1516
+ } catch (e) {
1517
+ if (e.errno != 20) throw e;
1518
+ }
1519
+ }
1520
+ }, mkdev(path, mode, dev) {
1521
+ if (typeof dev == "undefined") {
1522
+ dev = mode;
1523
+ mode = 438;
1524
+ }
1525
+ mode |= 8192;
1526
+ return FS.mknod(path, mode, dev);
1527
+ }, symlink(oldpath, newpath) {
1528
+ if (!PATH_FS.resolve(oldpath)) {
1529
+ throw new FS.ErrnoError(44);
1530
+ }
1531
+ var lookup = FS.lookupPath(newpath, { parent: true });
1532
+ var parent = lookup.node;
1533
+ if (!parent) {
1534
+ throw new FS.ErrnoError(44);
1535
+ }
1536
+ var newname = PATH.basename(newpath);
1537
+ var errCode = FS.mayCreate(parent, newname);
1538
+ if (errCode) {
1539
+ throw new FS.ErrnoError(errCode);
1540
+ }
1541
+ if (!parent.node_ops.symlink) {
1542
+ throw new FS.ErrnoError(63);
1543
+ }
1544
+ return parent.node_ops.symlink(parent, newname, oldpath);
1545
+ }, rename(old_path, new_path) {
1546
+ var old_dirname = PATH.dirname(old_path);
1547
+ var new_dirname = PATH.dirname(new_path);
1548
+ var old_name = PATH.basename(old_path);
1549
+ var new_name = PATH.basename(new_path);
1550
+ var lookup, old_dir, new_dir;
1551
+ lookup = FS.lookupPath(old_path, { parent: true });
1552
+ old_dir = lookup.node;
1553
+ lookup = FS.lookupPath(new_path, { parent: true });
1554
+ new_dir = lookup.node;
1555
+ if (!old_dir || !new_dir) throw new FS.ErrnoError(44);
1556
+ if (old_dir.mount !== new_dir.mount) {
1557
+ throw new FS.ErrnoError(75);
1558
+ }
1559
+ var old_node = FS.lookupNode(old_dir, old_name);
1560
+ var relative = PATH_FS.relative(old_path, new_dirname);
1561
+ if (relative.charAt(0) !== ".") {
1562
+ throw new FS.ErrnoError(28);
1563
+ }
1564
+ relative = PATH_FS.relative(new_path, old_dirname);
1565
+ if (relative.charAt(0) !== ".") {
1566
+ throw new FS.ErrnoError(55);
1567
+ }
1568
+ var new_node;
1569
+ try {
1570
+ new_node = FS.lookupNode(new_dir, new_name);
1571
+ } catch (e) {
1572
+ }
1573
+ if (old_node === new_node) {
1574
+ return;
1575
+ }
1576
+ var isdir = FS.isDir(old_node.mode);
1577
+ var errCode = FS.mayDelete(old_dir, old_name, isdir);
1578
+ if (errCode) {
1579
+ throw new FS.ErrnoError(errCode);
1580
+ }
1581
+ errCode = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name);
1582
+ if (errCode) {
1583
+ throw new FS.ErrnoError(errCode);
1584
+ }
1585
+ if (!old_dir.node_ops.rename) {
1586
+ throw new FS.ErrnoError(63);
1587
+ }
1588
+ if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
1589
+ throw new FS.ErrnoError(10);
1590
+ }
1591
+ if (new_dir !== old_dir) {
1592
+ errCode = FS.nodePermissions(old_dir, "w");
1593
+ if (errCode) {
1594
+ throw new FS.ErrnoError(errCode);
1595
+ }
1596
+ }
1597
+ FS.hashRemoveNode(old_node);
1598
+ try {
1599
+ old_dir.node_ops.rename(old_node, new_dir, new_name);
1600
+ old_node.parent = new_dir;
1601
+ } catch (e) {
1602
+ throw e;
1603
+ } finally {
1604
+ FS.hashAddNode(old_node);
1605
+ }
1606
+ }, rmdir(path) {
1607
+ var lookup = FS.lookupPath(path, { parent: true });
1608
+ var parent = lookup.node;
1609
+ var name = PATH.basename(path);
1610
+ var node = FS.lookupNode(parent, name);
1611
+ var errCode = FS.mayDelete(parent, name, true);
1612
+ if (errCode) {
1613
+ throw new FS.ErrnoError(errCode);
1614
+ }
1615
+ if (!parent.node_ops.rmdir) {
1616
+ throw new FS.ErrnoError(63);
1617
+ }
1618
+ if (FS.isMountpoint(node)) {
1619
+ throw new FS.ErrnoError(10);
1620
+ }
1621
+ parent.node_ops.rmdir(parent, name);
1622
+ FS.destroyNode(node);
1623
+ }, readdir(path) {
1624
+ var lookup = FS.lookupPath(path, { follow: true });
1625
+ var node = lookup.node;
1626
+ var readdir = FS.checkOpExists(node.node_ops.readdir, 54);
1627
+ return readdir(node);
1628
+ }, unlink(path) {
1629
+ var lookup = FS.lookupPath(path, { parent: true });
1630
+ var parent = lookup.node;
1631
+ if (!parent) {
1632
+ throw new FS.ErrnoError(44);
1633
+ }
1634
+ var name = PATH.basename(path);
1635
+ var node = FS.lookupNode(parent, name);
1636
+ var errCode = FS.mayDelete(parent, name, false);
1637
+ if (errCode) {
1638
+ throw new FS.ErrnoError(errCode);
1639
+ }
1640
+ if (!parent.node_ops.unlink) {
1641
+ throw new FS.ErrnoError(63);
1642
+ }
1643
+ if (FS.isMountpoint(node)) {
1644
+ throw new FS.ErrnoError(10);
1645
+ }
1646
+ parent.node_ops.unlink(parent, name);
1647
+ FS.destroyNode(node);
1648
+ }, readlink(path) {
1649
+ var lookup = FS.lookupPath(path);
1650
+ var link = lookup.node;
1651
+ if (!link) {
1652
+ throw new FS.ErrnoError(44);
1653
+ }
1654
+ if (!link.node_ops.readlink) {
1655
+ throw new FS.ErrnoError(28);
1656
+ }
1657
+ return link.node_ops.readlink(link);
1658
+ }, stat(path, dontFollow) {
1659
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
1660
+ var node = lookup.node;
1661
+ var getattr = FS.checkOpExists(node.node_ops.getattr, 63);
1662
+ return getattr(node);
1663
+ }, fstat(fd) {
1664
+ var stream = FS.getStreamChecked(fd);
1665
+ var node = stream.node;
1666
+ var getattr = stream.stream_ops.getattr;
1667
+ var arg = getattr ? stream : node;
1668
+ getattr ??= node.node_ops.getattr;
1669
+ FS.checkOpExists(getattr, 63);
1670
+ return getattr(arg);
1671
+ }, lstat(path) {
1672
+ return FS.stat(path, true);
1673
+ }, doChmod(stream, node, mode, dontFollow) {
1674
+ FS.doSetAttr(stream, node, { mode: mode & 4095 | node.mode & -4096, ctime: Date.now(), dontFollow });
1675
+ }, chmod(path, mode, dontFollow) {
1676
+ var node;
1677
+ if (typeof path == "string") {
1678
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
1679
+ node = lookup.node;
1680
+ } else {
1681
+ node = path;
1682
+ }
1683
+ FS.doChmod(null, node, mode, dontFollow);
1684
+ }, lchmod(path, mode) {
1685
+ FS.chmod(path, mode, true);
1686
+ }, fchmod(fd, mode) {
1687
+ var stream = FS.getStreamChecked(fd);
1688
+ FS.doChmod(stream, stream.node, mode, false);
1689
+ }, doChown(stream, node, dontFollow) {
1690
+ FS.doSetAttr(stream, node, { timestamp: Date.now(), dontFollow });
1691
+ }, chown(path, uid, gid, dontFollow) {
1692
+ var node;
1693
+ if (typeof path == "string") {
1694
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
1695
+ node = lookup.node;
1696
+ } else {
1697
+ node = path;
1698
+ }
1699
+ FS.doChown(null, node, dontFollow);
1700
+ }, lchown(path, uid, gid) {
1701
+ FS.chown(path, uid, gid, true);
1702
+ }, fchown(fd, uid, gid) {
1703
+ var stream = FS.getStreamChecked(fd);
1704
+ FS.doChown(stream, stream.node, false);
1705
+ }, doTruncate(stream, node, len) {
1706
+ if (FS.isDir(node.mode)) {
1707
+ throw new FS.ErrnoError(31);
1708
+ }
1709
+ if (!FS.isFile(node.mode)) {
1710
+ throw new FS.ErrnoError(28);
1711
+ }
1712
+ var errCode = FS.nodePermissions(node, "w");
1713
+ if (errCode) {
1714
+ throw new FS.ErrnoError(errCode);
1715
+ }
1716
+ FS.doSetAttr(stream, node, { size: len, timestamp: Date.now() });
1717
+ }, truncate(path, len) {
1718
+ if (len < 0) {
1719
+ throw new FS.ErrnoError(28);
1720
+ }
1721
+ var node;
1722
+ if (typeof path == "string") {
1723
+ var lookup = FS.lookupPath(path, { follow: true });
1724
+ node = lookup.node;
1725
+ } else {
1726
+ node = path;
1727
+ }
1728
+ FS.doTruncate(null, node, len);
1729
+ }, ftruncate(fd, len) {
1730
+ var stream = FS.getStreamChecked(fd);
1731
+ if (len < 0 || (stream.flags & 2097155) === 0) {
1732
+ throw new FS.ErrnoError(28);
1733
+ }
1734
+ FS.doTruncate(stream, stream.node, len);
1735
+ }, utime(path, atime, mtime) {
1736
+ var lookup = FS.lookupPath(path, { follow: true });
1737
+ var node = lookup.node;
1738
+ var setattr = FS.checkOpExists(node.node_ops.setattr, 63);
1739
+ setattr(node, { atime, mtime });
1740
+ }, open(path, flags, mode = 438) {
1741
+ if (path === "") {
1742
+ throw new FS.ErrnoError(44);
1743
+ }
1744
+ flags = typeof flags == "string" ? FS_modeStringToFlags(flags) : flags;
1745
+ if (flags & 64) {
1746
+ mode = mode & 4095 | 32768;
1747
+ } else {
1748
+ mode = 0;
1749
+ }
1750
+ var node;
1751
+ var isDirPath;
1752
+ if (typeof path == "object") {
1753
+ node = path;
1754
+ } else {
1755
+ isDirPath = path.endsWith("/");
1756
+ var lookup = FS.lookupPath(path, { follow: !(flags & 131072), noent_okay: true });
1757
+ node = lookup.node;
1758
+ path = lookup.path;
1759
+ }
1760
+ var created = false;
1761
+ if (flags & 64) {
1762
+ if (node) {
1763
+ if (flags & 128) {
1764
+ throw new FS.ErrnoError(20);
1765
+ }
1766
+ } else if (isDirPath) {
1767
+ throw new FS.ErrnoError(31);
1768
+ } else {
1769
+ node = FS.mknod(path, mode | 511, 0);
1770
+ created = true;
1771
+ }
1772
+ }
1773
+ if (!node) {
1774
+ throw new FS.ErrnoError(44);
1775
+ }
1776
+ if (FS.isChrdev(node.mode)) {
1777
+ flags &= -513;
1778
+ }
1779
+ if (flags & 65536 && !FS.isDir(node.mode)) {
1780
+ throw new FS.ErrnoError(54);
1781
+ }
1782
+ if (!created) {
1783
+ var errCode = FS.mayOpen(node, flags);
1784
+ if (errCode) {
1785
+ throw new FS.ErrnoError(errCode);
1786
+ }
1787
+ }
1788
+ if (flags & 512 && !created) {
1789
+ FS.truncate(node, 0);
1790
+ }
1791
+ flags &= -131713;
1792
+ var stream = FS.createStream({ node, path: FS.getPath(node), flags, seekable: true, position: 0, stream_ops: node.stream_ops, ungotten: [], error: false });
1793
+ if (stream.stream_ops.open) {
1794
+ stream.stream_ops.open(stream);
1795
+ }
1796
+ if (created) {
1797
+ FS.chmod(node, mode & 511);
1798
+ }
1799
+ if (Module2["logReadFiles"] && !(flags & 1)) {
1800
+ if (!(path in FS.readFiles)) {
1801
+ FS.readFiles[path] = 1;
1802
+ }
1803
+ }
1804
+ return stream;
1805
+ }, close(stream) {
1806
+ if (FS.isClosed(stream)) {
1807
+ throw new FS.ErrnoError(8);
1808
+ }
1809
+ if (stream.getdents) stream.getdents = null;
1810
+ try {
1811
+ if (stream.stream_ops.close) {
1812
+ stream.stream_ops.close(stream);
1813
+ }
1814
+ } catch (e) {
1815
+ throw e;
1816
+ } finally {
1817
+ FS.closeStream(stream.fd);
1818
+ }
1819
+ stream.fd = null;
1820
+ }, isClosed(stream) {
1821
+ return stream.fd === null;
1822
+ }, llseek(stream, offset, whence) {
1823
+ if (FS.isClosed(stream)) {
1824
+ throw new FS.ErrnoError(8);
1825
+ }
1826
+ if (!stream.seekable || !stream.stream_ops.llseek) {
1827
+ throw new FS.ErrnoError(70);
1828
+ }
1829
+ if (whence != 0 && whence != 1 && whence != 2) {
1830
+ throw new FS.ErrnoError(28);
1831
+ }
1832
+ stream.position = stream.stream_ops.llseek(stream, offset, whence);
1833
+ stream.ungotten = [];
1834
+ return stream.position;
1835
+ }, read(stream, buffer, offset, length, position) {
1836
+ assert(offset >= 0);
1837
+ if (length < 0 || position < 0) {
1838
+ throw new FS.ErrnoError(28);
1839
+ }
1840
+ if (FS.isClosed(stream)) {
1841
+ throw new FS.ErrnoError(8);
1842
+ }
1843
+ if ((stream.flags & 2097155) === 1) {
1844
+ throw new FS.ErrnoError(8);
1845
+ }
1846
+ if (FS.isDir(stream.node.mode)) {
1847
+ throw new FS.ErrnoError(31);
1848
+ }
1849
+ if (!stream.stream_ops.read) {
1850
+ throw new FS.ErrnoError(28);
1851
+ }
1852
+ var seeking = typeof position != "undefined";
1853
+ if (!seeking) {
1854
+ position = stream.position;
1855
+ } else if (!stream.seekable) {
1856
+ throw new FS.ErrnoError(70);
1857
+ }
1858
+ var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position);
1859
+ if (!seeking) stream.position += bytesRead;
1860
+ return bytesRead;
1861
+ }, write(stream, buffer, offset, length, position, canOwn) {
1862
+ assert(offset >= 0);
1863
+ if (length < 0 || position < 0) {
1864
+ throw new FS.ErrnoError(28);
1865
+ }
1866
+ if (FS.isClosed(stream)) {
1867
+ throw new FS.ErrnoError(8);
1868
+ }
1869
+ if ((stream.flags & 2097155) === 0) {
1870
+ throw new FS.ErrnoError(8);
1871
+ }
1872
+ if (FS.isDir(stream.node.mode)) {
1873
+ throw new FS.ErrnoError(31);
1874
+ }
1875
+ if (!stream.stream_ops.write) {
1876
+ throw new FS.ErrnoError(28);
1877
+ }
1878
+ if (stream.seekable && stream.flags & 1024) {
1879
+ FS.llseek(stream, 0, 2);
1880
+ }
1881
+ var seeking = typeof position != "undefined";
1882
+ if (!seeking) {
1883
+ position = stream.position;
1884
+ } else if (!stream.seekable) {
1885
+ throw new FS.ErrnoError(70);
1886
+ }
1887
+ var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn);
1888
+ if (!seeking) stream.position += bytesWritten;
1889
+ return bytesWritten;
1890
+ }, mmap(stream, length, position, prot, flags) {
1891
+ if ((prot & 2) !== 0 && (flags & 2) === 0 && (stream.flags & 2097155) !== 2) {
1892
+ throw new FS.ErrnoError(2);
1893
+ }
1894
+ if ((stream.flags & 2097155) === 1) {
1895
+ throw new FS.ErrnoError(2);
1896
+ }
1897
+ if (!stream.stream_ops.mmap) {
1898
+ throw new FS.ErrnoError(43);
1899
+ }
1900
+ if (!length) {
1901
+ throw new FS.ErrnoError(28);
1902
+ }
1903
+ return stream.stream_ops.mmap(stream, length, position, prot, flags);
1904
+ }, msync(stream, buffer, offset, length, mmapFlags) {
1905
+ assert(offset >= 0);
1906
+ if (!stream.stream_ops.msync) {
1907
+ return 0;
1908
+ }
1909
+ return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags);
1910
+ }, ioctl(stream, cmd, arg) {
1911
+ if (!stream.stream_ops.ioctl) {
1912
+ throw new FS.ErrnoError(59);
1913
+ }
1914
+ return stream.stream_ops.ioctl(stream, cmd, arg);
1915
+ }, readFile(path, opts = {}) {
1916
+ opts.flags = opts.flags || 0;
1917
+ opts.encoding = opts.encoding || "binary";
1918
+ if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
1919
+ abort(`Invalid encoding type "${opts.encoding}"`);
1920
+ }
1921
+ var stream = FS.open(path, opts.flags);
1922
+ var stat = FS.stat(path);
1923
+ var length = stat.size;
1924
+ var buf = new Uint8Array(length);
1925
+ FS.read(stream, buf, 0, length, 0);
1926
+ if (opts.encoding === "utf8") {
1927
+ buf = UTF8ArrayToString(buf);
1928
+ }
1929
+ FS.close(stream);
1930
+ return buf;
1931
+ }, writeFile(path, data, opts = {}) {
1932
+ opts.flags = opts.flags || 577;
1933
+ var stream = FS.open(path, opts.flags, opts.mode);
1934
+ if (typeof data == "string") {
1935
+ data = new Uint8Array(intArrayFromString(data));
1936
+ }
1937
+ if (ArrayBuffer.isView(data)) {
1938
+ FS.write(stream, data, 0, data.byteLength, void 0, opts.canOwn);
1939
+ } else {
1940
+ abort("Unsupported data type");
1941
+ }
1942
+ FS.close(stream);
1943
+ }, cwd: () => FS.currentPath, chdir(path) {
1944
+ var lookup = FS.lookupPath(path, { follow: true });
1945
+ if (lookup.node === null) {
1946
+ throw new FS.ErrnoError(44);
1947
+ }
1948
+ if (!FS.isDir(lookup.node.mode)) {
1949
+ throw new FS.ErrnoError(54);
1950
+ }
1951
+ var errCode = FS.nodePermissions(lookup.node, "x");
1952
+ if (errCode) {
1953
+ throw new FS.ErrnoError(errCode);
1954
+ }
1955
+ FS.currentPath = lookup.path;
1956
+ }, createDefaultDirectories() {
1957
+ FS.mkdir("/tmp");
1958
+ FS.mkdir("/home");
1959
+ FS.mkdir("/home/web_user");
1960
+ }, createDefaultDevices() {
1961
+ FS.mkdir("/dev");
1962
+ FS.registerDevice(FS.makedev(1, 3), { read: () => 0, write: (stream, buffer, offset, length, pos) => length, llseek: () => 0 });
1963
+ FS.mkdev("/dev/null", FS.makedev(1, 3));
1964
+ TTY.register(FS.makedev(5, 0), TTY.default_tty_ops);
1965
+ TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops);
1966
+ FS.mkdev("/dev/tty", FS.makedev(5, 0));
1967
+ FS.mkdev("/dev/tty1", FS.makedev(6, 0));
1968
+ var randomBuffer = new Uint8Array(1024), randomLeft = 0;
1969
+ var randomByte = () => {
1970
+ if (randomLeft === 0) {
1971
+ randomFill(randomBuffer);
1972
+ randomLeft = randomBuffer.byteLength;
1973
+ }
1974
+ return randomBuffer[--randomLeft];
1975
+ };
1976
+ FS.createDevice("/dev", "random", randomByte);
1977
+ FS.createDevice("/dev", "urandom", randomByte);
1978
+ FS.mkdir("/dev/shm");
1979
+ FS.mkdir("/dev/shm/tmp");
1980
+ }, createSpecialDirectories() {
1981
+ FS.mkdir("/proc");
1982
+ var proc_self = FS.mkdir("/proc/self");
1983
+ FS.mkdir("/proc/self/fd");
1984
+ FS.mount({ mount() {
1985
+ var node = FS.createNode(proc_self, "fd", 16895, 73);
1986
+ node.stream_ops = { llseek: MEMFS.stream_ops.llseek };
1987
+ node.node_ops = { lookup(parent, name) {
1988
+ var fd = +name;
1989
+ var stream = FS.getStreamChecked(fd);
1990
+ var ret = { parent: null, mount: { mountpoint: "fake" }, node_ops: { readlink: () => stream.path }, id: fd + 1 };
1991
+ ret.parent = ret;
1992
+ return ret;
1993
+ }, readdir() {
1994
+ return Array.from(FS.streams.entries()).filter(([k, v]) => v).map(([k, v]) => k.toString());
1995
+ } };
1996
+ return node;
1997
+ } }, {}, "/proc/self/fd");
1998
+ }, createStandardStreams(input, output, error) {
1999
+ if (input) {
2000
+ FS.createDevice("/dev", "stdin", input);
2001
+ } else {
2002
+ FS.symlink("/dev/tty", "/dev/stdin");
2003
+ }
2004
+ if (output) {
2005
+ FS.createDevice("/dev", "stdout", null, output);
2006
+ } else {
2007
+ FS.symlink("/dev/tty", "/dev/stdout");
2008
+ }
2009
+ if (error) {
2010
+ FS.createDevice("/dev", "stderr", null, error);
2011
+ } else {
2012
+ FS.symlink("/dev/tty1", "/dev/stderr");
2013
+ }
2014
+ var stdin = FS.open("/dev/stdin", 0);
2015
+ var stdout = FS.open("/dev/stdout", 1);
2016
+ var stderr = FS.open("/dev/stderr", 1);
2017
+ assert(stdin.fd === 0, `invalid handle for stdin (${stdin.fd})`);
2018
+ assert(stdout.fd === 1, `invalid handle for stdout (${stdout.fd})`);
2019
+ assert(stderr.fd === 2, `invalid handle for stderr (${stderr.fd})`);
2020
+ }, staticInit() {
2021
+ FS.nameTable = new Array(4096);
2022
+ FS.mount(MEMFS, {}, "/");
2023
+ FS.createDefaultDirectories();
2024
+ FS.createDefaultDevices();
2025
+ FS.createSpecialDirectories();
2026
+ FS.filesystems = { MEMFS };
2027
+ }, init(input, output, error) {
2028
+ assert(!FS.initialized, "FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)");
2029
+ FS.initialized = true;
2030
+ input ??= Module2["stdin"];
2031
+ output ??= Module2["stdout"];
2032
+ error ??= Module2["stderr"];
2033
+ FS.createStandardStreams(input, output, error);
2034
+ }, quit() {
2035
+ FS.initialized = false;
2036
+ _fflush(0);
2037
+ for (var stream of FS.streams) {
2038
+ if (stream) {
2039
+ FS.close(stream);
2040
+ }
2041
+ }
2042
+ }, findObject(path, dontResolveLastLink) {
2043
+ var ret = FS.analyzePath(path, dontResolveLastLink);
2044
+ if (!ret.exists) {
2045
+ return null;
2046
+ }
2047
+ return ret.object;
2048
+ }, analyzePath(path, dontResolveLastLink) {
2049
+ try {
2050
+ var lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
2051
+ path = lookup.path;
2052
+ } catch (e) {
2053
+ }
2054
+ var ret = { isRoot: false, exists: false, error: 0, name: null, path: null, object: null, parentExists: false, parentPath: null, parentObject: null };
2055
+ try {
2056
+ var lookup = FS.lookupPath(path, { parent: true });
2057
+ ret.parentExists = true;
2058
+ ret.parentPath = lookup.path;
2059
+ ret.parentObject = lookup.node;
2060
+ ret.name = PATH.basename(path);
2061
+ lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
2062
+ ret.exists = true;
2063
+ ret.path = lookup.path;
2064
+ ret.object = lookup.node;
2065
+ ret.name = lookup.node.name;
2066
+ ret.isRoot = lookup.path === "/";
2067
+ } catch (e) {
2068
+ ret.error = e.errno;
2069
+ }
2070
+ return ret;
2071
+ }, createPath(parent, path, canRead, canWrite) {
2072
+ parent = typeof parent == "string" ? parent : FS.getPath(parent);
2073
+ var parts = path.split("/").reverse();
2074
+ while (parts.length) {
2075
+ var part = parts.pop();
2076
+ if (!part) continue;
2077
+ var current = PATH.join2(parent, part);
2078
+ try {
2079
+ FS.mkdir(current);
2080
+ } catch (e) {
2081
+ if (e.errno != 20) throw e;
2082
+ }
2083
+ parent = current;
2084
+ }
2085
+ return current;
2086
+ }, createFile(parent, name, properties, canRead, canWrite) {
2087
+ var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
2088
+ var mode = FS_getMode(canRead, canWrite);
2089
+ return FS.create(path, mode);
2090
+ }, createDataFile(parent, name, data, canRead, canWrite, canOwn) {
2091
+ var path = name;
2092
+ if (parent) {
2093
+ parent = typeof parent == "string" ? parent : FS.getPath(parent);
2094
+ path = name ? PATH.join2(parent, name) : parent;
2095
+ }
2096
+ var mode = FS_getMode(canRead, canWrite);
2097
+ var node = FS.create(path, mode);
2098
+ if (data) {
2099
+ if (typeof data == "string") {
2100
+ var arr = new Array(data.length);
2101
+ for (var i = 0, len = data.length; i < len; ++i) arr[i] = data.charCodeAt(i);
2102
+ data = arr;
2103
+ }
2104
+ FS.chmod(node, mode | 146);
2105
+ var stream = FS.open(node, 577);
2106
+ FS.write(stream, data, 0, data.length, 0, canOwn);
2107
+ FS.close(stream);
2108
+ FS.chmod(node, mode);
2109
+ }
2110
+ }, createDevice(parent, name, input, output) {
2111
+ var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
2112
+ var mode = FS_getMode(!!input, !!output);
2113
+ FS.createDevice.major ??= 64;
2114
+ var dev = FS.makedev(FS.createDevice.major++, 0);
2115
+ FS.registerDevice(dev, { open(stream) {
2116
+ stream.seekable = false;
2117
+ }, close(stream) {
2118
+ if (output?.buffer?.length) {
2119
+ output(10);
2120
+ }
2121
+ }, read(stream, buffer, offset, length, pos) {
2122
+ var bytesRead = 0;
2123
+ for (var i = 0; i < length; i++) {
2124
+ var result;
2125
+ try {
2126
+ result = input();
2127
+ } catch (e) {
2128
+ throw new FS.ErrnoError(29);
2129
+ }
2130
+ if (result === void 0 && bytesRead === 0) {
2131
+ throw new FS.ErrnoError(6);
2132
+ }
2133
+ if (result === null || result === void 0) break;
2134
+ bytesRead++;
2135
+ buffer[offset + i] = result;
2136
+ }
2137
+ if (bytesRead) {
2138
+ stream.node.atime = Date.now();
2139
+ }
2140
+ return bytesRead;
2141
+ }, write(stream, buffer, offset, length, pos) {
2142
+ for (var i = 0; i < length; i++) {
2143
+ try {
2144
+ output(buffer[offset + i]);
2145
+ } catch (e) {
2146
+ throw new FS.ErrnoError(29);
2147
+ }
2148
+ }
2149
+ if (length) {
2150
+ stream.node.mtime = stream.node.ctime = Date.now();
2151
+ }
2152
+ return i;
2153
+ } });
2154
+ return FS.mkdev(path, mode, dev);
2155
+ }, forceLoadFile(obj) {
2156
+ if (obj.isDevice || obj.isFolder || obj.link || obj.contents) return true;
2157
+ if (typeof XMLHttpRequest != "undefined") {
2158
+ abort("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.");
2159
+ } else {
2160
+ try {
2161
+ obj.contents = readBinary(obj.url);
2162
+ } catch (e) {
2163
+ throw new FS.ErrnoError(29);
2164
+ }
2165
+ }
2166
+ }, createLazyFile(parent, name, url, canRead, canWrite) {
2167
+ class LazyUint8Array {
2168
+ lengthKnown = false;
2169
+ chunks = [];
2170
+ get(idx) {
2171
+ if (idx > this.length - 1 || idx < 0) {
2172
+ return void 0;
2173
+ }
2174
+ var chunkOffset = idx % this.chunkSize;
2175
+ var chunkNum = idx / this.chunkSize | 0;
2176
+ return this.getter(chunkNum)[chunkOffset];
2177
+ }
2178
+ setDataGetter(getter) {
2179
+ this.getter = getter;
2180
+ }
2181
+ cacheLength() {
2182
+ var xhr = new XMLHttpRequest();
2183
+ xhr.open("HEAD", url, false);
2184
+ xhr.send(null);
2185
+ if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304)) abort("Couldn't load " + url + ". Status: " + xhr.status);
2186
+ var datalength = Number(xhr.getResponseHeader("Content-length"));
2187
+ var header;
2188
+ var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes";
2189
+ var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip";
2190
+ var chunkSize = 1024 * 1024;
2191
+ if (!hasByteServing) chunkSize = datalength;
2192
+ var doXHR = (from, to) => {
2193
+ if (from > to) abort("invalid range (" + from + ", " + to + ") or no bytes requested!");
2194
+ if (to > datalength - 1) abort("only " + datalength + " bytes available! programmer error!");
2195
+ var xhr2 = new XMLHttpRequest();
2196
+ xhr2.open("GET", url, false);
2197
+ if (datalength !== chunkSize) xhr2.setRequestHeader("Range", "bytes=" + from + "-" + to);
2198
+ xhr2.responseType = "arraybuffer";
2199
+ if (xhr2.overrideMimeType) {
2200
+ xhr2.overrideMimeType("text/plain; charset=x-user-defined");
2201
+ }
2202
+ xhr2.send(null);
2203
+ if (!(xhr2.status >= 200 && xhr2.status < 300 || xhr2.status === 304)) abort("Couldn't load " + url + ". Status: " + xhr2.status);
2204
+ if (xhr2.response !== void 0) {
2205
+ return new Uint8Array(xhr2.response || []);
2206
+ }
2207
+ return intArrayFromString(xhr2.responseText || "");
2208
+ };
2209
+ var lazyArray2 = this;
2210
+ lazyArray2.setDataGetter((chunkNum) => {
2211
+ var start = chunkNum * chunkSize;
2212
+ var end = (chunkNum + 1) * chunkSize - 1;
2213
+ end = Math.min(end, datalength - 1);
2214
+ if (typeof lazyArray2.chunks[chunkNum] == "undefined") {
2215
+ lazyArray2.chunks[chunkNum] = doXHR(start, end);
2216
+ }
2217
+ if (typeof lazyArray2.chunks[chunkNum] == "undefined") abort("doXHR failed!");
2218
+ return lazyArray2.chunks[chunkNum];
2219
+ });
2220
+ if (usesGzip || !datalength) {
2221
+ chunkSize = datalength = 1;
2222
+ datalength = this.getter(0).length;
2223
+ chunkSize = datalength;
2224
+ out("LazyFiles on gzip forces download of the whole file when length is accessed");
2225
+ }
2226
+ this._length = datalength;
2227
+ this._chunkSize = chunkSize;
2228
+ this.lengthKnown = true;
2229
+ }
2230
+ get length() {
2231
+ if (!this.lengthKnown) {
2232
+ this.cacheLength();
2233
+ }
2234
+ return this._length;
2235
+ }
2236
+ get chunkSize() {
2237
+ if (!this.lengthKnown) {
2238
+ this.cacheLength();
2239
+ }
2240
+ return this._chunkSize;
2241
+ }
2242
+ }
2243
+ if (typeof XMLHttpRequest != "undefined") {
2244
+ abort("Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc");
2245
+ var lazyArray = new LazyUint8Array();
2246
+ var properties = { isDevice: false, contents: lazyArray };
2247
+ } else {
2248
+ var properties = { isDevice: false, url };
2249
+ }
2250
+ var node = FS.createFile(parent, name, properties, canRead, canWrite);
2251
+ if (properties.contents) {
2252
+ node.contents = properties.contents;
2253
+ } else if (properties.url) {
2254
+ node.contents = null;
2255
+ node.url = properties.url;
2256
+ }
2257
+ Object.defineProperties(node, { usedBytes: { get: function() {
2258
+ return this.contents.length;
2259
+ } } });
2260
+ var stream_ops = {};
2261
+ var keys = Object.keys(node.stream_ops);
2262
+ keys.forEach((key) => {
2263
+ var fn = node.stream_ops[key];
2264
+ stream_ops[key] = (...args) => {
2265
+ FS.forceLoadFile(node);
2266
+ return fn(...args);
2267
+ };
2268
+ });
2269
+ function writeChunks(stream, buffer, offset, length, position) {
2270
+ var contents = stream.node.contents;
2271
+ if (position >= contents.length) return 0;
2272
+ var size = Math.min(contents.length - position, length);
2273
+ assert(size >= 0);
2274
+ if (contents.slice) {
2275
+ for (var i = 0; i < size; i++) {
2276
+ buffer[offset + i] = contents[position + i];
2277
+ }
2278
+ } else {
2279
+ for (var i = 0; i < size; i++) {
2280
+ buffer[offset + i] = contents.get(position + i);
2281
+ }
2282
+ }
2283
+ return size;
2284
+ }
2285
+ stream_ops.read = (stream, buffer, offset, length, position) => {
2286
+ FS.forceLoadFile(node);
2287
+ return writeChunks(stream, buffer, offset, length, position);
2288
+ };
2289
+ stream_ops.mmap = (stream, length, position, prot, flags) => {
2290
+ FS.forceLoadFile(node);
2291
+ var ptr = mmapAlloc(length);
2292
+ if (!ptr) {
2293
+ throw new FS.ErrnoError(48);
2294
+ }
2295
+ writeChunks(stream, HEAP8, ptr, length, position);
2296
+ return { ptr, allocated: true };
2297
+ };
2298
+ node.stream_ops = stream_ops;
2299
+ return node;
2300
+ }, absolutePath() {
2301
+ abort("FS.absolutePath has been removed; use PATH_FS.resolve instead");
2302
+ }, createFolder() {
2303
+ abort("FS.createFolder has been removed; use FS.mkdir instead");
2304
+ }, createLink() {
2305
+ abort("FS.createLink has been removed; use FS.symlink instead");
2306
+ }, joinPath() {
2307
+ abort("FS.joinPath has been removed; use PATH.join instead");
2308
+ }, mmapAlloc() {
2309
+ abort("FS.mmapAlloc has been replaced by the top level function mmapAlloc");
2310
+ }, standardizePath() {
2311
+ abort("FS.standardizePath has been removed; use PATH.normalize instead");
2312
+ } };
2313
+ var SYSCALLS = { DEFAULT_POLLMASK: 5, calculateAt(dirfd, path, allowEmpty) {
2314
+ if (PATH.isAbs(path)) {
2315
+ return path;
2316
+ }
2317
+ var dir;
2318
+ if (dirfd === -100) {
2319
+ dir = FS.cwd();
2320
+ } else {
2321
+ var dirstream = SYSCALLS.getStreamFromFD(dirfd);
2322
+ dir = dirstream.path;
2323
+ }
2324
+ if (path.length == 0) {
2325
+ if (!allowEmpty) {
2326
+ throw new FS.ErrnoError(44);
2327
+ }
2328
+ return dir;
2329
+ }
2330
+ return dir + "/" + path;
2331
+ }, writeStat(buf, stat) {
2332
+ HEAPU32[buf >> 2] = stat.dev;
2333
+ HEAPU32[buf + 4 >> 2] = stat.mode;
2334
+ HEAPU32[buf + 8 >> 2] = stat.nlink;
2335
+ HEAPU32[buf + 12 >> 2] = stat.uid;
2336
+ HEAPU32[buf + 16 >> 2] = stat.gid;
2337
+ HEAPU32[buf + 20 >> 2] = stat.rdev;
2338
+ HEAP64[buf + 24 >> 3] = BigInt(stat.size);
2339
+ HEAP32[buf + 32 >> 2] = 4096;
2340
+ HEAP32[buf + 36 >> 2] = stat.blocks;
2341
+ var atime = stat.atime.getTime();
2342
+ var mtime = stat.mtime.getTime();
2343
+ var ctime = stat.ctime.getTime();
2344
+ HEAP64[buf + 40 >> 3] = BigInt(Math.floor(atime / 1e3));
2345
+ HEAPU32[buf + 48 >> 2] = atime % 1e3 * 1e3 * 1e3;
2346
+ HEAP64[buf + 56 >> 3] = BigInt(Math.floor(mtime / 1e3));
2347
+ HEAPU32[buf + 64 >> 2] = mtime % 1e3 * 1e3 * 1e3;
2348
+ HEAP64[buf + 72 >> 3] = BigInt(Math.floor(ctime / 1e3));
2349
+ HEAPU32[buf + 80 >> 2] = ctime % 1e3 * 1e3 * 1e3;
2350
+ HEAP64[buf + 88 >> 3] = BigInt(stat.ino);
2351
+ return 0;
2352
+ }, writeStatFs(buf, stats) {
2353
+ HEAPU32[buf + 4 >> 2] = stats.bsize;
2354
+ HEAPU32[buf + 60 >> 2] = stats.bsize;
2355
+ HEAP64[buf + 8 >> 3] = BigInt(stats.blocks);
2356
+ HEAP64[buf + 16 >> 3] = BigInt(stats.bfree);
2357
+ HEAP64[buf + 24 >> 3] = BigInt(stats.bavail);
2358
+ HEAP64[buf + 32 >> 3] = BigInt(stats.files);
2359
+ HEAP64[buf + 40 >> 3] = BigInt(stats.ffree);
2360
+ HEAPU32[buf + 48 >> 2] = stats.fsid;
2361
+ HEAPU32[buf + 64 >> 2] = stats.flags;
2362
+ HEAPU32[buf + 56 >> 2] = stats.namelen;
2363
+ }, doMsync(addr, stream, len, flags, offset) {
2364
+ if (!FS.isFile(stream.node.mode)) {
2365
+ throw new FS.ErrnoError(43);
2366
+ }
2367
+ if (flags & 2) {
2368
+ return 0;
2369
+ }
2370
+ var buffer = HEAPU8.slice(addr, addr + len);
2371
+ FS.msync(stream, buffer, offset, len, flags);
2372
+ }, getStreamFromFD(fd) {
2373
+ var stream = FS.getStreamChecked(fd);
2374
+ return stream;
2375
+ }, varargs: void 0, getStr(ptr) {
2376
+ var ret = UTF8ToString(ptr);
2377
+ return ret;
2378
+ } };
2379
+ var ___syscall__newselect = function(nfds, readfds, writefds, exceptfds, timeout) {
2380
+ try {
2381
+ assert(nfds <= 64, "nfds must be less than or equal to 64");
2382
+ var total = 0;
2383
+ var srcReadLow = readfds ? HEAP32[readfds >> 2] : 0, srcReadHigh = readfds ? HEAP32[readfds + 4 >> 2] : 0;
2384
+ var srcWriteLow = writefds ? HEAP32[writefds >> 2] : 0, srcWriteHigh = writefds ? HEAP32[writefds + 4 >> 2] : 0;
2385
+ var srcExceptLow = exceptfds ? HEAP32[exceptfds >> 2] : 0, srcExceptHigh = exceptfds ? HEAP32[exceptfds + 4 >> 2] : 0;
2386
+ var dstReadLow = 0, dstReadHigh = 0;
2387
+ var dstWriteLow = 0, dstWriteHigh = 0;
2388
+ var dstExceptLow = 0, dstExceptHigh = 0;
2389
+ var allLow = (readfds ? HEAP32[readfds >> 2] : 0) | (writefds ? HEAP32[writefds >> 2] : 0) | (exceptfds ? HEAP32[exceptfds >> 2] : 0);
2390
+ var allHigh = (readfds ? HEAP32[readfds + 4 >> 2] : 0) | (writefds ? HEAP32[writefds + 4 >> 2] : 0) | (exceptfds ? HEAP32[exceptfds + 4 >> 2] : 0);
2391
+ var check = (fd2, low, high, val) => fd2 < 32 ? low & val : high & val;
2392
+ for (var fd = 0; fd < nfds; fd++) {
2393
+ var mask = 1 << fd % 32;
2394
+ if (!check(fd, allLow, allHigh, mask)) {
2395
+ continue;
2396
+ }
2397
+ var stream = SYSCALLS.getStreamFromFD(fd);
2398
+ var flags = SYSCALLS.DEFAULT_POLLMASK;
2399
+ if (stream.stream_ops.poll) {
2400
+ var timeoutInMillis = -1;
2401
+ if (timeout) {
2402
+ var tv_sec = readfds ? HEAP32[timeout >> 2] : 0, tv_usec = readfds ? HEAP32[timeout + 4 >> 2] : 0;
2403
+ timeoutInMillis = (tv_sec + tv_usec / 1e6) * 1e3;
2404
+ }
2405
+ flags = stream.stream_ops.poll(stream, timeoutInMillis);
2406
+ }
2407
+ if (flags & 1 && check(fd, srcReadLow, srcReadHigh, mask)) {
2408
+ fd < 32 ? dstReadLow = dstReadLow | mask : dstReadHigh = dstReadHigh | mask;
2409
+ total++;
2410
+ }
2411
+ if (flags & 4 && check(fd, srcWriteLow, srcWriteHigh, mask)) {
2412
+ fd < 32 ? dstWriteLow = dstWriteLow | mask : dstWriteHigh = dstWriteHigh | mask;
2413
+ total++;
2414
+ }
2415
+ if (flags & 2 && check(fd, srcExceptLow, srcExceptHigh, mask)) {
2416
+ fd < 32 ? dstExceptLow = dstExceptLow | mask : dstExceptHigh = dstExceptHigh | mask;
2417
+ total++;
2418
+ }
2419
+ }
2420
+ if (readfds) {
2421
+ HEAP32[readfds >> 2] = dstReadLow;
2422
+ HEAP32[readfds + 4 >> 2] = dstReadHigh;
2423
+ }
2424
+ if (writefds) {
2425
+ HEAP32[writefds >> 2] = dstWriteLow;
2426
+ HEAP32[writefds + 4 >> 2] = dstWriteHigh;
2427
+ }
2428
+ if (exceptfds) {
2429
+ HEAP32[exceptfds >> 2] = dstExceptLow;
2430
+ HEAP32[exceptfds + 4 >> 2] = dstExceptHigh;
2431
+ }
2432
+ return total;
2433
+ } catch (e) {
2434
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
2435
+ return -e.errno;
2436
+ }
2437
+ };
2438
+ var SOCKFS = { websocketArgs: {}, callbacks: {}, on(event, callback) {
2439
+ SOCKFS.callbacks[event] = callback;
2440
+ }, emit(event, param) {
2441
+ SOCKFS.callbacks[event]?.(param);
2442
+ }, mount(mount) {
2443
+ SOCKFS.websocketArgs = Module2["websocket"] || {};
2444
+ (Module2["websocket"] ??= {})["on"] = SOCKFS.on;
2445
+ return FS.createNode(null, "/", 16895, 0);
2446
+ }, createSocket(family, type, protocol) {
2447
+ if (family != 2) {
2448
+ throw new FS.ErrnoError(5);
2449
+ }
2450
+ type &= -526337;
2451
+ if (type != 1 && type != 2) {
2452
+ throw new FS.ErrnoError(28);
2453
+ }
2454
+ var streaming = type == 1;
2455
+ if (streaming && protocol && protocol != 6) {
2456
+ throw new FS.ErrnoError(66);
2457
+ }
2458
+ var sock = { family, type, protocol, server: null, error: null, peers: {}, pending: [], recv_queue: [], sock_ops: SOCKFS.websocket_sock_ops };
2459
+ var name = SOCKFS.nextname();
2460
+ var node = FS.createNode(SOCKFS.root, name, 49152, 0);
2461
+ node.sock = sock;
2462
+ var stream = FS.createStream({ path: name, node, flags: 2, seekable: false, stream_ops: SOCKFS.stream_ops });
2463
+ sock.stream = stream;
2464
+ return sock;
2465
+ }, getSocket(fd) {
2466
+ var stream = FS.getStream(fd);
2467
+ if (!stream || !FS.isSocket(stream.node.mode)) {
2468
+ return null;
2469
+ }
2470
+ return stream.node.sock;
2471
+ }, stream_ops: { poll(stream) {
2472
+ var sock = stream.node.sock;
2473
+ return sock.sock_ops.poll(sock);
2474
+ }, ioctl(stream, request, varargs) {
2475
+ var sock = stream.node.sock;
2476
+ return sock.sock_ops.ioctl(sock, request, varargs);
2477
+ }, read(stream, buffer, offset, length, position) {
2478
+ var sock = stream.node.sock;
2479
+ var msg = sock.sock_ops.recvmsg(sock, length);
2480
+ if (!msg) {
2481
+ return 0;
2482
+ }
2483
+ buffer.set(msg.buffer, offset);
2484
+ return msg.buffer.length;
2485
+ }, write(stream, buffer, offset, length, position) {
2486
+ var sock = stream.node.sock;
2487
+ return sock.sock_ops.sendmsg(sock, buffer, offset, length);
2488
+ }, close(stream) {
2489
+ var sock = stream.node.sock;
2490
+ sock.sock_ops.close(sock);
2491
+ } }, nextname() {
2492
+ if (!SOCKFS.nextname.current) {
2493
+ SOCKFS.nextname.current = 0;
2494
+ }
2495
+ return `socket[${SOCKFS.nextname.current++}]`;
2496
+ }, websocket_sock_ops: { createPeer(sock, addr, port) {
2497
+ var ws;
2498
+ if (typeof addr == "object") {
2499
+ ws = addr;
2500
+ addr = null;
2501
+ port = null;
2502
+ }
2503
+ if (ws) {
2504
+ if (ws._socket) {
2505
+ addr = ws._socket.remoteAddress;
2506
+ port = ws._socket.remotePort;
2507
+ } else {
2508
+ var result = /ws[s]?:\/\/([^:]+):(\d+)/.exec(ws.url);
2509
+ if (!result) {
2510
+ throw new Error("WebSocket URL must be in the format ws(s)://address:port");
2511
+ }
2512
+ addr = result[1];
2513
+ port = parseInt(result[2], 10);
2514
+ }
2515
+ } else {
2516
+ try {
2517
+ var url = "ws://".replace("#", "//");
2518
+ var subProtocols = "binary";
2519
+ var opts = void 0;
2520
+ if (SOCKFS.websocketArgs["url"]) {
2521
+ url = SOCKFS.websocketArgs["url"];
2522
+ }
2523
+ if (SOCKFS.websocketArgs["subprotocol"]) {
2524
+ subProtocols = SOCKFS.websocketArgs["subprotocol"];
2525
+ } else if (SOCKFS.websocketArgs["subprotocol"] === null) {
2526
+ subProtocols = "null";
2527
+ }
2528
+ if (url === "ws://" || url === "wss://") {
2529
+ var parts = addr.split("/");
2530
+ url = url + parts[0] + ":" + port + "/" + parts.slice(1).join("/");
2531
+ }
2532
+ if (subProtocols !== "null") {
2533
+ subProtocols = subProtocols.replace(/^ +| +$/g, "").split(/ *, */);
2534
+ opts = subProtocols;
2535
+ }
2536
+ var WebSocketConstructor;
2537
+ if (ENVIRONMENT_IS_NODE) {
2538
+ WebSocketConstructor = require2("ws");
2539
+ }
2540
+ ws = new WebSocketConstructor(url, opts);
2541
+ ws.binaryType = "arraybuffer";
2542
+ } catch (e) {
2543
+ throw new FS.ErrnoError(23);
2544
+ }
2545
+ }
2546
+ var peer = { addr, port, socket: ws, msg_send_queue: [] };
2547
+ SOCKFS.websocket_sock_ops.addPeer(sock, peer);
2548
+ SOCKFS.websocket_sock_ops.handlePeerEvents(sock, peer);
2549
+ if (sock.type === 2 && typeof sock.sport != "undefined") {
2550
+ peer.msg_send_queue.push(new Uint8Array([255, 255, 255, 255, "p".charCodeAt(0), "o".charCodeAt(0), "r".charCodeAt(0), "t".charCodeAt(0), (sock.sport & 65280) >> 8, sock.sport & 255]));
2551
+ }
2552
+ return peer;
2553
+ }, getPeer(sock, addr, port) {
2554
+ return sock.peers[addr + ":" + port];
2555
+ }, addPeer(sock, peer) {
2556
+ sock.peers[peer.addr + ":" + peer.port] = peer;
2557
+ }, removePeer(sock, peer) {
2558
+ delete sock.peers[peer.addr + ":" + peer.port];
2559
+ }, handlePeerEvents(sock, peer) {
2560
+ var first = true;
2561
+ var handleOpen = function() {
2562
+ sock.connecting = false;
2563
+ SOCKFS.emit("open", sock.stream.fd);
2564
+ try {
2565
+ var queued = peer.msg_send_queue.shift();
2566
+ while (queued) {
2567
+ peer.socket.send(queued);
2568
+ queued = peer.msg_send_queue.shift();
2569
+ }
2570
+ } catch (e) {
2571
+ peer.socket.close();
2572
+ }
2573
+ };
2574
+ function handleMessage(data) {
2575
+ if (typeof data == "string") {
2576
+ var encoder = new TextEncoder();
2577
+ data = encoder.encode(data);
2578
+ } else {
2579
+ assert(data.byteLength !== void 0);
2580
+ if (data.byteLength == 0) {
2581
+ return;
2582
+ }
2583
+ data = new Uint8Array(data);
2584
+ }
2585
+ var wasfirst = first;
2586
+ first = false;
2587
+ if (wasfirst && data.length === 10 && data[0] === 255 && data[1] === 255 && data[2] === 255 && data[3] === 255 && data[4] === "p".charCodeAt(0) && data[5] === "o".charCodeAt(0) && data[6] === "r".charCodeAt(0) && data[7] === "t".charCodeAt(0)) {
2588
+ var newport = data[8] << 8 | data[9];
2589
+ SOCKFS.websocket_sock_ops.removePeer(sock, peer);
2590
+ peer.port = newport;
2591
+ SOCKFS.websocket_sock_ops.addPeer(sock, peer);
2592
+ return;
2593
+ }
2594
+ sock.recv_queue.push({ addr: peer.addr, port: peer.port, data });
2595
+ SOCKFS.emit("message", sock.stream.fd);
2596
+ }
2597
+ {
2598
+ peer.socket.on("open", handleOpen);
2599
+ peer.socket.on("message", function(data, isBinary) {
2600
+ if (!isBinary) {
2601
+ return;
2602
+ }
2603
+ handleMessage(new Uint8Array(data).buffer);
2604
+ });
2605
+ peer.socket.on("close", function() {
2606
+ SOCKFS.emit("close", sock.stream.fd);
2607
+ });
2608
+ peer.socket.on("error", function(error) {
2609
+ sock.error = 14;
2610
+ SOCKFS.emit("error", [sock.stream.fd, sock.error, "ECONNREFUSED: Connection refused"]);
2611
+ });
2612
+ }
2613
+ }, poll(sock) {
2614
+ if (sock.type === 1 && sock.server) {
2615
+ return sock.pending.length ? 64 | 1 : 0;
2616
+ }
2617
+ var mask = 0;
2618
+ var dest = sock.type === 1 ? SOCKFS.websocket_sock_ops.getPeer(sock, sock.daddr, sock.dport) : null;
2619
+ if (sock.recv_queue.length || !dest || dest && dest.socket.readyState === dest.socket.CLOSING || dest && dest.socket.readyState === dest.socket.CLOSED) {
2620
+ mask |= 64 | 1;
2621
+ }
2622
+ if (!dest || dest && dest.socket.readyState === dest.socket.OPEN) {
2623
+ mask |= 4;
2624
+ }
2625
+ if (dest && dest.socket.readyState === dest.socket.CLOSING || dest && dest.socket.readyState === dest.socket.CLOSED) {
2626
+ if (sock.connecting) {
2627
+ mask |= 4;
2628
+ } else {
2629
+ mask |= 16;
2630
+ }
2631
+ }
2632
+ return mask;
2633
+ }, ioctl(sock, request, arg) {
2634
+ switch (request) {
2635
+ case 21531:
2636
+ var bytes = 0;
2637
+ if (sock.recv_queue.length) {
2638
+ bytes = sock.recv_queue[0].data.length;
2639
+ }
2640
+ HEAP32[arg >> 2] = bytes;
2641
+ return 0;
2642
+ case 21537:
2643
+ var on = HEAP32[arg >> 2];
2644
+ if (on) {
2645
+ sock.stream.flags |= 2048;
2646
+ } else {
2647
+ sock.stream.flags &= -2049;
2648
+ }
2649
+ return 0;
2650
+ default:
2651
+ return 28;
2652
+ }
2653
+ }, close(sock) {
2654
+ if (sock.server) {
2655
+ try {
2656
+ sock.server.close();
2657
+ } catch (e) {
2658
+ }
2659
+ sock.server = null;
2660
+ }
2661
+ for (var peer of Object.values(sock.peers)) {
2662
+ try {
2663
+ peer.socket.close();
2664
+ } catch (e) {
2665
+ }
2666
+ SOCKFS.websocket_sock_ops.removePeer(sock, peer);
2667
+ }
2668
+ return 0;
2669
+ }, bind(sock, addr, port) {
2670
+ if (typeof sock.saddr != "undefined" || typeof sock.sport != "undefined") {
2671
+ throw new FS.ErrnoError(28);
2672
+ }
2673
+ sock.saddr = addr;
2674
+ sock.sport = port;
2675
+ if (sock.type === 2) {
2676
+ if (sock.server) {
2677
+ sock.server.close();
2678
+ sock.server = null;
2679
+ }
2680
+ try {
2681
+ sock.sock_ops.listen(sock, 0);
2682
+ } catch (e) {
2683
+ if (!(e.name === "ErrnoError")) throw e;
2684
+ if (e.errno !== 138) throw e;
2685
+ }
2686
+ }
2687
+ }, connect(sock, addr, port) {
2688
+ if (sock.server) {
2689
+ throw new FS.ErrnoError(138);
2690
+ }
2691
+ if (typeof sock.daddr != "undefined" && typeof sock.dport != "undefined") {
2692
+ var dest = SOCKFS.websocket_sock_ops.getPeer(sock, sock.daddr, sock.dport);
2693
+ if (dest) {
2694
+ if (dest.socket.readyState === dest.socket.CONNECTING) {
2695
+ throw new FS.ErrnoError(7);
2696
+ } else {
2697
+ throw new FS.ErrnoError(30);
2698
+ }
2699
+ }
2700
+ }
2701
+ var peer = SOCKFS.websocket_sock_ops.createPeer(sock, addr, port);
2702
+ sock.daddr = peer.addr;
2703
+ sock.dport = peer.port;
2704
+ sock.connecting = true;
2705
+ }, listen(sock, backlog) {
2706
+ if (sock.server) {
2707
+ throw new FS.ErrnoError(28);
2708
+ }
2709
+ var WebSocketServer = require2("ws").Server;
2710
+ var host = sock.saddr;
2711
+ sock.server = new WebSocketServer({ host, port: sock.sport });
2712
+ SOCKFS.emit("listen", sock.stream.fd);
2713
+ sock.server.on("connection", function(ws) {
2714
+ if (sock.type === 1) {
2715
+ var newsock = SOCKFS.createSocket(sock.family, sock.type, sock.protocol);
2716
+ var peer = SOCKFS.websocket_sock_ops.createPeer(newsock, ws);
2717
+ newsock.daddr = peer.addr;
2718
+ newsock.dport = peer.port;
2719
+ sock.pending.push(newsock);
2720
+ SOCKFS.emit("connection", newsock.stream.fd);
2721
+ } else {
2722
+ SOCKFS.websocket_sock_ops.createPeer(sock, ws);
2723
+ SOCKFS.emit("connection", sock.stream.fd);
2724
+ }
2725
+ });
2726
+ sock.server.on("close", function() {
2727
+ SOCKFS.emit("close", sock.stream.fd);
2728
+ sock.server = null;
2729
+ });
2730
+ sock.server.on("error", function(error) {
2731
+ sock.error = 23;
2732
+ SOCKFS.emit("error", [sock.stream.fd, sock.error, "EHOSTUNREACH: Host is unreachable"]);
2733
+ });
2734
+ }, accept(listensock) {
2735
+ if (!listensock.server || !listensock.pending.length) {
2736
+ throw new FS.ErrnoError(28);
2737
+ }
2738
+ var newsock = listensock.pending.shift();
2739
+ newsock.stream.flags = listensock.stream.flags;
2740
+ return newsock;
2741
+ }, getname(sock, peer) {
2742
+ var addr, port;
2743
+ if (peer) {
2744
+ if (sock.daddr === void 0 || sock.dport === void 0) {
2745
+ throw new FS.ErrnoError(53);
2746
+ }
2747
+ addr = sock.daddr;
2748
+ port = sock.dport;
2749
+ } else {
2750
+ addr = sock.saddr || 0;
2751
+ port = sock.sport || 0;
2752
+ }
2753
+ return { addr, port };
2754
+ }, sendmsg(sock, buffer, offset, length, addr, port) {
2755
+ if (sock.type === 2) {
2756
+ if (addr === void 0 || port === void 0) {
2757
+ addr = sock.daddr;
2758
+ port = sock.dport;
2759
+ }
2760
+ if (addr === void 0 || port === void 0) {
2761
+ throw new FS.ErrnoError(17);
2762
+ }
2763
+ } else {
2764
+ addr = sock.daddr;
2765
+ port = sock.dport;
2766
+ }
2767
+ var dest = SOCKFS.websocket_sock_ops.getPeer(sock, addr, port);
2768
+ if (sock.type === 1) {
2769
+ if (!dest || dest.socket.readyState === dest.socket.CLOSING || dest.socket.readyState === dest.socket.CLOSED) {
2770
+ throw new FS.ErrnoError(53);
2771
+ }
2772
+ }
2773
+ if (ArrayBuffer.isView(buffer)) {
2774
+ offset += buffer.byteOffset;
2775
+ buffer = buffer.buffer;
2776
+ }
2777
+ var data = buffer.slice(offset, offset + length);
2778
+ if (!dest || dest.socket.readyState !== dest.socket.OPEN) {
2779
+ if (sock.type === 2) {
2780
+ if (!dest || dest.socket.readyState === dest.socket.CLOSING || dest.socket.readyState === dest.socket.CLOSED) {
2781
+ dest = SOCKFS.websocket_sock_ops.createPeer(sock, addr, port);
2782
+ }
2783
+ }
2784
+ dest.msg_send_queue.push(data);
2785
+ return length;
2786
+ }
2787
+ try {
2788
+ dest.socket.send(data);
2789
+ return length;
2790
+ } catch (e) {
2791
+ throw new FS.ErrnoError(28);
2792
+ }
2793
+ }, recvmsg(sock, length) {
2794
+ if (sock.type === 1 && sock.server) {
2795
+ throw new FS.ErrnoError(53);
2796
+ }
2797
+ var queued = sock.recv_queue.shift();
2798
+ if (!queued) {
2799
+ if (sock.type === 1) {
2800
+ var dest = SOCKFS.websocket_sock_ops.getPeer(sock, sock.daddr, sock.dport);
2801
+ if (!dest) {
2802
+ throw new FS.ErrnoError(53);
2803
+ }
2804
+ if (dest.socket.readyState === dest.socket.CLOSING || dest.socket.readyState === dest.socket.CLOSED) {
2805
+ return null;
2806
+ }
2807
+ throw new FS.ErrnoError(6);
2808
+ }
2809
+ throw new FS.ErrnoError(6);
2810
+ }
2811
+ var queuedLength = queued.data.byteLength || queued.data.length;
2812
+ var queuedOffset = queued.data.byteOffset || 0;
2813
+ var queuedBuffer = queued.data.buffer || queued.data;
2814
+ var bytesRead = Math.min(length, queuedLength);
2815
+ var res = { buffer: new Uint8Array(queuedBuffer, queuedOffset, bytesRead), addr: queued.addr, port: queued.port };
2816
+ if (sock.type === 1 && bytesRead < queuedLength) {
2817
+ var bytesRemaining = queuedLength - bytesRead;
2818
+ queued.data = new Uint8Array(queuedBuffer, queuedOffset + bytesRead, bytesRemaining);
2819
+ sock.recv_queue.unshift(queued);
2820
+ }
2821
+ return res;
2822
+ } } };
2823
+ var getSocketFromFD = (fd) => {
2824
+ var socket = SOCKFS.getSocket(fd);
2825
+ if (!socket) throw new FS.ErrnoError(8);
2826
+ return socket;
2827
+ };
2828
+ var inetPton4 = (str) => {
2829
+ var b = str.split(".");
2830
+ for (var i = 0; i < 4; i++) {
2831
+ var tmp = Number(b[i]);
2832
+ if (isNaN(tmp)) return null;
2833
+ b[i] = tmp;
2834
+ }
2835
+ return (b[0] | b[1] << 8 | b[2] << 16 | b[3] << 24) >>> 0;
2836
+ };
2837
+ var inetPton6 = (str) => {
2838
+ var words;
2839
+ var w, offset, z;
2840
+ var valid6regx = /^((?=.*::)(?!.*::.+::)(::)?([\dA-F]{1,4}:(:|\b)|){5}|([\dA-F]{1,4}:){6})((([\dA-F]{1,4}((?!\3)::|:\b|$))|(?!\2\3)){2}|(((2[0-4]|1\d|[1-9])?\d|25[0-5])\.?\b){4})$/i;
2841
+ var parts = [];
2842
+ if (!valid6regx.test(str)) {
2843
+ return null;
2844
+ }
2845
+ if (str === "::") {
2846
+ return [0, 0, 0, 0, 0, 0, 0, 0];
2847
+ }
2848
+ if (str.startsWith("::")) {
2849
+ str = str.replace("::", "Z:");
2850
+ } else {
2851
+ str = str.replace("::", ":Z:");
2852
+ }
2853
+ if (str.indexOf(".") > 0) {
2854
+ str = str.replace(new RegExp("[.]", "g"), ":");
2855
+ words = str.split(":");
2856
+ words[words.length - 4] = Number(words[words.length - 4]) + Number(words[words.length - 3]) * 256;
2857
+ words[words.length - 3] = Number(words[words.length - 2]) + Number(words[words.length - 1]) * 256;
2858
+ words = words.slice(0, words.length - 2);
2859
+ } else {
2860
+ words = str.split(":");
2861
+ }
2862
+ offset = 0;
2863
+ z = 0;
2864
+ for (w = 0; w < words.length; w++) {
2865
+ if (typeof words[w] == "string") {
2866
+ if (words[w] === "Z") {
2867
+ for (z = 0; z < 8 - words.length + 1; z++) {
2868
+ parts[w + z] = 0;
2869
+ }
2870
+ offset = z - 1;
2871
+ } else {
2872
+ parts[w + offset] = _htons(parseInt(words[w], 16));
2873
+ }
2874
+ } else {
2875
+ parts[w + offset] = words[w];
2876
+ }
2877
+ }
2878
+ return [parts[1] << 16 | parts[0], parts[3] << 16 | parts[2], parts[5] << 16 | parts[4], parts[7] << 16 | parts[6]];
2879
+ };
2880
+ var writeSockaddr = (sa, family, addr, port, addrlen) => {
2881
+ switch (family) {
2882
+ case 2:
2883
+ addr = inetPton4(addr);
2884
+ zeroMemory(sa, 16);
2885
+ if (addrlen) {
2886
+ HEAP32[addrlen >> 2] = 16;
2887
+ }
2888
+ HEAP16[sa >> 1] = family;
2889
+ HEAP32[sa + 4 >> 2] = addr;
2890
+ HEAP16[sa + 2 >> 1] = _htons(port);
2891
+ break;
2892
+ case 10:
2893
+ addr = inetPton6(addr);
2894
+ zeroMemory(sa, 28);
2895
+ if (addrlen) {
2896
+ HEAP32[addrlen >> 2] = 28;
2897
+ }
2898
+ HEAP32[sa >> 2] = family;
2899
+ HEAP32[sa + 8 >> 2] = addr[0];
2900
+ HEAP32[sa + 12 >> 2] = addr[1];
2901
+ HEAP32[sa + 16 >> 2] = addr[2];
2902
+ HEAP32[sa + 20 >> 2] = addr[3];
2903
+ HEAP16[sa + 2 >> 1] = _htons(port);
2904
+ break;
2905
+ default:
2906
+ return 5;
2907
+ }
2908
+ return 0;
2909
+ };
2910
+ var DNS = { address_map: { id: 1, addrs: {}, names: {} }, lookup_name(name) {
2911
+ var res = inetPton4(name);
2912
+ if (res !== null) {
2913
+ return name;
2914
+ }
2915
+ res = inetPton6(name);
2916
+ if (res !== null) {
2917
+ return name;
2918
+ }
2919
+ var addr;
2920
+ if (DNS.address_map.addrs[name]) {
2921
+ addr = DNS.address_map.addrs[name];
2922
+ } else {
2923
+ var id = DNS.address_map.id++;
2924
+ assert(id < 65535, "exceeded max address mappings of 65535");
2925
+ addr = "172.29." + (id & 255) + "." + (id & 65280);
2926
+ DNS.address_map.names[addr] = name;
2927
+ DNS.address_map.addrs[name] = addr;
2928
+ }
2929
+ return addr;
2930
+ }, lookup_addr(addr) {
2931
+ if (DNS.address_map.names[addr]) {
2932
+ return DNS.address_map.names[addr];
2933
+ }
2934
+ return null;
2935
+ } };
2936
+ function ___syscall_accept4(fd, addr, addrlen, flags, d1, d2) {
2937
+ try {
2938
+ var sock = getSocketFromFD(fd);
2939
+ var newsock = sock.sock_ops.accept(sock);
2940
+ if (addr) {
2941
+ var errno = writeSockaddr(addr, newsock.family, DNS.lookup_name(newsock.daddr), newsock.dport, addrlen);
2942
+ assert(!errno);
2943
+ }
2944
+ return newsock.stream.fd;
2945
+ } catch (e) {
2946
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
2947
+ return -e.errno;
2948
+ }
2949
+ }
2950
+ var inetNtop4 = (addr) => (addr & 255) + "." + (addr >> 8 & 255) + "." + (addr >> 16 & 255) + "." + (addr >> 24 & 255);
2951
+ var inetNtop6 = (ints) => {
2952
+ var str = "";
2953
+ var word = 0;
2954
+ var longest = 0;
2955
+ var lastzero = 0;
2956
+ var zstart = 0;
2957
+ var len = 0;
2958
+ var i = 0;
2959
+ var parts = [ints[0] & 65535, ints[0] >> 16, ints[1] & 65535, ints[1] >> 16, ints[2] & 65535, ints[2] >> 16, ints[3] & 65535, ints[3] >> 16];
2960
+ var hasipv4 = true;
2961
+ var v4part = "";
2962
+ for (i = 0; i < 5; i++) {
2963
+ if (parts[i] !== 0) {
2964
+ hasipv4 = false;
2965
+ break;
2966
+ }
2967
+ }
2968
+ if (hasipv4) {
2969
+ v4part = inetNtop4(parts[6] | parts[7] << 16);
2970
+ if (parts[5] === -1) {
2971
+ str = "::ffff:";
2972
+ str += v4part;
2973
+ return str;
2974
+ }
2975
+ if (parts[5] === 0) {
2976
+ str = "::";
2977
+ if (v4part === "0.0.0.0") v4part = "";
2978
+ if (v4part === "0.0.0.1") v4part = "1";
2979
+ str += v4part;
2980
+ return str;
2981
+ }
2982
+ }
2983
+ for (word = 0; word < 8; word++) {
2984
+ if (parts[word] === 0) {
2985
+ if (word - lastzero > 1) {
2986
+ len = 0;
2987
+ }
2988
+ lastzero = word;
2989
+ len++;
2990
+ }
2991
+ if (len > longest) {
2992
+ longest = len;
2993
+ zstart = word - longest + 1;
2994
+ }
2995
+ }
2996
+ for (word = 0; word < 8; word++) {
2997
+ if (longest > 1) {
2998
+ if (parts[word] === 0 && word >= zstart && word < zstart + longest) {
2999
+ if (word === zstart) {
3000
+ str += ":";
3001
+ if (zstart === 0) str += ":";
3002
+ }
3003
+ continue;
3004
+ }
3005
+ }
3006
+ str += Number(_ntohs(parts[word] & 65535)).toString(16);
3007
+ str += word < 7 ? ":" : "";
3008
+ }
3009
+ return str;
3010
+ };
3011
+ var readSockaddr = (sa, salen) => {
3012
+ var family = HEAP16[sa >> 1];
3013
+ var port = _ntohs(HEAPU16[sa + 2 >> 1]);
3014
+ var addr;
3015
+ switch (family) {
3016
+ case 2:
3017
+ if (salen !== 16) {
3018
+ return { errno: 28 };
3019
+ }
3020
+ addr = HEAP32[sa + 4 >> 2];
3021
+ addr = inetNtop4(addr);
3022
+ break;
3023
+ case 10:
3024
+ if (salen !== 28) {
3025
+ return { errno: 28 };
3026
+ }
3027
+ addr = [HEAP32[sa + 8 >> 2], HEAP32[sa + 12 >> 2], HEAP32[sa + 16 >> 2], HEAP32[sa + 20 >> 2]];
3028
+ addr = inetNtop6(addr);
3029
+ break;
3030
+ default:
3031
+ return { errno: 5 };
3032
+ }
3033
+ return { family, addr, port };
3034
+ };
3035
+ var getSocketAddress = (addrp, addrlen) => {
3036
+ var info = readSockaddr(addrp, addrlen);
3037
+ if (info.errno) throw new FS.ErrnoError(info.errno);
3038
+ info.addr = DNS.lookup_addr(info.addr) || info.addr;
3039
+ return info;
3040
+ };
3041
+ function ___syscall_bind(fd, addr, addrlen, d1, d2, d3) {
3042
+ try {
3043
+ var sock = getSocketFromFD(fd);
3044
+ var info = getSocketAddress(addr, addrlen);
3045
+ sock.sock_ops.bind(sock, info.addr, info.port);
3046
+ return 0;
3047
+ } catch (e) {
3048
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3049
+ return -e.errno;
3050
+ }
3051
+ }
3052
+ function ___syscall_chdir(path) {
3053
+ try {
3054
+ path = SYSCALLS.getStr(path);
3055
+ FS.chdir(path);
3056
+ return 0;
3057
+ } catch (e) {
3058
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3059
+ return -e.errno;
3060
+ }
3061
+ }
3062
+ function ___syscall_chmod(path, mode) {
3063
+ try {
3064
+ path = SYSCALLS.getStr(path);
3065
+ FS.chmod(path, mode);
3066
+ return 0;
3067
+ } catch (e) {
3068
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3069
+ return -e.errno;
3070
+ }
3071
+ }
3072
+ function ___syscall_connect(fd, addr, addrlen, d1, d2, d3) {
3073
+ try {
3074
+ var sock = getSocketFromFD(fd);
3075
+ var info = getSocketAddress(addr, addrlen);
3076
+ sock.sock_ops.connect(sock, info.addr, info.port);
3077
+ return 0;
3078
+ } catch (e) {
3079
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3080
+ return -e.errno;
3081
+ }
3082
+ }
3083
+ function ___syscall_dup(fd) {
3084
+ try {
3085
+ var old = SYSCALLS.getStreamFromFD(fd);
3086
+ return FS.dupStream(old).fd;
3087
+ } catch (e) {
3088
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3089
+ return -e.errno;
3090
+ }
3091
+ }
3092
+ function ___syscall_dup3(fd, newfd, flags) {
3093
+ try {
3094
+ var old = SYSCALLS.getStreamFromFD(fd);
3095
+ assert(!flags);
3096
+ if (old.fd === newfd) return -28;
3097
+ if (newfd < 0 || newfd >= FS.MAX_OPEN_FDS) return -8;
3098
+ var existing = FS.getStream(newfd);
3099
+ if (existing) FS.close(existing);
3100
+ return FS.dupStream(old, newfd).fd;
3101
+ } catch (e) {
3102
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3103
+ return -e.errno;
3104
+ }
3105
+ }
3106
+ function ___syscall_faccessat(dirfd, path, amode, flags) {
3107
+ try {
3108
+ path = SYSCALLS.getStr(path);
3109
+ assert(!flags || flags == 512);
3110
+ path = SYSCALLS.calculateAt(dirfd, path);
3111
+ if (amode & ~7) {
3112
+ return -28;
3113
+ }
3114
+ var lookup = FS.lookupPath(path, { follow: true });
3115
+ var node = lookup.node;
3116
+ if (!node) {
3117
+ return -44;
3118
+ }
3119
+ var perms = "";
3120
+ if (amode & 4) perms += "r";
3121
+ if (amode & 2) perms += "w";
3122
+ if (amode & 1) perms += "x";
3123
+ if (perms && FS.nodePermissions(node, perms)) {
3124
+ return -2;
3125
+ }
3126
+ return 0;
3127
+ } catch (e) {
3128
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3129
+ return -e.errno;
3130
+ }
3131
+ }
3132
+ function ___syscall_fchmod(fd, mode) {
3133
+ try {
3134
+ FS.fchmod(fd, mode);
3135
+ return 0;
3136
+ } catch (e) {
3137
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3138
+ return -e.errno;
3139
+ }
3140
+ }
3141
+ var syscallGetVarargI = () => {
3142
+ assert(SYSCALLS.varargs != void 0);
3143
+ var ret = HEAP32[+SYSCALLS.varargs >> 2];
3144
+ SYSCALLS.varargs += 4;
3145
+ return ret;
3146
+ };
3147
+ var syscallGetVarargP = syscallGetVarargI;
3148
+ function ___syscall_fcntl64(fd, cmd, varargs) {
3149
+ SYSCALLS.varargs = varargs;
3150
+ try {
3151
+ var stream = SYSCALLS.getStreamFromFD(fd);
3152
+ switch (cmd) {
3153
+ case 0: {
3154
+ var arg = syscallGetVarargI();
3155
+ if (arg < 0) {
3156
+ return -28;
3157
+ }
3158
+ while (FS.streams[arg]) {
3159
+ arg++;
3160
+ }
3161
+ var newStream;
3162
+ newStream = FS.dupStream(stream, arg);
3163
+ return newStream.fd;
3164
+ }
3165
+ case 1:
3166
+ case 2:
3167
+ return 0;
3168
+ case 3:
3169
+ return stream.flags;
3170
+ case 4: {
3171
+ var arg = syscallGetVarargI();
3172
+ stream.flags |= arg;
3173
+ return 0;
3174
+ }
3175
+ case 12: {
3176
+ var arg = syscallGetVarargP();
3177
+ var offset = 0;
3178
+ HEAP16[arg + offset >> 1] = 2;
3179
+ return 0;
3180
+ }
3181
+ case 13:
3182
+ case 14:
3183
+ return 0;
3184
+ }
3185
+ return -28;
3186
+ } catch (e) {
3187
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3188
+ return -e.errno;
3189
+ }
3190
+ }
3191
+ function ___syscall_fstat64(fd, buf) {
3192
+ try {
3193
+ return SYSCALLS.writeStat(buf, FS.fstat(fd));
3194
+ } catch (e) {
3195
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3196
+ return -e.errno;
3197
+ }
3198
+ }
3199
+ var INT53_MAX = 9007199254740992;
3200
+ var INT53_MIN = -9007199254740992;
3201
+ var bigintToI53Checked = (num) => num < INT53_MIN || num > INT53_MAX ? NaN : Number(num);
3202
+ function ___syscall_ftruncate64(fd, length) {
3203
+ length = bigintToI53Checked(length);
3204
+ try {
3205
+ if (isNaN(length)) return -61;
3206
+ FS.ftruncate(fd, length);
3207
+ return 0;
3208
+ } catch (e) {
3209
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3210
+ return -e.errno;
3211
+ }
3212
+ }
3213
+ var stringToUTF8 = (str, outPtr, maxBytesToWrite) => {
3214
+ assert(typeof maxBytesToWrite == "number", "stringToUTF8(str, outPtr, maxBytesToWrite) is missing the third parameter that specifies the length of the output buffer!");
3215
+ return stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
3216
+ };
3217
+ function ___syscall_getcwd(buf, size) {
3218
+ try {
3219
+ if (size === 0) return -28;
3220
+ var cwd = FS.cwd();
3221
+ var cwdLengthInBytes = lengthBytesUTF8(cwd) + 1;
3222
+ if (size < cwdLengthInBytes) return -68;
3223
+ stringToUTF8(cwd, buf, size);
3224
+ return cwdLengthInBytes;
3225
+ } catch (e) {
3226
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3227
+ return -e.errno;
3228
+ }
3229
+ }
3230
+ function ___syscall_getdents64(fd, dirp, count) {
3231
+ try {
3232
+ var stream = SYSCALLS.getStreamFromFD(fd);
3233
+ stream.getdents ||= FS.readdir(stream.path);
3234
+ var struct_size = 280;
3235
+ var pos = 0;
3236
+ var off = FS.llseek(stream, 0, 1);
3237
+ var startIdx = Math.floor(off / struct_size);
3238
+ var endIdx = Math.min(stream.getdents.length, startIdx + Math.floor(count / struct_size));
3239
+ for (var idx = startIdx; idx < endIdx; idx++) {
3240
+ var id;
3241
+ var type;
3242
+ var name = stream.getdents[idx];
3243
+ if (name === ".") {
3244
+ id = stream.node.id;
3245
+ type = 4;
3246
+ } else if (name === "..") {
3247
+ var lookup = FS.lookupPath(stream.path, { parent: true });
3248
+ id = lookup.node.id;
3249
+ type = 4;
3250
+ } else {
3251
+ var child;
3252
+ try {
3253
+ child = FS.lookupNode(stream.node, name);
3254
+ } catch (e) {
3255
+ if (e?.errno === 28) {
3256
+ continue;
3257
+ }
3258
+ throw e;
3259
+ }
3260
+ id = child.id;
3261
+ type = FS.isChrdev(child.mode) ? 2 : FS.isDir(child.mode) ? 4 : FS.isLink(child.mode) ? 10 : 8;
3262
+ }
3263
+ assert(id);
3264
+ HEAP64[dirp + pos >> 3] = BigInt(id);
3265
+ HEAP64[dirp + pos + 8 >> 3] = BigInt((idx + 1) * struct_size);
3266
+ HEAP16[dirp + pos + 16 >> 1] = 280;
3267
+ HEAP8[dirp + pos + 18] = type;
3268
+ stringToUTF8(name, dirp + pos + 19, 256);
3269
+ pos += struct_size;
3270
+ }
3271
+ FS.llseek(stream, idx * struct_size, 0);
3272
+ return pos;
3273
+ } catch (e) {
3274
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3275
+ return -e.errno;
3276
+ }
3277
+ }
3278
+ function ___syscall_getpeername(fd, addr, addrlen, d1, d2, d3) {
3279
+ try {
3280
+ var sock = getSocketFromFD(fd);
3281
+ if (!sock.daddr) {
3282
+ return -53;
3283
+ }
3284
+ var errno = writeSockaddr(addr, sock.family, DNS.lookup_name(sock.daddr), sock.dport, addrlen);
3285
+ assert(!errno);
3286
+ return 0;
3287
+ } catch (e) {
3288
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3289
+ return -e.errno;
3290
+ }
3291
+ }
3292
+ function ___syscall_getsockname(fd, addr, addrlen, d1, d2, d3) {
3293
+ try {
3294
+ var sock = getSocketFromFD(fd);
3295
+ var errno = writeSockaddr(addr, sock.family, DNS.lookup_name(sock.saddr || "0.0.0.0"), sock.sport, addrlen);
3296
+ assert(!errno);
3297
+ return 0;
3298
+ } catch (e) {
3299
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3300
+ return -e.errno;
3301
+ }
3302
+ }
3303
+ function ___syscall_getsockopt(fd, level, optname, optval, optlen, d1) {
3304
+ try {
3305
+ var sock = getSocketFromFD(fd);
3306
+ if (level === 1) {
3307
+ if (optname === 4) {
3308
+ HEAP32[optval >> 2] = sock.error;
3309
+ HEAP32[optlen >> 2] = 4;
3310
+ sock.error = null;
3311
+ return 0;
3312
+ }
3313
+ }
3314
+ return -50;
3315
+ } catch (e) {
3316
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3317
+ return -e.errno;
3318
+ }
3319
+ }
3320
+ function ___syscall_ioctl(fd, op, varargs) {
3321
+ SYSCALLS.varargs = varargs;
3322
+ try {
3323
+ var stream = SYSCALLS.getStreamFromFD(fd);
3324
+ switch (op) {
3325
+ case 21509: {
3326
+ if (!stream.tty) return -59;
3327
+ return 0;
3328
+ }
3329
+ case 21505: {
3330
+ if (!stream.tty) return -59;
3331
+ if (stream.tty.ops.ioctl_tcgets) {
3332
+ var termios = stream.tty.ops.ioctl_tcgets(stream);
3333
+ var argp = syscallGetVarargP();
3334
+ HEAP32[argp >> 2] = termios.c_iflag || 0;
3335
+ HEAP32[argp + 4 >> 2] = termios.c_oflag || 0;
3336
+ HEAP32[argp + 8 >> 2] = termios.c_cflag || 0;
3337
+ HEAP32[argp + 12 >> 2] = termios.c_lflag || 0;
3338
+ for (var i = 0; i < 32; i++) {
3339
+ HEAP8[argp + i + 17] = termios.c_cc[i] || 0;
3340
+ }
3341
+ return 0;
3342
+ }
3343
+ return 0;
3344
+ }
3345
+ case 21510:
3346
+ case 21511:
3347
+ case 21512: {
3348
+ if (!stream.tty) return -59;
3349
+ return 0;
3350
+ }
3351
+ case 21506:
3352
+ case 21507:
3353
+ case 21508: {
3354
+ if (!stream.tty) return -59;
3355
+ if (stream.tty.ops.ioctl_tcsets) {
3356
+ var argp = syscallGetVarargP();
3357
+ var c_iflag = HEAP32[argp >> 2];
3358
+ var c_oflag = HEAP32[argp + 4 >> 2];
3359
+ var c_cflag = HEAP32[argp + 8 >> 2];
3360
+ var c_lflag = HEAP32[argp + 12 >> 2];
3361
+ var c_cc = [];
3362
+ for (var i = 0; i < 32; i++) {
3363
+ c_cc.push(HEAP8[argp + i + 17]);
3364
+ }
3365
+ return stream.tty.ops.ioctl_tcsets(stream.tty, op, { c_iflag, c_oflag, c_cflag, c_lflag, c_cc });
3366
+ }
3367
+ return 0;
3368
+ }
3369
+ case 21519: {
3370
+ if (!stream.tty) return -59;
3371
+ var argp = syscallGetVarargP();
3372
+ HEAP32[argp >> 2] = 0;
3373
+ return 0;
3374
+ }
3375
+ case 21520: {
3376
+ if (!stream.tty) return -59;
3377
+ return -28;
3378
+ }
3379
+ case 21537:
3380
+ case 21531: {
3381
+ var argp = syscallGetVarargP();
3382
+ return FS.ioctl(stream, op, argp);
3383
+ }
3384
+ case 21523: {
3385
+ if (!stream.tty) return -59;
3386
+ if (stream.tty.ops.ioctl_tiocgwinsz) {
3387
+ var winsize = stream.tty.ops.ioctl_tiocgwinsz(stream.tty);
3388
+ var argp = syscallGetVarargP();
3389
+ HEAP16[argp >> 1] = winsize[0];
3390
+ HEAP16[argp + 2 >> 1] = winsize[1];
3391
+ }
3392
+ return 0;
3393
+ }
3394
+ case 21524: {
3395
+ if (!stream.tty) return -59;
3396
+ return 0;
3397
+ }
3398
+ case 21515: {
3399
+ if (!stream.tty) return -59;
3400
+ return 0;
3401
+ }
3402
+ default:
3403
+ return -28;
3404
+ }
3405
+ } catch (e) {
3406
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3407
+ return -e.errno;
3408
+ }
3409
+ }
3410
+ function ___syscall_listen(fd, backlog) {
3411
+ try {
3412
+ var sock = getSocketFromFD(fd);
3413
+ sock.sock_ops.listen(sock, backlog);
3414
+ return 0;
3415
+ } catch (e) {
3416
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3417
+ return -e.errno;
3418
+ }
3419
+ }
3420
+ function ___syscall_lstat64(path, buf) {
3421
+ try {
3422
+ path = SYSCALLS.getStr(path);
3423
+ return SYSCALLS.writeStat(buf, FS.lstat(path));
3424
+ } catch (e) {
3425
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3426
+ return -e.errno;
3427
+ }
3428
+ }
3429
+ function ___syscall_mkdirat(dirfd, path, mode) {
3430
+ try {
3431
+ path = SYSCALLS.getStr(path);
3432
+ path = SYSCALLS.calculateAt(dirfd, path);
3433
+ FS.mkdir(path, mode, 0);
3434
+ return 0;
3435
+ } catch (e) {
3436
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3437
+ return -e.errno;
3438
+ }
3439
+ }
3440
+ function ___syscall_newfstatat(dirfd, path, buf, flags) {
3441
+ try {
3442
+ path = SYSCALLS.getStr(path);
3443
+ var nofollow = flags & 256;
3444
+ var allowEmpty = flags & 4096;
3445
+ flags = flags & ~6400;
3446
+ assert(!flags, `unknown flags in __syscall_newfstatat: ${flags}`);
3447
+ path = SYSCALLS.calculateAt(dirfd, path, allowEmpty);
3448
+ return SYSCALLS.writeStat(buf, nofollow ? FS.lstat(path) : FS.stat(path));
3449
+ } catch (e) {
3450
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3451
+ return -e.errno;
3452
+ }
3453
+ }
3454
+ function ___syscall_openat(dirfd, path, flags, varargs) {
3455
+ SYSCALLS.varargs = varargs;
3456
+ try {
3457
+ path = SYSCALLS.getStr(path);
3458
+ path = SYSCALLS.calculateAt(dirfd, path);
3459
+ var mode = varargs ? syscallGetVarargI() : 0;
3460
+ return FS.open(path, flags, mode).fd;
3461
+ } catch (e) {
3462
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3463
+ return -e.errno;
3464
+ }
3465
+ }
3466
+ var PIPEFS = { BUCKET_BUFFER_SIZE: 8192, mount(mount) {
3467
+ return FS.createNode(null, "/", 16384 | 511, 0);
3468
+ }, createPipe() {
3469
+ var pipe = { buckets: [], refcnt: 2, timestamp: /* @__PURE__ */ new Date() };
3470
+ pipe.buckets.push({ buffer: new Uint8Array(PIPEFS.BUCKET_BUFFER_SIZE), offset: 0, roffset: 0 });
3471
+ var rName = PIPEFS.nextname();
3472
+ var wName = PIPEFS.nextname();
3473
+ var rNode = FS.createNode(PIPEFS.root, rName, 4096, 0);
3474
+ var wNode = FS.createNode(PIPEFS.root, wName, 4096, 0);
3475
+ rNode.pipe = pipe;
3476
+ wNode.pipe = pipe;
3477
+ var readableStream = FS.createStream({ path: rName, node: rNode, flags: 0, seekable: false, stream_ops: PIPEFS.stream_ops });
3478
+ rNode.stream = readableStream;
3479
+ var writableStream = FS.createStream({ path: wName, node: wNode, flags: 1, seekable: false, stream_ops: PIPEFS.stream_ops });
3480
+ wNode.stream = writableStream;
3481
+ return { readable_fd: readableStream.fd, writable_fd: writableStream.fd };
3482
+ }, stream_ops: { getattr(stream) {
3483
+ var node = stream.node;
3484
+ var timestamp = node.pipe.timestamp;
3485
+ return { dev: 14, ino: node.id, mode: 4480, nlink: 1, uid: 0, gid: 0, rdev: 0, size: 0, atime: timestamp, mtime: timestamp, ctime: timestamp, blksize: 4096, blocks: 0 };
3486
+ }, poll(stream) {
3487
+ var pipe = stream.node.pipe;
3488
+ if ((stream.flags & 2097155) === 1) {
3489
+ return 256 | 4;
3490
+ }
3491
+ for (var bucket of pipe.buckets) {
3492
+ if (bucket.offset - bucket.roffset > 0) {
3493
+ return 64 | 1;
3494
+ }
3495
+ }
3496
+ return 0;
3497
+ }, dup(stream) {
3498
+ stream.node.pipe.refcnt++;
3499
+ }, ioctl(stream, request, varargs) {
3500
+ return 28;
3501
+ }, fsync(stream) {
3502
+ return 28;
3503
+ }, read(stream, buffer, offset, length, position) {
3504
+ var pipe = stream.node.pipe;
3505
+ var currentLength = 0;
3506
+ for (var bucket of pipe.buckets) {
3507
+ currentLength += bucket.offset - bucket.roffset;
3508
+ }
3509
+ assert(buffer instanceof ArrayBuffer || ArrayBuffer.isView(buffer));
3510
+ var data = buffer.subarray(offset, offset + length);
3511
+ if (length <= 0) {
3512
+ return 0;
3513
+ }
3514
+ if (currentLength == 0) {
3515
+ throw new FS.ErrnoError(6);
3516
+ }
3517
+ var toRead = Math.min(currentLength, length);
3518
+ var totalRead = toRead;
3519
+ var toRemove = 0;
3520
+ for (var bucket of pipe.buckets) {
3521
+ var bucketSize = bucket.offset - bucket.roffset;
3522
+ if (toRead <= bucketSize) {
3523
+ var tmpSlice = bucket.buffer.subarray(bucket.roffset, bucket.offset);
3524
+ if (toRead < bucketSize) {
3525
+ tmpSlice = tmpSlice.subarray(0, toRead);
3526
+ bucket.roffset += toRead;
3527
+ } else {
3528
+ toRemove++;
3529
+ }
3530
+ data.set(tmpSlice);
3531
+ break;
3532
+ } else {
3533
+ var tmpSlice = bucket.buffer.subarray(bucket.roffset, bucket.offset);
3534
+ data.set(tmpSlice);
3535
+ data = data.subarray(tmpSlice.byteLength);
3536
+ toRead -= tmpSlice.byteLength;
3537
+ toRemove++;
3538
+ }
3539
+ }
3540
+ if (toRemove && toRemove == pipe.buckets.length) {
3541
+ toRemove--;
3542
+ pipe.buckets[toRemove].offset = 0;
3543
+ pipe.buckets[toRemove].roffset = 0;
3544
+ }
3545
+ pipe.buckets.splice(0, toRemove);
3546
+ return totalRead;
3547
+ }, write(stream, buffer, offset, length, position) {
3548
+ var pipe = stream.node.pipe;
3549
+ assert(buffer instanceof ArrayBuffer || ArrayBuffer.isView(buffer));
3550
+ var data = buffer.subarray(offset, offset + length);
3551
+ var dataLen = data.byteLength;
3552
+ if (dataLen <= 0) {
3553
+ return 0;
3554
+ }
3555
+ var currBucket = null;
3556
+ if (pipe.buckets.length == 0) {
3557
+ currBucket = { buffer: new Uint8Array(PIPEFS.BUCKET_BUFFER_SIZE), offset: 0, roffset: 0 };
3558
+ pipe.buckets.push(currBucket);
3559
+ } else {
3560
+ currBucket = pipe.buckets[pipe.buckets.length - 1];
3561
+ }
3562
+ assert(currBucket.offset <= PIPEFS.BUCKET_BUFFER_SIZE);
3563
+ var freeBytesInCurrBuffer = PIPEFS.BUCKET_BUFFER_SIZE - currBucket.offset;
3564
+ if (freeBytesInCurrBuffer >= dataLen) {
3565
+ currBucket.buffer.set(data, currBucket.offset);
3566
+ currBucket.offset += dataLen;
3567
+ return dataLen;
3568
+ } else if (freeBytesInCurrBuffer > 0) {
3569
+ currBucket.buffer.set(data.subarray(0, freeBytesInCurrBuffer), currBucket.offset);
3570
+ currBucket.offset += freeBytesInCurrBuffer;
3571
+ data = data.subarray(freeBytesInCurrBuffer, data.byteLength);
3572
+ }
3573
+ var numBuckets = data.byteLength / PIPEFS.BUCKET_BUFFER_SIZE | 0;
3574
+ var remElements = data.byteLength % PIPEFS.BUCKET_BUFFER_SIZE;
3575
+ for (var i = 0; i < numBuckets; i++) {
3576
+ var newBucket = { buffer: new Uint8Array(PIPEFS.BUCKET_BUFFER_SIZE), offset: PIPEFS.BUCKET_BUFFER_SIZE, roffset: 0 };
3577
+ pipe.buckets.push(newBucket);
3578
+ newBucket.buffer.set(data.subarray(0, PIPEFS.BUCKET_BUFFER_SIZE));
3579
+ data = data.subarray(PIPEFS.BUCKET_BUFFER_SIZE, data.byteLength);
3580
+ }
3581
+ if (remElements > 0) {
3582
+ var newBucket = { buffer: new Uint8Array(PIPEFS.BUCKET_BUFFER_SIZE), offset: data.byteLength, roffset: 0 };
3583
+ pipe.buckets.push(newBucket);
3584
+ newBucket.buffer.set(data);
3585
+ }
3586
+ return dataLen;
3587
+ }, close(stream) {
3588
+ var pipe = stream.node.pipe;
3589
+ pipe.refcnt--;
3590
+ if (pipe.refcnt === 0) {
3591
+ pipe.buckets = null;
3592
+ }
3593
+ } }, nextname() {
3594
+ if (!PIPEFS.nextname.current) {
3595
+ PIPEFS.nextname.current = 0;
3596
+ }
3597
+ return "pipe[" + PIPEFS.nextname.current++ + "]";
3598
+ } };
3599
+ function ___syscall_pipe(fdPtr) {
3600
+ try {
3601
+ if (fdPtr == 0) {
3602
+ throw new FS.ErrnoError(21);
3603
+ }
3604
+ var res = PIPEFS.createPipe();
3605
+ HEAP32[fdPtr >> 2] = res.readable_fd;
3606
+ HEAP32[fdPtr + 4 >> 2] = res.writable_fd;
3607
+ return 0;
3608
+ } catch (e) {
3609
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3610
+ return -e.errno;
3611
+ }
3612
+ }
3613
+ function ___syscall_poll(fds, nfds, timeout) {
3614
+ try {
3615
+ var nonzero = 0;
3616
+ for (var i = 0; i < nfds; i++) {
3617
+ var pollfd = fds + 8 * i;
3618
+ var fd = HEAP32[pollfd >> 2];
3619
+ var events = HEAP16[pollfd + 4 >> 1];
3620
+ var mask = 32;
3621
+ var stream = FS.getStream(fd);
3622
+ if (stream) {
3623
+ mask = SYSCALLS.DEFAULT_POLLMASK;
3624
+ if (stream.stream_ops.poll) {
3625
+ mask = stream.stream_ops.poll(stream, -1);
3626
+ }
3627
+ }
3628
+ mask &= events | 8 | 16;
3629
+ if (mask) nonzero++;
3630
+ HEAP16[pollfd + 6 >> 1] = mask;
3631
+ }
3632
+ return nonzero;
3633
+ } catch (e) {
3634
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3635
+ return -e.errno;
3636
+ }
3637
+ }
3638
+ function ___syscall_recvfrom(fd, buf, len, flags, addr, addrlen) {
3639
+ try {
3640
+ var sock = getSocketFromFD(fd);
3641
+ var msg = sock.sock_ops.recvmsg(sock, len);
3642
+ if (!msg) return 0;
3643
+ if (addr) {
3644
+ var errno = writeSockaddr(addr, sock.family, DNS.lookup_name(msg.addr), msg.port, addrlen);
3645
+ assert(!errno);
3646
+ }
3647
+ HEAPU8.set(msg.buffer, buf);
3648
+ return msg.buffer.byteLength;
3649
+ } catch (e) {
3650
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3651
+ return -e.errno;
3652
+ }
3653
+ }
3654
+ function ___syscall_renameat(olddirfd, oldpath, newdirfd, newpath) {
3655
+ try {
3656
+ oldpath = SYSCALLS.getStr(oldpath);
3657
+ newpath = SYSCALLS.getStr(newpath);
3658
+ oldpath = SYSCALLS.calculateAt(olddirfd, oldpath);
3659
+ newpath = SYSCALLS.calculateAt(newdirfd, newpath);
3660
+ FS.rename(oldpath, newpath);
3661
+ return 0;
3662
+ } catch (e) {
3663
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3664
+ return -e.errno;
3665
+ }
3666
+ }
3667
+ function ___syscall_sendto(fd, message, length, flags, addr, addr_len) {
3668
+ try {
3669
+ var sock = getSocketFromFD(fd);
3670
+ if (!addr) {
3671
+ return FS.write(sock.stream, HEAP8, message, length);
3672
+ }
3673
+ var dest = getSocketAddress(addr, addr_len);
3674
+ return sock.sock_ops.sendmsg(sock, HEAP8, message, length, dest.addr, dest.port);
3675
+ } catch (e) {
3676
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3677
+ return -e.errno;
3678
+ }
3679
+ }
3680
+ function ___syscall_socket(domain, type, protocol) {
3681
+ try {
3682
+ var sock = SOCKFS.createSocket(domain, type, protocol);
3683
+ assert(sock.stream.fd < 64);
3684
+ return sock.stream.fd;
3685
+ } catch (e) {
3686
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3687
+ return -e.errno;
3688
+ }
3689
+ }
3690
+ function ___syscall_stat64(path, buf) {
3691
+ try {
3692
+ path = SYSCALLS.getStr(path);
3693
+ return SYSCALLS.writeStat(buf, FS.stat(path));
3694
+ } catch (e) {
3695
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3696
+ return -e.errno;
3697
+ }
3698
+ }
3699
+ function ___syscall_truncate64(path, length) {
3700
+ length = bigintToI53Checked(length);
3701
+ try {
3702
+ if (isNaN(length)) return -61;
3703
+ path = SYSCALLS.getStr(path);
3704
+ FS.truncate(path, length);
3705
+ return 0;
3706
+ } catch (e) {
3707
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3708
+ return -e.errno;
3709
+ }
3710
+ }
3711
+ function ___syscall_unlinkat(dirfd, path, flags) {
3712
+ try {
3713
+ path = SYSCALLS.getStr(path);
3714
+ path = SYSCALLS.calculateAt(dirfd, path);
3715
+ if (!flags) {
3716
+ FS.unlink(path);
3717
+ } else if (flags === 512) {
3718
+ FS.rmdir(path);
3719
+ } else {
3720
+ return -28;
3721
+ }
3722
+ return 0;
3723
+ } catch (e) {
3724
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3725
+ return -e.errno;
3726
+ }
3727
+ }
3728
+ var __abort_js = () => abort("native code called abort()");
3729
+ var runtimeKeepaliveCounter = 0;
3730
+ var __emscripten_runtime_keepalive_clear = () => {
3731
+ noExitRuntime = false;
3732
+ runtimeKeepaliveCounter = 0;
3733
+ };
3734
+ var __emscripten_throw_longjmp = () => {
3735
+ throw Infinity;
3736
+ };
3737
+ function __gmtime_js(time, tmPtr) {
3738
+ time = bigintToI53Checked(time);
3739
+ var date = new Date(time * 1e3);
3740
+ HEAP32[tmPtr >> 2] = date.getUTCSeconds();
3741
+ HEAP32[tmPtr + 4 >> 2] = date.getUTCMinutes();
3742
+ HEAP32[tmPtr + 8 >> 2] = date.getUTCHours();
3743
+ HEAP32[tmPtr + 12 >> 2] = date.getUTCDate();
3744
+ HEAP32[tmPtr + 16 >> 2] = date.getUTCMonth();
3745
+ HEAP32[tmPtr + 20 >> 2] = date.getUTCFullYear() - 1900;
3746
+ HEAP32[tmPtr + 24 >> 2] = date.getUTCDay();
3747
+ var start = Date.UTC(date.getUTCFullYear(), 0, 1, 0, 0, 0, 0);
3748
+ var yday = (date.getTime() - start) / (1e3 * 60 * 60 * 24) | 0;
3749
+ HEAP32[tmPtr + 28 >> 2] = yday;
3750
+ }
3751
+ var isLeapYear = (year) => year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
3752
+ var MONTH_DAYS_LEAP_CUMULATIVE = [0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335];
3753
+ var MONTH_DAYS_REGULAR_CUMULATIVE = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334];
3754
+ var ydayFromDate = (date) => {
3755
+ var leap = isLeapYear(date.getFullYear());
3756
+ var monthDaysCumulative = leap ? MONTH_DAYS_LEAP_CUMULATIVE : MONTH_DAYS_REGULAR_CUMULATIVE;
3757
+ var yday = monthDaysCumulative[date.getMonth()] + date.getDate() - 1;
3758
+ return yday;
3759
+ };
3760
+ function __localtime_js(time, tmPtr) {
3761
+ time = bigintToI53Checked(time);
3762
+ var date = new Date(time * 1e3);
3763
+ HEAP32[tmPtr >> 2] = date.getSeconds();
3764
+ HEAP32[tmPtr + 4 >> 2] = date.getMinutes();
3765
+ HEAP32[tmPtr + 8 >> 2] = date.getHours();
3766
+ HEAP32[tmPtr + 12 >> 2] = date.getDate();
3767
+ HEAP32[tmPtr + 16 >> 2] = date.getMonth();
3768
+ HEAP32[tmPtr + 20 >> 2] = date.getFullYear() - 1900;
3769
+ HEAP32[tmPtr + 24 >> 2] = date.getDay();
3770
+ var yday = ydayFromDate(date) | 0;
3771
+ HEAP32[tmPtr + 28 >> 2] = yday;
3772
+ HEAP32[tmPtr + 36 >> 2] = -(date.getTimezoneOffset() * 60);
3773
+ var start = new Date(date.getFullYear(), 0, 1);
3774
+ var summerOffset = new Date(date.getFullYear(), 6, 1).getTimezoneOffset();
3775
+ var winterOffset = start.getTimezoneOffset();
3776
+ var dst = (summerOffset != winterOffset && date.getTimezoneOffset() == Math.min(winterOffset, summerOffset)) | 0;
3777
+ HEAP32[tmPtr + 32 >> 2] = dst;
3778
+ }
3779
+ function __mmap_js(len, prot, flags, fd, offset, allocated, addr) {
3780
+ offset = bigintToI53Checked(offset);
3781
+ try {
3782
+ assert(!isNaN(offset));
3783
+ var stream = SYSCALLS.getStreamFromFD(fd);
3784
+ var res = FS.mmap(stream, len, offset, prot, flags);
3785
+ var ptr = res.ptr;
3786
+ HEAP32[allocated >> 2] = res.allocated;
3787
+ HEAPU32[addr >> 2] = ptr;
3788
+ return 0;
3789
+ } catch (e) {
3790
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3791
+ return -e.errno;
3792
+ }
3793
+ }
3794
+ var timers = {};
3795
+ var handleException = (e) => {
3796
+ if (e instanceof ExitStatus || e == "unwind") {
3797
+ return EXITSTATUS;
3798
+ }
3799
+ checkStackCookie();
3800
+ if (e instanceof WebAssembly.RuntimeError) {
3801
+ if (_emscripten_stack_get_current() <= 0) {
3802
+ err("Stack overflow detected. You can try increasing -sSTACK_SIZE (currently set to 1048576)");
3803
+ }
3804
+ }
3805
+ quit_(1, e);
3806
+ };
3807
+ var keepRuntimeAlive = () => noExitRuntime || runtimeKeepaliveCounter > 0;
3808
+ var _proc_exit = (code) => {
3809
+ EXITSTATUS = code;
3810
+ if (!keepRuntimeAlive()) {
3811
+ Module2["onExit"]?.(code);
3812
+ ABORT = true;
3813
+ }
3814
+ quit_(code, new ExitStatus(code));
3815
+ };
3816
+ var exitJS = (status, implicit) => {
3817
+ EXITSTATUS = status;
3818
+ checkUnflushedContent();
3819
+ if (keepRuntimeAlive() && !implicit) {
3820
+ var msg = `program exited (with status: ${status}), but keepRuntimeAlive() is set (counter=${runtimeKeepaliveCounter}) due to an async operation, so halting execution but not exiting the runtime or preventing further async execution (you can use emscripten_force_exit, if you want to force a true shutdown)`;
3821
+ readyPromiseReject?.(msg);
3822
+ err(msg);
3823
+ }
3824
+ _proc_exit(status);
3825
+ };
3826
+ var _exit = exitJS;
3827
+ var maybeExit = () => {
3828
+ if (!keepRuntimeAlive()) {
3829
+ try {
3830
+ _exit(EXITSTATUS);
3831
+ } catch (e) {
3832
+ handleException(e);
3833
+ }
3834
+ }
3835
+ };
3836
+ var callUserCallback = (func) => {
3837
+ if (ABORT) {
3838
+ err("user callback triggered after runtime exited or application aborted. Ignoring.");
3839
+ return;
3840
+ }
3841
+ try {
3842
+ func();
3843
+ maybeExit();
3844
+ } catch (e) {
3845
+ handleException(e);
3846
+ }
3847
+ };
3848
+ var _emscripten_get_now = () => performance.now();
3849
+ var __setitimer_js = (which, timeout_ms) => {
3850
+ if (timers[which]) {
3851
+ clearTimeout(timers[which].id);
3852
+ delete timers[which];
3853
+ }
3854
+ if (!timeout_ms) return 0;
3855
+ var id = setTimeout(() => {
3856
+ assert(which in timers);
3857
+ delete timers[which];
3858
+ callUserCallback(() => __emscripten_timeout(which, _emscripten_get_now()));
3859
+ }, timeout_ms);
3860
+ timers[which] = { id, timeout_ms };
3861
+ return 0;
3862
+ };
3863
+ var __tzset_js = (timezone, daylight, std_name, dst_name) => {
3864
+ var currentYear = (/* @__PURE__ */ new Date()).getFullYear();
3865
+ var winter = new Date(currentYear, 0, 1);
3866
+ var summer = new Date(currentYear, 6, 1);
3867
+ var winterOffset = winter.getTimezoneOffset();
3868
+ var summerOffset = summer.getTimezoneOffset();
3869
+ var stdTimezoneOffset = Math.max(winterOffset, summerOffset);
3870
+ HEAPU32[timezone >> 2] = stdTimezoneOffset * 60;
3871
+ HEAP32[daylight >> 2] = Number(winterOffset != summerOffset);
3872
+ var extractZone = (timezoneOffset) => {
3873
+ var sign = timezoneOffset >= 0 ? "-" : "+";
3874
+ var absOffset = Math.abs(timezoneOffset);
3875
+ var hours = String(Math.floor(absOffset / 60)).padStart(2, "0");
3876
+ var minutes = String(absOffset % 60).padStart(2, "0");
3877
+ return `UTC${sign}${hours}${minutes}`;
3878
+ };
3879
+ var winterName = extractZone(winterOffset);
3880
+ var summerName = extractZone(summerOffset);
3881
+ assert(winterName);
3882
+ assert(summerName);
3883
+ assert(lengthBytesUTF8(winterName) <= 16, `timezone name truncated to fit in TZNAME_MAX (${winterName})`);
3884
+ assert(lengthBytesUTF8(summerName) <= 16, `timezone name truncated to fit in TZNAME_MAX (${summerName})`);
3885
+ if (summerOffset < winterOffset) {
3886
+ stringToUTF8(winterName, std_name, 17);
3887
+ stringToUTF8(summerName, dst_name, 17);
3888
+ } else {
3889
+ stringToUTF8(winterName, dst_name, 17);
3890
+ stringToUTF8(summerName, std_name, 17);
3891
+ }
3892
+ };
3893
+ function _addCommandToBatch() {
3894
+ abort("missing function: addCommandToBatch");
3895
+ }
3896
+ _addCommandToBatch.stub = true;
3897
+ var _emscripten_date_now = () => Date.now();
3898
+ var checkWasiClock = (clock_id) => clock_id >= 0 && clock_id <= 3;
3899
+ function _clock_time_get(clk_id, ignored_precision, ptime) {
3900
+ if (!checkWasiClock(clk_id)) {
3901
+ return 28;
3902
+ }
3903
+ var now;
3904
+ if (clk_id === 0) {
3905
+ now = _emscripten_date_now();
3906
+ } else {
3907
+ now = _emscripten_get_now();
3908
+ }
3909
+ var nsec = Math.round(now * 1e3 * 1e3);
3910
+ HEAP64[ptime >> 3] = BigInt(nsec);
3911
+ return 0;
3912
+ }
3913
+ function _determinePrefetchCount() {
3914
+ abort("missing function: determinePrefetchCount");
3915
+ }
3916
+ _determinePrefetchCount.stub = true;
3917
+ var _emscripten_err = (str) => err(UTF8ToString(str));
3918
+ var getHeapMax = () => 2147483648;
3919
+ var _emscripten_get_heap_max = () => getHeapMax();
3920
+ var growMemory = (size) => {
3921
+ var oldHeapSize = wasmMemory.buffer.byteLength;
3922
+ var pages = (size - oldHeapSize + 65535) / 65536 | 0;
3923
+ try {
3924
+ wasmMemory.grow(pages);
3925
+ updateMemoryViews();
3926
+ return 1;
3927
+ } catch (e) {
3928
+ err(`growMemory: Attempted to grow heap from ${oldHeapSize} bytes to ${size} bytes, but got error: ${e}`);
3929
+ }
3930
+ };
3931
+ var _emscripten_resize_heap = (requestedSize) => {
3932
+ var oldSize = HEAPU8.length;
3933
+ requestedSize >>>= 0;
3934
+ assert(requestedSize > oldSize);
3935
+ var maxHeapSize = getHeapMax();
3936
+ if (requestedSize > maxHeapSize) {
3937
+ err(`Cannot enlarge memory, requested ${requestedSize} bytes, but the limit is ${maxHeapSize} bytes!`);
3938
+ return false;
3939
+ }
3940
+ for (var cutDown = 1; cutDown <= 4; cutDown *= 2) {
3941
+ var overGrownHeapSize = oldSize * (1 + 0.2 / cutDown);
3942
+ overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296);
3943
+ var newSize = Math.min(maxHeapSize, alignMemory(Math.max(requestedSize, overGrownHeapSize), 65536));
3944
+ var replacement = growMemory(newSize);
3945
+ if (replacement) {
3946
+ return true;
3947
+ }
3948
+ }
3949
+ err(`Failed to grow the heap from ${oldSize} bytes to ${newSize} bytes, not enough memory!`);
3950
+ return false;
3951
+ };
3952
+ var ENV = {};
3953
+ var getExecutableName = () => thisProgram || "./this.program";
3954
+ var getEnvStrings = () => {
3955
+ if (!getEnvStrings.strings) {
3956
+ var lang = (typeof navigator == "object" && navigator.language || "C").replace("-", "_") + ".UTF-8";
3957
+ var env = { USER: "web_user", LOGNAME: "web_user", PATH: "/", PWD: "/", HOME: "/home/web_user", LANG: lang, _: getExecutableName() };
3958
+ for (var x in ENV) {
3959
+ if (ENV[x] === void 0) delete env[x];
3960
+ else env[x] = ENV[x];
3961
+ }
3962
+ var strings = [];
3963
+ for (var x in env) {
3964
+ strings.push(`${x}=${env[x]}`);
3965
+ }
3966
+ getEnvStrings.strings = strings;
3967
+ }
3968
+ return getEnvStrings.strings;
3969
+ };
3970
+ var _environ_get = (__environ, environ_buf) => {
3971
+ var bufSize = 0;
3972
+ var envp = 0;
3973
+ for (var string of getEnvStrings()) {
3974
+ var ptr = environ_buf + bufSize;
3975
+ HEAPU32[__environ + envp >> 2] = ptr;
3976
+ bufSize += stringToUTF8(string, ptr, Infinity) + 1;
3977
+ envp += 4;
3978
+ }
3979
+ return 0;
3980
+ };
3981
+ var _environ_sizes_get = (penviron_count, penviron_buf_size) => {
3982
+ var strings = getEnvStrings();
3983
+ HEAPU32[penviron_count >> 2] = strings.length;
3984
+ var bufSize = 0;
3985
+ for (var string of strings) {
3986
+ bufSize += lengthBytesUTF8(string) + 1;
3987
+ }
3988
+ HEAPU32[penviron_buf_size >> 2] = bufSize;
3989
+ return 0;
3990
+ };
3991
+ function _fd_close(fd) {
3992
+ try {
3993
+ var stream = SYSCALLS.getStreamFromFD(fd);
3994
+ FS.close(stream);
3995
+ return 0;
3996
+ } catch (e) {
3997
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3998
+ return e.errno;
3999
+ }
4000
+ }
4001
+ function _fd_fdstat_get(fd, pbuf) {
4002
+ try {
4003
+ var rightsBase = 0;
4004
+ var rightsInheriting = 0;
4005
+ var flags = 0;
4006
+ {
4007
+ var stream = SYSCALLS.getStreamFromFD(fd);
4008
+ var type = stream.tty ? 2 : FS.isDir(stream.mode) ? 3 : FS.isLink(stream.mode) ? 7 : 4;
4009
+ }
4010
+ HEAP8[pbuf] = type;
4011
+ HEAP16[pbuf + 2 >> 1] = flags;
4012
+ HEAP64[pbuf + 8 >> 3] = BigInt(rightsBase);
4013
+ HEAP64[pbuf + 16 >> 3] = BigInt(rightsInheriting);
4014
+ return 0;
4015
+ } catch (e) {
4016
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
4017
+ return e.errno;
4018
+ }
4019
+ }
4020
+ var doReadv = (stream, iov, iovcnt, offset) => {
4021
+ var ret = 0;
4022
+ for (var i = 0; i < iovcnt; i++) {
4023
+ var ptr = HEAPU32[iov >> 2];
4024
+ var len = HEAPU32[iov + 4 >> 2];
4025
+ iov += 8;
4026
+ var curr = FS.read(stream, HEAP8, ptr, len, offset);
4027
+ if (curr < 0) return -1;
4028
+ ret += curr;
4029
+ if (curr < len) break;
4030
+ }
4031
+ return ret;
4032
+ };
4033
+ function _fd_read(fd, iov, iovcnt, pnum) {
4034
+ try {
4035
+ var stream = SYSCALLS.getStreamFromFD(fd);
4036
+ var num = doReadv(stream, iov, iovcnt);
4037
+ HEAPU32[pnum >> 2] = num;
4038
+ return 0;
4039
+ } catch (e) {
4040
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
4041
+ return e.errno;
4042
+ }
4043
+ }
4044
+ function _fd_seek(fd, offset, whence, newOffset) {
4045
+ offset = bigintToI53Checked(offset);
4046
+ try {
4047
+ if (isNaN(offset)) return 61;
4048
+ var stream = SYSCALLS.getStreamFromFD(fd);
4049
+ FS.llseek(stream, offset, whence);
4050
+ HEAP64[newOffset >> 3] = BigInt(stream.position);
4051
+ if (stream.getdents && offset === 0 && whence === 0) stream.getdents = null;
4052
+ return 0;
4053
+ } catch (e) {
4054
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
4055
+ return e.errno;
4056
+ }
4057
+ }
4058
+ function _fd_sync(fd) {
4059
+ try {
4060
+ var stream = SYSCALLS.getStreamFromFD(fd);
4061
+ if (stream.stream_ops?.fsync) {
4062
+ return stream.stream_ops.fsync(stream);
4063
+ }
4064
+ return 0;
4065
+ } catch (e) {
4066
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
4067
+ return e.errno;
4068
+ }
4069
+ }
4070
+ var doWritev = (stream, iov, iovcnt, offset) => {
4071
+ var ret = 0;
4072
+ for (var i = 0; i < iovcnt; i++) {
4073
+ var ptr = HEAPU32[iov >> 2];
4074
+ var len = HEAPU32[iov + 4 >> 2];
4075
+ iov += 8;
4076
+ var curr = FS.write(stream, HEAP8, ptr, len, offset);
4077
+ if (curr < 0) return -1;
4078
+ ret += curr;
4079
+ if (curr < len) {
4080
+ break;
4081
+ }
4082
+ }
4083
+ return ret;
4084
+ };
4085
+ function _fd_write(fd, iov, iovcnt, pnum) {
4086
+ try {
4087
+ var stream = SYSCALLS.getStreamFromFD(fd);
4088
+ var num = doWritev(stream, iov, iovcnt);
4089
+ HEAPU32[pnum >> 2] = num;
4090
+ return 0;
4091
+ } catch (e) {
4092
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
4093
+ return e.errno;
4094
+ }
4095
+ }
4096
+ var _getaddrinfo = (node, service, hint, out2) => {
4097
+ var addr = 0;
4098
+ var port = 0;
4099
+ var flags = 0;
4100
+ var family = 0;
4101
+ var type = 0;
4102
+ var proto = 0;
4103
+ var ai;
4104
+ function allocaddrinfo(family2, type2, proto2, canon, addr2, port2) {
4105
+ var sa, salen, ai2;
4106
+ var errno;
4107
+ salen = family2 === 10 ? 28 : 16;
4108
+ addr2 = family2 === 10 ? inetNtop6(addr2) : inetNtop4(addr2);
4109
+ sa = _malloc(salen);
4110
+ errno = writeSockaddr(sa, family2, addr2, port2);
4111
+ assert(!errno);
4112
+ ai2 = _malloc(32);
4113
+ HEAP32[ai2 + 4 >> 2] = family2;
4114
+ HEAP32[ai2 + 8 >> 2] = type2;
4115
+ HEAP32[ai2 + 12 >> 2] = proto2;
4116
+ HEAPU32[ai2 + 24 >> 2] = canon;
4117
+ HEAPU32[ai2 + 20 >> 2] = sa;
4118
+ if (family2 === 10) {
4119
+ HEAP32[ai2 + 16 >> 2] = 28;
4120
+ } else {
4121
+ HEAP32[ai2 + 16 >> 2] = 16;
4122
+ }
4123
+ HEAP32[ai2 + 28 >> 2] = 0;
4124
+ return ai2;
4125
+ }
4126
+ if (hint) {
4127
+ flags = HEAP32[hint >> 2];
4128
+ family = HEAP32[hint + 4 >> 2];
4129
+ type = HEAP32[hint + 8 >> 2];
4130
+ proto = HEAP32[hint + 12 >> 2];
4131
+ }
4132
+ if (type && !proto) {
4133
+ proto = type === 2 ? 17 : 6;
4134
+ }
4135
+ if (!type && proto) {
4136
+ type = proto === 17 ? 2 : 1;
4137
+ }
4138
+ if (proto === 0) {
4139
+ proto = 6;
4140
+ }
4141
+ if (type === 0) {
4142
+ type = 1;
4143
+ }
4144
+ if (!node && !service) {
4145
+ return -2;
4146
+ }
4147
+ if (flags & -1088) {
4148
+ return -1;
4149
+ }
4150
+ if (hint !== 0 && HEAP32[hint >> 2] & 2 && !node) {
4151
+ return -1;
4152
+ }
4153
+ if (flags & 32) {
4154
+ return -2;
4155
+ }
4156
+ if (type !== 0 && type !== 1 && type !== 2) {
4157
+ return -7;
4158
+ }
4159
+ if (family !== 0 && family !== 2 && family !== 10) {
4160
+ return -6;
4161
+ }
4162
+ if (service) {
4163
+ service = UTF8ToString(service);
4164
+ port = parseInt(service, 10);
4165
+ if (isNaN(port)) {
4166
+ if (flags & 1024) {
4167
+ return -2;
4168
+ }
4169
+ return -8;
4170
+ }
4171
+ }
4172
+ if (!node) {
4173
+ if (family === 0) {
4174
+ family = 2;
4175
+ }
4176
+ if ((flags & 1) === 0) {
4177
+ if (family === 2) {
4178
+ addr = _htonl(2130706433);
4179
+ } else {
4180
+ addr = [0, 0, 0, _htonl(1)];
4181
+ }
4182
+ }
4183
+ ai = allocaddrinfo(family, type, proto, null, addr, port);
4184
+ HEAPU32[out2 >> 2] = ai;
4185
+ return 0;
4186
+ }
4187
+ node = UTF8ToString(node);
4188
+ addr = inetPton4(node);
4189
+ if (addr !== null) {
4190
+ if (family === 0 || family === 2) {
4191
+ family = 2;
4192
+ } else if (family === 10 && flags & 8) {
4193
+ addr = [0, 0, _htonl(65535), addr];
4194
+ family = 10;
4195
+ } else {
4196
+ return -2;
4197
+ }
4198
+ } else {
4199
+ addr = inetPton6(node);
4200
+ if (addr !== null) {
4201
+ if (family === 0 || family === 10) {
4202
+ family = 10;
4203
+ } else {
4204
+ return -2;
4205
+ }
4206
+ }
4207
+ }
4208
+ if (addr != null) {
4209
+ ai = allocaddrinfo(family, type, proto, node, addr, port);
4210
+ HEAPU32[out2 >> 2] = ai;
4211
+ return 0;
4212
+ }
4213
+ if (flags & 4) {
4214
+ return -2;
4215
+ }
4216
+ node = DNS.lookup_name(node);
4217
+ addr = inetPton4(node);
4218
+ if (family === 0) {
4219
+ family = 2;
4220
+ } else if (family === 10) {
4221
+ addr = [0, 0, _htonl(65535), addr];
4222
+ }
4223
+ ai = allocaddrinfo(family, type, proto, null, addr, port);
4224
+ HEAPU32[out2 >> 2] = ai;
4225
+ return 0;
4226
+ };
4227
+ function _lolwutCommand() {
4228
+ abort("missing function: lolwutCommand");
4229
+ }
4230
+ _lolwutCommand.stub = true;
4231
+ function _prefetchCommands() {
4232
+ abort("missing function: prefetchCommands");
4233
+ }
4234
+ _prefetchCommands.stub = true;
4235
+ function _prefetchCommandsBatchInit() {
4236
+ abort("missing function: prefetchCommandsBatchInit");
4237
+ }
4238
+ _prefetchCommandsBatchInit.stub = true;
4239
+ function _rdbCheckError() {
4240
+ abort("missing function: rdbCheckError");
4241
+ }
4242
+ _rdbCheckError.stub = true;
4243
+ function _redis_check_aof_main() {
4244
+ abort("missing function: redis_check_aof_main");
4245
+ }
4246
+ _redis_check_aof_main.stub = true;
4247
+ function _redis_check_rdb_main() {
4248
+ abort("missing function: redis_check_rdb_main");
4249
+ }
4250
+ _redis_check_rdb_main.stub = true;
4251
+ function _resetCommandsBatch() {
4252
+ abort("missing function: resetCommandsBatch");
4253
+ }
4254
+ _resetCommandsBatch.stub = true;
4255
+ var stackAlloc = (sz) => __emscripten_stack_alloc(sz);
4256
+ var stringToUTF8OnStack = (str) => {
4257
+ var size = lengthBytesUTF8(str) + 1;
4258
+ var ret = stackAlloc(size);
4259
+ stringToUTF8(str, ret, size);
4260
+ return ret;
4261
+ };
4262
+ var getCFunc = (ident) => {
4263
+ var func = Module2["_" + ident];
4264
+ assert(func, "Cannot call unknown function " + ident + ", make sure it is exported");
4265
+ return func;
4266
+ };
4267
+ var writeArrayToMemory = (array, buffer) => {
4268
+ assert(array.length >= 0, "writeArrayToMemory array must have a length (should be an array or typed array)");
4269
+ HEAP8.set(array, buffer);
4270
+ };
4271
+ var ccall = (ident, returnType, argTypes, args, opts) => {
4272
+ var toC = { string: (str) => {
4273
+ var ret2 = 0;
4274
+ if (str !== null && str !== void 0 && str !== 0) {
4275
+ ret2 = stringToUTF8OnStack(str);
4276
+ }
4277
+ return ret2;
4278
+ }, array: (arr) => {
4279
+ var ret2 = stackAlloc(arr.length);
4280
+ writeArrayToMemory(arr, ret2);
4281
+ return ret2;
4282
+ } };
4283
+ function convertReturnValue(ret2) {
4284
+ if (returnType === "string") {
4285
+ return UTF8ToString(ret2);
4286
+ }
4287
+ if (returnType === "boolean") return Boolean(ret2);
4288
+ return ret2;
4289
+ }
4290
+ var func = getCFunc(ident);
4291
+ var cArgs = [];
4292
+ var stack = 0;
4293
+ assert(returnType !== "array", 'Return type should not be "array".');
4294
+ if (args) {
4295
+ for (var i = 0; i < args.length; i++) {
4296
+ var converter = toC[argTypes[i]];
4297
+ if (converter) {
4298
+ if (stack === 0) stack = stackSave();
4299
+ cArgs[i] = converter(args[i]);
4300
+ } else {
4301
+ cArgs[i] = args[i];
4302
+ }
4303
+ }
4304
+ }
4305
+ var ret = func(...cArgs);
4306
+ function onDone(ret2) {
4307
+ if (stack !== 0) stackRestore(stack);
4308
+ return convertReturnValue(ret2);
4309
+ }
4310
+ ret = onDone(ret);
4311
+ return ret;
4312
+ };
4313
+ var cwrap = (ident, returnType, argTypes, opts) => (...args) => ccall(ident, returnType, argTypes, args);
4314
+ FS.createPreloadedFile = FS_createPreloadedFile;
4315
+ FS.preloadFile = FS_preloadFile;
4316
+ FS.staticInit();
4317
+ {
4318
+ if (Module2["noExitRuntime"]) noExitRuntime = Module2["noExitRuntime"];
4319
+ if (Module2["preloadPlugins"]) preloadPlugins = Module2["preloadPlugins"];
4320
+ if (Module2["print"]) out = Module2["print"];
4321
+ if (Module2["printErr"]) err = Module2["printErr"];
4322
+ if (Module2["wasmBinary"]) wasmBinary = Module2["wasmBinary"];
4323
+ checkIncomingModuleAPI();
4324
+ if (Module2["arguments"]) arguments_ = Module2["arguments"];
4325
+ if (Module2["thisProgram"]) thisProgram = Module2["thisProgram"];
4326
+ assert(typeof Module2["memoryInitializerPrefixURL"] == "undefined", "Module.memoryInitializerPrefixURL option was removed, use Module.locateFile instead");
4327
+ assert(typeof Module2["pthreadMainPrefixURL"] == "undefined", "Module.pthreadMainPrefixURL option was removed, use Module.locateFile instead");
4328
+ assert(typeof Module2["cdInitializerPrefixURL"] == "undefined", "Module.cdInitializerPrefixURL option was removed, use Module.locateFile instead");
4329
+ assert(typeof Module2["filePackagePrefixURL"] == "undefined", "Module.filePackagePrefixURL option was removed, use Module.locateFile instead");
4330
+ assert(typeof Module2["read"] == "undefined", "Module.read option was removed");
4331
+ assert(typeof Module2["readAsync"] == "undefined", "Module.readAsync option was removed (modify readAsync in JS)");
4332
+ assert(typeof Module2["readBinary"] == "undefined", "Module.readBinary option was removed (modify readBinary in JS)");
4333
+ assert(typeof Module2["setWindowTitle"] == "undefined", "Module.setWindowTitle option was removed (modify emscripten_set_window_title in JS)");
4334
+ assert(typeof Module2["TOTAL_MEMORY"] == "undefined", "Module.TOTAL_MEMORY has been renamed Module.INITIAL_MEMORY");
4335
+ assert(typeof Module2["ENVIRONMENT"] == "undefined", "Module.ENVIRONMENT has been deprecated. To force the environment, use the ENVIRONMENT compile-time option (for example, -sENVIRONMENT=web or -sENVIRONMENT=node)");
4336
+ assert(typeof Module2["STACK_SIZE"] == "undefined", "STACK_SIZE can no longer be set at runtime. Use -sSTACK_SIZE at link time");
4337
+ assert(typeof Module2["wasmMemory"] == "undefined", "Use of `wasmMemory` detected. Use -sIMPORTED_MEMORY to define wasmMemory externally");
4338
+ assert(typeof Module2["INITIAL_MEMORY"] == "undefined", "Detected runtime INITIAL_MEMORY setting. Use -sIMPORTED_MEMORY to define wasmMemory dynamically");
4339
+ if (Module2["preInit"]) {
4340
+ if (typeof Module2["preInit"] == "function") Module2["preInit"] = [Module2["preInit"]];
4341
+ while (Module2["preInit"].length > 0) {
4342
+ Module2["preInit"].shift()();
4343
+ }
4344
+ }
4345
+ consumedModuleProp("preInit");
4346
+ }
4347
+ Module2["wasmMemory"] = wasmMemory;
4348
+ Module2["ccall"] = ccall;
4349
+ Module2["cwrap"] = cwrap;
4350
+ Module2["setValue"] = setValue;
4351
+ Module2["getValue"] = getValue;
4352
+ Module2["stringToUTF8"] = stringToUTF8;
4353
+ Module2["lengthBytesUTF8"] = lengthBytesUTF8;
4354
+ Module2["writeArrayToMemory"] = writeArrayToMemory;
4355
+ var missingLibrarySymbols = ["writeI53ToI64", "writeI53ToI64Clamped", "writeI53ToI64Signaling", "writeI53ToU64Clamped", "writeI53ToU64Signaling", "readI53FromI64", "readI53FromU64", "convertI32PairToI53", "convertI32PairToI53Checked", "convertU32PairToI53", "getTempRet0", "setTempRet0", "withStackSave", "readEmAsmArgs", "jstoi_q", "autoResumeAudioContext", "getDynCaller", "dynCall", "runtimeKeepalivePush", "runtimeKeepalivePop", "asmjsMangle", "HandleAllocator", "getNativeTypeSize", "addOnInit", "addOnPostCtor", "addOnPreMain", "addOnExit", "STACK_SIZE", "STACK_ALIGN", "POINTER_SIZE", "ASSERTIONS", "convertJsFunctionToWasm", "getEmptyTableSlot", "updateTableMap", "getFunctionAddress", "addFunction", "removeFunction", "intArrayToString", "AsciiToString", "stringToAscii", "UTF16ToString", "stringToUTF16", "lengthBytesUTF16", "UTF32ToString", "stringToUTF32", "lengthBytesUTF32", "stringToNewUTF8", "registerKeyEventCallback", "maybeCStringToJsString", "findEventTarget", "getBoundingClientRect", "fillMouseEventData", "registerMouseEventCallback", "registerWheelEventCallback", "registerUiEventCallback", "registerFocusEventCallback", "fillDeviceOrientationEventData", "registerDeviceOrientationEventCallback", "fillDeviceMotionEventData", "registerDeviceMotionEventCallback", "screenOrientation", "fillOrientationChangeEventData", "registerOrientationChangeEventCallback", "fillFullscreenChangeEventData", "registerFullscreenChangeEventCallback", "JSEvents_requestFullscreen", "JSEvents_resizeCanvasForFullscreen", "registerRestoreOldStyle", "hideEverythingExceptGivenElement", "restoreHiddenElements", "setLetterbox", "softFullscreenResizeWebGLRenderTarget", "doRequestFullscreen", "fillPointerlockChangeEventData", "registerPointerlockChangeEventCallback", "registerPointerlockErrorEventCallback", "requestPointerLock", "fillVisibilityChangeEventData", "registerVisibilityChangeEventCallback", "registerTouchEventCallback", "fillGamepadEventData", "registerGamepadEventCallback", "registerBeforeUnloadEventCallback", "fillBatteryEventData", "registerBatteryEventCallback", "setCanvasElementSize", "getCanvasElementSize", "jsStackTrace", "getCallstack", "convertPCtoSourceLocation", "wasiRightsToMuslOFlags", "wasiOFlagsToMuslOFlags", "safeSetTimeout", "setImmediateWrapped", "safeRequestAnimationFrame", "clearImmediateWrapped", "registerPostMainLoop", "registerPreMainLoop", "getPromise", "makePromise", "idsToPromises", "makePromiseCallback", "ExceptionInfo", "findMatchingCatch", "Browser_asyncPrepareDataCounter", "arraySum", "addDays", "FS_mkdirTree", "_setNetworkCallback", "heapObjectForWebGLType", "toTypedArrayIndex", "webgl_enable_ANGLE_instanced_arrays", "webgl_enable_OES_vertex_array_object", "webgl_enable_WEBGL_draw_buffers", "webgl_enable_WEBGL_multi_draw", "webgl_enable_EXT_polygon_offset_clamp", "webgl_enable_EXT_clip_control", "webgl_enable_WEBGL_polygon_mode", "emscriptenWebGLGet", "computeUnpackAlignedImageSize", "colorChannelsInGlTextureFormat", "emscriptenWebGLGetTexPixelData", "emscriptenWebGLGetUniform", "webglGetUniformLocation", "webglPrepareUniformLocationsBeforeFirstUse", "webglGetLeftBracePos", "emscriptenWebGLGetVertexAttrib", "__glGetActiveAttribOrUniform", "writeGLArray", "registerWebGlEventCallback", "runAndAbortIfError", "ALLOC_NORMAL", "ALLOC_STACK", "allocate", "writeStringToMemory", "writeAsciiToMemory", "demangle", "stackTrace"];
4356
+ missingLibrarySymbols.forEach(missingLibrarySymbol);
4357
+ var unexportedSymbols = ["run", "out", "err", "callMain", "abort", "wasmExports", "HEAPF32", "HEAPF64", "HEAP16", "HEAPU16", "HEAP32", "HEAPU32", "HEAP64", "HEAPU64", "writeStackCookie", "checkStackCookie", "INT53_MAX", "INT53_MIN", "bigintToI53Checked", "stackSave", "stackRestore", "stackAlloc", "ptrToString", "zeroMemory", "exitJS", "getHeapMax", "growMemory", "ENV", "ERRNO_CODES", "strError", "inetPton4", "inetNtop4", "inetPton6", "inetNtop6", "readSockaddr", "writeSockaddr", "DNS", "Protocols", "Sockets", "timers", "warnOnce", "readEmAsmArgsArray", "getExecutableName", "handleException", "keepRuntimeAlive", "callUserCallback", "maybeExit", "asyncLoad", "alignMemory", "mmapAlloc", "wasmTable", "getUniqueRunDependency", "noExitRuntime", "addRunDependency", "removeRunDependency", "addOnPreRun", "addOnPostRun", "freeTableIndexes", "functionsInTableMap", "PATH", "PATH_FS", "UTF8Decoder", "UTF8ArrayToString", "UTF8ToString", "stringToUTF8Array", "intArrayFromString", "UTF16Decoder", "stringToUTF8OnStack", "JSEvents", "specialHTMLTargets", "findCanvasEventTarget", "currentFullscreenStrategy", "restoreOldWindowedStyle", "UNWIND_CACHE", "ExitStatus", "getEnvStrings", "checkWasiClock", "doReadv", "doWritev", "initRandomFill", "randomFill", "emSetImmediate", "emClearImmediate_deps", "emClearImmediate", "promiseMap", "uncaughtExceptionCount", "exceptionLast", "exceptionCaught", "Browser", "requestFullscreen", "requestFullScreen", "setCanvasSize", "getUserMedia", "createContext", "getPreloadedImageData__data", "wget", "MONTH_DAYS_REGULAR", "MONTH_DAYS_LEAP", "MONTH_DAYS_REGULAR_CUMULATIVE", "MONTH_DAYS_LEAP_CUMULATIVE", "isLeapYear", "ydayFromDate", "SYSCALLS", "getSocketFromFD", "getSocketAddress", "preloadPlugins", "FS_createPreloadedFile", "FS_preloadFile", "FS_modeStringToFlags", "FS_getMode", "FS_stdin_getChar_buffer", "FS_stdin_getChar", "FS_unlink", "FS_createPath", "FS_createDevice", "FS_readFile", "FS", "FS_root", "FS_mounts", "FS_devices", "FS_streams", "FS_nextInode", "FS_nameTable", "FS_currentPath", "FS_initialized", "FS_ignorePermissions", "FS_filesystems", "FS_syncFSRequests", "FS_readFiles", "FS_lookupPath", "FS_getPath", "FS_hashName", "FS_hashAddNode", "FS_hashRemoveNode", "FS_lookupNode", "FS_createNode", "FS_destroyNode", "FS_isRoot", "FS_isMountpoint", "FS_isFile", "FS_isDir", "FS_isLink", "FS_isChrdev", "FS_isBlkdev", "FS_isFIFO", "FS_isSocket", "FS_flagsToPermissionString", "FS_nodePermissions", "FS_mayLookup", "FS_mayCreate", "FS_mayDelete", "FS_mayOpen", "FS_checkOpExists", "FS_nextfd", "FS_getStreamChecked", "FS_getStream", "FS_createStream", "FS_closeStream", "FS_dupStream", "FS_doSetAttr", "FS_chrdev_stream_ops", "FS_major", "FS_minor", "FS_makedev", "FS_registerDevice", "FS_getDevice", "FS_getMounts", "FS_syncfs", "FS_mount", "FS_unmount", "FS_lookup", "FS_mknod", "FS_statfs", "FS_statfsStream", "FS_statfsNode", "FS_create", "FS_mkdir", "FS_mkdev", "FS_symlink", "FS_rename", "FS_rmdir", "FS_readdir", "FS_readlink", "FS_stat", "FS_fstat", "FS_lstat", "FS_doChmod", "FS_chmod", "FS_lchmod", "FS_fchmod", "FS_doChown", "FS_chown", "FS_lchown", "FS_fchown", "FS_doTruncate", "FS_truncate", "FS_ftruncate", "FS_utime", "FS_open", "FS_close", "FS_isClosed", "FS_llseek", "FS_read", "FS_write", "FS_mmap", "FS_msync", "FS_ioctl", "FS_writeFile", "FS_cwd", "FS_chdir", "FS_createDefaultDirectories", "FS_createDefaultDevices", "FS_createSpecialDirectories", "FS_createStandardStreams", "FS_staticInit", "FS_init", "FS_quit", "FS_findObject", "FS_analyzePath", "FS_createFile", "FS_createDataFile", "FS_forceLoadFile", "FS_createLazyFile", "FS_absolutePath", "FS_createFolder", "FS_createLink", "FS_joinPath", "FS_mmapAlloc", "FS_standardizePath", "MEMFS", "TTY", "PIPEFS", "SOCKFS", "tempFixedLengthArray", "miniTempWebGLFloatBuffers", "miniTempWebGLIntBuffers", "GL", "AL", "GLUT", "EGL", "GLEW", "IDBStore", "SDL", "SDL_gfx", "allocateUTF8", "allocateUTF8OnStack", "print", "printErr", "jstoi_s"];
4358
+ unexportedSymbols.forEach(unexportedRuntimeSymbol);
4359
+ function checkIncomingModuleAPI() {
4360
+ ignoredModuleProp("fetchSettings");
4361
+ }
4362
+ var _strerror = makeInvalidEarlyAccess("_strerror");
4363
+ var _ntohs = makeInvalidEarlyAccess("_ntohs");
4364
+ var _fflush = makeInvalidEarlyAccess("_fflush");
4365
+ Module2["_free"] = makeInvalidEarlyAccess("_free");
4366
+ var _malloc = Module2["_malloc"] = makeInvalidEarlyAccess("_malloc");
4367
+ var _htonl = makeInvalidEarlyAccess("_htonl");
4368
+ var _htons = makeInvalidEarlyAccess("_htons");
4369
+ Module2["_redis_init"] = makeInvalidEarlyAccess("_redis_init");
4370
+ Module2["_redis_exec"] = makeInvalidEarlyAccess("_redis_exec");
4371
+ Module2["_redis_free"] = makeInvalidEarlyAccess("_redis_free");
4372
+ Module2["_redis_create_handle"] = makeInvalidEarlyAccess("_redis_create_handle");
4373
+ Module2["_redis_client_feed"] = makeInvalidEarlyAccess("_redis_client_feed");
4374
+ Module2["_redis_client_read"] = makeInvalidEarlyAccess("_redis_client_read");
4375
+ Module2["_redis_client_free"] = makeInvalidEarlyAccess("_redis_client_free");
4376
+ Module2["_redis_client_wants_close"] = makeInvalidEarlyAccess("_redis_client_wants_close");
4377
+ var _emscripten_stack_get_end = makeInvalidEarlyAccess("_emscripten_stack_get_end");
4378
+ var _emscripten_builtin_memalign = makeInvalidEarlyAccess("_emscripten_builtin_memalign");
4379
+ var __emscripten_timeout = makeInvalidEarlyAccess("__emscripten_timeout");
4380
+ var _setThrew = makeInvalidEarlyAccess("_setThrew");
4381
+ var _emscripten_stack_init = makeInvalidEarlyAccess("_emscripten_stack_init");
4382
+ var __emscripten_stack_restore = makeInvalidEarlyAccess("__emscripten_stack_restore");
4383
+ var __emscripten_stack_alloc = makeInvalidEarlyAccess("__emscripten_stack_alloc");
4384
+ var _emscripten_stack_get_current = makeInvalidEarlyAccess("_emscripten_stack_get_current");
4385
+ function assignWasmExports(wasmExports2) {
4386
+ _strerror = createExportWrapper("strerror", 1);
4387
+ _ntohs = createExportWrapper("ntohs", 1);
4388
+ _fflush = createExportWrapper("fflush", 1);
4389
+ Module2["_free"] = createExportWrapper("free", 1);
4390
+ Module2["_malloc"] = _malloc = createExportWrapper("malloc", 1);
4391
+ _htonl = createExportWrapper("htonl", 1);
4392
+ _htons = createExportWrapper("htons", 1);
4393
+ Module2["_redis_init"] = createExportWrapper("redis_init", 1);
4394
+ Module2["_redis_exec"] = createExportWrapper("redis_exec", 4);
4395
+ Module2["_redis_free"] = createExportWrapper("redis_free", 2);
4396
+ Module2["_redis_create_handle"] = createExportWrapper("redis_create_handle", 0);
4397
+ Module2["_redis_client_feed"] = createExportWrapper("redis_client_feed", 3);
4398
+ Module2["_redis_client_read"] = createExportWrapper("redis_client_read", 3);
4399
+ Module2["_redis_client_free"] = createExportWrapper("redis_client_free", 1);
4400
+ Module2["_redis_client_wants_close"] = createExportWrapper("redis_client_wants_close", 1);
4401
+ _emscripten_stack_get_end = wasmExports2["emscripten_stack_get_end"];
4402
+ wasmExports2["emscripten_stack_get_base"];
4403
+ _emscripten_builtin_memalign = createExportWrapper("emscripten_builtin_memalign", 2);
4404
+ __emscripten_timeout = createExportWrapper("_emscripten_timeout", 2);
4405
+ _setThrew = createExportWrapper("setThrew", 2);
4406
+ _emscripten_stack_init = wasmExports2["emscripten_stack_init"];
4407
+ wasmExports2["emscripten_stack_get_free"];
4408
+ __emscripten_stack_restore = wasmExports2["_emscripten_stack_restore"];
4409
+ __emscripten_stack_alloc = wasmExports2["_emscripten_stack_alloc"];
4410
+ _emscripten_stack_get_current = wasmExports2["emscripten_stack_get_current"];
4411
+ }
4412
+ var wasmImports = { __assert_fail: ___assert_fail, __call_sighandler: ___call_sighandler, __syscall__newselect: ___syscall__newselect, __syscall_accept4: ___syscall_accept4, __syscall_bind: ___syscall_bind, __syscall_chdir: ___syscall_chdir, __syscall_chmod: ___syscall_chmod, __syscall_connect: ___syscall_connect, __syscall_dup: ___syscall_dup, __syscall_dup3: ___syscall_dup3, __syscall_faccessat: ___syscall_faccessat, __syscall_fchmod: ___syscall_fchmod, __syscall_fcntl64: ___syscall_fcntl64, __syscall_fstat64: ___syscall_fstat64, __syscall_ftruncate64: ___syscall_ftruncate64, __syscall_getcwd: ___syscall_getcwd, __syscall_getdents64: ___syscall_getdents64, __syscall_getpeername: ___syscall_getpeername, __syscall_getsockname: ___syscall_getsockname, __syscall_getsockopt: ___syscall_getsockopt, __syscall_ioctl: ___syscall_ioctl, __syscall_listen: ___syscall_listen, __syscall_lstat64: ___syscall_lstat64, __syscall_mkdirat: ___syscall_mkdirat, __syscall_newfstatat: ___syscall_newfstatat, __syscall_openat: ___syscall_openat, __syscall_pipe: ___syscall_pipe, __syscall_poll: ___syscall_poll, __syscall_recvfrom: ___syscall_recvfrom, __syscall_renameat: ___syscall_renameat, __syscall_sendto: ___syscall_sendto, __syscall_socket: ___syscall_socket, __syscall_stat64: ___syscall_stat64, __syscall_truncate64: ___syscall_truncate64, __syscall_unlinkat: ___syscall_unlinkat, _abort_js: __abort_js, _emscripten_runtime_keepalive_clear: __emscripten_runtime_keepalive_clear, _emscripten_throw_longjmp: __emscripten_throw_longjmp, _gmtime_js: __gmtime_js, _localtime_js: __localtime_js, _mmap_js: __mmap_js, _setitimer_js: __setitimer_js, _tzset_js: __tzset_js, addCommandToBatch: _addCommandToBatch, clock_time_get: _clock_time_get, determinePrefetchCount: _determinePrefetchCount, emscripten_date_now: _emscripten_date_now, emscripten_err: _emscripten_err, emscripten_get_heap_max: _emscripten_get_heap_max, emscripten_get_now: _emscripten_get_now, emscripten_resize_heap: _emscripten_resize_heap, environ_get: _environ_get, environ_sizes_get: _environ_sizes_get, exit: _exit, fd_close: _fd_close, fd_fdstat_get: _fd_fdstat_get, fd_read: _fd_read, fd_seek: _fd_seek, fd_sync: _fd_sync, fd_write: _fd_write, getaddrinfo: _getaddrinfo, invoke_vii, lolwutCommand: _lolwutCommand, prefetchCommands: _prefetchCommands, prefetchCommandsBatchInit: _prefetchCommandsBatchInit, proc_exit: _proc_exit, rdbCheckError: _rdbCheckError, redis_check_aof_main: _redis_check_aof_main, redis_check_rdb_main: _redis_check_rdb_main, resetCommandsBatch: _resetCommandsBatch };
4413
+ function invoke_vii(index, a1, a2) {
4414
+ var sp = stackSave();
4415
+ try {
4416
+ getWasmTableEntry(index)(a1, a2);
4417
+ } catch (e) {
4418
+ stackRestore(sp);
4419
+ if (e !== e + 0) throw e;
4420
+ _setThrew(1, 0);
4421
+ }
4422
+ }
4423
+ var calledRun;
4424
+ function stackCheckInit() {
4425
+ _emscripten_stack_init();
4426
+ writeStackCookie();
4427
+ }
4428
+ function run(args = arguments_) {
4429
+ if (runDependencies > 0) {
4430
+ dependenciesFulfilled = run;
4431
+ return;
4432
+ }
4433
+ stackCheckInit();
4434
+ preRun();
4435
+ if (runDependencies > 0) {
4436
+ dependenciesFulfilled = run;
4437
+ return;
4438
+ }
4439
+ function doRun() {
4440
+ assert(!calledRun);
4441
+ calledRun = true;
4442
+ Module2["calledRun"] = true;
4443
+ if (ABORT) return;
4444
+ initRuntime();
4445
+ readyPromiseResolve?.(Module2);
4446
+ Module2["onRuntimeInitialized"]?.();
4447
+ consumedModuleProp("onRuntimeInitialized");
4448
+ assert(!Module2["_main"], 'compiled without a main, but one is present. if you added it from JS, use Module["onRuntimeInitialized"]');
4449
+ postRun();
4450
+ }
4451
+ if (Module2["setStatus"]) {
4452
+ Module2["setStatus"]("Running...");
4453
+ setTimeout(() => {
4454
+ setTimeout(() => Module2["setStatus"](""), 1);
4455
+ doRun();
4456
+ }, 1);
4457
+ } else {
4458
+ doRun();
4459
+ }
4460
+ checkStackCookie();
4461
+ }
4462
+ function checkUnflushedContent() {
4463
+ var oldOut = out;
4464
+ var oldErr = err;
4465
+ var has = false;
4466
+ out = err = (x) => {
4467
+ has = true;
4468
+ };
4469
+ try {
4470
+ _fflush(0);
4471
+ ["stdout", "stderr"].forEach((name) => {
4472
+ var info = FS.analyzePath("/dev/" + name);
4473
+ if (!info) return;
4474
+ var stream = info.object;
4475
+ var rdev = stream.rdev;
4476
+ var tty = TTY.ttys[rdev];
4477
+ if (tty?.output?.length) {
4478
+ has = true;
4479
+ }
4480
+ });
4481
+ } catch (e) {
4482
+ }
4483
+ out = oldOut;
4484
+ err = oldErr;
4485
+ if (has) {
4486
+ warnOnce("stdio streams had content in them that was not flushed. you should set EXIT_RUNTIME to 1 (see the Emscripten FAQ), or make sure to emit a newline when you printf etc.");
4487
+ }
4488
+ }
4489
+ var wasmExports;
4490
+ wasmExports = await createWasm();
4491
+ run();
4492
+ if (runtimeInitialized) {
4493
+ moduleRtn = Module2;
4494
+ } else {
4495
+ moduleRtn = new Promise((resolve, reject) => {
4496
+ readyPromiseResolve = resolve;
4497
+ readyPromiseReject = reject;
4498
+ });
4499
+ }
4500
+ for (const prop of Object.keys(Module2)) {
4501
+ if (!(prop in moduleArg)) {
4502
+ Object.defineProperty(moduleArg, prop, { configurable: true, get() {
4503
+ abort(`Access to module property ('${prop}') is no longer possible via the module constructor argument; Instead, use the result of the module constructor.`);
4504
+ } });
4505
+ }
4506
+ }
4507
+ return moduleRtn;
4508
+ }
4509
+ var redis_default = Module;
4510
+
4511
+ // src/wadisServer.ts
4512
+ var WadisServer = class _WadisServer {
4513
+ constructor(_opts = {}) {
4514
+ this._opts = _opts;
4515
+ }
4516
+ Module = null;
4517
+ _clientHandle = null;
4518
+ static async new(opts = { loglevel: "warning" }) {
4519
+ const server = new _WadisServer(opts);
4520
+ await server.start();
4521
+ return server;
4522
+ }
4523
+ async start() {
4524
+ this.Module = await redis_default({ noInitialRun: true });
4525
+ const init = this.Module.cwrap("redis_init", "number", ["number"]);
4526
+ const rc = init(this.loglevelToInt(this._opts.loglevel ?? "warning"));
4527
+ if (rc !== 0) throw new Error(`redis_init failed: ${rc}`);
4528
+ this._clientHandle = this._createHandle();
4529
+ if (this._opts.maxmemory !== void 0) {
4530
+ const val = typeof this._opts.maxmemory === "number" ? String(this._opts.maxmemory) : this._opts.maxmemory;
4531
+ await this.call("CONFIG", "SET", "maxmemory", val);
4532
+ }
4533
+ if (this._opts.maxmemoryPolicy) {
4534
+ await this.call(
4535
+ "CONFIG",
4536
+ "SET",
4537
+ "maxmemory-policy",
4538
+ this._opts.maxmemoryPolicy
4539
+ );
4540
+ }
4541
+ if (this._opts.loglevel) {
4542
+ await this.call("CONFIG", "SET", "loglevel", this._opts.loglevel);
4543
+ }
4544
+ }
4545
+ // Minimal RESP encoder for array of bulk strings: *N\r\n$len\r\nfoo\r\n...
4546
+ encodeCommand(parts) {
4547
+ const chunks = [];
4548
+ chunks.push(Buffer.from(`*${parts.length}\r
4549
+ `));
4550
+ for (const p of parts) {
4551
+ const b = Buffer.isBuffer(p) ? p : Buffer.from(p);
4552
+ chunks.push(Buffer.from(`$${b.length}\r
4553
+ `));
4554
+ chunks.push(b);
4555
+ chunks.push(Buffer.from(`\r
4556
+ `));
4557
+ }
4558
+ return Buffer.concat(chunks);
4559
+ }
4560
+ async call(...parts) {
4561
+ if (!this.Module) throw new Error("WASM not started");
4562
+ if (!this._clientHandle) this._clientHandle = this._createHandle();
4563
+ const input = this.encodeCommand(parts);
4564
+ this._clientFeed(this._clientHandle, input);
4565
+ const out = this._clientRead(this._clientHandle);
4566
+ return out ?? new Uint8Array(0);
4567
+ }
4568
+ _createHandle() {
4569
+ if (!this.Module) throw new Error("WASM not started");
4570
+ const mod = this.Module;
4571
+ const fn = mod.cwrap("redis_create_handle", "number", []);
4572
+ const h = fn();
4573
+ if (!h) throw new Error("redis_create_handle failed");
4574
+ return h;
4575
+ }
4576
+ _clientFeed(handle, data) {
4577
+ if (!this.Module) throw new Error("WASM not started");
4578
+ const mod = this.Module;
4579
+ const feed = mod.cwrap("redis_client_feed", "number", [
4580
+ "number",
4581
+ "number",
4582
+ "number"
4583
+ ]);
4584
+ const malloc = mod._malloc;
4585
+ const free = mod._free;
4586
+ const input = Buffer.isBuffer(data) ? data : Buffer.from(data);
4587
+ const inPtr = malloc(input.length);
4588
+ if (typeof mod.writeArrayToMemory === "function") {
4589
+ mod.writeArrayToMemory(input, inPtr);
4590
+ } else if (typeof mod.setValue === "function") {
4591
+ for (let i = 0; i < input.length; i++)
4592
+ mod.setValue(inPtr + i, input[i], "i8");
4593
+ } else {
4594
+ throw new Error(
4595
+ "Emscripten runtime missing writeArrayToMemory/setValue"
4596
+ );
4597
+ }
4598
+ const rc = feed(handle, inPtr, input.length);
4599
+ free(inPtr);
4600
+ if (rc !== 0) throw new Error(`redis_client_feed failed: ${rc}`);
4601
+ }
4602
+ _clientRead(handle) {
4603
+ if (!this.Module) throw new Error("WASM not started");
4604
+ const mod = this.Module;
4605
+ const malloc = mod._malloc;
4606
+ const free = mod._free;
4607
+ const read = mod.cwrap("redis_client_read", "number", [
4608
+ "number",
4609
+ "number",
4610
+ "number"
4611
+ ]);
4612
+ const freeOut = mod.cwrap("redis_free", "void", ["number", "number"]);
4613
+ const outPtrPtr = malloc(4);
4614
+ const outLenPtr = malloc(4);
4615
+ const rc = read(handle, outPtrPtr, outLenPtr);
4616
+ if (rc !== 0) {
4617
+ free(outPtrPtr);
4618
+ free(outLenPtr);
4619
+ throw new Error(`redis_client_read failed: ${rc}`);
4620
+ }
4621
+ const outPtr = mod.getValue(outPtrPtr, "i32");
4622
+ const outLen = mod.getValue(outLenPtr, "i32");
4623
+ free(outPtrPtr);
4624
+ free(outLenPtr);
4625
+ if (!outPtr || outLen === 0) return null;
4626
+ const out = new Uint8Array(outLen);
4627
+ for (let i = 0; i < outLen; i++)
4628
+ out[i] = mod.getValue(outPtr + i, "i8");
4629
+ freeOut(outPtr, outLen);
4630
+ return out;
4631
+ }
4632
+ _clientFree(handle) {
4633
+ if (!this.Module) return;
4634
+ const mod = this.Module;
4635
+ const fn = mod.cwrap("redis_client_free", "void", ["number"]);
4636
+ fn(handle);
4637
+ }
4638
+ _clientWantsClose(handle) {
4639
+ if (!this.Module) return false;
4640
+ const mod = this.Module;
4641
+ const fn = mod.cwrap("redis_client_wants_close", "number", [
4642
+ "number"
4643
+ ]);
4644
+ return fn(handle) !== 0;
4645
+ }
4646
+ createConnection() {
4647
+ if (!this.Module) throw new Error("WASM not started");
4648
+ const handle = this._createHandle();
4649
+ return {
4650
+ write: (data) => this._clientFeed(handle, data),
4651
+ read: () => this._clientRead(handle),
4652
+ wantsClose: () => this._clientWantsClose(handle),
4653
+ close: () => this._clientFree(handle)
4654
+ };
4655
+ }
4656
+ async terminate() {
4657
+ if (this._clientHandle !== null) {
4658
+ this._clientFree(this._clientHandle);
4659
+ }
4660
+ this.Module = null;
4661
+ this._clientHandle = null;
4662
+ }
4663
+ loglevelToInt(level) {
4664
+ const s = level.toLowerCase();
4665
+ if (s === "debug") return 0;
4666
+ if (s === "verbose") return 1;
4667
+ if (s === "notice") return 2;
4668
+ return 3;
4669
+ }
4670
+ };
4671
+ var WadisServerConnector = class extends net.Socket {
4672
+ conn;
4673
+ poll;
4674
+ _closed = false;
4675
+ queue = Promise.resolve();
4676
+ constructor(server) {
4677
+ super();
4678
+ this.conn = server.createConnection();
4679
+ this.startPolling();
4680
+ setImmediate(() => this.emit("connect"));
4681
+ }
4682
+ setTimeout(_msecs, _callback) {
4683
+ return this;
4684
+ }
4685
+ setNoDelay(_noDelay) {
4686
+ return this;
4687
+ }
4688
+ setKeepAlive(_enable, _initialDelay) {
4689
+ return this;
4690
+ }
4691
+ write(chunk, encoding, cb) {
4692
+ let callback;
4693
+ let enc;
4694
+ if (typeof encoding === "function") {
4695
+ callback = encoding;
4696
+ } else {
4697
+ enc = encoding;
4698
+ callback = cb;
4699
+ }
4700
+ const buf = typeof chunk === "string" ? Buffer.from(chunk, enc ?? "utf8") : Buffer.from(chunk);
4701
+ this.queue = this.queue.then(
4702
+ () => new Promise((resolve) => {
4703
+ setImmediate(() => {
4704
+ try {
4705
+ this.conn.write(buf);
4706
+ } catch (err) {
4707
+ this.emit("error", err);
4708
+ } finally {
4709
+ resolve();
4710
+ }
4711
+ });
4712
+ })
4713
+ );
4714
+ if (callback) setImmediate(() => callback());
4715
+ return true;
4716
+ }
4717
+ end(..._args) {
4718
+ if (this._closed) return this;
4719
+ this._closed = true;
4720
+ if (this.poll) {
4721
+ clearInterval(this.poll);
4722
+ this.poll = void 0;
4723
+ }
4724
+ this.conn.close();
4725
+ setImmediate(() => this.emit("end"));
4726
+ setImmediate(() => this.emit("close", false));
4727
+ return this;
4728
+ }
4729
+ destroy(_error) {
4730
+ if (this._closed) return this;
4731
+ this._closed = true;
4732
+ if (this.poll) {
4733
+ clearInterval(this.poll);
4734
+ this.poll = void 0;
4735
+ }
4736
+ this.conn.close();
4737
+ setImmediate(() => this.emit("close", true));
4738
+ return this;
4739
+ }
4740
+ startPolling() {
4741
+ this.poll = setInterval(() => this.drain(), 10);
4742
+ this.poll.unref?.();
4743
+ }
4744
+ drain() {
4745
+ while (true) {
4746
+ const out = this.conn.read();
4747
+ if (!out || out.length === 0) break;
4748
+ this.emit("data", Buffer.from(out));
4749
+ }
4750
+ if (!this._closed && this.conn.wantsClose()) {
4751
+ this.end();
4752
+ }
4753
+ }
4754
+ };
4755
+ var Wadis = class extends Redis__default.default {
4756
+ constructor({ server, ...options } = {}) {
4757
+ const wasmServer = server ?? WadisServer.new();
4758
+ class Connector extends Redis.AbstractConnector {
4759
+ constructor(something) {
4760
+ super(something);
4761
+ }
4762
+ async connect(_) {
4763
+ return new WadisServerConnector(await wasmServer);
4764
+ }
4765
+ }
4766
+ super({ Connector, maxRetriesPerRequest: null, ...options });
4767
+ }
4768
+ };
4769
+
4770
+ exports.Wadis = Wadis;
4771
+ exports.WadisServer = WadisServer;