@keymanapp/kmc-kmn 17.0.85-alpha

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.
@@ -0,0 +1,1898 @@
1
+ var Module = (() => {
2
+ var _scriptDir = import.meta.url;
3
+ return (async function (Module = {}) {
4
+ var Module = typeof Module != "undefined" ? Module : {};
5
+ var readyPromiseResolve, readyPromiseReject;
6
+ Module["ready"] = new Promise(function (resolve, reject) { readyPromiseResolve = resolve; readyPromiseReject = reject; });
7
+ var moduleOverrides = Object.assign({}, Module);
8
+ var arguments_ = [];
9
+ var thisProgram = "./this.program";
10
+ var quit_ = (status, toThrow) => { throw toThrow; };
11
+ var ENVIRONMENT_IS_WEB = typeof window == "object";
12
+ var ENVIRONMENT_IS_WORKER = typeof importScripts == "function";
13
+ var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string";
14
+ var scriptDirectory = "";
15
+ function locateFile(path) { if (Module["locateFile"]) {
16
+ return Module["locateFile"](path, scriptDirectory);
17
+ } return scriptDirectory + path; }
18
+ var read_, readAsync, readBinary, setWindowTitle;
19
+ if (ENVIRONMENT_IS_NODE) {
20
+ const { createRequire: createRequire } = await import("module");
21
+ var require = createRequire(import.meta.url);
22
+ var fs = require("fs");
23
+ var nodePath = require("path");
24
+ if (ENVIRONMENT_IS_WORKER) {
25
+ scriptDirectory = nodePath.dirname(scriptDirectory) + "/";
26
+ }
27
+ else {
28
+ scriptDirectory = require("url").fileURLToPath(new URL("./", import.meta.url));
29
+ }
30
+ read_ = (filename, binary) => { filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename); return fs.readFileSync(filename, binary ? undefined : "utf8"); };
31
+ readBinary = filename => { var ret = read_(filename, true); if (!ret.buffer) {
32
+ ret = new Uint8Array(ret);
33
+ } return ret; };
34
+ readAsync = (filename, onload, onerror) => { filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename); fs.readFile(filename, function (err, data) { if (err)
35
+ onerror(err);
36
+ else
37
+ onload(data.buffer); }); };
38
+ if (process.argv.length > 1) {
39
+ thisProgram = process.argv[1].replace(/\\/g, "/");
40
+ }
41
+ arguments_ = process.argv.slice(2);
42
+ process.on("uncaughtException", function (ex) { if (ex !== "unwind" && !(ex instanceof ExitStatus) && !(ex.context instanceof ExitStatus)) {
43
+ throw ex;
44
+ } });
45
+ var nodeMajor = process.versions.node.split(".")[0];
46
+ if (nodeMajor < 15) {
47
+ process.on("unhandledRejection", function (reason) { throw reason; });
48
+ }
49
+ quit_ = (status, toThrow) => { process.exitCode = status; throw toThrow; };
50
+ Module["inspect"] = function () { return "[Emscripten Module object]"; };
51
+ }
52
+ else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
53
+ if (ENVIRONMENT_IS_WORKER) {
54
+ scriptDirectory = self.location.href;
55
+ }
56
+ else if (typeof document != "undefined" && document.currentScript) {
57
+ scriptDirectory = document.currentScript.src;
58
+ }
59
+ if (_scriptDir) {
60
+ scriptDirectory = _scriptDir;
61
+ }
62
+ if (scriptDirectory.indexOf("blob:") !== 0) {
63
+ scriptDirectory = scriptDirectory.substr(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1);
64
+ }
65
+ else {
66
+ scriptDirectory = "";
67
+ }
68
+ {
69
+ read_ = url => { var xhr = new XMLHttpRequest; xhr.open("GET", url, false); xhr.send(null); return xhr.responseText; };
70
+ if (ENVIRONMENT_IS_WORKER) {
71
+ readBinary = url => { var xhr = new XMLHttpRequest; xhr.open("GET", url, false); xhr.responseType = "arraybuffer"; xhr.send(null); return new Uint8Array(xhr.response); };
72
+ }
73
+ readAsync = (url, onload, onerror) => { var xhr = new XMLHttpRequest; xhr.open("GET", url, true); xhr.responseType = "arraybuffer"; xhr.onload = () => { if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
74
+ onload(xhr.response);
75
+ return;
76
+ } onerror(); }; xhr.onerror = onerror; xhr.send(null); };
77
+ }
78
+ setWindowTitle = title => document.title = title;
79
+ }
80
+ else { }
81
+ var out = Module["print"] || console.log.bind(console);
82
+ var err = Module["printErr"] || console.warn.bind(console);
83
+ Object.assign(Module, moduleOverrides);
84
+ moduleOverrides = null;
85
+ if (Module["arguments"])
86
+ arguments_ = Module["arguments"];
87
+ if (Module["thisProgram"])
88
+ thisProgram = Module["thisProgram"];
89
+ if (Module["quit"])
90
+ quit_ = Module["quit"];
91
+ var wasmBinary;
92
+ if (Module["wasmBinary"])
93
+ wasmBinary = Module["wasmBinary"];
94
+ var noExitRuntime = Module["noExitRuntime"] || true;
95
+ if (typeof WebAssembly != "object") {
96
+ abort("no native wasm support detected");
97
+ }
98
+ var wasmMemory;
99
+ var ABORT = false;
100
+ var EXITSTATUS;
101
+ function assert(condition, text) { if (!condition) {
102
+ abort(text);
103
+ } }
104
+ var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf8") : undefined;
105
+ function UTF8ArrayToString(heapOrArray, idx, maxBytesToRead) { var endIdx = idx + maxBytesToRead; var endPtr = idx; while (heapOrArray[endPtr] && !(endPtr >= endIdx))
106
+ ++endPtr; if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
107
+ return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
108
+ } var str = ""; while (idx < endPtr) {
109
+ var u0 = heapOrArray[idx++];
110
+ if (!(u0 & 128)) {
111
+ str += String.fromCharCode(u0);
112
+ continue;
113
+ }
114
+ var u1 = heapOrArray[idx++] & 63;
115
+ if ((u0 & 224) == 192) {
116
+ str += String.fromCharCode((u0 & 31) << 6 | u1);
117
+ continue;
118
+ }
119
+ var u2 = heapOrArray[idx++] & 63;
120
+ if ((u0 & 240) == 224) {
121
+ u0 = (u0 & 15) << 12 | u1 << 6 | u2;
122
+ }
123
+ else {
124
+ u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
125
+ }
126
+ if (u0 < 65536) {
127
+ str += String.fromCharCode(u0);
128
+ }
129
+ else {
130
+ var ch = u0 - 65536;
131
+ str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
132
+ }
133
+ } return str; }
134
+ function UTF8ToString(ptr, maxBytesToRead) { return ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : ""; }
135
+ function stringToUTF8Array(str, heap, outIdx, maxBytesToWrite) { if (!(maxBytesToWrite > 0))
136
+ return 0; var startIdx = outIdx; var endIdx = outIdx + maxBytesToWrite - 1; for (var i = 0; i < str.length; ++i) {
137
+ var u = str.charCodeAt(i);
138
+ if (u >= 55296 && u <= 57343) {
139
+ var u1 = str.charCodeAt(++i);
140
+ u = 65536 + ((u & 1023) << 10) | u1 & 1023;
141
+ }
142
+ if (u <= 127) {
143
+ if (outIdx >= endIdx)
144
+ break;
145
+ heap[outIdx++] = u;
146
+ }
147
+ else if (u <= 2047) {
148
+ if (outIdx + 1 >= endIdx)
149
+ break;
150
+ heap[outIdx++] = 192 | u >> 6;
151
+ heap[outIdx++] = 128 | u & 63;
152
+ }
153
+ else if (u <= 65535) {
154
+ if (outIdx + 2 >= endIdx)
155
+ break;
156
+ heap[outIdx++] = 224 | u >> 12;
157
+ heap[outIdx++] = 128 | u >> 6 & 63;
158
+ heap[outIdx++] = 128 | u & 63;
159
+ }
160
+ else {
161
+ if (outIdx + 3 >= endIdx)
162
+ break;
163
+ heap[outIdx++] = 240 | u >> 18;
164
+ heap[outIdx++] = 128 | u >> 12 & 63;
165
+ heap[outIdx++] = 128 | u >> 6 & 63;
166
+ heap[outIdx++] = 128 | u & 63;
167
+ }
168
+ } heap[outIdx] = 0; return outIdx - startIdx; }
169
+ function stringToUTF8(str, outPtr, maxBytesToWrite) { return stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite); }
170
+ function lengthBytesUTF8(str) { var len = 0; for (var i = 0; i < str.length; ++i) {
171
+ var c = str.charCodeAt(i);
172
+ if (c <= 127) {
173
+ len++;
174
+ }
175
+ else if (c <= 2047) {
176
+ len += 2;
177
+ }
178
+ else if (c >= 55296 && c <= 57343) {
179
+ len += 4;
180
+ ++i;
181
+ }
182
+ else {
183
+ len += 3;
184
+ }
185
+ } return len; }
186
+ var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;
187
+ function updateMemoryViews() { var b = wasmMemory.buffer; Module["HEAP8"] = HEAP8 = new Int8Array(b); Module["HEAP16"] = HEAP16 = new Int16Array(b); Module["HEAP32"] = HEAP32 = new Int32Array(b); Module["HEAPU8"] = HEAPU8 = new Uint8Array(b); Module["HEAPU16"] = HEAPU16 = new Uint16Array(b); Module["HEAPU32"] = HEAPU32 = new Uint32Array(b); Module["HEAPF32"] = HEAPF32 = new Float32Array(b); Module["HEAPF64"] = HEAPF64 = new Float64Array(b); }
188
+ var wasmTable;
189
+ var __ATPRERUN__ = [];
190
+ var __ATINIT__ = [];
191
+ var __ATPOSTRUN__ = [];
192
+ var runtimeInitialized = false;
193
+ var runtimeKeepaliveCounter = 0;
194
+ function preRun() { if (Module["preRun"]) {
195
+ if (typeof Module["preRun"] == "function")
196
+ Module["preRun"] = [Module["preRun"]];
197
+ while (Module["preRun"].length) {
198
+ addOnPreRun(Module["preRun"].shift());
199
+ }
200
+ } callRuntimeCallbacks(__ATPRERUN__); }
201
+ function initRuntime() { runtimeInitialized = true; if (!Module["noFSInit"] && !FS.init.initialized)
202
+ FS.init(); FS.ignorePermissions = false; TTY.init(); callRuntimeCallbacks(__ATINIT__); }
203
+ function postRun() { if (Module["postRun"]) {
204
+ if (typeof Module["postRun"] == "function")
205
+ Module["postRun"] = [Module["postRun"]];
206
+ while (Module["postRun"].length) {
207
+ addOnPostRun(Module["postRun"].shift());
208
+ }
209
+ } callRuntimeCallbacks(__ATPOSTRUN__); }
210
+ function addOnPreRun(cb) { __ATPRERUN__.unshift(cb); }
211
+ function addOnInit(cb) { __ATINIT__.unshift(cb); }
212
+ function addOnPostRun(cb) { __ATPOSTRUN__.unshift(cb); }
213
+ var runDependencies = 0;
214
+ var runDependencyWatcher = null;
215
+ var dependenciesFulfilled = null;
216
+ function getUniqueRunDependency(id) { return id; }
217
+ function addRunDependency(id) { runDependencies++; if (Module["monitorRunDependencies"]) {
218
+ Module["monitorRunDependencies"](runDependencies);
219
+ } }
220
+ function removeRunDependency(id) { runDependencies--; if (Module["monitorRunDependencies"]) {
221
+ Module["monitorRunDependencies"](runDependencies);
222
+ } if (runDependencies == 0) {
223
+ if (runDependencyWatcher !== null) {
224
+ clearInterval(runDependencyWatcher);
225
+ runDependencyWatcher = null;
226
+ }
227
+ if (dependenciesFulfilled) {
228
+ var callback = dependenciesFulfilled;
229
+ dependenciesFulfilled = null;
230
+ callback();
231
+ }
232
+ } }
233
+ function abort(what) { if (Module["onAbort"]) {
234
+ Module["onAbort"](what);
235
+ } what = "Aborted(" + what + ")"; err(what); ABORT = true; EXITSTATUS = 1; what += ". Build with -sASSERTIONS for more info."; var e = new WebAssembly.RuntimeError(what); readyPromiseReject(e); throw e; }
236
+ var dataURIPrefix = "data:application/octet-stream;base64,";
237
+ function isDataURI(filename) { return filename.startsWith(dataURIPrefix); }
238
+ function isFileURI(filename) { return filename.startsWith("file://"); }
239
+ var wasmBinaryFile;
240
+ if (Module["locateFile"]) {
241
+ wasmBinaryFile = "wasm-host.wasm";
242
+ if (!isDataURI(wasmBinaryFile)) {
243
+ wasmBinaryFile = locateFile(wasmBinaryFile);
244
+ }
245
+ }
246
+ else {
247
+ wasmBinaryFile = new URL("wasm-host.wasm", import.meta.url).href;
248
+ }
249
+ function getBinary(file) { try {
250
+ if (file == wasmBinaryFile && wasmBinary) {
251
+ return new Uint8Array(wasmBinary);
252
+ }
253
+ if (readBinary) {
254
+ return readBinary(file);
255
+ }
256
+ throw "both async and sync fetching of the wasm failed";
257
+ }
258
+ catch (err) {
259
+ abort(err);
260
+ } }
261
+ function getBinaryPromise(binaryFile) { if (!wasmBinary && (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER)) {
262
+ if (typeof fetch == "function" && !isFileURI(binaryFile)) {
263
+ return fetch(binaryFile, { credentials: "same-origin" }).then(function (response) { if (!response["ok"]) {
264
+ throw "failed to load wasm binary file at '" + binaryFile + "'";
265
+ } return response["arrayBuffer"](); }).catch(function () { return getBinary(binaryFile); });
266
+ }
267
+ else {
268
+ if (readAsync) {
269
+ return new Promise(function (resolve, reject) { readAsync(binaryFile, function (response) { resolve(new Uint8Array(response)); }, reject); });
270
+ }
271
+ }
272
+ } return Promise.resolve().then(function () { return getBinary(binaryFile); }); }
273
+ function instantiateArrayBuffer(binaryFile, imports, receiver) { return getBinaryPromise(binaryFile).then(function (binary) { return WebAssembly.instantiate(binary, imports); }).then(function (instance) { return instance; }).then(receiver, function (reason) { err("failed to asynchronously prepare wasm: " + reason); abort(reason); }); }
274
+ function instantiateAsync(binary, binaryFile, imports, callback) { if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isDataURI(binaryFile) && !isFileURI(binaryFile) && !ENVIRONMENT_IS_NODE && typeof fetch == "function") {
275
+ return fetch(binaryFile, { credentials: "same-origin" }).then(function (response) { var result = WebAssembly.instantiateStreaming(response, imports); return result.then(callback, function (reason) { err("wasm streaming compile failed: " + reason); err("falling back to ArrayBuffer instantiation"); return instantiateArrayBuffer(binaryFile, imports, callback); }); });
276
+ }
277
+ else {
278
+ return instantiateArrayBuffer(binaryFile, imports, callback);
279
+ } }
280
+ function createWasm() { var info = { "env": wasmImports, "wasi_snapshot_preview1": wasmImports }; function receiveInstance(instance, module) { var exports = instance.exports; Module["asm"] = exports; wasmMemory = Module["asm"]["memory"]; updateMemoryViews(); wasmTable = Module["asm"]["__indirect_function_table"]; addOnInit(Module["asm"]["__wasm_call_ctors"]); removeRunDependency("wasm-instantiate"); return exports; } addRunDependency("wasm-instantiate"); function receiveInstantiationResult(result) { receiveInstance(result["instance"]); } if (Module["instantiateWasm"]) {
281
+ try {
282
+ return Module["instantiateWasm"](info, receiveInstance);
283
+ }
284
+ catch (e) {
285
+ err("Module.instantiateWasm callback failed with error: " + e);
286
+ readyPromiseReject(e);
287
+ }
288
+ } instantiateAsync(wasmBinary, wasmBinaryFile, info, receiveInstantiationResult).catch(readyPromiseReject); return {}; }
289
+ var tempDouble;
290
+ var tempI64;
291
+ var ASM_CONSTS = { 71619: $0 => { let path = Module.UTF8ToString($0); const isWin32Path = path.match(/^[a-zA-Z]:/); let root = "/nodefs-mount"; if (!FS.analyzePath(root).exists) {
292
+ FS.mkdir(root);
293
+ if (!isWin32Path) {
294
+ FS.mount(NODEFS, { root: "/" }, root);
295
+ }
296
+ } if (isWin32Path) {
297
+ root += "/" + path.charAt(0);
298
+ if (!FS.analyzePath(root).exists) {
299
+ FS.mkdir(root);
300
+ FS.mount(NODEFS, { root: path.substr(0, 3) }, root);
301
+ }
302
+ } } };
303
+ function wasm_msgproc(line, msgcode, text, context) { const proc = globalThis[context]; if (!proc || typeof proc != "function") {
304
+ console.log(`[${line}: ${msgcode}: ${UTF8ToString(text)}]`);
305
+ return 0;
306
+ }
307
+ else {
308
+ return proc(line, msgcode, UTF8ToString(text));
309
+ } }
310
+ function ExitStatus(status) { this.name = "ExitStatus"; this.message = "Program terminated with exit(" + status + ")"; this.status = status; }
311
+ function callRuntimeCallbacks(callbacks) { while (callbacks.length > 0) {
312
+ callbacks.shift()(Module);
313
+ } }
314
+ function ___assert_fail(condition, filename, line, func) { abort("Assertion failed: " + UTF8ToString(condition) + ", at: " + [filename ? UTF8ToString(filename) : "unknown filename", line, func ? UTF8ToString(func) : "unknown function"]); }
315
+ function ExceptionInfo(excPtr) { this.excPtr = excPtr; this.ptr = excPtr - 24; this.set_type = function (type) { HEAPU32[this.ptr + 4 >> 2] = type; }; this.get_type = function () { return HEAPU32[this.ptr + 4 >> 2]; }; this.set_destructor = function (destructor) { HEAPU32[this.ptr + 8 >> 2] = destructor; }; this.get_destructor = function () { return HEAPU32[this.ptr + 8 >> 2]; }; this.set_refcount = function (refcount) { HEAP32[this.ptr >> 2] = refcount; }; this.set_caught = function (caught) { caught = caught ? 1 : 0; HEAP8[this.ptr + 12 >> 0] = caught; }; this.get_caught = function () { return HEAP8[this.ptr + 12 >> 0] != 0; }; this.set_rethrown = function (rethrown) { rethrown = rethrown ? 1 : 0; HEAP8[this.ptr + 13 >> 0] = rethrown; }; this.get_rethrown = function () { return HEAP8[this.ptr + 13 >> 0] != 0; }; this.init = function (type, destructor) { this.set_adjusted_ptr(0); this.set_type(type); this.set_destructor(destructor); this.set_refcount(0); this.set_caught(false); this.set_rethrown(false); }; this.add_ref = function () { var value = HEAP32[this.ptr >> 2]; HEAP32[this.ptr >> 2] = value + 1; }; this.release_ref = function () { var prev = HEAP32[this.ptr >> 2]; HEAP32[this.ptr >> 2] = prev - 1; return prev === 1; }; this.set_adjusted_ptr = function (adjustedPtr) { HEAPU32[this.ptr + 16 >> 2] = adjustedPtr; }; this.get_adjusted_ptr = function () { return HEAPU32[this.ptr + 16 >> 2]; }; this.get_exception_ptr = function () { var isPointer = ___cxa_is_pointer_type(this.get_type()); if (isPointer) {
316
+ return HEAPU32[this.excPtr >> 2];
317
+ } var adjusted = this.get_adjusted_ptr(); if (adjusted !== 0)
318
+ return adjusted; return this.excPtr; }; }
319
+ var exceptionLast = 0;
320
+ var uncaughtExceptionCount = 0;
321
+ function ___cxa_throw(ptr, type, destructor) { var info = new ExceptionInfo(ptr); info.init(type, destructor); exceptionLast = ptr; uncaughtExceptionCount++; throw ptr; }
322
+ var PATH = { isAbs: path => path.charAt(0) === "/", splitPath: filename => { var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/; return splitPathRe.exec(filename).slice(1); }, normalizeArray: (parts, allowAboveRoot) => { var up = 0; for (var i = parts.length - 1; i >= 0; i--) {
323
+ var last = parts[i];
324
+ if (last === ".") {
325
+ parts.splice(i, 1);
326
+ }
327
+ else if (last === "..") {
328
+ parts.splice(i, 1);
329
+ up++;
330
+ }
331
+ else if (up) {
332
+ parts.splice(i, 1);
333
+ up--;
334
+ }
335
+ } if (allowAboveRoot) {
336
+ for (; up; up--) {
337
+ parts.unshift("..");
338
+ }
339
+ } return parts; }, normalize: path => { var isAbsolute = PATH.isAbs(path), trailingSlash = path.substr(-1) === "/"; path = PATH.normalizeArray(path.split("/").filter(p => !!p), !isAbsolute).join("/"); if (!path && !isAbsolute) {
340
+ path = ".";
341
+ } if (path && trailingSlash) {
342
+ path += "/";
343
+ } return (isAbsolute ? "/" : "") + path; }, dirname: path => { var result = PATH.splitPath(path), root = result[0], dir = result[1]; if (!root && !dir) {
344
+ return ".";
345
+ } if (dir) {
346
+ dir = dir.substr(0, dir.length - 1);
347
+ } return root + dir; }, basename: path => { if (path === "/")
348
+ return "/"; path = PATH.normalize(path); path = path.replace(/\/$/, ""); var lastSlash = path.lastIndexOf("/"); if (lastSlash === -1)
349
+ return path; return path.substr(lastSlash + 1); }, join: function () { var paths = Array.prototype.slice.call(arguments); return PATH.normalize(paths.join("/")); }, join2: (l, r) => { return PATH.normalize(l + "/" + r); } };
350
+ function getRandomDevice() { if (typeof crypto == "object" && typeof crypto["getRandomValues"] == "function") {
351
+ var randomBuffer = new Uint8Array(1);
352
+ return () => { crypto.getRandomValues(randomBuffer); return randomBuffer[0]; };
353
+ }
354
+ else if (ENVIRONMENT_IS_NODE) {
355
+ try {
356
+ var crypto_module = require("crypto");
357
+ return () => crypto_module["randomBytes"](1)[0];
358
+ }
359
+ catch (e) { }
360
+ } return () => abort("randomDevice"); }
361
+ var PATH_FS = { resolve: function () { var resolvedPath = "", resolvedAbsolute = false; for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {
362
+ var path = i >= 0 ? arguments[i] : FS.cwd();
363
+ if (typeof path != "string") {
364
+ throw new TypeError("Arguments to path.resolve must be strings");
365
+ }
366
+ else if (!path) {
367
+ return "";
368
+ }
369
+ resolvedPath = path + "/" + resolvedPath;
370
+ resolvedAbsolute = PATH.isAbs(path);
371
+ } resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter(p => !!p), !resolvedAbsolute).join("/"); return (resolvedAbsolute ? "/" : "") + resolvedPath || "."; }, relative: (from, to) => { from = PATH_FS.resolve(from).substr(1); to = PATH_FS.resolve(to).substr(1); function trim(arr) { var start = 0; for (; start < arr.length; start++) {
372
+ if (arr[start] !== "")
373
+ break;
374
+ } var end = arr.length - 1; for (; end >= 0; end--) {
375
+ if (arr[end] !== "")
376
+ break;
377
+ } if (start > end)
378
+ return []; return arr.slice(start, end - start + 1); } var fromParts = trim(from.split("/")); var toParts = trim(to.split("/")); var length = Math.min(fromParts.length, toParts.length); var samePartsLength = length; for (var i = 0; i < length; i++) {
379
+ if (fromParts[i] !== toParts[i]) {
380
+ samePartsLength = i;
381
+ break;
382
+ }
383
+ } var outputParts = []; for (var i = samePartsLength; i < fromParts.length; i++) {
384
+ outputParts.push("..");
385
+ } outputParts = outputParts.concat(toParts.slice(samePartsLength)); return outputParts.join("/"); } };
386
+ function intArrayFromString(stringy, dontAddNull, length) { var len = length > 0 ? length : lengthBytesUTF8(stringy) + 1; var u8array = new Array(len); var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length); if (dontAddNull)
387
+ u8array.length = numBytesWritten; return u8array; }
388
+ var TTY = { ttys: [], init: function () { }, shutdown: function () { }, register: function (dev, ops) { TTY.ttys[dev] = { input: [], output: [], ops: ops }; FS.registerDevice(dev, TTY.stream_ops); }, stream_ops: { open: function (stream) { var tty = TTY.ttys[stream.node.rdev]; if (!tty) {
389
+ throw new FS.ErrnoError(43);
390
+ } stream.tty = tty; stream.seekable = false; }, close: function (stream) { stream.tty.ops.fsync(stream.tty); }, fsync: function (stream) { stream.tty.ops.fsync(stream.tty); }, read: function (stream, buffer, offset, length, pos) { if (!stream.tty || !stream.tty.ops.get_char) {
391
+ throw new FS.ErrnoError(60);
392
+ } var bytesRead = 0; for (var i = 0; i < length; i++) {
393
+ var result;
394
+ try {
395
+ result = stream.tty.ops.get_char(stream.tty);
396
+ }
397
+ catch (e) {
398
+ throw new FS.ErrnoError(29);
399
+ }
400
+ if (result === undefined && bytesRead === 0) {
401
+ throw new FS.ErrnoError(6);
402
+ }
403
+ if (result === null || result === undefined)
404
+ break;
405
+ bytesRead++;
406
+ buffer[offset + i] = result;
407
+ } if (bytesRead) {
408
+ stream.node.timestamp = Date.now();
409
+ } return bytesRead; }, write: function (stream, buffer, offset, length, pos) { if (!stream.tty || !stream.tty.ops.put_char) {
410
+ throw new FS.ErrnoError(60);
411
+ } try {
412
+ for (var i = 0; i < length; i++) {
413
+ stream.tty.ops.put_char(stream.tty, buffer[offset + i]);
414
+ }
415
+ }
416
+ catch (e) {
417
+ throw new FS.ErrnoError(29);
418
+ } if (length) {
419
+ stream.node.timestamp = Date.now();
420
+ } return i; } }, default_tty_ops: { get_char: function (tty) { if (!tty.input.length) {
421
+ var result = null;
422
+ if (ENVIRONMENT_IS_NODE) {
423
+ var BUFSIZE = 256;
424
+ var buf = Buffer.alloc(BUFSIZE);
425
+ var bytesRead = 0;
426
+ try {
427
+ bytesRead = fs.readSync(process.stdin.fd, buf, 0, BUFSIZE, -1);
428
+ }
429
+ catch (e) {
430
+ if (e.toString().includes("EOF"))
431
+ bytesRead = 0;
432
+ else
433
+ throw e;
434
+ }
435
+ if (bytesRead > 0) {
436
+ result = buf.slice(0, bytesRead).toString("utf-8");
437
+ }
438
+ else {
439
+ result = null;
440
+ }
441
+ }
442
+ else if (typeof window != "undefined" && typeof window.prompt == "function") {
443
+ result = window.prompt("Input: ");
444
+ if (result !== null) {
445
+ result += "\n";
446
+ }
447
+ }
448
+ else if (typeof readline == "function") {
449
+ result = readline();
450
+ if (result !== null) {
451
+ result += "\n";
452
+ }
453
+ }
454
+ if (!result) {
455
+ return null;
456
+ }
457
+ tty.input = intArrayFromString(result, true);
458
+ } return tty.input.shift(); }, put_char: function (tty, val) { if (val === null || val === 10) {
459
+ out(UTF8ArrayToString(tty.output, 0));
460
+ tty.output = [];
461
+ }
462
+ else {
463
+ if (val != 0)
464
+ tty.output.push(val);
465
+ } }, fsync: function (tty) { if (tty.output && tty.output.length > 0) {
466
+ out(UTF8ArrayToString(tty.output, 0));
467
+ tty.output = [];
468
+ } } }, default_tty1_ops: { put_char: function (tty, val) { if (val === null || val === 10) {
469
+ err(UTF8ArrayToString(tty.output, 0));
470
+ tty.output = [];
471
+ }
472
+ else {
473
+ if (val != 0)
474
+ tty.output.push(val);
475
+ } }, fsync: function (tty) { if (tty.output && tty.output.length > 0) {
476
+ err(UTF8ArrayToString(tty.output, 0));
477
+ tty.output = [];
478
+ } } } };
479
+ function mmapAlloc(size) { abort(); }
480
+ var MEMFS = { ops_table: null, mount: function (mount) { return MEMFS.createNode(null, "/", 16384 | 511, 0); }, createNode: function (parent, name, mode, dev) { if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
481
+ throw new FS.ErrnoError(63);
482
+ } if (!MEMFS.ops_table) {
483
+ 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, allocate: MEMFS.stream_ops.allocate, 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 } };
484
+ } var node = FS.createNode(parent, name, mode, dev); if (FS.isDir(node.mode)) {
485
+ node.node_ops = MEMFS.ops_table.dir.node;
486
+ node.stream_ops = MEMFS.ops_table.dir.stream;
487
+ node.contents = {};
488
+ }
489
+ else if (FS.isFile(node.mode)) {
490
+ node.node_ops = MEMFS.ops_table.file.node;
491
+ node.stream_ops = MEMFS.ops_table.file.stream;
492
+ node.usedBytes = 0;
493
+ node.contents = null;
494
+ }
495
+ else if (FS.isLink(node.mode)) {
496
+ node.node_ops = MEMFS.ops_table.link.node;
497
+ node.stream_ops = MEMFS.ops_table.link.stream;
498
+ }
499
+ else if (FS.isChrdev(node.mode)) {
500
+ node.node_ops = MEMFS.ops_table.chrdev.node;
501
+ node.stream_ops = MEMFS.ops_table.chrdev.stream;
502
+ } node.timestamp = Date.now(); if (parent) {
503
+ parent.contents[name] = node;
504
+ parent.timestamp = node.timestamp;
505
+ } return node; }, getFileDataAsTypedArray: function (node) { if (!node.contents)
506
+ return new Uint8Array(0); if (node.contents.subarray)
507
+ return node.contents.subarray(0, node.usedBytes); return new Uint8Array(node.contents); }, expandFileStorage: function (node, newCapacity) { var prevCapacity = node.contents ? node.contents.length : 0; if (prevCapacity >= newCapacity)
508
+ return; var CAPACITY_DOUBLING_MAX = 1024 * 1024; newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) >>> 0); if (prevCapacity != 0)
509
+ newCapacity = Math.max(newCapacity, 256); var oldContents = node.contents; node.contents = new Uint8Array(newCapacity); if (node.usedBytes > 0)
510
+ node.contents.set(oldContents.subarray(0, node.usedBytes), 0); }, resizeFileStorage: function (node, newSize) { if (node.usedBytes == newSize)
511
+ return; if (newSize == 0) {
512
+ node.contents = null;
513
+ node.usedBytes = 0;
514
+ }
515
+ else {
516
+ var oldContents = node.contents;
517
+ node.contents = new Uint8Array(newSize);
518
+ if (oldContents) {
519
+ node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)));
520
+ }
521
+ node.usedBytes = newSize;
522
+ } }, node_ops: { getattr: function (node) { var attr = {}; attr.dev = FS.isChrdev(node.mode) ? node.id : 1; attr.ino = node.id; attr.mode = node.mode; attr.nlink = 1; attr.uid = 0; attr.gid = 0; attr.rdev = node.rdev; if (FS.isDir(node.mode)) {
523
+ attr.size = 4096;
524
+ }
525
+ else if (FS.isFile(node.mode)) {
526
+ attr.size = node.usedBytes;
527
+ }
528
+ else if (FS.isLink(node.mode)) {
529
+ attr.size = node.link.length;
530
+ }
531
+ else {
532
+ attr.size = 0;
533
+ } attr.atime = new Date(node.timestamp); attr.mtime = new Date(node.timestamp); attr.ctime = new Date(node.timestamp); attr.blksize = 4096; attr.blocks = Math.ceil(attr.size / attr.blksize); return attr; }, setattr: function (node, attr) { if (attr.mode !== undefined) {
534
+ node.mode = attr.mode;
535
+ } if (attr.timestamp !== undefined) {
536
+ node.timestamp = attr.timestamp;
537
+ } if (attr.size !== undefined) {
538
+ MEMFS.resizeFileStorage(node, attr.size);
539
+ } }, lookup: function (parent, name) { throw FS.genericErrors[44]; }, mknod: function (parent, name, mode, dev) { return MEMFS.createNode(parent, name, mode, dev); }, rename: function (old_node, new_dir, new_name) { if (FS.isDir(old_node.mode)) {
540
+ var new_node;
541
+ try {
542
+ new_node = FS.lookupNode(new_dir, new_name);
543
+ }
544
+ catch (e) { }
545
+ if (new_node) {
546
+ for (var i in new_node.contents) {
547
+ throw new FS.ErrnoError(55);
548
+ }
549
+ }
550
+ } delete old_node.parent.contents[old_node.name]; old_node.parent.timestamp = Date.now(); old_node.name = new_name; new_dir.contents[new_name] = old_node; new_dir.timestamp = old_node.parent.timestamp; old_node.parent = new_dir; }, unlink: function (parent, name) { delete parent.contents[name]; parent.timestamp = Date.now(); }, rmdir: function (parent, name) { var node = FS.lookupNode(parent, name); for (var i in node.contents) {
551
+ throw new FS.ErrnoError(55);
552
+ } delete parent.contents[name]; parent.timestamp = Date.now(); }, readdir: function (node) { var entries = [".", ".."]; for (var key in node.contents) {
553
+ if (!node.contents.hasOwnProperty(key)) {
554
+ continue;
555
+ }
556
+ entries.push(key);
557
+ } return entries; }, symlink: function (parent, newname, oldpath) { var node = MEMFS.createNode(parent, newname, 511 | 40960, 0); node.link = oldpath; return node; }, readlink: function (node) { if (!FS.isLink(node.mode)) {
558
+ throw new FS.ErrnoError(28);
559
+ } return node.link; } }, stream_ops: { read: function (stream, buffer, offset, length, position) { var contents = stream.node.contents; if (position >= stream.node.usedBytes)
560
+ return 0; var size = Math.min(stream.node.usedBytes - position, length); if (size > 8 && contents.subarray) {
561
+ buffer.set(contents.subarray(position, position + size), offset);
562
+ }
563
+ else {
564
+ for (var i = 0; i < size; i++)
565
+ buffer[offset + i] = contents[position + i];
566
+ } return size; }, write: function (stream, buffer, offset, length, position, canOwn) { if (!length)
567
+ return 0; var node = stream.node; node.timestamp = Date.now(); if (buffer.subarray && (!node.contents || node.contents.subarray)) {
568
+ if (canOwn) {
569
+ node.contents = buffer.subarray(offset, offset + length);
570
+ node.usedBytes = length;
571
+ return length;
572
+ }
573
+ else if (node.usedBytes === 0 && position === 0) {
574
+ node.contents = buffer.slice(offset, offset + length);
575
+ node.usedBytes = length;
576
+ return length;
577
+ }
578
+ else if (position + length <= node.usedBytes) {
579
+ node.contents.set(buffer.subarray(offset, offset + length), position);
580
+ return length;
581
+ }
582
+ } MEMFS.expandFileStorage(node, position + length); if (node.contents.subarray && buffer.subarray) {
583
+ node.contents.set(buffer.subarray(offset, offset + length), position);
584
+ }
585
+ else {
586
+ for (var i = 0; i < length; i++) {
587
+ node.contents[position + i] = buffer[offset + i];
588
+ }
589
+ } node.usedBytes = Math.max(node.usedBytes, position + length); return length; }, llseek: function (stream, offset, whence) { var position = offset; if (whence === 1) {
590
+ position += stream.position;
591
+ }
592
+ else if (whence === 2) {
593
+ if (FS.isFile(stream.node.mode)) {
594
+ position += stream.node.usedBytes;
595
+ }
596
+ } if (position < 0) {
597
+ throw new FS.ErrnoError(28);
598
+ } return position; }, allocate: function (stream, offset, length) { MEMFS.expandFileStorage(stream.node, offset + length); stream.node.usedBytes = Math.max(stream.node.usedBytes, offset + length); }, mmap: function (stream, length, position, prot, flags) { if (!FS.isFile(stream.node.mode)) {
599
+ throw new FS.ErrnoError(43);
600
+ } var ptr; var allocated; var contents = stream.node.contents; if (!(flags & 2) && contents.buffer === HEAP8.buffer) {
601
+ allocated = false;
602
+ ptr = contents.byteOffset;
603
+ }
604
+ else {
605
+ if (position > 0 || position + length < contents.length) {
606
+ if (contents.subarray) {
607
+ contents = contents.subarray(position, position + length);
608
+ }
609
+ else {
610
+ contents = Array.prototype.slice.call(contents, position, position + length);
611
+ }
612
+ }
613
+ allocated = true;
614
+ ptr = mmapAlloc(length);
615
+ if (!ptr) {
616
+ throw new FS.ErrnoError(48);
617
+ }
618
+ HEAP8.set(contents, ptr);
619
+ } return { ptr: ptr, allocated: allocated }; }, msync: function (stream, buffer, offset, length, mmapFlags) { MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false); return 0; } } };
620
+ function asyncLoad(url, onload, onerror, noRunDep) { var dep = !noRunDep ? getUniqueRunDependency("al " + url) : ""; readAsync(url, arrayBuffer => { assert(arrayBuffer, 'Loading data file "' + url + '" failed (no arrayBuffer).'); onload(new Uint8Array(arrayBuffer)); if (dep)
621
+ removeRunDependency(dep); }, event => { if (onerror) {
622
+ onerror();
623
+ }
624
+ else {
625
+ throw 'Loading data file "' + url + '" failed.';
626
+ } }); if (dep)
627
+ addRunDependency(dep); }
628
+ var ERRNO_CODES = {};
629
+ var NODEFS = { isWindows: false, staticInit: () => { NODEFS.isWindows = !!process.platform.match(/^win/); var flags = process.binding("constants"); if (flags["fs"]) {
630
+ flags = flags["fs"];
631
+ } NODEFS.flagsForNodeMap = { 1024: flags["O_APPEND"], 64: flags["O_CREAT"], 128: flags["O_EXCL"], 256: flags["O_NOCTTY"], 0: flags["O_RDONLY"], 2: flags["O_RDWR"], 4096: flags["O_SYNC"], 512: flags["O_TRUNC"], 1: flags["O_WRONLY"], 131072: flags["O_NOFOLLOW"] }; }, convertNodeCode: e => { var code = e.code; return ERRNO_CODES[code]; }, mount: mount => { return NODEFS.createNode(null, "/", NODEFS.getMode(mount.opts.root), 0); }, createNode: (parent, name, mode, dev) => { if (!FS.isDir(mode) && !FS.isFile(mode) && !FS.isLink(mode)) {
632
+ throw new FS.ErrnoError(28);
633
+ } var node = FS.createNode(parent, name, mode); node.node_ops = NODEFS.node_ops; node.stream_ops = NODEFS.stream_ops; return node; }, getMode: path => { var stat; try {
634
+ stat = fs.lstatSync(path);
635
+ if (NODEFS.isWindows) {
636
+ stat.mode = stat.mode | (stat.mode & 292) >> 2;
637
+ }
638
+ }
639
+ catch (e) {
640
+ if (!e.code)
641
+ throw e;
642
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
643
+ } return stat.mode; }, realPath: node => { var parts = []; while (node.parent !== node) {
644
+ parts.push(node.name);
645
+ node = node.parent;
646
+ } parts.push(node.mount.opts.root); parts.reverse(); return PATH.join.apply(null, parts); }, flagsForNode: flags => { flags &= ~2097152; flags &= ~2048; flags &= ~32768; flags &= ~524288; flags &= ~65536; var newFlags = 0; for (var k in NODEFS.flagsForNodeMap) {
647
+ if (flags & k) {
648
+ newFlags |= NODEFS.flagsForNodeMap[k];
649
+ flags ^= k;
650
+ }
651
+ } if (flags) {
652
+ throw new FS.ErrnoError(28);
653
+ } return newFlags; }, node_ops: { getattr: node => { var path = NODEFS.realPath(node); var stat; try {
654
+ stat = fs.lstatSync(path);
655
+ }
656
+ catch (e) {
657
+ if (!e.code)
658
+ throw e;
659
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
660
+ } if (NODEFS.isWindows && !stat.blksize) {
661
+ stat.blksize = 4096;
662
+ } if (NODEFS.isWindows && !stat.blocks) {
663
+ stat.blocks = (stat.size + stat.blksize - 1) / stat.blksize | 0;
664
+ } return { dev: stat.dev, ino: stat.ino, mode: stat.mode, nlink: stat.nlink, uid: stat.uid, gid: stat.gid, rdev: stat.rdev, size: stat.size, atime: stat.atime, mtime: stat.mtime, ctime: stat.ctime, blksize: stat.blksize, blocks: stat.blocks }; }, setattr: (node, attr) => { var path = NODEFS.realPath(node); try {
665
+ if (attr.mode !== undefined) {
666
+ fs.chmodSync(path, attr.mode);
667
+ node.mode = attr.mode;
668
+ }
669
+ if (attr.timestamp !== undefined) {
670
+ var date = new Date(attr.timestamp);
671
+ fs.utimesSync(path, date, date);
672
+ }
673
+ if (attr.size !== undefined) {
674
+ fs.truncateSync(path, attr.size);
675
+ }
676
+ }
677
+ catch (e) {
678
+ if (!e.code)
679
+ throw e;
680
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
681
+ } }, lookup: (parent, name) => { var path = PATH.join2(NODEFS.realPath(parent), name); var mode = NODEFS.getMode(path); return NODEFS.createNode(parent, name, mode); }, mknod: (parent, name, mode, dev) => { var node = NODEFS.createNode(parent, name, mode, dev); var path = NODEFS.realPath(node); try {
682
+ if (FS.isDir(node.mode)) {
683
+ fs.mkdirSync(path, node.mode);
684
+ }
685
+ else {
686
+ fs.writeFileSync(path, "", { mode: node.mode });
687
+ }
688
+ }
689
+ catch (e) {
690
+ if (!e.code)
691
+ throw e;
692
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
693
+ } return node; }, rename: (oldNode, newDir, newName) => { var oldPath = NODEFS.realPath(oldNode); var newPath = PATH.join2(NODEFS.realPath(newDir), newName); try {
694
+ fs.renameSync(oldPath, newPath);
695
+ }
696
+ catch (e) {
697
+ if (!e.code)
698
+ throw e;
699
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
700
+ } oldNode.name = newName; }, unlink: (parent, name) => { var path = PATH.join2(NODEFS.realPath(parent), name); try {
701
+ fs.unlinkSync(path);
702
+ }
703
+ catch (e) {
704
+ if (!e.code)
705
+ throw e;
706
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
707
+ } }, rmdir: (parent, name) => { var path = PATH.join2(NODEFS.realPath(parent), name); try {
708
+ fs.rmdirSync(path);
709
+ }
710
+ catch (e) {
711
+ if (!e.code)
712
+ throw e;
713
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
714
+ } }, readdir: node => { var path = NODEFS.realPath(node); try {
715
+ return fs.readdirSync(path);
716
+ }
717
+ catch (e) {
718
+ if (!e.code)
719
+ throw e;
720
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
721
+ } }, symlink: (parent, newName, oldPath) => { var newPath = PATH.join2(NODEFS.realPath(parent), newName); try {
722
+ fs.symlinkSync(oldPath, newPath);
723
+ }
724
+ catch (e) {
725
+ if (!e.code)
726
+ throw e;
727
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
728
+ } }, readlink: node => { var path = NODEFS.realPath(node); try {
729
+ path = fs.readlinkSync(path);
730
+ path = nodePath.relative(nodePath.resolve(node.mount.opts.root), path);
731
+ return path;
732
+ }
733
+ catch (e) {
734
+ if (!e.code)
735
+ throw e;
736
+ if (e.code === "UNKNOWN")
737
+ throw new FS.ErrnoError(28);
738
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
739
+ } } }, stream_ops: { open: stream => { var path = NODEFS.realPath(stream.node); try {
740
+ if (FS.isFile(stream.node.mode)) {
741
+ stream.nfd = fs.openSync(path, NODEFS.flagsForNode(stream.flags));
742
+ }
743
+ }
744
+ catch (e) {
745
+ if (!e.code)
746
+ throw e;
747
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
748
+ } }, close: stream => { try {
749
+ if (FS.isFile(stream.node.mode) && stream.nfd) {
750
+ fs.closeSync(stream.nfd);
751
+ }
752
+ }
753
+ catch (e) {
754
+ if (!e.code)
755
+ throw e;
756
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
757
+ } }, read: (stream, buffer, offset, length, position) => { if (length === 0)
758
+ return 0; try {
759
+ return fs.readSync(stream.nfd, Buffer.from(buffer.buffer), offset, length, position);
760
+ }
761
+ catch (e) {
762
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
763
+ } }, write: (stream, buffer, offset, length, position) => { try {
764
+ return fs.writeSync(stream.nfd, Buffer.from(buffer.buffer), offset, length, position);
765
+ }
766
+ catch (e) {
767
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
768
+ } }, llseek: (stream, offset, whence) => { var position = offset; if (whence === 1) {
769
+ position += stream.position;
770
+ }
771
+ else if (whence === 2) {
772
+ if (FS.isFile(stream.node.mode)) {
773
+ try {
774
+ var stat = fs.fstatSync(stream.nfd);
775
+ position += stat.size;
776
+ }
777
+ catch (e) {
778
+ throw new FS.ErrnoError(NODEFS.convertNodeCode(e));
779
+ }
780
+ }
781
+ } if (position < 0) {
782
+ throw new FS.ErrnoError(28);
783
+ } return position; }, mmap: (stream, length, position, prot, flags) => { if (!FS.isFile(stream.node.mode)) {
784
+ throw new FS.ErrnoError(43);
785
+ } var ptr = mmapAlloc(length); NODEFS.stream_ops.read(stream, HEAP8, ptr, length, position); return { ptr: ptr, allocated: true }; }, msync: (stream, buffer, offset, length, mmapFlags) => { NODEFS.stream_ops.write(stream, buffer, 0, length, offset, false); return 0; } } };
786
+ var FS = { root: null, mounts: [], devices: {}, streams: [], nextInode: 1, nameTable: null, currentPath: "/", initialized: false, ignorePermissions: true, ErrnoError: null, genericErrors: {}, filesystems: null, syncFSRequests: 0, lookupPath: (path, opts = {}) => { path = PATH_FS.resolve(path); if (!path)
787
+ return { path: "", node: null }; var defaults = { follow_mount: true, recurse_count: 0 }; opts = Object.assign(defaults, opts); if (opts.recurse_count > 8) {
788
+ throw new FS.ErrnoError(32);
789
+ } var parts = path.split("/").filter(p => !!p); var current = FS.root; var current_path = "/"; for (var i = 0; i < parts.length; i++) {
790
+ var islast = i === parts.length - 1;
791
+ if (islast && opts.parent) {
792
+ break;
793
+ }
794
+ current = FS.lookupNode(current, parts[i]);
795
+ current_path = PATH.join2(current_path, parts[i]);
796
+ if (FS.isMountpoint(current)) {
797
+ if (!islast || islast && opts.follow_mount) {
798
+ current = current.mounted.root;
799
+ }
800
+ }
801
+ if (!islast || opts.follow) {
802
+ var count = 0;
803
+ while (FS.isLink(current.mode)) {
804
+ var link = FS.readlink(current_path);
805
+ current_path = PATH_FS.resolve(PATH.dirname(current_path), link);
806
+ var lookup = FS.lookupPath(current_path, { recurse_count: opts.recurse_count + 1 });
807
+ current = lookup.node;
808
+ if (count++ > 40) {
809
+ throw new FS.ErrnoError(32);
810
+ }
811
+ }
812
+ }
813
+ } return { path: current_path, node: current }; }, getPath: node => { var path; while (true) {
814
+ if (FS.isRoot(node)) {
815
+ var mount = node.mount.mountpoint;
816
+ if (!path)
817
+ return mount;
818
+ return mount[mount.length - 1] !== "/" ? mount + "/" + path : mount + path;
819
+ }
820
+ path = path ? node.name + "/" + path : node.name;
821
+ node = node.parent;
822
+ } }, hashName: (parentid, name) => { var hash = 0; for (var i = 0; i < name.length; i++) {
823
+ hash = (hash << 5) - hash + name.charCodeAt(i) | 0;
824
+ } return (parentid + hash >>> 0) % FS.nameTable.length; }, hashAddNode: node => { var hash = FS.hashName(node.parent.id, node.name); node.name_next = FS.nameTable[hash]; FS.nameTable[hash] = node; }, hashRemoveNode: node => { var hash = FS.hashName(node.parent.id, node.name); if (FS.nameTable[hash] === node) {
825
+ FS.nameTable[hash] = node.name_next;
826
+ }
827
+ else {
828
+ var current = FS.nameTable[hash];
829
+ while (current) {
830
+ if (current.name_next === node) {
831
+ current.name_next = node.name_next;
832
+ break;
833
+ }
834
+ current = current.name_next;
835
+ }
836
+ } }, lookupNode: (parent, name) => { var errCode = FS.mayLookup(parent); if (errCode) {
837
+ throw new FS.ErrnoError(errCode, parent);
838
+ } var hash = FS.hashName(parent.id, name); for (var node = FS.nameTable[hash]; node; node = node.name_next) {
839
+ var nodeName = node.name;
840
+ if (node.parent.id === parent.id && nodeName === name) {
841
+ return node;
842
+ }
843
+ } return FS.lookup(parent, name); }, createNode: (parent, name, mode, rdev) => { var node = new FS.FSNode(parent, name, mode, rdev); FS.hashAddNode(node); return node; }, destroyNode: node => { FS.hashRemoveNode(node); }, isRoot: node => { return node === node.parent; }, isMountpoint: node => { return !!node.mounted; }, isFile: mode => { return (mode & 61440) === 32768; }, isDir: mode => { return (mode & 61440) === 16384; }, isLink: mode => { return (mode & 61440) === 40960; }, isChrdev: mode => { return (mode & 61440) === 8192; }, isBlkdev: mode => { return (mode & 61440) === 24576; }, isFIFO: mode => { return (mode & 61440) === 4096; }, isSocket: mode => { return (mode & 49152) === 49152; }, flagModes: { "r": 0, "r+": 2, "w": 577, "w+": 578, "a": 1089, "a+": 1090 }, modeStringToFlags: str => { var flags = FS.flagModes[str]; if (typeof flags == "undefined") {
844
+ throw new Error("Unknown file open mode: " + str);
845
+ } return flags; }, flagsToPermissionString: flag => { var perms = ["r", "w", "rw"][flag & 3]; if (flag & 512) {
846
+ perms += "w";
847
+ } return perms; }, nodePermissions: (node, perms) => { if (FS.ignorePermissions) {
848
+ return 0;
849
+ } if (perms.includes("r") && !(node.mode & 292)) {
850
+ return 2;
851
+ }
852
+ else if (perms.includes("w") && !(node.mode & 146)) {
853
+ return 2;
854
+ }
855
+ else if (perms.includes("x") && !(node.mode & 73)) {
856
+ return 2;
857
+ } return 0; }, mayLookup: dir => { var errCode = FS.nodePermissions(dir, "x"); if (errCode)
858
+ return errCode; if (!dir.node_ops.lookup)
859
+ return 2; return 0; }, mayCreate: (dir, name) => { try {
860
+ var node = FS.lookupNode(dir, name);
861
+ return 20;
862
+ }
863
+ catch (e) { } return FS.nodePermissions(dir, "wx"); }, mayDelete: (dir, name, isdir) => { var node; try {
864
+ node = FS.lookupNode(dir, name);
865
+ }
866
+ catch (e) {
867
+ return e.errno;
868
+ } var errCode = FS.nodePermissions(dir, "wx"); if (errCode) {
869
+ return errCode;
870
+ } if (isdir) {
871
+ if (!FS.isDir(node.mode)) {
872
+ return 54;
873
+ }
874
+ if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
875
+ return 10;
876
+ }
877
+ }
878
+ else {
879
+ if (FS.isDir(node.mode)) {
880
+ return 31;
881
+ }
882
+ } return 0; }, mayOpen: (node, flags) => { if (!node) {
883
+ return 44;
884
+ } if (FS.isLink(node.mode)) {
885
+ return 32;
886
+ }
887
+ else if (FS.isDir(node.mode)) {
888
+ if (FS.flagsToPermissionString(flags) !== "r" || flags & 512) {
889
+ return 31;
890
+ }
891
+ } return FS.nodePermissions(node, FS.flagsToPermissionString(flags)); }, MAX_OPEN_FDS: 4096, nextfd: (fd_start = 0, fd_end = FS.MAX_OPEN_FDS) => { for (var fd = fd_start; fd <= fd_end; fd++) {
892
+ if (!FS.streams[fd]) {
893
+ return fd;
894
+ }
895
+ } throw new FS.ErrnoError(33); }, getStream: fd => FS.streams[fd], createStream: (stream, fd_start, fd_end) => { if (!FS.FSStream) {
896
+ FS.FSStream = function () { this.shared = {}; };
897
+ FS.FSStream.prototype = {};
898
+ Object.defineProperties(FS.FSStream.prototype, { object: { get: function () { return this.node; }, set: function (val) { this.node = val; } }, isRead: { get: function () { return (this.flags & 2097155) !== 1; } }, isWrite: { get: function () { return (this.flags & 2097155) !== 0; } }, isAppend: { get: function () { return this.flags & 1024; } }, flags: { get: function () { return this.shared.flags; }, set: function (val) { this.shared.flags = val; } }, position: { get: function () { return this.shared.position; }, set: function (val) { this.shared.position = val; } } });
899
+ } stream = Object.assign(new FS.FSStream, stream); var fd = FS.nextfd(fd_start, fd_end); stream.fd = fd; FS.streams[fd] = stream; return stream; }, closeStream: fd => { FS.streams[fd] = null; }, chrdev_stream_ops: { open: stream => { var device = FS.getDevice(stream.node.rdev); stream.stream_ops = device.stream_ops; if (stream.stream_ops.open) {
900
+ stream.stream_ops.open(stream);
901
+ } }, llseek: () => { throw new FS.ErrnoError(70); } }, major: dev => dev >> 8, minor: dev => dev & 255, makedev: (ma, mi) => ma << 8 | mi, registerDevice: (dev, ops) => { FS.devices[dev] = { stream_ops: ops }; }, getDevice: dev => FS.devices[dev], getMounts: mount => { var mounts = []; var check = [mount]; while (check.length) {
902
+ var m = check.pop();
903
+ mounts.push(m);
904
+ check.push.apply(check, m.mounts);
905
+ } return mounts; }, syncfs: (populate, callback) => { if (typeof populate == "function") {
906
+ callback = populate;
907
+ populate = false;
908
+ } FS.syncFSRequests++; if (FS.syncFSRequests > 1) {
909
+ err("warning: " + FS.syncFSRequests + " FS.syncfs operations in flight at once, probably just doing extra work");
910
+ } var mounts = FS.getMounts(FS.root.mount); var completed = 0; function doCallback(errCode) { FS.syncFSRequests--; return callback(errCode); } function done(errCode) { if (errCode) {
911
+ if (!done.errored) {
912
+ done.errored = true;
913
+ return doCallback(errCode);
914
+ }
915
+ return;
916
+ } if (++completed >= mounts.length) {
917
+ doCallback(null);
918
+ } } mounts.forEach(mount => { if (!mount.type.syncfs) {
919
+ return done(null);
920
+ } mount.type.syncfs(mount, populate, done); }); }, mount: (type, opts, mountpoint) => { var root = mountpoint === "/"; var pseudo = !mountpoint; var node; if (root && FS.root) {
921
+ throw new FS.ErrnoError(10);
922
+ }
923
+ else if (!root && !pseudo) {
924
+ var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
925
+ mountpoint = lookup.path;
926
+ node = lookup.node;
927
+ if (FS.isMountpoint(node)) {
928
+ throw new FS.ErrnoError(10);
929
+ }
930
+ if (!FS.isDir(node.mode)) {
931
+ throw new FS.ErrnoError(54);
932
+ }
933
+ } var mount = { type: type, opts: opts, mountpoint: mountpoint, mounts: [] }; var mountRoot = type.mount(mount); mountRoot.mount = mount; mount.root = mountRoot; if (root) {
934
+ FS.root = mountRoot;
935
+ }
936
+ else if (node) {
937
+ node.mounted = mount;
938
+ if (node.mount) {
939
+ node.mount.mounts.push(mount);
940
+ }
941
+ } return mountRoot; }, unmount: mountpoint => { var lookup = FS.lookupPath(mountpoint, { follow_mount: false }); if (!FS.isMountpoint(lookup.node)) {
942
+ throw new FS.ErrnoError(28);
943
+ } var node = lookup.node; var mount = node.mounted; var mounts = FS.getMounts(mount); Object.keys(FS.nameTable).forEach(hash => { var current = FS.nameTable[hash]; while (current) {
944
+ var next = current.name_next;
945
+ if (mounts.includes(current.mount)) {
946
+ FS.destroyNode(current);
947
+ }
948
+ current = next;
949
+ } }); node.mounted = null; var idx = node.mount.mounts.indexOf(mount); node.mount.mounts.splice(idx, 1); }, lookup: (parent, name) => { return parent.node_ops.lookup(parent, name); }, mknod: (path, mode, dev) => { var lookup = FS.lookupPath(path, { parent: true }); var parent = lookup.node; var name = PATH.basename(path); if (!name || name === "." || name === "..") {
950
+ throw new FS.ErrnoError(28);
951
+ } var errCode = FS.mayCreate(parent, name); if (errCode) {
952
+ throw new FS.ErrnoError(errCode);
953
+ } if (!parent.node_ops.mknod) {
954
+ throw new FS.ErrnoError(63);
955
+ } return parent.node_ops.mknod(parent, name, mode, dev); }, create: (path, mode) => { mode = mode !== undefined ? mode : 438; mode &= 4095; mode |= 32768; return FS.mknod(path, mode, 0); }, mkdir: (path, mode) => { mode = mode !== undefined ? mode : 511; mode &= 511 | 512; mode |= 16384; return FS.mknod(path, mode, 0); }, mkdirTree: (path, mode) => { var dirs = path.split("/"); var d = ""; for (var i = 0; i < dirs.length; ++i) {
956
+ if (!dirs[i])
957
+ continue;
958
+ d += "/" + dirs[i];
959
+ try {
960
+ FS.mkdir(d, mode);
961
+ }
962
+ catch (e) {
963
+ if (e.errno != 20)
964
+ throw e;
965
+ }
966
+ } }, mkdev: (path, mode, dev) => { if (typeof dev == "undefined") {
967
+ dev = mode;
968
+ mode = 438;
969
+ } mode |= 8192; return FS.mknod(path, mode, dev); }, symlink: (oldpath, newpath) => { if (!PATH_FS.resolve(oldpath)) {
970
+ throw new FS.ErrnoError(44);
971
+ } var lookup = FS.lookupPath(newpath, { parent: true }); var parent = lookup.node; if (!parent) {
972
+ throw new FS.ErrnoError(44);
973
+ } var newname = PATH.basename(newpath); var errCode = FS.mayCreate(parent, newname); if (errCode) {
974
+ throw new FS.ErrnoError(errCode);
975
+ } if (!parent.node_ops.symlink) {
976
+ throw new FS.ErrnoError(63);
977
+ } return parent.node_ops.symlink(parent, newname, oldpath); }, rename: (old_path, new_path) => { var old_dirname = PATH.dirname(old_path); var new_dirname = PATH.dirname(new_path); var old_name = PATH.basename(old_path); var new_name = PATH.basename(new_path); var lookup, old_dir, new_dir; lookup = FS.lookupPath(old_path, { parent: true }); old_dir = lookup.node; lookup = FS.lookupPath(new_path, { parent: true }); new_dir = lookup.node; if (!old_dir || !new_dir)
978
+ throw new FS.ErrnoError(44); if (old_dir.mount !== new_dir.mount) {
979
+ throw new FS.ErrnoError(75);
980
+ } var old_node = FS.lookupNode(old_dir, old_name); var relative = PATH_FS.relative(old_path, new_dirname); if (relative.charAt(0) !== ".") {
981
+ throw new FS.ErrnoError(28);
982
+ } relative = PATH_FS.relative(new_path, old_dirname); if (relative.charAt(0) !== ".") {
983
+ throw new FS.ErrnoError(55);
984
+ } var new_node; try {
985
+ new_node = FS.lookupNode(new_dir, new_name);
986
+ }
987
+ catch (e) { } if (old_node === new_node) {
988
+ return;
989
+ } var isdir = FS.isDir(old_node.mode); var errCode = FS.mayDelete(old_dir, old_name, isdir); if (errCode) {
990
+ throw new FS.ErrnoError(errCode);
991
+ } errCode = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name); if (errCode) {
992
+ throw new FS.ErrnoError(errCode);
993
+ } if (!old_dir.node_ops.rename) {
994
+ throw new FS.ErrnoError(63);
995
+ } if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
996
+ throw new FS.ErrnoError(10);
997
+ } if (new_dir !== old_dir) {
998
+ errCode = FS.nodePermissions(old_dir, "w");
999
+ if (errCode) {
1000
+ throw new FS.ErrnoError(errCode);
1001
+ }
1002
+ } FS.hashRemoveNode(old_node); try {
1003
+ old_dir.node_ops.rename(old_node, new_dir, new_name);
1004
+ }
1005
+ catch (e) {
1006
+ throw e;
1007
+ }
1008
+ finally {
1009
+ FS.hashAddNode(old_node);
1010
+ } }, rmdir: path => { var lookup = FS.lookupPath(path, { parent: true }); var parent = lookup.node; var name = PATH.basename(path); var node = FS.lookupNode(parent, name); var errCode = FS.mayDelete(parent, name, true); if (errCode) {
1011
+ throw new FS.ErrnoError(errCode);
1012
+ } if (!parent.node_ops.rmdir) {
1013
+ throw new FS.ErrnoError(63);
1014
+ } if (FS.isMountpoint(node)) {
1015
+ throw new FS.ErrnoError(10);
1016
+ } parent.node_ops.rmdir(parent, name); FS.destroyNode(node); }, readdir: path => { var lookup = FS.lookupPath(path, { follow: true }); var node = lookup.node; if (!node.node_ops.readdir) {
1017
+ throw new FS.ErrnoError(54);
1018
+ } return node.node_ops.readdir(node); }, unlink: path => { var lookup = FS.lookupPath(path, { parent: true }); var parent = lookup.node; if (!parent) {
1019
+ throw new FS.ErrnoError(44);
1020
+ } var name = PATH.basename(path); var node = FS.lookupNode(parent, name); var errCode = FS.mayDelete(parent, name, false); if (errCode) {
1021
+ throw new FS.ErrnoError(errCode);
1022
+ } if (!parent.node_ops.unlink) {
1023
+ throw new FS.ErrnoError(63);
1024
+ } if (FS.isMountpoint(node)) {
1025
+ throw new FS.ErrnoError(10);
1026
+ } parent.node_ops.unlink(parent, name); FS.destroyNode(node); }, readlink: path => { var lookup = FS.lookupPath(path); var link = lookup.node; if (!link) {
1027
+ throw new FS.ErrnoError(44);
1028
+ } if (!link.node_ops.readlink) {
1029
+ throw new FS.ErrnoError(28);
1030
+ } return PATH_FS.resolve(FS.getPath(link.parent), link.node_ops.readlink(link)); }, stat: (path, dontFollow) => { var lookup = FS.lookupPath(path, { follow: !dontFollow }); var node = lookup.node; if (!node) {
1031
+ throw new FS.ErrnoError(44);
1032
+ } if (!node.node_ops.getattr) {
1033
+ throw new FS.ErrnoError(63);
1034
+ } return node.node_ops.getattr(node); }, lstat: path => { return FS.stat(path, true); }, chmod: (path, mode, dontFollow) => { var node; if (typeof path == "string") {
1035
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
1036
+ node = lookup.node;
1037
+ }
1038
+ else {
1039
+ node = path;
1040
+ } if (!node.node_ops.setattr) {
1041
+ throw new FS.ErrnoError(63);
1042
+ } node.node_ops.setattr(node, { mode: mode & 4095 | node.mode & ~4095, timestamp: Date.now() }); }, lchmod: (path, mode) => { FS.chmod(path, mode, true); }, fchmod: (fd, mode) => { var stream = FS.getStream(fd); if (!stream) {
1043
+ throw new FS.ErrnoError(8);
1044
+ } FS.chmod(stream.node, mode); }, chown: (path, uid, gid, dontFollow) => { var node; if (typeof path == "string") {
1045
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
1046
+ node = lookup.node;
1047
+ }
1048
+ else {
1049
+ node = path;
1050
+ } if (!node.node_ops.setattr) {
1051
+ throw new FS.ErrnoError(63);
1052
+ } node.node_ops.setattr(node, { timestamp: Date.now() }); }, lchown: (path, uid, gid) => { FS.chown(path, uid, gid, true); }, fchown: (fd, uid, gid) => { var stream = FS.getStream(fd); if (!stream) {
1053
+ throw new FS.ErrnoError(8);
1054
+ } FS.chown(stream.node, uid, gid); }, truncate: (path, len) => { if (len < 0) {
1055
+ throw new FS.ErrnoError(28);
1056
+ } var node; if (typeof path == "string") {
1057
+ var lookup = FS.lookupPath(path, { follow: true });
1058
+ node = lookup.node;
1059
+ }
1060
+ else {
1061
+ node = path;
1062
+ } if (!node.node_ops.setattr) {
1063
+ throw new FS.ErrnoError(63);
1064
+ } if (FS.isDir(node.mode)) {
1065
+ throw new FS.ErrnoError(31);
1066
+ } if (!FS.isFile(node.mode)) {
1067
+ throw new FS.ErrnoError(28);
1068
+ } var errCode = FS.nodePermissions(node, "w"); if (errCode) {
1069
+ throw new FS.ErrnoError(errCode);
1070
+ } node.node_ops.setattr(node, { size: len, timestamp: Date.now() }); }, ftruncate: (fd, len) => { var stream = FS.getStream(fd); if (!stream) {
1071
+ throw new FS.ErrnoError(8);
1072
+ } if ((stream.flags & 2097155) === 0) {
1073
+ throw new FS.ErrnoError(28);
1074
+ } FS.truncate(stream.node, len); }, utime: (path, atime, mtime) => { var lookup = FS.lookupPath(path, { follow: true }); var node = lookup.node; node.node_ops.setattr(node, { timestamp: Math.max(atime, mtime) }); }, open: (path, flags, mode) => { if (path === "") {
1075
+ throw new FS.ErrnoError(44);
1076
+ } flags = typeof flags == "string" ? FS.modeStringToFlags(flags) : flags; mode = typeof mode == "undefined" ? 438 : mode; if (flags & 64) {
1077
+ mode = mode & 4095 | 32768;
1078
+ }
1079
+ else {
1080
+ mode = 0;
1081
+ } var node; if (typeof path == "object") {
1082
+ node = path;
1083
+ }
1084
+ else {
1085
+ path = PATH.normalize(path);
1086
+ try {
1087
+ var lookup = FS.lookupPath(path, { follow: !(flags & 131072) });
1088
+ node = lookup.node;
1089
+ }
1090
+ catch (e) { }
1091
+ } var created = false; if (flags & 64) {
1092
+ if (node) {
1093
+ if (flags & 128) {
1094
+ throw new FS.ErrnoError(20);
1095
+ }
1096
+ }
1097
+ else {
1098
+ node = FS.mknod(path, mode, 0);
1099
+ created = true;
1100
+ }
1101
+ } if (!node) {
1102
+ throw new FS.ErrnoError(44);
1103
+ } if (FS.isChrdev(node.mode)) {
1104
+ flags &= ~512;
1105
+ } if (flags & 65536 && !FS.isDir(node.mode)) {
1106
+ throw new FS.ErrnoError(54);
1107
+ } if (!created) {
1108
+ var errCode = FS.mayOpen(node, flags);
1109
+ if (errCode) {
1110
+ throw new FS.ErrnoError(errCode);
1111
+ }
1112
+ } if (flags & 512 && !created) {
1113
+ FS.truncate(node, 0);
1114
+ } flags &= ~(128 | 512 | 131072); var stream = FS.createStream({ node: node, path: FS.getPath(node), flags: flags, seekable: true, position: 0, stream_ops: node.stream_ops, ungotten: [], error: false }); if (stream.stream_ops.open) {
1115
+ stream.stream_ops.open(stream);
1116
+ } if (Module["logReadFiles"] && !(flags & 1)) {
1117
+ if (!FS.readFiles)
1118
+ FS.readFiles = {};
1119
+ if (!(path in FS.readFiles)) {
1120
+ FS.readFiles[path] = 1;
1121
+ }
1122
+ } return stream; }, close: stream => { if (FS.isClosed(stream)) {
1123
+ throw new FS.ErrnoError(8);
1124
+ } if (stream.getdents)
1125
+ stream.getdents = null; try {
1126
+ if (stream.stream_ops.close) {
1127
+ stream.stream_ops.close(stream);
1128
+ }
1129
+ }
1130
+ catch (e) {
1131
+ throw e;
1132
+ }
1133
+ finally {
1134
+ FS.closeStream(stream.fd);
1135
+ } stream.fd = null; }, isClosed: stream => { return stream.fd === null; }, llseek: (stream, offset, whence) => { if (FS.isClosed(stream)) {
1136
+ throw new FS.ErrnoError(8);
1137
+ } if (!stream.seekable || !stream.stream_ops.llseek) {
1138
+ throw new FS.ErrnoError(70);
1139
+ } if (whence != 0 && whence != 1 && whence != 2) {
1140
+ throw new FS.ErrnoError(28);
1141
+ } stream.position = stream.stream_ops.llseek(stream, offset, whence); stream.ungotten = []; return stream.position; }, read: (stream, buffer, offset, length, position) => { if (length < 0 || position < 0) {
1142
+ throw new FS.ErrnoError(28);
1143
+ } if (FS.isClosed(stream)) {
1144
+ throw new FS.ErrnoError(8);
1145
+ } if ((stream.flags & 2097155) === 1) {
1146
+ throw new FS.ErrnoError(8);
1147
+ } if (FS.isDir(stream.node.mode)) {
1148
+ throw new FS.ErrnoError(31);
1149
+ } if (!stream.stream_ops.read) {
1150
+ throw new FS.ErrnoError(28);
1151
+ } var seeking = typeof position != "undefined"; if (!seeking) {
1152
+ position = stream.position;
1153
+ }
1154
+ else if (!stream.seekable) {
1155
+ throw new FS.ErrnoError(70);
1156
+ } var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position); if (!seeking)
1157
+ stream.position += bytesRead; return bytesRead; }, write: (stream, buffer, offset, length, position, canOwn) => { if (length < 0 || position < 0) {
1158
+ throw new FS.ErrnoError(28);
1159
+ } if (FS.isClosed(stream)) {
1160
+ throw new FS.ErrnoError(8);
1161
+ } if ((stream.flags & 2097155) === 0) {
1162
+ throw new FS.ErrnoError(8);
1163
+ } if (FS.isDir(stream.node.mode)) {
1164
+ throw new FS.ErrnoError(31);
1165
+ } if (!stream.stream_ops.write) {
1166
+ throw new FS.ErrnoError(28);
1167
+ } if (stream.seekable && stream.flags & 1024) {
1168
+ FS.llseek(stream, 0, 2);
1169
+ } var seeking = typeof position != "undefined"; if (!seeking) {
1170
+ position = stream.position;
1171
+ }
1172
+ else if (!stream.seekable) {
1173
+ throw new FS.ErrnoError(70);
1174
+ } var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn); if (!seeking)
1175
+ stream.position += bytesWritten; return bytesWritten; }, allocate: (stream, offset, length) => { if (FS.isClosed(stream)) {
1176
+ throw new FS.ErrnoError(8);
1177
+ } if (offset < 0 || length <= 0) {
1178
+ throw new FS.ErrnoError(28);
1179
+ } if ((stream.flags & 2097155) === 0) {
1180
+ throw new FS.ErrnoError(8);
1181
+ } if (!FS.isFile(stream.node.mode) && !FS.isDir(stream.node.mode)) {
1182
+ throw new FS.ErrnoError(43);
1183
+ } if (!stream.stream_ops.allocate) {
1184
+ throw new FS.ErrnoError(138);
1185
+ } stream.stream_ops.allocate(stream, offset, length); }, mmap: (stream, length, position, prot, flags) => { if ((prot & 2) !== 0 && (flags & 2) === 0 && (stream.flags & 2097155) !== 2) {
1186
+ throw new FS.ErrnoError(2);
1187
+ } if ((stream.flags & 2097155) === 1) {
1188
+ throw new FS.ErrnoError(2);
1189
+ } if (!stream.stream_ops.mmap) {
1190
+ throw new FS.ErrnoError(43);
1191
+ } return stream.stream_ops.mmap(stream, length, position, prot, flags); }, msync: (stream, buffer, offset, length, mmapFlags) => { if (!stream.stream_ops.msync) {
1192
+ return 0;
1193
+ } return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags); }, munmap: stream => 0, ioctl: (stream, cmd, arg) => { if (!stream.stream_ops.ioctl) {
1194
+ throw new FS.ErrnoError(59);
1195
+ } return stream.stream_ops.ioctl(stream, cmd, arg); }, readFile: (path, opts = {}) => { opts.flags = opts.flags || 0; opts.encoding = opts.encoding || "binary"; if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
1196
+ throw new Error('Invalid encoding type "' + opts.encoding + '"');
1197
+ } var ret; var stream = FS.open(path, opts.flags); var stat = FS.stat(path); var length = stat.size; var buf = new Uint8Array(length); FS.read(stream, buf, 0, length, 0); if (opts.encoding === "utf8") {
1198
+ ret = UTF8ArrayToString(buf, 0);
1199
+ }
1200
+ else if (opts.encoding === "binary") {
1201
+ ret = buf;
1202
+ } FS.close(stream); return ret; }, writeFile: (path, data, opts = {}) => { opts.flags = opts.flags || 577; var stream = FS.open(path, opts.flags, opts.mode); if (typeof data == "string") {
1203
+ var buf = new Uint8Array(lengthBytesUTF8(data) + 1);
1204
+ var actualNumBytes = stringToUTF8Array(data, buf, 0, buf.length);
1205
+ FS.write(stream, buf, 0, actualNumBytes, undefined, opts.canOwn);
1206
+ }
1207
+ else if (ArrayBuffer.isView(data)) {
1208
+ FS.write(stream, data, 0, data.byteLength, undefined, opts.canOwn);
1209
+ }
1210
+ else {
1211
+ throw new Error("Unsupported data type");
1212
+ } FS.close(stream); }, cwd: () => FS.currentPath, chdir: path => { var lookup = FS.lookupPath(path, { follow: true }); if (lookup.node === null) {
1213
+ throw new FS.ErrnoError(44);
1214
+ } if (!FS.isDir(lookup.node.mode)) {
1215
+ throw new FS.ErrnoError(54);
1216
+ } var errCode = FS.nodePermissions(lookup.node, "x"); if (errCode) {
1217
+ throw new FS.ErrnoError(errCode);
1218
+ } FS.currentPath = lookup.path; }, createDefaultDirectories: () => { FS.mkdir("/tmp"); FS.mkdir("/home"); FS.mkdir("/home/web_user"); }, createDefaultDevices: () => { FS.mkdir("/dev"); FS.registerDevice(FS.makedev(1, 3), { read: () => 0, write: (stream, buffer, offset, length, pos) => length }); FS.mkdev("/dev/null", FS.makedev(1, 3)); TTY.register(FS.makedev(5, 0), TTY.default_tty_ops); TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops); FS.mkdev("/dev/tty", FS.makedev(5, 0)); FS.mkdev("/dev/tty1", FS.makedev(6, 0)); var random_device = getRandomDevice(); FS.createDevice("/dev", "random", random_device); FS.createDevice("/dev", "urandom", random_device); FS.mkdir("/dev/shm"); FS.mkdir("/dev/shm/tmp"); }, createSpecialDirectories: () => { FS.mkdir("/proc"); var proc_self = FS.mkdir("/proc/self"); FS.mkdir("/proc/self/fd"); FS.mount({ mount: () => { var node = FS.createNode(proc_self, "fd", 16384 | 511, 73); node.node_ops = { lookup: (parent, name) => { var fd = +name; var stream = FS.getStream(fd); if (!stream)
1219
+ throw new FS.ErrnoError(8); var ret = { parent: null, mount: { mountpoint: "fake" }, node_ops: { readlink: () => stream.path } }; ret.parent = ret; return ret; } }; return node; } }, {}, "/proc/self/fd"); }, createStandardStreams: () => { if (Module["stdin"]) {
1220
+ FS.createDevice("/dev", "stdin", Module["stdin"]);
1221
+ }
1222
+ else {
1223
+ FS.symlink("/dev/tty", "/dev/stdin");
1224
+ } if (Module["stdout"]) {
1225
+ FS.createDevice("/dev", "stdout", null, Module["stdout"]);
1226
+ }
1227
+ else {
1228
+ FS.symlink("/dev/tty", "/dev/stdout");
1229
+ } if (Module["stderr"]) {
1230
+ FS.createDevice("/dev", "stderr", null, Module["stderr"]);
1231
+ }
1232
+ else {
1233
+ FS.symlink("/dev/tty1", "/dev/stderr");
1234
+ } var stdin = FS.open("/dev/stdin", 0); var stdout = FS.open("/dev/stdout", 1); var stderr = FS.open("/dev/stderr", 1); }, ensureErrnoError: () => { if (FS.ErrnoError)
1235
+ return; FS.ErrnoError = function ErrnoError(errno, node) { this.name = "ErrnoError"; this.node = node; this.setErrno = function (errno) { this.errno = errno; }; this.setErrno(errno); this.message = "FS error"; }; FS.ErrnoError.prototype = new Error; FS.ErrnoError.prototype.constructor = FS.ErrnoError; [44].forEach(code => { FS.genericErrors[code] = new FS.ErrnoError(code); FS.genericErrors[code].stack = "<generic error, no stack>"; }); }, staticInit: () => { FS.ensureErrnoError(); FS.nameTable = new Array(4096); FS.mount(MEMFS, {}, "/"); FS.createDefaultDirectories(); FS.createDefaultDevices(); FS.createSpecialDirectories(); FS.filesystems = { "MEMFS": MEMFS, "NODEFS": NODEFS }; }, init: (input, output, error) => { FS.init.initialized = true; FS.ensureErrnoError(); Module["stdin"] = input || Module["stdin"]; Module["stdout"] = output || Module["stdout"]; Module["stderr"] = error || Module["stderr"]; FS.createStandardStreams(); }, quit: () => { FS.init.initialized = false; for (var i = 0; i < FS.streams.length; i++) {
1236
+ var stream = FS.streams[i];
1237
+ if (!stream) {
1238
+ continue;
1239
+ }
1240
+ FS.close(stream);
1241
+ } }, getMode: (canRead, canWrite) => { var mode = 0; if (canRead)
1242
+ mode |= 292 | 73; if (canWrite)
1243
+ mode |= 146; return mode; }, findObject: (path, dontResolveLastLink) => { var ret = FS.analyzePath(path, dontResolveLastLink); if (!ret.exists) {
1244
+ return null;
1245
+ } return ret.object; }, analyzePath: (path, dontResolveLastLink) => { try {
1246
+ var lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
1247
+ path = lookup.path;
1248
+ }
1249
+ catch (e) { } var ret = { isRoot: false, exists: false, error: 0, name: null, path: null, object: null, parentExists: false, parentPath: null, parentObject: null }; try {
1250
+ var lookup = FS.lookupPath(path, { parent: true });
1251
+ ret.parentExists = true;
1252
+ ret.parentPath = lookup.path;
1253
+ ret.parentObject = lookup.node;
1254
+ ret.name = PATH.basename(path);
1255
+ lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
1256
+ ret.exists = true;
1257
+ ret.path = lookup.path;
1258
+ ret.object = lookup.node;
1259
+ ret.name = lookup.node.name;
1260
+ ret.isRoot = lookup.path === "/";
1261
+ }
1262
+ catch (e) {
1263
+ ret.error = e.errno;
1264
+ } return ret; }, createPath: (parent, path, canRead, canWrite) => { parent = typeof parent == "string" ? parent : FS.getPath(parent); var parts = path.split("/").reverse(); while (parts.length) {
1265
+ var part = parts.pop();
1266
+ if (!part)
1267
+ continue;
1268
+ var current = PATH.join2(parent, part);
1269
+ try {
1270
+ FS.mkdir(current);
1271
+ }
1272
+ catch (e) { }
1273
+ parent = current;
1274
+ } return current; }, createFile: (parent, name, properties, canRead, canWrite) => { var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name); var mode = FS.getMode(canRead, canWrite); return FS.create(path, mode); }, createDataFile: (parent, name, data, canRead, canWrite, canOwn) => { var path = name; if (parent) {
1275
+ parent = typeof parent == "string" ? parent : FS.getPath(parent);
1276
+ path = name ? PATH.join2(parent, name) : parent;
1277
+ } var mode = FS.getMode(canRead, canWrite); var node = FS.create(path, mode); if (data) {
1278
+ if (typeof data == "string") {
1279
+ var arr = new Array(data.length);
1280
+ for (var i = 0, len = data.length; i < len; ++i)
1281
+ arr[i] = data.charCodeAt(i);
1282
+ data = arr;
1283
+ }
1284
+ FS.chmod(node, mode | 146);
1285
+ var stream = FS.open(node, 577);
1286
+ FS.write(stream, data, 0, data.length, 0, canOwn);
1287
+ FS.close(stream);
1288
+ FS.chmod(node, mode);
1289
+ } return node; }, createDevice: (parent, name, input, output) => { var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name); var mode = FS.getMode(!!input, !!output); if (!FS.createDevice.major)
1290
+ FS.createDevice.major = 64; var dev = FS.makedev(FS.createDevice.major++, 0); FS.registerDevice(dev, { open: stream => { stream.seekable = false; }, close: stream => { if (output && output.buffer && output.buffer.length) {
1291
+ output(10);
1292
+ } }, read: (stream, buffer, offset, length, pos) => { var bytesRead = 0; for (var i = 0; i < length; i++) {
1293
+ var result;
1294
+ try {
1295
+ result = input();
1296
+ }
1297
+ catch (e) {
1298
+ throw new FS.ErrnoError(29);
1299
+ }
1300
+ if (result === undefined && bytesRead === 0) {
1301
+ throw new FS.ErrnoError(6);
1302
+ }
1303
+ if (result === null || result === undefined)
1304
+ break;
1305
+ bytesRead++;
1306
+ buffer[offset + i] = result;
1307
+ } if (bytesRead) {
1308
+ stream.node.timestamp = Date.now();
1309
+ } return bytesRead; }, write: (stream, buffer, offset, length, pos) => { for (var i = 0; i < length; i++) {
1310
+ try {
1311
+ output(buffer[offset + i]);
1312
+ }
1313
+ catch (e) {
1314
+ throw new FS.ErrnoError(29);
1315
+ }
1316
+ } if (length) {
1317
+ stream.node.timestamp = Date.now();
1318
+ } return i; } }); return FS.mkdev(path, mode, dev); }, forceLoadFile: obj => { if (obj.isDevice || obj.isFolder || obj.link || obj.contents)
1319
+ return true; if (typeof XMLHttpRequest != "undefined") {
1320
+ throw new Error("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.");
1321
+ }
1322
+ else if (read_) {
1323
+ try {
1324
+ obj.contents = intArrayFromString(read_(obj.url), true);
1325
+ obj.usedBytes = obj.contents.length;
1326
+ }
1327
+ catch (e) {
1328
+ throw new FS.ErrnoError(29);
1329
+ }
1330
+ }
1331
+ else {
1332
+ throw new Error("Cannot load without read() or XMLHttpRequest.");
1333
+ } }, createLazyFile: (parent, name, url, canRead, canWrite) => { function LazyUint8Array() { this.lengthKnown = false; this.chunks = []; } LazyUint8Array.prototype.get = function LazyUint8Array_get(idx) { if (idx > this.length - 1 || idx < 0) {
1334
+ return undefined;
1335
+ } var chunkOffset = idx % this.chunkSize; var chunkNum = idx / this.chunkSize | 0; return this.getter(chunkNum)[chunkOffset]; }; LazyUint8Array.prototype.setDataGetter = function LazyUint8Array_setDataGetter(getter) { this.getter = getter; }; LazyUint8Array.prototype.cacheLength = function LazyUint8Array_cacheLength() { var xhr = new XMLHttpRequest; xhr.open("HEAD", url, false); xhr.send(null); if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304))
1336
+ throw new Error("Couldn't load " + url + ". Status: " + xhr.status); var datalength = Number(xhr.getResponseHeader("Content-length")); var header; var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes"; var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip"; var chunkSize = 1024 * 1024; if (!hasByteServing)
1337
+ chunkSize = datalength; var doXHR = (from, to) => { if (from > to)
1338
+ throw new Error("invalid range (" + from + ", " + to + ") or no bytes requested!"); if (to > datalength - 1)
1339
+ throw new Error("only " + datalength + " bytes available! programmer error!"); var xhr = new XMLHttpRequest; xhr.open("GET", url, false); if (datalength !== chunkSize)
1340
+ xhr.setRequestHeader("Range", "bytes=" + from + "-" + to); xhr.responseType = "arraybuffer"; if (xhr.overrideMimeType) {
1341
+ xhr.overrideMimeType("text/plain; charset=x-user-defined");
1342
+ } xhr.send(null); if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304))
1343
+ throw new Error("Couldn't load " + url + ". Status: " + xhr.status); if (xhr.response !== undefined) {
1344
+ return new Uint8Array(xhr.response || []);
1345
+ } return intArrayFromString(xhr.responseText || "", true); }; var lazyArray = this; lazyArray.setDataGetter(chunkNum => { var start = chunkNum * chunkSize; var end = (chunkNum + 1) * chunkSize - 1; end = Math.min(end, datalength - 1); if (typeof lazyArray.chunks[chunkNum] == "undefined") {
1346
+ lazyArray.chunks[chunkNum] = doXHR(start, end);
1347
+ } if (typeof lazyArray.chunks[chunkNum] == "undefined")
1348
+ throw new Error("doXHR failed!"); return lazyArray.chunks[chunkNum]; }); if (usesGzip || !datalength) {
1349
+ chunkSize = datalength = 1;
1350
+ datalength = this.getter(0).length;
1351
+ chunkSize = datalength;
1352
+ out("LazyFiles on gzip forces download of the whole file when length is accessed");
1353
+ } this._length = datalength; this._chunkSize = chunkSize; this.lengthKnown = true; }; if (typeof XMLHttpRequest != "undefined") {
1354
+ if (!ENVIRONMENT_IS_WORKER)
1355
+ throw "Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";
1356
+ var lazyArray = new LazyUint8Array;
1357
+ Object.defineProperties(lazyArray, { length: { get: function () { if (!this.lengthKnown) {
1358
+ this.cacheLength();
1359
+ } return this._length; } }, chunkSize: { get: function () { if (!this.lengthKnown) {
1360
+ this.cacheLength();
1361
+ } return this._chunkSize; } } });
1362
+ var properties = { isDevice: false, contents: lazyArray };
1363
+ }
1364
+ else {
1365
+ var properties = { isDevice: false, url: url };
1366
+ } var node = FS.createFile(parent, name, properties, canRead, canWrite); if (properties.contents) {
1367
+ node.contents = properties.contents;
1368
+ }
1369
+ else if (properties.url) {
1370
+ node.contents = null;
1371
+ node.url = properties.url;
1372
+ } Object.defineProperties(node, { usedBytes: { get: function () { return this.contents.length; } } }); var stream_ops = {}; var keys = Object.keys(node.stream_ops); keys.forEach(key => { var fn = node.stream_ops[key]; stream_ops[key] = function forceLoadLazyFile() { FS.forceLoadFile(node); return fn.apply(null, arguments); }; }); function writeChunks(stream, buffer, offset, length, position) { var contents = stream.node.contents; if (position >= contents.length)
1373
+ return 0; var size = Math.min(contents.length - position, length); if (contents.slice) {
1374
+ for (var i = 0; i < size; i++) {
1375
+ buffer[offset + i] = contents[position + i];
1376
+ }
1377
+ }
1378
+ else {
1379
+ for (var i = 0; i < size; i++) {
1380
+ buffer[offset + i] = contents.get(position + i);
1381
+ }
1382
+ } return size; } stream_ops.read = (stream, buffer, offset, length, position) => { FS.forceLoadFile(node); return writeChunks(stream, buffer, offset, length, position); }; stream_ops.mmap = (stream, length, position, prot, flags) => { FS.forceLoadFile(node); var ptr = mmapAlloc(length); if (!ptr) {
1383
+ throw new FS.ErrnoError(48);
1384
+ } writeChunks(stream, HEAP8, ptr, length, position); return { ptr: ptr, allocated: true }; }; node.stream_ops = stream_ops; return node; }, createPreloadedFile: (parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) => { var fullname = name ? PATH_FS.resolve(PATH.join2(parent, name)) : parent; var dep = getUniqueRunDependency("cp " + fullname); function processData(byteArray) { function finish(byteArray) { if (preFinish)
1385
+ preFinish(); if (!dontCreateFile) {
1386
+ FS.createDataFile(parent, name, byteArray, canRead, canWrite, canOwn);
1387
+ } if (onload)
1388
+ onload(); removeRunDependency(dep); } if (Browser.handledByPreloadPlugin(byteArray, fullname, finish, () => { if (onerror)
1389
+ onerror(); removeRunDependency(dep); })) {
1390
+ return;
1391
+ } finish(byteArray); } addRunDependency(dep); if (typeof url == "string") {
1392
+ asyncLoad(url, byteArray => processData(byteArray), onerror);
1393
+ }
1394
+ else {
1395
+ processData(url);
1396
+ } }, indexedDB: () => { return window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB; }, DB_NAME: () => { return "EM_FS_" + window.location.pathname; }, DB_VERSION: 20, DB_STORE_NAME: "FILE_DATA", saveFilesToDB: (paths, onload = (() => { }), onerror = (() => { })) => { var indexedDB = FS.indexedDB(); try {
1397
+ var openRequest = indexedDB.open(FS.DB_NAME(), FS.DB_VERSION);
1398
+ }
1399
+ catch (e) {
1400
+ return onerror(e);
1401
+ } openRequest.onupgradeneeded = () => { out("creating db"); var db = openRequest.result; db.createObjectStore(FS.DB_STORE_NAME); }; openRequest.onsuccess = () => { var db = openRequest.result; var transaction = db.transaction([FS.DB_STORE_NAME], "readwrite"); var files = transaction.objectStore(FS.DB_STORE_NAME); var ok = 0, fail = 0, total = paths.length; function finish() { if (fail == 0)
1402
+ onload();
1403
+ else
1404
+ onerror(); } paths.forEach(path => { var putRequest = files.put(FS.analyzePath(path).object.contents, path); putRequest.onsuccess = () => { ok++; if (ok + fail == total)
1405
+ finish(); }; putRequest.onerror = () => { fail++; if (ok + fail == total)
1406
+ finish(); }; }); transaction.onerror = onerror; }; openRequest.onerror = onerror; }, loadFilesFromDB: (paths, onload = (() => { }), onerror = (() => { })) => { var indexedDB = FS.indexedDB(); try {
1407
+ var openRequest = indexedDB.open(FS.DB_NAME(), FS.DB_VERSION);
1408
+ }
1409
+ catch (e) {
1410
+ return onerror(e);
1411
+ } openRequest.onupgradeneeded = onerror; openRequest.onsuccess = () => { var db = openRequest.result; try {
1412
+ var transaction = db.transaction([FS.DB_STORE_NAME], "readonly");
1413
+ }
1414
+ catch (e) {
1415
+ onerror(e);
1416
+ return;
1417
+ } var files = transaction.objectStore(FS.DB_STORE_NAME); var ok = 0, fail = 0, total = paths.length; function finish() { if (fail == 0)
1418
+ onload();
1419
+ else
1420
+ onerror(); } paths.forEach(path => { var getRequest = files.get(path); getRequest.onsuccess = () => { if (FS.analyzePath(path).exists) {
1421
+ FS.unlink(path);
1422
+ } FS.createDataFile(PATH.dirname(path), PATH.basename(path), getRequest.result, true, true, true); ok++; if (ok + fail == total)
1423
+ finish(); }; getRequest.onerror = () => { fail++; if (ok + fail == total)
1424
+ finish(); }; }); transaction.onerror = onerror; }; openRequest.onerror = onerror; } };
1425
+ var SYSCALLS = { DEFAULT_POLLMASK: 5, calculateAt: function (dirfd, path, allowEmpty) { if (PATH.isAbs(path)) {
1426
+ return path;
1427
+ } var dir; if (dirfd === -100) {
1428
+ dir = FS.cwd();
1429
+ }
1430
+ else {
1431
+ var dirstream = SYSCALLS.getStreamFromFD(dirfd);
1432
+ dir = dirstream.path;
1433
+ } if (path.length == 0) {
1434
+ if (!allowEmpty) {
1435
+ throw new FS.ErrnoError(44);
1436
+ }
1437
+ return dir;
1438
+ } return PATH.join2(dir, path); }, doStat: function (func, path, buf) { try {
1439
+ var stat = func(path);
1440
+ }
1441
+ catch (e) {
1442
+ if (e && e.node && PATH.normalize(path) !== PATH.normalize(FS.getPath(e.node))) {
1443
+ return -54;
1444
+ }
1445
+ throw e;
1446
+ } HEAP32[buf >> 2] = stat.dev; HEAP32[buf + 8 >> 2] = stat.ino; HEAP32[buf + 12 >> 2] = stat.mode; HEAPU32[buf + 16 >> 2] = stat.nlink; HEAP32[buf + 20 >> 2] = stat.uid; HEAP32[buf + 24 >> 2] = stat.gid; HEAP32[buf + 28 >> 2] = stat.rdev; tempI64 = [stat.size >>> 0, (tempDouble = stat.size, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? (Math.min(+Math.floor(tempDouble / 4294967296), 4294967295) | 0) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 40 >> 2] = tempI64[0], HEAP32[buf + 44 >> 2] = tempI64[1]; HEAP32[buf + 48 >> 2] = 4096; HEAP32[buf + 52 >> 2] = stat.blocks; var atime = stat.atime.getTime(); var mtime = stat.mtime.getTime(); var ctime = stat.ctime.getTime(); tempI64 = [Math.floor(atime / 1e3) >>> 0, (tempDouble = Math.floor(atime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? (Math.min(+Math.floor(tempDouble / 4294967296), 4294967295) | 0) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 56 >> 2] = tempI64[0], HEAP32[buf + 60 >> 2] = tempI64[1]; HEAPU32[buf + 64 >> 2] = atime % 1e3 * 1e3; tempI64 = [Math.floor(mtime / 1e3) >>> 0, (tempDouble = Math.floor(mtime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? (Math.min(+Math.floor(tempDouble / 4294967296), 4294967295) | 0) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 72 >> 2] = tempI64[0], HEAP32[buf + 76 >> 2] = tempI64[1]; HEAPU32[buf + 80 >> 2] = mtime % 1e3 * 1e3; tempI64 = [Math.floor(ctime / 1e3) >>> 0, (tempDouble = Math.floor(ctime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? (Math.min(+Math.floor(tempDouble / 4294967296), 4294967295) | 0) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 88 >> 2] = tempI64[0], HEAP32[buf + 92 >> 2] = tempI64[1]; HEAPU32[buf + 96 >> 2] = ctime % 1e3 * 1e3; tempI64 = [stat.ino >>> 0, (tempDouble = stat.ino, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? (Math.min(+Math.floor(tempDouble / 4294967296), 4294967295) | 0) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 104 >> 2] = tempI64[0], HEAP32[buf + 108 >> 2] = tempI64[1]; return 0; }, doMsync: function (addr, stream, len, flags, offset) { if (!FS.isFile(stream.node.mode)) {
1447
+ throw new FS.ErrnoError(43);
1448
+ } if (flags & 2) {
1449
+ return 0;
1450
+ } var buffer = HEAPU8.slice(addr, addr + len); FS.msync(stream, buffer, offset, len, flags); }, varargs: undefined, get: function () { SYSCALLS.varargs += 4; var ret = HEAP32[SYSCALLS.varargs - 4 >> 2]; return ret; }, getStr: function (ptr) { var ret = UTF8ToString(ptr); return ret; }, getStreamFromFD: function (fd) { var stream = FS.getStream(fd); if (!stream)
1451
+ throw new FS.ErrnoError(8); return stream; } };
1452
+ function ___syscall_faccessat(dirfd, path, amode, flags) { try {
1453
+ path = SYSCALLS.getStr(path);
1454
+ path = SYSCALLS.calculateAt(dirfd, path);
1455
+ if (amode & ~7) {
1456
+ return -28;
1457
+ }
1458
+ var lookup = FS.lookupPath(path, { follow: true });
1459
+ var node = lookup.node;
1460
+ if (!node) {
1461
+ return -44;
1462
+ }
1463
+ var perms = "";
1464
+ if (amode & 4)
1465
+ perms += "r";
1466
+ if (amode & 2)
1467
+ perms += "w";
1468
+ if (amode & 1)
1469
+ perms += "x";
1470
+ if (perms && FS.nodePermissions(node, perms)) {
1471
+ return -2;
1472
+ }
1473
+ return 0;
1474
+ }
1475
+ catch (e) {
1476
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1477
+ throw e;
1478
+ return -e.errno;
1479
+ } }
1480
+ function setErrNo(value) { HEAP32[___errno_location() >> 2] = value; return value; }
1481
+ function ___syscall_fcntl64(fd, cmd, varargs) { SYSCALLS.varargs = varargs; try {
1482
+ var stream = SYSCALLS.getStreamFromFD(fd);
1483
+ switch (cmd) {
1484
+ case 0: {
1485
+ var arg = SYSCALLS.get();
1486
+ if (arg < 0) {
1487
+ return -28;
1488
+ }
1489
+ var newStream;
1490
+ newStream = FS.createStream(stream, arg);
1491
+ return newStream.fd;
1492
+ }
1493
+ case 1:
1494
+ case 2: return 0;
1495
+ case 3: return stream.flags;
1496
+ case 4: {
1497
+ var arg = SYSCALLS.get();
1498
+ stream.flags |= arg;
1499
+ return 0;
1500
+ }
1501
+ case 5: {
1502
+ var arg = SYSCALLS.get();
1503
+ var offset = 0;
1504
+ HEAP16[arg + offset >> 1] = 2;
1505
+ return 0;
1506
+ }
1507
+ case 6:
1508
+ case 7: return 0;
1509
+ case 16:
1510
+ case 8: return -28;
1511
+ case 9:
1512
+ setErrNo(28);
1513
+ return -1;
1514
+ default: {
1515
+ return -28;
1516
+ }
1517
+ }
1518
+ }
1519
+ catch (e) {
1520
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1521
+ throw e;
1522
+ return -e.errno;
1523
+ } }
1524
+ function ___syscall_ioctl(fd, op, varargs) { SYSCALLS.varargs = varargs; try {
1525
+ var stream = SYSCALLS.getStreamFromFD(fd);
1526
+ switch (op) {
1527
+ case 21509:
1528
+ case 21505: {
1529
+ if (!stream.tty)
1530
+ return -59;
1531
+ return 0;
1532
+ }
1533
+ case 21510:
1534
+ case 21511:
1535
+ case 21512:
1536
+ case 21506:
1537
+ case 21507:
1538
+ case 21508: {
1539
+ if (!stream.tty)
1540
+ return -59;
1541
+ return 0;
1542
+ }
1543
+ case 21519: {
1544
+ if (!stream.tty)
1545
+ return -59;
1546
+ var argp = SYSCALLS.get();
1547
+ HEAP32[argp >> 2] = 0;
1548
+ return 0;
1549
+ }
1550
+ case 21520: {
1551
+ if (!stream.tty)
1552
+ return -59;
1553
+ return -28;
1554
+ }
1555
+ case 21531: {
1556
+ var argp = SYSCALLS.get();
1557
+ return FS.ioctl(stream, op, argp);
1558
+ }
1559
+ case 21523: {
1560
+ if (!stream.tty)
1561
+ return -59;
1562
+ return 0;
1563
+ }
1564
+ case 21524: {
1565
+ if (!stream.tty)
1566
+ return -59;
1567
+ return 0;
1568
+ }
1569
+ default: return -28;
1570
+ }
1571
+ }
1572
+ catch (e) {
1573
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1574
+ throw e;
1575
+ return -e.errno;
1576
+ } }
1577
+ function ___syscall_openat(dirfd, path, flags, varargs) { SYSCALLS.varargs = varargs; try {
1578
+ path = SYSCALLS.getStr(path);
1579
+ path = SYSCALLS.calculateAt(dirfd, path);
1580
+ var mode = varargs ? SYSCALLS.get() : 0;
1581
+ return FS.open(path, flags, mode).fd;
1582
+ }
1583
+ catch (e) {
1584
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1585
+ throw e;
1586
+ return -e.errno;
1587
+ } }
1588
+ function ___syscall_rmdir(path) { try {
1589
+ path = SYSCALLS.getStr(path);
1590
+ FS.rmdir(path);
1591
+ return 0;
1592
+ }
1593
+ catch (e) {
1594
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1595
+ throw e;
1596
+ return -e.errno;
1597
+ } }
1598
+ function ___syscall_unlinkat(dirfd, path, flags) { try {
1599
+ path = SYSCALLS.getStr(path);
1600
+ path = SYSCALLS.calculateAt(dirfd, path);
1601
+ if (flags === 0) {
1602
+ FS.unlink(path);
1603
+ }
1604
+ else if (flags === 512) {
1605
+ FS.rmdir(path);
1606
+ }
1607
+ else {
1608
+ abort("Invalid flags passed to unlinkat");
1609
+ }
1610
+ return 0;
1611
+ }
1612
+ catch (e) {
1613
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1614
+ throw e;
1615
+ return -e.errno;
1616
+ } }
1617
+ var nowIsMonotonic = true;
1618
+ function __emscripten_get_now_is_monotonic() { return nowIsMonotonic; }
1619
+ function _abort() { abort(""); }
1620
+ var readEmAsmArgsArray = [];
1621
+ function readEmAsmArgs(sigPtr, buf) { readEmAsmArgsArray.length = 0; var ch; buf >>= 2; while (ch = HEAPU8[sigPtr++]) {
1622
+ buf += ch != 105 & buf;
1623
+ readEmAsmArgsArray.push(ch == 105 ? HEAP32[buf] : HEAPF64[buf++ >> 1]);
1624
+ ++buf;
1625
+ } return readEmAsmArgsArray; }
1626
+ function runEmAsmFunction(code, sigPtr, argbuf) { var args = readEmAsmArgs(sigPtr, argbuf); return ASM_CONSTS[code].apply(null, args); }
1627
+ function _emscripten_asm_const_int(code, sigPtr, argbuf) { return runEmAsmFunction(code, sigPtr, argbuf); }
1628
+ function _emscripten_date_now() { return Date.now(); }
1629
+ var _emscripten_get_now;
1630
+ if (ENVIRONMENT_IS_NODE) {
1631
+ _emscripten_get_now = () => { var t = process.hrtime(); return t[0] * 1e3 + t[1] / 1e6; };
1632
+ }
1633
+ else
1634
+ _emscripten_get_now = () => performance.now();
1635
+ function _emscripten_memcpy_big(dest, src, num) { HEAPU8.copyWithin(dest, src, src + num); }
1636
+ function abortOnCannotGrowMemory(requestedSize) { abort("OOM"); }
1637
+ function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length; requestedSize = requestedSize >>> 0; abortOnCannotGrowMemory(requestedSize); }
1638
+ var ENV = {};
1639
+ function getExecutableName() { return thisProgram || "./this.program"; }
1640
+ function getEnvStrings() { if (!getEnvStrings.strings) {
1641
+ var lang = (typeof navigator == "object" && navigator.languages && navigator.languages[0] || "C").replace("-", "_") + ".UTF-8";
1642
+ var env = { "USER": "web_user", "LOGNAME": "web_user", "PATH": "/", "PWD": "/", "HOME": "/home/web_user", "LANG": lang, "_": getExecutableName() };
1643
+ for (var x in ENV) {
1644
+ if (ENV[x] === undefined)
1645
+ delete env[x];
1646
+ else
1647
+ env[x] = ENV[x];
1648
+ }
1649
+ var strings = [];
1650
+ for (var x in env) {
1651
+ strings.push(x + "=" + env[x]);
1652
+ }
1653
+ getEnvStrings.strings = strings;
1654
+ } return getEnvStrings.strings; }
1655
+ function writeAsciiToMemory(str, buffer, dontAddNull) { for (var i = 0; i < str.length; ++i) {
1656
+ HEAP8[buffer++ >> 0] = str.charCodeAt(i);
1657
+ } if (!dontAddNull)
1658
+ HEAP8[buffer >> 0] = 0; }
1659
+ function _environ_get(__environ, environ_buf) { var bufSize = 0; getEnvStrings().forEach(function (string, i) { var ptr = environ_buf + bufSize; HEAPU32[__environ + i * 4 >> 2] = ptr; writeAsciiToMemory(string, ptr); bufSize += string.length + 1; }); return 0; }
1660
+ function _environ_sizes_get(penviron_count, penviron_buf_size) { var strings = getEnvStrings(); HEAPU32[penviron_count >> 2] = strings.length; var bufSize = 0; strings.forEach(function (string) { bufSize += string.length + 1; }); HEAPU32[penviron_buf_size >> 2] = bufSize; return 0; }
1661
+ function _fd_close(fd) { try {
1662
+ var stream = SYSCALLS.getStreamFromFD(fd);
1663
+ FS.close(stream);
1664
+ return 0;
1665
+ }
1666
+ catch (e) {
1667
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1668
+ throw e;
1669
+ return e.errno;
1670
+ } }
1671
+ function doReadv(stream, iov, iovcnt, offset) { var ret = 0; for (var i = 0; i < iovcnt; i++) {
1672
+ var ptr = HEAPU32[iov >> 2];
1673
+ var len = HEAPU32[iov + 4 >> 2];
1674
+ iov += 8;
1675
+ var curr = FS.read(stream, HEAP8, ptr, len, offset);
1676
+ if (curr < 0)
1677
+ return -1;
1678
+ ret += curr;
1679
+ if (curr < len)
1680
+ break;
1681
+ if (typeof offset !== "undefined") {
1682
+ offset += curr;
1683
+ }
1684
+ } return ret; }
1685
+ function _fd_read(fd, iov, iovcnt, pnum) { try {
1686
+ var stream = SYSCALLS.getStreamFromFD(fd);
1687
+ var num = doReadv(stream, iov, iovcnt);
1688
+ HEAPU32[pnum >> 2] = num;
1689
+ return 0;
1690
+ }
1691
+ catch (e) {
1692
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1693
+ throw e;
1694
+ return e.errno;
1695
+ } }
1696
+ function convertI32PairToI53Checked(lo, hi) { return hi + 2097152 >>> 0 < 4194305 - !!lo ? (lo >>> 0) + hi * 4294967296 : NaN; }
1697
+ function _fd_seek(fd, offset_low, offset_high, whence, newOffset) { try {
1698
+ var offset = convertI32PairToI53Checked(offset_low, offset_high);
1699
+ if (isNaN(offset))
1700
+ return 61;
1701
+ var stream = SYSCALLS.getStreamFromFD(fd);
1702
+ FS.llseek(stream, offset, whence);
1703
+ tempI64 = [stream.position >>> 0, (tempDouble = stream.position, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? (Math.min(+Math.floor(tempDouble / 4294967296), 4294967295) | 0) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[newOffset >> 2] = tempI64[0], HEAP32[newOffset + 4 >> 2] = tempI64[1];
1704
+ if (stream.getdents && offset === 0 && whence === 0)
1705
+ stream.getdents = null;
1706
+ return 0;
1707
+ }
1708
+ catch (e) {
1709
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1710
+ throw e;
1711
+ return e.errno;
1712
+ } }
1713
+ function doWritev(stream, iov, iovcnt, offset) { var ret = 0; for (var i = 0; i < iovcnt; i++) {
1714
+ var ptr = HEAPU32[iov >> 2];
1715
+ var len = HEAPU32[iov + 4 >> 2];
1716
+ iov += 8;
1717
+ var curr = FS.write(stream, HEAP8, ptr, len, offset);
1718
+ if (curr < 0)
1719
+ return -1;
1720
+ ret += curr;
1721
+ if (typeof offset !== "undefined") {
1722
+ offset += curr;
1723
+ }
1724
+ } return ret; }
1725
+ function _fd_write(fd, iov, iovcnt, pnum) { try {
1726
+ var stream = SYSCALLS.getStreamFromFD(fd);
1727
+ var num = doWritev(stream, iov, iovcnt);
1728
+ HEAPU32[pnum >> 2] = num;
1729
+ return 0;
1730
+ }
1731
+ catch (e) {
1732
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
1733
+ throw e;
1734
+ return e.errno;
1735
+ } }
1736
+ function __isLeapYear(year) { return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0); }
1737
+ function __arraySum(array, index) { var sum = 0; for (var i = 0; i <= index; sum += array[i++]) { } return sum; }
1738
+ var __MONTH_DAYS_LEAP = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
1739
+ var __MONTH_DAYS_REGULAR = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
1740
+ function __addDays(date, days) { var newDate = new Date(date.getTime()); while (days > 0) {
1741
+ var leap = __isLeapYear(newDate.getFullYear());
1742
+ var currentMonth = newDate.getMonth();
1743
+ var daysInCurrentMonth = (leap ? __MONTH_DAYS_LEAP : __MONTH_DAYS_REGULAR)[currentMonth];
1744
+ if (days > daysInCurrentMonth - newDate.getDate()) {
1745
+ days -= daysInCurrentMonth - newDate.getDate() + 1;
1746
+ newDate.setDate(1);
1747
+ if (currentMonth < 11) {
1748
+ newDate.setMonth(currentMonth + 1);
1749
+ }
1750
+ else {
1751
+ newDate.setMonth(0);
1752
+ newDate.setFullYear(newDate.getFullYear() + 1);
1753
+ }
1754
+ }
1755
+ else {
1756
+ newDate.setDate(newDate.getDate() + days);
1757
+ return newDate;
1758
+ }
1759
+ } return newDate; }
1760
+ function writeArrayToMemory(array, buffer) { HEAP8.set(array, buffer); }
1761
+ function _strftime(s, maxsize, format, tm) { var tm_zone = HEAP32[tm + 40 >> 2]; var date = { tm_sec: HEAP32[tm >> 2], tm_min: HEAP32[tm + 4 >> 2], tm_hour: HEAP32[tm + 8 >> 2], tm_mday: HEAP32[tm + 12 >> 2], tm_mon: HEAP32[tm + 16 >> 2], tm_year: HEAP32[tm + 20 >> 2], tm_wday: HEAP32[tm + 24 >> 2], tm_yday: HEAP32[tm + 28 >> 2], tm_isdst: HEAP32[tm + 32 >> 2], tm_gmtoff: HEAP32[tm + 36 >> 2], tm_zone: tm_zone ? UTF8ToString(tm_zone) : "" }; var pattern = UTF8ToString(format); var EXPANSION_RULES_1 = { "%c": "%a %b %d %H:%M:%S %Y", "%D": "%m/%d/%y", "%F": "%Y-%m-%d", "%h": "%b", "%r": "%I:%M:%S %p", "%R": "%H:%M", "%T": "%H:%M:%S", "%x": "%m/%d/%y", "%X": "%H:%M:%S", "%Ec": "%c", "%EC": "%C", "%Ex": "%m/%d/%y", "%EX": "%H:%M:%S", "%Ey": "%y", "%EY": "%Y", "%Od": "%d", "%Oe": "%e", "%OH": "%H", "%OI": "%I", "%Om": "%m", "%OM": "%M", "%OS": "%S", "%Ou": "%u", "%OU": "%U", "%OV": "%V", "%Ow": "%w", "%OW": "%W", "%Oy": "%y" }; for (var rule in EXPANSION_RULES_1) {
1762
+ pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_1[rule]);
1763
+ } var WEEKDAYS = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]; var MONTHS = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]; function leadingSomething(value, digits, character) { var str = typeof value == "number" ? value.toString() : value || ""; while (str.length < digits) {
1764
+ str = character[0] + str;
1765
+ } return str; } function leadingNulls(value, digits) { return leadingSomething(value, digits, "0"); } function compareByDay(date1, date2) { function sgn(value) { return value < 0 ? -1 : value > 0 ? 1 : 0; } var compare; if ((compare = sgn(date1.getFullYear() - date2.getFullYear())) === 0) {
1766
+ if ((compare = sgn(date1.getMonth() - date2.getMonth())) === 0) {
1767
+ compare = sgn(date1.getDate() - date2.getDate());
1768
+ }
1769
+ } return compare; } function getFirstWeekStartDate(janFourth) { switch (janFourth.getDay()) {
1770
+ case 0: return new Date(janFourth.getFullYear() - 1, 11, 29);
1771
+ case 1: return janFourth;
1772
+ case 2: return new Date(janFourth.getFullYear(), 0, 3);
1773
+ case 3: return new Date(janFourth.getFullYear(), 0, 2);
1774
+ case 4: return new Date(janFourth.getFullYear(), 0, 1);
1775
+ case 5: return new Date(janFourth.getFullYear() - 1, 11, 31);
1776
+ case 6: return new Date(janFourth.getFullYear() - 1, 11, 30);
1777
+ } } function getWeekBasedYear(date) { var thisDate = __addDays(new Date(date.tm_year + 1900, 0, 1), date.tm_yday); var janFourthThisYear = new Date(thisDate.getFullYear(), 0, 4); var janFourthNextYear = new Date(thisDate.getFullYear() + 1, 0, 4); var firstWeekStartThisYear = getFirstWeekStartDate(janFourthThisYear); var firstWeekStartNextYear = getFirstWeekStartDate(janFourthNextYear); if (compareByDay(firstWeekStartThisYear, thisDate) <= 0) {
1778
+ if (compareByDay(firstWeekStartNextYear, thisDate) <= 0) {
1779
+ return thisDate.getFullYear() + 1;
1780
+ }
1781
+ return thisDate.getFullYear();
1782
+ } return thisDate.getFullYear() - 1; } var EXPANSION_RULES_2 = { "%a": function (date) { return WEEKDAYS[date.tm_wday].substring(0, 3); }, "%A": function (date) { return WEEKDAYS[date.tm_wday]; }, "%b": function (date) { return MONTHS[date.tm_mon].substring(0, 3); }, "%B": function (date) { return MONTHS[date.tm_mon]; }, "%C": function (date) { var year = date.tm_year + 1900; return leadingNulls(year / 100 | 0, 2); }, "%d": function (date) { return leadingNulls(date.tm_mday, 2); }, "%e": function (date) { return leadingSomething(date.tm_mday, 2, " "); }, "%g": function (date) { return getWeekBasedYear(date).toString().substring(2); }, "%G": function (date) { return getWeekBasedYear(date); }, "%H": function (date) { return leadingNulls(date.tm_hour, 2); }, "%I": function (date) { var twelveHour = date.tm_hour; if (twelveHour == 0)
1783
+ twelveHour = 12;
1784
+ else if (twelveHour > 12)
1785
+ twelveHour -= 12; return leadingNulls(twelveHour, 2); }, "%j": function (date) { return leadingNulls(date.tm_mday + __arraySum(__isLeapYear(date.tm_year + 1900) ? __MONTH_DAYS_LEAP : __MONTH_DAYS_REGULAR, date.tm_mon - 1), 3); }, "%m": function (date) { return leadingNulls(date.tm_mon + 1, 2); }, "%M": function (date) { return leadingNulls(date.tm_min, 2); }, "%n": function () { return "\n"; }, "%p": function (date) { if (date.tm_hour >= 0 && date.tm_hour < 12) {
1786
+ return "AM";
1787
+ } return "PM"; }, "%S": function (date) { return leadingNulls(date.tm_sec, 2); }, "%t": function () { return "\t"; }, "%u": function (date) { return date.tm_wday || 7; }, "%U": function (date) { var days = date.tm_yday + 7 - date.tm_wday; return leadingNulls(Math.floor(days / 7), 2); }, "%V": function (date) { var val = Math.floor((date.tm_yday + 7 - (date.tm_wday + 6) % 7) / 7); if ((date.tm_wday + 371 - date.tm_yday - 2) % 7 <= 2) {
1788
+ val++;
1789
+ } if (!val) {
1790
+ val = 52;
1791
+ var dec31 = (date.tm_wday + 7 - date.tm_yday - 1) % 7;
1792
+ if (dec31 == 4 || dec31 == 5 && __isLeapYear(date.tm_year % 400 - 1)) {
1793
+ val++;
1794
+ }
1795
+ }
1796
+ else if (val == 53) {
1797
+ var jan1 = (date.tm_wday + 371 - date.tm_yday) % 7;
1798
+ if (jan1 != 4 && (jan1 != 3 || !__isLeapYear(date.tm_year)))
1799
+ val = 1;
1800
+ } return leadingNulls(val, 2); }, "%w": function (date) { return date.tm_wday; }, "%W": function (date) { var days = date.tm_yday + 7 - (date.tm_wday + 6) % 7; return leadingNulls(Math.floor(days / 7), 2); }, "%y": function (date) { return (date.tm_year + 1900).toString().substring(2); }, "%Y": function (date) { return date.tm_year + 1900; }, "%z": function (date) { var off = date.tm_gmtoff; var ahead = off >= 0; off = Math.abs(off) / 60; off = off / 60 * 100 + off % 60; return (ahead ? "+" : "-") + String("0000" + off).slice(-4); }, "%Z": function (date) { return date.tm_zone; }, "%%": function () { return "%"; } }; pattern = pattern.replace(/%%/g, "\0\0"); for (var rule in EXPANSION_RULES_2) {
1801
+ if (pattern.includes(rule)) {
1802
+ pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_2[rule](date));
1803
+ }
1804
+ } pattern = pattern.replace(/\0\0/g, "%"); var bytes = intArrayFromString(pattern, false); if (bytes.length > maxsize) {
1805
+ return 0;
1806
+ } writeArrayToMemory(bytes, s); return bytes.length - 1; }
1807
+ function _strftime_l(s, maxsize, format, tm, loc) { return _strftime(s, maxsize, format, tm); }
1808
+ function getCFunc(ident) { var func = Module["_" + ident]; return func; }
1809
+ function ccall(ident, returnType, argTypes, args, opts) { var toC = { "string": str => { var ret = 0; if (str !== null && str !== undefined && str !== 0) {
1810
+ var len = (str.length << 2) + 1;
1811
+ ret = stackAlloc(len);
1812
+ stringToUTF8(str, ret, len);
1813
+ } return ret; }, "array": arr => { var ret = stackAlloc(arr.length); writeArrayToMemory(arr, ret); return ret; } }; function convertReturnValue(ret) { if (returnType === "string") {
1814
+ return UTF8ToString(ret);
1815
+ } if (returnType === "boolean")
1816
+ return Boolean(ret); return ret; } var func = getCFunc(ident); var cArgs = []; var stack = 0; if (args) {
1817
+ for (var i = 0; i < args.length; i++) {
1818
+ var converter = toC[argTypes[i]];
1819
+ if (converter) {
1820
+ if (stack === 0)
1821
+ stack = stackSave();
1822
+ cArgs[i] = converter(args[i]);
1823
+ }
1824
+ else {
1825
+ cArgs[i] = args[i];
1826
+ }
1827
+ }
1828
+ } var ret = func.apply(null, cArgs); function onDone(ret) { if (stack !== 0)
1829
+ stackRestore(stack); return convertReturnValue(ret); } ret = onDone(ret); return ret; }
1830
+ function cwrap(ident, returnType, argTypes, opts) { var numericArgs = !argTypes || argTypes.every(type => type === "number" || type === "boolean"); var numericRet = returnType !== "string"; if (numericRet && numericArgs && !opts) {
1831
+ return getCFunc(ident);
1832
+ } return function () { return ccall(ident, returnType, argTypes, arguments, opts); }; }
1833
+ var FSNode = function (parent, name, mode, rdev) { if (!parent) {
1834
+ parent = this;
1835
+ } this.parent = parent; this.mount = parent.mount; this.mounted = null; this.id = FS.nextInode++; this.name = name; this.mode = mode; this.node_ops = {}; this.stream_ops = {}; this.rdev = rdev; };
1836
+ var readMode = 292 | 73;
1837
+ var writeMode = 146;
1838
+ Object.defineProperties(FSNode.prototype, { read: { get: function () { return (this.mode & readMode) === readMode; }, set: function (val) { val ? this.mode |= readMode : this.mode &= ~readMode; } }, write: { get: function () { return (this.mode & writeMode) === writeMode; }, set: function (val) { val ? this.mode |= writeMode : this.mode &= ~writeMode; } }, isFolder: { get: function () { return FS.isDir(this.mode); } }, isDevice: { get: function () { return FS.isChrdev(this.mode); } } });
1839
+ FS.FSNode = FSNode;
1840
+ FS.staticInit();
1841
+ if (ENVIRONMENT_IS_NODE) {
1842
+ NODEFS.staticInit();
1843
+ }
1844
+ 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 };
1845
+ var wasmImports = { "__assert_fail": ___assert_fail, "__cxa_throw": ___cxa_throw, "__syscall_faccessat": ___syscall_faccessat, "__syscall_fcntl64": ___syscall_fcntl64, "__syscall_ioctl": ___syscall_ioctl, "__syscall_openat": ___syscall_openat, "__syscall_rmdir": ___syscall_rmdir, "__syscall_unlinkat": ___syscall_unlinkat, "_emscripten_get_now_is_monotonic": __emscripten_get_now_is_monotonic, "abort": _abort, "emscripten_asm_const_int": _emscripten_asm_const_int, "emscripten_date_now": _emscripten_date_now, "emscripten_get_now": _emscripten_get_now, "emscripten_memcpy_big": _emscripten_memcpy_big, "emscripten_resize_heap": _emscripten_resize_heap, "environ_get": _environ_get, "environ_sizes_get": _environ_sizes_get, "fd_close": _fd_close, "fd_read": _fd_read, "fd_seek": _fd_seek, "fd_write": _fd_write, "strftime_l": _strftime_l, "wasm_msgproc": wasm_msgproc };
1846
+ var asm = createWasm();
1847
+ var ___wasm_call_ctors = function () { return (___wasm_call_ctors = Module["asm"]["__wasm_call_ctors"]).apply(null, arguments); };
1848
+ var _kmcmp_SetCompilerOptions = Module["_kmcmp_SetCompilerOptions"] = function () { return (_kmcmp_SetCompilerOptions = Module["_kmcmp_SetCompilerOptions"] = Module["asm"]["kmcmp_SetCompilerOptions"]).apply(null, arguments); };
1849
+ var _kmcmp_Wasm_SetCompilerOptions = Module["_kmcmp_Wasm_SetCompilerOptions"] = function () { return (_kmcmp_Wasm_SetCompilerOptions = Module["_kmcmp_Wasm_SetCompilerOptions"] = Module["asm"]["kmcmp_Wasm_SetCompilerOptions"]).apply(null, arguments); };
1850
+ var _kmcmp_Wasm_CompileKeyboardFile = Module["_kmcmp_Wasm_CompileKeyboardFile"] = function () { return (_kmcmp_Wasm_CompileKeyboardFile = Module["_kmcmp_Wasm_CompileKeyboardFile"] = Module["asm"]["kmcmp_Wasm_CompileKeyboardFile"]).apply(null, arguments); };
1851
+ var _kmcmp_CompileKeyboardFile = Module["_kmcmp_CompileKeyboardFile"] = function () { return (_kmcmp_CompileKeyboardFile = Module["_kmcmp_CompileKeyboardFile"] = Module["asm"]["kmcmp_CompileKeyboardFile"]).apply(null, arguments); };
1852
+ var _kmcmp_CompileKeyboardFileToBuffer = Module["_kmcmp_CompileKeyboardFileToBuffer"] = function () { return (_kmcmp_CompileKeyboardFileToBuffer = Module["_kmcmp_CompileKeyboardFileToBuffer"] = Module["asm"]["kmcmp_CompileKeyboardFileToBuffer"]).apply(null, arguments); };
1853
+ var _kmcmp_ValidateJsonFile = Module["_kmcmp_ValidateJsonFile"] = function () { return (_kmcmp_ValidateJsonFile = Module["_kmcmp_ValidateJsonFile"] = Module["asm"]["kmcmp_ValidateJsonFile"]).apply(null, arguments); };
1854
+ var ___errno_location = function () { return (___errno_location = Module["asm"]["__errno_location"]).apply(null, arguments); };
1855
+ var stackSave = function () { return (stackSave = Module["asm"]["stackSave"]).apply(null, arguments); };
1856
+ var stackRestore = function () { return (stackRestore = Module["asm"]["stackRestore"]).apply(null, arguments); };
1857
+ var stackAlloc = function () { return (stackAlloc = Module["asm"]["stackAlloc"]).apply(null, arguments); };
1858
+ var ___cxa_is_pointer_type = function () { return (___cxa_is_pointer_type = Module["asm"]["__cxa_is_pointer_type"]).apply(null, arguments); };
1859
+ var dynCall_viijii = Module["dynCall_viijii"] = function () { return (dynCall_viijii = Module["dynCall_viijii"] = Module["asm"]["dynCall_viijii"]).apply(null, arguments); };
1860
+ var dynCall_jiji = Module["dynCall_jiji"] = function () { return (dynCall_jiji = Module["dynCall_jiji"] = Module["asm"]["dynCall_jiji"]).apply(null, arguments); };
1861
+ var dynCall_iiiiij = Module["dynCall_iiiiij"] = function () { return (dynCall_iiiiij = Module["dynCall_iiiiij"] = Module["asm"]["dynCall_iiiiij"]).apply(null, arguments); };
1862
+ var dynCall_iiiiijj = Module["dynCall_iiiiijj"] = function () { return (dynCall_iiiiijj = Module["dynCall_iiiiijj"] = Module["asm"]["dynCall_iiiiijj"]).apply(null, arguments); };
1863
+ var dynCall_iiiiiijj = Module["dynCall_iiiiiijj"] = function () { return (dynCall_iiiiiijj = Module["dynCall_iiiiiijj"] = Module["asm"]["dynCall_iiiiiijj"]).apply(null, arguments); };
1864
+ var ___start_em_js = Module["___start_em_js"] = 71356;
1865
+ var ___stop_em_js = Module["___stop_em_js"] = 71619;
1866
+ Module["UTF8ToString"] = UTF8ToString;
1867
+ Module["cwrap"] = cwrap;
1868
+ var calledRun;
1869
+ dependenciesFulfilled = function runCaller() { if (!calledRun)
1870
+ run(); if (!calledRun)
1871
+ dependenciesFulfilled = runCaller; };
1872
+ function run() { if (runDependencies > 0) {
1873
+ return;
1874
+ } preRun(); if (runDependencies > 0) {
1875
+ return;
1876
+ } function doRun() { if (calledRun)
1877
+ return; calledRun = true; Module["calledRun"] = true; if (ABORT)
1878
+ return; initRuntime(); readyPromiseResolve(Module); if (Module["onRuntimeInitialized"])
1879
+ Module["onRuntimeInitialized"](); postRun(); } if (Module["setStatus"]) {
1880
+ Module["setStatus"]("Running...");
1881
+ setTimeout(function () { setTimeout(function () { Module["setStatus"](""); }, 1); doRun(); }, 1);
1882
+ }
1883
+ else {
1884
+ doRun();
1885
+ } }
1886
+ if (Module["preInit"]) {
1887
+ if (typeof Module["preInit"] == "function")
1888
+ Module["preInit"] = [Module["preInit"]];
1889
+ while (Module["preInit"].length > 0) {
1890
+ Module["preInit"].pop()();
1891
+ }
1892
+ }
1893
+ run();
1894
+ return Module.ready;
1895
+ });
1896
+ })();
1897
+ export default Module;
1898
+ //# sourceMappingURL=wasm-host.js.map