@areb0s/scip.js 1.0.5
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 +276 -0
- package/dist/basic.html +445 -0
- package/dist/index.mjs +73 -0
- package/dist/scip-core.js +15 -0
- package/dist/scip-worker-client.js +167 -0
- package/dist/scip-worker.js +81 -0
- package/dist/scip-wrapper.js +429 -0
- package/dist/scip.js +3223 -0
- package/dist/scip.js.map +7 -0
- package/dist/scip.min.js +43 -0
- package/dist/scip.min.js.map +7 -0
- package/dist/scip.wasm +0 -0
- package/dist/test-browser.html +118 -0
- package/dist/test-worker.html +161 -0
- package/dist/types.d.ts +230 -0
- package/package.json +66 -0
package/dist/scip.js
ADDED
|
@@ -0,0 +1,3223 @@
|
|
|
1
|
+
|
|
2
|
+
// Polyfill for import.meta.url in IIFE context (supports Worker)
|
|
3
|
+
var __importMetaUrl = (function() {
|
|
4
|
+
// Worker environment
|
|
5
|
+
if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope) {
|
|
6
|
+
// Check if SCIP_WASM_BASE_URL is defined (user can set this before loading)
|
|
7
|
+
if (typeof SCIP_WASM_BASE_URL !== 'undefined') {
|
|
8
|
+
return SCIP_WASM_BASE_URL;
|
|
9
|
+
}
|
|
10
|
+
// Fallback to self.location
|
|
11
|
+
return self.location.href;
|
|
12
|
+
}
|
|
13
|
+
// Browser main thread
|
|
14
|
+
if (typeof document !== 'undefined') {
|
|
15
|
+
if (document.currentScript && document.currentScript.src) {
|
|
16
|
+
return document.currentScript.src;
|
|
17
|
+
}
|
|
18
|
+
var scripts = document.getElementsByTagName('script');
|
|
19
|
+
for (var i = scripts.length - 1; i >= 0; i--) {
|
|
20
|
+
var src = scripts[i].src;
|
|
21
|
+
if (src && (src.includes('scip') && src.includes('.js'))) {
|
|
22
|
+
return src;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return window.location.href;
|
|
26
|
+
}
|
|
27
|
+
return '';
|
|
28
|
+
})();
|
|
29
|
+
|
|
30
|
+
var SCIPModule = (() => {
|
|
31
|
+
var __defProp = Object.defineProperty;
|
|
32
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
33
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
34
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
35
|
+
var __esm = (fn, res) => function __init() {
|
|
36
|
+
return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
|
|
37
|
+
};
|
|
38
|
+
var __export = (target, all) => {
|
|
39
|
+
for (var name in all)
|
|
40
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
41
|
+
};
|
|
42
|
+
var __copyProps = (to, from, except, desc) => {
|
|
43
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
44
|
+
for (let key of __getOwnPropNames(from))
|
|
45
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
46
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
47
|
+
}
|
|
48
|
+
return to;
|
|
49
|
+
};
|
|
50
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
51
|
+
|
|
52
|
+
// dist/scip-core.js
|
|
53
|
+
var scip_core_exports = {};
|
|
54
|
+
__export(scip_core_exports, {
|
|
55
|
+
default: () => scip_core_default
|
|
56
|
+
});
|
|
57
|
+
var createSCIP, scip_core_default;
|
|
58
|
+
var init_scip_core = __esm({
|
|
59
|
+
"dist/scip-core.js"() {
|
|
60
|
+
createSCIP = /* @__PURE__ */ (() => {
|
|
61
|
+
var _scriptDir = __importMetaUrl;
|
|
62
|
+
return function(moduleArg = {}) {
|
|
63
|
+
var Module = moduleArg;
|
|
64
|
+
var readyPromiseResolve, readyPromiseReject;
|
|
65
|
+
Module["ready"] = new Promise((resolve, reject) => {
|
|
66
|
+
readyPromiseResolve = resolve;
|
|
67
|
+
readyPromiseReject = reject;
|
|
68
|
+
});
|
|
69
|
+
var moduleOverrides = Object.assign({}, Module);
|
|
70
|
+
var arguments_ = [];
|
|
71
|
+
var thisProgram = "./this.program";
|
|
72
|
+
var quit_ = (status, toThrow) => {
|
|
73
|
+
throw toThrow;
|
|
74
|
+
};
|
|
75
|
+
var ENVIRONMENT_IS_WEB = typeof window == "object";
|
|
76
|
+
var ENVIRONMENT_IS_WORKER = typeof importScripts == "function";
|
|
77
|
+
var ENVIRONMENT_IS_NODE = typeof process == "object" && typeof process.versions == "object" && typeof process.versions.node == "string";
|
|
78
|
+
var scriptDirectory = "";
|
|
79
|
+
function locateFile(path) {
|
|
80
|
+
if (Module["locateFile"]) {
|
|
81
|
+
return Module["locateFile"](path, scriptDirectory);
|
|
82
|
+
}
|
|
83
|
+
return scriptDirectory + path;
|
|
84
|
+
}
|
|
85
|
+
var read_, readAsync, readBinary;
|
|
86
|
+
if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
|
|
87
|
+
if (ENVIRONMENT_IS_WORKER) {
|
|
88
|
+
scriptDirectory = self.location.href;
|
|
89
|
+
} else if (typeof document != "undefined" && document.currentScript) {
|
|
90
|
+
scriptDirectory = document.currentScript.src;
|
|
91
|
+
}
|
|
92
|
+
if (_scriptDir) {
|
|
93
|
+
scriptDirectory = _scriptDir;
|
|
94
|
+
}
|
|
95
|
+
if (scriptDirectory.startsWith("blob:")) {
|
|
96
|
+
scriptDirectory = "";
|
|
97
|
+
} else {
|
|
98
|
+
scriptDirectory = scriptDirectory.substr(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf("/") + 1);
|
|
99
|
+
}
|
|
100
|
+
{
|
|
101
|
+
read_ = (url) => {
|
|
102
|
+
var xhr = new XMLHttpRequest();
|
|
103
|
+
xhr.open("GET", url, false);
|
|
104
|
+
xhr.send(null);
|
|
105
|
+
return xhr.responseText;
|
|
106
|
+
};
|
|
107
|
+
if (ENVIRONMENT_IS_WORKER) {
|
|
108
|
+
readBinary = (url) => {
|
|
109
|
+
var xhr = new XMLHttpRequest();
|
|
110
|
+
xhr.open("GET", url, false);
|
|
111
|
+
xhr.responseType = "arraybuffer";
|
|
112
|
+
xhr.send(null);
|
|
113
|
+
return new Uint8Array(xhr.response);
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
readAsync = (url, onload, onerror) => {
|
|
117
|
+
var xhr = new XMLHttpRequest();
|
|
118
|
+
xhr.open("GET", url, true);
|
|
119
|
+
xhr.responseType = "arraybuffer";
|
|
120
|
+
xhr.onload = () => {
|
|
121
|
+
if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
|
|
122
|
+
onload(xhr.response);
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
onerror();
|
|
126
|
+
};
|
|
127
|
+
xhr.onerror = onerror;
|
|
128
|
+
xhr.send(null);
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
} else {
|
|
132
|
+
}
|
|
133
|
+
var out = Module["print"] || console.log.bind(console);
|
|
134
|
+
var err = Module["printErr"] || console.error.bind(console);
|
|
135
|
+
Object.assign(Module, moduleOverrides);
|
|
136
|
+
moduleOverrides = null;
|
|
137
|
+
if (Module["arguments"]) arguments_ = Module["arguments"];
|
|
138
|
+
if (Module["thisProgram"]) thisProgram = Module["thisProgram"];
|
|
139
|
+
if (Module["quit"]) quit_ = Module["quit"];
|
|
140
|
+
var wasmBinary;
|
|
141
|
+
if (Module["wasmBinary"]) wasmBinary = Module["wasmBinary"];
|
|
142
|
+
var wasmMemory;
|
|
143
|
+
var ABORT = false;
|
|
144
|
+
var EXITSTATUS;
|
|
145
|
+
var HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;
|
|
146
|
+
function updateMemoryViews() {
|
|
147
|
+
var b = wasmMemory.buffer;
|
|
148
|
+
Module["HEAP8"] = HEAP8 = new Int8Array(b);
|
|
149
|
+
Module["HEAP16"] = HEAP16 = new Int16Array(b);
|
|
150
|
+
Module["HEAPU8"] = HEAPU8 = new Uint8Array(b);
|
|
151
|
+
Module["HEAPU16"] = HEAPU16 = new Uint16Array(b);
|
|
152
|
+
Module["HEAP32"] = HEAP32 = new Int32Array(b);
|
|
153
|
+
Module["HEAPU32"] = HEAPU32 = new Uint32Array(b);
|
|
154
|
+
Module["HEAPF32"] = HEAPF32 = new Float32Array(b);
|
|
155
|
+
Module["HEAPF64"] = HEAPF64 = new Float64Array(b);
|
|
156
|
+
}
|
|
157
|
+
var __ATPRERUN__ = [];
|
|
158
|
+
var __ATINIT__ = [];
|
|
159
|
+
var __ATMAIN__ = [];
|
|
160
|
+
var __ATPOSTRUN__ = [];
|
|
161
|
+
var runtimeInitialized = false;
|
|
162
|
+
function preRun() {
|
|
163
|
+
if (Module["preRun"]) {
|
|
164
|
+
if (typeof Module["preRun"] == "function") Module["preRun"] = [Module["preRun"]];
|
|
165
|
+
while (Module["preRun"].length) {
|
|
166
|
+
addOnPreRun(Module["preRun"].shift());
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
callRuntimeCallbacks(__ATPRERUN__);
|
|
170
|
+
}
|
|
171
|
+
function initRuntime() {
|
|
172
|
+
runtimeInitialized = true;
|
|
173
|
+
if (!Module["noFSInit"] && !FS.init.initialized) FS.init();
|
|
174
|
+
FS.ignorePermissions = false;
|
|
175
|
+
TTY.init();
|
|
176
|
+
callRuntimeCallbacks(__ATINIT__);
|
|
177
|
+
}
|
|
178
|
+
function preMain() {
|
|
179
|
+
callRuntimeCallbacks(__ATMAIN__);
|
|
180
|
+
}
|
|
181
|
+
function postRun() {
|
|
182
|
+
if (Module["postRun"]) {
|
|
183
|
+
if (typeof Module["postRun"] == "function") Module["postRun"] = [Module["postRun"]];
|
|
184
|
+
while (Module["postRun"].length) {
|
|
185
|
+
addOnPostRun(Module["postRun"].shift());
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
callRuntimeCallbacks(__ATPOSTRUN__);
|
|
189
|
+
}
|
|
190
|
+
function addOnPreRun(cb) {
|
|
191
|
+
__ATPRERUN__.unshift(cb);
|
|
192
|
+
}
|
|
193
|
+
function addOnInit(cb) {
|
|
194
|
+
__ATINIT__.unshift(cb);
|
|
195
|
+
}
|
|
196
|
+
function addOnPostRun(cb) {
|
|
197
|
+
__ATPOSTRUN__.unshift(cb);
|
|
198
|
+
}
|
|
199
|
+
var runDependencies = 0;
|
|
200
|
+
var runDependencyWatcher = null;
|
|
201
|
+
var dependenciesFulfilled = null;
|
|
202
|
+
function getUniqueRunDependency(id) {
|
|
203
|
+
return id;
|
|
204
|
+
}
|
|
205
|
+
function addRunDependency(id) {
|
|
206
|
+
runDependencies++;
|
|
207
|
+
Module["monitorRunDependencies"]?.(runDependencies);
|
|
208
|
+
}
|
|
209
|
+
function removeRunDependency(id) {
|
|
210
|
+
runDependencies--;
|
|
211
|
+
Module["monitorRunDependencies"]?.(runDependencies);
|
|
212
|
+
if (runDependencies == 0) {
|
|
213
|
+
if (runDependencyWatcher !== null) {
|
|
214
|
+
clearInterval(runDependencyWatcher);
|
|
215
|
+
runDependencyWatcher = null;
|
|
216
|
+
}
|
|
217
|
+
if (dependenciesFulfilled) {
|
|
218
|
+
var callback = dependenciesFulfilled;
|
|
219
|
+
dependenciesFulfilled = null;
|
|
220
|
+
callback();
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
function abort(what) {
|
|
225
|
+
Module["onAbort"]?.(what);
|
|
226
|
+
what = "Aborted(" + what + ")";
|
|
227
|
+
err(what);
|
|
228
|
+
ABORT = true;
|
|
229
|
+
EXITSTATUS = 1;
|
|
230
|
+
what += ". Build with -sASSERTIONS for more info.";
|
|
231
|
+
var e = new WebAssembly.RuntimeError(what);
|
|
232
|
+
readyPromiseReject(e);
|
|
233
|
+
throw e;
|
|
234
|
+
}
|
|
235
|
+
var dataURIPrefix = "data:application/octet-stream;base64,";
|
|
236
|
+
var isDataURI = (filename) => filename.startsWith(dataURIPrefix);
|
|
237
|
+
var wasmBinaryFile;
|
|
238
|
+
if (Module["locateFile"]) {
|
|
239
|
+
wasmBinaryFile = "scip.wasm";
|
|
240
|
+
if (!isDataURI(wasmBinaryFile)) {
|
|
241
|
+
wasmBinaryFile = locateFile(wasmBinaryFile);
|
|
242
|
+
}
|
|
243
|
+
} else {
|
|
244
|
+
wasmBinaryFile = new URL("scip.wasm", __importMetaUrl).href;
|
|
245
|
+
}
|
|
246
|
+
function getBinarySync(file) {
|
|
247
|
+
if (file == wasmBinaryFile && wasmBinary) {
|
|
248
|
+
return new Uint8Array(wasmBinary);
|
|
249
|
+
}
|
|
250
|
+
if (readBinary) {
|
|
251
|
+
return readBinary(file);
|
|
252
|
+
}
|
|
253
|
+
throw "both async and sync fetching of the wasm failed";
|
|
254
|
+
}
|
|
255
|
+
function getBinaryPromise(binaryFile) {
|
|
256
|
+
if (!wasmBinary && (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER)) {
|
|
257
|
+
if (typeof fetch == "function") {
|
|
258
|
+
return fetch(binaryFile, { credentials: "same-origin" }).then((response) => {
|
|
259
|
+
if (!response["ok"]) {
|
|
260
|
+
throw `failed to load wasm binary file at '${binaryFile}'`;
|
|
261
|
+
}
|
|
262
|
+
return response["arrayBuffer"]();
|
|
263
|
+
}).catch(() => getBinarySync(binaryFile));
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
return Promise.resolve().then(() => getBinarySync(binaryFile));
|
|
267
|
+
}
|
|
268
|
+
function instantiateArrayBuffer(binaryFile, imports, receiver) {
|
|
269
|
+
return getBinaryPromise(binaryFile).then((binary) => WebAssembly.instantiate(binary, imports)).then(receiver, (reason) => {
|
|
270
|
+
err(`failed to asynchronously prepare wasm: ${reason}`);
|
|
271
|
+
abort(reason);
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
function instantiateAsync(binary, binaryFile, imports, callback) {
|
|
275
|
+
if (!binary && typeof WebAssembly.instantiateStreaming == "function" && !isDataURI(binaryFile) && typeof fetch == "function") {
|
|
276
|
+
return fetch(binaryFile, { credentials: "same-origin" }).then((response) => {
|
|
277
|
+
var result = WebAssembly.instantiateStreaming(response, imports);
|
|
278
|
+
return result.then(callback, function(reason) {
|
|
279
|
+
err(`wasm streaming compile failed: ${reason}`);
|
|
280
|
+
err("falling back to ArrayBuffer instantiation");
|
|
281
|
+
return instantiateArrayBuffer(binaryFile, imports, callback);
|
|
282
|
+
});
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
return instantiateArrayBuffer(binaryFile, imports, callback);
|
|
286
|
+
}
|
|
287
|
+
function createWasm() {
|
|
288
|
+
var info = { "a": wasmImports };
|
|
289
|
+
function receiveInstance(instance, module) {
|
|
290
|
+
wasmExports = instance.exports;
|
|
291
|
+
wasmMemory = wasmExports["y"];
|
|
292
|
+
updateMemoryViews();
|
|
293
|
+
addOnInit(wasmExports["z"]);
|
|
294
|
+
removeRunDependency("wasm-instantiate");
|
|
295
|
+
return wasmExports;
|
|
296
|
+
}
|
|
297
|
+
addRunDependency("wasm-instantiate");
|
|
298
|
+
function receiveInstantiationResult(result) {
|
|
299
|
+
receiveInstance(result["instance"]);
|
|
300
|
+
}
|
|
301
|
+
if (Module["instantiateWasm"]) {
|
|
302
|
+
try {
|
|
303
|
+
return Module["instantiateWasm"](info, receiveInstance);
|
|
304
|
+
} catch (e) {
|
|
305
|
+
err(`Module.instantiateWasm callback failed with error: ${e}`);
|
|
306
|
+
readyPromiseReject(e);
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
instantiateAsync(wasmBinary, wasmBinaryFile, info, receiveInstantiationResult).catch(readyPromiseReject);
|
|
310
|
+
return {};
|
|
311
|
+
}
|
|
312
|
+
var tempDouble;
|
|
313
|
+
var tempI64;
|
|
314
|
+
function ExitStatus(status) {
|
|
315
|
+
this.name = "ExitStatus";
|
|
316
|
+
this.message = `Program terminated with exit(${status})`;
|
|
317
|
+
this.status = status;
|
|
318
|
+
}
|
|
319
|
+
var callRuntimeCallbacks = (callbacks) => {
|
|
320
|
+
while (callbacks.length > 0) {
|
|
321
|
+
callbacks.shift()(Module);
|
|
322
|
+
}
|
|
323
|
+
};
|
|
324
|
+
var noExitRuntime = Module["noExitRuntime"] || true;
|
|
325
|
+
class ExceptionInfo {
|
|
326
|
+
constructor(excPtr) {
|
|
327
|
+
this.excPtr = excPtr;
|
|
328
|
+
this.ptr = excPtr - 24;
|
|
329
|
+
}
|
|
330
|
+
set_type(type) {
|
|
331
|
+
HEAPU32[this.ptr + 4 >> 2] = type;
|
|
332
|
+
}
|
|
333
|
+
get_type() {
|
|
334
|
+
return HEAPU32[this.ptr + 4 >> 2];
|
|
335
|
+
}
|
|
336
|
+
set_destructor(destructor) {
|
|
337
|
+
HEAPU32[this.ptr + 8 >> 2] = destructor;
|
|
338
|
+
}
|
|
339
|
+
get_destructor() {
|
|
340
|
+
return HEAPU32[this.ptr + 8 >> 2];
|
|
341
|
+
}
|
|
342
|
+
set_caught(caught) {
|
|
343
|
+
caught = caught ? 1 : 0;
|
|
344
|
+
HEAP8[this.ptr + 12] = caught;
|
|
345
|
+
}
|
|
346
|
+
get_caught() {
|
|
347
|
+
return HEAP8[this.ptr + 12] != 0;
|
|
348
|
+
}
|
|
349
|
+
set_rethrown(rethrown) {
|
|
350
|
+
rethrown = rethrown ? 1 : 0;
|
|
351
|
+
HEAP8[this.ptr + 13] = rethrown;
|
|
352
|
+
}
|
|
353
|
+
get_rethrown() {
|
|
354
|
+
return HEAP8[this.ptr + 13] != 0;
|
|
355
|
+
}
|
|
356
|
+
init(type, destructor) {
|
|
357
|
+
this.set_adjusted_ptr(0);
|
|
358
|
+
this.set_type(type);
|
|
359
|
+
this.set_destructor(destructor);
|
|
360
|
+
}
|
|
361
|
+
set_adjusted_ptr(adjustedPtr) {
|
|
362
|
+
HEAPU32[this.ptr + 16 >> 2] = adjustedPtr;
|
|
363
|
+
}
|
|
364
|
+
get_adjusted_ptr() {
|
|
365
|
+
return HEAPU32[this.ptr + 16 >> 2];
|
|
366
|
+
}
|
|
367
|
+
get_exception_ptr() {
|
|
368
|
+
var isPointer = ___cxa_is_pointer_type(this.get_type());
|
|
369
|
+
if (isPointer) {
|
|
370
|
+
return HEAPU32[this.excPtr >> 2];
|
|
371
|
+
}
|
|
372
|
+
var adjusted = this.get_adjusted_ptr();
|
|
373
|
+
if (adjusted !== 0) return adjusted;
|
|
374
|
+
return this.excPtr;
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
var exceptionLast = 0;
|
|
378
|
+
var uncaughtExceptionCount = 0;
|
|
379
|
+
var ___cxa_throw = (ptr, type, destructor) => {
|
|
380
|
+
var info = new ExceptionInfo(ptr);
|
|
381
|
+
info.init(type, destructor);
|
|
382
|
+
exceptionLast = ptr;
|
|
383
|
+
uncaughtExceptionCount++;
|
|
384
|
+
throw exceptionLast;
|
|
385
|
+
};
|
|
386
|
+
var PATH = { isAbs: (path) => path.charAt(0) === "/", splitPath: (filename) => {
|
|
387
|
+
var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;
|
|
388
|
+
return splitPathRe.exec(filename).slice(1);
|
|
389
|
+
}, normalizeArray: (parts, allowAboveRoot) => {
|
|
390
|
+
var up = 0;
|
|
391
|
+
for (var i = parts.length - 1; i >= 0; i--) {
|
|
392
|
+
var last = parts[i];
|
|
393
|
+
if (last === ".") {
|
|
394
|
+
parts.splice(i, 1);
|
|
395
|
+
} else if (last === "..") {
|
|
396
|
+
parts.splice(i, 1);
|
|
397
|
+
up++;
|
|
398
|
+
} else if (up) {
|
|
399
|
+
parts.splice(i, 1);
|
|
400
|
+
up--;
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
if (allowAboveRoot) {
|
|
404
|
+
for (; up; up--) {
|
|
405
|
+
parts.unshift("..");
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
return parts;
|
|
409
|
+
}, normalize: (path) => {
|
|
410
|
+
var isAbsolute = PATH.isAbs(path), trailingSlash = path.substr(-1) === "/";
|
|
411
|
+
path = PATH.normalizeArray(path.split("/").filter((p) => !!p), !isAbsolute).join("/");
|
|
412
|
+
if (!path && !isAbsolute) {
|
|
413
|
+
path = ".";
|
|
414
|
+
}
|
|
415
|
+
if (path && trailingSlash) {
|
|
416
|
+
path += "/";
|
|
417
|
+
}
|
|
418
|
+
return (isAbsolute ? "/" : "") + path;
|
|
419
|
+
}, dirname: (path) => {
|
|
420
|
+
var result = PATH.splitPath(path), root = result[0], dir = result[1];
|
|
421
|
+
if (!root && !dir) {
|
|
422
|
+
return ".";
|
|
423
|
+
}
|
|
424
|
+
if (dir) {
|
|
425
|
+
dir = dir.substr(0, dir.length - 1);
|
|
426
|
+
}
|
|
427
|
+
return root + dir;
|
|
428
|
+
}, basename: (path) => {
|
|
429
|
+
if (path === "/") return "/";
|
|
430
|
+
path = PATH.normalize(path);
|
|
431
|
+
path = path.replace(/\/$/, "");
|
|
432
|
+
var lastSlash = path.lastIndexOf("/");
|
|
433
|
+
if (lastSlash === -1) return path;
|
|
434
|
+
return path.substr(lastSlash + 1);
|
|
435
|
+
}, join: (...paths) => PATH.normalize(paths.join("/")), join2: (l, r) => PATH.normalize(l + "/" + r) };
|
|
436
|
+
var initRandomFill = () => {
|
|
437
|
+
if (typeof crypto == "object" && typeof crypto["getRandomValues"] == "function") {
|
|
438
|
+
return (view) => crypto.getRandomValues(view);
|
|
439
|
+
} else abort("initRandomDevice");
|
|
440
|
+
};
|
|
441
|
+
var randomFill = (view) => (randomFill = initRandomFill())(view);
|
|
442
|
+
var PATH_FS = { resolve: (...args) => {
|
|
443
|
+
var resolvedPath = "", resolvedAbsolute = false;
|
|
444
|
+
for (var i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {
|
|
445
|
+
var path = i >= 0 ? args[i] : FS.cwd();
|
|
446
|
+
if (typeof path != "string") {
|
|
447
|
+
throw new TypeError("Arguments to path.resolve must be strings");
|
|
448
|
+
} else if (!path) {
|
|
449
|
+
return "";
|
|
450
|
+
}
|
|
451
|
+
resolvedPath = path + "/" + resolvedPath;
|
|
452
|
+
resolvedAbsolute = PATH.isAbs(path);
|
|
453
|
+
}
|
|
454
|
+
resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter((p) => !!p), !resolvedAbsolute).join("/");
|
|
455
|
+
return (resolvedAbsolute ? "/" : "") + resolvedPath || ".";
|
|
456
|
+
}, relative: (from, to) => {
|
|
457
|
+
from = PATH_FS.resolve(from).substr(1);
|
|
458
|
+
to = PATH_FS.resolve(to).substr(1);
|
|
459
|
+
function trim(arr) {
|
|
460
|
+
var start = 0;
|
|
461
|
+
for (; start < arr.length; start++) {
|
|
462
|
+
if (arr[start] !== "") break;
|
|
463
|
+
}
|
|
464
|
+
var end = arr.length - 1;
|
|
465
|
+
for (; end >= 0; end--) {
|
|
466
|
+
if (arr[end] !== "") break;
|
|
467
|
+
}
|
|
468
|
+
if (start > end) return [];
|
|
469
|
+
return arr.slice(start, end - start + 1);
|
|
470
|
+
}
|
|
471
|
+
var fromParts = trim(from.split("/"));
|
|
472
|
+
var toParts = trim(to.split("/"));
|
|
473
|
+
var length = Math.min(fromParts.length, toParts.length);
|
|
474
|
+
var samePartsLength = length;
|
|
475
|
+
for (var i = 0; i < length; i++) {
|
|
476
|
+
if (fromParts[i] !== toParts[i]) {
|
|
477
|
+
samePartsLength = i;
|
|
478
|
+
break;
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
var outputParts = [];
|
|
482
|
+
for (var i = samePartsLength; i < fromParts.length; i++) {
|
|
483
|
+
outputParts.push("..");
|
|
484
|
+
}
|
|
485
|
+
outputParts = outputParts.concat(toParts.slice(samePartsLength));
|
|
486
|
+
return outputParts.join("/");
|
|
487
|
+
} };
|
|
488
|
+
var UTF8Decoder = typeof TextDecoder != "undefined" ? new TextDecoder("utf8") : void 0;
|
|
489
|
+
var UTF8ArrayToString = (heapOrArray, idx, maxBytesToRead) => {
|
|
490
|
+
var endIdx = idx + maxBytesToRead;
|
|
491
|
+
var endPtr = idx;
|
|
492
|
+
while (heapOrArray[endPtr] && !(endPtr >= endIdx)) ++endPtr;
|
|
493
|
+
if (endPtr - idx > 16 && heapOrArray.buffer && UTF8Decoder) {
|
|
494
|
+
return UTF8Decoder.decode(heapOrArray.subarray(idx, endPtr));
|
|
495
|
+
}
|
|
496
|
+
var str = "";
|
|
497
|
+
while (idx < endPtr) {
|
|
498
|
+
var u0 = heapOrArray[idx++];
|
|
499
|
+
if (!(u0 & 128)) {
|
|
500
|
+
str += String.fromCharCode(u0);
|
|
501
|
+
continue;
|
|
502
|
+
}
|
|
503
|
+
var u1 = heapOrArray[idx++] & 63;
|
|
504
|
+
if ((u0 & 224) == 192) {
|
|
505
|
+
str += String.fromCharCode((u0 & 31) << 6 | u1);
|
|
506
|
+
continue;
|
|
507
|
+
}
|
|
508
|
+
var u2 = heapOrArray[idx++] & 63;
|
|
509
|
+
if ((u0 & 240) == 224) {
|
|
510
|
+
u0 = (u0 & 15) << 12 | u1 << 6 | u2;
|
|
511
|
+
} else {
|
|
512
|
+
u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | heapOrArray[idx++] & 63;
|
|
513
|
+
}
|
|
514
|
+
if (u0 < 65536) {
|
|
515
|
+
str += String.fromCharCode(u0);
|
|
516
|
+
} else {
|
|
517
|
+
var ch = u0 - 65536;
|
|
518
|
+
str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023);
|
|
519
|
+
}
|
|
520
|
+
}
|
|
521
|
+
return str;
|
|
522
|
+
};
|
|
523
|
+
var FS_stdin_getChar_buffer = [];
|
|
524
|
+
var lengthBytesUTF8 = (str) => {
|
|
525
|
+
var len = 0;
|
|
526
|
+
for (var i = 0; i < str.length; ++i) {
|
|
527
|
+
var c = str.charCodeAt(i);
|
|
528
|
+
if (c <= 127) {
|
|
529
|
+
len++;
|
|
530
|
+
} else if (c <= 2047) {
|
|
531
|
+
len += 2;
|
|
532
|
+
} else if (c >= 55296 && c <= 57343) {
|
|
533
|
+
len += 4;
|
|
534
|
+
++i;
|
|
535
|
+
} else {
|
|
536
|
+
len += 3;
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
return len;
|
|
540
|
+
};
|
|
541
|
+
var stringToUTF8Array = (str, heap, outIdx, maxBytesToWrite) => {
|
|
542
|
+
if (!(maxBytesToWrite > 0)) return 0;
|
|
543
|
+
var startIdx = outIdx;
|
|
544
|
+
var endIdx = outIdx + maxBytesToWrite - 1;
|
|
545
|
+
for (var i = 0; i < str.length; ++i) {
|
|
546
|
+
var u = str.charCodeAt(i);
|
|
547
|
+
if (u >= 55296 && u <= 57343) {
|
|
548
|
+
var u1 = str.charCodeAt(++i);
|
|
549
|
+
u = 65536 + ((u & 1023) << 10) | u1 & 1023;
|
|
550
|
+
}
|
|
551
|
+
if (u <= 127) {
|
|
552
|
+
if (outIdx >= endIdx) break;
|
|
553
|
+
heap[outIdx++] = u;
|
|
554
|
+
} else if (u <= 2047) {
|
|
555
|
+
if (outIdx + 1 >= endIdx) break;
|
|
556
|
+
heap[outIdx++] = 192 | u >> 6;
|
|
557
|
+
heap[outIdx++] = 128 | u & 63;
|
|
558
|
+
} else if (u <= 65535) {
|
|
559
|
+
if (outIdx + 2 >= endIdx) break;
|
|
560
|
+
heap[outIdx++] = 224 | u >> 12;
|
|
561
|
+
heap[outIdx++] = 128 | u >> 6 & 63;
|
|
562
|
+
heap[outIdx++] = 128 | u & 63;
|
|
563
|
+
} else {
|
|
564
|
+
if (outIdx + 3 >= endIdx) break;
|
|
565
|
+
heap[outIdx++] = 240 | u >> 18;
|
|
566
|
+
heap[outIdx++] = 128 | u >> 12 & 63;
|
|
567
|
+
heap[outIdx++] = 128 | u >> 6 & 63;
|
|
568
|
+
heap[outIdx++] = 128 | u & 63;
|
|
569
|
+
}
|
|
570
|
+
}
|
|
571
|
+
heap[outIdx] = 0;
|
|
572
|
+
return outIdx - startIdx;
|
|
573
|
+
};
|
|
574
|
+
function intArrayFromString(stringy, dontAddNull, length) {
|
|
575
|
+
var len = length > 0 ? length : lengthBytesUTF8(stringy) + 1;
|
|
576
|
+
var u8array = new Array(len);
|
|
577
|
+
var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length);
|
|
578
|
+
if (dontAddNull) u8array.length = numBytesWritten;
|
|
579
|
+
return u8array;
|
|
580
|
+
}
|
|
581
|
+
var FS_stdin_getChar = () => {
|
|
582
|
+
if (!FS_stdin_getChar_buffer.length) {
|
|
583
|
+
var result = null;
|
|
584
|
+
if (typeof window != "undefined" && typeof window.prompt == "function") {
|
|
585
|
+
result = window.prompt("Input: ");
|
|
586
|
+
if (result !== null) {
|
|
587
|
+
result += "\n";
|
|
588
|
+
}
|
|
589
|
+
} else if (typeof readline == "function") {
|
|
590
|
+
result = readline();
|
|
591
|
+
if (result !== null) {
|
|
592
|
+
result += "\n";
|
|
593
|
+
}
|
|
594
|
+
}
|
|
595
|
+
if (!result) {
|
|
596
|
+
return null;
|
|
597
|
+
}
|
|
598
|
+
FS_stdin_getChar_buffer = intArrayFromString(result, true);
|
|
599
|
+
}
|
|
600
|
+
return FS_stdin_getChar_buffer.shift();
|
|
601
|
+
};
|
|
602
|
+
var TTY = { ttys: [], init() {
|
|
603
|
+
}, shutdown() {
|
|
604
|
+
}, register(dev, ops) {
|
|
605
|
+
TTY.ttys[dev] = { input: [], output: [], ops };
|
|
606
|
+
FS.registerDevice(dev, TTY.stream_ops);
|
|
607
|
+
}, stream_ops: { open(stream) {
|
|
608
|
+
var tty = TTY.ttys[stream.node.rdev];
|
|
609
|
+
if (!tty) {
|
|
610
|
+
throw new FS.ErrnoError(43);
|
|
611
|
+
}
|
|
612
|
+
stream.tty = tty;
|
|
613
|
+
stream.seekable = false;
|
|
614
|
+
}, close(stream) {
|
|
615
|
+
stream.tty.ops.fsync(stream.tty);
|
|
616
|
+
}, fsync(stream) {
|
|
617
|
+
stream.tty.ops.fsync(stream.tty);
|
|
618
|
+
}, read(stream, buffer, offset, length, pos) {
|
|
619
|
+
if (!stream.tty || !stream.tty.ops.get_char) {
|
|
620
|
+
throw new FS.ErrnoError(60);
|
|
621
|
+
}
|
|
622
|
+
var bytesRead = 0;
|
|
623
|
+
for (var i = 0; i < length; i++) {
|
|
624
|
+
var result;
|
|
625
|
+
try {
|
|
626
|
+
result = stream.tty.ops.get_char(stream.tty);
|
|
627
|
+
} catch (e) {
|
|
628
|
+
throw new FS.ErrnoError(29);
|
|
629
|
+
}
|
|
630
|
+
if (result === void 0 && bytesRead === 0) {
|
|
631
|
+
throw new FS.ErrnoError(6);
|
|
632
|
+
}
|
|
633
|
+
if (result === null || result === void 0) break;
|
|
634
|
+
bytesRead++;
|
|
635
|
+
buffer[offset + i] = result;
|
|
636
|
+
}
|
|
637
|
+
if (bytesRead) {
|
|
638
|
+
stream.node.timestamp = Date.now();
|
|
639
|
+
}
|
|
640
|
+
return bytesRead;
|
|
641
|
+
}, write(stream, buffer, offset, length, pos) {
|
|
642
|
+
if (!stream.tty || !stream.tty.ops.put_char) {
|
|
643
|
+
throw new FS.ErrnoError(60);
|
|
644
|
+
}
|
|
645
|
+
try {
|
|
646
|
+
for (var i = 0; i < length; i++) {
|
|
647
|
+
stream.tty.ops.put_char(stream.tty, buffer[offset + i]);
|
|
648
|
+
}
|
|
649
|
+
} catch (e) {
|
|
650
|
+
throw new FS.ErrnoError(29);
|
|
651
|
+
}
|
|
652
|
+
if (length) {
|
|
653
|
+
stream.node.timestamp = Date.now();
|
|
654
|
+
}
|
|
655
|
+
return i;
|
|
656
|
+
} }, default_tty_ops: { get_char(tty) {
|
|
657
|
+
return FS_stdin_getChar();
|
|
658
|
+
}, put_char(tty, val) {
|
|
659
|
+
if (val === null || val === 10) {
|
|
660
|
+
out(UTF8ArrayToString(tty.output, 0));
|
|
661
|
+
tty.output = [];
|
|
662
|
+
} else {
|
|
663
|
+
if (val != 0) tty.output.push(val);
|
|
664
|
+
}
|
|
665
|
+
}, fsync(tty) {
|
|
666
|
+
if (tty.output && tty.output.length > 0) {
|
|
667
|
+
out(UTF8ArrayToString(tty.output, 0));
|
|
668
|
+
tty.output = [];
|
|
669
|
+
}
|
|
670
|
+
}, ioctl_tcgets(tty) {
|
|
671
|
+
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] };
|
|
672
|
+
}, ioctl_tcsets(tty, optional_actions, data) {
|
|
673
|
+
return 0;
|
|
674
|
+
}, ioctl_tiocgwinsz(tty) {
|
|
675
|
+
return [24, 80];
|
|
676
|
+
} }, default_tty1_ops: { put_char(tty, val) {
|
|
677
|
+
if (val === null || val === 10) {
|
|
678
|
+
err(UTF8ArrayToString(tty.output, 0));
|
|
679
|
+
tty.output = [];
|
|
680
|
+
} else {
|
|
681
|
+
if (val != 0) tty.output.push(val);
|
|
682
|
+
}
|
|
683
|
+
}, fsync(tty) {
|
|
684
|
+
if (tty.output && tty.output.length > 0) {
|
|
685
|
+
err(UTF8ArrayToString(tty.output, 0));
|
|
686
|
+
tty.output = [];
|
|
687
|
+
}
|
|
688
|
+
} } };
|
|
689
|
+
var zeroMemory = (address, size) => {
|
|
690
|
+
HEAPU8.fill(0, address, address + size);
|
|
691
|
+
return address;
|
|
692
|
+
};
|
|
693
|
+
var alignMemory = (size, alignment) => Math.ceil(size / alignment) * alignment;
|
|
694
|
+
var mmapAlloc = (size) => {
|
|
695
|
+
size = alignMemory(size, 65536);
|
|
696
|
+
var ptr = _emscripten_builtin_memalign(65536, size);
|
|
697
|
+
if (!ptr) return 0;
|
|
698
|
+
return zeroMemory(ptr, size);
|
|
699
|
+
};
|
|
700
|
+
var MEMFS = { ops_table: null, mount(mount) {
|
|
701
|
+
return MEMFS.createNode(null, "/", 16384 | 511, 0);
|
|
702
|
+
}, createNode(parent, name, mode, dev) {
|
|
703
|
+
if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
|
|
704
|
+
throw new FS.ErrnoError(63);
|
|
705
|
+
}
|
|
706
|
+
MEMFS.ops_table || (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 } });
|
|
707
|
+
var node = FS.createNode(parent, name, mode, dev);
|
|
708
|
+
if (FS.isDir(node.mode)) {
|
|
709
|
+
node.node_ops = MEMFS.ops_table.dir.node;
|
|
710
|
+
node.stream_ops = MEMFS.ops_table.dir.stream;
|
|
711
|
+
node.contents = {};
|
|
712
|
+
} else if (FS.isFile(node.mode)) {
|
|
713
|
+
node.node_ops = MEMFS.ops_table.file.node;
|
|
714
|
+
node.stream_ops = MEMFS.ops_table.file.stream;
|
|
715
|
+
node.usedBytes = 0;
|
|
716
|
+
node.contents = null;
|
|
717
|
+
} else if (FS.isLink(node.mode)) {
|
|
718
|
+
node.node_ops = MEMFS.ops_table.link.node;
|
|
719
|
+
node.stream_ops = MEMFS.ops_table.link.stream;
|
|
720
|
+
} else if (FS.isChrdev(node.mode)) {
|
|
721
|
+
node.node_ops = MEMFS.ops_table.chrdev.node;
|
|
722
|
+
node.stream_ops = MEMFS.ops_table.chrdev.stream;
|
|
723
|
+
}
|
|
724
|
+
node.timestamp = Date.now();
|
|
725
|
+
if (parent) {
|
|
726
|
+
parent.contents[name] = node;
|
|
727
|
+
parent.timestamp = node.timestamp;
|
|
728
|
+
}
|
|
729
|
+
return node;
|
|
730
|
+
}, getFileDataAsTypedArray(node) {
|
|
731
|
+
if (!node.contents) return new Uint8Array(0);
|
|
732
|
+
if (node.contents.subarray) return node.contents.subarray(0, node.usedBytes);
|
|
733
|
+
return new Uint8Array(node.contents);
|
|
734
|
+
}, expandFileStorage(node, newCapacity) {
|
|
735
|
+
var prevCapacity = node.contents ? node.contents.length : 0;
|
|
736
|
+
if (prevCapacity >= newCapacity) return;
|
|
737
|
+
var CAPACITY_DOUBLING_MAX = 1024 * 1024;
|
|
738
|
+
newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) >>> 0);
|
|
739
|
+
if (prevCapacity != 0) newCapacity = Math.max(newCapacity, 256);
|
|
740
|
+
var oldContents = node.contents;
|
|
741
|
+
node.contents = new Uint8Array(newCapacity);
|
|
742
|
+
if (node.usedBytes > 0) node.contents.set(oldContents.subarray(0, node.usedBytes), 0);
|
|
743
|
+
}, resizeFileStorage(node, newSize) {
|
|
744
|
+
if (node.usedBytes == newSize) return;
|
|
745
|
+
if (newSize == 0) {
|
|
746
|
+
node.contents = null;
|
|
747
|
+
node.usedBytes = 0;
|
|
748
|
+
} else {
|
|
749
|
+
var oldContents = node.contents;
|
|
750
|
+
node.contents = new Uint8Array(newSize);
|
|
751
|
+
if (oldContents) {
|
|
752
|
+
node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)));
|
|
753
|
+
}
|
|
754
|
+
node.usedBytes = newSize;
|
|
755
|
+
}
|
|
756
|
+
}, node_ops: { getattr(node) {
|
|
757
|
+
var attr = {};
|
|
758
|
+
attr.dev = FS.isChrdev(node.mode) ? node.id : 1;
|
|
759
|
+
attr.ino = node.id;
|
|
760
|
+
attr.mode = node.mode;
|
|
761
|
+
attr.nlink = 1;
|
|
762
|
+
attr.uid = 0;
|
|
763
|
+
attr.gid = 0;
|
|
764
|
+
attr.rdev = node.rdev;
|
|
765
|
+
if (FS.isDir(node.mode)) {
|
|
766
|
+
attr.size = 4096;
|
|
767
|
+
} else if (FS.isFile(node.mode)) {
|
|
768
|
+
attr.size = node.usedBytes;
|
|
769
|
+
} else if (FS.isLink(node.mode)) {
|
|
770
|
+
attr.size = node.link.length;
|
|
771
|
+
} else {
|
|
772
|
+
attr.size = 0;
|
|
773
|
+
}
|
|
774
|
+
attr.atime = new Date(node.timestamp);
|
|
775
|
+
attr.mtime = new Date(node.timestamp);
|
|
776
|
+
attr.ctime = new Date(node.timestamp);
|
|
777
|
+
attr.blksize = 4096;
|
|
778
|
+
attr.blocks = Math.ceil(attr.size / attr.blksize);
|
|
779
|
+
return attr;
|
|
780
|
+
}, setattr(node, attr) {
|
|
781
|
+
if (attr.mode !== void 0) {
|
|
782
|
+
node.mode = attr.mode;
|
|
783
|
+
}
|
|
784
|
+
if (attr.timestamp !== void 0) {
|
|
785
|
+
node.timestamp = attr.timestamp;
|
|
786
|
+
}
|
|
787
|
+
if (attr.size !== void 0) {
|
|
788
|
+
MEMFS.resizeFileStorage(node, attr.size);
|
|
789
|
+
}
|
|
790
|
+
}, lookup(parent, name) {
|
|
791
|
+
throw FS.genericErrors[44];
|
|
792
|
+
}, mknod(parent, name, mode, dev) {
|
|
793
|
+
return MEMFS.createNode(parent, name, mode, dev);
|
|
794
|
+
}, rename(old_node, new_dir, new_name) {
|
|
795
|
+
if (FS.isDir(old_node.mode)) {
|
|
796
|
+
var new_node;
|
|
797
|
+
try {
|
|
798
|
+
new_node = FS.lookupNode(new_dir, new_name);
|
|
799
|
+
} catch (e) {
|
|
800
|
+
}
|
|
801
|
+
if (new_node) {
|
|
802
|
+
for (var i in new_node.contents) {
|
|
803
|
+
throw new FS.ErrnoError(55);
|
|
804
|
+
}
|
|
805
|
+
}
|
|
806
|
+
}
|
|
807
|
+
delete old_node.parent.contents[old_node.name];
|
|
808
|
+
old_node.parent.timestamp = Date.now();
|
|
809
|
+
old_node.name = new_name;
|
|
810
|
+
new_dir.contents[new_name] = old_node;
|
|
811
|
+
new_dir.timestamp = old_node.parent.timestamp;
|
|
812
|
+
old_node.parent = new_dir;
|
|
813
|
+
}, unlink(parent, name) {
|
|
814
|
+
delete parent.contents[name];
|
|
815
|
+
parent.timestamp = Date.now();
|
|
816
|
+
}, rmdir(parent, name) {
|
|
817
|
+
var node = FS.lookupNode(parent, name);
|
|
818
|
+
for (var i in node.contents) {
|
|
819
|
+
throw new FS.ErrnoError(55);
|
|
820
|
+
}
|
|
821
|
+
delete parent.contents[name];
|
|
822
|
+
parent.timestamp = Date.now();
|
|
823
|
+
}, readdir(node) {
|
|
824
|
+
var entries = [".", ".."];
|
|
825
|
+
for (var key of Object.keys(node.contents)) {
|
|
826
|
+
entries.push(key);
|
|
827
|
+
}
|
|
828
|
+
return entries;
|
|
829
|
+
}, symlink(parent, newname, oldpath) {
|
|
830
|
+
var node = MEMFS.createNode(parent, newname, 511 | 40960, 0);
|
|
831
|
+
node.link = oldpath;
|
|
832
|
+
return node;
|
|
833
|
+
}, readlink(node) {
|
|
834
|
+
if (!FS.isLink(node.mode)) {
|
|
835
|
+
throw new FS.ErrnoError(28);
|
|
836
|
+
}
|
|
837
|
+
return node.link;
|
|
838
|
+
} }, stream_ops: { read(stream, buffer, offset, length, position) {
|
|
839
|
+
var contents = stream.node.contents;
|
|
840
|
+
if (position >= stream.node.usedBytes) return 0;
|
|
841
|
+
var size = Math.min(stream.node.usedBytes - position, length);
|
|
842
|
+
if (size > 8 && contents.subarray) {
|
|
843
|
+
buffer.set(contents.subarray(position, position + size), offset);
|
|
844
|
+
} else {
|
|
845
|
+
for (var i = 0; i < size; i++) buffer[offset + i] = contents[position + i];
|
|
846
|
+
}
|
|
847
|
+
return size;
|
|
848
|
+
}, write(stream, buffer, offset, length, position, canOwn) {
|
|
849
|
+
if (buffer.buffer === HEAP8.buffer) {
|
|
850
|
+
canOwn = false;
|
|
851
|
+
}
|
|
852
|
+
if (!length) return 0;
|
|
853
|
+
var node = stream.node;
|
|
854
|
+
node.timestamp = Date.now();
|
|
855
|
+
if (buffer.subarray && (!node.contents || node.contents.subarray)) {
|
|
856
|
+
if (canOwn) {
|
|
857
|
+
node.contents = buffer.subarray(offset, offset + length);
|
|
858
|
+
node.usedBytes = length;
|
|
859
|
+
return length;
|
|
860
|
+
} else if (node.usedBytes === 0 && position === 0) {
|
|
861
|
+
node.contents = buffer.slice(offset, offset + length);
|
|
862
|
+
node.usedBytes = length;
|
|
863
|
+
return length;
|
|
864
|
+
} else if (position + length <= node.usedBytes) {
|
|
865
|
+
node.contents.set(buffer.subarray(offset, offset + length), position);
|
|
866
|
+
return length;
|
|
867
|
+
}
|
|
868
|
+
}
|
|
869
|
+
MEMFS.expandFileStorage(node, position + length);
|
|
870
|
+
if (node.contents.subarray && buffer.subarray) {
|
|
871
|
+
node.contents.set(buffer.subarray(offset, offset + length), position);
|
|
872
|
+
} else {
|
|
873
|
+
for (var i = 0; i < length; i++) {
|
|
874
|
+
node.contents[position + i] = buffer[offset + i];
|
|
875
|
+
}
|
|
876
|
+
}
|
|
877
|
+
node.usedBytes = Math.max(node.usedBytes, position + length);
|
|
878
|
+
return length;
|
|
879
|
+
}, llseek(stream, offset, whence) {
|
|
880
|
+
var position = offset;
|
|
881
|
+
if (whence === 1) {
|
|
882
|
+
position += stream.position;
|
|
883
|
+
} else if (whence === 2) {
|
|
884
|
+
if (FS.isFile(stream.node.mode)) {
|
|
885
|
+
position += stream.node.usedBytes;
|
|
886
|
+
}
|
|
887
|
+
}
|
|
888
|
+
if (position < 0) {
|
|
889
|
+
throw new FS.ErrnoError(28);
|
|
890
|
+
}
|
|
891
|
+
return position;
|
|
892
|
+
}, allocate(stream, offset, length) {
|
|
893
|
+
MEMFS.expandFileStorage(stream.node, offset + length);
|
|
894
|
+
stream.node.usedBytes = Math.max(stream.node.usedBytes, offset + length);
|
|
895
|
+
}, mmap(stream, length, position, prot, flags) {
|
|
896
|
+
if (!FS.isFile(stream.node.mode)) {
|
|
897
|
+
throw new FS.ErrnoError(43);
|
|
898
|
+
}
|
|
899
|
+
var ptr;
|
|
900
|
+
var allocated;
|
|
901
|
+
var contents = stream.node.contents;
|
|
902
|
+
if (!(flags & 2) && contents.buffer === HEAP8.buffer) {
|
|
903
|
+
allocated = false;
|
|
904
|
+
ptr = contents.byteOffset;
|
|
905
|
+
} else {
|
|
906
|
+
if (position > 0 || position + length < contents.length) {
|
|
907
|
+
if (contents.subarray) {
|
|
908
|
+
contents = contents.subarray(position, position + length);
|
|
909
|
+
} else {
|
|
910
|
+
contents = Array.prototype.slice.call(contents, position, position + length);
|
|
911
|
+
}
|
|
912
|
+
}
|
|
913
|
+
allocated = true;
|
|
914
|
+
ptr = mmapAlloc(length);
|
|
915
|
+
if (!ptr) {
|
|
916
|
+
throw new FS.ErrnoError(48);
|
|
917
|
+
}
|
|
918
|
+
HEAP8.set(contents, ptr);
|
|
919
|
+
}
|
|
920
|
+
return { ptr, allocated };
|
|
921
|
+
}, msync(stream, buffer, offset, length, mmapFlags) {
|
|
922
|
+
MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false);
|
|
923
|
+
return 0;
|
|
924
|
+
} } };
|
|
925
|
+
var asyncLoad = (url, onload, onerror, noRunDep) => {
|
|
926
|
+
var dep = !noRunDep ? getUniqueRunDependency(`al ${url}`) : "";
|
|
927
|
+
readAsync(url, (arrayBuffer) => {
|
|
928
|
+
onload(new Uint8Array(arrayBuffer));
|
|
929
|
+
if (dep) removeRunDependency(dep);
|
|
930
|
+
}, (event) => {
|
|
931
|
+
if (onerror) {
|
|
932
|
+
onerror();
|
|
933
|
+
} else {
|
|
934
|
+
throw `Loading data file "${url}" failed.`;
|
|
935
|
+
}
|
|
936
|
+
});
|
|
937
|
+
if (dep) addRunDependency(dep);
|
|
938
|
+
};
|
|
939
|
+
var FS_createDataFile = (parent, name, fileData, canRead, canWrite, canOwn) => {
|
|
940
|
+
FS.createDataFile(parent, name, fileData, canRead, canWrite, canOwn);
|
|
941
|
+
};
|
|
942
|
+
var preloadPlugins = Module["preloadPlugins"] || [];
|
|
943
|
+
var FS_handledByPreloadPlugin = (byteArray, fullname, finish, onerror) => {
|
|
944
|
+
if (typeof Browser != "undefined") Browser.init();
|
|
945
|
+
var handled = false;
|
|
946
|
+
preloadPlugins.forEach((plugin) => {
|
|
947
|
+
if (handled) return;
|
|
948
|
+
if (plugin["canHandle"](fullname)) {
|
|
949
|
+
plugin["handle"](byteArray, fullname, finish, onerror);
|
|
950
|
+
handled = true;
|
|
951
|
+
}
|
|
952
|
+
});
|
|
953
|
+
return handled;
|
|
954
|
+
};
|
|
955
|
+
var FS_createPreloadedFile = (parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) => {
|
|
956
|
+
var fullname = name ? PATH_FS.resolve(PATH.join2(parent, name)) : parent;
|
|
957
|
+
var dep = getUniqueRunDependency(`cp ${fullname}`);
|
|
958
|
+
function processData(byteArray) {
|
|
959
|
+
function finish(byteArray2) {
|
|
960
|
+
preFinish?.();
|
|
961
|
+
if (!dontCreateFile) {
|
|
962
|
+
FS_createDataFile(parent, name, byteArray2, canRead, canWrite, canOwn);
|
|
963
|
+
}
|
|
964
|
+
onload?.();
|
|
965
|
+
removeRunDependency(dep);
|
|
966
|
+
}
|
|
967
|
+
if (FS_handledByPreloadPlugin(byteArray, fullname, finish, () => {
|
|
968
|
+
onerror?.();
|
|
969
|
+
removeRunDependency(dep);
|
|
970
|
+
})) {
|
|
971
|
+
return;
|
|
972
|
+
}
|
|
973
|
+
finish(byteArray);
|
|
974
|
+
}
|
|
975
|
+
addRunDependency(dep);
|
|
976
|
+
if (typeof url == "string") {
|
|
977
|
+
asyncLoad(url, processData, onerror);
|
|
978
|
+
} else {
|
|
979
|
+
processData(url);
|
|
980
|
+
}
|
|
981
|
+
};
|
|
982
|
+
var FS_modeStringToFlags = (str) => {
|
|
983
|
+
var flagModes = { "r": 0, "r+": 2, "w": 512 | 64 | 1, "w+": 512 | 64 | 2, "a": 1024 | 64 | 1, "a+": 1024 | 64 | 2 };
|
|
984
|
+
var flags = flagModes[str];
|
|
985
|
+
if (typeof flags == "undefined") {
|
|
986
|
+
throw new Error(`Unknown file open mode: ${str}`);
|
|
987
|
+
}
|
|
988
|
+
return flags;
|
|
989
|
+
};
|
|
990
|
+
var FS_getMode = (canRead, canWrite) => {
|
|
991
|
+
var mode = 0;
|
|
992
|
+
if (canRead) mode |= 292 | 73;
|
|
993
|
+
if (canWrite) mode |= 146;
|
|
994
|
+
return mode;
|
|
995
|
+
};
|
|
996
|
+
var FS = { root: null, mounts: [], devices: {}, streams: [], nextInode: 1, nameTable: null, currentPath: "/", initialized: false, ignorePermissions: true, ErrnoError: class {
|
|
997
|
+
constructor(errno) {
|
|
998
|
+
this.name = "ErrnoError";
|
|
999
|
+
this.errno = errno;
|
|
1000
|
+
}
|
|
1001
|
+
}, genericErrors: {}, filesystems: null, syncFSRequests: 0, FSStream: class {
|
|
1002
|
+
constructor() {
|
|
1003
|
+
this.shared = {};
|
|
1004
|
+
}
|
|
1005
|
+
get object() {
|
|
1006
|
+
return this.node;
|
|
1007
|
+
}
|
|
1008
|
+
set object(val) {
|
|
1009
|
+
this.node = val;
|
|
1010
|
+
}
|
|
1011
|
+
get isRead() {
|
|
1012
|
+
return (this.flags & 2097155) !== 1;
|
|
1013
|
+
}
|
|
1014
|
+
get isWrite() {
|
|
1015
|
+
return (this.flags & 2097155) !== 0;
|
|
1016
|
+
}
|
|
1017
|
+
get isAppend() {
|
|
1018
|
+
return this.flags & 1024;
|
|
1019
|
+
}
|
|
1020
|
+
get flags() {
|
|
1021
|
+
return this.shared.flags;
|
|
1022
|
+
}
|
|
1023
|
+
set flags(val) {
|
|
1024
|
+
this.shared.flags = val;
|
|
1025
|
+
}
|
|
1026
|
+
get position() {
|
|
1027
|
+
return this.shared.position;
|
|
1028
|
+
}
|
|
1029
|
+
set position(val) {
|
|
1030
|
+
this.shared.position = val;
|
|
1031
|
+
}
|
|
1032
|
+
}, FSNode: class {
|
|
1033
|
+
constructor(parent, name, mode, rdev) {
|
|
1034
|
+
if (!parent) {
|
|
1035
|
+
parent = this;
|
|
1036
|
+
}
|
|
1037
|
+
this.parent = parent;
|
|
1038
|
+
this.mount = parent.mount;
|
|
1039
|
+
this.mounted = null;
|
|
1040
|
+
this.id = FS.nextInode++;
|
|
1041
|
+
this.name = name;
|
|
1042
|
+
this.mode = mode;
|
|
1043
|
+
this.node_ops = {};
|
|
1044
|
+
this.stream_ops = {};
|
|
1045
|
+
this.rdev = rdev;
|
|
1046
|
+
this.readMode = 292 | 73;
|
|
1047
|
+
this.writeMode = 146;
|
|
1048
|
+
}
|
|
1049
|
+
get read() {
|
|
1050
|
+
return (this.mode & this.readMode) === this.readMode;
|
|
1051
|
+
}
|
|
1052
|
+
set read(val) {
|
|
1053
|
+
val ? this.mode |= this.readMode : this.mode &= ~this.readMode;
|
|
1054
|
+
}
|
|
1055
|
+
get write() {
|
|
1056
|
+
return (this.mode & this.writeMode) === this.writeMode;
|
|
1057
|
+
}
|
|
1058
|
+
set write(val) {
|
|
1059
|
+
val ? this.mode |= this.writeMode : this.mode &= ~this.writeMode;
|
|
1060
|
+
}
|
|
1061
|
+
get isFolder() {
|
|
1062
|
+
return FS.isDir(this.mode);
|
|
1063
|
+
}
|
|
1064
|
+
get isDevice() {
|
|
1065
|
+
return FS.isChrdev(this.mode);
|
|
1066
|
+
}
|
|
1067
|
+
}, lookupPath(path, opts = {}) {
|
|
1068
|
+
path = PATH_FS.resolve(path);
|
|
1069
|
+
if (!path) return { path: "", node: null };
|
|
1070
|
+
var defaults = { follow_mount: true, recurse_count: 0 };
|
|
1071
|
+
opts = Object.assign(defaults, opts);
|
|
1072
|
+
if (opts.recurse_count > 8) {
|
|
1073
|
+
throw new FS.ErrnoError(32);
|
|
1074
|
+
}
|
|
1075
|
+
var parts = path.split("/").filter((p) => !!p);
|
|
1076
|
+
var current = FS.root;
|
|
1077
|
+
var current_path = "/";
|
|
1078
|
+
for (var i = 0; i < parts.length; i++) {
|
|
1079
|
+
var islast = i === parts.length - 1;
|
|
1080
|
+
if (islast && opts.parent) {
|
|
1081
|
+
break;
|
|
1082
|
+
}
|
|
1083
|
+
current = FS.lookupNode(current, parts[i]);
|
|
1084
|
+
current_path = PATH.join2(current_path, parts[i]);
|
|
1085
|
+
if (FS.isMountpoint(current)) {
|
|
1086
|
+
if (!islast || islast && opts.follow_mount) {
|
|
1087
|
+
current = current.mounted.root;
|
|
1088
|
+
}
|
|
1089
|
+
}
|
|
1090
|
+
if (!islast || opts.follow) {
|
|
1091
|
+
var count = 0;
|
|
1092
|
+
while (FS.isLink(current.mode)) {
|
|
1093
|
+
var link = FS.readlink(current_path);
|
|
1094
|
+
current_path = PATH_FS.resolve(PATH.dirname(current_path), link);
|
|
1095
|
+
var lookup = FS.lookupPath(current_path, { recurse_count: opts.recurse_count + 1 });
|
|
1096
|
+
current = lookup.node;
|
|
1097
|
+
if (count++ > 40) {
|
|
1098
|
+
throw new FS.ErrnoError(32);
|
|
1099
|
+
}
|
|
1100
|
+
}
|
|
1101
|
+
}
|
|
1102
|
+
}
|
|
1103
|
+
return { path: current_path, node: current };
|
|
1104
|
+
}, getPath(node) {
|
|
1105
|
+
var path;
|
|
1106
|
+
while (true) {
|
|
1107
|
+
if (FS.isRoot(node)) {
|
|
1108
|
+
var mount = node.mount.mountpoint;
|
|
1109
|
+
if (!path) return mount;
|
|
1110
|
+
return mount[mount.length - 1] !== "/" ? `${mount}/${path}` : mount + path;
|
|
1111
|
+
}
|
|
1112
|
+
path = path ? `${node.name}/${path}` : node.name;
|
|
1113
|
+
node = node.parent;
|
|
1114
|
+
}
|
|
1115
|
+
}, hashName(parentid, name) {
|
|
1116
|
+
var hash = 0;
|
|
1117
|
+
for (var i = 0; i < name.length; i++) {
|
|
1118
|
+
hash = (hash << 5) - hash + name.charCodeAt(i) | 0;
|
|
1119
|
+
}
|
|
1120
|
+
return (parentid + hash >>> 0) % FS.nameTable.length;
|
|
1121
|
+
}, hashAddNode(node) {
|
|
1122
|
+
var hash = FS.hashName(node.parent.id, node.name);
|
|
1123
|
+
node.name_next = FS.nameTable[hash];
|
|
1124
|
+
FS.nameTable[hash] = node;
|
|
1125
|
+
}, hashRemoveNode(node) {
|
|
1126
|
+
var hash = FS.hashName(node.parent.id, node.name);
|
|
1127
|
+
if (FS.nameTable[hash] === node) {
|
|
1128
|
+
FS.nameTable[hash] = node.name_next;
|
|
1129
|
+
} else {
|
|
1130
|
+
var current = FS.nameTable[hash];
|
|
1131
|
+
while (current) {
|
|
1132
|
+
if (current.name_next === node) {
|
|
1133
|
+
current.name_next = node.name_next;
|
|
1134
|
+
break;
|
|
1135
|
+
}
|
|
1136
|
+
current = current.name_next;
|
|
1137
|
+
}
|
|
1138
|
+
}
|
|
1139
|
+
}, lookupNode(parent, name) {
|
|
1140
|
+
var errCode = FS.mayLookup(parent);
|
|
1141
|
+
if (errCode) {
|
|
1142
|
+
throw new FS.ErrnoError(errCode);
|
|
1143
|
+
}
|
|
1144
|
+
var hash = FS.hashName(parent.id, name);
|
|
1145
|
+
for (var node = FS.nameTable[hash]; node; node = node.name_next) {
|
|
1146
|
+
var nodeName = node.name;
|
|
1147
|
+
if (node.parent.id === parent.id && nodeName === name) {
|
|
1148
|
+
return node;
|
|
1149
|
+
}
|
|
1150
|
+
}
|
|
1151
|
+
return FS.lookup(parent, name);
|
|
1152
|
+
}, createNode(parent, name, mode, rdev) {
|
|
1153
|
+
var node = new FS.FSNode(parent, name, mode, rdev);
|
|
1154
|
+
FS.hashAddNode(node);
|
|
1155
|
+
return node;
|
|
1156
|
+
}, destroyNode(node) {
|
|
1157
|
+
FS.hashRemoveNode(node);
|
|
1158
|
+
}, isRoot(node) {
|
|
1159
|
+
return node === node.parent;
|
|
1160
|
+
}, isMountpoint(node) {
|
|
1161
|
+
return !!node.mounted;
|
|
1162
|
+
}, isFile(mode) {
|
|
1163
|
+
return (mode & 61440) === 32768;
|
|
1164
|
+
}, isDir(mode) {
|
|
1165
|
+
return (mode & 61440) === 16384;
|
|
1166
|
+
}, isLink(mode) {
|
|
1167
|
+
return (mode & 61440) === 40960;
|
|
1168
|
+
}, isChrdev(mode) {
|
|
1169
|
+
return (mode & 61440) === 8192;
|
|
1170
|
+
}, isBlkdev(mode) {
|
|
1171
|
+
return (mode & 61440) === 24576;
|
|
1172
|
+
}, isFIFO(mode) {
|
|
1173
|
+
return (mode & 61440) === 4096;
|
|
1174
|
+
}, isSocket(mode) {
|
|
1175
|
+
return (mode & 49152) === 49152;
|
|
1176
|
+
}, flagsToPermissionString(flag) {
|
|
1177
|
+
var perms = ["r", "w", "rw"][flag & 3];
|
|
1178
|
+
if (flag & 512) {
|
|
1179
|
+
perms += "w";
|
|
1180
|
+
}
|
|
1181
|
+
return perms;
|
|
1182
|
+
}, nodePermissions(node, perms) {
|
|
1183
|
+
if (FS.ignorePermissions) {
|
|
1184
|
+
return 0;
|
|
1185
|
+
}
|
|
1186
|
+
if (perms.includes("r") && !(node.mode & 292)) {
|
|
1187
|
+
return 2;
|
|
1188
|
+
} else if (perms.includes("w") && !(node.mode & 146)) {
|
|
1189
|
+
return 2;
|
|
1190
|
+
} else if (perms.includes("x") && !(node.mode & 73)) {
|
|
1191
|
+
return 2;
|
|
1192
|
+
}
|
|
1193
|
+
return 0;
|
|
1194
|
+
}, mayLookup(dir) {
|
|
1195
|
+
if (!FS.isDir(dir.mode)) return 54;
|
|
1196
|
+
var errCode = FS.nodePermissions(dir, "x");
|
|
1197
|
+
if (errCode) return errCode;
|
|
1198
|
+
if (!dir.node_ops.lookup) return 2;
|
|
1199
|
+
return 0;
|
|
1200
|
+
}, mayCreate(dir, name) {
|
|
1201
|
+
try {
|
|
1202
|
+
var node = FS.lookupNode(dir, name);
|
|
1203
|
+
return 20;
|
|
1204
|
+
} catch (e) {
|
|
1205
|
+
}
|
|
1206
|
+
return FS.nodePermissions(dir, "wx");
|
|
1207
|
+
}, mayDelete(dir, name, isdir) {
|
|
1208
|
+
var node;
|
|
1209
|
+
try {
|
|
1210
|
+
node = FS.lookupNode(dir, name);
|
|
1211
|
+
} catch (e) {
|
|
1212
|
+
return e.errno;
|
|
1213
|
+
}
|
|
1214
|
+
var errCode = FS.nodePermissions(dir, "wx");
|
|
1215
|
+
if (errCode) {
|
|
1216
|
+
return errCode;
|
|
1217
|
+
}
|
|
1218
|
+
if (isdir) {
|
|
1219
|
+
if (!FS.isDir(node.mode)) {
|
|
1220
|
+
return 54;
|
|
1221
|
+
}
|
|
1222
|
+
if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
|
|
1223
|
+
return 10;
|
|
1224
|
+
}
|
|
1225
|
+
} else {
|
|
1226
|
+
if (FS.isDir(node.mode)) {
|
|
1227
|
+
return 31;
|
|
1228
|
+
}
|
|
1229
|
+
}
|
|
1230
|
+
return 0;
|
|
1231
|
+
}, mayOpen(node, flags) {
|
|
1232
|
+
if (!node) {
|
|
1233
|
+
return 44;
|
|
1234
|
+
}
|
|
1235
|
+
if (FS.isLink(node.mode)) {
|
|
1236
|
+
return 32;
|
|
1237
|
+
} else if (FS.isDir(node.mode)) {
|
|
1238
|
+
if (FS.flagsToPermissionString(flags) !== "r" || flags & 512) {
|
|
1239
|
+
return 31;
|
|
1240
|
+
}
|
|
1241
|
+
}
|
|
1242
|
+
return FS.nodePermissions(node, FS.flagsToPermissionString(flags));
|
|
1243
|
+
}, MAX_OPEN_FDS: 4096, nextfd() {
|
|
1244
|
+
for (var fd = 0; fd <= FS.MAX_OPEN_FDS; fd++) {
|
|
1245
|
+
if (!FS.streams[fd]) {
|
|
1246
|
+
return fd;
|
|
1247
|
+
}
|
|
1248
|
+
}
|
|
1249
|
+
throw new FS.ErrnoError(33);
|
|
1250
|
+
}, getStreamChecked(fd) {
|
|
1251
|
+
var stream = FS.getStream(fd);
|
|
1252
|
+
if (!stream) {
|
|
1253
|
+
throw new FS.ErrnoError(8);
|
|
1254
|
+
}
|
|
1255
|
+
return stream;
|
|
1256
|
+
}, getStream: (fd) => FS.streams[fd], createStream(stream, fd = -1) {
|
|
1257
|
+
stream = Object.assign(new FS.FSStream(), stream);
|
|
1258
|
+
if (fd == -1) {
|
|
1259
|
+
fd = FS.nextfd();
|
|
1260
|
+
}
|
|
1261
|
+
stream.fd = fd;
|
|
1262
|
+
FS.streams[fd] = stream;
|
|
1263
|
+
return stream;
|
|
1264
|
+
}, closeStream(fd) {
|
|
1265
|
+
FS.streams[fd] = null;
|
|
1266
|
+
}, dupStream(origStream, fd = -1) {
|
|
1267
|
+
var stream = FS.createStream(origStream, fd);
|
|
1268
|
+
stream.stream_ops?.dup?.(stream);
|
|
1269
|
+
return stream;
|
|
1270
|
+
}, chrdev_stream_ops: { open(stream) {
|
|
1271
|
+
var device = FS.getDevice(stream.node.rdev);
|
|
1272
|
+
stream.stream_ops = device.stream_ops;
|
|
1273
|
+
stream.stream_ops.open?.(stream);
|
|
1274
|
+
}, llseek() {
|
|
1275
|
+
throw new FS.ErrnoError(70);
|
|
1276
|
+
} }, major: (dev) => dev >> 8, minor: (dev) => dev & 255, makedev: (ma, mi) => ma << 8 | mi, registerDevice(dev, ops) {
|
|
1277
|
+
FS.devices[dev] = { stream_ops: ops };
|
|
1278
|
+
}, getDevice: (dev) => FS.devices[dev], getMounts(mount) {
|
|
1279
|
+
var mounts = [];
|
|
1280
|
+
var check = [mount];
|
|
1281
|
+
while (check.length) {
|
|
1282
|
+
var m = check.pop();
|
|
1283
|
+
mounts.push(m);
|
|
1284
|
+
check.push(...m.mounts);
|
|
1285
|
+
}
|
|
1286
|
+
return mounts;
|
|
1287
|
+
}, syncfs(populate, callback) {
|
|
1288
|
+
if (typeof populate == "function") {
|
|
1289
|
+
callback = populate;
|
|
1290
|
+
populate = false;
|
|
1291
|
+
}
|
|
1292
|
+
FS.syncFSRequests++;
|
|
1293
|
+
if (FS.syncFSRequests > 1) {
|
|
1294
|
+
err(`warning: ${FS.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`);
|
|
1295
|
+
}
|
|
1296
|
+
var mounts = FS.getMounts(FS.root.mount);
|
|
1297
|
+
var completed = 0;
|
|
1298
|
+
function doCallback(errCode) {
|
|
1299
|
+
FS.syncFSRequests--;
|
|
1300
|
+
return callback(errCode);
|
|
1301
|
+
}
|
|
1302
|
+
function done(errCode) {
|
|
1303
|
+
if (errCode) {
|
|
1304
|
+
if (!done.errored) {
|
|
1305
|
+
done.errored = true;
|
|
1306
|
+
return doCallback(errCode);
|
|
1307
|
+
}
|
|
1308
|
+
return;
|
|
1309
|
+
}
|
|
1310
|
+
if (++completed >= mounts.length) {
|
|
1311
|
+
doCallback(null);
|
|
1312
|
+
}
|
|
1313
|
+
}
|
|
1314
|
+
mounts.forEach((mount) => {
|
|
1315
|
+
if (!mount.type.syncfs) {
|
|
1316
|
+
return done(null);
|
|
1317
|
+
}
|
|
1318
|
+
mount.type.syncfs(mount, populate, done);
|
|
1319
|
+
});
|
|
1320
|
+
}, mount(type, opts, mountpoint) {
|
|
1321
|
+
var root = mountpoint === "/";
|
|
1322
|
+
var pseudo = !mountpoint;
|
|
1323
|
+
var node;
|
|
1324
|
+
if (root && FS.root) {
|
|
1325
|
+
throw new FS.ErrnoError(10);
|
|
1326
|
+
} else if (!root && !pseudo) {
|
|
1327
|
+
var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
|
|
1328
|
+
mountpoint = lookup.path;
|
|
1329
|
+
node = lookup.node;
|
|
1330
|
+
if (FS.isMountpoint(node)) {
|
|
1331
|
+
throw new FS.ErrnoError(10);
|
|
1332
|
+
}
|
|
1333
|
+
if (!FS.isDir(node.mode)) {
|
|
1334
|
+
throw new FS.ErrnoError(54);
|
|
1335
|
+
}
|
|
1336
|
+
}
|
|
1337
|
+
var mount = { type, opts, mountpoint, mounts: [] };
|
|
1338
|
+
var mountRoot = type.mount(mount);
|
|
1339
|
+
mountRoot.mount = mount;
|
|
1340
|
+
mount.root = mountRoot;
|
|
1341
|
+
if (root) {
|
|
1342
|
+
FS.root = mountRoot;
|
|
1343
|
+
} else if (node) {
|
|
1344
|
+
node.mounted = mount;
|
|
1345
|
+
if (node.mount) {
|
|
1346
|
+
node.mount.mounts.push(mount);
|
|
1347
|
+
}
|
|
1348
|
+
}
|
|
1349
|
+
return mountRoot;
|
|
1350
|
+
}, unmount(mountpoint) {
|
|
1351
|
+
var lookup = FS.lookupPath(mountpoint, { follow_mount: false });
|
|
1352
|
+
if (!FS.isMountpoint(lookup.node)) {
|
|
1353
|
+
throw new FS.ErrnoError(28);
|
|
1354
|
+
}
|
|
1355
|
+
var node = lookup.node;
|
|
1356
|
+
var mount = node.mounted;
|
|
1357
|
+
var mounts = FS.getMounts(mount);
|
|
1358
|
+
Object.keys(FS.nameTable).forEach((hash) => {
|
|
1359
|
+
var current = FS.nameTable[hash];
|
|
1360
|
+
while (current) {
|
|
1361
|
+
var next = current.name_next;
|
|
1362
|
+
if (mounts.includes(current.mount)) {
|
|
1363
|
+
FS.destroyNode(current);
|
|
1364
|
+
}
|
|
1365
|
+
current = next;
|
|
1366
|
+
}
|
|
1367
|
+
});
|
|
1368
|
+
node.mounted = null;
|
|
1369
|
+
var idx = node.mount.mounts.indexOf(mount);
|
|
1370
|
+
node.mount.mounts.splice(idx, 1);
|
|
1371
|
+
}, lookup(parent, name) {
|
|
1372
|
+
return parent.node_ops.lookup(parent, name);
|
|
1373
|
+
}, mknod(path, mode, dev) {
|
|
1374
|
+
var lookup = FS.lookupPath(path, { parent: true });
|
|
1375
|
+
var parent = lookup.node;
|
|
1376
|
+
var name = PATH.basename(path);
|
|
1377
|
+
if (!name || name === "." || name === "..") {
|
|
1378
|
+
throw new FS.ErrnoError(28);
|
|
1379
|
+
}
|
|
1380
|
+
var errCode = FS.mayCreate(parent, name);
|
|
1381
|
+
if (errCode) {
|
|
1382
|
+
throw new FS.ErrnoError(errCode);
|
|
1383
|
+
}
|
|
1384
|
+
if (!parent.node_ops.mknod) {
|
|
1385
|
+
throw new FS.ErrnoError(63);
|
|
1386
|
+
}
|
|
1387
|
+
return parent.node_ops.mknod(parent, name, mode, dev);
|
|
1388
|
+
}, create(path, mode) {
|
|
1389
|
+
mode = mode !== void 0 ? mode : 438;
|
|
1390
|
+
mode &= 4095;
|
|
1391
|
+
mode |= 32768;
|
|
1392
|
+
return FS.mknod(path, mode, 0);
|
|
1393
|
+
}, mkdir(path, mode) {
|
|
1394
|
+
mode = mode !== void 0 ? mode : 511;
|
|
1395
|
+
mode &= 511 | 512;
|
|
1396
|
+
mode |= 16384;
|
|
1397
|
+
return FS.mknod(path, mode, 0);
|
|
1398
|
+
}, mkdirTree(path, mode) {
|
|
1399
|
+
var dirs = path.split("/");
|
|
1400
|
+
var d = "";
|
|
1401
|
+
for (var i = 0; i < dirs.length; ++i) {
|
|
1402
|
+
if (!dirs[i]) continue;
|
|
1403
|
+
d += "/" + dirs[i];
|
|
1404
|
+
try {
|
|
1405
|
+
FS.mkdir(d, mode);
|
|
1406
|
+
} catch (e) {
|
|
1407
|
+
if (e.errno != 20) throw e;
|
|
1408
|
+
}
|
|
1409
|
+
}
|
|
1410
|
+
}, mkdev(path, mode, dev) {
|
|
1411
|
+
if (typeof dev == "undefined") {
|
|
1412
|
+
dev = mode;
|
|
1413
|
+
mode = 438;
|
|
1414
|
+
}
|
|
1415
|
+
mode |= 8192;
|
|
1416
|
+
return FS.mknod(path, mode, dev);
|
|
1417
|
+
}, symlink(oldpath, newpath) {
|
|
1418
|
+
if (!PATH_FS.resolve(oldpath)) {
|
|
1419
|
+
throw new FS.ErrnoError(44);
|
|
1420
|
+
}
|
|
1421
|
+
var lookup = FS.lookupPath(newpath, { parent: true });
|
|
1422
|
+
var parent = lookup.node;
|
|
1423
|
+
if (!parent) {
|
|
1424
|
+
throw new FS.ErrnoError(44);
|
|
1425
|
+
}
|
|
1426
|
+
var newname = PATH.basename(newpath);
|
|
1427
|
+
var errCode = FS.mayCreate(parent, newname);
|
|
1428
|
+
if (errCode) {
|
|
1429
|
+
throw new FS.ErrnoError(errCode);
|
|
1430
|
+
}
|
|
1431
|
+
if (!parent.node_ops.symlink) {
|
|
1432
|
+
throw new FS.ErrnoError(63);
|
|
1433
|
+
}
|
|
1434
|
+
return parent.node_ops.symlink(parent, newname, oldpath);
|
|
1435
|
+
}, rename(old_path, new_path) {
|
|
1436
|
+
var old_dirname = PATH.dirname(old_path);
|
|
1437
|
+
var new_dirname = PATH.dirname(new_path);
|
|
1438
|
+
var old_name = PATH.basename(old_path);
|
|
1439
|
+
var new_name = PATH.basename(new_path);
|
|
1440
|
+
var lookup, old_dir, new_dir;
|
|
1441
|
+
lookup = FS.lookupPath(old_path, { parent: true });
|
|
1442
|
+
old_dir = lookup.node;
|
|
1443
|
+
lookup = FS.lookupPath(new_path, { parent: true });
|
|
1444
|
+
new_dir = lookup.node;
|
|
1445
|
+
if (!old_dir || !new_dir) throw new FS.ErrnoError(44);
|
|
1446
|
+
if (old_dir.mount !== new_dir.mount) {
|
|
1447
|
+
throw new FS.ErrnoError(75);
|
|
1448
|
+
}
|
|
1449
|
+
var old_node = FS.lookupNode(old_dir, old_name);
|
|
1450
|
+
var relative = PATH_FS.relative(old_path, new_dirname);
|
|
1451
|
+
if (relative.charAt(0) !== ".") {
|
|
1452
|
+
throw new FS.ErrnoError(28);
|
|
1453
|
+
}
|
|
1454
|
+
relative = PATH_FS.relative(new_path, old_dirname);
|
|
1455
|
+
if (relative.charAt(0) !== ".") {
|
|
1456
|
+
throw new FS.ErrnoError(55);
|
|
1457
|
+
}
|
|
1458
|
+
var new_node;
|
|
1459
|
+
try {
|
|
1460
|
+
new_node = FS.lookupNode(new_dir, new_name);
|
|
1461
|
+
} catch (e) {
|
|
1462
|
+
}
|
|
1463
|
+
if (old_node === new_node) {
|
|
1464
|
+
return;
|
|
1465
|
+
}
|
|
1466
|
+
var isdir = FS.isDir(old_node.mode);
|
|
1467
|
+
var errCode = FS.mayDelete(old_dir, old_name, isdir);
|
|
1468
|
+
if (errCode) {
|
|
1469
|
+
throw new FS.ErrnoError(errCode);
|
|
1470
|
+
}
|
|
1471
|
+
errCode = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name);
|
|
1472
|
+
if (errCode) {
|
|
1473
|
+
throw new FS.ErrnoError(errCode);
|
|
1474
|
+
}
|
|
1475
|
+
if (!old_dir.node_ops.rename) {
|
|
1476
|
+
throw new FS.ErrnoError(63);
|
|
1477
|
+
}
|
|
1478
|
+
if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
|
|
1479
|
+
throw new FS.ErrnoError(10);
|
|
1480
|
+
}
|
|
1481
|
+
if (new_dir !== old_dir) {
|
|
1482
|
+
errCode = FS.nodePermissions(old_dir, "w");
|
|
1483
|
+
if (errCode) {
|
|
1484
|
+
throw new FS.ErrnoError(errCode);
|
|
1485
|
+
}
|
|
1486
|
+
}
|
|
1487
|
+
FS.hashRemoveNode(old_node);
|
|
1488
|
+
try {
|
|
1489
|
+
old_dir.node_ops.rename(old_node, new_dir, new_name);
|
|
1490
|
+
} catch (e) {
|
|
1491
|
+
throw e;
|
|
1492
|
+
} finally {
|
|
1493
|
+
FS.hashAddNode(old_node);
|
|
1494
|
+
}
|
|
1495
|
+
}, rmdir(path) {
|
|
1496
|
+
var lookup = FS.lookupPath(path, { parent: true });
|
|
1497
|
+
var parent = lookup.node;
|
|
1498
|
+
var name = PATH.basename(path);
|
|
1499
|
+
var node = FS.lookupNode(parent, name);
|
|
1500
|
+
var errCode = FS.mayDelete(parent, name, true);
|
|
1501
|
+
if (errCode) {
|
|
1502
|
+
throw new FS.ErrnoError(errCode);
|
|
1503
|
+
}
|
|
1504
|
+
if (!parent.node_ops.rmdir) {
|
|
1505
|
+
throw new FS.ErrnoError(63);
|
|
1506
|
+
}
|
|
1507
|
+
if (FS.isMountpoint(node)) {
|
|
1508
|
+
throw new FS.ErrnoError(10);
|
|
1509
|
+
}
|
|
1510
|
+
parent.node_ops.rmdir(parent, name);
|
|
1511
|
+
FS.destroyNode(node);
|
|
1512
|
+
}, readdir(path) {
|
|
1513
|
+
var lookup = FS.lookupPath(path, { follow: true });
|
|
1514
|
+
var node = lookup.node;
|
|
1515
|
+
if (!node.node_ops.readdir) {
|
|
1516
|
+
throw new FS.ErrnoError(54);
|
|
1517
|
+
}
|
|
1518
|
+
return node.node_ops.readdir(node);
|
|
1519
|
+
}, unlink(path) {
|
|
1520
|
+
var lookup = FS.lookupPath(path, { parent: true });
|
|
1521
|
+
var parent = lookup.node;
|
|
1522
|
+
if (!parent) {
|
|
1523
|
+
throw new FS.ErrnoError(44);
|
|
1524
|
+
}
|
|
1525
|
+
var name = PATH.basename(path);
|
|
1526
|
+
var node = FS.lookupNode(parent, name);
|
|
1527
|
+
var errCode = FS.mayDelete(parent, name, false);
|
|
1528
|
+
if (errCode) {
|
|
1529
|
+
throw new FS.ErrnoError(errCode);
|
|
1530
|
+
}
|
|
1531
|
+
if (!parent.node_ops.unlink) {
|
|
1532
|
+
throw new FS.ErrnoError(63);
|
|
1533
|
+
}
|
|
1534
|
+
if (FS.isMountpoint(node)) {
|
|
1535
|
+
throw new FS.ErrnoError(10);
|
|
1536
|
+
}
|
|
1537
|
+
parent.node_ops.unlink(parent, name);
|
|
1538
|
+
FS.destroyNode(node);
|
|
1539
|
+
}, readlink(path) {
|
|
1540
|
+
var lookup = FS.lookupPath(path);
|
|
1541
|
+
var link = lookup.node;
|
|
1542
|
+
if (!link) {
|
|
1543
|
+
throw new FS.ErrnoError(44);
|
|
1544
|
+
}
|
|
1545
|
+
if (!link.node_ops.readlink) {
|
|
1546
|
+
throw new FS.ErrnoError(28);
|
|
1547
|
+
}
|
|
1548
|
+
return PATH_FS.resolve(FS.getPath(link.parent), link.node_ops.readlink(link));
|
|
1549
|
+
}, stat(path, dontFollow) {
|
|
1550
|
+
var lookup = FS.lookupPath(path, { follow: !dontFollow });
|
|
1551
|
+
var node = lookup.node;
|
|
1552
|
+
if (!node) {
|
|
1553
|
+
throw new FS.ErrnoError(44);
|
|
1554
|
+
}
|
|
1555
|
+
if (!node.node_ops.getattr) {
|
|
1556
|
+
throw new FS.ErrnoError(63);
|
|
1557
|
+
}
|
|
1558
|
+
return node.node_ops.getattr(node);
|
|
1559
|
+
}, lstat(path) {
|
|
1560
|
+
return FS.stat(path, true);
|
|
1561
|
+
}, chmod(path, mode, dontFollow) {
|
|
1562
|
+
var node;
|
|
1563
|
+
if (typeof path == "string") {
|
|
1564
|
+
var lookup = FS.lookupPath(path, { follow: !dontFollow });
|
|
1565
|
+
node = lookup.node;
|
|
1566
|
+
} else {
|
|
1567
|
+
node = path;
|
|
1568
|
+
}
|
|
1569
|
+
if (!node.node_ops.setattr) {
|
|
1570
|
+
throw new FS.ErrnoError(63);
|
|
1571
|
+
}
|
|
1572
|
+
node.node_ops.setattr(node, { mode: mode & 4095 | node.mode & ~4095, timestamp: Date.now() });
|
|
1573
|
+
}, lchmod(path, mode) {
|
|
1574
|
+
FS.chmod(path, mode, true);
|
|
1575
|
+
}, fchmod(fd, mode) {
|
|
1576
|
+
var stream = FS.getStreamChecked(fd);
|
|
1577
|
+
FS.chmod(stream.node, mode);
|
|
1578
|
+
}, chown(path, uid, gid, dontFollow) {
|
|
1579
|
+
var node;
|
|
1580
|
+
if (typeof path == "string") {
|
|
1581
|
+
var lookup = FS.lookupPath(path, { follow: !dontFollow });
|
|
1582
|
+
node = lookup.node;
|
|
1583
|
+
} else {
|
|
1584
|
+
node = path;
|
|
1585
|
+
}
|
|
1586
|
+
if (!node.node_ops.setattr) {
|
|
1587
|
+
throw new FS.ErrnoError(63);
|
|
1588
|
+
}
|
|
1589
|
+
node.node_ops.setattr(node, { timestamp: Date.now() });
|
|
1590
|
+
}, lchown(path, uid, gid) {
|
|
1591
|
+
FS.chown(path, uid, gid, true);
|
|
1592
|
+
}, fchown(fd, uid, gid) {
|
|
1593
|
+
var stream = FS.getStreamChecked(fd);
|
|
1594
|
+
FS.chown(stream.node, uid, gid);
|
|
1595
|
+
}, truncate(path, len) {
|
|
1596
|
+
if (len < 0) {
|
|
1597
|
+
throw new FS.ErrnoError(28);
|
|
1598
|
+
}
|
|
1599
|
+
var node;
|
|
1600
|
+
if (typeof path == "string") {
|
|
1601
|
+
var lookup = FS.lookupPath(path, { follow: true });
|
|
1602
|
+
node = lookup.node;
|
|
1603
|
+
} else {
|
|
1604
|
+
node = path;
|
|
1605
|
+
}
|
|
1606
|
+
if (!node.node_ops.setattr) {
|
|
1607
|
+
throw new FS.ErrnoError(63);
|
|
1608
|
+
}
|
|
1609
|
+
if (FS.isDir(node.mode)) {
|
|
1610
|
+
throw new FS.ErrnoError(31);
|
|
1611
|
+
}
|
|
1612
|
+
if (!FS.isFile(node.mode)) {
|
|
1613
|
+
throw new FS.ErrnoError(28);
|
|
1614
|
+
}
|
|
1615
|
+
var errCode = FS.nodePermissions(node, "w");
|
|
1616
|
+
if (errCode) {
|
|
1617
|
+
throw new FS.ErrnoError(errCode);
|
|
1618
|
+
}
|
|
1619
|
+
node.node_ops.setattr(node, { size: len, timestamp: Date.now() });
|
|
1620
|
+
}, ftruncate(fd, len) {
|
|
1621
|
+
var stream = FS.getStreamChecked(fd);
|
|
1622
|
+
if ((stream.flags & 2097155) === 0) {
|
|
1623
|
+
throw new FS.ErrnoError(28);
|
|
1624
|
+
}
|
|
1625
|
+
FS.truncate(stream.node, len);
|
|
1626
|
+
}, utime(path, atime, mtime) {
|
|
1627
|
+
var lookup = FS.lookupPath(path, { follow: true });
|
|
1628
|
+
var node = lookup.node;
|
|
1629
|
+
node.node_ops.setattr(node, { timestamp: Math.max(atime, mtime) });
|
|
1630
|
+
}, open(path, flags, mode) {
|
|
1631
|
+
if (path === "") {
|
|
1632
|
+
throw new FS.ErrnoError(44);
|
|
1633
|
+
}
|
|
1634
|
+
flags = typeof flags == "string" ? FS_modeStringToFlags(flags) : flags;
|
|
1635
|
+
mode = typeof mode == "undefined" ? 438 : mode;
|
|
1636
|
+
if (flags & 64) {
|
|
1637
|
+
mode = mode & 4095 | 32768;
|
|
1638
|
+
} else {
|
|
1639
|
+
mode = 0;
|
|
1640
|
+
}
|
|
1641
|
+
var node;
|
|
1642
|
+
if (typeof path == "object") {
|
|
1643
|
+
node = path;
|
|
1644
|
+
} else {
|
|
1645
|
+
path = PATH.normalize(path);
|
|
1646
|
+
try {
|
|
1647
|
+
var lookup = FS.lookupPath(path, { follow: !(flags & 131072) });
|
|
1648
|
+
node = lookup.node;
|
|
1649
|
+
} catch (e) {
|
|
1650
|
+
}
|
|
1651
|
+
}
|
|
1652
|
+
var created = false;
|
|
1653
|
+
if (flags & 64) {
|
|
1654
|
+
if (node) {
|
|
1655
|
+
if (flags & 128) {
|
|
1656
|
+
throw new FS.ErrnoError(20);
|
|
1657
|
+
}
|
|
1658
|
+
} else {
|
|
1659
|
+
node = FS.mknod(path, mode, 0);
|
|
1660
|
+
created = true;
|
|
1661
|
+
}
|
|
1662
|
+
}
|
|
1663
|
+
if (!node) {
|
|
1664
|
+
throw new FS.ErrnoError(44);
|
|
1665
|
+
}
|
|
1666
|
+
if (FS.isChrdev(node.mode)) {
|
|
1667
|
+
flags &= ~512;
|
|
1668
|
+
}
|
|
1669
|
+
if (flags & 65536 && !FS.isDir(node.mode)) {
|
|
1670
|
+
throw new FS.ErrnoError(54);
|
|
1671
|
+
}
|
|
1672
|
+
if (!created) {
|
|
1673
|
+
var errCode = FS.mayOpen(node, flags);
|
|
1674
|
+
if (errCode) {
|
|
1675
|
+
throw new FS.ErrnoError(errCode);
|
|
1676
|
+
}
|
|
1677
|
+
}
|
|
1678
|
+
if (flags & 512 && !created) {
|
|
1679
|
+
FS.truncate(node, 0);
|
|
1680
|
+
}
|
|
1681
|
+
flags &= ~(128 | 512 | 131072);
|
|
1682
|
+
var stream = FS.createStream({ node, path: FS.getPath(node), flags, seekable: true, position: 0, stream_ops: node.stream_ops, ungotten: [], error: false });
|
|
1683
|
+
if (stream.stream_ops.open) {
|
|
1684
|
+
stream.stream_ops.open(stream);
|
|
1685
|
+
}
|
|
1686
|
+
if (Module["logReadFiles"] && !(flags & 1)) {
|
|
1687
|
+
if (!FS.readFiles) FS.readFiles = {};
|
|
1688
|
+
if (!(path in FS.readFiles)) {
|
|
1689
|
+
FS.readFiles[path] = 1;
|
|
1690
|
+
}
|
|
1691
|
+
}
|
|
1692
|
+
return stream;
|
|
1693
|
+
}, close(stream) {
|
|
1694
|
+
if (FS.isClosed(stream)) {
|
|
1695
|
+
throw new FS.ErrnoError(8);
|
|
1696
|
+
}
|
|
1697
|
+
if (stream.getdents) stream.getdents = null;
|
|
1698
|
+
try {
|
|
1699
|
+
if (stream.stream_ops.close) {
|
|
1700
|
+
stream.stream_ops.close(stream);
|
|
1701
|
+
}
|
|
1702
|
+
} catch (e) {
|
|
1703
|
+
throw e;
|
|
1704
|
+
} finally {
|
|
1705
|
+
FS.closeStream(stream.fd);
|
|
1706
|
+
}
|
|
1707
|
+
stream.fd = null;
|
|
1708
|
+
}, isClosed(stream) {
|
|
1709
|
+
return stream.fd === null;
|
|
1710
|
+
}, llseek(stream, offset, whence) {
|
|
1711
|
+
if (FS.isClosed(stream)) {
|
|
1712
|
+
throw new FS.ErrnoError(8);
|
|
1713
|
+
}
|
|
1714
|
+
if (!stream.seekable || !stream.stream_ops.llseek) {
|
|
1715
|
+
throw new FS.ErrnoError(70);
|
|
1716
|
+
}
|
|
1717
|
+
if (whence != 0 && whence != 1 && whence != 2) {
|
|
1718
|
+
throw new FS.ErrnoError(28);
|
|
1719
|
+
}
|
|
1720
|
+
stream.position = stream.stream_ops.llseek(stream, offset, whence);
|
|
1721
|
+
stream.ungotten = [];
|
|
1722
|
+
return stream.position;
|
|
1723
|
+
}, read(stream, buffer, offset, length, position) {
|
|
1724
|
+
if (length < 0 || position < 0) {
|
|
1725
|
+
throw new FS.ErrnoError(28);
|
|
1726
|
+
}
|
|
1727
|
+
if (FS.isClosed(stream)) {
|
|
1728
|
+
throw new FS.ErrnoError(8);
|
|
1729
|
+
}
|
|
1730
|
+
if ((stream.flags & 2097155) === 1) {
|
|
1731
|
+
throw new FS.ErrnoError(8);
|
|
1732
|
+
}
|
|
1733
|
+
if (FS.isDir(stream.node.mode)) {
|
|
1734
|
+
throw new FS.ErrnoError(31);
|
|
1735
|
+
}
|
|
1736
|
+
if (!stream.stream_ops.read) {
|
|
1737
|
+
throw new FS.ErrnoError(28);
|
|
1738
|
+
}
|
|
1739
|
+
var seeking = typeof position != "undefined";
|
|
1740
|
+
if (!seeking) {
|
|
1741
|
+
position = stream.position;
|
|
1742
|
+
} else if (!stream.seekable) {
|
|
1743
|
+
throw new FS.ErrnoError(70);
|
|
1744
|
+
}
|
|
1745
|
+
var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position);
|
|
1746
|
+
if (!seeking) stream.position += bytesRead;
|
|
1747
|
+
return bytesRead;
|
|
1748
|
+
}, write(stream, buffer, offset, length, position, canOwn) {
|
|
1749
|
+
if (length < 0 || position < 0) {
|
|
1750
|
+
throw new FS.ErrnoError(28);
|
|
1751
|
+
}
|
|
1752
|
+
if (FS.isClosed(stream)) {
|
|
1753
|
+
throw new FS.ErrnoError(8);
|
|
1754
|
+
}
|
|
1755
|
+
if ((stream.flags & 2097155) === 0) {
|
|
1756
|
+
throw new FS.ErrnoError(8);
|
|
1757
|
+
}
|
|
1758
|
+
if (FS.isDir(stream.node.mode)) {
|
|
1759
|
+
throw new FS.ErrnoError(31);
|
|
1760
|
+
}
|
|
1761
|
+
if (!stream.stream_ops.write) {
|
|
1762
|
+
throw new FS.ErrnoError(28);
|
|
1763
|
+
}
|
|
1764
|
+
if (stream.seekable && stream.flags & 1024) {
|
|
1765
|
+
FS.llseek(stream, 0, 2);
|
|
1766
|
+
}
|
|
1767
|
+
var seeking = typeof position != "undefined";
|
|
1768
|
+
if (!seeking) {
|
|
1769
|
+
position = stream.position;
|
|
1770
|
+
} else if (!stream.seekable) {
|
|
1771
|
+
throw new FS.ErrnoError(70);
|
|
1772
|
+
}
|
|
1773
|
+
var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn);
|
|
1774
|
+
if (!seeking) stream.position += bytesWritten;
|
|
1775
|
+
return bytesWritten;
|
|
1776
|
+
}, allocate(stream, offset, length) {
|
|
1777
|
+
if (FS.isClosed(stream)) {
|
|
1778
|
+
throw new FS.ErrnoError(8);
|
|
1779
|
+
}
|
|
1780
|
+
if (offset < 0 || length <= 0) {
|
|
1781
|
+
throw new FS.ErrnoError(28);
|
|
1782
|
+
}
|
|
1783
|
+
if ((stream.flags & 2097155) === 0) {
|
|
1784
|
+
throw new FS.ErrnoError(8);
|
|
1785
|
+
}
|
|
1786
|
+
if (!FS.isFile(stream.node.mode) && !FS.isDir(stream.node.mode)) {
|
|
1787
|
+
throw new FS.ErrnoError(43);
|
|
1788
|
+
}
|
|
1789
|
+
if (!stream.stream_ops.allocate) {
|
|
1790
|
+
throw new FS.ErrnoError(138);
|
|
1791
|
+
}
|
|
1792
|
+
stream.stream_ops.allocate(stream, offset, length);
|
|
1793
|
+
}, mmap(stream, length, position, prot, flags) {
|
|
1794
|
+
if ((prot & 2) !== 0 && (flags & 2) === 0 && (stream.flags & 2097155) !== 2) {
|
|
1795
|
+
throw new FS.ErrnoError(2);
|
|
1796
|
+
}
|
|
1797
|
+
if ((stream.flags & 2097155) === 1) {
|
|
1798
|
+
throw new FS.ErrnoError(2);
|
|
1799
|
+
}
|
|
1800
|
+
if (!stream.stream_ops.mmap) {
|
|
1801
|
+
throw new FS.ErrnoError(43);
|
|
1802
|
+
}
|
|
1803
|
+
return stream.stream_ops.mmap(stream, length, position, prot, flags);
|
|
1804
|
+
}, msync(stream, buffer, offset, length, mmapFlags) {
|
|
1805
|
+
if (!stream.stream_ops.msync) {
|
|
1806
|
+
return 0;
|
|
1807
|
+
}
|
|
1808
|
+
return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags);
|
|
1809
|
+
}, ioctl(stream, cmd, arg) {
|
|
1810
|
+
if (!stream.stream_ops.ioctl) {
|
|
1811
|
+
throw new FS.ErrnoError(59);
|
|
1812
|
+
}
|
|
1813
|
+
return stream.stream_ops.ioctl(stream, cmd, arg);
|
|
1814
|
+
}, readFile(path, opts = {}) {
|
|
1815
|
+
opts.flags = opts.flags || 0;
|
|
1816
|
+
opts.encoding = opts.encoding || "binary";
|
|
1817
|
+
if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
|
|
1818
|
+
throw new Error(`Invalid encoding type "${opts.encoding}"`);
|
|
1819
|
+
}
|
|
1820
|
+
var ret;
|
|
1821
|
+
var stream = FS.open(path, opts.flags);
|
|
1822
|
+
var stat = FS.stat(path);
|
|
1823
|
+
var length = stat.size;
|
|
1824
|
+
var buf = new Uint8Array(length);
|
|
1825
|
+
FS.read(stream, buf, 0, length, 0);
|
|
1826
|
+
if (opts.encoding === "utf8") {
|
|
1827
|
+
ret = UTF8ArrayToString(buf, 0);
|
|
1828
|
+
} else if (opts.encoding === "binary") {
|
|
1829
|
+
ret = buf;
|
|
1830
|
+
}
|
|
1831
|
+
FS.close(stream);
|
|
1832
|
+
return ret;
|
|
1833
|
+
}, writeFile(path, data, opts = {}) {
|
|
1834
|
+
opts.flags = opts.flags || 577;
|
|
1835
|
+
var stream = FS.open(path, opts.flags, opts.mode);
|
|
1836
|
+
if (typeof data == "string") {
|
|
1837
|
+
var buf = new Uint8Array(lengthBytesUTF8(data) + 1);
|
|
1838
|
+
var actualNumBytes = stringToUTF8Array(data, buf, 0, buf.length);
|
|
1839
|
+
FS.write(stream, buf, 0, actualNumBytes, void 0, opts.canOwn);
|
|
1840
|
+
} else if (ArrayBuffer.isView(data)) {
|
|
1841
|
+
FS.write(stream, data, 0, data.byteLength, void 0, opts.canOwn);
|
|
1842
|
+
} else {
|
|
1843
|
+
throw new Error("Unsupported data type");
|
|
1844
|
+
}
|
|
1845
|
+
FS.close(stream);
|
|
1846
|
+
}, cwd: () => FS.currentPath, chdir(path) {
|
|
1847
|
+
var lookup = FS.lookupPath(path, { follow: true });
|
|
1848
|
+
if (lookup.node === null) {
|
|
1849
|
+
throw new FS.ErrnoError(44);
|
|
1850
|
+
}
|
|
1851
|
+
if (!FS.isDir(lookup.node.mode)) {
|
|
1852
|
+
throw new FS.ErrnoError(54);
|
|
1853
|
+
}
|
|
1854
|
+
var errCode = FS.nodePermissions(lookup.node, "x");
|
|
1855
|
+
if (errCode) {
|
|
1856
|
+
throw new FS.ErrnoError(errCode);
|
|
1857
|
+
}
|
|
1858
|
+
FS.currentPath = lookup.path;
|
|
1859
|
+
}, createDefaultDirectories() {
|
|
1860
|
+
FS.mkdir("/tmp");
|
|
1861
|
+
FS.mkdir("/home");
|
|
1862
|
+
FS.mkdir("/home/web_user");
|
|
1863
|
+
}, createDefaultDevices() {
|
|
1864
|
+
FS.mkdir("/dev");
|
|
1865
|
+
FS.registerDevice(FS.makedev(1, 3), { read: () => 0, write: (stream, buffer, offset, length, pos) => length });
|
|
1866
|
+
FS.mkdev("/dev/null", FS.makedev(1, 3));
|
|
1867
|
+
TTY.register(FS.makedev(5, 0), TTY.default_tty_ops);
|
|
1868
|
+
TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops);
|
|
1869
|
+
FS.mkdev("/dev/tty", FS.makedev(5, 0));
|
|
1870
|
+
FS.mkdev("/dev/tty1", FS.makedev(6, 0));
|
|
1871
|
+
var randomBuffer = new Uint8Array(1024), randomLeft = 0;
|
|
1872
|
+
var randomByte = () => {
|
|
1873
|
+
if (randomLeft === 0) {
|
|
1874
|
+
randomLeft = randomFill(randomBuffer).byteLength;
|
|
1875
|
+
}
|
|
1876
|
+
return randomBuffer[--randomLeft];
|
|
1877
|
+
};
|
|
1878
|
+
FS.createDevice("/dev", "random", randomByte);
|
|
1879
|
+
FS.createDevice("/dev", "urandom", randomByte);
|
|
1880
|
+
FS.mkdir("/dev/shm");
|
|
1881
|
+
FS.mkdir("/dev/shm/tmp");
|
|
1882
|
+
}, createSpecialDirectories() {
|
|
1883
|
+
FS.mkdir("/proc");
|
|
1884
|
+
var proc_self = FS.mkdir("/proc/self");
|
|
1885
|
+
FS.mkdir("/proc/self/fd");
|
|
1886
|
+
FS.mount({ mount() {
|
|
1887
|
+
var node = FS.createNode(proc_self, "fd", 16384 | 511, 73);
|
|
1888
|
+
node.node_ops = { lookup(parent, name) {
|
|
1889
|
+
var fd = +name;
|
|
1890
|
+
var stream = FS.getStreamChecked(fd);
|
|
1891
|
+
var ret = { parent: null, mount: { mountpoint: "fake" }, node_ops: { readlink: () => stream.path } };
|
|
1892
|
+
ret.parent = ret;
|
|
1893
|
+
return ret;
|
|
1894
|
+
} };
|
|
1895
|
+
return node;
|
|
1896
|
+
} }, {}, "/proc/self/fd");
|
|
1897
|
+
}, createStandardStreams() {
|
|
1898
|
+
if (Module["stdin"]) {
|
|
1899
|
+
FS.createDevice("/dev", "stdin", Module["stdin"]);
|
|
1900
|
+
} else {
|
|
1901
|
+
FS.symlink("/dev/tty", "/dev/stdin");
|
|
1902
|
+
}
|
|
1903
|
+
if (Module["stdout"]) {
|
|
1904
|
+
FS.createDevice("/dev", "stdout", null, Module["stdout"]);
|
|
1905
|
+
} else {
|
|
1906
|
+
FS.symlink("/dev/tty", "/dev/stdout");
|
|
1907
|
+
}
|
|
1908
|
+
if (Module["stderr"]) {
|
|
1909
|
+
FS.createDevice("/dev", "stderr", null, Module["stderr"]);
|
|
1910
|
+
} else {
|
|
1911
|
+
FS.symlink("/dev/tty1", "/dev/stderr");
|
|
1912
|
+
}
|
|
1913
|
+
var stdin = FS.open("/dev/stdin", 0);
|
|
1914
|
+
var stdout = FS.open("/dev/stdout", 1);
|
|
1915
|
+
var stderr = FS.open("/dev/stderr", 1);
|
|
1916
|
+
}, staticInit() {
|
|
1917
|
+
[44].forEach((code) => {
|
|
1918
|
+
FS.genericErrors[code] = new FS.ErrnoError(code);
|
|
1919
|
+
FS.genericErrors[code].stack = "<generic error, no stack>";
|
|
1920
|
+
});
|
|
1921
|
+
FS.nameTable = new Array(4096);
|
|
1922
|
+
FS.mount(MEMFS, {}, "/");
|
|
1923
|
+
FS.createDefaultDirectories();
|
|
1924
|
+
FS.createDefaultDevices();
|
|
1925
|
+
FS.createSpecialDirectories();
|
|
1926
|
+
FS.filesystems = { "MEMFS": MEMFS };
|
|
1927
|
+
}, init(input, output, error) {
|
|
1928
|
+
FS.init.initialized = true;
|
|
1929
|
+
Module["stdin"] = input || Module["stdin"];
|
|
1930
|
+
Module["stdout"] = output || Module["stdout"];
|
|
1931
|
+
Module["stderr"] = error || Module["stderr"];
|
|
1932
|
+
FS.createStandardStreams();
|
|
1933
|
+
}, quit() {
|
|
1934
|
+
FS.init.initialized = false;
|
|
1935
|
+
for (var i = 0; i < FS.streams.length; i++) {
|
|
1936
|
+
var stream = FS.streams[i];
|
|
1937
|
+
if (!stream) {
|
|
1938
|
+
continue;
|
|
1939
|
+
}
|
|
1940
|
+
FS.close(stream);
|
|
1941
|
+
}
|
|
1942
|
+
}, findObject(path, dontResolveLastLink) {
|
|
1943
|
+
var ret = FS.analyzePath(path, dontResolveLastLink);
|
|
1944
|
+
if (!ret.exists) {
|
|
1945
|
+
return null;
|
|
1946
|
+
}
|
|
1947
|
+
return ret.object;
|
|
1948
|
+
}, analyzePath(path, dontResolveLastLink) {
|
|
1949
|
+
try {
|
|
1950
|
+
var lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
|
|
1951
|
+
path = lookup.path;
|
|
1952
|
+
} catch (e) {
|
|
1953
|
+
}
|
|
1954
|
+
var ret = { isRoot: false, exists: false, error: 0, name: null, path: null, object: null, parentExists: false, parentPath: null, parentObject: null };
|
|
1955
|
+
try {
|
|
1956
|
+
var lookup = FS.lookupPath(path, { parent: true });
|
|
1957
|
+
ret.parentExists = true;
|
|
1958
|
+
ret.parentPath = lookup.path;
|
|
1959
|
+
ret.parentObject = lookup.node;
|
|
1960
|
+
ret.name = PATH.basename(path);
|
|
1961
|
+
lookup = FS.lookupPath(path, { follow: !dontResolveLastLink });
|
|
1962
|
+
ret.exists = true;
|
|
1963
|
+
ret.path = lookup.path;
|
|
1964
|
+
ret.object = lookup.node;
|
|
1965
|
+
ret.name = lookup.node.name;
|
|
1966
|
+
ret.isRoot = lookup.path === "/";
|
|
1967
|
+
} catch (e) {
|
|
1968
|
+
ret.error = e.errno;
|
|
1969
|
+
}
|
|
1970
|
+
return ret;
|
|
1971
|
+
}, createPath(parent, path, canRead, canWrite) {
|
|
1972
|
+
parent = typeof parent == "string" ? parent : FS.getPath(parent);
|
|
1973
|
+
var parts = path.split("/").reverse();
|
|
1974
|
+
while (parts.length) {
|
|
1975
|
+
var part = parts.pop();
|
|
1976
|
+
if (!part) continue;
|
|
1977
|
+
var current = PATH.join2(parent, part);
|
|
1978
|
+
try {
|
|
1979
|
+
FS.mkdir(current);
|
|
1980
|
+
} catch (e) {
|
|
1981
|
+
}
|
|
1982
|
+
parent = current;
|
|
1983
|
+
}
|
|
1984
|
+
return current;
|
|
1985
|
+
}, createFile(parent, name, properties, canRead, canWrite) {
|
|
1986
|
+
var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
|
|
1987
|
+
var mode = FS_getMode(canRead, canWrite);
|
|
1988
|
+
return FS.create(path, mode);
|
|
1989
|
+
}, createDataFile(parent, name, data, canRead, canWrite, canOwn) {
|
|
1990
|
+
var path = name;
|
|
1991
|
+
if (parent) {
|
|
1992
|
+
parent = typeof parent == "string" ? parent : FS.getPath(parent);
|
|
1993
|
+
path = name ? PATH.join2(parent, name) : parent;
|
|
1994
|
+
}
|
|
1995
|
+
var mode = FS_getMode(canRead, canWrite);
|
|
1996
|
+
var node = FS.create(path, mode);
|
|
1997
|
+
if (data) {
|
|
1998
|
+
if (typeof data == "string") {
|
|
1999
|
+
var arr = new Array(data.length);
|
|
2000
|
+
for (var i = 0, len = data.length; i < len; ++i) arr[i] = data.charCodeAt(i);
|
|
2001
|
+
data = arr;
|
|
2002
|
+
}
|
|
2003
|
+
FS.chmod(node, mode | 146);
|
|
2004
|
+
var stream = FS.open(node, 577);
|
|
2005
|
+
FS.write(stream, data, 0, data.length, 0, canOwn);
|
|
2006
|
+
FS.close(stream);
|
|
2007
|
+
FS.chmod(node, mode);
|
|
2008
|
+
}
|
|
2009
|
+
}, createDevice(parent, name, input, output) {
|
|
2010
|
+
var path = PATH.join2(typeof parent == "string" ? parent : FS.getPath(parent), name);
|
|
2011
|
+
var mode = FS_getMode(!!input, !!output);
|
|
2012
|
+
if (!FS.createDevice.major) FS.createDevice.major = 64;
|
|
2013
|
+
var dev = FS.makedev(FS.createDevice.major++, 0);
|
|
2014
|
+
FS.registerDevice(dev, { open(stream) {
|
|
2015
|
+
stream.seekable = false;
|
|
2016
|
+
}, close(stream) {
|
|
2017
|
+
if (output?.buffer?.length) {
|
|
2018
|
+
output(10);
|
|
2019
|
+
}
|
|
2020
|
+
}, read(stream, buffer, offset, length, pos) {
|
|
2021
|
+
var bytesRead = 0;
|
|
2022
|
+
for (var i = 0; i < length; i++) {
|
|
2023
|
+
var result;
|
|
2024
|
+
try {
|
|
2025
|
+
result = input();
|
|
2026
|
+
} catch (e) {
|
|
2027
|
+
throw new FS.ErrnoError(29);
|
|
2028
|
+
}
|
|
2029
|
+
if (result === void 0 && bytesRead === 0) {
|
|
2030
|
+
throw new FS.ErrnoError(6);
|
|
2031
|
+
}
|
|
2032
|
+
if (result === null || result === void 0) break;
|
|
2033
|
+
bytesRead++;
|
|
2034
|
+
buffer[offset + i] = result;
|
|
2035
|
+
}
|
|
2036
|
+
if (bytesRead) {
|
|
2037
|
+
stream.node.timestamp = Date.now();
|
|
2038
|
+
}
|
|
2039
|
+
return bytesRead;
|
|
2040
|
+
}, write(stream, buffer, offset, length, pos) {
|
|
2041
|
+
for (var i = 0; i < length; i++) {
|
|
2042
|
+
try {
|
|
2043
|
+
output(buffer[offset + i]);
|
|
2044
|
+
} catch (e) {
|
|
2045
|
+
throw new FS.ErrnoError(29);
|
|
2046
|
+
}
|
|
2047
|
+
}
|
|
2048
|
+
if (length) {
|
|
2049
|
+
stream.node.timestamp = Date.now();
|
|
2050
|
+
}
|
|
2051
|
+
return i;
|
|
2052
|
+
} });
|
|
2053
|
+
return FS.mkdev(path, mode, dev);
|
|
2054
|
+
}, forceLoadFile(obj) {
|
|
2055
|
+
if (obj.isDevice || obj.isFolder || obj.link || obj.contents) return true;
|
|
2056
|
+
if (typeof XMLHttpRequest != "undefined") {
|
|
2057
|
+
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.");
|
|
2058
|
+
} else if (read_) {
|
|
2059
|
+
try {
|
|
2060
|
+
obj.contents = intArrayFromString(read_(obj.url), true);
|
|
2061
|
+
obj.usedBytes = obj.contents.length;
|
|
2062
|
+
} catch (e) {
|
|
2063
|
+
throw new FS.ErrnoError(29);
|
|
2064
|
+
}
|
|
2065
|
+
} else {
|
|
2066
|
+
throw new Error("Cannot load without read() or XMLHttpRequest.");
|
|
2067
|
+
}
|
|
2068
|
+
}, createLazyFile(parent, name, url, canRead, canWrite) {
|
|
2069
|
+
class LazyUint8Array {
|
|
2070
|
+
constructor() {
|
|
2071
|
+
this.lengthKnown = false;
|
|
2072
|
+
this.chunks = [];
|
|
2073
|
+
}
|
|
2074
|
+
get(idx) {
|
|
2075
|
+
if (idx > this.length - 1 || idx < 0) {
|
|
2076
|
+
return void 0;
|
|
2077
|
+
}
|
|
2078
|
+
var chunkOffset = idx % this.chunkSize;
|
|
2079
|
+
var chunkNum = idx / this.chunkSize | 0;
|
|
2080
|
+
return this.getter(chunkNum)[chunkOffset];
|
|
2081
|
+
}
|
|
2082
|
+
setDataGetter(getter) {
|
|
2083
|
+
this.getter = getter;
|
|
2084
|
+
}
|
|
2085
|
+
cacheLength() {
|
|
2086
|
+
var xhr = new XMLHttpRequest();
|
|
2087
|
+
xhr.open("HEAD", url, false);
|
|
2088
|
+
xhr.send(null);
|
|
2089
|
+
if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304)) throw new Error("Couldn't load " + url + ". Status: " + xhr.status);
|
|
2090
|
+
var datalength = Number(xhr.getResponseHeader("Content-length"));
|
|
2091
|
+
var header;
|
|
2092
|
+
var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes";
|
|
2093
|
+
var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip";
|
|
2094
|
+
var chunkSize = 1024 * 1024;
|
|
2095
|
+
if (!hasByteServing) chunkSize = datalength;
|
|
2096
|
+
var doXHR = (from, to) => {
|
|
2097
|
+
if (from > to) throw new Error("invalid range (" + from + ", " + to + ") or no bytes requested!");
|
|
2098
|
+
if (to > datalength - 1) throw new Error("only " + datalength + " bytes available! programmer error!");
|
|
2099
|
+
var xhr2 = new XMLHttpRequest();
|
|
2100
|
+
xhr2.open("GET", url, false);
|
|
2101
|
+
if (datalength !== chunkSize) xhr2.setRequestHeader("Range", "bytes=" + from + "-" + to);
|
|
2102
|
+
xhr2.responseType = "arraybuffer";
|
|
2103
|
+
if (xhr2.overrideMimeType) {
|
|
2104
|
+
xhr2.overrideMimeType("text/plain; charset=x-user-defined");
|
|
2105
|
+
}
|
|
2106
|
+
xhr2.send(null);
|
|
2107
|
+
if (!(xhr2.status >= 200 && xhr2.status < 300 || xhr2.status === 304)) throw new Error("Couldn't load " + url + ". Status: " + xhr2.status);
|
|
2108
|
+
if (xhr2.response !== void 0) {
|
|
2109
|
+
return new Uint8Array(xhr2.response || []);
|
|
2110
|
+
}
|
|
2111
|
+
return intArrayFromString(xhr2.responseText || "", true);
|
|
2112
|
+
};
|
|
2113
|
+
var lazyArray2 = this;
|
|
2114
|
+
lazyArray2.setDataGetter((chunkNum) => {
|
|
2115
|
+
var start = chunkNum * chunkSize;
|
|
2116
|
+
var end = (chunkNum + 1) * chunkSize - 1;
|
|
2117
|
+
end = Math.min(end, datalength - 1);
|
|
2118
|
+
if (typeof lazyArray2.chunks[chunkNum] == "undefined") {
|
|
2119
|
+
lazyArray2.chunks[chunkNum] = doXHR(start, end);
|
|
2120
|
+
}
|
|
2121
|
+
if (typeof lazyArray2.chunks[chunkNum] == "undefined") throw new Error("doXHR failed!");
|
|
2122
|
+
return lazyArray2.chunks[chunkNum];
|
|
2123
|
+
});
|
|
2124
|
+
if (usesGzip || !datalength) {
|
|
2125
|
+
chunkSize = datalength = 1;
|
|
2126
|
+
datalength = this.getter(0).length;
|
|
2127
|
+
chunkSize = datalength;
|
|
2128
|
+
out("LazyFiles on gzip forces download of the whole file when length is accessed");
|
|
2129
|
+
}
|
|
2130
|
+
this._length = datalength;
|
|
2131
|
+
this._chunkSize = chunkSize;
|
|
2132
|
+
this.lengthKnown = true;
|
|
2133
|
+
}
|
|
2134
|
+
get length() {
|
|
2135
|
+
if (!this.lengthKnown) {
|
|
2136
|
+
this.cacheLength();
|
|
2137
|
+
}
|
|
2138
|
+
return this._length;
|
|
2139
|
+
}
|
|
2140
|
+
get chunkSize() {
|
|
2141
|
+
if (!this.lengthKnown) {
|
|
2142
|
+
this.cacheLength();
|
|
2143
|
+
}
|
|
2144
|
+
return this._chunkSize;
|
|
2145
|
+
}
|
|
2146
|
+
}
|
|
2147
|
+
if (typeof XMLHttpRequest != "undefined") {
|
|
2148
|
+
if (!ENVIRONMENT_IS_WORKER) throw "Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";
|
|
2149
|
+
var lazyArray = new LazyUint8Array();
|
|
2150
|
+
var properties = { isDevice: false, contents: lazyArray };
|
|
2151
|
+
} else {
|
|
2152
|
+
var properties = { isDevice: false, url };
|
|
2153
|
+
}
|
|
2154
|
+
var node = FS.createFile(parent, name, properties, canRead, canWrite);
|
|
2155
|
+
if (properties.contents) {
|
|
2156
|
+
node.contents = properties.contents;
|
|
2157
|
+
} else if (properties.url) {
|
|
2158
|
+
node.contents = null;
|
|
2159
|
+
node.url = properties.url;
|
|
2160
|
+
}
|
|
2161
|
+
Object.defineProperties(node, { usedBytes: { get: function() {
|
|
2162
|
+
return this.contents.length;
|
|
2163
|
+
} } });
|
|
2164
|
+
var stream_ops = {};
|
|
2165
|
+
var keys = Object.keys(node.stream_ops);
|
|
2166
|
+
keys.forEach((key) => {
|
|
2167
|
+
var fn = node.stream_ops[key];
|
|
2168
|
+
stream_ops[key] = (...args) => {
|
|
2169
|
+
FS.forceLoadFile(node);
|
|
2170
|
+
return fn(...args);
|
|
2171
|
+
};
|
|
2172
|
+
});
|
|
2173
|
+
function writeChunks(stream, buffer, offset, length, position) {
|
|
2174
|
+
var contents = stream.node.contents;
|
|
2175
|
+
if (position >= contents.length) return 0;
|
|
2176
|
+
var size = Math.min(contents.length - position, length);
|
|
2177
|
+
if (contents.slice) {
|
|
2178
|
+
for (var i = 0; i < size; i++) {
|
|
2179
|
+
buffer[offset + i] = contents[position + i];
|
|
2180
|
+
}
|
|
2181
|
+
} else {
|
|
2182
|
+
for (var i = 0; i < size; i++) {
|
|
2183
|
+
buffer[offset + i] = contents.get(position + i);
|
|
2184
|
+
}
|
|
2185
|
+
}
|
|
2186
|
+
return size;
|
|
2187
|
+
}
|
|
2188
|
+
stream_ops.read = (stream, buffer, offset, length, position) => {
|
|
2189
|
+
FS.forceLoadFile(node);
|
|
2190
|
+
return writeChunks(stream, buffer, offset, length, position);
|
|
2191
|
+
};
|
|
2192
|
+
stream_ops.mmap = (stream, length, position, prot, flags) => {
|
|
2193
|
+
FS.forceLoadFile(node);
|
|
2194
|
+
var ptr = mmapAlloc(length);
|
|
2195
|
+
if (!ptr) {
|
|
2196
|
+
throw new FS.ErrnoError(48);
|
|
2197
|
+
}
|
|
2198
|
+
writeChunks(stream, HEAP8, ptr, length, position);
|
|
2199
|
+
return { ptr, allocated: true };
|
|
2200
|
+
};
|
|
2201
|
+
node.stream_ops = stream_ops;
|
|
2202
|
+
return node;
|
|
2203
|
+
} };
|
|
2204
|
+
var UTF8ToString = (ptr, maxBytesToRead) => ptr ? UTF8ArrayToString(HEAPU8, ptr, maxBytesToRead) : "";
|
|
2205
|
+
var SYSCALLS = { DEFAULT_POLLMASK: 5, calculateAt(dirfd, path, allowEmpty) {
|
|
2206
|
+
if (PATH.isAbs(path)) {
|
|
2207
|
+
return path;
|
|
2208
|
+
}
|
|
2209
|
+
var dir;
|
|
2210
|
+
if (dirfd === -100) {
|
|
2211
|
+
dir = FS.cwd();
|
|
2212
|
+
} else {
|
|
2213
|
+
var dirstream = SYSCALLS.getStreamFromFD(dirfd);
|
|
2214
|
+
dir = dirstream.path;
|
|
2215
|
+
}
|
|
2216
|
+
if (path.length == 0) {
|
|
2217
|
+
if (!allowEmpty) {
|
|
2218
|
+
throw new FS.ErrnoError(44);
|
|
2219
|
+
}
|
|
2220
|
+
return dir;
|
|
2221
|
+
}
|
|
2222
|
+
return PATH.join2(dir, path);
|
|
2223
|
+
}, doStat(func, path, buf) {
|
|
2224
|
+
var stat = func(path);
|
|
2225
|
+
HEAP32[buf >> 2] = stat.dev;
|
|
2226
|
+
HEAP32[buf + 4 >> 2] = stat.mode;
|
|
2227
|
+
HEAPU32[buf + 8 >> 2] = stat.nlink;
|
|
2228
|
+
HEAP32[buf + 12 >> 2] = stat.uid;
|
|
2229
|
+
HEAP32[buf + 16 >> 2] = stat.gid;
|
|
2230
|
+
HEAP32[buf + 20 >> 2] = stat.rdev;
|
|
2231
|
+
tempI64 = [stat.size >>> 0, (tempDouble = stat.size, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 24 >> 2] = tempI64[0], HEAP32[buf + 28 >> 2] = tempI64[1];
|
|
2232
|
+
HEAP32[buf + 32 >> 2] = 4096;
|
|
2233
|
+
HEAP32[buf + 36 >> 2] = stat.blocks;
|
|
2234
|
+
var atime = stat.atime.getTime();
|
|
2235
|
+
var mtime = stat.mtime.getTime();
|
|
2236
|
+
var ctime = stat.ctime.getTime();
|
|
2237
|
+
tempI64 = [Math.floor(atime / 1e3) >>> 0, (tempDouble = Math.floor(atime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 40 >> 2] = tempI64[0], HEAP32[buf + 44 >> 2] = tempI64[1];
|
|
2238
|
+
HEAPU32[buf + 48 >> 2] = atime % 1e3 * 1e3;
|
|
2239
|
+
tempI64 = [Math.floor(mtime / 1e3) >>> 0, (tempDouble = Math.floor(mtime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 56 >> 2] = tempI64[0], HEAP32[buf + 60 >> 2] = tempI64[1];
|
|
2240
|
+
HEAPU32[buf + 64 >> 2] = mtime % 1e3 * 1e3;
|
|
2241
|
+
tempI64 = [Math.floor(ctime / 1e3) >>> 0, (tempDouble = Math.floor(ctime / 1e3), +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 72 >> 2] = tempI64[0], HEAP32[buf + 76 >> 2] = tempI64[1];
|
|
2242
|
+
HEAPU32[buf + 80 >> 2] = ctime % 1e3 * 1e3;
|
|
2243
|
+
tempI64 = [stat.ino >>> 0, (tempDouble = stat.ino, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[buf + 88 >> 2] = tempI64[0], HEAP32[buf + 92 >> 2] = tempI64[1];
|
|
2244
|
+
return 0;
|
|
2245
|
+
}, doMsync(addr, stream, len, flags, offset) {
|
|
2246
|
+
if (!FS.isFile(stream.node.mode)) {
|
|
2247
|
+
throw new FS.ErrnoError(43);
|
|
2248
|
+
}
|
|
2249
|
+
if (flags & 2) {
|
|
2250
|
+
return 0;
|
|
2251
|
+
}
|
|
2252
|
+
var buffer = HEAPU8.slice(addr, addr + len);
|
|
2253
|
+
FS.msync(stream, buffer, offset, len, flags);
|
|
2254
|
+
}, varargs: void 0, get() {
|
|
2255
|
+
var ret = HEAP32[+SYSCALLS.varargs >> 2];
|
|
2256
|
+
SYSCALLS.varargs += 4;
|
|
2257
|
+
return ret;
|
|
2258
|
+
}, getp() {
|
|
2259
|
+
return SYSCALLS.get();
|
|
2260
|
+
}, getStr(ptr) {
|
|
2261
|
+
var ret = UTF8ToString(ptr);
|
|
2262
|
+
return ret;
|
|
2263
|
+
}, getStreamFromFD(fd) {
|
|
2264
|
+
var stream = FS.getStreamChecked(fd);
|
|
2265
|
+
return stream;
|
|
2266
|
+
} };
|
|
2267
|
+
function ___syscall_fcntl64(fd, cmd, varargs) {
|
|
2268
|
+
SYSCALLS.varargs = varargs;
|
|
2269
|
+
try {
|
|
2270
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2271
|
+
switch (cmd) {
|
|
2272
|
+
case 0: {
|
|
2273
|
+
var arg = SYSCALLS.get();
|
|
2274
|
+
if (arg < 0) {
|
|
2275
|
+
return -28;
|
|
2276
|
+
}
|
|
2277
|
+
while (FS.streams[arg]) {
|
|
2278
|
+
arg++;
|
|
2279
|
+
}
|
|
2280
|
+
var newStream;
|
|
2281
|
+
newStream = FS.dupStream(stream, arg);
|
|
2282
|
+
return newStream.fd;
|
|
2283
|
+
}
|
|
2284
|
+
case 1:
|
|
2285
|
+
case 2:
|
|
2286
|
+
return 0;
|
|
2287
|
+
case 3:
|
|
2288
|
+
return stream.flags;
|
|
2289
|
+
case 4: {
|
|
2290
|
+
var arg = SYSCALLS.get();
|
|
2291
|
+
stream.flags |= arg;
|
|
2292
|
+
return 0;
|
|
2293
|
+
}
|
|
2294
|
+
case 12: {
|
|
2295
|
+
var arg = SYSCALLS.getp();
|
|
2296
|
+
var offset = 0;
|
|
2297
|
+
HEAP16[arg + offset >> 1] = 2;
|
|
2298
|
+
return 0;
|
|
2299
|
+
}
|
|
2300
|
+
case 13:
|
|
2301
|
+
case 14:
|
|
2302
|
+
return 0;
|
|
2303
|
+
}
|
|
2304
|
+
return -28;
|
|
2305
|
+
} catch (e) {
|
|
2306
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2307
|
+
return -e.errno;
|
|
2308
|
+
}
|
|
2309
|
+
}
|
|
2310
|
+
function ___syscall_fstat64(fd, buf) {
|
|
2311
|
+
try {
|
|
2312
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2313
|
+
return SYSCALLS.doStat(FS.stat, stream.path, buf);
|
|
2314
|
+
} catch (e) {
|
|
2315
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2316
|
+
return -e.errno;
|
|
2317
|
+
}
|
|
2318
|
+
}
|
|
2319
|
+
function ___syscall_ioctl(fd, op, varargs) {
|
|
2320
|
+
SYSCALLS.varargs = varargs;
|
|
2321
|
+
try {
|
|
2322
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2323
|
+
switch (op) {
|
|
2324
|
+
case 21509: {
|
|
2325
|
+
if (!stream.tty) return -59;
|
|
2326
|
+
return 0;
|
|
2327
|
+
}
|
|
2328
|
+
case 21505: {
|
|
2329
|
+
if (!stream.tty) return -59;
|
|
2330
|
+
if (stream.tty.ops.ioctl_tcgets) {
|
|
2331
|
+
var termios = stream.tty.ops.ioctl_tcgets(stream);
|
|
2332
|
+
var argp = SYSCALLS.getp();
|
|
2333
|
+
HEAP32[argp >> 2] = termios.c_iflag || 0;
|
|
2334
|
+
HEAP32[argp + 4 >> 2] = termios.c_oflag || 0;
|
|
2335
|
+
HEAP32[argp + 8 >> 2] = termios.c_cflag || 0;
|
|
2336
|
+
HEAP32[argp + 12 >> 2] = termios.c_lflag || 0;
|
|
2337
|
+
for (var i = 0; i < 32; i++) {
|
|
2338
|
+
HEAP8[argp + i + 17] = termios.c_cc[i] || 0;
|
|
2339
|
+
}
|
|
2340
|
+
return 0;
|
|
2341
|
+
}
|
|
2342
|
+
return 0;
|
|
2343
|
+
}
|
|
2344
|
+
case 21510:
|
|
2345
|
+
case 21511:
|
|
2346
|
+
case 21512: {
|
|
2347
|
+
if (!stream.tty) return -59;
|
|
2348
|
+
return 0;
|
|
2349
|
+
}
|
|
2350
|
+
case 21506:
|
|
2351
|
+
case 21507:
|
|
2352
|
+
case 21508: {
|
|
2353
|
+
if (!stream.tty) return -59;
|
|
2354
|
+
if (stream.tty.ops.ioctl_tcsets) {
|
|
2355
|
+
var argp = SYSCALLS.getp();
|
|
2356
|
+
var c_iflag = HEAP32[argp >> 2];
|
|
2357
|
+
var c_oflag = HEAP32[argp + 4 >> 2];
|
|
2358
|
+
var c_cflag = HEAP32[argp + 8 >> 2];
|
|
2359
|
+
var c_lflag = HEAP32[argp + 12 >> 2];
|
|
2360
|
+
var c_cc = [];
|
|
2361
|
+
for (var i = 0; i < 32; i++) {
|
|
2362
|
+
c_cc.push(HEAP8[argp + i + 17]);
|
|
2363
|
+
}
|
|
2364
|
+
return stream.tty.ops.ioctl_tcsets(stream.tty, op, { c_iflag, c_oflag, c_cflag, c_lflag, c_cc });
|
|
2365
|
+
}
|
|
2366
|
+
return 0;
|
|
2367
|
+
}
|
|
2368
|
+
case 21519: {
|
|
2369
|
+
if (!stream.tty) return -59;
|
|
2370
|
+
var argp = SYSCALLS.getp();
|
|
2371
|
+
HEAP32[argp >> 2] = 0;
|
|
2372
|
+
return 0;
|
|
2373
|
+
}
|
|
2374
|
+
case 21520: {
|
|
2375
|
+
if (!stream.tty) return -59;
|
|
2376
|
+
return -28;
|
|
2377
|
+
}
|
|
2378
|
+
case 21531: {
|
|
2379
|
+
var argp = SYSCALLS.getp();
|
|
2380
|
+
return FS.ioctl(stream, op, argp);
|
|
2381
|
+
}
|
|
2382
|
+
case 21523: {
|
|
2383
|
+
if (!stream.tty) return -59;
|
|
2384
|
+
if (stream.tty.ops.ioctl_tiocgwinsz) {
|
|
2385
|
+
var winsize = stream.tty.ops.ioctl_tiocgwinsz(stream.tty);
|
|
2386
|
+
var argp = SYSCALLS.getp();
|
|
2387
|
+
HEAP16[argp >> 1] = winsize[0];
|
|
2388
|
+
HEAP16[argp + 2 >> 1] = winsize[1];
|
|
2389
|
+
}
|
|
2390
|
+
return 0;
|
|
2391
|
+
}
|
|
2392
|
+
case 21524: {
|
|
2393
|
+
if (!stream.tty) return -59;
|
|
2394
|
+
return 0;
|
|
2395
|
+
}
|
|
2396
|
+
case 21515: {
|
|
2397
|
+
if (!stream.tty) return -59;
|
|
2398
|
+
return 0;
|
|
2399
|
+
}
|
|
2400
|
+
default:
|
|
2401
|
+
return -28;
|
|
2402
|
+
}
|
|
2403
|
+
} catch (e) {
|
|
2404
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2405
|
+
return -e.errno;
|
|
2406
|
+
}
|
|
2407
|
+
}
|
|
2408
|
+
function ___syscall_newfstatat(dirfd, path, buf, flags) {
|
|
2409
|
+
try {
|
|
2410
|
+
path = SYSCALLS.getStr(path);
|
|
2411
|
+
var nofollow = flags & 256;
|
|
2412
|
+
var allowEmpty = flags & 4096;
|
|
2413
|
+
flags = flags & ~6400;
|
|
2414
|
+
path = SYSCALLS.calculateAt(dirfd, path, allowEmpty);
|
|
2415
|
+
return SYSCALLS.doStat(nofollow ? FS.lstat : FS.stat, path, buf);
|
|
2416
|
+
} catch (e) {
|
|
2417
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2418
|
+
return -e.errno;
|
|
2419
|
+
}
|
|
2420
|
+
}
|
|
2421
|
+
function ___syscall_openat(dirfd, path, flags, varargs) {
|
|
2422
|
+
SYSCALLS.varargs = varargs;
|
|
2423
|
+
try {
|
|
2424
|
+
path = SYSCALLS.getStr(path);
|
|
2425
|
+
path = SYSCALLS.calculateAt(dirfd, path);
|
|
2426
|
+
var mode = varargs ? SYSCALLS.get() : 0;
|
|
2427
|
+
return FS.open(path, flags, mode).fd;
|
|
2428
|
+
} catch (e) {
|
|
2429
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2430
|
+
return -e.errno;
|
|
2431
|
+
}
|
|
2432
|
+
}
|
|
2433
|
+
function ___syscall_stat64(path, buf) {
|
|
2434
|
+
try {
|
|
2435
|
+
path = SYSCALLS.getStr(path);
|
|
2436
|
+
return SYSCALLS.doStat(FS.stat, path, buf);
|
|
2437
|
+
} catch (e) {
|
|
2438
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2439
|
+
return -e.errno;
|
|
2440
|
+
}
|
|
2441
|
+
}
|
|
2442
|
+
var nowIsMonotonic = 1;
|
|
2443
|
+
var __emscripten_get_now_is_monotonic = () => nowIsMonotonic;
|
|
2444
|
+
var convertI32PairToI53Checked = (lo, hi) => hi + 2097152 >>> 0 < 4194305 - !!lo ? (lo >>> 0) + hi * 4294967296 : NaN;
|
|
2445
|
+
function __mmap_js(len, prot, flags, fd, offset_low, offset_high, allocated, addr) {
|
|
2446
|
+
var offset = convertI32PairToI53Checked(offset_low, offset_high);
|
|
2447
|
+
try {
|
|
2448
|
+
if (isNaN(offset)) return 61;
|
|
2449
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2450
|
+
var res = FS.mmap(stream, len, offset, prot, flags);
|
|
2451
|
+
var ptr = res.ptr;
|
|
2452
|
+
HEAP32[allocated >> 2] = res.allocated;
|
|
2453
|
+
HEAPU32[addr >> 2] = ptr;
|
|
2454
|
+
return 0;
|
|
2455
|
+
} catch (e) {
|
|
2456
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2457
|
+
return -e.errno;
|
|
2458
|
+
}
|
|
2459
|
+
}
|
|
2460
|
+
function __munmap_js(addr, len, prot, flags, fd, offset_low, offset_high) {
|
|
2461
|
+
var offset = convertI32PairToI53Checked(offset_low, offset_high);
|
|
2462
|
+
try {
|
|
2463
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2464
|
+
if (prot & 2) {
|
|
2465
|
+
SYSCALLS.doMsync(addr, stream, len, flags, offset);
|
|
2466
|
+
}
|
|
2467
|
+
} catch (e) {
|
|
2468
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2469
|
+
return -e.errno;
|
|
2470
|
+
}
|
|
2471
|
+
}
|
|
2472
|
+
var _abort = () => {
|
|
2473
|
+
abort("");
|
|
2474
|
+
};
|
|
2475
|
+
var _emscripten_date_now = () => Date.now();
|
|
2476
|
+
var getHeapMax = () => 2147483648;
|
|
2477
|
+
var _emscripten_get_heap_max = () => getHeapMax();
|
|
2478
|
+
var _emscripten_get_now;
|
|
2479
|
+
_emscripten_get_now = () => performance.now();
|
|
2480
|
+
var _emscripten_memcpy_js = (dest, src, num) => HEAPU8.copyWithin(dest, src, src + num);
|
|
2481
|
+
var growMemory = (size) => {
|
|
2482
|
+
var b = wasmMemory.buffer;
|
|
2483
|
+
var pages = (size - b.byteLength + 65535) / 65536;
|
|
2484
|
+
try {
|
|
2485
|
+
wasmMemory.grow(pages);
|
|
2486
|
+
updateMemoryViews();
|
|
2487
|
+
return 1;
|
|
2488
|
+
} catch (e) {
|
|
2489
|
+
}
|
|
2490
|
+
};
|
|
2491
|
+
var _emscripten_resize_heap = (requestedSize) => {
|
|
2492
|
+
var oldSize = HEAPU8.length;
|
|
2493
|
+
requestedSize >>>= 0;
|
|
2494
|
+
var maxHeapSize = getHeapMax();
|
|
2495
|
+
if (requestedSize > maxHeapSize) {
|
|
2496
|
+
return false;
|
|
2497
|
+
}
|
|
2498
|
+
var alignUp = (x, multiple) => x + (multiple - x % multiple) % multiple;
|
|
2499
|
+
for (var cutDown = 1; cutDown <= 4; cutDown *= 2) {
|
|
2500
|
+
var overGrownHeapSize = oldSize * (1 + 0.2 / cutDown);
|
|
2501
|
+
overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296);
|
|
2502
|
+
var newSize = Math.min(maxHeapSize, alignUp(Math.max(requestedSize, overGrownHeapSize), 65536));
|
|
2503
|
+
var replacement = growMemory(newSize);
|
|
2504
|
+
if (replacement) {
|
|
2505
|
+
return true;
|
|
2506
|
+
}
|
|
2507
|
+
}
|
|
2508
|
+
return false;
|
|
2509
|
+
};
|
|
2510
|
+
var ENV = {};
|
|
2511
|
+
var getExecutableName = () => thisProgram || "./this.program";
|
|
2512
|
+
var getEnvStrings = () => {
|
|
2513
|
+
if (!getEnvStrings.strings) {
|
|
2514
|
+
var lang = (typeof navigator == "object" && navigator.languages && navigator.languages[0] || "C").replace("-", "_") + ".UTF-8";
|
|
2515
|
+
var env = { "USER": "web_user", "LOGNAME": "web_user", "PATH": "/", "PWD": "/", "HOME": "/home/web_user", "LANG": lang, "_": getExecutableName() };
|
|
2516
|
+
for (var x in ENV) {
|
|
2517
|
+
if (ENV[x] === void 0) delete env[x];
|
|
2518
|
+
else env[x] = ENV[x];
|
|
2519
|
+
}
|
|
2520
|
+
var strings = [];
|
|
2521
|
+
for (var x in env) {
|
|
2522
|
+
strings.push(`${x}=${env[x]}`);
|
|
2523
|
+
}
|
|
2524
|
+
getEnvStrings.strings = strings;
|
|
2525
|
+
}
|
|
2526
|
+
return getEnvStrings.strings;
|
|
2527
|
+
};
|
|
2528
|
+
var stringToAscii = (str, buffer) => {
|
|
2529
|
+
for (var i = 0; i < str.length; ++i) {
|
|
2530
|
+
HEAP8[buffer++] = str.charCodeAt(i);
|
|
2531
|
+
}
|
|
2532
|
+
HEAP8[buffer] = 0;
|
|
2533
|
+
};
|
|
2534
|
+
var _environ_get = (__environ, environ_buf) => {
|
|
2535
|
+
var bufSize = 0;
|
|
2536
|
+
getEnvStrings().forEach((string, i) => {
|
|
2537
|
+
var ptr = environ_buf + bufSize;
|
|
2538
|
+
HEAPU32[__environ + i * 4 >> 2] = ptr;
|
|
2539
|
+
stringToAscii(string, ptr);
|
|
2540
|
+
bufSize += string.length + 1;
|
|
2541
|
+
});
|
|
2542
|
+
return 0;
|
|
2543
|
+
};
|
|
2544
|
+
var _environ_sizes_get = (penviron_count, penviron_buf_size) => {
|
|
2545
|
+
var strings = getEnvStrings();
|
|
2546
|
+
HEAPU32[penviron_count >> 2] = strings.length;
|
|
2547
|
+
var bufSize = 0;
|
|
2548
|
+
strings.forEach((string) => bufSize += string.length + 1);
|
|
2549
|
+
HEAPU32[penviron_buf_size >> 2] = bufSize;
|
|
2550
|
+
return 0;
|
|
2551
|
+
};
|
|
2552
|
+
var runtimeKeepaliveCounter = 0;
|
|
2553
|
+
var keepRuntimeAlive = () => noExitRuntime || runtimeKeepaliveCounter > 0;
|
|
2554
|
+
var _proc_exit = (code) => {
|
|
2555
|
+
EXITSTATUS = code;
|
|
2556
|
+
if (!keepRuntimeAlive()) {
|
|
2557
|
+
Module["onExit"]?.(code);
|
|
2558
|
+
ABORT = true;
|
|
2559
|
+
}
|
|
2560
|
+
quit_(code, new ExitStatus(code));
|
|
2561
|
+
};
|
|
2562
|
+
var exitJS = (status, implicit) => {
|
|
2563
|
+
EXITSTATUS = status;
|
|
2564
|
+
_proc_exit(status);
|
|
2565
|
+
};
|
|
2566
|
+
var _exit = exitJS;
|
|
2567
|
+
function _fd_close(fd) {
|
|
2568
|
+
try {
|
|
2569
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2570
|
+
FS.close(stream);
|
|
2571
|
+
return 0;
|
|
2572
|
+
} catch (e) {
|
|
2573
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2574
|
+
return e.errno;
|
|
2575
|
+
}
|
|
2576
|
+
}
|
|
2577
|
+
var doReadv = (stream, iov, iovcnt, offset) => {
|
|
2578
|
+
var ret = 0;
|
|
2579
|
+
for (var i = 0; i < iovcnt; i++) {
|
|
2580
|
+
var ptr = HEAPU32[iov >> 2];
|
|
2581
|
+
var len = HEAPU32[iov + 4 >> 2];
|
|
2582
|
+
iov += 8;
|
|
2583
|
+
var curr = FS.read(stream, HEAP8, ptr, len, offset);
|
|
2584
|
+
if (curr < 0) return -1;
|
|
2585
|
+
ret += curr;
|
|
2586
|
+
if (curr < len) break;
|
|
2587
|
+
if (typeof offset !== "undefined") {
|
|
2588
|
+
offset += curr;
|
|
2589
|
+
}
|
|
2590
|
+
}
|
|
2591
|
+
return ret;
|
|
2592
|
+
};
|
|
2593
|
+
function _fd_read(fd, iov, iovcnt, pnum) {
|
|
2594
|
+
try {
|
|
2595
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2596
|
+
var num = doReadv(stream, iov, iovcnt);
|
|
2597
|
+
HEAPU32[pnum >> 2] = num;
|
|
2598
|
+
return 0;
|
|
2599
|
+
} catch (e) {
|
|
2600
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2601
|
+
return e.errno;
|
|
2602
|
+
}
|
|
2603
|
+
}
|
|
2604
|
+
function _fd_seek(fd, offset_low, offset_high, whence, newOffset) {
|
|
2605
|
+
var offset = convertI32PairToI53Checked(offset_low, offset_high);
|
|
2606
|
+
try {
|
|
2607
|
+
if (isNaN(offset)) return 61;
|
|
2608
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2609
|
+
FS.llseek(stream, offset, whence);
|
|
2610
|
+
tempI64 = [stream.position >>> 0, (tempDouble = stream.position, +Math.abs(tempDouble) >= 1 ? tempDouble > 0 ? +Math.floor(tempDouble / 4294967296) >>> 0 : ~~+Math.ceil((tempDouble - +(~~tempDouble >>> 0)) / 4294967296) >>> 0 : 0)], HEAP32[newOffset >> 2] = tempI64[0], HEAP32[newOffset + 4 >> 2] = tempI64[1];
|
|
2611
|
+
if (stream.getdents && offset === 0 && whence === 0) stream.getdents = null;
|
|
2612
|
+
return 0;
|
|
2613
|
+
} catch (e) {
|
|
2614
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2615
|
+
return e.errno;
|
|
2616
|
+
}
|
|
2617
|
+
}
|
|
2618
|
+
var doWritev = (stream, iov, iovcnt, offset) => {
|
|
2619
|
+
var ret = 0;
|
|
2620
|
+
for (var i = 0; i < iovcnt; i++) {
|
|
2621
|
+
var ptr = HEAPU32[iov >> 2];
|
|
2622
|
+
var len = HEAPU32[iov + 4 >> 2];
|
|
2623
|
+
iov += 8;
|
|
2624
|
+
var curr = FS.write(stream, HEAP8, ptr, len, offset);
|
|
2625
|
+
if (curr < 0) return -1;
|
|
2626
|
+
ret += curr;
|
|
2627
|
+
if (typeof offset !== "undefined") {
|
|
2628
|
+
offset += curr;
|
|
2629
|
+
}
|
|
2630
|
+
}
|
|
2631
|
+
return ret;
|
|
2632
|
+
};
|
|
2633
|
+
function _fd_write(fd, iov, iovcnt, pnum) {
|
|
2634
|
+
try {
|
|
2635
|
+
var stream = SYSCALLS.getStreamFromFD(fd);
|
|
2636
|
+
var num = doWritev(stream, iov, iovcnt);
|
|
2637
|
+
HEAPU32[pnum >> 2] = num;
|
|
2638
|
+
return 0;
|
|
2639
|
+
} catch (e) {
|
|
2640
|
+
if (typeof FS == "undefined" || !(e.name === "ErrnoError")) throw e;
|
|
2641
|
+
return e.errno;
|
|
2642
|
+
}
|
|
2643
|
+
}
|
|
2644
|
+
var isLeapYear = (year) => year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
|
|
2645
|
+
var arraySum = (array, index) => {
|
|
2646
|
+
var sum = 0;
|
|
2647
|
+
for (var i = 0; i <= index; sum += array[i++]) {
|
|
2648
|
+
}
|
|
2649
|
+
return sum;
|
|
2650
|
+
};
|
|
2651
|
+
var MONTH_DAYS_LEAP = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
|
|
2652
|
+
var MONTH_DAYS_REGULAR = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
|
|
2653
|
+
var addDays = (date, days) => {
|
|
2654
|
+
var newDate = new Date(date.getTime());
|
|
2655
|
+
while (days > 0) {
|
|
2656
|
+
var leap = isLeapYear(newDate.getFullYear());
|
|
2657
|
+
var currentMonth = newDate.getMonth();
|
|
2658
|
+
var daysInCurrentMonth = (leap ? MONTH_DAYS_LEAP : MONTH_DAYS_REGULAR)[currentMonth];
|
|
2659
|
+
if (days > daysInCurrentMonth - newDate.getDate()) {
|
|
2660
|
+
days -= daysInCurrentMonth - newDate.getDate() + 1;
|
|
2661
|
+
newDate.setDate(1);
|
|
2662
|
+
if (currentMonth < 11) {
|
|
2663
|
+
newDate.setMonth(currentMonth + 1);
|
|
2664
|
+
} else {
|
|
2665
|
+
newDate.setMonth(0);
|
|
2666
|
+
newDate.setFullYear(newDate.getFullYear() + 1);
|
|
2667
|
+
}
|
|
2668
|
+
} else {
|
|
2669
|
+
newDate.setDate(newDate.getDate() + days);
|
|
2670
|
+
return newDate;
|
|
2671
|
+
}
|
|
2672
|
+
}
|
|
2673
|
+
return newDate;
|
|
2674
|
+
};
|
|
2675
|
+
var writeArrayToMemory = (array, buffer) => {
|
|
2676
|
+
HEAP8.set(array, buffer);
|
|
2677
|
+
};
|
|
2678
|
+
var _strftime = (s, maxsize, format, tm) => {
|
|
2679
|
+
var tm_zone = HEAPU32[tm + 40 >> 2];
|
|
2680
|
+
var date = { tm_sec: HEAP32[tm >> 2], tm_min: HEAP32[tm + 4 >> 2], tm_hour: HEAP32[tm + 8 >> 2], tm_mday: HEAP32[tm + 12 >> 2], tm_mon: HEAP32[tm + 16 >> 2], tm_year: HEAP32[tm + 20 >> 2], tm_wday: HEAP32[tm + 24 >> 2], tm_yday: HEAP32[tm + 28 >> 2], tm_isdst: HEAP32[tm + 32 >> 2], tm_gmtoff: HEAP32[tm + 36 >> 2], tm_zone: tm_zone ? UTF8ToString(tm_zone) : "" };
|
|
2681
|
+
var pattern = UTF8ToString(format);
|
|
2682
|
+
var EXPANSION_RULES_1 = { "%c": "%a %b %d %H:%M:%S %Y", "%D": "%m/%d/%y", "%F": "%Y-%m-%d", "%h": "%b", "%r": "%I:%M:%S %p", "%R": "%H:%M", "%T": "%H:%M:%S", "%x": "%m/%d/%y", "%X": "%H:%M:%S", "%Ec": "%c", "%EC": "%C", "%Ex": "%m/%d/%y", "%EX": "%H:%M:%S", "%Ey": "%y", "%EY": "%Y", "%Od": "%d", "%Oe": "%e", "%OH": "%H", "%OI": "%I", "%Om": "%m", "%OM": "%M", "%OS": "%S", "%Ou": "%u", "%OU": "%U", "%OV": "%V", "%Ow": "%w", "%OW": "%W", "%Oy": "%y" };
|
|
2683
|
+
for (var rule in EXPANSION_RULES_1) {
|
|
2684
|
+
pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_1[rule]);
|
|
2685
|
+
}
|
|
2686
|
+
var WEEKDAYS = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"];
|
|
2687
|
+
var MONTHS = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
|
|
2688
|
+
function leadingSomething(value, digits, character) {
|
|
2689
|
+
var str = typeof value == "number" ? value.toString() : value || "";
|
|
2690
|
+
while (str.length < digits) {
|
|
2691
|
+
str = character[0] + str;
|
|
2692
|
+
}
|
|
2693
|
+
return str;
|
|
2694
|
+
}
|
|
2695
|
+
function leadingNulls(value, digits) {
|
|
2696
|
+
return leadingSomething(value, digits, "0");
|
|
2697
|
+
}
|
|
2698
|
+
function compareByDay(date1, date2) {
|
|
2699
|
+
function sgn(value) {
|
|
2700
|
+
return value < 0 ? -1 : value > 0 ? 1 : 0;
|
|
2701
|
+
}
|
|
2702
|
+
var compare;
|
|
2703
|
+
if ((compare = sgn(date1.getFullYear() - date2.getFullYear())) === 0) {
|
|
2704
|
+
if ((compare = sgn(date1.getMonth() - date2.getMonth())) === 0) {
|
|
2705
|
+
compare = sgn(date1.getDate() - date2.getDate());
|
|
2706
|
+
}
|
|
2707
|
+
}
|
|
2708
|
+
return compare;
|
|
2709
|
+
}
|
|
2710
|
+
function getFirstWeekStartDate(janFourth) {
|
|
2711
|
+
switch (janFourth.getDay()) {
|
|
2712
|
+
case 0:
|
|
2713
|
+
return new Date(janFourth.getFullYear() - 1, 11, 29);
|
|
2714
|
+
case 1:
|
|
2715
|
+
return janFourth;
|
|
2716
|
+
case 2:
|
|
2717
|
+
return new Date(janFourth.getFullYear(), 0, 3);
|
|
2718
|
+
case 3:
|
|
2719
|
+
return new Date(janFourth.getFullYear(), 0, 2);
|
|
2720
|
+
case 4:
|
|
2721
|
+
return new Date(janFourth.getFullYear(), 0, 1);
|
|
2722
|
+
case 5:
|
|
2723
|
+
return new Date(janFourth.getFullYear() - 1, 11, 31);
|
|
2724
|
+
case 6:
|
|
2725
|
+
return new Date(janFourth.getFullYear() - 1, 11, 30);
|
|
2726
|
+
}
|
|
2727
|
+
}
|
|
2728
|
+
function getWeekBasedYear(date2) {
|
|
2729
|
+
var thisDate = addDays(new Date(date2.tm_year + 1900, 0, 1), date2.tm_yday);
|
|
2730
|
+
var janFourthThisYear = new Date(thisDate.getFullYear(), 0, 4);
|
|
2731
|
+
var janFourthNextYear = new Date(thisDate.getFullYear() + 1, 0, 4);
|
|
2732
|
+
var firstWeekStartThisYear = getFirstWeekStartDate(janFourthThisYear);
|
|
2733
|
+
var firstWeekStartNextYear = getFirstWeekStartDate(janFourthNextYear);
|
|
2734
|
+
if (compareByDay(firstWeekStartThisYear, thisDate) <= 0) {
|
|
2735
|
+
if (compareByDay(firstWeekStartNextYear, thisDate) <= 0) {
|
|
2736
|
+
return thisDate.getFullYear() + 1;
|
|
2737
|
+
}
|
|
2738
|
+
return thisDate.getFullYear();
|
|
2739
|
+
}
|
|
2740
|
+
return thisDate.getFullYear() - 1;
|
|
2741
|
+
}
|
|
2742
|
+
var EXPANSION_RULES_2 = { "%a": (date2) => WEEKDAYS[date2.tm_wday].substring(0, 3), "%A": (date2) => WEEKDAYS[date2.tm_wday], "%b": (date2) => MONTHS[date2.tm_mon].substring(0, 3), "%B": (date2) => MONTHS[date2.tm_mon], "%C": (date2) => {
|
|
2743
|
+
var year = date2.tm_year + 1900;
|
|
2744
|
+
return leadingNulls(year / 100 | 0, 2);
|
|
2745
|
+
}, "%d": (date2) => leadingNulls(date2.tm_mday, 2), "%e": (date2) => leadingSomething(date2.tm_mday, 2, " "), "%g": (date2) => getWeekBasedYear(date2).toString().substring(2), "%G": getWeekBasedYear, "%H": (date2) => leadingNulls(date2.tm_hour, 2), "%I": (date2) => {
|
|
2746
|
+
var twelveHour = date2.tm_hour;
|
|
2747
|
+
if (twelveHour == 0) twelveHour = 12;
|
|
2748
|
+
else if (twelveHour > 12) twelveHour -= 12;
|
|
2749
|
+
return leadingNulls(twelveHour, 2);
|
|
2750
|
+
}, "%j": (date2) => leadingNulls(date2.tm_mday + arraySum(isLeapYear(date2.tm_year + 1900) ? MONTH_DAYS_LEAP : MONTH_DAYS_REGULAR, date2.tm_mon - 1), 3), "%m": (date2) => leadingNulls(date2.tm_mon + 1, 2), "%M": (date2) => leadingNulls(date2.tm_min, 2), "%n": () => "\n", "%p": (date2) => {
|
|
2751
|
+
if (date2.tm_hour >= 0 && date2.tm_hour < 12) {
|
|
2752
|
+
return "AM";
|
|
2753
|
+
}
|
|
2754
|
+
return "PM";
|
|
2755
|
+
}, "%S": (date2) => leadingNulls(date2.tm_sec, 2), "%t": () => " ", "%u": (date2) => date2.tm_wday || 7, "%U": (date2) => {
|
|
2756
|
+
var days = date2.tm_yday + 7 - date2.tm_wday;
|
|
2757
|
+
return leadingNulls(Math.floor(days / 7), 2);
|
|
2758
|
+
}, "%V": (date2) => {
|
|
2759
|
+
var val = Math.floor((date2.tm_yday + 7 - (date2.tm_wday + 6) % 7) / 7);
|
|
2760
|
+
if ((date2.tm_wday + 371 - date2.tm_yday - 2) % 7 <= 2) {
|
|
2761
|
+
val++;
|
|
2762
|
+
}
|
|
2763
|
+
if (!val) {
|
|
2764
|
+
val = 52;
|
|
2765
|
+
var dec31 = (date2.tm_wday + 7 - date2.tm_yday - 1) % 7;
|
|
2766
|
+
if (dec31 == 4 || dec31 == 5 && isLeapYear(date2.tm_year % 400 - 1)) {
|
|
2767
|
+
val++;
|
|
2768
|
+
}
|
|
2769
|
+
} else if (val == 53) {
|
|
2770
|
+
var jan1 = (date2.tm_wday + 371 - date2.tm_yday) % 7;
|
|
2771
|
+
if (jan1 != 4 && (jan1 != 3 || !isLeapYear(date2.tm_year))) val = 1;
|
|
2772
|
+
}
|
|
2773
|
+
return leadingNulls(val, 2);
|
|
2774
|
+
}, "%w": (date2) => date2.tm_wday, "%W": (date2) => {
|
|
2775
|
+
var days = date2.tm_yday + 7 - (date2.tm_wday + 6) % 7;
|
|
2776
|
+
return leadingNulls(Math.floor(days / 7), 2);
|
|
2777
|
+
}, "%y": (date2) => (date2.tm_year + 1900).toString().substring(2), "%Y": (date2) => date2.tm_year + 1900, "%z": (date2) => {
|
|
2778
|
+
var off = date2.tm_gmtoff;
|
|
2779
|
+
var ahead = off >= 0;
|
|
2780
|
+
off = Math.abs(off) / 60;
|
|
2781
|
+
off = off / 60 * 100 + off % 60;
|
|
2782
|
+
return (ahead ? "+" : "-") + String("0000" + off).slice(-4);
|
|
2783
|
+
}, "%Z": (date2) => date2.tm_zone, "%%": () => "%" };
|
|
2784
|
+
pattern = pattern.replace(/%%/g, "\0\0");
|
|
2785
|
+
for (var rule in EXPANSION_RULES_2) {
|
|
2786
|
+
if (pattern.includes(rule)) {
|
|
2787
|
+
pattern = pattern.replace(new RegExp(rule, "g"), EXPANSION_RULES_2[rule](date));
|
|
2788
|
+
}
|
|
2789
|
+
}
|
|
2790
|
+
pattern = pattern.replace(/\0\0/g, "%");
|
|
2791
|
+
var bytes = intArrayFromString(pattern, false);
|
|
2792
|
+
if (bytes.length > maxsize) {
|
|
2793
|
+
return 0;
|
|
2794
|
+
}
|
|
2795
|
+
writeArrayToMemory(bytes, s);
|
|
2796
|
+
return bytes.length - 1;
|
|
2797
|
+
};
|
|
2798
|
+
var _strftime_l = (s, maxsize, format, tm, loc) => _strftime(s, maxsize, format, tm);
|
|
2799
|
+
var handleException = (e) => {
|
|
2800
|
+
if (e instanceof ExitStatus || e == "unwind") {
|
|
2801
|
+
return EXITSTATUS;
|
|
2802
|
+
}
|
|
2803
|
+
quit_(1, e);
|
|
2804
|
+
};
|
|
2805
|
+
var stringToUTF8 = (str, outPtr, maxBytesToWrite) => stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite);
|
|
2806
|
+
var stringToUTF8OnStack = (str) => {
|
|
2807
|
+
var size = lengthBytesUTF8(str) + 1;
|
|
2808
|
+
var ret = stackAlloc(size);
|
|
2809
|
+
stringToUTF8(str, ret, size);
|
|
2810
|
+
return ret;
|
|
2811
|
+
};
|
|
2812
|
+
FS.createPreloadedFile = FS_createPreloadedFile;
|
|
2813
|
+
FS.staticInit();
|
|
2814
|
+
Module["FS_createPath"] = FS.createPath;
|
|
2815
|
+
Module["FS_createDataFile"] = FS.createDataFile;
|
|
2816
|
+
Module["FS_createPreloadedFile"] = FS.createPreloadedFile;
|
|
2817
|
+
Module["FS_unlink"] = FS.unlink;
|
|
2818
|
+
Module["FS_createLazyFile"] = FS.createLazyFile;
|
|
2819
|
+
Module["FS_createDevice"] = FS.createDevice;
|
|
2820
|
+
var wasmImports = { a: ___cxa_throw, f: ___syscall_fcntl64, v: ___syscall_fstat64, k: ___syscall_ioctl, t: ___syscall_newfstatat, g: ___syscall_openat, u: ___syscall_stat64, x: __emscripten_get_now_is_monotonic, l: __mmap_js, m: __munmap_js, b: _abort, i: _emscripten_date_now, q: _emscripten_get_heap_max, w: _emscripten_get_now, j: _emscripten_memcpy_js, p: _emscripten_resize_heap, r: _environ_get, s: _environ_sizes_get, h: _exit, c: _fd_close, e: _fd_read, n: _fd_seek, d: _fd_write, o: _strftime_l };
|
|
2821
|
+
var wasmExports = createWasm();
|
|
2822
|
+
var ___wasm_call_ctors = () => (___wasm_call_ctors = wasmExports["z"])();
|
|
2823
|
+
var _main = Module["_main"] = (a0, a1) => (_main = Module["_main"] = wasmExports["A"])(a0, a1);
|
|
2824
|
+
var _emscripten_builtin_memalign = (a0, a1) => (_emscripten_builtin_memalign = wasmExports["C"])(a0, a1);
|
|
2825
|
+
var stackAlloc = (a0) => (stackAlloc = wasmExports["D"])(a0);
|
|
2826
|
+
var ___cxa_is_pointer_type = (a0) => (___cxa_is_pointer_type = wasmExports["E"])(a0);
|
|
2827
|
+
Module["addRunDependency"] = addRunDependency;
|
|
2828
|
+
Module["removeRunDependency"] = removeRunDependency;
|
|
2829
|
+
Module["FS_createPath"] = FS.createPath;
|
|
2830
|
+
Module["FS_createLazyFile"] = FS.createLazyFile;
|
|
2831
|
+
Module["FS_createDevice"] = FS.createDevice;
|
|
2832
|
+
Module["callMain"] = callMain;
|
|
2833
|
+
Module["FS_createPreloadedFile"] = FS.createPreloadedFile;
|
|
2834
|
+
Module["FS"] = FS;
|
|
2835
|
+
Module["FS_createDataFile"] = FS.createDataFile;
|
|
2836
|
+
Module["FS_unlink"] = FS.unlink;
|
|
2837
|
+
var calledRun;
|
|
2838
|
+
dependenciesFulfilled = function runCaller() {
|
|
2839
|
+
if (!calledRun) run();
|
|
2840
|
+
if (!calledRun) dependenciesFulfilled = runCaller;
|
|
2841
|
+
};
|
|
2842
|
+
function callMain(args = []) {
|
|
2843
|
+
var entryFunction = _main;
|
|
2844
|
+
args.unshift(thisProgram);
|
|
2845
|
+
var argc = args.length;
|
|
2846
|
+
var argv = stackAlloc((argc + 1) * 4);
|
|
2847
|
+
var argv_ptr = argv;
|
|
2848
|
+
args.forEach((arg) => {
|
|
2849
|
+
HEAPU32[argv_ptr >> 2] = stringToUTF8OnStack(arg);
|
|
2850
|
+
argv_ptr += 4;
|
|
2851
|
+
});
|
|
2852
|
+
HEAPU32[argv_ptr >> 2] = 0;
|
|
2853
|
+
try {
|
|
2854
|
+
var ret = entryFunction(argc, argv);
|
|
2855
|
+
exitJS(ret, true);
|
|
2856
|
+
return ret;
|
|
2857
|
+
} catch (e) {
|
|
2858
|
+
return handleException(e);
|
|
2859
|
+
}
|
|
2860
|
+
}
|
|
2861
|
+
function run(args = arguments_) {
|
|
2862
|
+
if (runDependencies > 0) {
|
|
2863
|
+
return;
|
|
2864
|
+
}
|
|
2865
|
+
preRun();
|
|
2866
|
+
if (runDependencies > 0) {
|
|
2867
|
+
return;
|
|
2868
|
+
}
|
|
2869
|
+
function doRun() {
|
|
2870
|
+
if (calledRun) return;
|
|
2871
|
+
calledRun = true;
|
|
2872
|
+
Module["calledRun"] = true;
|
|
2873
|
+
if (ABORT) return;
|
|
2874
|
+
initRuntime();
|
|
2875
|
+
preMain();
|
|
2876
|
+
readyPromiseResolve(Module);
|
|
2877
|
+
if (Module["onRuntimeInitialized"]) Module["onRuntimeInitialized"]();
|
|
2878
|
+
if (shouldRunNow) callMain(args);
|
|
2879
|
+
postRun();
|
|
2880
|
+
}
|
|
2881
|
+
if (Module["setStatus"]) {
|
|
2882
|
+
Module["setStatus"]("Running...");
|
|
2883
|
+
setTimeout(function() {
|
|
2884
|
+
setTimeout(function() {
|
|
2885
|
+
Module["setStatus"]("");
|
|
2886
|
+
}, 1);
|
|
2887
|
+
doRun();
|
|
2888
|
+
}, 1);
|
|
2889
|
+
} else {
|
|
2890
|
+
doRun();
|
|
2891
|
+
}
|
|
2892
|
+
}
|
|
2893
|
+
if (Module["preInit"]) {
|
|
2894
|
+
if (typeof Module["preInit"] == "function") Module["preInit"] = [Module["preInit"]];
|
|
2895
|
+
while (Module["preInit"].length > 0) {
|
|
2896
|
+
Module["preInit"].pop()();
|
|
2897
|
+
}
|
|
2898
|
+
}
|
|
2899
|
+
var shouldRunNow = false;
|
|
2900
|
+
if (Module["noInitialRun"]) shouldRunNow = false;
|
|
2901
|
+
run();
|
|
2902
|
+
return moduleArg.ready;
|
|
2903
|
+
};
|
|
2904
|
+
})();
|
|
2905
|
+
scip_core_default = createSCIP;
|
|
2906
|
+
}
|
|
2907
|
+
});
|
|
2908
|
+
|
|
2909
|
+
// src/scip-browser.js
|
|
2910
|
+
var scip_browser_exports = {};
|
|
2911
|
+
__export(scip_browser_exports, {
|
|
2912
|
+
Status: () => Status,
|
|
2913
|
+
default: () => scip_browser_default,
|
|
2914
|
+
getParameters: () => getParameters,
|
|
2915
|
+
init: () => init,
|
|
2916
|
+
isReady: () => isReady,
|
|
2917
|
+
maximize: () => maximize,
|
|
2918
|
+
minimize: () => minimize,
|
|
2919
|
+
ready: () => ready,
|
|
2920
|
+
solve: () => solve,
|
|
2921
|
+
version: () => version
|
|
2922
|
+
});
|
|
2923
|
+
|
|
2924
|
+
// src/scip-wrapper.js
|
|
2925
|
+
var scipModule = null;
|
|
2926
|
+
var isInitialized = false;
|
|
2927
|
+
var initPromise = null;
|
|
2928
|
+
var readyResolve = null;
|
|
2929
|
+
var readyReject = null;
|
|
2930
|
+
var ready = new Promise((resolve, reject) => {
|
|
2931
|
+
readyResolve = resolve;
|
|
2932
|
+
readyReject = reject;
|
|
2933
|
+
});
|
|
2934
|
+
var DEFAULT_CDN_BASE = "https://cdn.jsdelivr.net/gh/areb0s/scip.js/dist/";
|
|
2935
|
+
function getBaseUrl() {
|
|
2936
|
+
const globalScope2 = typeof globalThis !== "undefined" && globalThis || typeof self !== "undefined" && self || typeof window !== "undefined" && window || {};
|
|
2937
|
+
if (globalScope2.SCIP_BASE_URL) {
|
|
2938
|
+
return globalScope2.SCIP_BASE_URL;
|
|
2939
|
+
}
|
|
2940
|
+
if (typeof __importMetaUrl !== "undefined" && __importMetaUrl && !__importMetaUrl.startsWith("blob:")) {
|
|
2941
|
+
return __importMetaUrl.substring(0, __importMetaUrl.lastIndexOf("/") + 1);
|
|
2942
|
+
}
|
|
2943
|
+
return DEFAULT_CDN_BASE;
|
|
2944
|
+
}
|
|
2945
|
+
var Status = {
|
|
2946
|
+
OPTIMAL: "optimal",
|
|
2947
|
+
INFEASIBLE: "infeasible",
|
|
2948
|
+
UNBOUNDED: "unbounded",
|
|
2949
|
+
TIME_LIMIT: "timelimit",
|
|
2950
|
+
UNKNOWN: "unknown",
|
|
2951
|
+
ERROR: "error"
|
|
2952
|
+
};
|
|
2953
|
+
function parseStatus(output) {
|
|
2954
|
+
if (output.includes("optimal solution found")) return Status.OPTIMAL;
|
|
2955
|
+
if (output.includes("problem is infeasible")) return Status.INFEASIBLE;
|
|
2956
|
+
if (output.includes("problem is unbounded")) return Status.UNBOUNDED;
|
|
2957
|
+
if (output.includes("time limit reached")) return Status.TIME_LIMIT;
|
|
2958
|
+
return Status.UNKNOWN;
|
|
2959
|
+
}
|
|
2960
|
+
function parseSolution(output) {
|
|
2961
|
+
const variables = {};
|
|
2962
|
+
const objective = { value: null, sense: null };
|
|
2963
|
+
const objMatch = output.match(/objective value:\s*([\d.e+-]+)/i);
|
|
2964
|
+
if (objMatch) {
|
|
2965
|
+
objective.value = parseFloat(objMatch[1]);
|
|
2966
|
+
}
|
|
2967
|
+
const varRegex = /^(\w+)\s+([\d.e+-]+)/gm;
|
|
2968
|
+
let match;
|
|
2969
|
+
const solSection = output.split("solution:")[1] || output;
|
|
2970
|
+
while ((match = varRegex.exec(solSection)) !== null) {
|
|
2971
|
+
const name = match[1];
|
|
2972
|
+
const value = parseFloat(match[2]);
|
|
2973
|
+
if (!isNaN(value) && name !== "objective") {
|
|
2974
|
+
variables[name] = value;
|
|
2975
|
+
}
|
|
2976
|
+
}
|
|
2977
|
+
return { variables, objective };
|
|
2978
|
+
}
|
|
2979
|
+
function parseStatistics(output) {
|
|
2980
|
+
const stats = {
|
|
2981
|
+
solvingTime: null,
|
|
2982
|
+
nodes: null,
|
|
2983
|
+
iterations: null,
|
|
2984
|
+
gap: null
|
|
2985
|
+
};
|
|
2986
|
+
const timeMatch = output.match(/Solving Time \(sec\)\s*:\s*([\d.]+)/);
|
|
2987
|
+
if (timeMatch) stats.solvingTime = parseFloat(timeMatch[1]);
|
|
2988
|
+
const nodesMatch = output.match(/Nodes\s*:\s*(\d+)/);
|
|
2989
|
+
if (nodesMatch) stats.nodes = parseInt(nodesMatch[1]);
|
|
2990
|
+
const iterMatch = output.match(/LP Iterations\s*:\s*(\d+)/);
|
|
2991
|
+
if (iterMatch) stats.iterations = parseInt(iterMatch[1]);
|
|
2992
|
+
const gapMatch = output.match(/Gap\s*:\s*([\d.]+)\s*%/);
|
|
2993
|
+
if (gapMatch) stats.gap = parseFloat(gapMatch[1]);
|
|
2994
|
+
return stats;
|
|
2995
|
+
}
|
|
2996
|
+
async function init(options = {}) {
|
|
2997
|
+
if (isInitialized) {
|
|
2998
|
+
return;
|
|
2999
|
+
}
|
|
3000
|
+
if (initPromise) {
|
|
3001
|
+
return initPromise;
|
|
3002
|
+
}
|
|
3003
|
+
initPromise = (async () => {
|
|
3004
|
+
try {
|
|
3005
|
+
const baseUrl = getBaseUrl();
|
|
3006
|
+
const wasmPath = options.wasmPath || baseUrl + "scip.wasm";
|
|
3007
|
+
const createSCIP2 = (await Promise.resolve().then(() => (init_scip_core(), scip_core_exports))).default;
|
|
3008
|
+
scipModule = await createSCIP2({
|
|
3009
|
+
locateFile: (path) => {
|
|
3010
|
+
if (path.endsWith(".wasm")) {
|
|
3011
|
+
return wasmPath;
|
|
3012
|
+
}
|
|
3013
|
+
return path;
|
|
3014
|
+
},
|
|
3015
|
+
// Capture stdout/stderr from Emscripten
|
|
3016
|
+
print: (text) => {
|
|
3017
|
+
if (scipModule && scipModule.onStdout) {
|
|
3018
|
+
scipModule.onStdout(text);
|
|
3019
|
+
}
|
|
3020
|
+
},
|
|
3021
|
+
printErr: (text) => {
|
|
3022
|
+
if (scipModule && scipModule.onStderr) {
|
|
3023
|
+
scipModule.onStderr(text);
|
|
3024
|
+
}
|
|
3025
|
+
}
|
|
3026
|
+
});
|
|
3027
|
+
if (scipModule.FS) {
|
|
3028
|
+
try {
|
|
3029
|
+
scipModule.FS.mkdir("/problems");
|
|
3030
|
+
} catch (e) {
|
|
3031
|
+
}
|
|
3032
|
+
try {
|
|
3033
|
+
scipModule.FS.mkdir("/solutions");
|
|
3034
|
+
} catch (e) {
|
|
3035
|
+
}
|
|
3036
|
+
try {
|
|
3037
|
+
scipModule.FS.mkdir("/settings");
|
|
3038
|
+
} catch (e) {
|
|
3039
|
+
}
|
|
3040
|
+
}
|
|
3041
|
+
isInitialized = true;
|
|
3042
|
+
if (readyResolve) {
|
|
3043
|
+
readyResolve();
|
|
3044
|
+
}
|
|
3045
|
+
} catch (error) {
|
|
3046
|
+
if (readyReject) {
|
|
3047
|
+
readyReject(error);
|
|
3048
|
+
}
|
|
3049
|
+
throw error;
|
|
3050
|
+
}
|
|
3051
|
+
})();
|
|
3052
|
+
return initPromise;
|
|
3053
|
+
}
|
|
3054
|
+
function isReady() {
|
|
3055
|
+
return isInitialized;
|
|
3056
|
+
}
|
|
3057
|
+
async function solve(problem, options = {}) {
|
|
3058
|
+
if (!isInitialized) {
|
|
3059
|
+
await init(options);
|
|
3060
|
+
}
|
|
3061
|
+
const {
|
|
3062
|
+
format = "lp",
|
|
3063
|
+
timeLimit = 3600,
|
|
3064
|
+
gap = null,
|
|
3065
|
+
verbose = false,
|
|
3066
|
+
parameters = {}
|
|
3067
|
+
} = options;
|
|
3068
|
+
let stdout = "";
|
|
3069
|
+
let stderr = "";
|
|
3070
|
+
scipModule.onStdout = (text) => {
|
|
3071
|
+
stdout += text + "\n";
|
|
3072
|
+
if (verbose) console.log("[SCIP]", text);
|
|
3073
|
+
};
|
|
3074
|
+
scipModule.onStderr = (text) => {
|
|
3075
|
+
stderr += text + "\n";
|
|
3076
|
+
if (verbose) console.error("[SCIP Error]", text);
|
|
3077
|
+
};
|
|
3078
|
+
try {
|
|
3079
|
+
const ext = format === "mps" ? "mps" : format === "zpl" ? "zpl" : "lp";
|
|
3080
|
+
const problemFile = `/problems/problem.${ext}`;
|
|
3081
|
+
const solutionFile = "/solutions/solution.sol";
|
|
3082
|
+
scipModule.FS.writeFile(problemFile, problem);
|
|
3083
|
+
const commands = [];
|
|
3084
|
+
commands.push(`set limits time ${timeLimit}`);
|
|
3085
|
+
if (gap !== null) {
|
|
3086
|
+
commands.push(`set limits gap ${gap}`);
|
|
3087
|
+
}
|
|
3088
|
+
for (const [key, value] of Object.entries(parameters)) {
|
|
3089
|
+
commands.push(`set ${key} ${value}`);
|
|
3090
|
+
}
|
|
3091
|
+
commands.push(`read ${problemFile}`);
|
|
3092
|
+
commands.push("optimize");
|
|
3093
|
+
commands.push("display solution");
|
|
3094
|
+
commands.push(`write solution ${solutionFile}`);
|
|
3095
|
+
commands.push("display statistics");
|
|
3096
|
+
commands.push("quit");
|
|
3097
|
+
const settingsContent = commands.join("\n");
|
|
3098
|
+
scipModule.FS.writeFile("/settings/commands.txt", settingsContent);
|
|
3099
|
+
const exitCode = scipModule.callMain(["-b", "/settings/commands.txt"]);
|
|
3100
|
+
const status = parseStatus(stdout);
|
|
3101
|
+
const { variables, objective } = parseSolution(stdout);
|
|
3102
|
+
const statistics = parseStatistics(stdout);
|
|
3103
|
+
let rawSolution = null;
|
|
3104
|
+
try {
|
|
3105
|
+
rawSolution = scipModule.FS.readFile(solutionFile, { encoding: "utf8" });
|
|
3106
|
+
} catch (e) {
|
|
3107
|
+
}
|
|
3108
|
+
return {
|
|
3109
|
+
status,
|
|
3110
|
+
objective: objective.value,
|
|
3111
|
+
variables,
|
|
3112
|
+
statistics,
|
|
3113
|
+
exitCode,
|
|
3114
|
+
output: verbose ? stdout : void 0,
|
|
3115
|
+
rawSolution
|
|
3116
|
+
};
|
|
3117
|
+
} catch (error) {
|
|
3118
|
+
return {
|
|
3119
|
+
status: Status.ERROR,
|
|
3120
|
+
error: error.message,
|
|
3121
|
+
output: stdout + stderr
|
|
3122
|
+
};
|
|
3123
|
+
} finally {
|
|
3124
|
+
try {
|
|
3125
|
+
scipModule.FS.unlink("/problems/problem.lp");
|
|
3126
|
+
} catch (e) {
|
|
3127
|
+
}
|
|
3128
|
+
try {
|
|
3129
|
+
scipModule.FS.unlink("/problems/problem.mps");
|
|
3130
|
+
} catch (e) {
|
|
3131
|
+
}
|
|
3132
|
+
try {
|
|
3133
|
+
scipModule.FS.unlink("/solutions/solution.sol");
|
|
3134
|
+
} catch (e) {
|
|
3135
|
+
}
|
|
3136
|
+
try {
|
|
3137
|
+
scipModule.FS.unlink("/settings/commands.txt");
|
|
3138
|
+
} catch (e) {
|
|
3139
|
+
}
|
|
3140
|
+
}
|
|
3141
|
+
}
|
|
3142
|
+
async function minimize(problem, options = {}) {
|
|
3143
|
+
if (!problem.toLowerCase().includes("minimize")) {
|
|
3144
|
+
problem = "Minimize\n" + problem;
|
|
3145
|
+
}
|
|
3146
|
+
return solve(problem, options);
|
|
3147
|
+
}
|
|
3148
|
+
async function maximize(problem, options = {}) {
|
|
3149
|
+
if (!problem.toLowerCase().includes("maximize")) {
|
|
3150
|
+
problem = "Maximize\n" + problem;
|
|
3151
|
+
}
|
|
3152
|
+
return solve(problem, options);
|
|
3153
|
+
}
|
|
3154
|
+
async function version() {
|
|
3155
|
+
if (!isInitialized) {
|
|
3156
|
+
await init();
|
|
3157
|
+
}
|
|
3158
|
+
let output = "";
|
|
3159
|
+
scipModule.onStdout = (text) => {
|
|
3160
|
+
output += text + "\n";
|
|
3161
|
+
};
|
|
3162
|
+
scipModule.callMain(["--version"]);
|
|
3163
|
+
return output.trim();
|
|
3164
|
+
}
|
|
3165
|
+
async function getParameters() {
|
|
3166
|
+
if (!isInitialized) {
|
|
3167
|
+
await init();
|
|
3168
|
+
}
|
|
3169
|
+
let output = "";
|
|
3170
|
+
scipModule.onStdout = (text) => {
|
|
3171
|
+
output += text + "\n";
|
|
3172
|
+
};
|
|
3173
|
+
scipModule.FS.writeFile("/settings/params.txt", "set\nquit\n");
|
|
3174
|
+
scipModule.callMain(["-b", "/settings/params.txt"]);
|
|
3175
|
+
return output;
|
|
3176
|
+
}
|
|
3177
|
+
var scip_wrapper_default = {
|
|
3178
|
+
init,
|
|
3179
|
+
ready,
|
|
3180
|
+
isReady,
|
|
3181
|
+
solve,
|
|
3182
|
+
minimize,
|
|
3183
|
+
maximize,
|
|
3184
|
+
version,
|
|
3185
|
+
getParameters,
|
|
3186
|
+
Status
|
|
3187
|
+
};
|
|
3188
|
+
|
|
3189
|
+
// src/scip-browser.js
|
|
3190
|
+
var globalScope = typeof globalThis !== "undefined" && globalThis || typeof self !== "undefined" && self || typeof window !== "undefined" && window || {};
|
|
3191
|
+
var isBrowser = typeof window !== "undefined" || typeof self !== "undefined";
|
|
3192
|
+
if (isBrowser && globalScope) {
|
|
3193
|
+
globalScope.SCIP = scip_wrapper_default;
|
|
3194
|
+
globalScope.SCIP.init = init;
|
|
3195
|
+
globalScope.SCIP.ready = ready;
|
|
3196
|
+
globalScope.SCIP.isReady = isReady;
|
|
3197
|
+
globalScope.SCIP.solve = solve;
|
|
3198
|
+
globalScope.SCIP.minimize = minimize;
|
|
3199
|
+
globalScope.SCIP.maximize = maximize;
|
|
3200
|
+
globalScope.SCIP.version = version;
|
|
3201
|
+
globalScope.SCIP.getParameters = getParameters;
|
|
3202
|
+
globalScope.SCIP.Status = Status;
|
|
3203
|
+
init().catch((err) => {
|
|
3204
|
+
console.error("[SCIP.js] Auto-initialization failed:", err.message);
|
|
3205
|
+
});
|
|
3206
|
+
}
|
|
3207
|
+
var scip_browser_default = scip_wrapper_default;
|
|
3208
|
+
return __toCommonJS(scip_browser_exports);
|
|
3209
|
+
})();
|
|
3210
|
+
|
|
3211
|
+
// Expose SCIP globally
|
|
3212
|
+
if (typeof window !== 'undefined') {
|
|
3213
|
+
window.SCIP = SCIPModule.default || SCIPModule;
|
|
3214
|
+
// Also expose named exports
|
|
3215
|
+
if (SCIPModule.init) window.SCIP.init = SCIPModule.init;
|
|
3216
|
+
if (SCIPModule.solve) window.SCIP.solve = SCIPModule.solve;
|
|
3217
|
+
if (SCIPModule.minimize) window.SCIP.minimize = SCIPModule.minimize;
|
|
3218
|
+
if (SCIPModule.maximize) window.SCIP.maximize = SCIPModule.maximize;
|
|
3219
|
+
if (SCIPModule.version) window.SCIP.version = SCIPModule.version;
|
|
3220
|
+
if (SCIPModule.Status) window.SCIP.Status = SCIPModule.Status;
|
|
3221
|
+
}
|
|
3222
|
+
|
|
3223
|
+
//# sourceMappingURL=scip.js.map
|