starcoder.js
Version:
Web browser version of StarCoder.cpp
783 lines (671 loc) • 2.69 MB
JavaScript
var Module = (() => {
var _scriptDir = import.meta.url;
return (
async 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;
});
["_main","_fflush","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?
const { createRequire } = await import('module');
/** @suppress{duplicate} */
var require = createRequire(import.meta.url);
// 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 {
// EXPORT_ES6 + ENVIRONMENT_IS_NODE always requires use of import.meta.url,
// since there's no way getting the current absolute path of the module when
// support for that is not available.
scriptDirectory = require('url').fileURLToPath(new URL('./', import.meta.url)); // includes trailing slash
}
// include: node_shell_read.js
read_ = (filename, binary) => {
var ret = tryParseAsDataURI(filename);
if (ret) {
return binary ? ret : ret.toString();
}
// 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) => {
var ret = tryParseAsDataURI(filename);
if (ret) {
onload(ret);
}
// 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_ = (f) => {
const data = tryParseAsDataURI(f);
if (data) {
return intArrayToString(data);
}
return read(f);
};
}
readBinary = (f) => {
let data;
data = tryParseAsDataURI(f);
if (data) {
return data;
}
if (typeof readbuffer == 'function') {
return new Uint8Array(readbuffer(f));
}
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) => {
try {
var xhr = new XMLHttpRequest();
xhr.open('GET', url, false);
xhr.send(null);
return xhr.responseText;
} catch (err) {
var data = tryParseAsDataURI(url);
if (data) {
return intArrayToString(data);
}
throw err;
}
}
if (ENVIRONMENT_IS_WORKER) {
readBinary = (url) => {
try {
var xhr = new XMLHttpRequest();
xhr.open('GET', url, false);
xhr.responseType = 'arraybuffer';
xhr.send(null);
return new Uint8Array(/** @type{!ArrayBuffer} */(xhr.response));
} catch (err) {
var data = tryParseAsDataURI(url);
if (data) {
return data;
}
throw err;
}
};
}
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;
}
var data = tryParseAsDataURI(url);
if (data) {
onload(data.buffer);
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('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;
//========================================
// 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,
/* BigInt64Array type is not correctly defined in closure
/** not-@type {!BigInt64Array} */
HEAP64,
/* BigUInt64Array type is not correctly defined in closure
/** not-t@type {!BigUint64Array} */
HEAPU64,
/** @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);
Module['HEAP64'] = HEAP64 = new BigInt64Array(b);
Module['HEAPU64'] = HEAPU64 = new BigUint64Array(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**2)] = 0x02135467;
HEAPU32[(((max)+(4))/2**2)] = 0x89BACDFE;
// Also test the global address 0 for integrity.
HEAPU32[((0)/2**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**2)];
var cookie2 = HEAPU32[(((max)+(4))/2**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**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 __ATMAIN__ = []; // functions called when main() is to be run
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 preMain() {
checkStackCookie();
callRuntimeCallbacks(__ATMAIN__);
}
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 addOnPreMain(cb) {
__ATMAIN__.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
/** @param {boolean=} fixedasm */
function createExportWrapper(name, fixedasm) {
return function() {
var displayName = name;
var asm = fixedasm;
if (!fixedasm) {
asm = Module['asm'];
}
assert(runtimeInitialized, 'native function `' + displayName + '` called before runtime initialization');
if (!asm[name]) {
assert(asm[name], 'exported native function `' + displayName + '` not found');
}
return asm[name].apply(null, arguments);
};
}
// include: runtime_exceptions.js
// end include: runtime_exceptions.js
var wasmBinaryFile;
wasmBinaryFile = 'data:application/octet-stream;base64,AGFzbQEAAAABtoiAgACIAWABfgF/YAJ+fwF/YAF+AGACfn4AYAN+f34AYAR+fn5+AGADfn5+AX5gA35+fwBgBH9+fn4AYAN/fn4AYAN+fn8BfmAGfnx/f39/AX9gA35+fwF/YAh+fn5+fn5+fgF/YAV+fn5+fgF/YAN/fn8AYAZ+fn5+fn4BfmAEfn5+fgF+YAV+fn5/fgF+YAh+fn5+fn5/fwF+YAN+f38Bf2ABfgF+YAAAYAR+fn5/AGAGfn5+fn9/AGAFfn5+f38AYAN+fn4AYAF/AGAAAXxgAAF/YAR/fn9+AX9gA39/fgF/YAR/fn5+AX9gAX8Bf2ACf34Bf2ACfn4Bf2AFfn5+fn4BfmAAAX5gA35+fgF/YAJ+fgF+YAJ+fwBgBn5+fn5+fgBgBn5/f35+fgF/YAF9AX1gAn5/AX5gBX5+fn5+AGACf38Bf2ADf35+AX9gBH5+fn8Bf2AFfn5+fn8Bf2AFfn5+fn8AYAp+fn5+f3x8f31+AX9gBn5+fn5/fwF+YAR+fn9/AGAHfn5+fn5+fwBgA35/fgF+YAR+fn9+AX5gBX5+f35/AX5gA35/fgF/YAV+f35+fwBgBn5+fn5/fwF/YAZ+fn5/f38BfmADfn9/AGAEfn5+fwF+YAl+fn5+fn5+fn4AYAp+fn5+fn5+fn5+AGAFfn5+f38BfmAJfn9+fn9/f35+AX5gA35+fAF8YAJ+fgF8YAN+fHwBfmADfn5+AXxgAX4BfGABfwF9YAF9AX9gAX8BfmAFfn9/fn4BfmAEfn9/fgF+YAR+f35+AX5gBX5/fn5+AX5gA39+fQBgAn59AX5gBn5+f39/fwF+YAR+fn9/AX5gBn5+fn5/fgBgB35+fn5+fn4AYAV+fn5+fQBgBH9+fn0AYAJ9fQF9YAV/f35+fgBgAXwBfWAFfn5/f38Bf2ACfX4Bf2ACf3wBfGABfAF8YAF/AXxgAXwBf2ADfH5+AXxgAXwAYAJ/fQF9YAJ/fgF+YAR+fn5+AX9gA39+fwF+YAJ8fwF9YAJ8fwF8YAJ8fgF8YAd+fn5+fn5+AX9gBH5/fn4AYAV+f39/fwBgAXwBfmACfn0AYAJ+fABgBn5+f39/fwBgB35+f39/f38AYAJ+fgF9YAN/fn4BfmADfn5+AX1gB35+fn5+fn8BfmAKf39+fn5/fn5+fgF/YAx/fn5+fn9/fn5+fn4Bf2AGfn5+f35+AX5gBn5+fn5+fwF+YAV+fn5/fAF+YAZ+fn5/fH4BfmAHfn5+f35+fgF+YAh+fn5+fn5+fgF+YAd+fn5/fn9/AX5gC35+f35/fn5+fn5+AX9gCn9+fn5+fn5+fn4AYAd+fn9+f35+AX5gCn9/fn5+fn5+fn4AYA9+fn5/fn5+f35/f35+fn8AYAZ+fn9+f34BfmAGfn5+f39+AGAIfn5+fn5+fn8Bf2AIfn5+fn5+fn4AAq6EgIAAFANlbnYLX19jeGFfdGhyb3cAGgNlbnYEZXhpdAAbA2VudhVlbXNjcmlwdGVuX21lbWNweV9iaWcAGgNlbnYTZW1zY3JpcHRlbl9kYXRlX25vdwAcA2VudiBfZW1zY3JpcHRlbl9nZXRfbm93X2lzX21vbm90b25pYwAdA2VudhJlbXNjcmlwdGVuX2dldF9ub3cAHANlbnYQX19zeXNjYWxsX29wZW5hdAAeA2VudhFfX3N5c2NhbGxfZmNudGw2NAAfA2Vudg9fX3N5c2NhbGxfaW9jdGwAHxZ3YXNpX3NuYXBzaG90X3ByZXZpZXcxCGZkX3dyaXRlACAWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQdmZF9yZWFkACAWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MQhmZF9jbG9zZQAhFndhc2lfc25hcHNob3RfcHJldmlldzENZmRfZmRzdGF0X2dldAAiFndhc2lfc25hcHNob3RfcHJldmlldzEHZmRfc2VlawAeA2VudhZlbXNjcmlwdGVuX3Jlc2l6ZV9oZWFwAAADZW52BWFib3J0ABYWd2FzaV9zbmFwc2hvdF9wcmV2aWV3MRFlbnZpcm9uX3NpemVzX2dldAAjFndhc2lfc25hcHNob3RfcHJldmlldzELZW52aXJvbl9nZXQAIwNlbnYKc3RyZnRpbWVfbAAkA2VudhdlbXNjcmlwdGVuX2dldF9oZWFwX21heAAlA92lgIAAySUWJgoAFRUnAxUGJycnFQMnJycaGgAKJxUnFSMjAhUVBgooABUGAgIGJwMCAwMCFRUDAxUVFikVFRUpFRUDABUVFQIVAwMVKRUVFScAFSMnJxUnKhUVJysDFRUVAwMVIhUnLAAnABoaJxUVFScVFRonFScVAhUDBicnIxUVFRUVFRUnKAEKJwICBgYKAxUVFRUVFQYCBicDAgMDAhUaJycVFRUFAgIDAhUDAxUnBgMDFSMnAhUVFRUVFRUnFScGAhUGFRUVFScnFRUVFRUVFQYVFRUnFRUVJxUVFQYCFScnFRUVFQYVFRUnFRUVJhUnAhUDFRUDGhUVFRoVFRUaABoDAwIVFQICAhUVGhUtAxoVFRUDAxUVFScCFRUCAgIVFRoVFS0DGhUVFQMDFRUVFQMVFQMaFRUVGhUVFRUVAxUVAxoVFRUaFRUVFRUVFRUVFQMVFRUVFRUVFRUVFRoDAxUDGhUDFRUVAygdACcnFQIVGhUDBgMVFRUlJwInFRUVFS0nFRUlJhUnFicnFRUVFRUDAgICAwMDJxEDAxUDAycGFRUGFScRFQMCAhUnJxUVFQYFBQUaFS0nJxojFRUVFQYnFgMVAxUAAwYGBi0VBRUVJwYnFRUVFSYmJwoGFS0VAxUVFQMVFSYVIxUjAyMVFSYGJhUnBi0VFRUnJycGFScVFQYVJxUVFQACAhUDFRUDJycGLRUFFRUnBicVFRUVJiYnCgYVLRUVFRUDFRUmFRUVJwYtFRUVJycnBhUVFRUVFQMnJxUDJxEDAxUDAxUGAxUVAgYVGhUGFScRFQMDAgIVFQMVFRUVFScnFRUVBgUFBRoVLScnGiMVFRUVBicWAxUDFQYtFQUVFScGJxUVFRUmJicKBhUtFRUVFQMVFRUVFScGLRUVFScnJwYVFQMVFRUVAycnESMVJxUDFScRAwMVAwMDFQYDFRUVAhUGFRoVBhUCJxEVAwMCAhUaFQMVFRUVFRUVFRUnJycVFRUVLQYFBQUaFS0nJxojFRUVFQYnFgMaFQMDAxUhAAIVAC4hLhUVAQIVISUlBgIVJwMDAwYGJxUGBQUFGhUtJycaFRoFFQYnJwYVGgYnFQYVFRUCAicVJxUCFRoDBgMVFRUVFScVFRUtFRUVFRUVFRUDAgIaAxoDAwYnBhUGEQYFBQUaFS0nJxoVGgUVBicnBhUVGgYnGicRAxUaBhUVJxEVAwIVJxUVFQYFBQUaFS0nJxojFRUVFQYnFgMVAxUVFQUnBgUFGi0nGgUGGgYWBgYVAhUnFRUaFRUVJxUVIxUVIxUKFRUnIxUVFRUaFRUvCQonFRUGFQIFJwMDACEhISEhAxUDAxoAJycVMBUVIxUDAxUVFRUVIxUFJxUjFScVFScVMS4yFQAVFSMDAwMVJyMnJyMVFRUGAjMVBhUDFScGIxonAxUnFRoDIxUnFRUVAwMVFSMVFScDFQYjJxUVFRUnBgIVFQIVEQMVIxUVJxUDAwYRJycDAyMnBgIVFQIVEQMVFQMDJyMDAwYmFScCJwIVAgAVFScCAgICFRUaFRUtAxoVFRUDAxUVFRUnFSYVFQYVFRUGFScVFRUGJxUtJBoVBRUVJwYVJxUVJhUVJgYnFRUnCgYVFRoVFRUVAycVFRUVAxUVFRUVFQMVFRUVJwYaFRUVFRUnJycVFRUVFRUDAxoaAycGAiEsBiMWJxUuFScVJwMVFRUGBgYGBhYjFQYnAxUnFQMGAhUVGgIGJwIWBgYVFQIDBAIDJxUnFScVAxUDAwYVJwYGFQMnFScnJycVAgIVFRUDJxUVAhUnFRoVFRUVFRUVFRUVJxUVAgMVFRUCAhUVAxUGFQYnBgY0KBU1FgIGBgIoFgYZGTYRFhYANzcDODkuFQIDJyEDAxUCAwMnJxUCAzoMJycVAgMAOy4hPBUnJwICFRUnGhUVFQMVFRoAAxYCJxUnFgAVJxUVJwYCFScnFQYaAwInAwIVBgYVFRoVAwMDAhoVFQIaAxUVGhUVAxUtAwIaFRUVFScVFRUGAhUDAxUVFRoVAwMDJycnAicVFRUVBhUVGhUVJxEDFRUaFScnJwYDFQYCAxUnFScnFRUVFRUCFQYVGhUCJxEVAwMCAhUaFRUVFRUVFRUnJxUVFRUtEQMjFRUVAhUnFQIVJxojFQMVFQMVFRUVAxoVAxUGBhUVFRUnAicCAgICFRoVLQMaFRUDAxUVAgIRGgMVBhUVBhUnERUDAhUnFRUVEQMjFRUaFQIVJxoVAhUnGiMVFRUVFRUVAxUDFQMnEQMDFQMDBgMVFQIGFRoVBhUnERUDAwICFQMVFRUVFRUnJxUVFREDIxUVGhUCFScaFQIVJxojFRUVFRUVFQMVAxUDAwMCAwUCFQIDAwUCFScREQMaAhUnGgIaJxERAxoCFScaAhoCAicWBgYRFiwoETc3KBUCHRYoAxUUADg4Nx04ODcBAQEVAgMVAgMVAgMVAgMVAgMVAgMmJiY9AwMVFRUDIwYCBgIVFRUCAwYFFScjAAUVJyMFJyMnABUVJxUVFScVFRUnAicCAgICFRUaFS0DGhUVFQMDFRUVAgICFRUaFS0DGhUVFQMDFRUVFTIGMicaJycGAwMDAxoaGhoCFC4hISERERERJBEaPhEFFhUVBQM/FgMoLAUaAxYaAxoRMjInQBonQQYnJwMnJyYaJycGBhonJwYaJyMVFScjJxUGQgYVAwMGFQYaFScRAxUVGicVAgYVGhUnERUDAwICFRUVFRUVJycVFRURAyMVFRUCFScVAhUnGiMVFRUVFRUVAxUDFRUDAwYGFQYaFScRAxUVGhUCBhUaFScRFQMDAgIVFRUVFRUnJxUVFREDIxUVFQIVJxUCFScaIxUVFRUVFRUDFQMVFQIDFQIDFUMnFScVFRUVHRUGBhUVAxUVFQIDJwMVBAInFRUVAgMVFQMVHRUCAwQVAgMGBjQGBgYGBgYGBgIBJxUCAwYGBgYDAiw8JywVAycnFQA8PCcVAxUCAgMAFScCFQYnFRUCAxUVFRUBAyMVFRUCFQIVFRUGJxUVFRUVAxUVJwMDFREGBhUDFQMDFRUVFQAGFRUVFQMGJxoVGhUaBhUGFRoGFRUVFQMCFRoDBScGFRUVGgUFGhUtJycaBRUGJxoGJxoVJxUVFRUFBQUtBRoGFScnFRUnJxUVAxUDGhUDAwMVFRUCAwMjAxUDAicnAxoDGgMnAwYnAwUFBRoVLScnGhUGJwMnAwYCJwMFAgUFGhUtJycaJxUGJwMDFQMnEQMDFQMVBgMVFQIGFRoVBhUnERUDAwIVFQMVFRUVFRUVJycnFRUVEQMjFRUaFQIVJxoVAhUnGiMVFRUVFRUVAxUDFRUFBRoVLScnGhUaIwAVJxUVFQYnJwYVIwAAJwYDAwYGGhUVJxUVFRUnFQYaFScRAxUVGhUCBhUaFScRFQMDAgIVFRUVFRUnJxUVFREDIxUVGhUCFScaFQIVJxojFRUVFRUVFQMVAxUVJwYCJycGBhEVFScjFRUVFScVJycVFRUCAgIaFS0DGhUVFQMDFRUVFRUGFRoVJxEVAwMCAhUVFRUnJxUVFRURAyMVFRoVAhUVJxoVAhUnGiMVFRUVFRUVAxUDFQYVJwYnAxEaJyYDBRoDFScFFQMDAwMWBgUDAwMDAwYVAxUnFRUVAgICGhUtAxoVFRUDAxUVFRUVBhUaFScRFQMDAgIVFRUVJycVFRUVBhUFBQUaFS0nJxojFRUVFQYnFgMVAxUGGhUnGgYDAwMDAwYVAwYCAycDBQIVAEQjJycG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fgN/AX0BfwF9AX4EfQF/AX0DfwR+AX8BfQF/A30BfgR9AX8BfQN/BH4BfwF9AX8DfQF+BH0BfwF9A38EfgF/AX0BfwN9AX4EfQF/AX0DfwR+AX8BfQF/A30BfgR9AX8BfQN/BH4BfwF9Bn8BfQF/An0BfgR9AX8BfQN/BH4BfwF9BH8DfQF+BH0BfwF9A38EfgF/AX0CfwF9AX8CfQF+BH0BfwF9A38EfgF/AX0BfwN9AX4EfQF/AX0DfwR+AX8BfQR/AX0BfwJ9AX4EfQF/AX0DfwR+AX8BfQJ/A30BfgR9AX8BfQN/BH4BfwF9A38BfQF/An0BfgR9AX8BfQN/BH4BfwF9AX8DfQF+BH0BfwF9A38EfgV/An0BfgR9AX8BfQN/BH4FfwJ9AX4EfQF/AX0DfwR+CH8FfgF/K34DfwZ+BH8CfgF/AX4BfwF+AX8BfgJ/AX4CfwF+BH8DfgJ/A34CfwF+AX8EfgJ/AX4BfwR+A38BfgJ/BX4CfwF+An8BfgF/BH4DfwF+An9Tfgh/A34CfwR+An8BfgF/BH4CfwF+AX8EfgJ/AX4BfwR+An8BfgF/BH4DfwF+Bn8FfgZ/AX4BfwR+A38BfgJ/BX4CfwF+AX8EfgN/AX4EfwV+BH8BfgF/BH4FfwF+An8FfgJ/AX4Bfwd+AX8jfgF/I34BfyN+AX8jfgF/I34BfyN+AX8jfgF/I34BfyN+AX8jfgF/I34Bfx5+A38CfgF/AX4BfwF+B38CfgJ/AX4BfwR+An8BfgF/Cn4Bfx1+BH8Cfgp/C34Cfwd+CH8EfgR/BX4Cfxx+AX8DfgJ/Cn4EfxR+An8DfgN/An4CfwN+A38IfgF/An4Dfwx+BH8CfgJ/A34Dfwh+An8IfgV/AX4CfwR+A38GfgN/CH4Cfwt+BH8LfgZ/C34EfwR+AX8CfgF/A34EfwN+A38CfiOAgICAACEDQvAPIQQgAyAEfSEFIAUkgICAgAAgBSAANwPgDyAFIAE3A9gPIAUgAjcD0A8gBSkD4A8hBkKADSEHIAUgB3whCCAIIQlBBCEKIAkgBiAKEJaAgIAAGiAFKQOADSELQmghDCALIAx8IQ0gDSkDACEOQoANIQ8gBSAPfCEQIBAhESARIA58IRIgEhCXgICAACETQQEhFCATIBRxIRUCQAJAIBVFDQBCACEWIBYpA8C0oYCAgICAgAAh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