@keeratita/heic-converter 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js ADDED
@@ -0,0 +1,4250 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/index.ts
31
+ var index_exports = {};
32
+ __export(index_exports, {
33
+ LibheifDecoder: () => LibheifDecoder,
34
+ convertHeic: () => convertHeic,
35
+ freeSharedDecoder: () => freeSharedDecoder
36
+ });
37
+ module.exports = __toCommonJS(index_exports);
38
+
39
+ // src/wasm/wrapper/heic-decoder.js
40
+ var import_meta = {};
41
+ var createHeicDecoderModule = (() => {
42
+ var _scriptDir = import_meta.url;
43
+ return (async function(moduleArg = {}) {
44
+ var Module = moduleArg;
45
+ var readyPromiseResolve, readyPromiseReject;
46
+ Module["ready"] = new Promise((resolve, reject) => {
47
+ readyPromiseResolve = resolve;
48
+ readyPromiseReject = reject;
49
+ });
50
+ var moduleOverrides = Object.assign({}, Module);
51
+ var arguments_ = [];
52
+ var thisProgram = "./this.program";
53
+ var quit_ = (status, toThrow) => {
54
+ throw toThrow;
55
+ };
56
+ var ENVIRONMENT_IS_WEB = typeof window == "object";
57
+ var ENVIRONMENT_IS_WORKER = typeof importScripts == "function";
58
+ var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string";
59
+ var scriptDirectory = "";
60
+ function locateFile(path) {
61
+ if (Module["locateFile"]) {
62
+ return Module["locateFile"](path, scriptDirectory);
63
+ }
64
+ return scriptDirectory + path;
65
+ }
66
+ var read_, readAsync, readBinary;
67
+ if (ENVIRONMENT_IS_NODE) {
68
+ const { createRequire } = await import("module");
69
+ var require2 = createRequire(import_meta.url);
70
+ var fs = require2("fs");
71
+ var nodePath = require2("path");
72
+ if (ENVIRONMENT_IS_WORKER) {
73
+ scriptDirectory = nodePath.dirname(scriptDirectory) + "/";
74
+ } else {
75
+ scriptDirectory = require2("url").fileURLToPath(new URL("./", import_meta.url));
76
+ }
77
+ read_ = (filename, binary) => {
78
+ filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename);
79
+ return fs.readFileSync(filename, binary ? void 0 : "utf8");
80
+ };
81
+ readBinary = (filename) => {
82
+ var ret = read_(filename, true);
83
+ if (!ret.buffer) {
84
+ ret = new Uint8Array(ret);
85
+ }
86
+ return ret;
87
+ };
88
+ readAsync = (filename, onload, onerror, binary = true) => {
89
+ filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename);
90
+ fs.readFile(filename, binary ? void 0 : "utf8", (err2, data) => {
91
+ if (err2) onerror(err2);
92
+ else onload(binary ? data.buffer : data);
93
+ });
94
+ };
95
+ if (!Module["thisProgram"] && process.argv.length > 1) {
96
+ thisProgram = process.argv[1].replace(/\\/g, "/");
97
+ }
98
+ arguments_ = process.argv.slice(2);
99
+ quit_ = (status, toThrow) => {
100
+ process.exitCode = status;
101
+ throw toThrow;
102
+ };
103
+ } else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
104
+ if (ENVIRONMENT_IS_WORKER) {
105
+ scriptDirectory = self.location.href;
106
+ } else if (typeof document != "undefined" && document.currentScript) {
107
+ scriptDirectory = document.currentScript.src;
108
+ }
109
+ if (_scriptDir) {
110
+ scriptDirectory = _scriptDir;
111
+ }
112
+ if (scriptDirectory.startsWith("blob:")) {
113
+ scriptDirectory = "";
114
+ } else {
115
+ scriptDirectory = scriptDirectory.substr(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1);
116
+ }
117
+ {
118
+ read_ = (url) => {
119
+ var xhr = new XMLHttpRequest();
120
+ xhr.open("GET", url, false);
121
+ xhr.send(null);
122
+ return xhr.responseText;
123
+ };
124
+ if (ENVIRONMENT_IS_WORKER) {
125
+ readBinary = (url) => {
126
+ var xhr = new XMLHttpRequest();
127
+ xhr.open("GET", url, false);
128
+ xhr.responseType = "arraybuffer";
129
+ xhr.send(null);
130
+ return new Uint8Array(xhr.response);
131
+ };
132
+ }
133
+ readAsync = (url, onload, onerror) => {
134
+ var xhr = new XMLHttpRequest();
135
+ xhr.open("GET", url, true);
136
+ xhr.responseType = "arraybuffer";
137
+ xhr.onload = () => {
138
+ if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
139
+ onload(xhr.response);
140
+ return;
141
+ }
142
+ onerror();
143
+ };
144
+ xhr.onerror = onerror;
145
+ xhr.send(null);
146
+ };
147
+ }
148
+ } else {
149
+ }
150
+ var out = Module["print"] || console.log.bind(console);
151
+ var err = Module["printErr"] || console.error.bind(console);
152
+ Object.assign(Module, moduleOverrides);
153
+ moduleOverrides = null;
154
+ if (Module["arguments"]) arguments_ = Module["arguments"];
155
+ if (Module["thisProgram"]) thisProgram = Module["thisProgram"];
156
+ if (Module["quit"]) quit_ = Module["quit"];
157
+ var wasmBinary;
158
+ if (Module["wasmBinary"]) wasmBinary = Module["wasmBinary"];
159
+ var wasmMemory;
160
+ var ABORT = false;
161
+ var EXITSTATUS;
162
+ var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;
163
+ function updateMemoryViews() {
164
+ var b = wasmMemory.buffer;
165
+ Module["HEAP8"] = HEAP8 = new Int8Array(b);
166
+ Module["HEAP16"] = HEAP16 = new Int16Array(b);
167
+ Module["HEAPU8"] = HEAPU8 = new Uint8Array(b);
168
+ Module["HEAPU16"] = HEAPU16 = new Uint16Array(b);
169
+ Module["HEAP32"] = HEAP32 = new Int32Array(b);
170
+ Module["HEAPU32"] = HEAPU32 = new Uint32Array(b);
171
+ Module["HEAPF32"] = HEAPF32 = new Float32Array(b);
172
+ Module["HEAPF64"] = HEAPF64 = new Float64Array(b);
173
+ }
174
+ var __ATPRERUN__ = [];
175
+ var __ATINIT__ = [];
176
+ var __ATPOSTRUN__ = [];
177
+ var runtimeInitialized = false;
178
+ function preRun() {
179
+ if (Module["preRun"]) {
180
+ if (typeof Module["preRun"] == "function") Module["preRun"] = [Module["preRun"]];
181
+ while (Module["preRun"].length) {
182
+ addOnPreRun(Module["preRun"].shift());
183
+ }
184
+ }
185
+ callRuntimeCallbacks(__ATPRERUN__);
186
+ }
187
+ function initRuntime() {
188
+ runtimeInitialized = true;
189
+ if (!Module["noFSInit"] && !FS.init.initialized) FS.init();
190
+ FS.ignorePermissions = false;
191
+ TTY.init();
192
+ callRuntimeCallbacks(__ATINIT__);
193
+ }
194
+ function postRun() {
195
+ if (Module["postRun"]) {
196
+ if (typeof Module["postRun"] == "function") Module["postRun"] = [Module["postRun"]];
197
+ while (Module["postRun"].length) {
198
+ addOnPostRun(Module["postRun"].shift());
199
+ }
200
+ }
201
+ callRuntimeCallbacks(__ATPOSTRUN__);
202
+ }
203
+ function addOnPreRun(cb) {
204
+ __ATPRERUN__.unshift(cb);
205
+ }
206
+ function addOnInit(cb) {
207
+ __ATINIT__.unshift(cb);
208
+ }
209
+ function addOnPostRun(cb) {
210
+ __ATPOSTRUN__.unshift(cb);
211
+ }
212
+ var runDependencies = 0;
213
+ var runDependencyWatcher = null;
214
+ var dependenciesFulfilled = null;
215
+ function getUniqueRunDependency(id) {
216
+ return id;
217
+ }
218
+ function addRunDependency(id) {
219
+ runDependencies++;
220
+ Module["monitorRunDependencies"]?.(runDependencies);
221
+ }
222
+ function removeRunDependency(id) {
223
+ runDependencies--;
224
+ Module["monitorRunDependencies"]?.(runDependencies);
225
+ if (runDependencies == 0) {
226
+ if (runDependencyWatcher !== null) {
227
+ clearInterval(runDependencyWatcher);
228
+ runDependencyWatcher = null;
229
+ }
230
+ if (dependenciesFulfilled) {
231
+ var callback = dependenciesFulfilled;
232
+ dependenciesFulfilled = null;
233
+ callback();
234
+ }
235
+ }
236
+ }
237
+ function abort(what) {
238
+ Module["onAbort"]?.(what);
239
+ what = "Aborted(" + what + ")";
240
+ err(what);
241
+ ABORT = true;
242
+ EXITSTATUS = 1;
243
+ what += ". Build with -sASSERTIONS for more info.";
244
+ var e = new WebAssembly.RuntimeError(what);
245
+ readyPromiseReject(e);
246
+ throw e;
247
+ }
248
+ var dataURIPrefix = "data:application/octet-stream;base64,";
249
+ var isDataURI = (filename) => filename.startsWith(dataURIPrefix);
250
+ var isFileURI = (filename) => filename.startsWith("file://");
251
+ var wasmBinaryFile;
252
+ if (Module["locateFile"]) {
253
+ wasmBinaryFile = "heic-decoder.wasm";
254
+ if (!isDataURI(wasmBinaryFile)) {
255
+ wasmBinaryFile = locateFile(wasmBinaryFile);
256
+ }
257
+ } else {
258
+ wasmBinaryFile = new URL("heic-decoder.wasm", import_meta.url).href;
259
+ }
260
+ function getBinarySync(file) {
261
+ if (file == wasmBinaryFile && wasmBinary) {
262
+ return new Uint8Array(wasmBinary);
263
+ }
264
+ if (readBinary) {
265
+ return readBinary(file);
266
+ }
267
+ throw "both async and sync fetching of the wasm failed";
268
+ }
269
+ function getBinaryPromise(binaryFile) {
270
+ if (!wasmBinary && (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER)) {
271
+ if (typeof fetch == "function") {
272
+ return fetch(binaryFile, { credentials: "same-origin" }).then((response) => {
273
+ if (!response["ok"]) {
274
+ throw `failed to load wasm binary file at '${binaryFile}'`;
275
+ }
276
+ return response["arrayBuffer"]();
277
+ }).catch(() => getBinarySync(binaryFile));
278
+ }
279
+ }
280
+ return Promise.resolve().then(() => getBinarySync(binaryFile));
281
+ }
282
+ function instantiateArrayBuffer(binaryFile, imports, receiver) {
283
+ return getBinaryPromise(binaryFile).then((binary) => WebAssembly.instantiate(binary, imports)).then(receiver, (reason) => {
284
+ err(`failed to asynchronously prepare wasm: ${reason}`);
285
+ abort(reason);
286
+ });
287
+ }
288
+ function instantiateAsync(binary, binaryFile, imports, callback) {
289
+ if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isDataURI(binaryFile) && !ENVIRONMENT_IS_NODE && typeof fetch == "function") {
290
+ return fetch(binaryFile, { credentials: "same-origin" }).then((response) => {
291
+ var result = WebAssembly.instantiateStreaming(response, imports);
292
+ return result.then(callback, function(reason) {
293
+ err(`wasm streaming compile failed: ${reason}`);
294
+ err("falling back to ArrayBuffer instantiation");
295
+ return instantiateArrayBuffer(binaryFile, imports, callback);
296
+ });
297
+ });
298
+ }
299
+ return instantiateArrayBuffer(binaryFile, imports, callback);
300
+ }
301
+ function createWasm() {
302
+ var info = { "a": wasmImports };
303
+ function receiveInstance(instance, module2) {
304
+ wasmExports = instance.exports;
305
+ wasmMemory = wasmExports["Q"];
306
+ updateMemoryViews();
307
+ wasmTable = wasmExports["T"];
308
+ addOnInit(wasmExports["R"]);
309
+ removeRunDependency("wasm-instantiate");
310
+ return wasmExports;
311
+ }
312
+ addRunDependency("wasm-instantiate");
313
+ function receiveInstantiationResult(result) {
314
+ receiveInstance(result["instance"]);
315
+ }
316
+ if (Module["instantiateWasm"]) {
317
+ try {
318
+ return Module["instantiateWasm"](info, receiveInstance);
319
+ } catch (e) {
320
+ err(`Module.instantiateWasm callback failed with error: ${e}`);
321
+ readyPromiseReject(e);
322
+ }
323
+ }
324
+ instantiateAsync(wasmBinary, wasmBinaryFile, info, receiveInstantiationResult).catch(readyPromiseReject);
325
+ return {};
326
+ }
327
+ var tempDouble;
328
+ var tempI64;
329
+ var callRuntimeCallbacks = (callbacks) => {
330
+ while (callbacks.length > 0) {
331
+ callbacks.shift()(Module);
332
+ }
333
+ };
334
+ var noExitRuntime = Module["noExitRuntime"] || true;
335
+ var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf8") : void 0;
336
+ var UTF8ArrayToString = (heapOrArray, idx, maxBytesToRead) => {
337
+ var endIdx = idx + maxBytesToRead;
338
+ var endPtr = idx;
339
+ while (heapOrArray[endPtr] && !(endPtr >= endIdx)) ++endPtr;
340
+ if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
341
+ return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
342
+ }
343
+ var str = "";
344
+ while (idx < endPtr) {
345
+ var u0 = heapOrArray[idx++];
346
+ if (!(u0 & 128)) {
347
+ str += String.fromCharCode(u0);
348
+ continue;
349
+ }
350
+ var u1 = heapOrArray[idx++] & 63;
351
+ if ((u0 & 224) == 192) {
352
+ str += String.fromCharCode((u0 & 31) << 6 | u1);
353
+ continue;
354
+ }
355
+ var u2 = heapOrArray[idx++] & 63;
356
+ if ((u0 & 240) == 224) {
357
+ u0 = (u0 & 15) << 12 | u1 << 6 | u2;
358
+ } else {
359
+ u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
360
+ }
361
+ if (u0 < 65536) {
362
+ str += String.fromCharCode(u0);
363
+ } else {
364
+ var ch = u0 - 65536;
365
+ str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
366
+ }
367
+ }
368
+ return str;
369
+ };
370
+ var UTF8ToString = (ptr, maxBytesToRead) => ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
371
+ var ___assert_fail = (condition, filename, line, func) => {
372
+ abort(`Assertion failed: ${UTF8ToString(condition)}, at: ` + [filename ? UTF8ToString(filename) : "unknown filename", line, func ? UTF8ToString(func) : "unknown function"]);
373
+ };
374
+ class ExceptionInfo {
375
+ constructor(excPtr) {
376
+ this.excPtr = excPtr;
377
+ this.ptr = excPtr - 24;
378
+ }
379
+ set_type(type) {
380
+ HEAPU32[this.ptr + 4 >> 2] = type;
381
+ }
382
+ get_type() {
383
+ return HEAPU32[this.ptr + 4 >> 2];
384
+ }
385
+ set_destructor(destructor) {
386
+ HEAPU32[this.ptr + 8 >> 2] = destructor;
387
+ }
388
+ get_destructor() {
389
+ return HEAPU32[this.ptr + 8 >> 2];
390
+ }
391
+ set_caught(caught) {
392
+ caught = caught ? 1 : 0;
393
+ HEAP8[this.ptr + 12] = caught;
394
+ }
395
+ get_caught() {
396
+ return HEAP8[this.ptr + 12] != 0;
397
+ }
398
+ set_rethrown(rethrown) {
399
+ rethrown = rethrown ? 1 : 0;
400
+ HEAP8[this.ptr + 13] = rethrown;
401
+ }
402
+ get_rethrown() {
403
+ return HEAP8[this.ptr + 13] != 0;
404
+ }
405
+ init(type, destructor) {
406
+ this.set_adjusted_ptr(0);
407
+ this.set_type(type);
408
+ this.set_destructor(destructor);
409
+ }
410
+ set_adjusted_ptr(adjustedPtr) {
411
+ HEAPU32[this.ptr + 16 >> 2] = adjustedPtr;
412
+ }
413
+ get_adjusted_ptr() {
414
+ return HEAPU32[this.ptr + 16 >> 2];
415
+ }
416
+ get_exception_ptr() {
417
+ var isPointer = ___cxa_is_pointer_type(this.get_type());
418
+ if (isPointer) {
419
+ return HEAPU32[this.excPtr >> 2];
420
+ }
421
+ var adjusted = this.get_adjusted_ptr();
422
+ if (adjusted !== 0) return adjusted;
423
+ return this.excPtr;
424
+ }
425
+ }
426
+ var exceptionLast = 0;
427
+ var uncaughtExceptionCount = 0;
428
+ var ___cxa_throw = (ptr, type, destructor) => {
429
+ var info = new ExceptionInfo(ptr);
430
+ info.init(type, destructor);
431
+ exceptionLast = ptr;
432
+ uncaughtExceptionCount++;
433
+ throw exceptionLast;
434
+ };
435
+ var structRegistrations = {};
436
+ var runDestructors = (destructors) => {
437
+ while (destructors.length) {
438
+ var ptr = destructors.pop();
439
+ var del = destructors.pop();
440
+ del(ptr);
441
+ }
442
+ };
443
+ function readPointer(pointer) {
444
+ return this["fromWireType"](HEAPU32[pointer >> 2]);
445
+ }
446
+ var awaitingDependencies = {};
447
+ var registeredTypes = {};
448
+ var typeDependencies = {};
449
+ var InternalError;
450
+ var throwInternalError = (message) => {
451
+ throw new InternalError(message);
452
+ };
453
+ var whenDependentTypesAreResolved = (myTypes, dependentTypes, getTypeConverters) => {
454
+ myTypes.forEach(function(type) {
455
+ typeDependencies[type] = dependentTypes;
456
+ });
457
+ function onComplete(typeConverters2) {
458
+ var myTypeConverters = getTypeConverters(typeConverters2);
459
+ if (myTypeConverters.length !== myTypes.length) {
460
+ throwInternalError("Mismatched type converter count");
461
+ }
462
+ for (var i = 0; i < myTypes.length; ++i) {
463
+ registerType(myTypes[i], myTypeConverters[i]);
464
+ }
465
+ }
466
+ var typeConverters = new Array(dependentTypes.length);
467
+ var unregisteredTypes = [];
468
+ var registered = 0;
469
+ dependentTypes.forEach((dt, i) => {
470
+ if (registeredTypes.hasOwnProperty(dt)) {
471
+ typeConverters[i] = registeredTypes[dt];
472
+ } else {
473
+ unregisteredTypes.push(dt);
474
+ if (!awaitingDependencies.hasOwnProperty(dt)) {
475
+ awaitingDependencies[dt] = [];
476
+ }
477
+ awaitingDependencies[dt].push(() => {
478
+ typeConverters[i] = registeredTypes[dt];
479
+ ++registered;
480
+ if (registered === unregisteredTypes.length) {
481
+ onComplete(typeConverters);
482
+ }
483
+ });
484
+ }
485
+ });
486
+ if (0 === unregisteredTypes.length) {
487
+ onComplete(typeConverters);
488
+ }
489
+ };
490
+ var __embind_finalize_value_object = (structType) => {
491
+ var reg = structRegistrations[structType];
492
+ delete structRegistrations[structType];
493
+ var rawConstructor = reg.rawConstructor;
494
+ var rawDestructor = reg.rawDestructor;
495
+ var fieldRecords = reg.fields;
496
+ var fieldTypes = fieldRecords.map((field) => field.getterReturnType).concat(fieldRecords.map((field) => field.setterArgumentType));
497
+ whenDependentTypesAreResolved([structType], fieldTypes, (fieldTypes2) => {
498
+ var fields = {};
499
+ fieldRecords.forEach((field, i) => {
500
+ var fieldName = field.fieldName;
501
+ var getterReturnType = fieldTypes2[i];
502
+ var getter = field.getter;
503
+ var getterContext = field.getterContext;
504
+ var setterArgumentType = fieldTypes2[i + fieldRecords.length];
505
+ var setter = field.setter;
506
+ var setterContext = field.setterContext;
507
+ fields[fieldName] = { read: (ptr) => getterReturnType["fromWireType"](getter(getterContext, ptr)), write: (ptr, o) => {
508
+ var destructors = [];
509
+ setter(setterContext, ptr, setterArgumentType["toWireType"](destructors, o));
510
+ runDestructors(destructors);
511
+ } };
512
+ });
513
+ return [{ name: reg.name, "fromWireType": (ptr) => {
514
+ var rv = {};
515
+ for (var i in fields) {
516
+ rv[i] = fields[i].read(ptr);
517
+ }
518
+ rawDestructor(ptr);
519
+ return rv;
520
+ }, "toWireType": (destructors, o) => {
521
+ for (var fieldName in fields) {
522
+ if (!(fieldName in o)) {
523
+ throw new TypeError(`Missing field: "${fieldName}"`);
524
+ }
525
+ }
526
+ var ptr = rawConstructor();
527
+ for (fieldName in fields) {
528
+ fields[fieldName].write(ptr, o[fieldName]);
529
+ }
530
+ if (destructors !== null) {
531
+ destructors.push(rawDestructor, ptr);
532
+ }
533
+ return ptr;
534
+ }, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": readPointer, destructorFunction: rawDestructor }];
535
+ });
536
+ };
537
+ var __embind_register_bigint = (primitiveType, name, size, minRange, maxRange) => {
538
+ };
539
+ var embind_init_charCodes = () => {
540
+ var codes = new Array(256);
541
+ for (var i = 0; i < 256; ++i) {
542
+ codes[i] = String.fromCharCode(i);
543
+ }
544
+ embind_charCodes = codes;
545
+ };
546
+ var embind_charCodes;
547
+ var readLatin1String = (ptr) => {
548
+ var ret = "";
549
+ var c = ptr;
550
+ while (HEAPU8[c]) {
551
+ ret += embind_charCodes[HEAPU8[c++]];
552
+ }
553
+ return ret;
554
+ };
555
+ var BindingError;
556
+ var throwBindingError = (message) => {
557
+ throw new BindingError(message);
558
+ };
559
+ function sharedRegisterType(rawType, registeredInstance, options = {}) {
560
+ var name = registeredInstance.name;
561
+ if (!rawType) {
562
+ throwBindingError(`type "${name}" must have a positive integer typeid pointer`);
563
+ }
564
+ if (registeredTypes.hasOwnProperty(rawType)) {
565
+ if (options.ignoreDuplicateRegistrations) {
566
+ return;
567
+ } else {
568
+ throwBindingError(`Cannot register type '${name}' twice`);
569
+ }
570
+ }
571
+ registeredTypes[rawType] = registeredInstance;
572
+ delete typeDependencies[rawType];
573
+ if (awaitingDependencies.hasOwnProperty(rawType)) {
574
+ var callbacks = awaitingDependencies[rawType];
575
+ delete awaitingDependencies[rawType];
576
+ callbacks.forEach((cb) => cb());
577
+ }
578
+ }
579
+ function registerType(rawType, registeredInstance, options = {}) {
580
+ if (!("argPackAdvance" in registeredInstance)) {
581
+ throw new TypeError("registerType registeredInstance requires argPackAdvance");
582
+ }
583
+ return sharedRegisterType(rawType, registeredInstance, options);
584
+ }
585
+ var GenericWireTypeSize = 8;
586
+ var __embind_register_bool = (rawType, name, trueValue, falseValue) => {
587
+ name = readLatin1String(name);
588
+ registerType(rawType, { name, "fromWireType": function(wt) {
589
+ return !!wt;
590
+ }, "toWireType": function(destructors, o) {
591
+ return o ? trueValue : falseValue;
592
+ }, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": function(pointer) {
593
+ return this["fromWireType"](HEAPU8[pointer]);
594
+ }, destructorFunction: null });
595
+ };
596
+ var shallowCopyInternalPointer = (o) => ({ count: o.count, deleteScheduled: o.deleteScheduled, preservePointerOnDelete: o.preservePointerOnDelete, ptr: o.ptr, ptrType: o.ptrType, smartPtr: o.smartPtr, smartPtrType: o.smartPtrType });
597
+ var throwInstanceAlreadyDeleted = (obj) => {
598
+ function getInstanceTypeName(handle) {
599
+ return handle.$$.ptrType.registeredClass.name;
600
+ }
601
+ throwBindingError(getInstanceTypeName(obj) + " instance already deleted");
602
+ };
603
+ var finalizationRegistry = false;
604
+ var detachFinalizer = (handle) => {
605
+ };
606
+ var runDestructor = ($$) => {
607
+ if ($$.smartPtr) {
608
+ $$.smartPtrType.rawDestructor($$.smartPtr);
609
+ } else {
610
+ $$.ptrType.registeredClass.rawDestructor($$.ptr);
611
+ }
612
+ };
613
+ var releaseClassHandle = ($$) => {
614
+ $$.count.value -= 1;
615
+ var toDelete = 0 === $$.count.value;
616
+ if (toDelete) {
617
+ runDestructor($$);
618
+ }
619
+ };
620
+ var downcastPointer = (ptr, ptrClass, desiredClass) => {
621
+ if (ptrClass === desiredClass) {
622
+ return ptr;
623
+ }
624
+ if (void 0 === desiredClass.baseClass) {
625
+ return null;
626
+ }
627
+ var rv = downcastPointer(ptr, ptrClass, desiredClass.baseClass);
628
+ if (rv === null) {
629
+ return null;
630
+ }
631
+ return desiredClass.downcast(rv);
632
+ };
633
+ var registeredPointers = {};
634
+ var getInheritedInstanceCount = () => Object.keys(registeredInstances).length;
635
+ var getLiveInheritedInstances = () => {
636
+ var rv = [];
637
+ for (var k in registeredInstances) {
638
+ if (registeredInstances.hasOwnProperty(k)) {
639
+ rv.push(registeredInstances[k]);
640
+ }
641
+ }
642
+ return rv;
643
+ };
644
+ var deletionQueue = [];
645
+ var flushPendingDeletes = () => {
646
+ while (deletionQueue.length) {
647
+ var obj = deletionQueue.pop();
648
+ obj.$$.deleteScheduled = false;
649
+ obj["delete"]();
650
+ }
651
+ };
652
+ var delayFunction;
653
+ var setDelayFunction = (fn) => {
654
+ delayFunction = fn;
655
+ if (deletionQueue.length && delayFunction) {
656
+ delayFunction(flushPendingDeletes);
657
+ }
658
+ };
659
+ var init_embind = () => {
660
+ Module["getInheritedInstanceCount"] = getInheritedInstanceCount;
661
+ Module["getLiveInheritedInstances"] = getLiveInheritedInstances;
662
+ Module["flushPendingDeletes"] = flushPendingDeletes;
663
+ Module["setDelayFunction"] = setDelayFunction;
664
+ };
665
+ var registeredInstances = {};
666
+ var getBasestPointer = (class_, ptr) => {
667
+ if (ptr === void 0) {
668
+ throwBindingError("ptr should not be undefined");
669
+ }
670
+ while (class_.baseClass) {
671
+ ptr = class_.upcast(ptr);
672
+ class_ = class_.baseClass;
673
+ }
674
+ return ptr;
675
+ };
676
+ var getInheritedInstance = (class_, ptr) => {
677
+ ptr = getBasestPointer(class_, ptr);
678
+ return registeredInstances[ptr];
679
+ };
680
+ var makeClassHandle = (prototype, record) => {
681
+ if (!record.ptrType || !record.ptr) {
682
+ throwInternalError("makeClassHandle requires ptr and ptrType");
683
+ }
684
+ var hasSmartPtrType = !!record.smartPtrType;
685
+ var hasSmartPtr = !!record.smartPtr;
686
+ if (hasSmartPtrType !== hasSmartPtr) {
687
+ throwInternalError("Both smartPtrType and smartPtr must be specified");
688
+ }
689
+ record.count = { value: 1 };
690
+ return attachFinalizer(Object.create(prototype, { $$: { value: record, writable: true } }));
691
+ };
692
+ function RegisteredPointer_fromWireType(ptr) {
693
+ var rawPointer = this.getPointee(ptr);
694
+ if (!rawPointer) {
695
+ this.destructor(ptr);
696
+ return null;
697
+ }
698
+ var registeredInstance = getInheritedInstance(this.registeredClass, rawPointer);
699
+ if (void 0 !== registeredInstance) {
700
+ if (0 === registeredInstance.$$.count.value) {
701
+ registeredInstance.$$.ptr = rawPointer;
702
+ registeredInstance.$$.smartPtr = ptr;
703
+ return registeredInstance["clone"]();
704
+ } else {
705
+ var rv = registeredInstance["clone"]();
706
+ this.destructor(ptr);
707
+ return rv;
708
+ }
709
+ }
710
+ function makeDefaultHandle() {
711
+ if (this.isSmartPointer) {
712
+ return makeClassHandle(this.registeredClass.instancePrototype, { ptrType: this.pointeeType, ptr: rawPointer, smartPtrType: this, smartPtr: ptr });
713
+ } else {
714
+ return makeClassHandle(this.registeredClass.instancePrototype, { ptrType: this, ptr });
715
+ }
716
+ }
717
+ var actualType = this.registeredClass.getActualType(rawPointer);
718
+ var registeredPointerRecord = registeredPointers[actualType];
719
+ if (!registeredPointerRecord) {
720
+ return makeDefaultHandle.call(this);
721
+ }
722
+ var toType;
723
+ if (this.isConst) {
724
+ toType = registeredPointerRecord.constPointerType;
725
+ } else {
726
+ toType = registeredPointerRecord.pointerType;
727
+ }
728
+ var dp = downcastPointer(rawPointer, this.registeredClass, toType.registeredClass);
729
+ if (dp === null) {
730
+ return makeDefaultHandle.call(this);
731
+ }
732
+ if (this.isSmartPointer) {
733
+ return makeClassHandle(toType.registeredClass.instancePrototype, { ptrType: toType, ptr: dp, smartPtrType: this, smartPtr: ptr });
734
+ } else {
735
+ return makeClassHandle(toType.registeredClass.instancePrototype, { ptrType: toType, ptr: dp });
736
+ }
737
+ }
738
+ var attachFinalizer = (handle) => {
739
+ if ("undefined" === typeof FinalizationRegistry) {
740
+ attachFinalizer = (handle2) => handle2;
741
+ return handle;
742
+ }
743
+ finalizationRegistry = new FinalizationRegistry((info) => {
744
+ releaseClassHandle(info.$$);
745
+ });
746
+ attachFinalizer = (handle2) => {
747
+ var $$ = handle2.$$;
748
+ var hasSmartPtr = !!$$.smartPtr;
749
+ if (hasSmartPtr) {
750
+ var info = { $$ };
751
+ finalizationRegistry.register(handle2, info, handle2);
752
+ }
753
+ return handle2;
754
+ };
755
+ detachFinalizer = (handle2) => finalizationRegistry.unregister(handle2);
756
+ return attachFinalizer(handle);
757
+ };
758
+ var init_ClassHandle = () => {
759
+ Object.assign(ClassHandle.prototype, { "isAliasOf"(other) {
760
+ if (!(this instanceof ClassHandle)) {
761
+ return false;
762
+ }
763
+ if (!(other instanceof ClassHandle)) {
764
+ return false;
765
+ }
766
+ var leftClass = this.$$.ptrType.registeredClass;
767
+ var left = this.$$.ptr;
768
+ other.$$ = other.$$;
769
+ var rightClass = other.$$.ptrType.registeredClass;
770
+ var right = other.$$.ptr;
771
+ while (leftClass.baseClass) {
772
+ left = leftClass.upcast(left);
773
+ leftClass = leftClass.baseClass;
774
+ }
775
+ while (rightClass.baseClass) {
776
+ right = rightClass.upcast(right);
777
+ rightClass = rightClass.baseClass;
778
+ }
779
+ return leftClass === rightClass && left === right;
780
+ }, "clone"() {
781
+ if (!this.$$.ptr) {
782
+ throwInstanceAlreadyDeleted(this);
783
+ }
784
+ if (this.$$.preservePointerOnDelete) {
785
+ this.$$.count.value += 1;
786
+ return this;
787
+ } else {
788
+ var clone = attachFinalizer(Object.create(Object.getPrototypeOf(this), { $$: { value: shallowCopyInternalPointer(this.$$) } }));
789
+ clone.$$.count.value += 1;
790
+ clone.$$.deleteScheduled = false;
791
+ return clone;
792
+ }
793
+ }, "delete"() {
794
+ if (!this.$$.ptr) {
795
+ throwInstanceAlreadyDeleted(this);
796
+ }
797
+ if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
798
+ throwBindingError("Object already scheduled for deletion");
799
+ }
800
+ detachFinalizer(this);
801
+ releaseClassHandle(this.$$);
802
+ if (!this.$$.preservePointerOnDelete) {
803
+ this.$$.smartPtr = void 0;
804
+ this.$$.ptr = void 0;
805
+ }
806
+ }, "isDeleted"() {
807
+ return !this.$$.ptr;
808
+ }, "deleteLater"() {
809
+ if (!this.$$.ptr) {
810
+ throwInstanceAlreadyDeleted(this);
811
+ }
812
+ if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
813
+ throwBindingError("Object already scheduled for deletion");
814
+ }
815
+ deletionQueue.push(this);
816
+ if (deletionQueue.length === 1 && delayFunction) {
817
+ delayFunction(flushPendingDeletes);
818
+ }
819
+ this.$$.deleteScheduled = true;
820
+ return this;
821
+ } });
822
+ };
823
+ function ClassHandle() {
824
+ }
825
+ var createNamedFunction = (name, body) => Object.defineProperty(body, "name", { value: name });
826
+ var ensureOverloadTable = (proto, methodName, humanName) => {
827
+ if (void 0 === proto[methodName].overloadTable) {
828
+ var prevFunc = proto[methodName];
829
+ proto[methodName] = function(...args) {
830
+ if (!proto[methodName].overloadTable.hasOwnProperty(args.length)) {
831
+ throwBindingError(`Function '${humanName}' called with an invalid number of arguments (${args.length}) - expects one of (${proto[methodName].overloadTable})!`);
832
+ }
833
+ return proto[methodName].overloadTable[args.length].apply(this, args);
834
+ };
835
+ proto[methodName].overloadTable = [];
836
+ proto[methodName].overloadTable[prevFunc.argCount] = prevFunc;
837
+ }
838
+ };
839
+ var exposePublicSymbol = (name, value, numArguments) => {
840
+ if (Module.hasOwnProperty(name)) {
841
+ if (void 0 === numArguments || void 0 !== Module[name].overloadTable && void 0 !== Module[name].overloadTable[numArguments]) {
842
+ throwBindingError(`Cannot register public name '${name}' twice`);
843
+ }
844
+ ensureOverloadTable(Module, name, name);
845
+ if (Module.hasOwnProperty(numArguments)) {
846
+ throwBindingError(`Cannot register multiple overloads of a function with the same number of arguments (${numArguments})!`);
847
+ }
848
+ Module[name].overloadTable[numArguments] = value;
849
+ } else {
850
+ Module[name] = value;
851
+ if (void 0 !== numArguments) {
852
+ Module[name].numArguments = numArguments;
853
+ }
854
+ }
855
+ };
856
+ var char_0 = 48;
857
+ var char_9 = 57;
858
+ var makeLegalFunctionName = (name) => {
859
+ if (void 0 === name) {
860
+ return "_unknown";
861
+ }
862
+ name = name.replace(/[^a-zA-Z0-9_]/g, "$");
863
+ var f = name.charCodeAt(0);
864
+ if (f >= char_0 && f <= char_9) {
865
+ return `_${name}`;
866
+ }
867
+ return name;
868
+ };
869
+ function RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast) {
870
+ this.name = name;
871
+ this.constructor = constructor;
872
+ this.instancePrototype = instancePrototype;
873
+ this.rawDestructor = rawDestructor;
874
+ this.baseClass = baseClass;
875
+ this.getActualType = getActualType;
876
+ this.upcast = upcast;
877
+ this.downcast = downcast;
878
+ this.pureVirtualFunctions = [];
879
+ }
880
+ var upcastPointer = (ptr, ptrClass, desiredClass) => {
881
+ while (ptrClass !== desiredClass) {
882
+ if (!ptrClass.upcast) {
883
+ throwBindingError(`Expected null or instance of ${desiredClass.name}, got an instance of ${ptrClass.name}`);
884
+ }
885
+ ptr = ptrClass.upcast(ptr);
886
+ ptrClass = ptrClass.baseClass;
887
+ }
888
+ return ptr;
889
+ };
890
+ function constNoSmartPtrRawPointerToWireType(destructors, handle) {
891
+ if (handle === null) {
892
+ if (this.isReference) {
893
+ throwBindingError(`null is not a valid ${this.name}`);
894
+ }
895
+ return 0;
896
+ }
897
+ if (!handle.$$) {
898
+ throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`);
899
+ }
900
+ if (!handle.$$.ptr) {
901
+ throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);
902
+ }
903
+ var handleClass = handle.$$.ptrType.registeredClass;
904
+ var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass);
905
+ return ptr;
906
+ }
907
+ function genericPointerToWireType(destructors, handle) {
908
+ var ptr;
909
+ if (handle === null) {
910
+ if (this.isReference) {
911
+ throwBindingError(`null is not a valid ${this.name}`);
912
+ }
913
+ if (this.isSmartPointer) {
914
+ ptr = this.rawConstructor();
915
+ if (destructors !== null) {
916
+ destructors.push(this.rawDestructor, ptr);
917
+ }
918
+ return ptr;
919
+ } else {
920
+ return 0;
921
+ }
922
+ }
923
+ if (!handle || !handle.$$) {
924
+ throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`);
925
+ }
926
+ if (!handle.$$.ptr) {
927
+ throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);
928
+ }
929
+ if (!this.isConst && handle.$$.ptrType.isConst) {
930
+ throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name} to parameter type ${this.name}`);
931
+ }
932
+ var handleClass = handle.$$.ptrType.registeredClass;
933
+ ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass);
934
+ if (this.isSmartPointer) {
935
+ if (void 0 === handle.$$.smartPtr) {
936
+ throwBindingError("Passing raw pointer to smart pointer is illegal");
937
+ }
938
+ switch (this.sharingPolicy) {
939
+ case 0:
940
+ if (handle.$$.smartPtrType === this) {
941
+ ptr = handle.$$.smartPtr;
942
+ } else {
943
+ throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name} to parameter type ${this.name}`);
944
+ }
945
+ break;
946
+ case 1:
947
+ ptr = handle.$$.smartPtr;
948
+ break;
949
+ case 2:
950
+ if (handle.$$.smartPtrType === this) {
951
+ ptr = handle.$$.smartPtr;
952
+ } else {
953
+ var clonedHandle = handle["clone"]();
954
+ ptr = this.rawShare(ptr, Emval.toHandle(() => clonedHandle["delete"]()));
955
+ if (destructors !== null) {
956
+ destructors.push(this.rawDestructor, ptr);
957
+ }
958
+ }
959
+ break;
960
+ default:
961
+ throwBindingError("Unsupporting sharing policy");
962
+ }
963
+ }
964
+ return ptr;
965
+ }
966
+ function nonConstNoSmartPtrRawPointerToWireType(destructors, handle) {
967
+ if (handle === null) {
968
+ if (this.isReference) {
969
+ throwBindingError(`null is not a valid ${this.name}`);
970
+ }
971
+ return 0;
972
+ }
973
+ if (!handle.$$) {
974
+ throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`);
975
+ }
976
+ if (!handle.$$.ptr) {
977
+ throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);
978
+ }
979
+ if (handle.$$.ptrType.isConst) {
980
+ throwBindingError(`Cannot convert argument of type ${handle.$$.ptrType.name} to parameter type ${this.name}`);
981
+ }
982
+ var handleClass = handle.$$.ptrType.registeredClass;
983
+ var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass);
984
+ return ptr;
985
+ }
986
+ var init_RegisteredPointer = () => {
987
+ Object.assign(RegisteredPointer.prototype, { getPointee(ptr) {
988
+ if (this.rawGetPointee) {
989
+ ptr = this.rawGetPointee(ptr);
990
+ }
991
+ return ptr;
992
+ }, destructor(ptr) {
993
+ this.rawDestructor?.(ptr);
994
+ }, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": readPointer, "fromWireType": RegisteredPointer_fromWireType });
995
+ };
996
+ function RegisteredPointer(name, registeredClass, isReference, isConst, isSmartPointer, pointeeType, sharingPolicy, rawGetPointee, rawConstructor, rawShare, rawDestructor) {
997
+ this.name = name;
998
+ this.registeredClass = registeredClass;
999
+ this.isReference = isReference;
1000
+ this.isConst = isConst;
1001
+ this.isSmartPointer = isSmartPointer;
1002
+ this.pointeeType = pointeeType;
1003
+ this.sharingPolicy = sharingPolicy;
1004
+ this.rawGetPointee = rawGetPointee;
1005
+ this.rawConstructor = rawConstructor;
1006
+ this.rawShare = rawShare;
1007
+ this.rawDestructor = rawDestructor;
1008
+ if (!isSmartPointer && registeredClass.baseClass === void 0) {
1009
+ if (isConst) {
1010
+ this["toWireType"] = constNoSmartPtrRawPointerToWireType;
1011
+ this.destructorFunction = null;
1012
+ } else {
1013
+ this["toWireType"] = nonConstNoSmartPtrRawPointerToWireType;
1014
+ this.destructorFunction = null;
1015
+ }
1016
+ } else {
1017
+ this["toWireType"] = genericPointerToWireType;
1018
+ }
1019
+ }
1020
+ var replacePublicSymbol = (name, value, numArguments) => {
1021
+ if (!Module.hasOwnProperty(name)) {
1022
+ throwInternalError("Replacing nonexistent public symbol");
1023
+ }
1024
+ if (void 0 !== Module[name].overloadTable && void 0 !== numArguments) {
1025
+ Module[name].overloadTable[numArguments] = value;
1026
+ } else {
1027
+ Module[name] = value;
1028
+ Module[name].argCount = numArguments;
1029
+ }
1030
+ };
1031
+ var dynCallLegacy = (sig, ptr, args) => {
1032
+ var f = Module["dynCall_" + sig];
1033
+ return f(ptr, ...args);
1034
+ };
1035
+ var wasmTableMirror = [];
1036
+ var wasmTable;
1037
+ var getWasmTableEntry = (funcPtr) => {
1038
+ var func = wasmTableMirror[funcPtr];
1039
+ if (!func) {
1040
+ if (funcPtr >= wasmTableMirror.length) wasmTableMirror.length = funcPtr + 1;
1041
+ wasmTableMirror[funcPtr] = func = wasmTable.get(funcPtr);
1042
+ }
1043
+ return func;
1044
+ };
1045
+ var dynCall = (sig, ptr, args = []) => {
1046
+ if (sig.includes("j")) {
1047
+ return dynCallLegacy(sig, ptr, args);
1048
+ }
1049
+ var rtn = getWasmTableEntry(ptr)(...args);
1050
+ return rtn;
1051
+ };
1052
+ var getDynCaller = (sig, ptr) => (...args) => dynCall(sig, ptr, args);
1053
+ var embind__requireFunction = (signature, rawFunction) => {
1054
+ signature = readLatin1String(signature);
1055
+ function makeDynCaller() {
1056
+ if (signature.includes("j")) {
1057
+ return getDynCaller(signature, rawFunction);
1058
+ }
1059
+ return getWasmTableEntry(rawFunction);
1060
+ }
1061
+ var fp = makeDynCaller();
1062
+ if (typeof fp != "function") {
1063
+ throwBindingError(`unknown function pointer with signature ${signature}: ${rawFunction}`);
1064
+ }
1065
+ return fp;
1066
+ };
1067
+ var extendError = (baseErrorType, errorName) => {
1068
+ var errorClass = createNamedFunction(errorName, function(message) {
1069
+ this.name = errorName;
1070
+ this.message = message;
1071
+ var stack = new Error(message).stack;
1072
+ if (stack !== void 0) {
1073
+ this.stack = this.toString() + "\n" + stack.replace(/^Error(:[^\n]*)?\n/, "");
1074
+ }
1075
+ });
1076
+ errorClass.prototype = Object.create(baseErrorType.prototype);
1077
+ errorClass.prototype.constructor = errorClass;
1078
+ errorClass.prototype.toString = function() {
1079
+ if (this.message === void 0) {
1080
+ return this.name;
1081
+ } else {
1082
+ return `${this.name}: ${this.message}`;
1083
+ }
1084
+ };
1085
+ return errorClass;
1086
+ };
1087
+ var UnboundTypeError;
1088
+ var getTypeName = (type) => {
1089
+ var ptr = ___getTypeName(type);
1090
+ var rv = readLatin1String(ptr);
1091
+ _free(ptr);
1092
+ return rv;
1093
+ };
1094
+ var throwUnboundTypeError = (message, types) => {
1095
+ var unboundTypes = [];
1096
+ var seen = {};
1097
+ function visit(type) {
1098
+ if (seen[type]) {
1099
+ return;
1100
+ }
1101
+ if (registeredTypes[type]) {
1102
+ return;
1103
+ }
1104
+ if (typeDependencies[type]) {
1105
+ typeDependencies[type].forEach(visit);
1106
+ return;
1107
+ }
1108
+ unboundTypes.push(type);
1109
+ seen[type] = true;
1110
+ }
1111
+ types.forEach(visit);
1112
+ throw new UnboundTypeError(`${message}: ` + unboundTypes.map(getTypeName).join([", "]));
1113
+ };
1114
+ var __embind_register_class = (rawType, rawPointerType, rawConstPointerType, baseClassRawType, getActualTypeSignature, getActualType, upcastSignature, upcast, downcastSignature, downcast, name, destructorSignature, rawDestructor) => {
1115
+ name = readLatin1String(name);
1116
+ getActualType = embind__requireFunction(getActualTypeSignature, getActualType);
1117
+ upcast &&= embind__requireFunction(upcastSignature, upcast);
1118
+ downcast &&= embind__requireFunction(downcastSignature, downcast);
1119
+ rawDestructor = embind__requireFunction(destructorSignature, rawDestructor);
1120
+ var legalFunctionName = makeLegalFunctionName(name);
1121
+ exposePublicSymbol(legalFunctionName, function() {
1122
+ throwUnboundTypeError(`Cannot construct ${name} due to unbound types`, [baseClassRawType]);
1123
+ });
1124
+ whenDependentTypesAreResolved([rawType, rawPointerType, rawConstPointerType], baseClassRawType ? [baseClassRawType] : [], (base) => {
1125
+ base = base[0];
1126
+ var baseClass;
1127
+ var basePrototype;
1128
+ if (baseClassRawType) {
1129
+ baseClass = base.registeredClass;
1130
+ basePrototype = baseClass.instancePrototype;
1131
+ } else {
1132
+ basePrototype = ClassHandle.prototype;
1133
+ }
1134
+ var constructor = createNamedFunction(name, function(...args) {
1135
+ if (Object.getPrototypeOf(this) !== instancePrototype) {
1136
+ throw new BindingError("Use 'new' to construct " + name);
1137
+ }
1138
+ if (void 0 === registeredClass.constructor_body) {
1139
+ throw new BindingError(name + " has no accessible constructor");
1140
+ }
1141
+ var body = registeredClass.constructor_body[args.length];
1142
+ if (void 0 === body) {
1143
+ throw new BindingError(`Tried to invoke ctor of ${name} with invalid number of parameters (${args.length}) - expected (${Object.keys(registeredClass.constructor_body).toString()}) parameters instead!`);
1144
+ }
1145
+ return body.apply(this, args);
1146
+ });
1147
+ var instancePrototype = Object.create(basePrototype, { constructor: { value: constructor } });
1148
+ constructor.prototype = instancePrototype;
1149
+ var registeredClass = new RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast);
1150
+ if (registeredClass.baseClass) {
1151
+ registeredClass.baseClass.__derivedClasses ??= [];
1152
+ registeredClass.baseClass.__derivedClasses.push(registeredClass);
1153
+ }
1154
+ var referenceConverter = new RegisteredPointer(name, registeredClass, true, false, false);
1155
+ var pointerConverter = new RegisteredPointer(name + "*", registeredClass, false, false, false);
1156
+ var constPointerConverter = new RegisteredPointer(name + " const*", registeredClass, false, true, false);
1157
+ registeredPointers[rawType] = { pointerType: pointerConverter, constPointerType: constPointerConverter };
1158
+ replacePublicSymbol(legalFunctionName, constructor);
1159
+ return [referenceConverter, pointerConverter, constPointerConverter];
1160
+ });
1161
+ };
1162
+ var heap32VectorToArray = (count, firstElement) => {
1163
+ var array = [];
1164
+ for (var i = 0; i < count; i++) {
1165
+ array.push(HEAPU32[firstElement + i * 4 >> 2]);
1166
+ }
1167
+ return array;
1168
+ };
1169
+ function usesDestructorStack(argTypes) {
1170
+ for (var i = 1; i < argTypes.length; ++i) {
1171
+ if (argTypes[i] !== null && argTypes[i].destructorFunction === void 0) {
1172
+ return true;
1173
+ }
1174
+ }
1175
+ return false;
1176
+ }
1177
+ function craftInvokerFunction(humanName, argTypes, classType, cppInvokerFunc, cppTargetFunc, isAsync) {
1178
+ var argCount = argTypes.length;
1179
+ if (argCount < 2) {
1180
+ throwBindingError("argTypes array size mismatch! Must at least get return value and 'this' types!");
1181
+ }
1182
+ var isClassMethodFunc = argTypes[1] !== null && classType !== null;
1183
+ var needsDestructorStack = usesDestructorStack(argTypes);
1184
+ var returns = argTypes[0].name !== "void";
1185
+ var expectedArgCount = argCount - 2;
1186
+ var argsWired = new Array(expectedArgCount);
1187
+ var invokerFuncArgs = [];
1188
+ var destructors = [];
1189
+ var invokerFn = function(...args) {
1190
+ if (args.length !== expectedArgCount) {
1191
+ throwBindingError(`function ${humanName} called with ${args.length} arguments, expected ${expectedArgCount}`);
1192
+ }
1193
+ destructors.length = 0;
1194
+ var thisWired;
1195
+ invokerFuncArgs.length = isClassMethodFunc ? 2 : 1;
1196
+ invokerFuncArgs[0] = cppTargetFunc;
1197
+ if (isClassMethodFunc) {
1198
+ thisWired = argTypes[1]["toWireType"](destructors, this);
1199
+ invokerFuncArgs[1] = thisWired;
1200
+ }
1201
+ for (var i = 0; i < expectedArgCount; ++i) {
1202
+ argsWired[i] = argTypes[i + 2]["toWireType"](destructors, args[i]);
1203
+ invokerFuncArgs.push(argsWired[i]);
1204
+ }
1205
+ var rv = cppInvokerFunc(...invokerFuncArgs);
1206
+ function onDone(rv2) {
1207
+ if (needsDestructorStack) {
1208
+ runDestructors(destructors);
1209
+ } else {
1210
+ for (var i2 = isClassMethodFunc ? 1 : 2; i2 < argTypes.length; i2++) {
1211
+ var param = i2 === 1 ? thisWired : argsWired[i2 - 2];
1212
+ if (argTypes[i2].destructorFunction !== null) {
1213
+ argTypes[i2].destructorFunction(param);
1214
+ }
1215
+ }
1216
+ }
1217
+ if (returns) {
1218
+ return argTypes[0]["fromWireType"](rv2);
1219
+ }
1220
+ }
1221
+ return onDone(rv);
1222
+ };
1223
+ return createNamedFunction(humanName, invokerFn);
1224
+ }
1225
+ var __embind_register_class_constructor = (rawClassType, argCount, rawArgTypesAddr, invokerSignature, invoker, rawConstructor) => {
1226
+ var rawArgTypes = heap32VectorToArray(argCount, rawArgTypesAddr);
1227
+ invoker = embind__requireFunction(invokerSignature, invoker);
1228
+ whenDependentTypesAreResolved([], [rawClassType], (classType) => {
1229
+ classType = classType[0];
1230
+ var humanName = `constructor ${classType.name}`;
1231
+ if (void 0 === classType.registeredClass.constructor_body) {
1232
+ classType.registeredClass.constructor_body = [];
1233
+ }
1234
+ if (void 0 !== classType.registeredClass.constructor_body[argCount - 1]) {
1235
+ throw new BindingError(`Cannot register multiple constructors with identical number of parameters (${argCount - 1}) for class '${classType.name}'! Overload resolution is currently only performed using the parameter count, not actual type info!`);
1236
+ }
1237
+ classType.registeredClass.constructor_body[argCount - 1] = () => {
1238
+ throwUnboundTypeError(`Cannot construct ${classType.name} due to unbound types`, rawArgTypes);
1239
+ };
1240
+ whenDependentTypesAreResolved([], rawArgTypes, (argTypes) => {
1241
+ argTypes.splice(1, 0, null);
1242
+ classType.registeredClass.constructor_body[argCount - 1] = craftInvokerFunction(humanName, argTypes, null, invoker, rawConstructor);
1243
+ return [];
1244
+ });
1245
+ return [];
1246
+ });
1247
+ };
1248
+ var getFunctionName = (signature) => {
1249
+ signature = signature.trim();
1250
+ const argsIndex = signature.indexOf("(");
1251
+ if (argsIndex !== -1) {
1252
+ return signature.substr(0, argsIndex);
1253
+ } else {
1254
+ return signature;
1255
+ }
1256
+ };
1257
+ var __embind_register_class_function = (rawClassType, methodName, argCount, rawArgTypesAddr, invokerSignature, rawInvoker, context, isPureVirtual, isAsync) => {
1258
+ var rawArgTypes = heap32VectorToArray(argCount, rawArgTypesAddr);
1259
+ methodName = readLatin1String(methodName);
1260
+ methodName = getFunctionName(methodName);
1261
+ rawInvoker = embind__requireFunction(invokerSignature, rawInvoker);
1262
+ whenDependentTypesAreResolved([], [rawClassType], (classType) => {
1263
+ classType = classType[0];
1264
+ var humanName = `${classType.name}.${methodName}`;
1265
+ if (methodName.startsWith("@@")) {
1266
+ methodName = Symbol[methodName.substring(2)];
1267
+ }
1268
+ if (isPureVirtual) {
1269
+ classType.registeredClass.pureVirtualFunctions.push(methodName);
1270
+ }
1271
+ function unboundTypesHandler() {
1272
+ throwUnboundTypeError(`Cannot call ${humanName} due to unbound types`, rawArgTypes);
1273
+ }
1274
+ var proto = classType.registeredClass.instancePrototype;
1275
+ var method = proto[methodName];
1276
+ if (void 0 === method || void 0 === method.overloadTable && method.className !== classType.name && method.argCount === argCount - 2) {
1277
+ unboundTypesHandler.argCount = argCount - 2;
1278
+ unboundTypesHandler.className = classType.name;
1279
+ proto[methodName] = unboundTypesHandler;
1280
+ } else {
1281
+ ensureOverloadTable(proto, methodName, humanName);
1282
+ proto[methodName].overloadTable[argCount - 2] = unboundTypesHandler;
1283
+ }
1284
+ whenDependentTypesAreResolved([], rawArgTypes, (argTypes) => {
1285
+ var memberFunction = craftInvokerFunction(humanName, argTypes, classType, rawInvoker, context, isAsync);
1286
+ if (void 0 === proto[methodName].overloadTable) {
1287
+ memberFunction.argCount = argCount - 2;
1288
+ proto[methodName] = memberFunction;
1289
+ } else {
1290
+ proto[methodName].overloadTable[argCount - 2] = memberFunction;
1291
+ }
1292
+ return [];
1293
+ });
1294
+ return [];
1295
+ });
1296
+ };
1297
+ var emval_freelist = [];
1298
+ var emval_handles = [];
1299
+ var __emval_decref = (handle) => {
1300
+ if (handle > 9 && 0 === --emval_handles[handle + 1]) {
1301
+ emval_handles[handle] = void 0;
1302
+ emval_freelist.push(handle);
1303
+ }
1304
+ };
1305
+ var count_emval_handles = () => emval_handles.length / 2 - 5 - emval_freelist.length;
1306
+ var init_emval = () => {
1307
+ emval_handles.push(0, 1, void 0, 1, null, 1, true, 1, false, 1);
1308
+ Module["count_emval_handles"] = count_emval_handles;
1309
+ };
1310
+ var Emval = { toValue: (handle) => {
1311
+ if (!handle) {
1312
+ throwBindingError("Cannot use deleted val. handle = " + handle);
1313
+ }
1314
+ return emval_handles[handle];
1315
+ }, toHandle: (value) => {
1316
+ switch (value) {
1317
+ case void 0:
1318
+ return 2;
1319
+ case null:
1320
+ return 4;
1321
+ case true:
1322
+ return 6;
1323
+ case false:
1324
+ return 8;
1325
+ default: {
1326
+ const handle = emval_freelist.pop() || emval_handles.length;
1327
+ emval_handles[handle] = value;
1328
+ emval_handles[handle + 1] = 1;
1329
+ return handle;
1330
+ }
1331
+ }
1332
+ } };
1333
+ var EmValType = { name: "emscripten::val", "fromWireType": (handle) => {
1334
+ var rv = Emval.toValue(handle);
1335
+ __emval_decref(handle);
1336
+ return rv;
1337
+ }, "toWireType": (destructors, value) => Emval.toHandle(value), "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": readPointer, destructorFunction: null };
1338
+ var __embind_register_emval = (rawType) => registerType(rawType, EmValType);
1339
+ var enumReadValueFromPointer = (name, width, signed) => {
1340
+ switch (width) {
1341
+ case 1:
1342
+ return signed ? function(pointer) {
1343
+ return this["fromWireType"](HEAP8[pointer]);
1344
+ } : function(pointer) {
1345
+ return this["fromWireType"](HEAPU8[pointer]);
1346
+ };
1347
+ case 2:
1348
+ return signed ? function(pointer) {
1349
+ return this["fromWireType"](HEAP16[pointer >> 1]);
1350
+ } : function(pointer) {
1351
+ return this["fromWireType"](HEAPU16[pointer >> 1]);
1352
+ };
1353
+ case 4:
1354
+ return signed ? function(pointer) {
1355
+ return this["fromWireType"](HEAP32[pointer >> 2]);
1356
+ } : function(pointer) {
1357
+ return this["fromWireType"](HEAPU32[pointer >> 2]);
1358
+ };
1359
+ default:
1360
+ throw new TypeError(`invalid integer width (${width}): ${name}`);
1361
+ }
1362
+ };
1363
+ var __embind_register_enum = (rawType, name, size, isSigned) => {
1364
+ name = readLatin1String(name);
1365
+ function ctor() {
1366
+ }
1367
+ ctor.values = {};
1368
+ registerType(rawType, { name, constructor: ctor, "fromWireType": function(c) {
1369
+ return this.constructor.values[c];
1370
+ }, "toWireType": (destructors, c) => c.value, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": enumReadValueFromPointer(name, size, isSigned), destructorFunction: null });
1371
+ exposePublicSymbol(name, ctor);
1372
+ };
1373
+ var requireRegisteredType = (rawType, humanName) => {
1374
+ var impl = registeredTypes[rawType];
1375
+ if (void 0 === impl) {
1376
+ throwBindingError(`${humanName} has unknown type ${getTypeName(rawType)}`);
1377
+ }
1378
+ return impl;
1379
+ };
1380
+ var __embind_register_enum_value = (rawEnumType, name, enumValue) => {
1381
+ var enumType = requireRegisteredType(rawEnumType, "enum");
1382
+ name = readLatin1String(name);
1383
+ var Enum = enumType.constructor;
1384
+ var Value = Object.create(enumType.constructor.prototype, { value: { value: enumValue }, constructor: { value: createNamedFunction(`${enumType.name}_${name}`, function() {
1385
+ }) } });
1386
+ Enum.values[enumValue] = Value;
1387
+ Enum[name] = Value;
1388
+ };
1389
+ var embindRepr = (v) => {
1390
+ if (v === null) {
1391
+ return "null";
1392
+ }
1393
+ var t = typeof v;
1394
+ if (t === "object" || t === "array" || t === "function") {
1395
+ return v.toString();
1396
+ } else {
1397
+ return "" + v;
1398
+ }
1399
+ };
1400
+ var floatReadValueFromPointer = (name, width) => {
1401
+ switch (width) {
1402
+ case 4:
1403
+ return function(pointer) {
1404
+ return this["fromWireType"](HEAPF32[pointer >> 2]);
1405
+ };
1406
+ case 8:
1407
+ return function(pointer) {
1408
+ return this["fromWireType"](HEAPF64[pointer >> 3]);
1409
+ };
1410
+ default:
1411
+ throw new TypeError(`invalid float width (${width}): ${name}`);
1412
+ }
1413
+ };
1414
+ var __embind_register_float = (rawType, name, size) => {
1415
+ name = readLatin1String(name);
1416
+ registerType(rawType, { name, "fromWireType": (value) => value, "toWireType": (destructors, value) => value, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": floatReadValueFromPointer(name, size), destructorFunction: null });
1417
+ };
1418
+ var __embind_register_function = (name, argCount, rawArgTypesAddr, signature, rawInvoker, fn, isAsync) => {
1419
+ var argTypes = heap32VectorToArray(argCount, rawArgTypesAddr);
1420
+ name = readLatin1String(name);
1421
+ name = getFunctionName(name);
1422
+ rawInvoker = embind__requireFunction(signature, rawInvoker);
1423
+ exposePublicSymbol(name, function() {
1424
+ throwUnboundTypeError(`Cannot call ${name} due to unbound types`, argTypes);
1425
+ }, argCount - 1);
1426
+ whenDependentTypesAreResolved([], argTypes, (argTypes2) => {
1427
+ var invokerArgsArray = [argTypes2[0], null].concat(argTypes2.slice(1));
1428
+ replacePublicSymbol(name, craftInvokerFunction(name, invokerArgsArray, null, rawInvoker, fn, isAsync), argCount - 1);
1429
+ return [];
1430
+ });
1431
+ };
1432
+ var integerReadValueFromPointer = (name, width, signed) => {
1433
+ switch (width) {
1434
+ case 1:
1435
+ return signed ? (pointer) => HEAP8[pointer] : (pointer) => HEAPU8[pointer];
1436
+ case 2:
1437
+ return signed ? (pointer) => HEAP16[pointer >> 1] : (pointer) => HEAPU16[pointer >> 1];
1438
+ case 4:
1439
+ return signed ? (pointer) => HEAP32[pointer >> 2] : (pointer) => HEAPU32[pointer >> 2];
1440
+ default:
1441
+ throw new TypeError(`invalid integer width (${width}): ${name}`);
1442
+ }
1443
+ };
1444
+ var __embind_register_integer = (primitiveType, name, size, minRange, maxRange) => {
1445
+ name = readLatin1String(name);
1446
+ if (maxRange === -1) {
1447
+ maxRange = 4294967295;
1448
+ }
1449
+ var fromWireType = (value) => value;
1450
+ if (minRange === 0) {
1451
+ var bitshift = 32 - 8 * size;
1452
+ fromWireType = (value) => value << bitshift >>> bitshift;
1453
+ }
1454
+ var isUnsignedType = name.includes("unsigned");
1455
+ var checkAssertions = (value, toTypeName) => {
1456
+ };
1457
+ var toWireType;
1458
+ if (isUnsignedType) {
1459
+ toWireType = function(destructors, value) {
1460
+ checkAssertions(value, this.name);
1461
+ return value >>> 0;
1462
+ };
1463
+ } else {
1464
+ toWireType = function(destructors, value) {
1465
+ checkAssertions(value, this.name);
1466
+ return value;
1467
+ };
1468
+ }
1469
+ registerType(primitiveType, { name, "fromWireType": fromWireType, "toWireType": toWireType, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": integerReadValueFromPointer(name, size, minRange !== 0), destructorFunction: null });
1470
+ };
1471
+ var __embind_register_memory_view = (rawType, dataTypeIndex, name) => {
1472
+ var typeMapping = [Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array];
1473
+ var TA = typeMapping[dataTypeIndex];
1474
+ function decodeMemoryView(handle) {
1475
+ var size = HEAPU32[handle >> 2];
1476
+ var data = HEAPU32[handle + 4 >> 2];
1477
+ return new TA(HEAP8.buffer, data, size);
1478
+ }
1479
+ name = readLatin1String(name);
1480
+ registerType(rawType, { name, "fromWireType": decodeMemoryView, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": decodeMemoryView }, { ignoreDuplicateRegistrations: true });
1481
+ };
1482
+ var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => {
1483
+ if (!(maxBytesToWrite > 0)) return 0;
1484
+ var startIdx = outIdx;
1485
+ var endIdx = outIdx + maxBytesToWrite - 1;
1486
+ for (var i = 0; i < str.length; ++i) {
1487
+ var u = str.charCodeAt(i);
1488
+ if (u >= 55296 && u <= 57343) {
1489
+ var u1 = str.charCodeAt(++i);
1490
+ u = 65536 + ((u & 1023) << 10) | u1 & 1023;
1491
+ }
1492
+ if (u <= 127) {
1493
+ if (outIdx >= endIdx) break;
1494
+ heap[outIdx++] = u;
1495
+ } else if (u <= 2047) {
1496
+ if (outIdx + 1 >= endIdx) break;
1497
+ heap[outIdx++] = 192 | u >> 6;
1498
+ heap[outIdx++] = 128 | u & 63;
1499
+ } else if (u <= 65535) {
1500
+ if (outIdx + 2 >= endIdx) break;
1501
+ heap[outIdx++] = 224 | u >> 12;
1502
+ heap[outIdx++] = 128 | u >> 6 & 63;
1503
+ heap[outIdx++] = 128 | u & 63;
1504
+ } else {
1505
+ if (outIdx + 3 >= endIdx) break;
1506
+ heap[outIdx++] = 240 | u >> 18;
1507
+ heap[outIdx++] = 128 | u >> 12 & 63;
1508
+ heap[outIdx++] = 128 | u >> 6 & 63;
1509
+ heap[outIdx++] = 128 | u & 63;
1510
+ }
1511
+ }
1512
+ heap[outIdx] = 0;
1513
+ return outIdx - startIdx;
1514
+ };
1515
+ var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
1516
+ var lengthBytesUTF8 = (str) => {
1517
+ var len = 0;
1518
+ for (var i = 0; i < str.length; ++i) {
1519
+ var c = str.charCodeAt(i);
1520
+ if (c <= 127) {
1521
+ len++;
1522
+ } else if (c <= 2047) {
1523
+ len += 2;
1524
+ } else if (c >= 55296 && c <= 57343) {
1525
+ len += 4;
1526
+ ++i;
1527
+ } else {
1528
+ len += 3;
1529
+ }
1530
+ }
1531
+ return len;
1532
+ };
1533
+ var __embind_register_std_string = (rawType, name) => {
1534
+ name = readLatin1String(name);
1535
+ var stdStringIsUTF8 = name === "std::string";
1536
+ registerType(rawType, { name, "fromWireType"(value) {
1537
+ var length = HEAPU32[value >> 2];
1538
+ var payload = value + 4;
1539
+ var str;
1540
+ if (stdStringIsUTF8) {
1541
+ var decodeStartPtr = payload;
1542
+ for (var i = 0; i <= length; ++i) {
1543
+ var currentBytePtr = payload + i;
1544
+ if (i == length || HEAPU8[currentBytePtr] == 0) {
1545
+ var maxRead = currentBytePtr - decodeStartPtr;
1546
+ var stringSegment = UTF8ToString(decodeStartPtr, maxRead);
1547
+ if (str === void 0) {
1548
+ str = stringSegment;
1549
+ } else {
1550
+ str += String.fromCharCode(0);
1551
+ str += stringSegment;
1552
+ }
1553
+ decodeStartPtr = currentBytePtr + 1;
1554
+ }
1555
+ }
1556
+ } else {
1557
+ var a = new Array(length);
1558
+ for (var i = 0; i < length; ++i) {
1559
+ a[i] = String.fromCharCode(HEAPU8[payload + i]);
1560
+ }
1561
+ str = a.join("");
1562
+ }
1563
+ _free(value);
1564
+ return str;
1565
+ }, "toWireType"(destructors, value) {
1566
+ if (value instanceof ArrayBuffer) {
1567
+ value = new Uint8Array(value);
1568
+ }
1569
+ var length;
1570
+ var valueIsOfTypeString = typeof value == "string";
1571
+ if (!(valueIsOfTypeString || value instanceof Uint8Array || value instanceof Uint8ClampedArray || value instanceof Int8Array)) {
1572
+ throwBindingError("Cannot pass non-string to std::string");
1573
+ }
1574
+ if (stdStringIsUTF8 && valueIsOfTypeString) {
1575
+ length = lengthBytesUTF8(value);
1576
+ } else {
1577
+ length = value.length;
1578
+ }
1579
+ var base = _malloc(4 + length + 1);
1580
+ var ptr = base + 4;
1581
+ HEAPU32[base >> 2] = length;
1582
+ if (stdStringIsUTF8 && valueIsOfTypeString) {
1583
+ stringToUTF8(value, ptr, length + 1);
1584
+ } else {
1585
+ if (valueIsOfTypeString) {
1586
+ for (var i = 0; i < length; ++i) {
1587
+ var charCode = value.charCodeAt(i);
1588
+ if (charCode > 255) {
1589
+ _free(ptr);
1590
+ throwBindingError("String has UTF-16 code units that do not fit in 8 bits");
1591
+ }
1592
+ HEAPU8[ptr + i] = charCode;
1593
+ }
1594
+ } else {
1595
+ for (var i = 0; i < length; ++i) {
1596
+ HEAPU8[ptr + i] = value[i];
1597
+ }
1598
+ }
1599
+ }
1600
+ if (destructors !== null) {
1601
+ destructors.push(_free, base);
1602
+ }
1603
+ return base;
1604
+ }, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": readPointer, destructorFunction(ptr) {
1605
+ _free(ptr);
1606
+ } });
1607
+ };
1608
+ var UTF16Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf-16le") : void 0;
1609
+ var UTF16ToString = (ptr, maxBytesToRead) => {
1610
+ var endPtr = ptr;
1611
+ var idx = endPtr >> 1;
1612
+ var maxIdx = idx + maxBytesToRead / 2;
1613
+ while (!(idx >= maxIdx) && HEAPU16[idx]) ++idx;
1614
+ endPtr = idx << 1;
1615
+ if (endPtr - ptr > 32 && UTF16Decoder) return UTF16Decoder.decode(HEAPU8.subarray(ptr, endPtr));
1616
+ var str = "";
1617
+ for (var i = 0; !(i >= maxBytesToRead / 2); ++i) {
1618
+ var codeUnit = HEAP16[ptr + i * 2 >> 1];
1619
+ if (codeUnit == 0) break;
1620
+ str += String.fromCharCode(codeUnit);
1621
+ }
1622
+ return str;
1623
+ };
1624
+ var stringToUTF16 = (str, outPtr, maxBytesToWrite) => {
1625
+ maxBytesToWrite ??= 2147483647;
1626
+ if (maxBytesToWrite < 2) return 0;
1627
+ maxBytesToWrite -= 2;
1628
+ var startPtr = outPtr;
1629
+ var numCharsToWrite = maxBytesToWrite < str.length * 2 ? maxBytesToWrite / 2 : str.length;
1630
+ for (var i = 0; i < numCharsToWrite; ++i) {
1631
+ var codeUnit = str.charCodeAt(i);
1632
+ HEAP16[outPtr >> 1] = codeUnit;
1633
+ outPtr += 2;
1634
+ }
1635
+ HEAP16[outPtr >> 1] = 0;
1636
+ return outPtr - startPtr;
1637
+ };
1638
+ var lengthBytesUTF16 = (str) => str.length * 2;
1639
+ var UTF32ToString = (ptr, maxBytesToRead) => {
1640
+ var i = 0;
1641
+ var str = "";
1642
+ while (!(i >= maxBytesToRead / 4)) {
1643
+ var utf32 = HEAP32[ptr + i * 4 >> 2];
1644
+ if (utf32 == 0) break;
1645
+ ++i;
1646
+ if (utf32 >= 65536) {
1647
+ var ch = utf32 - 65536;
1648
+ str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
1649
+ } else {
1650
+ str += String.fromCharCode(utf32);
1651
+ }
1652
+ }
1653
+ return str;
1654
+ };
1655
+ var stringToUTF32 = (str, outPtr, maxBytesToWrite) => {
1656
+ maxBytesToWrite ??= 2147483647;
1657
+ if (maxBytesToWrite < 4) return 0;
1658
+ var startPtr = outPtr;
1659
+ var endPtr = startPtr + maxBytesToWrite - 4;
1660
+ for (var i = 0; i < str.length; ++i) {
1661
+ var codeUnit = str.charCodeAt(i);
1662
+ if (codeUnit >= 55296 && codeUnit <= 57343) {
1663
+ var trailSurrogate = str.charCodeAt(++i);
1664
+ codeUnit = 65536 + ((codeUnit & 1023) << 10) | trailSurrogate & 1023;
1665
+ }
1666
+ HEAP32[outPtr >> 2] = codeUnit;
1667
+ outPtr += 4;
1668
+ if (outPtr + 4 > endPtr) break;
1669
+ }
1670
+ HEAP32[outPtr >> 2] = 0;
1671
+ return outPtr - startPtr;
1672
+ };
1673
+ var lengthBytesUTF32 = (str) => {
1674
+ var len = 0;
1675
+ for (var i = 0; i < str.length; ++i) {
1676
+ var codeUnit = str.charCodeAt(i);
1677
+ if (codeUnit >= 55296 && codeUnit <= 57343) ++i;
1678
+ len += 4;
1679
+ }
1680
+ return len;
1681
+ };
1682
+ var __embind_register_std_wstring = (rawType, charSize, name) => {
1683
+ name = readLatin1String(name);
1684
+ var decodeString, encodeString, readCharAt, lengthBytesUTF;
1685
+ if (charSize === 2) {
1686
+ decodeString = UTF16ToString;
1687
+ encodeString = stringToUTF16;
1688
+ lengthBytesUTF = lengthBytesUTF16;
1689
+ readCharAt = (pointer) => HEAPU16[pointer >> 1];
1690
+ } else if (charSize === 4) {
1691
+ decodeString = UTF32ToString;
1692
+ encodeString = stringToUTF32;
1693
+ lengthBytesUTF = lengthBytesUTF32;
1694
+ readCharAt = (pointer) => HEAPU32[pointer >> 2];
1695
+ }
1696
+ registerType(rawType, { name, "fromWireType": (value) => {
1697
+ var length = HEAPU32[value >> 2];
1698
+ var str;
1699
+ var decodeStartPtr = value + 4;
1700
+ for (var i = 0; i <= length; ++i) {
1701
+ var currentBytePtr = value + 4 + i * charSize;
1702
+ if (i == length || readCharAt(currentBytePtr) == 0) {
1703
+ var maxReadBytes = currentBytePtr - decodeStartPtr;
1704
+ var stringSegment = decodeString(decodeStartPtr, maxReadBytes);
1705
+ if (str === void 0) {
1706
+ str = stringSegment;
1707
+ } else {
1708
+ str += String.fromCharCode(0);
1709
+ str += stringSegment;
1710
+ }
1711
+ decodeStartPtr = currentBytePtr + charSize;
1712
+ }
1713
+ }
1714
+ _free(value);
1715
+ return str;
1716
+ }, "toWireType": (destructors, value) => {
1717
+ if (!(typeof value == "string")) {
1718
+ throwBindingError(`Cannot pass non-string to C++ string type ${name}`);
1719
+ }
1720
+ var length = lengthBytesUTF(value);
1721
+ var ptr = _malloc(4 + length + charSize);
1722
+ HEAPU32[ptr >> 2] = length / charSize;
1723
+ encodeString(value, ptr + 4, length + charSize);
1724
+ if (destructors !== null) {
1725
+ destructors.push(_free, ptr);
1726
+ }
1727
+ return ptr;
1728
+ }, "argPackAdvance": GenericWireTypeSize, "readValueFromPointer": readPointer, destructorFunction(ptr) {
1729
+ _free(ptr);
1730
+ } });
1731
+ };
1732
+ var __embind_register_value_object = (rawType, name, constructorSignature, rawConstructor, destructorSignature, rawDestructor) => {
1733
+ structRegistrations[rawType] = { name: readLatin1String(name), rawConstructor: embind__requireFunction(constructorSignature, rawConstructor), rawDestructor: embind__requireFunction(destructorSignature, rawDestructor), fields: [] };
1734
+ };
1735
+ var __embind_register_value_object_field = (structType, fieldName, getterReturnType, getterSignature, getter, getterContext, setterArgumentType, setterSignature, setter, setterContext) => {
1736
+ structRegistrations[structType].fields.push({ fieldName: readLatin1String(fieldName), getterReturnType, getter: embind__requireFunction(getterSignature, getter), getterContext, setterArgumentType, setter: embind__requireFunction(setterSignature, setter), setterContext });
1737
+ };
1738
+ var __embind_register_void = (rawType, name) => {
1739
+ name = readLatin1String(name);
1740
+ registerType(rawType, { isVoid: true, name, "argPackAdvance": 0, "fromWireType": () => void 0, "toWireType": (destructors, o) => void 0 });
1741
+ };
1742
+ var emval_methodCallers = [];
1743
+ var __emval_call = (caller, handle, destructorsRef, args) => {
1744
+ caller = emval_methodCallers[caller];
1745
+ handle = Emval.toValue(handle);
1746
+ return caller(null, handle, destructorsRef, args);
1747
+ };
1748
+ var emval_symbols = {};
1749
+ var getStringOrSymbol = (address) => {
1750
+ var symbol = emval_symbols[address];
1751
+ if (symbol === void 0) {
1752
+ return readLatin1String(address);
1753
+ }
1754
+ return symbol;
1755
+ };
1756
+ var __emval_call_method = (caller, objHandle, methodName, destructorsRef, args) => {
1757
+ caller = emval_methodCallers[caller];
1758
+ objHandle = Emval.toValue(objHandle);
1759
+ methodName = getStringOrSymbol(methodName);
1760
+ return caller(objHandle, objHandle[methodName], destructorsRef, args);
1761
+ };
1762
+ var emval_get_global = () => {
1763
+ if (typeof globalThis == "object") {
1764
+ return globalThis;
1765
+ }
1766
+ function testGlobal(obj) {
1767
+ obj["$$$embind_global$$$"] = obj;
1768
+ var success = typeof $$$embind_global$$$ == "object" && obj["$$$embind_global$$$"] == obj;
1769
+ if (!success) {
1770
+ delete obj["$$$embind_global$$$"];
1771
+ }
1772
+ return success;
1773
+ }
1774
+ if (typeof $$$embind_global$$$ == "object") {
1775
+ return $$$embind_global$$$;
1776
+ }
1777
+ if (typeof global == "object" && testGlobal(global)) {
1778
+ $$$embind_global$$$ = global;
1779
+ } else if (typeof self == "object" && testGlobal(self)) {
1780
+ $$$embind_global$$$ = self;
1781
+ }
1782
+ if (typeof $$$embind_global$$$ == "object") {
1783
+ return $$$embind_global$$$;
1784
+ }
1785
+ throw Error("unable to get global object.");
1786
+ };
1787
+ var __emval_get_global = (name) => {
1788
+ if (name === 0) {
1789
+ return Emval.toHandle(emval_get_global());
1790
+ } else {
1791
+ name = getStringOrSymbol(name);
1792
+ return Emval.toHandle(emval_get_global()[name]);
1793
+ }
1794
+ };
1795
+ var emval_addMethodCaller = (caller) => {
1796
+ var id = emval_methodCallers.length;
1797
+ emval_methodCallers.push(caller);
1798
+ return id;
1799
+ };
1800
+ var emval_lookupTypes = (argCount, argTypes) => {
1801
+ var a = new Array(argCount);
1802
+ for (var i = 0; i < argCount; ++i) {
1803
+ a[i] = requireRegisteredType(HEAPU32[argTypes + i * 4 >> 2], "parameter " + i);
1804
+ }
1805
+ return a;
1806
+ };
1807
+ var reflectConstruct = Reflect.construct;
1808
+ var emval_returnValue = (returnType, destructorsRef, handle) => {
1809
+ var destructors = [];
1810
+ var result = returnType["toWireType"](destructors, handle);
1811
+ if (destructors.length) {
1812
+ HEAPU32[destructorsRef >> 2] = Emval.toHandle(destructors);
1813
+ }
1814
+ return result;
1815
+ };
1816
+ var __emval_get_method_caller = (argCount, argTypes, kind) => {
1817
+ var types = emval_lookupTypes(argCount, argTypes);
1818
+ var retType = types.shift();
1819
+ argCount--;
1820
+ var argN = new Array(argCount);
1821
+ var invokerFunction = (obj, func, destructorsRef, args) => {
1822
+ var offset = 0;
1823
+ for (var i = 0; i < argCount; ++i) {
1824
+ argN[i] = types[i]["readValueFromPointer"](args + offset);
1825
+ offset += types[i]["argPackAdvance"];
1826
+ }
1827
+ var rv = kind === 1 ? reflectConstruct(func, argN) : func.apply(obj, argN);
1828
+ return emval_returnValue(retType, destructorsRef, rv);
1829
+ };
1830
+ var functionName = `methodCaller<(${types.map((t) => t.name).join(", ")}) => ${retType.name}>`;
1831
+ return emval_addMethodCaller(createNamedFunction(functionName, invokerFunction));
1832
+ };
1833
+ var __emval_incref = (handle) => {
1834
+ if (handle > 9) {
1835
+ emval_handles[handle + 1] += 1;
1836
+ }
1837
+ };
1838
+ var __emval_new_array = () => Emval.toHandle([]);
1839
+ var __emval_new_cstring = (v) => Emval.toHandle(getStringOrSymbol(v));
1840
+ var __emval_new_object = () => Emval.toHandle({});
1841
+ var __emval_run_destructors = (handle) => {
1842
+ var destructors = Emval.toValue(handle);
1843
+ runDestructors(destructors);
1844
+ __emval_decref(handle);
1845
+ };
1846
+ var __emval_set_property = (handle, key, value) => {
1847
+ handle = Emval.toValue(handle);
1848
+ key = Emval.toValue(key);
1849
+ value = Emval.toValue(value);
1850
+ handle[key] = value;
1851
+ };
1852
+ var __emval_take_value = (type, arg) => {
1853
+ type = requireRegisteredType(type, "_emval_take_value");
1854
+ var v = type["readValueFromPointer"](arg);
1855
+ return Emval.toHandle(v);
1856
+ };
1857
+ var _abort = () => {
1858
+ abort("");
1859
+ };
1860
+ var _emscripten_memcpy_js = (dest, src, num) => HEAPU8.copyWithin(dest, src, src + num);
1861
+ var getHeapMax = () => 2147483648;
1862
+ var growMemory = (size) => {
1863
+ var b = wasmMemory.buffer;
1864
+ var pages = (size - b.byteLength + 65535) / 65536;
1865
+ try {
1866
+ wasmMemory.grow(pages);
1867
+ updateMemoryViews();
1868
+ return 1;
1869
+ } catch (e) {
1870
+ }
1871
+ };
1872
+ var _emscripten_resize_heap = (requestedSize) => {
1873
+ var oldSize = HEAPU8.length;
1874
+ requestedSize >>>= 0;
1875
+ var maxHeapSize = getHeapMax();
1876
+ if (requestedSize > maxHeapSize) {
1877
+ return false;
1878
+ }
1879
+ var alignUp = (x, multiple) => x + (multiple - x % multiple) % multiple;
1880
+ for (var cutDown = 1; cutDown <= 4; cutDown *= 2) {
1881
+ var overGrownHeapSize = oldSize * (1 + 0.2 / cutDown);
1882
+ overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296);
1883
+ var newSize = Math.min(maxHeapSize, alignUp(Math.max(requestedSize, overGrownHeapSize), 65536));
1884
+ var replacement = growMemory(newSize);
1885
+ if (replacement) {
1886
+ return true;
1887
+ }
1888
+ }
1889
+ return false;
1890
+ };
1891
+ var ENV = {};
1892
+ var getExecutableName = () => thisProgram || "./this.program";
1893
+ var getEnvStrings = () => {
1894
+ if (!getEnvStrings.strings) {
1895
+ var lang = (typeof navigator == "object" && navigator.languages && navigator.languages[0] || "C").replace("-", "_") + ".UTF-8";
1896
+ var env = { "USER": "web_user", "LOGNAME": "web_user", "PATH": "/", "PWD": "/", "HOME": "/home/web_user", "LANG": lang, "_": getExecutableName() };
1897
+ for (var x in ENV) {
1898
+ if (ENV[x] === void 0) delete env[x];
1899
+ else env[x] = ENV[x];
1900
+ }
1901
+ var strings = [];
1902
+ for (var x in env) {
1903
+ strings.push(`${x}=${env[x]}`);
1904
+ }
1905
+ getEnvStrings.strings = strings;
1906
+ }
1907
+ return getEnvStrings.strings;
1908
+ };
1909
+ var stringToAscii = (str, buffer) => {
1910
+ for (var i = 0; i < str.length; ++i) {
1911
+ HEAP8[buffer++] = str.charCodeAt(i);
1912
+ }
1913
+ HEAP8[buffer] = 0;
1914
+ };
1915
+ var _environ_get = (__environ, environ_buf) => {
1916
+ var bufSize = 0;
1917
+ getEnvStrings().forEach((string, i) => {
1918
+ var ptr = environ_buf + bufSize;
1919
+ HEAPU32[__environ + i * 4 >> 2] = ptr;
1920
+ stringToAscii(string, ptr);
1921
+ bufSize += string.length + 1;
1922
+ });
1923
+ return 0;
1924
+ };
1925
+ var _environ_sizes_get = (penviron_count, penviron_buf_size) => {
1926
+ var strings = getEnvStrings();
1927
+ HEAPU32[penviron_count >> 2] = strings.length;
1928
+ var bufSize = 0;
1929
+ strings.forEach((string) => bufSize += string.length + 1);
1930
+ HEAPU32[penviron_buf_size >> 2] = bufSize;
1931
+ return 0;
1932
+ };
1933
+ var PATH = { isAbs: (path) => path.charAt(0) === "/", splitPath: (filename) => {
1934
+ var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;
1935
+ return splitPathRe.exec(filename).slice(1);
1936
+ }, normalizeArray: (parts, allowAboveRoot) => {
1937
+ var up = 0;
1938
+ for (var i = parts.length - 1; i >= 0; i--) {
1939
+ var last = parts[i];
1940
+ if (last === ".") {
1941
+ parts.splice(i, 1);
1942
+ } else if (last === "..") {
1943
+ parts.splice(i, 1);
1944
+ up++;
1945
+ } else if (up) {
1946
+ parts.splice(i, 1);
1947
+ up--;
1948
+ }
1949
+ }
1950
+ if (allowAboveRoot) {
1951
+ for (; up; up--) {
1952
+ parts.unshift("..");
1953
+ }
1954
+ }
1955
+ return parts;
1956
+ }, normalize: (path) => {
1957
+ var isAbsolute = PATH.isAbs(path), trailingSlash = path.substr(-1) === "/";
1958
+ path = PATH.normalizeArray(path.split("/").filter((p) => !!p), !isAbsolute).join("/");
1959
+ if (!path && !isAbsolute) {
1960
+ path = ".";
1961
+ }
1962
+ if (path && trailingSlash) {
1963
+ path += "/";
1964
+ }
1965
+ return (isAbsolute ? "/" : "") + path;
1966
+ }, dirname: (path) => {
1967
+ var result = PATH.splitPath(path), root = result[0], dir = result[1];
1968
+ if (!root && !dir) {
1969
+ return ".";
1970
+ }
1971
+ if (dir) {
1972
+ dir = dir.substr(0, dir.length - 1);
1973
+ }
1974
+ return root + dir;
1975
+ }, basename: (path) => {
1976
+ if (path === "/") return "/";
1977
+ path = PATH.normalize(path);
1978
+ path = path.replace(/\/$/, "");
1979
+ var lastSlash = path.lastIndexOf("/");
1980
+ if (lastSlash === -1) return path;
1981
+ return path.substr(lastSlash + 1);
1982
+ }, join: (...paths) => PATH.normalize(paths.join("/")), join2: (l, r) => PATH.normalize(l + "/" + r) };
1983
+ var initRandomFill = () => {
1984
+ if (typeof crypto == "object" && typeof crypto["getRandomValues"] == "function") {
1985
+ return (view) => crypto.getRandomValues(view);
1986
+ } else if (ENVIRONMENT_IS_NODE) {
1987
+ try {
1988
+ var crypto_module = require2("crypto");
1989
+ var randomFillSync = crypto_module["randomFillSync"];
1990
+ if (randomFillSync) {
1991
+ return (view) => crypto_module["randomFillSync"](view);
1992
+ }
1993
+ var randomBytes = crypto_module["randomBytes"];
1994
+ return (view) => (view.set(randomBytes(view.byteLength)), view);
1995
+ } catch (e) {
1996
+ }
1997
+ }
1998
+ abort("initRandomDevice");
1999
+ };
2000
+ var randomFill = (view) => (randomFill = initRandomFill())(view);
2001
+ var PATH_FS = { resolve: (...args) => {
2002
+ var resolvedPath = "", resolvedAbsolute = false;
2003
+ for (var i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {
2004
+ var path = i >= 0 ? args[i] : FS.cwd();
2005
+ if (typeof path != "string") {
2006
+ throw new TypeError("Arguments to path.resolve must be strings");
2007
+ } else if (!path) {
2008
+ return "";
2009
+ }
2010
+ resolvedPath = path + "/" + resolvedPath;
2011
+ resolvedAbsolute = PATH.isAbs(path);
2012
+ }
2013
+ resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter((p) => !!p), !resolvedAbsolute).join("/");
2014
+ return (resolvedAbsolute ? "/" : "") + resolvedPath || ".";
2015
+ }, relative: (from, to) => {
2016
+ from = PATH_FS.resolve(from).substr(1);
2017
+ to = PATH_FS.resolve(to).substr(1);
2018
+ function trim(arr) {
2019
+ var start = 0;
2020
+ for (; start < arr.length; start++) {
2021
+ if (arr[start] !== "") break;
2022
+ }
2023
+ var end = arr.length - 1;
2024
+ for (; end >= 0; end--) {
2025
+ if (arr[end] !== "") break;
2026
+ }
2027
+ if (start > end) return [];
2028
+ return arr.slice(start, end - start + 1);
2029
+ }
2030
+ var fromParts = trim(from.split("/"));
2031
+ var toParts = trim(to.split("/"));
2032
+ var length = Math.min(fromParts.length, toParts.length);
2033
+ var samePartsLength = length;
2034
+ for (var i = 0; i < length; i++) {
2035
+ if (fromParts[i] !== toParts[i]) {
2036
+ samePartsLength = i;
2037
+ break;
2038
+ }
2039
+ }
2040
+ var outputParts = [];
2041
+ for (var i = samePartsLength; i < fromParts.length; i++) {
2042
+ outputParts.push("..");
2043
+ }
2044
+ outputParts = outputParts.concat(toParts.slice(samePartsLength));
2045
+ return outputParts.join("/");
2046
+ } };
2047
+ var FS_stdin_getChar_buffer = [];
2048
+ function intArrayFromString(stringy, dontAddNull, length) {
2049
+ var len = length > 0 ? length : lengthBytesUTF8(stringy) + 1;
2050
+ var u8array = new Array(len);
2051
+ var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length);
2052
+ if (dontAddNull) u8array.length = numBytesWritten;
2053
+ return u8array;
2054
+ }
2055
+ var FS_stdin_getChar = () => {
2056
+ if (!FS_stdin_getChar_buffer.length) {
2057
+ var result = null;
2058
+ if (ENVIRONMENT_IS_NODE) {
2059
+ var BUFSIZE = 256;
2060
+ var buf = Buffer.alloc(BUFSIZE);
2061
+ var bytesRead = 0;
2062
+ var fd = process.stdin.fd;
2063
+ try {
2064
+ bytesRead = fs.readSync(fd, buf);
2065
+ } catch (e) {
2066
+ if (e.toString().includes("EOF")) bytesRead = 0;
2067
+ else throw e;
2068
+ }
2069
+ if (bytesRead > 0) {
2070
+ result = buf.slice(0, bytesRead).toString("utf-8");
2071
+ } else {
2072
+ result = null;
2073
+ }
2074
+ } else if (typeof window != "undefined" && typeof window.prompt == "function") {
2075
+ result = window.prompt("Input: ");
2076
+ if (result !== null) {
2077
+ result += "\n";
2078
+ }
2079
+ } else if (typeof readline == "function") {
2080
+ result = readline();
2081
+ if (result !== null) {
2082
+ result += "\n";
2083
+ }
2084
+ }
2085
+ if (!result) {
2086
+ return null;
2087
+ }
2088
+ FS_stdin_getChar_buffer = intArrayFromString(result, true);
2089
+ }
2090
+ return FS_stdin_getChar_buffer.shift();
2091
+ };
2092
+ var TTY = { ttys: [], init() {
2093
+ }, shutdown() {
2094
+ }, register(dev, ops) {
2095
+ TTY.ttys[dev] = { input: [], output: [], ops };
2096
+ FS.registerDevice(dev, TTY.stream_ops);
2097
+ }, stream_ops: { open(stream) {
2098
+ var tty = TTY.ttys[stream.node.rdev];
2099
+ if (!tty) {
2100
+ throw new FS.ErrnoError(43);
2101
+ }
2102
+ stream.tty = tty;
2103
+ stream.seekable = false;
2104
+ }, close(stream) {
2105
+ stream.tty.ops.fsync(stream.tty);
2106
+ }, fsync(stream) {
2107
+ stream.tty.ops.fsync(stream.tty);
2108
+ }, read(stream, buffer, offset, length, pos) {
2109
+ if (!stream.tty || !stream.tty.ops.get_char) {
2110
+ throw new FS.ErrnoError(60);
2111
+ }
2112
+ var bytesRead = 0;
2113
+ for (var i = 0; i < length; i++) {
2114
+ var result;
2115
+ try {
2116
+ result = stream.tty.ops.get_char(stream.tty);
2117
+ } catch (e) {
2118
+ throw new FS.ErrnoError(29);
2119
+ }
2120
+ if (result === void 0 && bytesRead === 0) {
2121
+ throw new FS.ErrnoError(6);
2122
+ }
2123
+ if (result === null || result === void 0) break;
2124
+ bytesRead++;
2125
+ buffer[offset + i] = result;
2126
+ }
2127
+ if (bytesRead) {
2128
+ stream.node.timestamp = Date.now();
2129
+ }
2130
+ return bytesRead;
2131
+ }, write(stream, buffer, offset, length, pos) {
2132
+ if (!stream.tty || !stream.tty.ops.put_char) {
2133
+ throw new FS.ErrnoError(60);
2134
+ }
2135
+ try {
2136
+ for (var i = 0; i < length; i++) {
2137
+ stream.tty.ops.put_char(stream.tty, buffer[offset + i]);
2138
+ }
2139
+ } catch (e) {
2140
+ throw new FS.ErrnoError(29);
2141
+ }
2142
+ if (length) {
2143
+ stream.node.timestamp = Date.now();
2144
+ }
2145
+ return i;
2146
+ } }, default_tty_ops: { get_char(tty) {
2147
+ return FS_stdin_getChar();
2148
+ }, put_char(tty, val) {
2149
+ if (val === null || val === 10) {
2150
+ out(UTF8ArrayToString(tty.output, 0));
2151
+ tty.output = [];
2152
+ } else {
2153
+ if (val != 0) tty.output.push(val);
2154
+ }
2155
+ }, fsync(tty) {
2156
+ if (tty.output && tty.output.length > 0) {
2157
+ out(UTF8ArrayToString(tty.output, 0));
2158
+ tty.output = [];
2159
+ }
2160
+ }, ioctl_tcgets(tty) {
2161
+ return { c_iflag: 25856, c_oflag: 5, c_cflag: 191, c_lflag: 35387, c_cc: [3, 28, 127, 21, 4, 0, 1, 0, 17, 19, 26, 0, 18, 15, 23, 22, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0] };
2162
+ }, ioctl_tcsets(tty, optional_actions, data) {
2163
+ return 0;
2164
+ }, ioctl_tiocgwinsz(tty) {
2165
+ return [24, 80];
2166
+ } }, default_tty1_ops: { put_char(tty, val) {
2167
+ if (val === null || val === 10) {
2168
+ err(UTF8ArrayToString(tty.output, 0));
2169
+ tty.output = [];
2170
+ } else {
2171
+ if (val != 0) tty.output.push(val);
2172
+ }
2173
+ }, fsync(tty) {
2174
+ if (tty.output && tty.output.length > 0) {
2175
+ err(UTF8ArrayToString(tty.output, 0));
2176
+ tty.output = [];
2177
+ }
2178
+ } } };
2179
+ var mmapAlloc = (size) => {
2180
+ abort();
2181
+ };
2182
+ var MEMFS = { ops_table: null, mount(mount) {
2183
+ return MEMFS.createNode(null, "/", 16384 | 511, 0);
2184
+ }, createNode(parent, name, mode, dev) {
2185
+ if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
2186
+ throw new FS.ErrnoError(63);
2187
+ }
2188
+ 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 } };
2189
+ var node = FS.createNode(parent, name, mode, dev);
2190
+ if (FS.isDir(node.mode)) {
2191
+ node.node_ops = MEMFS.ops_table.dir.node;
2192
+ node.stream_ops = MEMFS.ops_table.dir.stream;
2193
+ node.contents = {};
2194
+ } else if (FS.isFile(node.mode)) {
2195
+ node.node_ops = MEMFS.ops_table.file.node;
2196
+ node.stream_ops = MEMFS.ops_table.file.stream;
2197
+ node.usedBytes = 0;
2198
+ node.contents = null;
2199
+ } else if (FS.isLink(node.mode)) {
2200
+ node.node_ops = MEMFS.ops_table.link.node;
2201
+ node.stream_ops = MEMFS.ops_table.link.stream;
2202
+ } else if (FS.isChrdev(node.mode)) {
2203
+ node.node_ops = MEMFS.ops_table.chrdev.node;
2204
+ node.stream_ops = MEMFS.ops_table.chrdev.stream;
2205
+ }
2206
+ node.timestamp = Date.now();
2207
+ if (parent) {
2208
+ parent.contents[name] = node;
2209
+ parent.timestamp = node.timestamp;
2210
+ }
2211
+ return node;
2212
+ }, getFileDataAsTypedArray(node) {
2213
+ if (!node.contents) return new Uint8Array(0);
2214
+ if (node.contents.subarray) return node.contents.subarray(0, node.usedBytes);
2215
+ return new Uint8Array(node.contents);
2216
+ }, expandFileStorage(node, newCapacity) {
2217
+ var prevCapacity = node.contents ? node.contents.length : 0;
2218
+ if (prevCapacity >= newCapacity) return;
2219
+ var CAPACITY_DOUBLING_MAX = 1024 * 1024;
2220
+ newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) >>> 0);
2221
+ if (prevCapacity != 0) newCapacity = Math.max(newCapacity, 256);
2222
+ var oldContents = node.contents;
2223
+ node.contents = new Uint8Array(newCapacity);
2224
+ if (node.usedBytes > 0) node.contents.set(oldContents.subarray(0, node.usedBytes), 0);
2225
+ }, resizeFileStorage(node, newSize) {
2226
+ if (node.usedBytes == newSize) return;
2227
+ if (newSize == 0) {
2228
+ node.contents = null;
2229
+ node.usedBytes = 0;
2230
+ } else {
2231
+ var oldContents = node.contents;
2232
+ node.contents = new Uint8Array(newSize);
2233
+ if (oldContents) {
2234
+ node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)));
2235
+ }
2236
+ node.usedBytes = newSize;
2237
+ }
2238
+ }, node_ops: { getattr(node) {
2239
+ var attr = {};
2240
+ attr.dev = FS.isChrdev(node.mode) ? node.id : 1;
2241
+ attr.ino = node.id;
2242
+ attr.mode = node.mode;
2243
+ attr.nlink = 1;
2244
+ attr.uid = 0;
2245
+ attr.gid = 0;
2246
+ attr.rdev = node.rdev;
2247
+ if (FS.isDir(node.mode)) {
2248
+ attr.size = 4096;
2249
+ } else if (FS.isFile(node.mode)) {
2250
+ attr.size = node.usedBytes;
2251
+ } else if (FS.isLink(node.mode)) {
2252
+ attr.size = node.link.length;
2253
+ } else {
2254
+ attr.size = 0;
2255
+ }
2256
+ attr.atime = new Date(node.timestamp);
2257
+ attr.mtime = new Date(node.timestamp);
2258
+ attr.ctime = new Date(node.timestamp);
2259
+ attr.blksize = 4096;
2260
+ attr.blocks = Math.ceil(attr.size / attr.blksize);
2261
+ return attr;
2262
+ }, setattr(node, attr) {
2263
+ if (attr.mode !== void 0) {
2264
+ node.mode = attr.mode;
2265
+ }
2266
+ if (attr.timestamp !== void 0) {
2267
+ node.timestamp = attr.timestamp;
2268
+ }
2269
+ if (attr.size !== void 0) {
2270
+ MEMFS.resizeFileStorage(node, attr.size);
2271
+ }
2272
+ }, lookup(parent, name) {
2273
+ throw FS.genericErrors[44];
2274
+ }, mknod(parent, name, mode, dev) {
2275
+ return MEMFS.createNode(parent, name, mode, dev);
2276
+ }, rename(old_node, new_dir, new_name) {
2277
+ if (FS.isDir(old_node.mode)) {
2278
+ var new_node;
2279
+ try {
2280
+ new_node = FS.lookupNode(new_dir, new_name);
2281
+ } catch (e) {
2282
+ }
2283
+ if (new_node) {
2284
+ for (var i in new_node.contents) {
2285
+ throw new FS.ErrnoError(55);
2286
+ }
2287
+ }
2288
+ }
2289
+ delete old_node.parent.contents[old_node.name];
2290
+ old_node.parent.timestamp = Date.now();
2291
+ old_node.name = new_name;
2292
+ new_dir.contents[new_name] = old_node;
2293
+ new_dir.timestamp = old_node.parent.timestamp;
2294
+ old_node.parent = new_dir;
2295
+ }, unlink(parent, name) {
2296
+ delete parent.contents[name];
2297
+ parent.timestamp = Date.now();
2298
+ }, rmdir(parent, name) {
2299
+ var node = FS.lookupNode(parent, name);
2300
+ for (var i in node.contents) {
2301
+ throw new FS.ErrnoError(55);
2302
+ }
2303
+ delete parent.contents[name];
2304
+ parent.timestamp = Date.now();
2305
+ }, readdir(node) {
2306
+ var entries = [".", ".."];
2307
+ for (var key of Object.keys(node.contents)) {
2308
+ entries.push(key);
2309
+ }
2310
+ return entries;
2311
+ }, symlink(parent, newname, oldpath) {
2312
+ var node = MEMFS.createNode(parent, newname, 511 | 40960, 0);
2313
+ node.link = oldpath;
2314
+ return node;
2315
+ }, readlink(node) {
2316
+ if (!FS.isLink(node.mode)) {
2317
+ throw new FS.ErrnoError(28);
2318
+ }
2319
+ return node.link;
2320
+ } }, stream_ops: { read(stream, buffer, offset, length, position) {
2321
+ var contents = stream.node.contents;
2322
+ if (position >= stream.node.usedBytes) return 0;
2323
+ var size = Math.min(stream.node.usedBytes - position, length);
2324
+ if (size > 8 && contents.subarray) {
2325
+ buffer.set(contents.subarray(position, position + size), offset);
2326
+ } else {
2327
+ for (var i = 0; i < size; i++) buffer[offset + i] = contents[position + i];
2328
+ }
2329
+ return size;
2330
+ }, write(stream, buffer, offset, length, position, canOwn) {
2331
+ if (buffer.buffer === HEAP8.buffer) {
2332
+ canOwn = false;
2333
+ }
2334
+ if (!length) return 0;
2335
+ var node = stream.node;
2336
+ node.timestamp = Date.now();
2337
+ if (buffer.subarray && (!node.contents || node.contents.subarray)) {
2338
+ if (canOwn) {
2339
+ node.contents = buffer.subarray(offset, offset + length);
2340
+ node.usedBytes = length;
2341
+ return length;
2342
+ } else if (node.usedBytes === 0 && position === 0) {
2343
+ node.contents = buffer.slice(offset, offset + length);
2344
+ node.usedBytes = length;
2345
+ return length;
2346
+ } else if (position + length <= node.usedBytes) {
2347
+ node.contents.set(buffer.subarray(offset, offset + length), position);
2348
+ return length;
2349
+ }
2350
+ }
2351
+ MEMFS.expandFileStorage(node, position + length);
2352
+ if (node.contents.subarray && buffer.subarray) {
2353
+ node.contents.set(buffer.subarray(offset, offset + length), position);
2354
+ } else {
2355
+ for (var i = 0; i < length; i++) {
2356
+ node.contents[position + i] = buffer[offset + i];
2357
+ }
2358
+ }
2359
+ node.usedBytes = Math.max(node.usedBytes, position + length);
2360
+ return length;
2361
+ }, llseek(stream, offset, whence) {
2362
+ var position = offset;
2363
+ if (whence === 1) {
2364
+ position += stream.position;
2365
+ } else if (whence === 2) {
2366
+ if (FS.isFile(stream.node.mode)) {
2367
+ position += stream.node.usedBytes;
2368
+ }
2369
+ }
2370
+ if (position < 0) {
2371
+ throw new FS.ErrnoError(28);
2372
+ }
2373
+ return position;
2374
+ }, allocate(stream, offset, length) {
2375
+ MEMFS.expandFileStorage(stream.node, offset + length);
2376
+ stream.node.usedBytes = Math.max(stream.node.usedBytes, offset + length);
2377
+ }, mmap(stream, length, position, prot, flags) {
2378
+ if (!FS.isFile(stream.node.mode)) {
2379
+ throw new FS.ErrnoError(43);
2380
+ }
2381
+ var ptr;
2382
+ var allocated;
2383
+ var contents = stream.node.contents;
2384
+ if (!(flags & 2) && contents.buffer === HEAP8.buffer) {
2385
+ allocated = false;
2386
+ ptr = contents.byteOffset;
2387
+ } else {
2388
+ if (position > 0 || position + length < contents.length) {
2389
+ if (contents.subarray) {
2390
+ contents = contents.subarray(position, position + length);
2391
+ } else {
2392
+ contents = Array.prototype.slice.call(contents, position, position + length);
2393
+ }
2394
+ }
2395
+ allocated = true;
2396
+ ptr = mmapAlloc(length);
2397
+ if (!ptr) {
2398
+ throw new FS.ErrnoError(48);
2399
+ }
2400
+ HEAP8.set(contents, ptr);
2401
+ }
2402
+ return { ptr, allocated };
2403
+ }, msync(stream, buffer, offset, length, mmapFlags) {
2404
+ MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false);
2405
+ return 0;
2406
+ } } };
2407
+ var asyncLoad = (url, onload, onerror, noRunDep) => {
2408
+ var dep = !noRunDep ? getUniqueRunDependency(`al ${url}`) : "";
2409
+ readAsync(url, (arrayBuffer) => {
2410
+ onload(new Uint8Array(arrayBuffer));
2411
+ if (dep) removeRunDependency(dep);
2412
+ }, (event) => {
2413
+ if (onerror) {
2414
+ onerror();
2415
+ } else {
2416
+ throw `Loading data file "${url}" failed.`;
2417
+ }
2418
+ });
2419
+ if (dep) addRunDependency(dep);
2420
+ };
2421
+ var FS_createDataFile = (parent, name, fileData, canRead, canWrite, canOwn) => {
2422
+ FS.createDataFile(parent, name, fileData, canRead, canWrite, canOwn);
2423
+ };
2424
+ var preloadPlugins = Module["preloadPlugins"] || [];
2425
+ var FS_handledByPreloadPlugin = (byteArray, fullname, finish, onerror) => {
2426
+ if (typeof Browser != "undefined") Browser.init();
2427
+ var handled = false;
2428
+ preloadPlugins.forEach((plugin) => {
2429
+ if (handled) return;
2430
+ if (plugin["canHandle"](fullname)) {
2431
+ plugin["handle"](byteArray, fullname, finish, onerror);
2432
+ handled = true;
2433
+ }
2434
+ });
2435
+ return handled;
2436
+ };
2437
+ var FS_createPreloadedFile = (parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) => {
2438
+ var fullname = name ? PATH_FS.resolve(PATH.join2(parent, name)) : parent;
2439
+ var dep = getUniqueRunDependency(`cp ${fullname}`);
2440
+ function processData(byteArray) {
2441
+ function finish(byteArray2) {
2442
+ preFinish?.();
2443
+ if (!dontCreateFile) {
2444
+ FS_createDataFile(parent, name, byteArray2, canRead, canWrite, canOwn);
2445
+ }
2446
+ onload?.();
2447
+ removeRunDependency(dep);
2448
+ }
2449
+ if (FS_handledByPreloadPlugin(byteArray, fullname, finish, () => {
2450
+ onerror?.();
2451
+ removeRunDependency(dep);
2452
+ })) {
2453
+ return;
2454
+ }
2455
+ finish(byteArray);
2456
+ }
2457
+ addRunDependency(dep);
2458
+ if (typeof url == "string") {
2459
+ asyncLoad(url, processData, onerror);
2460
+ } else {
2461
+ processData(url);
2462
+ }
2463
+ };
2464
+ var FS_modeStringToFlags = (str) => {
2465
+ var flagModes = { "r": 0, "r+": 2, "w": 512 | 64 | 1, "w+": 512 | 64 | 2, "a": 1024 | 64 | 1, "a+": 1024 | 64 | 2 };
2466
+ var flags = flagModes[str];
2467
+ if (typeof flags == "undefined") {
2468
+ throw new Error(`Unknown file open mode: ${str}`);
2469
+ }
2470
+ return flags;
2471
+ };
2472
+ var FS_getMode = (canRead, canWrite) => {
2473
+ var mode = 0;
2474
+ if (canRead) mode |= 292 | 73;
2475
+ if (canWrite) mode |= 146;
2476
+ return mode;
2477
+ };
2478
+ var FS = { root: null, mounts: [], devices: {}, streams: [], nextInode: 1, nameTable: null, currentPath: "/", initialized: false, ignorePermissions: true, ErrnoError: class {
2479
+ constructor(errno) {
2480
+ this.name = "ErrnoError";
2481
+ this.errno = errno;
2482
+ }
2483
+ }, genericErrors: {}, filesystems: null, syncFSRequests: 0, FSStream: class {
2484
+ constructor() {
2485
+ this.shared = {};
2486
+ }
2487
+ get object() {
2488
+ return this.node;
2489
+ }
2490
+ set object(val) {
2491
+ this.node = val;
2492
+ }
2493
+ get isRead() {
2494
+ return (this.flags & 2097155) !== 1;
2495
+ }
2496
+ get isWrite() {
2497
+ return (this.flags & 2097155) !== 0;
2498
+ }
2499
+ get isAppend() {
2500
+ return this.flags & 1024;
2501
+ }
2502
+ get flags() {
2503
+ return this.shared.flags;
2504
+ }
2505
+ set flags(val) {
2506
+ this.shared.flags = val;
2507
+ }
2508
+ get position() {
2509
+ return this.shared.position;
2510
+ }
2511
+ set position(val) {
2512
+ this.shared.position = val;
2513
+ }
2514
+ }, FSNode: class {
2515
+ constructor(parent, name, mode, rdev) {
2516
+ if (!parent) {
2517
+ parent = this;
2518
+ }
2519
+ this.parent = parent;
2520
+ this.mount = parent.mount;
2521
+ this.mounted = null;
2522
+ this.id = FS.nextInode++;
2523
+ this.name = name;
2524
+ this.mode = mode;
2525
+ this.node_ops = {};
2526
+ this.stream_ops = {};
2527
+ this.rdev = rdev;
2528
+ this.readMode = 292 | 73;
2529
+ this.writeMode = 146;
2530
+ }
2531
+ get read() {
2532
+ return (this.mode & this.readMode) === this.readMode;
2533
+ }
2534
+ set read(val) {
2535
+ val ? this.mode |= this.readMode : this.mode &= ~this.readMode;
2536
+ }
2537
+ get write() {
2538
+ return (this.mode & this.writeMode) === this.writeMode;
2539
+ }
2540
+ set write(val) {
2541
+ val ? this.mode |= this.writeMode : this.mode &= ~this.writeMode;
2542
+ }
2543
+ get isFolder() {
2544
+ return FS.isDir(this.mode);
2545
+ }
2546
+ get isDevice() {
2547
+ return FS.isChrdev(this.mode);
2548
+ }
2549
+ }, lookupPath(path, opts = {}) {
2550
+ path = PATH_FS.resolve(path);
2551
+ if (!path) return { path: "", node: null };
2552
+ var defaults = { follow_mount: true, recurse_count: 0 };
2553
+ opts = Object.assign(defaults, opts);
2554
+ if (opts.recurse_count > 8) {
2555
+ throw new FS.ErrnoError(32);
2556
+ }
2557
+ var parts = path.split("/").filter((p) => !!p);
2558
+ var current = FS.root;
2559
+ var current_path = "/";
2560
+ for (var i = 0; i < parts.length; i++) {
2561
+ var islast = i === parts.length - 1;
2562
+ if (islast && opts.parent) {
2563
+ break;
2564
+ }
2565
+ current = FS.lookupNode(current, parts[i]);
2566
+ current_path = PATH.join2(current_path, parts[i]);
2567
+ if (FS.isMountpoint(current)) {
2568
+ if (!islast || islast && opts.follow_mount) {
2569
+ current = current.mounted.root;
2570
+ }
2571
+ }
2572
+ if (!islast || opts.follow) {
2573
+ var count = 0;
2574
+ while (FS.isLink(current.mode)) {
2575
+ var link = FS.readlink(current_path);
2576
+ current_path = PATH_FS.resolve(PATH.dirname(current_path), link);
2577
+ var lookup = FS.lookupPath(current_path, { recurse_count: opts.recurse_count + 1 });
2578
+ current = lookup.node;
2579
+ if (count++ > 40) {
2580
+ throw new FS.ErrnoError(32);
2581
+ }
2582
+ }
2583
+ }
2584
+ }
2585
+ return { path: current_path, node: current };
2586
+ }, getPath(node) {
2587
+ var path;
2588
+ while (true) {
2589
+ if (FS.isRoot(node)) {
2590
+ var mount = node.mount.mountpoint;
2591
+ if (!path) return mount;
2592
+ return mount[mount.length - 1] !== "/" ? `${mount}/${path}` : mount + path;
2593
+ }
2594
+ path = path ? `${node.name}/${path}` : node.name;
2595
+ node = node.parent;
2596
+ }
2597
+ }, hashName(parentid, name) {
2598
+ var hash = 0;
2599
+ for (var i = 0; i < name.length; i++) {
2600
+ hash = (hash << 5) - hash + name.charCodeAt(i) | 0;
2601
+ }
2602
+ return (parentid + hash >>> 0) % FS.nameTable.length;
2603
+ }, hashAddNode(node) {
2604
+ var hash = FS.hashName(node.parent.id, node.name);
2605
+ node.name_next = FS.nameTable[hash];
2606
+ FS.nameTable[hash] = node;
2607
+ }, hashRemoveNode(node) {
2608
+ var hash = FS.hashName(node.parent.id, node.name);
2609
+ if (FS.nameTable[hash] === node) {
2610
+ FS.nameTable[hash] = node.name_next;
2611
+ } else {
2612
+ var current = FS.nameTable[hash];
2613
+ while (current) {
2614
+ if (current.name_next === node) {
2615
+ current.name_next = node.name_next;
2616
+ break;
2617
+ }
2618
+ current = current.name_next;
2619
+ }
2620
+ }
2621
+ }, lookupNode(parent, name) {
2622
+ var errCode = FS.mayLookup(parent);
2623
+ if (errCode) {
2624
+ throw new FS.ErrnoError(errCode);
2625
+ }
2626
+ var hash = FS.hashName(parent.id, name);
2627
+ for (var node = FS.nameTable[hash]; node; node = node.name_next) {
2628
+ var nodeName = node.name;
2629
+ if (node.parent.id === parent.id && nodeName === name) {
2630
+ return node;
2631
+ }
2632
+ }
2633
+ return FS.lookup(parent, name);
2634
+ }, createNode(parent, name, mode, rdev) {
2635
+ var node = new FS.FSNode(parent, name, mode, rdev);
2636
+ FS.hashAddNode(node);
2637
+ return node;
2638
+ }, destroyNode(node) {
2639
+ FS.hashRemoveNode(node);
2640
+ }, isRoot(node) {
2641
+ return node === node.parent;
2642
+ }, isMountpoint(node) {
2643
+ return !!node.mounted;
2644
+ }, isFile(mode) {
2645
+ return (mode & 61440) === 32768;
2646
+ }, isDir(mode) {
2647
+ return (mode & 61440) === 16384;
2648
+ }, isLink(mode) {
2649
+ return (mode & 61440) === 40960;
2650
+ }, isChrdev(mode) {
2651
+ return (mode & 61440) === 8192;
2652
+ }, isBlkdev(mode) {
2653
+ return (mode & 61440) === 24576;
2654
+ }, isFIFO(mode) {
2655
+ return (mode & 61440) === 4096;
2656
+ }, isSocket(mode) {
2657
+ return (mode & 49152) === 49152;
2658
+ }, flagsToPermissionString(flag) {
2659
+ var perms = ["r", "w", "rw"][flag & 3];
2660
+ if (flag & 512) {
2661
+ perms += "w";
2662
+ }
2663
+ return perms;
2664
+ }, nodePermissions(node, perms) {
2665
+ if (FS.ignorePermissions) {
2666
+ return 0;
2667
+ }
2668
+ if (perms.includes("r") && !(node.mode & 292)) {
2669
+ return 2;
2670
+ } else if (perms.includes("w") && !(node.mode & 146)) {
2671
+ return 2;
2672
+ } else if (perms.includes("x") && !(node.mode & 73)) {
2673
+ return 2;
2674
+ }
2675
+ return 0;
2676
+ }, mayLookup(dir) {
2677
+ if (!FS.isDir(dir.mode)) return 54;
2678
+ var errCode = FS.nodePermissions(dir, "x");
2679
+ if (errCode) return errCode;
2680
+ if (!dir.node_ops.lookup) return 2;
2681
+ return 0;
2682
+ }, mayCreate(dir, name) {
2683
+ try {
2684
+ var node = FS.lookupNode(dir, name);
2685
+ return 20;
2686
+ } catch (e) {
2687
+ }
2688
+ return FS.nodePermissions(dir, "wx");
2689
+ }, mayDelete(dir, name, isdir) {
2690
+ var node;
2691
+ try {
2692
+ node = FS.lookupNode(dir, name);
2693
+ } catch (e) {
2694
+ return e.errno;
2695
+ }
2696
+ var errCode = FS.nodePermissions(dir, "wx");
2697
+ if (errCode) {
2698
+ return errCode;
2699
+ }
2700
+ if (isdir) {
2701
+ if (!FS.isDir(node.mode)) {
2702
+ return 54;
2703
+ }
2704
+ if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
2705
+ return 10;
2706
+ }
2707
+ } else {
2708
+ if (FS.isDir(node.mode)) {
2709
+ return 31;
2710
+ }
2711
+ }
2712
+ return 0;
2713
+ }, mayOpen(node, flags) {
2714
+ if (!node) {
2715
+ return 44;
2716
+ }
2717
+ if (FS.isLink(node.mode)) {
2718
+ return 32;
2719
+ } else if (FS.isDir(node.mode)) {
2720
+ if (FS.flagsToPermissionString(flags) !== "r" || flags & 512) {
2721
+ return 31;
2722
+ }
2723
+ }
2724
+ return FS.nodePermissions(node, FS.flagsToPermissionString(flags));
2725
+ }, MAX_OPEN_FDS: 4096, nextfd() {
2726
+ for (var fd = 0; fd <= FS.MAX_OPEN_FDS; fd++) {
2727
+ if (!FS.streams[fd]) {
2728
+ return fd;
2729
+ }
2730
+ }
2731
+ throw new FS.ErrnoError(33);
2732
+ }, getStreamChecked(fd) {
2733
+ var stream = FS.getStream(fd);
2734
+ if (!stream) {
2735
+ throw new FS.ErrnoError(8);
2736
+ }
2737
+ return stream;
2738
+ }, getStream: (fd) => FS.streams[fd], createStream(stream, fd = -1) {
2739
+ stream = Object.assign(new FS.FSStream(), stream);
2740
+ if (fd == -1) {
2741
+ fd = FS.nextfd();
2742
+ }
2743
+ stream.fd = fd;
2744
+ FS.streams[fd] = stream;
2745
+ return stream;
2746
+ }, closeStream(fd) {
2747
+ FS.streams[fd] = null;
2748
+ }, dupStream(origStream, fd = -1) {
2749
+ var stream = FS.createStream(origStream, fd);
2750
+ stream.stream_ops?.dup?.(stream);
2751
+ return stream;
2752
+ }, chrdev_stream_ops: { open(stream) {
2753
+ var device = FS.getDevice(stream.node.rdev);
2754
+ stream.stream_ops = device.stream_ops;
2755
+ stream.stream_ops.open?.(stream);
2756
+ }, llseek() {
2757
+ throw new FS.ErrnoError(70);
2758
+ } }, major: (dev) => dev >> 8, minor: (dev) => dev & 255, makedev: (ma, mi) => ma << 8 | mi, registerDevice(dev, ops) {
2759
+ FS.devices[dev] = { stream_ops: ops };
2760
+ }, getDevice: (dev) => FS.devices[dev], getMounts(mount) {
2761
+ var mounts = [];
2762
+ var check = [mount];
2763
+ while (check.length) {
2764
+ var m = check.pop();
2765
+ mounts.push(m);
2766
+ check.push(...m.mounts);
2767
+ }
2768
+ return mounts;
2769
+ }, syncfs(populate, callback) {
2770
+ if (typeof populate == "function") {
2771
+ callback = populate;
2772
+ populate = false;
2773
+ }
2774
+ FS.syncFSRequests++;
2775
+ if (FS.syncFSRequests > 1) {
2776
+ err(`warning: ${FS.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);
2777
+ }
2778
+ var mounts = FS.getMounts(FS.root.mount);
2779
+ var completed = 0;
2780
+ function doCallback(errCode) {
2781
+ FS.syncFSRequests--;
2782
+ return callback(errCode);
2783
+ }
2784
+ function done(errCode) {
2785
+ if (errCode) {
2786
+ if (!done.errored) {
2787
+ done.errored = true;
2788
+ return doCallback(errCode);
2789
+ }
2790
+ return;
2791
+ }
2792
+ if (++completed >= mounts.length) {
2793
+ doCallback(null);
2794
+ }
2795
+ }
2796
+ mounts.forEach((mount) => {
2797
+ if (!mount.type.syncfs) {
2798
+ return done(null);
2799
+ }
2800
+ mount.type.syncfs(mount, populate, done);
2801
+ });
2802
+ }, mount(type, opts, mountpoint) {
2803
+ var root = mountpoint === "/";
2804
+ var pseudo = !mountpoint;
2805
+ var node;
2806
+ if (root && FS.root) {
2807
+ throw new FS.ErrnoError(10);
2808
+ } else if (!root && !pseudo) {
2809
+ var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
2810
+ mountpoint = lookup.path;
2811
+ node = lookup.node;
2812
+ if (FS.isMountpoint(node)) {
2813
+ throw new FS.ErrnoError(10);
2814
+ }
2815
+ if (!FS.isDir(node.mode)) {
2816
+ throw new FS.ErrnoError(54);
2817
+ }
2818
+ }
2819
+ var mount = { type, opts, mountpoint, mounts: [] };
2820
+ var mountRoot = type.mount(mount);
2821
+ mountRoot.mount = mount;
2822
+ mount.root = mountRoot;
2823
+ if (root) {
2824
+ FS.root = mountRoot;
2825
+ } else if (node) {
2826
+ node.mounted = mount;
2827
+ if (node.mount) {
2828
+ node.mount.mounts.push(mount);
2829
+ }
2830
+ }
2831
+ return mountRoot;
2832
+ }, unmount(mountpoint) {
2833
+ var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
2834
+ if (!FS.isMountpoint(lookup.node)) {
2835
+ throw new FS.ErrnoError(28);
2836
+ }
2837
+ var node = lookup.node;
2838
+ var mount = node.mounted;
2839
+ var mounts = FS.getMounts(mount);
2840
+ Object.keys(FS.nameTable).forEach((hash) => {
2841
+ var current = FS.nameTable[hash];
2842
+ while (current) {
2843
+ var next = current.name_next;
2844
+ if (mounts.includes(current.mount)) {
2845
+ FS.destroyNode(current);
2846
+ }
2847
+ current = next;
2848
+ }
2849
+ });
2850
+ node.mounted = null;
2851
+ var idx = node.mount.mounts.indexOf(mount);
2852
+ node.mount.mounts.splice(idx, 1);
2853
+ }, lookup(parent, name) {
2854
+ return parent.node_ops.lookup(parent, name);
2855
+ }, mknod(path, mode, dev) {
2856
+ var lookup = FS.lookupPath(path, { parent: true });
2857
+ var parent = lookup.node;
2858
+ var name = PATH.basename(path);
2859
+ if (!name || name === "." || name === "..") {
2860
+ throw new FS.ErrnoError(28);
2861
+ }
2862
+ var errCode = FS.mayCreate(parent, name);
2863
+ if (errCode) {
2864
+ throw new FS.ErrnoError(errCode);
2865
+ }
2866
+ if (!parent.node_ops.mknod) {
2867
+ throw new FS.ErrnoError(63);
2868
+ }
2869
+ return parent.node_ops.mknod(parent, name, mode, dev);
2870
+ }, create(path, mode) {
2871
+ mode = mode !== void 0 ? mode : 438;
2872
+ mode &= 4095;
2873
+ mode |= 32768;
2874
+ return FS.mknod(path, mode, 0);
2875
+ }, mkdir(path, mode) {
2876
+ mode = mode !== void 0 ? mode : 511;
2877
+ mode &= 511 | 512;
2878
+ mode |= 16384;
2879
+ return FS.mknod(path, mode, 0);
2880
+ }, mkdirTree(path, mode) {
2881
+ var dirs = path.split("/");
2882
+ var d = "";
2883
+ for (var i = 0; i < dirs.length; ++i) {
2884
+ if (!dirs[i]) continue;
2885
+ d += "/" + dirs[i];
2886
+ try {
2887
+ FS.mkdir(d, mode);
2888
+ } catch (e) {
2889
+ if (e.errno != 20) throw e;
2890
+ }
2891
+ }
2892
+ }, mkdev(path, mode, dev) {
2893
+ if (typeof dev == "undefined") {
2894
+ dev = mode;
2895
+ mode = 438;
2896
+ }
2897
+ mode |= 8192;
2898
+ return FS.mknod(path, mode, dev);
2899
+ }, symlink(oldpath, newpath) {
2900
+ if (!PATH_FS.resolve(oldpath)) {
2901
+ throw new FS.ErrnoError(44);
2902
+ }
2903
+ var lookup = FS.lookupPath(newpath, { parent: true });
2904
+ var parent = lookup.node;
2905
+ if (!parent) {
2906
+ throw new FS.ErrnoError(44);
2907
+ }
2908
+ var newname = PATH.basename(newpath);
2909
+ var errCode = FS.mayCreate(parent, newname);
2910
+ if (errCode) {
2911
+ throw new FS.ErrnoError(errCode);
2912
+ }
2913
+ if (!parent.node_ops.symlink) {
2914
+ throw new FS.ErrnoError(63);
2915
+ }
2916
+ return parent.node_ops.symlink(parent, newname, oldpath);
2917
+ }, rename(old_path, new_path) {
2918
+ var old_dirname = PATH.dirname(old_path);
2919
+ var new_dirname = PATH.dirname(new_path);
2920
+ var old_name = PATH.basename(old_path);
2921
+ var new_name = PATH.basename(new_path);
2922
+ var lookup, old_dir, new_dir;
2923
+ lookup = FS.lookupPath(old_path, { parent: true });
2924
+ old_dir = lookup.node;
2925
+ lookup = FS.lookupPath(new_path, { parent: true });
2926
+ new_dir = lookup.node;
2927
+ if (!old_dir || !new_dir) throw new FS.ErrnoError(44);
2928
+ if (old_dir.mount !== new_dir.mount) {
2929
+ throw new FS.ErrnoError(75);
2930
+ }
2931
+ var old_node = FS.lookupNode(old_dir, old_name);
2932
+ var relative = PATH_FS.relative(old_path, new_dirname);
2933
+ if (relative.charAt(0) !== ".") {
2934
+ throw new FS.ErrnoError(28);
2935
+ }
2936
+ relative = PATH_FS.relative(new_path, old_dirname);
2937
+ if (relative.charAt(0) !== ".") {
2938
+ throw new FS.ErrnoError(55);
2939
+ }
2940
+ var new_node;
2941
+ try {
2942
+ new_node = FS.lookupNode(new_dir, new_name);
2943
+ } catch (e) {
2944
+ }
2945
+ if (old_node === new_node) {
2946
+ return;
2947
+ }
2948
+ var isdir = FS.isDir(old_node.mode);
2949
+ var errCode = FS.mayDelete(old_dir, old_name, isdir);
2950
+ if (errCode) {
2951
+ throw new FS.ErrnoError(errCode);
2952
+ }
2953
+ errCode = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name);
2954
+ if (errCode) {
2955
+ throw new FS.ErrnoError(errCode);
2956
+ }
2957
+ if (!old_dir.node_ops.rename) {
2958
+ throw new FS.ErrnoError(63);
2959
+ }
2960
+ if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
2961
+ throw new FS.ErrnoError(10);
2962
+ }
2963
+ if (new_dir !== old_dir) {
2964
+ errCode = FS.nodePermissions(old_dir, "w");
2965
+ if (errCode) {
2966
+ throw new FS.ErrnoError(errCode);
2967
+ }
2968
+ }
2969
+ FS.hashRemoveNode(old_node);
2970
+ try {
2971
+ old_dir.node_ops.rename(old_node, new_dir, new_name);
2972
+ } catch (e) {
2973
+ throw e;
2974
+ } finally {
2975
+ FS.hashAddNode(old_node);
2976
+ }
2977
+ }, rmdir(path) {
2978
+ var lookup = FS.lookupPath(path, { parent: true });
2979
+ var parent = lookup.node;
2980
+ var name = PATH.basename(path);
2981
+ var node = FS.lookupNode(parent, name);
2982
+ var errCode = FS.mayDelete(parent, name, true);
2983
+ if (errCode) {
2984
+ throw new FS.ErrnoError(errCode);
2985
+ }
2986
+ if (!parent.node_ops.rmdir) {
2987
+ throw new FS.ErrnoError(63);
2988
+ }
2989
+ if (FS.isMountpoint(node)) {
2990
+ throw new FS.ErrnoError(10);
2991
+ }
2992
+ parent.node_ops.rmdir(parent, name);
2993
+ FS.destroyNode(node);
2994
+ }, readdir(path) {
2995
+ var lookup = FS.lookupPath(path, { follow: true });
2996
+ var node = lookup.node;
2997
+ if (!node.node_ops.readdir) {
2998
+ throw new FS.ErrnoError(54);
2999
+ }
3000
+ return node.node_ops.readdir(node);
3001
+ }, unlink(path) {
3002
+ var lookup = FS.lookupPath(path, { parent: true });
3003
+ var parent = lookup.node;
3004
+ if (!parent) {
3005
+ throw new FS.ErrnoError(44);
3006
+ }
3007
+ var name = PATH.basename(path);
3008
+ var node = FS.lookupNode(parent, name);
3009
+ var errCode = FS.mayDelete(parent, name, false);
3010
+ if (errCode) {
3011
+ throw new FS.ErrnoError(errCode);
3012
+ }
3013
+ if (!parent.node_ops.unlink) {
3014
+ throw new FS.ErrnoError(63);
3015
+ }
3016
+ if (FS.isMountpoint(node)) {
3017
+ throw new FS.ErrnoError(10);
3018
+ }
3019
+ parent.node_ops.unlink(parent, name);
3020
+ FS.destroyNode(node);
3021
+ }, readlink(path) {
3022
+ var lookup = FS.lookupPath(path);
3023
+ var link = lookup.node;
3024
+ if (!link) {
3025
+ throw new FS.ErrnoError(44);
3026
+ }
3027
+ if (!link.node_ops.readlink) {
3028
+ throw new FS.ErrnoError(28);
3029
+ }
3030
+ return PATH_FS.resolve(FS.getPath(link.parent), link.node_ops.readlink(link));
3031
+ }, stat(path, dontFollow) {
3032
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
3033
+ var node = lookup.node;
3034
+ if (!node) {
3035
+ throw new FS.ErrnoError(44);
3036
+ }
3037
+ if (!node.node_ops.getattr) {
3038
+ throw new FS.ErrnoError(63);
3039
+ }
3040
+ return node.node_ops.getattr(node);
3041
+ }, lstat(path) {
3042
+ return FS.stat(path, true);
3043
+ }, chmod(path, mode, dontFollow) {
3044
+ var node;
3045
+ if (typeof path == "string") {
3046
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
3047
+ node = lookup.node;
3048
+ } else {
3049
+ node = path;
3050
+ }
3051
+ if (!node.node_ops.setattr) {
3052
+ throw new FS.ErrnoError(63);
3053
+ }
3054
+ node.node_ops.setattr(node, { mode: mode & 4095 | node.mode & ~4095, timestamp: Date.now() });
3055
+ }, lchmod(path, mode) {
3056
+ FS.chmod(path, mode, true);
3057
+ }, fchmod(fd, mode) {
3058
+ var stream = FS.getStreamChecked(fd);
3059
+ FS.chmod(stream.node, mode);
3060
+ }, chown(path, uid, gid, dontFollow) {
3061
+ var node;
3062
+ if (typeof path == "string") {
3063
+ var lookup = FS.lookupPath(path, { follow: !dontFollow });
3064
+ node = lookup.node;
3065
+ } else {
3066
+ node = path;
3067
+ }
3068
+ if (!node.node_ops.setattr) {
3069
+ throw new FS.ErrnoError(63);
3070
+ }
3071
+ node.node_ops.setattr(node, { timestamp: Date.now() });
3072
+ }, lchown(path, uid, gid) {
3073
+ FS.chown(path, uid, gid, true);
3074
+ }, fchown(fd, uid, gid) {
3075
+ var stream = FS.getStreamChecked(fd);
3076
+ FS.chown(stream.node, uid, gid);
3077
+ }, truncate(path, len) {
3078
+ if (len < 0) {
3079
+ throw new FS.ErrnoError(28);
3080
+ }
3081
+ var node;
3082
+ if (typeof path == "string") {
3083
+ var lookup = FS.lookupPath(path, { follow: true });
3084
+ node = lookup.node;
3085
+ } else {
3086
+ node = path;
3087
+ }
3088
+ if (!node.node_ops.setattr) {
3089
+ throw new FS.ErrnoError(63);
3090
+ }
3091
+ if (FS.isDir(node.mode)) {
3092
+ throw new FS.ErrnoError(31);
3093
+ }
3094
+ if (!FS.isFile(node.mode)) {
3095
+ throw new FS.ErrnoError(28);
3096
+ }
3097
+ var errCode = FS.nodePermissions(node, "w");
3098
+ if (errCode) {
3099
+ throw new FS.ErrnoError(errCode);
3100
+ }
3101
+ node.node_ops.setattr(node, { size: len, timestamp: Date.now() });
3102
+ }, ftruncate(fd, len) {
3103
+ var stream = FS.getStreamChecked(fd);
3104
+ if ((stream.flags & 2097155) === 0) {
3105
+ throw new FS.ErrnoError(28);
3106
+ }
3107
+ FS.truncate(stream.node, len);
3108
+ }, utime(path, atime, mtime) {
3109
+ var lookup = FS.lookupPath(path, { follow: true });
3110
+ var node = lookup.node;
3111
+ node.node_ops.setattr(node, { timestamp: Math.max(atime, mtime) });
3112
+ }, open(path, flags, mode) {
3113
+ if (path === "") {
3114
+ throw new FS.ErrnoError(44);
3115
+ }
3116
+ flags = typeof flags == "string" ? FS_modeStringToFlags(flags) : flags;
3117
+ mode = typeof mode == "undefined" ? 438 : mode;
3118
+ if (flags & 64) {
3119
+ mode = mode & 4095 | 32768;
3120
+ } else {
3121
+ mode = 0;
3122
+ }
3123
+ var node;
3124
+ if (typeof path == "object") {
3125
+ node = path;
3126
+ } else {
3127
+ path = PATH.normalize(path);
3128
+ try {
3129
+ var lookup = FS.lookupPath(path, { follow: !(flags & 131072) });
3130
+ node = lookup.node;
3131
+ } catch (e) {
3132
+ }
3133
+ }
3134
+ var created = false;
3135
+ if (flags & 64) {
3136
+ if (node) {
3137
+ if (flags & 128) {
3138
+ throw new FS.ErrnoError(20);
3139
+ }
3140
+ } else {
3141
+ node = FS.mknod(path, mode, 0);
3142
+ created = true;
3143
+ }
3144
+ }
3145
+ if (!node) {
3146
+ throw new FS.ErrnoError(44);
3147
+ }
3148
+ if (FS.isChrdev(node.mode)) {
3149
+ flags &= ~512;
3150
+ }
3151
+ if (flags & 65536 && !FS.isDir(node.mode)) {
3152
+ throw new FS.ErrnoError(54);
3153
+ }
3154
+ if (!created) {
3155
+ var errCode = FS.mayOpen(node, flags);
3156
+ if (errCode) {
3157
+ throw new FS.ErrnoError(errCode);
3158
+ }
3159
+ }
3160
+ if (flags & 512 && !created) {
3161
+ FS.truncate(node, 0);
3162
+ }
3163
+ flags &= ~(128 | 512 | 131072);
3164
+ var stream = FS.createStream({ node, path: FS.getPath(node), flags, seekable: true, position: 0, stream_ops: node.stream_ops, ungotten: [], error: false });
3165
+ if (stream.stream_ops.open) {
3166
+ stream.stream_ops.open(stream);
3167
+ }
3168
+ if (Module["logReadFiles"] && !(flags & 1)) {
3169
+ if (!FS.readFiles) FS.readFiles = {};
3170
+ if (!(path in FS.readFiles)) {
3171
+ FS.readFiles[path] = 1;
3172
+ }
3173
+ }
3174
+ return stream;
3175
+ }, close(stream) {
3176
+ if (FS.isClosed(stream)) {
3177
+ throw new FS.ErrnoError(8);
3178
+ }
3179
+ if (stream.getdents) stream.getdents = null;
3180
+ try {
3181
+ if (stream.stream_ops.close) {
3182
+ stream.stream_ops.close(stream);
3183
+ }
3184
+ } catch (e) {
3185
+ throw e;
3186
+ } finally {
3187
+ FS.closeStream(stream.fd);
3188
+ }
3189
+ stream.fd = null;
3190
+ }, isClosed(stream) {
3191
+ return stream.fd === null;
3192
+ }, llseek(stream, offset, whence) {
3193
+ if (FS.isClosed(stream)) {
3194
+ throw new FS.ErrnoError(8);
3195
+ }
3196
+ if (!stream.seekable || !stream.stream_ops.llseek) {
3197
+ throw new FS.ErrnoError(70);
3198
+ }
3199
+ if (whence != 0 && whence != 1 && whence != 2) {
3200
+ throw new FS.ErrnoError(28);
3201
+ }
3202
+ stream.position = stream.stream_ops.llseek(stream, offset, whence);
3203
+ stream.ungotten = [];
3204
+ return stream.position;
3205
+ }, read(stream, buffer, offset, length, position) {
3206
+ if (length < 0 || position < 0) {
3207
+ throw new FS.ErrnoError(28);
3208
+ }
3209
+ if (FS.isClosed(stream)) {
3210
+ throw new FS.ErrnoError(8);
3211
+ }
3212
+ if ((stream.flags & 2097155) === 1) {
3213
+ throw new FS.ErrnoError(8);
3214
+ }
3215
+ if (FS.isDir(stream.node.mode)) {
3216
+ throw new FS.ErrnoError(31);
3217
+ }
3218
+ if (!stream.stream_ops.read) {
3219
+ throw new FS.ErrnoError(28);
3220
+ }
3221
+ var seeking = typeof position != "undefined";
3222
+ if (!seeking) {
3223
+ position = stream.position;
3224
+ } else if (!stream.seekable) {
3225
+ throw new FS.ErrnoError(70);
3226
+ }
3227
+ var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position);
3228
+ if (!seeking) stream.position += bytesRead;
3229
+ return bytesRead;
3230
+ }, write(stream, buffer, offset, length, position, canOwn) {
3231
+ if (length < 0 || position < 0) {
3232
+ throw new FS.ErrnoError(28);
3233
+ }
3234
+ if (FS.isClosed(stream)) {
3235
+ throw new FS.ErrnoError(8);
3236
+ }
3237
+ if ((stream.flags & 2097155) === 0) {
3238
+ throw new FS.ErrnoError(8);
3239
+ }
3240
+ if (FS.isDir(stream.node.mode)) {
3241
+ throw new FS.ErrnoError(31);
3242
+ }
3243
+ if (!stream.stream_ops.write) {
3244
+ throw new FS.ErrnoError(28);
3245
+ }
3246
+ if (stream.seekable && stream.flags & 1024) {
3247
+ FS.llseek(stream, 0, 2);
3248
+ }
3249
+ var seeking = typeof position != "undefined";
3250
+ if (!seeking) {
3251
+ position = stream.position;
3252
+ } else if (!stream.seekable) {
3253
+ throw new FS.ErrnoError(70);
3254
+ }
3255
+ var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn);
3256
+ if (!seeking) stream.position += bytesWritten;
3257
+ return bytesWritten;
3258
+ }, allocate(stream, offset, length) {
3259
+ if (FS.isClosed(stream)) {
3260
+ throw new FS.ErrnoError(8);
3261
+ }
3262
+ if (offset < 0 || length <= 0) {
3263
+ throw new FS.ErrnoError(28);
3264
+ }
3265
+ if ((stream.flags & 2097155) === 0) {
3266
+ throw new FS.ErrnoError(8);
3267
+ }
3268
+ if (!FS.isFile(stream.node.mode) && !FS.isDir(stream.node.mode)) {
3269
+ throw new FS.ErrnoError(43);
3270
+ }
3271
+ if (!stream.stream_ops.allocate) {
3272
+ throw new FS.ErrnoError(138);
3273
+ }
3274
+ stream.stream_ops.allocate(stream, offset, length);
3275
+ }, mmap(stream, length, position, prot, flags) {
3276
+ if ((prot & 2) !== 0 && (flags & 2) === 0 && (stream.flags & 2097155) !== 2) {
3277
+ throw new FS.ErrnoError(2);
3278
+ }
3279
+ if ((stream.flags & 2097155) === 1) {
3280
+ throw new FS.ErrnoError(2);
3281
+ }
3282
+ if (!stream.stream_ops.mmap) {
3283
+ throw new FS.ErrnoError(43);
3284
+ }
3285
+ return stream.stream_ops.mmap(stream, length, position, prot, flags);
3286
+ }, msync(stream, buffer, offset, length, mmapFlags) {
3287
+ if (!stream.stream_ops.msync) {
3288
+ return 0;
3289
+ }
3290
+ return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags);
3291
+ }, ioctl(stream, cmd, arg) {
3292
+ if (!stream.stream_ops.ioctl) {
3293
+ throw new FS.ErrnoError(59);
3294
+ }
3295
+ return stream.stream_ops.ioctl(stream, cmd, arg);
3296
+ }, readFile(path, opts = {}) {
3297
+ opts.flags = opts.flags || 0;
3298
+ opts.encoding = opts.encoding || "binary";
3299
+ if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
3300
+ throw new Error(`Invalid encoding type "${opts.encoding}"`);
3301
+ }
3302
+ var ret;
3303
+ var stream = FS.open(path, opts.flags);
3304
+ var stat = FS.stat(path);
3305
+ var length = stat.size;
3306
+ var buf = new Uint8Array(length);
3307
+ FS.read(stream, buf, 0, length, 0);
3308
+ if (opts.encoding === "utf8") {
3309
+ ret = UTF8ArrayToString(buf, 0);
3310
+ } else if (opts.encoding === "binary") {
3311
+ ret = buf;
3312
+ }
3313
+ FS.close(stream);
3314
+ return ret;
3315
+ }, writeFile(path, data, opts = {}) {
3316
+ opts.flags = opts.flags || 577;
3317
+ var stream = FS.open(path, opts.flags, opts.mode);
3318
+ if (typeof data == "string") {
3319
+ var buf = new Uint8Array(lengthBytesUTF8(data) + 1);
3320
+ var actualNumBytes = stringToUTF8Array(data, buf, 0, buf.length);
3321
+ FS.write(stream, buf, 0, actualNumBytes, void 0, opts.canOwn);
3322
+ } else if (ArrayBuffer.isView(data)) {
3323
+ FS.write(stream, data, 0, data.byteLength, void 0, opts.canOwn);
3324
+ } else {
3325
+ throw new Error("Unsupported data type");
3326
+ }
3327
+ FS.close(stream);
3328
+ }, cwd: () => FS.currentPath, chdir(path) {
3329
+ var lookup = FS.lookupPath(path, { follow: true });
3330
+ if (lookup.node === null) {
3331
+ throw new FS.ErrnoError(44);
3332
+ }
3333
+ if (!FS.isDir(lookup.node.mode)) {
3334
+ throw new FS.ErrnoError(54);
3335
+ }
3336
+ var errCode = FS.nodePermissions(lookup.node, "x");
3337
+ if (errCode) {
3338
+ throw new FS.ErrnoError(errCode);
3339
+ }
3340
+ FS.currentPath = lookup.path;
3341
+ }, createDefaultDirectories() {
3342
+ FS.mkdir("/tmp");
3343
+ FS.mkdir("/home");
3344
+ FS.mkdir("/home/web_user");
3345
+ }, createDefaultDevices() {
3346
+ FS.mkdir("/dev");
3347
+ FS.registerDevice(FS.makedev(1, 3), { read: () => 0, write: (stream, buffer, offset, length, pos) => length });
3348
+ FS.mkdev("/dev/null", FS.makedev(1, 3));
3349
+ TTY.register(FS.makedev(5, 0), TTY.default_tty_ops);
3350
+ TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops);
3351
+ FS.mkdev("/dev/tty", FS.makedev(5, 0));
3352
+ FS.mkdev("/dev/tty1", FS.makedev(6, 0));
3353
+ var randomBuffer = new Uint8Array(1024), randomLeft = 0;
3354
+ var randomByte = () => {
3355
+ if (randomLeft === 0) {
3356
+ randomLeft = randomFill(randomBuffer).byteLength;
3357
+ }
3358
+ return randomBuffer[--randomLeft];
3359
+ };
3360
+ FS.createDevice("/dev", "random", randomByte);
3361
+ FS.createDevice("/dev", "urandom", randomByte);
3362
+ FS.mkdir("/dev/shm");
3363
+ FS.mkdir("/dev/shm/tmp");
3364
+ }, createSpecialDirectories() {
3365
+ FS.mkdir("/proc");
3366
+ var proc_self = FS.mkdir("/proc/self");
3367
+ FS.mkdir("/proc/self/fd");
3368
+ FS.mount({ mount() {
3369
+ var node = FS.createNode(proc_self, "fd", 16384 | 511, 73);
3370
+ node.node_ops = { lookup(parent, name) {
3371
+ var fd = +name;
3372
+ var stream = FS.getStreamChecked(fd);
3373
+ var ret = { parent: null, mount: { mountpoint: "fake" }, node_ops: { readlink: () => stream.path } };
3374
+ ret.parent = ret;
3375
+ return ret;
3376
+ } };
3377
+ return node;
3378
+ } }, {}, "/proc/self/fd");
3379
+ }, createStandardStreams() {
3380
+ if (Module["stdin"]) {
3381
+ FS.createDevice("/dev", "stdin", Module["stdin"]);
3382
+ } else {
3383
+ FS.symlink("/dev/tty", "/dev/stdin");
3384
+ }
3385
+ if (Module["stdout"]) {
3386
+ FS.createDevice("/dev", "stdout", null, Module["stdout"]);
3387
+ } else {
3388
+ FS.symlink("/dev/tty", "/dev/stdout");
3389
+ }
3390
+ if (Module["stderr"]) {
3391
+ FS.createDevice("/dev", "stderr", null, Module["stderr"]);
3392
+ } else {
3393
+ FS.symlink("/dev/tty1", "/dev/stderr");
3394
+ }
3395
+ var stdin = FS.open("/dev/stdin", 0);
3396
+ var stdout = FS.open("/dev/stdout", 1);
3397
+ var stderr = FS.open("/dev/stderr", 1);
3398
+ }, staticInit() {
3399
+ [44].forEach((code) => {
3400
+ FS.genericErrors[code] = new FS.ErrnoError(code);
3401
+ FS.genericErrors[code].stack = "<generic error, no stack>";
3402
+ });
3403
+ FS.nameTable = new Array(4096);
3404
+ FS.mount(MEMFS, {}, "/");
3405
+ FS.createDefaultDirectories();
3406
+ FS.createDefaultDevices();
3407
+ FS.createSpecialDirectories();
3408
+ FS.filesystems = { "MEMFS": MEMFS };
3409
+ }, init(input, output, error) {
3410
+ FS.init.initialized = true;
3411
+ Module["stdin"] = input || Module["stdin"];
3412
+ Module["stdout"] = output || Module["stdout"];
3413
+ Module["stderr"] = error || Module["stderr"];
3414
+ FS.createStandardStreams();
3415
+ }, quit() {
3416
+ FS.init.initialized = false;
3417
+ for (var i = 0; i < FS.streams.length; i++) {
3418
+ var stream = FS.streams[i];
3419
+ if (!stream) {
3420
+ continue;
3421
+ }
3422
+ FS.close(stream);
3423
+ }
3424
+ }, findObject(path, dontResolveLastLink) {
3425
+ var ret = FS.analyzePath(path, dontResolveLastLink);
3426
+ if (!ret.exists) {
3427
+ return null;
3428
+ }
3429
+ return ret.object;
3430
+ }, analyzePath(path, dontResolveLastLink) {
3431
+ try {
3432
+ var lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
3433
+ path = lookup.path;
3434
+ } catch (e) {
3435
+ }
3436
+ var ret = { isRoot: false, exists: false, error: 0, name: null, path: null, object: null, parentExists: false, parentPath: null, parentObject: null };
3437
+ try {
3438
+ var lookup = FS.lookupPath(path, { parent: true });
3439
+ ret.parentExists = true;
3440
+ ret.parentPath = lookup.path;
3441
+ ret.parentObject = lookup.node;
3442
+ ret.name = PATH.basename(path);
3443
+ lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
3444
+ ret.exists = true;
3445
+ ret.path = lookup.path;
3446
+ ret.object = lookup.node;
3447
+ ret.name = lookup.node.name;
3448
+ ret.isRoot = lookup.path === "/";
3449
+ } catch (e) {
3450
+ ret.error = e.errno;
3451
+ }
3452
+ return ret;
3453
+ }, createPath(parent, path, canRead, canWrite) {
3454
+ parent = typeof parent == "string" ? parent : FS.getPath(parent);
3455
+ var parts = path.split("/").reverse();
3456
+ while (parts.length) {
3457
+ var part = parts.pop();
3458
+ if (!part) continue;
3459
+ var current = PATH.join2(parent, part);
3460
+ try {
3461
+ FS.mkdir(current);
3462
+ } catch (e) {
3463
+ }
3464
+ parent = current;
3465
+ }
3466
+ return current;
3467
+ }, createFile(parent, name, properties, canRead, canWrite) {
3468
+ var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
3469
+ var mode = FS_getMode(canRead, canWrite);
3470
+ return FS.create(path, mode);
3471
+ }, createDataFile(parent, name, data, canRead, canWrite, canOwn) {
3472
+ var path = name;
3473
+ if (parent) {
3474
+ parent = typeof parent == "string" ? parent : FS.getPath(parent);
3475
+ path = name ? PATH.join2(parent, name) : parent;
3476
+ }
3477
+ var mode = FS_getMode(canRead, canWrite);
3478
+ var node = FS.create(path, mode);
3479
+ if (data) {
3480
+ if (typeof data == "string") {
3481
+ var arr = new Array(data.length);
3482
+ for (var i = 0, len = data.length; i < len; ++i) arr[i] = data.charCodeAt(i);
3483
+ data = arr;
3484
+ }
3485
+ FS.chmod(node, mode | 146);
3486
+ var stream = FS.open(node, 577);
3487
+ FS.write(stream, data, 0, data.length, 0, canOwn);
3488
+ FS.close(stream);
3489
+ FS.chmod(node, mode);
3490
+ }
3491
+ }, createDevice(parent, name, input, output) {
3492
+ var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
3493
+ var mode = FS_getMode(!!input, !!output);
3494
+ if (!FS.createDevice.major) FS.createDevice.major = 64;
3495
+ var dev = FS.makedev(FS.createDevice.major++, 0);
3496
+ FS.registerDevice(dev, { open(stream) {
3497
+ stream.seekable = false;
3498
+ }, close(stream) {
3499
+ if (output?.buffer?.length) {
3500
+ output(10);
3501
+ }
3502
+ }, read(stream, buffer, offset, length, pos) {
3503
+ var bytesRead = 0;
3504
+ for (var i = 0; i < length; i++) {
3505
+ var result;
3506
+ try {
3507
+ result = input();
3508
+ } catch (e) {
3509
+ throw new FS.ErrnoError(29);
3510
+ }
3511
+ if (result === void 0 && bytesRead === 0) {
3512
+ throw new FS.ErrnoError(6);
3513
+ }
3514
+ if (result === null || result === void 0) break;
3515
+ bytesRead++;
3516
+ buffer[offset + i] = result;
3517
+ }
3518
+ if (bytesRead) {
3519
+ stream.node.timestamp = Date.now();
3520
+ }
3521
+ return bytesRead;
3522
+ }, write(stream, buffer, offset, length, pos) {
3523
+ for (var i = 0; i < length; i++) {
3524
+ try {
3525
+ output(buffer[offset + i]);
3526
+ } catch (e) {
3527
+ throw new FS.ErrnoError(29);
3528
+ }
3529
+ }
3530
+ if (length) {
3531
+ stream.node.timestamp = Date.now();
3532
+ }
3533
+ return i;
3534
+ } });
3535
+ return FS.mkdev(path, mode, dev);
3536
+ }, forceLoadFile(obj) {
3537
+ if (obj.isDevice || obj.isFolder || obj.link || obj.contents) return true;
3538
+ if (typeof XMLHttpRequest != "undefined") {
3539
+ 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.");
3540
+ } else if (read_) {
3541
+ try {
3542
+ obj.contents = intArrayFromString(read_(obj.url), true);
3543
+ obj.usedBytes = obj.contents.length;
3544
+ } catch (e) {
3545
+ throw new FS.ErrnoError(29);
3546
+ }
3547
+ } else {
3548
+ throw new Error("Cannot load without read() or XMLHttpRequest.");
3549
+ }
3550
+ }, createLazyFile(parent, name, url, canRead, canWrite) {
3551
+ class LazyUint8Array {
3552
+ constructor() {
3553
+ this.lengthKnown = false;
3554
+ this.chunks = [];
3555
+ }
3556
+ get(idx) {
3557
+ if (idx > this.length - 1 || idx < 0) {
3558
+ return void 0;
3559
+ }
3560
+ var chunkOffset = idx % this.chunkSize;
3561
+ var chunkNum = idx / this.chunkSize | 0;
3562
+ return this.getter(chunkNum)[chunkOffset];
3563
+ }
3564
+ setDataGetter(getter) {
3565
+ this.getter = getter;
3566
+ }
3567
+ cacheLength() {
3568
+ var xhr = new XMLHttpRequest();
3569
+ xhr.open("HEAD", url, false);
3570
+ xhr.send(null);
3571
+ if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304)) throw new Error("Couldn't load " + url + ". Status: " + xhr.status);
3572
+ var datalength = Number(xhr.getResponseHeader("Content-length"));
3573
+ var header;
3574
+ var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes";
3575
+ var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip";
3576
+ var chunkSize = 1024 * 1024;
3577
+ if (!hasByteServing) chunkSize = datalength;
3578
+ var doXHR = (from, to) => {
3579
+ if (from > to) throw new Error("invalid range (" + from + ", " + to + ") or no bytes requested!");
3580
+ if (to > datalength - 1) throw new Error("only " + datalength + " bytes available! programmer error!");
3581
+ var xhr2 = new XMLHttpRequest();
3582
+ xhr2.open("GET", url, false);
3583
+ if (datalength !== chunkSize) xhr2.setRequestHeader("Range", "bytes=" + from + "-" + to);
3584
+ xhr2.responseType = "arraybuffer";
3585
+ if (xhr2.overrideMimeType) {
3586
+ xhr2.overrideMimeType("text/plain; charset=x-user-defined");
3587
+ }
3588
+ xhr2.send(null);
3589
+ if (!(xhr2.status >= 200 && xhr2.status < 300 || xhr2.status === 304)) throw new Error("Couldn't load " + url + ". Status: " + xhr2.status);
3590
+ if (xhr2.response !== void 0) {
3591
+ return new Uint8Array(xhr2.response || []);
3592
+ }
3593
+ return intArrayFromString(xhr2.responseText || "", true);
3594
+ };
3595
+ var lazyArray2 = this;
3596
+ lazyArray2.setDataGetter((chunkNum) => {
3597
+ var start = chunkNum * chunkSize;
3598
+ var end = (chunkNum + 1) * chunkSize - 1;
3599
+ end = Math.min(end, datalength - 1);
3600
+ if (typeof lazyArray2.chunks[chunkNum] == "undefined") {
3601
+ lazyArray2.chunks[chunkNum] = doXHR(start, end);
3602
+ }
3603
+ if (typeof lazyArray2.chunks[chunkNum] == "undefined") throw new Error("doXHR failed!");
3604
+ return lazyArray2.chunks[chunkNum];
3605
+ });
3606
+ if (usesGzip || !datalength) {
3607
+ chunkSize = datalength = 1;
3608
+ datalength = this.getter(0).length;
3609
+ chunkSize = datalength;
3610
+ out("LazyFiles on gzip forces download of the whole file when length is accessed");
3611
+ }
3612
+ this._length = datalength;
3613
+ this._chunkSize = chunkSize;
3614
+ this.lengthKnown = true;
3615
+ }
3616
+ get length() {
3617
+ if (!this.lengthKnown) {
3618
+ this.cacheLength();
3619
+ }
3620
+ return this._length;
3621
+ }
3622
+ get chunkSize() {
3623
+ if (!this.lengthKnown) {
3624
+ this.cacheLength();
3625
+ }
3626
+ return this._chunkSize;
3627
+ }
3628
+ }
3629
+ if (typeof XMLHttpRequest != "undefined") {
3630
+ if (!ENVIRONMENT_IS_WORKER) throw "Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";
3631
+ var lazyArray = new LazyUint8Array();
3632
+ var properties = { isDevice: false, contents: lazyArray };
3633
+ } else {
3634
+ var properties = { isDevice: false, url };
3635
+ }
3636
+ var node = FS.createFile(parent, name, properties, canRead, canWrite);
3637
+ if (properties.contents) {
3638
+ node.contents = properties.contents;
3639
+ } else if (properties.url) {
3640
+ node.contents = null;
3641
+ node.url = properties.url;
3642
+ }
3643
+ Object.defineProperties(node, { usedBytes: { get: function() {
3644
+ return this.contents.length;
3645
+ } } });
3646
+ var stream_ops = {};
3647
+ var keys = Object.keys(node.stream_ops);
3648
+ keys.forEach((key) => {
3649
+ var fn = node.stream_ops[key];
3650
+ stream_ops[key] = (...args) => {
3651
+ FS.forceLoadFile(node);
3652
+ return fn(...args);
3653
+ };
3654
+ });
3655
+ function writeChunks(stream, buffer, offset, length, position) {
3656
+ var contents = stream.node.contents;
3657
+ if (position >= contents.length) return 0;
3658
+ var size = Math.min(contents.length - position, length);
3659
+ if (contents.slice) {
3660
+ for (var i = 0; i < size; i++) {
3661
+ buffer[offset + i] = contents[position + i];
3662
+ }
3663
+ } else {
3664
+ for (var i = 0; i < size; i++) {
3665
+ buffer[offset + i] = contents.get(position + i);
3666
+ }
3667
+ }
3668
+ return size;
3669
+ }
3670
+ stream_ops.read = (stream, buffer, offset, length, position) => {
3671
+ FS.forceLoadFile(node);
3672
+ return writeChunks(stream, buffer, offset, length, position);
3673
+ };
3674
+ stream_ops.mmap = (stream, length, position, prot, flags) => {
3675
+ FS.forceLoadFile(node);
3676
+ var ptr = mmapAlloc(length);
3677
+ if (!ptr) {
3678
+ throw new FS.ErrnoError(48);
3679
+ }
3680
+ writeChunks(stream, HEAP8, ptr, length, position);
3681
+ return { ptr, allocated: true };
3682
+ };
3683
+ node.stream_ops = stream_ops;
3684
+ return node;
3685
+ } };
3686
+ var SYSCALLS = { DEFAULT_POLLMASK: 5, calculateAt(dirfd, path, allowEmpty) {
3687
+ if (PATH.isAbs(path)) {
3688
+ return path;
3689
+ }
3690
+ var dir;
3691
+ if (dirfd === -100) {
3692
+ dir = FS.cwd();
3693
+ } else {
3694
+ var dirstream = SYSCALLS.getStreamFromFD(dirfd);
3695
+ dir = dirstream.path;
3696
+ }
3697
+ if (path.length == 0) {
3698
+ if (!allowEmpty) {
3699
+ throw new FS.ErrnoError(44);
3700
+ }
3701
+ return dir;
3702
+ }
3703
+ return PATH.join2(dir, path);
3704
+ }, doStat(func, path, buf) {
3705
+ var stat = func(path);
3706
+ HEAP32[buf >> 2] = stat.dev;
3707
+ HEAP32[buf + 4 >> 2] = stat.mode;
3708
+ HEAPU32[buf + 8 >> 2] = stat.nlink;
3709
+ HEAP32[buf + 12 >> 2] = stat.uid;
3710
+ HEAP32[buf + 16 >> 2] = stat.gid;
3711
+ HEAP32[buf + 20 >> 2] = stat.rdev;
3712
+ tempI64 = [stat.size >>> 0, (tempDouble = stat.size, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 24 >> 2] = tempI64[0], HEAP32[buf + 28 >> 2] = tempI64[1];
3713
+ HEAP32[buf + 32 >> 2] = 4096;
3714
+ HEAP32[buf + 36 >> 2] = stat.blocks;
3715
+ var atime = stat.atime.getTime();
3716
+ var mtime = stat.mtime.getTime();
3717
+ var ctime = stat.ctime.getTime();
3718
+ tempI64 = [Math.floor(atime / 1e3) >>> 0, (tempDouble = Math.floor(atime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 40 >> 2] = tempI64[0], HEAP32[buf + 44 >> 2] = tempI64[1];
3719
+ HEAPU32[buf + 48 >> 2] = atime % 1e3 * 1e3;
3720
+ tempI64 = [Math.floor(mtime / 1e3) >>> 0, (tempDouble = Math.floor(mtime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 56 >> 2] = tempI64[0], HEAP32[buf + 60 >> 2] = tempI64[1];
3721
+ HEAPU32[buf + 64 >> 2] = mtime % 1e3 * 1e3;
3722
+ tempI64 = [Math.floor(ctime / 1e3) >>> 0, (tempDouble = Math.floor(ctime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 72 >> 2] = tempI64[0], HEAP32[buf + 76 >> 2] = tempI64[1];
3723
+ HEAPU32[buf + 80 >> 2] = ctime % 1e3 * 1e3;
3724
+ tempI64 = [stat.ino >>> 0, (tempDouble = stat.ino, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 88 >> 2] = tempI64[0], HEAP32[buf + 92 >> 2] = tempI64[1];
3725
+ return 0;
3726
+ }, doMsync(addr, stream, len, flags, offset) {
3727
+ if (!FS.isFile(stream.node.mode)) {
3728
+ throw new FS.ErrnoError(43);
3729
+ }
3730
+ if (flags & 2) {
3731
+ return 0;
3732
+ }
3733
+ var buffer = HEAPU8.slice(addr, addr + len);
3734
+ FS.msync(stream, buffer, offset, len, flags);
3735
+ }, varargs: void 0, get() {
3736
+ var ret = HEAP32[+SYSCALLS.varargs >> 2];
3737
+ SYSCALLS.varargs += 4;
3738
+ return ret;
3739
+ }, getp() {
3740
+ return SYSCALLS.get();
3741
+ }, getStr(ptr) {
3742
+ var ret = UTF8ToString(ptr);
3743
+ return ret;
3744
+ }, getStreamFromFD(fd) {
3745
+ var stream = FS.getStreamChecked(fd);
3746
+ return stream;
3747
+ } };
3748
+ function _fd_close(fd) {
3749
+ try {
3750
+ var stream = SYSCALLS.getStreamFromFD(fd);
3751
+ FS.close(stream);
3752
+ return 0;
3753
+ } catch (e) {
3754
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3755
+ return e.errno;
3756
+ }
3757
+ }
3758
+ var doReadv = (stream, iov, iovcnt, offset) => {
3759
+ var ret = 0;
3760
+ for (var i = 0; i < iovcnt; i++) {
3761
+ var ptr = HEAPU32[iov >> 2];
3762
+ var len = HEAPU32[iov + 4 >> 2];
3763
+ iov += 8;
3764
+ var curr = FS.read(stream, HEAP8, ptr, len, offset);
3765
+ if (curr < 0) return -1;
3766
+ ret += curr;
3767
+ if (curr < len) break;
3768
+ if (typeof offset !== "undefined") {
3769
+ offset += curr;
3770
+ }
3771
+ }
3772
+ return ret;
3773
+ };
3774
+ function _fd_read(fd, iov, iovcnt, pnum) {
3775
+ try {
3776
+ var stream = SYSCALLS.getStreamFromFD(fd);
3777
+ var num = doReadv(stream, iov, iovcnt);
3778
+ HEAPU32[pnum >> 2] = num;
3779
+ return 0;
3780
+ } catch (e) {
3781
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3782
+ return e.errno;
3783
+ }
3784
+ }
3785
+ var convertI32PairToI53Checked = (lo, hi) => hi + 2097152 >>> 0 < 4194305 - !!lo ? (lo >>> 0) + hi * 4294967296 : NaN;
3786
+ function _fd_seek(fd, offset_low, offset_high, whence, newOffset) {
3787
+ var offset = convertI32PairToI53Checked(offset_low, offset_high);
3788
+ try {
3789
+ if (isNaN(offset)) return 61;
3790
+ var stream = SYSCALLS.getStreamFromFD(fd);
3791
+ FS.llseek(stream, offset, whence);
3792
+ tempI64 = [stream.position >>> 0, (tempDouble = stream.position, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[newOffset >> 2] = tempI64[0], HEAP32[newOffset + 4 >> 2] = tempI64[1];
3793
+ if (stream.getdents && offset === 0 && whence === 0) stream.getdents = null;
3794
+ return 0;
3795
+ } catch (e) {
3796
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3797
+ return e.errno;
3798
+ }
3799
+ }
3800
+ var doWritev = (stream, iov, iovcnt, offset) => {
3801
+ var ret = 0;
3802
+ for (var i = 0; i < iovcnt; i++) {
3803
+ var ptr = HEAPU32[iov >> 2];
3804
+ var len = HEAPU32[iov + 4 >> 2];
3805
+ iov += 8;
3806
+ var curr = FS.write(stream, HEAP8, ptr, len, offset);
3807
+ if (curr < 0) return -1;
3808
+ ret += curr;
3809
+ if (typeof offset !== "undefined") {
3810
+ offset += curr;
3811
+ }
3812
+ }
3813
+ return ret;
3814
+ };
3815
+ function _fd_write(fd, iov, iovcnt, pnum) {
3816
+ try {
3817
+ var stream = SYSCALLS.getStreamFromFD(fd);
3818
+ var num = doWritev(stream, iov, iovcnt);
3819
+ HEAPU32[pnum >> 2] = num;
3820
+ return 0;
3821
+ } catch (e) {
3822
+ if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
3823
+ return e.errno;
3824
+ }
3825
+ }
3826
+ var isLeapYear = (year) => year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
3827
+ var arraySum = (array, index) => {
3828
+ var sum = 0;
3829
+ for (var i = 0; i <= index; sum += array[i++]) {
3830
+ }
3831
+ return sum;
3832
+ };
3833
+ var MONTH_DAYS_LEAP = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
3834
+ var MONTH_DAYS_REGULAR = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
3835
+ var addDays = (date, days) => {
3836
+ var newDate = new Date(date.getTime());
3837
+ while (days > 0) {
3838
+ var leap = isLeapYear(newDate.getFullYear());
3839
+ var currentMonth = newDate.getMonth();
3840
+ var daysInCurrentMonth = (leap ? MONTH_DAYS_LEAP : MONTH_DAYS_REGULAR)[currentMonth];
3841
+ if (days > daysInCurrentMonth - newDate.getDate()) {
3842
+ days -= daysInCurrentMonth - newDate.getDate() + 1;
3843
+ newDate.setDate(1);
3844
+ if (currentMonth < 11) {
3845
+ newDate.setMonth(currentMonth + 1);
3846
+ } else {
3847
+ newDate.setMonth(0);
3848
+ newDate.setFullYear(newDate.getFullYear() + 1);
3849
+ }
3850
+ } else {
3851
+ newDate.setDate(newDate.getDate() + days);
3852
+ return newDate;
3853
+ }
3854
+ }
3855
+ return newDate;
3856
+ };
3857
+ var writeArrayToMemory = (array, buffer) => {
3858
+ HEAP8.set(array, buffer);
3859
+ };
3860
+ var _strftime = (s, maxsize, format, tm) => {
3861
+ var tm_zone = HEAPU32[tm + 40 >> 2];
3862
+ 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) : "" };
3863
+ var pattern = UTF8ToString(format);
3864
+ 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" };
3865
+ for (var rule in EXPANSION_RULES_1) {
3866
+ pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_1[rule]);
3867
+ }
3868
+ var WEEKDAYS = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"];
3869
+ var MONTHS = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
3870
+ function leadingSomething(value, digits, character) {
3871
+ var str = typeof value == "number" ? value.toString() : value || "";
3872
+ while (str.length < digits) {
3873
+ str = character[0] + str;
3874
+ }
3875
+ return str;
3876
+ }
3877
+ function leadingNulls(value, digits) {
3878
+ return leadingSomething(value, digits, "0");
3879
+ }
3880
+ function compareByDay(date1, date2) {
3881
+ function sgn(value) {
3882
+ return value < 0 ? -1 : value > 0 ? 1 : 0;
3883
+ }
3884
+ var compare;
3885
+ if ((compare = sgn(date1.getFullYear() - date2.getFullYear())) === 0) {
3886
+ if ((compare = sgn(date1.getMonth() - date2.getMonth())) === 0) {
3887
+ compare = sgn(date1.getDate() - date2.getDate());
3888
+ }
3889
+ }
3890
+ return compare;
3891
+ }
3892
+ function getFirstWeekStartDate(janFourth) {
3893
+ switch (janFourth.getDay()) {
3894
+ case 0:
3895
+ return new Date(janFourth.getFullYear() - 1, 11, 29);
3896
+ case 1:
3897
+ return janFourth;
3898
+ case 2:
3899
+ return new Date(janFourth.getFullYear(), 0, 3);
3900
+ case 3:
3901
+ return new Date(janFourth.getFullYear(), 0, 2);
3902
+ case 4:
3903
+ return new Date(janFourth.getFullYear(), 0, 1);
3904
+ case 5:
3905
+ return new Date(janFourth.getFullYear() - 1, 11, 31);
3906
+ case 6:
3907
+ return new Date(janFourth.getFullYear() - 1, 11, 30);
3908
+ }
3909
+ }
3910
+ function getWeekBasedYear(date2) {
3911
+ var thisDate = addDays(new Date(date2.tm_year + 1900, 0, 1), date2.tm_yday);
3912
+ var janFourthThisYear = new Date(thisDate.getFullYear(), 0, 4);
3913
+ var janFourthNextYear = new Date(thisDate.getFullYear() + 1, 0, 4);
3914
+ var firstWeekStartThisYear = getFirstWeekStartDate(janFourthThisYear);
3915
+ var firstWeekStartNextYear = getFirstWeekStartDate(janFourthNextYear);
3916
+ if (compareByDay(firstWeekStartThisYear, thisDate) <= 0) {
3917
+ if (compareByDay(firstWeekStartNextYear, thisDate) <= 0) {
3918
+ return thisDate.getFullYear() + 1;
3919
+ }
3920
+ return thisDate.getFullYear();
3921
+ }
3922
+ return thisDate.getFullYear() - 1;
3923
+ }
3924
+ var EXPANSION_RULES_2 = { "%a": (date2) => WEEKDAYS[date2.tm_wday].substring(0, 3), "%A": (date2) => WEEKDAYS[date2.tm_wday], "%b": (date2) => MONTHS[date2.tm_mon].substring(0, 3), "%B": (date2) => MONTHS[date2.tm_mon], "%C": (date2) => {
3925
+ var year = date2.tm_year + 1900;
3926
+ return leadingNulls(year / 100 | 0, 2);
3927
+ }, "%d": (date2) => leadingNulls(date2.tm_mday, 2), "%e": (date2) => leadingSomething(date2.tm_mday, 2, " "), "%g": (date2) => getWeekBasedYear(date2).toString().substring(2), "%G": getWeekBasedYear, "%H": (date2) => leadingNulls(date2.tm_hour, 2), "%I": (date2) => {
3928
+ var twelveHour = date2.tm_hour;
3929
+ if (twelveHour == 0) twelveHour = 12;
3930
+ else if (twelveHour > 12) twelveHour -= 12;
3931
+ return leadingNulls(twelveHour, 2);
3932
+ }, "%j": (date2) => leadingNulls(date2.tm_mday + arraySum(isLeapYear(date2.tm_year + 1900) ? MONTH_DAYS_LEAP : MONTH_DAYS_REGULAR, date2.tm_mon - 1), 3), "%m": (date2) => leadingNulls(date2.tm_mon + 1, 2), "%M": (date2) => leadingNulls(date2.tm_min, 2), "%n": () => "\n", "%p": (date2) => {
3933
+ if (date2.tm_hour >= 0 && date2.tm_hour < 12) {
3934
+ return "AM";
3935
+ }
3936
+ return "PM";
3937
+ }, "%S": (date2) => leadingNulls(date2.tm_sec, 2), "%t": () => " ", "%u": (date2) => date2.tm_wday || 7, "%U": (date2) => {
3938
+ var days = date2.tm_yday + 7 - date2.tm_wday;
3939
+ return leadingNulls(Math.floor(days / 7), 2);
3940
+ }, "%V": (date2) => {
3941
+ var val = Math.floor((date2.tm_yday + 7 - (date2.tm_wday + 6) % 7) / 7);
3942
+ if ((date2.tm_wday + 371 - date2.tm_yday - 2) % 7 <= 2) {
3943
+ val++;
3944
+ }
3945
+ if (!val) {
3946
+ val = 52;
3947
+ var dec31 = (date2.tm_wday + 7 - date2.tm_yday - 1) % 7;
3948
+ if (dec31 == 4 || dec31 == 5 && isLeapYear(date2.tm_year % 400 - 1)) {
3949
+ val++;
3950
+ }
3951
+ } else if (val == 53) {
3952
+ var jan1 = (date2.tm_wday + 371 - date2.tm_yday) % 7;
3953
+ if (jan1 != 4 && (jan1 != 3 || !isLeapYear(date2.tm_year))) val = 1;
3954
+ }
3955
+ return leadingNulls(val, 2);
3956
+ }, "%w": (date2) => date2.tm_wday, "%W": (date2) => {
3957
+ var days = date2.tm_yday + 7 - (date2.tm_wday + 6) % 7;
3958
+ return leadingNulls(Math.floor(days / 7), 2);
3959
+ }, "%y": (date2) => (date2.tm_year + 1900).toString().substring(2), "%Y": (date2) => date2.tm_year + 1900, "%z": (date2) => {
3960
+ var off = date2.tm_gmtoff;
3961
+ var ahead = off >= 0;
3962
+ off = Math.abs(off) / 60;
3963
+ off = off / 60 * 100 + off % 60;
3964
+ return (ahead ? "+" : "-") + String("0000" + off).slice(-4);
3965
+ }, "%Z": (date2) => date2.tm_zone, "%%": () => "%" };
3966
+ pattern = pattern.replace(/%%/g, "\0\0");
3967
+ for (var rule in EXPANSION_RULES_2) {
3968
+ if (pattern.includes(rule)) {
3969
+ pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_2[rule](date));
3970
+ }
3971
+ }
3972
+ pattern = pattern.replace(/\0\0/g, "%");
3973
+ var bytes = intArrayFromString(pattern, false);
3974
+ if (bytes.length > maxsize) {
3975
+ return 0;
3976
+ }
3977
+ writeArrayToMemory(bytes, s);
3978
+ return bytes.length - 1;
3979
+ };
3980
+ var _strftime_l = (s, maxsize, format, tm, loc) => _strftime(s, maxsize, format, tm);
3981
+ InternalError = Module["InternalError"] = class InternalError extends Error {
3982
+ constructor(message) {
3983
+ super(message);
3984
+ this.name = "InternalError";
3985
+ }
3986
+ };
3987
+ embind_init_charCodes();
3988
+ BindingError = Module["BindingError"] = class BindingError extends Error {
3989
+ constructor(message) {
3990
+ super(message);
3991
+ this.name = "BindingError";
3992
+ }
3993
+ };
3994
+ init_ClassHandle();
3995
+ init_embind();
3996
+ init_RegisteredPointer();
3997
+ UnboundTypeError = Module["UnboundTypeError"] = extendError(Error, "UnboundTypeError");
3998
+ init_emval();
3999
+ FS.createPreloadedFile = FS_createPreloadedFile;
4000
+ FS.staticInit();
4001
+ var wasmImports = { a: ___assert_fail, p: ___cxa_throw, N: __embind_finalize_value_object, C: __embind_register_bigint, L: __embind_register_bool, n: __embind_register_class, A: __embind_register_class_constructor, y: __embind_register_class_function, K: __embind_register_emval, j: __embind_register_enum, b: __embind_register_enum_value, w: __embind_register_float, f: __embind_register_function, i: __embind_register_integer, e: __embind_register_memory_view, v: __embind_register_std_string, r: __embind_register_std_wstring, O: __embind_register_value_object, s: __embind_register_value_object_field, M: __embind_register_void, o: __emval_call, z: __emval_call_method, c: __emval_decref, P: __emval_get_global, l: __emval_get_method_caller, q: __emval_incref, x: __emval_new_array, g: __emval_new_cstring, m: __emval_new_object, k: __emval_run_destructors, h: __emval_set_property, d: __emval_take_value, t: _abort, J: _emscripten_memcpy_js, H: _emscripten_resize_heap, E: _environ_get, F: _environ_sizes_get, I: _fd_close, G: _fd_read, B: _fd_seek, u: _fd_write, D: _strftime_l };
4002
+ var wasmExports = createWasm();
4003
+ var ___wasm_call_ctors = () => (___wasm_call_ctors = wasmExports["R"])();
4004
+ var _malloc = (a0) => (_malloc = wasmExports["S"])(a0);
4005
+ var _free = (a0) => (_free = wasmExports["U"])(a0);
4006
+ var ___getTypeName = (a0) => (___getTypeName = wasmExports["V"])(a0);
4007
+ var ___cxa_is_pointer_type = (a0) => (___cxa_is_pointer_type = wasmExports["W"])(a0);
4008
+ var dynCall_ji = Module["dynCall_ji"] = (a0, a1) => (dynCall_ji = Module["dynCall_ji"] = wasmExports["X"])(a0, a1);
4009
+ var dynCall_iij = Module["dynCall_iij"] = (a0, a1, a2, a3) => (dynCall_iij = Module["dynCall_iij"] = wasmExports["Y"])(a0, a1, a2, a3);
4010
+ var dynCall_jiji = Module["dynCall_jiji"] = (a0, a1, a2, a3, a4) => (dynCall_jiji = Module["dynCall_jiji"] = wasmExports["Z"])(a0, a1, a2, a3, a4);
4011
+ var dynCall_viijii = Module["dynCall_viijii"] = (a0, a1, a2, a3, a4, a5, a6) => (dynCall_viijii = Module["dynCall_viijii"] = wasmExports["_"])(a0, a1, a2, a3, a4, a5, a6);
4012
+ var dynCall_iiiiij = Module["dynCall_iiiiij"] = (a0, a1, a2, a3, a4, a5, a6) => (dynCall_iiiiij = Module["dynCall_iiiiij"] = wasmExports["$"])(a0, a1, a2, a3, a4, a5, a6);
4013
+ var dynCall_iiiiijj = Module["dynCall_iiiiijj"] = (a0, a1, a2, a3, a4, a5, a6, a7, a8) => (dynCall_iiiiijj = Module["dynCall_iiiiijj"] = wasmExports["aa"])(a0, a1, a2, a3, a4, a5, a6, a7, a8);
4014
+ var dynCall_iiiiiijj = Module["dynCall_iiiiiijj"] = (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) => (dynCall_iiiiiijj = Module["dynCall_iiiiiijj"] = wasmExports["ba"])(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9);
4015
+ var calledRun;
4016
+ dependenciesFulfilled = function runCaller() {
4017
+ if (!calledRun) run();
4018
+ if (!calledRun) dependenciesFulfilled = runCaller;
4019
+ };
4020
+ function run() {
4021
+ if (runDependencies > 0) {
4022
+ return;
4023
+ }
4024
+ preRun();
4025
+ if (runDependencies > 0) {
4026
+ return;
4027
+ }
4028
+ function doRun() {
4029
+ if (calledRun) return;
4030
+ calledRun = true;
4031
+ Module["calledRun"] = true;
4032
+ if (ABORT) return;
4033
+ initRuntime();
4034
+ readyPromiseResolve(Module);
4035
+ if (Module["onRuntimeInitialized"]) Module["onRuntimeInitialized"]();
4036
+ postRun();
4037
+ }
4038
+ if (Module["setStatus"]) {
4039
+ Module["setStatus"]("Running...");
4040
+ setTimeout(function() {
4041
+ setTimeout(function() {
4042
+ Module["setStatus"]("");
4043
+ }, 1);
4044
+ doRun();
4045
+ }, 1);
4046
+ } else {
4047
+ doRun();
4048
+ }
4049
+ }
4050
+ if (Module["preInit"]) {
4051
+ if (typeof Module["preInit"] == "function") Module["preInit"] = [Module["preInit"]];
4052
+ while (Module["preInit"].length > 0) {
4053
+ Module["preInit"].pop()();
4054
+ }
4055
+ }
4056
+ run();
4057
+ return moduleArg.ready;
4058
+ });
4059
+ })();
4060
+ var heic_decoder_default = createHeicDecoderModule;
4061
+
4062
+ // src/wasm/wrapper.ts
4063
+ var LibheifDecoder = class {
4064
+ options;
4065
+ module = null;
4066
+ decoderInstance = null;
4067
+ constructor(options) {
4068
+ this.options = options;
4069
+ }
4070
+ /**
4071
+ * Initializes the WebAssembly module and instantiates the HEIC decoder.
4072
+ */
4073
+ async initialize() {
4074
+ if (this.module) {
4075
+ return;
4076
+ }
4077
+ const moduleArgs = {};
4078
+ if (this.options?.locateFile) {
4079
+ moduleArgs.locateFile = this.options.locateFile;
4080
+ }
4081
+ if (this.options?.wasmBinary) {
4082
+ moduleArgs.wasmBinary = this.options.wasmBinary;
4083
+ }
4084
+ this.module = await heic_decoder_default(moduleArgs);
4085
+ this.decoderInstance = new this.module.HeicDecoder();
4086
+ }
4087
+ /**
4088
+ * Decodes HEIC binary data into raw RGBA pixel data.
4089
+ * @param data The HEIC file contents as a Uint8Array.
4090
+ * @param onProgress Optional progress callback.
4091
+ */
4092
+ async decode(data, onProgress) {
4093
+ if (!this.module || !this.decoderInstance) {
4094
+ await this.initialize();
4095
+ }
4096
+ const result = this.decoderInstance.decode(data, onProgress || null);
4097
+ if (!result) {
4098
+ throw new Error("HEIC decoding failed");
4099
+ }
4100
+ if (typeof result === "string") {
4101
+ throw new Error(`HEIC decoding failed: ${result}`);
4102
+ }
4103
+ const width = result.width;
4104
+ const height = result.height;
4105
+ const clampedData = new Uint8ClampedArray(
4106
+ result.data.buffer,
4107
+ result.data.byteOffset,
4108
+ result.data.byteLength
4109
+ );
4110
+ return {
4111
+ width,
4112
+ height,
4113
+ data: clampedData
4114
+ };
4115
+ }
4116
+ /**
4117
+ * Cleans up the WebAssembly decoder instance and resources.
4118
+ */
4119
+ free() {
4120
+ if (this.decoderInstance) {
4121
+ this.decoderInstance.delete();
4122
+ this.decoderInstance = null;
4123
+ }
4124
+ this.module = null;
4125
+ }
4126
+ };
4127
+
4128
+ // src/render/canvas.ts
4129
+ async function blobToBase64(blob) {
4130
+ if (typeof FileReader !== "undefined") {
4131
+ return new Promise((resolve, reject) => {
4132
+ const reader = new FileReader();
4133
+ reader.onloadend = () => {
4134
+ if (typeof reader.result === "string") {
4135
+ resolve(reader.result);
4136
+ } else {
4137
+ reject(new Error("Failed to convert Blob to base64 string"));
4138
+ }
4139
+ };
4140
+ reader.onerror = () => reject(reader.error);
4141
+ reader.readAsDataURL(blob);
4142
+ });
4143
+ }
4144
+ const arrayBuffer = await blob.arrayBuffer();
4145
+ const buffer = Buffer.from(arrayBuffer);
4146
+ return `data:${blob.type};base64,${buffer.toString("base64")}`;
4147
+ }
4148
+ function canvasToBlob(canvas, type, quality) {
4149
+ if ("convertToBlob" in canvas) {
4150
+ return canvas.convertToBlob({ type, quality });
4151
+ }
4152
+ return new Promise((resolve, reject) => {
4153
+ canvas.toBlob(
4154
+ (blob) => {
4155
+ if (blob) {
4156
+ resolve(blob);
4157
+ } else {
4158
+ reject(new Error("Failed to convert canvas to blob"));
4159
+ }
4160
+ },
4161
+ type,
4162
+ quality
4163
+ );
4164
+ });
4165
+ }
4166
+ async function renderAndEncode(decoded, format, quality) {
4167
+ const { width, height, data } = decoded;
4168
+ let canvas;
4169
+ if (typeof OffscreenCanvas !== "undefined") {
4170
+ canvas = new OffscreenCanvas(width, height);
4171
+ } else if (typeof document !== "undefined") {
4172
+ canvas = document.createElement("canvas");
4173
+ canvas.width = width;
4174
+ canvas.height = height;
4175
+ } else {
4176
+ throw new Error(
4177
+ "Canvas is not supported in the current environment. Conversion requires a browser environment or canvas polyfills."
4178
+ );
4179
+ }
4180
+ const ctx = canvas.getContext("2d");
4181
+ if (!ctx) {
4182
+ throw new Error("Failed to acquire 2D rendering context from canvas");
4183
+ }
4184
+ let imageData;
4185
+ if (typeof ImageData !== "undefined") {
4186
+ imageData = new ImageData(data, width, height);
4187
+ } else {
4188
+ const created = ctx.createImageData(width, height);
4189
+ created.data.set(data);
4190
+ imageData = created;
4191
+ }
4192
+ ctx.putImageData(imageData, 0, 0);
4193
+ const normalizedFormat = format.toLowerCase();
4194
+ if (normalizedFormat === "png") {
4195
+ return canvasToBlob(canvas, "image/png");
4196
+ } else if (normalizedFormat === "jpeg" || normalizedFormat === "jpg") {
4197
+ return canvasToBlob(canvas, "image/jpeg", quality);
4198
+ } else if (normalizedFormat === "svg") {
4199
+ const pngBlob = await canvasToBlob(canvas, "image/png");
4200
+ const base64Url = await blobToBase64(pngBlob);
4201
+ const svgString = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${width} ${height}" width="${width}" height="${height}">
4202
+ <image width="${width}" height="${height}" href="${base64Url}" />
4203
+ </svg>`;
4204
+ return new Blob([svgString], { type: "image/svg+xml" });
4205
+ } else {
4206
+ throw new Error(`Unsupported output format: ${format}`);
4207
+ }
4208
+ }
4209
+
4210
+ // src/index.ts
4211
+ var sharedDecoder = null;
4212
+ function freeSharedDecoder() {
4213
+ if (sharedDecoder) {
4214
+ sharedDecoder.free();
4215
+ sharedDecoder = null;
4216
+ }
4217
+ }
4218
+ async function convertHeic(input, options) {
4219
+ let buffer;
4220
+ if (input instanceof Uint8Array) {
4221
+ buffer = input;
4222
+ } else if (input instanceof ArrayBuffer) {
4223
+ buffer = new Uint8Array(input);
4224
+ } else if (typeof Blob !== "undefined" && input instanceof Blob) {
4225
+ const arrayBuffer = await input.arrayBuffer();
4226
+ buffer = new Uint8Array(arrayBuffer);
4227
+ } else {
4228
+ throw new Error(
4229
+ "Unsupported input type. Expected Blob, File, ArrayBuffer, or Uint8Array."
4230
+ );
4231
+ }
4232
+ let decoder = options?.decoder;
4233
+ if (!decoder) {
4234
+ if (!sharedDecoder) {
4235
+ sharedDecoder = new LibheifDecoder();
4236
+ }
4237
+ decoder = sharedDecoder;
4238
+ }
4239
+ await decoder.initialize();
4240
+ const decoded = await decoder.decode(buffer, options?.onProgress);
4241
+ const format = options?.to || "jpeg";
4242
+ const quality = options?.quality !== void 0 ? options.quality : 0.92;
4243
+ return renderAndEncode(decoded, format, quality);
4244
+ }
4245
+ // Annotate the CommonJS export names for ESM import in node:
4246
+ 0 && (module.exports = {
4247
+ LibheifDecoder,
4248
+ convertHeic,
4249
+ freeSharedDecoder
4250
+ });