@mlightcad/libredwg-web 0.0.1
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/README.md +85 -0
- package/dist/libredwg-web.mjs +2969 -0
- package/dist/libredwg-web.umd.js +17 -0
- package/dist/libredwg-web.wasm +0 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +3 -0
- package/lib/libredwg-web.d.ts +3 -0
- package/lib/libredwg-web.js +2452 -0
- package/lib/libredwg.d.ts +73 -0
- package/lib/libredwg.js +181 -0
- package/lib/utils.d.ts +342 -0
- package/lib/utils.js +352 -0
- package/package.json +69 -0
- package/wasm/libredwg-web.d.ts +2485 -0
- package/wasm/libredwg-web.js +15 -0
- package/wasm/libredwg-web.wasm +0 -0
|
@@ -0,0 +1,2452 @@
|
|
|
1
|
+
var createModule = (() => {
|
|
2
|
+
var _scriptName = import.meta.url;
|
|
3
|
+
return (async function (moduleArg = {}) {
|
|
4
|
+
var moduleRtn;
|
|
5
|
+
var Module = moduleArg;
|
|
6
|
+
var readyPromiseResolve, readyPromiseReject;
|
|
7
|
+
var readyPromise = new Promise((resolve, reject) => { readyPromiseResolve = resolve; readyPromiseReject = reject; });
|
|
8
|
+
var ENVIRONMENT_IS_WEB = typeof window == "object";
|
|
9
|
+
var ENVIRONMENT_IS_WORKER = typeof WorkerGlobalScope != "undefined";
|
|
10
|
+
var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string" && process.type != "renderer";
|
|
11
|
+
var ENVIRONMENT_IS_SHELL = !ENVIRONMENT_IS_WEB && !ENVIRONMENT_IS_NODE && !ENVIRONMENT_IS_WORKER;
|
|
12
|
+
if (ENVIRONMENT_IS_NODE) {
|
|
13
|
+
const { createRequire } = await import("module");
|
|
14
|
+
var require = createRequire(import.meta.url);
|
|
15
|
+
}
|
|
16
|
+
var moduleOverrides = Object.assign({}, Module);
|
|
17
|
+
var arguments_ = [];
|
|
18
|
+
var thisProgram = "./this.program";
|
|
19
|
+
var quit_ = (status, toThrow) => { throw toThrow; };
|
|
20
|
+
var scriptDirectory = "";
|
|
21
|
+
function locateFile(path) { if (Module["locateFile"]) {
|
|
22
|
+
return Module["locateFile"](path, scriptDirectory);
|
|
23
|
+
} return scriptDirectory + path; }
|
|
24
|
+
var readAsync, readBinary;
|
|
25
|
+
if (ENVIRONMENT_IS_NODE) {
|
|
26
|
+
var fs = require("fs");
|
|
27
|
+
var nodePath = require("path");
|
|
28
|
+
if (!import.meta.url.startsWith("data:")) {
|
|
29
|
+
scriptDirectory = nodePath.dirname(require("url").fileURLToPath(import.meta.url)) + "/";
|
|
30
|
+
}
|
|
31
|
+
readBinary = filename => { filename = isFileURI(filename) ? new URL(filename) : filename; var ret = fs.readFileSync(filename); return ret; };
|
|
32
|
+
readAsync = async (filename, binary = true) => { filename = isFileURI(filename) ? new URL(filename) : filename; var ret = fs.readFileSync(filename, binary ? undefined : "utf8"); return ret; };
|
|
33
|
+
if (!Module["thisProgram"] && process.argv.length > 1) {
|
|
34
|
+
thisProgram = process.argv[1].replace(/\\/g, "/");
|
|
35
|
+
}
|
|
36
|
+
arguments_ = process.argv.slice(2);
|
|
37
|
+
quit_ = (status, toThrow) => { process.exitCode = status; throw toThrow; };
|
|
38
|
+
}
|
|
39
|
+
else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
|
|
40
|
+
if (ENVIRONMENT_IS_WORKER) {
|
|
41
|
+
scriptDirectory = self.location.href;
|
|
42
|
+
}
|
|
43
|
+
else if (typeof document != "undefined" && document.currentScript) {
|
|
44
|
+
scriptDirectory = document.currentScript.src;
|
|
45
|
+
}
|
|
46
|
+
if (_scriptName) {
|
|
47
|
+
scriptDirectory = _scriptName;
|
|
48
|
+
}
|
|
49
|
+
if (scriptDirectory.startsWith("blob:")) {
|
|
50
|
+
scriptDirectory = "";
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
scriptDirectory = scriptDirectory.slice(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1);
|
|
54
|
+
}
|
|
55
|
+
{
|
|
56
|
+
if (ENVIRONMENT_IS_WORKER) {
|
|
57
|
+
readBinary = url => { var xhr = new XMLHttpRequest; xhr.open("GET", url, false); xhr.responseType = "arraybuffer"; xhr.send(null); return new Uint8Array(xhr.response); };
|
|
58
|
+
}
|
|
59
|
+
readAsync = async (url) => { if (isFileURI(url)) {
|
|
60
|
+
return new Promise((resolve, reject) => { var xhr = new XMLHttpRequest; xhr.open("GET", url, true); xhr.responseType = "arraybuffer"; xhr.onload = () => { if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
|
|
61
|
+
resolve(xhr.response);
|
|
62
|
+
return;
|
|
63
|
+
} reject(xhr.status); }; xhr.onerror = reject; xhr.send(null); });
|
|
64
|
+
} var response = await fetch(url, { credentials: "same-origin" }); if (response.ok) {
|
|
65
|
+
return response.arrayBuffer();
|
|
66
|
+
} throw new Error(response.status + " : " + response.url); };
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
else { }
|
|
70
|
+
var out = Module["print"] || console.log.bind(console);
|
|
71
|
+
var err = Module["printErr"] || console.error.bind(console);
|
|
72
|
+
Object.assign(Module, moduleOverrides);
|
|
73
|
+
moduleOverrides = null;
|
|
74
|
+
if (Module["arguments"])
|
|
75
|
+
arguments_ = Module["arguments"];
|
|
76
|
+
if (Module["thisProgram"])
|
|
77
|
+
thisProgram = Module["thisProgram"];
|
|
78
|
+
var wasmBinary = Module["wasmBinary"];
|
|
79
|
+
var wasmMemory;
|
|
80
|
+
var ABORT = false;
|
|
81
|
+
var EXITSTATUS;
|
|
82
|
+
function assert(condition, text) { if (!condition) {
|
|
83
|
+
abort(text);
|
|
84
|
+
} }
|
|
85
|
+
var HEAP, HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAP64, HEAPU64, HEAPF64;
|
|
86
|
+
var runtimeInitialized = false;
|
|
87
|
+
var isFileURI = filename => filename.startsWith("file://");
|
|
88
|
+
function updateMemoryViews() { var b = wasmMemory.buffer; Module["HEAP8"] = HEAP8 = new Int8Array(b); Module["HEAP16"] = HEAP16 = new Int16Array(b); Module["HEAPU8"] = HEAPU8 = new Uint8Array(b); Module["HEAPU16"] = HEAPU16 = new Uint16Array(b); Module["HEAP32"] = HEAP32 = new Int32Array(b); Module["HEAPU32"] = HEAPU32 = new Uint32Array(b); Module["HEAPF32"] = HEAPF32 = new Float32Array(b); Module["HEAPF64"] = HEAPF64 = new Float64Array(b); Module["HEAP64"] = HEAP64 = new BigInt64Array(b); Module["HEAPU64"] = HEAPU64 = new BigUint64Array(b); }
|
|
89
|
+
function preRun() { if (Module["preRun"]) {
|
|
90
|
+
if (typeof Module["preRun"] == "function")
|
|
91
|
+
Module["preRun"] = [Module["preRun"]];
|
|
92
|
+
while (Module["preRun"].length) {
|
|
93
|
+
addOnPreRun(Module["preRun"].shift());
|
|
94
|
+
}
|
|
95
|
+
} callRuntimeCallbacks(onPreRuns); }
|
|
96
|
+
function initRuntime() { runtimeInitialized = true; if (!Module["noFSInit"] && !FS.initialized)
|
|
97
|
+
FS.init(); TTY.init(); wasmExports["__wasm_call_ctors"](); FS.ignorePermissions = false; }
|
|
98
|
+
function postRun() { if (Module["postRun"]) {
|
|
99
|
+
if (typeof Module["postRun"] == "function")
|
|
100
|
+
Module["postRun"] = [Module["postRun"]];
|
|
101
|
+
while (Module["postRun"].length) {
|
|
102
|
+
addOnPostRun(Module["postRun"].shift());
|
|
103
|
+
}
|
|
104
|
+
} callRuntimeCallbacks(onPostRuns); }
|
|
105
|
+
var runDependencies = 0;
|
|
106
|
+
var dependenciesFulfilled = null;
|
|
107
|
+
function getUniqueRunDependency(id) { return id; }
|
|
108
|
+
function addRunDependency(id) { runDependencies++; Module["monitorRunDependencies"]?.(runDependencies); }
|
|
109
|
+
function removeRunDependency(id) { runDependencies--; Module["monitorRunDependencies"]?.(runDependencies); if (runDependencies == 0) {
|
|
110
|
+
if (dependenciesFulfilled) {
|
|
111
|
+
var callback = dependenciesFulfilled;
|
|
112
|
+
dependenciesFulfilled = null;
|
|
113
|
+
callback();
|
|
114
|
+
}
|
|
115
|
+
} }
|
|
116
|
+
function abort(what) { Module["onAbort"]?.(what); what = "Aborted(" + what + ")"; err(what); ABORT = true; what += ". Build with -sASSERTIONS for more info."; var e = new WebAssembly.RuntimeError(what); readyPromiseReject(e); throw e; }
|
|
117
|
+
var wasmBinaryFile;
|
|
118
|
+
function findWasmBinary() { if (Module["locateFile"]) {
|
|
119
|
+
return locateFile("libredwg-web.wasm");
|
|
120
|
+
} return new URL("libredwg-web.wasm", import.meta.url).href; }
|
|
121
|
+
function getBinarySync(file) { if (file == wasmBinaryFile && wasmBinary) {
|
|
122
|
+
return new Uint8Array(wasmBinary);
|
|
123
|
+
} if (readBinary) {
|
|
124
|
+
return readBinary(file);
|
|
125
|
+
} throw "both async and sync fetching of the wasm failed"; }
|
|
126
|
+
async function getWasmBinary(binaryFile) { if (!wasmBinary) {
|
|
127
|
+
try {
|
|
128
|
+
var response = await readAsync(binaryFile);
|
|
129
|
+
return new Uint8Array(response);
|
|
130
|
+
}
|
|
131
|
+
catch { }
|
|
132
|
+
} return getBinarySync(binaryFile); }
|
|
133
|
+
async function instantiateArrayBuffer(binaryFile, imports) { try {
|
|
134
|
+
var binary = await getWasmBinary(binaryFile);
|
|
135
|
+
var instance = await WebAssembly.instantiate(binary, imports);
|
|
136
|
+
return instance;
|
|
137
|
+
}
|
|
138
|
+
catch (reason) {
|
|
139
|
+
err(`failed to asynchronously prepare wasm: ${reason}`);
|
|
140
|
+
abort(reason);
|
|
141
|
+
} }
|
|
142
|
+
async function instantiateAsync(binary, binaryFile, imports) { if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isFileURI(binaryFile) && !ENVIRONMENT_IS_NODE) {
|
|
143
|
+
try {
|
|
144
|
+
var response = fetch(binaryFile, { credentials: "same-origin" });
|
|
145
|
+
var instantiationResult = await WebAssembly.instantiateStreaming(response, imports);
|
|
146
|
+
return instantiationResult;
|
|
147
|
+
}
|
|
148
|
+
catch (reason) {
|
|
149
|
+
err(`wasm streaming compile failed: ${reason}`);
|
|
150
|
+
err("falling back to ArrayBuffer instantiation");
|
|
151
|
+
}
|
|
152
|
+
} return instantiateArrayBuffer(binaryFile, imports); }
|
|
153
|
+
function getWasmImports() { return { env: wasmImports, wasi_snapshot_preview1: wasmImports }; }
|
|
154
|
+
async function createWasm() { function receiveInstance(instance, module) { wasmExports = instance.exports; wasmMemory = wasmExports["memory"]; updateMemoryViews(); wasmTable = wasmExports["__indirect_function_table"]; removeRunDependency("wasm-instantiate"); return wasmExports; } addRunDependency("wasm-instantiate"); function receiveInstantiationResult(result) { return receiveInstance(result["instance"]); } var info = getWasmImports(); if (Module["instantiateWasm"]) {
|
|
155
|
+
return new Promise((resolve, reject) => { Module["instantiateWasm"](info, (mod, inst) => { receiveInstance(mod, inst); resolve(mod.exports); }); });
|
|
156
|
+
} wasmBinaryFile ??= findWasmBinary(); try {
|
|
157
|
+
var result = await instantiateAsync(wasmBinary, wasmBinaryFile, info);
|
|
158
|
+
var exports = receiveInstantiationResult(result);
|
|
159
|
+
return exports;
|
|
160
|
+
}
|
|
161
|
+
catch (e) {
|
|
162
|
+
readyPromiseReject(e);
|
|
163
|
+
return Promise.reject(e);
|
|
164
|
+
} }
|
|
165
|
+
class ExitStatus {
|
|
166
|
+
name = "ExitStatus";
|
|
167
|
+
constructor(status) { this.message = `Program terminated with exit(${status})`; this.status = status; }
|
|
168
|
+
}
|
|
169
|
+
var callRuntimeCallbacks = callbacks => { while (callbacks.length > 0) {
|
|
170
|
+
callbacks.shift()(Module);
|
|
171
|
+
} };
|
|
172
|
+
var onPostRuns = [];
|
|
173
|
+
var addOnPostRun = cb => onPostRuns.unshift(cb);
|
|
174
|
+
var onPreRuns = [];
|
|
175
|
+
var addOnPreRun = cb => onPreRuns.unshift(cb);
|
|
176
|
+
function getValue(ptr, type = "i8") { if (type.endsWith("*"))
|
|
177
|
+
type = "*"; switch (type) {
|
|
178
|
+
case "i1": return HEAP8[ptr];
|
|
179
|
+
case "i8": return HEAP8[ptr];
|
|
180
|
+
case "i16": return HEAP16[ptr >> 1];
|
|
181
|
+
case "i32": return HEAP32[ptr >> 2];
|
|
182
|
+
case "i64": return HEAP64[ptr >> 3];
|
|
183
|
+
case "float": return HEAPF32[ptr >> 2];
|
|
184
|
+
case "double": return HEAPF64[ptr >> 3];
|
|
185
|
+
case "*": return HEAPU32[ptr >> 2];
|
|
186
|
+
default: abort(`invalid type for getValue: ${type}`);
|
|
187
|
+
} }
|
|
188
|
+
var noExitRuntime = Module["noExitRuntime"] || true;
|
|
189
|
+
function setValue(ptr, value, type = "i8") { if (type.endsWith("*"))
|
|
190
|
+
type = "*"; switch (type) {
|
|
191
|
+
case "i1":
|
|
192
|
+
HEAP8[ptr] = value;
|
|
193
|
+
break;
|
|
194
|
+
case "i8":
|
|
195
|
+
HEAP8[ptr] = value;
|
|
196
|
+
break;
|
|
197
|
+
case "i16":
|
|
198
|
+
HEAP16[ptr >> 1] = value;
|
|
199
|
+
break;
|
|
200
|
+
case "i32":
|
|
201
|
+
HEAP32[ptr >> 2] = value;
|
|
202
|
+
break;
|
|
203
|
+
case "i64":
|
|
204
|
+
HEAP64[ptr >> 3] = BigInt(value);
|
|
205
|
+
break;
|
|
206
|
+
case "float":
|
|
207
|
+
HEAPF32[ptr >> 2] = value;
|
|
208
|
+
break;
|
|
209
|
+
case "double":
|
|
210
|
+
HEAPF64[ptr >> 3] = value;
|
|
211
|
+
break;
|
|
212
|
+
case "*":
|
|
213
|
+
HEAPU32[ptr >> 2] = value;
|
|
214
|
+
break;
|
|
215
|
+
default: abort(`invalid type for setValue: ${type}`);
|
|
216
|
+
} }
|
|
217
|
+
var stackRestore = val => __emscripten_stack_restore(val);
|
|
218
|
+
var stackSave = () => _emscripten_stack_get_current();
|
|
219
|
+
var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder : undefined;
|
|
220
|
+
var UTF8ArrayToString = (heapOrArray, idx = 0, maxBytesToRead = NaN) => { var endIdx = idx + maxBytesToRead; var endPtr = idx; while (heapOrArray[endPtr] && !(endPtr >= endIdx))
|
|
221
|
+
++endPtr; if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
|
|
222
|
+
return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
|
|
223
|
+
} var str = ""; while (idx < endPtr) {
|
|
224
|
+
var u0 = heapOrArray[idx++];
|
|
225
|
+
if (!(u0 & 128)) {
|
|
226
|
+
str += String.fromCharCode(u0);
|
|
227
|
+
continue;
|
|
228
|
+
}
|
|
229
|
+
var u1 = heapOrArray[idx++] & 63;
|
|
230
|
+
if ((u0 & 224) == 192) {
|
|
231
|
+
str += String.fromCharCode((u0 & 31) << 6 | u1);
|
|
232
|
+
continue;
|
|
233
|
+
}
|
|
234
|
+
var u2 = heapOrArray[idx++] & 63;
|
|
235
|
+
if ((u0 & 240) == 224) {
|
|
236
|
+
u0 = (u0 & 15) << 12 | u1 << 6 | u2;
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
|
|
240
|
+
}
|
|
241
|
+
if (u0 < 65536) {
|
|
242
|
+
str += String.fromCharCode(u0);
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
var ch = u0 - 65536;
|
|
246
|
+
str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
|
|
247
|
+
}
|
|
248
|
+
} return str; };
|
|
249
|
+
var UTF8ToString = (ptr, maxBytesToRead) => ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
|
|
250
|
+
var ___assert_fail = (condition, filename, line, func) => abort(`Assertion failed: ${UTF8ToString(condition)}, at: ` + [filename ? UTF8ToString(filename) : "unknown filename", line, func ? UTF8ToString(func) : "unknown function"]);
|
|
251
|
+
var wasmTableMirror = [];
|
|
252
|
+
var wasmTable;
|
|
253
|
+
var getWasmTableEntry = funcPtr => { var func = wasmTableMirror[funcPtr]; if (!func) {
|
|
254
|
+
if (funcPtr >= wasmTableMirror.length)
|
|
255
|
+
wasmTableMirror.length = funcPtr + 1;
|
|
256
|
+
wasmTableMirror[funcPtr] = func = wasmTable.get(funcPtr);
|
|
257
|
+
} return func; };
|
|
258
|
+
var ___call_sighandler = (fp, sig) => getWasmTableEntry(fp)(sig);
|
|
259
|
+
class ExceptionInfo {
|
|
260
|
+
constructor(excPtr) { this.excPtr = excPtr; this.ptr = excPtr - 24; }
|
|
261
|
+
set_type(type) { HEAPU32[this.ptr + 4 >> 2] = type; }
|
|
262
|
+
get_type() { return HEAPU32[this.ptr + 4 >> 2]; }
|
|
263
|
+
set_destructor(destructor) { HEAPU32[this.ptr + 8 >> 2] = destructor; }
|
|
264
|
+
get_destructor() { return HEAPU32[this.ptr + 8 >> 2]; }
|
|
265
|
+
set_caught(caught) { caught = caught ? 1 : 0; HEAP8[this.ptr + 12] = caught; }
|
|
266
|
+
get_caught() { return HEAP8[this.ptr + 12] != 0; }
|
|
267
|
+
set_rethrown(rethrown) { rethrown = rethrown ? 1 : 0; HEAP8[this.ptr + 13] = rethrown; }
|
|
268
|
+
get_rethrown() { return HEAP8[this.ptr + 13] != 0; }
|
|
269
|
+
init(type, destructor) { this.set_adjusted_ptr(0); this.set_type(type); this.set_destructor(destructor); }
|
|
270
|
+
set_adjusted_ptr(adjustedPtr) { HEAPU32[this.ptr + 16 >> 2] = adjustedPtr; }
|
|
271
|
+
get_adjusted_ptr() { return HEAPU32[this.ptr + 16 >> 2]; }
|
|
272
|
+
}
|
|
273
|
+
var exceptionLast = 0;
|
|
274
|
+
var uncaughtExceptionCount = 0;
|
|
275
|
+
var ___cxa_throw = (ptr, type, destructor) => { var info = new ExceptionInfo(ptr); info.init(type, destructor); exceptionLast = ptr; uncaughtExceptionCount++; throw exceptionLast; };
|
|
276
|
+
var syscallGetVarargI = () => { var ret = HEAP32[+SYSCALLS.varargs >> 2]; SYSCALLS.varargs += 4; return ret; };
|
|
277
|
+
var syscallGetVarargP = syscallGetVarargI;
|
|
278
|
+
var PATH = { isAbs: path => path.charAt(0) === "/", splitPath: filename => { var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/; return splitPathRe.exec(filename).slice(1); }, normalizeArray: (parts, allowAboveRoot) => { var up = 0; for (var i = parts.length - 1; i >= 0; i--) {
|
|
279
|
+
var last = parts[i];
|
|
280
|
+
if (last === ".") {
|
|
281
|
+
parts.splice(i, 1);
|
|
282
|
+
}
|
|
283
|
+
else if (last === "..") {
|
|
284
|
+
parts.splice(i, 1);
|
|
285
|
+
up++;
|
|
286
|
+
}
|
|
287
|
+
else if (up) {
|
|
288
|
+
parts.splice(i, 1);
|
|
289
|
+
up--;
|
|
290
|
+
}
|
|
291
|
+
} if (allowAboveRoot) {
|
|
292
|
+
for (; up; up--) {
|
|
293
|
+
parts.unshift("..");
|
|
294
|
+
}
|
|
295
|
+
} return parts; }, normalize: path => { var isAbsolute = PATH.isAbs(path), trailingSlash = path.slice(-1) === "/"; path = PATH.normalizeArray(path.split("/").filter(p => !!p), !isAbsolute).join("/"); if (!path && !isAbsolute) {
|
|
296
|
+
path = ".";
|
|
297
|
+
} if (path && trailingSlash) {
|
|
298
|
+
path += "/";
|
|
299
|
+
} return (isAbsolute ? "/" : "") + path; }, dirname: path => { var result = PATH.splitPath(path), root = result[0], dir = result[1]; if (!root && !dir) {
|
|
300
|
+
return ".";
|
|
301
|
+
} if (dir) {
|
|
302
|
+
dir = dir.slice(0, -1);
|
|
303
|
+
} return root + dir; }, basename: path => path && path.match(/([^\/]+|\/)\/*$/)[1], join: (...paths) => PATH.normalize(paths.join("/")), join2: (l, r) => PATH.normalize(l + "/" + r) };
|
|
304
|
+
var initRandomFill = () => { if (ENVIRONMENT_IS_NODE) {
|
|
305
|
+
var nodeCrypto = require("crypto");
|
|
306
|
+
return view => nodeCrypto.randomFillSync(view);
|
|
307
|
+
} return view => crypto.getRandomValues(view); };
|
|
308
|
+
var randomFill = view => { (randomFill = initRandomFill())(view); };
|
|
309
|
+
var PATH_FS = { resolve: (...args) => { var resolvedPath = "", resolvedAbsolute = false; for (var i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {
|
|
310
|
+
var path = i >= 0 ? args[i] : FS.cwd();
|
|
311
|
+
if (typeof path != "string") {
|
|
312
|
+
throw new TypeError("Arguments to path.resolve must be strings");
|
|
313
|
+
}
|
|
314
|
+
else if (!path) {
|
|
315
|
+
return "";
|
|
316
|
+
}
|
|
317
|
+
resolvedPath = path + "/" + resolvedPath;
|
|
318
|
+
resolvedAbsolute = PATH.isAbs(path);
|
|
319
|
+
} resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter(p => !!p), !resolvedAbsolute).join("/"); return (resolvedAbsolute ? "/" : "") + resolvedPath || "."; }, relative: (from, to) => { from = PATH_FS.resolve(from).slice(1); to = PATH_FS.resolve(to).slice(1); function trim(arr) { var start = 0; for (; start < arr.length; start++) {
|
|
320
|
+
if (arr[start] !== "")
|
|
321
|
+
break;
|
|
322
|
+
} var end = arr.length - 1; for (; end >= 0; end--) {
|
|
323
|
+
if (arr[end] !== "")
|
|
324
|
+
break;
|
|
325
|
+
} if (start > end)
|
|
326
|
+
return []; return arr.slice(start, end - start + 1); } var fromParts = trim(from.split("/")); var toParts = trim(to.split("/")); var length = Math.min(fromParts.length, toParts.length); var samePartsLength = length; for (var i = 0; i < length; i++) {
|
|
327
|
+
if (fromParts[i] !== toParts[i]) {
|
|
328
|
+
samePartsLength = i;
|
|
329
|
+
break;
|
|
330
|
+
}
|
|
331
|
+
} var outputParts = []; for (var i = samePartsLength; i < fromParts.length; i++) {
|
|
332
|
+
outputParts.push("..");
|
|
333
|
+
} outputParts = outputParts.concat(toParts.slice(samePartsLength)); return outputParts.join("/"); } };
|
|
334
|
+
var FS_stdin_getChar_buffer = [];
|
|
335
|
+
var lengthBytesUTF8 = str => { var len = 0; for (var i = 0; i < str.length; ++i) {
|
|
336
|
+
var c = str.charCodeAt(i);
|
|
337
|
+
if (c <= 127) {
|
|
338
|
+
len++;
|
|
339
|
+
}
|
|
340
|
+
else if (c <= 2047) {
|
|
341
|
+
len += 2;
|
|
342
|
+
}
|
|
343
|
+
else if (c >= 55296 && c <= 57343) {
|
|
344
|
+
len += 4;
|
|
345
|
+
++i;
|
|
346
|
+
}
|
|
347
|
+
else {
|
|
348
|
+
len += 3;
|
|
349
|
+
}
|
|
350
|
+
} return len; };
|
|
351
|
+
var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => { if (!(maxBytesToWrite > 0))
|
|
352
|
+
return 0; var startIdx = outIdx; var endIdx = outIdx + maxBytesToWrite - 1; for (var i = 0; i < str.length; ++i) {
|
|
353
|
+
var u = str.charCodeAt(i);
|
|
354
|
+
if (u >= 55296 && u <= 57343) {
|
|
355
|
+
var u1 = str.charCodeAt(++i);
|
|
356
|
+
u = 65536 + ((u & 1023) << 10) | u1 & 1023;
|
|
357
|
+
}
|
|
358
|
+
if (u <= 127) {
|
|
359
|
+
if (outIdx >= endIdx)
|
|
360
|
+
break;
|
|
361
|
+
heap[outIdx++] = u;
|
|
362
|
+
}
|
|
363
|
+
else if (u <= 2047) {
|
|
364
|
+
if (outIdx + 1 >= endIdx)
|
|
365
|
+
break;
|
|
366
|
+
heap[outIdx++] = 192 | u >> 6;
|
|
367
|
+
heap[outIdx++] = 128 | u & 63;
|
|
368
|
+
}
|
|
369
|
+
else if (u <= 65535) {
|
|
370
|
+
if (outIdx + 2 >= endIdx)
|
|
371
|
+
break;
|
|
372
|
+
heap[outIdx++] = 224 | u >> 12;
|
|
373
|
+
heap[outIdx++] = 128 | u >> 6 & 63;
|
|
374
|
+
heap[outIdx++] = 128 | u & 63;
|
|
375
|
+
}
|
|
376
|
+
else {
|
|
377
|
+
if (outIdx + 3 >= endIdx)
|
|
378
|
+
break;
|
|
379
|
+
heap[outIdx++] = 240 | u >> 18;
|
|
380
|
+
heap[outIdx++] = 128 | u >> 12 & 63;
|
|
381
|
+
heap[outIdx++] = 128 | u >> 6 & 63;
|
|
382
|
+
heap[outIdx++] = 128 | u & 63;
|
|
383
|
+
}
|
|
384
|
+
} heap[outIdx] = 0; return outIdx - startIdx; };
|
|
385
|
+
var intArrayFromString = (stringy, dontAddNull, length) => { var len = length > 0 ? length : lengthBytesUTF8(stringy) + 1; var u8array = new Array(len); var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length); if (dontAddNull)
|
|
386
|
+
u8array.length = numBytesWritten; return u8array; };
|
|
387
|
+
var FS_stdin_getChar = () => { if (!FS_stdin_getChar_buffer.length) {
|
|
388
|
+
var result = null;
|
|
389
|
+
if (ENVIRONMENT_IS_NODE) {
|
|
390
|
+
var BUFSIZE = 256;
|
|
391
|
+
var buf = Buffer.alloc(BUFSIZE);
|
|
392
|
+
var bytesRead = 0;
|
|
393
|
+
var fd = process.stdin.fd;
|
|
394
|
+
try {
|
|
395
|
+
bytesRead = fs.readSync(fd, buf, 0, BUFSIZE);
|
|
396
|
+
}
|
|
397
|
+
catch (e) {
|
|
398
|
+
if (e.toString().includes("EOF"))
|
|
399
|
+
bytesRead = 0;
|
|
400
|
+
else
|
|
401
|
+
throw e;
|
|
402
|
+
}
|
|
403
|
+
if (bytesRead > 0) {
|
|
404
|
+
result = buf.slice(0, bytesRead).toString("utf-8");
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
else if (typeof window != "undefined" && typeof window.prompt == "function") {
|
|
408
|
+
result = window.prompt("Input: ");
|
|
409
|
+
if (result !== null) {
|
|
410
|
+
result += "\n";
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
else { }
|
|
414
|
+
if (!result) {
|
|
415
|
+
return null;
|
|
416
|
+
}
|
|
417
|
+
FS_stdin_getChar_buffer = intArrayFromString(result, true);
|
|
418
|
+
} return FS_stdin_getChar_buffer.shift(); };
|
|
419
|
+
var TTY = { ttys: [], init() { }, shutdown() { }, register(dev, ops) { TTY.ttys[dev] = { input: [], output: [], ops }; FS.registerDevice(dev, TTY.stream_ops); }, stream_ops: { open(stream) { var tty = TTY.ttys[stream.node.rdev]; if (!tty) {
|
|
420
|
+
throw new FS.ErrnoError(43);
|
|
421
|
+
} stream.tty = tty; stream.seekable = false; }, close(stream) { stream.tty.ops.fsync(stream.tty); }, fsync(stream) { stream.tty.ops.fsync(stream.tty); }, read(stream, buffer, offset, length, pos) { if (!stream.tty || !stream.tty.ops.get_char) {
|
|
422
|
+
throw new FS.ErrnoError(60);
|
|
423
|
+
} var bytesRead = 0; for (var i = 0; i < length; i++) {
|
|
424
|
+
var result;
|
|
425
|
+
try {
|
|
426
|
+
result = stream.tty.ops.get_char(stream.tty);
|
|
427
|
+
}
|
|
428
|
+
catch (e) {
|
|
429
|
+
throw new FS.ErrnoError(29);
|
|
430
|
+
}
|
|
431
|
+
if (result === undefined && bytesRead === 0) {
|
|
432
|
+
throw new FS.ErrnoError(6);
|
|
433
|
+
}
|
|
434
|
+
if (result === null || result === undefined)
|
|
435
|
+
break;
|
|
436
|
+
bytesRead++;
|
|
437
|
+
buffer[offset + i] = result;
|
|
438
|
+
} if (bytesRead) {
|
|
439
|
+
stream.node.atime = Date.now();
|
|
440
|
+
} return bytesRead; }, write(stream, buffer, offset, length, pos) { if (!stream.tty || !stream.tty.ops.put_char) {
|
|
441
|
+
throw new FS.ErrnoError(60);
|
|
442
|
+
} try {
|
|
443
|
+
for (var i = 0; i < length; i++) {
|
|
444
|
+
stream.tty.ops.put_char(stream.tty, buffer[offset + i]);
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
catch (e) {
|
|
448
|
+
throw new FS.ErrnoError(29);
|
|
449
|
+
} if (length) {
|
|
450
|
+
stream.node.mtime = stream.node.ctime = Date.now();
|
|
451
|
+
} return i; } }, default_tty_ops: { get_char(tty) { return FS_stdin_getChar(); }, put_char(tty, val) { if (val === null || val === 10) {
|
|
452
|
+
out(UTF8ArrayToString(tty.output));
|
|
453
|
+
tty.output = [];
|
|
454
|
+
}
|
|
455
|
+
else {
|
|
456
|
+
if (val != 0)
|
|
457
|
+
tty.output.push(val);
|
|
458
|
+
} }, fsync(tty) { if (tty.output?.length > 0) {
|
|
459
|
+
out(UTF8ArrayToString(tty.output));
|
|
460
|
+
tty.output = [];
|
|
461
|
+
} }, ioctl_tcgets(tty) { 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] }; }, ioctl_tcsets(tty, optional_actions, data) { return 0; }, ioctl_tiocgwinsz(tty) { return [24, 80]; } }, default_tty1_ops: { put_char(tty, val) { if (val === null || val === 10) {
|
|
462
|
+
err(UTF8ArrayToString(tty.output));
|
|
463
|
+
tty.output = [];
|
|
464
|
+
}
|
|
465
|
+
else {
|
|
466
|
+
if (val != 0)
|
|
467
|
+
tty.output.push(val);
|
|
468
|
+
} }, fsync(tty) { if (tty.output?.length > 0) {
|
|
469
|
+
err(UTF8ArrayToString(tty.output));
|
|
470
|
+
tty.output = [];
|
|
471
|
+
} } } };
|
|
472
|
+
var zeroMemory = (address, size) => { HEAPU8.fill(0, address, address + size); };
|
|
473
|
+
var alignMemory = (size, alignment) => Math.ceil(size / alignment) * alignment;
|
|
474
|
+
var mmapAlloc = size => { size = alignMemory(size, 65536); var ptr = _emscripten_builtin_memalign(65536, size); if (ptr)
|
|
475
|
+
zeroMemory(ptr, size); return ptr; };
|
|
476
|
+
var MEMFS = { ops_table: null, mount(mount) { return MEMFS.createNode(null, "/", 16895, 0); }, createNode(parent, name, mode, dev) { if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
|
|
477
|
+
throw new FS.ErrnoError(63);
|
|
478
|
+
} 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 } }; var node = FS.createNode(parent, name, mode, dev); if (FS.isDir(node.mode)) {
|
|
479
|
+
node.node_ops = MEMFS.ops_table.dir.node;
|
|
480
|
+
node.stream_ops = MEMFS.ops_table.dir.stream;
|
|
481
|
+
node.contents = {};
|
|
482
|
+
}
|
|
483
|
+
else if (FS.isFile(node.mode)) {
|
|
484
|
+
node.node_ops = MEMFS.ops_table.file.node;
|
|
485
|
+
node.stream_ops = MEMFS.ops_table.file.stream;
|
|
486
|
+
node.usedBytes = 0;
|
|
487
|
+
node.contents = null;
|
|
488
|
+
}
|
|
489
|
+
else if (FS.isLink(node.mode)) {
|
|
490
|
+
node.node_ops = MEMFS.ops_table.link.node;
|
|
491
|
+
node.stream_ops = MEMFS.ops_table.link.stream;
|
|
492
|
+
}
|
|
493
|
+
else if (FS.isChrdev(node.mode)) {
|
|
494
|
+
node.node_ops = MEMFS.ops_table.chrdev.node;
|
|
495
|
+
node.stream_ops = MEMFS.ops_table.chrdev.stream;
|
|
496
|
+
} node.atime = node.mtime = node.ctime = Date.now(); if (parent) {
|
|
497
|
+
parent.contents[name] = node;
|
|
498
|
+
parent.atime = parent.mtime = parent.ctime = node.atime;
|
|
499
|
+
} return node; }, getFileDataAsTypedArray(node) { if (!node.contents)
|
|
500
|
+
return new Uint8Array(0); if (node.contents.subarray)
|
|
501
|
+
return node.contents.subarray(0, node.usedBytes); return new Uint8Array(node.contents); }, expandFileStorage(node, newCapacity) { var prevCapacity = node.contents ? node.contents.length : 0; if (prevCapacity >= newCapacity)
|
|
502
|
+
return; var CAPACITY_DOUBLING_MAX = 1024 * 1024; newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) >>> 0); if (prevCapacity != 0)
|
|
503
|
+
newCapacity = Math.max(newCapacity, 256); var oldContents = node.contents; node.contents = new Uint8Array(newCapacity); if (node.usedBytes > 0)
|
|
504
|
+
node.contents.set(oldContents.subarray(0, node.usedBytes), 0); }, resizeFileStorage(node, newSize) { if (node.usedBytes == newSize)
|
|
505
|
+
return; if (newSize == 0) {
|
|
506
|
+
node.contents = null;
|
|
507
|
+
node.usedBytes = 0;
|
|
508
|
+
}
|
|
509
|
+
else {
|
|
510
|
+
var oldContents = node.contents;
|
|
511
|
+
node.contents = new Uint8Array(newSize);
|
|
512
|
+
if (oldContents) {
|
|
513
|
+
node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)));
|
|
514
|
+
}
|
|
515
|
+
node.usedBytes = newSize;
|
|
516
|
+
} }, node_ops: { getattr(node) { var attr = {}; attr.dev = FS.isChrdev(node.mode) ? node.id : 1; attr.ino = node.id; attr.mode = node.mode; attr.nlink = 1; attr.uid = 0; attr.gid = 0; attr.rdev = node.rdev; if (FS.isDir(node.mode)) {
|
|
517
|
+
attr.size = 4096;
|
|
518
|
+
}
|
|
519
|
+
else if (FS.isFile(node.mode)) {
|
|
520
|
+
attr.size = node.usedBytes;
|
|
521
|
+
}
|
|
522
|
+
else if (FS.isLink(node.mode)) {
|
|
523
|
+
attr.size = node.link.length;
|
|
524
|
+
}
|
|
525
|
+
else {
|
|
526
|
+
attr.size = 0;
|
|
527
|
+
} attr.atime = new Date(node.atime); attr.mtime = new Date(node.mtime); attr.ctime = new Date(node.ctime); attr.blksize = 4096; attr.blocks = Math.ceil(attr.size / attr.blksize); return attr; }, setattr(node, attr) { for (const key of ["mode", "atime", "mtime", "ctime"]) {
|
|
528
|
+
if (attr[key] != null) {
|
|
529
|
+
node[key] = attr[key];
|
|
530
|
+
}
|
|
531
|
+
} if (attr.size !== undefined) {
|
|
532
|
+
MEMFS.resizeFileStorage(node, attr.size);
|
|
533
|
+
} }, lookup(parent, name) { throw MEMFS.doesNotExistError; }, mknod(parent, name, mode, dev) { return MEMFS.createNode(parent, name, mode, dev); }, rename(old_node, new_dir, new_name) { var new_node; try {
|
|
534
|
+
new_node = FS.lookupNode(new_dir, new_name);
|
|
535
|
+
}
|
|
536
|
+
catch (e) { } if (new_node) {
|
|
537
|
+
if (FS.isDir(old_node.mode)) {
|
|
538
|
+
for (var i in new_node.contents) {
|
|
539
|
+
throw new FS.ErrnoError(55);
|
|
540
|
+
}
|
|
541
|
+
}
|
|
542
|
+
FS.hashRemoveNode(new_node);
|
|
543
|
+
} delete old_node.parent.contents[old_node.name]; new_dir.contents[new_name] = old_node; old_node.name = new_name; new_dir.ctime = new_dir.mtime = old_node.parent.ctime = old_node.parent.mtime = Date.now(); }, unlink(parent, name) { delete parent.contents[name]; parent.ctime = parent.mtime = Date.now(); }, rmdir(parent, name) { var node = FS.lookupNode(parent, name); for (var i in node.contents) {
|
|
544
|
+
throw new FS.ErrnoError(55);
|
|
545
|
+
} delete parent.contents[name]; parent.ctime = parent.mtime = Date.now(); }, readdir(node) { return [".", "..", ...Object.keys(node.contents)]; }, symlink(parent, newname, oldpath) { var node = MEMFS.createNode(parent, newname, 511 | 40960, 0); node.link = oldpath; return node; }, readlink(node) { if (!FS.isLink(node.mode)) {
|
|
546
|
+
throw new FS.ErrnoError(28);
|
|
547
|
+
} return node.link; } }, stream_ops: { read(stream, buffer, offset, length, position) { var contents = stream.node.contents; if (position >= stream.node.usedBytes)
|
|
548
|
+
return 0; var size = Math.min(stream.node.usedBytes - position, length); if (size > 8 && contents.subarray) {
|
|
549
|
+
buffer.set(contents.subarray(position, position + size), offset);
|
|
550
|
+
}
|
|
551
|
+
else {
|
|
552
|
+
for (var i = 0; i < size; i++)
|
|
553
|
+
buffer[offset + i] = contents[position + i];
|
|
554
|
+
} return size; }, write(stream, buffer, offset, length, position, canOwn) { if (buffer.buffer === HEAP8.buffer) {
|
|
555
|
+
canOwn = false;
|
|
556
|
+
} if (!length)
|
|
557
|
+
return 0; var node = stream.node; node.mtime = node.ctime = Date.now(); if (buffer.subarray && (!node.contents || node.contents.subarray)) {
|
|
558
|
+
if (canOwn) {
|
|
559
|
+
node.contents = buffer.subarray(offset, offset + length);
|
|
560
|
+
node.usedBytes = length;
|
|
561
|
+
return length;
|
|
562
|
+
}
|
|
563
|
+
else if (node.usedBytes === 0 && position === 0) {
|
|
564
|
+
node.contents = buffer.slice(offset, offset + length);
|
|
565
|
+
node.usedBytes = length;
|
|
566
|
+
return length;
|
|
567
|
+
}
|
|
568
|
+
else if (position + length <= node.usedBytes) {
|
|
569
|
+
node.contents.set(buffer.subarray(offset, offset + length), position);
|
|
570
|
+
return length;
|
|
571
|
+
}
|
|
572
|
+
} MEMFS.expandFileStorage(node, position + length); if (node.contents.subarray && buffer.subarray) {
|
|
573
|
+
node.contents.set(buffer.subarray(offset, offset + length), position);
|
|
574
|
+
}
|
|
575
|
+
else {
|
|
576
|
+
for (var i = 0; i < length; i++) {
|
|
577
|
+
node.contents[position + i] = buffer[offset + i];
|
|
578
|
+
}
|
|
579
|
+
} node.usedBytes = Math.max(node.usedBytes, position + length); return length; }, llseek(stream, offset, whence) { var position = offset; if (whence === 1) {
|
|
580
|
+
position += stream.position;
|
|
581
|
+
}
|
|
582
|
+
else if (whence === 2) {
|
|
583
|
+
if (FS.isFile(stream.node.mode)) {
|
|
584
|
+
position += stream.node.usedBytes;
|
|
585
|
+
}
|
|
586
|
+
} if (position < 0) {
|
|
587
|
+
throw new FS.ErrnoError(28);
|
|
588
|
+
} return position; }, allocate(stream, offset, length) { MEMFS.expandFileStorage(stream.node, offset + length); stream.node.usedBytes = Math.max(stream.node.usedBytes, offset + length); }, mmap(stream, length, position, prot, flags) { if (!FS.isFile(stream.node.mode)) {
|
|
589
|
+
throw new FS.ErrnoError(43);
|
|
590
|
+
} var ptr; var allocated; var contents = stream.node.contents; if (!(flags & 2) && contents && contents.buffer === HEAP8.buffer) {
|
|
591
|
+
allocated = false;
|
|
592
|
+
ptr = contents.byteOffset;
|
|
593
|
+
}
|
|
594
|
+
else {
|
|
595
|
+
allocated = true;
|
|
596
|
+
ptr = mmapAlloc(length);
|
|
597
|
+
if (!ptr) {
|
|
598
|
+
throw new FS.ErrnoError(48);
|
|
599
|
+
}
|
|
600
|
+
if (contents) {
|
|
601
|
+
if (position > 0 || position + length < contents.length) {
|
|
602
|
+
if (contents.subarray) {
|
|
603
|
+
contents = contents.subarray(position, position + length);
|
|
604
|
+
}
|
|
605
|
+
else {
|
|
606
|
+
contents = Array.prototype.slice.call(contents, position, position + length);
|
|
607
|
+
}
|
|
608
|
+
}
|
|
609
|
+
HEAP8.set(contents, ptr);
|
|
610
|
+
}
|
|
611
|
+
} return { ptr, allocated }; }, msync(stream, buffer, offset, length, mmapFlags) { MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false); return 0; } } };
|
|
612
|
+
var asyncLoad = async (url) => { var arrayBuffer = await readAsync(url); return new Uint8Array(arrayBuffer); };
|
|
613
|
+
var FS_createDataFile = (parent, name, fileData, canRead, canWrite, canOwn) => { FS.createDataFile(parent, name, fileData, canRead, canWrite, canOwn); };
|
|
614
|
+
var preloadPlugins = Module["preloadPlugins"] || [];
|
|
615
|
+
var FS_handledByPreloadPlugin = (byteArray, fullname, finish, onerror) => { if (typeof Browser != "undefined")
|
|
616
|
+
Browser.init(); var handled = false; preloadPlugins.forEach(plugin => { if (handled)
|
|
617
|
+
return; if (plugin["canHandle"](fullname)) {
|
|
618
|
+
plugin["handle"](byteArray, fullname, finish, onerror);
|
|
619
|
+
handled = true;
|
|
620
|
+
} }); return handled; };
|
|
621
|
+
var FS_createPreloadedFile = (parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) => { var fullname = name ? PATH_FS.resolve(PATH.join2(parent, name)) : parent; var dep = getUniqueRunDependency(`cp ${fullname}`); function processData(byteArray) { function finish(byteArray) { preFinish?.(); if (!dontCreateFile) {
|
|
622
|
+
FS_createDataFile(parent, name, byteArray, canRead, canWrite, canOwn);
|
|
623
|
+
} onload?.(); removeRunDependency(dep); } if (FS_handledByPreloadPlugin(byteArray, fullname, finish, () => { onerror?.(); removeRunDependency(dep); })) {
|
|
624
|
+
return;
|
|
625
|
+
} finish(byteArray); } addRunDependency(dep); if (typeof url == "string") {
|
|
626
|
+
asyncLoad(url).then(processData, onerror);
|
|
627
|
+
}
|
|
628
|
+
else {
|
|
629
|
+
processData(url);
|
|
630
|
+
} };
|
|
631
|
+
var FS_modeStringToFlags = str => { var flagModes = { r: 0, "r+": 2, w: 512 | 64 | 1, "w+": 512 | 64 | 2, a: 1024 | 64 | 1, "a+": 1024 | 64 | 2 }; var flags = flagModes[str]; if (typeof flags == "undefined") {
|
|
632
|
+
throw new Error(`Unknown file open mode: ${str}`);
|
|
633
|
+
} return flags; };
|
|
634
|
+
var FS_getMode = (canRead, canWrite) => { var mode = 0; if (canRead)
|
|
635
|
+
mode |= 292 | 73; if (canWrite)
|
|
636
|
+
mode |= 146; return mode; };
|
|
637
|
+
var FS = { root: null, mounts: [], devices: {}, streams: [], nextInode: 1, nameTable: null, currentPath: "/", initialized: false, ignorePermissions: true, ErrnoError: class {
|
|
638
|
+
name = "ErrnoError";
|
|
639
|
+
constructor(errno) { this.errno = errno; }
|
|
640
|
+
}, filesystems: null, syncFSRequests: 0, readFiles: {}, FSStream: class {
|
|
641
|
+
shared = {};
|
|
642
|
+
get object() { return this.node; }
|
|
643
|
+
set object(val) { this.node = val; }
|
|
644
|
+
get isRead() { return (this.flags & 2097155) !== 1; }
|
|
645
|
+
get isWrite() { return (this.flags & 2097155) !== 0; }
|
|
646
|
+
get isAppend() { return this.flags & 1024; }
|
|
647
|
+
get flags() { return this.shared.flags; }
|
|
648
|
+
set flags(val) { this.shared.flags = val; }
|
|
649
|
+
get position() { return this.shared.position; }
|
|
650
|
+
set position(val) { this.shared.position = val; }
|
|
651
|
+
}, FSNode: class {
|
|
652
|
+
node_ops = {};
|
|
653
|
+
stream_ops = {};
|
|
654
|
+
readMode = 292 | 73;
|
|
655
|
+
writeMode = 146;
|
|
656
|
+
mounted = null;
|
|
657
|
+
constructor(parent, name, mode, rdev) { if (!parent) {
|
|
658
|
+
parent = this;
|
|
659
|
+
} this.parent = parent; this.mount = parent.mount; this.id = FS.nextInode++; this.name = name; this.mode = mode; this.rdev = rdev; this.atime = this.mtime = this.ctime = Date.now(); }
|
|
660
|
+
get read() { return (this.mode & this.readMode) === this.readMode; }
|
|
661
|
+
set read(val) { val ? this.mode |= this.readMode : this.mode &= ~this.readMode; }
|
|
662
|
+
get write() { return (this.mode & this.writeMode) === this.writeMode; }
|
|
663
|
+
set write(val) { val ? this.mode |= this.writeMode : this.mode &= ~this.writeMode; }
|
|
664
|
+
get isFolder() { return FS.isDir(this.mode); }
|
|
665
|
+
get isDevice() { return FS.isChrdev(this.mode); }
|
|
666
|
+
}, lookupPath(path, opts = {}) { if (!path) {
|
|
667
|
+
throw new FS.ErrnoError(44);
|
|
668
|
+
} opts.follow_mount ??= true; if (!PATH.isAbs(path)) {
|
|
669
|
+
path = FS.cwd() + "/" + path;
|
|
670
|
+
} linkloop: for (var nlinks = 0; nlinks < 40; nlinks++) {
|
|
671
|
+
var parts = path.split("/").filter(p => !!p);
|
|
672
|
+
var current = FS.root;
|
|
673
|
+
var current_path = "/";
|
|
674
|
+
for (var i = 0; i < parts.length; i++) {
|
|
675
|
+
var islast = i === parts.length - 1;
|
|
676
|
+
if (islast && opts.parent) {
|
|
677
|
+
break;
|
|
678
|
+
}
|
|
679
|
+
if (parts[i] === ".") {
|
|
680
|
+
continue;
|
|
681
|
+
}
|
|
682
|
+
if (parts[i] === "..") {
|
|
683
|
+
current_path = PATH.dirname(current_path);
|
|
684
|
+
current = current.parent;
|
|
685
|
+
continue;
|
|
686
|
+
}
|
|
687
|
+
current_path = PATH.join2(current_path, parts[i]);
|
|
688
|
+
try {
|
|
689
|
+
current = FS.lookupNode(current, parts[i]);
|
|
690
|
+
}
|
|
691
|
+
catch (e) {
|
|
692
|
+
if (e?.errno === 44 && islast && opts.noent_okay) {
|
|
693
|
+
return { path: current_path };
|
|
694
|
+
}
|
|
695
|
+
throw e;
|
|
696
|
+
}
|
|
697
|
+
if (FS.isMountpoint(current) && (!islast || opts.follow_mount)) {
|
|
698
|
+
current = current.mounted.root;
|
|
699
|
+
}
|
|
700
|
+
if (FS.isLink(current.mode) && (!islast || opts.follow)) {
|
|
701
|
+
if (!current.node_ops.readlink) {
|
|
702
|
+
throw new FS.ErrnoError(52);
|
|
703
|
+
}
|
|
704
|
+
var link = current.node_ops.readlink(current);
|
|
705
|
+
if (!PATH.isAbs(link)) {
|
|
706
|
+
link = PATH.dirname(current_path) + "/" + link;
|
|
707
|
+
}
|
|
708
|
+
path = link + "/" + parts.slice(i + 1).join("/");
|
|
709
|
+
continue linkloop;
|
|
710
|
+
}
|
|
711
|
+
}
|
|
712
|
+
return { path: current_path, node: current };
|
|
713
|
+
} throw new FS.ErrnoError(32); }, getPath(node) { var path; while (true) {
|
|
714
|
+
if (FS.isRoot(node)) {
|
|
715
|
+
var mount = node.mount.mountpoint;
|
|
716
|
+
if (!path)
|
|
717
|
+
return mount;
|
|
718
|
+
return mount[mount.length - 1] !== "/" ? `${mount}/${path}` : mount + path;
|
|
719
|
+
}
|
|
720
|
+
path = path ? `${node.name}/${path}` : node.name;
|
|
721
|
+
node = node.parent;
|
|
722
|
+
} }, hashName(parentid, name) { var hash = 0; for (var i = 0; i < name.length; i++) {
|
|
723
|
+
hash = (hash << 5) - hash + name.charCodeAt(i) | 0;
|
|
724
|
+
} return (parentid + hash >>> 0) % FS.nameTable.length; }, hashAddNode(node) { var hash = FS.hashName(node.parent.id, node.name); node.name_next = FS.nameTable[hash]; FS.nameTable[hash] = node; }, hashRemoveNode(node) { var hash = FS.hashName(node.parent.id, node.name); if (FS.nameTable[hash] === node) {
|
|
725
|
+
FS.nameTable[hash] = node.name_next;
|
|
726
|
+
}
|
|
727
|
+
else {
|
|
728
|
+
var current = FS.nameTable[hash];
|
|
729
|
+
while (current) {
|
|
730
|
+
if (current.name_next === node) {
|
|
731
|
+
current.name_next = node.name_next;
|
|
732
|
+
break;
|
|
733
|
+
}
|
|
734
|
+
current = current.name_next;
|
|
735
|
+
}
|
|
736
|
+
} }, lookupNode(parent, name) { var errCode = FS.mayLookup(parent); if (errCode) {
|
|
737
|
+
throw new FS.ErrnoError(errCode);
|
|
738
|
+
} var hash = FS.hashName(parent.id, name); for (var node = FS.nameTable[hash]; node; node = node.name_next) {
|
|
739
|
+
var nodeName = node.name;
|
|
740
|
+
if (node.parent.id === parent.id && nodeName === name) {
|
|
741
|
+
return node;
|
|
742
|
+
}
|
|
743
|
+
} return FS.lookup(parent, name); }, createNode(parent, name, mode, rdev) { var node = new FS.FSNode(parent, name, mode, rdev); FS.hashAddNode(node); return node; }, destroyNode(node) { FS.hashRemoveNode(node); }, isRoot(node) { return node === node.parent; }, isMountpoint(node) { return !!node.mounted; }, isFile(mode) { return (mode & 61440) === 32768; }, isDir(mode) { return (mode & 61440) === 16384; }, isLink(mode) { return (mode & 61440) === 40960; }, isChrdev(mode) { return (mode & 61440) === 8192; }, isBlkdev(mode) { return (mode & 61440) === 24576; }, isFIFO(mode) { return (mode & 61440) === 4096; }, isSocket(mode) { return (mode & 49152) === 49152; }, flagsToPermissionString(flag) { var perms = ["r", "w", "rw"][flag & 3]; if (flag & 512) {
|
|
744
|
+
perms += "w";
|
|
745
|
+
} return perms; }, nodePermissions(node, perms) { if (FS.ignorePermissions) {
|
|
746
|
+
return 0;
|
|
747
|
+
} if (perms.includes("r") && !(node.mode & 292)) {
|
|
748
|
+
return 2;
|
|
749
|
+
}
|
|
750
|
+
else if (perms.includes("w") && !(node.mode & 146)) {
|
|
751
|
+
return 2;
|
|
752
|
+
}
|
|
753
|
+
else if (perms.includes("x") && !(node.mode & 73)) {
|
|
754
|
+
return 2;
|
|
755
|
+
} return 0; }, mayLookup(dir) { if (!FS.isDir(dir.mode))
|
|
756
|
+
return 54; var errCode = FS.nodePermissions(dir, "x"); if (errCode)
|
|
757
|
+
return errCode; if (!dir.node_ops.lookup)
|
|
758
|
+
return 2; return 0; }, mayCreate(dir, name) { if (!FS.isDir(dir.mode)) {
|
|
759
|
+
return 54;
|
|
760
|
+
} try {
|
|
761
|
+
var node = FS.lookupNode(dir, name);
|
|
762
|
+
return 20;
|
|
763
|
+
}
|
|
764
|
+
catch (e) { } return FS.nodePermissions(dir, "wx"); }, mayDelete(dir, name, isdir) { var node; try {
|
|
765
|
+
node = FS.lookupNode(dir, name);
|
|
766
|
+
}
|
|
767
|
+
catch (e) {
|
|
768
|
+
return e.errno;
|
|
769
|
+
} var errCode = FS.nodePermissions(dir, "wx"); if (errCode) {
|
|
770
|
+
return errCode;
|
|
771
|
+
} if (isdir) {
|
|
772
|
+
if (!FS.isDir(node.mode)) {
|
|
773
|
+
return 54;
|
|
774
|
+
}
|
|
775
|
+
if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
|
|
776
|
+
return 10;
|
|
777
|
+
}
|
|
778
|
+
}
|
|
779
|
+
else {
|
|
780
|
+
if (FS.isDir(node.mode)) {
|
|
781
|
+
return 31;
|
|
782
|
+
}
|
|
783
|
+
} return 0; }, mayOpen(node, flags) { if (!node) {
|
|
784
|
+
return 44;
|
|
785
|
+
} if (FS.isLink(node.mode)) {
|
|
786
|
+
return 32;
|
|
787
|
+
}
|
|
788
|
+
else if (FS.isDir(node.mode)) {
|
|
789
|
+
if (FS.flagsToPermissionString(flags) !== "r" || flags & (512 | 64)) {
|
|
790
|
+
return 31;
|
|
791
|
+
}
|
|
792
|
+
} return FS.nodePermissions(node, FS.flagsToPermissionString(flags)); }, checkOpExists(op, err) { if (!op) {
|
|
793
|
+
throw new FS.ErrnoError(err);
|
|
794
|
+
} return op; }, MAX_OPEN_FDS: 4096, nextfd() { for (var fd = 0; fd <= FS.MAX_OPEN_FDS; fd++) {
|
|
795
|
+
if (!FS.streams[fd]) {
|
|
796
|
+
return fd;
|
|
797
|
+
}
|
|
798
|
+
} throw new FS.ErrnoError(33); }, getStreamChecked(fd) { var stream = FS.getStream(fd); if (!stream) {
|
|
799
|
+
throw new FS.ErrnoError(8);
|
|
800
|
+
} return stream; }, getStream: fd => FS.streams[fd], createStream(stream, fd = -1) { stream = Object.assign(new FS.FSStream, stream); if (fd == -1) {
|
|
801
|
+
fd = FS.nextfd();
|
|
802
|
+
} stream.fd = fd; FS.streams[fd] = stream; return stream; }, closeStream(fd) { FS.streams[fd] = null; }, dupStream(origStream, fd = -1) { var stream = FS.createStream(origStream, fd); stream.stream_ops?.dup?.(stream); return stream; }, doSetAttr(stream, node, attr) { var setattr = stream?.stream_ops.setattr; var arg = setattr ? stream : node; setattr ??= node.node_ops.setattr; FS.checkOpExists(setattr, 63); setattr(arg, attr); }, chrdev_stream_ops: { open(stream) { var device = FS.getDevice(stream.node.rdev); stream.stream_ops = device.stream_ops; stream.stream_ops.open?.(stream); }, llseek() { throw new FS.ErrnoError(70); } }, major: dev => dev >> 8, minor: dev => dev & 255, makedev: (ma, mi) => ma << 8 | mi, registerDevice(dev, ops) { FS.devices[dev] = { stream_ops: ops }; }, getDevice: dev => FS.devices[dev], getMounts(mount) { var mounts = []; var check = [mount]; while (check.length) {
|
|
803
|
+
var m = check.pop();
|
|
804
|
+
mounts.push(m);
|
|
805
|
+
check.push(...m.mounts);
|
|
806
|
+
} return mounts; }, syncfs(populate, callback) { if (typeof populate == "function") {
|
|
807
|
+
callback = populate;
|
|
808
|
+
populate = false;
|
|
809
|
+
} FS.syncFSRequests++; if (FS.syncFSRequests > 1) {
|
|
810
|
+
err(`warning: ${FS.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);
|
|
811
|
+
} var mounts = FS.getMounts(FS.root.mount); var completed = 0; function doCallback(errCode) { FS.syncFSRequests--; return callback(errCode); } function done(errCode) { if (errCode) {
|
|
812
|
+
if (!done.errored) {
|
|
813
|
+
done.errored = true;
|
|
814
|
+
return doCallback(errCode);
|
|
815
|
+
}
|
|
816
|
+
return;
|
|
817
|
+
} if (++completed >= mounts.length) {
|
|
818
|
+
doCallback(null);
|
|
819
|
+
} } mounts.forEach(mount => { if (!mount.type.syncfs) {
|
|
820
|
+
return done(null);
|
|
821
|
+
} mount.type.syncfs(mount, populate, done); }); }, mount(type, opts, mountpoint) { var root = mountpoint === "/"; var pseudo = !mountpoint; var node; if (root && FS.root) {
|
|
822
|
+
throw new FS.ErrnoError(10);
|
|
823
|
+
}
|
|
824
|
+
else if (!root && !pseudo) {
|
|
825
|
+
var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
|
|
826
|
+
mountpoint = lookup.path;
|
|
827
|
+
node = lookup.node;
|
|
828
|
+
if (FS.isMountpoint(node)) {
|
|
829
|
+
throw new FS.ErrnoError(10);
|
|
830
|
+
}
|
|
831
|
+
if (!FS.isDir(node.mode)) {
|
|
832
|
+
throw new FS.ErrnoError(54);
|
|
833
|
+
}
|
|
834
|
+
} var mount = { type, opts, mountpoint, mounts: [] }; var mountRoot = type.mount(mount); mountRoot.mount = mount; mount.root = mountRoot; if (root) {
|
|
835
|
+
FS.root = mountRoot;
|
|
836
|
+
}
|
|
837
|
+
else if (node) {
|
|
838
|
+
node.mounted = mount;
|
|
839
|
+
if (node.mount) {
|
|
840
|
+
node.mount.mounts.push(mount);
|
|
841
|
+
}
|
|
842
|
+
} return mountRoot; }, unmount(mountpoint) { var lookup = FS.lookupPath(mountpoint, { follow_mount: false }); if (!FS.isMountpoint(lookup.node)) {
|
|
843
|
+
throw new FS.ErrnoError(28);
|
|
844
|
+
} var node = lookup.node; var mount = node.mounted; var mounts = FS.getMounts(mount); Object.keys(FS.nameTable).forEach(hash => { var current = FS.nameTable[hash]; while (current) {
|
|
845
|
+
var next = current.name_next;
|
|
846
|
+
if (mounts.includes(current.mount)) {
|
|
847
|
+
FS.destroyNode(current);
|
|
848
|
+
}
|
|
849
|
+
current = next;
|
|
850
|
+
} }); node.mounted = null; var idx = node.mount.mounts.indexOf(mount); node.mount.mounts.splice(idx, 1); }, lookup(parent, name) { return parent.node_ops.lookup(parent, name); }, mknod(path, mode, dev) { var lookup = FS.lookupPath(path, { parent: true }); var parent = lookup.node; var name = PATH.basename(path); if (!name) {
|
|
851
|
+
throw new FS.ErrnoError(28);
|
|
852
|
+
} if (name === "." || name === "..") {
|
|
853
|
+
throw new FS.ErrnoError(20);
|
|
854
|
+
} var errCode = FS.mayCreate(parent, name); if (errCode) {
|
|
855
|
+
throw new FS.ErrnoError(errCode);
|
|
856
|
+
} if (!parent.node_ops.mknod) {
|
|
857
|
+
throw new FS.ErrnoError(63);
|
|
858
|
+
} return parent.node_ops.mknod(parent, name, mode, dev); }, statfs(path) { return FS.statfsNode(FS.lookupPath(path, { follow: true }).node); }, statfsStream(stream) { return FS.statfsNode(stream.node); }, statfsNode(node) { var rtn = { bsize: 4096, frsize: 4096, blocks: 1e6, bfree: 5e5, bavail: 5e5, files: FS.nextInode, ffree: FS.nextInode - 1, fsid: 42, flags: 2, namelen: 255 }; if (node.node_ops.statfs) {
|
|
859
|
+
Object.assign(rtn, node.node_ops.statfs(node.mount.opts.root));
|
|
860
|
+
} return rtn; }, create(path, mode = 438) { mode &= 4095; mode |= 32768; return FS.mknod(path, mode, 0); }, mkdir(path, mode = 511) { mode &= 511 | 512; mode |= 16384; return FS.mknod(path, mode, 0); }, mkdirTree(path, mode) { var dirs = path.split("/"); var d = ""; for (var i = 0; i < dirs.length; ++i) {
|
|
861
|
+
if (!dirs[i])
|
|
862
|
+
continue;
|
|
863
|
+
d += "/" + dirs[i];
|
|
864
|
+
try {
|
|
865
|
+
FS.mkdir(d, mode);
|
|
866
|
+
}
|
|
867
|
+
catch (e) {
|
|
868
|
+
if (e.errno != 20)
|
|
869
|
+
throw e;
|
|
870
|
+
}
|
|
871
|
+
} }, mkdev(path, mode, dev) { if (typeof dev == "undefined") {
|
|
872
|
+
dev = mode;
|
|
873
|
+
mode = 438;
|
|
874
|
+
} mode |= 8192; return FS.mknod(path, mode, dev); }, symlink(oldpath, newpath) { if (!PATH_FS.resolve(oldpath)) {
|
|
875
|
+
throw new FS.ErrnoError(44);
|
|
876
|
+
} var lookup = FS.lookupPath(newpath, { parent: true }); var parent = lookup.node; if (!parent) {
|
|
877
|
+
throw new FS.ErrnoError(44);
|
|
878
|
+
} var newname = PATH.basename(newpath); var errCode = FS.mayCreate(parent, newname); if (errCode) {
|
|
879
|
+
throw new FS.ErrnoError(errCode);
|
|
880
|
+
} if (!parent.node_ops.symlink) {
|
|
881
|
+
throw new FS.ErrnoError(63);
|
|
882
|
+
} return parent.node_ops.symlink(parent, newname, oldpath); }, rename(old_path, new_path) { var old_dirname = PATH.dirname(old_path); var new_dirname = PATH.dirname(new_path); var old_name = PATH.basename(old_path); var new_name = PATH.basename(new_path); var lookup, old_dir, new_dir; lookup = FS.lookupPath(old_path, { parent: true }); old_dir = lookup.node; lookup = FS.lookupPath(new_path, { parent: true }); new_dir = lookup.node; if (!old_dir || !new_dir)
|
|
883
|
+
throw new FS.ErrnoError(44); if (old_dir.mount !== new_dir.mount) {
|
|
884
|
+
throw new FS.ErrnoError(75);
|
|
885
|
+
} var old_node = FS.lookupNode(old_dir, old_name); var relative = PATH_FS.relative(old_path, new_dirname); if (relative.charAt(0) !== ".") {
|
|
886
|
+
throw new FS.ErrnoError(28);
|
|
887
|
+
} relative = PATH_FS.relative(new_path, old_dirname); if (relative.charAt(0) !== ".") {
|
|
888
|
+
throw new FS.ErrnoError(55);
|
|
889
|
+
} var new_node; try {
|
|
890
|
+
new_node = FS.lookupNode(new_dir, new_name);
|
|
891
|
+
}
|
|
892
|
+
catch (e) { } if (old_node === new_node) {
|
|
893
|
+
return;
|
|
894
|
+
} var isdir = FS.isDir(old_node.mode); var errCode = FS.mayDelete(old_dir, old_name, isdir); if (errCode) {
|
|
895
|
+
throw new FS.ErrnoError(errCode);
|
|
896
|
+
} errCode = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name); if (errCode) {
|
|
897
|
+
throw new FS.ErrnoError(errCode);
|
|
898
|
+
} if (!old_dir.node_ops.rename) {
|
|
899
|
+
throw new FS.ErrnoError(63);
|
|
900
|
+
} if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
|
|
901
|
+
throw new FS.ErrnoError(10);
|
|
902
|
+
} if (new_dir !== old_dir) {
|
|
903
|
+
errCode = FS.nodePermissions(old_dir, "w");
|
|
904
|
+
if (errCode) {
|
|
905
|
+
throw new FS.ErrnoError(errCode);
|
|
906
|
+
}
|
|
907
|
+
} FS.hashRemoveNode(old_node); try {
|
|
908
|
+
old_dir.node_ops.rename(old_node, new_dir, new_name);
|
|
909
|
+
old_node.parent = new_dir;
|
|
910
|
+
}
|
|
911
|
+
catch (e) {
|
|
912
|
+
throw e;
|
|
913
|
+
}
|
|
914
|
+
finally {
|
|
915
|
+
FS.hashAddNode(old_node);
|
|
916
|
+
} }, rmdir(path) { var lookup = FS.lookupPath(path, { parent: true }); var parent = lookup.node; var name = PATH.basename(path); var node = FS.lookupNode(parent, name); var errCode = FS.mayDelete(parent, name, true); if (errCode) {
|
|
917
|
+
throw new FS.ErrnoError(errCode);
|
|
918
|
+
} if (!parent.node_ops.rmdir) {
|
|
919
|
+
throw new FS.ErrnoError(63);
|
|
920
|
+
} if (FS.isMountpoint(node)) {
|
|
921
|
+
throw new FS.ErrnoError(10);
|
|
922
|
+
} parent.node_ops.rmdir(parent, name); FS.destroyNode(node); }, readdir(path) { var lookup = FS.lookupPath(path, { follow: true }); var node = lookup.node; var readdir = FS.checkOpExists(node.node_ops.readdir, 54); return readdir(node); }, unlink(path) { var lookup = FS.lookupPath(path, { parent: true }); var parent = lookup.node; if (!parent) {
|
|
923
|
+
throw new FS.ErrnoError(44);
|
|
924
|
+
} var name = PATH.basename(path); var node = FS.lookupNode(parent, name); var errCode = FS.mayDelete(parent, name, false); if (errCode) {
|
|
925
|
+
throw new FS.ErrnoError(errCode);
|
|
926
|
+
} if (!parent.node_ops.unlink) {
|
|
927
|
+
throw new FS.ErrnoError(63);
|
|
928
|
+
} if (FS.isMountpoint(node)) {
|
|
929
|
+
throw new FS.ErrnoError(10);
|
|
930
|
+
} parent.node_ops.unlink(parent, name); FS.destroyNode(node); }, readlink(path) { var lookup = FS.lookupPath(path); var link = lookup.node; if (!link) {
|
|
931
|
+
throw new FS.ErrnoError(44);
|
|
932
|
+
} if (!link.node_ops.readlink) {
|
|
933
|
+
throw new FS.ErrnoError(28);
|
|
934
|
+
} return link.node_ops.readlink(link); }, stat(path, dontFollow) { var lookup = FS.lookupPath(path, { follow: !dontFollow }); var node = lookup.node; var getattr = FS.checkOpExists(node.node_ops.getattr, 63); return getattr(node); }, fstat(fd) { var stream = FS.getStreamChecked(fd); var node = stream.node; var getattr = stream.stream_ops.getattr; var arg = getattr ? stream : node; getattr ??= node.node_ops.getattr; FS.checkOpExists(getattr, 63); return getattr(arg); }, lstat(path) { return FS.stat(path, true); }, doChmod(stream, node, mode, dontFollow) { FS.doSetAttr(stream, node, { mode: mode & 4095 | node.mode & ~4095, ctime: Date.now(), dontFollow }); }, chmod(path, mode, dontFollow) { var node; if (typeof path == "string") {
|
|
935
|
+
var lookup = FS.lookupPath(path, { follow: !dontFollow });
|
|
936
|
+
node = lookup.node;
|
|
937
|
+
}
|
|
938
|
+
else {
|
|
939
|
+
node = path;
|
|
940
|
+
} FS.doChmod(null, node, mode, dontFollow); }, lchmod(path, mode) { FS.chmod(path, mode, true); }, fchmod(fd, mode) { var stream = FS.getStreamChecked(fd); FS.doChmod(stream, stream.node, mode, false); }, doChown(stream, node, dontFollow) { FS.doSetAttr(stream, node, { timestamp: Date.now(), dontFollow }); }, chown(path, uid, gid, dontFollow) { var node; if (typeof path == "string") {
|
|
941
|
+
var lookup = FS.lookupPath(path, { follow: !dontFollow });
|
|
942
|
+
node = lookup.node;
|
|
943
|
+
}
|
|
944
|
+
else {
|
|
945
|
+
node = path;
|
|
946
|
+
} FS.doChown(null, node, dontFollow); }, lchown(path, uid, gid) { FS.chown(path, uid, gid, true); }, fchown(fd, uid, gid) { var stream = FS.getStreamChecked(fd); FS.doChown(stream, stream.node, false); }, doTruncate(stream, node, len) { if (FS.isDir(node.mode)) {
|
|
947
|
+
throw new FS.ErrnoError(31);
|
|
948
|
+
} if (!FS.isFile(node.mode)) {
|
|
949
|
+
throw new FS.ErrnoError(28);
|
|
950
|
+
} var errCode = FS.nodePermissions(node, "w"); if (errCode) {
|
|
951
|
+
throw new FS.ErrnoError(errCode);
|
|
952
|
+
} FS.doSetAttr(stream, node, { size: len, timestamp: Date.now() }); }, truncate(path, len) { if (len < 0) {
|
|
953
|
+
throw new FS.ErrnoError(28);
|
|
954
|
+
} var node; if (typeof path == "string") {
|
|
955
|
+
var lookup = FS.lookupPath(path, { follow: true });
|
|
956
|
+
node = lookup.node;
|
|
957
|
+
}
|
|
958
|
+
else {
|
|
959
|
+
node = path;
|
|
960
|
+
} FS.doTruncate(null, node, len); }, ftruncate(fd, len) { var stream = FS.getStreamChecked(fd); if (len < 0 || (stream.flags & 2097155) === 0) {
|
|
961
|
+
throw new FS.ErrnoError(28);
|
|
962
|
+
} FS.doTruncate(stream, stream.node, len); }, utime(path, atime, mtime) { var lookup = FS.lookupPath(path, { follow: true }); var node = lookup.node; var setattr = FS.checkOpExists(node.node_ops.setattr, 63); setattr(node, { atime, mtime }); }, open(path, flags, mode = 438) { if (path === "") {
|
|
963
|
+
throw new FS.ErrnoError(44);
|
|
964
|
+
} flags = typeof flags == "string" ? FS_modeStringToFlags(flags) : flags; if (flags & 64) {
|
|
965
|
+
mode = mode & 4095 | 32768;
|
|
966
|
+
}
|
|
967
|
+
else {
|
|
968
|
+
mode = 0;
|
|
969
|
+
} var node; var isDirPath; if (typeof path == "object") {
|
|
970
|
+
node = path;
|
|
971
|
+
}
|
|
972
|
+
else {
|
|
973
|
+
isDirPath = path.endsWith("/");
|
|
974
|
+
var lookup = FS.lookupPath(path, { follow: !(flags & 131072), noent_okay: true });
|
|
975
|
+
node = lookup.node;
|
|
976
|
+
path = lookup.path;
|
|
977
|
+
} var created = false; if (flags & 64) {
|
|
978
|
+
if (node) {
|
|
979
|
+
if (flags & 128) {
|
|
980
|
+
throw new FS.ErrnoError(20);
|
|
981
|
+
}
|
|
982
|
+
}
|
|
983
|
+
else if (isDirPath) {
|
|
984
|
+
throw new FS.ErrnoError(31);
|
|
985
|
+
}
|
|
986
|
+
else {
|
|
987
|
+
node = FS.mknod(path, mode | 511, 0);
|
|
988
|
+
created = true;
|
|
989
|
+
}
|
|
990
|
+
} if (!node) {
|
|
991
|
+
throw new FS.ErrnoError(44);
|
|
992
|
+
} if (FS.isChrdev(node.mode)) {
|
|
993
|
+
flags &= ~512;
|
|
994
|
+
} if (flags & 65536 && !FS.isDir(node.mode)) {
|
|
995
|
+
throw new FS.ErrnoError(54);
|
|
996
|
+
} if (!created) {
|
|
997
|
+
var errCode = FS.mayOpen(node, flags);
|
|
998
|
+
if (errCode) {
|
|
999
|
+
throw new FS.ErrnoError(errCode);
|
|
1000
|
+
}
|
|
1001
|
+
} if (flags & 512 && !created) {
|
|
1002
|
+
FS.truncate(node, 0);
|
|
1003
|
+
} flags &= ~(128 | 512 | 131072); var stream = FS.createStream({ node, path: FS.getPath(node), flags, seekable: true, position: 0, stream_ops: node.stream_ops, ungotten: [], error: false }); if (stream.stream_ops.open) {
|
|
1004
|
+
stream.stream_ops.open(stream);
|
|
1005
|
+
} if (created) {
|
|
1006
|
+
FS.chmod(node, mode & 511);
|
|
1007
|
+
} if (Module["logReadFiles"] && !(flags & 1)) {
|
|
1008
|
+
if (!(path in FS.readFiles)) {
|
|
1009
|
+
FS.readFiles[path] = 1;
|
|
1010
|
+
}
|
|
1011
|
+
} return stream; }, close(stream) { if (FS.isClosed(stream)) {
|
|
1012
|
+
throw new FS.ErrnoError(8);
|
|
1013
|
+
} if (stream.getdents)
|
|
1014
|
+
stream.getdents = null; try {
|
|
1015
|
+
if (stream.stream_ops.close) {
|
|
1016
|
+
stream.stream_ops.close(stream);
|
|
1017
|
+
}
|
|
1018
|
+
}
|
|
1019
|
+
catch (e) {
|
|
1020
|
+
throw e;
|
|
1021
|
+
}
|
|
1022
|
+
finally {
|
|
1023
|
+
FS.closeStream(stream.fd);
|
|
1024
|
+
} stream.fd = null; }, isClosed(stream) { return stream.fd === null; }, llseek(stream, offset, whence) { if (FS.isClosed(stream)) {
|
|
1025
|
+
throw new FS.ErrnoError(8);
|
|
1026
|
+
} if (!stream.seekable || !stream.stream_ops.llseek) {
|
|
1027
|
+
throw new FS.ErrnoError(70);
|
|
1028
|
+
} if (whence != 0 && whence != 1 && whence != 2) {
|
|
1029
|
+
throw new FS.ErrnoError(28);
|
|
1030
|
+
} stream.position = stream.stream_ops.llseek(stream, offset, whence); stream.ungotten = []; return stream.position; }, read(stream, buffer, offset, length, position) { if (length < 0 || position < 0) {
|
|
1031
|
+
throw new FS.ErrnoError(28);
|
|
1032
|
+
} if (FS.isClosed(stream)) {
|
|
1033
|
+
throw new FS.ErrnoError(8);
|
|
1034
|
+
} if ((stream.flags & 2097155) === 1) {
|
|
1035
|
+
throw new FS.ErrnoError(8);
|
|
1036
|
+
} if (FS.isDir(stream.node.mode)) {
|
|
1037
|
+
throw new FS.ErrnoError(31);
|
|
1038
|
+
} if (!stream.stream_ops.read) {
|
|
1039
|
+
throw new FS.ErrnoError(28);
|
|
1040
|
+
} var seeking = typeof position != "undefined"; if (!seeking) {
|
|
1041
|
+
position = stream.position;
|
|
1042
|
+
}
|
|
1043
|
+
else if (!stream.seekable) {
|
|
1044
|
+
throw new FS.ErrnoError(70);
|
|
1045
|
+
} var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position); if (!seeking)
|
|
1046
|
+
stream.position += bytesRead; return bytesRead; }, write(stream, buffer, offset, length, position, canOwn) { if (length < 0 || position < 0) {
|
|
1047
|
+
throw new FS.ErrnoError(28);
|
|
1048
|
+
} if (FS.isClosed(stream)) {
|
|
1049
|
+
throw new FS.ErrnoError(8);
|
|
1050
|
+
} if ((stream.flags & 2097155) === 0) {
|
|
1051
|
+
throw new FS.ErrnoError(8);
|
|
1052
|
+
} if (FS.isDir(stream.node.mode)) {
|
|
1053
|
+
throw new FS.ErrnoError(31);
|
|
1054
|
+
} if (!stream.stream_ops.write) {
|
|
1055
|
+
throw new FS.ErrnoError(28);
|
|
1056
|
+
} if (stream.seekable && stream.flags & 1024) {
|
|
1057
|
+
FS.llseek(stream, 0, 2);
|
|
1058
|
+
} var seeking = typeof position != "undefined"; if (!seeking) {
|
|
1059
|
+
position = stream.position;
|
|
1060
|
+
}
|
|
1061
|
+
else if (!stream.seekable) {
|
|
1062
|
+
throw new FS.ErrnoError(70);
|
|
1063
|
+
} var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn); if (!seeking)
|
|
1064
|
+
stream.position += bytesWritten; return bytesWritten; }, allocate(stream, offset, length) { if (FS.isClosed(stream)) {
|
|
1065
|
+
throw new FS.ErrnoError(8);
|
|
1066
|
+
} if (offset < 0 || length <= 0) {
|
|
1067
|
+
throw new FS.ErrnoError(28);
|
|
1068
|
+
} if ((stream.flags & 2097155) === 0) {
|
|
1069
|
+
throw new FS.ErrnoError(8);
|
|
1070
|
+
} if (!FS.isFile(stream.node.mode) && !FS.isDir(stream.node.mode)) {
|
|
1071
|
+
throw new FS.ErrnoError(43);
|
|
1072
|
+
} if (!stream.stream_ops.allocate) {
|
|
1073
|
+
throw new FS.ErrnoError(138);
|
|
1074
|
+
} stream.stream_ops.allocate(stream, offset, length); }, mmap(stream, length, position, prot, flags) { if ((prot & 2) !== 0 && (flags & 2) === 0 && (stream.flags & 2097155) !== 2) {
|
|
1075
|
+
throw new FS.ErrnoError(2);
|
|
1076
|
+
} if ((stream.flags & 2097155) === 1) {
|
|
1077
|
+
throw new FS.ErrnoError(2);
|
|
1078
|
+
} if (!stream.stream_ops.mmap) {
|
|
1079
|
+
throw new FS.ErrnoError(43);
|
|
1080
|
+
} if (!length) {
|
|
1081
|
+
throw new FS.ErrnoError(28);
|
|
1082
|
+
} return stream.stream_ops.mmap(stream, length, position, prot, flags); }, msync(stream, buffer, offset, length, mmapFlags) { if (!stream.stream_ops.msync) {
|
|
1083
|
+
return 0;
|
|
1084
|
+
} return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags); }, ioctl(stream, cmd, arg) { if (!stream.stream_ops.ioctl) {
|
|
1085
|
+
throw new FS.ErrnoError(59);
|
|
1086
|
+
} return stream.stream_ops.ioctl(stream, cmd, arg); }, readFile(path, opts = {}) { opts.flags = opts.flags || 0; opts.encoding = opts.encoding || "binary"; if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
|
|
1087
|
+
throw new Error(`Invalid encoding type "${opts.encoding}"`);
|
|
1088
|
+
} var ret; var stream = FS.open(path, opts.flags); var stat = FS.stat(path); var length = stat.size; var buf = new Uint8Array(length); FS.read(stream, buf, 0, length, 0); if (opts.encoding === "utf8") {
|
|
1089
|
+
ret = UTF8ArrayToString(buf);
|
|
1090
|
+
}
|
|
1091
|
+
else if (opts.encoding === "binary") {
|
|
1092
|
+
ret = buf;
|
|
1093
|
+
} FS.close(stream); return ret; }, writeFile(path, data, opts = {}) { opts.flags = opts.flags || 577; var stream = FS.open(path, opts.flags, opts.mode); if (typeof data == "string") {
|
|
1094
|
+
var buf = new Uint8Array(lengthBytesUTF8(data) + 1);
|
|
1095
|
+
var actualNumBytes = stringToUTF8Array(data, buf, 0, buf.length);
|
|
1096
|
+
FS.write(stream, buf, 0, actualNumBytes, undefined, opts.canOwn);
|
|
1097
|
+
}
|
|
1098
|
+
else if (ArrayBuffer.isView(data)) {
|
|
1099
|
+
FS.write(stream, data, 0, data.byteLength, undefined, opts.canOwn);
|
|
1100
|
+
}
|
|
1101
|
+
else {
|
|
1102
|
+
throw new Error("Unsupported data type");
|
|
1103
|
+
} FS.close(stream); }, cwd: () => FS.currentPath, chdir(path) { var lookup = FS.lookupPath(path, { follow: true }); if (lookup.node === null) {
|
|
1104
|
+
throw new FS.ErrnoError(44);
|
|
1105
|
+
} if (!FS.isDir(lookup.node.mode)) {
|
|
1106
|
+
throw new FS.ErrnoError(54);
|
|
1107
|
+
} var errCode = FS.nodePermissions(lookup.node, "x"); if (errCode) {
|
|
1108
|
+
throw new FS.ErrnoError(errCode);
|
|
1109
|
+
} FS.currentPath = lookup.path; }, createDefaultDirectories() { FS.mkdir("/tmp"); FS.mkdir("/home"); FS.mkdir("/home/web_user"); }, createDefaultDevices() { FS.mkdir("/dev"); FS.registerDevice(FS.makedev(1, 3), { read: () => 0, write: (stream, buffer, offset, length, pos) => length, llseek: () => 0 }); FS.mkdev("/dev/null", FS.makedev(1, 3)); TTY.register(FS.makedev(5, 0), TTY.default_tty_ops); TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops); FS.mkdev("/dev/tty", FS.makedev(5, 0)); FS.mkdev("/dev/tty1", FS.makedev(6, 0)); var randomBuffer = new Uint8Array(1024), randomLeft = 0; var randomByte = () => { if (randomLeft === 0) {
|
|
1110
|
+
randomFill(randomBuffer);
|
|
1111
|
+
randomLeft = randomBuffer.byteLength;
|
|
1112
|
+
} return randomBuffer[--randomLeft]; }; FS.createDevice("/dev", "random", randomByte); FS.createDevice("/dev", "urandom", randomByte); FS.mkdir("/dev/shm"); FS.mkdir("/dev/shm/tmp"); }, createSpecialDirectories() { FS.mkdir("/proc"); var proc_self = FS.mkdir("/proc/self"); FS.mkdir("/proc/self/fd"); FS.mount({ mount() { var node = FS.createNode(proc_self, "fd", 16895, 73); node.stream_ops = { llseek: MEMFS.stream_ops.llseek }; node.node_ops = { lookup(parent, name) { var fd = +name; var stream = FS.getStreamChecked(fd); var ret = { parent: null, mount: { mountpoint: "fake" }, node_ops: { readlink: () => stream.path }, id: fd + 1 }; ret.parent = ret; return ret; }, readdir() { return Array.from(FS.streams.entries()).filter(([k, v]) => v).map(([k, v]) => k.toString()); } }; return node; } }, {}, "/proc/self/fd"); }, createStandardStreams(input, output, error) { if (input) {
|
|
1113
|
+
FS.createDevice("/dev", "stdin", input);
|
|
1114
|
+
}
|
|
1115
|
+
else {
|
|
1116
|
+
FS.symlink("/dev/tty", "/dev/stdin");
|
|
1117
|
+
} if (output) {
|
|
1118
|
+
FS.createDevice("/dev", "stdout", null, output);
|
|
1119
|
+
}
|
|
1120
|
+
else {
|
|
1121
|
+
FS.symlink("/dev/tty", "/dev/stdout");
|
|
1122
|
+
} if (error) {
|
|
1123
|
+
FS.createDevice("/dev", "stderr", null, error);
|
|
1124
|
+
}
|
|
1125
|
+
else {
|
|
1126
|
+
FS.symlink("/dev/tty1", "/dev/stderr");
|
|
1127
|
+
} var stdin = FS.open("/dev/stdin", 0); var stdout = FS.open("/dev/stdout", 1); var stderr = FS.open("/dev/stderr", 1); }, staticInit() { FS.nameTable = new Array(4096); FS.mount(MEMFS, {}, "/"); FS.createDefaultDirectories(); FS.createDefaultDevices(); FS.createSpecialDirectories(); FS.filesystems = { MEMFS }; }, init(input, output, error) { FS.initialized = true; input ??= Module["stdin"]; output ??= Module["stdout"]; error ??= Module["stderr"]; FS.createStandardStreams(input, output, error); }, quit() { FS.initialized = false; for (var i = 0; i < FS.streams.length; i++) {
|
|
1128
|
+
var stream = FS.streams[i];
|
|
1129
|
+
if (!stream) {
|
|
1130
|
+
continue;
|
|
1131
|
+
}
|
|
1132
|
+
FS.close(stream);
|
|
1133
|
+
} }, findObject(path, dontResolveLastLink) { var ret = FS.analyzePath(path, dontResolveLastLink); if (!ret.exists) {
|
|
1134
|
+
return null;
|
|
1135
|
+
} return ret.object; }, analyzePath(path, dontResolveLastLink) { try {
|
|
1136
|
+
var lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
|
|
1137
|
+
path = lookup.path;
|
|
1138
|
+
}
|
|
1139
|
+
catch (e) { } var ret = { isRoot: false, exists: false, error: 0, name: null, path: null, object: null, parentExists: false, parentPath: null, parentObject: null }; try {
|
|
1140
|
+
var lookup = FS.lookupPath(path, { parent: true });
|
|
1141
|
+
ret.parentExists = true;
|
|
1142
|
+
ret.parentPath = lookup.path;
|
|
1143
|
+
ret.parentObject = lookup.node;
|
|
1144
|
+
ret.name = PATH.basename(path);
|
|
1145
|
+
lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
|
|
1146
|
+
ret.exists = true;
|
|
1147
|
+
ret.path = lookup.path;
|
|
1148
|
+
ret.object = lookup.node;
|
|
1149
|
+
ret.name = lookup.node.name;
|
|
1150
|
+
ret.isRoot = lookup.path === "/";
|
|
1151
|
+
}
|
|
1152
|
+
catch (e) {
|
|
1153
|
+
ret.error = e.errno;
|
|
1154
|
+
} return ret; }, createPath(parent, path, canRead, canWrite) { parent = typeof parent == "string" ? parent : FS.getPath(parent); var parts = path.split("/").reverse(); while (parts.length) {
|
|
1155
|
+
var part = parts.pop();
|
|
1156
|
+
if (!part)
|
|
1157
|
+
continue;
|
|
1158
|
+
var current = PATH.join2(parent, part);
|
|
1159
|
+
try {
|
|
1160
|
+
FS.mkdir(current);
|
|
1161
|
+
}
|
|
1162
|
+
catch (e) { }
|
|
1163
|
+
parent = current;
|
|
1164
|
+
} return current; }, createFile(parent, name, properties, canRead, canWrite) { var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name); var mode = FS_getMode(canRead, canWrite); return FS.create(path, mode); }, createDataFile(parent, name, data, canRead, canWrite, canOwn) { var path = name; if (parent) {
|
|
1165
|
+
parent = typeof parent == "string" ? parent : FS.getPath(parent);
|
|
1166
|
+
path = name ? PATH.join2(parent, name) : parent;
|
|
1167
|
+
} var mode = FS_getMode(canRead, canWrite); var node = FS.create(path, mode); if (data) {
|
|
1168
|
+
if (typeof data == "string") {
|
|
1169
|
+
var arr = new Array(data.length);
|
|
1170
|
+
for (var i = 0, len = data.length; i < len; ++i)
|
|
1171
|
+
arr[i] = data.charCodeAt(i);
|
|
1172
|
+
data = arr;
|
|
1173
|
+
}
|
|
1174
|
+
FS.chmod(node, mode | 146);
|
|
1175
|
+
var stream = FS.open(node, 577);
|
|
1176
|
+
FS.write(stream, data, 0, data.length, 0, canOwn);
|
|
1177
|
+
FS.close(stream);
|
|
1178
|
+
FS.chmod(node, mode);
|
|
1179
|
+
} }, createDevice(parent, name, input, output) { var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name); var mode = FS_getMode(!!input, !!output); FS.createDevice.major ??= 64; var dev = FS.makedev(FS.createDevice.major++, 0); FS.registerDevice(dev, { open(stream) { stream.seekable = false; }, close(stream) { if (output?.buffer?.length) {
|
|
1180
|
+
output(10);
|
|
1181
|
+
} }, read(stream, buffer, offset, length, pos) { var bytesRead = 0; for (var i = 0; i < length; i++) {
|
|
1182
|
+
var result;
|
|
1183
|
+
try {
|
|
1184
|
+
result = input();
|
|
1185
|
+
}
|
|
1186
|
+
catch (e) {
|
|
1187
|
+
throw new FS.ErrnoError(29);
|
|
1188
|
+
}
|
|
1189
|
+
if (result === undefined && bytesRead === 0) {
|
|
1190
|
+
throw new FS.ErrnoError(6);
|
|
1191
|
+
}
|
|
1192
|
+
if (result === null || result === undefined)
|
|
1193
|
+
break;
|
|
1194
|
+
bytesRead++;
|
|
1195
|
+
buffer[offset + i] = result;
|
|
1196
|
+
} if (bytesRead) {
|
|
1197
|
+
stream.node.atime = Date.now();
|
|
1198
|
+
} return bytesRead; }, write(stream, buffer, offset, length, pos) { for (var i = 0; i < length; i++) {
|
|
1199
|
+
try {
|
|
1200
|
+
output(buffer[offset + i]);
|
|
1201
|
+
}
|
|
1202
|
+
catch (e) {
|
|
1203
|
+
throw new FS.ErrnoError(29);
|
|
1204
|
+
}
|
|
1205
|
+
} if (length) {
|
|
1206
|
+
stream.node.mtime = stream.node.ctime = Date.now();
|
|
1207
|
+
} return i; } }); return FS.mkdev(path, mode, dev); }, forceLoadFile(obj) { if (obj.isDevice || obj.isFolder || obj.link || obj.contents)
|
|
1208
|
+
return true; if (typeof XMLHttpRequest != "undefined") {
|
|
1209
|
+
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.");
|
|
1210
|
+
}
|
|
1211
|
+
else {
|
|
1212
|
+
try {
|
|
1213
|
+
obj.contents = readBinary(obj.url);
|
|
1214
|
+
obj.usedBytes = obj.contents.length;
|
|
1215
|
+
}
|
|
1216
|
+
catch (e) {
|
|
1217
|
+
throw new FS.ErrnoError(29);
|
|
1218
|
+
}
|
|
1219
|
+
} }, createLazyFile(parent, name, url, canRead, canWrite) { class LazyUint8Array {
|
|
1220
|
+
lengthKnown = false;
|
|
1221
|
+
chunks = [];
|
|
1222
|
+
get(idx) { if (idx > this.length - 1 || idx < 0) {
|
|
1223
|
+
return undefined;
|
|
1224
|
+
} var chunkOffset = idx % this.chunkSize; var chunkNum = idx / this.chunkSize | 0; return this.getter(chunkNum)[chunkOffset]; }
|
|
1225
|
+
setDataGetter(getter) { this.getter = getter; }
|
|
1226
|
+
cacheLength() { var xhr = new XMLHttpRequest; xhr.open("HEAD", url, false); xhr.send(null); if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304))
|
|
1227
|
+
throw new Error("Couldn't load " + url + ". Status: " + xhr.status); var datalength = Number(xhr.getResponseHeader("Content-length")); var header; var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes"; var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip"; var chunkSize = 1024 * 1024; if (!hasByteServing)
|
|
1228
|
+
chunkSize = datalength; var doXHR = (from, to) => { if (from > to)
|
|
1229
|
+
throw new Error("invalid range (" + from + ", " + to + ") or no bytes requested!"); if (to > datalength - 1)
|
|
1230
|
+
throw new Error("only " + datalength + " bytes available! programmer error!"); var xhr = new XMLHttpRequest; xhr.open("GET", url, false); if (datalength !== chunkSize)
|
|
1231
|
+
xhr.setRequestHeader("Range", "bytes=" + from + "-" + to); xhr.responseType = "arraybuffer"; if (xhr.overrideMimeType) {
|
|
1232
|
+
xhr.overrideMimeType("text/plain; charset=x-user-defined");
|
|
1233
|
+
} xhr.send(null); if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304))
|
|
1234
|
+
throw new Error("Couldn't load " + url + ". Status: " + xhr.status); if (xhr.response !== undefined) {
|
|
1235
|
+
return new Uint8Array(xhr.response || []);
|
|
1236
|
+
} return intArrayFromString(xhr.responseText || "", true); }; var lazyArray = this; lazyArray.setDataGetter(chunkNum => { var start = chunkNum * chunkSize; var end = (chunkNum + 1) * chunkSize - 1; end = Math.min(end, datalength - 1); if (typeof lazyArray.chunks[chunkNum] == "undefined") {
|
|
1237
|
+
lazyArray.chunks[chunkNum] = doXHR(start, end);
|
|
1238
|
+
} if (typeof lazyArray.chunks[chunkNum] == "undefined")
|
|
1239
|
+
throw new Error("doXHR failed!"); return lazyArray.chunks[chunkNum]; }); if (usesGzip || !datalength) {
|
|
1240
|
+
chunkSize = datalength = 1;
|
|
1241
|
+
datalength = this.getter(0).length;
|
|
1242
|
+
chunkSize = datalength;
|
|
1243
|
+
out("LazyFiles on gzip forces download of the whole file when length is accessed");
|
|
1244
|
+
} this._length = datalength; this._chunkSize = chunkSize; this.lengthKnown = true; }
|
|
1245
|
+
get length() { if (!this.lengthKnown) {
|
|
1246
|
+
this.cacheLength();
|
|
1247
|
+
} return this._length; }
|
|
1248
|
+
get chunkSize() { if (!this.lengthKnown) {
|
|
1249
|
+
this.cacheLength();
|
|
1250
|
+
} return this._chunkSize; }
|
|
1251
|
+
} if (typeof XMLHttpRequest != "undefined") {
|
|
1252
|
+
if (!ENVIRONMENT_IS_WORKER)
|
|
1253
|
+
throw "Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";
|
|
1254
|
+
var lazyArray = new LazyUint8Array;
|
|
1255
|
+
var properties = { isDevice: false, contents: lazyArray };
|
|
1256
|
+
}
|
|
1257
|
+
else {
|
|
1258
|
+
var properties = { isDevice: false, url };
|
|
1259
|
+
} var node = FS.createFile(parent, name, properties, canRead, canWrite); if (properties.contents) {
|
|
1260
|
+
node.contents = properties.contents;
|
|
1261
|
+
}
|
|
1262
|
+
else if (properties.url) {
|
|
1263
|
+
node.contents = null;
|
|
1264
|
+
node.url = properties.url;
|
|
1265
|
+
} Object.defineProperties(node, { usedBytes: { get: function () { return this.contents.length; } } }); var stream_ops = {}; var keys = Object.keys(node.stream_ops); keys.forEach(key => { var fn = node.stream_ops[key]; stream_ops[key] = (...args) => { FS.forceLoadFile(node); return fn(...args); }; }); function writeChunks(stream, buffer, offset, length, position) { var contents = stream.node.contents; if (position >= contents.length)
|
|
1266
|
+
return 0; var size = Math.min(contents.length - position, length); if (contents.slice) {
|
|
1267
|
+
for (var i = 0; i < size; i++) {
|
|
1268
|
+
buffer[offset + i] = contents[position + i];
|
|
1269
|
+
}
|
|
1270
|
+
}
|
|
1271
|
+
else {
|
|
1272
|
+
for (var i = 0; i < size; i++) {
|
|
1273
|
+
buffer[offset + i] = contents.get(position + i);
|
|
1274
|
+
}
|
|
1275
|
+
} return size; } stream_ops.read = (stream, buffer, offset, length, position) => { FS.forceLoadFile(node); return writeChunks(stream, buffer, offset, length, position); }; stream_ops.mmap = (stream, length, position, prot, flags) => { FS.forceLoadFile(node); var ptr = mmapAlloc(length); if (!ptr) {
|
|
1276
|
+
throw new FS.ErrnoError(48);
|
|
1277
|
+
} writeChunks(stream, HEAP8, ptr, length, position); return { ptr, allocated: true }; }; node.stream_ops = stream_ops; return node; } };
|
|
1278
|
+
var SYSCALLS = { DEFAULT_POLLMASK: 5, calculateAt(dirfd, path, allowEmpty) { if (PATH.isAbs(path)) {
|
|
1279
|
+
return path;
|
|
1280
|
+
} var dir; if (dirfd === -100) {
|
|
1281
|
+
dir = FS.cwd();
|
|
1282
|
+
}
|
|
1283
|
+
else {
|
|
1284
|
+
var dirstream = SYSCALLS.getStreamFromFD(dirfd);
|
|
1285
|
+
dir = dirstream.path;
|
|
1286
|
+
} if (path.length == 0) {
|
|
1287
|
+
if (!allowEmpty) {
|
|
1288
|
+
throw new FS.ErrnoError(44);
|
|
1289
|
+
}
|
|
1290
|
+
return dir;
|
|
1291
|
+
} return dir + "/" + path; }, writeStat(buf, stat) { HEAP32[buf >> 2] = stat.dev; HEAP32[buf + 4 >> 2] = stat.mode; HEAPU32[buf + 8 >> 2] = stat.nlink; HEAP32[buf + 12 >> 2] = stat.uid; HEAP32[buf + 16 >> 2] = stat.gid; HEAP32[buf + 20 >> 2] = stat.rdev; HEAP64[buf + 24 >> 3] = BigInt(stat.size); HEAP32[buf + 32 >> 2] = 4096; HEAP32[buf + 36 >> 2] = stat.blocks; var atime = stat.atime.getTime(); var mtime = stat.mtime.getTime(); var ctime = stat.ctime.getTime(); HEAP64[buf + 40 >> 3] = BigInt(Math.floor(atime / 1e3)); HEAPU32[buf + 48 >> 2] = atime % 1e3 * 1e3 * 1e3; HEAP64[buf + 56 >> 3] = BigInt(Math.floor(mtime / 1e3)); HEAPU32[buf + 64 >> 2] = mtime % 1e3 * 1e3 * 1e3; HEAP64[buf + 72 >> 3] = BigInt(Math.floor(ctime / 1e3)); HEAPU32[buf + 80 >> 2] = ctime % 1e3 * 1e3 * 1e3; HEAP64[buf + 88 >> 3] = BigInt(stat.ino); return 0; }, writeStatFs(buf, stats) { HEAP32[buf + 4 >> 2] = stats.bsize; HEAP32[buf + 40 >> 2] = stats.bsize; HEAP32[buf + 8 >> 2] = stats.blocks; HEAP32[buf + 12 >> 2] = stats.bfree; HEAP32[buf + 16 >> 2] = stats.bavail; HEAP32[buf + 20 >> 2] = stats.files; HEAP32[buf + 24 >> 2] = stats.ffree; HEAP32[buf + 28 >> 2] = stats.fsid; HEAP32[buf + 44 >> 2] = stats.flags; HEAP32[buf + 36 >> 2] = stats.namelen; }, doMsync(addr, stream, len, flags, offset) { if (!FS.isFile(stream.node.mode)) {
|
|
1292
|
+
throw new FS.ErrnoError(43);
|
|
1293
|
+
} if (flags & 2) {
|
|
1294
|
+
return 0;
|
|
1295
|
+
} var buffer = HEAPU8.slice(addr, addr + len); FS.msync(stream, buffer, offset, len, flags); }, getStreamFromFD(fd) { var stream = FS.getStreamChecked(fd); return stream; }, varargs: undefined, getStr(ptr) { var ret = UTF8ToString(ptr); return ret; } };
|
|
1296
|
+
function ___syscall_fcntl64(fd, cmd, varargs) { SYSCALLS.varargs = varargs; try {
|
|
1297
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
1298
|
+
switch (cmd) {
|
|
1299
|
+
case 0: {
|
|
1300
|
+
var arg = syscallGetVarargI();
|
|
1301
|
+
if (arg < 0) {
|
|
1302
|
+
return -28;
|
|
1303
|
+
}
|
|
1304
|
+
while (FS.streams[arg]) {
|
|
1305
|
+
arg++;
|
|
1306
|
+
}
|
|
1307
|
+
var newStream;
|
|
1308
|
+
newStream = FS.dupStream(stream, arg);
|
|
1309
|
+
return newStream.fd;
|
|
1310
|
+
}
|
|
1311
|
+
case 1:
|
|
1312
|
+
case 2: return 0;
|
|
1313
|
+
case 3: return stream.flags;
|
|
1314
|
+
case 4: {
|
|
1315
|
+
var arg = syscallGetVarargI();
|
|
1316
|
+
stream.flags |= arg;
|
|
1317
|
+
return 0;
|
|
1318
|
+
}
|
|
1319
|
+
case 12: {
|
|
1320
|
+
var arg = syscallGetVarargP();
|
|
1321
|
+
var offset = 0;
|
|
1322
|
+
HEAP16[arg + offset >> 1] = 2;
|
|
1323
|
+
return 0;
|
|
1324
|
+
}
|
|
1325
|
+
case 13:
|
|
1326
|
+
case 14: return 0;
|
|
1327
|
+
}
|
|
1328
|
+
return -28;
|
|
1329
|
+
}
|
|
1330
|
+
catch (e) {
|
|
1331
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1332
|
+
throw e;
|
|
1333
|
+
return -e.errno;
|
|
1334
|
+
} }
|
|
1335
|
+
function ___syscall_fstat64(fd, buf) { try {
|
|
1336
|
+
return SYSCALLS.writeStat(buf, FS.fstat(fd));
|
|
1337
|
+
}
|
|
1338
|
+
catch (e) {
|
|
1339
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1340
|
+
throw e;
|
|
1341
|
+
return -e.errno;
|
|
1342
|
+
} }
|
|
1343
|
+
function ___syscall_ioctl(fd, op, varargs) { SYSCALLS.varargs = varargs; try {
|
|
1344
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
1345
|
+
switch (op) {
|
|
1346
|
+
case 21509: {
|
|
1347
|
+
if (!stream.tty)
|
|
1348
|
+
return -59;
|
|
1349
|
+
return 0;
|
|
1350
|
+
}
|
|
1351
|
+
case 21505: {
|
|
1352
|
+
if (!stream.tty)
|
|
1353
|
+
return -59;
|
|
1354
|
+
if (stream.tty.ops.ioctl_tcgets) {
|
|
1355
|
+
var termios = stream.tty.ops.ioctl_tcgets(stream);
|
|
1356
|
+
var argp = syscallGetVarargP();
|
|
1357
|
+
HEAP32[argp >> 2] = termios.c_iflag || 0;
|
|
1358
|
+
HEAP32[argp + 4 >> 2] = termios.c_oflag || 0;
|
|
1359
|
+
HEAP32[argp + 8 >> 2] = termios.c_cflag || 0;
|
|
1360
|
+
HEAP32[argp + 12 >> 2] = termios.c_lflag || 0;
|
|
1361
|
+
for (var i = 0; i < 32; i++) {
|
|
1362
|
+
HEAP8[argp + i + 17] = termios.c_cc[i] || 0;
|
|
1363
|
+
}
|
|
1364
|
+
return 0;
|
|
1365
|
+
}
|
|
1366
|
+
return 0;
|
|
1367
|
+
}
|
|
1368
|
+
case 21510:
|
|
1369
|
+
case 21511:
|
|
1370
|
+
case 21512: {
|
|
1371
|
+
if (!stream.tty)
|
|
1372
|
+
return -59;
|
|
1373
|
+
return 0;
|
|
1374
|
+
}
|
|
1375
|
+
case 21506:
|
|
1376
|
+
case 21507:
|
|
1377
|
+
case 21508: {
|
|
1378
|
+
if (!stream.tty)
|
|
1379
|
+
return -59;
|
|
1380
|
+
if (stream.tty.ops.ioctl_tcsets) {
|
|
1381
|
+
var argp = syscallGetVarargP();
|
|
1382
|
+
var c_iflag = HEAP32[argp >> 2];
|
|
1383
|
+
var c_oflag = HEAP32[argp + 4 >> 2];
|
|
1384
|
+
var c_cflag = HEAP32[argp + 8 >> 2];
|
|
1385
|
+
var c_lflag = HEAP32[argp + 12 >> 2];
|
|
1386
|
+
var c_cc = [];
|
|
1387
|
+
for (var i = 0; i < 32; i++) {
|
|
1388
|
+
c_cc.push(HEAP8[argp + i + 17]);
|
|
1389
|
+
}
|
|
1390
|
+
return stream.tty.ops.ioctl_tcsets(stream.tty, op, { c_iflag, c_oflag, c_cflag, c_lflag, c_cc });
|
|
1391
|
+
}
|
|
1392
|
+
return 0;
|
|
1393
|
+
}
|
|
1394
|
+
case 21519: {
|
|
1395
|
+
if (!stream.tty)
|
|
1396
|
+
return -59;
|
|
1397
|
+
var argp = syscallGetVarargP();
|
|
1398
|
+
HEAP32[argp >> 2] = 0;
|
|
1399
|
+
return 0;
|
|
1400
|
+
}
|
|
1401
|
+
case 21520: {
|
|
1402
|
+
if (!stream.tty)
|
|
1403
|
+
return -59;
|
|
1404
|
+
return -28;
|
|
1405
|
+
}
|
|
1406
|
+
case 21531: {
|
|
1407
|
+
var argp = syscallGetVarargP();
|
|
1408
|
+
return FS.ioctl(stream, op, argp);
|
|
1409
|
+
}
|
|
1410
|
+
case 21523: {
|
|
1411
|
+
if (!stream.tty)
|
|
1412
|
+
return -59;
|
|
1413
|
+
if (stream.tty.ops.ioctl_tiocgwinsz) {
|
|
1414
|
+
var winsize = stream.tty.ops.ioctl_tiocgwinsz(stream.tty);
|
|
1415
|
+
var argp = syscallGetVarargP();
|
|
1416
|
+
HEAP16[argp >> 1] = winsize[0];
|
|
1417
|
+
HEAP16[argp + 2 >> 1] = winsize[1];
|
|
1418
|
+
}
|
|
1419
|
+
return 0;
|
|
1420
|
+
}
|
|
1421
|
+
case 21524: {
|
|
1422
|
+
if (!stream.tty)
|
|
1423
|
+
return -59;
|
|
1424
|
+
return 0;
|
|
1425
|
+
}
|
|
1426
|
+
case 21515: {
|
|
1427
|
+
if (!stream.tty)
|
|
1428
|
+
return -59;
|
|
1429
|
+
return 0;
|
|
1430
|
+
}
|
|
1431
|
+
default: return -28;
|
|
1432
|
+
}
|
|
1433
|
+
}
|
|
1434
|
+
catch (e) {
|
|
1435
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1436
|
+
throw e;
|
|
1437
|
+
return -e.errno;
|
|
1438
|
+
} }
|
|
1439
|
+
function ___syscall_lstat64(path, buf) { try {
|
|
1440
|
+
path = SYSCALLS.getStr(path);
|
|
1441
|
+
return SYSCALLS.writeStat(buf, FS.lstat(path));
|
|
1442
|
+
}
|
|
1443
|
+
catch (e) {
|
|
1444
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1445
|
+
throw e;
|
|
1446
|
+
return -e.errno;
|
|
1447
|
+
} }
|
|
1448
|
+
function ___syscall_newfstatat(dirfd, path, buf, flags) { try {
|
|
1449
|
+
path = SYSCALLS.getStr(path);
|
|
1450
|
+
var nofollow = flags & 256;
|
|
1451
|
+
var allowEmpty = flags & 4096;
|
|
1452
|
+
flags = flags & ~6400;
|
|
1453
|
+
path = SYSCALLS.calculateAt(dirfd, path, allowEmpty);
|
|
1454
|
+
return SYSCALLS.writeStat(buf, nofollow ? FS.lstat(path) : FS.stat(path));
|
|
1455
|
+
}
|
|
1456
|
+
catch (e) {
|
|
1457
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1458
|
+
throw e;
|
|
1459
|
+
return -e.errno;
|
|
1460
|
+
} }
|
|
1461
|
+
function ___syscall_openat(dirfd, path, flags, varargs) { SYSCALLS.varargs = varargs; try {
|
|
1462
|
+
path = SYSCALLS.getStr(path);
|
|
1463
|
+
path = SYSCALLS.calculateAt(dirfd, path);
|
|
1464
|
+
var mode = varargs ? syscallGetVarargI() : 0;
|
|
1465
|
+
return FS.open(path, flags, mode).fd;
|
|
1466
|
+
}
|
|
1467
|
+
catch (e) {
|
|
1468
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1469
|
+
throw e;
|
|
1470
|
+
return -e.errno;
|
|
1471
|
+
} }
|
|
1472
|
+
function ___syscall_stat64(path, buf) { try {
|
|
1473
|
+
path = SYSCALLS.getStr(path);
|
|
1474
|
+
return SYSCALLS.writeStat(buf, FS.stat(path));
|
|
1475
|
+
}
|
|
1476
|
+
catch (e) {
|
|
1477
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
1478
|
+
throw e;
|
|
1479
|
+
return -e.errno;
|
|
1480
|
+
} }
|
|
1481
|
+
var __abort_js = () => abort("");
|
|
1482
|
+
var embindRepr = v => { if (v === null) {
|
|
1483
|
+
return "null";
|
|
1484
|
+
} var t = typeof v; if (t === "object" || t === "array" || t === "function") {
|
|
1485
|
+
return v.toString();
|
|
1486
|
+
}
|
|
1487
|
+
else {
|
|
1488
|
+
return "" + v;
|
|
1489
|
+
} };
|
|
1490
|
+
var embind_init_charCodes = () => { var codes = new Array(256); for (var i = 0; i < 256; ++i) {
|
|
1491
|
+
codes[i] = String.fromCharCode(i);
|
|
1492
|
+
} embind_charCodes = codes; };
|
|
1493
|
+
var embind_charCodes;
|
|
1494
|
+
var readLatin1String = ptr => { var ret = ""; var c = ptr; while (HEAPU8[c]) {
|
|
1495
|
+
ret += embind_charCodes[HEAPU8[c++]];
|
|
1496
|
+
} return ret; };
|
|
1497
|
+
var awaitingDependencies = {};
|
|
1498
|
+
var registeredTypes = {};
|
|
1499
|
+
var typeDependencies = {};
|
|
1500
|
+
var BindingError;
|
|
1501
|
+
var throwBindingError = message => { throw new BindingError(message); };
|
|
1502
|
+
var InternalError;
|
|
1503
|
+
var throwInternalError = message => { throw new InternalError(message); };
|
|
1504
|
+
var whenDependentTypesAreResolved = (myTypes, dependentTypes, getTypeConverters) => { myTypes.forEach(type => typeDependencies[type] = dependentTypes); function onComplete(typeConverters) { var myTypeConverters = getTypeConverters(typeConverters); if (myTypeConverters.length !== myTypes.length) {
|
|
1505
|
+
throwInternalError("Mismatched type converter count");
|
|
1506
|
+
} for (var i = 0; i < myTypes.length; ++i) {
|
|
1507
|
+
registerType(myTypes[i], myTypeConverters[i]);
|
|
1508
|
+
} } var typeConverters = new Array(dependentTypes.length); var unregisteredTypes = []; var registered = 0; dependentTypes.forEach((dt, i) => { if (registeredTypes.hasOwnProperty(dt)) {
|
|
1509
|
+
typeConverters[i] = registeredTypes[dt];
|
|
1510
|
+
}
|
|
1511
|
+
else {
|
|
1512
|
+
unregisteredTypes.push(dt);
|
|
1513
|
+
if (!awaitingDependencies.hasOwnProperty(dt)) {
|
|
1514
|
+
awaitingDependencies[dt] = [];
|
|
1515
|
+
}
|
|
1516
|
+
awaitingDependencies[dt].push(() => { typeConverters[i] = registeredTypes[dt]; ++registered; if (registered === unregisteredTypes.length) {
|
|
1517
|
+
onComplete(typeConverters);
|
|
1518
|
+
} });
|
|
1519
|
+
} }); if (0 === unregisteredTypes.length) {
|
|
1520
|
+
onComplete(typeConverters);
|
|
1521
|
+
} };
|
|
1522
|
+
function sharedRegisterType(rawType, registeredInstance, options = {}) { var name = registeredInstance.name; if (!rawType) {
|
|
1523
|
+
throwBindingError(`type "${name}" must have a positive integer typeid pointer`);
|
|
1524
|
+
} if (registeredTypes.hasOwnProperty(rawType)) {
|
|
1525
|
+
if (options.ignoreDuplicateRegistrations) {
|
|
1526
|
+
return;
|
|
1527
|
+
}
|
|
1528
|
+
else {
|
|
1529
|
+
throwBindingError(`Cannot register type '${name}' twice`);
|
|
1530
|
+
}
|
|
1531
|
+
} registeredTypes[rawType] = registeredInstance; delete typeDependencies[rawType]; if (awaitingDependencies.hasOwnProperty(rawType)) {
|
|
1532
|
+
var callbacks = awaitingDependencies[rawType];
|
|
1533
|
+
delete awaitingDependencies[rawType];
|
|
1534
|
+
callbacks.forEach(cb => cb());
|
|
1535
|
+
} }
|
|
1536
|
+
function registerType(rawType, registeredInstance, options = {}) { return sharedRegisterType(rawType, registeredInstance, options); }
|
|
1537
|
+
var integerReadValueFromPointer = (name, width, signed) => { switch (width) {
|
|
1538
|
+
case 1: return signed ? pointer => HEAP8[pointer] : pointer => HEAPU8[pointer];
|
|
1539
|
+
case 2: return signed ? pointer => HEAP16[pointer >> 1] : pointer => HEAPU16[pointer >> 1];
|
|
1540
|
+
case 4: return signed ? pointer => HEAP32[pointer >> 2] : pointer => HEAPU32[pointer >> 2];
|
|
1541
|
+
case 8: return signed ? pointer => HEAP64[pointer >> 3] : pointer => HEAPU64[pointer >> 3];
|
|
1542
|
+
default: throw new TypeError(`invalid integer width (${width}): ${name}`);
|
|
1543
|
+
} };
|
|
1544
|
+
var __embind_register_bigint = (primitiveType, name, size, minRange, maxRange) => { name = readLatin1String(name); var isUnsignedType = name.indexOf("u") != -1; if (isUnsignedType) {
|
|
1545
|
+
maxRange = (1n << 64n) - 1n;
|
|
1546
|
+
} registerType(primitiveType, { name, fromWireType: value => value, toWireType: function (destructors, value) { if (typeof value != "bigint" && typeof value != "number") {
|
|
1547
|
+
throw new TypeError(`Cannot convert "${embindRepr(value)}" to ${this.name}`);
|
|
1548
|
+
} if (typeof value == "number") {
|
|
1549
|
+
value = BigInt(value);
|
|
1550
|
+
} return value; }, argPackAdvance: GenericWireTypeSize, readValueFromPointer: integerReadValueFromPointer(name, size, !isUnsignedType), destructorFunction: null }); };
|
|
1551
|
+
var GenericWireTypeSize = 8;
|
|
1552
|
+
var __embind_register_bool = (rawType, name, trueValue, falseValue) => { name = readLatin1String(name); registerType(rawType, { name, fromWireType: function (wt) { return !!wt; }, toWireType: function (destructors, o) { return o ? trueValue : falseValue; }, argPackAdvance: GenericWireTypeSize, readValueFromPointer: function (pointer) { return this["fromWireType"](HEAPU8[pointer]); }, destructorFunction: null }); };
|
|
1553
|
+
var shallowCopyInternalPointer = o => ({ count: o.count, deleteScheduled: o.deleteScheduled, preservePointerOnDelete: o.preservePointerOnDelete, ptr: o.ptr, ptrType: o.ptrType, smartPtr: o.smartPtr, smartPtrType: o.smartPtrType });
|
|
1554
|
+
var throwInstanceAlreadyDeleted = obj => { function getInstanceTypeName(handle) { return handle.$$.ptrType.registeredClass.name; } throwBindingError(getInstanceTypeName(obj) + " instance already deleted"); };
|
|
1555
|
+
var finalizationRegistry = false;
|
|
1556
|
+
var detachFinalizer = handle => { };
|
|
1557
|
+
var runDestructor = $$ => { if ($$.smartPtr) {
|
|
1558
|
+
$$.smartPtrType.rawDestructor($$.smartPtr);
|
|
1559
|
+
}
|
|
1560
|
+
else {
|
|
1561
|
+
$$.ptrType.registeredClass.rawDestructor($$.ptr);
|
|
1562
|
+
} };
|
|
1563
|
+
var releaseClassHandle = $$ => { $$.count.value -= 1; var toDelete = 0 === $$.count.value; if (toDelete) {
|
|
1564
|
+
runDestructor($$);
|
|
1565
|
+
} };
|
|
1566
|
+
var downcastPointer = (ptr, ptrClass, desiredClass) => { if (ptrClass === desiredClass) {
|
|
1567
|
+
return ptr;
|
|
1568
|
+
} if (undefined === desiredClass.baseClass) {
|
|
1569
|
+
return null;
|
|
1570
|
+
} var rv = downcastPointer(ptr, ptrClass, desiredClass.baseClass); if (rv === null) {
|
|
1571
|
+
return null;
|
|
1572
|
+
} return desiredClass.downcast(rv); };
|
|
1573
|
+
var registeredPointers = {};
|
|
1574
|
+
var registeredInstances = {};
|
|
1575
|
+
var getBasestPointer = (class_, ptr) => { if (ptr === undefined) {
|
|
1576
|
+
throwBindingError("ptr should not be undefined");
|
|
1577
|
+
} while (class_.baseClass) {
|
|
1578
|
+
ptr = class_.upcast(ptr);
|
|
1579
|
+
class_ = class_.baseClass;
|
|
1580
|
+
} return ptr; };
|
|
1581
|
+
var getInheritedInstance = (class_, ptr) => { ptr = getBasestPointer(class_, ptr); return registeredInstances[ptr]; };
|
|
1582
|
+
var makeClassHandle = (prototype, record) => { if (!record.ptrType || !record.ptr) {
|
|
1583
|
+
throwInternalError("makeClassHandle requires ptr and ptrType");
|
|
1584
|
+
} var hasSmartPtrType = !!record.smartPtrType; var hasSmartPtr = !!record.smartPtr; if (hasSmartPtrType !== hasSmartPtr) {
|
|
1585
|
+
throwInternalError("Both smartPtrType and smartPtr must be specified");
|
|
1586
|
+
} record.count = { value: 1 }; return attachFinalizer(Object.create(prototype, { $$: { value: record, writable: true } })); };
|
|
1587
|
+
function RegisteredPointer_fromWireType(ptr) { var rawPointer = this.getPointee(ptr); if (!rawPointer) {
|
|
1588
|
+
this.destructor(ptr);
|
|
1589
|
+
return null;
|
|
1590
|
+
} var registeredInstance = getInheritedInstance(this.registeredClass, rawPointer); if (undefined !== registeredInstance) {
|
|
1591
|
+
if (0 === registeredInstance.$$.count.value) {
|
|
1592
|
+
registeredInstance.$$.ptr = rawPointer;
|
|
1593
|
+
registeredInstance.$$.smartPtr = ptr;
|
|
1594
|
+
return registeredInstance["clone"]();
|
|
1595
|
+
}
|
|
1596
|
+
else {
|
|
1597
|
+
var rv = registeredInstance["clone"]();
|
|
1598
|
+
this.destructor(ptr);
|
|
1599
|
+
return rv;
|
|
1600
|
+
}
|
|
1601
|
+
} function makeDefaultHandle() { if (this.isSmartPointer) {
|
|
1602
|
+
return makeClassHandle(this.registeredClass.instancePrototype, { ptrType: this.pointeeType, ptr: rawPointer, smartPtrType: this, smartPtr: ptr });
|
|
1603
|
+
}
|
|
1604
|
+
else {
|
|
1605
|
+
return makeClassHandle(this.registeredClass.instancePrototype, { ptrType: this, ptr });
|
|
1606
|
+
} } var actualType = this.registeredClass.getActualType(rawPointer); var registeredPointerRecord = registeredPointers[actualType]; if (!registeredPointerRecord) {
|
|
1607
|
+
return makeDefaultHandle.call(this);
|
|
1608
|
+
} var toType; if (this.isConst) {
|
|
1609
|
+
toType = registeredPointerRecord.constPointerType;
|
|
1610
|
+
}
|
|
1611
|
+
else {
|
|
1612
|
+
toType = registeredPointerRecord.pointerType;
|
|
1613
|
+
} var dp = downcastPointer(rawPointer, this.registeredClass, toType.registeredClass); if (dp === null) {
|
|
1614
|
+
return makeDefaultHandle.call(this);
|
|
1615
|
+
} if (this.isSmartPointer) {
|
|
1616
|
+
return makeClassHandle(toType.registeredClass.instancePrototype, { ptrType: toType, ptr: dp, smartPtrType: this, smartPtr: ptr });
|
|
1617
|
+
}
|
|
1618
|
+
else {
|
|
1619
|
+
return makeClassHandle(toType.registeredClass.instancePrototype, { ptrType: toType, ptr: dp });
|
|
1620
|
+
} }
|
|
1621
|
+
var attachFinalizer = handle => { if ("undefined" === typeof FinalizationRegistry) {
|
|
1622
|
+
attachFinalizer = handle => handle;
|
|
1623
|
+
return handle;
|
|
1624
|
+
} finalizationRegistry = new FinalizationRegistry(info => { releaseClassHandle(info.$$); }); attachFinalizer = handle => { var $$ = handle.$$; var hasSmartPtr = !!$$.smartPtr; if (hasSmartPtr) {
|
|
1625
|
+
var info = { $$ };
|
|
1626
|
+
finalizationRegistry.register(handle, info, handle);
|
|
1627
|
+
} return handle; }; detachFinalizer = handle => finalizationRegistry.unregister(handle); return attachFinalizer(handle); };
|
|
1628
|
+
var deletionQueue = [];
|
|
1629
|
+
var flushPendingDeletes = () => { while (deletionQueue.length) {
|
|
1630
|
+
var obj = deletionQueue.pop();
|
|
1631
|
+
obj.$$.deleteScheduled = false;
|
|
1632
|
+
obj["delete"]();
|
|
1633
|
+
} };
|
|
1634
|
+
var delayFunction;
|
|
1635
|
+
var init_ClassHandle = () => { Object.assign(ClassHandle.prototype, { isAliasOf(other) { if (!(this instanceof ClassHandle)) {
|
|
1636
|
+
return false;
|
|
1637
|
+
} if (!(other instanceof ClassHandle)) {
|
|
1638
|
+
return false;
|
|
1639
|
+
} var leftClass = this.$$.ptrType.registeredClass; var left = this.$$.ptr; other.$$ = other.$$; var rightClass = other.$$.ptrType.registeredClass; var right = other.$$.ptr; while (leftClass.baseClass) {
|
|
1640
|
+
left = leftClass.upcast(left);
|
|
1641
|
+
leftClass = leftClass.baseClass;
|
|
1642
|
+
} while (rightClass.baseClass) {
|
|
1643
|
+
right = rightClass.upcast(right);
|
|
1644
|
+
rightClass = rightClass.baseClass;
|
|
1645
|
+
} return leftClass === rightClass && left === right; }, clone() { if (!this.$$.ptr) {
|
|
1646
|
+
throwInstanceAlreadyDeleted(this);
|
|
1647
|
+
} if (this.$$.preservePointerOnDelete) {
|
|
1648
|
+
this.$$.count.value += 1;
|
|
1649
|
+
return this;
|
|
1650
|
+
}
|
|
1651
|
+
else {
|
|
1652
|
+
var clone = attachFinalizer(Object.create(Object.getPrototypeOf(this), { $$: { value: shallowCopyInternalPointer(this.$$) } }));
|
|
1653
|
+
clone.$$.count.value += 1;
|
|
1654
|
+
clone.$$.deleteScheduled = false;
|
|
1655
|
+
return clone;
|
|
1656
|
+
} }, delete() { if (!this.$$.ptr) {
|
|
1657
|
+
throwInstanceAlreadyDeleted(this);
|
|
1658
|
+
} if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
|
|
1659
|
+
throwBindingError("Object already scheduled for deletion");
|
|
1660
|
+
} detachFinalizer(this); releaseClassHandle(this.$$); if (!this.$$.preservePointerOnDelete) {
|
|
1661
|
+
this.$$.smartPtr = undefined;
|
|
1662
|
+
this.$$.ptr = undefined;
|
|
1663
|
+
} }, isDeleted() { return !this.$$.ptr; }, deleteLater() { if (!this.$$.ptr) {
|
|
1664
|
+
throwInstanceAlreadyDeleted(this);
|
|
1665
|
+
} if (this.$$.deleteScheduled && !this.$$.preservePointerOnDelete) {
|
|
1666
|
+
throwBindingError("Object already scheduled for deletion");
|
|
1667
|
+
} deletionQueue.push(this); if (deletionQueue.length === 1 && delayFunction) {
|
|
1668
|
+
delayFunction(flushPendingDeletes);
|
|
1669
|
+
} this.$$.deleteScheduled = true; return this; } }); };
|
|
1670
|
+
function ClassHandle() { }
|
|
1671
|
+
var createNamedFunction = (name, body) => Object.defineProperty(body, "name", { value: name });
|
|
1672
|
+
var ensureOverloadTable = (proto, methodName, humanName) => { if (undefined === proto[methodName].overloadTable) {
|
|
1673
|
+
var prevFunc = proto[methodName];
|
|
1674
|
+
proto[methodName] = function (...args) { if (!proto[methodName].overloadTable.hasOwnProperty(args.length)) {
|
|
1675
|
+
throwBindingError(`Function '${humanName}' called with an invalid number of arguments (${args.length}) - expects one of (${proto[methodName].overloadTable})!`);
|
|
1676
|
+
} return proto[methodName].overloadTable[args.length].apply(this, args); };
|
|
1677
|
+
proto[methodName].overloadTable = [];
|
|
1678
|
+
proto[methodName].overloadTable[prevFunc.argCount] = prevFunc;
|
|
1679
|
+
} };
|
|
1680
|
+
var exposePublicSymbol = (name, value, numArguments) => { if (Module.hasOwnProperty(name)) {
|
|
1681
|
+
if (undefined === numArguments || undefined !== Module[name].overloadTable && undefined !== Module[name].overloadTable[numArguments]) {
|
|
1682
|
+
throwBindingError(`Cannot register public name '${name}' twice`);
|
|
1683
|
+
}
|
|
1684
|
+
ensureOverloadTable(Module, name, name);
|
|
1685
|
+
if (Module[name].overloadTable.hasOwnProperty(numArguments)) {
|
|
1686
|
+
throwBindingError(`Cannot register multiple overloads of a function with the same number of arguments (${numArguments})!`);
|
|
1687
|
+
}
|
|
1688
|
+
Module[name].overloadTable[numArguments] = value;
|
|
1689
|
+
}
|
|
1690
|
+
else {
|
|
1691
|
+
Module[name] = value;
|
|
1692
|
+
Module[name].argCount = numArguments;
|
|
1693
|
+
} };
|
|
1694
|
+
var char_0 = 48;
|
|
1695
|
+
var char_9 = 57;
|
|
1696
|
+
var makeLegalFunctionName = name => { name = name.replace(/[^a-zA-Z0-9_]/g, "$"); var f = name.charCodeAt(0); if (f >= char_0 && f <= char_9) {
|
|
1697
|
+
return `_${name}`;
|
|
1698
|
+
} return name; };
|
|
1699
|
+
function RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast) { this.name = name; this.constructor = constructor; this.instancePrototype = instancePrototype; this.rawDestructor = rawDestructor; this.baseClass = baseClass; this.getActualType = getActualType; this.upcast = upcast; this.downcast = downcast; this.pureVirtualFunctions = []; }
|
|
1700
|
+
var upcastPointer = (ptr, ptrClass, desiredClass) => { while (ptrClass !== desiredClass) {
|
|
1701
|
+
if (!ptrClass.upcast) {
|
|
1702
|
+
throwBindingError(`Expected null or instance of ${desiredClass.name}, got an instance of ${ptrClass.name}`);
|
|
1703
|
+
}
|
|
1704
|
+
ptr = ptrClass.upcast(ptr);
|
|
1705
|
+
ptrClass = ptrClass.baseClass;
|
|
1706
|
+
} return ptr; };
|
|
1707
|
+
function constNoSmartPtrRawPointerToWireType(destructors, handle) { if (handle === null) {
|
|
1708
|
+
if (this.isReference) {
|
|
1709
|
+
throwBindingError(`null is not a valid ${this.name}`);
|
|
1710
|
+
}
|
|
1711
|
+
return 0;
|
|
1712
|
+
} if (!handle.$$) {
|
|
1713
|
+
throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`);
|
|
1714
|
+
} if (!handle.$$.ptr) {
|
|
1715
|
+
throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);
|
|
1716
|
+
} var handleClass = handle.$$.ptrType.registeredClass; var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass); return ptr; }
|
|
1717
|
+
function genericPointerToWireType(destructors, handle) { var ptr; if (handle === null) {
|
|
1718
|
+
if (this.isReference) {
|
|
1719
|
+
throwBindingError(`null is not a valid ${this.name}`);
|
|
1720
|
+
}
|
|
1721
|
+
if (this.isSmartPointer) {
|
|
1722
|
+
ptr = this.rawConstructor();
|
|
1723
|
+
if (destructors !== null) {
|
|
1724
|
+
destructors.push(this.rawDestructor, ptr);
|
|
1725
|
+
}
|
|
1726
|
+
return ptr;
|
|
1727
|
+
}
|
|
1728
|
+
else {
|
|
1729
|
+
return 0;
|
|
1730
|
+
}
|
|
1731
|
+
} if (!handle || !handle.$$) {
|
|
1732
|
+
throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`);
|
|
1733
|
+
} if (!handle.$$.ptr) {
|
|
1734
|
+
throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);
|
|
1735
|
+
} if (!this.isConst && handle.$$.ptrType.isConst) {
|
|
1736
|
+
throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name} to parameter type ${this.name}`);
|
|
1737
|
+
} var handleClass = handle.$$.ptrType.registeredClass; ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass); if (this.isSmartPointer) {
|
|
1738
|
+
if (undefined === handle.$$.smartPtr) {
|
|
1739
|
+
throwBindingError("Passing raw pointer to smart pointer is illegal");
|
|
1740
|
+
}
|
|
1741
|
+
switch (this.sharingPolicy) {
|
|
1742
|
+
case 0:
|
|
1743
|
+
if (handle.$$.smartPtrType === this) {
|
|
1744
|
+
ptr = handle.$$.smartPtr;
|
|
1745
|
+
}
|
|
1746
|
+
else {
|
|
1747
|
+
throwBindingError(`Cannot convert argument of type ${handle.$$.smartPtrType ? handle.$$.smartPtrType.name : handle.$$.ptrType.name} to parameter type ${this.name}`);
|
|
1748
|
+
}
|
|
1749
|
+
break;
|
|
1750
|
+
case 1:
|
|
1751
|
+
ptr = handle.$$.smartPtr;
|
|
1752
|
+
break;
|
|
1753
|
+
case 2:
|
|
1754
|
+
if (handle.$$.smartPtrType === this) {
|
|
1755
|
+
ptr = handle.$$.smartPtr;
|
|
1756
|
+
}
|
|
1757
|
+
else {
|
|
1758
|
+
var clonedHandle = handle["clone"]();
|
|
1759
|
+
ptr = this.rawShare(ptr, Emval.toHandle(() => clonedHandle["delete"]()));
|
|
1760
|
+
if (destructors !== null) {
|
|
1761
|
+
destructors.push(this.rawDestructor, ptr);
|
|
1762
|
+
}
|
|
1763
|
+
}
|
|
1764
|
+
break;
|
|
1765
|
+
default: throwBindingError("Unsupporting sharing policy");
|
|
1766
|
+
}
|
|
1767
|
+
} return ptr; }
|
|
1768
|
+
function nonConstNoSmartPtrRawPointerToWireType(destructors, handle) { if (handle === null) {
|
|
1769
|
+
if (this.isReference) {
|
|
1770
|
+
throwBindingError(`null is not a valid ${this.name}`);
|
|
1771
|
+
}
|
|
1772
|
+
return 0;
|
|
1773
|
+
} if (!handle.$$) {
|
|
1774
|
+
throwBindingError(`Cannot pass "${embindRepr(handle)}" as a ${this.name}`);
|
|
1775
|
+
} if (!handle.$$.ptr) {
|
|
1776
|
+
throwBindingError(`Cannot pass deleted object as a pointer of type ${this.name}`);
|
|
1777
|
+
} if (handle.$$.ptrType.isConst) {
|
|
1778
|
+
throwBindingError(`Cannot convert argument of type ${handle.$$.ptrType.name} to parameter type ${this.name}`);
|
|
1779
|
+
} var handleClass = handle.$$.ptrType.registeredClass; var ptr = upcastPointer(handle.$$.ptr, handleClass, this.registeredClass); return ptr; }
|
|
1780
|
+
function readPointer(pointer) { return this["fromWireType"](HEAPU32[pointer >> 2]); }
|
|
1781
|
+
var init_RegisteredPointer = () => { Object.assign(RegisteredPointer.prototype, { getPointee(ptr) { if (this.rawGetPointee) {
|
|
1782
|
+
ptr = this.rawGetPointee(ptr);
|
|
1783
|
+
} return ptr; }, destructor(ptr) { this.rawDestructor?.(ptr); }, argPackAdvance: GenericWireTypeSize, readValueFromPointer: readPointer, fromWireType: RegisteredPointer_fromWireType }); };
|
|
1784
|
+
function RegisteredPointer(name, registeredClass, isReference, isConst, isSmartPointer, pointeeType, sharingPolicy, rawGetPointee, rawConstructor, rawShare, rawDestructor) { this.name = name; this.registeredClass = registeredClass; this.isReference = isReference; this.isConst = isConst; this.isSmartPointer = isSmartPointer; this.pointeeType = pointeeType; this.sharingPolicy = sharingPolicy; this.rawGetPointee = rawGetPointee; this.rawConstructor = rawConstructor; this.rawShare = rawShare; this.rawDestructor = rawDestructor; if (!isSmartPointer && registeredClass.baseClass === undefined) {
|
|
1785
|
+
if (isConst) {
|
|
1786
|
+
this["toWireType"] = constNoSmartPtrRawPointerToWireType;
|
|
1787
|
+
this.destructorFunction = null;
|
|
1788
|
+
}
|
|
1789
|
+
else {
|
|
1790
|
+
this["toWireType"] = nonConstNoSmartPtrRawPointerToWireType;
|
|
1791
|
+
this.destructorFunction = null;
|
|
1792
|
+
}
|
|
1793
|
+
}
|
|
1794
|
+
else {
|
|
1795
|
+
this["toWireType"] = genericPointerToWireType;
|
|
1796
|
+
} }
|
|
1797
|
+
var replacePublicSymbol = (name, value, numArguments) => { if (!Module.hasOwnProperty(name)) {
|
|
1798
|
+
throwInternalError("Replacing nonexistent public symbol");
|
|
1799
|
+
} if (undefined !== Module[name].overloadTable && undefined !== numArguments) {
|
|
1800
|
+
Module[name].overloadTable[numArguments] = value;
|
|
1801
|
+
}
|
|
1802
|
+
else {
|
|
1803
|
+
Module[name] = value;
|
|
1804
|
+
Module[name].argCount = numArguments;
|
|
1805
|
+
} };
|
|
1806
|
+
var embind__requireFunction = (signature, rawFunction) => { signature = readLatin1String(signature); function makeDynCaller() { return getWasmTableEntry(rawFunction); } var fp = makeDynCaller(); if (typeof fp != "function") {
|
|
1807
|
+
throwBindingError(`unknown function pointer with signature ${signature}: ${rawFunction}`);
|
|
1808
|
+
} return fp; };
|
|
1809
|
+
var extendError = (baseErrorType, errorName) => { var errorClass = createNamedFunction(errorName, function (message) { this.name = errorName; this.message = message; var stack = new Error(message).stack; if (stack !== undefined) {
|
|
1810
|
+
this.stack = this.toString() + "\n" + stack.replace(/^Error(:[^\n]*)?\n/, "");
|
|
1811
|
+
} }); errorClass.prototype = Object.create(baseErrorType.prototype); errorClass.prototype.constructor = errorClass; errorClass.prototype.toString = function () { if (this.message === undefined) {
|
|
1812
|
+
return this.name;
|
|
1813
|
+
}
|
|
1814
|
+
else {
|
|
1815
|
+
return `${this.name}: ${this.message}`;
|
|
1816
|
+
} }; return errorClass; };
|
|
1817
|
+
var UnboundTypeError;
|
|
1818
|
+
var getTypeName = type => { var ptr = ___getTypeName(type); var rv = readLatin1String(ptr); _free(ptr); return rv; };
|
|
1819
|
+
var throwUnboundTypeError = (message, types) => { var unboundTypes = []; var seen = {}; function visit(type) { if (seen[type]) {
|
|
1820
|
+
return;
|
|
1821
|
+
} if (registeredTypes[type]) {
|
|
1822
|
+
return;
|
|
1823
|
+
} if (typeDependencies[type]) {
|
|
1824
|
+
typeDependencies[type].forEach(visit);
|
|
1825
|
+
return;
|
|
1826
|
+
} unboundTypes.push(type); seen[type] = true; } types.forEach(visit); throw new UnboundTypeError(`${message}: ` + unboundTypes.map(getTypeName).join([", "])); };
|
|
1827
|
+
var __embind_register_class = (rawType, rawPointerType, rawConstPointerType, baseClassRawType, getActualTypeSignature, getActualType, upcastSignature, upcast, downcastSignature, downcast, name, destructorSignature, rawDestructor) => { name = readLatin1String(name); getActualType = embind__requireFunction(getActualTypeSignature, getActualType); upcast &&= embind__requireFunction(upcastSignature, upcast); downcast &&= embind__requireFunction(downcastSignature, downcast); rawDestructor = embind__requireFunction(destructorSignature, rawDestructor); var legalFunctionName = makeLegalFunctionName(name); exposePublicSymbol(legalFunctionName, function () { throwUnboundTypeError(`Cannot construct ${name} due to unbound types`, [baseClassRawType]); }); whenDependentTypesAreResolved([rawType, rawPointerType, rawConstPointerType], baseClassRawType ? [baseClassRawType] : [], base => { base = base[0]; var baseClass; var basePrototype; if (baseClassRawType) {
|
|
1828
|
+
baseClass = base.registeredClass;
|
|
1829
|
+
basePrototype = baseClass.instancePrototype;
|
|
1830
|
+
}
|
|
1831
|
+
else {
|
|
1832
|
+
basePrototype = ClassHandle.prototype;
|
|
1833
|
+
} var constructor = createNamedFunction(name, function (...args) { if (Object.getPrototypeOf(this) !== instancePrototype) {
|
|
1834
|
+
throw new BindingError("Use 'new' to construct " + name);
|
|
1835
|
+
} if (undefined === registeredClass.constructor_body) {
|
|
1836
|
+
throw new BindingError(name + " has no accessible constructor");
|
|
1837
|
+
} var body = registeredClass.constructor_body[args.length]; if (undefined === body) {
|
|
1838
|
+
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!`);
|
|
1839
|
+
} return body.apply(this, args); }); var instancePrototype = Object.create(basePrototype, { constructor: { value: constructor } }); constructor.prototype = instancePrototype; var registeredClass = new RegisteredClass(name, constructor, instancePrototype, rawDestructor, baseClass, getActualType, upcast, downcast); if (registeredClass.baseClass) {
|
|
1840
|
+
registeredClass.baseClass.__derivedClasses ??= [];
|
|
1841
|
+
registeredClass.baseClass.__derivedClasses.push(registeredClass);
|
|
1842
|
+
} var referenceConverter = new RegisteredPointer(name, registeredClass, true, false, false); var pointerConverter = new RegisteredPointer(name + "*", registeredClass, false, false, false); var constPointerConverter = new RegisteredPointer(name + " const*", registeredClass, false, true, false); registeredPointers[rawType] = { pointerType: pointerConverter, constPointerType: constPointerConverter }; replacePublicSymbol(legalFunctionName, constructor); return [referenceConverter, pointerConverter, constPointerConverter]; }); };
|
|
1843
|
+
var runDestructors = destructors => { while (destructors.length) {
|
|
1844
|
+
var ptr = destructors.pop();
|
|
1845
|
+
var del = destructors.pop();
|
|
1846
|
+
del(ptr);
|
|
1847
|
+
} };
|
|
1848
|
+
var validateThis = (this_, classType, humanName) => { if (!(this_ instanceof Object)) {
|
|
1849
|
+
throwBindingError(`${humanName} with invalid "this": ${this_}`);
|
|
1850
|
+
} if (!(this_ instanceof classType.registeredClass.constructor)) {
|
|
1851
|
+
throwBindingError(`${humanName} incompatible with "this" of type ${this_.constructor.name}`);
|
|
1852
|
+
} if (!this_.$$.ptr) {
|
|
1853
|
+
throwBindingError(`cannot call emscripten binding method ${humanName} on deleted object`);
|
|
1854
|
+
} return upcastPointer(this_.$$.ptr, this_.$$.ptrType.registeredClass, classType.registeredClass); };
|
|
1855
|
+
var __embind_register_class_property = (classType, fieldName, getterReturnType, getterSignature, getter, getterContext, setterArgumentType, setterSignature, setter, setterContext) => { fieldName = readLatin1String(fieldName); getter = embind__requireFunction(getterSignature, getter); whenDependentTypesAreResolved([], [classType], classType => { classType = classType[0]; var humanName = `${classType.name}.${fieldName}`; var desc = { get() { throwUnboundTypeError(`Cannot access ${humanName} due to unbound types`, [getterReturnType, setterArgumentType]); }, enumerable: true, configurable: true }; if (setter) {
|
|
1856
|
+
desc.set = () => throwUnboundTypeError(`Cannot access ${humanName} due to unbound types`, [getterReturnType, setterArgumentType]);
|
|
1857
|
+
}
|
|
1858
|
+
else {
|
|
1859
|
+
desc.set = v => throwBindingError(humanName + " is a read-only property");
|
|
1860
|
+
} Object.defineProperty(classType.registeredClass.instancePrototype, fieldName, desc); whenDependentTypesAreResolved([], setter ? [getterReturnType, setterArgumentType] : [getterReturnType], types => { var getterReturnType = types[0]; var desc = { get() { var ptr = validateThis(this, classType, humanName + " getter"); return getterReturnType["fromWireType"](getter(getterContext, ptr)); }, enumerable: true }; if (setter) {
|
|
1861
|
+
setter = embind__requireFunction(setterSignature, setter);
|
|
1862
|
+
var setterArgumentType = types[1];
|
|
1863
|
+
desc.set = function (v) { var ptr = validateThis(this, classType, humanName + " setter"); var destructors = []; setter(setterContext, ptr, setterArgumentType["toWireType"](destructors, v)); runDestructors(destructors); };
|
|
1864
|
+
} Object.defineProperty(classType.registeredClass.instancePrototype, fieldName, desc); return []; }); return []; }); };
|
|
1865
|
+
var emval_freelist = [];
|
|
1866
|
+
var emval_handles = [];
|
|
1867
|
+
var __emval_decref = handle => { if (handle > 9 && 0 === --emval_handles[handle + 1]) {
|
|
1868
|
+
emval_handles[handle] = undefined;
|
|
1869
|
+
emval_freelist.push(handle);
|
|
1870
|
+
} };
|
|
1871
|
+
var count_emval_handles = () => emval_handles.length / 2 - 5 - emval_freelist.length;
|
|
1872
|
+
var init_emval = () => { emval_handles.push(0, 1, undefined, 1, null, 1, true, 1, false, 1); Module["count_emval_handles"] = count_emval_handles; };
|
|
1873
|
+
var Emval = { toValue: handle => { if (!handle) {
|
|
1874
|
+
throwBindingError("Cannot use deleted val. handle = " + handle);
|
|
1875
|
+
} return emval_handles[handle]; }, toHandle: value => { switch (value) {
|
|
1876
|
+
case undefined: return 2;
|
|
1877
|
+
case null: return 4;
|
|
1878
|
+
case true: return 6;
|
|
1879
|
+
case false: return 8;
|
|
1880
|
+
default: {
|
|
1881
|
+
const handle = emval_freelist.pop() || emval_handles.length;
|
|
1882
|
+
emval_handles[handle] = value;
|
|
1883
|
+
emval_handles[handle + 1] = 1;
|
|
1884
|
+
return handle;
|
|
1885
|
+
}
|
|
1886
|
+
} } };
|
|
1887
|
+
var EmValType = { name: "emscripten::val", fromWireType: handle => { var rv = Emval.toValue(handle); __emval_decref(handle); return rv; }, toWireType: (destructors, value) => Emval.toHandle(value), argPackAdvance: GenericWireTypeSize, readValueFromPointer: readPointer, destructorFunction: null };
|
|
1888
|
+
var __embind_register_emval = rawType => registerType(rawType, EmValType);
|
|
1889
|
+
var enumReadValueFromPointer = (name, width, signed) => { switch (width) {
|
|
1890
|
+
case 1: return signed ? function (pointer) { return this["fromWireType"](HEAP8[pointer]); } : function (pointer) { return this["fromWireType"](HEAPU8[pointer]); };
|
|
1891
|
+
case 2: return signed ? function (pointer) { return this["fromWireType"](HEAP16[pointer >> 1]); } : function (pointer) { return this["fromWireType"](HEAPU16[pointer >> 1]); };
|
|
1892
|
+
case 4: return signed ? function (pointer) { return this["fromWireType"](HEAP32[pointer >> 2]); } : function (pointer) { return this["fromWireType"](HEAPU32[pointer >> 2]); };
|
|
1893
|
+
default: throw new TypeError(`invalid integer width (${width}): ${name}`);
|
|
1894
|
+
} };
|
|
1895
|
+
var __embind_register_enum = (rawType, name, size, isSigned) => { name = readLatin1String(name); function ctor() { } ctor.values = {}; registerType(rawType, { name, constructor: ctor, fromWireType: function (c) { return this.constructor.values[c]; }, toWireType: (destructors, c) => c.value, argPackAdvance: GenericWireTypeSize, readValueFromPointer: enumReadValueFromPointer(name, size, isSigned), destructorFunction: null }); exposePublicSymbol(name, ctor); };
|
|
1896
|
+
var requireRegisteredType = (rawType, humanName) => { var impl = registeredTypes[rawType]; if (undefined === impl) {
|
|
1897
|
+
throwBindingError(`${humanName} has unknown type ${getTypeName(rawType)}`);
|
|
1898
|
+
} return impl; };
|
|
1899
|
+
var __embind_register_enum_value = (rawEnumType, name, enumValue) => { var enumType = requireRegisteredType(rawEnumType, "enum"); name = readLatin1String(name); var Enum = enumType.constructor; var Value = Object.create(enumType.constructor.prototype, { value: { value: enumValue }, constructor: { value: createNamedFunction(`${enumType.name}_${name}`, function () { }) } }); Enum.values[enumValue] = Value; Enum[name] = Value; };
|
|
1900
|
+
var floatReadValueFromPointer = (name, width) => { switch (width) {
|
|
1901
|
+
case 4: return function (pointer) { return this["fromWireType"](HEAPF32[pointer >> 2]); };
|
|
1902
|
+
case 8: return function (pointer) { return this["fromWireType"](HEAPF64[pointer >> 3]); };
|
|
1903
|
+
default: throw new TypeError(`invalid float width (${width}): ${name}`);
|
|
1904
|
+
} };
|
|
1905
|
+
var __embind_register_float = (rawType, name, size) => { name = readLatin1String(name); registerType(rawType, { name, fromWireType: value => value, toWireType: (destructors, value) => value, argPackAdvance: GenericWireTypeSize, readValueFromPointer: floatReadValueFromPointer(name, size), destructorFunction: null }); };
|
|
1906
|
+
function usesDestructorStack(argTypes) { for (var i = 1; i < argTypes.length; ++i) {
|
|
1907
|
+
if (argTypes[i] !== null && argTypes[i].destructorFunction === undefined) {
|
|
1908
|
+
return true;
|
|
1909
|
+
}
|
|
1910
|
+
} return false; }
|
|
1911
|
+
function newFunc(constructor, argumentList) { if (!(constructor instanceof Function)) {
|
|
1912
|
+
throw new TypeError(`new_ called with constructor type ${typeof constructor} which is not a function`);
|
|
1913
|
+
} var dummy = createNamedFunction(constructor.name || "unknownFunctionName", function () { }); dummy.prototype = constructor.prototype; var obj = new dummy; var r = constructor.apply(obj, argumentList); return r instanceof Object ? r : obj; }
|
|
1914
|
+
function createJsInvoker(argTypes, isClassMethodFunc, returns, isAsync) { var needsDestructorStack = usesDestructorStack(argTypes); var argCount = argTypes.length - 2; var argsList = []; var argsListWired = ["fn"]; if (isClassMethodFunc) {
|
|
1915
|
+
argsListWired.push("thisWired");
|
|
1916
|
+
} for (var i = 0; i < argCount; ++i) {
|
|
1917
|
+
argsList.push(`arg${i}`);
|
|
1918
|
+
argsListWired.push(`arg${i}Wired`);
|
|
1919
|
+
} argsList = argsList.join(","); argsListWired = argsListWired.join(","); var invokerFnBody = `return function (${argsList}) {\n`; if (needsDestructorStack) {
|
|
1920
|
+
invokerFnBody += "var destructors = [];\n";
|
|
1921
|
+
} var dtorStack = needsDestructorStack ? "destructors" : "null"; var args1 = ["humanName", "throwBindingError", "invoker", "fn", "runDestructors", "retType", "classParam"]; if (isClassMethodFunc) {
|
|
1922
|
+
invokerFnBody += `var thisWired = classParam['toWireType'](${dtorStack}, this);\n`;
|
|
1923
|
+
} for (var i = 0; i < argCount; ++i) {
|
|
1924
|
+
invokerFnBody += `var arg${i}Wired = argType${i}['toWireType'](${dtorStack}, arg${i});\n`;
|
|
1925
|
+
args1.push(`argType${i}`);
|
|
1926
|
+
} invokerFnBody += (returns || isAsync ? "var rv = " : "") + `invoker(${argsListWired});\n`; var returnVal = returns ? "rv" : ""; if (needsDestructorStack) {
|
|
1927
|
+
invokerFnBody += "runDestructors(destructors);\n";
|
|
1928
|
+
}
|
|
1929
|
+
else {
|
|
1930
|
+
for (var i = isClassMethodFunc ? 1 : 2; i < argTypes.length; ++i) {
|
|
1931
|
+
var paramName = i === 1 ? "thisWired" : "arg" + (i - 2) + "Wired";
|
|
1932
|
+
if (argTypes[i].destructorFunction !== null) {
|
|
1933
|
+
invokerFnBody += `${paramName}_dtor(${paramName});\n`;
|
|
1934
|
+
args1.push(`${paramName}_dtor`);
|
|
1935
|
+
}
|
|
1936
|
+
}
|
|
1937
|
+
} if (returns) {
|
|
1938
|
+
invokerFnBody += "var ret = retType['fromWireType'](rv);\n" + "return ret;\n";
|
|
1939
|
+
}
|
|
1940
|
+
else { } invokerFnBody += "}\n"; return [args1, invokerFnBody]; }
|
|
1941
|
+
function craftInvokerFunction(humanName, argTypes, classType, cppInvokerFunc, cppTargetFunc, isAsync) { var argCount = argTypes.length; if (argCount < 2) {
|
|
1942
|
+
throwBindingError("argTypes array size mismatch! Must at least get return value and 'this' types!");
|
|
1943
|
+
} var isClassMethodFunc = argTypes[1] !== null && classType !== null; var needsDestructorStack = usesDestructorStack(argTypes); var returns = argTypes[0].name !== "void"; var expectedArgCount = argCount - 2; var closureArgs = [humanName, throwBindingError, cppInvokerFunc, cppTargetFunc, runDestructors, argTypes[0], argTypes[1]]; for (var i = 0; i < argCount - 2; ++i) {
|
|
1944
|
+
closureArgs.push(argTypes[i + 2]);
|
|
1945
|
+
} if (!needsDestructorStack) {
|
|
1946
|
+
for (var i = isClassMethodFunc ? 1 : 2; i < argTypes.length; ++i) {
|
|
1947
|
+
if (argTypes[i].destructorFunction !== null) {
|
|
1948
|
+
closureArgs.push(argTypes[i].destructorFunction);
|
|
1949
|
+
}
|
|
1950
|
+
}
|
|
1951
|
+
} let [args, invokerFnBody] = createJsInvoker(argTypes, isClassMethodFunc, returns, isAsync); args.push(invokerFnBody); var invokerFn = newFunc(Function, args)(...closureArgs); return createNamedFunction(humanName, invokerFn); }
|
|
1952
|
+
var heap32VectorToArray = (count, firstElement) => { var array = []; for (var i = 0; i < count; i++) {
|
|
1953
|
+
array.push(HEAPU32[firstElement + i * 4 >> 2]);
|
|
1954
|
+
} return array; };
|
|
1955
|
+
var getFunctionName = signature => { signature = signature.trim(); const argsIndex = signature.indexOf("("); if (argsIndex === -1)
|
|
1956
|
+
return signature; return signature.slice(0, argsIndex); };
|
|
1957
|
+
var __embind_register_function = (name, argCount, rawArgTypesAddr, signature, rawInvoker, fn, isAsync, isNonnullReturn) => { var argTypes = heap32VectorToArray(argCount, rawArgTypesAddr); name = readLatin1String(name); name = getFunctionName(name); rawInvoker = embind__requireFunction(signature, rawInvoker); exposePublicSymbol(name, function () { throwUnboundTypeError(`Cannot call ${name} due to unbound types`, argTypes); }, argCount - 1); whenDependentTypesAreResolved([], argTypes, argTypes => { var invokerArgsArray = [argTypes[0], null].concat(argTypes.slice(1)); replacePublicSymbol(name, craftInvokerFunction(name, invokerArgsArray, null, rawInvoker, fn, isAsync), argCount - 1); return []; }); };
|
|
1958
|
+
var __embind_register_integer = (primitiveType, name, size, minRange, maxRange) => { name = readLatin1String(name); if (maxRange === -1) {
|
|
1959
|
+
maxRange = 4294967295;
|
|
1960
|
+
} var fromWireType = value => value; if (minRange === 0) {
|
|
1961
|
+
var bitshift = 32 - 8 * size;
|
|
1962
|
+
fromWireType = value => value << bitshift >>> bitshift;
|
|
1963
|
+
} var isUnsignedType = name.includes("unsigned"); var checkAssertions = (value, toTypeName) => { }; var toWireType; if (isUnsignedType) {
|
|
1964
|
+
toWireType = function (destructors, value) { checkAssertions(value, this.name); return value >>> 0; };
|
|
1965
|
+
}
|
|
1966
|
+
else {
|
|
1967
|
+
toWireType = function (destructors, value) { checkAssertions(value, this.name); return value; };
|
|
1968
|
+
} registerType(primitiveType, { name, fromWireType, toWireType, argPackAdvance: GenericWireTypeSize, readValueFromPointer: integerReadValueFromPointer(name, size, minRange !== 0), destructorFunction: null }); };
|
|
1969
|
+
var __embind_register_memory_view = (rawType, dataTypeIndex, name) => { var typeMapping = [Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array, BigInt64Array, BigUint64Array]; var TA = typeMapping[dataTypeIndex]; function decodeMemoryView(handle) { var size = HEAPU32[handle >> 2]; var data = HEAPU32[handle + 4 >> 2]; return new TA(HEAP8.buffer, data, size); } name = readLatin1String(name); registerType(rawType, { name, fromWireType: decodeMemoryView, argPackAdvance: GenericWireTypeSize, readValueFromPointer: decodeMemoryView }, { ignoreDuplicateRegistrations: true }); };
|
|
1970
|
+
var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
|
|
1971
|
+
var __embind_register_std_string = (rawType, name) => { name = readLatin1String(name); var stdStringIsUTF8 = true; registerType(rawType, { name, fromWireType(value) { var length = HEAPU32[value >> 2]; var payload = value + 4; var str; if (stdStringIsUTF8) {
|
|
1972
|
+
var decodeStartPtr = payload;
|
|
1973
|
+
for (var i = 0; i <= length; ++i) {
|
|
1974
|
+
var currentBytePtr = payload + i;
|
|
1975
|
+
if (i == length || HEAPU8[currentBytePtr] == 0) {
|
|
1976
|
+
var maxRead = currentBytePtr - decodeStartPtr;
|
|
1977
|
+
var stringSegment = UTF8ToString(decodeStartPtr, maxRead);
|
|
1978
|
+
if (str === undefined) {
|
|
1979
|
+
str = stringSegment;
|
|
1980
|
+
}
|
|
1981
|
+
else {
|
|
1982
|
+
str += String.fromCharCode(0);
|
|
1983
|
+
str += stringSegment;
|
|
1984
|
+
}
|
|
1985
|
+
decodeStartPtr = currentBytePtr + 1;
|
|
1986
|
+
}
|
|
1987
|
+
}
|
|
1988
|
+
}
|
|
1989
|
+
else {
|
|
1990
|
+
var a = new Array(length);
|
|
1991
|
+
for (var i = 0; i < length; ++i) {
|
|
1992
|
+
a[i] = String.fromCharCode(HEAPU8[payload + i]);
|
|
1993
|
+
}
|
|
1994
|
+
str = a.join("");
|
|
1995
|
+
} _free(value); return str; }, toWireType(destructors, value) { if (value instanceof ArrayBuffer) {
|
|
1996
|
+
value = new Uint8Array(value);
|
|
1997
|
+
} var length; var valueIsOfTypeString = typeof value == "string"; if (!(valueIsOfTypeString || value instanceof Uint8Array || value instanceof Uint8ClampedArray || value instanceof Int8Array)) {
|
|
1998
|
+
throwBindingError("Cannot pass non-string to std::string");
|
|
1999
|
+
} if (stdStringIsUTF8 && valueIsOfTypeString) {
|
|
2000
|
+
length = lengthBytesUTF8(value);
|
|
2001
|
+
}
|
|
2002
|
+
else {
|
|
2003
|
+
length = value.length;
|
|
2004
|
+
} var base = _malloc(4 + length + 1); var ptr = base + 4; HEAPU32[base >> 2] = length; if (stdStringIsUTF8 && valueIsOfTypeString) {
|
|
2005
|
+
stringToUTF8(value, ptr, length + 1);
|
|
2006
|
+
}
|
|
2007
|
+
else {
|
|
2008
|
+
if (valueIsOfTypeString) {
|
|
2009
|
+
for (var i = 0; i < length; ++i) {
|
|
2010
|
+
var charCode = value.charCodeAt(i);
|
|
2011
|
+
if (charCode > 255) {
|
|
2012
|
+
_free(base);
|
|
2013
|
+
throwBindingError("String has UTF-16 code units that do not fit in 8 bits");
|
|
2014
|
+
}
|
|
2015
|
+
HEAPU8[ptr + i] = charCode;
|
|
2016
|
+
}
|
|
2017
|
+
}
|
|
2018
|
+
else {
|
|
2019
|
+
for (var i = 0; i < length; ++i) {
|
|
2020
|
+
HEAPU8[ptr + i] = value[i];
|
|
2021
|
+
}
|
|
2022
|
+
}
|
|
2023
|
+
} if (destructors !== null) {
|
|
2024
|
+
destructors.push(_free, base);
|
|
2025
|
+
} return base; }, argPackAdvance: GenericWireTypeSize, readValueFromPointer: readPointer, destructorFunction(ptr) { _free(ptr); } }); };
|
|
2026
|
+
var UTF16Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf-16le") : undefined;
|
|
2027
|
+
var UTF16ToString = (ptr, maxBytesToRead) => { var endPtr = ptr; var idx = endPtr >> 1; var maxIdx = idx + maxBytesToRead / 2; while (!(idx >= maxIdx) && HEAPU16[idx])
|
|
2028
|
+
++idx; endPtr = idx << 1; if (endPtr - ptr > 32 && UTF16Decoder)
|
|
2029
|
+
return UTF16Decoder.decode(HEAPU8.subarray(ptr, endPtr)); var str = ""; for (var i = 0; !(i >= maxBytesToRead / 2); ++i) {
|
|
2030
|
+
var codeUnit = HEAP16[ptr + i * 2 >> 1];
|
|
2031
|
+
if (codeUnit == 0)
|
|
2032
|
+
break;
|
|
2033
|
+
str += String.fromCharCode(codeUnit);
|
|
2034
|
+
} return str; };
|
|
2035
|
+
var stringToUTF16 = (str, outPtr, maxBytesToWrite) => { maxBytesToWrite ??= 2147483647; if (maxBytesToWrite < 2)
|
|
2036
|
+
return 0; maxBytesToWrite -= 2; var startPtr = outPtr; var numCharsToWrite = maxBytesToWrite < str.length * 2 ? maxBytesToWrite / 2 : str.length; for (var i = 0; i < numCharsToWrite; ++i) {
|
|
2037
|
+
var codeUnit = str.charCodeAt(i);
|
|
2038
|
+
HEAP16[outPtr >> 1] = codeUnit;
|
|
2039
|
+
outPtr += 2;
|
|
2040
|
+
} HEAP16[outPtr >> 1] = 0; return outPtr - startPtr; };
|
|
2041
|
+
var lengthBytesUTF16 = str => str.length * 2;
|
|
2042
|
+
var UTF32ToString = (ptr, maxBytesToRead) => { var i = 0; var str = ""; while (!(i >= maxBytesToRead / 4)) {
|
|
2043
|
+
var utf32 = HEAP32[ptr + i * 4 >> 2];
|
|
2044
|
+
if (utf32 == 0)
|
|
2045
|
+
break;
|
|
2046
|
+
++i;
|
|
2047
|
+
if (utf32 >= 65536) {
|
|
2048
|
+
var ch = utf32 - 65536;
|
|
2049
|
+
str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
|
|
2050
|
+
}
|
|
2051
|
+
else {
|
|
2052
|
+
str += String.fromCharCode(utf32);
|
|
2053
|
+
}
|
|
2054
|
+
} return str; };
|
|
2055
|
+
var stringToUTF32 = (str, outPtr, maxBytesToWrite) => { maxBytesToWrite ??= 2147483647; if (maxBytesToWrite < 4)
|
|
2056
|
+
return 0; var startPtr = outPtr; var endPtr = startPtr + maxBytesToWrite - 4; for (var i = 0; i < str.length; ++i) {
|
|
2057
|
+
var codeUnit = str.charCodeAt(i);
|
|
2058
|
+
if (codeUnit >= 55296 && codeUnit <= 57343) {
|
|
2059
|
+
var trailSurrogate = str.charCodeAt(++i);
|
|
2060
|
+
codeUnit = 65536 + ((codeUnit & 1023) << 10) | trailSurrogate & 1023;
|
|
2061
|
+
}
|
|
2062
|
+
HEAP32[outPtr >> 2] = codeUnit;
|
|
2063
|
+
outPtr += 4;
|
|
2064
|
+
if (outPtr + 4 > endPtr)
|
|
2065
|
+
break;
|
|
2066
|
+
} HEAP32[outPtr >> 2] = 0; return outPtr - startPtr; };
|
|
2067
|
+
var lengthBytesUTF32 = str => { var len = 0; for (var i = 0; i < str.length; ++i) {
|
|
2068
|
+
var codeUnit = str.charCodeAt(i);
|
|
2069
|
+
if (codeUnit >= 55296 && codeUnit <= 57343)
|
|
2070
|
+
++i;
|
|
2071
|
+
len += 4;
|
|
2072
|
+
} return len; };
|
|
2073
|
+
var __embind_register_std_wstring = (rawType, charSize, name) => { name = readLatin1String(name); var decodeString, encodeString, readCharAt, lengthBytesUTF; if (charSize === 2) {
|
|
2074
|
+
decodeString = UTF16ToString;
|
|
2075
|
+
encodeString = stringToUTF16;
|
|
2076
|
+
lengthBytesUTF = lengthBytesUTF16;
|
|
2077
|
+
readCharAt = pointer => HEAPU16[pointer >> 1];
|
|
2078
|
+
}
|
|
2079
|
+
else if (charSize === 4) {
|
|
2080
|
+
decodeString = UTF32ToString;
|
|
2081
|
+
encodeString = stringToUTF32;
|
|
2082
|
+
lengthBytesUTF = lengthBytesUTF32;
|
|
2083
|
+
readCharAt = pointer => HEAPU32[pointer >> 2];
|
|
2084
|
+
} registerType(rawType, { name, fromWireType: value => { var length = HEAPU32[value >> 2]; var str; var decodeStartPtr = value + 4; for (var i = 0; i <= length; ++i) {
|
|
2085
|
+
var currentBytePtr = value + 4 + i * charSize;
|
|
2086
|
+
if (i == length || readCharAt(currentBytePtr) == 0) {
|
|
2087
|
+
var maxReadBytes = currentBytePtr - decodeStartPtr;
|
|
2088
|
+
var stringSegment = decodeString(decodeStartPtr, maxReadBytes);
|
|
2089
|
+
if (str === undefined) {
|
|
2090
|
+
str = stringSegment;
|
|
2091
|
+
}
|
|
2092
|
+
else {
|
|
2093
|
+
str += String.fromCharCode(0);
|
|
2094
|
+
str += stringSegment;
|
|
2095
|
+
}
|
|
2096
|
+
decodeStartPtr = currentBytePtr + charSize;
|
|
2097
|
+
}
|
|
2098
|
+
} _free(value); return str; }, toWireType: (destructors, value) => { if (!(typeof value == "string")) {
|
|
2099
|
+
throwBindingError(`Cannot pass non-string to C++ string type ${name}`);
|
|
2100
|
+
} var length = lengthBytesUTF(value); var ptr = _malloc(4 + length + charSize); HEAPU32[ptr >> 2] = length / charSize; encodeString(value, ptr + 4, length + charSize); if (destructors !== null) {
|
|
2101
|
+
destructors.push(_free, ptr);
|
|
2102
|
+
} return ptr; }, argPackAdvance: GenericWireTypeSize, readValueFromPointer: readPointer, destructorFunction(ptr) { _free(ptr); } }); };
|
|
2103
|
+
var __embind_register_void = (rawType, name) => { name = readLatin1String(name); registerType(rawType, { isVoid: true, name, argPackAdvance: 0, fromWireType: () => undefined, toWireType: (destructors, o) => undefined }); };
|
|
2104
|
+
var getExecutableName = () => thisProgram || "./this.program";
|
|
2105
|
+
var __emscripten_get_progname = (str, len) => stringToUTF8(getExecutableName(), str, len);
|
|
2106
|
+
var runtimeKeepaliveCounter = 0;
|
|
2107
|
+
var __emscripten_runtime_keepalive_clear = () => { noExitRuntime = false; runtimeKeepaliveCounter = 0; };
|
|
2108
|
+
var emval_symbols = {};
|
|
2109
|
+
var getStringOrSymbol = address => { var symbol = emval_symbols[address]; if (symbol === undefined) {
|
|
2110
|
+
return readLatin1String(address);
|
|
2111
|
+
} return symbol; };
|
|
2112
|
+
var emval_methodCallers = [];
|
|
2113
|
+
var __emval_call_method = (caller, objHandle, methodName, destructorsRef, args) => { caller = emval_methodCallers[caller]; objHandle = Emval.toValue(objHandle); methodName = getStringOrSymbol(methodName); return caller(objHandle, objHandle[methodName], destructorsRef, args); };
|
|
2114
|
+
var emval_addMethodCaller = caller => { var id = emval_methodCallers.length; emval_methodCallers.push(caller); return id; };
|
|
2115
|
+
var emval_lookupTypes = (argCount, argTypes) => { var a = new Array(argCount); for (var i = 0; i < argCount; ++i) {
|
|
2116
|
+
a[i] = requireRegisteredType(HEAPU32[argTypes + i * 4 >> 2], "parameter " + i);
|
|
2117
|
+
} return a; };
|
|
2118
|
+
var reflectConstruct = Reflect.construct;
|
|
2119
|
+
var emval_returnValue = (returnType, destructorsRef, handle) => { var destructors = []; var result = returnType["toWireType"](destructors, handle); if (destructors.length) {
|
|
2120
|
+
HEAPU32[destructorsRef >> 2] = Emval.toHandle(destructors);
|
|
2121
|
+
} return result; };
|
|
2122
|
+
var __emval_get_method_caller = (argCount, argTypes, kind) => { var types = emval_lookupTypes(argCount, argTypes); var retType = types.shift(); argCount--; var functionBody = `return function (obj, func, destructorsRef, args) {\n`; var offset = 0; var argsList = []; if (kind === 0) {
|
|
2123
|
+
argsList.push("obj");
|
|
2124
|
+
} var params = ["retType"]; var args = [retType]; for (var i = 0; i < argCount; ++i) {
|
|
2125
|
+
argsList.push("arg" + i);
|
|
2126
|
+
params.push("argType" + i);
|
|
2127
|
+
args.push(types[i]);
|
|
2128
|
+
functionBody += ` var arg${i} = argType${i}.readValueFromPointer(args${offset ? "+" + offset : ""});\n`;
|
|
2129
|
+
offset += types[i].argPackAdvance;
|
|
2130
|
+
} var invoker = kind === 1 ? "new func" : "func.call"; functionBody += ` var rv = ${invoker}(${argsList.join(", ")});\n`; if (!retType.isVoid) {
|
|
2131
|
+
params.push("emval_returnValue");
|
|
2132
|
+
args.push(emval_returnValue);
|
|
2133
|
+
functionBody += " return emval_returnValue(retType, destructorsRef, rv);\n";
|
|
2134
|
+
} functionBody += "};\n"; params.push(functionBody); var invokerFunction = newFunc(Function, params)(...args); var functionName = `methodCaller<(${types.map(t => t.name).join(", ")}) => ${retType.name}>`; return emval_addMethodCaller(createNamedFunction(functionName, invokerFunction)); };
|
|
2135
|
+
var __emval_incref = handle => { if (handle > 9) {
|
|
2136
|
+
emval_handles[handle + 1] += 1;
|
|
2137
|
+
} };
|
|
2138
|
+
var __emval_new_array = () => Emval.toHandle([]);
|
|
2139
|
+
var __emval_new_cstring = v => Emval.toHandle(getStringOrSymbol(v));
|
|
2140
|
+
var __emval_new_object = () => Emval.toHandle({});
|
|
2141
|
+
var __emval_run_destructors = handle => { var destructors = Emval.toValue(handle); runDestructors(destructors); __emval_decref(handle); };
|
|
2142
|
+
var __emval_set_property = (handle, key, value) => { handle = Emval.toValue(handle); key = Emval.toValue(key); value = Emval.toValue(value); handle[key] = value; };
|
|
2143
|
+
var __emval_take_value = (type, arg) => { type = requireRegisteredType(type, "_emval_take_value"); var v = type["readValueFromPointer"](arg); return Emval.toHandle(v); };
|
|
2144
|
+
var INT53_MAX = 9007199254740992;
|
|
2145
|
+
var INT53_MIN = -9007199254740992;
|
|
2146
|
+
var bigintToI53Checked = num => num < INT53_MIN || num > INT53_MAX ? NaN : Number(num);
|
|
2147
|
+
function __gmtime_js(time, tmPtr) { time = bigintToI53Checked(time); var date = new Date(time * 1e3); HEAP32[tmPtr >> 2] = date.getUTCSeconds(); HEAP32[tmPtr + 4 >> 2] = date.getUTCMinutes(); HEAP32[tmPtr + 8 >> 2] = date.getUTCHours(); HEAP32[tmPtr + 12 >> 2] = date.getUTCDate(); HEAP32[tmPtr + 16 >> 2] = date.getUTCMonth(); HEAP32[tmPtr + 20 >> 2] = date.getUTCFullYear() - 1900; HEAP32[tmPtr + 24 >> 2] = date.getUTCDay(); var start = Date.UTC(date.getUTCFullYear(), 0, 1, 0, 0, 0, 0); var yday = (date.getTime() - start) / (1e3 * 60 * 60 * 24) | 0; HEAP32[tmPtr + 28 >> 2] = yday; }
|
|
2148
|
+
var isLeapYear = year => year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
|
|
2149
|
+
var MONTH_DAYS_LEAP_CUMULATIVE = [0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335];
|
|
2150
|
+
var MONTH_DAYS_REGULAR_CUMULATIVE = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334];
|
|
2151
|
+
var ydayFromDate = date => { var leap = isLeapYear(date.getFullYear()); var monthDaysCumulative = leap ? MONTH_DAYS_LEAP_CUMULATIVE : MONTH_DAYS_REGULAR_CUMULATIVE; var yday = monthDaysCumulative[date.getMonth()] + date.getDate() - 1; return yday; };
|
|
2152
|
+
function __localtime_js(time, tmPtr) { time = bigintToI53Checked(time); var date = new Date(time * 1e3); HEAP32[tmPtr >> 2] = date.getSeconds(); HEAP32[tmPtr + 4 >> 2] = date.getMinutes(); HEAP32[tmPtr + 8 >> 2] = date.getHours(); HEAP32[tmPtr + 12 >> 2] = date.getDate(); HEAP32[tmPtr + 16 >> 2] = date.getMonth(); HEAP32[tmPtr + 20 >> 2] = date.getFullYear() - 1900; HEAP32[tmPtr + 24 >> 2] = date.getDay(); var yday = ydayFromDate(date) | 0; HEAP32[tmPtr + 28 >> 2] = yday; HEAP32[tmPtr + 36 >> 2] = -(date.getTimezoneOffset() * 60); var start = new Date(date.getFullYear(), 0, 1); var summerOffset = new Date(date.getFullYear(), 6, 1).getTimezoneOffset(); var winterOffset = start.getTimezoneOffset(); var dst = (summerOffset != winterOffset && date.getTimezoneOffset() == Math.min(winterOffset, summerOffset)) | 0; HEAP32[tmPtr + 32 >> 2] = dst; }
|
|
2153
|
+
var __mktime_js = function (tmPtr) { var ret = (() => { var date = new Date(HEAP32[tmPtr + 20 >> 2] + 1900, HEAP32[tmPtr + 16 >> 2], HEAP32[tmPtr + 12 >> 2], HEAP32[tmPtr + 8 >> 2], HEAP32[tmPtr + 4 >> 2], HEAP32[tmPtr >> 2], 0); var dst = HEAP32[tmPtr + 32 >> 2]; var guessedOffset = date.getTimezoneOffset(); var start = new Date(date.getFullYear(), 0, 1); var summerOffset = new Date(date.getFullYear(), 6, 1).getTimezoneOffset(); var winterOffset = start.getTimezoneOffset(); var dstOffset = Math.min(winterOffset, summerOffset); if (dst < 0) {
|
|
2154
|
+
HEAP32[tmPtr + 32 >> 2] = Number(summerOffset != winterOffset && dstOffset == guessedOffset);
|
|
2155
|
+
}
|
|
2156
|
+
else if (dst > 0 != (dstOffset == guessedOffset)) {
|
|
2157
|
+
var nonDstOffset = Math.max(winterOffset, summerOffset);
|
|
2158
|
+
var trueOffset = dst > 0 ? dstOffset : nonDstOffset;
|
|
2159
|
+
date.setTime(date.getTime() + (trueOffset - guessedOffset) * 6e4);
|
|
2160
|
+
} HEAP32[tmPtr + 24 >> 2] = date.getDay(); var yday = ydayFromDate(date) | 0; HEAP32[tmPtr + 28 >> 2] = yday; HEAP32[tmPtr >> 2] = date.getSeconds(); HEAP32[tmPtr + 4 >> 2] = date.getMinutes(); HEAP32[tmPtr + 8 >> 2] = date.getHours(); HEAP32[tmPtr + 12 >> 2] = date.getDate(); HEAP32[tmPtr + 16 >> 2] = date.getMonth(); HEAP32[tmPtr + 20 >> 2] = date.getYear(); var timeMs = date.getTime(); if (isNaN(timeMs)) {
|
|
2161
|
+
return -1;
|
|
2162
|
+
} return timeMs / 1e3; })(); return BigInt(ret); };
|
|
2163
|
+
var timers = {};
|
|
2164
|
+
var handleException = e => { if (e instanceof ExitStatus || e == "unwind") {
|
|
2165
|
+
return EXITSTATUS;
|
|
2166
|
+
} quit_(1, e); };
|
|
2167
|
+
var keepRuntimeAlive = () => noExitRuntime || runtimeKeepaliveCounter > 0;
|
|
2168
|
+
var _proc_exit = code => { EXITSTATUS = code; if (!keepRuntimeAlive()) {
|
|
2169
|
+
Module["onExit"]?.(code);
|
|
2170
|
+
ABORT = true;
|
|
2171
|
+
} quit_(code, new ExitStatus(code)); };
|
|
2172
|
+
var exitJS = (status, implicit) => { EXITSTATUS = status; _proc_exit(status); };
|
|
2173
|
+
var _exit = exitJS;
|
|
2174
|
+
var maybeExit = () => { if (!keepRuntimeAlive()) {
|
|
2175
|
+
try {
|
|
2176
|
+
_exit(EXITSTATUS);
|
|
2177
|
+
}
|
|
2178
|
+
catch (e) {
|
|
2179
|
+
handleException(e);
|
|
2180
|
+
}
|
|
2181
|
+
} };
|
|
2182
|
+
var callUserCallback = func => { if (ABORT) {
|
|
2183
|
+
return;
|
|
2184
|
+
} try {
|
|
2185
|
+
func();
|
|
2186
|
+
maybeExit();
|
|
2187
|
+
}
|
|
2188
|
+
catch (e) {
|
|
2189
|
+
handleException(e);
|
|
2190
|
+
} };
|
|
2191
|
+
var _emscripten_get_now = () => performance.now();
|
|
2192
|
+
var __setitimer_js = (which, timeout_ms) => { if (timers[which]) {
|
|
2193
|
+
clearTimeout(timers[which].id);
|
|
2194
|
+
delete timers[which];
|
|
2195
|
+
} if (!timeout_ms)
|
|
2196
|
+
return 0; var id = setTimeout(() => { delete timers[which]; callUserCallback(() => __emscripten_timeout(which, _emscripten_get_now())); }, timeout_ms); timers[which] = { id, timeout_ms }; return 0; };
|
|
2197
|
+
var __tzset_js = (timezone, daylight, std_name, dst_name) => { var currentYear = (new Date).getFullYear(); var winter = new Date(currentYear, 0, 1); var summer = new Date(currentYear, 6, 1); var winterOffset = winter.getTimezoneOffset(); var summerOffset = summer.getTimezoneOffset(); var stdTimezoneOffset = Math.max(winterOffset, summerOffset); HEAPU32[timezone >> 2] = stdTimezoneOffset * 60; HEAP32[daylight >> 2] = Number(winterOffset != summerOffset); var extractZone = timezoneOffset => { var sign = timezoneOffset >= 0 ? "-" : "+"; var absOffset = Math.abs(timezoneOffset); var hours = String(Math.floor(absOffset / 60)).padStart(2, "0"); var minutes = String(absOffset % 60).padStart(2, "0"); return `UTC${sign}${hours}${minutes}`; }; var winterName = extractZone(winterOffset); var summerName = extractZone(summerOffset); if (summerOffset < winterOffset) {
|
|
2198
|
+
stringToUTF8(winterName, std_name, 17);
|
|
2199
|
+
stringToUTF8(summerName, dst_name, 17);
|
|
2200
|
+
}
|
|
2201
|
+
else {
|
|
2202
|
+
stringToUTF8(winterName, dst_name, 17);
|
|
2203
|
+
stringToUTF8(summerName, std_name, 17);
|
|
2204
|
+
} };
|
|
2205
|
+
var _emscripten_date_now = () => Date.now();
|
|
2206
|
+
var getHeapMax = () => 2147483648;
|
|
2207
|
+
var growMemory = size => { var b = wasmMemory.buffer; var pages = (size - b.byteLength + 65535) / 65536 | 0; try {
|
|
2208
|
+
wasmMemory.grow(pages);
|
|
2209
|
+
updateMemoryViews();
|
|
2210
|
+
return 1;
|
|
2211
|
+
}
|
|
2212
|
+
catch (e) { } };
|
|
2213
|
+
var _emscripten_resize_heap = requestedSize => { var oldSize = HEAPU8.length; requestedSize >>>= 0; var maxHeapSize = getHeapMax(); if (requestedSize > maxHeapSize) {
|
|
2214
|
+
return false;
|
|
2215
|
+
} for (var cutDown = 1; cutDown <= 4; cutDown *= 2) {
|
|
2216
|
+
var overGrownHeapSize = oldSize * (1 + .2 / cutDown);
|
|
2217
|
+
overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296);
|
|
2218
|
+
var newSize = Math.min(maxHeapSize, alignMemory(Math.max(requestedSize, overGrownHeapSize), 65536));
|
|
2219
|
+
var replacement = growMemory(newSize);
|
|
2220
|
+
if (replacement) {
|
|
2221
|
+
return true;
|
|
2222
|
+
}
|
|
2223
|
+
} return false; };
|
|
2224
|
+
var ENV = {};
|
|
2225
|
+
var getEnvStrings = () => { if (!getEnvStrings.strings) {
|
|
2226
|
+
var lang = (typeof navigator == "object" && navigator.languages && navigator.languages[0] || "C").replace("-", "_") + ".UTF-8";
|
|
2227
|
+
var env = { USER: "web_user", LOGNAME: "web_user", PATH: "/", PWD: "/", HOME: "/home/web_user", LANG: lang, _: getExecutableName() };
|
|
2228
|
+
for (var x in ENV) {
|
|
2229
|
+
if (ENV[x] === undefined)
|
|
2230
|
+
delete env[x];
|
|
2231
|
+
else
|
|
2232
|
+
env[x] = ENV[x];
|
|
2233
|
+
}
|
|
2234
|
+
var strings = [];
|
|
2235
|
+
for (var x in env) {
|
|
2236
|
+
strings.push(`${x}=${env[x]}`);
|
|
2237
|
+
}
|
|
2238
|
+
getEnvStrings.strings = strings;
|
|
2239
|
+
} return getEnvStrings.strings; };
|
|
2240
|
+
var stringToAscii = (str, buffer) => { for (var i = 0; i < str.length; ++i) {
|
|
2241
|
+
HEAP8[buffer++] = str.charCodeAt(i);
|
|
2242
|
+
} HEAP8[buffer] = 0; };
|
|
2243
|
+
var _environ_get = (__environ, environ_buf) => { var bufSize = 0; getEnvStrings().forEach((string, i) => { var ptr = environ_buf + bufSize; HEAPU32[__environ + i * 4 >> 2] = ptr; stringToAscii(string, ptr); bufSize += string.length + 1; }); return 0; };
|
|
2244
|
+
var _environ_sizes_get = (penviron_count, penviron_buf_size) => { var strings = getEnvStrings(); HEAPU32[penviron_count >> 2] = strings.length; var bufSize = 0; strings.forEach(string => bufSize += string.length + 1); HEAPU32[penviron_buf_size >> 2] = bufSize; return 0; };
|
|
2245
|
+
function _fd_close(fd) { try {
|
|
2246
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2247
|
+
FS.close(stream);
|
|
2248
|
+
return 0;
|
|
2249
|
+
}
|
|
2250
|
+
catch (e) {
|
|
2251
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
2252
|
+
throw e;
|
|
2253
|
+
return e.errno;
|
|
2254
|
+
} }
|
|
2255
|
+
var doReadv = (stream, iov, iovcnt, offset) => { var ret = 0; for (var i = 0; i < iovcnt; i++) {
|
|
2256
|
+
var ptr = HEAPU32[iov >> 2];
|
|
2257
|
+
var len = HEAPU32[iov + 4 >> 2];
|
|
2258
|
+
iov += 8;
|
|
2259
|
+
var curr = FS.read(stream, HEAP8, ptr, len, offset);
|
|
2260
|
+
if (curr < 0)
|
|
2261
|
+
return -1;
|
|
2262
|
+
ret += curr;
|
|
2263
|
+
if (curr < len)
|
|
2264
|
+
break;
|
|
2265
|
+
if (typeof offset != "undefined") {
|
|
2266
|
+
offset += curr;
|
|
2267
|
+
}
|
|
2268
|
+
} return ret; };
|
|
2269
|
+
function _fd_read(fd, iov, iovcnt, pnum) { try {
|
|
2270
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2271
|
+
var num = doReadv(stream, iov, iovcnt);
|
|
2272
|
+
HEAPU32[pnum >> 2] = num;
|
|
2273
|
+
return 0;
|
|
2274
|
+
}
|
|
2275
|
+
catch (e) {
|
|
2276
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
2277
|
+
throw e;
|
|
2278
|
+
return e.errno;
|
|
2279
|
+
} }
|
|
2280
|
+
function _fd_seek(fd, offset, whence, newOffset) { offset = bigintToI53Checked(offset); try {
|
|
2281
|
+
if (isNaN(offset))
|
|
2282
|
+
return 61;
|
|
2283
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2284
|
+
FS.llseek(stream, offset, whence);
|
|
2285
|
+
HEAP64[newOffset >> 3] = BigInt(stream.position);
|
|
2286
|
+
if (stream.getdents && offset === 0 && whence === 0)
|
|
2287
|
+
stream.getdents = null;
|
|
2288
|
+
return 0;
|
|
2289
|
+
}
|
|
2290
|
+
catch (e) {
|
|
2291
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
2292
|
+
throw e;
|
|
2293
|
+
return e.errno;
|
|
2294
|
+
} }
|
|
2295
|
+
var doWritev = (stream, iov, iovcnt, offset) => { var ret = 0; for (var i = 0; i < iovcnt; i++) {
|
|
2296
|
+
var ptr = HEAPU32[iov >> 2];
|
|
2297
|
+
var len = HEAPU32[iov + 4 >> 2];
|
|
2298
|
+
iov += 8;
|
|
2299
|
+
var curr = FS.write(stream, HEAP8, ptr, len, offset);
|
|
2300
|
+
if (curr < 0)
|
|
2301
|
+
return -1;
|
|
2302
|
+
ret += curr;
|
|
2303
|
+
if (curr < len) {
|
|
2304
|
+
break;
|
|
2305
|
+
}
|
|
2306
|
+
if (typeof offset != "undefined") {
|
|
2307
|
+
offset += curr;
|
|
2308
|
+
}
|
|
2309
|
+
} return ret; };
|
|
2310
|
+
function _fd_write(fd, iov, iovcnt, pnum) { try {
|
|
2311
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2312
|
+
var num = doWritev(stream, iov, iovcnt);
|
|
2313
|
+
HEAPU32[pnum >> 2] = num;
|
|
2314
|
+
return 0;
|
|
2315
|
+
}
|
|
2316
|
+
catch (e) {
|
|
2317
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError"))
|
|
2318
|
+
throw e;
|
|
2319
|
+
return e.errno;
|
|
2320
|
+
} }
|
|
2321
|
+
var getCFunc = ident => { var func = Module["_" + ident]; return func; };
|
|
2322
|
+
var writeArrayToMemory = (array, buffer) => { HEAP8.set(array, buffer); };
|
|
2323
|
+
var stackAlloc = sz => __emscripten_stack_alloc(sz);
|
|
2324
|
+
var stringToUTF8OnStack = str => { var size = lengthBytesUTF8(str) + 1; var ret = stackAlloc(size); stringToUTF8(str, ret, size); return ret; };
|
|
2325
|
+
var ccall = (ident, returnType, argTypes, args, opts) => { var toC = { string: str => { var ret = 0; if (str !== null && str !== undefined && str !== 0) {
|
|
2326
|
+
ret = stringToUTF8OnStack(str);
|
|
2327
|
+
} return ret; }, array: arr => { var ret = stackAlloc(arr.length); writeArrayToMemory(arr, ret); return ret; } }; function convertReturnValue(ret) { if (returnType === "string") {
|
|
2328
|
+
return UTF8ToString(ret);
|
|
2329
|
+
} if (returnType === "boolean")
|
|
2330
|
+
return Boolean(ret); return ret; } var func = getCFunc(ident); var cArgs = []; var stack = 0; if (args) {
|
|
2331
|
+
for (var i = 0; i < args.length; i++) {
|
|
2332
|
+
var converter = toC[argTypes[i]];
|
|
2333
|
+
if (converter) {
|
|
2334
|
+
if (stack === 0)
|
|
2335
|
+
stack = stackSave();
|
|
2336
|
+
cArgs[i] = converter(args[i]);
|
|
2337
|
+
}
|
|
2338
|
+
else {
|
|
2339
|
+
cArgs[i] = args[i];
|
|
2340
|
+
}
|
|
2341
|
+
}
|
|
2342
|
+
} var ret = func(...cArgs); function onDone(ret) { if (stack !== 0)
|
|
2343
|
+
stackRestore(stack); return convertReturnValue(ret); } ret = onDone(ret); return ret; };
|
|
2344
|
+
var cwrap = (ident, returnType, argTypes, opts) => { var numericArgs = !argTypes || argTypes.every(type => type === "number" || type === "boolean"); var numericRet = returnType !== "string"; if (numericRet && numericArgs && !opts) {
|
|
2345
|
+
return getCFunc(ident);
|
|
2346
|
+
} return (...args) => ccall(ident, returnType, argTypes, args, opts); };
|
|
2347
|
+
var stringToNewUTF8 = str => { var size = lengthBytesUTF8(str) + 1; var ret = _malloc(size); if (ret)
|
|
2348
|
+
stringToUTF8(str, ret, size); return ret; };
|
|
2349
|
+
var setTempRet0 = val => __emscripten_tempret_set(val);
|
|
2350
|
+
var _setTempRet0 = setTempRet0;
|
|
2351
|
+
Module["_setTempRet0"] = _setTempRet0;
|
|
2352
|
+
var getTempRet0 = val => __emscripten_tempret_get();
|
|
2353
|
+
var _getTempRet0 = getTempRet0;
|
|
2354
|
+
Module["_getTempRet0"] = _getTempRet0;
|
|
2355
|
+
var ___cxa_uncaught_exceptions = () => uncaughtExceptionCount;
|
|
2356
|
+
Module["___cxa_uncaught_exceptions"] = ___cxa_uncaught_exceptions;
|
|
2357
|
+
var exceptionCaught = [];
|
|
2358
|
+
var ___cxa_current_primary_exception = () => { if (!exceptionCaught.length) {
|
|
2359
|
+
return 0;
|
|
2360
|
+
} var info = exceptionCaught[exceptionCaught.length - 1]; ___cxa_increment_exception_refcount(info.excPtr); return info.excPtr; };
|
|
2361
|
+
Module["___cxa_current_primary_exception"] = ___cxa_current_primary_exception;
|
|
2362
|
+
var ___cxa_rethrow = () => { var info = exceptionCaught.pop(); if (!info) {
|
|
2363
|
+
abort("no exception to throw");
|
|
2364
|
+
} var ptr = info.excPtr; if (!info.get_rethrown()) {
|
|
2365
|
+
exceptionCaught.push(info);
|
|
2366
|
+
info.set_rethrown(true);
|
|
2367
|
+
info.set_caught(false);
|
|
2368
|
+
uncaughtExceptionCount++;
|
|
2369
|
+
} exceptionLast = ptr; throw exceptionLast; };
|
|
2370
|
+
var ___cxa_rethrow_primary_exception = ptr => { if (!ptr)
|
|
2371
|
+
return; var info = new ExceptionInfo(ptr); exceptionCaught.push(info); info.set_rethrown(true); ___cxa_rethrow(); };
|
|
2372
|
+
Module["___cxa_rethrow_primary_exception"] = ___cxa_rethrow_primary_exception;
|
|
2373
|
+
FS.createPreloadedFile = FS_createPreloadedFile;
|
|
2374
|
+
FS.staticInit();
|
|
2375
|
+
MEMFS.doesNotExistError = new FS.ErrnoError(44);
|
|
2376
|
+
MEMFS.doesNotExistError.stack = "<generic error, no stack>";
|
|
2377
|
+
embind_init_charCodes();
|
|
2378
|
+
BindingError = Module["BindingError"] = class BindingError extends Error {
|
|
2379
|
+
constructor(message) { super(message); this.name = "BindingError"; }
|
|
2380
|
+
};
|
|
2381
|
+
InternalError = Module["InternalError"] = class InternalError extends Error {
|
|
2382
|
+
constructor(message) { super(message); this.name = "InternalError"; }
|
|
2383
|
+
};
|
|
2384
|
+
init_ClassHandle();
|
|
2385
|
+
init_RegisteredPointer();
|
|
2386
|
+
UnboundTypeError = Module["UnboundTypeError"] = extendError(Error, "UnboundTypeError");
|
|
2387
|
+
init_emval();
|
|
2388
|
+
var wasmImports = { __assert_fail: ___assert_fail, __call_sighandler: ___call_sighandler, __cxa_throw: ___cxa_throw, __syscall_fcntl64: ___syscall_fcntl64, __syscall_fstat64: ___syscall_fstat64, __syscall_ioctl: ___syscall_ioctl, __syscall_lstat64: ___syscall_lstat64, __syscall_newfstatat: ___syscall_newfstatat, __syscall_openat: ___syscall_openat, __syscall_stat64: ___syscall_stat64, _abort_js: __abort_js, _embind_register_bigint: __embind_register_bigint, _embind_register_bool: __embind_register_bool, _embind_register_class: __embind_register_class, _embind_register_class_property: __embind_register_class_property, _embind_register_emval: __embind_register_emval, _embind_register_enum: __embind_register_enum, _embind_register_enum_value: __embind_register_enum_value, _embind_register_float: __embind_register_float, _embind_register_function: __embind_register_function, _embind_register_integer: __embind_register_integer, _embind_register_memory_view: __embind_register_memory_view, _embind_register_std_string: __embind_register_std_string, _embind_register_std_wstring: __embind_register_std_wstring, _embind_register_void: __embind_register_void, _emscripten_get_progname: __emscripten_get_progname, _emscripten_runtime_keepalive_clear: __emscripten_runtime_keepalive_clear, _emval_call_method: __emval_call_method, _emval_decref: __emval_decref, _emval_get_method_caller: __emval_get_method_caller, _emval_incref: __emval_incref, _emval_new_array: __emval_new_array, _emval_new_cstring: __emval_new_cstring, _emval_new_object: __emval_new_object, _emval_run_destructors: __emval_run_destructors, _emval_set_property: __emval_set_property, _emval_take_value: __emval_take_value, _gmtime_js: __gmtime_js, _localtime_js: __localtime_js, _mktime_js: __mktime_js, _setitimer_js: __setitimer_js, _tzset_js: __tzset_js, emscripten_date_now: _emscripten_date_now, emscripten_resize_heap: _emscripten_resize_heap, environ_get: _environ_get, environ_sizes_get: _environ_sizes_get, fd_close: _fd_close, fd_read: _fd_read, fd_seek: _fd_seek, fd_write: _fd_write, proc_exit: _proc_exit };
|
|
2389
|
+
var wasmExports = await createWasm();
|
|
2390
|
+
var ___wasm_call_ctors = wasmExports["__wasm_call_ctors"];
|
|
2391
|
+
var _malloc = wasmExports["malloc"];
|
|
2392
|
+
var _free = wasmExports["free"];
|
|
2393
|
+
var _memcmp = wasmExports["memcmp"];
|
|
2394
|
+
var _calloc = wasmExports["calloc"];
|
|
2395
|
+
var _realloc = wasmExports["realloc"];
|
|
2396
|
+
var ___errno_location = wasmExports["__errno_location"];
|
|
2397
|
+
var _fileno = wasmExports["fileno"];
|
|
2398
|
+
var ___getTypeName = wasmExports["__getTypeName"];
|
|
2399
|
+
var __emval_coro_resume = wasmExports["_emval_coro_resume"];
|
|
2400
|
+
var _memcpy = wasmExports["memcpy"];
|
|
2401
|
+
var _htonl = wasmExports["htonl"];
|
|
2402
|
+
var _htons = wasmExports["htons"];
|
|
2403
|
+
var _ntohs = wasmExports["ntohs"];
|
|
2404
|
+
var __emscripten_timeout = wasmExports["_emscripten_timeout"];
|
|
2405
|
+
var _strerror = wasmExports["strerror"];
|
|
2406
|
+
var _emscripten_builtin_memalign = wasmExports["emscripten_builtin_memalign"];
|
|
2407
|
+
var _setThrew = wasmExports["setThrew"];
|
|
2408
|
+
var __emscripten_tempret_set = wasmExports["_emscripten_tempret_set"];
|
|
2409
|
+
var __emscripten_tempret_get = wasmExports["_emscripten_tempret_get"];
|
|
2410
|
+
var __emscripten_stack_restore = wasmExports["_emscripten_stack_restore"];
|
|
2411
|
+
var __emscripten_stack_alloc = wasmExports["_emscripten_stack_alloc"];
|
|
2412
|
+
var _emscripten_stack_get_current = wasmExports["emscripten_stack_get_current"];
|
|
2413
|
+
var ___cxa_decrement_exception_refcount = wasmExports["__cxa_decrement_exception_refcount"];
|
|
2414
|
+
var ___cxa_increment_exception_refcount = wasmExports["__cxa_increment_exception_refcount"];
|
|
2415
|
+
var ___cxa_demangle = wasmExports["__cxa_demangle"];
|
|
2416
|
+
var ___cxa_can_catch = wasmExports["__cxa_can_catch"];
|
|
2417
|
+
var ___cxa_get_exception_ptr = wasmExports["__cxa_get_exception_ptr"];
|
|
2418
|
+
Module["ENV"] = ENV;
|
|
2419
|
+
Module["ccall"] = ccall;
|
|
2420
|
+
Module["cwrap"] = cwrap;
|
|
2421
|
+
Module["setValue"] = setValue;
|
|
2422
|
+
Module["UTF8ToString"] = UTF8ToString;
|
|
2423
|
+
Module["stringToNewUTF8"] = stringToNewUTF8;
|
|
2424
|
+
Module["FS"] = FS;
|
|
2425
|
+
function run() { if (runDependencies > 0) {
|
|
2426
|
+
dependenciesFulfilled = run;
|
|
2427
|
+
return;
|
|
2428
|
+
} preRun(); if (runDependencies > 0) {
|
|
2429
|
+
dependenciesFulfilled = run;
|
|
2430
|
+
return;
|
|
2431
|
+
} function doRun() { Module["calledRun"] = true; if (ABORT)
|
|
2432
|
+
return; initRuntime(); readyPromiseResolve(Module); Module["onRuntimeInitialized"]?.(); postRun(); } if (Module["setStatus"]) {
|
|
2433
|
+
Module["setStatus"]("Running...");
|
|
2434
|
+
setTimeout(() => { setTimeout(() => Module["setStatus"](""), 1); doRun(); }, 1);
|
|
2435
|
+
}
|
|
2436
|
+
else {
|
|
2437
|
+
doRun();
|
|
2438
|
+
} }
|
|
2439
|
+
if (Module["preInit"]) {
|
|
2440
|
+
if (typeof Module["preInit"] == "function")
|
|
2441
|
+
Module["preInit"] = [Module["preInit"]];
|
|
2442
|
+
while (Module["preInit"].length > 0) {
|
|
2443
|
+
Module["preInit"].pop()();
|
|
2444
|
+
}
|
|
2445
|
+
}
|
|
2446
|
+
run();
|
|
2447
|
+
moduleRtn = readyPromise;
|
|
2448
|
+
return moduleRtn;
|
|
2449
|
+
});
|
|
2450
|
+
})();
|
|
2451
|
+
export default createModule;
|
|
2452
|
+
//# sourceMappingURL=libredwg-web.js.map
|