UNPKG

libxml2-wasm

Version:

WebAssembly-based libxml2 javascript wrapper

713 lines (605 loc) 1.34 MB
var Module = (() => { var _scriptDir = typeof document !== 'undefined' && document.currentScript ? document.currentScript.src : undefined; if (typeof __filename !== 'undefined') _scriptDir = _scriptDir || __filename; return ( function(moduleArg = {}) { // include: shell.js // The Module object: Our interface to the outside world. We import // and export values on it. There are various ways Module can be used: // 1. Not defined. We create it here // 2. A function parameter, function(Module) { ..generated code.. } // 3. pre-run appended it, var Module = {}; ..generated code.. // 4. External script tag defines var Module. // We need to check if Module already exists (e.g. case 3 above). // Substitution will be replaced with actual code on later stage of the build, // this way Closure Compiler will not mangle it (e.g. case 4. above). // Note that if you want to run closure, and also to use Module // after the generated code, you will need to define var Module = {}; // before the code. Then that object will be used in the code, and you // can continue to use Module afterwards as well. var Module = moduleArg; // Set up the promise that indicates the Module is initialized var readyPromiseResolve, readyPromiseReject; Module['ready'] = new Promise((resolve, reject) => { readyPromiseResolve = resolve; readyPromiseReject = reject; }); ["_free","_malloc","_xmlAddChild","_xmlAddNextSibling","_xmlAddPrevSibling","_xmlCleanupInputCallbacks","_xmlCtxtReadMemory","_xmlCtxtSetErrorHandler","_xmlDocGetRootElement","_xmlDocSetRootElement","_xmlFreeDoc","_xmlFreeNode","_xmlFreeParserCtxt","_xmlGetLastError","_xmlGetNsList","_xmlHasNsProp","_xmlInitParser","_xmlNewCDataBlock","_xmlNewDoc","_xmlNewDocComment","_xmlNewDocNode","_xmlNewDocTextLen","_xmlNewNode","_xmlNewNs","_xmlNewParserCtxt","_xmlNodeGetContent","_xmlNodeSetContentLen","_xmlOutputBufferCreateIO","_xmlRegisterInputCallbacks","_xmlRelaxNGFree","_xmlRelaxNGFreeParserCtxt","_xmlRelaxNGFreeValidCtxt","_xmlRelaxNGNewDocParserCtxt","_xmlRelaxNGNewValidCtxt","_xmlRelaxNGParse","_xmlRelaxNGSetParserStructuredErrors","_xmlRelaxNGSetValidStructuredErrors","_xmlRelaxNGValidateDoc","_xmlRemoveProp","_xmlResetLastError","_xmlSaveFormatFileTo","_xmlSchemaNewDocParserCtxt","_xmlSchemaFree","_xmlSchemaFreeParserCtxt","_xmlSchemaFreeValidCtxt","_xmlSchemaNewValidCtxt","_xmlSchemaParse","_xmlSchemaSetParserStructuredErrors","_xmlSchemaSetValidStructuredErrors","_xmlSchemaValidateDoc","_xmlSearchNs","_xmlSetNs","_xmlSetNsProp","_xmlUnlinkNode","_xmlXIncludeFreeContext","_xmlXIncludeNewContext","_xmlXIncludeProcessNode","_xmlXIncludeSetErrorHandler","_xmlXPathCompiledEval","_xmlXPathCtxtCompile","_xmlXPathFreeCompExpr","_xmlXPathFreeContext","_xmlXPathFreeObject","_xmlXPathNewContext","_xmlXPathRegisterNs","_xmlXPathSetContextNode","_memory","_fflush","___indirect_function_table","onRuntimeInitialized"].forEach((prop) => { if (!Object.getOwnPropertyDescriptor(Module['ready'], prop)) { Object.defineProperty(Module['ready'], prop, { get: () => abort('You are getting ' + prop + ' on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js'), set: () => abort('You are setting ' + prop + ' on the Promise object, instead of the instance. Use .then() to get called back with the instance, see the MODULARIZE docs in src/settings.js'), }); } }); // --pre-jses are emitted after the Module integration code, so that they can // refer to Module (if they choose; they can also define Module) // Sometimes an existing Module object exists with properties // meant to overwrite the default module functionality. Here // we collect those properties and reapply _after_ we configure // the current environment's defaults to avoid having to be so // defensive during initialization. var moduleOverrides = Object.assign({}, Module); var arguments_ = []; var thisProgram = './this.program'; var quit_ = (status, toThrow) => { throw toThrow; }; // Determine the runtime environment we are in. You can customize this by // setting the ENVIRONMENT setting at compile time (see settings.js). // Attempt to auto-detect the environment var ENVIRONMENT_IS_WEB = typeof window == 'object'; var ENVIRONMENT_IS_WORKER = typeof importScripts == 'function'; // N.b. Electron.js environment is simultaneously a NODE-environment, but // also a web environment. var ENVIRONMENT_IS_NODE = typeof process == 'object' && typeof process.versions == 'object' && typeof process.versions.node == 'string'; var ENVIRONMENT_IS_SHELL = !ENVIRONMENT_IS_WEB && !ENVIRONMENT_IS_NODE && !ENVIRONMENT_IS_WORKER; if (Module['ENVIRONMENT']) { throw new Error('Module.ENVIRONMENT has been deprecated. To force the environment, use the ENVIRONMENT compile-time option (for example, -sENVIRONMENT=web or -sENVIRONMENT=node)'); } // `/` should be present at the end if `scriptDirectory` is not empty var scriptDirectory = ''; function locateFile(path) { if (Module['locateFile']) { return Module['locateFile'](path, scriptDirectory); } return scriptDirectory + path; } // Hooks that are implemented differently in different runtime environments. var read_, readAsync, readBinary, setWindowTitle; if (ENVIRONMENT_IS_NODE) { if (typeof process == 'undefined' || !process.release || process.release.name !== 'node') throw new Error('not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)'); var nodeVersion = process.versions.node; var numericVersion = nodeVersion.split('.').slice(0, 3); numericVersion = (numericVersion[0] * 10000) + (numericVersion[1] * 100) + (numericVersion[2].split('-')[0] * 1); var minVersion = 160000; if (numericVersion < 160000) { throw new Error('This emscripten-generated code requires node v16.0.0 (detected v' + nodeVersion + ')'); } // `require()` is no-op in an ESM module, use `createRequire()` to construct // the require()` function. This is only necessary for multi-environment // builds, `-sENVIRONMENT=node` emits a static import declaration instead. // TODO: Swap all `require()`'s with `import()`'s? // These modules will usually be used on Node.js. Load them eagerly to avoid // the complexity of lazy-loading. var fs = require('fs'); var nodePath = require('path'); if (ENVIRONMENT_IS_WORKER) { scriptDirectory = nodePath.dirname(scriptDirectory) + '/'; } else { scriptDirectory = __dirname + '/'; } // include: node_shell_read.js read_ = (filename, binary) => { // We need to re-wrap `file://` strings to URLs. Normalizing isn't // necessary in that case, the path should already be absolute. filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename); return fs.readFileSync(filename, binary ? undefined : 'utf8'); }; readBinary = (filename) => { var ret = read_(filename, true); if (!ret.buffer) { ret = new Uint8Array(ret); } assert(ret.buffer); return ret; }; readAsync = (filename, onload, onerror, binary = true) => { // See the comment in the `read_` function. filename = isFileURI(filename) ? new URL(filename) : nodePath.normalize(filename); fs.readFile(filename, binary ? undefined : 'utf8', (err, data) => { if (err) onerror(err); else onload(binary ? data.buffer : data); }); }; // end include: node_shell_read.js if (!Module['thisProgram'] && process.argv.length > 1) { thisProgram = process.argv[1].replace(/\\/g, '/'); } arguments_ = process.argv.slice(2); // MODULARIZE will export the module in the proper place outside, we don't need to export here quit_ = (status, toThrow) => { process.exitCode = status; throw toThrow; }; Module['inspect'] = () => '[Emscripten Module object]'; } else if (ENVIRONMENT_IS_SHELL) { if ((typeof process == 'object' && typeof require === 'function') || typeof window == 'object' || typeof importScripts == 'function') throw new Error('not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)'); if (typeof read != 'undefined') { read_ = read; } readBinary = (f) => { if (typeof readbuffer == 'function') { return new Uint8Array(readbuffer(f)); } let data = read(f, 'binary'); assert(typeof data == 'object'); return data; }; readAsync = (f, onload, onerror) => { setTimeout(() => onload(readBinary(f))); }; if (typeof clearTimeout == 'undefined') { globalThis.clearTimeout = (id) => {}; } if (typeof setTimeout == 'undefined') { // spidermonkey lacks setTimeout but we use it above in readAsync. globalThis.setTimeout = (f) => (typeof f == 'function') ? f() : abort(); } if (typeof scriptArgs != 'undefined') { arguments_ = scriptArgs; } else if (typeof arguments != 'undefined') { arguments_ = arguments; } if (typeof quit == 'function') { quit_ = (status, toThrow) => { // Unlike node which has process.exitCode, d8 has no such mechanism. So we // have no way to set the exit code and then let the program exit with // that code when it naturally stops running (say, when all setTimeouts // have completed). For that reason, we must call `quit` - the only way to // set the exit code - but quit also halts immediately. To increase // consistency with node (and the web) we schedule the actual quit call // using a setTimeout to give the current stack and any exception handlers // a chance to run. This enables features such as addOnPostRun (which // expected to be able to run code after main returns). setTimeout(() => { if (!(toThrow instanceof ExitStatus)) { let toLog = toThrow; if (toThrow && typeof toThrow == 'object' && toThrow.stack) { toLog = [toThrow, toThrow.stack]; } err(`exiting due to exception: ${toLog}`); } quit(status); }); throw toThrow; }; } if (typeof print != 'undefined') { // Prefer to use print/printErr where they exist, as they usually work better. if (typeof console == 'undefined') console = /** @type{!Console} */({}); console.log = /** @type{!function(this:Console, ...*): undefined} */ (print); console.warn = console.error = /** @type{!function(this:Console, ...*): undefined} */ (typeof printErr != 'undefined' ? printErr : print); } } else // Note that this includes Node.js workers when relevant (pthreads is enabled). // Node.js workers are detected as a combination of ENVIRONMENT_IS_WORKER and // ENVIRONMENT_IS_NODE. if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) { if (ENVIRONMENT_IS_WORKER) { // Check worker, not web, since window could be polyfilled scriptDirectory = self.location.href; } else if (typeof document != 'undefined' && document.currentScript) { // web scriptDirectory = document.currentScript.src; } // When MODULARIZE, this JS may be executed later, after document.currentScript // is gone, so we saved it, and we use it here instead of any other info. if (_scriptDir) { scriptDirectory = _scriptDir; } // blob urls look like blob:http://site.com/etc/etc and we cannot infer anything from them. // otherwise, slice off the final part of the url to find the script directory. // if scriptDirectory does not contain a slash, lastIndexOf will return -1, // and scriptDirectory will correctly be replaced with an empty string. // If scriptDirectory contains a query (starting with ?) or a fragment (starting with #), // they are removed because they could contain a slash. if (scriptDirectory.indexOf('blob:') !== 0) { scriptDirectory = scriptDirectory.substr(0, scriptDirectory.replace(/[?#].*/, "").lastIndexOf('/')+1); } else { scriptDirectory = ''; } if (!(typeof window == 'object' || typeof importScripts == 'function')) throw new Error('not compiled for this environment (did you build to HTML and try to run it not on the web, or set ENVIRONMENT to something - like node - and run it someplace else - like on the web?)'); // Differentiate the Web Worker from the Node Worker case, as reading must // be done differently. { // include: web_or_worker_shell_read.js read_ = (url) => { var xhr = new XMLHttpRequest(); xhr.open('GET', url, false); xhr.send(null); return xhr.responseText; } if (ENVIRONMENT_IS_WORKER) { readBinary = (url) => { var xhr = new XMLHttpRequest(); xhr.open('GET', url, false); xhr.responseType = 'arraybuffer'; xhr.send(null); return new Uint8Array(/** @type{!ArrayBuffer} */(xhr.response)); }; } readAsync = (url, onload, onerror) => { var xhr = new XMLHttpRequest(); xhr.open('GET', url, true); xhr.responseType = 'arraybuffer'; xhr.onload = () => { if (xhr.status == 200 || (xhr.status == 0 && xhr.response)) { // file URLs can return 0 onload(xhr.response); return; } onerror(); }; xhr.onerror = onerror; xhr.send(null); } // end include: web_or_worker_shell_read.js } setWindowTitle = (title) => document.title = title; } else { throw new Error('environment detection error'); } var out = Module['print'] || console.log.bind(console); var err = Module['printErr'] || console.error.bind(console); // Merge back in the overrides Object.assign(Module, moduleOverrides); // Free the object hierarchy contained in the overrides, this lets the GC // reclaim data used e.g. in memoryInitializerRequest, which is a large typed array. moduleOverrides = null; checkIncomingModuleAPI(); // Emit code to handle expected values on the Module object. This applies Module.x // to the proper local x. This has two benefits: first, we only emit it if it is // expected to arrive, and second, by using a local everywhere else that can be // minified. if (Module['arguments']) arguments_ = Module['arguments'];legacyModuleProp('arguments', 'arguments_'); if (Module['thisProgram']) thisProgram = Module['thisProgram'];legacyModuleProp('thisProgram', 'thisProgram'); if (Module['quit']) quit_ = Module['quit'];legacyModuleProp('quit', 'quit_'); // perform assertions in shell.js after we set up out() and err(), as otherwise if an assertion fails it cannot print the message // Assertions on removed incoming Module JS APIs. assert(typeof Module['memoryInitializerPrefixURL'] == 'undefined', 'Module.memoryInitializerPrefixURL option was removed, use Module.locateFile instead'); assert(typeof Module['pthreadMainPrefixURL'] == 'undefined', 'Module.pthreadMainPrefixURL option was removed, use Module.locateFile instead'); assert(typeof Module['cdInitializerPrefixURL'] == 'undefined', 'Module.cdInitializerPrefixURL option was removed, use Module.locateFile instead'); assert(typeof Module['filePackagePrefixURL'] == 'undefined', 'Module.filePackagePrefixURL option was removed, use Module.locateFile instead'); assert(typeof Module['read'] == 'undefined', 'Module.read option was removed (modify read_ in JS)'); assert(typeof Module['readAsync'] == 'undefined', 'Module.readAsync option was removed (modify readAsync in JS)'); assert(typeof Module['readBinary'] == 'undefined', 'Module.readBinary option was removed (modify readBinary in JS)'); assert(typeof Module['setWindowTitle'] == 'undefined', 'Module.setWindowTitle option was removed (modify setWindowTitle in JS)'); assert(typeof Module['TOTAL_MEMORY'] == 'undefined', 'Module.TOTAL_MEMORY has been renamed Module.INITIAL_MEMORY'); legacyModuleProp('asm', 'wasmExports'); legacyModuleProp('read', 'read_'); legacyModuleProp('readAsync', 'readAsync'); legacyModuleProp('readBinary', 'readBinary'); legacyModuleProp('setWindowTitle', 'setWindowTitle'); var IDBFS = 'IDBFS is no longer included by default; build with -lidbfs.js'; var PROXYFS = 'PROXYFS is no longer included by default; build with -lproxyfs.js'; var WORKERFS = 'WORKERFS is no longer included by default; build with -lworkerfs.js'; var NODEFS = 'NODEFS is no longer included by default; build with -lnodefs.js'; assert(!ENVIRONMENT_IS_SHELL, "shell environment detected but not enabled at build time. Add 'shell' to `-sENVIRONMENT` to enable."); // end include: shell.js // include: preamble.js // === Preamble library stuff === // Documentation for the public APIs defined in this file must be updated in: // site/source/docs/api_reference/preamble.js.rst // A prebuilt local version of the documentation is available at: // site/build/text/docs/api_reference/preamble.js.txt // You can also build docs locally as HTML or other formats in site/ // An online HTML version (which may be of a different version of Emscripten) // is up at http://kripken.github.io/emscripten-site/docs/api_reference/preamble.js.html var wasmBinary; if (Module['wasmBinary']) wasmBinary = Module['wasmBinary'];legacyModuleProp('wasmBinary', 'wasmBinary'); var noExitRuntime = Module['noExitRuntime'] || true;legacyModuleProp('noExitRuntime', 'noExitRuntime'); if (typeof WebAssembly != 'object') { abort('no native wasm support detected'); } // Wasm globals var wasmMemory; var wasmExports; //======================================== // Runtime essentials //======================================== // whether we are quitting the application. no code should run after this. // set in exit() and abort() var ABORT = false; // set by exit() and abort(). Passed to 'onExit' handler. // NOTE: This is also used as the process return code code in shell environments // but only when noExitRuntime is false. var EXITSTATUS; /** @type {function(*, string=)} */ function assert(condition, text) { if (!condition) { abort('Assertion failed' + (text ? ': ' + text : '')); } } // We used to include malloc/free by default in the past. Show a helpful error in // builds with assertions. // Memory management var HEAP, /** @type {!Int8Array} */ HEAP8, /** @type {!Uint8Array} */ HEAPU8, /** @type {!Int16Array} */ HEAP16, /** @type {!Uint16Array} */ HEAPU16, /** @type {!Int32Array} */ HEAP32, /** @type {!Uint32Array} */ HEAPU32, /** @type {!Float32Array} */ HEAPF32, /** @type {!Float64Array} */ HEAPF64; function updateMemoryViews() { var b = wasmMemory.buffer; Module['HEAP8'] = HEAP8 = new Int8Array(b); Module['HEAP16'] = HEAP16 = new Int16Array(b); Module['HEAP32'] = HEAP32 = new Int32Array(b); Module['HEAPU8'] = HEAPU8 = new Uint8Array(b); Module['HEAPU16'] = HEAPU16 = new Uint16Array(b); Module['HEAPU32'] = HEAPU32 = new Uint32Array(b); Module['HEAPF32'] = HEAPF32 = new Float32Array(b); Module['HEAPF64'] = HEAPF64 = new Float64Array(b); } assert(!Module['STACK_SIZE'], 'STACK_SIZE can no longer be set at runtime. Use -sSTACK_SIZE at link time') assert(typeof Int32Array != 'undefined' && typeof Float64Array !== 'undefined' && Int32Array.prototype.subarray != undefined && Int32Array.prototype.set != undefined, 'JS engine does not provide full typed array support'); // If memory is defined in wasm, the user can't provide it, or set INITIAL_MEMORY assert(!Module['wasmMemory'], 'Use of `wasmMemory` detected. Use -sIMPORTED_MEMORY to define wasmMemory externally'); assert(!Module['INITIAL_MEMORY'], 'Detected runtime INITIAL_MEMORY setting. Use -sIMPORTED_MEMORY to define wasmMemory dynamically'); // include: runtime_init_table.js // In regular non-RELOCATABLE mode the table is exported // from the wasm module and this will be assigned once // the exports are available. var wasmTable; // end include: runtime_init_table.js // include: runtime_stack_check.js // Initializes the stack cookie. Called at the startup of main and at the startup of each thread in pthreads mode. function writeStackCookie() { var max = _emscripten_stack_get_end(); assert((max & 3) == 0); // If the stack ends at address zero we write our cookies 4 bytes into the // stack. This prevents interference with SAFE_HEAP and ASAN which also // monitor writes to address zero. if (max == 0) { max += 4; } // The stack grow downwards towards _emscripten_stack_get_end. // We write cookies to the final two words in the stack and detect if they are // ever overwritten. HEAPU32[((max)>>2)] = 0x02135467; HEAPU32[(((max)+(4))>>2)] = 0x89BACDFE; // Also test the global address 0 for integrity. HEAPU32[((0)>>2)] = 1668509029; } function checkStackCookie() { if (ABORT) return; var max = _emscripten_stack_get_end(); // See writeStackCookie(). if (max == 0) { max += 4; } var cookie1 = HEAPU32[((max)>>2)]; var cookie2 = HEAPU32[(((max)+(4))>>2)]; if (cookie1 != 0x02135467 || cookie2 != 0x89BACDFE) { abort(`Stack overflow! Stack cookie has been overwritten at ${ptrToString(max)}, expected hex dwords 0x89BACDFE and 0x2135467, but received ${ptrToString(cookie2)} ${ptrToString(cookie1)}`); } // Also test the global address 0 for integrity. if (HEAPU32[((0)>>2)] != 0x63736d65 /* 'emsc' */) { abort('Runtime error: The application has corrupted its heap memory area (address zero)!'); } } // end include: runtime_stack_check.js // include: runtime_assertions.js // Endianness check (function() { var h16 = new Int16Array(1); var h8 = new Int8Array(h16.buffer); h16[0] = 0x6373; if (h8[0] !== 0x73 || h8[1] !== 0x63) throw 'Runtime error: expected the system to be little-endian! (Run with -sSUPPORT_BIG_ENDIAN to bypass)'; })(); // end include: runtime_assertions.js var __ATPRERUN__ = []; // functions called before the runtime is initialized var __ATINIT__ = []; // functions called during startup var __ATEXIT__ = []; // functions called during shutdown var __ATPOSTRUN__ = []; // functions called after the main() is called var runtimeInitialized = false; var runtimeKeepaliveCounter = 0; function keepRuntimeAlive() { return noExitRuntime || runtimeKeepaliveCounter > 0; } function preRun() { if (Module['preRun']) { if (typeof Module['preRun'] == 'function') Module['preRun'] = [Module['preRun']]; while (Module['preRun'].length) { addOnPreRun(Module['preRun'].shift()); } } callRuntimeCallbacks(__ATPRERUN__); } function initRuntime() { assert(!runtimeInitialized); runtimeInitialized = true; checkStackCookie(); if (!Module["noFSInit"] && !FS.init.initialized) FS.init(); FS.ignorePermissions = false; TTY.init(); callRuntimeCallbacks(__ATINIT__); } function postRun() { checkStackCookie(); if (Module['postRun']) { if (typeof Module['postRun'] == 'function') Module['postRun'] = [Module['postRun']]; while (Module['postRun'].length) { addOnPostRun(Module['postRun'].shift()); } } callRuntimeCallbacks(__ATPOSTRUN__); } function addOnPreRun(cb) { __ATPRERUN__.unshift(cb); } function addOnInit(cb) { __ATINIT__.unshift(cb); } function addOnExit(cb) { } function addOnPostRun(cb) { __ATPOSTRUN__.unshift(cb); } // include: runtime_math.js // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/imul // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/fround // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/clz32 // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/trunc assert(Math.imul, 'This browser does not support Math.imul(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill'); assert(Math.fround, 'This browser does not support Math.fround(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill'); assert(Math.clz32, 'This browser does not support Math.clz32(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill'); assert(Math.trunc, 'This browser does not support Math.trunc(), build with LEGACY_VM_SUPPORT or POLYFILL_OLD_MATH_FUNCTIONS to add in a polyfill'); // end include: runtime_math.js // A counter of dependencies for calling run(). If we need to // do asynchronous work before running, increment this and // decrement it. Incrementing must happen in a place like // Module.preRun (used by emcc to add file preloading). // Note that you can add dependencies in preRun, even though // it happens right before run - run will be postponed until // the dependencies are met. var runDependencies = 0; var runDependencyWatcher = null; var dependenciesFulfilled = null; // overridden to take different actions when all run dependencies are fulfilled var runDependencyTracking = {}; function getUniqueRunDependency(id) { var orig = id; while (1) { if (!runDependencyTracking[id]) return id; id = orig + Math.random(); } } function addRunDependency(id) { runDependencies++; if (Module['monitorRunDependencies']) { Module['monitorRunDependencies'](runDependencies); } if (id) { assert(!runDependencyTracking[id]); runDependencyTracking[id] = 1; if (runDependencyWatcher === null && typeof setInterval != 'undefined') { // Check for missing dependencies every few seconds runDependencyWatcher = setInterval(() => { if (ABORT) { clearInterval(runDependencyWatcher); runDependencyWatcher = null; return; } var shown = false; for (var dep in runDependencyTracking) { if (!shown) { shown = true; err('still waiting on run dependencies:'); } err('dependency: ' + dep); } if (shown) { err('(end of list)'); } }, 10000); } } else { err('warning: run dependency added without ID'); } } function removeRunDependency(id) { runDependencies--; if (Module['monitorRunDependencies']) { Module['monitorRunDependencies'](runDependencies); } if (id) { assert(runDependencyTracking[id]); delete runDependencyTracking[id]; } else { err('warning: run dependency removed without ID'); } if (runDependencies == 0) { if (runDependencyWatcher !== null) { clearInterval(runDependencyWatcher); runDependencyWatcher = null; } if (dependenciesFulfilled) { var callback = dependenciesFulfilled; dependenciesFulfilled = null; callback(); // can add another dependenciesFulfilled } } } /** @param {string|number=} what */ function abort(what) { if (Module['onAbort']) { Module['onAbort'](what); } what = 'Aborted(' + what + ')'; // TODO(sbc): Should we remove printing and leave it up to whoever // catches the exception? err(what); ABORT = true; EXITSTATUS = 1; // Use a wasm runtime error, because a JS error might be seen as a foreign // exception, which means we'd run destructors on it. We need the error to // simply make the program stop. // FIXME This approach does not work in Wasm EH because it currently does not assume // all RuntimeErrors are from traps; it decides whether a RuntimeError is from // a trap or not based on a hidden field within the object. So at the moment // we don't have a way of throwing a wasm trap from JS. TODO Make a JS API that // allows this in the wasm spec. // Suppress closure compiler warning here. Closure compiler's builtin extern // defintion for WebAssembly.RuntimeError claims it takes no arguments even // though it can. // TODO(https://github.com/google/closure-compiler/pull/3913): Remove if/when upstream closure gets fixed. /** @suppress {checkTypes} */ var e = new WebAssembly.RuntimeError(what); readyPromiseReject(e); // Throw the error whether or not MODULARIZE is set because abort is used // in code paths apart from instantiation where an exception is expected // to be thrown when abort is called. throw e; } // include: memoryprofiler.js // end include: memoryprofiler.js // include: URIUtils.js // Prefix of data URIs emitted by SINGLE_FILE and related options. var dataURIPrefix = 'data:application/octet-stream;base64,'; // Indicates whether filename is a base64 data URI. function isDataURI(filename) { // Prefix of data URIs emitted by SINGLE_FILE and related options. return filename.startsWith(dataURIPrefix); } // Indicates whether filename is delivered via file protocol (as opposed to http/https) function isFileURI(filename) { return filename.startsWith('file://'); } // end include: URIUtils.js function createExportWrapper(name) { return function() { assert(runtimeInitialized, `native function \`${name}\` called before runtime initialization`); var f = wasmExports[name]; assert(f, `exported native function \`${name}\` not found`); return f.apply(null, arguments); }; } // include: runtime_exceptions.js // end include: runtime_exceptions.js var wasmBinaryFile; wasmBinaryFile = 'data:application/octet-stream;base64,AGFzbQEAAAAB2IOAgAA8YAF/AGABfwF/YAJ/fwF/YAN/f38Bf2ACf38AYAN/f38AYAR/f39/AX9gBX9/f39/AX9gBH9/f38AYAAAYAABf2AGf39/f39/AX9gBn9/f39/fwBgBX9/f39/AGAHf39/f39/fwF/YAh/f39/f39/fwF/YAV/fn5+fgBgB39/f39/f38AYAN/fn8BfmABfAF8YAl/f39/f39/f38AYAh/f39/f39/fwBgBH9+fn8AYAp/f39/f39/f39/AGABfwF8YAF8AX9gAnx/AXxgBn98f39/fwF/YAJ+fwF/YAF8AX5gEX9/f39/f39/f39/f39/f39/AX9gD39/f39/f39/f39/f39/fwF/YAt/f39/f39/f39/fwBgCX9/f39/f39/fwF/YAJ8fAF8YAF+AX9gDH9/f39/f39/f39/fwBgBH5+fn4Bf2AEf39/fgF+YAJ+fgF8YAN+f38Bf2ACf3wBfGACfn8BfGADfHx/AXxgA3x+fgF8YAF8AGACf38BfGAEf398fwF/YAp/f39/f39/f39/AX9gAn9+AGACf30AYAJ/fABgAn5+AX9gA39+fgBgAn9/AX5gAn5+AX1gA39/fgBgAn98AX9gBH9/fn8BfmAEf35/fwF/ArGDgIAAEANlbnYVZW1zY3JpcHRlbl9tZW1jcHlfYmlnAAUDZW52BGV4aXQAAANlbnYWZW1zY3JpcHRlbl9yZXNpemVfaGVhcAABA2VudgpnZXRlbnRyb3B5AAIWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQhmZF9jbG9zZQABFndhc2lfc25hcHNob3RfcHJldmlldzEIZmRfd3JpdGUABgNlbnYFYWJvcnQACQNlbnYRX19zeXNjYWxsX2ZzdGF0NjQAAgNlbnYQX19zeXNjYWxsX3N0YXQ2NAACA2VudhRfX3N5c2NhbGxfbmV3ZnN0YXRhdAAGA2VudhFfX3N5c2NhbGxfbHN0YXQ2NAACA2VudhBfX3N5c2NhbGxfb3BlbmF0AAYWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQdmZF9yZWFkAAYWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MRFlbnZpcm9uX3NpemVzX2dldAACFndhc2lfc25hcHNob3RfcHJldmlldzELZW52aXJvbl9nZXQAAhZ3YXNpX3Nu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ALQKCXhtbE5ld0RvYwC6Cgp4bWxGcmVlRG9jALsKDXhtbFJlbW92ZVByb3AAxQoKeG1sTmV3Tm9kZQDHCg14bWxOZXdEb2NOb2RlAMgKEHhtbE5ld0RvY1RleHRMZW4AzAoQeG1sTmV3Q0RhdGFCbG9jawDNChB4bWxOZXdEb2NDb21tZW50AM4KEXhtbEFkZE5leHRTaWJsaW5nANMKEXhtbEFkZFByZXZTaWJsaW5nANcKC3htbEFkZENoaWxkANgKDXhtbFVubGlua05vZGUA2goReG1sTm9kZUdldENvbnRlbnQA4QoUeG1sRG9jR2V0Um9vdEVsZW1lbnQA6woUeG1sRG9jU2V0Um9vdEVsZW1lbnQA7AoMeG1sU2V0TnNQcm9wAO0KFHhtbE5vZGVTZXRDb250ZW50TGVuAPcKDHhtbEdldE5zTGlzdAD6Cgt4bWxTZWFyY2hOcwD7Cgx4bWxIYXNOc1Byb3AA/goXeG1sT3V0cHV0QnVmZmVyQ3JlYXRlSU8A/gMZeG1sUmVnaXN0ZXJJbnB1dENhbGxiYWNrcwCPBBh4bWxDbGVhbnVwSW5wdXRDYWxsYmFja3MAkAQTeG1sU2F2ZUZvcm1hdEZpbGVUbwCcBA54bWxSZWxheE5HRnJlZQCICxp4bWxSZWxheE5HTmV3RG9jUGFyc2VyQ3R4dACZCxh4bWxSZWxheE5HRnJlZVBhcnNlckN0eHQAmgsPeG1sUmVsYXhOR1BhcnNlAJsLI3htbFJlbGF4TkdTZXRQYXJzZXJTdHJ1Y3R1cmVkRXJyb3JzAKwLFnhtbFJlbGF4TkdOZXdWYWxpZEN0eHQAugsXeG1sUmVsYXhOR0ZyZWVWYWxpZEN0eHQAvAsieG1sUmVsYXhOR1NldFZhbGlkU3RydWN0dXJlZEVycm9ycwC9CxV4bWxSZWxheE5HVmFsaWRhdGVEb2MAvgsNeG1sU2NoZW1hRnJlZQCRCBl4bWxTY2hlbWFOZXdEb2NQYXJzZXJDdHh0AJYIF3htbFNjaGVtYUZyZWVQYXJzZXJDdHh0AJcIFnhtbFNjaGVtYUZyZWVWYWxpZEN0eHQAmAgOeG1sU2NoZW1hUGFyc2UAqggieG1sU2NoZW1hU2V0UGFyc2VyU3RydWN0dXJlZEVycm9ycwDiCCF4bWxTY2hlbWFTZXRWYWxpZFN0cnVjdHVyZWRFcnJvcnMA4wgVeG1sU2NoZW1hTmV3VmFsaWRDdHh0AOQIFHhtbFNjaGVtYVZhbGlkYXRlRG9jAPAIFXhtbFhJbmNsdWRlTmV3Q29udGV4dAD8BxZ4bWxYSW5jbHVkZUZyZWVDb250ZXh0AP0HGnhtbFhJbmNsdWRlU2V0RXJyb3JIYW5kbGVyAP8HFnhtbFhJbmNsdWRlUHJvY2Vzc05vZGUAgQgUeG1sWFBhdGhGcmVlQ29tcEV4cHIA3wYSeG1sWFBhdGhGcmVlT2JqZWN0AOAGEnhtbFhQYXRoUmVnaXN0ZXJOcwD4BhJ4bWxYUGF0aE5ld0NvbnRleHQA+wYTeG1sWFBhdGhGcmVlQ29udGV4dAD9BhN4bWxYUGF0aEN0eHRDb21waWxlAMcHFHhtbFhQYXRoQ29tcGlsZWRFdmFsAMwHFnhtbFhQYXRoU2V0Q29udGV4dE5vZGUA0gcQX19lcnJub19sb2NhdGlvbgATBmZmbHVzaADtAwZtYWxsb2MAVARmcmVlAFUVZW1zY3JpcHRlbl9zdGFja19pbml0AN4LGWVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2ZyZWUA3wsZZW1zY3JpcHRlbl9zdGFja19nZXRfYmFzZQDgCxhlbXNjcmlwdGVuX3N0YWNrX2dldF9lbmQA4QsJc3RhY2tTYXZlAOILDHN0YWNrUmVzdG9yZQDjCwpzdGFja0FsbG9jAOQLHGVtc2NyaXB0ZW5fc3RhY2tfZ2V0X2N1cnJlbnQA5QsZX19pbmRpcmVjdF9mdW5jdGlvbl90YWJsZQEADGR5bkNhbGxfamlqaQDnCwm8hICAAAEAQQELnwI1NjpcXmCNAY4BsQGyAbMBtAG1AbYBowGkAbcBuAHCAcMBxAG5AcUB4QHrAewB7QHuAe8B8AHxAfIB8wH0AfUB9gH3AfgB+QH6AfsB/AH9Af4B/wGAAoECggKDAoQChQKGAocCiAKJAooCiwKMAo0CjgKPApACkQKSApMClAKVApYClwKYApkCmgKbApwCnQKeAp8CoAKhAqICowKkAqUCpgKnAqgCqQKqAqsCrAKtAq4CrwKwArECsgKzArQCtQK2ArcCuAK5AroCuwK8Ar0CvgK/AsACwQLCAsMCxALFAsYCxwLIAskCygLLAswCzQLOAs8C0ALRAtIC0wLU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QQAQIDYCrJ8RC6ACAQF/QQEhAwJAAkAgAEUNACABQf8ATQ0BAkACQBAhKAJgKAIADQAgAUGAf3FBgL8DRg0DEBNBGTYCAAwBCwJAIAFB/w9LDQAgACABQT9xQYABcjoAASAAIAFBBnZBwAFyOgAAQQIPCwJAAkAgAUGAsANJDQAgAUGAQHFBgMADRw0BCyAAIAFBP3FBgAFyOgACIAAgAUEMdkHgAXI6AAAgACABQQZ2QT9xQYABcjoAAUEDDwsCQCABQYCAfGpB//8/Sw0AIAAgAUE/cUGAAXI6AAMgACABQRJ2QfABcjoAACAAIAFBBnZBP3FBgAFyOgACIAAgAUEMdkE/cUGAAXI6AAFBBA8LEBNBGTYCAAtBfyEDCyADDwsgACABOgAAQQELFAACQCAADQBBAA8LIAAgAUEAECMLjgECAX4BfwJAIAC9IgJCNIinQf8PcSIDQf8PRg0AAkAgAw0AAkACQCAARAAAAAAAAAAAYg0AQQAhAwwBCyAARAAAAAAAAPBDoiABECUhACABKAIAQUBqIQMLIAEgAzYCACAADwsgASADQYJ4ajYCACACQv////////+HgH+DQoCAgICAgIDwP4S/IQALIAALUwEBfgJAAkAgA0HAAHFFDQAgASADQUBqrYYhAkIAIQEMAQsgA0UNACABQcAAIANrrYggAiADrSIEhoQhAiABIASGIQELIAAgATcDACAAIAI3AwgLUwEBfgJAAkAgA0HAAHFFDQAgAiADQUBqrYghAUIAIQIMAQsgA0UNACACQcAAIANrrYYgASADrSIEiIQhASACIASIIQILIAAgATcDACAAIAI3AwgL4gMCAn8CfiMAQSBrIgIkAAJAAkAgAUL///////////8AgyIEQoCAgICAgMD/Q3wgBEKAgICAgIDAgLx/fFoNACAAQjyIIAFCBIaEIQQCQCAAQv//////////D4MiAEKBgICAgICAgAhUDQAgBEKBgICAgICAgMAAfCEFDAILIARCgICAgICAgIDAAHwhBSAAQoCAgICAgICACFINASAFIARCAYN8IQUMAQsCQCAAUCAEQoCAgICAgMD//wBUIARCgICAgICAwP//AFEbDQAgAEI8iCABQgSGhEL/////////A4NCgICAgICAgPz/AIQhBQwBC0KAgICAgICA+P8AIQUgBEL///////+/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