From 7dbbe244345140c25ecf4c13bdd33b6c2ad312bb Mon Sep 17 00:00:00 2001 From: yvesgurcan Date: Sun, 23 Feb 2020 11:33:01 -0800 Subject: [PATCH 1/3] restore play next song automatically --- example/react/index.html | 2 +- example/react/main.3b4e534021ecd2f7b4b0.js | 1277 ++++++++++++++++++++ example/react/main.dd6d3b44adb0ac3ff77b.js | 53 - example/react/src/components/Player.js | 2 +- 4 files changed, 1279 insertions(+), 55 deletions(-) create mode 100644 example/react/main.3b4e534021ecd2f7b4b0.js delete mode 100644 example/react/main.dd6d3b44adb0ac3ff77b.js diff --git a/example/react/index.html b/example/react/index.html index e3584c9..2170566 100644 --- a/example/react/index.html +++ b/example/react/index.html @@ -5,5 +5,5 @@
- + diff --git a/example/react/main.3b4e534021ecd2f7b4b0.js b/example/react/main.3b4e534021ecd2f7b4b0.js new file mode 100644 index 0000000..8e5e6dd --- /dev/null +++ b/example/react/main.3b4e534021ecd2f7b4b0.js @@ -0,0 +1,1277 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 0); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "../../index.js": +/*!******************************************************!*\ + !*** /Users/owner/Projects/web-midi-player/index.js ***! + \******************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +eval("!function(g,I){ true?module.exports=I():undefined;}(window,function(){return function(g){var I={};function A(C){if(I[C])return I[C].exports;var i=I[C]={i:C,l:!1,exports:{}};return g[C].call(i.exports,i,i.exports,A),i.l=!0,i.exports;}return A.m=g,A.c=I,A.d=function(g,I,C){A.o(g,I)||Object.defineProperty(g,I,{enumerable:!0,get:C});},A.r=function(g){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(g,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(g,\"__esModule\",{value:!0});},A.t=function(g,I){if(1&I&&(g=A(g)),8&I)return g;if(4&I&&\"object\"==typeof g&&g&&g.__esModule)return g;var C=Object.create(null);if(A.r(C),Object.defineProperty(C,\"default\",{enumerable:!0,value:g}),2&I&&\"string\"!=typeof g)for(var i in g)A.d(C,i,function(I){return g[I];}.bind(null,i));return C;},A.n=function(g){var I=g&&g.__esModule?function(){return g.default;}:function(){return g;};return A.d(I,\"a\",I),I;},A.o=function(g,I){return Object.prototype.hasOwnProperty.call(g,I);},A.p=\"\",A(A.s=11);}([function(module,exports){eval(\"function _defineProperty(obj, key, value) {\\n if (key in obj) {\\n Object.defineProperty(obj, key, {\\n value: value,\\n enumerable: true,\\n configurable: true,\\n writable: true\\n });\\n } else {\\n obj[key] = value;\\n }\\n\\n return obj;\\n}\\n\\nmodule.exports = _defineProperty;//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9oZWxwZXJzL2RlZmluZVByb3BlcnR5LmpzPzk1MjMiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2RlZmluZVByb3BlcnR5KG9iaiwga2V5LCB2YWx1ZSkge1xuICBpZiAoa2V5IGluIG9iaikge1xuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwge1xuICAgICAgdmFsdWU6IHZhbHVlLFxuICAgICAgZW51bWVyYWJsZTogdHJ1ZSxcbiAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSxcbiAgICAgIHdyaXRhYmxlOiB0cnVlXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgb2JqW2tleV0gPSB2YWx1ZTtcbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gX2RlZmluZVByb3BlcnR5OyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\\n//# sourceURL=webpack-internal:///0\\n\");},function(module,exports,__webpack_require__){eval(\"module.exports = __webpack_require__(7);\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9yZWdlbmVyYXRvci9pbmRleC5qcz9hMzRhIl0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gcmVxdWlyZShcInJlZ2VuZXJhdG9yLXJ1bnRpbWVcIik7XG4iXSwibWFwcGluZ3MiOiJBQUFBOyIsInNvdXJjZVJvb3QiOiIifQ==\\n//# sourceURL=webpack-internal:///1\\n\");},function(module,exports){eval('function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\\n try {\\n var info = gen[key](arg);\\n var value = info.value;\\n } catch (error) {\\n reject(error);\\n return;\\n }\\n\\n if (info.done) {\\n resolve(value);\\n } else {\\n Promise.resolve(value).then(_next, _throw);\\n }\\n}\\n\\nfunction _asyncToGenerator(fn) {\\n return function () {\\n var self = this,\\n args = arguments;\\n return new Promise(function (resolve, reject) {\\n var gen = fn.apply(self, args);\\n\\n function _next(value) {\\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\\n }\\n\\n function _throw(err) {\\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\\n }\\n\\n _next(undefined);\\n });\\n };\\n}\\n\\nmodule.exports = _asyncToGenerator;//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9oZWxwZXJzL2FzeW5jVG9HZW5lcmF0b3IuanM/Yzk3MyJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBhc3luY0dlbmVyYXRvclN0ZXAoZ2VuLCByZXNvbHZlLCByZWplY3QsIF9uZXh0LCBfdGhyb3csIGtleSwgYXJnKSB7XG4gIHRyeSB7XG4gICAgdmFyIGluZm8gPSBnZW5ba2V5XShhcmcpO1xuICAgIHZhciB2YWx1ZSA9IGluZm8udmFsdWU7XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgcmVqZWN0KGVycm9yKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoaW5mby5kb25lKSB7XG4gICAgcmVzb2x2ZSh2YWx1ZSk7XG4gIH0gZWxzZSB7XG4gICAgUHJvbWlzZS5yZXNvbHZlKHZhbHVlKS50aGVuKF9uZXh0LCBfdGhyb3cpO1xuICB9XG59XG5cbmZ1bmN0aW9uIF9hc3luY1RvR2VuZXJhdG9yKGZuKSB7XG4gIHJldHVybiBmdW5jdGlvbiAoKSB7XG4gICAgdmFyIHNlbGYgPSB0aGlzLFxuICAgICAgICBhcmdzID0gYXJndW1lbnRzO1xuICAgIHJldHVybiBuZXcgUHJvbWlzZShmdW5jdGlvbiAocmVzb2x2ZSwgcmVqZWN0KSB7XG4gICAgICB2YXIgZ2VuID0gZm4uYXBwbHkoc2VsZiwgYXJncyk7XG5cbiAgICAgIGZ1bmN0aW9uIF9uZXh0KHZhbHVlKSB7XG4gICAgICAgIGFzeW5jR2VuZXJhdG9yU3RlcChnZW4sIHJlc29sdmUsIHJlamVjdCwgX25leHQsIF90aHJvdywgXCJuZXh0XCIsIHZhbHVlKTtcbiAgICAgIH1cblxuICAgICAgZnVuY3Rpb24gX3Rocm93KGVycikge1xuICAgICAgICBhc3luY0dlbmVyYXRvclN0ZXAoZ2VuLCByZXNvbHZlLCByZWplY3QsIF9uZXh0LCBfdGhyb3csIFwidGhyb3dcIiwgZXJyKTtcbiAgICAgIH1cblxuICAgICAgX25leHQodW5kZWZpbmVkKTtcbiAgICB9KTtcbiAgfTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBfYXN5bmNUb0dlbmVyYXRvcjsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\\n//# sourceURL=webpack-internal:///2\\n');},function(module,exports){eval('function _classCallCheck(instance, Constructor) {\\n if (!(instance instanceof Constructor)) {\\n throw new TypeError(\"Cannot call a class as a function\");\\n }\\n}\\n\\nmodule.exports = _classCallCheck;//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9oZWxwZXJzL2NsYXNzQ2FsbENoZWNrLmpzPzk3MGIiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2NsYXNzQ2FsbENoZWNrKGluc3RhbmNlLCBDb25zdHJ1Y3Rvcikge1xuICBpZiAoIShpbnN0YW5jZSBpbnN0YW5jZW9mIENvbnN0cnVjdG9yKSkge1xuICAgIHRocm93IG5ldyBUeXBlRXJyb3IoXCJDYW5ub3QgY2FsbCBhIGNsYXNzIGFzIGEgZnVuY3Rpb25cIik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBfY2xhc3NDYWxsQ2hlY2s7Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\\n//# sourceURL=webpack-internal:///3\\n');},function(module,exports){eval('function _defineProperties(target, props) {\\n for (var i = 0; i < props.length; i++) {\\n var descriptor = props[i];\\n descriptor.enumerable = descriptor.enumerable || false;\\n descriptor.configurable = true;\\n if (\"value\" in descriptor) descriptor.writable = true;\\n Object.defineProperty(target, descriptor.key, descriptor);\\n }\\n}\\n\\nfunction _createClass(Constructor, protoProps, staticProps) {\\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\\n if (staticProps) _defineProperties(Constructor, staticProps);\\n return Constructor;\\n}\\n\\nmodule.exports = _createClass;//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9oZWxwZXJzL2NyZWF0ZUNsYXNzLmpzPzViYzMiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2RlZmluZVByb3BlcnRpZXModGFyZ2V0LCBwcm9wcykge1xuICBmb3IgKHZhciBpID0gMDsgaSA8IHByb3BzLmxlbmd0aDsgaSsrKSB7XG4gICAgdmFyIGRlc2NyaXB0b3IgPSBwcm9wc1tpXTtcbiAgICBkZXNjcmlwdG9yLmVudW1lcmFibGUgPSBkZXNjcmlwdG9yLmVudW1lcmFibGUgfHwgZmFsc2U7XG4gICAgZGVzY3JpcHRvci5jb25maWd1cmFibGUgPSB0cnVlO1xuICAgIGlmIChcInZhbHVlXCIgaW4gZGVzY3JpcHRvcikgZGVzY3JpcHRvci53cml0YWJsZSA9IHRydWU7XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwgZGVzY3JpcHRvci5rZXksIGRlc2NyaXB0b3IpO1xuICB9XG59XG5cbmZ1bmN0aW9uIF9jcmVhdGVDbGFzcyhDb25zdHJ1Y3RvciwgcHJvdG9Qcm9wcywgc3RhdGljUHJvcHMpIHtcbiAgaWYgKHByb3RvUHJvcHMpIF9kZWZpbmVQcm9wZXJ0aWVzKENvbnN0cnVjdG9yLnByb3RvdHlwZSwgcHJvdG9Qcm9wcyk7XG4gIGlmIChzdGF0aWNQcm9wcykgX2RlZmluZVByb3BlcnRpZXMoQ29uc3RydWN0b3IsIHN0YXRpY1Byb3BzKTtcbiAgcmV0dXJuIENvbnN0cnVjdG9yO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IF9jcmVhdGVDbGFzczsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\\n//# sourceURL=webpack-internal:///4\\n');},function(module,exports){eval('function _typeof(obj) {\\n \"@babel/helpers - typeof\";\\n\\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\\n module.exports = _typeof = function _typeof(obj) {\\n return typeof obj;\\n };\\n } else {\\n module.exports = _typeof = function _typeof(obj) {\\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\\n };\\n }\\n\\n return _typeof(obj);\\n}\\n\\nmodule.exports = _typeof;//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9oZWxwZXJzL3R5cGVvZi5qcz83MDM3Il0sInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIF90eXBlb2Yob2JqKSB7XG4gIFwiQGJhYmVsL2hlbHBlcnMgLSB0eXBlb2ZcIjtcblxuICBpZiAodHlwZW9mIFN5bWJvbCA9PT0gXCJmdW5jdGlvblwiICYmIHR5cGVvZiBTeW1ib2wuaXRlcmF0b3IgPT09IFwic3ltYm9sXCIpIHtcbiAgICBtb2R1bGUuZXhwb3J0cyA9IF90eXBlb2YgPSBmdW5jdGlvbiBfdHlwZW9mKG9iaikge1xuICAgICAgcmV0dXJuIHR5cGVvZiBvYmo7XG4gICAgfTtcbiAgfSBlbHNlIHtcbiAgICBtb2R1bGUuZXhwb3J0cyA9IF90eXBlb2YgPSBmdW5jdGlvbiBfdHlwZW9mKG9iaikge1xuICAgICAgcmV0dXJuIG9iaiAmJiB0eXBlb2YgU3ltYm9sID09PSBcImZ1bmN0aW9uXCIgJiYgb2JqLmNvbnN0cnVjdG9yID09PSBTeW1ib2wgJiYgb2JqICE9PSBTeW1ib2wucHJvdG90eXBlID8gXCJzeW1ib2xcIiA6IHR5cGVvZiBvYmo7XG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiBfdHlwZW9mKG9iaik7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gX3R5cGVvZjsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\\n//# sourceURL=webpack-internal:///5\\n');},function(module,exports,__webpack_require__){eval(\"var rng = __webpack_require__(8);\\nvar bytesToUuid = __webpack_require__(9);\\n\\nfunction v4(options, buf, offset) {\\n var i = buf && offset || 0;\\n\\n if (typeof(options) == 'string') {\\n buf = options === 'binary' ? new Array(16) : null;\\n options = null;\\n }\\n options = options || {};\\n\\n var rnds = options.random || (options.rng || rng)();\\n\\n // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\\n\\n // Copy bytes to buffer, if provided\\n if (buf) {\\n for (var ii = 0; ii < 16; ++ii) {\\n buf[i + ii] = rnds[ii];\\n }\\n }\\n\\n return buf || bytesToUuid(rnds);\\n}\\n\\nmodule.exports = v4;\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy91dWlkL3Y0LmpzP2M2NGUiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIHJuZyA9IHJlcXVpcmUoJy4vbGliL3JuZycpO1xudmFyIGJ5dGVzVG9VdWlkID0gcmVxdWlyZSgnLi9saWIvYnl0ZXNUb1V1aWQnKTtcblxuZnVuY3Rpb24gdjQob3B0aW9ucywgYnVmLCBvZmZzZXQpIHtcbiAgdmFyIGkgPSBidWYgJiYgb2Zmc2V0IHx8IDA7XG5cbiAgaWYgKHR5cGVvZihvcHRpb25zKSA9PSAnc3RyaW5nJykge1xuICAgIGJ1ZiA9IG9wdGlvbnMgPT09ICdiaW5hcnknID8gbmV3IEFycmF5KDE2KSA6IG51bGw7XG4gICAgb3B0aW9ucyA9IG51bGw7XG4gIH1cbiAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG5cbiAgdmFyIHJuZHMgPSBvcHRpb25zLnJhbmRvbSB8fCAob3B0aW9ucy5ybmcgfHwgcm5nKSgpO1xuXG4gIC8vIFBlciA0LjQsIHNldCBiaXRzIGZvciB2ZXJzaW9uIGFuZCBgY2xvY2tfc2VxX2hpX2FuZF9yZXNlcnZlZGBcbiAgcm5kc1s2XSA9IChybmRzWzZdICYgMHgwZikgfCAweDQwO1xuICBybmRzWzhdID0gKHJuZHNbOF0gJiAweDNmKSB8IDB4ODA7XG5cbiAgLy8gQ29weSBieXRlcyB0byBidWZmZXIsIGlmIHByb3ZpZGVkXG4gIGlmIChidWYpIHtcbiAgICBmb3IgKHZhciBpaSA9IDA7IGlpIDwgMTY7ICsraWkpIHtcbiAgICAgIGJ1ZltpICsgaWldID0gcm5kc1tpaV07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGJ1ZiB8fCBieXRlc1RvVXVpZChybmRzKTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSB2NDtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0=\\n//# sourceURL=webpack-internal:///6\\n\");},function(module,exports,__webpack_require__){eval('/**\\n * Copyright (c) 2014-present, Facebook, Inc.\\n *\\n * This source code is licensed under the MIT license found in the\\n * LICENSE file in the root directory of this source tree.\\n */\\n\\nvar runtime = (function (exports) {\\n \"use strict\";\\n\\n var Op = Object.prototype;\\n var hasOwn = Op.hasOwnProperty;\\n var undefined; // More compressible than void 0.\\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\\n\\n function wrap(innerFn, outerFn, self, tryLocsList) {\\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\\n var generator = Object.create(protoGenerator.prototype);\\n var context = new Context(tryLocsList || []);\\n\\n // The ._invoke method unifies the implementations of the .next,\\n // .throw, and .return methods.\\n generator._invoke = makeInvokeMethod(innerFn, self, context);\\n\\n return generator;\\n }\\n exports.wrap = wrap;\\n\\n // Try/catch helper to minimize deoptimizations. Returns a completion\\n // record like context.tryEntries[i].completion. This interface could\\n // have been (and was previously) designed to take a closure to be\\n // invoked without arguments, but in all the cases we care about we\\n // already have an existing method we want to call, so there\\'s no need\\n // to create a new function object. We can even get away with assuming\\n // the method takes exactly one argument, since that happens to be true\\n // in every case, so we don\\'t have to touch the arguments object. The\\n // only additional allocation required is the completion record, which\\n // has a stable shape and so hopefully should be cheap to allocate.\\n function tryCatch(fn, obj, arg) {\\n try {\\n return { type: \"normal\", arg: fn.call(obj, arg) };\\n } catch (err) {\\n return { type: \"throw\", arg: err };\\n }\\n }\\n\\n var GenStateSuspendedStart = \"suspendedStart\";\\n var GenStateSuspendedYield = \"suspendedYield\";\\n var GenStateExecuting = \"executing\";\\n var GenStateCompleted = \"completed\";\\n\\n // Returning this object from the innerFn has the same effect as\\n // breaking out of the dispatch switch statement.\\n var ContinueSentinel = {};\\n\\n // Dummy constructor functions that we use as the .constructor and\\n // .constructor.prototype properties for functions that return Generator\\n // objects. For full spec compliance, you may wish to configure your\\n // minifier not to mangle the names of these two functions.\\n function Generator() {}\\n function GeneratorFunction() {}\\n function GeneratorFunctionPrototype() {}\\n\\n // This is a polyfill for %IteratorPrototype% for environments that\\n // don\\'t natively support it.\\n var IteratorPrototype = {};\\n IteratorPrototype[iteratorSymbol] = function () {\\n return this;\\n };\\n\\n var getProto = Object.getPrototypeOf;\\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\\n if (NativeIteratorPrototype &&\\n NativeIteratorPrototype !== Op &&\\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\\n // This environment has a native %IteratorPrototype%; use it instead\\n // of the polyfill.\\n IteratorPrototype = NativeIteratorPrototype;\\n }\\n\\n var Gp = GeneratorFunctionPrototype.prototype =\\n Generator.prototype = Object.create(IteratorPrototype);\\n GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\\n GeneratorFunctionPrototype.constructor = GeneratorFunction;\\n GeneratorFunctionPrototype[toStringTagSymbol] =\\n GeneratorFunction.displayName = \"GeneratorFunction\";\\n\\n // Helper for defining the .next, .throw, and .return methods of the\\n // Iterator interface in terms of a single ._invoke method.\\n function defineIteratorMethods(prototype) {\\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\\n prototype[method] = function(arg) {\\n return this._invoke(method, arg);\\n };\\n });\\n }\\n\\n exports.isGeneratorFunction = function(genFun) {\\n var ctor = typeof genFun === \"function\" && genFun.constructor;\\n return ctor\\n ? ctor === GeneratorFunction ||\\n // For the native GeneratorFunction constructor, the best we can\\n // do is to check its .name property.\\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\\n : false;\\n };\\n\\n exports.mark = function(genFun) {\\n if (Object.setPrototypeOf) {\\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\\n } else {\\n genFun.__proto__ = GeneratorFunctionPrototype;\\n if (!(toStringTagSymbol in genFun)) {\\n genFun[toStringTagSymbol] = \"GeneratorFunction\";\\n }\\n }\\n genFun.prototype = Object.create(Gp);\\n return genFun;\\n };\\n\\n // Within the body of any async function, `await x` is transformed to\\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\\n // meant to be awaited.\\n exports.awrap = function(arg) {\\n return { __await: arg };\\n };\\n\\n function AsyncIterator(generator) {\\n function invoke(method, arg, resolve, reject) {\\n var record = tryCatch(generator[method], generator, arg);\\n if (record.type === \"throw\") {\\n reject(record.arg);\\n } else {\\n var result = record.arg;\\n var value = result.value;\\n if (value &&\\n typeof value === \"object\" &&\\n hasOwn.call(value, \"__await\")) {\\n return Promise.resolve(value.__await).then(function(value) {\\n invoke(\"next\", value, resolve, reject);\\n }, function(err) {\\n invoke(\"throw\", err, resolve, reject);\\n });\\n }\\n\\n return Promise.resolve(value).then(function(unwrapped) {\\n // When a yielded Promise is resolved, its final value becomes\\n // the .value of the Promise<{value,done}> result for the\\n // current iteration.\\n result.value = unwrapped;\\n resolve(result);\\n }, function(error) {\\n // If a rejected Promise was yielded, throw the rejection back\\n // into the async generator function so it can be handled there.\\n return invoke(\"throw\", error, resolve, reject);\\n });\\n }\\n }\\n\\n var previousPromise;\\n\\n function enqueue(method, arg) {\\n function callInvokeWithMethodAndArg() {\\n return new Promise(function(resolve, reject) {\\n invoke(method, arg, resolve, reject);\\n });\\n }\\n\\n return previousPromise =\\n // If enqueue has been called before, then we want to wait until\\n // all previous Promises have been resolved before calling invoke,\\n // so that results are always delivered in the correct order. If\\n // enqueue has not been called before, then it is important to\\n // call invoke immediately, without waiting on a callback to fire,\\n // so that the async generator function has the opportunity to do\\n // any necessary setup in a predictable way. This predictability\\n // is why the Promise constructor synchronously invokes its\\n // executor callback, and why async functions synchronously\\n // execute code before the first await. Since we implement simple\\n // async functions in terms of async generators, it is especially\\n // important to get this right, even though it requires care.\\n previousPromise ? previousPromise.then(\\n callInvokeWithMethodAndArg,\\n // Avoid propagating failures to Promises returned by later\\n // invocations of the iterator.\\n callInvokeWithMethodAndArg\\n ) : callInvokeWithMethodAndArg();\\n }\\n\\n // Define the unified helper method that is used to implement .next,\\n // .throw, and .return (see defineIteratorMethods).\\n this._invoke = enqueue;\\n }\\n\\n defineIteratorMethods(AsyncIterator.prototype);\\n AsyncIterator.prototype[asyncIteratorSymbol] = function () {\\n return this;\\n };\\n exports.AsyncIterator = AsyncIterator;\\n\\n // Note that simple async functions are implemented on top of\\n // AsyncIterator objects; they just return a Promise for the value of\\n // the final result produced by the iterator.\\n exports.async = function(innerFn, outerFn, self, tryLocsList) {\\n var iter = new AsyncIterator(\\n wrap(innerFn, outerFn, self, tryLocsList)\\n );\\n\\n return exports.isGeneratorFunction(outerFn)\\n ? iter // If outerFn is a generator, return the full iterator.\\n : iter.next().then(function(result) {\\n return result.done ? result.value : iter.next();\\n });\\n };\\n\\n function makeInvokeMethod(innerFn, self, context) {\\n var state = GenStateSuspendedStart;\\n\\n return function invoke(method, arg) {\\n if (state === GenStateExecuting) {\\n throw new Error(\"Generator is already running\");\\n }\\n\\n if (state === GenStateCompleted) {\\n if (method === \"throw\") {\\n throw arg;\\n }\\n\\n // Be forgiving, per 25.3.3.3.3 of the spec:\\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\\n return doneResult();\\n }\\n\\n context.method = method;\\n context.arg = arg;\\n\\n while (true) {\\n var delegate = context.delegate;\\n if (delegate) {\\n var delegateResult = maybeInvokeDelegate(delegate, context);\\n if (delegateResult) {\\n if (delegateResult === ContinueSentinel) continue;\\n return delegateResult;\\n }\\n }\\n\\n if (context.method === \"next\") {\\n // Setting context._sent for legacy support of Babel\\'s\\n // function.sent implementation.\\n context.sent = context._sent = context.arg;\\n\\n } else if (context.method === \"throw\") {\\n if (state === GenStateSuspendedStart) {\\n state = GenStateCompleted;\\n throw context.arg;\\n }\\n\\n context.dispatchException(context.arg);\\n\\n } else if (context.method === \"return\") {\\n context.abrupt(\"return\", context.arg);\\n }\\n\\n state = GenStateExecuting;\\n\\n var record = tryCatch(innerFn, self, context);\\n if (record.type === \"normal\") {\\n // If an exception is thrown from innerFn, we leave state ===\\n // GenStateExecuting and loop back for another invocation.\\n state = context.done\\n ? GenStateCompleted\\n : GenStateSuspendedYield;\\n\\n if (record.arg === ContinueSentinel) {\\n continue;\\n }\\n\\n return {\\n value: record.arg,\\n done: context.done\\n };\\n\\n } else if (record.type === \"throw\") {\\n state = GenStateCompleted;\\n // Dispatch the exception by looping back around to the\\n // context.dispatchException(context.arg) call above.\\n context.method = \"throw\";\\n context.arg = record.arg;\\n }\\n }\\n };\\n }\\n\\n // Call delegate.iterator[context.method](context.arg) and handle the\\n // result, either by returning a { value, done } result from the\\n // delegate iterator, or by modifying context.method and context.arg,\\n // setting context.delegate to null, and returning the ContinueSentinel.\\n function maybeInvokeDelegate(delegate, context) {\\n var method = delegate.iterator[context.method];\\n if (method === undefined) {\\n // A .throw or .return when the delegate iterator has no .throw\\n // method always terminates the yield* loop.\\n context.delegate = null;\\n\\n if (context.method === \"throw\") {\\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\\n if (delegate.iterator[\"return\"]) {\\n // If the delegate iterator has a return method, give it a\\n // chance to clean up.\\n context.method = \"return\";\\n context.arg = undefined;\\n maybeInvokeDelegate(delegate, context);\\n\\n if (context.method === \"throw\") {\\n // If maybeInvokeDelegate(context) changed context.method from\\n // \"return\" to \"throw\", let that override the TypeError below.\\n return ContinueSentinel;\\n }\\n }\\n\\n context.method = \"throw\";\\n context.arg = new TypeError(\\n \"The iterator does not provide a \\'throw\\' method\");\\n }\\n\\n return ContinueSentinel;\\n }\\n\\n var record = tryCatch(method, delegate.iterator, context.arg);\\n\\n if (record.type === \"throw\") {\\n context.method = \"throw\";\\n context.arg = record.arg;\\n context.delegate = null;\\n return ContinueSentinel;\\n }\\n\\n var info = record.arg;\\n\\n if (! info) {\\n context.method = \"throw\";\\n context.arg = new TypeError(\"iterator result is not an object\");\\n context.delegate = null;\\n return ContinueSentinel;\\n }\\n\\n if (info.done) {\\n // Assign the result of the finished delegate to the temporary\\n // variable specified by delegate.resultName (see delegateYield).\\n context[delegate.resultName] = info.value;\\n\\n // Resume execution at the desired location (see delegateYield).\\n context.next = delegate.nextLoc;\\n\\n // If context.method was \"throw\" but the delegate handled the\\n // exception, let the outer generator proceed normally. If\\n // context.method was \"next\", forget context.arg since it has been\\n // \"consumed\" by the delegate iterator. If context.method was\\n // \"return\", allow the original .return call to continue in the\\n // outer generator.\\n if (context.method !== \"return\") {\\n context.method = \"next\";\\n context.arg = undefined;\\n }\\n\\n } else {\\n // Re-yield the result returned by the delegate method.\\n return info;\\n }\\n\\n // The delegate iterator is finished, so forget it and continue with\\n // the outer generator.\\n context.delegate = null;\\n return ContinueSentinel;\\n }\\n\\n // Define Generator.prototype.{next,throw,return} in terms of the\\n // unified ._invoke helper method.\\n defineIteratorMethods(Gp);\\n\\n Gp[toStringTagSymbol] = \"Generator\";\\n\\n // A Generator should always return itself as the iterator object when the\\n // @@iterator function is called on it. Some browsers\\' implementations of the\\n // iterator prototype chain incorrectly implement this, causing the Generator\\n // object to not be returned from this call. This ensures that doesn\\'t happen.\\n // See https://github.com/facebook/regenerator/issues/274 for more details.\\n Gp[iteratorSymbol] = function() {\\n return this;\\n };\\n\\n Gp.toString = function() {\\n return \"[object Generator]\";\\n };\\n\\n function pushTryEntry(locs) {\\n var entry = { tryLoc: locs[0] };\\n\\n if (1 in locs) {\\n entry.catchLoc = locs[1];\\n }\\n\\n if (2 in locs) {\\n entry.finallyLoc = locs[2];\\n entry.afterLoc = locs[3];\\n }\\n\\n this.tryEntries.push(entry);\\n }\\n\\n function resetTryEntry(entry) {\\n var record = entry.completion || {};\\n record.type = \"normal\";\\n delete record.arg;\\n entry.completion = record;\\n }\\n\\n function Context(tryLocsList) {\\n // The root entry object (effectively a try statement without a catch\\n // or a finally block) gives us a place to store values thrown from\\n // locations where there is no enclosing try statement.\\n this.tryEntries = [{ tryLoc: \"root\" }];\\n tryLocsList.forEach(pushTryEntry, this);\\n this.reset(true);\\n }\\n\\n exports.keys = function(object) {\\n var keys = [];\\n for (var key in object) {\\n keys.push(key);\\n }\\n keys.reverse();\\n\\n // Rather than returning an object with a next method, we keep\\n // things simple and return the next function itself.\\n return function next() {\\n while (keys.length) {\\n var key = keys.pop();\\n if (key in object) {\\n next.value = key;\\n next.done = false;\\n return next;\\n }\\n }\\n\\n // To avoid creating an additional object, we just hang the .value\\n // and .done properties off the next function object itself. This\\n // also ensures that the minifier will not anonymize the function.\\n next.done = true;\\n return next;\\n };\\n };\\n\\n function values(iterable) {\\n if (iterable) {\\n var iteratorMethod = iterable[iteratorSymbol];\\n if (iteratorMethod) {\\n return iteratorMethod.call(iterable);\\n }\\n\\n if (typeof iterable.next === \"function\") {\\n return iterable;\\n }\\n\\n if (!isNaN(iterable.length)) {\\n var i = -1, next = function next() {\\n while (++i < iterable.length) {\\n if (hasOwn.call(iterable, i)) {\\n next.value = iterable[i];\\n next.done = false;\\n return next;\\n }\\n }\\n\\n next.value = undefined;\\n next.done = true;\\n\\n return next;\\n };\\n\\n return next.next = next;\\n }\\n }\\n\\n // Return an iterator with no values.\\n return { next: doneResult };\\n }\\n exports.values = values;\\n\\n function doneResult() {\\n return { value: undefined, done: true };\\n }\\n\\n Context.prototype = {\\n constructor: Context,\\n\\n reset: function(skipTempReset) {\\n this.prev = 0;\\n this.next = 0;\\n // Resetting context._sent for legacy support of Babel\\'s\\n // function.sent implementation.\\n this.sent = this._sent = undefined;\\n this.done = false;\\n this.delegate = null;\\n\\n this.method = \"next\";\\n this.arg = undefined;\\n\\n this.tryEntries.forEach(resetTryEntry);\\n\\n if (!skipTempReset) {\\n for (var name in this) {\\n // Not sure about the optimal order of these conditions:\\n if (name.charAt(0) === \"t\" &&\\n hasOwn.call(this, name) &&\\n !isNaN(+name.slice(1))) {\\n this[name] = undefined;\\n }\\n }\\n }\\n },\\n\\n stop: function() {\\n this.done = true;\\n\\n var rootEntry = this.tryEntries[0];\\n var rootRecord = rootEntry.completion;\\n if (rootRecord.type === \"throw\") {\\n throw rootRecord.arg;\\n }\\n\\n return this.rval;\\n },\\n\\n dispatchException: function(exception) {\\n if (this.done) {\\n throw exception;\\n }\\n\\n var context = this;\\n function handle(loc, caught) {\\n record.type = \"throw\";\\n record.arg = exception;\\n context.next = loc;\\n\\n if (caught) {\\n // If the dispatched exception was caught by a catch block,\\n // then let that catch block handle the exception normally.\\n context.method = \"next\";\\n context.arg = undefined;\\n }\\n\\n return !! caught;\\n }\\n\\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\\n var entry = this.tryEntries[i];\\n var record = entry.completion;\\n\\n if (entry.tryLoc === \"root\") {\\n // Exception thrown outside of any try block that could handle\\n // it, so set the completion value of the entire function to\\n // throw the exception.\\n return handle(\"end\");\\n }\\n\\n if (entry.tryLoc <= this.prev) {\\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\\n\\n if (hasCatch && hasFinally) {\\n if (this.prev < entry.catchLoc) {\\n return handle(entry.catchLoc, true);\\n } else if (this.prev < entry.finallyLoc) {\\n return handle(entry.finallyLoc);\\n }\\n\\n } else if (hasCatch) {\\n if (this.prev < entry.catchLoc) {\\n return handle(entry.catchLoc, true);\\n }\\n\\n } else if (hasFinally) {\\n if (this.prev < entry.finallyLoc) {\\n return handle(entry.finallyLoc);\\n }\\n\\n } else {\\n throw new Error(\"try statement without catch or finally\");\\n }\\n }\\n }\\n },\\n\\n abrupt: function(type, arg) {\\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\\n var entry = this.tryEntries[i];\\n if (entry.tryLoc <= this.prev &&\\n hasOwn.call(entry, \"finallyLoc\") &&\\n this.prev < entry.finallyLoc) {\\n var finallyEntry = entry;\\n break;\\n }\\n }\\n\\n if (finallyEntry &&\\n (type === \"break\" ||\\n type === \"continue\") &&\\n finallyEntry.tryLoc <= arg &&\\n arg <= finallyEntry.finallyLoc) {\\n // Ignore the finally entry if control is not jumping to a\\n // location outside the try/catch block.\\n finallyEntry = null;\\n }\\n\\n var record = finallyEntry ? finallyEntry.completion : {};\\n record.type = type;\\n record.arg = arg;\\n\\n if (finallyEntry) {\\n this.method = \"next\";\\n this.next = finallyEntry.finallyLoc;\\n return ContinueSentinel;\\n }\\n\\n return this.complete(record);\\n },\\n\\n complete: function(record, afterLoc) {\\n if (record.type === \"throw\") {\\n throw record.arg;\\n }\\n\\n if (record.type === \"break\" ||\\n record.type === \"continue\") {\\n this.next = record.arg;\\n } else if (record.type === \"return\") {\\n this.rval = this.arg = record.arg;\\n this.method = \"return\";\\n this.next = \"end\";\\n } else if (record.type === \"normal\" && afterLoc) {\\n this.next = afterLoc;\\n }\\n\\n return ContinueSentinel;\\n },\\n\\n finish: function(finallyLoc) {\\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\\n var entry = this.tryEntries[i];\\n if (entry.finallyLoc === finallyLoc) {\\n this.complete(entry.completion, entry.afterLoc);\\n resetTryEntry(entry);\\n return ContinueSentinel;\\n }\\n }\\n },\\n\\n \"catch\": function(tryLoc) {\\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\\n var entry = this.tryEntries[i];\\n if (entry.tryLoc === tryLoc) {\\n var record = entry.completion;\\n if (record.type === \"throw\") {\\n var thrown = record.arg;\\n resetTryEntry(entry);\\n }\\n return thrown;\\n }\\n }\\n\\n // The context.catch method must only be called with a location\\n // argument that corresponds to a known catch block.\\n throw new Error(\"illegal catch attempt\");\\n },\\n\\n delegateYield: function(iterable, resultName, nextLoc) {\\n this.delegate = {\\n iterator: values(iterable),\\n resultName: resultName,\\n nextLoc: nextLoc\\n };\\n\\n if (this.method === \"next\") {\\n // Deliberately forget the last sent value so that we don\\'t\\n // accidentally pass it on to the delegate.\\n this.arg = undefined;\\n }\\n\\n return ContinueSentinel;\\n }\\n };\\n\\n // Regardless of whether this script is executing as a CommonJS module\\n // or not, return the runtime object so that we can declare the variable\\n // regeneratorRuntime in the outer scope, which allows this module to be\\n // injected easily by `bin/regenerator --include-runtime script.js`.\\n return exports;\\n\\n}(\\n // If this script is executing as a CommonJS module, use module.exports\\n // as the regeneratorRuntime namespace. Otherwise create a new empty\\n // object. Either way, the resulting object will be used to initialize\\n // the regeneratorRuntime variable at the top of this file.\\n true ? module.exports : undefined\\n));\\n\\ntry {\\n regeneratorRuntime = runtime;\\n} catch (accidentalStrictMode) {\\n // This module should not be running in strict mode, so the above\\n // assignment should always work unless something is misconfigured. Just\\n // in case runtime.js accidentally runs in strict mode, we can escape\\n // strict mode using a global Function call. This could conceivably fail\\n // if a Content Security Policy forbids using Function, but in that case\\n // the proper solution is to fix the accidental strict mode problem. If\\n // you\\'ve misconfigured your bundler to force strict mode and applied a\\n // CSP to forbid Function, and you\\'re not willing to fix either of those\\n // problems, please detail your unique predicament in a GitHub issue.\\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\\n}\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"7.js","sources":["webpack://web-midi-player/./node_modules/regenerator-runtime/runtime.js?96cf"],"sourcesContent":["/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n  \"use strict\";\n\n  var Op = Object.prototype;\n  var hasOwn = Op.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n  var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n  var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n  var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n    var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n    var generator = Object.create(protoGenerator.prototype);\n    var context = new Context(tryLocsList || []);\n\n    // The ._invoke method unifies the implementations of the .next,\n    // .throw, and .return methods.\n    generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n    return generator;\n  }\n  exports.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function Generator() {}\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  // This is a polyfill for %IteratorPrototype% for environments that\n  // don't natively support it.\n  var IteratorPrototype = {};\n  IteratorPrototype[iteratorSymbol] = function () {\n    return this;\n  };\n\n  var getProto = Object.getPrototypeOf;\n  var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n  if (NativeIteratorPrototype &&\n      NativeIteratorPrototype !== Op &&\n      hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n    // This environment has a native %IteratorPrototype%; use it instead\n    // of the polyfill.\n    IteratorPrototype = NativeIteratorPrototype;\n  }\n\n  var Gp = GeneratorFunctionPrototype.prototype =\n    Generator.prototype = Object.create(IteratorPrototype);\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunctionPrototype[toStringTagSymbol] =\n    GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function(method) {\n      prototype[method] = function(arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  exports.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  exports.mark = function(genFun) {\n    if (Object.setPrototypeOf) {\n      Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n    } else {\n      genFun.__proto__ = GeneratorFunctionPrototype;\n      if (!(toStringTagSymbol in genFun)) {\n        genFun[toStringTagSymbol] = \"GeneratorFunction\";\n      }\n    }\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n  // meant to be awaited.\n  exports.awrap = function(arg) {\n    return { __await: arg };\n  };\n\n  function AsyncIterator(generator) {\n    function invoke(method, arg, resolve, reject) {\n      var record = tryCatch(generator[method], generator, arg);\n      if (record.type === \"throw\") {\n        reject(record.arg);\n      } else {\n        var result = record.arg;\n        var value = result.value;\n        if (value &&\n            typeof value === \"object\" &&\n            hasOwn.call(value, \"__await\")) {\n          return Promise.resolve(value.__await).then(function(value) {\n            invoke(\"next\", value, resolve, reject);\n          }, function(err) {\n            invoke(\"throw\", err, resolve, reject);\n          });\n        }\n\n        return Promise.resolve(value).then(function(unwrapped) {\n          // When a yielded Promise is resolved, its final value becomes\n          // the .value of the Promise<{value,done}> result for the\n          // current iteration.\n          result.value = unwrapped;\n          resolve(result);\n        }, function(error) {\n          // If a rejected Promise was yielded, throw the rejection back\n          // into the async generator function so it can be handled there.\n          return invoke(\"throw\", error, resolve, reject);\n        });\n      }\n    }\n\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      function callInvokeWithMethodAndArg() {\n        return new Promise(function(resolve, reject) {\n          invoke(method, arg, resolve, reject);\n        });\n      }\n\n      return previousPromise =\n        // If enqueue has been called before, then we want to wait until\n        // all previous Promises have been resolved before calling invoke,\n        // so that results are always delivered in the correct order. If\n        // enqueue has not been called before, then it is important to\n        // call invoke immediately, without waiting on a callback to fire,\n        // so that the async generator function has the opportunity to do\n        // any necessary setup in a predictable way. This predictability\n        // is why the Promise constructor synchronously invokes its\n        // executor callback, and why async functions synchronously\n        // execute code before the first await. Since we implement simple\n        // async functions in terms of async generators, it is especially\n        // important to get this right, even though it requires care.\n        previousPromise ? previousPromise.then(\n          callInvokeWithMethodAndArg,\n          // Avoid propagating failures to Promises returned by later\n          // invocations of the iterator.\n          callInvokeWithMethodAndArg\n        ) : callInvokeWithMethodAndArg();\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n  AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n    return this;\n  };\n  exports.AsyncIterator = AsyncIterator;\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  exports.async = function(innerFn, outerFn, self, tryLocsList) {\n    var iter = new AsyncIterator(\n      wrap(innerFn, outerFn, self, tryLocsList)\n    );\n\n    return exports.isGeneratorFunction(outerFn)\n      ? iter // If outerFn is a generator, return the full iterator.\n      : iter.next().then(function(result) {\n          return result.done ? result.value : iter.next();\n        });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      context.method = method;\n      context.arg = arg;\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var delegateResult = maybeInvokeDelegate(delegate, context);\n          if (delegateResult) {\n            if (delegateResult === ContinueSentinel) continue;\n            return delegateResult;\n          }\n        }\n\n        if (context.method === \"next\") {\n          // Setting context._sent for legacy support of Babel's\n          // function.sent implementation.\n          context.sent = context._sent = context.arg;\n\n        } else if (context.method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw context.arg;\n          }\n\n          context.dispatchException(context.arg);\n\n        } else if (context.method === \"return\") {\n          context.abrupt(\"return\", context.arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          if (record.arg === ContinueSentinel) {\n            continue;\n          }\n\n          return {\n            value: record.arg,\n            done: context.done\n          };\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(context.arg) call above.\n          context.method = \"throw\";\n          context.arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Call delegate.iterator[context.method](context.arg) and handle the\n  // result, either by returning a { value, done } result from the\n  // delegate iterator, or by modifying context.method and context.arg,\n  // setting context.delegate to null, and returning the ContinueSentinel.\n  function maybeInvokeDelegate(delegate, context) {\n    var method = delegate.iterator[context.method];\n    if (method === undefined) {\n      // A .throw or .return when the delegate iterator has no .throw\n      // method always terminates the yield* loop.\n      context.delegate = null;\n\n      if (context.method === \"throw\") {\n        // Note: [\"return\"] must be used for ES3 parsing compatibility.\n        if (delegate.iterator[\"return\"]) {\n          // If the delegate iterator has a return method, give it a\n          // chance to clean up.\n          context.method = \"return\";\n          context.arg = undefined;\n          maybeInvokeDelegate(delegate, context);\n\n          if (context.method === \"throw\") {\n            // If maybeInvokeDelegate(context) changed context.method from\n            // \"return\" to \"throw\", let that override the TypeError below.\n            return ContinueSentinel;\n          }\n        }\n\n        context.method = \"throw\";\n        context.arg = new TypeError(\n          \"The iterator does not provide a 'throw' method\");\n      }\n\n      return ContinueSentinel;\n    }\n\n    var record = tryCatch(method, delegate.iterator, context.arg);\n\n    if (record.type === \"throw\") {\n      context.method = \"throw\";\n      context.arg = record.arg;\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    var info = record.arg;\n\n    if (! info) {\n      context.method = \"throw\";\n      context.arg = new TypeError(\"iterator result is not an object\");\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    if (info.done) {\n      // Assign the result of the finished delegate to the temporary\n      // variable specified by delegate.resultName (see delegateYield).\n      context[delegate.resultName] = info.value;\n\n      // Resume execution at the desired location (see delegateYield).\n      context.next = delegate.nextLoc;\n\n      // If context.method was \"throw\" but the delegate handled the\n      // exception, let the outer generator proceed normally. If\n      // context.method was \"next\", forget context.arg since it has been\n      // \"consumed\" by the delegate iterator. If context.method was\n      // \"return\", allow the original .return call to continue in the\n      // outer generator.\n      if (context.method !== \"return\") {\n        context.method = \"next\";\n        context.arg = undefined;\n      }\n\n    } else {\n      // Re-yield the result returned by the delegate method.\n      return info;\n    }\n\n    // The delegate iterator is finished, so forget it and continue with\n    // the outer generator.\n    context.delegate = null;\n    return ContinueSentinel;\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\n\n  Gp[toStringTagSymbol] = \"Generator\";\n\n  // A Generator should always return itself as the iterator object when the\n  // @@iterator function is called on it. Some browsers' implementations of the\n  // iterator prototype chain incorrectly implement this, causing the Generator\n  // object to not be returned from this call. This ensures that doesn't happen.\n  // See https://github.com/facebook/regenerator/issues/274 for more details.\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset(true);\n  }\n\n  exports.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  exports.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function(skipTempReset) {\n      this.prev = 0;\n      this.next = 0;\n      // Resetting context._sent for legacy support of Babel's\n      // function.sent implementation.\n      this.sent = this._sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.method = \"next\";\n      this.arg = undefined;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" &&\n              hasOwn.call(this, name) &&\n              !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n\n        if (caught) {\n          // If the dispatched exception was caught by a catch block,\n          // then let that catch block handle the exception normally.\n          context.method = \"next\";\n          context.arg = undefined;\n        }\n\n        return !! caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg <= finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.method = \"next\";\n        this.next = finallyEntry.finallyLoc;\n        return ContinueSentinel;\n      }\n\n      return this.complete(record);\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = this.arg = record.arg;\n        this.method = \"return\";\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      if (this.method === \"next\") {\n        // Deliberately forget the last sent value so that we don't\n        // accidentally pass it on to the delegate.\n        this.arg = undefined;\n      }\n\n      return ContinueSentinel;\n    }\n  };\n\n  // Regardless of whether this script is executing as a CommonJS module\n  // or not, return the runtime object so that we can declare the variable\n  // regeneratorRuntime in the outer scope, which allows this module to be\n  // injected easily by `bin/regenerator --include-runtime script.js`.\n  return exports;\n\n}(\n  // If this script is executing as a CommonJS module, use module.exports\n  // as the regeneratorRuntime namespace. Otherwise create a new empty\n  // object. Either way, the resulting object will be used to initialize\n  // the regeneratorRuntime variable at the top of this file.\n  typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n  regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n  // This module should not be running in strict mode, so the above\n  // assignment should always work unless something is misconfigured. Just\n  // in case runtime.js accidentally runs in strict mode, we can escape\n  // strict mode using a global Function call. This could conceivably fail\n  // if a Content Security Policy forbids using Function, but in that case\n  // the proper solution is to fix the accidental strict mode problem. If\n  // you've misconfigured your bundler to force strict mode and applied a\n  // CSP to forbid Function, and you're not willing to fix either of those\n  // problems, please detail your unique predicament in a GitHub issue.\n  Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;","sourceRoot":""}\\n//# sourceURL=webpack-internal:///7\\n');},function(module,exports){eval(\"// Unique ID creation requires a high quality random # generator. In the\\n// browser this is a little complicated due to unknown quality of Math.random()\\n// and inconsistent support for the `crypto` API. We do the best we can via\\n// feature-detection\\n\\n// getRandomValues needs to be invoked in a context where \\\"this\\\" is a Crypto\\n// implementation. Also, find the complete implementation of crypto on IE11.\\nvar getRandomValues = (typeof(crypto) != 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto)) ||\\n (typeof(msCrypto) != 'undefined' && typeof window.msCrypto.getRandomValues == 'function' && msCrypto.getRandomValues.bind(msCrypto));\\n\\nif (getRandomValues) {\\n // WHATWG crypto RNG - http://wiki.whatwg.org/wiki/Crypto\\n var rnds8 = new Uint8Array(16); // eslint-disable-line no-undef\\n\\n module.exports = function whatwgRNG() {\\n getRandomValues(rnds8);\\n return rnds8;\\n };\\n} else {\\n // Math.random()-based (RNG)\\n //\\n // If all else fails, use Math.random(). It's fast, but is of unspecified\\n // quality.\\n var rnds = new Array(16);\\n\\n module.exports = function mathRNG() {\\n for (var i = 0, r; i < 16; i++) {\\n if ((i & 0x03) === 0) r = Math.random() * 0x100000000;\\n rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;\\n }\\n\\n return rnds;\\n };\\n}\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy91dWlkL2xpYi9ybmctYnJvd3Nlci5qcz9lMWY0Il0sInNvdXJjZXNDb250ZW50IjpbIi8vIFVuaXF1ZSBJRCBjcmVhdGlvbiByZXF1aXJlcyBhIGhpZ2ggcXVhbGl0eSByYW5kb20gIyBnZW5lcmF0b3IuICBJbiB0aGVcbi8vIGJyb3dzZXIgdGhpcyBpcyBhIGxpdHRsZSBjb21wbGljYXRlZCBkdWUgdG8gdW5rbm93biBxdWFsaXR5IG9mIE1hdGgucmFuZG9tKClcbi8vIGFuZCBpbmNvbnNpc3RlbnQgc3VwcG9ydCBmb3IgdGhlIGBjcnlwdG9gIEFQSS4gIFdlIGRvIHRoZSBiZXN0IHdlIGNhbiB2aWFcbi8vIGZlYXR1cmUtZGV0ZWN0aW9uXG5cbi8vIGdldFJhbmRvbVZhbHVlcyBuZWVkcyB0byBiZSBpbnZva2VkIGluIGEgY29udGV4dCB3aGVyZSBcInRoaXNcIiBpcyBhIENyeXB0b1xuLy8gaW1wbGVtZW50YXRpb24uIEFsc28sIGZpbmQgdGhlIGNvbXBsZXRlIGltcGxlbWVudGF0aW9uIG9mIGNyeXB0byBvbiBJRTExLlxudmFyIGdldFJhbmRvbVZhbHVlcyA9ICh0eXBlb2YoY3J5cHRvKSAhPSAndW5kZWZpbmVkJyAmJiBjcnlwdG8uZ2V0UmFuZG9tVmFsdWVzICYmIGNyeXB0by5nZXRSYW5kb21WYWx1ZXMuYmluZChjcnlwdG8pKSB8fFxuICAgICAgICAgICAgICAgICAgICAgICh0eXBlb2YobXNDcnlwdG8pICE9ICd1bmRlZmluZWQnICYmIHR5cGVvZiB3aW5kb3cubXNDcnlwdG8uZ2V0UmFuZG9tVmFsdWVzID09ICdmdW5jdGlvbicgJiYgbXNDcnlwdG8uZ2V0UmFuZG9tVmFsdWVzLmJpbmQobXNDcnlwdG8pKTtcblxuaWYgKGdldFJhbmRvbVZhbHVlcykge1xuICAvLyBXSEFUV0cgY3J5cHRvIFJORyAtIGh0dHA6Ly93aWtpLndoYXR3Zy5vcmcvd2lraS9DcnlwdG9cbiAgdmFyIHJuZHM4ID0gbmV3IFVpbnQ4QXJyYXkoMTYpOyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLXVuZGVmXG5cbiAgbW9kdWxlLmV4cG9ydHMgPSBmdW5jdGlvbiB3aGF0d2dSTkcoKSB7XG4gICAgZ2V0UmFuZG9tVmFsdWVzKHJuZHM4KTtcbiAgICByZXR1cm4gcm5kczg7XG4gIH07XG59IGVsc2Uge1xuICAvLyBNYXRoLnJhbmRvbSgpLWJhc2VkIChSTkcpXG4gIC8vXG4gIC8vIElmIGFsbCBlbHNlIGZhaWxzLCB1c2UgTWF0aC5yYW5kb20oKS4gIEl0J3MgZmFzdCwgYnV0IGlzIG9mIHVuc3BlY2lmaWVkXG4gIC8vIHF1YWxpdHkuXG4gIHZhciBybmRzID0gbmV3IEFycmF5KDE2KTtcblxuICBtb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIG1hdGhSTkcoKSB7XG4gICAgZm9yICh2YXIgaSA9IDAsIHI7IGkgPCAxNjsgaSsrKSB7XG4gICAgICBpZiAoKGkgJiAweDAzKSA9PT0gMCkgciA9IE1hdGgucmFuZG9tKCkgKiAweDEwMDAwMDAwMDtcbiAgICAgIHJuZHNbaV0gPSByID4+PiAoKGkgJiAweDAzKSA8PCAzKSAmIDB4ZmY7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJuZHM7XG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ==\\n//# sourceURL=webpack-internal:///8\\n\");},function(module,exports){eval(\"/**\\n * Convert array of 16 byte values to UUID string format of the form:\\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\\n */\\nvar byteToHex = [];\\nfor (var i = 0; i < 256; ++i) {\\n byteToHex[i] = (i + 0x100).toString(16).substr(1);\\n}\\n\\nfunction bytesToUuid(buf, offset) {\\n var i = offset || 0;\\n var bth = byteToHex;\\n // join used to fix memory issue caused by concatenation: https://bugs.chromium.org/p/v8/issues/detail?id=3175#c4\\n return ([\\n bth[buf[i++]], bth[buf[i++]],\\n bth[buf[i++]], bth[buf[i++]], '-',\\n bth[buf[i++]], bth[buf[i++]], '-',\\n bth[buf[i++]], bth[buf[i++]], '-',\\n bth[buf[i++]], bth[buf[i++]], '-',\\n bth[buf[i++]], bth[buf[i++]],\\n bth[buf[i++]], bth[buf[i++]],\\n bth[buf[i++]], bth[buf[i++]]\\n ]).join('');\\n}\\n\\nmodule.exports = bytesToUuid;\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL3dlYi1taWRpLXBsYXllci8uL25vZGVfbW9kdWxlcy91dWlkL2xpYi9ieXRlc1RvVXVpZC5qcz8yMzY2Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29udmVydCBhcnJheSBvZiAxNiBieXRlIHZhbHVlcyB0byBVVUlEIHN0cmluZyBmb3JtYXQgb2YgdGhlIGZvcm06XG4gKiBYWFhYWFhYWC1YWFhYLVhYWFgtWFhYWC1YWFhYWFhYWFhYWFhcbiAqL1xudmFyIGJ5dGVUb0hleCA9IFtdO1xuZm9yICh2YXIgaSA9IDA7IGkgPCAyNTY7ICsraSkge1xuICBieXRlVG9IZXhbaV0gPSAoaSArIDB4MTAwKS50b1N0cmluZygxNikuc3Vic3RyKDEpO1xufVxuXG5mdW5jdGlvbiBieXRlc1RvVXVpZChidWYsIG9mZnNldCkge1xuICB2YXIgaSA9IG9mZnNldCB8fCAwO1xuICB2YXIgYnRoID0gYnl0ZVRvSGV4O1xuICAvLyBqb2luIHVzZWQgdG8gZml4IG1lbW9yeSBpc3N1ZSBjYXVzZWQgYnkgY29uY2F0ZW5hdGlvbjogaHR0cHM6Ly9idWdzLmNocm9taXVtLm9yZy9wL3Y4L2lzc3Vlcy9kZXRhaWw/aWQ9MzE3NSNjNFxuICByZXR1cm4gKFtcbiAgICBidGhbYnVmW2krK11dLCBidGhbYnVmW2krK11dLFxuICAgIGJ0aFtidWZbaSsrXV0sIGJ0aFtidWZbaSsrXV0sICctJyxcbiAgICBidGhbYnVmW2krK11dLCBidGhbYnVmW2krK11dLCAnLScsXG4gICAgYnRoW2J1ZltpKytdXSwgYnRoW2J1ZltpKytdXSwgJy0nLFxuICAgIGJ0aFtidWZbaSsrXV0sIGJ0aFtidWZbaSsrXV0sICctJyxcbiAgICBidGhbYnVmW2krK11dLCBidGhbYnVmW2krK11dLFxuICAgIGJ0aFtidWZbaSsrXV0sIGJ0aFtidWZbaSsrXV0sXG4gICAgYnRoW2J1ZltpKytdXSwgYnRoW2J1ZltpKytdXVxuICBdKS5qb2luKCcnKTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBieXRlc1RvVXVpZDtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0=\\n//# sourceURL=webpack-internal:///9\\n\");},function(module,exports,__webpack_require__){\"use strict\";eval(\"\\n\\nmodule.exports = function() {\\n throw new Error(\\n 'ws does not work in the browser. Browser clients must use the native ' +\\n 'WebSocket object'\\n );\\n};\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTAuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly93ZWItbWlkaS1wbGF5ZXIvLi9ub2RlX21vZHVsZXMvd3MvYnJvd3Nlci5qcz83ZjczIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxubW9kdWxlLmV4cG9ydHMgPSBmdW5jdGlvbigpIHtcbiAgdGhyb3cgbmV3IEVycm9yKFxuICAgICd3cyBkb2VzIG5vdCB3b3JrIGluIHRoZSBicm93c2VyLiBCcm93c2VyIGNsaWVudHMgbXVzdCB1c2UgdGhlIG5hdGl2ZSAnICtcbiAgICAgICdXZWJTb2NrZXQgb2JqZWN0J1xuICApO1xufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTsiLCJzb3VyY2VSb290IjoiIn0=\\n//# sourceURL=webpack-internal:///10\\n\");},function(module,__webpack_exports__,__webpack_require__){\"use strict\";eval(\"__webpack_require__.r(__webpack_exports__);\\n\\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/regenerator/index.js\\nvar regenerator = __webpack_require__(1);\\nvar regenerator_default = /*#__PURE__*/__webpack_require__.n(regenerator);\\n\\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/asyncToGenerator.js\\nvar asyncToGenerator = __webpack_require__(2);\\nvar asyncToGenerator_default = /*#__PURE__*/__webpack_require__.n(asyncToGenerator);\\n\\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/classCallCheck.js\\nvar classCallCheck = __webpack_require__(3);\\nvar classCallCheck_default = /*#__PURE__*/__webpack_require__.n(classCallCheck);\\n\\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/createClass.js\\nvar createClass = __webpack_require__(4);\\nvar createClass_default = /*#__PURE__*/__webpack_require__.n(createClass);\\n\\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/defineProperty.js\\nvar defineProperty = __webpack_require__(0);\\nvar defineProperty_default = /*#__PURE__*/__webpack_require__.n(defineProperty);\\n\\n// EXTERNAL MODULE: ./node_modules/uuid/v4.js\\nvar v4 = __webpack_require__(6);\\nvar v4_default = /*#__PURE__*/__webpack_require__.n(v4);\\n\\n// CONCATENATED MODULE: ./src/constants.js\\nvar MAX_I16 = Math.pow(2, 15);\\nvar MIDI_AUDIO_BUFFER_SIZE = 8192;\\nvar MIDI_AUDIO_S16LSB = 0x8010;\\nvar MIDI_DEFAULT_PATCH_URL = 'https://cdn.jsdelivr.net/npm/midi-instrument-patches@latest/';\\nvar MIDI_PLAYER_MESSAGE_PREFIX = 'Midi player:';\\nvar LIBTIMIDITY_PATCH_DIRECTORY = 'pat';\\nvar LIBTIMIDITY_PATCH_DRUM_DIRECTORY = 'MT32Drums';\\nvar LIBTIMIDITY_CONFIG_FILE = 'timidity.cfg';\\nvar LIBTIMIDITY_ERROR_CODES = {\\n EPERM: 1,\\n ENOENT: 2,\\n ESRCH: 3,\\n EINTR: 4,\\n EIO: 5,\\n ENXIO: 6,\\n E2BIG: 7,\\n ENOEXEC: 8,\\n EBADF: 9,\\n ECHILD: 10,\\n EAGAIN: 11,\\n EWOULDBLOCK: 11,\\n ENOMEM: 12,\\n EACCES: 13,\\n EFAULT: 14,\\n ENOTBLK: 15,\\n EBUSY: 16,\\n EEXIST: 17,\\n EXDEV: 18,\\n ENODEV: 19,\\n ENOTDIR: 20,\\n EISDIR: 21,\\n EINVAL: 22,\\n ENFILE: 23,\\n EMFILE: 24,\\n ENOTTY: 25,\\n ETXTBSY: 26,\\n EFBIG: 27,\\n ENOSPC: 28,\\n ESPIPE: 29,\\n EROFS: 30,\\n EMLINK: 31,\\n EPIPE: 32,\\n EDOM: 33,\\n ERANGE: 34,\\n ENOMSG: 42,\\n EIDRM: 43,\\n ECHRNG: 44,\\n EL2NSYNC: 45,\\n EL3HLT: 46,\\n EL3RST: 47,\\n ELNRNG: 48,\\n EUNATCH: 49,\\n ENOCSI: 50,\\n EL2HLT: 51,\\n EDEADLK: 35,\\n ENOLCK: 37,\\n EBADE: 52,\\n EBADR: 53,\\n EXFULL: 54,\\n ENOANO: 55,\\n EBADRQC: 56,\\n EBADSLT: 57,\\n EDEADLOCK: 35,\\n EBFONT: 59,\\n ENOSTR: 60,\\n ENODATA: 61,\\n ETIME: 62,\\n ENOSR: 63,\\n ENONET: 64,\\n ENOPKG: 65,\\n EREMOTE: 66,\\n ENOLINK: 67,\\n EADV: 68,\\n ESRMNT: 69,\\n ECOMM: 70,\\n EPROTO: 71,\\n EMULTIHOP: 72,\\n EDOTDOT: 73,\\n EBADMSG: 74,\\n ENOTUNIQ: 76,\\n EBADFD: 77,\\n EREMCHG: 78,\\n ELIBACC: 79,\\n ELIBBAD: 80,\\n ELIBSCN: 81,\\n ELIBMAX: 82,\\n ELIBEXEC: 83,\\n ENOSYS: 38,\\n ENOTEMPTY: 39,\\n ENAMETOOLONG: 36,\\n ELOOP: 40,\\n EOPNOTSUPP: 95,\\n EPFNOSUPPORT: 96,\\n ECONNRESET: 104,\\n ENOBUFS: 105,\\n EAFNOSUPPORT: 97,\\n EPROTOTYPE: 91,\\n ENOTSOCK: 88,\\n ENOPROTOOPT: 92,\\n ESHUTDOWN: 108,\\n ECONNREFUSED: 111,\\n EADDRINUSE: 98,\\n ECONNABORTED: 103,\\n ENETUNREACH: 101,\\n ENETDOWN: 100,\\n ETIMEDOUT: 110,\\n EHOSTDOWN: 112,\\n EHOSTUNREACH: 113,\\n EINPROGRESS: 115,\\n EALREADY: 114,\\n EDESTADDRREQ: 89,\\n EMSGSIZE: 90,\\n EPROTONOSUPPORT: 93,\\n ESOCKTNOSUPPORT: 94,\\n EADDRNOTAVAIL: 99,\\n ENETRESET: 102,\\n EISCONN: 106,\\n ENOTCONN: 107,\\n ETOOMANYREFS: 109,\\n EUSERS: 87,\\n EDQUOT: 122,\\n ESTALE: 116,\\n ENOTSUP: 95,\\n ENOMEDIUM: 123,\\n EILSEQ: 84,\\n EOVERFLOW: 75,\\n ECANCELED: 125,\\n ENOTRECOVERABLE: 131,\\n EOWNERDEAD: 130,\\n ESTRPIPE: 86\\n};\\nvar LIBTIMIDITY_ERROR_MESSAGES = {\\n 0: 'Success',\\n 1: 'Not super-user',\\n 2: 'No such file or directory',\\n 3: 'No such process',\\n 4: 'Interrupted system call',\\n 5: 'I/O error',\\n 6: 'No such device or address',\\n 7: 'Arg list too long',\\n 8: 'Exec format error',\\n 9: 'Bad file number',\\n 10: 'No children',\\n 11: 'No more processes',\\n 12: 'Not enough core',\\n 13: 'Permission denied',\\n 14: 'Bad address',\\n 15: 'Block device required',\\n 16: 'Mount device busy',\\n 17: 'File exists',\\n 18: 'Cross-device link',\\n 19: 'No such device',\\n 20: 'Not a directory',\\n 21: 'Is a directory',\\n 22: 'Invalid argument',\\n 23: 'Too many open files in system',\\n 24: 'Too many open files',\\n 25: 'Not a typewriter',\\n 26: 'Text file busy',\\n 27: 'File too large',\\n 28: 'No space left on device',\\n 29: 'Illegal seek',\\n 30: 'Read only file system',\\n 31: 'Too many links',\\n 32: 'Broken pipe',\\n 33: 'Math arg out of domain of func',\\n 34: 'Math result not representable',\\n 35: 'File locking deadlock error',\\n 36: 'File or path name too long',\\n 37: 'No record locks available',\\n 38: 'Function not implemented',\\n 39: 'Directory not empty',\\n 40: 'Too many symbolic links',\\n 42: 'No message of desired type',\\n 43: 'Identifier removed',\\n 44: 'Channel number out of range',\\n 45: 'Level 2 not synchronized',\\n 46: 'Level 3 halted',\\n 47: 'Level 3 reset',\\n 48: 'Link number out of range',\\n 49: 'Protocol driver not attached',\\n 50: 'No CSI structure available',\\n 51: 'Level 2 halted',\\n 52: 'Invalid exchange',\\n 53: 'Invalid request descriptor',\\n 54: 'Exchange full',\\n 55: 'No anode',\\n 56: 'Invalid request code',\\n 57: 'Invalid slot',\\n 59: 'Bad font file fmt',\\n 60: 'Device not a stream',\\n 61: 'No data (for no delay io)',\\n 62: 'Timer expired',\\n 63: 'Out of streams resources',\\n 64: 'Machine is not on the network',\\n 65: 'Package not installed',\\n 66: 'The object is remote',\\n 67: 'The link has been severed',\\n 68: 'Advertise error',\\n 69: 'Srmount error',\\n 70: 'Communication error on send',\\n 71: 'Protocol error',\\n 72: 'Multihop attempted',\\n 73: 'Cross mount point (not really error)',\\n 74: 'Trying to read unreadable message',\\n 75: 'Value too large for defined data type',\\n 76: 'Given log. name not unique',\\n 77: 'f.d. invalid for this operation',\\n 78: 'Remote address changed',\\n 79: 'Can access a needed shared lib',\\n 80: 'Accessing a corrupted shared lib',\\n 81: '.lib section in a.out corrupted',\\n 82: 'Attempting to link in too many libs',\\n 83: 'Attempting to exec a shared library',\\n 84: 'Illegal byte sequence',\\n 86: 'Streams pipe error',\\n 87: 'Too many users',\\n 88: 'Socket operation on non-socket',\\n 89: 'Destination address required',\\n 90: 'Message too long',\\n 91: 'Protocol wrong type for socket',\\n 92: 'Protocol not available',\\n 93: 'Unknown protocol',\\n 94: 'Socket type not supported',\\n 95: 'Not supported',\\n 96: 'Protocol family not supported',\\n 97: 'Address family not supported by protocol family',\\n 98: 'Address already in use',\\n 99: 'Address not available',\\n 100: 'Network interface is not configured',\\n 101: 'Network is unreachable',\\n 102: 'Connection reset by network',\\n 103: 'Connection aborted',\\n 104: 'Connection reset by peer',\\n 105: 'No buffer space available',\\n 106: 'Socket is already connected',\\n 107: 'Socket is not connected',\\n 108: \\\"Can't send after socket shutdown\\\",\\n 109: 'Too many references',\\n 110: 'Connection timed out',\\n 111: 'Connection refused',\\n 112: 'Host is down',\\n 113: 'Host is unreachable',\\n 114: 'Socket already connected',\\n 115: 'Connection already in progress',\\n 116: 'Stale file handle',\\n 122: 'Quota exceeded',\\n 123: 'No medium (in tape drive)',\\n 125: 'Operation canceled',\\n 130: 'Previous owner died',\\n 131: 'State not recoverable'\\n}; // prettier-ignore\\n\\nvar LIBTIMIDITY_CONFIG_DATA = [100, 105, 114, 32, 46, 47, 112, 97, 116, 10, 10, 100, 114, 117, 109, 115, 101, 116, 32, 48, 10, 10, 32, 51, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 48, 46, 112, 97, 116, 10, 32, 51, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 46, 112, 97, 116, 10, 32, 51, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 46, 112, 97, 116, 10, 32, 51, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 46, 112, 97, 116, 10, 32, 51, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 46, 112, 97, 116, 10, 32, 52, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 53, 46, 112, 97, 116, 10, 32, 52, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 54, 46, 112, 97, 116, 10, 32, 52, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 55, 46, 112, 97, 116, 10, 32, 52, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 56, 46, 112, 97, 116, 10, 32, 52, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 57, 46, 112, 97, 116, 10, 32, 52, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 48, 46, 112, 97, 116, 10, 32, 52, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 49, 46, 112, 97, 116, 10, 32, 52, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 50, 46, 112, 97, 116, 10, 32, 52, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 51, 46, 112, 97, 116, 10, 32, 52, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 52, 46, 112, 97, 116, 10, 32, 53, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 53, 46, 112, 97, 116, 10, 32, 53, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 54, 46, 112, 97, 116, 10, 32, 53, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 55, 46, 112, 97, 116, 10, 32, 53, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 56, 46, 112, 97, 116, 10, 32, 53, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 57, 46, 112, 97, 116, 10, 32, 53, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 48, 46, 112, 97, 116, 10, 32, 53, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 49, 46, 112, 97, 116, 10, 32, 53, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 50, 46, 112, 97, 116, 10, 32, 53, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 51, 46, 112, 97, 116, 10, 32, 53, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 52, 46, 112, 97, 116, 10, 32, 54, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 53, 46, 112, 97, 116, 10, 32, 54, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 54, 46, 112, 97, 116, 10, 32, 54, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 55, 46, 112, 97, 116, 10, 32, 54, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 56, 46, 112, 97, 116, 10, 32, 54, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 57, 46, 112, 97, 116, 10, 32, 54, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 48, 46, 112, 97, 116, 10, 32, 54, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 49, 46, 112, 97, 116, 10, 32, 54, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 50, 46, 112, 97, 116, 10, 32, 54, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 51, 46, 112, 97, 116, 10, 32, 54, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 52, 46, 112, 97, 116, 10, 32, 55, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 53, 46, 112, 97, 116, 10, 32, 55, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 54, 46, 112, 97, 116, 10, 32, 55, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 55, 46, 112, 97, 116, 10, 32, 55, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 56, 46, 112, 97, 116, 10, 32, 55, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 57, 46, 112, 97, 116, 10, 32, 55, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 48, 46, 112, 97, 116, 10, 32, 55, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 49, 46, 112, 97, 116, 10, 32, 55, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 50, 46, 112, 97, 116, 10, 32, 55, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 51, 46, 112, 97, 116, 10, 32, 55, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 52, 46, 112, 97, 116, 10, 32, 56, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 53, 46, 112, 97, 116, 10, 32, 56, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 54, 46, 112, 97, 116, 10, 10, 98, 97, 110, 107, 32, 48, 10, 10, 32, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 55, 46, 112, 97, 116, 10, 32, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 54, 46, 112, 97, 116, 10, 32, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 53, 46, 112, 97, 116, 10, 32, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 52, 46, 112, 97, 116, 10, 32, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 51, 46, 112, 97, 116, 10, 32, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 50, 46, 112, 97, 116, 10, 32, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 49, 46, 112, 97, 116, 10, 32, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 48, 46, 112, 97, 116, 10, 32, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 57, 46, 112, 97, 116, 10, 32, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 56, 46, 112, 97, 116, 10, 32, 49, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 55, 46, 112, 97, 116, 10, 32, 49, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 54, 46, 112, 97, 116, 10, 32, 49, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 53, 46, 112, 97, 116, 10, 32, 49, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 52, 46, 112, 97, 116, 10, 32, 49, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 51, 46, 112, 97, 116, 10, 32, 49, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 50, 46, 112, 97, 116, 10, 32, 49, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 49, 46, 112, 97, 116, 10, 32, 49, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 48, 46, 112, 97, 116, 10, 32, 49, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 57, 46, 112, 97, 116, 10, 32, 49, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 56, 46, 112, 97, 116, 10, 32, 50, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 55, 46, 112, 97, 116, 10, 32, 50, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 54, 46, 112, 97, 116, 10, 32, 50, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 53, 46, 112, 97, 116, 10, 32, 50, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 52, 46, 112, 97, 116, 10, 32, 50, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 51, 46, 112, 97, 116, 10, 32, 50, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 50, 46, 112, 97, 116, 10, 32, 50, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 49, 46, 112, 97, 116, 10, 32, 50, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 48, 46, 112, 97, 116, 10, 32, 50, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 57, 46, 112, 97, 116, 10, 32, 50, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 56, 46, 112, 97, 116, 10, 32, 51, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 55, 46, 112, 97, 116, 10, 32, 51, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 54, 46, 112, 97, 116, 10, 32, 51, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 53, 46, 112, 97, 116, 10, 32, 51, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 52, 46, 112, 97, 116, 10, 32, 51, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 51, 46, 112, 97, 116, 10, 32, 51, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 50, 46, 112, 97, 116, 10, 32, 51, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 49, 46, 112, 97, 116, 10, 32, 51, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 48, 46, 112, 97, 116, 10, 32, 51, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 57, 46, 112, 97, 116, 10, 32, 51, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 56, 46, 112, 97, 116, 10, 32, 52, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 55, 46, 112, 97, 116, 10, 32, 52, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 54, 46, 112, 97, 116, 10, 32, 52, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 53, 46, 112, 97, 116, 10, 32, 52, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 52, 46, 112, 97, 116, 10, 32, 52, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 51, 46, 112, 97, 116, 10, 32, 52, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 50, 46, 112, 97, 116, 10, 32, 52, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 49, 46, 112, 97, 116, 10, 32, 52, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 48, 46, 112, 97, 116, 10, 32, 52, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 57, 46, 112, 97, 116, 10, 32, 52, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 56, 46, 112, 97, 116, 10, 32, 53, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 55, 46, 112, 97, 116, 10, 32, 53, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 54, 46, 112, 97, 116, 10, 32, 53, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 53, 46, 112, 97, 116, 10, 32, 53, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 52, 46, 112, 97, 116, 10, 32, 53, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 51, 46, 112, 97, 116, 10, 32, 53, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 50, 46, 112, 97, 116, 10, 32, 53, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 49, 46, 112, 97, 116, 10, 32, 53, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 48, 46, 112, 97, 116, 10, 32, 53, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 57, 46, 112, 97, 116, 10, 32, 53, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 56, 46, 112, 97, 116, 10, 32, 54, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 55, 46, 112, 97, 116, 10, 32, 54, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 54, 46, 112, 97, 116, 10, 32, 54, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 53, 46, 112, 97, 116, 10, 32, 54, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 52, 46, 112, 97, 116, 10, 32, 54, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 51, 46, 112, 97, 116, 10, 32, 54, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 50, 46, 112, 97, 116, 10, 32, 54, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 49, 46, 112, 97, 116, 10, 32, 54, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 48, 46, 112, 97, 116, 10, 32, 54, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 57, 46, 112, 97, 116, 10, 32, 54, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 56, 46, 112, 97, 116, 10, 32, 55, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 55, 46, 112, 97, 116, 10, 32, 55, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 54, 46, 112, 97, 116, 10, 32, 55, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 53, 46, 112, 97, 116, 10, 32, 55, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 52, 46, 112, 97, 116, 10, 32, 55, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 51, 46, 112, 97, 116, 10, 32, 55, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 50, 46, 112, 97, 116, 10, 32, 55, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 49, 46, 112, 97, 116, 10, 32, 55, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 48, 46, 112, 97, 116, 10, 32, 55, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 57, 46, 112, 97, 116, 10, 32, 55, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 56, 46, 112, 97, 116, 10, 32, 56, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 55, 46, 112, 97, 116, 10, 32, 56, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 54, 46, 112, 97, 116, 10, 32, 56, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 53, 46, 112, 97, 116, 10, 32, 56, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 52, 46, 112, 97, 116, 10, 32, 56, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 51, 46, 112, 97, 116, 10, 32, 56, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 50, 46, 112, 97, 116, 10, 32, 56, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 49, 46, 112, 97, 116, 10, 32, 56, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 48, 46, 112, 97, 116, 10, 32, 56, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 57, 46, 112, 97, 116, 10, 32, 56, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 56, 46, 112, 97, 116, 10, 32, 57, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 55, 46, 112, 97, 116, 10, 32, 57, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 54, 46, 112, 97, 116, 10, 32, 57, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 53, 46, 112, 97, 116, 10, 32, 57, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 52, 46, 112, 97, 116, 10, 32, 57, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 51, 46, 112, 97, 116, 10, 32, 57, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 50, 46, 112, 97, 116, 10, 32, 57, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 49, 46, 112, 97, 116, 10, 32, 57, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 48, 46, 112, 97, 116, 10, 32, 57, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 57, 46, 112, 97, 116, 10, 32, 57, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 56, 46, 112, 97, 116, 10, 32, 49, 48, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 55, 46, 112, 97, 116, 10, 32, 49, 48, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 54, 46, 112, 97, 116, 10, 32, 49, 48, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 53, 46, 112, 97, 116, 10, 32, 49, 48, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 52, 46, 112, 97, 116, 10, 32, 49, 48, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 51, 46, 112, 97, 116, 10, 32, 49, 48, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 50, 46, 112, 97, 116, 10, 32, 49, 48, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 49, 46, 112, 97, 116, 10, 32, 49, 48, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 48, 46, 112, 97, 116, 10, 32, 49, 48, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 57, 46, 112, 97, 116, 10, 32, 49, 48, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 56, 46, 112, 97, 116, 10, 32, 49, 49, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 55, 46, 112, 97, 116, 10, 32, 49, 49, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 54, 46, 112, 97, 116, 10, 32, 49, 49, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 53, 46, 112, 97, 116, 10, 32, 49, 49, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 52, 46, 112, 97, 116, 10, 32, 49, 49, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 51, 46, 112, 97, 116, 10, 32, 49, 49, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 46, 112, 97, 116, 10, 32, 49, 49, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 46, 112, 97, 116, 10, 32, 49, 49, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 46, 112, 97, 116, 10, 32, 49, 49, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 46, 112, 97, 116, 10, 32, 49, 49, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 46, 112, 97, 116, 10, 32, 49, 50, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 46, 112, 97, 116, 10, 32, 49, 50, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 46, 112, 97, 116, 10, 32, 49, 50, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 46, 112, 97, 116, 10, 32, 49, 50, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 46, 112, 97, 116, 10, 32, 49, 50, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 46, 112, 97, 116, 10, 32, 49, 50, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 46, 112, 97, 116, 10, 32, 49, 50, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 46, 112, 97, 116, 10, 32, 49, 50, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 48, 46, 112, 97, 116, 10];\\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/typeof.js\\nvar helpers_typeof = __webpack_require__(5);\\nvar typeof_default = /*#__PURE__*/__webpack_require__.n(helpers_typeof);\\n\\n// CONCATENATED MODULE: ./src/LibTiMidity.js\\n// https://github.com/kripken/emscripten/wiki/\\nvar INT_TYPES={i1:0,i8:0,i16:0,i32:0,i64:0};var FLOAT_TYPES={\\\"float\\\":0,\\\"double\\\":0};/** @class */var LibTiMidity_LibTiMidity=/**\\n * Library to enable playback of MIDI files.\\n * @param {undefined}\\n * @return {object} The module of an instance of LibTiMidity.\\n * @property {Number} TOTAL_MEMORY The amount of memory available to the library.\\n */function LibTiMidity(){classCallCheck_default()(this,LibTiMidity);var Runtime={stackSave:function stackSave(){return STACKTOP;},stackRestore:function stackRestore(stackTop){STACKTOP=stackTop;},isNumberType:function isNumberType(type){return type in INT_TYPES||type in FLOAT_TYPES;},isPointerType:function isPointerType(type){return type[type.length-1]=='*';},isStructType:function isStructType(type){if(isPointerType(type))return false;if(isArrayType(type))return true;if(/?/.test(type))return true;// { i32, i8 } etc. - anonymous struct types\\n// See comment in isStructPointerType()\\nreturn type[0]=='%';},getNativeTypeSize:function getNativeTypeSize(type){switch(type){case'i1':case'i8':return 1;case'i16':return 2;case'i32':return 4;case'i64':return 8;case'float':return 4;case'double':return 8;default:{if(type[type.length-1]==='*'){return Runtime.QUANTUM_SIZE;// A pointer\\n}else if(type[0]==='i'){var bits=parseInt(type.substr(1));assert(bits%8===0);return bits/8;}}}},getNativeFieldSize:function getNativeFieldSize(type){return Math.max(Runtime.getNativeTypeSize(type),Runtime.QUANTUM_SIZE);},dedup:function dedup(items,ident){var seen={};if(ident){return items.filter(function(item){if(seen[item[ident]])return false;seen[item[ident]]=true;return true;});}else{return items.filter(function(item){if(seen[item])return false;seen[item]=true;return true;});}},set:function set(){var args=typeof_default()(arguments[0])==='object'?arguments[0]:arguments;var ret={};for(var i=0;i=0){diffs.push(curr-prev);}prev=curr;return curr;});type.flatSize=Runtime.alignMemory(type.flatSize,type.alignSize);if(diffs.length==0){type.flatFactor=type.flatSize;}else if(Runtime.dedup(diffs).length==1){type.flatFactor=diffs[0];}type.needsFlattening=type.flatFactor!=1;return type.flatIndexes;},generateStructInfo:function generateStructInfo(struct,typeName,offset){var type,alignment;if(typeName){offset=offset||0;type=(typeof Types==='undefined'?Runtime.typeInfo:Types.types)[typeName];if(!type)return null;if(type.fields.length!=struct.length){console.warn('Number of named fields must match the type for '+typeName+': possibly duplicate struct names. Cannot return structInfo');return null;}alignment=type.flatIndexes;}else{var type={fields:struct.map(function(item){return item[0];})};alignment=Runtime.calculateStructAlignment(type);}var ret={__size__:type.flatSize};if(typeName){struct.forEach(function(item,i){if(typeof item==='string'){ret[item]=alignment[i]+offset;}else{// embedded struct\\nvar key;for(var k in item){key=k;}ret[key]=Runtime.generateStructInfo(item[key],type.fields[i],alignment[i]);}});}else{struct.forEach(function(item,i){ret[item[1]]=alignment[i];});}return ret;},dynCall:function dynCall(sig,ptr,args){if(args&&args.length){if(!args.splice)args=Array.prototype.slice.call(args);args.splice(0,0,ptr);return Module['dynCall_'+sig].apply(null,args);}else{return Module['dynCall_'+sig].call(null,ptr);}},UTF8Processor:function UTF8Processor(){var buffer=[];var needed=0;this.processCChar=function(code){code=code&0xff;if(buffer.length==0){if((code&0x80)==0x00){// 0xxxxxxx\\nreturn String.fromCharCode(code);}buffer.push(code);if((code&0xe0)==0xc0){// 110xxxxx\\nneeded=1;}else if((code&0xf0)==0xe0){// 1110xxxx\\nneeded=2;}else{// 11110xxx\\nneeded=3;}return'';}if(needed){buffer.push(code);needed--;if(needed>0)return'';}var c1=buffer[0];var c2=buffer[1];var c3=buffer[2];var c4=buffer[3];var ret;if(buffer.length==2){ret=String.fromCharCode((c1&0x1f)<<6|c2&0x3f);}else if(buffer.length==3){ret=String.fromCharCode((c1&0x0f)<<12|(c2&0x3f)<<6|c3&0x3f);}else{// http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\\nvar codePoint=(c1&0x07)<<18|(c2&0x3f)<<12|(c3&0x3f)<<6|c4&0x3f;ret=String.fromCharCode(Math.floor((codePoint-0x10000)/0x400)+0xd800,(codePoint-0x10000)%0x400+0xdc00);}buffer.length=0;return ret;};this.processJSString=function(string){string=unescape(encodeURIComponent(string));var ret=[];for(var i=0;i=TOTAL_MEMORY){abort('Out of memory.');}return ret;},alignMemory:function alignMemory(size,quantum){var ret=size=Math.ceil(size/(quantum?quantum:8))*(quantum?quantum:8);return ret;},makeBigInt:function makeBigInt(low,high,unsigned){var ret=unsigned?+(low>>>0)+ +(high>>>0)*+4294967296:+(low>>>0)+ +(high|0)*+4294967296;return ret;},GLOBAL_BASE:8,QUANTUM_SIZE:4};/* Initialize the runtime memory */ // TODO: Allow user to set up how much memory LibTimidity get at initialization\\n// original amount of memory was 67108864\\nvar TOTAL_MEMORY=67108864*8;var PAGE_SIZE=4096;var HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;var STATIC_BASE=0,STATICTOP=0;var STACK_BASE=0,STACKTOP=0,STACK_MAX=0;// stack area\\nvar DYNAMIC_BASE=0,DYNAMICTOP=0;// dynamic area handled by sbrk\\nassert(typeof Int32Array!=='undefined'&&typeof Float64Array!=='undefined'&&!!new Int32Array(1)['subarray']&&!!new Int32Array(1)['set'],'Typed arrays not supported.');var buffer=new ArrayBuffer(TOTAL_MEMORY);HEAP8=new Int8Array(buffer);HEAP16=new Int16Array(buffer);HEAP32=new Int32Array(buffer);HEAPU8=new Uint8Array(buffer);HEAPU16=new Uint16Array(buffer);HEAPU32=new Uint32Array(buffer);HEAPF32=new Float32Array(buffer);HEAPF64=new Float64Array(buffer);// Endianness check (note: assumes compiler arch was little-endian)\\nHEAP32[0]=255;assert(HEAPU8[0]===255&&HEAPU8[3]===0,'Typed arrays 2 must be run on a little-endian system');/**\\n * @function alignMemoryPage\\n * @memberof LibTiMidity\\n * @instance\\n * @param {Number} x\\n */function alignMemoryPage(x){return x+4095&-4096;}var Module={};this.Module=Module;Module.arguments=arguments;if(!Module['arguments']){Module['arguments']=[];}Module.read=function(url){var xhr=new XMLHttpRequest();xhr.open('GET',url,false);xhr.send(null);return xhr.responseText;};Module.print=function(message){console.log(message);};Module.preRun=[];Module.postRun=[];// Whether we are quitting the application. If so, no more code should run.\\nvar ABORT=false;var tempI64;function ExitStatus(status){this.name='ExitStatus';this.message='Program terminated with exit('+status+')';this.status=status;}ExitStatus.prototype=new Error();ExitStatus.prototype.constructor=ExitStatus;/**\\n * Exits the script.\\n * @function exit\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} status The message to display.\\n */function exit(status){ABORT=true;STACKTOP=initialStackTop;// exit the runtime\\nexitRuntime();throw new ExitStatus(status);}Module.exit=exit;/**\\n * Throws an error that aborts the execution of the script.\\n * @function abort\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} text The message to display.\\n */function abort(text){ABORT=true;throw new Error(text).stack;}Module.abort=abort;/**\\n * Aborts the execution of the script if assertion fails.\\n * @function assert\\n * @memberof LibTiMidity\\n * @instance\\n * @param {boolean} condition The assertion to test.\\n * @param {string} text The message to display if the assertion fails.\\n */function assert(condition,text){if(!condition){abort(text);}}Module.assert=assert;/**\\n * A wrapper to call functions.\\n * @function call\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} ident The name of the function to call.\\n * @param {string} returnType The return type of the function, one of the JS types 'number', 'string' or 'array' (use 'number' for any C pointer, and 'array' for JavaScript arrays and typed arrays; note that arrays are 8-bit).\\n * @param {array} argTypes An array of the types of arguments for the function (if there are no arguments, this can be ommitted). Types are as in returnType, except that 'array' is not possible (there is no way for us to know the length of the array)\\n * @param {array} args An array of the arguments to the function, as native JS values (as in returnType). Note that string arguments will be stored on the stack (the JS string will become a C string on the stack).\\n * @return Native JS value (as in returnType)\\n */Module.call=function call(ident,returnType,argTypes,args){var func=Module['_'+ident];if(!func){abort(\\\"Unknown function: \\\\\\\"\\\".concat(ident,\\\"\\\\\\\".\\\"));}var stack=0;function toC(value,type){if(type=='string'){if(value===null||value===undefined||value===0)return 0;// null string\\nvalue=intArrayFromString(value);type='array';}if(type=='array'){if(!stack)stack=Runtime.stackSave();var _ret=Runtime.stackAlloc(value.length);writeArrayToMemory(value,_ret);return _ret;}return value;}function fromC(value,type){if(type=='string'){return Pointer_stringify(value);}assert(type!='array');return value;}var i=0;var cArgs=args?args.map(function(arg){return toC(arg,argTypes[i++]);}):[];var ret=fromC(func.apply(null,cArgs),returnType);if(stack)Runtime.stackRestore(stack);return ret;};/**\\n * Dynamically sets a value in memory at runtime. Only does *aligned* writes. This is a lower-level operation.\\n * @function setValue\\n * @memberof LibTiMidity\\n * @instance\\n * @param ptr Pointer.\\n * @param value\\n * @param {string} type LLVM type ('i8', , 'i16', 'i32', 'i64', 'float', 'double')\\n */function setValue(ptr,value,type){type=type||'i8';if(type.charAt(type.length-1)==='*')type='i32';// pointers are 32-bit\\nswitch(type){case'i1':HEAP8[ptr]=value;break;case'i8':HEAP8[ptr]=value;break;case'i16':HEAP16[ptr>>1]=value;break;case'i32':HEAP32[ptr>>2]=value;break;case'i64':tempI64=[value>>>0,(tempDouble=value,+Math_abs(tempDouble)>=+1?tempDouble>+0?(Math_min(+Math_floor(tempDouble/+4294967296),+4294967295)|0)>>>0:~~+Math_ceil((tempDouble-+(~~tempDouble>>>0))/+4294967296)>>>0:0)],HEAP32[ptr>>2]=tempI64[0],HEAP32[ptr+4>>2]=tempI64[1];break;case'float':HEAPF32[ptr>>2]=value;break;case'double':HEAPF64[ptr>>3]=value;break;default:abort('invalid type for setValue: '+type);}}Module.setValue=setValue;/**\\n * Dynamically gets a value in memory at runtime. Only does *aligned* reads. This is a lower-level operation.\\n * @function getValue\\n * @memberof LibTiMidity\\n * @instance\\n * @param ptr Pointer.\\n * @param {string} type LLVM type ('i8', , 'i16', 'i32', 'i64', 'float', 'double')\\n */function getValue(ptr,type){type=type||'i8';if(type.charAt(type.length-1)==='*')type='i32';// pointers are 32-bit\\nswitch(type){case'i1':return HEAP8[ptr];case'i8':return HEAP8[ptr];case'i16':return HEAP16[ptr>>1];case'i32':return HEAP32[ptr>>2];case'i64':return HEAP32[ptr>>2];case'float':return HEAPF32[ptr>>2];case'double':return HEAPF64[ptr>>3];default:abort('invalid type for getValue: '+type);}return null;}Module['getValue']=getValue;var ALLOC_NORMAL=0;// Tries to use _malloc()\\nvar ALLOC_STACK=1;// Lives for the duration of the current function call\\nvar ALLOC_STATIC=2;// Cannot be freed\\nvar ALLOC_DYNAMIC=3;// Cannot be freed except through sbrk\\nvar ALLOC_NONE=4;// Do not allocate\\nModule['ALLOC_NORMAL']=ALLOC_NORMAL;Module['ALLOC_STACK']=ALLOC_STACK;Module['ALLOC_STATIC']=ALLOC_STATIC;Module['ALLOC_DYNAMIC']=ALLOC_DYNAMIC;Module['ALLOC_NONE']=ALLOC_NONE;/**\\n * This is for internal use. Optimized for multiple syntaxes to save space in generated code. You should allocate memory using _malloc(), initialize it with setValue(), and so forth.\\n * @function allocate\\n * @memberof LibTiMidity\\n * @instance\\n * @param slab An array of data or a number. If a number, then the size of the block to allocate in *bytes* (note that this is sometimes confusing: the next parameter does not affect this).\\n * @param types Either an array of types, one for each byte (or 0 if no type at that position), or a single type which is used for the entire block. This only matters if there is initial data. If slab is a number, then this does not matter at all and is ignored.\\n * @param allocator How to allocate memory, see ALLOC_*\\n */function allocate(slab,types,allocator,ptr){var zeroinit,size;if(typeof slab==='number'){zeroinit=true;size=slab;}else{zeroinit=false;size=slab.length;}var singleType=typeof types==='string'?types:null;var ret;if(allocator==ALLOC_NONE){ret=ptr;}else{ret=[_malloc,Runtime.stackAlloc,Runtime.staticAlloc,Runtime.dynamicAlloc][allocator===undefined?ALLOC_STATIC:allocator](Math.max(size,singleType?1:types.length));}if(zeroinit){var ptr=ret,stop;assert((ret&3)==0);stop=ret+(size&~3);for(;ptr>2]=0;}stop=ret+size;while(ptr=128)hasUtf=true;else if(t==0&&!length)break;i++;if(length&&i==length)break;}if(!length)length=i;var ret='';if(!hasUtf){var MAX_CHUNK=1024;// split up into chunks, because .apply on a huge string can overflow the stack\\nvar curr;while(length>0){curr=String.fromCharCode.apply(String,HEAPU8.subarray(ptr,ptr+Math.min(length,MAX_CHUNK)));ret=ret?ret+curr:curr;ptr+=MAX_CHUNK;length-=MAX_CHUNK;}return ret;}var utf8=new Runtime.UTF8Processor();for(i=0;i>1];if(codeUnit==0)return str;++i;// fromCharCode constructs a character from a UTF-16 code unit, so we can pass the UTF16 string right through.\\nstr+=String.fromCharCode(codeUnit);}}Module['UTF16ToString']=UTF16ToString;/**\\n * Copies a JavaScript string to the emscripten HEAP. The copy is null-terminated and encoded in UTF16LE form. The copy will require at most (str.length*2+1)*2 bytes of space in the HEAP.\\n * @function stringToUTF16\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} str JavaScript string.\\n * @param outPtr HEAP address (pointer).\\n */function stringToUTF16(str,outPtr){for(var i=0;i>1]=codeUnit;}// Null-terminate the pointer to the HEAP.\\nHEAP16[outPtr+str.length*2>>1]=0;}Module['stringToUTF16']=stringToUTF16;/**\\n * @function UTF32ToString\\n * @memberof LibTiMidity\\n * @instance\\n * @param ptr Pointer to a null-terminated UTF32LE-encoded string in the emscripten HEAP.\\n * @return\\n */function UTF32ToString(ptr){var i=0;var str='';while(1){var utf32=HEAP32[ptr+i*4>>2];if(utf32==0)return str;++i;// Gotcha: fromCharCode constructs a character from a UTF-16 encoded code (pair), not from a Unicode code point! So encode the code point to UTF-16 for constructing.\\nif(utf32>=0x10000){var ch=utf32-0x10000;str+=String.fromCharCode(0xd800|ch>>10,0xdc00|ch&0x3ff);}else{str+=String.fromCharCode(utf32);}}}Module['UTF32ToString']=UTF32ToString;/**\\n * Copies a JavaScript string to the emscripten HEAP. The copy is null-terminated and encoded in UTF32LE form. The copy will require at most (str.length+1)*4 bytes of space in the HEAP.\\n * @function stringToUTF32\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} str JavaScript string.\\n * @param outPtr HEAP address (pointer).\\n */function stringToUTF32(str,outPtr){var iChar=0;for(var iCodeUnit=0;iCodeUnit=0xd800&&codeUnit<=0xdfff){var trailSurrogate=str.charCodeAt(++iCodeUnit);codeUnit=0x10000+((codeUnit&0x3ff)<<10)|trailSurrogate&0x3ff;}HEAP32[outPtr+iChar*4>>2]=codeUnit;++iChar;}// Null-terminate the pointer to the HEAP.\\nHEAP32[outPtr+iChar*4>>2]=0;}Module['stringToUTF32']=stringToUTF32;/**\\n * @function callRuntimeCallbacks\\n * @memberof LibTiMidity\\n * @instance\\n * @param callbacks\\n */function callRuntimeCallbacks(callbacks){while(callbacks.length>0){var callback=callbacks.shift();if(typeof callback=='function'){callback();continue;}var func=callback.func;if(typeof func==='number'){if(callback.arg===undefined){Runtime.dynCall('v',func);}else{Runtime.dynCall('vi',func,[callback.arg]);}}else{func(callback.arg===undefined?null:callback.arg);}}}var __ATPRERUN__=[];// functions called before the runtime is initialized\\nvar __ATINIT__=[];// functions called during startup\\nvar __ATMAIN__=[];// functions called when main() is to be run\\nvar __ATEXIT__=[];// functions called during shutdown\\nvar __ATPOSTRUN__=[];// functions called after the runtime has exited\\nvar runtimeInitialized=false;function preRun(){// compatibility - merge in anything from Module['preRun'] at this time\\nif(Module['preRun']){if(typeof Module['preRun']=='function')Module['preRun']=[Module['preRun']];while(Module['preRun'].length){addOnPreRun(Module['preRun'].shift());}}callRuntimeCallbacks(__ATPRERUN__);}function ensureInitRuntime(){if(runtimeInitialized)return;runtimeInitialized=true;callRuntimeCallbacks(__ATINIT__);}function preMain(){callRuntimeCallbacks(__ATMAIN__);}function exitRuntime(){callRuntimeCallbacks(__ATEXIT__);}function postRun(){// compatibility - merge in anything from Module['postRun'] at this time\\nif(Module['postRun']){if(typeof Module['postRun']=='function')Module['postRun']=[Module['postRun']];while(Module['postRun'].length){addOnPostRun(Module['postRun'].shift());}}callRuntimeCallbacks(__ATPOSTRUN__);}/**\\n * @function addOnPreRun\\n * @memberof LibTiMidity\\n * @instance\\n * @param cb Callback.\\n */function addOnPreRun(cb){__ATPRERUN__.unshift(cb);}Module['addOnPreRun']=Module.addOnPreRun=addOnPreRun;/**\\n * @function addOnInit\\n * @memberof LibTiMidity\\n * @instance\\n * @param cb Callback.\\n */function addOnInit(cb){__ATINIT__.unshift(cb);}Module['addOnInit']=addOnInit;/**\\n * @function addOnPreMain\\n * @memberof LibTiMidity\\n * @instance\\n * @param cb Callback.\\n */function addOnPreMain(cb){__ATMAIN__.unshift(cb);}Module['addOnPreMain']=addOnPreMain;/**\\n * @function addOnExit\\n * @memberof LibTiMidity\\n * @instance\\n * @param cb Callback.\\n */function addOnExit(cb){__ATEXIT__.unshift(cb);}Module['addOnExit']=addOnExit;/**\\n * @function addOnPostRun\\n * @memberof LibTiMidity\\n * @instance\\n * @param cb Callback.\\n */function addOnPostRun(cb){__ATPOSTRUN__.unshift(cb);}Module['addOnPostRun']=addOnPostRun;/**\\n * @function intArrayFromString\\n * @memberof LibTiMidity\\n * @instance\\n * @param stringy\\n * @param dontAddNull\\n * @param length\\n */ // Tools\\n// This processes a JS string into a C-line array of numbers, 0-terminated.\\n// For LLVM-originating strings, see parser.js:parseLLVMString function\\nfunction intArrayFromString(stringy,dontAddNull,length/* optional */){var ret=new Runtime.UTF8Processor().processJSString(stringy);if(length){ret.length=length;}if(!dontAddNull){ret.push(0);}return ret;}Module['intArrayFromString']=intArrayFromString;/**\\n * @function intArrayToString\\n * @memberof LibTiMidity\\n * @instance\\n * @param array\\n */function intArrayToString(array){var ret=[];for(var i=0;i0xff){chr&=0xff;}ret.push(String.fromCharCode(chr));}return ret.join('');}Module['intArrayToString']=intArrayToString;/**\\n * @function writeStringToMemory\\n * @memberof LibTiMidity\\n * @instance\\n * @param string\\n * @param buffer\\n * @param dontAddNull\\n */ // Write a Javascript array to somewhere in the heap\\nfunction writeStringToMemory(string,buffer,dontAddNull){var array=intArrayFromString(string,dontAddNull);var i=0;while(i=0){return value;}return bits<=32?2*Math.abs(1<=half&&(bits<=32||value>half)){// for huge values, we can hit the precision limit and always get true here. so don't do that\\n// but, in general there is no perfect solution here. With 64-bit ints, we get rounding and errors\\n// TODO: In i64 mode 1, resign the two parts separately and safely\\nvalue=-2*half+value;// Cannot bitshift half, as it may be at the limit of the bits JS uses in bitshifts\\n}return value;}if(!Math['imul'])Math['imul']=function(a,b){var ah=a>>>16;var al=a&0xffff;var bh=b>>>16;var bl=b&0xffff;return al*bl+(ah*bl+al*bh<<16)|0;};Math.imul=Math['imul'];var Math_abs=Math.abs;var Math_sin=Math.sin;var Math_ceil=Math.ceil;var Math_floor=Math.floor;var Math_pow=Math.pow;var Math_min=Math.min;// A counter of dependencies for calling run(). If we need to\\n// do asynchronous work before running, increment this and\\n// decrement it. Incrementing must happen in a place like\\n// PRE_RUN_ADDITIONS (used by emcc to add file preloading).\\n// Note that you can add dependencies in preRun, even though\\n// it happens right before run - run will be postponed until\\n// the dependencies are met.\\nvar runDependencies=0;var runDependencyTracking={};var runDependencyWatcher=null;var dependenciesFulfilled=null;// overridden to take different actions when all run dependencies are fulfilled\\n/**\\n * @function addRunDependency\\n * @memberof LibTiMidity\\n * @instance\\n * @param id\\n */function addRunDependency(id){runDependencies++;if(Module['monitorRunDependencies']){Module['monitorRunDependencies'](runDependencies);}if(id){assert(!runDependencyTracking[id]);runDependencyTracking[id]=1;}else{console.warn('warning: run dependency added without ID');}}Module['addRunDependency']=addRunDependency;/**\\n * @function removeRunDependency\\n * @memberof LibTiMidity\\n * @instance\\n * @param id\\n */function removeRunDependency(id){runDependencies--;if(Module['monitorRunDependencies']){Module['monitorRunDependencies'](runDependencies);}if(id){assert(runDependencyTracking[id]);delete runDependencyTracking[id];}else{console.warn('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\\n}}}Module['removeRunDependency']=removeRunDependency;var memoryInitializer=null;// === Body ===\\nSTATIC_BASE=8;STATICTOP=STATIC_BASE+8448;/* global initializers */__ATINIT__.push({func:function func(){runPostSets();}});var _stderr;var _stderr=_stderr=allocate([0,0,0,0,0,0,0,0],'i8',ALLOC_STATIC);/* memory initializer */ // prettier-ignore\\nallocate([0,0,0,0,0,0,144,63,75,191,53,65,90,136,144,63,241,46,189,130,62,21,145,63,249,198,51,115,211,166,145,63,194,109,221,10,65,61,146,63,61,194,157,150,176,216,146,63,232,234,78,195,76,121,147,63,204,6,121,169,65,31,148,63,172,119,109,217,188,202,148,63,136,88,201,103,237,123,149,63,154,143,98,250,3,51,150,63,89,8,163,213,50,240,150,63,69,192,85,234,173,179,151,63,98,112,233,227,170,125,152,63,242,189,44,55,97,78,153,63,189,253,135,49,10,38,154,63,84,184,184,8,225,4,155,63,232,64,19,235,34,235,155,63,101,213,78,16,15,217,156,63,82,228,224,202,230,206,157,63,110,60,236,153,237,204,158,63,149,18,201,59,105,211,159,63,39,122,149,224,80,113,160,63,129,244,116,208,112,253,160,63,39,24,58,230,58,142,161,63,74,29,119,226,214,35,162,63,50,84,131,216,109,190,162,63,137,39,194,57,42,94,163,63,195,57,74,225,55,3,164,63,225,208,239,31,196,173,164,63,141,222,181,200,253,93,165,63,62,15,169,61,21,20,166,63,223,103,40,125,60,208,166,63,155,23,159,47,167,146,167,63,148,66,179,181,138,91,168,63,80,170,237,54,30,43,169,63,237,57,222,176,154,1,170,63,104,158,193,6,59,223,170,63,182,54,172,17,60,196,171,63,248,203,62,177,220,176,172,63,49,168,233,220,93,165,173,63,115,200,194,181,2,162,174,63,108,16,244,152,16,167,175,63,78,71,99,153,103,90,176,63,213,5,40,73,196,229,176,63,17,38,228,158,196,117,177,63,185,204,197,35,144,10,178,63,128,43,232,177,79,164,178,63,152,204,138,127,45,67,179,63,121,115,168,42,85,231,179,63,129,193,240,196,243,144,180,63,19,232,39,224,55,64,181,63,242,205,239,154,81,245,181,63,121,42,254,173,114,176,182,63,62,55,195,121,206,113,183,63,150,183,132,20,154,57,184,63,124,53,241,88,12,8,185,63,40,116,47,245,93,221,185,63,234,58,110,122,201,185,186,63,0,190,248,108,139,157,187,63,185,15,212,84,226,136,188,63,119,41,234,206,14,124,189,63,90,67,199,158,83,119,190,63,113,89,238,192,245,122,191,63,90,243,228,62,158,67,192,63,134,4,159,190,56,206,192,63,250,182,112,109,112,93,193,63,134,74,113,157,108,241,193,63,158,146,207,239,85,138,194,63,241,160,249,95,86,40,195,63,53,128,35,79,153,203,195,63,8,41,48,144,75,116,196,63,52,246,255,115,155,34,197,63,60,249,39,214,184,214,197,63,231,172,21,42,213,144,198,63,103,161,162,136,35,81,199,63,64,220,27,190,216,23,200,63,253,197,192,88,43,229,200,63,169,160,189,183,83,185,201,63,151,163,165,26,140,148,202,63,112,252,112,177,16,119,203,63,132,25,3,173,31,97,204,63,196,198,61,80,249,82,205,63,129,205,165,1,224,76,206,63,12,239,157,93,24,79,207,63,179,157,158,164,244,44,208,63,24,248,226,2,206,182,208,63,221,27,97,34,62,69,209,63,241,38,102,30,108,216,209,63,184,223,131,95,128,112,210,63,143,212,168,166,164,13,211,63,246,6,151,24,4,176,211,63,25,72,188,73,203,87,212,63,38,135,111,74,40,5,213,63,234,109,150,179,74,184,213,63,94,196,182,179,99,113,214,63,191,49,119,28,166,48,215,63,64,16,147,112,70,246,215,63,245,39,69,242,122,194,216,63,68,70,45,178,123,149,217,63,234,200,180,158,130,111,218,63,100,86,246,147,203,80,219,63,204,33,45,108,148,57,220,63,17,61,176,16,29,42,221,63,59,163,126,139,167,34,222,63,13,204,96,25,120,35,223,63,161,97,82,158,106,22,224,63,42,244,60,232,131,159,224,63,162,211,120,142,45,45,225,63,38,84,213,117,142,191,225,63,187,17,150,206,206,86,226,63,84,154,123,31,24,243,226,63,218,31,42,81,149,148,227,63,89,83,241,185,114,59,228,63,111,165,248,41,222,231,228,63,145,67,211,247,6,154,229,63,32,70,127,13,30,82,230,63,216,160,211,245,85,16,231,63,137,133,96,234,226,212,231,63,76,8,198,225,250,159,232,63,27,245,132,158,213,113,233,63,9,232,77,190,172,74,234,63,44,220,210,201,187,42,235,63,254,136,31,69,64,18,236,63,11,11,125,192,121,1,237,63,244,122,229,233,169,248,237,63,130,61,12,159,20,248,238,63,0,0,0,0,0,0,240,63,0,0,128,63,0,0,0,0,0,0,220,67,0,0,0,0,168,25,0,0,0,0,0,0,240,31,0,0,214,33,0,0,217,35,0,0,251,37,0,0,61,40,0,0,161,42,0,0,42,45,0,0,218,47,0,0,178,50,0,0,182,53,0,0,232,56,0,0,74,60,0,0,224,63,0,0,172,67,0,0,178,71,0,0,245,75,0,0,122,80,0,0,67,85,0,0,85,90,0,0,180,95,0,0,101,101,0,0,108,107,0,0,207,113,0,0,148,120,0,0,191,127,0,0,88,135,0,0,100,143,0,0,235,151,0,0,243,160,0,0,134,170,0,0,169,180,0,0,103,191,0,0,201,202,0,0,216,214,0,0,158,227,0,0,39,241,0,0,126,255,0,0,176,14,1,0,200,30,1,0,214,47,1,0,231,65,1,0,11,85,1,0,83,105,1,0,207,126,1,0,146,149,1,0,176,173,1,0,61,199,1,0,79,226,1,0,253,254,1,0,95,29,2,0,144,61,2,0,171,95,2,0,206,131,2,0,22,170,2,0,165,210,2,0,158,253,2,0,36,43,3,0,96,91,3,0,122,142,3,0,158,196,3,0,250,253,3,0,191,58,4,0,33,123,4,0,87,191,4,0,156,7,5,0,44,84,5,0,74,165,5,0,59,251,5,0,73,86,6,0,192,182,6,0,244,28,7,0,59,137,7,0,243,251,7,0,125,117,8,0,66,246,8,0,174,126,9,0,55,15,10,0,88,168,10,0,149,74,11,0,119,246,11,0,145,172,12,0,128,109,13,0,232,57,14,0,119,18,15,0,230,247,15,0,251,234,16,0,131,236,17,0,92,253,18,0,110,30,20,0,177,80,21,0,42,149,22,0,238,236,23,0,35,89,25,0,0,219,26,0,207,115,28,0,237,36,30,0,205,239,31,0,245,213,33,0,6,217,35,0,184,250,37,0,220,60,40,0,98,161,42,0,83,42,45,0,219,217,47,0,70,178,50,0,0,182,53,0,158,231,56,0,218,73,60,0,153,223,63,0,234,171,67,0,12,178,71,0,112,245,75,0,185,121,80,0,196,66,85,0,167,84,90,0,183,179,95,0,139,100,101,0,0,108,107,0,60,207,113,0,181,147,120,0,50,191,127,0,212,87,135,0,25,100,143,0,223,234,151,0,114,243,160,0,135,133,170,0,78,169,180,0,110,103,191,0,32,161,7,0,0,0,0,0,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,240,63,113,93,245,158,236,0,240,63,84,18,150,75,217,1,240,63,207,232,226,5,198,2,240,63,21,171,220,205,178,3,240,63,102,35,132,163,159,4,240,63,10,28,218,134,140,5,240,63,88,95,223,119,121,6,240,63,177,183,148,118,102,7,240,63,131,239,250,130,83,8,240,63,70,209,18,157,64,9,240,63,127,39,221,196,45,10,240,63,191,188,90,250,26,11,240,63,160,91,140,61,8,12,240,63,204,206,114,142,245,12,240,63,245,224,14,237,226,13,240,63,218,92,97,89,208,14,240,63,71,13,107,211,189,15,240,63,17,189,44,91,171,16,240,63,28,55,167,240,152,17,240,63,85,70,219,147,134,18,240,63,181,181,201,68,116,19,240,63,66,80,115,3,98,20,240,63,14,225,216,207,79,21,240,63,53,51,251,169,61,22,240,63,224,17,219,145,43,23,240,63,68,72,121,135,25,24,240,63,159,161,214,138,7,25,240,63,63,233,243,155,245,25,240,63,122,234,209,186,227,26,240,63,180,112,113,231,209,27,240,63,93,71,211,33,192,28,240,63,238,57,248,105,174,29,240,63,239,19,225,191,156,30,240,63,242,160,142,35,139,31,240,63,148,172,1,149,121,32,240,63,129,2,59,20,104,33,240,63,109,110,59,161,86,34,240,63,26,188,3,60,69,35,240,63,85,183,148,228,51,36,240,63,247,43,239,154,34,37,240,63,228,229,19,95,17,38,240,63,14,177,3,49,0,39,240,63,112,89,191,16,239,39,240,63,19,171,71,254,221,40,240,63,10,114,157,249,204,41,240,63,117,122,193,2,188,42,240,63,128,144,180,25,171,43,240,63,97,128,119,62,154,44,240,63,92,22,11,113,137,45,240,63,191,30,112,177,120,46,240,63,230,101,167,255,103,47,240,63,54,184,177,91,87,48,240,63,34,226,143,197,70,49,240,63,39,176,66,61,54,50,240,63,209,238,202,194,37,51,240,63,180,106,41,86,21,52,240,63,113,240,94,247,4,53,240,63,183,76,108,166,244,53,240,63,63,76,82,99,228,54,240,63,204,187,17,46,212,55,240,63,49,104,171,6,196,56,240,63,73,30,32,237,179,57,240,63,254,170,112,225,163,58,240,63,67,219,157,227,147,59,240,63,24,124,168,243,131,60,240,63,138,90,145,17,116,61,240,63,177,67,89,61,100,62,240,63,176,4,1,119,84,63,240,63,182,106,137,190,68,64,240,63,0,67,243,19,53,65,240,63,212,90,63,119,37,66,240,63,133,127,110,232,21,67,240,63,114,126,129,103,6,68,240,63,7,37,121,244,246,68,240,63,185,64,86,143,231,69,240,63,12,159,25,56,216,70,240,63,141,13,196,238,200,71,240,63,216,89,86,179,185,72,240,63,146,81,209,133,170,73,240,63,109,194,53,102,155,74,240,63,40,122,132,84,140,75,240,63,140,70,190,80,125,76,240,63,110,245,227,90,110,77,240,63,177,84,246,114,95,78,240,63,66,50,246,152,80,79,240,63,26,92,228,204,65,80,240,63,63,160,193,14,51,81,240,63,194,204,142,94,36,82,240,63,192,175,76,188,21,83,240,63,98,23,252,39,7,84,240,63,220,209,157,161,248,84,240,63,112,173,50,41,234,85,240,63,107,120,187,190,219,86,240,63,37,1,57,98,205,87,240,63,2,22,172,19,191,88,240,63,116,133,21,211,176,89,240,63,247,29,118,160,162,90,240,63,18,174,206,123,148,91,240,63,91,4,32,101,134,92,240,63,113,239,106,92,120,93,240,63,1,62,176,97,106,94,240,63,194,190,240,116,92,95,240,63,122,64,45,150,78,96,240,63,247,145,102,197,64,97,240,63,22,130,157,2,51,98,240,63,191,223,210,77,37,99,240,63,229,121,7,167,23,100,240,63,137,31,60,14,10,101,240,63,181,159,113,131,252,101,240,63,130,201,168,6,239,102,240,63,20,108,226,151,225,103,240,63,154,86,31,55,212,104,240,63,79,88,96,228,198,105,240,63,124,64,166,159,185,106,240,63,115,222,241,104,172,107,240,63,149,1,68,64,159,108,240,63,77,121,157,37,146,109,240,63,18,21,255,24,133,110,240,63,104,164,105,26,120,111,240,63,222,246,221,41,107,112,240,63,16,220,92,71,94,113,240,63,165,35,231,114,81,114,240,63,81,157,125,172,68,115,240,63,211,24,33,244,55,116,240,63,246,101,210,73,43,117,240,63,147,84,146,173,30,118,240,63,140,180,97,31,18,119,240,63,209,85,65,159,5,120,240,63,93,8,50,45,249,120,240,63,57,156,52,201,236,121,240,63,118,225,73,115,224,122,240,63,54,168,114,43,212,123,240,63,163,192,175,241,199,124,240,63,246,250,1,198,187,125,240,63,113,39,106,168,175,126,240,63,101,22,233,152,163,127,240,63,44,152,127,151,151,128,240,63,48,125,46,164,139,129,240,63,226,149,246,190,127,130,240,63,197,178,216,231,115,131,240,63,98,164,213,30,104,132,240,63,82,59,238,99,92,133,240,63,58,72,35,183,80,134,240,63,200,155,117,24,69,135,240,63,185,6,230,135,57,136,240,63,214,89,117,5,46,137,240,63,242,101,36,145,34,138,240,63,237,251,243,42,23,139,240,63,180,236,228,210,11,140,240,63,63,9,248,136,0,141,240,63,147,34,46,77,245,141,240,63,192,9,136,31,234,142,240,63,226,143,6,0,223,143,240,63,35,134,170,238,211,144,240,63,184,189,116,235,200,145,240,63,224,7,102,246,189,146,240,63,233,53,127,15,179,147,240,63,44,25,193,54,168,148,240,63,13,131,44,108,157,149,240,63,0,69,194,175,146,150,240,63,127,48,131,1,136,151,240,63,22,23,112,97,125,152,240,63,89,202,137,207,114,153,240,63,234,27,209,75,104,154,240,63,119,221,70,214,93,155,240,63,185,224,235,110,83,156,240,63,119,247,192,21,73,157,240,63,131,243,198,202,62,158,240,63,187,166,254,141,52,159,240,63,9,227,104,95,42,160,240,63,99,122,6,63,32,161,240,63,205,62,216,44,22,162,240,63,85,2,223,40,12,163,240,63,21,151,27,51,2,164,240,63,53,207,142,75,248,164,240,63,233,124,57,114,238,165,240,63,110,114,28,167,228,166,240,63,17,130,56,234,218,167,240,63,40,126,142,59,209,168,240,63,25,57,31,155,199,169,240,63,83,133,235,8,190,170,240,63,81,53,244,132,180,171,240,63,156,27,58,15,171,172,240,63,200,10,190,167,161,173,240,63,118,213,128,78,152,174,240,63,82,78,131,3,143,175,240,63,22,72,198,198,133,176,240,63,134,149,74,152,124,177,240,63,116,9,17,120,115,178,240,63,188,118,26,102,106,179,240,63,73,176,103,98,97,180,240,63,15,137,249,108,88,181,240,63,18,212,208,133,79,182,240,63,95,100,238,172,70,183,240,63,17,13,83,226,61,184,240,63,78,161,255,37,53,185,240,63,72,244,244,119,44,186,240,63,63,217,51,216,35,187,240,63,125,35,189,70,27,188,240,63,91,166,145,195,18,189,240,63,59,53,178,78,10,190,240,63,142,163,31,232,1,191,240,63,206,196,218,143,249,191,240,63,133,108,228,69,241,192,240,63,71,110,61,10,233,193,240,63,180,157,230,220,224,194,240,63,122,206,224,189,216,195,240,63,80,212,44,173,208,196,240,63,253,130,203,170,200,197,240,63,83,174,189,182,192,198,240,63,46,42,4,209,184,199,240,63,121,202,159,249,176,200,240,63,42,99,145,48,169,201,240,63,67,200,217,117,161,202,240,63,212,205,121,201,153,203,240,63,247,71,114,43,146,204,240,63,212,10,196,155,138,205,240,63,158,234,111,26,131,206,240,63,148,187,118,167,123,207,240,63,3,82,217,66,116,208,240,63,68,130,152,236,108,209,240,63,186,32,181,164,101,210,240,63,214,1,48,107,94,211,240,63,22,250,9,64,87,212,240,63,2,222,67,35,80,213,240,63,50,130,222,20,73,214,240,63,69,187,218,20,66,215,240,63,236,93,57,35,59,216,240,63,223,62,251,63,52,217,240,63,230,50,33,107,45,218,240,63,213,14,172,164,38,219,240,63,137,167,156,236,31,220,240,63,240,209,243,66,25,221,240,63,0,99,178,167,18,222,240,63,191,47,217,26,12,223,240,63,61,13,105,156,5,224,240,63,150,208,98,44,255,224,240,63,245,78,199,202,248,225,240,63,141,93,151,119,242,226,240,63,162,209,211,50,236,227,240,63,129,128,125,252,229,228,240,63,133,63,149,212,223,229,240,63,21,228,27,187,217,230,240,63,163,67,18,176,211,231,240,63,176,51,121,179,205,232,240,63,198,137,81,197,199,233,240,63,127,27,156,229,193,234,240,63,126,190,89,20,188,235,240,63,116,72,139,81,182,236,240,63,31,143,49,157,176,237,240,63,72,104,77,247,170,238,240,63,197,169,223,95,165,239,240,63,119,41,233,214,159,240,240,63,79,189,106,92,154,241,240,63,69,59,101,240,148,242,240,63,0,0,0,0,0,0,240,63,99,121,217,146,143,243,240,63,192,214,199,195,154,245,241,63,21,183,49,10,254,6,243,63,139,114,141,249,162,40,244,63,94,236,240,8,129,91,245,63,205,59,127,102,158,160,246,63,176,207,104,215,16,249,247,63,60,110,61,165,254,101,249,63,173,211,90,153,159,232,250,63,41,193,78,7,62,130,252,63,67,19,16,231,55,52,254,63,0,0,0,0,0,0,0,64,99,121,217,146,143,243,0,64,192,214,199,195,154,245,1,64,21,183,49,10,254,6,3,64,139,114,141,249,162,40,4,64,94,236,240,8,129,91,5,64,205,59,127,102,158,160,6,64,176,207,104,215,16,249,7,64,61,110,61,165,254,101,9,64,173,211,90,153,159,232,10,64,41,193,78,7,62,130,12,64,68,19,16,231,55,52,14,64,0,0,0,0,0,0,16,64,99,121,217,146,143,243,16,64,191,214,199,195,154,245,17,64,21,183,49,10,254,6,19,64,139,114,141,249,162,40,20,64,93,236,240,8,129,91,21,64,205,59,127,102,158,160,22,64,177,207,104,215,16,249,23,64,60,110,61,165,254,101,25,64,173,211,90,153,159,232,26,64,42,193,78,7,62,130,28,64,67,19,16,231,55,52,30,64,0,0,0,0,0,0,32,64,99,121,217,146,143,243,32,64,191,214,199,195,154,245,33,64,21,183,49,10,254,6,35,64,139,114,141,249,162,40,36,64,93,236,240,8,129,91,37,64,205,59,127,102,158,160,38,64,177,207,104,215,16,249,39,64,60,110,61,165,254,101,41,64,173,211,90,153,159,232,42,64,42,193,78,7,62,130,44,64,67,19,16,231,55,52,46,64,0,0,0,0,0,0,48,64,98,121,217,146,143,243,48,64,193,214,199,195,154,245,49,64,21,183,49,10,254,6,51,64,138,114,141,249,162,40,52,64,95,236,240,8,129,91,53,64,205,59,127,102,158,160,54,64,175,207,104,215,16,249,55,64,62,110,61,165,254,101,57,64,173,211,90,153,159,232,58,64,40,193,78,7,62,130,60,64,69,19,16,231,55,52,62,64,0,0,0,0,0,0,64,64,98,121,217,146,143,243,64,64,193,214,199,195,154,245,65,64,21,183,49,10,254,6,67,64,138,114,141,249,162,40,68,64,95,236,240,8,129,91,69,64,205,59,127,102,158,160,70,64,175,207,104,215,16,249,71,64,62,110,61,165,254,101,73,64,173,211,90,153,159,232,74,64,40,193,78,7,62,130,76,64,69,19,16,231,55,52,78,64,0,0,0,0,0,0,80,64,98,121,217,146,143,243,80,64,193,214,199,195,154,245,81,64,21,183,49,10,254,6,83,64,138,114,141,249,162,40,84,64,95,236,240,8,129,91,85,64,205,59,127,102,158,160,86,64,175,207,104,215,16,249,87,64,62,110,61,165,254,101,89,64,173,211,90,153,159,232,90,64,40,193,78,7,62,130,92,64,69,19,16,231,55,52,94,64,0,0,0,0,0,0,96,64,98,121,217,146,143,243,96,64,193,214,199,195,154,245,97,64,21,183,49,10,254,6,99,64,138,114,141,249,162,40,100,64,95,236,240,8,129,91,101,64,205,59,127,102,158,160,102,64,175,207,104,215,16,249,103,64,62,110,61,165,254,101,105,64,173,211,90,153,159,232,106,64,40,193,78,7,62,130,108,64,69,19,16,231,55,52,110,64,0,0,0,0,0,0,112,64,101,121,217,146,143,243,112,64,190,214,199,195,154,245,113,64,21,183,49,10,254,6,115,64,141,114,141,249,162,40,116,64,92,236,240,8,129,91,117,64,205,59,127,102,158,160,118,64,179,207,104,215,16,249,119,64,58,110,61,165,254,101,121,64,173,211,90,153,159,232,122,64,45,193,78,7,62,130,124,64,64,19,16,231,55,52,126,64,0,0,0,0,0,0,128,64,101,121,217,146,143,243,128,64,190,214,199,195,154,245,129,64,21,183,49,10,254,6,131,64,141,114,141,249,162,40,132,64,92,236,240,8,129,91,133,64,205,59,127,102,158,160,134,64,179,207,104,215,16,249,135,64,58,110,61,165,254,101,137,64,173,211,90,153,159,232,138,64,45,193,78,7,62,130,140,64,64,19,16,231,55,52,142,64,0,0,0,0,0,0,144,64,101,121,217,146,143,243,144,64,190,214,199,195,154,245,145,64,21,183,49,10,254,6,147,64,141,114,141,249,162,40,148,64,92,236,240,8,129,91,149,64,205,59,127,102,158,160,150,64,179,207,104,215,16,249,151,64,77,84,104,100,0,0,0,0,86,101,108,111,99,105,116,121,32,37,100,32,37,100,10,0,70,84,80,112,114,111,120,121,0,0,0,0,0,0,0,0,72,84,84,80,112,114,111,120,121,0,0,0,0,0,0,0,99,111,109,109,0,0,0,0,35,101,120,116,101,110,115,105,111,110,0,0,0,0,0,0,78,117,109,32,77,105,115,115,105,110,103,32,112,97,116,99,104,101,115,58,32,37,100,10,0,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,115,116,114,105,112,32,109,117,115,116,32,98,101,32,101,110,118,44,32,108,111,111,112,44,32,111,114,32,116,97,105,108,10,0,0,116,97,105,108,0,0,0,0,115,116,114,105,112,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,107,101,101,112,32,109,117,115,116,32,98,101,32,101,110,118,32,111,114,32,108,111,111,112,10,0,0,108,111,111,112,0,0,0,0,101,110,118,0,0,0,0,0,107,101,101,112,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,112,97,110,110,105,110,103,32,109,117,115,116,32,98,101,32,108,101,102,116,44,32,114,105,103,104,116,44,32,99,101,110,116,101,114,44,32,111,114,32,98,101,116,119,101,101,110,32,45,49,48,48,32,97,110,100,32,49,48,48,10,0,0,0,0,0,0,32,9,160,0,0,0,0,0,114,105,103,104,116,0,0,0,108,101,102,116,0,0,0,0,77,105,115,115,105,110,103,32,112,97,116,99,104,58,32,37,115,10,0,0,0,0,0,0,99,101,110,116,101,114,0,0,112,97,110,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,110,111,116,101,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,0,0,0,110,111,116,101,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,97,109,112,108,105,102,105,99,97,116,105,111,110,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,37,100,10,0,0,0,0,97,109,112,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,98,97,100,32,112,97,116,99,104,32,111,112,116,105,111,110,32,37,115,10,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,77,117,115,116,32,115,112,101,99,105,102,121,32,116,111,110,101,32,98,97,110,107,32,111,114,32,100,114,117,109,32,115,101,116,32,98,101,102,111,114,101,32,97,115,115,105,103,110,109,101,110,116,10,0,0,0,0,0,0,67,111,110,102,105,103,117,114,97,116,105,111,110,32,102,105,108,101,32,37,115,32,110,111,116,32,102,111,117,110,100,10,0,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,80,114,111,103,114,97,109,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,37,115,58,32,108,105,110,101,32,37,100,58,32,115,121,110,116,97,120,32,101,114,114,111,114,10,0,0,0,0,0,0,63,63,63,63,63,63,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,84,111,110,101,32,98,97,110,107,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,98,97,110,107,32,110,117,109,98,101,114,32,103,105,118,101,110,10,0,0,0,0,0,0,98,97,110,107,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,68,114,117,109,32,115,101,116,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,100,114,117,109,32,115,101,116,32,110,117,109,98,101,114,32,103,105,118,101,110,10,0,0,100,114,117,109,115,101,116,0,37,115,58,32,108,105,110,101,32,37,100,58,32,77,117,115,116,32,115,112,101,99,105,102,121,32,101,120,97,99,116,108,121,32,111,110,101,32,112,97,116,99,104,32,110,97,109,101,10,0,0,0,0,0,0,0,100,101,102,97,117,108,116,0,80,114,111,98,97,98,108,101,32,115,111,117,114,99,101,32,108,111,111,112,32,105,110,32,99,111,110,102,105,103,117,114,97,116,105,111,110,32,102,105,108,101,115,10,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,102,105,108,101,32,110,97,109,101,32,103,105,118,101,110,10,0,0,0,0,0,0,0,0,115,111,117,114,99,101,0,0,71,70,49,80,65,84,67,72,49,48,48,0,73,68,35,48,48,48,48,48,50,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,100,105,114,101,99,116,111,114,121,32,103,105,118,101,110,10,0,0,0,0,0,0,0,0,100,105,114,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,109,97,112,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,109,97,112,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,112,114,111,103,98,97,115,101,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,0,0,0,112,114,111,103,98,97,115,101,0,0,0,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,109,101,109,101,110,116,32,34,37,115,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,102,111,110,116,0,0,0,0,85,110,115,117,112,112,111,114,116,101,100,32,97,117,100,105,111,32,102,111,114,109,97,116,10,0,0,0,0,0,0,0,115,111,117,110,100,102,111,110,116,0,0,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,97,108,116,97,115,115,105,103,110,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,0,0,71,70,49,80,65,84,67,72,49,49,48,0,73,68,35,48,48,48,48,48,50,0,0,0,77,84,114,107,0,0,0,0,97,108,116,97,115,115,105,103,110,0,0,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,117,110,100,101,102,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,117,110,100,101,102,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,37,115,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,0,99,111,112,121,98,97,110,107,0,0,0,0,0,0,0,0,99,111,112,121,100,114,117,109,115,101,116,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,116,105,109,101,111,117,116,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,97,100,100,32,116,111,32,112,97,116,104,108,105,115,116,58,32,37,115,10,0,0,0,0,116,105,109,101,111,117,116,0,46,0,0,0,0,0,0,0,116,105,109,105,100,105,116,121,46,99,102,103,0,0,0,0,111,112,116,0,0,0,0,0,114,98,0,0,0,0,0,0,109,97,105,108,97,100,100,114,0,0,0,0,0,0,0,0,46,112,97,116,0,0,0,0,114,98,0,0,0,0,0,0],\\\"i8\\\",ALLOC_NONE,Runtime.GLOBAL_BASE);var tempDoublePtr=Runtime.alignMemory(allocate(12,'i8',ALLOC_STATIC),8);assert(tempDoublePtr%8==0);var ___errno_state=0;function ___setErrNo(value){// For convenient setting and returning of errno.\\nHEAP32[___errno_state>>2]=value;return value;}var PATH={splitPath:function splitPath(filename){var splitPathRe=/^(\\\\/?|)([\\\\s\\\\S]*?)((?:\\\\.{1,2}|[^\\\\/]+?|)(\\\\.[^.\\\\/]*|))(?:[\\\\/]*)$/;return splitPathRe.exec(filename).slice(1);},normalizeArray:function normalizeArray(parts,allowAboveRoot){// if the path tries to go above the root, `up` ends up > 0\\nvar up=0;for(var i=parts.length-1;i>=0;i--){var last=parts[i];if(last==='.'){parts.splice(i,1);}else if(last==='..'){parts.splice(i,1);up++;}else if(up){parts.splice(i,1);up--;}}// if the path is allowed to go above the root, restore leading ..s\\nif(allowAboveRoot){for(;up--;up){parts.unshift('..');}}return parts;},normalize:function normalize(path){var isAbsolute=path.charAt(0)==='/',trailingSlash=path.substr(-1)==='/';// Normalize the path\\npath=PATH.normalizeArray(path.split('/').filter(function(p){return!!p;}),!isAbsolute).join('/');if(!path&&!isAbsolute){path='.';}if(path&&trailingSlash){path+='/';}return(isAbsolute?'/':'')+path;},dirname:function dirname(path){var result=PATH.splitPath(path),root=result[0],dir=result[1];if(!root&&!dir){// No dirname whatsoever\\nreturn'.';}if(dir){// It has a dirname, strip trailing slash\\ndir=dir.substr(0,dir.length-1);}return root+dir;},basename:function basename(path,ext){// EMSCRIPTEN return '/'' for '/', not an empty string\\nif(path==='/')return'/';var f=PATH.splitPath(path)[2];if(ext&&f.substr(-1*ext.length)===ext){f=f.substr(0,f.length-ext.length);}return f;},extname:function extname(path){return PATH.splitPath(path)[3];},join:function join(){var paths=Array.prototype.slice.call(arguments,0);return PATH.normalize(paths.filter(function(p,index){if(typeof p!=='string'){throw new TypeError('Arguments to path.join must be strings');}return p;}).join('/'));},resolve:function resolve(){var resolvedPath='',resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?arguments[i]:FS.cwd();// Skip empty and invalid entries\\nif(typeof path!=='string'){throw new TypeError('Arguments to path.resolve must be strings');}else if(!path){continue;}resolvedPath=path+'/'+resolvedPath;resolvedAbsolute=path.charAt(0)==='/';}// At this point the path should be resolved to a full absolute path, but handle relative paths to be safe (might happen when process.cwd() fails)\\nresolvedPath=PATH.normalizeArray(resolvedPath.split('/').filter(function(p){return!!p;}),!resolvedAbsolute).join('/');return(resolvedAbsolute?'/':'')+resolvedPath||'.';},relative:function relative(from,to){from=PATH.resolve(from).substr(1);to=PATH.resolve(to).substr(1);function trim(arr){var start=0;for(;start=0;end--){if(arr[end]!=='')break;}if(start>end)return[];return arr.slice(start,end-start+1);}var fromParts=trim(from.split('/'));var toParts=trim(to.split('/'));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i=0;icontents.length){contents.push(0);}}},lookup:function lookup(){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOENT);},mknod:function mknod(parent,name,mode,dev){return MEMFS.createNode(parent,name,mode,dev);},rename:function rename(old_node,new_dir,new_name){// if we're overwriting a directory at new_name, make sure it's empty.\\nif(FS.isDir(old_node.mode)){var new_node;try{new_node=FS.lookupNode(new_dir,new_name);}catch(e){}if(new_node){for(var i in new_node.contents){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOTEMPTY);}}}// do the internal rewiring\\ndelete old_node.parent.contents[old_node.name];old_node.name=new_name;new_dir.contents[new_name]=old_node;},unlink:function unlink(parent,name){delete parent.contents[name];},rmdir:function rmdir(parent,name){var node=FS.lookupNode(parent,name);for(var i in node.contents){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOTEMPTY);}delete parent.contents[name];},readdir:function readdir(node){var entries=['.','..'];for(var key in node.contents){if(!node.contents.hasOwnProperty(key)){continue;}entries.push(key);}return entries;},symlink:function symlink(parent,newname,oldpath){var node=MEMFS.createNode(parent,newname,511|40960,0);node.link=oldpath;return node;},readlink:function readlink(node){if(!FS.isLink(node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}return node.link;}},stream_ops:{read:function read(stream,buffer,offset,length,position){var contents=stream.node.contents;if(position>=contents.length)return 0;var size=Math.min(contents.length-position,length);assert(size>=0);if(size>8&&contents.subarray){// non-trivial and typed array\\nbuffer.set(contents.subarray(position,position+size),offset);}else{for(var i=0;icontents.length){contents.push(0);}},mmap:function mmap(stream,buffer,length,position,flags){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENODEV);}var ptr;var allocated;var contents=stream.node.contents;// Only make a new copy when MAP_PRIVATE is specified.\\nif(!(flags&2)&&(contents.buffer===buffer||contents.buffer===buffer.buffer)){// We can't emulate MAP_SHARED when the file is not backed by the buffer\\n// we're mapping to (e.g. the HEAP buffer).\\nallocated=false;ptr=contents.byteOffset;}else{// Try to avoid unnecessary slices.\\nif(position>0||position+length8){// max recursive lookup of 8\\nthrow new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ELOOP);}// split the path\\nvar parts=PATH.normalizeArray(path.split('/').filter(function(p){return!!p;}),false);// start at the root\\nvar current=FS.root;var current_path='/';for(var i=0;i40){// limit max consecutive symlinks to 40 (SYMLOOP_MAX).\\nthrow new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ELOOP);}}}}return{path:current_path,node:current};},getPath:function getPath(node){var path;while(true){if(FS.isRoot(node)){return path?PATH.join(node.mount.mountpoint,path):node.mount.mountpoint;}path=path?PATH.join(node.name,path):node.name;node=node.parent;}},hashName:function hashName(parentid,name){var hash=0;for(var i=0;i>>0)%FS.nameTable.length;},hashAddNode:function hashAddNode(node){var hash=FS.hashName(node.parent.id,node.name);node.name_next=FS.nameTable[hash];FS.nameTable[hash]=node;},hashRemoveNode:function hashRemoveNode(node){var hash=FS.hashName(node.parent.id,node.name);if(FS.nameTable[hash]===node){FS.nameTable[hash]=node.name_next;}else{var current=FS.nameTable[hash];while(current){if(current.name_next===node){current.name_next=node.name_next;break;}current=current.name_next;}}},lookupNode:function lookupNode(parent,name){var err=FS.mayLookup(parent);if(err){throw new FS.ErrnoError(err,name);}var hash=FS.hashName(parent.id,name);for(var _node=FS.nameTable[hash];_node;_node=_node.name_next){var nodeName=_node.name;if(_node.parent.id===parent.id&&nodeName===name){return _node;}}// if we failed to find it in the cache, call into the VFS\\nreturn FS.lookup(parent,name);},createNode:function createNode(parent,name,mode,rdev){var node={id:FS.nextInode++,name:name,mode:mode,node_ops:{},stream_ops:{},rdev:rdev,parent:null,mount:null};if(!parent){parent=node;// root node sets parent to itself\\n}node.parent=parent;node.mount=parent.mount;// compatibility\\nvar readMode=292|73;var writeMode=146;// NOTE we must use Object.defineProperties instead of individual calls to\\n// Object.defineProperty in order to make closure compiler happy\\nObject.defineProperties(node,{read:{get:function get(){return(node.mode&readMode)===readMode;},set:function set(val){val?node.mode|=readMode:node.mode&=~readMode;}},write:{get:function get(){return(node.mode&writeMode)===writeMode;},set:function set(val){val?node.mode|=writeMode:node.mode&=~writeMode;}},isFolder:{get:function get(){return FS.isDir(node.mode);}},isDevice:{get:function get(){return FS.isChrdev(node.mode);}}});FS.hashAddNode(node);return node;},destroyNode:function destroyNode(node){FS.hashRemoveNode(node);},isRoot:function isRoot(node){return node===node.parent;},isMountpoint:function isMountpoint(node){return node.mounted;},isFile:function isFile(mode){return(mode&61440)===32768;},isDir:function isDir(mode){return(mode&61440)===16384;},isLink:function isLink(mode){return(mode&61440)===40960;},isChrdev:function isChrdev(mode){return(mode&61440)===8192;},isBlkdev:function isBlkdev(mode){return(mode&61440)===24576;},isFIFO:function isFIFO(mode){return(mode&61440)===4096;},isSocket:function isSocket(mode){return(mode&49152)===49152;},flagModes:{r:0,rs:1052672,'r+':2,w:577,wx:705,xw:705,'w+':578,'wx+':706,'xw+':706,a:1089,ax:1217,xa:1217,'a+':1090,'ax+':1218,'xa+':1218},modeStringToFlags:function modeStringToFlags(str){var flags=FS.flagModes[str];if(typeof flags==='undefined'){throw new Error('Unknown file open mode: '+str);}return flags;},flagsToPermissionString:function flagsToPermissionString(flag){var accmode=flag&2097155;var perms=['r','w','rw'][accmode];if(flag&512){perms+='w';}return perms;},nodePermissions:function nodePermissions(node,perms){if(FS.ignorePermissions){return 0;}// return 0 if any user, group or owner bits are set.\\nif(perms.indexOf('r')!==-1&&!(node.mode&292)){return LIBTIMIDITY_ERROR_CODES.EACCES;}else if(perms.indexOf('w')!==-1&&!(node.mode&146)){return LIBTIMIDITY_ERROR_CODES.EACCES;}else if(perms.indexOf('x')!==-1&&!(node.mode&73)){return LIBTIMIDITY_ERROR_CODES.EACCES;}return 0;},mayLookup:function mayLookup(dir){return FS.nodePermissions(dir,'x');},mayCreate:function mayCreate(dir,name){try{FS.lookupNode(dir,name);return LIBTIMIDITY_ERROR_CODES.EEXIST;}catch(e){}return FS.nodePermissions(dir,'wx');},mayDelete:function mayDelete(dir,name,isdir){var node;try{node=FS.lookupNode(dir,name);}catch(e){return e.errno;}var err=FS.nodePermissions(dir,'wx');if(err){return err;}if(isdir){if(!FS.isDir(node.mode)){return LIBTIMIDITY_ERROR_CODES.ENOTDIR;}if(FS.isRoot(node)||FS.getPath(node)===FS.cwd()){return LIBTIMIDITY_ERROR_CODES.EBUSY;}}else{if(FS.isDir(node.mode)){return LIBTIMIDITY_ERROR_CODES.EISDIR;}}return 0;},mayOpen:function mayOpen(node,flags){if(!node){return LIBTIMIDITY_ERROR_CODES.ENOENT;}if(FS.isLink(node.mode)){return LIBTIMIDITY_ERROR_CODES.ELOOP;}else if(FS.isDir(node.mode)){if((flags&2097155)!==0||// opening for write\\nflags&512){return LIBTIMIDITY_ERROR_CODES.EISDIR;}}return FS.nodePermissions(node,FS.flagsToPermissionString(flags));},MAX_OPEN_FDS:4096,nextfd:function nextfd(fd_start,fd_end){fd_start=fd_start||1;fd_end=fd_end||FS.MAX_OPEN_FDS;for(var fd=fd_start;fd<=fd_end;fd++){if(!FS.streams[fd]){return fd;}}throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EMFILE);},getStream:function getStream(fd){return FS.streams[fd];},createStream:function createStream(stream,fd_start,fd_end){var fd=FS.nextfd(fd_start,fd_end);stream.fd=fd;// compatibility\\nObject.defineProperties(stream,{object:{get:function get(){return stream.node;},set:function set(val){stream.node=val;}},isRead:{get:function get(){return(stream.flags&2097155)!==1;}},isWrite:{get:function get(){return(stream.flags&2097155)!==0;}},isAppend:{get:function get(){return stream.flags&1024;}}});FS.streams[fd]=stream;return stream;},closeStream:function closeStream(fd){FS.streams[fd]=null;},chrdev_stream_ops:{open:function open(stream){var device=FS.getDevice(stream.node.rdev);// override node's stream ops with the device's\\nstream.stream_ops=device.stream_ops;// forward the open call\\nif(stream.stream_ops.open){stream.stream_ops.open(stream);}},llseek:function llseek(){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ESPIPE);}},major:function major(dev){return dev>>8;},minor:function minor(dev){return dev&0xff;},makedev:function makedev(ma,mi){return ma<<8|mi;},registerDevice:function registerDevice(dev,ops){FS.devices[dev]={stream_ops:ops};},getDevice:function getDevice(dev){return FS.devices[dev];},syncfs:function syncfs(populate,callback){if(typeof populate==='function'){callback=populate;populate=false;}var completed=0;var total=FS.mounts.length;var done=function done(err){if(err){return callback(err);}if(++completed>=total){callback(null);}};// sync all mounts\\nfor(var i=0;i3&&arguments[3]!==undefined?arguments[3]:true;var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var error=FS.mayCreate(parent,name);if(error){if(throwError){throw new FS.ErrnoError(error,path);}return;}if(!parent.node_ops.mknod){if(throwError){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM,path);}return;}return parent.node_ops.mknod(parent,name,mode,dev);},create:function create(path,mode){var throwError=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;mode=mode!==undefined?mode:438;mode&=4095;mode|=32768;return FS.mknod(path,mode,0,throwError);},mkdir:function mkdir(path,mode){var throwError=arguments.length>2&&arguments[2]!==undefined?arguments[2]:true;mode=mode!==undefined?mode:511;mode&=511|512;mode|=16384;return FS.mknod(path,mode,0,throwError);},mkdev:function mkdev(path,mode,dev){if(typeof dev==='undefined'){dev=mode;mode=438;}mode|=8192;return FS.mknod(path,mode,dev);},symlink:function symlink(oldpath,newpath){var lookup=FS.lookupPath(newpath,{parent:true});var parent=lookup.node;var newname=PATH.basename(newpath);var err=FS.mayCreate(parent,newname);if(err){throw new FS.ErrnoError(err);}if(!parent.node_ops.symlink){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}return parent.node_ops.symlink(parent,newname,oldpath);},rename:function rename(old_path,new_path){var old_dirname=PATH.dirname(old_path);var new_dirname=PATH.dirname(new_path);var old_name=PATH.basename(old_path);var new_name=PATH.basename(new_path);// parents must exist\\nvar lookup,old_dir,new_dir;try{lookup=FS.lookupPath(old_path,{parent:true});old_dir=lookup.node;lookup=FS.lookupPath(new_path,{parent:true});new_dir=lookup.node;}catch(e){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBUSY);}// need to be part of the same mount\\nif(old_dir.mount!==new_dir.mount){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EXDEV);}// source must exist\\nvar old_node=FS.lookupNode(old_dir,old_name);// old path should not be an ancestor of the new path\\nvar relative=PATH.relative(old_path,new_dirname);if(relative.charAt(0)!=='.'){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}// new path should not be an ancestor of the old path\\nrelative=PATH.relative(new_path,old_dirname);if(relative.charAt(0)!=='.'){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOTEMPTY);}// see if the new path already exists\\nvar new_node;try{new_node=FS.lookupNode(new_dir,new_name);}catch(e){}// not fatal\\n// early out if nothing needs to change\\nif(old_node===new_node){return;}// we'll need to delete the old entry\\nvar isdir=FS.isDir(old_node.mode);var err=FS.mayDelete(old_dir,old_name,isdir);if(err){throw new FS.ErrnoError(err);}// need delete permissions if we'll be overwriting.\\n// need create permissions if new doesn't already exist.\\nerr=new_node?FS.mayDelete(new_dir,new_name,isdir):FS.mayCreate(new_dir,new_name);if(err){throw new FS.ErrnoError(err);}if(!old_dir.node_ops.rename){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}if(FS.isMountpoint(old_node)||new_node&&FS.isMountpoint(new_node)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBUSY);}// if we are going to change the parent, check write permissions\\nif(new_dir!==old_dir){err=FS.nodePermissions(old_dir,'w');if(err){throw new FS.ErrnoError(err);}}// remove the node from the lookup hash\\nFS.hashRemoveNode(old_node);// do the underlying fs rename\\ntry{old_dir.node_ops.rename(old_node,new_dir,new_name);}catch(e){throw e;}finally{// add the node back to the hash (in case node_ops.rename\\n// changed its name)\\nFS.hashAddNode(old_node);}},rmdir:function rmdir(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent,name,true);if(err){throw new FS.ErrnoError(err);}if(!parent.node_ops.rmdir){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}if(FS.isMountpoint(node)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBUSY);}parent.node_ops.rmdir(parent,name);FS.destroyNode(node);},readdir:function readdir(path){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;if(!node.node_ops.readdir){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOTDIR);}return node.node_ops.readdir(node);},unlink:function unlink(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent,name,false);if(err){// POSIX says unlink should set EPERM, not EISDIR\\nif(err===LIBTIMIDITY_ERROR_CODES.EISDIR)err=LIBTIMIDITY_ERROR_CODES.EPERM;throw new FS.ErrnoError(err);}if(!parent.node_ops.unlink){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}if(FS.isMountpoint(node)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBUSY);}parent.node_ops.unlink(parent,name);FS.destroyNode(node);},readlink:function readlink(path){var lookup=FS.lookupPath(path,{follow:false});var link=lookup.node;if(!link.node_ops.readlink){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}return link.node_ops.readlink(link);},stat:function stat(path,dontFollow){var lookup=FS.lookupPath(path,{follow:!dontFollow});var node=lookup.node;if(!node.node_ops.getattr){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}return node.node_ops.getattr(node);},lstat:function lstat(path){return FS.stat(path,true);},chmod:function chmod(path,mode,dontFollow){var node;if(typeof path==='string'){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node;}else{node=path;}if(!node.node_ops.setattr){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}node.node_ops.setattr(node,{mode:mode&4095|node.mode&~4095,timestamp:Date.now()});},lchmod:function lchmod(path,mode){FS.chmod(path,mode,true);},fchmod:function fchmod(fd,mode){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBADF);}FS.chmod(stream.node,mode);},chown:function chown(path,uid,gid,dontFollow){var node;if(typeof path==='string'){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node;}else{node=path;}if(!node.node_ops.setattr){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}node.node_ops.setattr(node,{timestamp:Date.now()// we ignore the uid / gid for now\\n});},lchown:function lchown(path,uid,gid){FS.chown(path,uid,gid,true);},fchown:function fchown(fd,uid,gid){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBADF);}FS.chown(stream.node,uid,gid);},truncate:function truncate(path,len){if(len<0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}var node;if(typeof path==='string'){var lookup=FS.lookupPath(path,{follow:true});node=lookup.node;}else{node=path;}if(!node.node_ops.setattr){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EPERM);}if(FS.isDir(node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EISDIR);}if(!FS.isFile(node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}var err=FS.nodePermissions(node,'w');if(err){throw new FS.ErrnoError(err);}node.node_ops.setattr(node,{size:len,timestamp:Date.now()});},ftruncate:function ftruncate(fd,len){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBADF);}if((stream.flags&2097155)===0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}FS.truncate(stream.node,len);},utime:function utime(path,atime,mtime){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;node.node_ops.setattr(node,{timestamp:Math.max(atime,mtime)});},open:function open(path,flags,mode,fd_start,fd_end){path=PATH.normalize(path);flags=typeof flags==='string'?FS.modeStringToFlags(flags):flags;mode=typeof mode==='undefined'?438:mode;if(flags&64){mode=mode&4095|32768;}else{mode=0;}var node;try{var lookup=FS.lookupPath(path,{follow:!(flags&131072)});node=lookup.node;}catch(e){}// ignore\\n// perhaps we need to create the node\\nif(flags&64){if(node){// if O_CREAT and O_EXCL are set, error out if the node already exists\\nif(flags&128){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EEXIST);}}else{// node doesn't exist, try to create it\\nnode=FS.mknod(path,mode,0);}}if(!node){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOENT);}// can't truncate a device\\nif(FS.isChrdev(node.mode)){flags&=~512;}// check permissions\\nvar err=FS.mayOpen(node,flags);if(err){throw new FS.ErrnoError(err);}// do truncation if necessary\\nif(flags&512){FS.truncate(node,0);}// we've already handled these, don't pass down to the underlying vfs\\nflags&=~(128|512);// register the stream with the filesystem\\nvar stream=FS.createStream({node:node,path:FS.getPath(node),// we want the absolute path to the node\\nflags:flags,seekable:true,position:0,stream_ops:node.stream_ops,// used by the file family libc calls (fopen, fwrite, ferror, etc.)\\nungotten:[],error:false},fd_start,fd_end);// call the new stream's open function\\nif(stream.stream_ops.open){stream.stream_ops.open(stream);}if(Module['logReadFiles']&&!(flags&1)){if(!FS.readFiles)FS.readFiles={};if(!(path in FS.readFiles)){FS.readFiles[path]=1;console.warn('read file: '+path);}}return stream;},close:function close(stream){try{if(stream.stream_ops.close){stream.stream_ops.close(stream);}}catch(e){throw e;}finally{FS.closeStream(stream.fd);}},llseek:function llseek(stream,offset,whence){if(!stream.seekable||!stream.stream_ops.llseek){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ESPIPE);}return stream.stream_ops.llseek(stream,offset,whence);},read:function read(stream,buffer,offset,length,position){if(length<0||position<0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}if((stream.flags&2097155)===1){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBADF);}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EISDIR);}if(!stream.stream_ops.read){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}var seeking=true;if(typeof position==='undefined'){position=stream.position;seeking=false;}else if(!stream.seekable){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ESPIPE);}var bytesRead=stream.stream_ops.read(stream,buffer,offset,length,position);if(!seeking)stream.position+=bytesRead;return bytesRead;},write:function write(stream,buffer,offset,length,position,canOwn){if(length<0||position<0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}if((stream.flags&2097155)===0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBADF);}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EISDIR);}if(!stream.stream_ops.write){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}var seeking=true;if(typeof position==='undefined'){position=stream.position;seeking=false;}else if(!stream.seekable){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ESPIPE);}if(stream.flags&1024){// seek to the end before writing in append mode\\nFS.llseek(stream,0,2);}var bytesWritten=stream.stream_ops.write(stream,buffer,offset,length,position,canOwn);if(!seeking)stream.position+=bytesWritten;return bytesWritten;},allocate:function allocate(stream,offset,length){if(offset<0||length<=0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EINVAL);}if((stream.flags&2097155)===0){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EBADF);}if(!FS.isFile(stream.node.mode)&&!FS.isDir(node.mode)){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENODEV);}if(!stream.stream_ops.allocate){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EOPNOTSUPP);}stream.stream_ops.allocate(stream,offset,length);},mmap:function mmap(stream,buffer,offset,length,position,prot,flags){// TODO if PROT is PROT_WRITE, make sure we have write access\\nif((stream.flags&2097155)===1){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EACCES);}if(!stream.stream_ops.mmap){throw new FS.errnoError(LIBTIMIDITY_ERROR_CODES.ENODEV);}return stream.stream_ops.mmap(stream,buffer,offset,length,position,prot,flags);},ioctl:function ioctl(stream,cmd,arg){if(!stream.stream_ops.ioctl){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.ENOTTY);}return stream.stream_ops.ioctl(stream,cmd,arg);},readFile:function readFile(path,opts){opts=opts||{};opts.flags=opts.flags||'r';opts.encoding=opts.encoding||'binary';var ret;var stream=FS.open(path,opts.flags);var stat=FS.stat(path);var length=stat.size;var buf=new Uint8Array(length);FS.read(stream,buf,0,length,0);if(opts.encoding==='utf8'){ret='';var utf8=new Runtime.UTF8Processor();for(var i=0;i>2]=stdin.fd;assert(stdin.fd===1,'invalid handle for stdin ('+stdin.fd+')');var stdout=FS.open('/dev/stdout','w');HEAP32[_stdout>>2]=stdout.fd;assert(stdout.fd===2,'invalid handle for stdout ('+stdout.fd+')');var stderr=FS.open('/dev/stderr','w');HEAP32[_stderr>>2]=stderr.fd;assert(stderr.fd===3,'invalid handle for stderr ('+stderr.fd+')');},staticInit:function staticInit(){FS.nameTable=new Array(4096);FS.root=FS.createNode(null,'/',16384|511,0);FS.mount(MEMFS,{},'/');FS.createDefaultDirectories();FS.createDefaultDevices();},init:function init(input,output,error){assert(!FS.init.initialized,'FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)');FS.init.initialized=true;// Allow Module.stdin etc. to provide defaults, if none explicitly passed to us here\\nModule['stdin']=input||Module['stdin'];Module['stdout']=output||Module['stdout'];Module['stderr']=error||Module['stderr'];FS.createStandardStreams();},quit:function quit(){FS.init.initialized=false;for(var i=0;i2&&arguments[2]!==undefined?arguments[2]:true;var parts=path.split('/').reverse();while(parts.length){var part=parts.pop();if(!part){continue;}var current=PATH.join(parent,part);try{FS.mkdir(current,undefined,throwError);}catch(error){// console.error(error)\\n}parent=current;}},/**\\n * Creates a file.\\n * @function createFile\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} parent The parent folder.\\n * @param {string} name The path to create.\\n * @param {boolean} canRead\\n * @param {boolean} canWrite\\n */createFile:function createFile(parent,name,canRead,canWrite){var path=PATH.join(typeof parent==='string'?parent:FS.getPath(parent),name);var mode=FS.getMode(canRead,canWrite);return FS.create(path,mode);},/**\\n * Creates a data file and writes data to it.\\n * @function createDataFile\\n * @memberof LibTiMidity\\n * @instance\\n * @param {string} parent\\n * @param {string} name\\n * @param {array} data\\n * @param {boolean} canRead\\n * @param {boolean} canWrite\\n * @param {boolean} [canOwn]\\n * @param {boolean} [throwError = true] If file creation failed, throw an error.\\n */createDataFile:function createDataFile(parent,name,data,canRead,canWrite,canOwn){var throwError=arguments.length>6&&arguments[6]!==undefined?arguments[6]:true;var path=name?PATH.join(typeof parent==='string'?parent:FS.getPath(parent),name):parent;var mode=FS.getMode(canRead,canWrite);if(throwError){FS.create(path,mode);}else{try{FS.create(path,mode);}catch(error){return;}}if(data){if(typeof data==='string'){var arr=new Array(data.length);for(var i=0,len=data.length;i>2];path=Pointer_stringify(path);try{var stream=FS.open(path,oflag,mode);return stream.fd;}catch(e){FS.handleFSError(e);return-1;}}function _fopen(filename,mode){// FILE *fopen(const char *restrict filename, const char *restrict mode);\\n// http://pubs.opengroup.org/onlinepubs/000095399/functions/fopen.html\\nvar flags;mode=Pointer_stringify(mode);if(mode[0]=='r'){if(mode.indexOf('+')!=-1){flags=2;}else{flags=0;}}else if(mode[0]=='w'){if(mode.indexOf('+')!=-1){flags=2;}else{flags=1;}flags|=64;flags|=512;}else if(mode[0]=='a'){if(mode.indexOf('+')!=-1){flags=2;}else{flags=1;}flags|=64;flags|=1024;}else{___setErrNo(LIBTIMIDITY_ERROR_CODES.EINVAL);return 0;}var ret=_open(filename,flags,allocate([0x1ff,0,0,0],'i32',ALLOC_STACK));// All creation permissions.\\nreturn ret==-1?0:ret;}Module['_strlen']=_strlen;Module['_strcpy']=_strcpy;Module['_strcat']=_strcat;var SOCKFS={mount:function mount(){return FS.createNode(null,'/',16384|511,0);},createSocket:function createSocket(family,type,protocol){var streaming=type==1;if(protocol){assert(streaming==(protocol==6));// if SOCK_STREAM, must be tcp\\n}// create our internal socket structure\\nvar sock={family:family,type:type,protocol:protocol,server:null,peers:{},pending:[],recv_queue:[],sock_ops:SOCKFS.websocket_sock_ops};// create the filesystem node to store the socket structure\\nvar name=SOCKFS.nextname();var node=FS.createNode(SOCKFS.root,name,49152,0);node.sock=sock;// and the wrapping stream that enables library functions such as read and write to indirectly interact with the socket\\nvar stream=FS.createStream({path:name,node:node,flags:FS.modeStringToFlags('r+'),seekable:false,stream_ops:SOCKFS.stream_ops});// map the new stream to the socket structure (sockets have a 1:1 relationship with a stream)\\nsock.stream=stream;return sock;},getSocket:function getSocket(fd){var stream=FS.getStream(fd);if(!stream||!FS.isSocket(stream.node.mode)){return null;}return stream.node.sock;},stream_ops:{poll:function poll(stream){var sock=stream.node.sock;return sock.sock_ops.poll(sock);},ioctl:function ioctl(stream,request,varargs){var sock=stream.node.sock;return sock.sock_ops.ioctl(sock,request,varargs);},read:function read(stream,buffer,offset,length){var sock=stream.node.sock;var msg=sock.sock_ops.recvmsg(sock,length);if(!msg){// socket is closed\\nreturn 0;}buffer.set(msg.buffer,offset);return msg.buffer.length;},write:function write(stream,buffer,offset,length){var sock=stream.node.sock;return sock.sock_ops.sendmsg(sock,buffer,offset,length);},close:function close(stream){var sock=stream.node.sock;sock.sock_ops.close(sock);}},nextname:function nextname(){if(!SOCKFS.nextname.current){SOCKFS.nextname.current=0;}return'socket['+SOCKFS.nextname.current++ +']';},websocket_sock_ops:{createPeer:function createPeer(sock,addr,port){var ws;if(typeof_default()(addr)==='object'){ws=addr;addr=null;port=null;}if(ws){// for sockets that've already connected (e.g. we're the server) we can inspect the _socket property for the address\\nif(ws._socket){addr=ws._socket.remoteAddress;port=ws._socket.remotePort;}// if we're just now initializing a connection to the remote, inspect the url property\\nelse{var result=/ws[s]?:\\\\/\\\\/([^:]+):(\\\\d+)/.exec(ws.url);if(!result){throw new Error('WebSocket URL must be in the format ws(s)://address:port');}addr=result[1];port=parseInt(result[2],10);}}else{// create the actual websocket object and connect\\ntry{var url='ws://'+addr+':'+port;// the node ws library API is slightly different than the browser's\\nvar opts=['binary'];ws=new WebSocket(url,opts);ws.binaryType='arraybuffer';}catch(e){throw new FS.ErrnoError(LIBTIMIDITY_ERROR_CODES.EHOSTUNREACH);}}var peer={addr:addr,port:port,socket:ws,dgram_send_queue:[]};SOCKFS.websocket_sock_ops.addPeer(sock,peer);SOCKFS.websocket_sock_ops.handlePeerEvents(sock,peer);// if this is a bound dgram socket, send the port number first to allow\\n// us to override the ephemeral port reported to us by remotePort on the\\n// remote end.\\nif(sock.type===2&&typeof sock.sport!=='undefined'){peer.dgram_send_queue.push(new Uint8Array([255,255,255,255,'p'.charCodeAt(0),'o'.charCodeAt(0),'r'.charCodeAt(0),'t'.charCodeAt(0),(sock.sport&0xff00)>>8,sock.sport&0xff]));}return peer;},getPeer:function getPeer(sock,addr,port){return sock.peers[addr+':'+port];},addPeer:function addPeer(sock,peer){sock.peers[peer.addr+':'+peer.port]=peer;},removePeer:function removePeer(sock,peer){delete sock.peers[peer.addr+':'+peer.port];},handlePeerEvents:function handlePeerEvents(sock,peer){var first=true;var handleOpen=function handleOpen(){try{var queued=peer.dgram_send_queue.shift();while(queued){peer.socket.send(queued);queued=peer.dgram_send_queue.shift();}}catch(e){// not much we can do here in the way of proper error handling as we've already\\n// lied and said this data was sent. shut it down.\\npeer.socket.close();}};var handleMessage=function handleMessage(data){assert(typeof data!=='string'&&data.byteLength!==undefined);// must receive an ArrayBuffer\\ndata=new Uint8Array(data);// make a typed array view on the array buffer\\n// if this is the port message, override the peer's port with it\\nvar wasfirst=first;first=false;if(wasfirst&&data.length===10&&data[0]===255&&data[1]===255&&data[2]===255&&data[3]===255&&data[4]==='p'.charCodeAt(0)&&data[5]==='o'.charCodeAt(0)&&data[6]==='r'.charCodeAt(0)&&data[7]==='t'.charCodeAt(0)){// update the peer's port and it's key in the peer map\\nvar newport=data[8]<<8|data[9];SOCKFS.websocket_sock_ops.removePeer(sock,peer);peer.port=newport;SOCKFS.websocket_sock_ops.addPeer(sock,peer);return;}sock.recv_queue.push({addr:peer.addr,port:peer.port,data:data});};peer.socket.onopen=handleOpen;peer.socket.onmessage=function(event){handleMessage(event.data);};},poll:function poll(sock){if(sock.type===1&&sock.server){// listen sockets should only say they're available for reading\\n// if there are pending clients.\\nreturn sock.pending.length?64|1:0;}var mask=0;var dest=sock.type===1// we only care about the socket state for connection-based sockets\\n?SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dport):null;if(sock.recv_queue.length||!dest||// connection-less sockets are always ready to read\\ndest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){// let recv return 0 once closed\\nmask|=64|1;}if(!dest||// connection-less sockets are always ready to write\\ndest&&dest.socket.readyState===dest.socket.OPEN){mask|=4;}if(dest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){mask|=16;}return mask;},ioctl:function ioctl(sock,request,arg){switch(request){case 21531:var bytes=0;if(sock.recv_queue.length){bytes=sock.recv_queue[0].data.length;}HEAP32[arg>>2]=bytes;return 0;default:return LIBTIMIDITY_ERROR_CODES.EINVAL;}},close:function close(sock){// if we've spawned a listen server, close it\\nif(sock.server){try{sock.server.close();}catch(e){}sock.server=null;}// close any peer connections\\nvar peers=Object.keys(sock.peers);for(var i=0;i>3];}else if(type=='i64'){ret=[HEAP32[varargs+argIndex>>2],HEAP32[varargs+(argIndex+8)>>2]];argIndex+=8;// each 32-bit chunk is in a 64-bit block\\n}else{type='i32';// varargs are always i32, i64, or double\\nret=HEAP32[varargs+argIndex>>2];}argIndex+=Math.max(Runtime.getNativeFieldSize(type),Runtime.getAlignSize(type,null,true));return ret;}var ret=[];var curr,next,currArg;while(1){var startTextIndex=textIndex;curr=HEAP8[textIndex];if(curr===0)break;next=HEAP8[textIndex+1|0];if(curr==37){// Handle flags.\\nvar flagAlwaysSigned=false;var flagLeftAlign=false;var flagAlternative=false;var flagZeroPad=false;var flagPadSign=false;flagsLoop:while(1){switch(next){case 43:flagAlwaysSigned=true;break;case 45:flagLeftAlign=true;break;case 35:flagAlternative=true;break;case 48:if(flagZeroPad){break flagsLoop;}else{flagZeroPad=true;break;}case 32:flagPadSign=true;break;default:break flagsLoop;}textIndex++;next=HEAP8[textIndex+1|0];}// Handle width.\\nvar width=0;if(next==42){width=getNextArg('i32');textIndex++;next=HEAP8[textIndex+1|0];}else{while(next>=48&&next<=57){width=width*10+(next-48);textIndex++;next=HEAP8[textIndex+1|0];}}// Handle precision.\\nvar precisionSet=false;if(next==46){var precision=0;precisionSet=true;textIndex++;next=HEAP8[textIndex+1|0];if(next==42){precision=getNextArg('i32');textIndex++;}else{while(1){var precisionChr=HEAP8[textIndex+1|0];if(precisionChr<48||precisionChr>57)break;precision=precision*10+(precisionChr-48);textIndex++;}}next=HEAP8[textIndex+1|0];}else{var precision=6;// Standard default.\\n}// Handle integer sizes. WARNING: These assume a 32-bit architecture!\\nvar argSize=void 0;switch(String.fromCharCode(next)){case'h':var nextNext=HEAP8[textIndex+2|0];if(nextNext==104){textIndex++;argSize=1;// char (actually i32 in varargs)\\n}else{argSize=2;// short (actually i32 in varargs)\\n}break;case'l':var nextNext=HEAP8[textIndex+2|0];if(nextNext==108){textIndex++;argSize=8;// long long\\n}else{argSize=4;// long\\n}break;case'L':// long long\\ncase'q':// int64_t\\ncase'j':// intmax_t\\nargSize=8;break;case'z':// size_t\\ncase't':// ptrdiff_t\\ncase'I':// signed ptrdiff_t or unsigned size_t\\nargSize=4;break;default:argSize=null;}if(argSize)textIndex++;next=HEAP8[textIndex+1|0];// Handle type specifier.\\nswitch(String.fromCharCode(next)){case'd':case'i':case'u':case'o':case'x':case'X':case'p':{// Integer.\\nvar signed=next==100||next==105;argSize=argSize||4;var currArg=getNextArg('i'+argSize*8);var origArg=currArg;var argText;// Flatten i64-1 [low, high] into a (slightly rounded) double\\nif(argSize==8){currArg=Runtime.makeBigInt(currArg[0],currArg[1],next==117);}// Truncate to requested size.\\nif(argSize<=4){var limit=Math.pow(256,argSize)-1;currArg=(signed?reSign:unSign)(currArg&limit,argSize*8);}// Format the number.\\nvar currAbsArg=Math.abs(currArg);var prefix='';if(next==100||next==105){if(argSize==8&&i64Math)argText=i64Math.stringify(origArg[0],origArg[1],null);else argText=reSign(currArg,8*argSize,1).toString(10);}else if(next==117){if(argSize==8&&i64Math)argText=i64Math.stringify(origArg[0],origArg[1],true);else argText=unSign(currArg,8*argSize,1).toString(10);currArg=Math.abs(currArg);}else if(next==111){argText=(flagAlternative?'0':'')+currAbsArg.toString(8);}else if(next==120||next==88){prefix=flagAlternative&&currArg!=0?'0x':'';if(argSize==8&&i64Math){if(origArg[1]){argText=(origArg[1]>>>0).toString(16);var lower=(origArg[0]>>>0).toString(16);while(lower.length<8){lower='0'+lower;}argText+=lower;}else{argText=(origArg[0]>>>0).toString(16);}}else if(currArg<0){// Represent negative numbers in hex as 2's complement.\\ncurrArg=-currArg;argText=(currAbsArg-1).toString(16);var _buffer=[];for(var i=0;i=0){if(flagAlwaysSigned){prefix='+'+prefix;}else if(flagPadSign){prefix=' '+prefix;}}// Move sign to prefix so we zero-pad after the sign\\nif(argText.charAt(0)=='-'){prefix='-'+prefix;argText=argText.substr(1);}// Add padding.\\nwhile(prefix.length+argText.lengthexponent&&exponent>=-4){next=(next==103?'f':'F').charCodeAt(0);precision-=exponent+1;}else{next=(next==103?'e':'E').charCodeAt(0);precision--;}effectivePrecision=Math.min(precision,20);}if(next==101||next==69){argText=currArg.toExponential(effectivePrecision);// Make sure the exponent has at least 2 digits.\\nif(/[eE][-+]\\\\d$/.test(argText)){argText=argText.slice(0,-1)+'0'+argText.slice(-1);}}else if(next==102||next==70){argText=currArg.toFixed(effectivePrecision);if(currArg===0&&__reallyNegative(currArg)){argText='-'+argText;}}var parts=argText.split('e');if(isGeneral&&!flagAlternative){// Discard trailing zeros and periods.\\nwhile(parts[0].length>1&&parts[0].indexOf('.')!=-1&&(parts[0].slice(-1)=='0'||parts[0].slice(-1)=='.')){parts[0]=parts[0].slice(0,-1);}}else{// Make sure we have a period in alternative mode.\\nif(flagAlternative&&argText.indexOf('.')==-1)parts[0]+='.';// Zero pad until required precision.\\nwhile(precision>effectivePrecision++){parts[0]+='0';}}argText=parts[0]+(parts.length>1?'e'+parts[1]:'');// Capitalize 'E' if needed.\\nif(next==69)argText=argText.toUpperCase();// Add sign.\\nif(currArg>=0){if(flagAlwaysSigned){argText='+'+argText;}else if(flagPadSign){argText=' '+argText;}}}// Add padding.\\nwhile(argText.length0){ret.push(32);}if(!flagLeftAlign)ret.push(getNextArg('i8'));break;}case'n':{// Write the length written so far to the next parameter.\\nvar ptr=getNextArg('i32*');HEAP32[ptr>>2]=ret.length;break;}case'%':{// Literal percent sign.\\nret.push(curr);break;}default:{// Unknown specifiers remain untouched.\\nfor(var i=startTextIndex;i0){HEAP8[ptr++|0]=streamObj.ungotten.pop();bytesToRead--;bytesRead++;}var err=_read(stream,ptr,bytesToRead);if(err==-1){if(streamObj)streamObj.error=true;return 0;}bytesRead+=err;if(bytesRead>2];return _fprintf(stdout,format,varargs);}Module['_memset']=_memset;Module['_memcpy']=_memcpy;var _llvm_pow_f64=Math_pow;var _sin=Math_sin;function _strrchr(ptr,chr){var ptr2=ptr+_strlen(ptr);do{if(HEAP8[ptr2]==chr)return ptr2;ptr2--;}while(ptr2>=ptr);return 0;}var ___strtok_state=0;function _strtok_r(s,delim,lasts){var skip_leading_delim=1;var spanp;var c,sc;var tok;if(s==0&&(s=getValue(lasts,'i8*'))==0){return 0;}cont:while(1){c=getValue(s++,'i8');for(spanp=delim;(sc=getValue(spanp++,'i8'))!=0;){if(c==sc){if(skip_leading_delim){continue cont;}else{setValue(lasts,s,'i8*');setValue(s-1,0,'i8');return s-1;}}}break;}if(c==0){setValue(lasts,0,'i8*');return 0;}tok=s-1;for(;;){c=getValue(s++,'i8');spanp=delim;do{if((sc=getValue(spanp++,'i8'))==c){if(c==0){s=0;}else{setValue(s-1,0,'i8');}setValue(lasts,s,'i8*');return tok;}}while(sc!=0);}abort('strtok_r error!');}function _strtok(s,delim){return _strtok_r(s,delim,___strtok_state);}function _strncmp(px,py,n){var i=0;while(iy?1:-1;}}return 0;}function _strcmp(px,py){return _strncmp(px,py,TOTAL_MEMORY);}Module['_strncpy']=_strncpy;function _isspace(chr){return chr==32||chr>=9&&chr<=13;}function __parseInt(str,endptr,base,min,max,bits,unsign){// Skip space.\\nwhile(_isspace(HEAP8[str])){str++;}// Check for a plus/minus sign.\\nvar multiplier=1;if(HEAP8[str]==45){multiplier=-1;str++;}else if(HEAP8[str]==43){str++;}// Find base.\\nvar finalBase=base;if(!finalBase){if(HEAP8[str]==48){if(HEAP8[str+1|0]==120||HEAP8[str+1|0]==88){finalBase=16;str+=2;}else{finalBase=8;str++;}}}else if(finalBase==16){if(HEAP8[str]==48){if(HEAP8[str+1|0]==120||HEAP8[str+1|0]==88){str+=2;}}}if(!finalBase)finalBase=10;// Get digits.\\nvar chr;var ret=0;while((chr=HEAP8[str])!=0){var digit=parseInt(String.fromCharCode(chr),finalBase);if(isNaN(digit)){break;}else{ret=ret*finalBase+digit;str++;}}// Apply sign.\\nret*=multiplier;// Set end pointer.\\nif(endptr){HEAP32[endptr>>2]=str;}// Unsign if needed.\\nif(unsign){if(Math.abs(ret)>max){ret=max;___setErrNo(LIBTIMIDITY_ERROR_CODES.ERANGE);}else{ret=unSign(ret,bits);}}// Validate range.\\nif(ret>max||retmax?max:min;___setErrNo(LIBTIMIDITY_ERROR_CODES.ERANGE);}if(bits==64){return(asm['setTempRet0']((tempDouble=ret,+Math_abs(tempDouble)>=+1?tempDouble>+0?(Math_min(+Math_floor(tempDouble/+4294967296),+4294967295)|0)>>>0:~~+Math_ceil((tempDouble-+(~~tempDouble>>>0))/+4294967296)>>>0:0)),ret>>>0)|0;}return ret;}function _strtol(str,endptr,base){return __parseInt(str,endptr,base,-2147483648,2147483647,32);// LONG_MIN, LONG_MAX.\\n}function _atoi(ptr){return _strtol(ptr,null,10);}function _strchr(ptr,chr){ptr--;do{ptr++;var val=HEAP8[ptr];if(val==chr)return ptr;}while(val);return 0;}function _abort(){Module['abort']();}function ___errno_location(){return ___errno_state;}function _sbrk(bytes){/*\\n Implement a Linux-like 'memory area' for our 'process'.\\n Changes the size of the memory area by |bytes|.\\n Returns the address of the previous top ('break') of the memory area.\\n We control the \\\"dynamic\\\" memory - DYNAMIC_BASE to DYNAMICTOP.\\n */var self=_sbrk;if(!self.called){DYNAMICTOP=alignMemoryPage(DYNAMICTOP);// make sure we start out aligned\\nself.called=true;assert(Runtime.dynamicAlloc);self.alloc=Runtime.dynamicAlloc;Runtime.dynamicAlloc=function(){abort('cannot dynamically allocate, sbrk now has control');};}var ret=DYNAMICTOP;if(bytes!=0)self.alloc(bytes);return ret;// Previous break location.\\n}function _sysconf(name){// long sysconf(int name);\\n// http://pubs.opengroup.org/onlinepubs/009695399/functions/sysconf.html\\nswitch(name){case 30:return PAGE_SIZE;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 80:case 81:case 79:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1000;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:return 1;}___setErrNo(LIBTIMIDITY_ERROR_CODES.EINVAL);return-1;}function _time(ptr){var ret=Math.floor(Date.now()/1000);if(ptr){HEAP32[ptr>>2]=ret;}return ret;}FS.staticInit();__ATINIT__.unshift({func:function func(){if(!Module['noFSInit']&&!FS.init.initialized)FS.init();}});__ATMAIN__.push({func:function func(){FS.ignorePermissions=false;}});__ATEXIT__.push({func:function func(){FS.quit();}});Module['FS_createFolder']=FS.createFolder;Module.createPath=FS.createPath;Module.createDataFile=FS.createDataFile;Module.loadPatchFromUrl=FS.loadPatchFromUrl;Module['FS_createPreloadedFile']=FS.createPreloadedFile;Module['FS_createLink']=FS.createLink;Module['FS_createDevice']=FS.createDevice;___errno_state=Runtime.staticAlloc(4);HEAP32[___errno_state>>2]=0;__ATINIT__.unshift({func:function func(){TTY.init();}});__ATEXIT__.push({func:function func(){TTY.shutdown();}});TTY.utf8=new Runtime.UTF8Processor();__ATINIT__.push({func:function func(){SOCKFS.root=FS.mount(SOCKFS,{},null);}});___strtok_state=Runtime.staticAlloc(4);STACK_BASE=STACKTOP=Runtime.alignMemory(STATICTOP);STACK_MAX=STACK_BASE+5242880;DYNAMIC_BASE=DYNAMICTOP=Runtime.alignMemory(STACK_MAX);assert(DYNAMIC_BASE>2]|0)|0;if((l|0)!=0){m=e|0;n=c[b>>2]|0;c2(m|0,n|0)|0;if((a[e+(l-1)|0]|0)!=47){a[e+l|0]=47;a[e+(l+1)|0]=0;}}c3(e|0,f|0)|0;l=av(e|0,6576)|0;g=l;if((l|0)!=0){break;}b=c[b+4>>2]|0;}if((k|0)==16){break;}h=g;j=h;i=d;return j|0;}}while(0);h=0;j=h;i=d;return j|0;}}while(0);h=0;j=h;i=d;return j|0;}function bi(a){a=a|0;var b=0;b=c$(a)|0;return b|0;}function bj(a){a=a|0;var b=0,d=0,e=0;b=a;a=bi(8)|0;if((a|0)==0){return;}c[a>>2]=bi((c1(b|0)|0)+1|0)|0;if((c[a>>2]|0)==0){c0(a);return;}else{d=c[a>>2]|0;e=b;c2(d|0,e|0)|0;c[a+4>>2]=c[1664];c[1664]=a;return;}}function bk(){var a=0,b=0;a=c[1664]|0;while(1){if((a|0)==0){break;}b=c[a+4>>2]|0;c0(c[a>>2]|0);c0(a);a=b;}c[1664]=0;return;}function bl(f,h,j,k,l,n,o,p,q){f=f|0;h=h|0;j=j|0;k=k|0;l=l|0;n=n|0;o=o|0;p=p|0;q=q|0;var r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0;j=i;i=i+1056|0;r=j|0;s=j+1024|0;t=j+1032|0;u=j+1040|0;v=j+1048|0;w=f;f=h;h=k;k=l;l=n;n=o;o=p;p=q;q=0;if((f|0)==0){x=0;y=x;i=j;return y|0;}z=bh(f)|0;A=z;if((z|0)==0){z=c[m>>2]|0;// _fprintf;\\nar(6512,(z=i,i=i+1|0,i=i+7&-8,c[z>>2]=0,z)|0)|0;i=z;q=1;B=0;while(1){if((c[1048+(B<<2)>>2]|0)==0){break;}z=c1(f|0)|0;if((z+(c1(c[1048+(B<<2)>>2]|0)|0)|0)>>>0<1024){z=r|0;C=f;c2(z|0,C|0)|0;C=r|0;z=c[1048+(B<<2)>>2]|0;c3(C|0,z|0)|0;z=bh(r|0)|0;A=z;if((z|0)!=0){D=46;break;}}B=B+1|0;}if((D|0)==46){q=0;f=r|0;}}if((q|0)!=0){x=0;y=x;i=j;return y|0;}do{if(239==(an(r|0,1,239,A|0)|0)){if((c4(r|0,6248,22)|0)!=0){if((c4(r|0,5888,22)|0)!=0){break;}}do{if((a[r+82|0]|0)!=1){if((a[r+82|0]|0)==0){break;}x=0;y=x;i=j;return y|0;}}while(0);do{if((a[r+151|0]|0)!=1){if((a[r+151|0]|0)==0){break;}x=0;y=x;i=j;return y|0;}}while(0);q=bi(8)|0;c[q>>2]=a[r+198|0]|0;c[q+4>>2]=bi((c[q>>2]|0)*116|0)|0;B=0;while(1){if((B|0)>=(c[q>>2]|0)){D=162;break;}aB(A|0,7,1)|0;if(1!=(an(s|0,1,1,A|0)|0)){D=66;break;}f=(c[q+4>>2]|0)+(B*116|0)|0;if(1!=(an(t|0,4,1,A|0)|0)){D=73;break;}c[f+8>>2]=c[t>>2];if(1!=(an(t|0,4,1,A|0)|0)){D=75;break;}c[f>>2]=c[t>>2];if(1!=(an(t|0,4,1,A|0)|0)){D=77;break;}c[f+4>>2]=c[t>>2];if(1!=(an(u|0,2,1,A|0)|0)){D=79;break;}c[f+12>>2]=e[u>>1]|0;if(1!=(an(t|0,4,1,A|0)|0)){D=81;break;}c[f+24>>2]=c[t>>2];if(1!=(an(t|0,4,1,A|0)|0)){D=83;break;}c[f+28>>2]=c[t>>2];if(1!=(an(t|0,4,1,A|0)|0)){D=85;break;}c[f+32>>2]=c[t>>2];c[f+16>>2]=0;c[f+20>>2]=127;aB(A|0,2,1)|0;if(1!=(an(v|0,1,1,A|0)|0)){D=87;break;}a[r|0]=a[v]|0;if((h|0)==-1){a[f+111|0]=(a[r|0]<<3)+4&127;}else{a[f+111|0]=h&127;}if(18!=(an(r|0,1,18,A|0)|0)){D=92;break;}do{if((a[r+13|0]|0)!=0){if((a[r+14|0]|0)==0){D=95;break;}c[f+92>>2]=bm(w,a[r+12|0]|0)|0;c[f+96>>2]=bn(w,a[r+13|0]|0)|0;a[f+108|0]=a[r+14|0]|0;}else{D=95;}}while(0);if((D|0)==95){D=0;a[f+108|0]=0;c[f+96>>2]=0;c[f+92>>2]=0;}do{if((a[r+16|0]|0)!=0){if((a[r+17|0]|0)==0){D=99;break;}c[f+104>>2]=bo(w,a[r+16|0]|0)|0;c[f+100>>2]=bp(w,a[r+15|0]|0,c[f+104>>2]|0)|0;a[f+109|0]=a[r+17|0]|0;}else{D=99;}}while(0);if((D|0)==99){D=0;a[f+109|0]=0;c[f+104>>2]=0;c[f+100>>2]=0;}if(1!=(an(v|0,1,1,A|0)|0)){D=102;break;}a[f+110|0]=a[v]|0;aB(A|0,40,1)|0;if((l|0)!=-1){a[f+112|0]=l&255;}else{a[f+112|0]=0;}if((a[f+110|0]&4|0)!=0){z=f+110|0;a[z]=(d[z]|32)&255;}do{if((n|0)==1){if((a[f+110|0]&60|0)==0){break;}z=f+110|0;a[z]=d[z]&-61&255;}}while(0);if((o|0)==1){(a[f+110|0]&64|0)!=0;z=f+110|0;a[z]=d[z]&-65&255;}else{if((o|0)!=0){if((a[f+110|0]&28|0)!=0){do{if((c4(r|0,5512,6)|0)!=0){if((a[r+11|0]|0)>=100){D=120;break;}if((a[f+110|0]&32|0)==0){z=f+110|0;a[z]=d[z]&-65&255;}}else{D=120;}}while(0);if((D|0)==120){D=0;z=f+110|0;a[z]=d[z]&-65&255;}}else{z=f+110|0;a[z]=d[z]&-97&255;}}}E=0;while(1){if((E|0)>=6){break;}c[f+36+(E<<2)>>2]=bq(w,a[r+E|0]|0)|0;c[f+60+(E<<2)>>2]=br(a[r+(E+6)|0]|0)|0;E=E+1|0;}c[f+88>>2]=bi(c[f+8>>2]|0)|0;if(1!=(an(c[f+88>>2]|0,c[f+8>>2]|0,1,A|0)|0)){D=132;break;}if((a[f+110|0]&1|0)==0){z=c[f+8>>2]|0;C=c[f+88>>2]|0;F=bi(c[f+8>>2]<<1)|0;G=F;H=F;while(1){F=z;z=F-1|0;if((F|0)==0){break;}F=C;C=F+1|0;I=H;H=I+2|0;b[I>>1]=(a[F]&255)<<8&65535;}C=c[f+88>>2]|0;c[f+88>>2]=G;c0(C);H=f+8|0;c[H>>2]=c[H>>2]<<1;H=f|0;c[H>>2]=c[H>>2]<<1;H=f+4|0;c[H>>2]=c[H>>2]<<1;}if((a[f+110|0]&2|0)!=0){H=(c[f+8>>2]|0)/2|0;z=c[f+88>>2]|0;while(1){F=H;H=F-1|0;if((F|0)==0){break;}F=z;z=F+2|0;b[F>>1]=(b[F>>1]^32768)&65535;}}if((a[f+110|0]&16|0)!=0){bs(c[f+88>>2]|0,0,(c[f+8>>2]|0)/2|0);z=c[f>>2]|0;c[f>>2]=(c[f+8>>2]|0)-(c[f+4>>2]|0);c[f+4>>2]=(c[f+8>>2]|0)-z;z=f+110|0;a[z]=d[z]&-17&255;z=f+110|0;a[z]=(d[z]|4)&255;}if((k|0)!=-1){g[f+84>>2]=+(k|0)/100.0;}else{z=(c[f+8>>2]|0)/2|0;H=0;C=c[f+88>>2]|0;while(1){G=z;z=G-1|0;if((G|0)==0){break;}G=C;C=G+2|0;F=b[G>>1]|0;if((F<<16>>16|0)<0){F=-(F<<16>>16)&65535;}if((F<<16>>16|0)>(H<<16>>16|0)){H=F;}}g[f+84>>2]=32768.0/+(H<<16>>16|0);}C=f+8|0;c[C>>2]=(c[C>>2]|0)/2|0;C=f|0;c[C>>2]=(c[C>>2]|0)/2|0;C=f+4|0;c[C>>2]=(c[C>>2]|0)/2|0;C=f+8|0;c[C>>2]=c[C>>2]<<12;C=f|0;c[C>>2]=c[C>>2]<<12;C=f+4|0;c[C>>2]=c[C>>2]<<12;C=f|0;c[C>>2]=c[C>>2]|(a[s]&15)<<8;C=f+4|0;c[C>>2]=c[C>>2]|(d[s]>>4&15)<<8;do{if((a[f+112|0]|0)!=0){if((a[f+110|0]&4|0)!=0){break;}cF(w,f);}}while(0);if((p|0)==1){c[f+8>>2]=c[f+4>>2];}B=B+1|0;}if((D|0)!=66)if((D|0)!=73)if((D|0)!=75)if((D|0)!=77)if((D|0)!=79)if((D|0)!=81)if((D|0)!=83)if((D|0)!=85)if((D|0)!=87)if((D|0)!=92)if((D|0)!=102)if((D|0)!=132)if((D|0)==162){ao(A|0)|0;x=q;y=x;i=j;return y|0;}E=0;while(1){if((E|0)>=(B|0)){break;}c0(c[(c[q+4>>2]|0)+(E*116|0)+88>>2]|0);E=E+1|0;}c0(c[q+4>>2]|0);c0(q);x=0;y=x;i=j;return y|0;}}while(0);x=0;y=x;i=j;return y|0;}function bm(a,b){a=a|0;b=b|0;var d=0,e=0,f=0;d=a;a=b;if(a<<24>>24!=0){b=((c[d+13060>>2]|0)*38|0)<<16;e=(b|0)/(_(c[d+4>>2]|0,a&255)|0)|0;f=e;return f|0;}else{e=0;f=e;return f|0;}return 0;}function bn(a,b){a=a|0;b=b|0;var d=0;d=a;a=(_(c[d+13060>>2]<<10,b&255)|0)<<5;return(a|0)/((c[d+4>>2]|0)*38|0|0)|0|0;}function bo(a,b){a=a|0;b=b|0;return((c[a+4>>2]|0)*38|0|0)/((b&255)<<1<<5|0)|0|0;}function bp(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0;e=b;if(e<<24>>24!=0){f=~~(+(d|0)*38.0*65536.0/+(_(c[a+4>>2]|0,e&255)|0));g=f;return g|0;}else{f=0;g=f;return g|0;}return 0;}function bq(a,b){a=a|0;b=b|0;var d=0;d=a;a=b;b=3-((a&255)>>6&3)|0;b=b*3|0;b=(a&63)<>2]|0)|0,c[d+13060>>2]|0)|0;return b<<10|0;}function br(a){a=a|0;return(a&255)<<22|0;}function bs(a,c,d){a=a|0;c=c|0;d=d|0;var e=0,f=0;e=a;a=c;c=d;d=e+(c<<1)|0;e=e+(a<<1)|0;c=c-a|0;c=(c|0)/2|0;while(1){a=c;c=a-1|0;if((a|0)==0){break;}a=b[e>>1]|0;f=e;e=f+2|0;b[f>>1]=b[d>>1]|0;f=d;d=f-2|0;b[f>>1]=a;}return;}// mid_song_get_num_missing_instruments\\n// takes a number (a)\\n// returns a number\\nfunction bt(a){a=a|0;return c[a+13136>>2]|0;}// mid_song_get_missing_instrument\\nfunction bu(a,b){a=a|0;b=b|0;var d=0,e=0,f=0;d=a;a=b;do{if((a|0)>=0){// stops when reached last instrument\\nif((a|0)>=(c[d+13136>>2]|0)){break;}// path to patch file\\ne=c[d+13140+(a<<2)>>2]|0;f=e;return f|0;}}while(0);e=0;f=e;return f|0;}// returns number of missing patches\\nfunction bv(a){a=a|0;var b=0,d=0,e=0;b=a;a=128;d=0;c[b+13136>>2]=0;while(1){e=a;a=e-1|0;if((e|0)==0){break;}// get number of instrument patches\\nif((c[b+28+(a<<2)>>2]|0)!=0){d=d+(bw(b,0,a)|0)|0;}// get number of drum patches\\nif((c[b+540+(a<<2)>>2]|0)!=0){d=d+(bw(b,1,a)|0)|0;}}return d|0;}function bw(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0;e=i;f=a;a=b;b=d;d=0;if((a|0)!=0){g=c[f+540+(b<<2)>>2]|0;}else{g=c[f+28+(b<<2)>>2]|0;}h=g;if((h|0)==0){j=0;k=j;i=e;return k|0;}g=0;while(1){if((g|0)>=128){break;}do{if((c[h+4+(g<<2)>>2]|0)==-1){c[h+4+(g<<2)>>2]=bB(f,a,b,g)|0;if((c[h+4+(g<<2)>>2]|0)!=0){break;}if((c[(c[h>>2]|0)+(g*28|0)>>2]|0)!=0){l=f;n=c[(c[h>>2]|0)+(g*28|0)>>2]|0;o=(a|0)!=0?1:0;p=c[(c[h>>2]|0)+(g*28|0)+12>>2]|0;q=c[(c[h>>2]|0)+(g*28|0)+8>>2]|0;if((c[(c[h>>2]|0)+(g*28|0)+4>>2]|0)!=-1){r=c[(c[h>>2]|0)+(g*28|0)+4>>2]|0;}else{if((a|0)!=0){s=g;}else{s=-1;}r=s;}if((c[(c[h>>2]|0)+(g*28|0)+16>>2]|0)!=-1){t=c[(c[h>>2]|0)+(g*28|0)+16>>2]|0;}else{t=(a|0)!=0?1:-1;}if((c[(c[h>>2]|0)+(g*28|0)+20>>2]|0)!=-1){u=c[(c[h>>2]|0)+(g*28|0)+20>>2]|0;}else{u=(a|0)!=0?1:-1;}v=bl(l,n,o,p,q,r,t,u,c[(c[h>>2]|0)+(g*28|0)+24>>2]|0)|0;c[h+4+(g<<2)>>2]=v;if((v|0)==0){v=c[m>>2]|0;q=c[(c[h>>2]|0)+(g*28|0)>>2]|0;// prints 'Missing patch: arachno-88.pat' or 'Missing patch: MT32Drums/mt32drum-6.pat'\\nar(v|0,5120,(v=i,i=i+8|0,c[v>>2]=q,v)|0)|0;i=v;if((c[f+13136>>2]|0)<256){q=c[m>>2]|0;p=c[f+13136>>2]|0;i=v;c[f+13140+(c[f+13136>>2]<<2)>>2]=c[(c[h>>2]|0)+(g*28|0)>>2];v=f+13136|0;c[v>>2]=(c[v>>2]|0)+1;}d=d+1|0;}}else{if((b|0)!=0){if((a|0)!=0){if((c[(c[f+540>>2]|0)+4+(g<<2)>>2]|0)==0){c[(c[f+540>>2]|0)+4+(g<<2)>>2]=-1;}}else{if((c[(c[f+28>>2]|0)+4+(g<<2)>>2]|0)==0){c[(c[f+28>>2]|0)+4+(g<<2)>>2]=-1;}}}c[h+4+(g<<2)>>2]=0;d=d+1|0;}w=246;}else{w=246;}}while(0);if((w|0)==246){w=0;}g=g+1|0;}j=d;k=j;i=e;return k|0;}function bx(a){a=a|0;var b=0,d=0;b=a;a=128;while(1){d=a;a=d-1|0;if((d|0)==0){break;}if((c[b+28+(a<<2)>>2]|0)!=0){by(b,0,a);}if((c[b+540+(a<<2)>>2]|0)!=0){by(b,1,a);}}return;}function by(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0;e=a;a=d;if((b|0)!=0){f=c[e+540+(a<<2)>>2]|0;}else{f=c[e+28+(a<<2)>>2]|0;}a=f;f=0;while(1){if((f|0)>=128){break;}if((c[a+4+(f<<2)>>2]|0)!=0){if((c[a+4+(f<<2)>>2]|0)!=-1){bA(c[a+4+(f<<2)>>2]|0);}c[a+4+(f<<2)>>2]=0;}f=f+1|0;}return;}function bz(a,b){a=a|0;b=b|0;var d=0,e=0,f=0;d=a;a=bl(d,b,0,-1,-1,-1,0,0,0)|0;if((a|0)!=0){c[d+1052>>2]=a;c[d+1056>>2]=-1;e=0;f=e;return f|0;}else{e=-1;f=e;return f|0;}return 0;}function bA(a){a=a|0;var b=0;b=a;if((b|0)==0){return;}a=0;while(1){if((a|0)>=(c[b>>2]|0)){break;}c0(c[(c[b+4>>2]|0)+(a*116|0)+88>>2]|0);a=a+1|0;}c0(c[b+4>>2]|0);c0(b);return;}function bB(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0;f=a;a=b;b=d;d=e;if((c[f+24>>2]|0)==0){g=0;h=g;return h|0;}a=(a|0)!=0?-2147483648:0;e=0;L368:while(1){if(e>>>0>=(c[(c[f+24>>2]|0)+4>>2]|0)>>>0){break;}i=(c[(c[f+24>>2]|0)+8>>2]|0)+(e*20|0)|0;do{if((c[(c[i+4>>2]|0)+4>>2]&-2147483648|0)==(a|0)){if(((c[(c[i+4>>2]|0)+4>>2]|0)>>>8&255|0)!=(b|0)){break;}if((c[(c[i+4>>2]|0)+8>>2]|0)==(d|0)){j=295;break L368;}}}while(0);e=e+1|0;}do{if((e|0)==(c[(c[f+24>>2]|0)+4>>2]|0)){if((b|0)!=0){break;}e=0;while(1){if(e>>>0>=(c[(c[f+24>>2]|0)+4>>2]|0)>>>0){break;}i=(c[(c[f+24>>2]|0)+8>>2]|0)+(e*20|0)|0;if((c[(c[i+4>>2]|0)+4>>2]&-2147483648|0)==(a|0)){if((c[(c[i+4>>2]|0)+8>>2]|0)==(d|0)){j=304;break;}}e=e+1|0;}}}while(0);if((e|0)==(c[(c[f+24>>2]|0)+4>>2]|0)){g=0;h=g;return h|0;}j=bi(8)|0;c[j>>2]=c[c[i+4>>2]>>2];c[j+4>>2]=bi((c[j>>2]|0)*116|0)|0;c5(c[j+4>>2]|0,0,(c[j>>2]|0)*116|0|0);e=0;while(1){if(e>>>0>=(c[c[i+4>>2]>>2]|0)>>>0){break;}bC(f,(c[j+4>>2]|0)+(e*116|0)|0,i,e);e=e+1|0;}g=j;h=g;return h|0;}function bC(b,f,h,i){b=b|0;f=f|0;h=h|0;i=i|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0.0,B=0.0,C=0.0,D=0.0;j=b;b=f;f=h;h=(c[f+8>>2]|0)+(i*24|0)|0;i=(c[(c[j+24>>2]|0)+20>>2]|0)+((c[(c[h+4>>2]|0)+8>>2]|0)*20|0)|0;k=1056+((e[c[h>>2]>>1]|0)<<2)|0;c[b+24>>2]=d[k]|d[k+1|0]<<8|d[k+2|0]<<16|d[k+3|0]<<24;k=1056+((e[(c[h>>2]|0)+2>>1]|0)<<2)|0;c[b+28>>2]=d[k]|d[k+1|0]<<8|d[k+2|0]<<16|d[k+3|0]<<24;k=1056+((e[(c[h+8>>2]|0)+4>>1]|0)<<2)|0;c[b+32>>2]=d[k]|d[k+1|0]<<8|d[k+2|0]<<16|d[k+3|0]<<24;c[b+16>>2]=e[(c[h>>2]|0)+4>>1]|0;c[b+20>>2]=e[(c[h>>2]|0)+6>>1]|0;a[b+110|0]=1;c[b+12>>2]=c[(c[i>>2]|0)+4>>2];c[b+8>>2]=((c[i+8>>2]|0)>>>0)/2|0;c[b+88>>2]=bi(c[i+8>>2]|0)|0;k=c[b+88>>2]|0;l=c[i+4>>2]|0;m=c[i+8>>2]|0;c6(k|0,l|0,m)|0;if((c[(c[h+8>>2]|0)+16>>2]|0)!=0){m=b+110|0;a[m]=(d[m]|0|36)&255;c[b>>2]=((c[(c[h+12>>2]|0)+8>>2]|0)>>>0)/2|0;c[b+4>>2]=(c[b>>2]|0)+(((c[(c[h+12>>2]|0)+12>>2]|0)>>>0)/2|0);}g[b+84>>2]=1.0;if((a[b+110|0]&32|0)==0){n=b;o=n+8|0;p=c[o>>2]|0;q=p<<12;c[o>>2]=q;r=b;s=r|0;t=c[s>>2]|0;u=t<<12;c[s>>2]=u;v=b;w=v+4|0;x=c[w>>2]|0;y=x<<12;c[w>>2]=y;return;}m=0;l=0;do{if((c[f+12>>2]|0)!=0){if((c[(c[f+12>>2]|0)+4>>2]|0)>>>0<=0){z=326;break;}if((c[f+16>>2]|0)==0){z=326;break;}m=c[f+12>>2]|0;l=c[f+16>>2]|0;}else{z=326;}}while(0);if((z|0)==326){m=c[h+16>>2]|0;l=c[h+20>>2]|0;}h=bD(c[m+4>>2]|0,l,518)|0;A=+bE(h);h=bD(c[m+4>>2]|0,l,524)|0;B=+bE(h);h=bD(c[m+4>>2]|0,l,519)|0;C=+bE(h);h=bD(c[m+4>>2]|0,l,521)|0;D=+bE(h);h=bD(c[m+4>>2]|0,l,522)|0;z=~~((1.0-+bF(h))*250.0);h=bD(c[m+4>>2]|0,l,4)|0;a[b+111|0]=~~((+bF(h)+0.5)*127.0)&255;c[b+60>>2]=bG(255)|0;c[b+36>>2]=bH(j,255,c[b+12>>2]|0,A)|0;c[b+64>>2]=bG(250)|0;c[b+40>>2]=bH(j,5,c[b+12>>2]|0,B)|0;c[b+68>>2]=bG(z)|0;c[b+44>>2]=bH(j,255-z|0,c[b+12>>2]|0,C)|0;c[b+72>>2]=bG(0)|0;c[b+48>>2]=bH(j,z+5|0,c[b+12>>2]|0,D)|0;c[b+76>>2]=bG(0)|0;c[b+52>>2]=bG(1)|0;c[b+80>>2]=bG(0)|0;c[b+56>>2]=bG(1)|0;z=b+110|0;a[z]=(d[z]|0|64)&255;n=b;o=n+8|0;p=c[o>>2]|0;q=p<<12;c[o>>2]=q;r=b;s=r|0;t=c[s>>2]|0;u=t<<12;c[s>>2]=u;v=b;w=v+4|0;x=c[w>>2]|0;y=x<<12;c[w>>2]=y;return;}function bD(a,b,d){a=a|0;b=b|0;d=d|0;var f=0,g=0,h=0;f=a;a=b;b=d;d=0;g=0;while(1){if(g>>>0>=f>>>0){break;}h=a+(g*12|0)|0;if((e[h+4>>1]|0|0)==(b&65535|0)){do{if((e[h>>1]|0|0)==0){if((e[h+2>>1]|0|0)!=0){break;}if((e[h+6>>1]|0|0)!=0){break;}d=d+(c[h+8>>2]|0)|0;}}while(0);}g=g+1|0;}return d|0;}function bE(a){a=a|0;var b=0,c=0.0,d=0.0;b=a;do{if((b|0)!=-2147483648){if((b|0)==0){break;}c=+P(2.0,+(+((b|0)/65536|0|0)/1200.0))*1.0e3;d=c;return+d;}}while(0);c=0.0;d=c;return+d;}function bF(a){a=a|0;return+(+((a|0)/65536|0|0)/1.0e3);}function bG(a){a=a|0;return a<<22|0;}function bH(a,b,d,e){a=a|0;b=b|0;d=d|0;e=+e;var f=0.0;d=a;a=b;f=e;if(f<6.0){f=6.0;}if((a|0)==0){a=255;}a=a<<22;return~~(+(a|0)/+(c[d+4>>2]|0)*+(c[d+13060>>2]|0)*1.0e3/f)|0;}function bI(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,i=0;f=b;b=e;e=c[f+1724+(b*236|0)+220>>2]|0;if((e|0)>5){a[f+1724+(b*236|0)|0]=0;g=1;h=g;return h|0;}if((a[(c[f+1724+(b*236|0)+4>>2]|0)+110|0]&64|0)!=0){if((d[f+1724+(b*236|0)|0]|0|0)==1){i=361;}else{if((d[f+1724+(b*236|0)|0]|0|0)==2){i=361;}}do{if((i|0)==361){if((e|0)<=2){break;}c[f+1724+(b*236|0)+32>>2]=0;g=0;h=g;return h|0;}}while(0);}c[f+1724+(b*236|0)+220>>2]=e+1;if((c[f+1724+(b*236|0)+24>>2]|0)==(c[(c[f+1724+(b*236|0)+4>>2]|0)+60+(e<<2)>>2]|0)){g=bI(f,b)|0;h=g;return h|0;}c[f+1724+(b*236|0)+28>>2]=c[(c[f+1724+(b*236|0)+4>>2]|0)+60+(e<<2)>>2];c[f+1724+(b*236|0)+32>>2]=c[(c[f+1724+(b*236|0)+4>>2]|0)+36+(e<<2)>>2];if((c[f+1724+(b*236|0)+28>>2]|0)<(c[f+1724+(b*236|0)+24>>2]|0)){c[f+1724+(b*236|0)+32>>2]=-(c[f+1724+(b*236|0)+32>>2]|0);}g=0;h=g;return h|0;}function bJ(b,e){b=b|0;e=e|0;var f=0,i=0.0,j=0,l=0.0;f=b;b=e;i=+g[f+1724+(b*236|0)+68>>2];if((c[f+1724+(b*236|0)+232>>2]|0)!=0){if((c[f+1724+(b*236|0)+48>>2]|0)!=0){i=i*+g[f+1724+(b*236|0)+76>>2];}if((a[(c[f+1724+(b*236|0)+4>>2]|0)+110|0]&64|0)!=0){e=8+(c[f+1724+(b*236|0)+24>>2]>>23<<3)|0;i=i*(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]);}j=~~(i*4096.0);if((j|0)>8191){j=8191;}c[f+1724+(b*236|0)+60>>2]=j;return;}l=+g[f+1724+(b*236|0)+72>>2];if((c[f+1724+(b*236|0)+48>>2]|0)!=0){i=i*+g[f+1724+(b*236|0)+76>>2];l=l*+g[f+1724+(b*236|0)+76>>2];}if((a[(c[f+1724+(b*236|0)+4>>2]|0)+110|0]&64|0)!=0){e=8+(c[f+1724+(b*236|0)+24>>2]>>23<<3)|0;i=i*(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]);e=8+(c[f+1724+(b*236|0)+24>>2]>>23<<3)|0;l=l*(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]);}j=~~(i*4096.0);if((j|0)>8191){j=8191;}e=~~(l*4096.0);if((e|0)>8191){e=8191;}c[f+1724+(b*236|0)+60>>2]=j;c[f+1724+(b*236|0)+64>>2]=e;return;}function bK(b,e,f,g){b=b|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0;h=i;i=i+8|0;j=h|0;k=b;b=e;e=f;c[j>>2]=g;g=k+1724+(e*236|0)|0;if((d[g|0]|0|0)==4){if((c[j>>2]|0)>=20){c[j>>2]=20;}l=cy(k,e,j)|0;bL(k,l,b,e,c[j>>2]|0);a[g|0]=0;i=h;return;}l=cy(k,e,j)|0;if((c[k+8>>2]&1|0)!=0){do{if((c[g+32>>2]|0)!=0){m=402;}else{if((c[g+48>>2]|0)!=0){m=402;break;}bN(k,l,b,e,c[j>>2]|0);}}while(0);if((m|0)==402){bM(k,l,b,e,c[j>>2]|0);}}else{if((c[g+232>>2]|0)==0){do{if((c[g+32>>2]|0)!=0){m=408;}else{if((c[g+48>>2]|0)!=0){m=408;break;}bP(k,l,b,e,c[j>>2]|0);}}while(0);if((m|0)==408){bO(k,l,b,e,c[j>>2]|0);}}else{if((c[g+232>>2]|0)==3){do{if((c[g+32>>2]|0)!=0){m=414;}else{if((c[g+48>>2]|0)!=0){m=414;break;}bR(k,l,b,e,c[j>>2]|0);}}while(0);if((m|0)==414){bQ(k,l,b,e,c[j>>2]|0);}}else{if((c[g+232>>2]|0)==2){b=b+4|0;}do{if((c[g+32>>2]|0)!=0){m=421;}else{if((c[g+48>>2]|0)!=0){m=421;break;}bT(k,l,b,e,c[j>>2]|0);}}while(0);if((m|0)==421){bS(k,l,b,e,c[j>>2]|0);}}}}i=h;return;}function bL(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;h=a;a=d;d=e;e=f;f=g;g=0;if((f|0)==0){f=1;}i=c[h+1724+(e*236|0)+60>>2]|0;j=-((i|0)/(f|0)|0)|0;if((j|0)==0){j=-1;}if((c[h+8>>2]&1|0)!=0){while(1){k=f;f=k-1|0;if((k|0)==0){l=474;break;}i=i+j|0;if((i|0)<0){l=472;break;}k=a;a=k+2|0;g=b[k>>1]|0;k=_(i,g<<16>>16)|0;m=d;d=m+4|0;c[m>>2]=(c[m>>2]|0)+k;}if((l|0)==472){return;}else if((l|0)==474){return;}}if((c[h+1724+(e*236|0)+232>>2]|0)==0){k=c[h+1724+(e*236|0)+64>>2]|0;m=-((k|0)/(f|0)|0)|0;while(1){n=f;f=n-1|0;if((n|0)==0){break;}i=i+j|0;if((i|0)<0){i=0;}k=k+m|0;if((k|0)<0){k=0;}n=a;a=n+2|0;g=b[n>>1]|0;n=_(i,g<<16>>16)|0;o=d;d=o+4|0;c[o>>2]=(c[o>>2]|0)+n;n=_(k,g<<16>>16)|0;o=d;d=o+4|0;c[o>>2]=(c[o>>2]|0)+n;}}else{do{if((c[h+1724+(e*236|0)+232>>2]|0)==3){while(1){k=f;f=k-1|0;if((k|0)==0){l=450;break;}i=i+j|0;if((i|0)<0){break;}k=a;a=k+2|0;g=b[k>>1]|0;k=_(i,g<<16>>16)|0;m=d;d=m+4|0;c[m>>2]=(c[m>>2]|0)+k;k=_(i,g<<16>>16)|0;m=d;d=m+4|0;c[m>>2]=(c[m>>2]|0)+k;}if((l|0)==450){break;}return;}else{do{if((c[h+1724+(e*236|0)+232>>2]|0)==1){while(1){k=f;f=k-1|0;if((k|0)==0){l=457;break;}i=i+j|0;if((i|0)<0){break;}k=a;a=k+2|0;g=b[k>>1]|0;k=_(i,g<<16>>16)|0;m=d;d=m+4|0;c[m>>2]=(c[m>>2]|0)+k;d=d+4|0;}if((l|0)==457){break;}return;}else{do{if((c[h+1724+(e*236|0)+232>>2]|0)==2){while(1){k=f;f=k-1|0;if((k|0)==0){l=464;break;}i=i+j|0;if((i|0)<0){break;}k=a;a=k+2|0;g=b[k>>1]|0;d=d+4|0;k=_(i,g<<16>>16)|0;m=d;d=m+4|0;c[m>>2]=(c[m>>2]|0)+k;}if((l|0)==464){break;}return;}}while(0);}}while(0);}}while(0);}return;}function bM(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0;h=a;a=d;d=e;e=f;f=g;g=h+1724+(e*236|0)|0;i=c[g+60>>2]|0;j=c[g+224>>2]|0;k=j;do{if((j|0)==0){k=c[h+13060>>2]|0;if((bU(h,e)|0)==0){i=c[g+60>>2]|0;break;}return;}}while(0);while(1){if((f|0)==0){l=502;break;}if((k|0)>=(f|0)){l=495;break;}f=f-k|0;while(1){j=k;k=j-1|0;if((j|0)==0){break;}j=a;a=j+2|0;m=b[j>>1]|0;j=_(i,m<<16>>16)|0;n=d;d=n+4|0;c[n>>2]=(c[n>>2]|0)+j;}k=c[h+13060>>2]|0;if((bU(h,e)|0)!=0){l=493;break;}i=c[g+60>>2]|0;}if((l|0)==502){return;}else if((l|0)==493){return;}else if((l|0)==495){c[g+224>>2]=k-f;while(1){k=f;f=k-1|0;if((k|0)==0){break;}k=a;a=k+2|0;m=b[k>>1]|0;k=_(i,m<<16>>16)|0;g=d;d=g+4|0;c[g>>2]=(c[g>>2]|0)+k;}return;}}function bN(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0;h=d;d=e;e=g;g=c[a+1724+(f*236|0)+60>>2]|0;while(1){f=e;e=f-1|0;if((f|0)==0){break;}f=h;h=f+2|0;a=_(g,b[f>>1]|0)|0;f=d;d=f+4|0;c[f>>2]=(c[f>>2]|0)+a;}return;}function bO(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;h=a;a=d;d=e;e=f;f=g;g=h+1724+(e*236|0)|0;i=c[g+60>>2]|0;j=c[g+64>>2]|0;k=c[g+224>>2]|0;l=k;do{if((k|0)==0){l=c[h+13060>>2]|0;if((bU(h,e)|0)==0){i=c[g+60>>2]|0;j=c[g+64>>2]|0;break;}return;}}while(0);while(1){if((f|0)==0){m=530;break;}if((l|0)>=(f|0)){m=522;break;}f=f-l|0;while(1){k=l;l=k-1|0;if((k|0)==0){break;}k=a;a=k+2|0;n=b[k>>1]|0;k=_(i,n<<16>>16)|0;o=d;d=o+4|0;c[o>>2]=(c[o>>2]|0)+k;k=_(j,n<<16>>16)|0;o=d;d=o+4|0;c[o>>2]=(c[o>>2]|0)+k;}l=c[h+13060>>2]|0;if((bU(h,e)|0)!=0){m=520;break;}i=c[g+60>>2]|0;j=c[g+64>>2]|0;}if((m|0)==522){c[g+224>>2]=l-f;while(1){l=f;f=l-1|0;if((l|0)==0){break;}l=a;a=l+2|0;n=b[l>>1]|0;l=_(i,n<<16>>16)|0;g=d;d=g+4|0;c[g>>2]=(c[g>>2]|0)+l;l=_(j,n<<16>>16)|0;g=d;d=g+4|0;c[g>>2]=(c[g>>2]|0)+l;}return;}else if((m|0)==520){return;}else if((m|0)==530){return;}}function bP(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0;h=a;a=d;d=e;e=f;f=g;g=c[h+1724+(e*236|0)+60>>2]|0;i=c[h+1724+(e*236|0)+64>>2]|0;while(1){e=f;f=e-1|0;if((e|0)==0){break;}e=a;a=e+2|0;h=b[e>>1]|0;e=_(g,h<<16>>16)|0;j=d;d=j+4|0;c[j>>2]=(c[j>>2]|0)+e;e=_(i,h<<16>>16)|0;h=d;d=h+4|0;c[h>>2]=(c[h>>2]|0)+e;}return;}function bQ(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0;h=a;a=d;d=e;e=f;f=g;g=h+1724+(e*236|0)|0;i=c[g+60>>2]|0;j=c[g+224>>2]|0;k=j;do{if((j|0)==0){k=c[h+13060>>2]|0;if((bU(h,e)|0)==0){i=c[g+60>>2]|0;break;}return;}}while(0);while(1){if((f|0)==0){l=556;break;}if((k|0)>=(f|0)){l=549;break;}f=f-k|0;while(1){j=k;k=j-1|0;if((j|0)==0){break;}j=a;a=j+2|0;m=b[j>>1]|0;j=_(i,m<<16>>16)|0;n=d;d=n+4|0;c[n>>2]=(c[n>>2]|0)+j;j=_(i,m<<16>>16)|0;n=d;d=n+4|0;c[n>>2]=(c[n>>2]|0)+j;}k=c[h+13060>>2]|0;if((bU(h,e)|0)!=0){l=547;break;}i=c[g+60>>2]|0;}if((l|0)==549){c[g+224>>2]=k-f;while(1){k=f;f=k-1|0;if((k|0)==0){break;}k=a;a=k+2|0;m=b[k>>1]|0;k=_(i,m<<16>>16)|0;g=d;d=g+4|0;c[g>>2]=(c[g>>2]|0)+k;k=_(i,m<<16>>16)|0;g=d;d=g+4|0;c[g>>2]=(c[g>>2]|0)+k;}return;}else if((l|0)==556){return;}else if((l|0)==547){return;}}function bR(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0;h=d;d=e;e=g;g=c[a+1724+(f*236|0)+60>>2]|0;while(1){f=e;e=f-1|0;if((f|0)==0){break;}f=h;h=f+2|0;a=b[f>>1]|0;f=_(g,a<<16>>16)|0;i=d;d=i+4|0;c[i>>2]=(c[i>>2]|0)+f;f=_(g,a<<16>>16)|0;a=d;d=a+4|0;c[a>>2]=(c[a>>2]|0)+f;}return;}function bS(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0;h=a;a=d;d=e;e=f;f=g;g=h+1724+(e*236|0)|0;i=c[g+60>>2]|0;j=c[g+224>>2]|0;k=j;do{if((j|0)==0){k=c[h+13060>>2]|0;if((bU(h,e)|0)==0){i=c[g+60>>2]|0;break;}return;}}while(0);while(1){if((f|0)==0){l=582;break;}if((k|0)>=(f|0)){l=576;break;}f=f-k|0;while(1){j=k;k=j-1|0;if((j|0)==0){break;}j=a;a=j+2|0;m=b[j>>1]|0;j=_(i,m<<16>>16)|0;n=d;d=n+4|0;c[n>>2]=(c[n>>2]|0)+j;d=d+4|0;}k=c[h+13060>>2]|0;if((bU(h,e)|0)!=0){l=574;break;}i=c[g+60>>2]|0;}if((l|0)==582){return;}else if((l|0)==576){c[g+224>>2]=k-f;while(1){k=f;f=k-1|0;if((k|0)==0){break;}k=a;a=k+2|0;m=b[k>>1]|0;k=_(i,m<<16>>16)|0;g=d;d=g+4|0;c[g>>2]=(c[g>>2]|0)+k;d=d+4|0;}return;}else if((l|0)==574){return;}}function bT(a,d,e,f,g){a=a|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0;h=d;d=e;e=g;g=c[a+1724+(f*236|0)+60>>2]|0;while(1){f=e;e=f-1|0;if((f|0)==0){break;}f=h;h=f+2|0;a=_(g,b[f>>1]|0)|0;f=d;d=f+4|0;c[f>>2]=(c[f>>2]|0)+a;d=d+4|0;}return;}function bU(a,b){a=a|0;b=b|0;var d=0,e=0,f=0;d=a;a=b;do{if((c[d+1724+(a*236|0)+32>>2]|0)!=0){if((bV(d,a)|0)==0){break;}e=1;f=e;return f|0;}}while(0);if((c[d+1724+(a*236|0)+48>>2]|0)!=0){bW(d,a);}bJ(d,a);e=0;f=e;return f|0;}function bV(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0;d=a;a=b;b=d+1724+(a*236|0)+24|0;c[b>>2]=(c[b>>2]|0)+(c[d+1724+(a*236|0)+32>>2]|0);if((c[d+1724+(a*236|0)+32>>2]|0)<0){if((c[d+1724+(a*236|0)+24>>2]|0)<=(c[d+1724+(a*236|0)+28>>2]|0)){e=603;}else{e=601;}}else{e=601;}do{if((e|0)==601){if((c[d+1724+(a*236|0)+32>>2]|0)<=0){break;}if((c[d+1724+(a*236|0)+24>>2]|0)>=(c[d+1724+(a*236|0)+28>>2]|0)){e=603;}}}while(0);do{if((e|0)==603){c[d+1724+(a*236|0)+24>>2]=c[d+1724+(a*236|0)+28>>2];if((bI(d,a)|0)==0){break;}f=1;g=f;return g|0;}}while(0);f=0;g=f;return g|0;}function bW(a,b){a=a|0;b=b|0;var e=0,f=0;e=a;a=b;b=(d[(c[e+1724+(a*236|0)+4>>2]|0)+108|0]|0)<<7;if((c[e+1724+(a*236|0)+36>>2]|0)!=0){f=e+1724+(a*236|0)+40|0;c[f>>2]=(c[f>>2]|0)+(c[e+1724+(a*236|0)+36>>2]|0);if((c[e+1724+(a*236|0)+40>>2]|0)>=65536){c[e+1724+(a*236|0)+36>>2]=0;}else{b=_(b,c[e+1724+(a*236|0)+40>>2]|0)|0;b=b>>16;}}f=e+1724+(a*236|0)+44|0;c[f>>2]=(c[f>>2]|0)+(c[e+1724+(a*236|0)+48>>2]|0);g[e+1724+(a*236|0)+76>>2]=1.0-(+R(+(+(c[e+1724+(a*236|0)+44>>2]>>5|0)*0.006135923151542565))+1.0)*+(b|0)*1.0*762939453125.0e-17;return;}function bX(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0;f=d;d=e;e=b;while(1){b=d;d=b-1|0;if((b|0)==0){break;}b=f;f=b+4|0;g=c[b>>2]>>21;if((g|0)>127){g=127;}else{if((g|0)<-128){g=-128;}}b=e;e=b+1|0;a[b]=g&255;}return;}function bY(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0;f=d;d=e;e=b;while(1){b=d;d=b-1|0;if((b|0)==0){break;}b=f;f=b+4|0;g=c[b>>2]>>21;if((g|0)>127){g=127;}else{if((g|0)<-128){g=-128;}}b=e;e=b+1|0;a[b]=(128^g&255)&255;}return;}function bZ(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0;f=d;d=e;e=a;while(1){a=d;d=a-1|0;if((a|0)==0){break;}a=f;f=a+4|0;g=c[a>>2]>>13;if((g|0)>32767){g=32767;}else{if((g|0)<-32768){g=-32768;}}a=e;e=a+2|0;b[a>>1]=g&65535;}return;}function b_(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0;f=d;d=e;e=a;while(1){a=d;d=a-1|0;if((a|0)==0){break;}a=f;f=a+4|0;g=c[a>>2]>>13;if((g|0)>32767){g=32767;}else{if((g|0)<-32768){g=-32768;}}a=e;e=a+2|0;b[a>>1]=(32768^g&65535)&65535;}return;}function b$(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0;f=d;d=e;e=a;while(1){a=d;d=a-1|0;if((a|0)==0){break;}a=f;f=a+4|0;g=c[a>>2]>>13;if((g|0)>32767){g=32767;}else{if((g|0)<-32768){g=-32768;}}a=e;e=a+2|0;b[a>>1]=(((g&65535)<<16>>16&255)<<8|(g&65535)<<16>>16>>8&255)&65535;}return;}function b0(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0;g=i;i=i+8|0;h=g|0;c[h>>2]=0;a[h+5|0]=1;a[h+4|0]=d&255;a[h+6|0]=e&255;a[h+7|0]=f&255;b1(b,h);i=g;return;}function b1(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,i=0;f=b;b=e;e=c[f+13052>>2]|0;g=-1;h=2147483647;if(0==(b|0)){i=c[f+13080>>2]|0;}else{i=b;}while(1){b=e;e=b-1|0;if((b|0)==0){break;}if((d[f+1724+(e*236|0)|0]|0|0)==0){g=e;}else{do{if((d[f+1724+(e*236|0)+1|0]|0|0)==(d[i+4|0]|0|0)){if((d[f+1724+(e*236|0)+2|0]|0|0)!=(d[i+6|0]|0|0)){if((c[f+1084+((d[f+1724+(e*236|0)+1|0]|0)*40|0)+28>>2]|0)==0){break;}}ch(f,e);}}while(0);}}if((g|0)!=-1){cn(f,i,g);return;}e=c[f+13052>>2]|0;while(1){b=e;e=b-1|0;if((b|0)==0){break;}do{if((d[f+1724+(e*236|0)|0]|0|0)!=1){if((d[f+1724+(e*236|0)|0]|0|0)==4){break;}b=c[f+1724+(e*236|0)+60>>2]|0;do{if((c[f+1724+(e*236|0)+232>>2]|0)==0){if((c[f+1724+(e*236|0)+64>>2]|0)<=(b|0)){break;}b=c[f+1724+(e*236|0)+64>>2]|0;}}while(0);if((b|0)<(h|0)){h=b;g=e;}}}while(0);}if((g|0)!=-1){e=f+13068|0;c[e>>2]=(c[e>>2]|0)+1;a[f+1724+(g*236|0)|0]=0;cn(f,i,g);return;}else{g=f+13064|0;c[g>>2]=(c[g>>2]|0)+1;return;}}function b2(b,e){b=b|0;e=e|0;var f=0,g=0,h=0;f=b;b=e;e=c[f+13052>>2]|0;if(0==(b|0)){g=c[f+13080>>2]|0;}else{g=b;}L890:while(1){b=e;e=b-1|0;if((b|0)==0){h=709;break;}do{if((d[f+1724+(e*236|0)|0]|0|0)==1){if((d[f+1724+(e*236|0)+1|0]|0|0)!=(d[g+4|0]|0|0)){break;}if((d[f+1724+(e*236|0)+2|0]|0|0)==(d[g+6|0]|0|0)){break L890;}}}while(0);}if((h|0)==709){return;}if((c[f+1084+((d[g+4|0]|0)*40|0)+12>>2]|0)!=0){a[f+1724+(e*236|0)|0]=2;}else{ci(f,e);}return;}function b3(a){a=a|0;var b=0;b=a;c[b>>2]=1;b4(b);b5(b,0);return;}function b4(a){a=a|0;var b=0;b=a;g[b+16>>2]=+(c[b+20>>2]|0)/100.0;return;}function b5(a,b){a=a|0;b=b|0;var d=0;d=a;a=b;if((c[d+13088>>2]|0)>(a|0)){c[d+13088>>2]=0;}ck(d);c[d+13080>>2]=c[d+13076>>2];c[392]=5e5;if((a|0)==0){return;}cl(d,a);return;}function b6(b,e,f,h){b=b|0;e=e|0;f=f|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0;j=i;i=i+8|0;k=j|0;l=b;c[k>>2]=e;e=h;if((c[l>>2]|0)==0){m=0;n=m;i=j;return n|0;}h=(f>>>0)/((c[l+12>>2]|0)>>>0)|0;f=c[l+13088>>2]|0;b=(c[l+13088>>2]|0)+h|0;L920:while(1){if((c[l+13088>>2]|0)>=(b|0)){o=758;break;}while(1){if(~~(+(c[c[l+13080>>2]>>2]|0)/+g[258])>>>0>(c[l+13088>>2]|0)>>>0){break;}switch(d[(c[l+13080>>2]|0)+5|0]|0){case 99:{if(0==(e|0)){o=752;break L920;}break;}case 6:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+12>>2]=d[(c[l+13080>>2]|0)+6|0]|0;if((a[(c[l+13080>>2]|0)+6|0]|0)==0){ca(l);}break;}case 3:{b7(l);break;}case 11:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+32>>2]=d[(c[l+13080>>2]|0)+6|0]|0;g[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+36>>2]=0.0;break;}case 14:{cc(l);break;}case 12:{cd(l);break;}case 13:{cb(l,d[(c[l+13080>>2]|0)+4|0]|0);break;}case 9:{if((c[l+13056>>2]&1<>2]|0)+4|0]|0)!=0){c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)>>2]=d[(c[l+13080>>2]|0)+6|0]|0;}else{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+4>>2]=d[(c[l+13080>>2]|0)+6|0]|0;}break;}case 5:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+16>>2]=d[(c[l+13080>>2]|0)+6|0]|0;break;}case 7:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+24>>2]=d[(c[l+13080>>2]|0)+6|0]|0;b9(l);break;}case 1:{if((a[(c[l+13080>>2]|0)+7|0]|0)!=0){b1(l,0);}else{b2(l,0);}break;}case 15:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)>>2]=d[(c[l+13080>>2]|0)+6|0]|0;break;}case 10:{c[392]=(d[(c[l+13080>>2]|0)+4|0]|0)+(d[(c[l+13080>>2]|0)+7|0]<<8)+(d[(c[l+13080>>2]|0)+6|0]<<16);break;}case 8:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+20>>2]=(d[(c[l+13080>>2]|0)+6|0]|0)+(d[(c[l+13080>>2]|0)+7|0]<<7);g[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+36>>2]=0.0;b8(l);break;}case 4:{c[l+1084+((d[(c[l+13080>>2]|0)+4|0]|0)*40|0)+8>>2]=d[(c[l+13080>>2]|0)+6|0]|0;b9(l);break;}case 2:{b2(l,0);break;}default:{}}p=l+13080|0;c[p>>2]=(c[p>>2]|0)+8;}if(~~(+(c[c[l+13080>>2]>>2]|0)/+g[258])>>>0>b>>>0){ce(l,k,b-(c[l+13088>>2]|0)|0);}else{ce(l,k,~~(+(c[c[l+13080>>2]>>2]|0)/+g[258])-(c[l+13088>>2]|0)|0);}}if((o|0)==752){c[l>>2]=0;m=_((c[l+13088>>2]|0)-f|0,c[l+12>>2]|0)|0;n=m;i=j;return n|0;}else if((o|0)==758){m=_(h,c[l+12>>2]|0)|0;n=m;i=j;return n|0;}return 0;}function b7(b){b=b|0;var e=0,f=0,g=0,h=0;e=b;b=c[e+13080>>2]|0;f=c[e+13052>>2]|0;L967:while(1){g=f;f=g-1|0;if((g|0)==0){h=772;break;}do{if((d[e+1724+(f*236|0)|0]|0|0)==1){if((d[e+1724+(f*236|0)+1|0]|0|0)!=(d[b+4|0]|0|0)){break;}if((d[e+1724+(f*236|0)+2|0]|0|0)==(d[b+6|0]|0|0)){break L967;}}}while(0);}if((h|0)==772){return;}a[e+1724+(f*236|0)+3|0]=a[b+7|0]|0;cf(e,f);bJ(e,f);return;}function b8(a){a=a|0;var b=0,e=0,f=0;b=a;a=d[(c[b+13080>>2]|0)+4|0]|0;e=c[b+13052>>2]|0;while(1){f=e;e=f-1|0;if((f|0)==0){break;}do{if((d[b+1724+(e*236|0)|0]|0|0)!=0){if((d[b+1724+(e*236|0)+1|0]|0|0)!=(a|0)){break;}cj(b,e);}}while(0);}return;}function b9(a){a=a|0;var b=0,e=0,f=0;b=a;a=d[(c[b+13080>>2]|0)+4|0]|0;e=c[b+13052>>2]|0;while(1){f=e;e=f-1|0;if((f|0)==0){break;}do{if((d[b+1724+(e*236|0)+1|0]|0|0)==(a|0)){if((d[b+1724+(e*236|0)|0]|0|0)!=1){if((d[b+1724+(e*236|0)|0]|0|0)!=2){break;}}cf(b,e);bJ(b,e);}}while(0);}return;}function ca(a){a=a|0;var b=0,e=0,f=0;b=a;a=c[b+13052>>2]|0;e=d[(c[b+13080>>2]|0)+4|0]|0;while(1){f=a;a=f-1|0;if((f|0)==0){break;}do{if((d[b+1724+(a*236|0)|0]|0|0)==2){if((d[b+1724+(a*236|0)+1|0]|0|0)!=(e|0)){break;}ci(b,a);}}while(0);}return;}function cb(a,b){a=a|0;b=b|0;var d=0;d=a;a=b;c[d+1084+(a*40|0)+8>>2]=90;c[d+1084+(a*40|0)+24>>2]=127;c[d+1084+(a*40|0)+12>>2]=0;c[d+1084+(a*40|0)+20>>2]=8192;g[d+1084+(a*40|0)+36>>2]=0.0;return;}function cc(b){b=b|0;var e=0,f=0,g=0;e=b;b=c[e+13052>>2]|0;f=d[(c[e+13080>>2]|0)+4|0]|0;while(1){g=b;b=g-1|0;if((g|0)==0){break;}do{if((d[e+1724+(b*236|0)|0]|0|0)==1){if((d[e+1724+(b*236|0)+1|0]|0|0)!=(f|0)){break;}if((c[e+1084+(f*40|0)+12>>2]|0)!=0){a[e+1724+(b*236|0)|0]=2;}else{ci(e,b);}}}while(0);}return;}function cd(a){a=a|0;var b=0,e=0,f=0;b=a;a=c[b+13052>>2]|0;e=d[(c[b+13080>>2]|0)+4|0]|0;while(1){f=a;a=f-1|0;if((f|0)==0){break;}do{if((d[b+1724+(a*236|0)+1|0]|0|0)==(e|0)){if((d[b+1724+(a*236|0)|0]|0|0)==0){break;}if((d[b+1724+(a*236|0)|0]|0|0)==4){break;}ch(b,a);}}while(0);}return;}function ce(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0;e=a;a=b;b=d;if((c[e+8>>2]&1|0)!=0){f=1;}else{f=2;}while(1){if((b|0)==0){break;}d=b;if((d|0)>(c[e+1064>>2]|0)){d=c[e+1064>>2]|0;}cg(e,d);g=c[e+1060>>2]|0;h=c[a>>2]|0;i=c[e+1072>>2]|0;j=_(f,d)|0;aZ[g&15](h,i,j);j=_(c[e+12>>2]|0,d)|0;i=a;c[i>>2]=(c[i>>2]|0)+j;b=b-d|0;}return;}function cf(a,b){a=a|0;b=b|0;var e=0,f=0,h=0;e=a;a=b;b=_(d[e+1724+(a*236|0)+3|0]|0,c[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+8>>2]|0)|0;f=_(b,c[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+24>>2]|0)|0;if((c[e+8>>2]&1|0)!=0){c[e+1724+(a*236|0)+232>>2]=3;g[e+1724+(a*236|0)+68>>2]=+(f|0)*+g[(c[e+1724+(a*236|0)+4>>2]|0)+84>>2]*+g[e+16>>2]*4.76837158203125e-7;return;}do{if((c[e+1724+(a*236|0)+228>>2]|0)>60){if((c[e+1724+(a*236|0)+228>>2]|0)>=68){h=827;break;}c[e+1724+(a*236|0)+232>>2]=3;g[e+1724+(a*236|0)+68>>2]=+(f|0)*+g[(c[e+1724+(a*236|0)+4>>2]|0)+84>>2]*+g[e+16>>2]*4.76837158203125e-7;}else{h=827;}}while(0);if((h|0)==827){if((c[e+1724+(a*236|0)+228>>2]|0)<5){c[e+1724+(a*236|0)+232>>2]=1;g[e+1724+(a*236|0)+68>>2]=+(f|0)*+g[(c[e+1724+(a*236|0)+4>>2]|0)+84>>2]*+g[e+16>>2]*9.5367431640625e-7;}else{if((c[e+1724+(a*236|0)+228>>2]|0)>123){c[e+1724+(a*236|0)+232>>2]=2;g[e+1724+(a*236|0)+68>>2]=+(f|0)*+g[(c[e+1724+(a*236|0)+4>>2]|0)+84>>2]*+g[e+16>>2]*9.5367431640625e-7;}else{c[e+1724+(a*236|0)+232>>2]=0;g[e+1724+(a*236|0)+68>>2]=+(f|0)*+g[(c[e+1724+(a*236|0)+4>>2]|0)+84>>2]*+g[e+16>>2]*7.450580596923828e-9;g[e+1724+(a*236|0)+72>>2]=+g[e+1724+(a*236|0)+68>>2]*+(c[e+1724+(a*236|0)+228>>2]|0);f=e+1724+(a*236|0)+68|0;g[f>>2]=+g[f>>2]*+(127-(c[e+1724+(a*236|0)+228>>2]|0)|0);}}}return;}function cg(a,b){a=a|0;b=b|0;var e=0,f=0;e=a;a=b;if((c[e+8>>2]&1|0)!=0){f=a<<2;}else{f=a<<3;}c5(c[e+1072>>2]|0,0,f|0);f=0;while(1){if((f|0)>=(c[e+13052>>2]|0)){break;}if((d[e+1724+(f*236|0)|0]|0|0)!=0){bK(e,c[e+1072>>2]|0,f,a);}f=f+1|0;}f=e+13088|0;c[f>>2]=(c[f>>2]|0)+a;return;}function ch(b,c){b=b|0;c=c|0;a[b+1724+(c*236|0)|0]=4;return;}function ci(b,d){b=b|0;d=d|0;var e=0,f=0;e=b;b=d;if((a[(c[e+1724+(b*236|0)+4>>2]|0)+110|0]&64|0)!=0){c[e+1724+(b*236|0)+220>>2]=3;a[e+1724+(b*236|0)|0]=3;d=e;f=b;bI(d,f)|0;bJ(e,b);return;}else{a[e+1724+(b*236|0)|0]=3;return;}}function cj(a,b){a=a|0;b=b|0;var e=0,f=0,i=0,j=0,l=0,m=0.0;e=a;a=b;b=(c[e+1724+(a*236|0)+20>>2]|0)<0|0;f=c[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+20>>2]|0;if((c[(c[e+1724+(a*236|0)+4>>2]|0)+12>>2]|0)==0){return;}if((c[e+1724+(a*236|0)+212>>2]|0)!=0){i=32;while(1){j=i;i=j-1|0;if((j|0)==0){break;}c[e+1724+(a*236|0)+80+(i<<2)>>2]=0;}}do{if((f|0)==8192){l=866;}else{if((f|0)<0){l=866;break;}if((f|0)>16383){l=866;break;}f=f-8192|0;if(+g[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+36>>2]==0.0){i=_(f,c[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+32>>2]|0)|0;if((f|0)<0){i=-i|0;}j=1704+((i>>5&255)<<3)|0;m=(c[k>>2]=d[j]|d[j+1|0]<<8|d[j+2|0]<<16|d[j+3|0]<<24,c[k+4>>2]=d[j+4|0]|d[j+5|0]<<8|d[j+6|0]<<16|d[j+7|0]<<24,+h[k>>3]);j=3752+(i>>13<<3)|0;g[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+36>>2]=m*(c[k>>2]=d[j]|d[j+1|0]<<8|d[j+2|0]<<16|d[j+3|0]<<24,c[k+4>>2]=d[j+4|0]|d[j+5|0]<<8|d[j+6|0]<<16|d[j+7|0]<<24,+h[k>>3]);}if((f|0)>0){c[e+1724+(a*236|0)+12>>2]=~~(+g[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+36>>2]*+(c[e+1724+(a*236|0)+8>>2]|0));}else{c[e+1724+(a*236|0)+12>>2]=~~(+(c[e+1724+(a*236|0)+8>>2]|0)/+g[e+1084+((d[e+1724+(a*236|0)+1|0]|0)*40|0)+36>>2]);}}}while(0);if((l|0)==866){c[e+1724+(a*236|0)+12>>2]=c[e+1724+(a*236|0)+8>>2];}m=+(c[(c[e+1724+(a*236|0)+4>>2]|0)+12>>2]|0)*+(c[e+1724+(a*236|0)+12>>2]|0)/(+(c[(c[e+1724+(a*236|0)+4>>2]|0)+32>>2]|0)*+(c[e+4>>2]|0))*4096.0;if((b|0)!=0){m=-0.0-m;}c[e+1724+(a*236|0)+20>>2]=~~m;return;}function ck(a){a=a|0;var b=0;b=a;a=0;while(1){if((a|0)>=16){break;}cb(b,a);c[b+1084+(a*40|0)+4>>2]=c[b+1056>>2];c[b+1084+(a*40|0)+16>>2]=-1;c[b+1084+(a*40|0)+32>>2]=2;c[b+1084+(a*40|0)>>2]=0;a=a+1|0;}cm(b);return;}function cl(a,b){a=a|0;b=b|0;var e=0,f=0;e=a;a=b;cm(e);L1123:while(1){if(+(c[c[e+13080>>2]>>2]|0)/+g[258]>=+(a|0)){break;}switch(d[(c[e+13080>>2]|0)+5|0]|0|0){case 7:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+24>>2]=d[(c[e+13080>>2]|0)+6|0]|0;break;}case 13:{cb(e,d[(c[e+13080>>2]|0)+4|0]|0);break;}case 4:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+8>>2]=d[(c[e+13080>>2]|0)+6|0]|0;break;}case 11:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+32>>2]=d[(c[e+13080>>2]|0)+6|0]|0;g[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+36>>2]=0.0;break;}case 99:{f=902;break L1123;break;}case 9:{if((c[e+13056>>2]&1<<(d[(c[e+13080>>2]|0)+4|0]|0)|0)!=0){c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)>>2]=d[(c[e+13080>>2]|0)+6|0]|0;}else{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+4>>2]=d[(c[e+13080>>2]|0)+6|0]|0;}break;}case 8:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+20>>2]=(d[(c[e+13080>>2]|0)+6|0]|0)+((d[(c[e+13080>>2]|0)+7|0]|0)<<7);g[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+36>>2]=0.0;break;}case 15:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)>>2]=d[(c[e+13080>>2]|0)+6|0]|0;break;}case 10:{c[392]=(d[(c[e+13080>>2]|0)+4|0]|0)+((d[(c[e+13080>>2]|0)+7|0]|0)<<8)+((d[(c[e+13080>>2]|0)+6|0]|0)<<16);break;}case 5:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+16>>2]=d[(c[e+13080>>2]|0)+6|0]|0;break;}case 6:{c[e+1084+((d[(c[e+13080>>2]|0)+4|0]|0)*40|0)+12>>2]=d[(c[e+13080>>2]|0)+6|0]|0;break;}default:{}}b=e+13080|0;c[b>>2]=(c[b>>2]|0)+8;}if((f|0)==902){c[e+13088>>2]=~~(+(c[c[e+13080>>2]>>2]|0)/+g[258]);return;}if((c[e+13080>>2]|0)!=(c[e+13076>>2]|0)){f=e+13080|0;c[f>>2]=(c[f>>2]|0)-8;}c[e+13088>>2]=a;return;}function cm(b){b=b|0;var c=0;c=b;b=0;while(1){if((b|0)>=48){break;}a[c+1724+(b*236|0)|0]=0;b=b+1|0;}return;}function cn(b,e,f){b=b|0;e=e|0;f=f|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0;h=b;b=e;e=f;if((c[h+13056>>2]&1<>2]<<2)>>2]|0)+4+(d[b+6|0]<<2)>>2]|0;i=f;do{if((f|0)==0){j=c[(c[h+540>>2]|0)+4+(d[b+6|0]<<2)>>2]|0;i=j;if((j|0)!=0){break;}return;}}while(0);(c[i>>2]|0)!=1;if((a[(c[i+4>>2]|0)+112|0]|0)!=0){f=1056+(a[(c[i+4>>2]|0)+112|0]<<2)|0;c[h+1724+(e*236|0)+8>>2]=d[f]|d[f+1|0]<<8|d[f+2|0]<<16|d[f+3|0]<<24;}else{f=1056+((a[b+6|0]&127)<<2)|0;c[h+1724+(e*236|0)+8>>2]=d[f]|d[f+1|0]<<8|d[f+2|0]<<16|d[f+3|0]<<24;}c[h+1724+(e*236|0)+4>>2]=c[i+4>>2];}else{if(-1!=(c[1640+(d[b+4|0]<<2)>>2]|0)){f=c[h+28+(c[h+1084+((d[b+4|0]|0)*40|0)>>2]<<2)>>2]|0;j=c[1640+(d[b+4|0]<<2)>>2]|0;if(0==(c[f+4+(j<<2)>>2]|0)){k=0;l=h;m=c[(c[f>>2]|0)+(j*28|0)>>2]|0;n=(k|0)!=0?1:0;o=c[(c[f>>2]|0)+(j*28|0)+12>>2]|0;p=c[(c[f>>2]|0)+(j*28|0)+8>>2]|0;if((c[(c[f>>2]|0)+(j*28|0)+4>>2]|0)!=-1){q=c[(c[f>>2]|0)+(j*28|0)+4>>2]|0;}else{if((k|0)!=0){r=j;}else{r=-1;}q=r;}if((c[(c[f>>2]|0)+(j*28|0)+16>>2]|0)!=-1){s=c[(c[f>>2]|0)+(j*28|0)+16>>2]|0;}else{s=(k|0)!=0?1:-1;}if((c[(c[f>>2]|0)+(j*28|0)+20>>2]|0)!=-1){t=c[(c[f>>2]|0)+(j*28|0)+20>>2]|0;}else{t=(k|0)!=0?1:-1;}c[f+4+(j<<2)>>2]=bl(l,m,n,o,p,q,s,t,c[(c[f>>2]|0)+(j*28|0)+24>>2]|0)|0;}i=c[f+4+(j<<2)>>2]|0;}else{if((c[h+1084+((d[b+4|0]|0)*40|0)+4>>2]|0)==-1){i=c[h+1052>>2]|0;}else{j=c[(c[h+28+(c[h+1084+((d[b+4|0]|0)*40|0)>>2]<<2)>>2]|0)+4+(c[h+1084+((d[b+4|0]|0)*40|0)+4>>2]<<2)>>2]|0;i=j;do{if((j|0)==0){f=c[(c[h+28>>2]|0)+4+(c[h+1084+((d[b+4|0]|0)*40|0)+4>>2]<<2)>>2]|0;i=f;if((f|0)!=0){break;}return;}}while(0);}}if((a[(c[i+4>>2]|0)+112|0]|0)!=0){j=1056+(a[(c[i+4>>2]|0)+112|0]<<2)|0;c[h+1724+(e*236|0)+8>>2]=d[j]|d[j+1|0]<<8|d[j+2|0]<<16|d[j+3|0]<<24;}else{j=1056+(((d[b+6|0]|0)+(c[1662]|0)&127)<<2)|0;c[h+1724+(e*236|0)+8>>2]=d[j]|d[j+1|0]<<8|d[j+2|0]<<16|d[j+3|0]<<24;}c[h+1724+(e*236|0)+8>>2]=~~(+(c[h+1724+(e*236|0)+8>>2]|0)*+g[260]/440.0);co(h,e,i,d[b+7|0]|0);}a[h+1724+(e*236|0)|0]=1;a[h+1724+(e*236|0)+1|0]=a[b+4|0]|0;a[h+1724+(e*236|0)+2|0]=a[b+6|0]|0;a[h+1724+(e*236|0)+3|0]=cp(a[b+7|0]|0,+g[1576+(d[b+4|0]<<2)>>2])|0;c[h+1724+(e*236|0)+16>>2]=0;c[h+1724+(e*236|0)+20>>2]=0;c[h+1724+(e*236|0)+44>>2]=0;c[h+1724+(e*236|0)+48>>2]=c[(c[h+1724+(e*236|0)+4>>2]|0)+96>>2];c[h+1724+(e*236|0)+36>>2]=c[(c[h+1724+(e*236|0)+4>>2]|0)+92>>2];c[h+1724+(e*236|0)+40>>2]=0;c[h+1724+(e*236|0)+52>>2]=c[(c[h+1724+(e*236|0)+4>>2]|0)+100>>2];c[h+1724+(e*236|0)+56>>2]=0;c[h+1724+(e*236|0)+212>>2]=c[(c[h+1724+(e*236|0)+4>>2]|0)+104>>2];c[h+1724+(e*236|0)+208>>2]=0;c[h+1724+(e*236|0)+216>>2]=0;i=0;while(1){if((i|0)>=32){break;}c[h+1724+(e*236|0)+80+(i<<2)>>2]=0;i=i+1|0;}if((c[h+1084+((d[b+4|0]|0)*40|0)+16>>2]|0)!=-1){c[h+1724+(e*236|0)+228>>2]=c[h+1084+((d[b+4|0]|0)*40|0)+16>>2];}else{c[h+1724+(e*236|0)+228>>2]=a[(c[h+1724+(e*236|0)+4>>2]|0)+111|0]|0;}cj(h,e);cf(h,e);if((a[(c[h+1724+(e*236|0)+4>>2]|0)+110|0]&64|0)!=0){c[h+1724+(e*236|0)+220>>2]=0;c[h+1724+(e*236|0)+24>>2]=0;c[h+1724+(e*236|0)+224>>2]=0;b=h;i=e;bI(b,i)|0;bJ(h,e);return;}else{c[h+1724+(e*236|0)+32>>2]=0;bJ(h,e);return;}}function co(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0;f=a;a=b;b=d;d=e;e=c[b>>2]|0;g=c[b+4>>2]|0;if((e|0)==1){c[f+1724+(a*236|0)+4>>2]=g;return;}h=c[f+1724+(a*236|0)+8>>2]|0;i=0;L1232:while(1){if((i|0)>=(e|0)){break;}do{if((c[g+16>>2]|0)<=(d|0)){if((c[g+20>>2]|0)<(d|0)){break;}if((c[g+24>>2]|0)>(h|0)){break;}if((c[g+28>>2]|0)>=(h|0)){j=977;break L1232;}}}while(0);g=g+116|0;i=i+1|0;}if((j|0)==977){c[f+1724+(a*236|0)+4>>2]=g;return;}j=2147483647;d=c[b+4>>2]|0;g=d;b=d;i=0;while(1){if((i|0)>=(e|0)){break;}d=(c[g+32>>2]|0)-h|0;if((d|0)<0){d=-d|0;}if((d|0)<(j|0)){j=d;b=g;}g=g+116|0;i=i+1|0;}c[f+1724+(a*236|0)+4>>2]=b;return;}function cp(a,b){a=a|0;b=+b;var d=0,e=0,f=0.0,g=0,h=0,j=0,k=0;d=i;e=a;f=b;if(f<=1.0){g=~~(+(e&255|0)*f);h=g;i=d;return h|0;}else{a=(e&255)+(~~(+(127-(e&255)|0)*(f-1.0))&255)&255;j=e&255;e=a&255;aG(4784,(k=i,i=i+16|0,c[k>>2]=j,c[k+8>>2]=e,k)|0)|0;i=k;g=a;h=g;i=d;return h|0;}return 0;}function cq(d,e,f,g){d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;h=i;i=i+40|0;j=h|0;k=h+8|0;l=h+16|0;m=h+24|0;n=h+32|0;o=d;d=e;e=f;f=g;c[d+13092>>2]=0;c[d+13096>>2]=0;c[d+13084>>2]=0;do{if((cP(o,n|0,1,4)|0)==4){if((cP(o,j,4,1)|0)!=1){break;}c[j>>2]=(c[j>>2]&255)<<24|(c[j>>2]&65280)<<8|(c[j>>2]&16711680)>>8|c[j>>2]>>24&255;do{if((c4(n|0,4776,4)|0)==0){if((c[j>>2]|0)<6){break;}g=o;p=k;cP(g,p,2,1)|0;p=o;g=l;cP(p,g,2,1)|0;g=o;p=m;cP(g,p,2,1)|0;b[k>>1]=((b[k>>1]&255)<<8|b[k>>1]>>8&255)&65535;b[l>>1]=((b[l>>1]&255)<<8|b[l>>1]>>8&255)&65535;b[m>>1]=((b[m>>1]&255)<<8|b[m>>1]>>8&255)&65535;if((b[m>>1]|0)<0){q=_(-((b[m>>1]|0)/256|0)|0,b[m>>1]&255)|0;}else{q=b[m>>1]|0;}if((c[j>>2]|0)>6){cQ(o,(c[j>>2]|0)-6|0);}do{if((b[k>>1]|0)>=0){if((b[k>>1]|0)>2){break;}c[d+13084>>2]=bi(12)|0;c[c[d+13084>>2]>>2]=0;a[(c[d+13084>>2]|0)+5|0]=0;c[(c[d+13084>>2]|0)+8>>2]=0;p=d+13092|0;c[p>>2]=(c[p>>2]|0)+1;p=b[k>>1]|0;do{if((p|0)==1){r=0;while(1){if((r|0)>=(b[l>>1]|0)){s=1023;break;}if((cr(o,d,0)|0)!=0){break;}r=r+1|0;}if((s|0)==1023){break;}cs(d);t=0;u=t;i=h;return u|0;}else if((p|0)==2){r=0;while(1){if((r|0)>=(b[l>>1]|0)){s=1030;break;}if((cr(o,d,1)|0)!=0){break;}r=r+1|0;}if((s|0)==1030){break;}cs(d);t=0;u=t;i=h;return u|0;}else if((p|0)==0){if((cr(o,d,0)|0)==0){break;}cs(d);t=0;u=t;i=h;return u|0;}}while(0);t=ct(d,q,e,f)|0;u=t;i=h;return u|0;}}while(0);t=0;u=t;i=h;return u|0;}}while(0);t=0;u=t;i=h;return u|0;}}while(0);t=0;u=t;i=h;return u|0;}function cr(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0;e=i;i=i+16|0;f=e|0;g=e+8|0;h=a;a=b;b=c[a+13084>>2]|0;do{if((d|0)!=0){if((b|0)==0){j=1047;break;}while(1){if((c[b+8>>2]|0)==0){break;}b=c[b+8>>2]|0;}c[a+13096>>2]=c[b>>2];}else{j=1047;}}while(0);if((j|0)==1047){c[a+13096>>2]=0;}do{if((cP(h,g|0,1,4)|0)==4){if((cP(h,f,4,1)|0)!=1){break;}c[f>>2]=(c[f>>2]&255)<<24|(c[f>>2]&65280)<<8|(c[f>>2]&16711680)>>8|c[f>>2]>>24&255;if((c4(g|0,6272,4)|0)!=0){k=-2;l=k;i=e;return l|0;}while(1){d=cv(h,a)|0;m=d;if((d|0)==0){j=1055;break;}if((m|0)==-1){j=1057;break;}d=c[b+8>>2]|0;while(1){if((d|0)!=0){n=(c[d>>2]|0)<(c[m>>2]|0);}else{n=0;}if(!n){break;}b=d;d=c[b+8>>2]|0;}c[m+8>>2]=d;c[b+8>>2]=m;o=a+13092|0;c[o>>2]=(c[o>>2]|0)+1;b=m;}if((j|0)==1055){k=-2;l=k;i=e;return l|0;}else if((j|0)==1057){k=0;l=k;i=e;return l|0;}}}while(0);k=-1;l=k;i=e;return l|0;}function cs(a){a=a|0;var b=0,d=0;b=a;a=c[b+13084>>2]|0;d=a;if((a|0)==0){return;}while(1){if((d|0)==0){break;}a=c[d+8>>2]|0;c0(d);d=a;}c[b+13084>>2]=0;return;}function ct(b,e,f,g){b=b|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0;h=i;i=i+192|0;j=h|0;k=h+64|0;l=h+128|0;m=b;b=e;e=f;f=g;g=0;while(1){if((g|0)>=16){break;}c[j+(g<<2)>>2]=0;c[k+(g<<2)>>2]=0;c[l+(g<<2)>>2]=c[m+1056>>2];g=g+1|0;}n=5e5;cu(m,n,b);o=bi((c[m+13092>>2]|0)+1<<3)|0;p=o;q=o;o=c[m+13084>>2]|0;r=0;s=0;t=0;u=0;v=0;g=0;while(1){if((g|0)>=(c[m+13092>>2]|0)){break;}w=0;x=d[o+5|0]|0;do{if((x|0)==9){if((c[m+13056>>2]&1<<(d[o+4|0]|0)|0)!=0){if((c[m+540+((d[o+6|0]|0)<<2)>>2]|0)!=0){y=d[o+6|0]|0;}else{a[o+6|0]=0;y=0;}if((c[k+((d[o+4|0]|0)<<2)>>2]|0)!=(y|0)){c[k+((d[o+4|0]|0)<<2)>>2]=y;}else{w=1;}}else{y=d[o+6|0]|0;do{if((c[l+((d[o+4|0]|0)<<2)>>2]|0)!=-1){if((c[l+((d[o+4|0]|0)<<2)>>2]|0)==(y|0)){z=1096;break;}c[l+((d[o+4|0]|0)<<2)>>2]=y;}else{z=1096;}}while(0);if((z|0)==1096){z=0;w=1;}}}else if((x|0)==15){if((c[m+13056>>2]&1<<(d[o+4|0]|0)|0)!=0){w=1;break;}if((c[m+28+((d[o+6|0]|0)<<2)>>2]|0)!=0){y=d[o+6|0]|0;}else{a[o+6|0]=0;y=0;}if((c[j+((d[o+4|0]|0)<<2)>>2]|0)!=(y|0)){c[j+((d[o+4|0]|0)<<2)>>2]=y;}else{w=1;}}else if((x|0)==1){if((v|0)!=0){v=1;}if((c[m+13056>>2]&1<<(d[o+4|0]|0)|0)!=0){if((c[(c[m+540+(c[k+((d[o+4|0]|0)<<2)>>2]<<2)>>2]|0)+4+((d[o+6|0]|0)<<2)>>2]|0)==0){c[(c[m+540+(c[k+((d[o+4|0]|0)<<2)>>2]<<2)>>2]|0)+4+((d[o+6|0]|0)<<2)>>2]=-1;}}else{if((c[l+((d[o+4|0]|0)<<2)>>2]|0)==-1){break;}if((c[(c[m+28+(c[j+((d[o+4|0]|0)<<2)>>2]<<2)>>2]|0)+4+(c[l+((d[o+4|0]|0)<<2)>>2]<<2)>>2]|0)==0){c[(c[m+28+(c[j+((d[o+4|0]|0)<<2)>>2]<<2)>>2]|0)+4+(c[l+((d[o+4|0]|0)<<2)>>2]<<2)>>2]=-1;}}}}while(0);x=(c[o>>2]|0)-t|0;A=x;do{if((x|0)!=0){if((v|0)!=0){z=1125;break;}B=_(c[m+1076>>2]|0,A)|0;s=s+(_(c[m+1080>>2]|0,A)|0)|0;if((s&-65536|0)!=0){B=B+(s>>16&65535)|0;s=s&65535;}u=u+B|0;}else{z=1125;}}while(0);if((z|0)==1125){z=0;if((v|0)==1){v=0;}}if((d[o+5|0]|0|0)==10){n=(d[o+4|0]|0)+((d[o+7|0]|0)<<8)+((d[o+6|0]|0)<<16)|0;cu(m,n,b);}if((w|0)==0){A=p;x=o|0;c[A>>2]=c[x>>2];c[A+4>>2]=c[x+4>>2];c[p>>2]=u;p=p+8|0;r=r+1|0;}t=c[o>>2]|0;o=c[o+8>>2]|0;g=g+1|0;}c[p>>2]=u;a[p+5|0]=99;r=r+1|0;cs(m);c[e>>2]=r;c[f>>2]=u;i=h;return q|0;}function cu(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0.0;e=a;f=+(b|0)*+(c[e+4>>2]|0)*0.065536/+(d|0);c[e+1080>>2]=~~f&65535;c[e+1076>>2]=~~f>>16;return;}function cv(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0;f=i;i=i+40|0;g=f|0;h=f+8|0;j=f+16|0;k=f+24|0;l=f+32|0;m=b;b=e;L1442:while(1){e=cw(m)|0;n=b+13096|0;c[n>>2]=(c[n>>2]|0)+e;if((cP(m,g,1,1)|0)!=1){o=1138;break;}do{if((d[g]|0)==240){o=1141;}else{if((d[g]|0)==247){o=1141;break;}if((d[g]|0)==255){e=m;cP(e,h,1,1)|0;p=cw(m)|0;do{if((d[h]|0)>0){if((d[h]|0)>=16){o=1146;break;}e=m;n=p;q=a[h]|0;r=b;cx(e,n,q,r)|0;}else{o=1146;}}while(0);if((o|0)==1146){o=0;r=d[h]|0;if((r|0)==47){o=1147;break L1442;}else if((r|0)==81){o=1148;break L1442;}cQ(m,p);}}else{a[j]=a[g]|0;if((a[j]&128|0)!=0){a[6632]=d[j]&15;a[6624]=d[j]>>4&7;r=m;cP(r,j,1,1)|0;a[j]=d[j]&127;}switch(d[6624]|0){case 1:{o=1156;break L1442;break;}case 6:{o=1188;break L1442;break;}case 4:{o=1186;break L1442;break;}case 5:{break;}case 0:{o=1155;break L1442;break;}case 2:{o=1157;break L1442;break;}case 3:{cP(m,k,1,1)|0;a[k]=d[k]&127;s=255;L1466:do{switch(d[j]|0){case 98:{a[6616]=1;a[6600+(d[6632]|0)|0]=a[k]|0;break;}case 6:{if((a[6616]|0)!=0){break L1466;}r=d[6584+(d[6632]|0)|0]<<8|d[6600+(d[6632]|0)|0];if((r|0)==0){s=11;}else if((r|0)==32639){o=1179;break L1442;}break;}case 7:{s=4;break;}case 10:{s=5;break;}case 11:{s=7;break;}case 64:{s=6;break;}case 120:{s=12;break;}case 121:{s=13;break;}case 123:{s=14;break;}case 0:{s=15;break;}case 32:{if((d[k]|0)==0){s=15;}break;}case 100:{a[6616]=0;a[6584+(d[6632]|0)|0]=a[k]|0;break;}case 101:{a[6616]=0;a[6600+(d[6632]|0)|0]=a[k]|0;break;}case 99:{a[6616]=1;a[6584+(d[6632]|0)|0]=a[k]|0;break;}default:{}}}while(0);if((s|0)!=255){o=1184;break L1442;}break;}default:{}}}}}while(0);if((o|0)==1141){o=0;p=cw(m)|0;cQ(m,p);}}if((o|0)==1184){t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=s&255;a[t+4|0]=a[6632]|0;a[t+6|0]=a[k]|0;a[t+7|0]=0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1156){cP(m,k,1,1)|0;a[k]=d[k]&127;t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=1;a[t+4|0]=a[6632]|0;a[t+6|0]=a[j]|0;a[t+7|0]=a[k]|0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1179){t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=11;a[t+4|0]=a[6632]|0;a[t+6|0]=2;a[t+7|0]=0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1138){u=0;v=u;i=f;return v|0;}else if((o|0)==1188){cP(m,k,1,1)|0;a[k]=d[k]&127;t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=8;a[t+4|0]=a[6632]|0;a[t+6|0]=a[j]|0;a[t+7|0]=a[k]|0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1186){a[j]=d[j]&127;t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=9;a[t+4|0]=a[6632]|0;a[t+6|0]=a[j]|0;a[t+7|0]=0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1147){u=-1;v=u;i=f;return v|0;}else if((o|0)==1148){cP(m,j,1,1)|0;cP(m,k,1,1)|0;cP(m,l,1,1)|0;t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=10;a[t+4|0]=a[l]|0;a[t+6|0]=a[j]|0;a[t+7|0]=a[k]|0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1155){cP(m,k,1,1)|0;a[k]=d[k]&127;t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=2;a[t+4|0]=a[6632]|0;a[t+6|0]=a[j]|0;a[t+7|0]=a[k]|0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}else if((o|0)==1157){cP(m,k,1,1)|0;a[k]=d[k]&127;t=bi(12)|0;c[t>>2]=c[b+13096>>2];a[t+5|0]=3;a[t+4|0]=a[6632]|0;a[t+6|0]=a[j]|0;a[t+7|0]=a[k]|0;c[t+8>>2]=0;u=t;v=u;i=f;return v|0;}return 0;}function cw(b){b=b|0;var c=0,d=0,e=0;c=i;i=i+8|0;d=c|0;e=b;b=0;while(1){cP(e,d,1,1)|0;b=b+(a[d]&127)|0;if((a[d]&128|0)==0){break;}b=b<<7;}i=c;return b|0;}function cx(b,e,f,g){b=b|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0;h=e;e=f;f=g;g=bi(h+1|0)|0;if((h|0)!=(cP(b,g,1,h)|0)){c0(g);i=-1;j=i;return j|0;}a[g+h|0]=0;while(1){b=h;h=b-1|0;if((b|0)==0){break;}if((d[g+h|0]|0|0)<32){a[g+h|0]=46;}}h=e&255;if((h|0)==1){k=0;}else if((h|0)==2){k=1;}else{c0(g);g=0;}if((g|0)!=0){if((c[f+13104+(k<<2)>>2]|0)!=0){c0(c[f+13104+(k<<2)>>2]|0);}c[f+13104+(k<<2)>>2]=g;}i=0;j=i;return j|0;}function cy(b,e,f){b=b|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0;g=b;b=e;e=f;f=g+1724+(b*236|0)|0;if((c[(c[f+4>>2]|0)+12>>2]|0)==0){h=c[f+16>>2]>>12;if((c[e>>2]|0)>=((c[(c[f+4>>2]|0)+8>>2]>>12)-h|0)){a[f|0]=0;c[e>>2]=(c[(c[f+4>>2]|0)+8>>2]>>12)-h;}else{i=f+16|0;c[i>>2]=(c[i>>2]|0)+(c[e>>2]<<12);}j=(c[(c[f+4>>2]|0)+88>>2]|0)+(h<<1)|0;k=j;return k|0;}h=a[(c[f+4>>2]|0)+110|0]|0;if((c[f+212>>2]|0)!=0){L1575:do{if((h&4|0)!=0){do{if((h&64|0)==0){if((d[f|0]|0|0)==1){break;}if((d[f|0]|0|0)!=2){break L1575;}}}while(0);if((h&8|0)!=0){j=cz(g,f,c[e>>2]|0)|0;k=j;return k|0;}else{j=cA(g,f,c[e>>2]|0)|0;k=j;return k|0;}}}while(0);j=cB(g,b,e)|0;k=j;return k|0;}else{L1561:do{if((h&4|0)!=0){do{if((h&64|0)==0){if((d[f|0]|0|0)==1){break;}if((d[f|0]|0|0)!=2){break L1561;}}}while(0);if((h&8|0)!=0){j=cC(g,f,c[e>>2]|0)|0;k=j;return k|0;}else{j=cD(g,f,c[e>>2]|0)|0;k=j;return k|0;}}}while(0);j=cE(g,b,e)|0;k=j;return k|0;}return 0;}function cz(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;f=a;a=d;d=e;e=c[a+16>>2]|0;g=c[a+20>>2]|0;h=c[(c[a+4>>2]|0)+4>>2]|0;i=c[c[a+4>>2]>>2]|0;j=c[f+1068>>2]|0;k=c[(c[a+4>>2]|0)+88>>2]|0;l=c[a+216>>2]|0;m=h<<1;n=i<<1;o=0;while(1){if((d|0)!=0){p=(e|0)<=(i|0);}else{p=0;}if(!p){break;}q=((i-e|0)/(g|0)|0)+1|0;if((q|0)>(d|0)){q=d;}if((q|0)>(l|0)){q=l;o=1;}else{l=l-q|0;}d=d-q|0;while(1){r=q;q=r-1|0;if((r|0)==0){break;}s=b[k+(e>>12<<1)>>1]|0;t=b[k+((e>>12)+1<<1)>>1]|0;r=j;j=r+2|0;b[r>>1]=(s<<16>>16)+((_((t<<16>>16)-(s<<16>>16)|0,e&4095)|0)>>>12)&65535;e=e+g|0;}if((o|0)!=0){l=c[a+212>>2]|0;g=cG(f,a,0)|0;o=0;}}while(1){if((d|0)==0){break;}if((g|0)>0){u=h;}else{u=i;}q=((u-e|0)/(g|0)|0)+1|0;if((q|0)>(d|0)){q=d;}if((q|0)>(l|0)){q=l;o=1;}else{l=l-q|0;}d=d-q|0;while(1){p=q;q=p-1|0;if((p|0)==0){break;}s=b[k+(e>>12<<1)>>1]|0;t=b[k+((e>>12)+1<<1)>>1]|0;p=j;j=p+2|0;b[p>>1]=(s<<16>>16)+((_((t<<16>>16)-(s<<16>>16)|0,e&4095)|0)>>>12)&65535;e=e+g|0;}if((o|0)!=0){l=c[a+212>>2]|0;g=cG(f,a,(g|0)<0|0)|0;o=0;}if((e|0)>=(h|0)){e=m-e|0;g=g*-1|0;}else{if((e|0)<=(i|0)){e=n-e|0;g=g*-1|0;}}}c[a+216>>2]=l;c[a+20>>2]=g;c[a+16>>2]=e;return c[f+1068>>2]|0;}function cA(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0;f=a;a=d;d=e;e=c[a+16>>2]|0;g=c[a+20>>2]|0;h=c[(c[a+4>>2]|0)+4>>2]|0;i=h-(c[c[a+4>>2]>>2]|0)|0;j=c[f+1068>>2]|0;k=c[(c[a+4>>2]|0)+88>>2]|0;l=c[a+216>>2]|0;m=0;while(1){if((d|0)==0){break;}if((e|0)>=(h|0)){e=e-i|0;}n=((h-e|0)/(g|0)|0)+1|0;if((n|0)>(d|0)){n=d;}if((n|0)>(l|0)){n=l;m=1;}else{l=l-n|0;}d=d-n|0;while(1){o=n;n=o-1|0;if((o|0)==0){break;}o=b[k+(e>>12<<1)>>1]|0;p=j;j=p+2|0;b[p>>1]=(o<<16>>16)+((_((b[k+((e>>12)+1<<1)>>1]|0)-(o<<16>>16)|0,e&4095)|0)>>>12)&65535;e=e+g|0;}if((m|0)!=0){l=c[a+212>>2]|0;g=cG(f,a,0)|0;m=0;}}c[a+216>>2]=l;c[a+20>>2]=g;c[a+16>>2]=e;return c[f+1068>>2]|0;}function cB(d,e,f){d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0;g=d;d=f;f=g+1724+(e*236|0)|0;e=c[g+1068>>2]|0;h=c[(c[f+4>>2]|0)+88>>2]|0;i=c[(c[f+4>>2]|0)+8>>2]|0;j=c[f+16>>2]|0;k=c[f+20>>2]|0;l=c[d>>2]|0;m=c[f+216>>2]|0;if((k|0)<0){k=-k|0;}do{n=l;l=n-1|0;if((n|0)==0){o=1322;break;}n=m;m=n-1|0;if((n|0)==0){m=c[f+212>>2]|0;k=cG(g,f,0)|0;}n=b[h+(j>>12<<1)>>1]|0;p=e;e=p+2|0;b[p>>1]=(n<<16>>16)+((_((b[h+((j>>12)+1<<1)>>1]|0)-(n<<16>>16)|0,j&4095)|0)>>>12)&65535;j=j+k|0;}while((j|0)<(i|0));if((o|0)==1322){q=m;r=f;s=r+216|0;c[s>>2]=q;t=k;u=f;v=u+20|0;c[v>>2]=t;w=j;x=f;y=x+16|0;c[y>>2]=w;z=g;A=z+1068|0;B=c[A>>2]|0;return B|0;}if((j|0)==(i|0)){i=e;e=i+2|0;b[i>>1]=b[h+(j>>12<<1)>>1]|0;}a[f|0]=0;h=d;c[h>>2]=(c[h>>2]|0)-(l+1);q=m;r=f;s=r+216|0;c[s>>2]=q;t=k;u=f;v=u+20|0;c[v>>2]=t;w=j;x=f;y=x+16|0;c[y>>2]=w;z=g;A=z+1068|0;B=c[A>>2]|0;return B|0;}function cC(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;f=a;a=d;d=e;e=c[a+16>>2]|0;g=c[a+20>>2]|0;h=c[(c[a+4>>2]|0)+4>>2]|0;i=c[c[a+4>>2]>>2]|0;j=c[f+1068>>2]|0;k=c[(c[a+4>>2]|0)+88>>2]|0;l=h<<1;m=i<<1;if((e|0)<=(i|0)){n=((i-e|0)/(g|0)|0)+1|0;if((n|0)>(d|0)){n=d;d=0;}else{d=d-n|0;}while(1){o=n;n=o-1|0;if((o|0)==0){break;}p=b[k+(e>>12<<1)>>1]|0;q=b[k+((e>>12)+1<<1)>>1]|0;o=j;j=o+2|0;b[o>>1]=(p<<16>>16)+((_((q<<16>>16)-(p<<16>>16)|0,e&4095)|0)>>>12)&65535;e=e+g|0;}}while(1){if((d|0)==0){break;}if((g|0)>0){r=h;}else{r=i;}n=((r-e|0)/(g|0)|0)+1|0;if((n|0)>(d|0)){n=d;d=0;}else{d=d-n|0;}while(1){o=n;n=o-1|0;if((o|0)==0){break;}p=b[k+(e>>12<<1)>>1]|0;q=b[k+((e>>12)+1<<1)>>1]|0;o=j;j=o+2|0;b[o>>1]=(p<<16>>16)+((_((q<<16>>16)-(p<<16>>16)|0,e&4095)|0)>>>12)&65535;e=e+g|0;}if((e|0)>=(h|0)){e=l-e|0;g=g*-1|0;}else{if((e|0)<=(i|0)){e=m-e|0;g=g*-1|0;}}}c[a+20>>2]=g;c[a+16>>2]=e;return c[f+1068>>2]|0;}function cD(a,d,e){a=a|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0;f=a;a=d;d=e;e=c[a+16>>2]|0;g=c[a+20>>2]|0;h=c[(c[a+4>>2]|0)+4>>2]|0;i=h-(c[c[a+4>>2]>>2]|0)|0;j=c[f+1068>>2]|0;k=c[(c[a+4>>2]|0)+88>>2]|0;while(1){if((d|0)==0){break;}if((e|0)>=(h|0)){e=e-i|0;}l=((h-e|0)/(g|0)|0)+1|0;if((l|0)>(d|0)){l=d;d=0;}else{d=d-l|0;}while(1){m=l;l=m-1|0;if((m|0)==0){break;}m=b[k+(e>>12<<1)>>1]|0;n=j;j=n+2|0;b[n>>1]=(m<<16>>16)+((_((b[k+((e>>12)+1<<1)>>1]|0)-(m<<16>>16)|0,e&4095)|0)>>>12)&65535;e=e+g|0;}}c[a+16>>2]=e;return c[f+1068>>2]|0;}function cE(d,e,f){d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;g=d;d=f;f=g+1724+(e*236|0)|0;e=c[g+1068>>2]|0;h=c[(c[f+4>>2]|0)+88>>2]|0;i=c[f+16>>2]|0;j=c[f+20>>2]|0;k=c[(c[f+4>>2]|0)+8>>2]|0;l=c[d>>2]|0;if((j|0)<0){j=-j|0;}m=((k-i|0)/(j|0)|0)+1|0;if((m|0)>(l|0)){m=l;l=0;}else{l=l-m|0;}while(1){n=m;m=n-1|0;if((n|0)==0){break;}n=b[h+(i>>12<<1)>>1]|0;o=e;e=o+2|0;b[o>>1]=(n<<16>>16)+((_((b[h+((i>>12)+1<<1)>>1]|0)-(n<<16>>16)|0,i&4095)|0)>>>12)&65535;i=i+j|0;}if((i|0)<(k|0)){p=i;q=f;r=q+16|0;c[r>>2]=p;s=g;t=s+1068|0;u=c[t>>2]|0;return u|0;}if((i|0)==(k|0)){k=e;e=k+2|0;b[k>>1]=b[h+(i>>12<<1)>>1]|0;}a[f|0]=0;h=d;c[h>>2]=(c[h>>2]|0)-(l+1);p=i;q=f;r=q+16|0;c[r>>2]=p;s=g;t=s+1068|0;u=c[t>>2]|0;return u|0;}function cF(e,f){e=e|0;f=f|0;var g=0,h=0,i=0.0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0.0,u=0,v=0,w=0,x=0,y=0,z=0,A=0.0,B=0.0,C=0.0,D=0,E=0,F=0,G=0,H=0,I=0,J=0.0,K=0.0,L=0.0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0;g=f;f=c[g+88>>2]|0;h=1056+(a[g+112|0]<<2)|0;i=+(c[g+12>>2]|0)*+(d[h]|d[h+1|0]<<8|d[h+2|0]<<16|d[h+3|0]<<24|0)/(+(c[g+32>>2]|0)*+(c[e+4>>2]|0));e=~~(+(c[g+8>>2]|0)/i);h=bi(e>>11)|0;j=h;k=h;h=(e>>12)-1|0;l=((c[g+8>>2]|0)-4096|0)/(h|0)|0;m=l;n=l;l=h-1|0;h=l;if((l|0)!=0){l=k;k=l+2|0;b[l>>1]=b[f>>1]|0;}while(1){l=h-1|0;h=l;if((l|0)==0){break;}l=f+(n>>12<<1)|0;if(l>>>0>f>>>0){o=b[l-2>>1]|0;}else{o=0;}p=o&65535;q=b[l>>1]|0;r=b[l+2>>1]|0;s=b[l+4>>1]|0;t=+((n&4095)>>>0>>>0)*0.000244140625;l=k;k=l+2|0;b[l>>1]=~~(+(q<<16>>16|0)+t/6.0*(+(((p<<16>>16)*-2|0)-((q<<16>>16)*3|0)+((r<<16>>16)*6|0)-(s<<16>>16)|0)+t*(+(((p<<16>>16)-(q<<16>>16<<1)+(r<<16>>16)|0)*3|0|0)+t*+((-(p<<16>>16)|0)+(((q<<16>>16)-(r<<16>>16)|0)*3|0)+(s<<16>>16)|0))));n=n+m|0;}if((n&4095|0)!=0){p=b[f+(n>>12<<1)>>1]|0;q=b[f+((n>>12)+1<<1)>>1]|0;m=k;k=m+2|0;b[m>>1]=(p<<16>>16)+((_((q<<16>>16)-(p<<16>>16)|0,n&4095)|0)>>>12)&65535;u=e;v=g;w=v+8|0;c[w>>2]=u;x=g;y=x|0;z=c[y>>2]|0;A=+(z|0);B=i;C=A/B;D=~~C;E=g;F=E|0;c[F>>2]=D;G=g;H=G+4|0;I=c[H>>2]|0;J=+(I|0);K=i;L=J/K;M=~~L;N=g;O=N+4|0;c[O>>2]=M;P=g;Q=P+88|0;R=c[Q>>2]|0;S=R;c0(S);T=j;U=g;V=U+88|0;c[V>>2]=T;W=g;X=W+12|0;c[X>>2]=0;return;}else{p=k;k=p+2|0;b[p>>1]=b[f+(n>>12<<1)>>1]|0;u=e;v=g;w=v+8|0;c[w>>2]=u;x=g;y=x|0;z=c[y>>2]|0;A=+(z|0);B=i;C=A/B;D=~~C;E=g;F=E|0;c[F>>2]=D;G=g;H=G+4|0;I=c[H>>2]|0;J=+(I|0);K=i;L=J/K;M=~~L;N=g;O=N+4|0;c[O>>2]=M;P=g;Q=P+88|0;R=c[Q>>2]|0;S=R;c0(S);T=j;U=g;V=U+88|0;c[V>>2]=T;W=g;X=W+12|0;c[X>>2]=0;return;}}function cG(a,b,e){a=a|0;b=b|0;e=e|0;var f=0,g=0,i=0,j=0,l=0,m=0.0,n=0.0;f=a;a=b;b=e;e=a+208|0;g=c[e>>2]|0;c[e>>2]=g+1;if((g|0)>=63){c[a+208>>2]=0;}g=cH(c[a+208>>2]|0)|0;if((c[a+80+(g<<2)>>2]|0)!=0){if((b|0)!=0){i=-(c[a+80+(g<<2)>>2]|0)|0;j=i;return j|0;}else{i=c[a+80+(g<<2)>>2]|0;j=i;return j|0;}}e=(d[(c[a+4>>2]|0)+109|0]|0)<<7;if((c[a+52>>2]|0)!=0){l=a+56|0;c[l>>2]=(c[l>>2]|0)+(c[a+52>>2]|0);if((c[a+56>>2]|0)>=65536){c[a+52>>2]=0;}else{e=_(e,c[a+56>>2]|0)|0;e=e>>16;}}m=+(c[(c[a+4>>2]|0)+12>>2]|0)*+(c[a+12>>2]|0)/(+(c[(c[a+4>>2]|0)+32>>2]|0)*+(c[f+4>>2]|0))*4096.0;f=~~(+R(+(+(c[a+208>>2]<<4|0)*0.006135923151542565))*+(e|0)*1.0);if((f|0)<0){f=-f|0;e=1704+((f>>5&255)<<3)|0;n=(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]);e=3752+(f>>13<<3)|0;m=m/(n*(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]));}else{e=1704+((f>>5&255)<<3)|0;n=(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]);e=3752+(f>>13<<3)|0;m=m*n*(c[k>>2]=d[e]|d[e+1|0]<<8|d[e+2|0]<<16|d[e+3|0]<<24,c[k+4>>2]=d[e+4|0]|d[e+5|0]<<8|d[e+6|0]<<16|d[e+7|0]<<24,+h[k>>3]);}if((c[a+52>>2]|0)==0){c[a+80+(g<<2)>>2]=~~m;}if((b|0)!=0){m=-0.0-m;}i=~~m;j=i;return j|0;}function cH(a){a=a|0;var b=0,c=0;b=a;do{if((b|0)<16){c=15-b|0;}else{if((b|0)>=48){c=79-b|0;break;}else{c=b-16|0;break;}}}while(0);return c|0;}function cI(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;return an(b|0,d|0,e|0,c[a>>2]|0)|0;}function cJ(a){a=a|0;var b=0,d=0,e=0;b=a;a=0;if((c[b+4>>2]|0)==0){d=b;c0(d);e=a;return e|0;}a=ao(c[b>>2]|0)|0;d=b;c0(d);e=a;return e|0;}function cK(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0;f=d;d=a;a=e;e=c[d+4>>2]|0;g=e+(_(a,f)|0)|0;if(g>>>0>(c[d+8>>2]|0)>>>0){a=(((c[d+8>>2]|0)-(c[d+4>>2]|0)|0)>>>0)/(f>>>0)|0;}g=b;b=c[d+4>>2]|0;e=_(a,f)|0;c6(g|0,b|0,e)|0;e=_(a,f)|0;f=d+4|0;c[f>>2]=(c[f>>2]|0)+e;return a|0;}function cL(a){a=a|0;var b=0,d=0;b=a;if((c[b+12>>2]|0)==0){d=b;c0(d);return 0;}c0(c[b>>2]|0);d=b;c0(d);return 0;}function cM(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0;d=bi(12)|0;if((d|0)==0){e=0;f=e;return f|0;}g=bi(8)|0;if((g|0)==0){c0(d);e=0;f=e;return f|0;}else{c[g>>2]=a;c[g+4>>2]=b;c[d+8>>2]=g;c[d>>2]=2;c[d+4>>2]=4;e=d;f=e;return f|0;}return 0;}function cN(a){a=a|0;var b=0,c=0,d=0;b=av(a|0,6544)|0;if((b|0)==0){c=0;d=c;return d|0;}else{c=cM(b,1)|0;d=c;return d|0;}return 0;}function cO(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0;e=a;a=bi(12)|0;if((a|0)==0){f=0;g=f;return g|0;}h=bi(16)|0;if((h|0)==0){c0(a);f=0;g=f;return g|0;}else{c[h>>2]=e;c[h+4>>2]=e;c[h+8>>2]=e+b;c[h+12>>2]=d;c[a+8>>2]=h;c[a>>2]=4;c[a+4>>2]=2;f=a;g=f;return g|0;}return 0;}function cP(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0;f=a;return aY[c[f>>2]&7](c[f+8>>2]|0,b,d,e)|0;}function cQ(a,b){a=a|0;b=b|0;var c=0,d=0,e=0;c=i;i=i+1024|0;d=c|0;e=a;a=b;while(1){if(a>>>0<=0){break;}b=a;if(b>>>0>1024){b=1024;}a=a-b|0;(b|0)!=(cP(e,d|0,1,b)|0);}i=c;return;}function cR(a){a=a|0;var b=0;b=a;a=aW[c[b+4>>2]&7](c[b+8>>2]|0)|0;c0(b);return a|0;}function cS(){var a=0;c[1676]=bi(516)|0;c5(c[1676]|0,0,516);a=bi(3584)|0;c[c[1676]>>2]=a;c5(c[c[1676]>>2]|0,0,3584);c[1804]=bi(516)|0;c5(c[1804]|0,0,516);a=bi(3584)|0;c[c[1804]>>2]=a;c5(c[c[1804]>>2]|0,0,3584);return 0;}function cT(b){b=b|0;var d=0,e=0,f=0,g=0,h=0,j=0;d=i;i=i+1024|0;e=d|0;f=b;do{if((f|0)!=0){if((c1(f|0)|0)>>>0>=1024){break;}b=e|0;g=f;c2(b|0,g|0)|0;g=aE(f|0,47)|0;if((g|0)!=0){a[e+(g-f)|0]=0;g=c[m>>2]|0;b=e|0;ar(g|0,6480,(g=i,i=i+8|0,c[g>>2]=b,g)|0)|0;i=g;bj(e|0);}}}while(0);cS()|0;do{if((f|0)!=0){if((a[f]|0)==0){break;}h=f;j=cU(h)|0;i=d;return j|0;}}while(0);f=6520;h=f;j=cU(h)|0;i=d;return j|0;}function cU(b){b=b|0;var d=0,e=0,f=0,g=0,h=0,j=0,k=0,l=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0;d=i;i=i+1064|0;e=d|0;f=d+1024|0;g=b;b=0;h=0;if((c[1660]|0)>50){j=c[m>>2]|0;ar(j|0,5792,(k=i,i=i+1|0,i=i+7&-8,c[k>>2]=0,k)|0)|0;i=k;l=-1;n=l;i=d;return n|0;}j=bh(g)|0;o=j;if((j|0)==0){j=c[m>>2]|0;p=g;ar(j|0,5392,(k=i,i=i+8|0,c[k>>2]=p,k)|0)|0;i=k;l=-1;n=l;i=d;return n|0;}L1881:while(1){if((c_(e|0,1024,o)|0)==0){q=1646;break;}h=h+1|0;p=0;c[f>>2]=ay(e|0,5096)|0;if((c[f>>2]|0)==0){continue;}do{if((aV(c[f>>2]|0,4840)|0)==0){p=-1;}else{if((a[c[f>>2]|0]|0)==35){continue L1881;}else{break;}}}while(0);while(1){do{if((c[f+(p<<2)>>2]|0)!=0){if((a[c[f+(p<<2)>>2]|0]|0)==35){r=0;break;}r=(p|0)<10;}else{r=0;}}while(0);if(!r){break;}j=p+1|0;p=j;c[f+(j<<2)>>2]=ay(0,5096)|0;}do{if((aV(c[f>>2]|0,4832)|0)!=0){if((aV(c[f>>2]|0,4816)|0)==0){q=1504;break;}if((aV(c[f>>2]|0,4800)|0)==0){q=1504;break;}if((aV(c[f>>2]|0,6552)|0)==0){q=1504;break;}if((aV(c[f>>2]|0,6536)|0)==0){q=1504;break;}if((aV(c[f>>2]|0,6504)|0)!=0){do{if((aV(c[f>>2]|0,6416)|0)!=0){if((aV(c[f>>2]|0,6400)|0)==0){q=1509;break;}if((aV(c[f>>2]|0,6344)|0)!=0){if((aV(c[f>>2]|0,6280)|0)!=0){do{if((aV(c[f>>2]|0,6176)|0)!=0){if((aV(c[f>>2]|0,6136)|0)==0){q=1516;break;}if((aV(c[f>>2]|0,6072)|0)!=0){if((aV(c[f>>2]|0,6008)|0)!=0){if((aV(c[f>>2]|0,5952)|0)!=0){if((aV(c[f>>2]|0,5880)|0)!=0){if((aV(c[f>>2]|0,5784)|0)!=0){if((aV(c[f>>2]|0,5720)|0)!=0){if((aV(c[f>>2]|0,5616)|0)!=0){if((p|0)<2){q=1562;break L1881;}if((a[c[f>>2]|0]|0)<48){q=1562;break L1881;}if((a[c[f>>2]|0]|0)>57){q=1562;break L1881;}s=aL(c[f>>2]|0)|0;if((s|0)<0){q=1565;break L1881;}if((s|0)>127){q=1565;break L1881;}if((b|0)==0){q=1567;break L1881;}if((c[(c[b>>2]|0)+(s*28|0)>>2]|0)!=0){c0(c[(c[b>>2]|0)+(s*28|0)>>2]|0);}j=bi((c1(c[f+4>>2]|0)|0)+1|0)|0;c[(c[b>>2]|0)+(s*28|0)>>2]=j;t=c[f+4>>2]|0;c2(j|0,t|0)|0;c[(c[b>>2]|0)+(s*28|0)+24>>2]=-1;c[(c[b>>2]|0)+(s*28|0)+20>>2]=-1;c[(c[b>>2]|0)+(s*28|0)+16>>2]=-1;c[(c[b>>2]|0)+(s*28|0)+12>>2]=-1;c[(c[b>>2]|0)+(s*28|0)+8>>2]=-1;c[(c[b>>2]|0)+(s*28|0)+4>>2]=-1;u=2;while(1){if((u|0)>=(p|0)){break;}t=aH(c[f+(u<<2)>>2]|0,61)|0;j=t;if((t|0)==0){q=1573;break L1881;}t=j;j=t+1|0;a[t]=0;if((aV(c[f+(u<<2)>>2]|0,5272)|0)!=0){if((aV(c[f+(u<<2)>>2]|0,5208)|0)!=0){if((aV(c[f+(u<<2)>>2]|0,5152)|0)!=0){if((aV(c[f+(u<<2)>>2]|0,5008)|0)!=0){if((aV(c[f+(u<<2)>>2]|0,4944)|0)!=0){q=1625;break L1881;}if((aV(j|0,5e3)|0)!=0){if((aV(j|0,4992)|0)!=0){if((aV(j|0,4936)|0)!=0){q=1621;break L1881;}c[(c[b>>2]|0)+(s*28|0)+24>>2]=1;}else{c[(c[b>>2]|0)+(s*28|0)+16>>2]=1;}}else{c[(c[b>>2]|0)+(s*28|0)+20>>2]=1;}}else{if((aV(j|0,5e3)|0)!=0){if((aV(j|0,4992)|0)!=0){q=1611;break L1881;}c[(c[b>>2]|0)+(s*28|0)+16>>2]=0;}else{c[(c[b>>2]|0)+(s*28|0)+20>>2]=0;}}}else{if((aV(j|0,5144)|0)!=0){if((aV(j|0,5112)|0)!=0){if((aV(j|0,5104)|0)!=0){v=(((aL(j|0)|0)+100|0)*100|0|0)/157|0;}else{v=127;}}else{v=0;}}else{v=64;}if((v|0)<0){q=1604;break L1881;}if((v|0)>127){q=1604;break L1881;}do{if((v|0)==0){if((a[j]|0)==45){break;}if((a[j]|0)<48){q=1604;break L1881;}if((a[j]|0)>57){q=1604;break L1881;}}}while(0);c[(c[b>>2]|0)+(s*28|0)+12>>2]=v;}}else{v=aL(j|0)|0;if((v|0)<0){q=1586;break L1881;}if((v|0)>127){q=1586;break L1881;}if((a[j]|0)<48){q=1586;break L1881;}if((a[j]|0)>57){q=1586;break L1881;}c[(c[b>>2]|0)+(s*28|0)+4>>2]=v;}}else{v=aL(j|0)|0;if((v|0)<0){q=1579;break L1881;}if((v|0)>800){q=1579;break L1881;}if((a[j]|0)<48){q=1579;break L1881;}if((a[j]|0)>57){q=1579;break L1881;}c[(c[b>>2]|0)+(s*28|0)+8>>2]=v;}u=u+1|0;}}else{if((p|0)<2){q=1552;break L1881;}s=aL(c[f+4>>2]|0)|0;if((s|0)<0){q=1555;break L1881;}if((s|0)>127){q=1555;break L1881;}if((c[6704+(s<<2)>>2]|0)==0){c[6704+(s<<2)>>2]=bi(516)|0;c5(c[6704+(s<<2)>>2]|0,0,516);t=bi(3584)|0;c[c[6704+(s<<2)>>2]>>2]=t;c5(c[c[6704+(s<<2)>>2]>>2]|0,0,3584);}b=c[6704+(s<<2)>>2]|0;}}else{if((p|0)<2){q=1543;break L1881;}s=aL(c[f+4>>2]|0)|0;if((s|0)<0){q=1546;break L1881;}if((s|0)>127){q=1546;break L1881;}if((c[7216+(s<<2)>>2]|0)==0){c[7216+(s<<2)>>2]=bi(516)|0;c5(c[7216+(s<<2)>>2]|0,0,516);t=bi(3584)|0;c[c[7216+(s<<2)>>2]>>2]=t;c5(c[c[7216+(s<<2)>>2]>>2]|0,0,3584);}b=c[7216+(s<<2)>>2]|0;}}else{if((p|0)!=2){q=1539;break L1881;}t=c[f+4>>2]|0;c7(7728,t|0,255)|0;a[7983]=0;}}else{if((p|0)<2){q=1531;break L1881;}s=1;while(1){if((s|0)>=(p|0)){break;}c[1660]=(c[1660]|0)+1;cU(c[f+(s<<2)>>2]|0)|0;c[1660]=(c[1660]|0)-1;s=s+1|0;}}}else{if((p|0)<2){q=1523;break L1881;}s=1;while(1){if((s|0)>=(p|0)){break;}bj(c[f+(s<<2)>>2]|0);s=s+1|0;}}}else{t=c[m>>2]|0;ar(t|0,5960,(k=i,i=i+1|0,i=i+7&-8,c[k>>2]=0,k)|0)|0;i=k;}}else{t=c[m>>2]|0;ar(t|0,6016,(k=i,i=i+1|0,i=i+7&-8,c[k>>2]=0,k)|0)|0;i=k;}}else{q=1516;}}while(0);if((q|0)==1516){q=0;t=c[m>>2]|0;w=c[f>>2]|0;ar(t|0,6088,(k=i,i=i+8|0,c[k>>2]=w,k)|0)|0;i=k;}}else{w=c[m>>2]|0;ar(w|0,6192,(k=i,i=i+1|0,i=i+7&-8,c[k>>2]=0,k)|0)|0;i=k;}}else{w=c[m>>2]|0;ar(w|0,6296,(k=i,i=i+1|0,i=i+7&-8,c[k>>2]=0,k)|0)|0;i=k;}}else{q=1509;}}while(0);if((q|0)==1509){q=0;w=c[m>>2]|0;t=c[f>>2]|0;ar(w|0,6352,(k=i,i=i+8|0,c[k>>2]=t,k)|0)|0;i=k;}}else{t=c[m>>2]|0;ar(t|0,6432,(k=i,i=i+1|0,i=i+7&-8,c[k>>2]=0,k)|0)|0;i=k;}}else{q=1504;}}while(0);if((q|0)==1504){q=0;}}if((q|0)==1523){s=c[m>>2]|0;b=g;v=h;ar(s|0,5912,(k=i,i=i+16|0,c[k>>2]=b,c[k+8>>2]=v,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1555){ar(c[m>>2]|0,5520,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1562){ar(c[m>>2]|0,5480,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1565){ar(c[m>>2]|0,5432,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1567){ar(c[m>>2]|0,5320,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1539){ar(c[m>>2]|0,5728,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1531){ar(c[m>>2]|0,5840,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1552){ar(c[m>>2]|0,5576,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1579){ar(c[m>>2]|0,5216,(k=i,i=i+24|0,c[k>>2]=g,c[k+8>>2]=h,c[k+16>>2]=800,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1586){ar(c[m>>2]|0,5160,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1611){ar(c[m>>2]|0,4952,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1621){ar(c[m>>2]|0,4888,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1625){v=c[f+(u<<2)>>2]|0;ar(c[m>>2]|0,5280,(k=i,i=i+24|0,c[k>>2]=g,c[k+8>>2]=h,c[k+16>>2]=v,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1546){ar(c[m>>2]|0,5624,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1543){ar(c[m>>2]|0,5680,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1604){ar(c[m>>2]|0,5016,(k=i,i=i+16|0,c[k>>2]=g,c[k+8>>2]=h,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1573){v=c[f+(u<<2)>>2]|0;ar(c[m>>2]|0,5280,(k=i,i=i+24|0,c[k>>2]=g,c[k+8>>2]=h,c[k+16>>2]=v,k)|0)|0;i=k;l=-2;n=l;i=d;return n|0;}else if((q|0)==1646){ao(o|0)|0;l=0;n=l;i=d;return n|0;}return 0;}function cV(d,e,f,g){d=d|0;e=e|0;f=f|0;g=g|0;c[1672]=d;b[3346]=e;a[6694]=f;b[3348]=g;return 6688;}function cW(f,g,h){f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,n=0;j=i;k=f;f=h;if((k|0)==0){l=0;n=l;i=j;return n|0;}h=bi(14164)|0;c5(h|0,0,14164);c[h+24>>2]=g;g=0;while(1){if((g|0)>=128){break;}if((c[6704+(g<<2)>>2]|0)!=0){c[h+28+(g<<2)>>2]=bi(516)|0;c5(c[h+28+(g<<2)>>2]|0,0,516);c[c[h+28+(g<<2)>>2]>>2]=c[c[6704+(g<<2)>>2]>>2];}if((c[7216+(g<<2)>>2]|0)!=0){c[h+540+(g<<2)>>2]=bi(516)|0;c5(c[h+540+(g<<2)>>2]|0,0,516);c[c[h+540+(g<<2)>>2]>>2]=c[c[7216+(g<<2)>>2]>>2];}g=g+1|0;}c[h+20>>2]=70;c[h+13052>>2]=32;c[h+13056>>2]=33280;c[h+4>>2]=c[f>>2];c[h+8>>2]=0;if((b[f+4>>1]&255|0)==16){g=h+8|0;c[g>>2]=c[g>>2]|4;}if((b[f+4>>1]&32768|0)!=0){g=h+8|0;c[g>>2]=c[g>>2]|2;}if((d[f+6|0]|0)==1){g=h+8|0;c[g>>2]=c[g>>2]|1;}g=e[f+4>>1]|0;if((g|0)==36880){c[h+1060>>2]=4;}else if((g|0)==16){c[h+1060>>2]=6;}else if((g|0)==32776){c[h+1060>>2]=10;}else if((g|0)==8){c[h+1060>>2]=8;}else if((g|0)==32784){c[h+1060>>2]=2;}else{ar(c[m>>2]|0,6144,(g=i,i=i+1|0,i=i+7&-8,c[g>>2]=0,g)|0)|0;i=g;c[h+1060>>2]=6;}c[h+1064>>2]=e[f+8>>1]|0;c[h+1068>>2]=bi(e[f+8>>1]<<1)|0;c[h+1072>>2]=bi(e[f+8>>1]<<1<<2)|0;c[h+12>>2]=_((c[h+8>>2]&1|0)!=0?1:2,(c[h+8>>2]&4|0)!=0?2:1)|0;c[h+13060>>2]=(c[f>>2]|0)/1e3|0;if((c[h+13060>>2]|0)<1){c[h+13060>>2]=1;}else{if((c[h+13060>>2]|0)>255){c[h+13060>>2]=255;}}c[h+13064>>2]=0;c[h+13068>>2]=0;c[h+13076>>2]=cq(k,h,h+13100|0,h+13072|0)|0;if((c[h+13076>>2]|0)==0){c0(h);l=0;n=l;i=j;return n|0;}c[h+1052>>2]=0;c[h+1056>>2]=0;if((a[7728]|0)!=0){k=h;bz(k,7728)|0;}bv(h)|0;l=h;n=l;i=j;return n|0;}// mid_song_load\\nfunction cX(a,b){a=a|0;b=b|0;return cW(a,0,b)|0;}// mid_song_free\\nfunction cY(a){a=a|0;var b=0;b=a;bx(b);a=0;while(1){if((a|0)>=128){break;}if((c[b+28+(a<<2)>>2]|0)!=0){c0(c[b+28+(a<<2)>>2]|0);}if((c[b+540+(a<<2)>>2]|0)!=0){c0(c[b+540+(a<<2)>>2]|0);}a=a+1|0;}c0(c[b+1072>>2]|0);c0(c[b+1068>>2]|0);c0(c[b+13076>>2]|0);a=0;while(1){if(a>>>0>=8){break;}if((c[b+13104+(a<<2)>>2]|0)!=0){c0(c[b+13104+(a<<2)>>2]|0);}a=a+1|0;}c0(b);return;}// mid_exit\\nfunction cZ(){var a=0,b=0,d=0,e=0;a=0;while(1){if((a|0)>=128){break;}if((c[6704+(a<<2)>>2]|0)!=0){b=c[c[6704+(a<<2)>>2]>>2]|0;if((b|0)!=0){d=0;while(1){if((d|0)>=128){break;}if((c[b+(d*28|0)>>2]|0)!=0){c0(c[b+(d*28|0)>>2]|0);}d=d+1|0;}c0(b);}c0(c[6704+(a<<2)>>2]|0);}if((c[7216+(a<<2)>>2]|0)!=0){e=c[c[7216+(a<<2)>>2]>>2]|0;if((e|0)!=0){d=0;while(1){if((d|0)>=128){break;}if((c[e+(d*28|0)>>2]|0)!=0){c0(c[e+(d*28|0)>>2]|0);}d=d+1|0;}c0(e);}c0(c[7216+(a<<2)>>2]|0);}a=a+1|0;}bk();return;}function c_(b,c,d){b=b|0;c=c|0;d=d|0;var e=0,f=0,g=0,h=0,i=0;e=b;b=c;c=d;d=0;f=0;while(1){if((d|0)<(b|0)){g=(f|0)!=0^1;}else{g=0;}if(!g){break;}if((an(e+d|0,1,1,c|0)|0)!=1){h=1752;break;}if((a[e+d|0]|0)==10){h=1755;}else{if((a[e+d|0]|0)==13){h=1755;}}if((h|0)==1755){h=0;a[e+d|0]=0;f=1;}d=d+1|0;}a[e+d|0]=0;if((d|0)!=0){i=e;return i|0;}else{i=0;return i|0;}return 0;}// malloc\\nfunction c$(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ab=0,ac=0,ad=0,ae=0,af=0,ag=0,ah=0,ai=0,aj=0,ak=0,al=0,an=0,ao=0,ap=0,ar=0,as=0,at=0,au=0,av=0,aw=0,ax=0,ay=0,az=0,aA=0,aB=0,aC=0,aD=0,aE=0,aF=0,aG=0,aH=0,aI=0;do{if(a>>>0<245){if(a>>>0<11){b=16;}else{b=a+11&-8;}d=b>>>3;e=c[1996]|0;f=e>>>(d>>>0);if((f&3|0)!=0){g=(f&1^1)+d|0;h=g<<1;i=8024+(h<<2)|0;j=8024+(h+2<<2)|0;h=c[j>>2]|0;k=h+8|0;l=c[k>>2]|0;do{if((i|0)==(l|0)){c[1996]=e&~(1<>>0<(c[2e3]|0)>>>0){aq();return 0;}m=l+12|0;if((c[m>>2]|0)==(h|0)){c[m>>2]=i;c[j>>2]=l;break;}else{aq();return 0;}}}while(0);l=g<<3;c[h+4>>2]=l|3;j=h+(l|4)|0;c[j>>2]=c[j>>2]|1;n=k;return n|0;}if(b>>>0<=(c[1998]|0)>>>0){o=b;break;}if((f|0)!=0){j=2<>>12&16;i=j>>>(l>>>0);j=i>>>5&8;m=i>>>(j>>>0);i=m>>>2&4;p=m>>>(i>>>0);m=p>>>1&2;q=p>>>(m>>>0);p=q>>>1&1;r=(j|l|i|m|p)+(q>>>(p>>>0))|0;p=r<<1;q=8024+(p<<2)|0;m=8024+(p+2<<2)|0;p=c[m>>2]|0;i=p+8|0;l=c[i>>2]|0;do{if((q|0)==(l|0)){c[1996]=e&~(1<>>0<(c[2e3]|0)>>>0){aq();return 0;}j=l+12|0;if((c[j>>2]|0)==(p|0)){c[j>>2]=q;c[m>>2]=l;break;}else{aq();return 0;}}}while(0);l=r<<3;m=l-b|0;c[p+4>>2]=b|3;q=p;e=q+b|0;c[q+(b|4)>>2]=m|1;c[q+l>>2]=m;l=c[1998]|0;if((l|0)!=0){q=c[2001]|0;d=l>>>3;l=d<<1;f=8024+(l<<2)|0;k=c[1996]|0;h=1<>2]|0;if(g>>>0>=(c[2e3]|0)>>>0){s=g;t=d;break;}aq();return 0;}}while(0);c[t>>2]=q;c[s+12>>2]=q;c[q+8>>2]=s;c[q+12>>2]=f;}c[1998]=m;c[2001]=e;n=i;return n|0;}l=c[1997]|0;if((l|0)==0){o=b;break;}h=(l&-l)-1|0;l=h>>>12&16;k=h>>>(l>>>0);h=k>>>5&8;p=k>>>(h>>>0);k=p>>>2&4;r=p>>>(k>>>0);p=r>>>1&2;d=r>>>(p>>>0);r=d>>>1&1;g=c[8288+((h|l|k|p|r)+(d>>>(r>>>0))<<2)>>2]|0;r=g;d=g;p=(c[g+4>>2]&-8)-b|0;while(1){g=c[r+16>>2]|0;if((g|0)==0){k=c[r+20>>2]|0;if((k|0)==0){break;}else{u=k;}}else{u=g;}g=(c[u+4>>2]&-8)-b|0;k=g>>>0

>>0;r=u;d=k?u:d;p=k?g:p;}r=d;i=c[2e3]|0;if(r>>>0>>0){aq();return 0;}e=r+b|0;m=e;if(r>>>0>=e>>>0){aq();return 0;}e=c[d+24>>2]|0;f=c[d+12>>2]|0;do{if((f|0)==(d|0)){q=d+20|0;g=c[q>>2]|0;if((g|0)==0){k=d+16|0;l=c[k>>2]|0;if((l|0)==0){v=0;break;}else{w=l;x=k;}}else{w=g;x=q;}while(1){q=w+20|0;g=c[q>>2]|0;if((g|0)!=0){w=g;x=q;continue;}q=w+16|0;g=c[q>>2]|0;if((g|0)==0){break;}else{w=g;x=q;}}if(x>>>0>>0){aq();return 0;}else{c[x>>2]=0;v=w;break;}}else{q=c[d+8>>2]|0;if(q>>>0>>0){aq();return 0;}g=q+12|0;if((c[g>>2]|0)!=(d|0)){aq();return 0;}k=f+8|0;if((c[k>>2]|0)==(d|0)){c[g>>2]=f;c[k>>2]=q;v=f;break;}else{aq();return 0;}}}while(0);L2304:do{if((e|0)!=0){f=d+28|0;i=8288+(c[f>>2]<<2)|0;do{if((d|0)==(c[i>>2]|0)){c[i>>2]=v;if((v|0)!=0){break;}c[1997]=c[1997]&~(1<>2]);break L2304;}else{if(e>>>0<(c[2e3]|0)>>>0){aq();return 0;}q=e+16|0;if((c[q>>2]|0)==(d|0)){c[q>>2]=v;}else{c[e+20>>2]=v;}if((v|0)==0){break L2304;}}}while(0);if(v>>>0<(c[2e3]|0)>>>0){aq();return 0;}c[v+24>>2]=e;f=c[d+16>>2]|0;do{if((f|0)!=0){if(f>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[v+16>>2]=f;c[f+24>>2]=v;break;}}}while(0);f=c[d+20>>2]|0;if((f|0)==0){break;}if(f>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[v+20>>2]=f;c[f+24>>2]=v;break;}}}while(0);if(p>>>0<16){e=p+b|0;c[d+4>>2]=e|3;f=r+(e+4)|0;c[f>>2]=c[f>>2]|1;}else{c[d+4>>2]=b|3;c[r+(b|4)>>2]=p|1;c[r+(p+b)>>2]=p;f=c[1998]|0;if((f|0)!=0){e=c[2001]|0;i=f>>>3;f=i<<1;q=8024+(f<<2)|0;k=c[1996]|0;g=1<>2]|0;if(l>>>0>=(c[2e3]|0)>>>0){y=l;z=i;break;}aq();return 0;}}while(0);c[z>>2]=e;c[y+12>>2]=e;c[e+8>>2]=y;c[e+12>>2]=q;}c[1998]=p;c[2001]=m;}f=d+8|0;if((f|0)==0){o=b;break;}else{n=f;}return n|0;}else{if(a>>>0>4294967231){o=-1;break;}f=a+11|0;g=f&-8;k=c[1997]|0;if((k|0)==0){o=g;break;}r=-g|0;i=f>>>8;do{if((i|0)==0){A=0;}else{if(g>>>0>16777215){A=31;break;}f=(i+1048320|0)>>>16&8;l=i<>>16&4;j=l<>>16&2;B=14-(h|f|l)+(j<>>15)|0;A=g>>>((B+7|0)>>>0)&1|B<<1;}}while(0);i=c[8288+(A<<2)>>2]|0;L2352:do{if((i|0)==0){C=0;D=r;E=0;}else{if((A|0)==31){F=0;}else{F=25-(A>>>1)|0;}d=0;m=r;p=i;q=g<>2]&-8;l=B-g|0;if(l>>>0>>0){if((B|0)==(g|0)){C=p;D=l;E=p;break L2352;}else{G=p;H=l;}}else{G=d;H=m;}l=c[p+20>>2]|0;B=c[p+16+(q>>>31<<2)>>2]|0;j=(l|0)==0|(l|0)==(B|0)?e:l;if((B|0)==0){C=G;D=H;E=j;break;}else{d=G;m=H;p=B;q=q<<1;e=j;}}}}while(0);if((E|0)==0&(C|0)==0){i=2<>>12&16;e=i>>>(r>>>0);i=e>>>5&8;q=e>>>(i>>>0);e=q>>>2&4;p=q>>>(e>>>0);q=p>>>1&2;m=p>>>(q>>>0);p=m>>>1&1;I=c[8288+((i|r|e|q|p)+(m>>>(p>>>0))<<2)>>2]|0;}else{I=E;}if((I|0)==0){J=D;K=C;}else{p=I;m=D;q=C;while(1){e=(c[p+4>>2]&-8)-g|0;r=e>>>0>>0;i=r?e:m;e=r?p:q;r=c[p+16>>2]|0;if((r|0)!=0){p=r;m=i;q=e;continue;}r=c[p+20>>2]|0;if((r|0)==0){J=i;K=e;break;}else{p=r;m=i;q=e;}}}if((K|0)==0){o=g;break;}if(J>>>0>=((c[1998]|0)-g|0)>>>0){o=g;break;}q=K;m=c[2e3]|0;if(q>>>0>>0){aq();return 0;}p=q+g|0;k=p;if(q>>>0>=p>>>0){aq();return 0;}e=c[K+24>>2]|0;i=c[K+12>>2]|0;do{if((i|0)==(K|0)){r=K+20|0;d=c[r>>2]|0;if((d|0)==0){j=K+16|0;B=c[j>>2]|0;if((B|0)==0){L=0;break;}else{M=B;N=j;}}else{M=d;N=r;}while(1){r=M+20|0;d=c[r>>2]|0;if((d|0)!=0){M=d;N=r;continue;}r=M+16|0;d=c[r>>2]|0;if((d|0)==0){break;}else{M=d;N=r;}}if(N>>>0>>0){aq();return 0;}else{c[N>>2]=0;L=M;break;}}else{r=c[K+8>>2]|0;if(r>>>0>>0){aq();return 0;}d=r+12|0;if((c[d>>2]|0)!=(K|0)){aq();return 0;}j=i+8|0;if((c[j>>2]|0)==(K|0)){c[d>>2]=i;c[j>>2]=r;L=i;break;}else{aq();return 0;}}}while(0);L2402:do{if((e|0)!=0){i=K+28|0;m=8288+(c[i>>2]<<2)|0;do{if((K|0)==(c[m>>2]|0)){c[m>>2]=L;if((L|0)!=0){break;}c[1997]=c[1997]&~(1<>2]);break L2402;}else{if(e>>>0<(c[2e3]|0)>>>0){aq();return 0;}r=e+16|0;if((c[r>>2]|0)==(K|0)){c[r>>2]=L;}else{c[e+20>>2]=L;}if((L|0)==0){break L2402;}}}while(0);if(L>>>0<(c[2e3]|0)>>>0){aq();return 0;}c[L+24>>2]=e;i=c[K+16>>2]|0;do{if((i|0)!=0){if(i>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[L+16>>2]=i;c[i+24>>2]=L;break;}}}while(0);i=c[K+20>>2]|0;if((i|0)==0){break;}if(i>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[L+20>>2]=i;c[i+24>>2]=L;break;}}}while(0);do{if(J>>>0<16){e=J+g|0;c[K+4>>2]=e|3;i=q+(e+4)|0;c[i>>2]=c[i>>2]|1;}else{c[K+4>>2]=g|3;c[q+(g|4)>>2]=J|1;c[q+(J+g)>>2]=J;i=J>>>3;if(J>>>0<256){e=i<<1;m=8024+(e<<2)|0;r=c[1996]|0;j=1<>2]|0;if(d>>>0>=(c[2e3]|0)>>>0){O=d;P=i;break;}aq();return 0;}}while(0);c[P>>2]=k;c[O+12>>2]=k;c[q+(g+8)>>2]=O;c[q+(g+12)>>2]=m;break;}e=p;j=J>>>8;do{if((j|0)==0){Q=0;}else{if(J>>>0>16777215){Q=31;break;}r=(j+1048320|0)>>>16&8;i=j<>>16&4;B=i<>>16&2;l=14-(d|r|i)+(B<>>15)|0;Q=J>>>((l+7|0)>>>0)&1|l<<1;}}while(0);j=8288+(Q<<2)|0;c[q+(g+28)>>2]=Q;c[q+(g+20)>>2]=0;c[q+(g+16)>>2]=0;m=c[1997]|0;l=1<>2]=e;c[q+(g+24)>>2]=j;c[q+(g+12)>>2]=e;c[q+(g+8)>>2]=e;break;}if((Q|0)==31){R=0;}else{R=25-(Q>>>1)|0;}l=J<>2]|0;while(1){if((c[m+4>>2]&-8|0)==(J|0)){break;}S=m+16+(l>>>31<<2)|0;j=c[S>>2]|0;if((j|0)==0){T=1913;break;}else{l=l<<1;m=j;}}if((T|0)==1913){if(S>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[S>>2]=e;c[q+(g+24)>>2]=m;c[q+(g+12)>>2]=e;c[q+(g+8)>>2]=e;break;}}l=m+8|0;j=c[l>>2]|0;i=c[2e3]|0;if(m>>>0>>0){aq();return 0;}if(j>>>0>>0){aq();return 0;}else{c[j+12>>2]=e;c[l>>2]=e;c[q+(g+8)>>2]=j;c[q+(g+12)>>2]=m;c[q+(g+24)>>2]=0;break;}}}while(0);q=K+8|0;if((q|0)==0){o=g;break;}else{n=q;}return n|0;}}while(0);K=c[1998]|0;if(o>>>0<=K>>>0){S=K-o|0;J=c[2001]|0;if(S>>>0>15){R=J;c[2001]=R+o;c[1998]=S;c[R+(o+4)>>2]=S|1;c[R+K>>2]=S;c[J+4>>2]=o|3;}else{c[1998]=0;c[2001]=0;c[J+4>>2]=K|3;S=J+(K+4)|0;c[S>>2]=c[S>>2]|1;}n=J+8|0;return n|0;}J=c[1999]|0;if(o>>>0>>0){S=J-o|0;c[1999]=S;J=c[2002]|0;K=J;c[2002]=K+o;c[K+(o+4)>>2]=S|1;c[J+4>>2]=o|3;n=J+8|0;return n|0;}do{if((c[1666]|0)==0){J=am(30)|0;if((J-1&J|0)==0){c[1668]=J;c[1667]=J;c[1669]=-1;c[1670]=-1;c[1671]=0;c[2107]=0;c[1666]=(aJ(0)|0)&-16^1431655768;break;}else{aq();return 0;}}}while(0);J=o+48|0;S=c[1668]|0;K=o+47|0;R=S+K|0;Q=-S|0;S=R&Q;if(S>>>0<=o>>>0){n=0;return n|0;}O=c[2106]|0;do{if((O|0)!=0){P=c[2104]|0;L=P+S|0;if(L>>>0<=P>>>0|L>>>0>O>>>0){n=0;}else{break;}return n|0;}}while(0);L2494:do{if((c[2107]&4|0)==0){O=c[2002]|0;L2496:do{if((O|0)==0){T=1943;}else{L=O;P=8432;while(1){U=P|0;M=c[U>>2]|0;if(M>>>0<=L>>>0){V=P+4|0;if((M+(c[V>>2]|0)|0)>>>0>L>>>0){break;}}M=c[P+8>>2]|0;if((M|0)==0){T=1943;break L2496;}else{P=M;}}if((P|0)==0){T=1943;break;}L=R-(c[1999]|0)&Q;if(L>>>0>=2147483647){W=0;break;}m=aS(L|0)|0;e=(m|0)==((c[U>>2]|0)+(c[V>>2]|0)|0);X=e?m:-1;Y=e?L:0;Z=m;_=L;T=1952;}}while(0);do{if((T|0)==1943){O=aS(0)|0;if((O|0)==-1){W=0;break;}g=O;L=c[1667]|0;m=L-1|0;if((m&g|0)==0){$=S;}else{$=S-g+(m+g&-L)|0;}L=c[2104]|0;g=L+$|0;if(!($>>>0>o>>>0&$>>>0<2147483647)){W=0;break;}m=c[2106]|0;if((m|0)!=0){if(g>>>0<=L>>>0|g>>>0>m>>>0){W=0;break;}}m=aS($|0)|0;g=(m|0)==(O|0);X=g?O:-1;Y=g?$:0;Z=m;_=$;T=1952;}}while(0);L2516:do{if((T|0)==1952){m=-_|0;if((X|0)!=-1){aa=Y;ab=X;T=1963;break L2494;}do{if((Z|0)!=-1&_>>>0<2147483647&_>>>0>>0){g=c[1668]|0;O=K-_+g&-g;if(O>>>0>=2147483647){ac=_;break;}if((aS(O|0)|0)==-1){aS(m|0)|0;W=Y;break L2516;}else{ac=O+_|0;break;}}else{ac=_;}}while(0);if((Z|0)==-1){W=Y;}else{aa=ac;ab=Z;T=1963;break L2494;}}}while(0);c[2107]=c[2107]|4;ad=W;T=1960;}else{ad=0;T=1960;}}while(0);do{if((T|0)==1960){if(S>>>0>=2147483647){break;}W=aS(S|0)|0;Z=aS(0)|0;if(!((Z|0)!=-1&(W|0)!=-1&W>>>0>>0)){break;}ac=Z-W|0;Z=ac>>>0>(o+40|0)>>>0;Y=Z?W:-1;if((Y|0)!=-1){aa=Z?ac:ad;ab=Y;T=1963;}}}while(0);do{if((T|0)==1963){ad=(c[2104]|0)+aa|0;c[2104]=ad;if(ad>>>0>(c[2105]|0)>>>0){c[2105]=ad;}ad=c[2002]|0;L2536:do{if((ad|0)==0){S=c[2e3]|0;if((S|0)==0|ab>>>0>>0){c[2e3]=ab;}c[2108]=ab;c[2109]=aa;c[2111]=0;c[2005]=c[1666];c[2004]=-1;S=0;do{Y=S<<1;ac=8024+(Y<<2)|0;c[8024+(Y+3<<2)>>2]=ac;c[8024+(Y+2<<2)>>2]=ac;S=S+1|0;}while(S>>>0<32);S=ab+8|0;if((S&7|0)==0){ae=0;}else{ae=-S&7;}S=aa-40-ae|0;c[2002]=ab+ae;c[1999]=S;c[ab+(ae+4)>>2]=S|1;c[ab+(aa-36)>>2]=40;c[2003]=c[1670];}else{S=8432;while(1){af=c[S>>2]|0;ag=S+4|0;ah=c[ag>>2]|0;if((ab|0)==(af+ah|0)){T=1975;break;}ac=c[S+8>>2]|0;if((ac|0)==0){break;}else{S=ac;}}do{if((T|0)==1975){if((c[S+12>>2]&8|0)!=0){break;}ac=ad;if(!(ac>>>0>=af>>>0&ac>>>0>>0)){break;}c[ag>>2]=ah+aa;ac=c[2002]|0;Y=(c[1999]|0)+aa|0;Z=ac;W=ac+8|0;if((W&7|0)==0){ai=0;}else{ai=-W&7;}W=Y-ai|0;c[2002]=Z+ai;c[1999]=W;c[Z+(ai+4)>>2]=W|1;c[Z+(Y+4)>>2]=40;c[2003]=c[1670];break L2536;}}while(0);if(ab>>>0<(c[2e3]|0)>>>0){c[2e3]=ab;}S=ab+aa|0;Y=8432;while(1){aj=Y|0;if((c[aj>>2]|0)==(S|0)){T=1985;break;}Z=c[Y+8>>2]|0;if((Z|0)==0){break;}else{Y=Z;}}do{if((T|0)==1985){if((c[Y+12>>2]&8|0)!=0){break;}c[aj>>2]=ab;S=Y+4|0;c[S>>2]=(c[S>>2]|0)+aa;S=ab+8|0;if((S&7|0)==0){ak=0;}else{ak=-S&7;}S=ab+(aa+8)|0;if((S&7|0)==0){al=0;}else{al=-S&7;}S=ab+(al+aa)|0;Z=S;W=ak+o|0;ac=ab+W|0;_=ac;K=S-(ab+ak)-o|0;c[ab+(ak+4)>>2]=o|3;do{if((Z|0)==(c[2002]|0)){J=(c[1999]|0)+K|0;c[1999]=J;c[2002]=_;c[ab+(W+4)>>2]=J|1;}else{if((Z|0)==(c[2001]|0)){J=(c[1998]|0)+K|0;c[1998]=J;c[2001]=_;c[ab+(W+4)>>2]=J|1;c[ab+(J+W)>>2]=J;break;}J=aa+4|0;X=c[ab+(J+al)>>2]|0;if((X&3|0)==1){$=X&-8;V=X>>>3;L2571:do{if(X>>>0<256){U=c[ab+((al|8)+aa)>>2]|0;Q=c[ab+(aa+12+al)>>2]|0;R=8024+(V<<1<<2)|0;do{if((U|0)!=(R|0)){if(U>>>0<(c[2e3]|0)>>>0){aq();return 0;}if((c[U+12>>2]|0)==(Z|0)){break;}aq();return 0;}}while(0);if((Q|0)==(U|0)){c[1996]=c[1996]&~(1<>>0<(c[2e3]|0)>>>0){aq();return 0;}m=Q+8|0;if((c[m>>2]|0)==(Z|0)){an=m;break;}aq();return 0;}}while(0);c[U+12>>2]=Q;c[an>>2]=U;}else{R=S;m=c[ab+((al|24)+aa)>>2]|0;P=c[ab+(aa+12+al)>>2]|0;do{if((P|0)==(R|0)){O=al|16;g=ab+(J+O)|0;L=c[g>>2]|0;if((L|0)==0){e=ab+(O+aa)|0;O=c[e>>2]|0;if((O|0)==0){ao=0;break;}else{ap=O;ar=e;}}else{ap=L;ar=g;}while(1){g=ap+20|0;L=c[g>>2]|0;if((L|0)!=0){ap=L;ar=g;continue;}g=ap+16|0;L=c[g>>2]|0;if((L|0)==0){break;}else{ap=L;ar=g;}}if(ar>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[ar>>2]=0;ao=ap;break;}}else{g=c[ab+((al|8)+aa)>>2]|0;if(g>>>0<(c[2e3]|0)>>>0){aq();return 0;}L=g+12|0;if((c[L>>2]|0)!=(R|0)){aq();return 0;}e=P+8|0;if((c[e>>2]|0)==(R|0)){c[L>>2]=P;c[e>>2]=g;ao=P;break;}else{aq();return 0;}}}while(0);if((m|0)==0){break;}P=ab+(aa+28+al)|0;U=8288+(c[P>>2]<<2)|0;do{if((R|0)==(c[U>>2]|0)){c[U>>2]=ao;if((ao|0)!=0){break;}c[1997]=c[1997]&~(1<>2]);break L2571;}else{if(m>>>0<(c[2e3]|0)>>>0){aq();return 0;}Q=m+16|0;if((c[Q>>2]|0)==(R|0)){c[Q>>2]=ao;}else{c[m+20>>2]=ao;}if((ao|0)==0){break L2571;}}}while(0);if(ao>>>0<(c[2e3]|0)>>>0){aq();return 0;}c[ao+24>>2]=m;R=al|16;P=c[ab+(R+aa)>>2]|0;do{if((P|0)!=0){if(P>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[ao+16>>2]=P;c[P+24>>2]=ao;break;}}}while(0);P=c[ab+(J+R)>>2]|0;if((P|0)==0){break;}if(P>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[ao+20>>2]=P;c[P+24>>2]=ao;break;}}}while(0);as=ab+(($|al)+aa)|0;at=$+K|0;}else{as=Z;at=K;}J=as+4|0;c[J>>2]=c[J>>2]&-2;c[ab+(W+4)>>2]=at|1;c[ab+(at+W)>>2]=at;J=at>>>3;if(at>>>0<256){V=J<<1;X=8024+(V<<2)|0;P=c[1996]|0;m=1<>2]|0;if(U>>>0>=(c[2e3]|0)>>>0){au=U;av=J;break;}aq();return 0;}}while(0);c[av>>2]=_;c[au+12>>2]=_;c[ab+(W+8)>>2]=au;c[ab+(W+12)>>2]=X;break;}V=ac;m=at>>>8;do{if((m|0)==0){aw=0;}else{if(at>>>0>16777215){aw=31;break;}P=(m+1048320|0)>>>16&8;$=m<>>16&4;U=$<>>16&2;Q=14-(J|P|$)+(U<<$>>>15)|0;aw=at>>>((Q+7|0)>>>0)&1|Q<<1;}}while(0);m=8288+(aw<<2)|0;c[ab+(W+28)>>2]=aw;c[ab+(W+20)>>2]=0;c[ab+(W+16)>>2]=0;X=c[1997]|0;Q=1<>2]=V;c[ab+(W+24)>>2]=m;c[ab+(W+12)>>2]=V;c[ab+(W+8)>>2]=V;break;}if((aw|0)==31){ax=0;}else{ax=25-(aw>>>1)|0;}Q=at<>2]|0;while(1){if((c[X+4>>2]&-8|0)==(at|0)){break;}ay=X+16+(Q>>>31<<2)|0;m=c[ay>>2]|0;if((m|0)==0){T=2058;break;}else{Q=Q<<1;X=m;}}if((T|0)==2058){if(ay>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[ay>>2]=V;c[ab+(W+24)>>2]=X;c[ab+(W+12)>>2]=V;c[ab+(W+8)>>2]=V;break;}}Q=X+8|0;m=c[Q>>2]|0;$=c[2e3]|0;if(X>>>0<$>>>0){aq();return 0;}if(m>>>0<$>>>0){aq();return 0;}else{c[m+12>>2]=V;c[Q>>2]=V;c[ab+(W+8)>>2]=m;c[ab+(W+12)>>2]=X;c[ab+(W+24)>>2]=0;break;}}}while(0);n=ab+(ak|8)|0;return n|0;}}while(0);Y=ad;W=8432;while(1){az=c[W>>2]|0;if(az>>>0<=Y>>>0){aA=c[W+4>>2]|0;aB=az+aA|0;if(aB>>>0>Y>>>0){break;}}W=c[W+8>>2]|0;}W=az+(aA-39)|0;if((W&7|0)==0){aC=0;}else{aC=-W&7;}W=az+(aA-47+aC)|0;ac=W>>>0<(ad+16|0)>>>0?Y:W;W=ac+8|0;_=ab+8|0;if((_&7|0)==0){aD=0;}else{aD=-_&7;}_=aa-40-aD|0;c[2002]=ab+aD;c[1999]=_;c[ab+(aD+4)>>2]=_|1;c[ab+(aa-36)>>2]=40;c[2003]=c[1670];c[ac+4>>2]=27;c[W>>2]=c[2108];c[W+4>>2]=c[2109];c[W+8>>2]=c[2110];c[W+12>>2]=c[2111];c[2108]=ab;c[2109]=aa;c[2111]=0;c[2110]=W;W=ac+28|0;c[W>>2]=7;if((ac+32|0)>>>0>>0){_=W;while(1){W=_+4|0;c[W>>2]=7;if((_+8|0)>>>0>>0){_=W;}else{break;}}}if((ac|0)==(Y|0)){break;}_=ac-ad|0;W=Y+(_+4)|0;c[W>>2]=c[W>>2]&-2;c[ad+4>>2]=_|1;c[Y+_>>2]=_;W=_>>>3;if(_>>>0<256){K=W<<1;Z=8024+(K<<2)|0;S=c[1996]|0;m=1<>2]|0;if(Q>>>0>=(c[2e3]|0)>>>0){aE=Q;aF=W;break;}aq();return 0;}}while(0);c[aF>>2]=ad;c[aE+12>>2]=ad;c[ad+8>>2]=aE;c[ad+12>>2]=Z;break;}K=ad;m=_>>>8;do{if((m|0)==0){aG=0;}else{if(_>>>0>16777215){aG=31;break;}S=(m+1048320|0)>>>16&8;Y=m<>>16&4;W=Y<>>16&2;Q=14-(ac|S|Y)+(W<>>15)|0;aG=_>>>((Q+7|0)>>>0)&1|Q<<1;}}while(0);m=8288+(aG<<2)|0;c[ad+28>>2]=aG;c[ad+20>>2]=0;c[ad+16>>2]=0;Z=c[1997]|0;Q=1<>2]=K;c[ad+24>>2]=m;c[ad+12>>2]=ad;c[ad+8>>2]=ad;break;}if((aG|0)==31){aH=0;}else{aH=25-(aG>>>1)|0;}Q=_<>2]|0;while(1){if((c[Z+4>>2]&-8|0)==(_|0)){break;}aI=Z+16+(Q>>>31<<2)|0;m=c[aI>>2]|0;if((m|0)==0){T=2093;break;}else{Q=Q<<1;Z=m;}}if((T|0)==2093){if(aI>>>0<(c[2e3]|0)>>>0){aq();return 0;}else{c[aI>>2]=K;c[ad+24>>2]=Z;c[ad+12>>2]=ad;c[ad+8>>2]=ad;break;}}Q=Z+8|0;_=c[Q>>2]|0;m=c[2e3]|0;if(Z>>>0>>0){aq();return 0;}if(_>>>0>>0){aq();return 0;}else{c[_+12>>2]=K;c[Q>>2]=K;c[ad+8>>2]=_;c[ad+12>>2]=Z;c[ad+24>>2]=0;break;}}}while(0);ad=c[1999]|0;if(ad>>>0<=o>>>0){break;}_=ad-o|0;c[1999]=_;ad=c[2002]|0;Q=ad;c[2002]=Q+o;c[Q+(o+4)>>2]=_|1;c[ad+4>>2]=o|3;n=ad+8|0;return n|0;}}while(0);c[(aQ()|0)>>2]=12;n=0;return n|0;}// free\\nfunction c0(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0;if((a|0)==0){return;}b=a-8|0;d=b;e=c[2e3]|0;if(b>>>0>>0){aq();}f=c[a-4>>2]|0;g=f&3;if((g|0)==1){aq();}h=f&-8;i=a+(h-8)|0;j=i;L2753:do{if((f&1|0)==0){k=c[b>>2]|0;if((g|0)==0){return;}l=-8-k|0;m=a+l|0;n=m;o=k+h|0;if(m>>>0>>0){aq();}if((n|0)==(c[2001]|0)){p=a+(h-4)|0;if((c[p>>2]&3|0)!=3){q=n;r=o;break;}c[1998]=o;c[p>>2]=c[p>>2]&-2;c[a+(l+4)>>2]=o|1;c[i>>2]=o;return;}p=k>>>3;if(k>>>0<256){k=c[a+(l+8)>>2]|0;s=c[a+(l+12)>>2]|0;t=8024+(p<<1<<2)|0;do{if((k|0)!=(t|0)){if(k>>>0>>0){aq();}if((c[k+12>>2]|0)==(n|0)){break;}aq();}}while(0);if((s|0)==(k|0)){c[1996]=c[1996]&~(1<>>0>>0){aq();}v=s+8|0;if((c[v>>2]|0)==(n|0)){u=v;break;}aq();}}while(0);c[k+12>>2]=s;c[u>>2]=k;q=n;r=o;break;}t=m;p=c[a+(l+24)>>2]|0;v=c[a+(l+12)>>2]|0;do{if((v|0)==(t|0)){w=a+(l+20)|0;x=c[w>>2]|0;if((x|0)==0){y=a+(l+16)|0;z=c[y>>2]|0;if((z|0)==0){A=0;break;}else{B=z;C=y;}}else{B=x;C=w;}while(1){w=B+20|0;x=c[w>>2]|0;if((x|0)!=0){B=x;C=w;continue;}w=B+16|0;x=c[w>>2]|0;if((x|0)==0){break;}else{B=x;C=w;}}if(C>>>0>>0){aq();}else{c[C>>2]=0;A=B;break;}}else{w=c[a+(l+8)>>2]|0;if(w>>>0>>0){aq();}x=w+12|0;if((c[x>>2]|0)!=(t|0)){aq();}y=v+8|0;if((c[y>>2]|0)==(t|0)){c[x>>2]=v;c[y>>2]=w;A=v;break;}else{aq();}}}while(0);if((p|0)==0){q=n;r=o;break;}v=a+(l+28)|0;m=8288+(c[v>>2]<<2)|0;do{if((t|0)==(c[m>>2]|0)){c[m>>2]=A;if((A|0)!=0){break;}c[1997]=c[1997]&~(1<>2]);q=n;r=o;break L2753;}else{if(p>>>0<(c[2e3]|0)>>>0){aq();}k=p+16|0;if((c[k>>2]|0)==(t|0)){c[k>>2]=A;}else{c[p+20>>2]=A;}if((A|0)==0){q=n;r=o;break L2753;}}}while(0);if(A>>>0<(c[2e3]|0)>>>0){aq();}c[A+24>>2]=p;t=c[a+(l+16)>>2]|0;do{if((t|0)!=0){if(t>>>0<(c[2e3]|0)>>>0){aq();}else{c[A+16>>2]=t;c[t+24>>2]=A;break;}}}while(0);t=c[a+(l+20)>>2]|0;if((t|0)==0){q=n;r=o;break;}if(t>>>0<(c[2e3]|0)>>>0){aq();}else{c[A+20>>2]=t;c[t+24>>2]=A;q=n;r=o;break;}}else{q=d;r=h;}}while(0);d=q;if(d>>>0>=i>>>0){aq();}A=a+(h-4)|0;e=c[A>>2]|0;if((e&1|0)==0){aq();}do{if((e&2|0)==0){if((j|0)==(c[2002]|0)){B=(c[1999]|0)+r|0;c[1999]=B;c[2002]=q;c[q+4>>2]=B|1;if((q|0)!=(c[2001]|0)){return;}c[2001]=0;c[1998]=0;return;}if((j|0)==(c[2001]|0)){B=(c[1998]|0)+r|0;c[1998]=B;c[2001]=q;c[q+4>>2]=B|1;c[d+B>>2]=B;return;}B=(e&-8)+r|0;C=e>>>3;L2856:do{if(e>>>0<256){u=c[a+h>>2]|0;g=c[a+(h|4)>>2]|0;b=8024+(C<<1<<2)|0;do{if((u|0)!=(b|0)){if(u>>>0<(c[2e3]|0)>>>0){aq();}if((c[u+12>>2]|0)==(j|0)){break;}aq();}}while(0);if((g|0)==(u|0)){c[1996]=c[1996]&~(1<>>0<(c[2e3]|0)>>>0){aq();}f=g+8|0;if((c[f>>2]|0)==(j|0)){D=f;break;}aq();}}while(0);c[u+12>>2]=g;c[D>>2]=u;}else{b=i;f=c[a+(h+16)>>2]|0;t=c[a+(h|4)>>2]|0;do{if((t|0)==(b|0)){p=a+(h+12)|0;v=c[p>>2]|0;if((v|0)==0){m=a+(h+8)|0;k=c[m>>2]|0;if((k|0)==0){E=0;break;}else{F=k;G=m;}}else{F=v;G=p;}while(1){p=F+20|0;v=c[p>>2]|0;if((v|0)!=0){F=v;G=p;continue;}p=F+16|0;v=c[p>>2]|0;if((v|0)==0){break;}else{F=v;G=p;}}if(G>>>0<(c[2e3]|0)>>>0){aq();}else{c[G>>2]=0;E=F;break;}}else{p=c[a+h>>2]|0;if(p>>>0<(c[2e3]|0)>>>0){aq();}v=p+12|0;if((c[v>>2]|0)!=(b|0)){aq();}m=t+8|0;if((c[m>>2]|0)==(b|0)){c[v>>2]=t;c[m>>2]=p;E=t;break;}else{aq();}}}while(0);if((f|0)==0){break;}t=a+(h+20)|0;u=8288+(c[t>>2]<<2)|0;do{if((b|0)==(c[u>>2]|0)){c[u>>2]=E;if((E|0)!=0){break;}c[1997]=c[1997]&~(1<>2]);break L2856;}else{if(f>>>0<(c[2e3]|0)>>>0){aq();}g=f+16|0;if((c[g>>2]|0)==(b|0)){c[g>>2]=E;}else{c[f+20>>2]=E;}if((E|0)==0){break L2856;}}}while(0);if(E>>>0<(c[2e3]|0)>>>0){aq();}c[E+24>>2]=f;b=c[a+(h+8)>>2]|0;do{if((b|0)!=0){if(b>>>0<(c[2e3]|0)>>>0){aq();}else{c[E+16>>2]=b;c[b+24>>2]=E;break;}}}while(0);b=c[a+(h+12)>>2]|0;if((b|0)==0){break;}if(b>>>0<(c[2e3]|0)>>>0){aq();}else{c[E+20>>2]=b;c[b+24>>2]=E;break;}}}while(0);c[q+4>>2]=B|1;c[d+B>>2]=B;if((q|0)!=(c[2001]|0)){H=B;break;}c[1998]=B;return;}else{c[A>>2]=e&-2;c[q+4>>2]=r|1;c[d+r>>2]=r;H=r;}}while(0);r=H>>>3;if(H>>>0<256){d=r<<1;e=8024+(d<<2)|0;A=c[1996]|0;E=1<>2]|0;if(h>>>0>=(c[2e3]|0)>>>0){I=h;J=r;break;}aq();}}while(0);c[J>>2]=q;c[I+12>>2]=q;c[q+8>>2]=I;c[q+12>>2]=e;return;}e=q;I=H>>>8;do{if((I|0)==0){K=0;}else{if(H>>>0>16777215){K=31;break;}J=(I+1048320|0)>>>16&8;d=I<>>16&4;A=d<>>16&2;r=14-(E|J|d)+(A<>>15)|0;K=H>>>((r+7|0)>>>0)&1|r<<1;}}while(0);I=8288+(K<<2)|0;c[q+28>>2]=K;c[q+20>>2]=0;c[q+16>>2]=0;r=c[1997]|0;d=1<>2]=e;c[q+24>>2]=I;c[q+12>>2]=q;c[q+8>>2]=q;}else{if((K|0)==31){L=0;}else{L=25-(K>>>1)|0;}A=H<>2]|0;while(1){if((c[J+4>>2]&-8|0)==(H|0)){break;}M=J+16+(A>>>31<<2)|0;E=c[M>>2]|0;if((E|0)==0){N=2270;break;}else{A=A<<1;J=E;}}if((N|0)==2270){if(M>>>0<(c[2e3]|0)>>>0){aq();}else{c[M>>2]=e;c[q+24>>2]=J;c[q+12>>2]=q;c[q+8>>2]=q;break;}}A=J+8|0;B=c[A>>2]|0;E=c[2e3]|0;if(J>>>0>>0){aq();}if(B>>>0>>0){aq();}else{c[B+12>>2]=e;c[A>>2]=e;c[q+8>>2]=B;c[q+12>>2]=J;c[q+24>>2]=0;break;}}}while(0);q=(c[2004]|0)-1|0;c[2004]=q;if((q|0)==0){O=8440;}else{return;}while(1){q=c[O>>2]|0;if((q|0)==0){break;}else{O=q+8|0;}}c[2004]=-1;return;}function c1(b){b=b|0;var c=0;c=b;while(a[c]|0){c=c+1|0;}return c-b|0;}function c2(b,c){b=b|0;c=c|0;var d=0;do{a[b+d|0]=a[c+d|0];d=d+1|0;}while(a[c+(d-1)|0]|0);return b|0;}function c3(b,c){b=b|0;c=c|0;var d=0,e=0;d=b+(c1(b)|0)|0;do{a[d+e|0]=a[c+e|0];e=e+1|0;}while(a[c+(e-1)|0]|0);return b|0;}function c4(a,b,c){a=a|0;b=b|0;c=c|0;var e=0,f=0,g=0;while((e|0)<(c|0)){f=d[a+e|0]|0;g=d[b+e|0]|0;if((f|0)!=(g|0))return((f|0)>(g|0)?1:-1)|0;e=e+1|0;}return 0;}function c5(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0;f=b+e|0;if((e|0)>=20){d=d&255;e=b&3;g=d|d<<8|d<<16|d<<24;h=f&~3;if(e){e=b+4-e|0;while((b|0)<(e|0)){a[b]=d;b=b+1|0;}}while((b|0)<(h|0)){c[b>>2]=g;b=b+4|0;}}while((b|0)<(f|0)){a[b]=d;b=b+1|0;}}function c6(b,d,e){b=b|0;d=d|0;e=e|0;var f=0;f=b|0;if((b&3)==(d&3)){while(b&3){if((e|0)==0)return f|0;a[b]=a[d]|0;b=b+1|0;d=d+1|0;e=e-1|0;}while((e|0)>=4){c[b>>2]=c[d>>2];b=b+4|0;d=d+4|0;e=e-4|0;}}while((e|0)>0){a[b]=a[d]|0;b=b+1|0;d=d+1|0;e=e-1|0;}return f|0;}function c7(b,c,d){b=b|0;c=c|0;d=d|0;var e=0,f=0;while((e|0)<(d|0)){a[b+e|0]=f?0:a[c+e|0]|0;f=f?1:(a[c+e|0]|0)==0;e=e+1|0;}return b|0;}function c8(a,b){a=a|0;b=b|0;return aW[a&7](b|0)|0;}function c9(a,b){a=a|0;b=b|0;aX[a&1](b|0);}function da(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;return aY[a&7](b|0,c|0,d|0,e|0)|0;}function db(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;aZ[a&15](b|0,c|0,d|0);}function dc(a){a=a|0;a_[a&1]();}function dd(a,b,c){a=a|0;b=b|0;c=c|0;return a$[a&1](b|0,c|0)|0;}function de(a){a=a|0;$(0);return 0;}function df(a){a=a|0;$(1);}function dg(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;$(2);return 0;}function dh(a,b,c){a=a|0;b=b|0;c=c|0;$(3);}function di(){$(4);}function dj(a,b){a=a|0;b=b|0;$(5);return 0;}// EMSCRIPTEN_END_FUNCS\\nvar aW=[de,de,cL,de,cJ,de,de,de];var aX=[df,df];var aY=[dg,dg,cI,dg,cK,dg,dg,dg];var aZ=[dh,dh,bZ,dh,b$,dh,b_,dh,bY,dh,bX,dh,dh,dh,dh,dh];var a_=[di,di];var a$=[dj,dj];return{_strlen:c1,_strcat:c3,_mid_create_options:cV,_mid_istream_open_mem:cO,_mid_istream_open_file:cN,_mid_song_read_wave:b6,_mid_exit:cZ,_mid_song_note_on:b0,_strncpy:c7,_memset:c5,_memcpy:c6,_mid_song_get_missing_instrument:bu,_mid_istream_close:cR,_mid_song_free:cY,_mid_init:cT,_mid_song_load:cX,_mid_song_start:b3,_mid_song_get_num_missing_instruments:bt,_memcmp:c4,_free:c0,_malloc:c$,_strcpy:c2,runPostSets:bg,stackAlloc:a0,stackSave:a1,stackRestore:a2,setThrew:a3,setTempRet0:a6,setTempRet1:a7,setTempRet2:a8,setTempRet3:a9,setTempRet4:ba,setTempRet5:bb,setTempRet6:bc,setTempRet7:bd,setTempRet8:be,setTempRet9:bf,dynCall_ii:c8,dynCall_vi:c9,dynCall_iiiii:da,dynCall_viii:db,dynCall_v:dc,dynCall_iii:dd};}(// EMSCRIPTEN_END_ASM\\n{Math:Math,Int8Array:Int8Array,Int16Array:Int16Array,Int32Array:Int32Array,Uint8Array:Uint8Array,Uint16Array:Uint16Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array},{abort:abort,assert:assert,asmPrintInt:asmPrintInt,asmPrintFloat:asmPrintFloat,min:Math_min,invoke_ii:invoke_ii,invoke_vi:invoke_vi,invoke_iiiii:invoke_iiiii,invoke_viii:invoke_viii,invoke_v:invoke_v,invoke_iii:invoke_iii,_strncmp:_strncmp,_lseek:_lseek,_sysconf:_sysconf,_fread:_fread,_fclose:_fclose,_strtok_r:_strtok_r,_abort:_abort,_fprintf:_fprintf,_close:_close,_pread:_pread,_fflush:_fflush,_fopen:_fopen,_open:_open,_strtol:_strtol,_strtok:_strtok,___setErrNo:___setErrNo,__reallyNegative:__reallyNegative,_fseek:_fseek,_send:_send,_write:_write,_strrchr:_strrchr,_sin:_sin,_printf:_printf,_strchr:_strchr,_read:_read,_time:_time,__formatString:__formatString,_atoi:_atoi,_recv:_recv,_pwrite:_pwrite,_llvm_pow_f64:_llvm_pow_f64,_fsync:_fsync,___errno_location:___errno_location,_isspace:_isspace,_sbrk:_sbrk,__parseInt:__parseInt,_fwrite:_fwrite,_strcmp:_strcmp,STACKTOP:STACKTOP,STACK_MAX:STACK_MAX,tempDoublePtr:tempDoublePtr,ABORT:ABORT,NaN:NaN,Infinity:Infinity,_stderr:_stderr},buffer);var _strlen=Module['_strlen']=asm['_strlen'];var _strcat=Module['_strcat']=asm['_strcat'];Module['_mid_create_options']=asm['_mid_create_options'];Module['_mid_istream_open_mem']=asm['_mid_istream_open_mem'];Module['_mid_istream_open_file']=asm['_mid_istream_open_file'];Module['_mid_song_read_wave']=asm['_mid_song_read_wave'];Module['_mid_exit']=asm['_mid_exit'];Module['_mid_song_note_on']=asm['_mid_song_note_on'];var _strncpy=Module['_strncpy']=asm['_strncpy'];var _memset=Module['_memset']=asm['_memset'];var _memcpy=Module['_memcpy']=asm['_memcpy'];Module['_mid_song_get_missing_instrument']=asm['_mid_song_get_missing_instrument'];Module['_mid_istream_close']=asm['_mid_istream_close'];Module['_mid_song_free']=asm['_mid_song_free'];Module['_mid_init']=asm['_mid_init'];Module['_mid_song_load']=asm['_mid_song_load'];Module['_mid_song_start']=asm['_mid_song_start'];Module['_mid_song_get_num_missing_instruments']=asm['_mid_song_get_num_missing_instruments'];var _memcmp=Module['_memcmp']=asm['_memcmp'];Module['_free']=asm['_free'];var _malloc=Module._malloc=asm['_malloc'];var _strcpy=Module['_strcpy']=asm['_strcpy'];var runPostSets=Module['runPostSets']=asm['runPostSets'];Module['dynCall_ii']=asm['dynCall_ii'];Module['dynCall_vi']=asm['dynCall_vi'];Module['dynCall_iiiii']=asm['dynCall_iiiii'];Module['dynCall_viii']=asm['dynCall_viii'];Module['dynCall_v']=asm['dynCall_v'];Module['dynCall_iii']=asm['dynCall_iii'];Runtime.stackAlloc=function(size){return asm['stackAlloc'](size);};Runtime.stackSave=function(){return asm['stackSave']();};Runtime.stackRestore=function(top){asm['stackRestore'](top);};// Warning: printing of i64 values may be slightly rounded! No deep i64 math used, so precise i64 code not included\\nvar i64Math=null;// === Auto-generated postamble setup entry stuff ===\\nif(memoryInitializer){var applyData=function applyData(data){HEAPU8.set(data,STATIC_BASE);};addRunDependency('memory initializer');}var initialStackTop;var calledRun=false;dependenciesFulfilled=function runCaller(){// If run has never been called, and we should call run (INVOKE_RUN is true, and Module.noInitialRun is not false)\\nif(!calledRun&&shouldRunNow)run();if(!calledRun)dependenciesFulfilled=runCaller;// try this again later, after new deps are fulfilled\\n};Module['callMain']=Module.callMain=function callMain(args){assert(runDependencies==0,'cannot call main when async dependencies remain! (listen on __ATMAIN__)');assert(__ATPRERUN__.length==0,'cannot call main when preRun functions remain to be called');args=args||[];ensureInitRuntime();var argc=args.length+1;function pad(){for(var _i=0;_i<4-1;_i++){argv.push(0);}}var argv=[allocate(intArrayFromString('/bin/this.program'),'i8',ALLOC_NORMAL)];pad();for(var i=0;i0){console.warn('run() called, but dependencies remain, so not running');return FS;}preRun();if(runDependencies>0){// a preRun added a dependency, run will be called later\\nreturn FS;}function doRun(){ensureInitRuntime();preMain();calledRun=true;if(Module['_main']&&shouldRunNow){Module['callMain'](args);}postRun();}if(Module['setStatus']){Module['setStatus']('Running...');setTimeout(function(){setTimeout(function(){Module['setStatus']('');},1);if(!ABORT)doRun();},1);}else{doRun();}return FS;}Module.run=run;/**\\n * Initializes the library.\\n * @function init\\n * @memberof LibTiMidity\\n * @param {boolean} [throwError = true] Throw an error if file/folder creation failed.\\n * @instance\\n */Module.init=function(){var throwError=arguments.length>0&&arguments[0]!==undefined?arguments[0]:true;// creates folders for instrument patches\\nModule.createPath('/',LIBTIMIDITY_PATCH_DIRECTORY,throwError);Module.createPath(\\\"/\\\".concat(LIBTIMIDITY_PATCH_DIRECTORY),LIBTIMIDITY_PATCH_DRUM_DIRECTORY,throwError);// creates config file\\nModule.createDataFile('/',LIBTIMIDITY_CONFIG_FILE,LIBTIMIDITY_CONFIG_DATA,true,true,undefined,throwError);};// shouldRunNow refers to calling main(), not run().\\nvar shouldRunNow=true;if(Module['noInitialRun']){shouldRunNow=false;}Module.FS=run();this.Module=Module;};var libtimidity=new LibTiMidity_LibTiMidity();/* harmony default export */ var src_LibTiMidity = (libtimidity.Module);\\n// CONCATENATED MODULE: ./src/events.js\\nvar MIDI_INIT = 'MIDI_INIT';\\nvar MIDI_ERROR = 'MIDI_ERROR';\\nvar MIDI_STATUS = 'MIDI_STATUS';\\nvar MIDI_PRELOAD = 'MIDI_PRELOAD';\\nvar MIDI_LOAD_FILE = 'MIDI_LOAD_FILE';\\nvar MIDI_LOAD_PATCH = 'MIDI_LOAD_PATCH';\\nvar MIDI_PLAY = 'MIDI_PLAY';\\nvar MIDI_PAUSE = 'MIDI_PAUSE';\\nvar MIDI_RESUME = 'MIDI_RESUME';\\nvar MIDI_STOP = 'MIDI_STOP';\\nvar MIDI_END = 'MIDI_END';\\n// CONCATENATED MODULE: ./src/EventHandler.js\\n\\n\\n\\n\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\\n\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { defineProperty_default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\\n\\n\\n\\nvar EventHandler_EventHandler =\\n/*#__PURE__*/\\nfunction () {\\n /**\\n * @class EventHandler\\n * @param {object} [configuration]\\n * @param {string} [configuration.playerId = undefined] The ID of the Midi Player that sends events.\\n * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\\n * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\\n * @return {object} An `EventHandler` instance.\\n */\\n function EventHandler(_ref) {\\n var _this = this;\\n\\n var _ref$eventLogger = _ref.eventLogger,\\n eventLogger = _ref$eventLogger === void 0 ? undefined : _ref$eventLogger,\\n _ref$logging = _ref.logging,\\n logging = _ref$logging === void 0 ? false : _ref$logging,\\n _ref$playerId = _ref.playerId,\\n playerId = _ref$playerId === void 0 ? undefined : _ref$playerId;\\n\\n classCallCheck_default()(this, EventHandler);\\n\\n defineProperty_default()(this, \\\"emitLoadFile\\\", function (_ref2) {\\n var _ref2$message = _ref2.message,\\n message = _ref2$message === void 0 ? 'Loading MIDI file...' : _ref2$message;\\n\\n _this.emitEvent({\\n event: MIDI_LOAD_FILE,\\n message: message\\n });\\n });\\n\\n defineProperty_default()(this, \\\"emitLoadPatch\\\", function (_ref3) {\\n var _ref3$message = _ref3.message,\\n message = _ref3$message === void 0 ? 'Loading instrument patch...' : _ref3$message;\\n\\n _this.emitEvent({\\n event: MIDI_LOAD_PATCH,\\n message: message\\n });\\n });\\n\\n defineProperty_default()(this, \\\"emitError\\\", function (_ref4) {\\n var _ref4$message = _ref4.message,\\n message = _ref4$message === void 0 ? 'An error occurred.' : _ref4$message,\\n _ref4$error = _ref4.error,\\n error = _ref4$error === void 0 ? '' : _ref4$error;\\n\\n _this.emitEvent({\\n event: MIDI_ERROR,\\n message: message,\\n error: error\\n });\\n });\\n\\n defineProperty_default()(this, \\\"emitEvent\\\", function (payload) {\\n var payloadWithId = _objectSpread({}, payload, {\\n playerId: _this.playerId\\n });\\n\\n if (_this.eventLogger) {\\n _this.eventLogger(payloadWithId);\\n } else if (_this.logging) {\\n if (payloadWithId.event === MIDI_ERROR) {\\n console.error(payloadWithId);\\n } else {\\n console.log(payloadWithId);\\n }\\n }\\n });\\n\\n this.playerId = playerId;\\n this.logging = logging;\\n this.eventLogger = eventLogger;\\n }\\n /**\\n * Emits an event that indicates that the MIDI player is initialized.\\n * @function\\n * @param {undefined}\\n */\\n\\n\\n createClass_default()(EventHandler, [{\\n key: \\\"emitInit\\\",\\n value: function emitInit() {\\n this.emitEvent({\\n event: MIDI_INIT,\\n message: 'MIDI player initialized.'\\n });\\n }\\n /**\\n * Emits an event that indicates that a MIDI file is being loaded.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.message] A message about the MIDI file being loaded.\\n */\\n\\n }, {\\n key: \\\"emitPlay\\\",\\n\\n /**\\n * Emits an event that indicates that the MIDI player currently playing a MIDI file.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.time] The playback position.\\n */\\n value: function emitPlay(_ref5) {\\n var time = _ref5.time;\\n this.emitEvent({\\n event: MIDI_PLAY,\\n time: time\\n });\\n }\\n /**\\n * Emits an event that indicates that the MIDI player has paused the playback of a file.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.time] The playback position.\\n */\\n\\n }, {\\n key: \\\"emitPause\\\",\\n value: function emitPause(_ref6) {\\n var time = _ref6.time;\\n this.emitEvent({\\n event: MIDI_PAUSE,\\n time: time\\n });\\n }\\n /**\\n * Emits an event that indicates that the MIDI player has resumed the playback of a file.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.time] The playback position.\\n */\\n\\n }, {\\n key: \\\"emitResume\\\",\\n value: function emitResume(_ref7) {\\n var time = _ref7.time;\\n this.emitEvent({\\n event: MIDI_RESUME,\\n time: time\\n });\\n }\\n /**\\n * Emits an event that indicates that the MIDI player has stopped the playback of a file.\\n * @function\\n * @param {undefined}\\n */\\n\\n }, {\\n key: \\\"emitStop\\\",\\n value: function emitStop() {\\n this.emitEvent({\\n event: MIDI_STOP,\\n time: 0\\n });\\n }\\n /**\\n * Emits an event that indicates that the MIDI player has reached the end of a file.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.time] The playback position.\\n */\\n\\n }, {\\n key: \\\"emitEnd\\\",\\n value: function emitEnd(_ref8) {\\n var time = _ref8.time;\\n this.emitEvent({\\n event: MIDI_END,\\n time: time\\n });\\n }\\n /**\\n * Emits an event that indicates that an error prevented the MIDI player to continue.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.message] A message that indicates that an error occurred.\\n * @param {string} [payload.error] A message that describes the details of the error.\\n */\\n\\n }, {\\n key: \\\"setLogger\\\",\\n\\n /**\\n * Updates the configuration of the logger.\\n * @function\\n * @param {object} [configuration]\\n * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\\n * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\\n */\\n value: function setLogger(_ref9) {\\n var _ref9$eventLogger = _ref9.eventLogger,\\n eventLogger = _ref9$eventLogger === void 0 ? undefined : _ref9$eventLogger,\\n _ref9$logging = _ref9.logging,\\n logging = _ref9$logging === void 0 ? false : _ref9$logging;\\n this.eventLogger = eventLogger;\\n this.logging = logging;\\n }\\n }]);\\n\\n return EventHandler;\\n}();\\n\\n\\n// CONCATENATED MODULE: ./src/MidiPlayer.js\\n\\n\\n\\n\\n\\n\\n\\n\\n\\nvar isFirstInstance = true;\\n\\nvar MidiPlayer_MidiPlayer =\\n/*#__PURE__*/\\nfunction () {\\n /**\\n * @class MidiPlayer\\n * @param {object} [configuration]\\n * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\\n * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\\n * @param {string} [configuration.patchUrl = https://cdn.jsdelivr.net/npm/midi-instrument-patches@latest/] The public path where MIDI instrument patches can be found.\\n * @property {string} playerId ID of this instance of Midi Player.\\n * @property {object} context The AudioContext instance.\\n * @property {number} sampleRate The sample rate of the AudioContext.\\n * @property {function} eventLogger The function that is called to emit events.\\n * @property {boolean} logging Whether console logging is ON or OFF.\\n * @property {arrayBuffer} midiFileArray A typed array that represents the content of the MIDI.\\n * @property {*} midiFileBuffer The buffer with the MIDI data.\\n * @property {string} patchUrl The URL used to load MIDI instrument patches.\\n * @property {object} source The source that plays the audio signal.\\n * @property {number} startTime The time when MIDI playback started.\\n * @property {number} stream The MIDI stream.\\n * @property {*} waveBuffer The buffer with the MIDI data converted to WAV.\\n * @property {boolean} isFirstInstance Whether this is the first instance of the Midi Player or not.\\n *\\n * @return {object} A `MidiPlayer` instance.\\n * @example\\n * import MidiPlayer from 'web-midi-player';\\n *\\n * const eventLogger = (payload) => {\\n * console.log('Received event:', payload.event);\\n * }\\n *\\n * const midiPlayer = new MidiPlayer({ eventLogger });\\n */\\n function MidiPlayer() {\\n var _this = this;\\n\\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\\n _ref$eventLogger = _ref.eventLogger,\\n eventLogger = _ref$eventLogger === void 0 ? undefined : _ref$eventLogger,\\n _ref$logging = _ref.logging,\\n logging = _ref$logging === void 0 ? false : _ref$logging,\\n _ref$patchUrl = _ref.patchUrl,\\n patchUrl = _ref$patchUrl === void 0 ? MIDI_DEFAULT_PATCH_URL : _ref$patchUrl;\\n\\n classCallCheck_default()(this, MidiPlayer);\\n\\n defineProperty_default()(this, \\\"initPlayback\\\", function () {\\n src_LibTiMidity.call('mid_song_start', 'void', ['number'], [_this.song]);\\n\\n try {\\n _this.connectSource();\\n\\n _this.waveBuffer = src_LibTiMidity._malloc(MIDI_AUDIO_BUFFER_SIZE * 2);\\n _this.startTime = _this.context.currentTime;\\n } catch (error) {\\n _this.eventHandler.emitError({\\n message: 'Could not initialize playback.',\\n error: error\\n });\\n\\n return;\\n }\\n\\n _this.eventHandler.emitPlay({\\n time: 0\\n });\\n });\\n\\n defineProperty_default()(this, \\\"connectSource\\\", function () {\\n // Warning! This feature has been marked as deprecated: https://developer.mozilla.org/en-US/docs/Web/API/BaseAudioContext/createScriptProcessor\\n // See issue: https://github.com/yvesgurcan/web-midi-player/issues/29\\n _this.source = _this.context.createScriptProcessor(MIDI_AUDIO_BUFFER_SIZE, 0, 1); // event handler for next buffer full of audio data\\n\\n _this.source.onaudioprocess = function (event) {\\n return _this.handleOutput(event);\\n }; // connects the source to the context's destination (the speakers)\\n\\n\\n _this.source.connect(_this.context.destination);\\n });\\n\\n defineProperty_default()(this, \\\"emitEvent\\\", function (payload) {\\n return _this.eventHandler.emitEvent(payload);\\n });\\n\\n try {\\n var playerId = v4_default()();\\n this.playerId = playerId;\\n this.eventHandler = new EventHandler_EventHandler({\\n eventLogger: eventLogger,\\n logging: logging,\\n playerId: playerId\\n });\\n } catch (error) {\\n console.error('Fatal error. Could not initialize event handler.');\\n return;\\n }\\n\\n try {\\n this.eventLogger = eventLogger;\\n this.logging = logging;\\n this.patchUrl = patchUrl;\\n this.startTime = 0;\\n src_LibTiMidity.init(isFirstInstance);\\n this.isFirstInstance = isFirstInstance;\\n\\n if (isFirstInstance) {\\n isFirstInstance = false;\\n }\\n\\n this.eventHandler.emitInit();\\n } catch (error) {\\n this.eventHandler.emitError({\\n message: 'Could not initialize instance of MidiPlayer.',\\n error: error\\n });\\n }\\n }\\n /**\\n * Formats the name of a MIDI for display purposes.\\n * @param {String} name Name of the MIDI song.\\n * @return {String}\\n */\\n\\n\\n createClass_default()(MidiPlayer, [{\\n key: \\\"preload\\\",\\n\\n /**\\n * Loads instrument patches for a list of MIDI input.\\n *\\n * Please note that you can not use `parameters.items.arrayBuffer` and `parameters.items.url` concurrently.\\n * @param {object} parameters\\n * @param {object} [parameters.items] An array.\\n * @param {arrayBuffer} [parameters.items.arrayBuffer] An array buffer containing MIDI data to play.\\n * @param {string} [parameters.items.url] The URL where the MIDI file to play is located.\\n * @param {object} [parameters.audioContext] An instance of the Web Audio API AudioContext interface.\\n * @return {boolean} Whether instrument patches were successfully preloaded or not.\\n * @example\\n * const name1 = 'My MIDI file from URL';\\n * const url = 'media/file.midi';\\n * const name2 = 'My MIDI file from ArrayBuffer';\\n * const arrayBuffer = new ArrayBuffer();\\n *\\n * midiPlayer.preload({\\n * items: [\\n * { url, name: name1 },\\n * { arrayBuffer, name: name2 }\\n * ]\\n * });\\n */\\n value: function () {\\n var _preload = asyncToGenerator_default()(\\n /*#__PURE__*/\\n regenerator_default.a.mark(function _callee() {\\n var _ref2,\\n _ref2$items,\\n items,\\n audioContext,\\n i,\\n item,\\n url,\\n arrayBuffer,\\n initialized,\\n data,\\n _args = arguments;\\n\\n return regenerator_default.a.wrap(function _callee$(_context) {\\n while (1) {\\n switch (_context.prev = _context.next) {\\n case 0:\\n _ref2 = _args.length > 0 && _args[0] !== undefined ? _args[0] : {}, _ref2$items = _ref2.items, items = _ref2$items === void 0 ? [] : _ref2$items, audioContext = _ref2.audioContext;\\n i = 0;\\n\\n case 2:\\n if (!(i < items.length)) {\\n _context.next = 22;\\n break;\\n }\\n\\n item = items[i];\\n url = item.url, arrayBuffer = item.arrayBuffer;\\n initialized = this.initAudioContext({\\n audioContext: audioContext\\n });\\n\\n if (initialized) {\\n _context.next = 8;\\n break;\\n }\\n\\n return _context.abrupt(\\\"return\\\", false);\\n\\n case 8:\\n if (this.isSourceValid({\\n url: url,\\n arrayBuffer: arrayBuffer\\n })) {\\n _context.next = 10;\\n break;\\n }\\n\\n return _context.abrupt(\\\"return\\\", false);\\n\\n case 10:\\n _context.next = 12;\\n return this.getSource({\\n url: url,\\n arrayBuffer: arrayBuffer\\n });\\n\\n case 12:\\n data = _context.sent;\\n\\n if (data) {\\n _context.next = 15;\\n break;\\n }\\n\\n return _context.abrupt(\\\"return\\\", false);\\n\\n case 15:\\n this.midiFileArray = new Int8Array(data);\\n this.handleStream();\\n _context.next = 19;\\n return this.getInstrumentPatches();\\n\\n case 19:\\n i++;\\n _context.next = 2;\\n break;\\n\\n case 22:\\n case \\\"end\\\":\\n return _context.stop();\\n }\\n }\\n }, _callee, this);\\n }));\\n\\n function preload() {\\n return _preload.apply(this, arguments);\\n }\\n\\n return preload;\\n }()\\n /**\\n * Starts playback of MIDI input.\\n *\\n * Please note that you can not use `input.arrayBuffer` and `input.url` concurrently.\\n * @param {object} input\\n * @param {arrayBuffer} [input.arrayBuffer] An array buffer containing MIDI data to play.\\n * @param {string} [input.url] The URL where the MIDI file to play is located.\\n * @param {string} [input.name] A human-friendly name for the song.\\n * @param {object} [input.audioContext] An instance of the Web Audio API AudioContext interface.\\n * @return {boolean} Whether playback was successfully initiated or not.\\n * @example\\n * const name1 = 'My MIDI file from URL';\\n * const url = 'media/file.midi';\\n * midiPlayer.play({ url, name: name1 });\\n *\\n * const name2 = 'My MIDI file from ArrayBuffer';\\n * const arrayBuffer = new ArrayBuffer();\\n * midiPlayer.play({ arrayBuffer, name: name2 });\\n */\\n\\n }, {\\n key: \\\"play\\\",\\n value: function () {\\n var _play = asyncToGenerator_default()(\\n /*#__PURE__*/\\n regenerator_default.a.mark(function _callee2() {\\n var _ref3,\\n arrayBuffer,\\n url,\\n name,\\n audioContext,\\n initialized,\\n data,\\n loaded,\\n _args2 = arguments;\\n\\n return regenerator_default.a.wrap(function _callee2$(_context2) {\\n while (1) {\\n switch (_context2.prev = _context2.next) {\\n case 0:\\n _ref3 = _args2.length > 0 && _args2[0] !== undefined ? _args2[0] : {}, arrayBuffer = _ref3.arrayBuffer, url = _ref3.url, name = _ref3.name, audioContext = _ref3.audioContext;\\n this.stop();\\n initialized = this.initAudioContext({\\n audioContext: audioContext\\n });\\n\\n if (initialized) {\\n _context2.next = 5;\\n break;\\n }\\n\\n return _context2.abrupt(\\\"return\\\", false);\\n\\n case 5:\\n if (this.isSourceValid({\\n url: url,\\n arrayBuffer: arrayBuffer\\n })) {\\n _context2.next = 7;\\n break;\\n }\\n\\n return _context2.abrupt(\\\"return\\\", false);\\n\\n case 7:\\n this.eventHandler.emitLoadFile({\\n message: \\\"Loading\\\".concat(MidiPlayer.formatMidiName(name), \\\"...\\\")\\n });\\n _context2.next = 10;\\n return this.getSource({\\n url: url,\\n arrayBuffer: arrayBuffer\\n });\\n\\n case 10:\\n data = _context2.sent;\\n\\n if (data) {\\n _context2.next = 13;\\n break;\\n }\\n\\n return _context2.abrupt(\\\"return\\\", false);\\n\\n case 13:\\n _context2.next = 15;\\n return this.loadSong({\\n arrayBuffer: data\\n });\\n\\n case 15:\\n loaded = _context2.sent;\\n\\n if (!loaded) {\\n _context2.next = 18;\\n break;\\n }\\n\\n return _context2.abrupt(\\\"return\\\", this.initPlayback());\\n\\n case 18:\\n case \\\"end\\\":\\n return _context2.stop();\\n }\\n }\\n }, _callee2, this);\\n }));\\n\\n function play() {\\n return _play.apply(this, arguments);\\n }\\n\\n return play;\\n }()\\n }, {\\n key: \\\"initAudioContext\\\",\\n value: function initAudioContext(_ref4) {\\n var audioContext = _ref4.audioContext;\\n\\n try {\\n // AudioContext must be fired close to the touch/click event initiated by the user to work in Safari\\n this.context = audioContext || new (window.AudioContext || window.webkitAudioContext)();\\n this.sampleRate = this.context.sampleRate;\\n var gainNode = this.context.createGain();\\n gainNode.gain.value = 1; // volume\\n\\n return true;\\n } catch (error) {\\n this.eventHandler.emitError({\\n message: \\\"Could not set AudioContext.\\\",\\n error: error\\n });\\n return false;\\n }\\n }\\n }, {\\n key: \\\"isSourceValid\\\",\\n value: function isSourceValid(_ref5) {\\n var arrayBuffer = _ref5.arrayBuffer,\\n url = _ref5.url;\\n\\n if (!arrayBuffer && !url) {\\n this.eventHandler.emitError({\\n message: \\\"Unknown source. URL or array buffer can't be both undefined to start playback.\\\"\\n });\\n return false;\\n }\\n\\n if (arrayBuffer && url) {\\n this.eventHandler.emitError({\\n message: 'Ambiguous source. MIDI data must originate either from a URL or an array buffer to start playback. Not both.'\\n });\\n return false;\\n }\\n\\n return true;\\n }\\n }, {\\n key: \\\"getSource\\\",\\n value: function () {\\n var _getSource = asyncToGenerator_default()(\\n /*#__PURE__*/\\n regenerator_default.a.mark(function _callee3(_ref6) {\\n var arrayBuffer, url, response;\\n return regenerator_default.a.wrap(function _callee3$(_context3) {\\n while (1) {\\n switch (_context3.prev = _context3.next) {\\n case 0:\\n arrayBuffer = _ref6.arrayBuffer, url = _ref6.url;\\n\\n if (!arrayBuffer) {\\n _context3.next = 3;\\n break;\\n }\\n\\n return _context3.abrupt(\\\"return\\\", arrayBuffer);\\n\\n case 3:\\n _context3.prev = 3;\\n _context3.next = 6;\\n return fetch(url);\\n\\n case 6:\\n response = _context3.sent;\\n\\n if (!(response.status !== 200)) {\\n _context3.next = 10;\\n break;\\n }\\n\\n this.eventHandler.emitError({\\n message: \\\"Could not retrieve MIDI\\\".concat(MidiPlayer.formatMidiName(name), \\\".\\\"),\\n error: \\\"Status code: \\\".concat(response.status, \\\".\\\")\\n });\\n return _context3.abrupt(\\\"return\\\", false);\\n\\n case 10:\\n return _context3.abrupt(\\\"return\\\", response.arrayBuffer());\\n\\n case 13:\\n _context3.prev = 13;\\n _context3.t0 = _context3[\\\"catch\\\"](3);\\n this.eventHandler.emitError({\\n message: \\\"Could not retrieve MIDI\\\".concat(MidiPlayer.formatMidiName(name), \\\".\\\"),\\n error: _context3.t0\\n });\\n return _context3.abrupt(\\\"return\\\", null);\\n\\n case 17:\\n case \\\"end\\\":\\n return _context3.stop();\\n }\\n }\\n }, _callee3, this, [[3, 13]]);\\n }));\\n\\n function getSource(_x) {\\n return _getSource.apply(this, arguments);\\n }\\n\\n return getSource;\\n }()\\n }, {\\n key: \\\"loadSong\\\",\\n value: function () {\\n var _loadSong = asyncToGenerator_default()(\\n /*#__PURE__*/\\n regenerator_default.a.mark(function _callee4(_ref7) {\\n var arrayBuffer, options;\\n return regenerator_default.a.wrap(function _callee4$(_context4) {\\n while (1) {\\n switch (_context4.prev = _context4.next) {\\n case 0:\\n arrayBuffer = _ref7.arrayBuffer;\\n this.midiFileArray = new Int8Array(arrayBuffer);\\n _context4.prev = 2;\\n options = this.handleStream();\\n _context4.next = 6;\\n return this.getInstrumentPatches();\\n\\n case 6:\\n // we need to reload the MIDI once the instrument patches have been loaded\\n this.stream = src_LibTiMidity.call('mid_istream_open_mem', 'number', ['number', 'number', 'number'], [this.midiFileBuffer, this.midiFileArray.length, false]);\\n this.song = src_LibTiMidity.call('mid_song_load', 'number', ['number', 'number'], [this.stream, options]);\\n src_LibTiMidity.call('mid_istream_close', 'number', ['number'], [this.stream]);\\n _context4.next = 15;\\n break;\\n\\n case 11:\\n _context4.prev = 11;\\n _context4.t0 = _context4[\\\"catch\\\"](2);\\n this.eventHandler.emitError({\\n message: 'Could not load song.',\\n error: _context4.t0\\n });\\n return _context4.abrupt(\\\"return\\\", false);\\n\\n case 15:\\n return _context4.abrupt(\\\"return\\\", true);\\n\\n case 16:\\n case \\\"end\\\":\\n return _context4.stop();\\n }\\n }\\n }, _callee4, this, [[2, 11]]);\\n }));\\n\\n function loadSong(_x2) {\\n return _loadSong.apply(this, arguments);\\n }\\n\\n return loadSong;\\n }()\\n }, {\\n key: \\\"handleStream\\\",\\n value: function handleStream() {\\n this.midiFileBuffer = src_LibTiMidity._malloc(this.midiFileArray.length);\\n src_LibTiMidity.writeArrayToMemory(this.midiFileArray, this.midiFileBuffer);\\n src_LibTiMidity.call('mid_init', 'number', [], []);\\n this.stream = src_LibTiMidity.call('mid_istream_open_mem', 'number', ['number', 'number', 'number'], [this.midiFileBuffer, this.midiFileArray.length, false]);\\n var options = src_LibTiMidity.call('mid_create_options', 'number', ['number', 'number', 'number', 'number'], [this.sampleRate, MIDI_AUDIO_S16LSB, 1, MIDI_AUDIO_BUFFER_SIZE * 2]);\\n this.song = src_LibTiMidity.call('mid_song_load', 'number', ['number', 'number'], [this.stream, options]);\\n src_LibTiMidity.call('mid_istream_close', 'number', ['number'], [this.stream]);\\n return options;\\n }\\n }, {\\n key: \\\"getInstrumentPatches\\\",\\n value: function () {\\n var _getInstrumentPatches = asyncToGenerator_default()(\\n /*#__PURE__*/\\n regenerator_default.a.mark(function _callee5() {\\n var missingPatchCount, i, missingPatch;\\n return regenerator_default.a.wrap(function _callee5$(_context5) {\\n while (1) {\\n switch (_context5.prev = _context5.next) {\\n case 0:\\n missingPatchCount = src_LibTiMidity.call('mid_song_get_num_missing_instruments', 'number', ['number'], [this.song]);\\n\\n if (!(missingPatchCount > 0)) {\\n _context5.next = 18;\\n break;\\n }\\n\\n this.eventHandler.emitLoadPatch({\\n message: \\\"Loading \\\".concat(missingPatchCount, \\\" instrument patches...\\\")\\n });\\n i = 0;\\n\\n case 4:\\n if (!(i < missingPatchCount)) {\\n _context5.next = 18;\\n break;\\n }\\n\\n missingPatch = src_LibTiMidity.call('mid_song_get_missing_instrument', 'string', ['number', 'number'], [this.song, i]);\\n _context5.prev = 6;\\n _context5.next = 9;\\n return src_LibTiMidity.loadPatchFromUrl(this.patchUrl, missingPatch);\\n\\n case 9:\\n _context5.next = 15;\\n break;\\n\\n case 11:\\n _context5.prev = 11;\\n _context5.t0 = _context5[\\\"catch\\\"](6);\\n this.eventHandler.emitError({\\n message: \\\"Could not retrieve missing instrument patch \\\".concat(missingPatch ? \\\"'\\\".concat(missingPatch, \\\"'\\\") : \\\"#\\\".concat(i), \\\".\\\"),\\n error: _context5.t0\\n });\\n return _context5.abrupt(\\\"return\\\", false);\\n\\n case 15:\\n i++;\\n _context5.next = 4;\\n break;\\n\\n case 18:\\n case \\\"end\\\":\\n return _context5.stop();\\n }\\n }\\n }, _callee5, this, [[6, 11]]);\\n }));\\n\\n function getInstrumentPatches() {\\n return _getInstrumentPatches.apply(this, arguments);\\n }\\n\\n return getInstrumentPatches;\\n }()\\n }, {\\n key: \\\"handleOutput\\\",\\n value: function handleOutput(_ref8) {\\n var outputBuffer = _ref8.outputBuffer;\\n\\n try {\\n var time = this.context.currentTime - this.startTime;\\n this.eventHandler.emitPlay({\\n time: time\\n }); // collect new wave data from LibTiMidity into waveBuffer\\n\\n var readWaveBytes = src_LibTiMidity.call('mid_song_read_wave', 'number', ['number', 'number', 'number', 'number'], [this.song, this.waveBuffer, MIDI_AUDIO_BUFFER_SIZE * 2, false]);\\n\\n if (readWaveBytes === 0) {\\n this.stop();\\n this.eventHandler.emitEnd({\\n time: time\\n });\\n return;\\n } // loop through the samples\\n\\n\\n for (var i = 0; i < MIDI_AUDIO_BUFFER_SIZE; i++) {\\n if (i < readWaveBytes) {\\n // converts PCM data from sint16 in C to number in JavaScript (range: -1.0 .. +1.0)\\n outputBuffer.getChannelData(0)[i] = src_LibTiMidity.getValue(this.waveBuffer + 2 * i, 'i16') / MAX_I16;\\n } else {\\n // fill end of buffer with zeroes, may happen at the end of a piece\\n outputBuffer.getChannelData(0)[i] = 0;\\n }\\n }\\n } catch (error) {\\n this.eventHandler.emitError({\\n message: 'Could not process audio.',\\n error: error\\n });\\n }\\n }\\n /**\\n * Pauses playback of MIDI input.\\n * @param {undefined}\\n * @return {boolean} Whether playback was successfully paused or not.\\n * @example\\n * midiPlayer.pause();\\n */\\n\\n }, {\\n key: \\\"pause\\\",\\n value: function pause() {\\n try {\\n var time = 0;\\n\\n if (this.context) {\\n this.context.suspend();\\n time = this.context.currentTime - this.startTime;\\n }\\n\\n this.eventHandler.emitPause({\\n time: time\\n });\\n return true;\\n } catch (error) {\\n this.eventHandler.emitError({\\n message: 'Could not pause playback.',\\n error: error\\n });\\n return false;\\n }\\n }\\n /**\\n * Resumes playback of MIDI input.\\n * @param {undefined}\\n * @return {boolean} Whether playback was successfully ressumed or not.\\n * @example\\n * midiPlayer.resume();\\n */\\n\\n }, {\\n key: \\\"resume\\\",\\n value: function resume() {\\n try {\\n var time = 0;\\n\\n if (this.context) {\\n this.context.resume();\\n time = this.context.currentTime - this.startTime;\\n }\\n\\n this.eventHandler.emitResume({\\n time: time\\n });\\n return true;\\n } catch (error) {\\n this.eventHandler.emitError({\\n message: 'Could not resume playback.',\\n error: error\\n });\\n return false;\\n }\\n }\\n /**\\n * Stops playback of MIDI input.\\n * @param {undefined}\\n * @return {boolean} Whether playback was successfully stopped or not.\\n * @example\\n * midiPlayer.stop();\\n */\\n\\n }, {\\n key: \\\"stop\\\",\\n value: function stop() {\\n try {\\n if (this.source) {\\n this.context.close();\\n this.disconnectSource();\\n this.freeMemory();\\n src_LibTiMidity.call('mid_exit', 'void', [], []);\\n this.song = 0;\\n }\\n\\n this.startTime = 0;\\n this.eventHandler.emitStop();\\n return true;\\n } catch (error) {\\n this.eventHandler.emitError({\\n message: 'Could not stop playback.',\\n error: error\\n });\\n return false;\\n }\\n }\\n }, {\\n key: \\\"freeMemory\\\",\\n value: function freeMemory() {\\n src_LibTiMidity._free(this.waveBuffer);\\n\\n src_LibTiMidity._free(this.midiFileBuffer);\\n\\n src_LibTiMidity.call('mid_song_free', 'void', ['number'], [this.song]);\\n } // terminate playback\\n\\n }, {\\n key: \\\"disconnectSource\\\",\\n value: function disconnectSource() {\\n this.source.disconnect();\\n this.source = null;\\n }\\n /**\\n * Send custom payloads to the event logger.\\n * @function\\n * @param {object} payload\\n * @param {string} [payload.event] The name of the event.\\n * @param {string} [payload.message] A message that described the event.\\n * @example\\n * const event = 'MIDI_CUSTOM_EVENT';\\n * const message = 'Something happened.';\\n * midiPlayer.emitEvent({ event, message });\\n */\\n\\n }, {\\n key: \\\"setLogger\\\",\\n\\n /**\\n * Updates the configuration of the logger.\\n * @param {object} [configuration]\\n * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\\n * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\\n * @example\\n * const eventLogger = (payload) => {\\n * console.log('Received event:', payload.event);\\n * }\\n * midiPlayer.setLogger({ eventLogger });\\n */\\n value: function setLogger(_ref9) {\\n var _ref9$eventLogger = _ref9.eventLogger,\\n eventLogger = _ref9$eventLogger === void 0 ? undefined : _ref9$eventLogger,\\n _ref9$logging = _ref9.logging,\\n logging = _ref9$logging === void 0 ? false : _ref9$logging;\\n this.eventLogger = eventLogger;\\n this.logging = logging;\\n this.eventHandler.setLogger({\\n eventLogger: eventLogger,\\n logging: logging\\n });\\n }\\n }], [{\\n key: \\\"formatMidiName\\\",\\n value: function formatMidiName(name) {\\n return name ? \\\" '\\\".concat(name, \\\"'\\\") : '';\\n }\\n }]);\\n\\n return MidiPlayer;\\n}();\\n\\n\\n// CONCATENATED MODULE: ./src/index.js\\n\\n/* harmony default export */ var src = __webpack_exports__[\\\"default\\\"] = (MidiPlayer_MidiPlayer);//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"11.js","sources":["webpack://web-midi-player/./src/constants.js?5fb0","webpack://web-midi-player/./src/LibTiMidity.js?cb20","webpack://web-midi-player/./src/events.js?1566","webpack://web-midi-player/./src/EventHandler.js?f7d0","webpack://web-midi-player/./src/MidiPlayer.js?f2c5","webpack://web-midi-player/./src/index.js?b635"],"sourcesContent":["export const MAX_I16 = 2 ** 15;\n\nexport const MIDI_AUDIO_BUFFER_SIZE = 8192;\n\nexport const MIDI_AUDIO_S16LSB = 0x8010;\n\nexport const MIDI_DEFAULT_PATCH_URL =\n    'https://cdn.jsdelivr.net/npm/midi-instrument-patches@latest/';\n\nexport const MIDI_PLAYER_MESSAGE_PREFIX = 'Midi player:';\n\nexport const LIBTIMIDITY_PATCH_DIRECTORY = 'pat';\n\nexport const LIBTIMIDITY_PATCH_DRUM_DIRECTORY = 'MT32Drums';\n\nexport const LIBTIMIDITY_CONFIG_FILE = 'timidity.cfg';\n\nexport const LIBTIMIDITY_ERROR_CODES = {\n    EPERM: 1,\n    ENOENT: 2,\n    ESRCH: 3,\n    EINTR: 4,\n    EIO: 5,\n    ENXIO: 6,\n    E2BIG: 7,\n    ENOEXEC: 8,\n    EBADF: 9,\n    ECHILD: 10,\n    EAGAIN: 11,\n    EWOULDBLOCK: 11,\n    ENOMEM: 12,\n    EACCES: 13,\n    EFAULT: 14,\n    ENOTBLK: 15,\n    EBUSY: 16,\n    EEXIST: 17,\n    EXDEV: 18,\n    ENODEV: 19,\n    ENOTDIR: 20,\n    EISDIR: 21,\n    EINVAL: 22,\n    ENFILE: 23,\n    EMFILE: 24,\n    ENOTTY: 25,\n    ETXTBSY: 26,\n    EFBIG: 27,\n    ENOSPC: 28,\n    ESPIPE: 29,\n    EROFS: 30,\n    EMLINK: 31,\n    EPIPE: 32,\n    EDOM: 33,\n    ERANGE: 34,\n    ENOMSG: 42,\n    EIDRM: 43,\n    ECHRNG: 44,\n    EL2NSYNC: 45,\n    EL3HLT: 46,\n    EL3RST: 47,\n    ELNRNG: 48,\n    EUNATCH: 49,\n    ENOCSI: 50,\n    EL2HLT: 51,\n    EDEADLK: 35,\n    ENOLCK: 37,\n    EBADE: 52,\n    EBADR: 53,\n    EXFULL: 54,\n    ENOANO: 55,\n    EBADRQC: 56,\n    EBADSLT: 57,\n    EDEADLOCK: 35,\n    EBFONT: 59,\n    ENOSTR: 60,\n    ENODATA: 61,\n    ETIME: 62,\n    ENOSR: 63,\n    ENONET: 64,\n    ENOPKG: 65,\n    EREMOTE: 66,\n    ENOLINK: 67,\n    EADV: 68,\n    ESRMNT: 69,\n    ECOMM: 70,\n    EPROTO: 71,\n    EMULTIHOP: 72,\n    EDOTDOT: 73,\n    EBADMSG: 74,\n    ENOTUNIQ: 76,\n    EBADFD: 77,\n    EREMCHG: 78,\n    ELIBACC: 79,\n    ELIBBAD: 80,\n    ELIBSCN: 81,\n    ELIBMAX: 82,\n    ELIBEXEC: 83,\n    ENOSYS: 38,\n    ENOTEMPTY: 39,\n    ENAMETOOLONG: 36,\n    ELOOP: 40,\n    EOPNOTSUPP: 95,\n    EPFNOSUPPORT: 96,\n    ECONNRESET: 104,\n    ENOBUFS: 105,\n    EAFNOSUPPORT: 97,\n    EPROTOTYPE: 91,\n    ENOTSOCK: 88,\n    ENOPROTOOPT: 92,\n    ESHUTDOWN: 108,\n    ECONNREFUSED: 111,\n    EADDRINUSE: 98,\n    ECONNABORTED: 103,\n    ENETUNREACH: 101,\n    ENETDOWN: 100,\n    ETIMEDOUT: 110,\n    EHOSTDOWN: 112,\n    EHOSTUNREACH: 113,\n    EINPROGRESS: 115,\n    EALREADY: 114,\n    EDESTADDRREQ: 89,\n    EMSGSIZE: 90,\n    EPROTONOSUPPORT: 93,\n    ESOCKTNOSUPPORT: 94,\n    EADDRNOTAVAIL: 99,\n    ENETRESET: 102,\n    EISCONN: 106,\n    ENOTCONN: 107,\n    ETOOMANYREFS: 109,\n    EUSERS: 87,\n    EDQUOT: 122,\n    ESTALE: 116,\n    ENOTSUP: 95,\n    ENOMEDIUM: 123,\n    EILSEQ: 84,\n    EOVERFLOW: 75,\n    ECANCELED: 125,\n    ENOTRECOVERABLE: 131,\n    EOWNERDEAD: 130,\n    ESTRPIPE: 86\n};\n\nexport const LIBTIMIDITY_ERROR_MESSAGES = {\n    0: 'Success',\n    1: 'Not super-user',\n    2: 'No such file or directory',\n    3: 'No such process',\n    4: 'Interrupted system call',\n    5: 'I/O error',\n    6: 'No such device or address',\n    7: 'Arg list too long',\n    8: 'Exec format error',\n    9: 'Bad file number',\n    10: 'No children',\n    11: 'No more processes',\n    12: 'Not enough core',\n    13: 'Permission denied',\n    14: 'Bad address',\n    15: 'Block device required',\n    16: 'Mount device busy',\n    17: 'File exists',\n    18: 'Cross-device link',\n    19: 'No such device',\n    20: 'Not a directory',\n    21: 'Is a directory',\n    22: 'Invalid argument',\n    23: 'Too many open files in system',\n    24: 'Too many open files',\n    25: 'Not a typewriter',\n    26: 'Text file busy',\n    27: 'File too large',\n    28: 'No space left on device',\n    29: 'Illegal seek',\n    30: 'Read only file system',\n    31: 'Too many links',\n    32: 'Broken pipe',\n    33: 'Math arg out of domain of func',\n    34: 'Math result not representable',\n    35: 'File locking deadlock error',\n    36: 'File or path name too long',\n    37: 'No record locks available',\n    38: 'Function not implemented',\n    39: 'Directory not empty',\n    40: 'Too many symbolic links',\n    42: 'No message of desired type',\n    43: 'Identifier removed',\n    44: 'Channel number out of range',\n    45: 'Level 2 not synchronized',\n    46: 'Level 3 halted',\n    47: 'Level 3 reset',\n    48: 'Link number out of range',\n    49: 'Protocol driver not attached',\n    50: 'No CSI structure available',\n    51: 'Level 2 halted',\n    52: 'Invalid exchange',\n    53: 'Invalid request descriptor',\n    54: 'Exchange full',\n    55: 'No anode',\n    56: 'Invalid request code',\n    57: 'Invalid slot',\n    59: 'Bad font file fmt',\n    60: 'Device not a stream',\n    61: 'No data (for no delay io)',\n    62: 'Timer expired',\n    63: 'Out of streams resources',\n    64: 'Machine is not on the network',\n    65: 'Package not installed',\n    66: 'The object is remote',\n    67: 'The link has been severed',\n    68: 'Advertise error',\n    69: 'Srmount error',\n    70: 'Communication error on send',\n    71: 'Protocol error',\n    72: 'Multihop attempted',\n    73: 'Cross mount point (not really error)',\n    74: 'Trying to read unreadable message',\n    75: 'Value too large for defined data type',\n    76: 'Given log. name not unique',\n    77: 'f.d. invalid for this operation',\n    78: 'Remote address changed',\n    79: 'Can   access a needed shared lib',\n    80: 'Accessing a corrupted shared lib',\n    81: '.lib section in a.out corrupted',\n    82: 'Attempting to link in too many libs',\n    83: 'Attempting to exec a shared library',\n    84: 'Illegal byte sequence',\n    86: 'Streams pipe error',\n    87: 'Too many users',\n    88: 'Socket operation on non-socket',\n    89: 'Destination address required',\n    90: 'Message too long',\n    91: 'Protocol wrong type for socket',\n    92: 'Protocol not available',\n    93: 'Unknown protocol',\n    94: 'Socket type not supported',\n    95: 'Not supported',\n    96: 'Protocol family not supported',\n    97: 'Address family not supported by protocol family',\n    98: 'Address already in use',\n    99: 'Address not available',\n    100: 'Network interface is not configured',\n    101: 'Network is unreachable',\n    102: 'Connection reset by network',\n    103: 'Connection aborted',\n    104: 'Connection reset by peer',\n    105: 'No buffer space available',\n    106: 'Socket is already connected',\n    107: 'Socket is not connected',\n    108: \"Can't send after socket shutdown\",\n    109: 'Too many references',\n    110: 'Connection timed out',\n    111: 'Connection refused',\n    112: 'Host is down',\n    113: 'Host is unreachable',\n    114: 'Socket already connected',\n    115: 'Connection already in progress',\n    116: 'Stale file handle',\n    122: 'Quota exceeded',\n    123: 'No medium (in tape drive)',\n    125: 'Operation canceled',\n    130: 'Previous owner died',\n    131: 'State not recoverable'\n};\n\n// prettier-ignore\nexport const LIBTIMIDITY_CONFIG_DATA = [100, 105, 114, 32, 46, 47, 112, 97, 116, 10, 10, 100, 114, 117, 109, 115, 101, 116, 32, 48, 10, 10, 32, 51, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 48, 46, 112, 97, 116, 10, 32, 51, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 46, 112, 97, 116, 10, 32, 51, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 46, 112, 97, 116, 10, 32, 51, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 46, 112, 97, 116, 10, 32, 51, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 46, 112, 97, 116, 10, 32, 52, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 53, 46, 112, 97, 116, 10, 32, 52, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 54, 46, 112, 97, 116, 10, 32, 52, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 55, 46, 112, 97, 116, 10, 32, 52, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 56, 46, 112, 97, 116, 10, 32, 52, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 57, 46, 112, 97, 116, 10, 32, 52, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 48, 46, 112, 97, 116, 10, 32, 52, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 49, 46, 112, 97, 116, 10, 32, 52, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 50, 46, 112, 97, 116, 10, 32, 52, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 51, 46, 112, 97, 116, 10, 32, 52, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 52, 46, 112, 97, 116, 10, 32, 53, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 53, 46, 112, 97, 116, 10, 32, 53, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 54, 46, 112, 97, 116, 10, 32, 53, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 55, 46, 112, 97, 116, 10, 32, 53, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 56, 46, 112, 97, 116, 10, 32, 53, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 49, 57, 46, 112, 97, 116, 10, 32, 53, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 48, 46, 112, 97, 116, 10, 32, 53, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 49, 46, 112, 97, 116, 10, 32, 53, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 50, 46, 112, 97, 116, 10, 32, 53, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 51, 46, 112, 97, 116, 10, 32, 53, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 52, 46, 112, 97, 116, 10, 32, 54, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 53, 46, 112, 97, 116, 10, 32, 54, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 54, 46, 112, 97, 116, 10, 32, 54, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 55, 46, 112, 97, 116, 10, 32, 54, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 56, 46, 112, 97, 116, 10, 32, 54, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 50, 57, 46, 112, 97, 116, 10, 32, 54, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 48, 46, 112, 97, 116, 10, 32, 54, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 49, 46, 112, 97, 116, 10, 32, 54, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 50, 46, 112, 97, 116, 10, 32, 54, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 51, 46, 112, 97, 116, 10, 32, 54, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 52, 46, 112, 97, 116, 10, 32, 55, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 53, 46, 112, 97, 116, 10, 32, 55, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 54, 46, 112, 97, 116, 10, 32, 55, 50, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 55, 46, 112, 97, 116, 10, 32, 55, 51, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 56, 46, 112, 97, 116, 10, 32, 55, 52, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 51, 57, 46, 112, 97, 116, 10, 32, 55, 53, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 48, 46, 112, 97, 116, 10, 32, 55, 54, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 49, 46, 112, 97, 116, 10, 32, 55, 55, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 50, 46, 112, 97, 116, 10, 32, 55, 56, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 51, 46, 112, 97, 116, 10, 32, 55, 57, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 52, 46, 112, 97, 116, 10, 32, 56, 48, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 53, 46, 112, 97, 116, 10, 32, 56, 49, 9, 32, 77, 84, 51, 50, 68, 114, 117, 109, 115, 47, 109, 116, 51, 50, 100, 114, 117, 109, 45, 52, 54, 46, 112, 97, 116, 10, 10, 98, 97, 110, 107, 32, 48, 10, 10, 32, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 55, 46, 112, 97, 116, 10, 32, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 54, 46, 112, 97, 116, 10, 32, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 53, 46, 112, 97, 116, 10, 32, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 52, 46, 112, 97, 116, 10, 32, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 51, 46, 112, 97, 116, 10, 32, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 50, 46, 112, 97, 116, 10, 32, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 49, 46, 112, 97, 116, 10, 32, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 48, 46, 112, 97, 116, 10, 32, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 57, 46, 112, 97, 116, 10, 32, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 56, 46, 112, 97, 116, 10, 32, 49, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 55, 46, 112, 97, 116, 10, 32, 49, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 54, 46, 112, 97, 116, 10, 32, 49, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 53, 46, 112, 97, 116, 10, 32, 49, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 52, 46, 112, 97, 116, 10, 32, 49, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 51, 46, 112, 97, 116, 10, 32, 49, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 50, 46, 112, 97, 116, 10, 32, 49, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 49, 46, 112, 97, 116, 10, 32, 49, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 48, 46, 112, 97, 116, 10, 32, 49, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 57, 46, 112, 97, 116, 10, 32, 49, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 56, 46, 112, 97, 116, 10, 32, 50, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 55, 46, 112, 97, 116, 10, 32, 50, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 54, 46, 112, 97, 116, 10, 32, 50, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 53, 46, 112, 97, 116, 10, 32, 50, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 52, 46, 112, 97, 116, 10, 32, 50, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 51, 46, 112, 97, 116, 10, 32, 50, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 50, 46, 112, 97, 116, 10, 32, 50, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 49, 46, 112, 97, 116, 10, 32, 50, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 48, 46, 112, 97, 116, 10, 32, 50, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 57, 46, 112, 97, 116, 10, 32, 50, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 56, 46, 112, 97, 116, 10, 32, 51, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 55, 46, 112, 97, 116, 10, 32, 51, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 54, 46, 112, 97, 116, 10, 32, 51, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 53, 46, 112, 97, 116, 10, 32, 51, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 52, 46, 112, 97, 116, 10, 32, 51, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 51, 46, 112, 97, 116, 10, 32, 51, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 50, 46, 112, 97, 116, 10, 32, 51, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 49, 46, 112, 97, 116, 10, 32, 51, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 48, 46, 112, 97, 116, 10, 32, 51, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 57, 46, 112, 97, 116, 10, 32, 51, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 56, 46, 112, 97, 116, 10, 32, 52, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 55, 46, 112, 97, 116, 10, 32, 52, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 54, 46, 112, 97, 116, 10, 32, 52, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 53, 46, 112, 97, 116, 10, 32, 52, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 52, 46, 112, 97, 116, 10, 32, 52, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 51, 46, 112, 97, 116, 10, 32, 52, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 50, 46, 112, 97, 116, 10, 32, 52, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 49, 46, 112, 97, 116, 10, 32, 52, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 48, 46, 112, 97, 116, 10, 32, 52, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 57, 46, 112, 97, 116, 10, 32, 52, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 56, 46, 112, 97, 116, 10, 32, 53, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 55, 46, 112, 97, 116, 10, 32, 53, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 54, 46, 112, 97, 116, 10, 32, 53, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 53, 46, 112, 97, 116, 10, 32, 53, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 52, 46, 112, 97, 116, 10, 32, 53, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 51, 46, 112, 97, 116, 10, 32, 53, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 50, 46, 112, 97, 116, 10, 32, 53, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 49, 46, 112, 97, 116, 10, 32, 53, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 48, 46, 112, 97, 116, 10, 32, 53, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 57, 46, 112, 97, 116, 10, 32, 53, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 56, 46, 112, 97, 116, 10, 32, 54, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 55, 46, 112, 97, 116, 10, 32, 54, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 54, 46, 112, 97, 116, 10, 32, 54, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 53, 46, 112, 97, 116, 10, 32, 54, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 52, 46, 112, 97, 116, 10, 32, 54, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 51, 46, 112, 97, 116, 10, 32, 54, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 50, 46, 112, 97, 116, 10, 32, 54, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 49, 46, 112, 97, 116, 10, 32, 54, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 48, 46, 112, 97, 116, 10, 32, 54, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 57, 46, 112, 97, 116, 10, 32, 54, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 56, 46, 112, 97, 116, 10, 32, 55, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 55, 46, 112, 97, 116, 10, 32, 55, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 54, 46, 112, 97, 116, 10, 32, 55, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 53, 46, 112, 97, 116, 10, 32, 55, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 52, 46, 112, 97, 116, 10, 32, 55, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 51, 46, 112, 97, 116, 10, 32, 55, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 50, 46, 112, 97, 116, 10, 32, 55, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 49, 46, 112, 97, 116, 10, 32, 55, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 48, 46, 112, 97, 116, 10, 32, 55, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 57, 46, 112, 97, 116, 10, 32, 55, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 56, 46, 112, 97, 116, 10, 32, 56, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 55, 46, 112, 97, 116, 10, 32, 56, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 54, 46, 112, 97, 116, 10, 32, 56, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 53, 46, 112, 97, 116, 10, 32, 56, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 52, 46, 112, 97, 116, 10, 32, 56, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 51, 46, 112, 97, 116, 10, 32, 56, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 50, 46, 112, 97, 116, 10, 32, 56, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 49, 46, 112, 97, 116, 10, 32, 56, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 48, 46, 112, 97, 116, 10, 32, 56, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 57, 46, 112, 97, 116, 10, 32, 56, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 56, 46, 112, 97, 116, 10, 32, 57, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 55, 46, 112, 97, 116, 10, 32, 57, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 54, 46, 112, 97, 116, 10, 32, 57, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 53, 46, 112, 97, 116, 10, 32, 57, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 52, 46, 112, 97, 116, 10, 32, 57, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 51, 46, 112, 97, 116, 10, 32, 57, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 50, 46, 112, 97, 116, 10, 32, 57, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 49, 46, 112, 97, 116, 10, 32, 57, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 48, 46, 112, 97, 116, 10, 32, 57, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 57, 46, 112, 97, 116, 10, 32, 57, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 56, 46, 112, 97, 116, 10, 32, 49, 48, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 55, 46, 112, 97, 116, 10, 32, 49, 48, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 54, 46, 112, 97, 116, 10, 32, 49, 48, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 53, 46, 112, 97, 116, 10, 32, 49, 48, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 52, 46, 112, 97, 116, 10, 32, 49, 48, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 51, 46, 112, 97, 116, 10, 32, 49, 48, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 50, 46, 112, 97, 116, 10, 32, 49, 48, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 49, 46, 112, 97, 116, 10, 32, 49, 48, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 48, 46, 112, 97, 116, 10, 32, 49, 48, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 57, 46, 112, 97, 116, 10, 32, 49, 48, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 56, 46, 112, 97, 116, 10, 32, 49, 49, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 55, 46, 112, 97, 116, 10, 32, 49, 49, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 54, 46, 112, 97, 116, 10, 32, 49, 49, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 53, 46, 112, 97, 116, 10, 32, 49, 49, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 52, 46, 112, 97, 116, 10, 32, 49, 49, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 51, 46, 112, 97, 116, 10, 32, 49, 49, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 50, 46, 112, 97, 116, 10, 32, 49, 49, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 49, 46, 112, 97, 116, 10, 32, 49, 49, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 48, 46, 112, 97, 116, 10, 32, 49, 49, 56, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 57, 46, 112, 97, 116, 10, 32, 49, 49, 57, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 56, 46, 112, 97, 116, 10, 32, 49, 50, 48, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 55, 46, 112, 97, 116, 10, 32, 49, 50, 49, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 54, 46, 112, 97, 116, 10, 32, 49, 50, 50, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 53, 46, 112, 97, 116, 10, 32, 49, 50, 51, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 52, 46, 112, 97, 116, 10, 32, 49, 50, 52, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 51, 46, 112, 97, 116, 10, 32, 49, 50, 53, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 50, 46, 112, 97, 116, 10, 32, 49, 50, 54, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 49, 46, 112, 97, 116, 10, 32, 49, 50, 55, 9, 32, 97, 114, 97, 99, 104, 110, 111, 45, 48, 46, 112, 97, 116, 10];\n","import {\n    LIBTIMIDITY_PATCH_DIRECTORY,\n    LIBTIMIDITY_PATCH_DRUM_DIRECTORY,\n    LIBTIMIDITY_CONFIG_FILE,\n    LIBTIMIDITY_CONFIG_DATA,\n    LIBTIMIDITY_ERROR_CODES as ERRNO_CODES,\n    LIBTIMIDITY_ERROR_MESSAGES as ERRNO_MESSAGES\n} from './constants';\n\n// https://github.com/kripken/emscripten/wiki/\n\nconst INT_TYPES = { i1: 0, i8: 0, i16: 0, i32: 0, i64: 0 };\nconst FLOAT_TYPES = { float: 0, double: 0 };\n\n/** @class */\nclass LibTiMidity {\n    /**\n     * Library to enable playback of MIDI files.\n     * @param {undefined}\n     * @return {object} The module of an instance of LibTiMidity.\n     * @property {Number} TOTAL_MEMORY The amount of memory available to the library.\n     */\n    constructor() {\n        const Runtime = {\n            stackSave: function() {\n                return STACKTOP;\n            },\n            stackRestore: function(stackTop) {\n                STACKTOP = stackTop;\n            },\n            isNumberType: function(type) {\n                return type in INT_TYPES || type in FLOAT_TYPES;\n            },\n            isPointerType: function isPointerType(type) {\n                return type[type.length - 1] == '*';\n            },\n            isStructType: function isStructType(type) {\n                if (isPointerType(type)) return false;\n                if (isArrayType(type)) return true;\n                if (/<?{ ?[^}]* ?}>?/.test(type)) return true; // { i32, i8 } etc. - anonymous struct types\n                // See comment in isStructPointerType()\n                return type[0] == '%';\n            },\n            getNativeTypeSize: function(type) {\n                switch (type) {\n                    case 'i1':\n                    case 'i8':\n                        return 1;\n                    case 'i16':\n                        return 2;\n                    case 'i32':\n                        return 4;\n                    case 'i64':\n                        return 8;\n                    case 'float':\n                        return 4;\n                    case 'double':\n                        return 8;\n                    default: {\n                        if (type[type.length - 1] === '*') {\n                            return Runtime.QUANTUM_SIZE; // A pointer\n                        } else if (type[0] === 'i') {\n                            const bits = parseInt(type.substr(1));\n                            assert(bits % 8 === 0);\n                            return bits / 8;\n                        }\n                    }\n                }\n            },\n            getNativeFieldSize: function(type) {\n                return Math.max(\n                    Runtime.getNativeTypeSize(type),\n                    Runtime.QUANTUM_SIZE\n                );\n            },\n            dedup: function dedup(items, ident) {\n                const seen = {};\n                if (ident) {\n                    return items.filter(function(item) {\n                        if (seen[item[ident]]) return false;\n                        seen[item[ident]] = true;\n                        return true;\n                    });\n                } else {\n                    return items.filter(function(item) {\n                        if (seen[item]) return false;\n                        seen[item] = true;\n                        return true;\n                    });\n                }\n            },\n            set: function set() {\n                const args =\n                    typeof arguments[0] === 'object' ? arguments[0] : arguments;\n                const ret = {};\n                for (let i = 0; i < args.length; i++) {\n                    ret[args[i]] = 0;\n                }\n                return ret;\n            },\n            getAlignSize: function(type, size, vararg) {\n                // we align i64s and doubles on 64-bit boundaries, unlike x86\n                if (type == 'i64' || type == 'double' || vararg) return 8;\n                if (!type) return Math.min(size, 8); // align structures internally to 64 bits\n                return Math.min(\n                    size || (type ? Runtime.getNativeFieldSize(type) : 0),\n                    Runtime.QUANTUM_SIZE\n                );\n            },\n            calculateStructAlignment: function calculateStructAlignment(type) {\n                type.flatSize = 0;\n                type.alignSize = 0;\n                const diffs = [];\n                let prev = -1;\n                type.flatIndexes = type.fields.map(function(field) {\n                    let size, alignSize;\n                    if (\n                        Runtime.isNumberType(field) ||\n                        Runtime.isPointerType(field)\n                    ) {\n                        size = Runtime.getNativeTypeSize(field); // pack char; char; in structs, also char[X]s.\n                        alignSize = Runtime.getAlignSize(field, size);\n                    } else if (Runtime.isStructType(field)) {\n                        if (field[1] === '0') {\n                            // this is [0 x something]. When inside another structure like here, it must be at the end, and it adds no size\n                            // this happens in java-nbody for example... assert(index === type.fields.length, 'zero-length in the middle!');\n                            size = 0;\n                            if (Types.types[field]) {\n                                alignSize = Runtime.getAlignSize(\n                                    null,\n                                    Types.types[field].alignSize\n                                );\n                            } else {\n                                alignSize = type.alignSize || QUANTUM_SIZE;\n                            }\n                        } else {\n                            size = Types.types[field].flatSize;\n                            alignSize = Runtime.getAlignSize(\n                                null,\n                                Types.types[field].alignSize\n                            );\n                        }\n                    } else if (field[0] == 'b') {\n                        // bN, large number field, like a [N x i8]\n                        size = field.substr(1) | 0;\n                        alignSize = 1;\n                    } else {\n                        throw 'Unclear type in struct: ' +\n                            field +\n                            ', in ' +\n                            type.name_ +\n                            ' :: ' +\n                            dump(Types.types[type.name_]);\n                    }\n                    if (type.packed) alignSize = 1;\n                    type.alignSize = Math.max(type.alignSize, alignSize);\n                    const curr = Runtime.alignMemory(type.flatSize, alignSize); // if necessary, place this on aligned memory\n                    type.flatSize = curr + size;\n                    if (prev >= 0) {\n                        diffs.push(curr - prev);\n                    }\n                    prev = curr;\n                    return curr;\n                });\n                type.flatSize = Runtime.alignMemory(\n                    type.flatSize,\n                    type.alignSize\n                );\n                if (diffs.length == 0) {\n                    type.flatFactor = type.flatSize;\n                } else if (Runtime.dedup(diffs).length == 1) {\n                    type.flatFactor = diffs[0];\n                }\n                type.needsFlattening = type.flatFactor != 1;\n                return type.flatIndexes;\n            },\n            generateStructInfo: function(struct, typeName, offset) {\n                var type, alignment;\n                if (typeName) {\n                    offset = offset || 0;\n                    type = (typeof Types === 'undefined'\n                        ? Runtime.typeInfo\n                        : Types.types)[typeName];\n                    if (!type) return null;\n                    if (type.fields.length != struct.length) {\n                        console.warn(\n                            'Number of named fields must match the type for ' +\n                                typeName +\n                                ': possibly duplicate struct names. Cannot return structInfo'\n                        );\n                        return null;\n                    }\n                    alignment = type.flatIndexes;\n                } else {\n                    var type = {\n                        fields: struct.map(function(item) {\n                            return item[0];\n                        })\n                    };\n                    alignment = Runtime.calculateStructAlignment(type);\n                }\n                const ret = {\n                    __size__: type.flatSize\n                };\n                if (typeName) {\n                    struct.forEach(function(item, i) {\n                        if (typeof item === 'string') {\n                            ret[item] = alignment[i] + offset;\n                        } else {\n                            // embedded struct\n                            let key;\n                            for (const k in item) key = k;\n                            ret[key] = Runtime.generateStructInfo(\n                                item[key],\n                                type.fields[i],\n                                alignment[i]\n                            );\n                        }\n                    });\n                } else {\n                    struct.forEach(function(item, i) {\n                        ret[item[1]] = alignment[i];\n                    });\n                }\n                return ret;\n            },\n            dynCall: function(sig, ptr, args) {\n                if (args && args.length) {\n                    if (!args.splice) args = Array.prototype.slice.call(args);\n                    args.splice(0, 0, ptr);\n                    return Module['dynCall_' + sig].apply(null, args);\n                } else {\n                    return Module['dynCall_' + sig].call(null, ptr);\n                }\n            },\n            UTF8Processor: function() {\n                const buffer = [];\n                let needed = 0;\n                this.processCChar = function(code) {\n                    code = code & 0xff;\n                    if (buffer.length == 0) {\n                        if ((code & 0x80) == 0x00) {\n                            // 0xxxxxxx\n                            return String.fromCharCode(code);\n                        }\n                        buffer.push(code);\n                        if ((code & 0xe0) == 0xc0) {\n                            // 110xxxxx\n                            needed = 1;\n                        } else if ((code & 0xf0) == 0xe0) {\n                            // 1110xxxx\n                            needed = 2;\n                        } else {\n                            // 11110xxx\n                            needed = 3;\n                        }\n                        return '';\n                    }\n                    if (needed) {\n                        buffer.push(code);\n                        needed--;\n                        if (needed > 0) return '';\n                    }\n                    const c1 = buffer[0];\n                    const c2 = buffer[1];\n                    const c3 = buffer[2];\n                    const c4 = buffer[3];\n                    let ret;\n                    if (buffer.length == 2) {\n                        ret = String.fromCharCode(\n                            ((c1 & 0x1f) << 6) | (c2 & 0x3f)\n                        );\n                    } else if (buffer.length == 3) {\n                        ret = String.fromCharCode(\n                            ((c1 & 0x0f) << 12) |\n                                ((c2 & 0x3f) << 6) |\n                                (c3 & 0x3f)\n                        );\n                    } else {\n                        // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n                        const codePoint =\n                            ((c1 & 0x07) << 18) |\n                            ((c2 & 0x3f) << 12) |\n                            ((c3 & 0x3f) << 6) |\n                            (c4 & 0x3f);\n                        ret = String.fromCharCode(\n                            Math.floor((codePoint - 0x10000) / 0x400) + 0xd800,\n                            ((codePoint - 0x10000) % 0x400) + 0xdc00\n                        );\n                    }\n                    buffer.length = 0;\n                    return ret;\n                };\n                this.processJSString = function(string) {\n                    string = unescape(encodeURIComponent(string));\n                    const ret = [];\n                    for (let i = 0; i < string.length; i++) {\n                        ret.push(string.charCodeAt(i));\n                    }\n                    return ret;\n                };\n            },\n            stackAlloc: function(size) {\n                const ret = STACKTOP;\n                STACKTOP = (STACKTOP + size) | 0;\n                STACKTOP = (STACKTOP + 7) & -8;\n                return ret;\n            },\n            staticAlloc: function(size) {\n                const ret = STATICTOP;\n                STATICTOP = (STATICTOP + size) | 0;\n                STATICTOP = (STATICTOP + 7) & -8;\n                return ret;\n            },\n            dynamicAlloc: function(size) {\n                const ret = DYNAMICTOP;\n                DYNAMICTOP = (DYNAMICTOP + size) | 0;\n                DYNAMICTOP = (DYNAMICTOP + 7) & -8;\n\n                if (DYNAMICTOP >= TOTAL_MEMORY) {\n                    abort('Out of memory.');\n                }\n\n                return ret;\n            },\n            alignMemory: function(size, quantum) {\n                const ret = (size =\n                    Math.ceil(size / (quantum ? quantum : 8)) *\n                    (quantum ? quantum : 8));\n                return ret;\n            },\n            makeBigInt: function(low, high, unsigned) {\n                const ret = unsigned\n                    ? +(low >>> 0) + +(high >>> 0) * +4294967296\n                    : +(low >>> 0) + +(high | 0) * +4294967296;\n                return ret;\n            },\n            GLOBAL_BASE: 8,\n            QUANTUM_SIZE: 4\n        };\n\n        /* Initialize the runtime memory */\n\n        // TODO: Allow user to set up how much memory LibTimidity get at initialization\n        // original amount of memory was 67108864\n        const TOTAL_MEMORY = 67108864 * 8;\n        const PAGE_SIZE = 4096;\n\n        let HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;\n        let STATIC_BASE = 0,\n            STATICTOP = 0;\n        let STACK_BASE = 0,\n            STACKTOP = 0,\n            STACK_MAX = 0; // stack area\n        let DYNAMIC_BASE = 0,\n            DYNAMICTOP = 0; // dynamic area handled by sbrk\n\n        assert(\n            typeof Int32Array !== 'undefined' &&\n                typeof Float64Array !== 'undefined' &&\n                !!new Int32Array(1)['subarray'] &&\n                !!new Int32Array(1)['set'],\n            'Typed arrays not supported.'\n        );\n\n        const buffer = new ArrayBuffer(TOTAL_MEMORY);\n        HEAP8 = new Int8Array(buffer);\n        HEAP16 = new Int16Array(buffer);\n        HEAP32 = new Int32Array(buffer);\n        HEAPU8 = new Uint8Array(buffer);\n        HEAPU16 = new Uint16Array(buffer);\n        HEAPU32 = new Uint32Array(buffer);\n        HEAPF32 = new Float32Array(buffer);\n        HEAPF64 = new Float64Array(buffer);\n\n        // Endianness check (note: assumes compiler arch was little-endian)\n        HEAP32[0] = 255;\n        assert(\n            HEAPU8[0] === 255 && HEAPU8[3] === 0,\n            'Typed arrays 2 must be run on a little-endian system'\n        );\n\n        /**\n         * @function alignMemoryPage\n         * @memberof LibTiMidity\n         * @instance\n         * @param {Number} x\n         */\n\n        function alignMemoryPage(x) {\n            return (x + 4095) & -4096;\n        }\n\n        const Module = {};\n        this.Module = Module;\n\n        Module.arguments = arguments;\n\n        if (!Module['arguments']) {\n            Module['arguments'] = [];\n        }\n\n        Module.read = function(url) {\n            const xhr = new XMLHttpRequest();\n            xhr.open('GET', url, false);\n            xhr.send(null);\n            return xhr.responseText;\n        };\n\n        Module.print = function(message) {\n            console.log(message);\n        };\n\n        Module.preRun = [];\n        Module.postRun = [];\n\n        // Whether we are quitting the application. If so, no more code should run.\n        var ABORT = false;\n        let tempI64;\n\n        function ExitStatus(status) {\n            this.name = 'ExitStatus';\n            this.message = 'Program terminated with exit(' + status + ')';\n            this.status = status;\n        }\n\n        ExitStatus.prototype = new Error();\n        ExitStatus.prototype.constructor = ExitStatus;\n\n        /**\n         * Exits the script.\n         * @function exit\n         * @memberof LibTiMidity\n         * @instance\n         * @param {string} status The message to display.\n         */\n\n        function exit(status) {\n            ABORT = true;\n            STACKTOP = initialStackTop;\n            // exit the runtime\n            exitRuntime();\n            throw new ExitStatus(status);\n        }\n\n        Module.exit = exit;\n\n        /**\n         * Throws an error that aborts the execution of the script.\n         * @function abort\n         * @memberof LibTiMidity\n         * @instance\n         * @param {string} text The message to display.\n         */\n\n        function abort(text) {\n            ABORT = true;\n            throw new Error(text).stack;\n        }\n\n        Module.abort = abort;\n\n        /**\n         * Aborts the execution of the script if assertion fails.\n         * @function assert\n         * @memberof LibTiMidity\n         * @instance\n         * @param {boolean} condition The assertion to test.\n         * @param {string} text The message to display if the assertion fails.\n         */\n\n        function assert(condition, text) {\n            if (!condition) {\n                abort(text);\n            }\n        }\n\n        Module.assert = assert;\n\n        /**\n         * A wrapper to call functions.\n         * @function call\n         * @memberof LibTiMidity\n         * @instance\n         * @param {string} ident The name of the function to call.\n         * @param {string} returnType The return type of the function, one of the JS types 'number', 'string' or 'array' (use 'number' for any C pointer, and 'array' for JavaScript arrays and typed arrays; note that arrays are 8-bit).\n         * @param {array} argTypes An array of the types of arguments for the function (if there are no arguments, this can be ommitted). Types are as in returnType, except that 'array' is not possible (there is no way for us to know the length of the array)\n         * @param {array} args An array of the arguments to the function, as native JS values (as in returnType). Note that string arguments will be stored on the stack (the JS string will become a C string on the stack).\n         * @return Native JS value (as in returnType)\n         */\n\n        Module.call = function call(ident, returnType, argTypes, args) {\n            const func = Module['_' + ident];\n            if (!func) {\n                abort(`Unknown function: \"${ident}\".`);\n            }\n\n            let stack = 0;\n            function toC(value, type) {\n                if (type == 'string') {\n                    if (value === null || value === undefined || value === 0)\n                        return 0; // null string\n                    value = intArrayFromString(value);\n                    type = 'array';\n                }\n                if (type == 'array') {\n                    if (!stack) stack = Runtime.stackSave();\n                    const ret = Runtime.stackAlloc(value.length);\n                    writeArrayToMemory(value, ret);\n                    return ret;\n                }\n                return value;\n            }\n\n            function fromC(value, type) {\n                if (type == 'string') {\n                    return Pointer_stringify(value);\n                }\n                assert(type != 'array');\n                return value;\n            }\n\n            let i = 0;\n            const cArgs = args\n                ? args.map(function(arg) {\n                      return toC(arg, argTypes[i++]);\n                  })\n                : [];\n            var ret = fromC(func.apply(null, cArgs), returnType);\n            if (stack) Runtime.stackRestore(stack);\n            return ret;\n        };\n\n        /**\n         * Dynamically sets a value in memory at runtime. Only does *aligned* writes. This is a lower-level operation.\n         * @function setValue\n         * @memberof LibTiMidity\n         * @instance\n         * @param ptr Pointer.\n         * @param value\n         * @param {string} type LLVM type ('i8', , 'i16', 'i32', 'i64', 'float', 'double')\n         */\n        function setValue(ptr, value, type) {\n            type = type || 'i8';\n            if (type.charAt(type.length - 1) === '*') type = 'i32'; // pointers are 32-bit\n            switch (type) {\n                case 'i1':\n                    HEAP8[ptr] = value;\n                    break;\n                case 'i8':\n                    HEAP8[ptr] = value;\n                    break;\n                case 'i16':\n                    HEAP16[ptr >> 1] = value;\n                    break;\n                case 'i32':\n                    HEAP32[ptr >> 2] = value;\n                    break;\n                case 'i64':\n                    (tempI64 = [\n                        value >>> 0,\n                        ((tempDouble = value),\n                        +Math_abs(tempDouble) >= +1\n                            ? tempDouble > +0\n                                ? (Math_min(\n                                      +Math_floor(tempDouble / +4294967296),\n                                      +4294967295\n                                  ) |\n                                      0) >>>\n                                  0\n                                : ~~+Math_ceil(\n                                      (tempDouble - +(~~tempDouble >>> 0)) /\n                                          +4294967296\n                                  ) >>> 0\n                            : 0)\n                    ]),\n                        (HEAP32[ptr >> 2] = tempI64[0]),\n                        (HEAP32[(ptr + 4) >> 2] = tempI64[1]);\n                    break;\n                case 'float':\n                    HEAPF32[ptr >> 2] = value;\n                    break;\n                case 'double':\n                    HEAPF64[ptr >> 3] = value;\n                    break;\n                default:\n                    abort('invalid type for setValue: ' + type);\n            }\n        }\n        Module.setValue = setValue;\n\n        /**\n         * Dynamically gets a value in memory at runtime. Only does *aligned* reads. This is a lower-level operation.\n         * @function getValue\n         * @memberof LibTiMidity\n         * @instance\n         * @param ptr Pointer.\n         * @param {string} type LLVM type ('i8', , 'i16', 'i32', 'i64', 'float', 'double')\n         */\n        function getValue(ptr, type) {\n            type = type || 'i8';\n            if (type.charAt(type.length - 1) === '*') type = 'i32'; // pointers are 32-bit\n            switch (type) {\n                case 'i1':\n                    return HEAP8[ptr];\n                case 'i8':\n                    return HEAP8[ptr];\n                case 'i16':\n                    return HEAP16[ptr >> 1];\n                case 'i32':\n                    return HEAP32[ptr >> 2];\n                case 'i64':\n                    return HEAP32[ptr >> 2];\n                case 'float':\n                    return HEAPF32[ptr >> 2];\n                case 'double':\n                    return HEAPF64[ptr >> 3];\n                default:\n                    abort('invalid type for getValue: ' + type);\n            }\n            return null;\n        }\n\n        Module['getValue'] = getValue;\n\n        const ALLOC_NORMAL = 0; // Tries to use _malloc()\n        const ALLOC_STACK = 1; // Lives for the duration of the current function call\n        const ALLOC_STATIC = 2; // Cannot be freed\n        const ALLOC_DYNAMIC = 3; // Cannot be freed except through sbrk\n        const ALLOC_NONE = 4; // Do not allocate\n        Module['ALLOC_NORMAL'] = ALLOC_NORMAL;\n        Module['ALLOC_STACK'] = ALLOC_STACK;\n        Module['ALLOC_STATIC'] = ALLOC_STATIC;\n        Module['ALLOC_DYNAMIC'] = ALLOC_DYNAMIC;\n        Module['ALLOC_NONE'] = ALLOC_NONE;\n\n        /**\n         * This is for internal use. Optimized for multiple syntaxes to save space in generated code. You should allocate memory using _malloc(), initialize it with setValue(), and so forth.\n         * @function allocate\n         * @memberof LibTiMidity\n         * @instance\n         * @param slab An array of data or a number. If a number, then the size of the block to allocate in *bytes* (note that this is sometimes confusing: the next parameter does not affect this).\n         * @param types Either an array of types, one for each byte (or 0 if no type at that position), or a single type which is used for the entire block. This only matters if there is initial data. If slab is a number, then this does not matter at all and is ignored.\n         * @param allocator How to allocate memory, see ALLOC_*\n         */\n\n        function allocate(slab, types, allocator, ptr) {\n            let zeroinit, size;\n            if (typeof slab === 'number') {\n                zeroinit = true;\n                size = slab;\n            } else {\n                zeroinit = false;\n                size = slab.length;\n            }\n            const singleType = typeof types === 'string' ? types : null;\n            let ret;\n            if (allocator == ALLOC_NONE) {\n                ret = ptr;\n            } else {\n                ret = [\n                    _malloc,\n                    Runtime.stackAlloc,\n                    Runtime.staticAlloc,\n                    Runtime.dynamicAlloc\n                ][allocator === undefined ? ALLOC_STATIC : allocator](\n                    Math.max(size, singleType ? 1 : types.length)\n                );\n            }\n            if (zeroinit) {\n                var ptr = ret,\n                    stop;\n                assert((ret & 3) == 0);\n                stop = ret + (size & ~3);\n                for (; ptr < stop; ptr += 4) {\n                    HEAP32[ptr >> 2] = 0;\n                }\n                stop = ret + size;\n                while (ptr < stop) {\n                    HEAP8[ptr++ | 0] = 0;\n                }\n                return ret;\n            }\n            if (singleType === 'i8') {\n                if (slab.subarray || slab.slice) {\n                    HEAPU8.set(slab, ret);\n                } else {\n                    HEAPU8.set(new Uint8Array(slab), ret);\n                }\n                return ret;\n            }\n            let i = 0,\n                type,\n                typeSize,\n                previousType;\n            while (i < size) {\n                let curr = slab[i];\n                if (typeof curr === 'function') {\n                    curr = Runtime.getFunctionIndex(curr);\n                }\n                type = singleType || types[i];\n                if (type === 0) {\n                    i++;\n                    continue;\n                }\n                if (type == 'i64') type = 'i32'; // special case: we have one i32 here, and one i32 later\n                setValue(ret + i, curr, type);\n                // no need to look up size unless type changes, so cache it\n                if (previousType !== type) {\n                    typeSize = Runtime.getNativeTypeSize(type);\n                    previousType = type;\n                }\n                i += typeSize;\n            }\n            return ret;\n        }\n\n        Module['allocate'] = allocate;\n\n        /**\n         * @function Pointer_stringify\n         * @memberof LibTiMidity\n         * @instance\n         * @param ptr Pointer.\n         * @param {*} [length]\n         */\n\n        function Pointer_stringify(ptr, length) {\n            // TODO: use TextDecoder\n            // Find the length, and check for UTF while doing so\n            let hasUtf = false;\n            let t;\n            let i = 0;\n            while (1) {\n                t = HEAPU8[(ptr + i) | 0];\n                if (t >= 128) hasUtf = true;\n                else if (t == 0 && !length) break;\n                i++;\n                if (length && i == length) break;\n            }\n            if (!length) length = i;\n            let ret = '';\n            if (!hasUtf) {\n                const MAX_CHUNK = 1024; // split up into chunks, because .apply on a huge string can overflow the stack\n                let curr;\n                while (length > 0) {\n                    curr = String.fromCharCode.apply(\n                        String,\n                        HEAPU8.subarray(ptr, ptr + Math.min(length, MAX_CHUNK))\n                    );\n                    ret = ret ? ret + curr : curr;\n                    ptr += MAX_CHUNK;\n                    length -= MAX_CHUNK;\n                }\n                return ret;\n            }\n            const utf8 = new Runtime.UTF8Processor();\n            for (i = 0; i < length; i++) {\n                t = HEAPU8[(ptr + i) | 0];\n                ret += utf8.processCChar(t);\n            }\n            return ret;\n        }\n\n        Module['Pointer_stringify'] = Pointer_stringify;\n\n        /**\n         * @function UTF16ToString\n         * @memberof LibTiMidity\n         * @instance\n         * @param ptr Pointer to a null-terminated UTF16LE-encoded string in the emscripten HEAP.\n         */\n\n        function UTF16ToString(ptr) {\n            let i = 0;\n            let str = '';\n            while (1) {\n                const codeUnit = HEAP16[(ptr + i * 2) >> 1];\n                if (codeUnit == 0) return str;\n                ++i;\n                // fromCharCode constructs a character from a UTF-16 code unit, so we can pass the UTF16 string right through.\n                str += String.fromCharCode(codeUnit);\n            }\n        }\n\n        Module['UTF16ToString'] = UTF16ToString;\n\n        /**\n         * Copies a JavaScript string to the emscripten HEAP. The copy is null-terminated and encoded in UTF16LE form. The copy will require at most (str.length*2+1)*2 bytes of space in the HEAP.\n         * @function stringToUTF16\n         * @memberof LibTiMidity\n         * @instance\n         * @param {string} str JavaScript string.\n         * @param outPtr HEAP address (pointer).\n         */\n\n        function stringToUTF16(str, outPtr) {\n            for (let i = 0; i < str.length; ++i) {\n                // charCodeAt returns a UTF-16 encoded code unit, so it can be directly written to the HEAP.\n                const codeUnit = str.charCodeAt(i); // possibly a lead surrogate\n                HEAP16[(outPtr + i * 2) >> 1] = codeUnit;\n            }\n            // Null-terminate the pointer to the HEAP.\n            HEAP16[(outPtr + str.length * 2) >> 1] = 0;\n        }\n\n        Module['stringToUTF16'] = stringToUTF16;\n\n        /**\n         * @function UTF32ToString\n         * @memberof LibTiMidity\n         * @instance\n         * @param ptr Pointer to a null-terminated UTF32LE-encoded string in the emscripten HEAP.\n         * @return\n         */\n\n        function UTF32ToString(ptr) {\n            let i = 0;\n            let str = '';\n            while (1) {\n                const utf32 = HEAP32[(ptr + i * 4) >> 2];\n                if (utf32 == 0) return str;\n                ++i;\n                // Gotcha: fromCharCode constructs a character from a UTF-16 encoded code (pair), not from a Unicode code point! So encode the code point to UTF-16 for constructing.\n                if (utf32 >= 0x10000) {\n                    const ch = utf32 - 0x10000;\n                    str += String.fromCharCode(\n                        0xd800 | (ch >> 10),\n                        0xdc00 | (ch & 0x3ff)\n                    );\n                } else {\n                    str += String.fromCharCode(utf32);\n                }\n            }\n        }\n\n        Module['UTF32ToString'] = UTF32ToString;\n\n        /**\n         * Copies a JavaScript string to the emscripten HEAP. The copy is null-terminated and encoded in UTF32LE form. The copy will require at most (str.length+1)*4 bytes of space in the HEAP.\n         * @function stringToUTF32\n         * @memberof LibTiMidity\n         * @instance\n         * @param {string} str JavaScript string.\n         * @param outPtr HEAP address (pointer).\n         */\n\n        function stringToUTF32(str, outPtr) {\n            let iChar = 0;\n            for (let iCodeUnit = 0; iCodeUnit < str.length; ++iCodeUnit) {\n                // Gotcha: charCodeAt returns a 16-bit word that is a UTF-16 encoded code unit, not a Unicode code point of the character! We must decode the string to UTF-32 to the heap.\n                let codeUnit = str.charCodeAt(iCodeUnit); // possibly a lead surrogate\n                if (codeUnit >= 0xd800 && codeUnit <= 0xdfff) {\n                    const trailSurrogate = str.charCodeAt(++iCodeUnit);\n                    codeUnit =\n                        (0x10000 + ((codeUnit & 0x3ff) << 10)) |\n                        (trailSurrogate & 0x3ff);\n                }\n                HEAP32[(outPtr + iChar * 4) >> 2] = codeUnit;\n                ++iChar;\n            }\n            // Null-terminate the pointer to the HEAP.\n            HEAP32[(outPtr + iChar * 4) >> 2] = 0;\n        }\n\n        Module['stringToUTF32'] = stringToUTF32;\n\n        /**\n         * @function callRuntimeCallbacks\n         * @memberof LibTiMidity\n         * @instance\n         * @param callbacks\n         */\n\n        function callRuntimeCallbacks(callbacks) {\n            while (callbacks.length > 0) {\n                const callback = callbacks.shift();\n                if (typeof callback == 'function') {\n                    callback();\n                    continue;\n                }\n                const func = callback.func;\n                if (typeof func === 'number') {\n                    if (callback.arg === undefined) {\n                        Runtime.dynCall('v', func);\n                    } else {\n                        Runtime.dynCall('vi', func, [callback.arg]);\n                    }\n                } else {\n                    func(callback.arg === undefined ? null : callback.arg);\n                }\n            }\n        }\n\n        var __ATPRERUN__ = []; // functions called before the runtime is initialized\n        const __ATINIT__ = []; // functions called during startup\n        const __ATMAIN__ = []; // functions called when main() is to be run\n        var __ATEXIT__ = []; // functions called during shutdown\n        var __ATPOSTRUN__ = []; // functions called after the runtime has exited\n        let runtimeInitialized = false;\n\n        function preRun() {\n            // compatibility - merge in anything from Module['preRun'] at this time\n            if (Module['preRun']) {\n                if (typeof Module['preRun'] == 'function')\n                    Module['preRun'] = [Module['preRun']];\n                while (Module['preRun'].length) {\n                    addOnPreRun(Module['preRun'].shift());\n                }\n            }\n            callRuntimeCallbacks(__ATPRERUN__);\n        }\n\n        function ensureInitRuntime() {\n            if (runtimeInitialized) return;\n            runtimeInitialized = true;\n            callRuntimeCallbacks(__ATINIT__);\n        }\n\n        function preMain() {\n            callRuntimeCallbacks(__ATMAIN__);\n        }\n\n        function exitRuntime() {\n            callRuntimeCallbacks(__ATEXIT__);\n        }\n\n        function postRun() {\n            // compatibility - merge in anything from Module['postRun'] at this time\n            if (Module['postRun']) {\n                if (typeof Module['postRun'] == 'function')\n                    Module['postRun'] = [Module['postRun']];\n                while (Module['postRun'].length) {\n                    addOnPostRun(Module['postRun'].shift());\n                }\n            }\n            callRuntimeCallbacks(__ATPOSTRUN__);\n        }\n\n        /**\n         * @function addOnPreRun\n         * @memberof LibTiMidity\n         * @instance\n         * @param cb Callback.\n         */\n\n        function addOnPreRun(cb) {\n            __ATPRERUN__.unshift(cb);\n        }\n\n        Module['addOnPreRun'] = Module.addOnPreRun = addOnPreRun;\n\n        /**\n         * @function addOnInit\n         * @memberof LibTiMidity\n         * @instance\n         * @param cb Callback.\n         */\n\n        function addOnInit(cb) {\n            __ATINIT__.unshift(cb);\n        }\n\n        Module['addOnInit'] = addOnInit;\n\n        /**\n         * @function addOnPreMain\n         * @memberof LibTiMidity\n         * @instance\n         * @param cb Callback.\n         */\n\n        function addOnPreMain(cb) {\n            __ATMAIN__.unshift(cb);\n        }\n\n        Module['addOnPreMain'] = addOnPreMain;\n\n        /**\n         * @function addOnExit\n         * @memberof LibTiMidity\n         * @instance\n         * @param cb Callback.\n         */\n\n        function addOnExit(cb) {\n            __ATEXIT__.unshift(cb);\n        }\n\n        Module['addOnExit'] = addOnExit;\n\n        /**\n         * @function addOnPostRun\n         * @memberof LibTiMidity\n         * @instance\n         * @param cb Callback.\n         */\n\n        function addOnPostRun(cb) {\n            __ATPOSTRUN__.unshift(cb);\n        }\n\n        Module['addOnPostRun'] = addOnPostRun;\n\n        /**\n         * @function intArrayFromString\n         * @memberof LibTiMidity\n         * @instance\n         * @param stringy\n         * @param dontAddNull\n         * @param length\n         */\n\n        // Tools\n        // This processes a JS string into a C-line array of numbers, 0-terminated.\n        // For LLVM-originating strings, see parser.js:parseLLVMString function\n        function intArrayFromString(\n            stringy,\n            dontAddNull,\n            length /* optional */\n        ) {\n            const ret = new Runtime.UTF8Processor().processJSString(stringy);\n            if (length) {\n                ret.length = length;\n            }\n            if (!dontAddNull) {\n                ret.push(0);\n            }\n            return ret;\n        }\n\n        Module['intArrayFromString'] = intArrayFromString;\n\n        /**\n         * @function intArrayToString\n         * @memberof LibTiMidity\n         * @instance\n         * @param array\n         */\n\n        function intArrayToString(array) {\n            const ret = [];\n            for (let i = 0; i < array.length; i++) {\n                let chr = array[i];\n                if (chr > 0xff) {\n                    chr &= 0xff;\n                }\n                ret.push(String.fromCharCode(chr));\n            }\n            return ret.join('');\n        }\n\n        Module['intArrayToString'] = intArrayToString;\n\n        /**\n         * @function writeStringToMemory\n         * @memberof LibTiMidity\n         * @instance\n         * @param string\n         * @param buffer\n         * @param dontAddNull\n         */\n\n        // Write a Javascript array to somewhere in the heap\n        function writeStringToMemory(string, buffer, dontAddNull) {\n            const array = intArrayFromString(string, dontAddNull);\n            let i = 0;\n            while (i < array.length) {\n                const chr = array[i];\n                HEAP8[(buffer + i) | 0] = chr;\n                i = i + 1;\n            }\n        }\n\n        Module['writeStringToMemory'] = writeStringToMemory;\n\n        /**\n         * @function writeArrayToMemory\n         * @memberof LibTiMidity\n         * @instance\n         * @param array\n         * @param buffer\n         */\n\n        function writeArrayToMemory(array, buffer) {\n            for (let i = 0; i < array.length; i++) {\n                HEAP8[(buffer + i) | 0] = array[i];\n            }\n        }\n\n        Module['writeArrayToMemory'] = writeArrayToMemory;\n\n        /**\n         * @function writeAsciiToMemory\n         * @memberof LibTiMidity\n         * @instance\n         * @param str\n         * @param buffer\n         * @param dontAddNull\n         */\n\n        function writeAsciiToMemory(str, buffer, dontAddNull) {\n            for (let i = 0; i < str.length; i++) {\n                HEAP8[(buffer + i) | 0] = str.charCodeAt(i);\n            }\n            if (!dontAddNull) HEAP8[(buffer + str.length) | 0] = 0;\n        }\n\n        Module['writeAsciiToMemory'] = writeAsciiToMemory;\n\n        function unSign(value, bits, ignore, sig) {\n            if (value >= 0) {\n                return value;\n            }\n            return bits <= 32\n                ? 2 * Math.abs(1 << (bits - 1)) + value // Need some trickery, since if bits == 32, we are right at the limit of the bits JS uses in bitshifts\n                : Math.pow(2, bits) + value;\n        }\n\n        function reSign(value, bits) {\n            if (value <= 0) {\n                return value;\n            }\n            const half =\n                bits <= 32\n                    ? Math.abs(1 << (bits - 1)) // abs is needed if bits == 32\n                    : Math.pow(2, bits - 1);\n            if (value >= half && (bits <= 32 || value > half)) {\n                // for huge values, we can hit the precision limit and always get true here. so don't do that\n                // but, in general there is no perfect solution here. With 64-bit ints, we get rounding and errors\n                // TODO: In i64 mode 1, resign the two parts separately and safely\n                value = -2 * half + value; // Cannot bitshift half, as it may be at the limit of the bits JS uses in bitshifts\n            }\n            return value;\n        }\n\n        if (!Math['imul'])\n            Math['imul'] = function(a, b) {\n                const ah = a >>> 16;\n                const al = a & 0xffff;\n                const bh = b >>> 16;\n                const bl = b & 0xffff;\n                return (al * bl + ((ah * bl + al * bh) << 16)) | 0;\n            };\n\n        Math.imul = Math['imul'];\n\n        var Math_abs = Math.abs;\n        const Math_sin = Math.sin;\n        var Math_ceil = Math.ceil;\n        var Math_floor = Math.floor;\n        const Math_pow = Math.pow;\n        var Math_min = Math.min;\n\n        // A counter of dependencies for calling run(). If we need to\n        // do asynchronous work before running, increment this and\n        // decrement it. Incrementing must happen in a place like\n        // PRE_RUN_ADDITIONS (used by emcc to add file preloading).\n        // Note that you can add dependencies in preRun, even though\n        // it happens right before run - run will be postponed until\n        // the dependencies are met.\n        let runDependencies = 0;\n        const runDependencyTracking = {};\n        let runDependencyWatcher = null;\n        let dependenciesFulfilled = null; // overridden to take different actions when all run dependencies are fulfilled\n\n        /**\n         * @function addRunDependency\n         * @memberof LibTiMidity\n         * @instance\n         * @param id\n         */\n\n        function addRunDependency(id) {\n            runDependencies++;\n            if (Module['monitorRunDependencies']) {\n                Module['monitorRunDependencies'](runDependencies);\n            }\n            if (id) {\n                assert(!runDependencyTracking[id]);\n                runDependencyTracking[id] = 1;\n            } else {\n                console.warn('warning: run dependency added without ID');\n            }\n        }\n\n        Module['addRunDependency'] = addRunDependency;\n\n        /**\n         * @function removeRunDependency\n         * @memberof LibTiMidity\n         * @instance\n         * @param id\n         */\n\n        function removeRunDependency(id) {\n            runDependencies--;\n            if (Module['monitorRunDependencies']) {\n                Module['monitorRunDependencies'](runDependencies);\n            }\n            if (id) {\n                assert(runDependencyTracking[id]);\n                delete runDependencyTracking[id];\n            } else {\n                console.warn('warning: run dependency removed without ID');\n            }\n            if (runDependencies == 0) {\n                if (runDependencyWatcher !== null) {\n                    clearInterval(runDependencyWatcher);\n                    runDependencyWatcher = null;\n                }\n                if (dependenciesFulfilled) {\n                    const callback = dependenciesFulfilled;\n                    dependenciesFulfilled = null;\n                    callback(); // can add another dependenciesFulfilled\n                }\n            }\n        }\n\n        Module['removeRunDependency'] = removeRunDependency;\n\n        const memoryInitializer = null;\n        // === Body ===\n        STATIC_BASE = 8;\n        STATICTOP = STATIC_BASE + 8448;\n        /* global initializers */ __ATINIT__.push({\n            func: function() {\n                runPostSets();\n            }\n        });\n        var _stderr;\n        var _stderr = (_stderr = allocate(\n            [0, 0, 0, 0, 0, 0, 0, 0],\n            'i8',\n            ALLOC_STATIC\n        ));\n        /* memory initializer */\n        // prettier-ignore\n        allocate([0,0,0,0,0,0,144,63,75,191,53,65,90,136,144,63,241,46,189,130,62,21,145,63,249,198,51,115,211,166,145,63,194,109,221,10,65,61,146,63,61,194,157,150,176,216,146,63,232,234,78,195,76,121,147,63,204,6,121,169,65,31,148,63,172,119,109,217,188,202,148,63,136,88,201,103,237,123,149,63,154,143,98,250,3,51,150,63,89,8,163,213,50,240,150,63,69,192,85,234,173,179,151,63,98,112,233,227,170,125,152,63,242,189,44,55,97,78,153,63,189,253,135,49,10,38,154,63,84,184,184,8,225,4,155,63,232,64,19,235,34,235,155,63,101,213,78,16,15,217,156,63,82,228,224,202,230,206,157,63,110,60,236,153,237,204,158,63,149,18,201,59,105,211,159,63,39,122,149,224,80,113,160,63,129,244,116,208,112,253,160,63,39,24,58,230,58,142,161,63,74,29,119,226,214,35,162,63,50,84,131,216,109,190,162,63,137,39,194,57,42,94,163,63,195,57,74,225,55,3,164,63,225,208,239,31,196,173,164,63,141,222,181,200,253,93,165,63,62,15,169,61,21,20,166,63,223,103,40,125,60,208,166,63,155,23,159,47,167,146,167,63,148,66,179,181,138,91,168,63,80,170,237,54,30,43,169,63,237,57,222,176,154,1,170,63,104,158,193,6,59,223,170,63,182,54,172,17,60,196,171,63,248,203,62,177,220,176,172,63,49,168,233,220,93,165,173,63,115,200,194,181,2,162,174,63,108,16,244,152,16,167,175,63,78,71,99,153,103,90,176,63,213,5,40,73,196,229,176,63,17,38,228,158,196,117,177,63,185,204,197,35,144,10,178,63,128,43,232,177,79,164,178,63,152,204,138,127,45,67,179,63,121,115,168,42,85,231,179,63,129,193,240,196,243,144,180,63,19,232,39,224,55,64,181,63,242,205,239,154,81,245,181,63,121,42,254,173,114,176,182,63,62,55,195,121,206,113,183,63,150,183,132,20,154,57,184,63,124,53,241,88,12,8,185,63,40,116,47,245,93,221,185,63,234,58,110,122,201,185,186,63,0,190,248,108,139,157,187,63,185,15,212,84,226,136,188,63,119,41,234,206,14,124,189,63,90,67,199,158,83,119,190,63,113,89,238,192,245,122,191,63,90,243,228,62,158,67,192,63,134,4,159,190,56,206,192,63,250,182,112,109,112,93,193,63,134,74,113,157,108,241,193,63,158,146,207,239,85,138,194,63,241,160,249,95,86,40,195,63,53,128,35,79,153,203,195,63,8,41,48,144,75,116,196,63,52,246,255,115,155,34,197,63,60,249,39,214,184,214,197,63,231,172,21,42,213,144,198,63,103,161,162,136,35,81,199,63,64,220,27,190,216,23,200,63,253,197,192,88,43,229,200,63,169,160,189,183,83,185,201,63,151,163,165,26,140,148,202,63,112,252,112,177,16,119,203,63,132,25,3,173,31,97,204,63,196,198,61,80,249,82,205,63,129,205,165,1,224,76,206,63,12,239,157,93,24,79,207,63,179,157,158,164,244,44,208,63,24,248,226,2,206,182,208,63,221,27,97,34,62,69,209,63,241,38,102,30,108,216,209,63,184,223,131,95,128,112,210,63,143,212,168,166,164,13,211,63,246,6,151,24,4,176,211,63,25,72,188,73,203,87,212,63,38,135,111,74,40,5,213,63,234,109,150,179,74,184,213,63,94,196,182,179,99,113,214,63,191,49,119,28,166,48,215,63,64,16,147,112,70,246,215,63,245,39,69,242,122,194,216,63,68,70,45,178,123,149,217,63,234,200,180,158,130,111,218,63,100,86,246,147,203,80,219,63,204,33,45,108,148,57,220,63,17,61,176,16,29,42,221,63,59,163,126,139,167,34,222,63,13,204,96,25,120,35,223,63,161,97,82,158,106,22,224,63,42,244,60,232,131,159,224,63,162,211,120,142,45,45,225,63,38,84,213,117,142,191,225,63,187,17,150,206,206,86,226,63,84,154,123,31,24,243,226,63,218,31,42,81,149,148,227,63,89,83,241,185,114,59,228,63,111,165,248,41,222,231,228,63,145,67,211,247,6,154,229,63,32,70,127,13,30,82,230,63,216,160,211,245,85,16,231,63,137,133,96,234,226,212,231,63,76,8,198,225,250,159,232,63,27,245,132,158,213,113,233,63,9,232,77,190,172,74,234,63,44,220,210,201,187,42,235,63,254,136,31,69,64,18,236,63,11,11,125,192,121,1,237,63,244,122,229,233,169,248,237,63,130,61,12,159,20,248,238,63,0,0,0,0,0,0,240,63,0,0,128,63,0,0,0,0,0,0,220,67,0,0,0,0,168,25,0,0,0,0,0,0,240,31,0,0,214,33,0,0,217,35,0,0,251,37,0,0,61,40,0,0,161,42,0,0,42,45,0,0,218,47,0,0,178,50,0,0,182,53,0,0,232,56,0,0,74,60,0,0,224,63,0,0,172,67,0,0,178,71,0,0,245,75,0,0,122,80,0,0,67,85,0,0,85,90,0,0,180,95,0,0,101,101,0,0,108,107,0,0,207,113,0,0,148,120,0,0,191,127,0,0,88,135,0,0,100,143,0,0,235,151,0,0,243,160,0,0,134,170,0,0,169,180,0,0,103,191,0,0,201,202,0,0,216,214,0,0,158,227,0,0,39,241,0,0,126,255,0,0,176,14,1,0,200,30,1,0,214,47,1,0,231,65,1,0,11,85,1,0,83,105,1,0,207,126,1,0,146,149,1,0,176,173,1,0,61,199,1,0,79,226,1,0,253,254,1,0,95,29,2,0,144,61,2,0,171,95,2,0,206,131,2,0,22,170,2,0,165,210,2,0,158,253,2,0,36,43,3,0,96,91,3,0,122,142,3,0,158,196,3,0,250,253,3,0,191,58,4,0,33,123,4,0,87,191,4,0,156,7,5,0,44,84,5,0,74,165,5,0,59,251,5,0,73,86,6,0,192,182,6,0,244,28,7,0,59,137,7,0,243,251,7,0,125,117,8,0,66,246,8,0,174,126,9,0,55,15,10,0,88,168,10,0,149,74,11,0,119,246,11,0,145,172,12,0,128,109,13,0,232,57,14,0,119,18,15,0,230,247,15,0,251,234,16,0,131,236,17,0,92,253,18,0,110,30,20,0,177,80,21,0,42,149,22,0,238,236,23,0,35,89,25,0,0,219,26,0,207,115,28,0,237,36,30,0,205,239,31,0,245,213,33,0,6,217,35,0,184,250,37,0,220,60,40,0,98,161,42,0,83,42,45,0,219,217,47,0,70,178,50,0,0,182,53,0,158,231,56,0,218,73,60,0,153,223,63,0,234,171,67,0,12,178,71,0,112,245,75,0,185,121,80,0,196,66,85,0,167,84,90,0,183,179,95,0,139,100,101,0,0,108,107,0,60,207,113,0,181,147,120,0,50,191,127,0,212,87,135,0,25,100,143,0,223,234,151,0,114,243,160,0,135,133,170,0,78,169,180,0,110,103,191,0,32,161,7,0,0,0,0,0,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,0,0,128,63,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,240,63,113,93,245,158,236,0,240,63,84,18,150,75,217,1,240,63,207,232,226,5,198,2,240,63,21,171,220,205,178,3,240,63,102,35,132,163,159,4,240,63,10,28,218,134,140,5,240,63,88,95,223,119,121,6,240,63,177,183,148,118,102,7,240,63,131,239,250,130,83,8,240,63,70,209,18,157,64,9,240,63,127,39,221,196,45,10,240,63,191,188,90,250,26,11,240,63,160,91,140,61,8,12,240,63,204,206,114,142,245,12,240,63,245,224,14,237,226,13,240,63,218,92,97,89,208,14,240,63,71,13,107,211,189,15,240,63,17,189,44,91,171,16,240,63,28,55,167,240,152,17,240,63,85,70,219,147,134,18,240,63,181,181,201,68,116,19,240,63,66,80,115,3,98,20,240,63,14,225,216,207,79,21,240,63,53,51,251,169,61,22,240,63,224,17,219,145,43,23,240,63,68,72,121,135,25,24,240,63,159,161,214,138,7,25,240,63,63,233,243,155,245,25,240,63,122,234,209,186,227,26,240,63,180,112,113,231,209,27,240,63,93,71,211,33,192,28,240,63,238,57,248,105,174,29,240,63,239,19,225,191,156,30,240,63,242,160,142,35,139,31,240,63,148,172,1,149,121,32,240,63,129,2,59,20,104,33,240,63,109,110,59,161,86,34,240,63,26,188,3,60,69,35,240,63,85,183,148,228,51,36,240,63,247,43,239,154,34,37,240,63,228,229,19,95,17,38,240,63,14,177,3,49,0,39,240,63,112,89,191,16,239,39,240,63,19,171,71,254,221,40,240,63,10,114,157,249,204,41,240,63,117,122,193,2,188,42,240,63,128,144,180,25,171,43,240,63,97,128,119,62,154,44,240,63,92,22,11,113,137,45,240,63,191,30,112,177,120,46,240,63,230,101,167,255,103,47,240,63,54,184,177,91,87,48,240,63,34,226,143,197,70,49,240,63,39,176,66,61,54,50,240,63,209,238,202,194,37,51,240,63,180,106,41,86,21,52,240,63,113,240,94,247,4,53,240,63,183,76,108,166,244,53,240,63,63,76,82,99,228,54,240,63,204,187,17,46,212,55,240,63,49,104,171,6,196,56,240,63,73,30,32,237,179,57,240,63,254,170,112,225,163,58,240,63,67,219,157,227,147,59,240,63,24,124,168,243,131,60,240,63,138,90,145,17,116,61,240,63,177,67,89,61,100,62,240,63,176,4,1,119,84,63,240,63,182,106,137,190,68,64,240,63,0,67,243,19,53,65,240,63,212,90,63,119,37,66,240,63,133,127,110,232,21,67,240,63,114,126,129,103,6,68,240,63,7,37,121,244,246,68,240,63,185,64,86,143,231,69,240,63,12,159,25,56,216,70,240,63,141,13,196,238,200,71,240,63,216,89,86,179,185,72,240,63,146,81,209,133,170,73,240,63,109,194,53,102,155,74,240,63,40,122,132,84,140,75,240,63,140,70,190,80,125,76,240,63,110,245,227,90,110,77,240,63,177,84,246,114,95,78,240,63,66,50,246,152,80,79,240,63,26,92,228,204,65,80,240,63,63,160,193,14,51,81,240,63,194,204,142,94,36,82,240,63,192,175,76,188,21,83,240,63,98,23,252,39,7,84,240,63,220,209,157,161,248,84,240,63,112,173,50,41,234,85,240,63,107,120,187,190,219,86,240,63,37,1,57,98,205,87,240,63,2,22,172,19,191,88,240,63,116,133,21,211,176,89,240,63,247,29,118,160,162,90,240,63,18,174,206,123,148,91,240,63,91,4,32,101,134,92,240,63,113,239,106,92,120,93,240,63,1,62,176,97,106,94,240,63,194,190,240,116,92,95,240,63,122,64,45,150,78,96,240,63,247,145,102,197,64,97,240,63,22,130,157,2,51,98,240,63,191,223,210,77,37,99,240,63,229,121,7,167,23,100,240,63,137,31,60,14,10,101,240,63,181,159,113,131,252,101,240,63,130,201,168,6,239,102,240,63,20,108,226,151,225,103,240,63,154,86,31,55,212,104,240,63,79,88,96,228,198,105,240,63,124,64,166,159,185,106,240,63,115,222,241,104,172,107,240,63,149,1,68,64,159,108,240,63,77,121,157,37,146,109,240,63,18,21,255,24,133,110,240,63,104,164,105,26,120,111,240,63,222,246,221,41,107,112,240,63,16,220,92,71,94,113,240,63,165,35,231,114,81,114,240,63,81,157,125,172,68,115,240,63,211,24,33,244,55,116,240,63,246,101,210,73,43,117,240,63,147,84,146,173,30,118,240,63,140,180,97,31,18,119,240,63,209,85,65,159,5,120,240,63,93,8,50,45,249,120,240,63,57,156,52,201,236,121,240,63,118,225,73,115,224,122,240,63,54,168,114,43,212,123,240,63,163,192,175,241,199,124,240,63,246,250,1,198,187,125,240,63,113,39,106,168,175,126,240,63,101,22,233,152,163,127,240,63,44,152,127,151,151,128,240,63,48,125,46,164,139,129,240,63,226,149,246,190,127,130,240,63,197,178,216,231,115,131,240,63,98,164,213,30,104,132,240,63,82,59,238,99,92,133,240,63,58,72,35,183,80,134,240,63,200,155,117,24,69,135,240,63,185,6,230,135,57,136,240,63,214,89,117,5,46,137,240,63,242,101,36,145,34,138,240,63,237,251,243,42,23,139,240,63,180,236,228,210,11,140,240,63,63,9,248,136,0,141,240,63,147,34,46,77,245,141,240,63,192,9,136,31,234,142,240,63,226,143,6,0,223,143,240,63,35,134,170,238,211,144,240,63,184,189,116,235,200,145,240,63,224,7,102,246,189,146,240,63,233,53,127,15,179,147,240,63,44,25,193,54,168,148,240,63,13,131,44,108,157,149,240,63,0,69,194,175,146,150,240,63,127,48,131,1,136,151,240,63,22,23,112,97,125,152,240,63,89,202,137,207,114,153,240,63,234,27,209,75,104,154,240,63,119,221,70,214,93,155,240,63,185,224,235,110,83,156,240,63,119,247,192,21,73,157,240,63,131,243,198,202,62,158,240,63,187,166,254,141,52,159,240,63,9,227,104,95,42,160,240,63,99,122,6,63,32,161,240,63,205,62,216,44,22,162,240,63,85,2,223,40,12,163,240,63,21,151,27,51,2,164,240,63,53,207,142,75,248,164,240,63,233,124,57,114,238,165,240,63,110,114,28,167,228,166,240,63,17,130,56,234,218,167,240,63,40,126,142,59,209,168,240,63,25,57,31,155,199,169,240,63,83,133,235,8,190,170,240,63,81,53,244,132,180,171,240,63,156,27,58,15,171,172,240,63,200,10,190,167,161,173,240,63,118,213,128,78,152,174,240,63,82,78,131,3,143,175,240,63,22,72,198,198,133,176,240,63,134,149,74,152,124,177,240,63,116,9,17,120,115,178,240,63,188,118,26,102,106,179,240,63,73,176,103,98,97,180,240,63,15,137,249,108,88,181,240,63,18,212,208,133,79,182,240,63,95,100,238,172,70,183,240,63,17,13,83,226,61,184,240,63,78,161,255,37,53,185,240,63,72,244,244,119,44,186,240,63,63,217,51,216,35,187,240,63,125,35,189,70,27,188,240,63,91,166,145,195,18,189,240,63,59,53,178,78,10,190,240,63,142,163,31,232,1,191,240,63,206,196,218,143,249,191,240,63,133,108,228,69,241,192,240,63,71,110,61,10,233,193,240,63,180,157,230,220,224,194,240,63,122,206,224,189,216,195,240,63,80,212,44,173,208,196,240,63,253,130,203,170,200,197,240,63,83,174,189,182,192,198,240,63,46,42,4,209,184,199,240,63,121,202,159,249,176,200,240,63,42,99,145,48,169,201,240,63,67,200,217,117,161,202,240,63,212,205,121,201,153,203,240,63,247,71,114,43,146,204,240,63,212,10,196,155,138,205,240,63,158,234,111,26,131,206,240,63,148,187,118,167,123,207,240,63,3,82,217,66,116,208,240,63,68,130,152,236,108,209,240,63,186,32,181,164,101,210,240,63,214,1,48,107,94,211,240,63,22,250,9,64,87,212,240,63,2,222,67,35,80,213,240,63,50,130,222,20,73,214,240,63,69,187,218,20,66,215,240,63,236,93,57,35,59,216,240,63,223,62,251,63,52,217,240,63,230,50,33,107,45,218,240,63,213,14,172,164,38,219,240,63,137,167,156,236,31,220,240,63,240,209,243,66,25,221,240,63,0,99,178,167,18,222,240,63,191,47,217,26,12,223,240,63,61,13,105,156,5,224,240,63,150,208,98,44,255,224,240,63,245,78,199,202,248,225,240,63,141,93,151,119,242,226,240,63,162,209,211,50,236,227,240,63,129,128,125,252,229,228,240,63,133,63,149,212,223,229,240,63,21,228,27,187,217,230,240,63,163,67,18,176,211,231,240,63,176,51,121,179,205,232,240,63,198,137,81,197,199,233,240,63,127,27,156,229,193,234,240,63,126,190,89,20,188,235,240,63,116,72,139,81,182,236,240,63,31,143,49,157,176,237,240,63,72,104,77,247,170,238,240,63,197,169,223,95,165,239,240,63,119,41,233,214,159,240,240,63,79,189,106,92,154,241,240,63,69,59,101,240,148,242,240,63,0,0,0,0,0,0,240,63,99,121,217,146,143,243,240,63,192,214,199,195,154,245,241,63,21,183,49,10,254,6,243,63,139,114,141,249,162,40,244,63,94,236,240,8,129,91,245,63,205,59,127,102,158,160,246,63,176,207,104,215,16,249,247,63,60,110,61,165,254,101,249,63,173,211,90,153,159,232,250,63,41,193,78,7,62,130,252,63,67,19,16,231,55,52,254,63,0,0,0,0,0,0,0,64,99,121,217,146,143,243,0,64,192,214,199,195,154,245,1,64,21,183,49,10,254,6,3,64,139,114,141,249,162,40,4,64,94,236,240,8,129,91,5,64,205,59,127,102,158,160,6,64,176,207,104,215,16,249,7,64,61,110,61,165,254,101,9,64,173,211,90,153,159,232,10,64,41,193,78,7,62,130,12,64,68,19,16,231,55,52,14,64,0,0,0,0,0,0,16,64,99,121,217,146,143,243,16,64,191,214,199,195,154,245,17,64,21,183,49,10,254,6,19,64,139,114,141,249,162,40,20,64,93,236,240,8,129,91,21,64,205,59,127,102,158,160,22,64,177,207,104,215,16,249,23,64,60,110,61,165,254,101,25,64,173,211,90,153,159,232,26,64,42,193,78,7,62,130,28,64,67,19,16,231,55,52,30,64,0,0,0,0,0,0,32,64,99,121,217,146,143,243,32,64,191,214,199,195,154,245,33,64,21,183,49,10,254,6,35,64,139,114,141,249,162,40,36,64,93,236,240,8,129,91,37,64,205,59,127,102,158,160,38,64,177,207,104,215,16,249,39,64,60,110,61,165,254,101,41,64,173,211,90,153,159,232,42,64,42,193,78,7,62,130,44,64,67,19,16,231,55,52,46,64,0,0,0,0,0,0,48,64,98,121,217,146,143,243,48,64,193,214,199,195,154,245,49,64,21,183,49,10,254,6,51,64,138,114,141,249,162,40,52,64,95,236,240,8,129,91,53,64,205,59,127,102,158,160,54,64,175,207,104,215,16,249,55,64,62,110,61,165,254,101,57,64,173,211,90,153,159,232,58,64,40,193,78,7,62,130,60,64,69,19,16,231,55,52,62,64,0,0,0,0,0,0,64,64,98,121,217,146,143,243,64,64,193,214,199,195,154,245,65,64,21,183,49,10,254,6,67,64,138,114,141,249,162,40,68,64,95,236,240,8,129,91,69,64,205,59,127,102,158,160,70,64,175,207,104,215,16,249,71,64,62,110,61,165,254,101,73,64,173,211,90,153,159,232,74,64,40,193,78,7,62,130,76,64,69,19,16,231,55,52,78,64,0,0,0,0,0,0,80,64,98,121,217,146,143,243,80,64,193,214,199,195,154,245,81,64,21,183,49,10,254,6,83,64,138,114,141,249,162,40,84,64,95,236,240,8,129,91,85,64,205,59,127,102,158,160,86,64,175,207,104,215,16,249,87,64,62,110,61,165,254,101,89,64,173,211,90,153,159,232,90,64,40,193,78,7,62,130,92,64,69,19,16,231,55,52,94,64,0,0,0,0,0,0,96,64,98,121,217,146,143,243,96,64,193,214,199,195,154,245,97,64,21,183,49,10,254,6,99,64,138,114,141,249,162,40,100,64,95,236,240,8,129,91,101,64,205,59,127,102,158,160,102,64,175,207,104,215,16,249,103,64,62,110,61,165,254,101,105,64,173,211,90,153,159,232,106,64,40,193,78,7,62,130,108,64,69,19,16,231,55,52,110,64,0,0,0,0,0,0,112,64,101,121,217,146,143,243,112,64,190,214,199,195,154,245,113,64,21,183,49,10,254,6,115,64,141,114,141,249,162,40,116,64,92,236,240,8,129,91,117,64,205,59,127,102,158,160,118,64,179,207,104,215,16,249,119,64,58,110,61,165,254,101,121,64,173,211,90,153,159,232,122,64,45,193,78,7,62,130,124,64,64,19,16,231,55,52,126,64,0,0,0,0,0,0,128,64,101,121,217,146,143,243,128,64,190,214,199,195,154,245,129,64,21,183,49,10,254,6,131,64,141,114,141,249,162,40,132,64,92,236,240,8,129,91,133,64,205,59,127,102,158,160,134,64,179,207,104,215,16,249,135,64,58,110,61,165,254,101,137,64,173,211,90,153,159,232,138,64,45,193,78,7,62,130,140,64,64,19,16,231,55,52,142,64,0,0,0,0,0,0,144,64,101,121,217,146,143,243,144,64,190,214,199,195,154,245,145,64,21,183,49,10,254,6,147,64,141,114,141,249,162,40,148,64,92,236,240,8,129,91,149,64,205,59,127,102,158,160,150,64,179,207,104,215,16,249,151,64,77,84,104,100,0,0,0,0,86,101,108,111,99,105,116,121,32,37,100,32,37,100,10,0,70,84,80,112,114,111,120,121,0,0,0,0,0,0,0,0,72,84,84,80,112,114,111,120,121,0,0,0,0,0,0,0,99,111,109,109,0,0,0,0,35,101,120,116,101,110,115,105,111,110,0,0,0,0,0,0,78,117,109,32,77,105,115,115,105,110,103,32,112,97,116,99,104,101,115,58,32,37,100,10,0,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,115,116,114,105,112,32,109,117,115,116,32,98,101,32,101,110,118,44,32,108,111,111,112,44,32,111,114,32,116,97,105,108,10,0,0,116,97,105,108,0,0,0,0,115,116,114,105,112,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,107,101,101,112,32,109,117,115,116,32,98,101,32,101,110,118,32,111,114,32,108,111,111,112,10,0,0,108,111,111,112,0,0,0,0,101,110,118,0,0,0,0,0,107,101,101,112,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,112,97,110,110,105,110,103,32,109,117,115,116,32,98,101,32,108,101,102,116,44,32,114,105,103,104,116,44,32,99,101,110,116,101,114,44,32,111,114,32,98,101,116,119,101,101,110,32,45,49,48,48,32,97,110,100,32,49,48,48,10,0,0,0,0,0,0,32,9,160,0,0,0,0,0,114,105,103,104,116,0,0,0,108,101,102,116,0,0,0,0,77,105,115,115,105,110,103,32,112,97,116,99,104,58,32,37,115,10,0,0,0,0,0,0,99,101,110,116,101,114,0,0,112,97,110,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,110,111,116,101,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,0,0,0,110,111,116,101,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,97,109,112,108,105,102,105,99,97,116,105,111,110,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,37,100,10,0,0,0,0,97,109,112,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,98,97,100,32,112,97,116,99,104,32,111,112,116,105,111,110,32,37,115,10,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,77,117,115,116,32,115,112,101,99,105,102,121,32,116,111,110,101,32,98,97,110,107,32,111,114,32,100,114,117,109,32,115,101,116,32,98,101,102,111,114,101,32,97,115,115,105,103,110,109,101,110,116,10,0,0,0,0,0,0,67,111,110,102,105,103,117,114,97,116,105,111,110,32,102,105,108,101,32,37,115,32,110,111,116,32,102,111,117,110,100,10,0,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,80,114,111,103,114,97,109,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,37,115,58,32,108,105,110,101,32,37,100,58,32,115,121,110,116,97,120,32,101,114,114,111,114,10,0,0,0,0,0,0,63,63,63,63,63,63,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,84,111,110,101,32,98,97,110,107,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,98,97,110,107,32,110,117,109,98,101,114,32,103,105,118,101,110,10,0,0,0,0,0,0,98,97,110,107,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,68,114,117,109,32,115,101,116,32,109,117,115,116,32,98,101,32,98,101,116,119,101,101,110,32,48,32,97,110,100,32,49,50,55,10,0,0,0,0,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,100,114,117,109,32,115,101,116,32,110,117,109,98,101,114,32,103,105,118,101,110,10,0,0,100,114,117,109,115,101,116,0,37,115,58,32,108,105,110,101,32,37,100,58,32,77,117,115,116,32,115,112,101,99,105,102,121,32,101,120,97,99,116,108,121,32,111,110,101,32,112,97,116,99,104,32,110,97,109,101,10,0,0,0,0,0,0,0,100,101,102,97,117,108,116,0,80,114,111,98,97,98,108,101,32,115,111,117,114,99,101,32,108,111,111,112,32,105,110,32,99,111,110,102,105,103,117,114,97,116,105,111,110,32,102,105,108,101,115,10,0,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,102,105,108,101,32,110,97,109,101,32,103,105,118,101,110,10,0,0,0,0,0,0,0,0,115,111,117,114,99,101,0,0,71,70,49,80,65,84,67,72,49,48,48,0,73,68,35,48,48,48,48,48,50,0,0,0,37,115,58,32,108,105,110,101,32,37,100,58,32,78,111,32,100,105,114,101,99,116,111,114,121,32,103,105,118,101,110,10,0,0,0,0,0,0,0,0,100,105,114,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,109,97,112,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,109,97,112,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,112,114,111,103,98,97,115,101,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,0,0,0,112,114,111,103,98,97,115,101,0,0,0,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,109,101,109,101,110,116,32,34,37,115,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,102,111,110,116,0,0,0,0,85,110,115,117,112,112,111,114,116,101,100,32,97,117,100,105,111,32,102,111,114,109,97,116,10,0,0,0,0,0,0,0,115,111,117,110,100,102,111,110,116,0,0,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,97,108,116,97,115,115,105,103,110,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,0,0,71,70,49,80,65,84,67,72,49,49,48,0,73,68,35,48,48,48,48,48,50,0,0,0,77,84,114,107,0,0,0,0,97,108,116,97,115,115,105,103,110,0,0,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,117,110,100,101,102,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,117,110,100,101,102,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,37,115,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,0,0,0,0,0,99,111,112,121,98,97,110,107,0,0,0,0,0,0,0,0,99,111,112,121,100,114,117,109,115,101,116,0,0,0,0,0,70,73,88,77,69,58,32,73,109,112,108,101,109,101,110,116,32,34,116,105,109,101,111,117,116,34,32,105,110,32,84,105,77,105,100,105,116,121,32,99,111,110,102,105,103,46,10,0,97,100,100,32,116,111,32,112,97,116,104,108,105,115,116,58,32,37,115,10,0,0,0,0,116,105,109,101,111,117,116,0,46,0,0,0,0,0,0,0,116,105,109,105,100,105,116,121,46,99,102,103,0,0,0,0,111,112,116,0,0,0,0,0,114,98,0,0,0,0,0,0,109,97,105,108,97,100,100,114,0,0,0,0,0,0,0,0,46,112,97,116,0,0,0,0,114,98,0,0,0,0,0,0], \"i8\", ALLOC_NONE, Runtime.GLOBAL_BASE)\n        const tempDoublePtr = Runtime.alignMemory(\n            allocate(12, 'i8', ALLOC_STATIC),\n            8\n        );\n        assert(tempDoublePtr % 8 == 0);\n\n        let ___errno_state = 0;\n        function ___setErrNo(value) {\n            // For convenient setting and returning of errno.\n            HEAP32[___errno_state >> 2] = value;\n            return value;\n        }\n\n        const PATH = {\n            splitPath: function(filename) {\n                const splitPathRe = /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\n                return splitPathRe.exec(filename).slice(1);\n            },\n            normalizeArray: function(parts, allowAboveRoot) {\n                // if the path tries to go above the root, `up` ends up > 0\n                let up = 0;\n                for (let i = parts.length - 1; i >= 0; i--) {\n                    const last = parts[i];\n                    if (last === '.') {\n                        parts.splice(i, 1);\n                    } else if (last === '..') {\n                        parts.splice(i, 1);\n                        up++;\n                    } else if (up) {\n                        parts.splice(i, 1);\n                        up--;\n                    }\n                }\n                // if the path is allowed to go above the root, restore leading ..s\n                if (allowAboveRoot) {\n                    for (; up--; up) {\n                        parts.unshift('..');\n                    }\n                }\n                return parts;\n            },\n            normalize: function(path) {\n                const isAbsolute = path.charAt(0) === '/',\n                    trailingSlash = path.substr(-1) === '/';\n                // Normalize the path\n                path = PATH.normalizeArray(\n                    path.split('/').filter(function(p) {\n                        return !!p;\n                    }),\n                    !isAbsolute\n                ).join('/');\n                if (!path && !isAbsolute) {\n                    path = '.';\n                }\n                if (path && trailingSlash) {\n                    path += '/';\n                }\n                return (isAbsolute ? '/' : '') + path;\n            },\n            dirname: function(path) {\n                let result = PATH.splitPath(path),\n                    root = result[0],\n                    dir = result[1];\n                if (!root && !dir) {\n                    // No dirname whatsoever\n                    return '.';\n                }\n                if (dir) {\n                    // It has a dirname, strip trailing slash\n                    dir = dir.substr(0, dir.length - 1);\n                }\n                return root + dir;\n            },\n            basename: function(path, ext) {\n                // EMSCRIPTEN return '/'' for '/', not an empty string\n                if (path === '/') return '/';\n                let f = PATH.splitPath(path)[2];\n                if (ext && f.substr(-1 * ext.length) === ext) {\n                    f = f.substr(0, f.length - ext.length);\n                }\n                return f;\n            },\n            extname: function(path) {\n                return PATH.splitPath(path)[3];\n            },\n            join: function() {\n                const paths = Array.prototype.slice.call(arguments, 0);\n                return PATH.normalize(\n                    paths\n                        .filter(function(p, index) {\n                            if (typeof p !== 'string') {\n                                throw new TypeError(\n                                    'Arguments to path.join must be strings'\n                                );\n                            }\n                            return p;\n                        })\n                        .join('/')\n                );\n            },\n            resolve: function() {\n                let resolvedPath = '',\n                    resolvedAbsolute = false;\n                for (\n                    let i = arguments.length - 1;\n                    i >= -1 && !resolvedAbsolute;\n                    i--\n                ) {\n                    const path = i >= 0 ? arguments[i] : FS.cwd();\n                    // Skip empty and invalid entries\n                    if (typeof path !== 'string') {\n                        throw new TypeError(\n                            'Arguments to path.resolve must be strings'\n                        );\n                    } else if (!path) {\n                        continue;\n                    }\n                    resolvedPath = path + '/' + resolvedPath;\n                    resolvedAbsolute = path.charAt(0) === '/';\n                }\n                // At this point the path should be resolved to a full absolute path, but handle relative paths to be safe (might happen when process.cwd() fails)\n                resolvedPath = PATH.normalizeArray(\n                    resolvedPath.split('/').filter(function(p) {\n                        return !!p;\n                    }),\n                    !resolvedAbsolute\n                ).join('/');\n                return (resolvedAbsolute ? '/' : '') + resolvedPath || '.';\n            },\n            relative: function(from, to) {\n                from = PATH.resolve(from).substr(1);\n                to = PATH.resolve(to).substr(1);\n                function trim(arr) {\n                    let start = 0;\n                    for (; start < arr.length; start++) {\n                        if (arr[start] !== '') break;\n                    }\n                    let end = arr.length - 1;\n                    for (; end >= 0; end--) {\n                        if (arr[end] !== '') break;\n                    }\n                    if (start > end) return [];\n                    return arr.slice(start, end - start + 1);\n                }\n                const fromParts = trim(from.split('/'));\n                const toParts = trim(to.split('/'));\n                var length = Math.min(fromParts.length, toParts.length);\n                let samePartsLength = length;\n                for (var i = 0; i < length; i++) {\n                    if (fromParts[i] !== toParts[i]) {\n                        samePartsLength = i;\n                        break;\n                    }\n                }\n                let outputParts = [];\n                for (var i = samePartsLength; i < fromParts.length; i++) {\n                    outputParts.push('..');\n                }\n                outputParts = outputParts.concat(\n                    toParts.slice(samePartsLength)\n                );\n                return outputParts.join('/');\n            }\n        };\n        const TTY = {\n            ttys: [],\n            init: function() {},\n            shutdown: function() {},\n            register: function(dev, ops) {\n                TTY.ttys[dev] = { input: [], output: [], ops: ops };\n                FS.registerDevice(dev, TTY.stream_ops);\n            },\n            stream_ops: {\n                open: function(stream) {\n                    const tty = TTY.ttys[stream.node.rdev];\n                    if (!tty) {\n                        throw new FS.ErrnoError(ERRNO_CODES.ENODEV);\n                    }\n                    stream.tty = tty;\n                    stream.seekable = false;\n                },\n                close: function(stream) {\n                    // flush any pending line data\n                    if (stream.tty.output.length) {\n                        stream.tty.ops.put_char(stream.tty, 10);\n                    }\n                },\n                read: function(stream, buffer, offset, length) {\n                    if (!stream.tty || !stream.tty.ops.get_char) {\n                        throw new FS.ErrnoError(ERRNO_CODES.ENXIO);\n                    }\n                    let bytesRead = 0;\n                    for (let i = 0; i < length; i++) {\n                        let result;\n                        try {\n                            result = stream.tty.ops.get_char(stream.tty);\n                        } catch (e) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EIO);\n                        }\n                        if (result === undefined && bytesRead === 0) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EAGAIN);\n                        }\n                        if (result === null || result === undefined) break;\n                        bytesRead++;\n                        buffer[offset + i] = result;\n                    }\n                    if (bytesRead) {\n                        stream.node.timestamp = Date.now();\n                    }\n                    return bytesRead;\n                },\n                write: function(stream, buffer, offset, length, pos) {\n                    if (!stream.tty || !stream.tty.ops.put_char) {\n                        throw new FS.ErrnoError(ERRNO_CODES.ENXIO);\n                    }\n                    for (var i = 0; i < length; i++) {\n                        try {\n                            stream.tty.ops.put_char(\n                                stream.tty,\n                                buffer[offset + i]\n                            );\n                        } catch (e) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EIO);\n                        }\n                    }\n                    if (length) {\n                        stream.node.timestamp = Date.now();\n                    }\n                    return i;\n                }\n            },\n            default_tty_ops: {\n                get_char: function(tty) {\n                    if (!tty.input.length) {\n                        let result = null;\n                        result = window.prompt('Input: ');\n                        if (!result) {\n                            return null;\n                        }\n                        result += '\\n';\n                        tty.input = intArrayFromString(result, true);\n                    }\n                    return tty.input.shift();\n                },\n                put_char: function(tty, val) {\n                    if (val === null || val === 10) {\n                        console.log(tty.output.join(''));\n                        tty.output = [];\n                    } else {\n                        tty.output.push(TTY.utf8.processCChar(val));\n                    }\n                }\n            },\n            default_tty1_ops: {\n                put_char: function(tty, val) {\n                    if (val === null || val === 10) {\n                        console.warn(tty.output.join(''));\n                        tty.output = [];\n                    } else {\n                        tty.output.push(TTY.utf8.processCChar(val));\n                    }\n                }\n            }\n        };\n        const MEMFS = {\n            CONTENT_OWNING: 1,\n            CONTENT_FLEXIBLE: 2,\n            CONTENT_FIXED: 3,\n            mount: function() {\n                return MEMFS.createNode(null, '/', 16384 | 0o777, 0);\n            },\n            createNode: function(parent, name, mode, dev) {\n                if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {\n                    // not supported\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                const node = FS.createNode(parent, name, mode, dev);\n                if (FS.isDir(node.mode)) {\n                    node.node_ops = {\n                        getattr: MEMFS.node_ops.getattr,\n                        setattr: MEMFS.node_ops.setattr,\n                        lookup: MEMFS.node_ops.lookup,\n                        mknod: MEMFS.node_ops.mknod,\n                        mknod: MEMFS.node_ops.mknod,\n                        rename: MEMFS.node_ops.rename,\n                        unlink: MEMFS.node_ops.unlink,\n                        rmdir: MEMFS.node_ops.rmdir,\n                        readdir: MEMFS.node_ops.readdir,\n                        symlink: MEMFS.node_ops.symlink\n                    };\n                    node.stream_ops = {\n                        llseek: MEMFS.stream_ops.llseek\n                    };\n                    node.contents = {};\n                } else if (FS.isFile(node.mode)) {\n                    node.node_ops = {\n                        getattr: MEMFS.node_ops.getattr,\n                        setattr: MEMFS.node_ops.setattr\n                    };\n                    node.stream_ops = {\n                        llseek: MEMFS.stream_ops.llseek,\n                        read: MEMFS.stream_ops.read,\n                        write: MEMFS.stream_ops.write,\n                        allocate: MEMFS.stream_ops.allocate,\n                        mmap: MEMFS.stream_ops.mmap\n                    };\n                    node.contents = [];\n                    node.contentMode = MEMFS.CONTENT_FLEXIBLE;\n                } else if (FS.isLink(node.mode)) {\n                    node.node_ops = {\n                        getattr: MEMFS.node_ops.getattr,\n                        setattr: MEMFS.node_ops.setattr,\n                        readlink: MEMFS.node_ops.readlink\n                    };\n                    node.stream_ops = {};\n                } else if (FS.isChrdev(node.mode)) {\n                    node.node_ops = {\n                        getattr: MEMFS.node_ops.getattr,\n                        setattr: MEMFS.node_ops.setattr\n                    };\n                    node.stream_ops = FS.chrdev_stream_ops;\n                }\n                node.timestamp = Date.now();\n                // add the new node to the parent\n                if (parent) {\n                    parent.contents[name] = node;\n                }\n                return node;\n            },\n            ensureFlexible: function(node) {\n                if (node.contentMode !== MEMFS.CONTENT_FLEXIBLE) {\n                    const contents = node.contents;\n                    node.contents = Array.prototype.slice.call(contents);\n                    node.contentMode = MEMFS.CONTENT_FLEXIBLE;\n                }\n            },\n            node_ops: {\n                getattr: function(node) {\n                    const attr = {};\n                    // device numbers reuse inode numbers.\n                    attr.dev = FS.isChrdev(node.mode) ? node.id : 1;\n                    attr.ino = node.id;\n                    attr.mode = node.mode;\n                    attr.nlink = 1;\n                    attr.uid = 0;\n                    attr.gid = 0;\n                    attr.rdev = node.rdev;\n                    if (FS.isDir(node.mode)) {\n                        attr.size = 4096;\n                    } else if (FS.isFile(node.mode)) {\n                        attr.size = node.contents.length;\n                    } else if (FS.isLink(node.mode)) {\n                        attr.size = node.link.length;\n                    } else {\n                        attr.size = 0;\n                    }\n                    attr.atime = new Date(node.timestamp);\n                    attr.mtime = new Date(node.timestamp);\n                    attr.ctime = new Date(node.timestamp);\n                    // NOTE: In our implementation, st_blocks = Math.ceil(st_size/st_blksize), but this is not required by the standard.\n                    attr.blksize = 4096;\n                    attr.blocks = Math.ceil(attr.size / attr.blksize);\n                    return attr;\n                },\n                setattr: function(node, attr) {\n                    if (attr.mode !== undefined) {\n                        node.mode = attr.mode;\n                    }\n                    if (attr.timestamp !== undefined) {\n                        node.timestamp = attr.timestamp;\n                    }\n                    if (attr.size !== undefined) {\n                        MEMFS.ensureFlexible(node);\n                        const contents = node.contents;\n                        if (attr.size < contents.length)\n                            contents.length = attr.size;\n                        else\n                            while (attr.size > contents.length)\n                                contents.push(0);\n                    }\n                },\n                lookup: function() {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENOENT);\n                },\n                mknod: function(parent, name, mode, dev) {\n                    return MEMFS.createNode(parent, name, mode, dev);\n                },\n                rename: function(old_node, new_dir, new_name) {\n                    // if we're overwriting a directory at new_name, make sure it's empty.\n                    if (FS.isDir(old_node.mode)) {\n                        let new_node;\n                        try {\n                            new_node = FS.lookupNode(new_dir, new_name);\n                        } catch (e) {}\n                        if (new_node) {\n                            for (const i in new_node.contents) {\n                                throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY);\n                            }\n                        }\n                    }\n                    // do the internal rewiring\n                    delete old_node.parent.contents[old_node.name];\n                    old_node.name = new_name;\n                    new_dir.contents[new_name] = old_node;\n                },\n                unlink: function(parent, name) {\n                    delete parent.contents[name];\n                },\n                rmdir: function(parent, name) {\n                    const node = FS.lookupNode(parent, name);\n                    for (const i in node.contents) {\n                        throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY);\n                    }\n                    delete parent.contents[name];\n                },\n                readdir: function(node) {\n                    const entries = ['.', '..'];\n                    for (const key in node.contents) {\n                        if (!node.contents.hasOwnProperty(key)) {\n                            continue;\n                        }\n                        entries.push(key);\n                    }\n                    return entries;\n                },\n                symlink: function(parent, newname, oldpath) {\n                    const node = MEMFS.createNode(\n                        parent,\n                        newname,\n                        0o777 | 40960,\n                        0\n                    );\n                    node.link = oldpath;\n                    return node;\n                },\n                readlink: function(node) {\n                    if (!FS.isLink(node.mode)) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                    }\n                    return node.link;\n                }\n            },\n            stream_ops: {\n                read: function(stream, buffer, offset, length, position) {\n                    const contents = stream.node.contents;\n                    if (position >= contents.length) return 0;\n                    const size = Math.min(contents.length - position, length);\n                    assert(size >= 0);\n                    if (size > 8 && contents.subarray) {\n                        // non-trivial and typed array\n                        buffer.set(\n                            contents.subarray(position, position + size),\n                            offset\n                        );\n                    } else {\n                        for (let i = 0; i < size; i++) {\n                            buffer[offset + i] = contents[position + i];\n                        }\n                    }\n                    return size;\n                },\n                write: function(\n                    stream,\n                    buffer,\n                    offset,\n                    length,\n                    position,\n                    canOwn\n                ) {\n                    const node = stream.node;\n                    node.timestamp = Date.now();\n                    var contents = node.contents;\n                    if (\n                        length &&\n                        contents.length === 0 &&\n                        position === 0 &&\n                        buffer.subarray\n                    ) {\n                        // just replace it with the new data\n                        assert(buffer.length);\n                        if (\n                            canOwn &&\n                            buffer.buffer === HEAP8.buffer &&\n                            offset === 0\n                        ) {\n                            node.contents = buffer; // this is a subarray of the heap, and we can own it\n                            node.contentMode = MEMFS.CONTENT_OWNING;\n                        } else {\n                            node.contents = new Uint8Array(\n                                buffer.subarray(offset, offset + length)\n                            );\n                            node.contentMode = MEMFS.CONTENT_FIXED;\n                        }\n                        return length;\n                    }\n                    MEMFS.ensureFlexible(node);\n                    var contents = node.contents;\n                    while (contents.length < position) contents.push(0);\n                    for (let i = 0; i < length; i++) {\n                        contents[position + i] = buffer[offset + i];\n                    }\n                    return length;\n                },\n                llseek: function(stream, offset, whence) {\n                    let position = offset;\n                    if (whence === 1) {\n                        // SEEK_CUR.\n                        position += stream.position;\n                    } else if (whence === 2) {\n                        // SEEK_END.\n                        if (FS.isFile(stream.node.mode)) {\n                            position += stream.node.contents.length;\n                        }\n                    }\n                    if (position < 0) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                    }\n                    stream.ungotten = [];\n                    stream.position = position;\n                    return position;\n                },\n                allocate: function(stream, offset, length) {\n                    MEMFS.ensureFlexible(stream.node);\n                    const contents = stream.node.contents;\n                    const limit = offset + length;\n                    while (limit > contents.length) contents.push(0);\n                },\n                mmap: function(stream, buffer, length, position, flags) {\n                    if (!FS.isFile(stream.node.mode)) {\n                        throw new FS.ErrnoError(ERRNO_CODES.ENODEV);\n                    }\n                    let ptr;\n                    let allocated;\n                    let contents = stream.node.contents;\n                    // Only make a new copy when MAP_PRIVATE is specified.\n                    if (\n                        !(flags & 2) &&\n                        (contents.buffer === buffer ||\n                            contents.buffer === buffer.buffer)\n                    ) {\n                        // We can't emulate MAP_SHARED when the file is not backed by the buffer\n                        // we're mapping to (e.g. the HEAP buffer).\n                        allocated = false;\n                        ptr = contents.byteOffset;\n                    } else {\n                        // Try to avoid unnecessary slices.\n                        if (\n                            position > 0 ||\n                            position + length < contents.length\n                        ) {\n                            if (contents.subarray) {\n                                contents = contents.subarray(\n                                    position,\n                                    position + length\n                                );\n                            } else {\n                                contents = Array.prototype.slice.call(\n                                    contents,\n                                    position,\n                                    position + length\n                                );\n                            }\n                        }\n                        allocated = true;\n                        ptr = _malloc(length);\n                        if (!ptr) {\n                            throw new FS.ErrnoError(ERRNO_CODES.ENOMEM);\n                        }\n                        buffer.set(contents, ptr);\n                    }\n                    return { ptr: ptr, allocated: allocated };\n                }\n            }\n        };\n        const _stdin = allocate(1, 'i32*', ALLOC_STATIC);\n        const _stdout = allocate(1, 'i32*', ALLOC_STATIC);\n        var _stderr = allocate(1, 'i32*', ALLOC_STATIC);\n        function _fflush() {\n            // int fflush(FILE *stream);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fflush.html\n            // we don't currently perform any user-space buffering of data\n        }\n        const FS = {\n            root: null,\n            mounts: [],\n            devices: [null],\n            streams: [null],\n            nextInode: 1,\n            nameTable: null,\n            currentPath: '/',\n            initialized: false,\n            ignorePermissions: true,\n            // error instance\n            ErrnoError: function ErrnoError(errorNumber, details) {\n                this.errorNumber = errorNumber;\n                for (const key in ERRNO_CODES) {\n                    if (ERRNO_CODES[key] === errorNumber) {\n                        // remove the prefix 'E'\n                        this.code = key.substring(1);\n                        break;\n                    }\n                }\n                this.message = ERRNO_MESSAGES[errorNumber];\n                this.details = details || '';\n            },\n            handleFSError: function(e) {\n                if (!(e instanceof FS.ErrnoError))\n                    throw e + ' : ' + new Error().stack;\n                return ___setErrNo(e.errno);\n            },\n            lookupPath: function(path, opts) {\n                path = PATH.resolve(FS.cwd(), path);\n                opts = opts || { recurse_count: 0 };\n                if (opts.recurse_count > 8) {\n                    // max recursive lookup of 8\n                    throw new FS.ErrnoError(ERRNO_CODES.ELOOP);\n                }\n                // split the path\n                const parts = PATH.normalizeArray(\n                    path.split('/').filter(function(p) {\n                        return !!p;\n                    }),\n                    false\n                );\n                // start at the root\n                let current = FS.root;\n                let current_path = '/';\n                for (let i = 0; i < parts.length; i++) {\n                    const islast = i === parts.length - 1;\n                    if (islast && opts.parent) {\n                        // stop resolving\n                        break;\n                    }\n                    current = FS.lookupNode(current, parts[i]);\n                    current_path = PATH.join(current_path, parts[i]);\n                    // jump to the mount's root node if this is a mountpoint\n                    if (FS.isMountpoint(current)) {\n                        current = current.mount.root;\n                    }\n                    // follow symlinks\n                    // by default, lookupPath will not follow a symlink if it is the final path component.\n                    // setting opts.follow = true will override this behavior.\n                    if (!islast || opts.follow) {\n                        let count = 0;\n                        while (FS.isLink(current.mode)) {\n                            const link = FS.readlink(current_path);\n                            current_path = PATH.resolve(\n                                PATH.dirname(current_path),\n                                link\n                            );\n                            const lookup = FS.lookupPath(current_path, {\n                                recurse_count: opts.recurse_count\n                            });\n                            current = lookup.node;\n                            if (count++ > 40) {\n                                // limit max consecutive symlinks to 40 (SYMLOOP_MAX).\n                                throw new FS.ErrnoError(ERRNO_CODES.ELOOP);\n                            }\n                        }\n                    }\n                }\n                return { path: current_path, node: current };\n            },\n            getPath: function(node) {\n                let path;\n                while (true) {\n                    if (FS.isRoot(node)) {\n                        return path\n                            ? PATH.join(node.mount.mountpoint, path)\n                            : node.mount.mountpoint;\n                    }\n                    path = path ? PATH.join(node.name, path) : node.name;\n                    node = node.parent;\n                }\n            },\n            hashName: function(parentid, name) {\n                let hash = 0;\n                for (let i = 0; i < name.length; i++) {\n                    hash = ((hash << 5) - hash + name.charCodeAt(i)) | 0;\n                }\n                return ((parentid + hash) >>> 0) % FS.nameTable.length;\n            },\n            hashAddNode: function(node) {\n                const hash = FS.hashName(node.parent.id, node.name);\n                node.name_next = FS.nameTable[hash];\n                FS.nameTable[hash] = node;\n            },\n            hashRemoveNode: function(node) {\n                const hash = FS.hashName(node.parent.id, node.name);\n                if (FS.nameTable[hash] === node) {\n                    FS.nameTable[hash] = node.name_next;\n                } else {\n                    let current = FS.nameTable[hash];\n                    while (current) {\n                        if (current.name_next === node) {\n                            current.name_next = node.name_next;\n                            break;\n                        }\n                        current = current.name_next;\n                    }\n                }\n            },\n            lookupNode: function(parent, name) {\n                const err = FS.mayLookup(parent);\n                if (err) {\n                    throw new FS.ErrnoError(err, name);\n                }\n                const hash = FS.hashName(parent.id, name);\n                for (\n                    let node = FS.nameTable[hash];\n                    node;\n                    node = node.name_next\n                ) {\n                    const nodeName = node.name;\n                    if (node.parent.id === parent.id && nodeName === name) {\n                        return node;\n                    }\n                }\n                // if we failed to find it in the cache, call into the VFS\n                return FS.lookup(parent, name);\n            },\n            createNode: function(parent, name, mode, rdev) {\n                const node = {\n                    id: FS.nextInode++,\n                    name: name,\n                    mode: mode,\n                    node_ops: {},\n                    stream_ops: {},\n                    rdev: rdev,\n                    parent: null,\n                    mount: null\n                };\n                if (!parent) {\n                    parent = node; // root node sets parent to itself\n                }\n                node.parent = parent;\n                node.mount = parent.mount;\n                // compatibility\n                const readMode = 292 | 73;\n                const writeMode = 146;\n                // NOTE we must use Object.defineProperties instead of individual calls to\n                // Object.defineProperty in order to make closure compiler happy\n                Object.defineProperties(node, {\n                    read: {\n                        get: function() {\n                            return (node.mode & readMode) === readMode;\n                        },\n                        set: function(val) {\n                            val\n                                ? (node.mode |= readMode)\n                                : (node.mode &= ~readMode);\n                        }\n                    },\n                    write: {\n                        get: function() {\n                            return (node.mode & writeMode) === writeMode;\n                        },\n                        set: function(val) {\n                            val\n                                ? (node.mode |= writeMode)\n                                : (node.mode &= ~writeMode);\n                        }\n                    },\n                    isFolder: {\n                        get: function() {\n                            return FS.isDir(node.mode);\n                        }\n                    },\n                    isDevice: {\n                        get: function() {\n                            return FS.isChrdev(node.mode);\n                        }\n                    }\n                });\n                FS.hashAddNode(node);\n                return node;\n            },\n            destroyNode: function(node) {\n                FS.hashRemoveNode(node);\n            },\n            isRoot: function(node) {\n                return node === node.parent;\n            },\n            isMountpoint: function(node) {\n                return node.mounted;\n            },\n            isFile: function(mode) {\n                return (mode & 61440) === 32768;\n            },\n            isDir: function(mode) {\n                return (mode & 61440) === 16384;\n            },\n            isLink: function(mode) {\n                return (mode & 61440) === 40960;\n            },\n            isChrdev: function(mode) {\n                return (mode & 61440) === 8192;\n            },\n            isBlkdev: function(mode) {\n                return (mode & 61440) === 24576;\n            },\n            isFIFO: function(mode) {\n                return (mode & 61440) === 4096;\n            },\n            isSocket: function(mode) {\n                return (mode & 49152) === 49152;\n            },\n            flagModes: {\n                r: 0,\n                rs: 1052672,\n                'r+': 2,\n                w: 577,\n                wx: 705,\n                xw: 705,\n                'w+': 578,\n                'wx+': 706,\n                'xw+': 706,\n                a: 1089,\n                ax: 1217,\n                xa: 1217,\n                'a+': 1090,\n                'ax+': 1218,\n                'xa+': 1218\n            },\n            modeStringToFlags: function(str) {\n                const flags = FS.flagModes[str];\n                if (typeof flags === 'undefined') {\n                    throw new Error('Unknown file open mode: ' + str);\n                }\n                return flags;\n            },\n            flagsToPermissionString: function(flag) {\n                const accmode = flag & 2097155;\n                let perms = ['r', 'w', 'rw'][accmode];\n                if (flag & 512) {\n                    perms += 'w';\n                }\n                return perms;\n            },\n            nodePermissions: function(node, perms) {\n                if (FS.ignorePermissions) {\n                    return 0;\n                }\n                // return 0 if any user, group or owner bits are set.\n                if (perms.indexOf('r') !== -1 && !(node.mode & 292)) {\n                    return ERRNO_CODES.EACCES;\n                } else if (perms.indexOf('w') !== -1 && !(node.mode & 146)) {\n                    return ERRNO_CODES.EACCES;\n                } else if (perms.indexOf('x') !== -1 && !(node.mode & 73)) {\n                    return ERRNO_CODES.EACCES;\n                }\n                return 0;\n            },\n            mayLookup: function(dir) {\n                return FS.nodePermissions(dir, 'x');\n            },\n            mayCreate: function(dir, name) {\n                try {\n                    FS.lookupNode(dir, name);\n                    return ERRNO_CODES.EEXIST;\n                } catch (e) {}\n                return FS.nodePermissions(dir, 'wx');\n            },\n            mayDelete: function(dir, name, isdir) {\n                let node;\n                try {\n                    node = FS.lookupNode(dir, name);\n                } catch (e) {\n                    return e.errno;\n                }\n                const err = FS.nodePermissions(dir, 'wx');\n                if (err) {\n                    return err;\n                }\n                if (isdir) {\n                    if (!FS.isDir(node.mode)) {\n                        return ERRNO_CODES.ENOTDIR;\n                    }\n                    if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {\n                        return ERRNO_CODES.EBUSY;\n                    }\n                } else {\n                    if (FS.isDir(node.mode)) {\n                        return ERRNO_CODES.EISDIR;\n                    }\n                }\n                return 0;\n            },\n            mayOpen: function(node, flags) {\n                if (!node) {\n                    return ERRNO_CODES.ENOENT;\n                }\n                if (FS.isLink(node.mode)) {\n                    return ERRNO_CODES.ELOOP;\n                } else if (FS.isDir(node.mode)) {\n                    if (\n                        (flags & 2097155) !== 0 || // opening for write\n                        flags & 512\n                    ) {\n                        return ERRNO_CODES.EISDIR;\n                    }\n                }\n                return FS.nodePermissions(\n                    node,\n                    FS.flagsToPermissionString(flags)\n                );\n            },\n            MAX_OPEN_FDS: 4096,\n            nextfd: function(fd_start, fd_end) {\n                fd_start = fd_start || 1;\n                fd_end = fd_end || FS.MAX_OPEN_FDS;\n                for (let fd = fd_start; fd <= fd_end; fd++) {\n                    if (!FS.streams[fd]) {\n                        return fd;\n                    }\n                }\n                throw new FS.ErrnoError(ERRNO_CODES.EMFILE);\n            },\n            getStream: function(fd) {\n                return FS.streams[fd];\n            },\n            createStream: function(stream, fd_start, fd_end) {\n                const fd = FS.nextfd(fd_start, fd_end);\n                stream.fd = fd;\n                // compatibility\n                Object.defineProperties(stream, {\n                    object: {\n                        get: function() {\n                            return stream.node;\n                        },\n                        set: function(val) {\n                            stream.node = val;\n                        }\n                    },\n                    isRead: {\n                        get: function() {\n                            return (stream.flags & 2097155) !== 1;\n                        }\n                    },\n                    isWrite: {\n                        get: function() {\n                            return (stream.flags & 2097155) !== 0;\n                        }\n                    },\n                    isAppend: {\n                        get: function() {\n                            return stream.flags & 1024;\n                        }\n                    }\n                });\n                FS.streams[fd] = stream;\n                return stream;\n            },\n            closeStream: function(fd) {\n                FS.streams[fd] = null;\n            },\n            chrdev_stream_ops: {\n                open: function(stream) {\n                    const device = FS.getDevice(stream.node.rdev);\n                    // override node's stream ops with the device's\n                    stream.stream_ops = device.stream_ops;\n                    // forward the open call\n                    if (stream.stream_ops.open) {\n                        stream.stream_ops.open(stream);\n                    }\n                },\n                llseek: function() {\n                    throw new FS.ErrnoError(ERRNO_CODES.ESPIPE);\n                }\n            },\n            major: function(dev) {\n                return dev >> 8;\n            },\n            minor: function(dev) {\n                return dev & 0xff;\n            },\n            makedev: function(ma, mi) {\n                return (ma << 8) | mi;\n            },\n            registerDevice: function(dev, ops) {\n                FS.devices[dev] = { stream_ops: ops };\n            },\n            getDevice: function(dev) {\n                return FS.devices[dev];\n            },\n            syncfs: function(populate, callback) {\n                if (typeof populate === 'function') {\n                    callback = populate;\n                    populate = false;\n                }\n                let completed = 0;\n                const total = FS.mounts.length;\n                const done = function(err) {\n                    if (err) {\n                        return callback(err);\n                    }\n                    if (++completed >= total) {\n                        callback(null);\n                    }\n                };\n                // sync all mounts\n                for (let i = 0; i < FS.mounts.length; i++) {\n                    const mount = FS.mounts[i];\n                    if (!mount.type.syncfs) {\n                        done(null);\n                        continue;\n                    }\n                    mount.type.syncfs(mount, populate, done);\n                }\n            },\n            mount: function(type, opts, mountpoint) {\n                let lookup;\n                if (mountpoint) {\n                    lookup = FS.lookupPath(mountpoint, { follow: false });\n                    mountpoint = lookup.path; // use the absolute path\n                }\n                const mount = {\n                    type: type,\n                    opts: opts,\n                    mountpoint: mountpoint,\n                    root: null\n                };\n                // create a root node for the fs\n                var root = type.mount(mount);\n                root.mount = mount;\n                mount.root = root;\n                // assign the mount info to the mountpoint's node\n                if (lookup) {\n                    lookup.node.mount = mount;\n                    lookup.node.mounted = true;\n                    // compatibility update FS.root if we mount to /\n                    if (mountpoint === '/') {\n                        FS.root = mount.root;\n                    }\n                }\n                // add to our cached list of mounts\n                FS.mounts.push(mount);\n                return root;\n            },\n            lookup: function(parent, name) {\n                return parent.node_ops.lookup(parent, name);\n            },\n            mknod: function(path, mode, dev, throwError = true) {\n                const lookup = FS.lookupPath(path, { parent: true });\n                const parent = lookup.node;\n                const name = PATH.basename(path);\n                const error = FS.mayCreate(parent, name);\n                if (error) {\n                    if (throwError) {\n                        throw new FS.ErrnoError(error, path);\n                    }\n                    return;\n                }\n                if (!parent.node_ops.mknod) {\n                    if (throwError) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EPERM, path);\n                    }\n                    return;\n                }\n                return parent.node_ops.mknod(parent, name, mode, dev);\n            },\n            create: function(path, mode, throwError = true) {\n                mode = mode !== undefined ? mode : 0o666;\n                mode &= 4095;\n                mode |= 32768;\n                return FS.mknod(path, mode, 0, throwError);\n            },\n            mkdir: function(path, mode, throwError = true) {\n                mode = mode !== undefined ? mode : 0o777;\n                mode &= 511 | 512;\n                mode |= 16384;\n                return FS.mknod(path, mode, 0, throwError);\n            },\n            mkdev: function(path, mode, dev) {\n                if (typeof dev === 'undefined') {\n                    dev = mode;\n                    mode = 0o666;\n                }\n                mode |= 8192;\n                return FS.mknod(path, mode, dev);\n            },\n            symlink: function(oldpath, newpath) {\n                const lookup = FS.lookupPath(newpath, { parent: true });\n                var parent = lookup.node;\n                const newname = PATH.basename(newpath);\n                const err = FS.mayCreate(parent, newname);\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                if (!parent.node_ops.symlink) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                return parent.node_ops.symlink(parent, newname, oldpath);\n            },\n            rename: function(old_path, new_path) {\n                const old_dirname = PATH.dirname(old_path);\n                const new_dirname = PATH.dirname(new_path);\n                const old_name = PATH.basename(old_path);\n                const new_name = PATH.basename(new_path);\n                // parents must exist\n                let lookup, old_dir, new_dir;\n                try {\n                    lookup = FS.lookupPath(old_path, { parent: true });\n                    old_dir = lookup.node;\n                    lookup = FS.lookupPath(new_path, { parent: true });\n                    new_dir = lookup.node;\n                } catch (e) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBUSY);\n                }\n                // need to be part of the same mount\n                if (old_dir.mount !== new_dir.mount) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EXDEV);\n                }\n                // source must exist\n                const old_node = FS.lookupNode(old_dir, old_name);\n                // old path should not be an ancestor of the new path\n                let relative = PATH.relative(old_path, new_dirname);\n                if (relative.charAt(0) !== '.') {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                // new path should not be an ancestor of the old path\n                relative = PATH.relative(new_path, old_dirname);\n                if (relative.charAt(0) !== '.') {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY);\n                }\n                // see if the new path already exists\n                let new_node;\n                try {\n                    new_node = FS.lookupNode(new_dir, new_name);\n                } catch (e) {\n                    // not fatal\n                }\n                // early out if nothing needs to change\n                if (old_node === new_node) {\n                    return;\n                }\n                // we'll need to delete the old entry\n                const isdir = FS.isDir(old_node.mode);\n                let err = FS.mayDelete(old_dir, old_name, isdir);\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                // need delete permissions if we'll be overwriting.\n                // need create permissions if new doesn't already exist.\n                err = new_node\n                    ? FS.mayDelete(new_dir, new_name, isdir)\n                    : FS.mayCreate(new_dir, new_name);\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                if (!old_dir.node_ops.rename) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                if (\n                    FS.isMountpoint(old_node) ||\n                    (new_node && FS.isMountpoint(new_node))\n                ) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBUSY);\n                }\n                // if we are going to change the parent, check write permissions\n                if (new_dir !== old_dir) {\n                    err = FS.nodePermissions(old_dir, 'w');\n                    if (err) {\n                        throw new FS.ErrnoError(err);\n                    }\n                }\n                // remove the node from the lookup hash\n                FS.hashRemoveNode(old_node);\n                // do the underlying fs rename\n                try {\n                    old_dir.node_ops.rename(old_node, new_dir, new_name);\n                } catch (e) {\n                    throw e;\n                } finally {\n                    // add the node back to the hash (in case node_ops.rename\n                    // changed its name)\n                    FS.hashAddNode(old_node);\n                }\n            },\n            rmdir: function(path) {\n                const lookup = FS.lookupPath(path, { parent: true });\n                var parent = lookup.node;\n                const name = PATH.basename(path);\n                var node = FS.lookupNode(parent, name);\n                const err = FS.mayDelete(parent, name, true);\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                if (!parent.node_ops.rmdir) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                if (FS.isMountpoint(node)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBUSY);\n                }\n                parent.node_ops.rmdir(parent, name);\n                FS.destroyNode(node);\n            },\n            readdir: function(path) {\n                const lookup = FS.lookupPath(path, { follow: true });\n                const node = lookup.node;\n                if (!node.node_ops.readdir) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR);\n                }\n                return node.node_ops.readdir(node);\n            },\n            unlink: function(path) {\n                const lookup = FS.lookupPath(path, { parent: true });\n                var parent = lookup.node;\n                const name = PATH.basename(path);\n                var node = FS.lookupNode(parent, name);\n                let err = FS.mayDelete(parent, name, false);\n                if (err) {\n                    // POSIX says unlink should set EPERM, not EISDIR\n                    if (err === ERRNO_CODES.EISDIR) err = ERRNO_CODES.EPERM;\n                    throw new FS.ErrnoError(err);\n                }\n                if (!parent.node_ops.unlink) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                if (FS.isMountpoint(node)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBUSY);\n                }\n                parent.node_ops.unlink(parent, name);\n                FS.destroyNode(node);\n            },\n            readlink: function(path) {\n                const lookup = FS.lookupPath(path, { follow: false });\n                const link = lookup.node;\n                if (!link.node_ops.readlink) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                return link.node_ops.readlink(link);\n            },\n            stat: function(path, dontFollow) {\n                const lookup = FS.lookupPath(path, { follow: !dontFollow });\n                const node = lookup.node;\n                if (!node.node_ops.getattr) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                return node.node_ops.getattr(node);\n            },\n            lstat: function(path) {\n                return FS.stat(path, true);\n            },\n            chmod: function(path, mode, dontFollow) {\n                let node;\n                if (typeof path === 'string') {\n                    const lookup = FS.lookupPath(path, { follow: !dontFollow });\n                    node = lookup.node;\n                } else {\n                    node = path;\n                }\n                if (!node.node_ops.setattr) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                node.node_ops.setattr(node, {\n                    mode: (mode & 4095) | (node.mode & ~4095),\n                    timestamp: Date.now()\n                });\n            },\n            lchmod: function(path, mode) {\n                FS.chmod(path, mode, true);\n            },\n            fchmod: function(fd, mode) {\n                const stream = FS.getStream(fd);\n                if (!stream) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBADF);\n                }\n                FS.chmod(stream.node, mode);\n            },\n            chown: function(path, uid, gid, dontFollow) {\n                let node;\n                if (typeof path === 'string') {\n                    const lookup = FS.lookupPath(path, { follow: !dontFollow });\n                    node = lookup.node;\n                } else {\n                    node = path;\n                }\n                if (!node.node_ops.setattr) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                node.node_ops.setattr(node, {\n                    timestamp: Date.now()\n                    // we ignore the uid / gid for now\n                });\n            },\n            lchown: function(path, uid, gid) {\n                FS.chown(path, uid, gid, true);\n            },\n            fchown: function(fd, uid, gid) {\n                const stream = FS.getStream(fd);\n                if (!stream) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBADF);\n                }\n                FS.chown(stream.node, uid, gid);\n            },\n            truncate: function(path, len) {\n                if (len < 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                let node;\n                if (typeof path === 'string') {\n                    const lookup = FS.lookupPath(path, { follow: true });\n                    node = lookup.node;\n                } else {\n                    node = path;\n                }\n                if (!node.node_ops.setattr) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EPERM);\n                }\n                if (FS.isDir(node.mode)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EISDIR);\n                }\n                if (!FS.isFile(node.mode)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                const err = FS.nodePermissions(node, 'w');\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                node.node_ops.setattr(node, {\n                    size: len,\n                    timestamp: Date.now()\n                });\n            },\n            ftruncate: function(fd, len) {\n                const stream = FS.getStream(fd);\n                if (!stream) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBADF);\n                }\n                if ((stream.flags & 2097155) === 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                FS.truncate(stream.node, len);\n            },\n            utime: function(path, atime, mtime) {\n                const lookup = FS.lookupPath(path, { follow: true });\n                const node = lookup.node;\n                node.node_ops.setattr(node, {\n                    timestamp: Math.max(atime, mtime)\n                });\n            },\n            open: function(path, flags, mode, fd_start, fd_end) {\n                path = PATH.normalize(path);\n                flags =\n                    typeof flags === 'string'\n                        ? FS.modeStringToFlags(flags)\n                        : flags;\n                mode = typeof mode === 'undefined' ? 0o666 : mode;\n                if (flags & 64) {\n                    mode = (mode & 4095) | 32768;\n                } else {\n                    mode = 0;\n                }\n                let node;\n                try {\n                    const lookup = FS.lookupPath(path, {\n                        follow: !(flags & 131072)\n                    });\n                    node = lookup.node;\n                } catch (e) {\n                    // ignore\n                }\n                // perhaps we need to create the node\n                if (flags & 64) {\n                    if (node) {\n                        // if O_CREAT and O_EXCL are set, error out if the node already exists\n                        if (flags & 128) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EEXIST);\n                        }\n                    } else {\n                        // node doesn't exist, try to create it\n                        node = FS.mknod(path, mode, 0);\n                    }\n                }\n                if (!node) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENOENT);\n                }\n                // can't truncate a device\n                if (FS.isChrdev(node.mode)) {\n                    flags &= ~512;\n                }\n                // check permissions\n                const err = FS.mayOpen(node, flags);\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                // do truncation if necessary\n                if (flags & 512) {\n                    FS.truncate(node, 0);\n                }\n                // we've already handled these, don't pass down to the underlying vfs\n                flags &= ~(128 | 512);\n                // register the stream with the filesystem\n                const stream = FS.createStream(\n                    {\n                        node: node,\n                        path: FS.getPath(node), // we want the absolute path to the node\n                        flags: flags,\n                        seekable: true,\n                        position: 0,\n                        stream_ops: node.stream_ops,\n                        // used by the file family libc calls (fopen, fwrite, ferror, etc.)\n                        ungotten: [],\n                        error: false\n                    },\n                    fd_start,\n                    fd_end\n                );\n                // call the new stream's open function\n                if (stream.stream_ops.open) {\n                    stream.stream_ops.open(stream);\n                }\n                if (Module['logReadFiles'] && !(flags & 1)) {\n                    if (!FS.readFiles) FS.readFiles = {};\n                    if (!(path in FS.readFiles)) {\n                        FS.readFiles[path] = 1;\n                        console.warn('read file: ' + path);\n                    }\n                }\n                return stream;\n            },\n            close: function(stream) {\n                try {\n                    if (stream.stream_ops.close) {\n                        stream.stream_ops.close(stream);\n                    }\n                } catch (e) {\n                    throw e;\n                } finally {\n                    FS.closeStream(stream.fd);\n                }\n            },\n            llseek: function(stream, offset, whence) {\n                if (!stream.seekable || !stream.stream_ops.llseek) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ESPIPE);\n                }\n                return stream.stream_ops.llseek(stream, offset, whence);\n            },\n            read: function(stream, buffer, offset, length, position) {\n                if (length < 0 || position < 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                if ((stream.flags & 2097155) === 1) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBADF);\n                }\n                if (FS.isDir(stream.node.mode)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EISDIR);\n                }\n                if (!stream.stream_ops.read) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                let seeking = true;\n                if (typeof position === 'undefined') {\n                    position = stream.position;\n                    seeking = false;\n                } else if (!stream.seekable) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ESPIPE);\n                }\n                const bytesRead = stream.stream_ops.read(\n                    stream,\n                    buffer,\n                    offset,\n                    length,\n                    position\n                );\n                if (!seeking) stream.position += bytesRead;\n                return bytesRead;\n            },\n            write: function(stream, buffer, offset, length, position, canOwn) {\n                if (length < 0 || position < 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                if ((stream.flags & 2097155) === 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBADF);\n                }\n                if (FS.isDir(stream.node.mode)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EISDIR);\n                }\n                if (!stream.stream_ops.write) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                let seeking = true;\n                if (typeof position === 'undefined') {\n                    position = stream.position;\n                    seeking = false;\n                } else if (!stream.seekable) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ESPIPE);\n                }\n                if (stream.flags & 1024) {\n                    // seek to the end before writing in append mode\n                    FS.llseek(stream, 0, 2);\n                }\n                const bytesWritten = stream.stream_ops.write(\n                    stream,\n                    buffer,\n                    offset,\n                    length,\n                    position,\n                    canOwn\n                );\n                if (!seeking) stream.position += bytesWritten;\n                return bytesWritten;\n            },\n            allocate: function(stream, offset, length) {\n                if (offset < 0 || length <= 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                }\n                if ((stream.flags & 2097155) === 0) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EBADF);\n                }\n                if (!FS.isFile(stream.node.mode) && !FS.isDir(node.mode)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENODEV);\n                }\n                if (!stream.stream_ops.allocate) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP);\n                }\n                stream.stream_ops.allocate(stream, offset, length);\n            },\n            mmap: function(\n                stream,\n                buffer,\n                offset,\n                length,\n                position,\n                prot,\n                flags\n            ) {\n                // TODO if PROT is PROT_WRITE, make sure we have write access\n                if ((stream.flags & 2097155) === 1) {\n                    throw new FS.ErrnoError(ERRNO_CODES.EACCES);\n                }\n                if (!stream.stream_ops.mmap) {\n                    throw new FS.errnoError(ERRNO_CODES.ENODEV);\n                }\n                return stream.stream_ops.mmap(\n                    stream,\n                    buffer,\n                    offset,\n                    length,\n                    position,\n                    prot,\n                    flags\n                );\n            },\n            ioctl: function(stream, cmd, arg) {\n                if (!stream.stream_ops.ioctl) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENOTTY);\n                }\n                return stream.stream_ops.ioctl(stream, cmd, arg);\n            },\n            readFile: function(path, opts) {\n                opts = opts || {};\n                opts.flags = opts.flags || 'r';\n                opts.encoding = opts.encoding || 'binary';\n                let ret;\n                const stream = FS.open(path, opts.flags);\n                const stat = FS.stat(path);\n                const length = stat.size;\n                const buf = new Uint8Array(length);\n                FS.read(stream, buf, 0, length, 0);\n                if (opts.encoding === 'utf8') {\n                    ret = '';\n                    const utf8 = new Runtime.UTF8Processor();\n                    for (let i = 0; i < length; i++) {\n                        ret += utf8.processCChar(buf[i]);\n                    }\n                } else if (opts.encoding === 'binary') {\n                    ret = buf;\n                } else {\n                    throw new Error(\n                        'Invalid encoding type \"' + opts.encoding + '\"'\n                    );\n                }\n                FS.close(stream);\n                return ret;\n            },\n            writeFile: function(path, data, opts) {\n                opts = opts || {};\n                opts.flags = opts.flags || 'w';\n                opts.encoding = opts.encoding || 'utf8';\n                const stream = FS.open(path, opts.flags, opts.mode);\n                if (opts.encoding === 'utf8') {\n                    const utf8 = new Runtime.UTF8Processor();\n                    const buf = new Uint8Array(utf8.processJSString(data));\n                    FS.write(stream, buf, 0, buf.length, 0);\n                } else if (opts.encoding === 'binary') {\n                    FS.write(stream, data, 0, data.length, 0);\n                } else {\n                    throw new Error(\n                        'Invalid encoding type \"' + opts.encoding + '\"'\n                    );\n                }\n                FS.close(stream);\n            },\n            cwd: function() {\n                return FS.currentPath;\n            },\n            chdir: function(path) {\n                const lookup = FS.lookupPath(path, { follow: true });\n                if (!FS.isDir(lookup.node.mode)) {\n                    throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR);\n                }\n                const err = FS.nodePermissions(lookup.node, 'x');\n                if (err) {\n                    throw new FS.ErrnoError(err);\n                }\n                FS.currentPath = lookup.path;\n            },\n            createDefaultDirectories: function() {\n                FS.mkdir('/tmp');\n            },\n            createDefaultDevices: function() {\n                // create /dev\n                FS.mkdir('/dev');\n                // setup /dev/null\n                FS.registerDevice(FS.makedev(1, 3), {\n                    read: function() {\n                        return 0;\n                    },\n                    write: function() {\n                        return 0;\n                    }\n                });\n                FS.mkdev('/dev/null', FS.makedev(1, 3));\n                // setup /dev/tty and /dev/tty1\n                // stderr needs to print output using console.warn\n                // so we register a second tty just for it.\n                TTY.register(FS.makedev(5, 0), TTY.default_tty_ops);\n                TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops);\n                FS.mkdev('/dev/tty', FS.makedev(5, 0));\n                FS.mkdev('/dev/tty1', FS.makedev(6, 0));\n                // we're not going to emulate the actual shm device,\n                // just create the tmp dirs that reside in it commonly\n                FS.mkdir('/dev/shm');\n                FS.mkdir('/dev/shm/tmp');\n            },\n            createStandardStreams: function() {\n                // TODO deprecate the old functionality of a single\n                // input / output callback and that utilizes FS.createDevice\n                // and instead require a unique set of stream ops\n                // by default, we symlink the standard streams to the\n                // default tty devices. however, if the standard streams\n                // have been overwritten we create a unique device for\n                // them instead.\n                if (Module['stdin']) {\n                    FS.createDevice('/dev', 'stdin', Module['stdin']);\n                } else {\n                    FS.symlink('/dev/tty', '/dev/stdin');\n                }\n                if (Module['stdout']) {\n                    FS.createDevice('/dev', 'stdout', null, Module['stdout']);\n                } else {\n                    FS.symlink('/dev/tty', '/dev/stdout');\n                }\n                if (Module['stderr']) {\n                    FS.createDevice('/dev', 'stderr', null, Module['stderr']);\n                } else {\n                    FS.symlink('/dev/tty1', '/dev/stderr');\n                }\n                // open default streams for the stdin, stdout and stderr devices\n                const stdin = FS.open('/dev/stdin', 'r');\n                HEAP32[_stdin >> 2] = stdin.fd;\n                assert(\n                    stdin.fd === 1,\n                    'invalid handle for stdin (' + stdin.fd + ')'\n                );\n                const stdout = FS.open('/dev/stdout', 'w');\n                HEAP32[_stdout >> 2] = stdout.fd;\n                assert(\n                    stdout.fd === 2,\n                    'invalid handle for stdout (' + stdout.fd + ')'\n                );\n                const stderr = FS.open('/dev/stderr', 'w');\n                HEAP32[_stderr >> 2] = stderr.fd;\n                assert(\n                    stderr.fd === 3,\n                    'invalid handle for stderr (' + stderr.fd + ')'\n                );\n            },\n            staticInit: function() {\n                FS.nameTable = new Array(4096);\n                FS.root = FS.createNode(null, '/', 16384 | 0o777, 0);\n                FS.mount(MEMFS, {}, '/');\n                FS.createDefaultDirectories();\n                FS.createDefaultDevices();\n            },\n            init: function(input, output, error) {\n                assert(\n                    !FS.init.initialized,\n                    'FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)'\n                );\n                FS.init.initialized = true;\n                // Allow Module.stdin etc. to provide defaults, if none explicitly passed to us here\n                Module['stdin'] = input || Module['stdin'];\n                Module['stdout'] = output || Module['stdout'];\n                Module['stderr'] = error || Module['stderr'];\n                FS.createStandardStreams();\n            },\n            quit: function() {\n                FS.init.initialized = false;\n                for (let i = 0; i < FS.streams.length; i++) {\n                    const stream = FS.streams[i];\n                    if (!stream) {\n                        continue;\n                    }\n                    FS.close(stream);\n                }\n            },\n            getMode: function(canRead, canWrite) {\n                let mode = 0;\n                if (canRead) mode |= 292 | 73;\n                if (canWrite) mode |= 146;\n                return mode;\n            },\n            joinPath: function(parts, forceRelative) {\n                let path = PATH.join.apply(null, parts);\n                if (forceRelative && path[0] == '/') path = path.substr(1);\n                return path;\n            },\n            absolutePath: function(relative, base) {\n                return PATH.resolve(base, relative);\n            },\n            standardizePath: function(path) {\n                return PATH.normalize(path);\n            },\n            findObject: function(path, dontResolveLastLink) {\n                const ret = FS.analyzePath(path, dontResolveLastLink);\n                if (ret.exists) {\n                    return ret.object;\n                } else {\n                    ___setErrNo(ret.error);\n                    return null;\n                }\n            },\n            analyzePath: function(path, dontResolveLastLink) {\n                // operate from within the context of the symlink's target\n                try {\n                    var lookup = FS.lookupPath(path, {\n                        follow: !dontResolveLastLink\n                    });\n                    path = lookup.path;\n                } catch (e) {}\n                const ret = {\n                    isRoot: false,\n                    exists: false,\n                    error: 0,\n                    name: null,\n                    path: null,\n                    object: null,\n                    parentExists: false,\n                    parentPath: null,\n                    parentObject: null\n                };\n                try {\n                    var lookup = FS.lookupPath(path, { parent: true });\n                    ret.parentExists = true;\n                    ret.parentPath = lookup.path;\n                    ret.parentObject = lookup.node;\n                    ret.name = PATH.basename(path);\n                    lookup = FS.lookupPath(path, {\n                        follow: !dontResolveLastLink\n                    });\n                    ret.exists = true;\n                    ret.path = lookup.path;\n                    ret.object = lookup.node;\n                    ret.name = lookup.node.name;\n                    ret.isRoot = lookup.path === '/';\n                } catch (e) {\n                    ret.error = e.errno;\n                }\n                return ret;\n            },\n            createFolder: function(parent, name, canRead, canWrite) {\n                const path = PATH.join(\n                    typeof parent === 'string' ? parent : FS.getPath(parent),\n                    name\n                );\n                const mode = FS.getMode(canRead, canWrite);\n                return FS.mkdir(path, mode);\n            },\n\n            /**\n             * Creates a directory.\n             * @function createPath\n             * @memberof LibTiMidity\n             * @instance\n             * @param {string} parent The parent folder.\n             * @param {string} path The path to create.\n             * @param {boolean} [throwError = true] If directory creation failed, throw an error.\n             */\n            createPath: function(parent, path, throwError = true) {\n                const parts = path.split('/').reverse();\n                while (parts.length) {\n                    const part = parts.pop();\n                    if (!part) {\n                        continue;\n                    }\n                    const current = PATH.join(parent, part);\n                    try {\n                        FS.mkdir(current, undefined, throwError);\n                    } catch (error) {\n                        // console.error(error)\n                    }\n                    parent = current;\n                }\n            },\n\n            /**\n             * Creates a file.\n             * @function createFile\n             * @memberof LibTiMidity\n             * @instance\n             * @param {string} parent The parent folder.\n             * @param {string} name The path to create.\n             * @param {boolean} canRead\n             * @param {boolean} canWrite\n             */\n            createFile: function(parent, name, canRead, canWrite) {\n                const path = PATH.join(\n                    typeof parent === 'string' ? parent : FS.getPath(parent),\n                    name\n                );\n                const mode = FS.getMode(canRead, canWrite);\n                return FS.create(path, mode);\n            },\n\n            /**\n             * Creates a data file and writes data to it.\n             * @function createDataFile\n             * @memberof LibTiMidity\n             * @instance\n             * @param {string} parent\n             * @param {string} name\n             * @param {array} data\n             * @param {boolean} canRead\n             * @param {boolean} canWrite\n             * @param {boolean} [canOwn]\n             * @param {boolean} [throwError = true] If file creation failed, throw an error.\n             */\n\n            createDataFile: function(\n                parent,\n                name,\n                data,\n                canRead,\n                canWrite,\n                canOwn,\n                throwError = true\n            ) {\n                const path = name\n                    ? PATH.join(\n                          typeof parent === 'string'\n                              ? parent\n                              : FS.getPath(parent),\n                          name\n                      )\n                    : parent;\n                const mode = FS.getMode(canRead, canWrite);\n\n                if (throwError) {\n                    FS.create(path, mode);\n                } else {\n                    try {\n                        FS.create(path, mode);\n                    } catch (error) {\n                        return;\n                    }\n                }\n\n                if (data) {\n                    if (typeof data === 'string') {\n                        let arr = new Array(data.length);\n                        for (let i = 0, len = data.length; i < len; ++i) {\n                            arr[i] = data.charCodeAt(i);\n                        }\n                        data = arr;\n                    }\n\n                    // make sure we can write to the file\n                    FS.chmod(path, mode | 146);\n                    const stream = FS.open(path, 'w');\n                    FS.write(stream, data, 0, data.length, 0, canOwn);\n                    FS.close(stream);\n                    FS.chmod(path, mode);\n                }\n            },\n\n            /**\n             * Creates a file in the patch directory and writes the instrument data to it.\n             * @function loadPatchFromUrl\n             * @memberof LibTiMidity\n             * @instance\n             * @param {string} baseUrl The public URL where all patches can be found as a group.\n             * @param {string} filename The name of the instrument patch to load (including subfolder for drums).\n             */\n\n            loadPatchFromUrl: async function(baseUrl, filename) {\n                const response = await fetch(`${baseUrl}${filename}`);\n                if (response.status !== 200) {\n                    throw new Error(JSON.stringify(response));\n                }\n\n                const arrayBuffer = await response.arrayBuffer();\n\n                const data = new Int8Array(arrayBuffer);\n                const mode = FS.getMode(true, true);\n                const path = PATH.join(LIBTIMIDITY_PATCH_DIRECTORY, filename);\n\n                FS.create(path, mode);\n                FS.chmod(path, mode | 146);\n                const stream = FS.open(path, 'w');\n                FS.write(stream, data, 0, data.length, 0, undefined);\n                FS.close(stream);\n                FS.chmod(path, mode);\n            },\n\n            createDevice: function(parent, name, input, output) {\n                const path = PATH.join(\n                    typeof parent === 'string' ? parent : FS.getPath(parent),\n                    name\n                );\n                const mode = FS.getMode(!!input, !!output);\n                if (!FS.createDevice.major) FS.createDevice.major = 64;\n                const dev = FS.makedev(FS.createDevice.major++, 0);\n                // Create a fake device that a set of stream ops to emulate he old behavior.\n                FS.registerDevice(dev, {\n                    open: function(stream) {\n                        stream.seekable = false;\n                    },\n                    close: function() {\n                        // flush any pending line data\n                        if (output && output.buffer && output.buffer.length) {\n                            output(10);\n                        }\n                    },\n                    read: function(stream, buffer, offset, length) {\n                        let bytesRead = 0;\n                        for (let i = 0; i < length; i++) {\n                            let result;\n                            try {\n                                result = input();\n                            } catch (e) {\n                                throw new FS.ErrnoError(ERRNO_CODES.EIO);\n                            }\n                            if (result === undefined && bytesRead === 0) {\n                                throw new FS.ErrnoError(ERRNO_CODES.EAGAIN);\n                            }\n                            if (result === null || result === undefined) break;\n                            bytesRead++;\n                            buffer[offset + i] = result;\n                        }\n                        if (bytesRead) {\n                            stream.node.timestamp = Date.now();\n                        }\n                        return bytesRead;\n                    },\n                    write: function(stream, buffer, offset, length) {\n                        for (var i = 0; i < length; i++) {\n                            try {\n                                output(buffer[offset + i]);\n                            } catch (e) {\n                                throw new FS.ErrnoError(ERRNO_CODES.EIO);\n                            }\n                        }\n                        if (length) {\n                            stream.node.timestamp = Date.now();\n                        }\n                        return i;\n                    }\n                });\n                return FS.mkdev(path, mode, dev);\n            },\n            createLink: function(parent, name, target) {\n                const path = PATH.join(\n                    typeof parent === 'string' ? parent : FS.getPath(parent),\n                    name\n                );\n                return FS.symlink(target, path);\n            },\n            createPreloadedFile: function(\n                parent,\n                name,\n                url,\n                canRead,\n                canWrite,\n                onload,\n                dontCreateFile,\n                canOwn\n            ) {\n                // TODO we should allow people to just pass in a complete filename instead of parent and name being that we just join them anyways\n                const fullname = name\n                    ? PATH.resolve(PATH.join(parent, name))\n                    : parent;\n                function processData(byteArray) {\n                    function finish(byteArray) {\n                        if (!dontCreateFile) {\n                            FS.createDataFile(\n                                parent,\n                                name,\n                                byteArray,\n                                canRead,\n                                canWrite,\n                                canOwn\n                            );\n                        }\n                        if (onload) onload();\n                        removeRunDependency('cp ' + fullname);\n                    }\n                    finish(byteArray);\n                }\n                addRunDependency('cp ' + fullname);\n                processData(url);\n            },\n            indexedDB: function() {\n                return (\n                    window.indexedDB ||\n                    window.mozIndexedDB ||\n                    window.webkitIndexedDB ||\n                    window.msIndexedDB\n                );\n            },\n            DB_NAME: function() {\n                return 'EM_FS_' + window.location.pathname;\n            },\n            DB_VERSION: 20,\n            DB_STORE_NAME: 'FILE_DATA',\n            saveFilesToDB: function(paths, onload, onerror) {\n                onload = onload || function() {};\n                onerror = onerror || function() {};\n                const indexedDB = FS.indexedDB();\n                try {\n                    var openRequest = indexedDB.open(\n                        FS.DB_NAME(),\n                        FS.DB_VERSION\n                    );\n                } catch (e) {\n                    return onerror(e);\n                }\n                openRequest.onupgradeneeded = function() {\n                    const db = openRequest.result;\n                    db.createObjectStore(FS.DB_STORE_NAME);\n                };\n                openRequest.onsuccess = function() {\n                    const db = openRequest.result;\n                    const transaction = db.transaction(\n                        [FS.DB_STORE_NAME],\n                        'readwrite'\n                    );\n                    const files = transaction.objectStore(FS.DB_STORE_NAME);\n                    let ok = 0,\n                        fail = 0,\n                        total = paths.length;\n                    function finish() {\n                        if (fail == 0) onload();\n                        else onerror();\n                    }\n                    paths.forEach(function(path) {\n                        const putRequest = files.put(\n                            FS.analyzePath(path).object.contents,\n                            path\n                        );\n                        putRequest.onsuccess = function() {\n                            ok++;\n                            if (ok + fail == total) finish();\n                        };\n                        putRequest.onerror = function() {\n                            fail++;\n                            if (ok + fail == total) finish();\n                        };\n                    });\n                    transaction.onerror = onerror;\n                };\n                openRequest.onerror = onerror;\n            },\n            loadFilesFromDB: function(paths, onload, onerror) {\n                onload = onload || function() {};\n                onerror = onerror || function() {};\n                const indexedDB = FS.indexedDB();\n                try {\n                    var openRequest = indexedDB.open(\n                        FS.DB_NAME(),\n                        FS.DB_VERSION\n                    );\n                } catch (e) {\n                    return onerror(e);\n                }\n                openRequest.onupgradeneeded = onerror; // no database to load from\n                openRequest.onsuccess = function() {\n                    const db = openRequest.result;\n                    try {\n                        var transaction = db.transaction(\n                            [FS.DB_STORE_NAME],\n                            'readonly'\n                        );\n                    } catch (e) {\n                        onerror(e);\n                        return;\n                    }\n                    const files = transaction.objectStore(FS.DB_STORE_NAME);\n                    let ok = 0,\n                        fail = 0,\n                        total = paths.length;\n                    function finish() {\n                        if (fail == 0) onload();\n                        else onerror();\n                    }\n                    paths.forEach(function(path) {\n                        const getRequest = files.get(path);\n                        getRequest.onsuccess = function() {\n                            if (FS.analyzePath(path).exists) {\n                                FS.unlink(path);\n                            }\n                            FS.createDataFile(\n                                PATH.dirname(path),\n                                PATH.basename(path),\n                                getRequest.result,\n                                true,\n                                true,\n                                true\n                            );\n                            ok++;\n                            if (ok + fail == total) finish();\n                        };\n                        getRequest.onerror = function() {\n                            fail++;\n                            if (ok + fail == total) finish();\n                        };\n                    });\n                    transaction.onerror = onerror;\n                };\n                openRequest.onerror = onerror;\n            }\n        };\n        function _open(path, oflag, varargs) {\n            // int open(const char *path, int oflag, ...);\n            // http://pubs.opengroup.org/onlinepubs/009695399/functions/open.html\n            const mode = HEAP32[varargs >> 2];\n            path = Pointer_stringify(path);\n            try {\n                const stream = FS.open(path, oflag, mode);\n                return stream.fd;\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _fopen(filename, mode) {\n            // FILE *fopen(const char *restrict filename, const char *restrict mode);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fopen.html\n            let flags;\n            mode = Pointer_stringify(mode);\n            if (mode[0] == 'r') {\n                if (mode.indexOf('+') != -1) {\n                    flags = 2;\n                } else {\n                    flags = 0;\n                }\n            } else if (mode[0] == 'w') {\n                if (mode.indexOf('+') != -1) {\n                    flags = 2;\n                } else {\n                    flags = 1;\n                }\n                flags |= 64;\n                flags |= 512;\n            } else if (mode[0] == 'a') {\n                if (mode.indexOf('+') != -1) {\n                    flags = 2;\n                } else {\n                    flags = 1;\n                }\n                flags |= 64;\n                flags |= 1024;\n            } else {\n                ___setErrNo(ERRNO_CODES.EINVAL);\n                return 0;\n            }\n            const ret = _open(\n                filename,\n                flags,\n                allocate([0x1ff, 0, 0, 0], 'i32', ALLOC_STACK)\n            ); // All creation permissions.\n            return ret == -1 ? 0 : ret;\n        }\n        Module['_strlen'] = _strlen;\n        Module['_strcpy'] = _strcpy;\n        Module['_strcat'] = _strcat;\n        const SOCKFS = {\n            mount: function() {\n                return FS.createNode(null, '/', 16384 | 0o777, 0);\n            },\n            createSocket: function(family, type, protocol) {\n                const streaming = type == 1;\n                if (protocol) {\n                    assert(streaming == (protocol == 6)); // if SOCK_STREAM, must be tcp\n                }\n                // create our internal socket structure\n                const sock = {\n                    family: family,\n                    type: type,\n                    protocol: protocol,\n                    server: null,\n                    peers: {},\n                    pending: [],\n                    recv_queue: [],\n                    sock_ops: SOCKFS.websocket_sock_ops\n                };\n                // create the filesystem node to store the socket structure\n                const name = SOCKFS.nextname();\n                const node = FS.createNode(SOCKFS.root, name, 49152, 0);\n                node.sock = sock;\n                // and the wrapping stream that enables library functions such as read and write to indirectly interact with the socket\n                const stream = FS.createStream({\n                    path: name,\n                    node: node,\n                    flags: FS.modeStringToFlags('r+'),\n                    seekable: false,\n                    stream_ops: SOCKFS.stream_ops\n                });\n                // map the new stream to the socket structure (sockets have a 1:1 relationship with a stream)\n                sock.stream = stream;\n                return sock;\n            },\n            getSocket: function(fd) {\n                const stream = FS.getStream(fd);\n                if (!stream || !FS.isSocket(stream.node.mode)) {\n                    return null;\n                }\n                return stream.node.sock;\n            },\n            stream_ops: {\n                poll: function(stream) {\n                    const sock = stream.node.sock;\n                    return sock.sock_ops.poll(sock);\n                },\n                ioctl: function(stream, request, varargs) {\n                    const sock = stream.node.sock;\n                    return sock.sock_ops.ioctl(sock, request, varargs);\n                },\n                read: function(stream, buffer, offset, length) {\n                    const sock = stream.node.sock;\n                    const msg = sock.sock_ops.recvmsg(sock, length);\n                    if (!msg) {\n                        // socket is closed\n                        return 0;\n                    }\n                    buffer.set(msg.buffer, offset);\n                    return msg.buffer.length;\n                },\n                write: function(stream, buffer, offset, length) {\n                    const sock = stream.node.sock;\n                    return sock.sock_ops.sendmsg(sock, buffer, offset, length);\n                },\n                close: function(stream) {\n                    const sock = stream.node.sock;\n                    sock.sock_ops.close(sock);\n                }\n            },\n            nextname: function() {\n                if (!SOCKFS.nextname.current) {\n                    SOCKFS.nextname.current = 0;\n                }\n                return 'socket[' + SOCKFS.nextname.current++ + ']';\n            },\n            websocket_sock_ops: {\n                createPeer: function(sock, addr, port) {\n                    let ws;\n                    if (typeof addr === 'object') {\n                        ws = addr;\n                        addr = null;\n                        port = null;\n                    }\n                    if (ws) {\n                        // for sockets that've already connected (e.g. we're the server) we can inspect the _socket property for the address\n                        if (ws._socket) {\n                            addr = ws._socket.remoteAddress;\n                            port = ws._socket.remotePort;\n                        }\n                        // if we're just now initializing a connection to the remote, inspect the url property\n                        else {\n                            const result = /ws[s]?:\\/\\/([^:]+):(\\d+)/.exec(\n                                ws.url\n                            );\n                            if (!result) {\n                                throw new Error(\n                                    'WebSocket URL must be in the format ws(s)://address:port'\n                                );\n                            }\n                            addr = result[1];\n                            port = parseInt(result[2], 10);\n                        }\n                    } else {\n                        // create the actual websocket object and connect\n                        try {\n                            var url = 'ws://' + addr + ':' + port;\n                            // the node ws library API is slightly different than the browser's\n                            const opts = ['binary'];\n                            ws = new WebSocket(url, opts);\n                            ws.binaryType = 'arraybuffer';\n                        } catch (e) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EHOSTUNREACH);\n                        }\n                    }\n                    const peer = {\n                        addr: addr,\n                        port: port,\n                        socket: ws,\n                        dgram_send_queue: []\n                    };\n                    SOCKFS.websocket_sock_ops.addPeer(sock, peer);\n                    SOCKFS.websocket_sock_ops.handlePeerEvents(sock, peer);\n                    // if this is a bound dgram socket, send the port number first to allow\n                    // us to override the ephemeral port reported to us by remotePort on the\n                    // remote end.\n                    if (sock.type === 2 && typeof sock.sport !== 'undefined') {\n                        peer.dgram_send_queue.push(\n                            new Uint8Array([\n                                255,\n                                255,\n                                255,\n                                255,\n                                'p'.charCodeAt(0),\n                                'o'.charCodeAt(0),\n                                'r'.charCodeAt(0),\n                                't'.charCodeAt(0),\n                                (sock.sport & 0xff00) >> 8,\n                                sock.sport & 0xff\n                            ])\n                        );\n                    }\n                    return peer;\n                },\n                getPeer: function(sock, addr, port) {\n                    return sock.peers[addr + ':' + port];\n                },\n                addPeer: function(sock, peer) {\n                    sock.peers[peer.addr + ':' + peer.port] = peer;\n                },\n                removePeer: function(sock, peer) {\n                    delete sock.peers[peer.addr + ':' + peer.port];\n                },\n                handlePeerEvents: function(sock, peer) {\n                    let first = true;\n                    const handleOpen = function() {\n                        try {\n                            let queued = peer.dgram_send_queue.shift();\n                            while (queued) {\n                                peer.socket.send(queued);\n                                queued = peer.dgram_send_queue.shift();\n                            }\n                        } catch (e) {\n                            // not much we can do here in the way of proper error handling as we've already\n                            // lied and said this data was sent. shut it down.\n                            peer.socket.close();\n                        }\n                    };\n                    const handleMessage = function(data) {\n                        assert(\n                            typeof data !== 'string' &&\n                                data.byteLength !== undefined\n                        ); // must receive an ArrayBuffer\n                        data = new Uint8Array(data); // make a typed array view on the array buffer\n                        // if this is the port message, override the peer's port with it\n                        const wasfirst = first;\n                        first = false;\n                        if (\n                            wasfirst &&\n                            data.length === 10 &&\n                            data[0] === 255 &&\n                            data[1] === 255 &&\n                            data[2] === 255 &&\n                            data[3] === 255 &&\n                            data[4] === 'p'.charCodeAt(0) &&\n                            data[5] === 'o'.charCodeAt(0) &&\n                            data[6] === 'r'.charCodeAt(0) &&\n                            data[7] === 't'.charCodeAt(0)\n                        ) {\n                            // update the peer's port and it's key in the peer map\n                            const newport = (data[8] << 8) | data[9];\n                            SOCKFS.websocket_sock_ops.removePeer(sock, peer);\n                            peer.port = newport;\n                            SOCKFS.websocket_sock_ops.addPeer(sock, peer);\n                            return;\n                        }\n                        sock.recv_queue.push({\n                            addr: peer.addr,\n                            port: peer.port,\n                            data: data\n                        });\n                    };\n                    peer.socket.onopen = handleOpen;\n                    peer.socket.onmessage = function(event) {\n                        handleMessage(event.data);\n                    };\n                },\n                poll: function(sock) {\n                    if (sock.type === 1 && sock.server) {\n                        // listen sockets should only say they're available for reading\n                        // if there are pending clients.\n                        return sock.pending.length ? 64 | 1 : 0;\n                    }\n                    let mask = 0;\n                    const dest =\n                        sock.type === 1 // we only care about the socket state for connection-based sockets\n                            ? SOCKFS.websocket_sock_ops.getPeer(\n                                  sock,\n                                  sock.daddr,\n                                  sock.dport\n                              )\n                            : null;\n                    if (\n                        sock.recv_queue.length ||\n                        !dest || // connection-less sockets are always ready to read\n                        (dest &&\n                            dest.socket.readyState === dest.socket.CLOSING) ||\n                        (dest && dest.socket.readyState === dest.socket.CLOSED)\n                    ) {\n                        // let recv return 0 once closed\n                        mask |= 64 | 1;\n                    }\n                    if (\n                        !dest || // connection-less sockets are always ready to write\n                        (dest && dest.socket.readyState === dest.socket.OPEN)\n                    ) {\n                        mask |= 4;\n                    }\n                    if (\n                        (dest &&\n                            dest.socket.readyState === dest.socket.CLOSING) ||\n                        (dest && dest.socket.readyState === dest.socket.CLOSED)\n                    ) {\n                        mask |= 16;\n                    }\n                    return mask;\n                },\n                ioctl: function(sock, request, arg) {\n                    switch (request) {\n                        case 21531:\n                            let bytes = 0;\n                            if (sock.recv_queue.length) {\n                                bytes = sock.recv_queue[0].data.length;\n                            }\n                            HEAP32[arg >> 2] = bytes;\n                            return 0;\n                        default:\n                            return ERRNO_CODES.EINVAL;\n                    }\n                },\n                close: function(sock) {\n                    // if we've spawned a listen server, close it\n                    if (sock.server) {\n                        try {\n                            sock.server.close();\n                        } catch (e) {}\n                        sock.server = null;\n                    }\n                    // close any peer connections\n                    const peers = Object.keys(sock.peers);\n                    for (let i = 0; i < peers.length; i++) {\n                        const peer = sock.peers[peers[i]];\n                        try {\n                            peer.socket.close();\n                        } catch (e) {}\n                        SOCKFS.websocket_sock_ops.removePeer(sock, peer);\n                    }\n                    return 0;\n                },\n                bind: function(sock, addr, port) {\n                    if (\n                        typeof sock.saddr !== 'undefined' ||\n                        typeof sock.sport !== 'undefined'\n                    ) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EINVAL); // already bound\n                    }\n                    sock.saddr = addr;\n                    sock.sport = port || _mkport();\n                    // in order to emulate dgram sockets, we need to launch a listen server when binding on a connection-less socket\n                    // note: this is only required on the server side\n                    if (sock.type === 2) {\n                        // close the existing server if it exists\n                        if (sock.server) {\n                            sock.server.close();\n                            sock.server = null;\n                        }\n                        // swallow error operation not supported error that occurs when binding in the\n                        // browser where this isn't supported\n                        try {\n                            sock.sock_ops.listen(sock, 0);\n                        } catch (e) {\n                            if (!(e instanceof FS.ErrnoError)) throw e;\n                            if (e.errno !== ERRNO_CODES.EOPNOTSUPP) throw e;\n                        }\n                    }\n                },\n                connect: function(sock, addr, port) {\n                    if (sock.server) {\n                        throw new FS.ErrnoError(ERRNO_CODS.EOPNOTSUPP);\n                    }\n                    if (\n                        typeof sock.daddr !== 'undefined' &&\n                        typeof sock.dport !== 'undefined'\n                    ) {\n                        const dest = SOCKFS.websocket_sock_ops.getPeer(\n                            sock,\n                            sock.daddr,\n                            sock.dport\n                        );\n                        if (dest) {\n                            if (\n                                dest.socket.readyState ===\n                                dest.socket.CONNECTING\n                            ) {\n                                throw new FS.ErrnoError(ERRNO_CODES.EALREADY);\n                            } else {\n                                throw new FS.ErrnoError(ERRNO_CODES.EISCONN);\n                            }\n                        }\n                    }\n                    // add the socket to our peer list and set our destination address / port to match\n                    const peer = SOCKFS.websocket_sock_ops.createPeer(\n                        sock,\n                        addr,\n                        port\n                    );\n                    sock.daddr = peer.addr;\n                    sock.dport = peer.port;\n                    // always \"fail\" in non-blocking mode\n                    throw new FS.ErrnoError(ERRNO_CODES.EINPROGRESS);\n                },\n                listen: function(sock) {\n                    if (sock.server) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EINVAL); // already listening\n                    }\n                    const WebSocketServer = require('ws').Server;\n                    const host = sock.saddr;\n                    sock.server = new WebSocketServer({\n                        host: host,\n                        port: sock.sport\n                    });\n                    sock.server.on('connection', function(ws) {\n                        if (sock.type === 1) {\n                            const newsock = SOCKFS.createSocket(\n                                sock.family,\n                                sock.type,\n                                sock.protocol\n                            );\n                            // create a peer on the new socket\n                            const peer = SOCKFS.websocket_sock_ops.createPeer(\n                                newsock,\n                                ws\n                            );\n                            newsock.daddr = peer.addr;\n                            newsock.dport = peer.port;\n                            // push to queue for accept to pick up\n                            sock.pending.push(newsock);\n                        } else {\n                            // create a peer on the listen socket so calling sendto with the listen socket and an address will resolve to the correct client\n                            SOCKFS.websocket_sock_ops.createPeer(sock, ws);\n                        }\n                    });\n                    sock.server.on('closed', function() {\n                        sock.server = null;\n                    });\n                    sock.server.on('error', function() {\n                        // don't throw\n                    });\n                },\n                accept: function(listensock) {\n                    if (!listensock.server) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                    }\n                    const newsock = listensock.pending.shift();\n                    newsock.stream.flags = listensock.stream.flags;\n                    return newsock;\n                },\n                getname: function(sock, peer) {\n                    let addr, port;\n                    if (peer) {\n                        if (\n                            sock.daddr === undefined ||\n                            sock.dport === undefined\n                        ) {\n                            throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN);\n                        }\n                        addr = sock.daddr;\n                        port = sock.dport;\n                    } else {\n                        addr = sock.saddr || 0;\n                        port = sock.sport || 0;\n                    }\n                    return { addr: addr, port: port };\n                },\n                sendmsg: function(sock, buffer, offset, length, addr, port) {\n                    if (sock.type === 2) {\n                        // connection-less sockets will honor the message address, and otherwise fall back to the bound destination address\n                        if (addr === undefined || port === undefined) {\n                            addr = sock.daddr;\n                            port = sock.dport;\n                        }\n                        // if there was no address to fall back to, error out\n                        if (addr === undefined || port === undefined) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EDESTADDRREQ);\n                        }\n                    } else {\n                        // connection-based sockets will only use the bound\n                        addr = sock.daddr;\n                        port = sock.dport;\n                    }\n                    // find the peer for the destination address\n                    let dest = SOCKFS.websocket_sock_ops.getPeer(\n                        sock,\n                        addr,\n                        port\n                    );\n                    // early out if not connected with a connection-based socket\n                    if (sock.type === 1) {\n                        if (\n                            !dest ||\n                            dest.socket.readyState === dest.socket.CLOSING ||\n                            dest.socket.readyState === dest.socket.CLOSED\n                        ) {\n                            throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN);\n                        } else if (\n                            dest.socket.readyState === dest.socket.CONNECTING\n                        ) {\n                            throw new FS.ErrnoError(ERRNO_CODES.EAGAIN);\n                        }\n                    }\n                    // create a copy of the incoming data to send, as the WebSocket API doesn't work entirely with an ArrayBufferView, it'll just send the entire underlying buffer\n                    let data;\n                    if (\n                        buffer instanceof Array ||\n                        buffer instanceof ArrayBuffer\n                    ) {\n                        data = buffer.slice(offset, offset + length);\n                    } else {\n                        // ArrayBufferView\n                        data = buffer.buffer.slice(\n                            buffer.byteOffset + offset,\n                            buffer.byteOffset + offset + length\n                        );\n                    }\n                    // if we're emulating a connection-less dgram socket and don't have a cached connection, queue the buffer to send upon connect and lie, saying the data was sent now.\n                    if (sock.type === 2) {\n                        if (\n                            !dest ||\n                            dest.socket.readyState !== dest.socket.OPEN\n                        ) {\n                            // if we're not connected, open a new connection\n                            if (\n                                !dest ||\n                                dest.socket.readyState ===\n                                    dest.socket.CLOSING ||\n                                dest.socket.readyState === dest.socket.CLOSED\n                            ) {\n                                dest = SOCKFS.websocket_sock_ops.createPeer(\n                                    sock,\n                                    addr,\n                                    port\n                                );\n                            }\n                            dest.dgram_send_queue.push(data);\n                            return length;\n                        }\n                    }\n                    try {\n                        // send the actual data\n                        dest.socket.send(data);\n                        return length;\n                    } catch (e) {\n                        throw new FS.ErrnoError(ERRNO_CODES.EINVAL);\n                    }\n                },\n                recvmsg: function(sock, length) {\n                    // http://pubs.opengroup.org/onlinepubs/7908799/xns/recvmsg.html\n                    if (sock.type === 1 && sock.server) {\n                        // tcp servers should not be recv()'ing on the listen socket\n                        throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN);\n                    }\n                    const queued = sock.recv_queue.shift();\n                    if (!queued) {\n                        if (sock.type === 1) {\n                            const dest = SOCKFS.websocket_sock_ops.getPeer(\n                                sock,\n                                sock.daddr,\n                                sock.dport\n                            );\n                            if (!dest) {\n                                // if we have a destination address but are not connected, error out\n                                throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN);\n                            } else if (\n                                dest.socket.readyState ===\n                                    dest.socket.CLOSING ||\n                                dest.socket.readyState === dest.socket.CLOSED\n                            ) {\n                                // return null if the socket has closed\n                                return null;\n                            } else {\n                                // else, our socket is in a valid state but truly has nothing available\n                                throw new FS.ErrnoError(ERRNO_CODES.EAGAIN);\n                            }\n                        } else {\n                            throw new FS.ErrnoError(ERRNO_CODES.EAGAIN);\n                        }\n                    }\n                    // queued.data will be an ArrayBuffer if it's unadulterated, but if it's requeued TCP data it'll be an ArrayBufferView\n                    const queuedLength =\n                        queued.data.byteLength || queued.data.length;\n                    const queuedOffset = queued.data.byteOffset || 0;\n                    const queuedBuffer = queued.data.buffer || queued.data;\n                    const bytesRead = Math.min(length, queuedLength);\n                    const res = {\n                        buffer: new Uint8Array(\n                            queuedBuffer,\n                            queuedOffset,\n                            bytesRead\n                        ),\n                        addr: queued.addr,\n                        port: queued.port\n                    };\n                    // push back any unread data for TCP connections\n                    if (sock.type === 1 && bytesRead < queuedLength) {\n                        const bytesRemaining = queuedLength - bytesRead;\n                        queued.data = new Uint8Array(\n                            queuedBuffer,\n                            queuedOffset + bytesRead,\n                            bytesRemaining\n                        );\n                        sock.recv_queue.unshift(queued);\n                    }\n                    return res;\n                }\n            }\n        };\n        function _send(fd, buf, len) {\n            const sock = SOCKFS.getSocket(fd);\n            if (!sock) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            return _write(fd, buf, len);\n        }\n        function _pwrite(fildes, buf, nbyte, offset) {\n            // ssize_t pwrite(int fildes, const void *buf, size_t nbyte, off_t offset);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/write.html\n            const stream = FS.getStream(fildes);\n            if (!stream) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            try {\n                const slab = HEAP8;\n                return FS.write(stream, slab, buf, nbyte, offset);\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _write(fildes, buf, nbyte) {\n            // ssize_t write(int fildes, const void *buf, size_t nbyte);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/write.html\n            const stream = FS.getStream(fildes);\n            if (!stream) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            try {\n                const slab = HEAP8;\n                return FS.write(stream, slab, buf, nbyte);\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _fwrite(ptr, size, nitems, stream) {\n            // size_t fwrite(const void *restrict ptr, size_t size, size_t nitems, FILE *restrict stream);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fwrite.html\n            const bytesToWrite = nitems * size;\n            if (bytesToWrite == 0) return 0;\n            const bytesWritten = _write(stream, ptr, bytesToWrite);\n            if (bytesWritten == -1) {\n                const streamObj = FS.getStream(stream);\n                if (streamObj) streamObj.error = true;\n                return 0;\n            } else {\n                return Math.floor(bytesWritten / size);\n            }\n        }\n        function __reallyNegative(x) {\n            return x < 0 || (x === 0 && 1 / x === -Infinity);\n        }\n        function __formatString(format, varargs) {\n            let textIndex = format;\n            let argIndex = 0;\n            function getNextArg(type) {\n                // NOTE: Explicitly ignoring type safety. Otherwise this fails:\n                //       int x = 4; printf(\"%c\\n\", (char)x);\n                let ret;\n                if (type === 'double') {\n                    ret = HEAPF64[(varargs + argIndex) >> 3];\n                } else if (type == 'i64') {\n                    ret = [\n                        HEAP32[(varargs + argIndex) >> 2],\n                        HEAP32[(varargs + (argIndex + 8)) >> 2]\n                    ];\n                    argIndex += 8; // each 32-bit chunk is in a 64-bit block\n                } else {\n                    type = 'i32'; // varargs are always i32, i64, or double\n                    ret = HEAP32[(varargs + argIndex) >> 2];\n                }\n                argIndex += Math.max(\n                    Runtime.getNativeFieldSize(type),\n                    Runtime.getAlignSize(type, null, true)\n                );\n                return ret;\n            }\n            var ret = [];\n            var curr, next, currArg;\n            while (1) {\n                const startTextIndex = textIndex;\n                curr = HEAP8[textIndex];\n                if (curr === 0) break;\n                next = HEAP8[(textIndex + 1) | 0];\n                if (curr == 37) {\n                    // Handle flags.\n                    let flagAlwaysSigned = false;\n                    let flagLeftAlign = false;\n                    let flagAlternative = false;\n                    let flagZeroPad = false;\n                    let flagPadSign = false;\n                    flagsLoop: while (1) {\n                        switch (next) {\n                            case 43:\n                                flagAlwaysSigned = true;\n                                break;\n                            case 45:\n                                flagLeftAlign = true;\n                                break;\n                            case 35:\n                                flagAlternative = true;\n                                break;\n                            case 48:\n                                if (flagZeroPad) {\n                                    break flagsLoop;\n                                } else {\n                                    flagZeroPad = true;\n                                    break;\n                                }\n                            case 32:\n                                flagPadSign = true;\n                                break;\n                            default:\n                                break flagsLoop;\n                        }\n                        textIndex++;\n                        next = HEAP8[(textIndex + 1) | 0];\n                    }\n                    // Handle width.\n                    let width = 0;\n                    if (next == 42) {\n                        width = getNextArg('i32');\n                        textIndex++;\n                        next = HEAP8[(textIndex + 1) | 0];\n                    } else {\n                        while (next >= 48 && next <= 57) {\n                            width = width * 10 + (next - 48);\n                            textIndex++;\n                            next = HEAP8[(textIndex + 1) | 0];\n                        }\n                    }\n                    // Handle precision.\n                    let precisionSet = false;\n                    if (next == 46) {\n                        var precision = 0;\n                        precisionSet = true;\n                        textIndex++;\n                        next = HEAP8[(textIndex + 1) | 0];\n                        if (next == 42) {\n                            precision = getNextArg('i32');\n                            textIndex++;\n                        } else {\n                            while (1) {\n                                const precisionChr = HEAP8[(textIndex + 1) | 0];\n                                if (precisionChr < 48 || precisionChr > 57)\n                                    break;\n                                precision =\n                                    precision * 10 + (precisionChr - 48);\n                                textIndex++;\n                            }\n                        }\n                        next = HEAP8[(textIndex + 1) | 0];\n                    } else {\n                        var precision = 6; // Standard default.\n                    }\n                    // Handle integer sizes. WARNING: These assume a 32-bit architecture!\n                    let argSize;\n                    switch (String.fromCharCode(next)) {\n                        case 'h':\n                            var nextNext = HEAP8[(textIndex + 2) | 0];\n                            if (nextNext == 104) {\n                                textIndex++;\n                                argSize = 1; // char (actually i32 in varargs)\n                            } else {\n                                argSize = 2; // short (actually i32 in varargs)\n                            }\n                            break;\n                        case 'l':\n                            var nextNext = HEAP8[(textIndex + 2) | 0];\n                            if (nextNext == 108) {\n                                textIndex++;\n                                argSize = 8; // long long\n                            } else {\n                                argSize = 4; // long\n                            }\n                            break;\n                        case 'L': // long long\n                        case 'q': // int64_t\n                        case 'j': // intmax_t\n                            argSize = 8;\n                            break;\n                        case 'z': // size_t\n                        case 't': // ptrdiff_t\n                        case 'I': // signed ptrdiff_t or unsigned size_t\n                            argSize = 4;\n                            break;\n                        default:\n                            argSize = null;\n                    }\n                    if (argSize) textIndex++;\n                    next = HEAP8[(textIndex + 1) | 0];\n                    // Handle type specifier.\n                    switch (String.fromCharCode(next)) {\n                        case 'd':\n                        case 'i':\n                        case 'u':\n                        case 'o':\n                        case 'x':\n                        case 'X':\n                        case 'p': {\n                            // Integer.\n                            const signed = next == 100 || next == 105;\n                            argSize = argSize || 4;\n                            var currArg = getNextArg('i' + argSize * 8);\n                            const origArg = currArg;\n                            var argText;\n                            // Flatten i64-1 [low, high] into a (slightly rounded) double\n                            if (argSize == 8) {\n                                currArg = Runtime.makeBigInt(\n                                    currArg[0],\n                                    currArg[1],\n                                    next == 117\n                                );\n                            }\n                            // Truncate to requested size.\n                            if (argSize <= 4) {\n                                const limit = Math.pow(256, argSize) - 1;\n                                currArg = (signed ? reSign : unSign)(\n                                    currArg & limit,\n                                    argSize * 8\n                                );\n                            }\n                            // Format the number.\n                            const currAbsArg = Math.abs(currArg);\n                            let prefix = '';\n                            if (next == 100 || next == 105) {\n                                if (argSize == 8 && i64Math)\n                                    argText = i64Math.stringify(\n                                        origArg[0],\n                                        origArg[1],\n                                        null\n                                    );\n                                else\n                                    argText = reSign(\n                                        currArg,\n                                        8 * argSize,\n                                        1\n                                    ).toString(10);\n                            } else if (next == 117) {\n                                if (argSize == 8 && i64Math)\n                                    argText = i64Math.stringify(\n                                        origArg[0],\n                                        origArg[1],\n                                        true\n                                    );\n                                else\n                                    argText = unSign(\n                                        currArg,\n                                        8 * argSize,\n                                        1\n                                    ).toString(10);\n                                currArg = Math.abs(currArg);\n                            } else if (next == 111) {\n                                argText =\n                                    (flagAlternative ? '0' : '') +\n                                    currAbsArg.toString(8);\n                            } else if (next == 120 || next == 88) {\n                                prefix =\n                                    flagAlternative && currArg != 0 ? '0x' : '';\n                                if (argSize == 8 && i64Math) {\n                                    if (origArg[1]) {\n                                        argText = (origArg[1] >>> 0).toString(\n                                            16\n                                        );\n                                        let lower = (origArg[0] >>> 0).toString(\n                                            16\n                                        );\n                                        while (lower.length < 8)\n                                            lower = '0' + lower;\n                                        argText += lower;\n                                    } else {\n                                        argText = (origArg[0] >>> 0).toString(\n                                            16\n                                        );\n                                    }\n                                } else if (currArg < 0) {\n                                    // Represent negative numbers in hex as 2's complement.\n                                    currArg = -currArg;\n                                    argText = (currAbsArg - 1).toString(16);\n                                    const buffer = [];\n                                    for (var i = 0; i < argText.length; i++) {\n                                        buffer.push(\n                                            (\n                                                0xf - parseInt(argText[i], 16)\n                                            ).toString(16)\n                                        );\n                                    }\n                                    argText = buffer.join('');\n                                    while (argText.length < argSize * 2)\n                                        argText = 'f' + argText;\n                                } else {\n                                    argText = currAbsArg.toString(16);\n                                }\n                                if (next == 88) {\n                                    prefix = prefix.toUpperCase();\n                                    argText = argText.toUpperCase();\n                                }\n                            } else if (next == 112) {\n                                if (currAbsArg === 0) {\n                                    argText = '(nil)';\n                                } else {\n                                    prefix = '0x';\n                                    argText = currAbsArg.toString(16);\n                                }\n                            }\n                            if (precisionSet) {\n                                while (argText.length < precision) {\n                                    argText = '0' + argText;\n                                }\n                            }\n                            // Add sign if needed\n                            if (currArg >= 0) {\n                                if (flagAlwaysSigned) {\n                                    prefix = '+' + prefix;\n                                } else if (flagPadSign) {\n                                    prefix = ' ' + prefix;\n                                }\n                            }\n                            // Move sign to prefix so we zero-pad after the sign\n                            if (argText.charAt(0) == '-') {\n                                prefix = '-' + prefix;\n                                argText = argText.substr(1);\n                            }\n                            // Add padding.\n                            while (prefix.length + argText.length < width) {\n                                if (flagLeftAlign) {\n                                    argText += ' ';\n                                } else {\n                                    if (flagZeroPad) {\n                                        argText = '0' + argText;\n                                    } else {\n                                        prefix = ' ' + prefix;\n                                    }\n                                }\n                            }\n                            // Insert the result into the buffer.\n                            argText = prefix + argText;\n                            argText.split('').forEach(function(chr) {\n                                ret.push(chr.charCodeAt(0));\n                            });\n                            break;\n                        }\n                        case 'f':\n                        case 'F':\n                        case 'e':\n                        case 'E':\n                        case 'g':\n                        case 'G': {\n                            // Float.\n                            var currArg = getNextArg('double');\n                            var argText;\n                            if (isNaN(currArg)) {\n                                argText = 'nan';\n                                flagZeroPad = false;\n                            } else if (!isFinite(currArg)) {\n                                argText = (currArg < 0 ? '-' : '') + 'inf';\n                                flagZeroPad = false;\n                            } else {\n                                let isGeneral = false;\n                                let effectivePrecision = Math.min(\n                                    precision,\n                                    20\n                                );\n                                // Convert g/G to f/F or e/E, as per:\n                                // http://pubs.opengroup.org/onlinepubs/9699919799/functions/printf.html\n                                if (next == 103 || next == 71) {\n                                    isGeneral = true;\n                                    precision = precision || 1;\n                                    const exponent = parseInt(\n                                        currArg\n                                            .toExponential(effectivePrecision)\n                                            .split('e')[1],\n                                        10\n                                    );\n                                    if (\n                                        precision > exponent &&\n                                        exponent >= -4\n                                    ) {\n                                        next = (next == 103\n                                            ? 'f'\n                                            : 'F'\n                                        ).charCodeAt(0);\n                                        precision -= exponent + 1;\n                                    } else {\n                                        next = (next == 103\n                                            ? 'e'\n                                            : 'E'\n                                        ).charCodeAt(0);\n                                        precision--;\n                                    }\n                                    effectivePrecision = Math.min(\n                                        precision,\n                                        20\n                                    );\n                                }\n                                if (next == 101 || next == 69) {\n                                    argText = currArg.toExponential(\n                                        effectivePrecision\n                                    );\n                                    // Make sure the exponent has at least 2 digits.\n                                    if (/[eE][-+]\\d$/.test(argText)) {\n                                        argText =\n                                            argText.slice(0, -1) +\n                                            '0' +\n                                            argText.slice(-1);\n                                    }\n                                } else if (next == 102 || next == 70) {\n                                    argText = currArg.toFixed(\n                                        effectivePrecision\n                                    );\n                                    if (\n                                        currArg === 0 &&\n                                        __reallyNegative(currArg)\n                                    ) {\n                                        argText = '-' + argText;\n                                    }\n                                }\n                                const parts = argText.split('e');\n                                if (isGeneral && !flagAlternative) {\n                                    // Discard trailing zeros and periods.\n                                    while (\n                                        parts[0].length > 1 &&\n                                        parts[0].indexOf('.') != -1 &&\n                                        (parts[0].slice(-1) == '0' ||\n                                            parts[0].slice(-1) == '.')\n                                    ) {\n                                        parts[0] = parts[0].slice(0, -1);\n                                    }\n                                } else {\n                                    // Make sure we have a period in alternative mode.\n                                    if (\n                                        flagAlternative &&\n                                        argText.indexOf('.') == -1\n                                    )\n                                        parts[0] += '.';\n                                    // Zero pad until required precision.\n                                    while (precision > effectivePrecision++)\n                                        parts[0] += '0';\n                                }\n                                argText =\n                                    parts[0] +\n                                    (parts.length > 1 ? 'e' + parts[1] : '');\n                                // Capitalize 'E' if needed.\n                                if (next == 69) argText = argText.toUpperCase();\n                                // Add sign.\n                                if (currArg >= 0) {\n                                    if (flagAlwaysSigned) {\n                                        argText = '+' + argText;\n                                    } else if (flagPadSign) {\n                                        argText = ' ' + argText;\n                                    }\n                                }\n                            }\n                            // Add padding.\n                            while (argText.length < width) {\n                                if (flagLeftAlign) {\n                                    argText += ' ';\n                                } else {\n                                    if (\n                                        flagZeroPad &&\n                                        (argText[0] == '-' || argText[0] == '+')\n                                    ) {\n                                        argText =\n                                            argText[0] + '0' + argText.slice(1);\n                                    } else {\n                                        argText =\n                                            (flagZeroPad ? '0' : ' ') + argText;\n                                    }\n                                }\n                            }\n                            // Adjust case.\n                            if (next < 97) argText = argText.toUpperCase();\n                            // Insert the result into the buffer.\n                            argText.split('').forEach(function(chr) {\n                                ret.push(chr.charCodeAt(0));\n                            });\n                            break;\n                        }\n                        case 's': {\n                            // String.\n                            let arg = getNextArg('i8*');\n                            let argLength = arg\n                                ? _strlen(arg)\n                                : '(null)'.length;\n                            if (precisionSet)\n                                argLength = Math.min(argLength, precision);\n                            if (!flagLeftAlign) {\n                                while (argLength < width--) {\n                                    ret.push(32);\n                                }\n                            }\n                            if (arg) {\n                                for (var i = 0; i < argLength; i++) {\n                                    ret.push(HEAPU8[arg++ | 0]);\n                                }\n                            } else {\n                                ret = ret.concat(\n                                    intArrayFromString(\n                                        '(null)'.substr(0, argLength),\n                                        true\n                                    )\n                                );\n                            }\n                            if (flagLeftAlign) {\n                                while (argLength < width--) {\n                                    ret.push(32);\n                                }\n                            }\n                            break;\n                        }\n                        case 'c': {\n                            // Character.\n                            if (flagLeftAlign) ret.push(getNextArg('i8'));\n                            while (--width > 0) {\n                                ret.push(32);\n                            }\n                            if (!flagLeftAlign) ret.push(getNextArg('i8'));\n                            break;\n                        }\n                        case 'n': {\n                            // Write the length written so far to the next parameter.\n                            const ptr = getNextArg('i32*');\n                            HEAP32[ptr >> 2] = ret.length;\n                            break;\n                        }\n                        case '%': {\n                            // Literal percent sign.\n                            ret.push(curr);\n                            break;\n                        }\n                        default: {\n                            // Unknown specifiers remain untouched.\n                            for (\n                                var i = startTextIndex;\n                                i < textIndex + 2;\n                                i++\n                            ) {\n                                ret.push(HEAP8[i]);\n                            }\n                        }\n                    }\n                    textIndex += 2;\n                } else {\n                    ret.push(curr);\n                    textIndex += 1;\n                }\n            }\n            return ret;\n        }\n        function _fprintf(stream, format, varargs) {\n            // int fprintf(FILE *restrict stream, const char *restrict format, ...);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/printf.html\n            const result = __formatString(format, varargs);\n            const stack = Runtime.stackSave();\n            const ret = _fwrite(\n                allocate(result, 'i8', ALLOC_STACK),\n                1,\n                result.length,\n                stream\n            );\n            Runtime.stackRestore(stack);\n            return ret;\n        }\n        function _recv(fd, buf, len) {\n            const sock = SOCKFS.getSocket(fd);\n            if (!sock) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            return _read(fd, buf, len);\n        }\n        function _pread(fildes, buf, nbyte, offset) {\n            // ssize_t pread(int fildes, void *buf, size_t nbyte, off_t offset);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/read.html\n            const stream = FS.getStream(fildes);\n            if (!stream) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            try {\n                const slab = HEAP8;\n                return FS.read(stream, slab, buf, nbyte, offset);\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _read(fildes, buf, nbyte) {\n            // ssize_t read(int fildes, void *buf, size_t nbyte);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/read.html\n            const stream = FS.getStream(fildes);\n            if (!stream) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            try {\n                const slab = HEAP8;\n                return FS.read(stream, slab, buf, nbyte);\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _fread(ptr, size, nitems, stream) {\n            // size_t fread(void *restrict ptr, size_t size, size_t nitems, FILE *restrict stream);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fread.html\n            let bytesToRead = nitems * size;\n            if (bytesToRead == 0) {\n                return 0;\n            }\n            let bytesRead = 0;\n            const streamObj = FS.getStream(stream);\n            while (streamObj.ungotten.length && bytesToRead > 0) {\n                HEAP8[ptr++ | 0] = streamObj.ungotten.pop();\n                bytesToRead--;\n                bytesRead++;\n            }\n            const err = _read(stream, ptr, bytesToRead);\n            if (err == -1) {\n                if (streamObj) streamObj.error = true;\n                return 0;\n            }\n            bytesRead += err;\n            if (bytesRead < bytesToRead) streamObj.eof = true;\n            return Math.floor(bytesRead / size);\n        }\n        Module['_memcmp'] = _memcmp;\n        function _lseek(fildes, offset, whence) {\n            // off_t lseek(int fildes, off_t offset, int whence);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/lseek.html\n            const stream = FS.getStream(fildes);\n            if (!stream) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            try {\n                return FS.llseek(stream, offset, whence);\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _fseek(stream, offset, whence) {\n            // int fseek(FILE *stream, long offset, int whence);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fseek.html\n            const ret = _lseek(stream, offset, whence);\n            if (ret == -1) {\n                return -1;\n            }\n            stream = FS.getStream(stream);\n            stream.eof = false;\n            return 0;\n        }\n        function _close(fildes) {\n            // int close(int fildes);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/close.html\n            const stream = FS.getStream(fildes);\n            if (!stream) {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n            try {\n                FS.close(stream);\n                return 0;\n            } catch (e) {\n                FS.handleFSError(e);\n                return -1;\n            }\n        }\n        function _fsync(fildes) {\n            // int fsync(int fildes);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fsync.html\n            const stream = FS.getStream(fildes);\n            if (stream) {\n                // We write directly to the file system, so there's nothing to do here.\n                return 0;\n            } else {\n                ___setErrNo(ERRNO_CODES.EBADF);\n                return -1;\n            }\n        }\n        function _fclose(stream) {\n            // int fclose(FILE *stream);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/fclose.html\n            _fsync(stream);\n            return _close(stream);\n        }\n        function _printf(format, varargs) {\n            // int printf(const char *restrict format, ...);\n            // http://pubs.opengroup.org/onlinepubs/000095399/functions/printf.html\n            const stdout = HEAP32[_stdout >> 2];\n            return _fprintf(stdout, format, varargs);\n        }\n        Module['_memset'] = _memset;\n        Module['_memcpy'] = _memcpy;\n        const _llvm_pow_f64 = Math_pow;\n        const _sin = Math_sin;\n        function _strrchr(ptr, chr) {\n            let ptr2 = ptr + _strlen(ptr);\n            do {\n                if (HEAP8[ptr2] == chr) return ptr2;\n                ptr2--;\n            } while (ptr2 >= ptr);\n            return 0;\n        }\n        let ___strtok_state = 0;\n        function _strtok_r(s, delim, lasts) {\n            const skip_leading_delim = 1;\n            let spanp;\n            let c, sc;\n            let tok;\n            if (s == 0 && (s = getValue(lasts, 'i8*')) == 0) {\n                return 0;\n            }\n            cont: while (1) {\n                c = getValue(s++, 'i8');\n                for (spanp = delim; (sc = getValue(spanp++, 'i8')) != 0; ) {\n                    if (c == sc) {\n                        if (skip_leading_delim) {\n                            continue cont;\n                        } else {\n                            setValue(lasts, s, 'i8*');\n                            setValue(s - 1, 0, 'i8');\n                            return s - 1;\n                        }\n                    }\n                }\n                break;\n            }\n            if (c == 0) {\n                setValue(lasts, 0, 'i8*');\n                return 0;\n            }\n            tok = s - 1;\n            for (;;) {\n                c = getValue(s++, 'i8');\n                spanp = delim;\n                do {\n                    if ((sc = getValue(spanp++, 'i8')) == c) {\n                        if (c == 0) {\n                            s = 0;\n                        } else {\n                            setValue(s - 1, 0, 'i8');\n                        }\n                        setValue(lasts, s, 'i8*');\n                        return tok;\n                    }\n                } while (sc != 0);\n            }\n            abort('strtok_r error!');\n        }\n        function _strtok(s, delim) {\n            return _strtok_r(s, delim, ___strtok_state);\n        }\n        function _strncmp(px, py, n) {\n            let i = 0;\n            while (i < n) {\n                const x = HEAPU8[(px + i) | 0];\n                const y = HEAPU8[(py + i) | 0];\n                if (x == y && x == 0) return 0;\n                if (x == 0) return -1;\n                if (y == 0) return 1;\n                if (x == y) {\n                    i++;\n                    continue;\n                } else {\n                    return x > y ? 1 : -1;\n                }\n            }\n            return 0;\n        }\n        function _strcmp(px, py) {\n            return _strncmp(px, py, TOTAL_MEMORY);\n        }\n        Module['_strncpy'] = _strncpy;\n        function _isspace(chr) {\n            return chr == 32 || (chr >= 9 && chr <= 13);\n        }\n        function __parseInt(str, endptr, base, min, max, bits, unsign) {\n            // Skip space.\n            while (_isspace(HEAP8[str])) str++;\n            // Check for a plus/minus sign.\n            let multiplier = 1;\n            if (HEAP8[str] == 45) {\n                multiplier = -1;\n                str++;\n            } else if (HEAP8[str] == 43) {\n                str++;\n            }\n            // Find base.\n            let finalBase = base;\n            if (!finalBase) {\n                if (HEAP8[str] == 48) {\n                    if (\n                        HEAP8[(str + 1) | 0] == 120 ||\n                        HEAP8[(str + 1) | 0] == 88\n                    ) {\n                        finalBase = 16;\n                        str += 2;\n                    } else {\n                        finalBase = 8;\n                        str++;\n                    }\n                }\n            } else if (finalBase == 16) {\n                if (HEAP8[str] == 48) {\n                    if (\n                        HEAP8[(str + 1) | 0] == 120 ||\n                        HEAP8[(str + 1) | 0] == 88\n                    ) {\n                        str += 2;\n                    }\n                }\n            }\n            if (!finalBase) finalBase = 10;\n            // Get digits.\n            let chr;\n            let ret = 0;\n            while ((chr = HEAP8[str]) != 0) {\n                const digit = parseInt(String.fromCharCode(chr), finalBase);\n                if (isNaN(digit)) {\n                    break;\n                } else {\n                    ret = ret * finalBase + digit;\n                    str++;\n                }\n            }\n            // Apply sign.\n            ret *= multiplier;\n            // Set end pointer.\n            if (endptr) {\n                HEAP32[endptr >> 2] = str;\n            }\n            // Unsign if needed.\n            if (unsign) {\n                if (Math.abs(ret) > max) {\n                    ret = max;\n                    ___setErrNo(ERRNO_CODES.ERANGE);\n                } else {\n                    ret = unSign(ret, bits);\n                }\n            }\n            // Validate range.\n            if (ret > max || ret < min) {\n                ret = ret > max ? max : min;\n                ___setErrNo(ERRNO_CODES.ERANGE);\n            }\n            if (bits == 64) {\n                return (\n                    (asm['setTempRet0'](\n                        ((tempDouble = ret),\n                        +Math_abs(tempDouble) >= +1\n                            ? tempDouble > +0\n                                ? (Math_min(\n                                      +Math_floor(tempDouble / +4294967296),\n                                      +4294967295\n                                  ) |\n                                      0) >>>\n                                  0\n                                : ~~+Math_ceil(\n                                      (tempDouble - +(~~tempDouble >>> 0)) /\n                                          +4294967296\n                                  ) >>> 0\n                            : 0)\n                    ),\n                    ret >>> 0) | 0\n                );\n            }\n            return ret;\n        }\n        function _strtol(str, endptr, base) {\n            return __parseInt(str, endptr, base, -2147483648, 2147483647, 32); // LONG_MIN, LONG_MAX.\n        }\n        function _atoi(ptr) {\n            return _strtol(ptr, null, 10);\n        }\n        function _strchr(ptr, chr) {\n            ptr--;\n            do {\n                ptr++;\n                var val = HEAP8[ptr];\n                if (val == chr) return ptr;\n            } while (val);\n            return 0;\n        }\n        function _abort() {\n            Module['abort']();\n        }\n        function ___errno_location() {\n            return ___errno_state;\n        }\n        function _sbrk(bytes) {\n            /*\n                Implement a Linux-like 'memory area' for our 'process'.\n                Changes the size of the memory area by |bytes|.\n                Returns the address of the previous top ('break') of the memory area.\n                We control the \"dynamic\" memory - DYNAMIC_BASE to DYNAMICTOP.\n            */\n            const self = _sbrk;\n            if (!self.called) {\n                DYNAMICTOP = alignMemoryPage(DYNAMICTOP); // make sure we start out aligned\n                self.called = true;\n                assert(Runtime.dynamicAlloc);\n                self.alloc = Runtime.dynamicAlloc;\n                Runtime.dynamicAlloc = function() {\n                    abort('cannot dynamically allocate, sbrk now has control');\n                };\n            }\n            const ret = DYNAMICTOP;\n            if (bytes != 0) self.alloc(bytes);\n            return ret; // Previous break location.\n        }\n        function _sysconf(name) {\n            // long sysconf(int name);\n            // http://pubs.opengroup.org/onlinepubs/009695399/functions/sysconf.html\n            switch (name) {\n                case 30:\n                    return PAGE_SIZE;\n                case 132:\n                case 133:\n                case 12:\n                case 137:\n                case 138:\n                case 15:\n                case 235:\n                case 16:\n                case 17:\n                case 18:\n                case 19:\n                case 20:\n                case 149:\n                case 13:\n                case 10:\n                case 236:\n                case 153:\n                case 9:\n                case 21:\n                case 22:\n                case 159:\n                case 154:\n                case 14:\n                case 77:\n                case 78:\n                case 139:\n                case 80:\n                case 81:\n                case 79:\n                case 82:\n                case 68:\n                case 67:\n                case 164:\n                case 11:\n                case 29:\n                case 47:\n                case 48:\n                case 95:\n                case 52:\n                case 51:\n                case 46:\n                    return 200809;\n                case 27:\n                case 246:\n                case 127:\n                case 128:\n                case 23:\n                case 24:\n                case 160:\n                case 161:\n                case 181:\n                case 182:\n                case 242:\n                case 183:\n                case 184:\n                case 243:\n                case 244:\n                case 245:\n                case 165:\n                case 178:\n                case 179:\n                case 49:\n                case 50:\n                case 168:\n                case 169:\n                case 175:\n                case 170:\n                case 171:\n                case 172:\n                case 97:\n                case 76:\n                case 32:\n                case 173:\n                case 35:\n                    return -1;\n                case 176:\n                case 177:\n                case 7:\n                case 155:\n                case 8:\n                case 157:\n                case 125:\n                case 126:\n                case 92:\n                case 93:\n                case 129:\n                case 130:\n                case 131:\n                case 94:\n                case 91:\n                    return 1;\n                case 74:\n                case 60:\n                case 69:\n                case 70:\n                case 4:\n                    return 1024;\n                case 31:\n                case 42:\n                case 72:\n                    return 32;\n                case 87:\n                case 26:\n                case 33:\n                    return 2147483647;\n                case 34:\n                case 1:\n                    return 47839;\n                case 38:\n                case 36:\n                    return 99;\n                case 43:\n                case 37:\n                    return 2048;\n                case 0:\n                    return 2097152;\n                case 3:\n                    return 65536;\n                case 28:\n                    return 32768;\n                case 44:\n                    return 32767;\n                case 75:\n                    return 16384;\n                case 39:\n                    return 1000;\n                case 89:\n                    return 700;\n                case 71:\n                    return 256;\n                case 40:\n                    return 255;\n                case 2:\n                    return 100;\n                case 180:\n                    return 64;\n                case 25:\n                    return 20;\n                case 5:\n                    return 16;\n                case 6:\n                    return 6;\n                case 73:\n                    return 4;\n                case 84:\n                    return 1;\n            }\n            ___setErrNo(ERRNO_CODES.EINVAL);\n            return -1;\n        }\n        function _time(ptr) {\n            const ret = Math.floor(Date.now() / 1000);\n            if (ptr) {\n                HEAP32[ptr >> 2] = ret;\n            }\n            return ret;\n        }\n\n        FS.staticInit();\n        __ATINIT__.unshift({\n            func: function() {\n                if (!Module['noFSInit'] && !FS.init.initialized) FS.init();\n            }\n        });\n        __ATMAIN__.push({\n            func: function() {\n                FS.ignorePermissions = false;\n            }\n        });\n        __ATEXIT__.push({\n            func: function() {\n                FS.quit();\n            }\n        });\n\n        Module['FS_createFolder'] = FS.createFolder;\n        Module.createPath = FS.createPath;\n        Module.createDataFile = FS.createDataFile;\n        Module.loadPatchFromUrl = FS.loadPatchFromUrl;\n        Module['FS_createPreloadedFile'] = FS.createPreloadedFile;\n        Module['FS_createLink'] = FS.createLink;\n        Module['FS_createDevice'] = FS.createDevice;\n\n        ___errno_state = Runtime.staticAlloc(4);\n        HEAP32[___errno_state >> 2] = 0;\n        __ATINIT__.unshift({\n            func: function() {\n                TTY.init();\n            }\n        });\n        __ATEXIT__.push({\n            func: function() {\n                TTY.shutdown();\n            }\n        });\n        TTY.utf8 = new Runtime.UTF8Processor();\n        __ATINIT__.push({\n            func: function() {\n                SOCKFS.root = FS.mount(SOCKFS, {}, null);\n            }\n        });\n        ___strtok_state = Runtime.staticAlloc(4);\n        STACK_BASE = STACKTOP = Runtime.alignMemory(STATICTOP);\n        STACK_MAX = STACK_BASE + 5242880;\n        DYNAMIC_BASE = DYNAMICTOP = Runtime.alignMemory(STACK_MAX);\n        assert(DYNAMIC_BASE < TOTAL_MEMORY); // Stack must fit in TOTAL_MEMORY; allocations from here on may enlarge TOTAL_MEMORY\n        var Math_min = Math.min;\n\n        function invoke_ii(index, a1) {\n            try {\n                return Module['dynCall_ii'](index, a1);\n            } catch (e) {\n                if (typeof e !== 'number' && e !== 'longjmp') throw e;\n                asm['setThrew'](1, 0);\n            }\n        }\n\n        function invoke_vi(index, a1) {\n            try {\n                Module['dynCall_vi'](index, a1);\n            } catch (e) {\n                if (typeof e !== 'number' && e !== 'longjmp') throw e;\n                asm['setThrew'](1, 0);\n            }\n        }\n\n        function invoke_iiiii(index, a1, a2, a3, a4) {\n            try {\n                return Module['dynCall_iiiii'](index, a1, a2, a3, a4);\n            } catch (e) {\n                if (typeof e !== 'number' && e !== 'longjmp') throw e;\n                asm['setThrew'](1, 0);\n            }\n        }\n\n        function invoke_viii(index, a1, a2, a3) {\n            try {\n                Module['dynCall_viii'](index, a1, a2, a3);\n            } catch (e) {\n                if (typeof e !== 'number' && e !== 'longjmp') throw e;\n                asm['setThrew'](1, 0);\n            }\n        }\n\n        function invoke_v(index) {\n            try {\n                Module['dynCall_v'](index);\n            } catch (e) {\n                if (typeof e !== 'number' && e !== 'longjmp') throw e;\n                asm['setThrew'](1, 0);\n            }\n        }\n\n        function invoke_iii(index, a1, a2) {\n            try {\n                return Module['dynCall_iii'](index, a1, a2);\n            } catch (e) {\n                if (typeof e !== 'number' && e !== 'longjmp') throw e;\n                asm['setThrew'](1, 0);\n            }\n        }\n\n        function asmPrintInt(x, y) {\n            console.log('int ' + x + ',' + y);\n        }\n\n        function asmPrintFloat(x, y) {\n            console.log('float ' + x + ',' + y);\n        }\n\n        // EMSCRIPTEN_START_ASM\n\n        var asm = (function(global, env, buffer) {\n            'use asm';\n            let a = new global.Int8Array(buffer);\n            let b = new global.Int16Array(buffer);\n            let c = new global.Int32Array(buffer);\n            let d = new global.Uint8Array(buffer);\n            let e = new global.Uint16Array(buffer);\n            let f = new global.Uint32Array(buffer);\n            let g = new global.Float32Array(buffer);\n            let h = new global.Float64Array(buffer);\n            let i = env.STACKTOP | 0;\n            let j = env.STACK_MAX | 0;\n            let k = env.tempDoublePtr | 0;\n            let l = env.ABORT | 0;\n            let m = env._stderr | 0;\n            let n = +env.NaN;\n            let o = +env.Infinity;\n            let p = 0;\n            let q = 0;\n            let r = 0;\n            let s = 0;\n            let t = 0,\n                u = 0,\n                v = 0,\n                w = 0,\n                x = 0.0,\n                y = 0,\n                z = 0,\n                A = 0,\n                B = 0.0;\n            let C = 0;\n            let D = 0;\n            let E = 0;\n            let F = 0;\n            let G = 0;\n            let H = 0;\n            let I = 0;\n            let J = 0;\n            let K = 0;\n            let L = 0;\n            let M = global.Math.floor;\n            let N = global.Math.abs;\n            let O = global.Math.sqrt;\n            let P = global.Math.pow;\n            let Q = global.Math.cos;\n            let R = global.Math.sin;\n            let S = global.Math.tan;\n            let T = global.Math.acos;\n            let U = global.Math.asin;\n            let V = global.Math.atan;\n            let W = global.Math.atan2;\n            let X = global.Math.exp;\n            let Y = global.Math.log;\n            let Z = global.Math.ceil;\n            let _ = global.Math.imul;\n            let $ = env.abort;\n            let aa = env.assert;\n            let ab = env.asmPrintInt;\n            let ac = env.asmPrintFloat;\n            let ad = env.min;\n            let ae = env.invoke_ii;\n            let af = env.invoke_vi;\n            let ag = env.invoke_iiiii;\n            let ah = env.invoke_viii;\n            let ai = env.invoke_v;\n            let aj = env.invoke_iii;\n            let ak = env._strncmp;\n            let al = env._lseek;\n            const am = env._sysconf;\n            let an = env._fread;\n            let ao = env._fclose;\n            let ap = env._strtok_r;\n            const aq = env._abort;\n            let ar = env._fprintf;\n            let as = env._close;\n            let at = env._pread;\n            let au = env._fflush;\n            let av = env._fopen;\n            let aw = env._open;\n            let ax = env._strtol;\n            let ay = env._strtok;\n            let az = env.___setErrNo;\n            let aA = env.__reallyNegative;\n            let aB = env._fseek;\n            let aC = env._send;\n            let aD = env._write;\n            let aE = env._strrchr;\n            let aF = env._sin;\n            let aG = env._printf;\n            let aH = env._strchr;\n            let aI = env._read;\n            const aJ = env._time;\n            const aL = env._atoi;\n            const aQ = env.___errno_location;\n            const aS = env._sbrk;\n            const aV = env._strcmp;\n\n            // EMSCRIPTEN_START_FUNCS\n\n            function a0(a) {\n                a = a | 0;\n                let b = 0;\n                b = i;\n                i = (i + a) | 0;\n                i = (i + 7) & -8;\n                return b | 0;\n            }\n            function a1() {\n                return i | 0;\n            }\n            function a2(a) {\n                a = a | 0;\n                i = a;\n            }\n            function a3(a, b) {\n                a = a | 0;\n                b = b | 0;\n                if ((p | 0) == 0) {\n                    p = a;\n                    q = b;\n                }\n            }\n            function a4(b) {\n                b = b | 0;\n                a[k] = a[b];\n                a[(k + 1) | 0] = a[(b + 1) | 0];\n                a[(k + 2) | 0] = a[(b + 2) | 0];\n                a[(k + 3) | 0] = a[(b + 3) | 0];\n            }\n            function a6(a) {\n                a = a | 0;\n                C = a;\n            }\n            function a7(a) {\n                a = a | 0;\n                D = a;\n            }\n            function a8(a) {\n                a = a | 0;\n                E = a;\n            }\n            function a9(a) {\n                a = a | 0;\n                F = a;\n            }\n            function ba(a) {\n                a = a | 0;\n                G = a;\n            }\n            function bb(a) {\n                a = a | 0;\n                H = a;\n            }\n            function bc(a) {\n                a = a | 0;\n                I = a;\n            }\n            function bd(a) {\n                a = a | 0;\n                J = a;\n            }\n            function be(a) {\n                a = a | 0;\n                K = a;\n            }\n            function bf(a) {\n                a = a | 0;\n                L = a;\n            }\n            function bg() {}\n            function bh(b) {\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0;\n                d = i;\n                i = (i + 1024) | 0;\n                e = d | 0;\n                f = b;\n                do {\n                    if ((f | 0) != 0) {\n                        if ((a[f] | 0) == 0) {\n                            break;\n                        }\n                        b = av(f | 0, 6576) | 0;\n                        g = b;\n                        if ((b | 0) != 0) {\n                            h = g;\n                            j = h;\n                            i = d;\n                            return j | 0;\n                        }\n                        do {\n                            if ((a[f | 0] | 0) != 47) {\n                                b = c[1664] | 0;\n                                while (1) {\n                                    if ((b | 0) == 0) {\n                                        k = 16;\n                                        break;\n                                    }\n                                    a[e | 0] = 0;\n                                    l = c1(c[b >> 2] | 0) | 0;\n                                    if ((l | 0) != 0) {\n                                        m = e | 0;\n                                        n = c[b >> 2] | 0;\n                                        c2(m | 0, n | 0) | 0;\n                                        if ((a[(e + (l - 1)) | 0] | 0) != 47) {\n                                            a[(e + l) | 0] = 47;\n                                            a[(e + (l + 1)) | 0] = 0;\n                                        }\n                                    }\n                                    c3(e | 0, f | 0) | 0;\n                                    l = av(e | 0, 6576) | 0;\n                                    g = l;\n                                    if ((l | 0) != 0) {\n                                        break;\n                                    }\n                                    b = c[(b + 4) >> 2] | 0;\n                                }\n                                if ((k | 0) == 16) {\n                                    break;\n                                }\n                                h = g;\n                                j = h;\n                                i = d;\n                                return j | 0;\n                            }\n                        } while (0);\n                        h = 0;\n                        j = h;\n                        i = d;\n                        return j | 0;\n                    }\n                } while (0);\n                h = 0;\n                j = h;\n                i = d;\n                return j | 0;\n            }\n            function bi(a) {\n                a = a | 0;\n                let b = 0;\n                b = c$(a) | 0;\n                return b | 0;\n            }\n            function bj(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0,\n                    e = 0;\n                b = a;\n                a = bi(8) | 0;\n                if ((a | 0) == 0) {\n                    return;\n                }\n                c[a >> 2] = bi(((c1(b | 0) | 0) + 1) | 0) | 0;\n                if ((c[a >> 2] | 0) == 0) {\n                    c0(a);\n                    return;\n                } else {\n                    d = c[a >> 2] | 0;\n                    e = b;\n                    c2(d | 0, e | 0) | 0;\n                    c[(a + 4) >> 2] = c[1664];\n                    c[1664] = a;\n                    return;\n                }\n            }\n            function bk() {\n                let a = 0,\n                    b = 0;\n                a = c[1664] | 0;\n                while (1) {\n                    if ((a | 0) == 0) {\n                        break;\n                    }\n                    b = c[(a + 4) >> 2] | 0;\n                    c0(c[a >> 2] | 0);\n                    c0(a);\n                    a = b;\n                }\n                c[1664] = 0;\n                return;\n            }\n            function bl(f, h, j, k, l, n, o, p, q) {\n                f = f | 0;\n                h = h | 0;\n                j = j | 0;\n                k = k | 0;\n                l = l | 0;\n                n = n | 0;\n                o = o | 0;\n                p = p | 0;\n                q = q | 0;\n                let r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0,\n                    B = 0,\n                    C = 0,\n                    D = 0,\n                    E = 0,\n                    F = 0,\n                    G = 0,\n                    H = 0,\n                    I = 0;\n                j = i;\n                i = (i + 1056) | 0;\n                r = j | 0;\n                s = (j + 1024) | 0;\n                t = (j + 1032) | 0;\n                u = (j + 1040) | 0;\n                v = (j + 1048) | 0;\n                w = f;\n                f = h;\n                h = k;\n                k = l;\n                l = n;\n                n = o;\n                o = p;\n                p = q;\n                q = 0;\n                if ((f | 0) == 0) {\n                    x = 0;\n                    y = x;\n                    i = j;\n                    return y | 0;\n                }\n                z = bh(f) | 0;\n                A = z;\n                if ((z | 0) == 0) {\n                    z = c[m >> 2] | 0;\n                    // _fprintf;\n                    ar(\n                        6512,\n                        ((z = i),\n                        (i = (i + 1) | 0),\n                        (i = (i + 7) & -8),\n                        (c[z >> 2] = 0),\n                        z) | 0\n                    ) | 0;\n                    i = z;\n                    q = 1;\n                    B = 0;\n                    while (1) {\n                        if ((c[(1048 + (B << 2)) >> 2] | 0) == 0) {\n                            break;\n                        }\n                        z = c1(f | 0) | 0;\n                        if (\n                            ((z + (c1(c[(1048 + (B << 2)) >> 2] | 0) | 0)) |\n                                0) >>>\n                                0 <\n                            1024\n                        ) {\n                            z = r | 0;\n                            C = f;\n                            c2(z | 0, C | 0) | 0;\n                            C = r | 0;\n                            z = c[(1048 + (B << 2)) >> 2] | 0;\n                            c3(C | 0, z | 0) | 0;\n                            z = bh(r | 0) | 0;\n                            A = z;\n                            if ((z | 0) != 0) {\n                                D = 46;\n                                break;\n                            }\n                        }\n                        B = (B + 1) | 0;\n                    }\n                    if ((D | 0) == 46) {\n                        q = 0;\n                        f = r | 0;\n                    }\n                }\n                if ((q | 0) != 0) {\n                    x = 0;\n                    y = x;\n                    i = j;\n                    return y | 0;\n                }\n                do {\n                    if (239 == (an(r | 0, 1, 239, A | 0) | 0)) {\n                        if ((c4(r | 0, 6248, 22) | 0) != 0) {\n                            if ((c4(r | 0, 5888, 22) | 0) != 0) {\n                                break;\n                            }\n                        }\n                        do {\n                            if ((a[(r + 82) | 0] | 0) != 1) {\n                                if ((a[(r + 82) | 0] | 0) == 0) {\n                                    break;\n                                }\n                                x = 0;\n                                y = x;\n                                i = j;\n                                return y | 0;\n                            }\n                        } while (0);\n                        do {\n                            if ((a[(r + 151) | 0] | 0) != 1) {\n                                if ((a[(r + 151) | 0] | 0) == 0) {\n                                    break;\n                                }\n                                x = 0;\n                                y = x;\n                                i = j;\n                                return y | 0;\n                            }\n                        } while (0);\n                        q = bi(8) | 0;\n                        c[q >> 2] = a[(r + 198) | 0] | 0;\n                        c[(q + 4) >> 2] = bi(((c[q >> 2] | 0) * 116) | 0) | 0;\n                        B = 0;\n                        while (1) {\n                            if ((B | 0) >= (c[q >> 2] | 0)) {\n                                D = 162;\n                                break;\n                            }\n                            aB(A | 0, 7, 1) | 0;\n                            if (1 != (an(s | 0, 1, 1, A | 0) | 0)) {\n                                D = 66;\n                                break;\n                            }\n                            f = ((c[(q + 4) >> 2] | 0) + ((B * 116) | 0)) | 0;\n                            if (1 != (an(t | 0, 4, 1, A | 0) | 0)) {\n                                D = 73;\n                                break;\n                            }\n                            c[(f + 8) >> 2] = c[t >> 2];\n                            if (1 != (an(t | 0, 4, 1, A | 0) | 0)) {\n                                D = 75;\n                                break;\n                            }\n                            c[f >> 2] = c[t >> 2];\n                            if (1 != (an(t | 0, 4, 1, A | 0) | 0)) {\n                                D = 77;\n                                break;\n                            }\n                            c[(f + 4) >> 2] = c[t >> 2];\n                            if (1 != (an(u | 0, 2, 1, A | 0) | 0)) {\n                                D = 79;\n                                break;\n                            }\n                            c[(f + 12) >> 2] = e[u >> 1] | 0;\n                            if (1 != (an(t | 0, 4, 1, A | 0) | 0)) {\n                                D = 81;\n                                break;\n                            }\n                            c[(f + 24) >> 2] = c[t >> 2];\n                            if (1 != (an(t | 0, 4, 1, A | 0) | 0)) {\n                                D = 83;\n                                break;\n                            }\n                            c[(f + 28) >> 2] = c[t >> 2];\n                            if (1 != (an(t | 0, 4, 1, A | 0) | 0)) {\n                                D = 85;\n                                break;\n                            }\n                            c[(f + 32) >> 2] = c[t >> 2];\n                            c[(f + 16) >> 2] = 0;\n                            c[(f + 20) >> 2] = 127;\n                            aB(A | 0, 2, 1) | 0;\n                            if (1 != (an(v | 0, 1, 1, A | 0) | 0)) {\n                                D = 87;\n                                break;\n                            }\n                            a[r | 0] = a[v] | 0;\n                            if ((h | 0) == -1) {\n                                a[(f + 111) | 0] = ((a[r | 0] << 3) + 4) & 127;\n                            } else {\n                                a[(f + 111) | 0] = h & 127;\n                            }\n                            if (18 != (an(r | 0, 1, 18, A | 0) | 0)) {\n                                D = 92;\n                                break;\n                            }\n                            do {\n                                if ((a[(r + 13) | 0] | 0) != 0) {\n                                    if ((a[(r + 14) | 0] | 0) == 0) {\n                                        D = 95;\n                                        break;\n                                    }\n                                    c[(f + 92) >> 2] =\n                                        bm(w, a[(r + 12) | 0] | 0) | 0;\n                                    c[(f + 96) >> 2] =\n                                        bn(w, a[(r + 13) | 0] | 0) | 0;\n                                    a[(f + 108) | 0] = a[(r + 14) | 0] | 0;\n                                } else {\n                                    D = 95;\n                                }\n                            } while (0);\n                            if ((D | 0) == 95) {\n                                D = 0;\n                                a[(f + 108) | 0] = 0;\n                                c[(f + 96) >> 2] = 0;\n                                c[(f + 92) >> 2] = 0;\n                            }\n                            do {\n                                if ((a[(r + 16) | 0] | 0) != 0) {\n                                    if ((a[(r + 17) | 0] | 0) == 0) {\n                                        D = 99;\n                                        break;\n                                    }\n                                    c[(f + 104) >> 2] =\n                                        bo(w, a[(r + 16) | 0] | 0) | 0;\n                                    c[(f + 100) >> 2] =\n                                        bp(\n                                            w,\n                                            a[(r + 15) | 0] | 0,\n                                            c[(f + 104) >> 2] | 0\n                                        ) | 0;\n                                    a[(f + 109) | 0] = a[(r + 17) | 0] | 0;\n                                } else {\n                                    D = 99;\n                                }\n                            } while (0);\n                            if ((D | 0) == 99) {\n                                D = 0;\n                                a[(f + 109) | 0] = 0;\n                                c[(f + 104) >> 2] = 0;\n                                c[(f + 100) >> 2] = 0;\n                            }\n                            if (1 != (an(v | 0, 1, 1, A | 0) | 0)) {\n                                D = 102;\n                                break;\n                            }\n                            a[(f + 110) | 0] = a[v] | 0;\n                            aB(A | 0, 40, 1) | 0;\n                            if ((l | 0) != -1) {\n                                a[(f + 112) | 0] = l & 255;\n                            } else {\n                                a[(f + 112) | 0] = 0;\n                            }\n                            if (((a[(f + 110) | 0] & 4) | 0) != 0) {\n                                z = (f + 110) | 0;\n                                a[z] = (d[z] | 32) & 255;\n                            }\n                            do {\n                                if ((n | 0) == 1) {\n                                    if (((a[(f + 110) | 0] & 60) | 0) == 0) {\n                                        break;\n                                    }\n                                    z = (f + 110) | 0;\n                                    a[z] = d[z] & -61 & 255;\n                                }\n                            } while (0);\n                            if ((o | 0) == 1) {\n                                ((a[(f + 110) | 0] & 64) | 0) != 0;\n                                z = (f + 110) | 0;\n                                a[z] = d[z] & -65 & 255;\n                            } else {\n                                if ((o | 0) != 0) {\n                                    if (((a[(f + 110) | 0] & 28) | 0) != 0) {\n                                        do {\n                                            if ((c4(r | 0, 5512, 6) | 0) != 0) {\n                                                if (\n                                                    (a[(r + 11) | 0] | 0) >=\n                                                    100\n                                                ) {\n                                                    D = 120;\n                                                    break;\n                                                }\n                                                if (\n                                                    ((a[(f + 110) | 0] & 32) |\n                                                        0) ==\n                                                    0\n                                                ) {\n                                                    z = (f + 110) | 0;\n                                                    a[z] = d[z] & -65 & 255;\n                                                }\n                                            } else {\n                                                D = 120;\n                                            }\n                                        } while (0);\n                                        if ((D | 0) == 120) {\n                                            D = 0;\n                                            z = (f + 110) | 0;\n                                            a[z] = d[z] & -65 & 255;\n                                        }\n                                    } else {\n                                        z = (f + 110) | 0;\n                                        a[z] = d[z] & -97 & 255;\n                                    }\n                                }\n                            }\n                            E = 0;\n                            while (1) {\n                                if ((E | 0) >= 6) {\n                                    break;\n                                }\n                                c[(f + 36 + (E << 2)) >> 2] =\n                                    bq(w, a[(r + E) | 0] | 0) | 0;\n                                c[(f + 60 + (E << 2)) >> 2] =\n                                    br(a[(r + (E + 6)) | 0] | 0) | 0;\n                                E = (E + 1) | 0;\n                            }\n                            c[(f + 88) >> 2] = bi(c[(f + 8) >> 2] | 0) | 0;\n                            if (\n                                1 !=\n                                (an(\n                                    c[(f + 88) >> 2] | 0,\n                                    c[(f + 8) >> 2] | 0,\n                                    1,\n                                    A | 0\n                                ) |\n                                    0)\n                            ) {\n                                D = 132;\n                                break;\n                            }\n                            if (((a[(f + 110) | 0] & 1) | 0) == 0) {\n                                z = c[(f + 8) >> 2] | 0;\n                                C = c[(f + 88) >> 2] | 0;\n                                F = bi(c[(f + 8) >> 2] << 1) | 0;\n                                G = F;\n                                H = F;\n                                while (1) {\n                                    F = z;\n                                    z = (F - 1) | 0;\n                                    if ((F | 0) == 0) {\n                                        break;\n                                    }\n                                    F = C;\n                                    C = (F + 1) | 0;\n                                    I = H;\n                                    H = (I + 2) | 0;\n                                    b[I >> 1] = ((a[F] & 255) << 8) & 65535;\n                                }\n                                C = c[(f + 88) >> 2] | 0;\n                                c[(f + 88) >> 2] = G;\n                                c0(C);\n                                H = (f + 8) | 0;\n                                c[H >> 2] = c[H >> 2] << 1;\n                                H = f | 0;\n                                c[H >> 2] = c[H >> 2] << 1;\n                                H = (f + 4) | 0;\n                                c[H >> 2] = c[H >> 2] << 1;\n                            }\n                            if (((a[(f + 110) | 0] & 2) | 0) != 0) {\n                                H = ((c[(f + 8) >> 2] | 0) / 2) | 0;\n                                z = c[(f + 88) >> 2] | 0;\n                                while (1) {\n                                    F = H;\n                                    H = (F - 1) | 0;\n                                    if ((F | 0) == 0) {\n                                        break;\n                                    }\n                                    F = z;\n                                    z = (F + 2) | 0;\n                                    b[F >> 1] = (b[F >> 1] ^ 32768) & 65535;\n                                }\n                            }\n                            if (((a[(f + 110) | 0] & 16) | 0) != 0) {\n                                bs(\n                                    c[(f + 88) >> 2] | 0,\n                                    0,\n                                    ((c[(f + 8) >> 2] | 0) / 2) | 0\n                                );\n                                z = c[f >> 2] | 0;\n                                c[f >> 2] =\n                                    (c[(f + 8) >> 2] | 0) -\n                                    (c[(f + 4) >> 2] | 0);\n                                c[(f + 4) >> 2] = (c[(f + 8) >> 2] | 0) - z;\n                                z = (f + 110) | 0;\n                                a[z] = d[z] & -17 & 255;\n                                z = (f + 110) | 0;\n                                a[z] = (d[z] | 4) & 255;\n                            }\n                            if ((k | 0) != -1) {\n                                g[(f + 84) >> 2] = +(k | 0) / 100.0;\n                            } else {\n                                z = ((c[(f + 8) >> 2] | 0) / 2) | 0;\n                                H = 0;\n                                C = c[(f + 88) >> 2] | 0;\n                                while (1) {\n                                    G = z;\n                                    z = (G - 1) | 0;\n                                    if ((G | 0) == 0) {\n                                        break;\n                                    }\n                                    G = C;\n                                    C = (G + 2) | 0;\n                                    F = b[G >> 1] | 0;\n                                    if ((((F << 16) >> 16) | 0) < 0) {\n                                        F = -((F << 16) >> 16) & 65535;\n                                    }\n                                    if (\n                                        (((F << 16) >> 16) | 0) >\n                                        (((H << 16) >> 16) | 0)\n                                    ) {\n                                        H = F;\n                                    }\n                                }\n                                g[(f + 84) >> 2] =\n                                    32768.0 / +(((H << 16) >> 16) | 0);\n                            }\n                            C = (f + 8) | 0;\n                            c[C >> 2] = ((c[C >> 2] | 0) / 2) | 0;\n                            C = f | 0;\n                            c[C >> 2] = ((c[C >> 2] | 0) / 2) | 0;\n                            C = (f + 4) | 0;\n                            c[C >> 2] = ((c[C >> 2] | 0) / 2) | 0;\n                            C = (f + 8) | 0;\n                            c[C >> 2] = c[C >> 2] << 12;\n                            C = f | 0;\n                            c[C >> 2] = c[C >> 2] << 12;\n                            C = (f + 4) | 0;\n                            c[C >> 2] = c[C >> 2] << 12;\n                            C = f | 0;\n                            c[C >> 2] = c[C >> 2] | ((a[s] & 15) << 8);\n                            C = (f + 4) | 0;\n                            c[C >> 2] = c[C >> 2] | (((d[s] >> 4) & 15) << 8);\n                            do {\n                                if ((a[(f + 112) | 0] | 0) != 0) {\n                                    if (((a[(f + 110) | 0] & 4) | 0) != 0) {\n                                        break;\n                                    }\n                                    cF(w, f);\n                                }\n                            } while (0);\n                            if ((p | 0) == 1) {\n                                c[(f + 8) >> 2] = c[(f + 4) >> 2];\n                            }\n                            B = (B + 1) | 0;\n                        }\n                        if ((D | 0) != 66)\n                            if ((D | 0) != 73)\n                                if ((D | 0) != 75)\n                                    if ((D | 0) != 77)\n                                        if ((D | 0) != 79)\n                                            if ((D | 0) != 81)\n                                                if ((D | 0) != 83)\n                                                    if ((D | 0) != 85)\n                                                        if ((D | 0) != 87)\n                                                            if ((D | 0) != 92)\n                                                                if (\n                                                                    (D | 0) !=\n                                                                    102\n                                                                )\n                                                                    if (\n                                                                        (D |\n                                                                            0) !=\n                                                                        132\n                                                                    )\n                                                                        if (\n                                                                            (D |\n                                                                                0) ==\n                                                                            162\n                                                                        ) {\n                                                                            ao(\n                                                                                A |\n                                                                                    0\n                                                                            ) |\n                                                                                0;\n                                                                            x = q;\n                                                                            y = x;\n                                                                            i = j;\n                                                                            return (\n                                                                                y |\n                                                                                0\n                                                                            );\n                                                                        }\n                        E = 0;\n                        while (1) {\n                            if ((E | 0) >= (B | 0)) {\n                                break;\n                            }\n                            c0(\n                                c[\n                                    ((c[(q + 4) >> 2] | 0) +\n                                        ((E * 116) | 0) +\n                                        88) >>\n                                        2\n                                ] | 0\n                            );\n                            E = (E + 1) | 0;\n                        }\n                        c0(c[(q + 4) >> 2] | 0);\n                        c0(q);\n                        x = 0;\n                        y = x;\n                        i = j;\n                        return y | 0;\n                    }\n                } while (0);\n                x = 0;\n                y = x;\n                i = j;\n                return y | 0;\n            }\n            function bm(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0;\n                d = a;\n                a = b;\n                if ((a << 24) >> 24 != 0) {\n                    b = (((c[(d + 13060) >> 2] | 0) * 38) | 0) << 16;\n                    e = ((b | 0) / (_(c[(d + 4) >> 2] | 0, a & 255) | 0)) | 0;\n                    f = e;\n                    return f | 0;\n                } else {\n                    e = 0;\n                    f = e;\n                    return f | 0;\n                }\n                return 0;\n            }\n            function bn(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0;\n                d = a;\n                a = (_(c[(d + 13060) >> 2] << 10, b & 255) | 0) << 5;\n                return (\n                    ((a | 0) / (((c[(d + 4) >> 2] | 0) * 38) | 0 | 0)) | 0 | 0\n                );\n            }\n            function bo(a, b) {\n                a = a | 0;\n                b = b | 0;\n                return (\n                    ((((c[(a + 4) >> 2] | 0) * 38) | 0 | 0) /\n                        ((((b & 255) << 1) << 5) | 0)) |\n                    0 |\n                    0\n                );\n            }\n            function bp(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0;\n                e = b;\n                if ((e << 24) >> 24 != 0) {\n                    f = ~~(\n                        (+(d | 0) * 38.0 * 65536.0) /\n                        +(_(c[(a + 4) >> 2] | 0, e & 255) | 0)\n                    );\n                    g = f;\n                    return g | 0;\n                } else {\n                    f = 0;\n                    g = f;\n                    return g | 0;\n                }\n                return 0;\n            }\n            function bq(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0;\n                d = a;\n                a = b;\n                b = (3 - (((a & 255) >> 6) & 3)) | 0;\n                b = (b * 3) | 0;\n                b = (a & 63) << b;\n                b =\n                    _(\n                        (((b * 44100) | 0 | 0) / (c[(d + 4) >> 2] | 0)) | 0,\n                        c[(d + 13060) >> 2] | 0\n                    ) | 0;\n                return (b << 10) | 0;\n            }\n            function br(a) {\n                a = a | 0;\n                return ((a & 255) << 22) | 0;\n            }\n            function bs(a, c, d) {\n                a = a | 0;\n                c = c | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0;\n                e = a;\n                a = c;\n                c = d;\n                d = (e + (c << 1)) | 0;\n                e = (e + (a << 1)) | 0;\n                c = (c - a) | 0;\n                c = ((c | 0) / 2) | 0;\n                while (1) {\n                    a = c;\n                    c = (a - 1) | 0;\n                    if ((a | 0) == 0) {\n                        break;\n                    }\n                    a = b[e >> 1] | 0;\n                    f = e;\n                    e = (f + 2) | 0;\n                    b[f >> 1] = b[d >> 1] | 0;\n                    f = d;\n                    d = (f - 2) | 0;\n                    b[f >> 1] = a;\n                }\n                return;\n            }\n            // mid_song_get_num_missing_instruments\n            // takes a number (a)\n            // returns a number\n            function bt(a) {\n                a = a | 0;\n                return c[(a + 13136) >> 2] | 0;\n            }\n\n            // mid_song_get_missing_instrument\n            function bu(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0;\n                d = a;\n                a = b;\n                do {\n                    if ((a | 0) >= 0) {\n                        // stops when reached last instrument\n                        if ((a | 0) >= (c[(d + 13136) >> 2] | 0)) {\n                            break;\n                        }\n                        // path to patch file\n                        e = c[(d + 13140 + (a << 2)) >> 2] | 0;\n                        f = e;\n                        return f | 0;\n                    }\n                } while (0);\n                e = 0;\n                f = e;\n                return f | 0;\n            }\n\n            // returns number of missing patches\n            function bv(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0,\n                    e = 0;\n                b = a;\n                a = 128;\n                d = 0;\n                c[(b + 13136) >> 2] = 0;\n                while (1) {\n                    e = a;\n                    a = (e - 1) | 0;\n                    if ((e | 0) == 0) {\n                        break;\n                    }\n                    // get number of instrument patches\n                    if ((c[(b + 28 + (a << 2)) >> 2] | 0) != 0) {\n                        d = (d + (bw(b, 0, a) | 0)) | 0;\n                    }\n                    // get number of drum patches\n                    if ((c[(b + 540 + (a << 2)) >> 2] | 0) != 0) {\n                        d = (d + (bw(b, 1, a) | 0)) | 0;\n                    }\n                }\n                return d | 0;\n            }\n            function bw(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0;\n                e = i;\n                f = a;\n                a = b;\n                b = d;\n                d = 0;\n                if ((a | 0) != 0) {\n                    g = c[(f + 540 + (b << 2)) >> 2] | 0;\n                } else {\n                    g = c[(f + 28 + (b << 2)) >> 2] | 0;\n                }\n                h = g;\n                if ((h | 0) == 0) {\n                    j = 0;\n                    k = j;\n                    i = e;\n                    return k | 0;\n                }\n                g = 0;\n                while (1) {\n                    if ((g | 0) >= 128) {\n                        break;\n                    }\n                    do {\n                        if ((c[(h + 4 + (g << 2)) >> 2] | 0) == -1) {\n                            c[(h + 4 + (g << 2)) >> 2] = bB(f, a, b, g) | 0;\n                            if ((c[(h + 4 + (g << 2)) >> 2] | 0) != 0) {\n                                break;\n                            }\n                            if (\n                                (c[((c[h >> 2] | 0) + ((g * 28) | 0)) >> 2] |\n                                    0) !=\n                                0\n                            ) {\n                                l = f;\n                                n =\n                                    c[((c[h >> 2] | 0) + ((g * 28) | 0)) >> 2] |\n                                    0;\n                                o = (a | 0) != 0 ? 1 : 0;\n                                p =\n                                    c[\n                                        ((c[h >> 2] | 0) +\n                                            ((g * 28) | 0) +\n                                            12) >>\n                                            2\n                                    ] | 0;\n                                q =\n                                    c[\n                                        ((c[h >> 2] | 0) +\n                                            ((g * 28) | 0) +\n                                            8) >>\n                                            2\n                                    ] | 0;\n                                if (\n                                    (c[\n                                        ((c[h >> 2] | 0) +\n                                            ((g * 28) | 0) +\n                                            4) >>\n                                            2\n                                    ] |\n                                        0) !=\n                                    -1\n                                ) {\n                                    r =\n                                        c[\n                                            ((c[h >> 2] | 0) +\n                                                ((g * 28) | 0) +\n                                                4) >>\n                                                2\n                                        ] | 0;\n                                } else {\n                                    if ((a | 0) != 0) {\n                                        s = g;\n                                    } else {\n                                        s = -1;\n                                    }\n                                    r = s;\n                                }\n                                if (\n                                    (c[\n                                        ((c[h >> 2] | 0) +\n                                            ((g * 28) | 0) +\n                                            16) >>\n                                            2\n                                    ] |\n                                        0) !=\n                                    -1\n                                ) {\n                                    t =\n                                        c[\n                                            ((c[h >> 2] | 0) +\n                                                ((g * 28) | 0) +\n                                                16) >>\n                                                2\n                                        ] | 0;\n                                } else {\n                                    t = (a | 0) != 0 ? 1 : -1;\n                                }\n                                if (\n                                    (c[\n                                        ((c[h >> 2] | 0) +\n                                            ((g * 28) | 0) +\n                                            20) >>\n                                            2\n                                    ] |\n                                        0) !=\n                                    -1\n                                ) {\n                                    u =\n                                        c[\n                                            ((c[h >> 2] | 0) +\n                                                ((g * 28) | 0) +\n                                                20) >>\n                                                2\n                                        ] | 0;\n                                } else {\n                                    u = (a | 0) != 0 ? 1 : -1;\n                                }\n                                v =\n                                    bl(\n                                        l,\n                                        n,\n                                        o,\n                                        p,\n                                        q,\n                                        r,\n                                        t,\n                                        u,\n                                        c[\n                                            ((c[h >> 2] | 0) +\n                                                ((g * 28) | 0) +\n                                                24) >>\n                                                2\n                                        ] | 0\n                                    ) | 0;\n                                c[(h + 4 + (g << 2)) >> 2] = v;\n                                if ((v | 0) == 0) {\n                                    v = c[m >> 2] | 0;\n                                    q =\n                                        c[\n                                            ((c[h >> 2] | 0) +\n                                                ((g * 28) | 0)) >>\n                                                2\n                                        ] | 0;\n                                    // prints 'Missing patch: arachno-88.pat' or 'Missing patch: MT32Drums/mt32drum-6.pat'\n                                    ar(\n                                        v | 0,\n                                        5120,\n                                        ((v = i),\n                                        (i = (i + 8) | 0),\n                                        (c[v >> 2] = q),\n                                        v) | 0\n                                    ) | 0;\n                                    i = v;\n                                    if ((c[(f + 13136) >> 2] | 0) < 256) {\n                                        q = c[m >> 2] | 0;\n                                        p = c[(f + 13136) >> 2] | 0;\n                                        i = v;\n                                        c[\n                                            (f +\n                                                13140 +\n                                                (c[(f + 13136) >> 2] << 2)) >>\n                                                2\n                                        ] =\n                                            c[\n                                                ((c[h >> 2] | 0) +\n                                                    ((g * 28) | 0)) >>\n                                                    2\n                                            ];\n                                        v = (f + 13136) | 0;\n                                        c[v >> 2] = (c[v >> 2] | 0) + 1;\n                                    }\n                                    d = (d + 1) | 0;\n                                }\n                            } else {\n                                if ((b | 0) != 0) {\n                                    if ((a | 0) != 0) {\n                                        if (\n                                            (c[\n                                                ((c[(f + 540) >> 2] | 0) +\n                                                    4 +\n                                                    (g << 2)) >>\n                                                    2\n                                            ] |\n                                                0) ==\n                                            0\n                                        ) {\n                                            c[\n                                                ((c[(f + 540) >> 2] | 0) +\n                                                    4 +\n                                                    (g << 2)) >>\n                                                    2\n                                            ] = -1;\n                                        }\n                                    } else {\n                                        if (\n                                            (c[\n                                                ((c[(f + 28) >> 2] | 0) +\n                                                    4 +\n                                                    (g << 2)) >>\n                                                    2\n                                            ] |\n                                                0) ==\n                                            0\n                                        ) {\n                                            c[\n                                                ((c[(f + 28) >> 2] | 0) +\n                                                    4 +\n                                                    (g << 2)) >>\n                                                    2\n                                            ] = -1;\n                                        }\n                                    }\n                                }\n                                c[(h + 4 + (g << 2)) >> 2] = 0;\n                                d = (d + 1) | 0;\n                            }\n                            w = 246;\n                        } else {\n                            w = 246;\n                        }\n                    } while (0);\n                    if ((w | 0) == 246) {\n                        w = 0;\n                    }\n                    g = (g + 1) | 0;\n                }\n                j = d;\n                k = j;\n                i = e;\n                return k | 0;\n            }\n            function bx(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0;\n                b = a;\n                a = 128;\n                while (1) {\n                    d = a;\n                    a = (d - 1) | 0;\n                    if ((d | 0) == 0) {\n                        break;\n                    }\n                    if ((c[(b + 28 + (a << 2)) >> 2] | 0) != 0) {\n                        by(b, 0, a);\n                    }\n                    if ((c[(b + 540 + (a << 2)) >> 2] | 0) != 0) {\n                        by(b, 1, a);\n                    }\n                }\n                return;\n            }\n            function by(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0;\n                e = a;\n                a = d;\n                if ((b | 0) != 0) {\n                    f = c[(e + 540 + (a << 2)) >> 2] | 0;\n                } else {\n                    f = c[(e + 28 + (a << 2)) >> 2] | 0;\n                }\n                a = f;\n                f = 0;\n                while (1) {\n                    if ((f | 0) >= 128) {\n                        break;\n                    }\n                    if ((c[(a + 4 + (f << 2)) >> 2] | 0) != 0) {\n                        if ((c[(a + 4 + (f << 2)) >> 2] | 0) != -1) {\n                            bA(c[(a + 4 + (f << 2)) >> 2] | 0);\n                        }\n                        c[(a + 4 + (f << 2)) >> 2] = 0;\n                    }\n                    f = (f + 1) | 0;\n                }\n                return;\n            }\n            function bz(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0;\n                d = a;\n                a = bl(d, b, 0, -1, -1, -1, 0, 0, 0) | 0;\n                if ((a | 0) != 0) {\n                    c[(d + 1052) >> 2] = a;\n                    c[(d + 1056) >> 2] = -1;\n                    e = 0;\n                    f = e;\n                    return f | 0;\n                } else {\n                    e = -1;\n                    f = e;\n                    return f | 0;\n                }\n                return 0;\n            }\n            function bA(a) {\n                a = a | 0;\n                let b = 0;\n                b = a;\n                if ((b | 0) == 0) {\n                    return;\n                }\n                a = 0;\n                while (1) {\n                    if ((a | 0) >= (c[b >> 2] | 0)) {\n                        break;\n                    }\n                    c0(\n                        c[((c[(b + 4) >> 2] | 0) + ((a * 116) | 0) + 88) >> 2] |\n                            0\n                    );\n                    a = (a + 1) | 0;\n                }\n                c0(c[(b + 4) >> 2] | 0);\n                c0(b);\n                return;\n            }\n            function bB(a, b, d, e) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0;\n                f = a;\n                a = b;\n                b = d;\n                d = e;\n                if ((c[(f + 24) >> 2] | 0) == 0) {\n                    g = 0;\n                    h = g;\n                    return h | 0;\n                }\n                a = (a | 0) != 0 ? -2147483648 : 0;\n                e = 0;\n                L368: while (1) {\n                    if (\n                        e >>> 0 >=\n                        (c[((c[(f + 24) >> 2] | 0) + 4) >> 2] | 0) >>> 0\n                    ) {\n                        break;\n                    }\n                    i =\n                        ((c[((c[(f + 24) >> 2] | 0) + 8) >> 2] | 0) +\n                            ((e * 20) | 0)) |\n                        0;\n                    do {\n                        if (\n                            ((c[((c[(i + 4) >> 2] | 0) + 4) >> 2] &\n                                -2147483648) |\n                                0) ==\n                            (a | 0)\n                        ) {\n                            if (\n                                ((((c[((c[(i + 4) >> 2] | 0) + 4) >> 2] | 0) >>>\n                                    8) &\n                                    255) |\n                                    0) !=\n                                (b | 0)\n                            ) {\n                                break;\n                            }\n                            if (\n                                (c[((c[(i + 4) >> 2] | 0) + 8) >> 2] | 0) ==\n                                (d | 0)\n                            ) {\n                                j = 295;\n                                break L368;\n                            }\n                        }\n                    } while (0);\n                    e = (e + 1) | 0;\n                }\n                do {\n                    if ((e | 0) == (c[((c[(f + 24) >> 2] | 0) + 4) >> 2] | 0)) {\n                        if ((b | 0) != 0) {\n                            break;\n                        }\n                        e = 0;\n                        while (1) {\n                            if (\n                                e >>> 0 >=\n                                (c[((c[(f + 24) >> 2] | 0) + 4) >> 2] | 0) >>> 0\n                            ) {\n                                break;\n                            }\n                            i =\n                                ((c[((c[(f + 24) >> 2] | 0) + 8) >> 2] | 0) +\n                                    ((e * 20) | 0)) |\n                                0;\n                            if (\n                                ((c[((c[(i + 4) >> 2] | 0) + 4) >> 2] &\n                                    -2147483648) |\n                                    0) ==\n                                (a | 0)\n                            ) {\n                                if (\n                                    (c[((c[(i + 4) >> 2] | 0) + 8) >> 2] | 0) ==\n                                    (d | 0)\n                                ) {\n                                    j = 304;\n                                    break;\n                                }\n                            }\n                            e = (e + 1) | 0;\n                        }\n                    }\n                } while (0);\n                if ((e | 0) == (c[((c[(f + 24) >> 2] | 0) + 4) >> 2] | 0)) {\n                    g = 0;\n                    h = g;\n                    return h | 0;\n                }\n                j = bi(8) | 0;\n                c[j >> 2] = c[c[(i + 4) >> 2] >> 2];\n                c[(j + 4) >> 2] = bi(((c[j >> 2] | 0) * 116) | 0) | 0;\n                c5(c[(j + 4) >> 2] | 0, 0, ((c[j >> 2] | 0) * 116) | 0 | 0);\n                e = 0;\n                while (1) {\n                    if (e >>> 0 >= (c[c[(i + 4) >> 2] >> 2] | 0) >>> 0) {\n                        break;\n                    }\n                    bC(f, ((c[(j + 4) >> 2] | 0) + ((e * 116) | 0)) | 0, i, e);\n                    e = (e + 1) | 0;\n                }\n                g = j;\n                h = g;\n                return h | 0;\n            }\n            function bC(b, f, h, i) {\n                b = b | 0;\n                f = f | 0;\n                h = h | 0;\n                i = i | 0;\n                let j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0.0,\n                    B = 0.0,\n                    C = 0.0,\n                    D = 0.0;\n                j = b;\n                b = f;\n                f = h;\n                h = ((c[(f + 8) >> 2] | 0) + ((i * 24) | 0)) | 0;\n                i =\n                    ((c[((c[(j + 24) >> 2] | 0) + 20) >> 2] | 0) +\n                        (((c[((c[(h + 4) >> 2] | 0) + 8) >> 2] | 0) * 20) |\n                            0)) |\n                    0;\n                k = (1056 + ((e[c[h >> 2] >> 1] | 0) << 2)) | 0;\n                c[(b + 24) >> 2] =\n                    d[k] |\n                    (d[(k + 1) | 0] << 8) |\n                    (d[(k + 2) | 0] << 16) |\n                    (d[(k + 3) | 0] << 24);\n                k = (1056 + ((e[((c[h >> 2] | 0) + 2) >> 1] | 0) << 2)) | 0;\n                c[(b + 28) >> 2] =\n                    d[k] |\n                    (d[(k + 1) | 0] << 8) |\n                    (d[(k + 2) | 0] << 16) |\n                    (d[(k + 3) | 0] << 24);\n                k =\n                    (1056 + ((e[((c[(h + 8) >> 2] | 0) + 4) >> 1] | 0) << 2)) |\n                    0;\n                c[(b + 32) >> 2] =\n                    d[k] |\n                    (d[(k + 1) | 0] << 8) |\n                    (d[(k + 2) | 0] << 16) |\n                    (d[(k + 3) | 0] << 24);\n                c[(b + 16) >> 2] = e[((c[h >> 2] | 0) + 4) >> 1] | 0;\n                c[(b + 20) >> 2] = e[((c[h >> 2] | 0) + 6) >> 1] | 0;\n                a[(b + 110) | 0] = 1;\n                c[(b + 12) >> 2] = c[((c[i >> 2] | 0) + 4) >> 2];\n                c[(b + 8) >> 2] = (((c[(i + 8) >> 2] | 0) >>> 0) / 2) | 0;\n                c[(b + 88) >> 2] = bi(c[(i + 8) >> 2] | 0) | 0;\n                k = c[(b + 88) >> 2] | 0;\n                l = c[(i + 4) >> 2] | 0;\n                m = c[(i + 8) >> 2] | 0;\n                c6(k | 0, l | 0, m) | 0;\n                if ((c[((c[(h + 8) >> 2] | 0) + 16) >> 2] | 0) != 0) {\n                    m = (b + 110) | 0;\n                    a[m] = (d[m] | 0 | 36) & 255;\n                    c[b >> 2] =\n                        (((c[((c[(h + 12) >> 2] | 0) + 8) >> 2] | 0) >>> 0) /\n                            2) |\n                        0;\n                    c[(b + 4) >> 2] =\n                        (c[b >> 2] | 0) +\n                        ((((c[((c[(h + 12) >> 2] | 0) + 12) >> 2] | 0) >>> 0) /\n                            2) |\n                            0);\n                }\n                g[(b + 84) >> 2] = 1.0;\n                if (((a[(b + 110) | 0] & 32) | 0) == 0) {\n                    n = b;\n                    o = (n + 8) | 0;\n                    p = c[o >> 2] | 0;\n                    q = p << 12;\n                    c[o >> 2] = q;\n                    r = b;\n                    s = r | 0;\n                    t = c[s >> 2] | 0;\n                    u = t << 12;\n                    c[s >> 2] = u;\n                    v = b;\n                    w = (v + 4) | 0;\n                    x = c[w >> 2] | 0;\n                    y = x << 12;\n                    c[w >> 2] = y;\n                    return;\n                }\n                m = 0;\n                l = 0;\n                do {\n                    if ((c[(f + 12) >> 2] | 0) != 0) {\n                        if (\n                            (c[((c[(f + 12) >> 2] | 0) + 4) >> 2] | 0) >>> 0 <=\n                            0\n                        ) {\n                            z = 326;\n                            break;\n                        }\n                        if ((c[(f + 16) >> 2] | 0) == 0) {\n                            z = 326;\n                            break;\n                        }\n                        m = c[(f + 12) >> 2] | 0;\n                        l = c[(f + 16) >> 2] | 0;\n                    } else {\n                        z = 326;\n                    }\n                } while (0);\n                if ((z | 0) == 326) {\n                    m = c[(h + 16) >> 2] | 0;\n                    l = c[(h + 20) >> 2] | 0;\n                }\n                h = bD(c[(m + 4) >> 2] | 0, l, 518) | 0;\n                A = +bE(h);\n                h = bD(c[(m + 4) >> 2] | 0, l, 524) | 0;\n                B = +bE(h);\n                h = bD(c[(m + 4) >> 2] | 0, l, 519) | 0;\n                C = +bE(h);\n                h = bD(c[(m + 4) >> 2] | 0, l, 521) | 0;\n                D = +bE(h);\n                h = bD(c[(m + 4) >> 2] | 0, l, 522) | 0;\n                z = ~~((1.0 - +bF(h)) * 250.0);\n                h = bD(c[(m + 4) >> 2] | 0, l, 4) | 0;\n                a[(b + 111) | 0] = ~~((+bF(h) + 0.5) * 127.0) & 255;\n                c[(b + 60) >> 2] = bG(255) | 0;\n                c[(b + 36) >> 2] = bH(j, 255, c[(b + 12) >> 2] | 0, A) | 0;\n                c[(b + 64) >> 2] = bG(250) | 0;\n                c[(b + 40) >> 2] = bH(j, 5, c[(b + 12) >> 2] | 0, B) | 0;\n                c[(b + 68) >> 2] = bG(z) | 0;\n                c[(b + 44) >> 2] =\n                    bH(j, (255 - z) | 0, c[(b + 12) >> 2] | 0, C) | 0;\n                c[(b + 72) >> 2] = bG(0) | 0;\n                c[(b + 48) >> 2] =\n                    bH(j, (z + 5) | 0, c[(b + 12) >> 2] | 0, D) | 0;\n                c[(b + 76) >> 2] = bG(0) | 0;\n                c[(b + 52) >> 2] = bG(1) | 0;\n                c[(b + 80) >> 2] = bG(0) | 0;\n                c[(b + 56) >> 2] = bG(1) | 0;\n                z = (b + 110) | 0;\n                a[z] = (d[z] | 0 | 64) & 255;\n                n = b;\n                o = (n + 8) | 0;\n                p = c[o >> 2] | 0;\n                q = p << 12;\n                c[o >> 2] = q;\n                r = b;\n                s = r | 0;\n                t = c[s >> 2] | 0;\n                u = t << 12;\n                c[s >> 2] = u;\n                v = b;\n                w = (v + 4) | 0;\n                x = c[w >> 2] | 0;\n                y = x << 12;\n                c[w >> 2] = y;\n                return;\n            }\n            function bD(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0;\n                f = a;\n                a = b;\n                b = d;\n                d = 0;\n                g = 0;\n                while (1) {\n                    if (g >>> 0 >= f >>> 0) {\n                        break;\n                    }\n                    h = (a + ((g * 12) | 0)) | 0;\n                    if ((e[(h + 4) >> 1] | 0 | 0) == ((b & 65535) | 0)) {\n                        do {\n                            if ((e[h >> 1] | 0 | 0) == 0) {\n                                if ((e[(h + 2) >> 1] | 0 | 0) != 0) {\n                                    break;\n                                }\n                                if ((e[(h + 6) >> 1] | 0 | 0) != 0) {\n                                    break;\n                                }\n                                d = (d + (c[(h + 8) >> 2] | 0)) | 0;\n                            }\n                        } while (0);\n                    }\n                    g = (g + 1) | 0;\n                }\n                return d | 0;\n            }\n            function bE(a) {\n                a = a | 0;\n                let b = 0,\n                    c = 0.0,\n                    d = 0.0;\n                b = a;\n                do {\n                    if ((b | 0) != -2147483648) {\n                        if ((b | 0) == 0) {\n                            break;\n                        }\n                        c =\n                            +P(2.0, +(+(((b | 0) / 65536) | 0 | 0) / 1200.0)) *\n                            1.0e3;\n                        d = c;\n                        return +d;\n                    }\n                } while (0);\n                c = 0.0;\n                d = c;\n                return +d;\n            }\n            function bF(a) {\n                a = a | 0;\n                return +(+(((a | 0) / 65536) | 0 | 0) / 1.0e3);\n            }\n            function bG(a) {\n                a = a | 0;\n                return (a << 22) | 0;\n            }\n            function bH(a, b, d, e) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                e = +e;\n                let f = 0.0;\n                d = a;\n                a = b;\n                f = e;\n                if (f < 6.0) {\n                    f = 6.0;\n                }\n                if ((a | 0) == 0) {\n                    a = 255;\n                }\n                a = a << 22;\n                return (\n                    ~~(\n                        ((+(a | 0) / +(c[(d + 4) >> 2] | 0)) *\n                            +(c[(d + 13060) >> 2] | 0) *\n                            1.0e3) /\n                        f\n                    ) | 0\n                );\n            }\n            function bI(b, e) {\n                b = b | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0;\n                f = b;\n                b = e;\n                e = c[(f + 1724 + ((b * 236) | 0) + 220) >> 2] | 0;\n                if ((e | 0) > 5) {\n                    a[(f + 1724 + ((b * 236) | 0)) | 0] = 0;\n                    g = 1;\n                    h = g;\n                    return h | 0;\n                }\n                if (\n                    ((a[\n                        ((c[(f + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) + 110) |\n                            0\n                    ] &\n                        64) |\n                        0) !=\n                    0\n                ) {\n                    if ((d[(f + 1724 + ((b * 236) | 0)) | 0] | 0 | 0) == 1) {\n                        i = 361;\n                    } else {\n                        if (\n                            (d[(f + 1724 + ((b * 236) | 0)) | 0] | 0 | 0) ==\n                            2\n                        ) {\n                            i = 361;\n                        }\n                    }\n                    do {\n                        if ((i | 0) == 361) {\n                            if ((e | 0) <= 2) {\n                                break;\n                            }\n                            c[(f + 1724 + ((b * 236) | 0) + 32) >> 2] = 0;\n                            g = 0;\n                            h = g;\n                            return h | 0;\n                        }\n                    } while (0);\n                }\n                c[(f + 1724 + ((b * 236) | 0) + 220) >> 2] = e + 1;\n                if (\n                    (c[(f + 1724 + ((b * 236) | 0) + 24) >> 2] | 0) ==\n                    (c[\n                        ((c[(f + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) +\n                            60 +\n                            (e << 2)) >>\n                            2\n                    ] |\n                        0)\n                ) {\n                    g = bI(f, b) | 0;\n                    h = g;\n                    return h | 0;\n                }\n                c[(f + 1724 + ((b * 236) | 0) + 28) >> 2] =\n                    c[\n                        ((c[(f + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) +\n                            60 +\n                            (e << 2)) >>\n                            2\n                    ];\n                c[(f + 1724 + ((b * 236) | 0) + 32) >> 2] =\n                    c[\n                        ((c[(f + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) +\n                            36 +\n                            (e << 2)) >>\n                            2\n                    ];\n                if (\n                    (c[(f + 1724 + ((b * 236) | 0) + 28) >> 2] | 0) <\n                    (c[(f + 1724 + ((b * 236) | 0) + 24) >> 2] | 0)\n                ) {\n                    c[(f + 1724 + ((b * 236) | 0) + 32) >> 2] = -(\n                        c[(f + 1724 + ((b * 236) | 0) + 32) >> 2] | 0\n                    );\n                }\n                g = 0;\n                h = g;\n                return h | 0;\n            }\n            function bJ(b, e) {\n                b = b | 0;\n                e = e | 0;\n                let f = 0,\n                    i = 0.0,\n                    j = 0,\n                    l = 0.0;\n                f = b;\n                b = e;\n                i = +g[(f + 1724 + ((b * 236) | 0) + 68) >> 2];\n                if ((c[(f + 1724 + ((b * 236) | 0) + 232) >> 2] | 0) != 0) {\n                    if ((c[(f + 1724 + ((b * 236) | 0) + 48) >> 2] | 0) != 0) {\n                        i = i * +g[(f + 1724 + ((b * 236) | 0) + 76) >> 2];\n                    }\n                    if (\n                        ((a[\n                            ((c[(f + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) +\n                                110) |\n                                0\n                        ] &\n                            64) |\n                            0) !=\n                        0\n                    ) {\n                        e =\n                            (8 +\n                                ((c[(f + 1724 + ((b * 236) | 0) + 24) >> 2] >>\n                                    23) <<\n                                    3)) |\n                            0;\n                        i =\n                            i *\n                            ((c[k >> 2] =\n                                d[e] |\n                                (d[(e + 1) | 0] << 8) |\n                                (d[(e + 2) | 0] << 16) |\n                                (d[(e + 3) | 0] << 24)),\n                            (c[(k + 4) >> 2] =\n                                d[(e + 4) | 0] |\n                                (d[(e + 5) | 0] << 8) |\n                                (d[(e + 6) | 0] << 16) |\n                                (d[(e + 7) | 0] << 24)),\n                            +h[k >> 3]);\n                    }\n                    j = ~~(i * 4096.0);\n                    if ((j | 0) > 8191) {\n                        j = 8191;\n                    }\n                    c[(f + 1724 + ((b * 236) | 0) + 60) >> 2] = j;\n                    return;\n                }\n                l = +g[(f + 1724 + ((b * 236) | 0) + 72) >> 2];\n                if ((c[(f + 1724 + ((b * 236) | 0) + 48) >> 2] | 0) != 0) {\n                    i = i * +g[(f + 1724 + ((b * 236) | 0) + 76) >> 2];\n                    l = l * +g[(f + 1724 + ((b * 236) | 0) + 76) >> 2];\n                }\n                if (\n                    ((a[\n                        ((c[(f + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) + 110) |\n                            0\n                    ] &\n                        64) |\n                        0) !=\n                    0\n                ) {\n                    e =\n                        (8 +\n                            ((c[(f + 1724 + ((b * 236) | 0) + 24) >> 2] >>\n                                23) <<\n                                3)) |\n                        0;\n                    i =\n                        i *\n                        ((c[k >> 2] =\n                            d[e] |\n                            (d[(e + 1) | 0] << 8) |\n                            (d[(e + 2) | 0] << 16) |\n                            (d[(e + 3) | 0] << 24)),\n                        (c[(k + 4) >> 2] =\n                            d[(e + 4) | 0] |\n                            (d[(e + 5) | 0] << 8) |\n                            (d[(e + 6) | 0] << 16) |\n                            (d[(e + 7) | 0] << 24)),\n                        +h[k >> 3]);\n                    e =\n                        (8 +\n                            ((c[(f + 1724 + ((b * 236) | 0) + 24) >> 2] >>\n                                23) <<\n                                3)) |\n                        0;\n                    l =\n                        l *\n                        ((c[k >> 2] =\n                            d[e] |\n                            (d[(e + 1) | 0] << 8) |\n                            (d[(e + 2) | 0] << 16) |\n                            (d[(e + 3) | 0] << 24)),\n                        (c[(k + 4) >> 2] =\n                            d[(e + 4) | 0] |\n                            (d[(e + 5) | 0] << 8) |\n                            (d[(e + 6) | 0] << 16) |\n                            (d[(e + 7) | 0] << 24)),\n                        +h[k >> 3]);\n                }\n                j = ~~(i * 4096.0);\n                if ((j | 0) > 8191) {\n                    j = 8191;\n                }\n                e = ~~(l * 4096.0);\n                if ((e | 0) > 8191) {\n                    e = 8191;\n                }\n                c[(f + 1724 + ((b * 236) | 0) + 60) >> 2] = j;\n                c[(f + 1724 + ((b * 236) | 0) + 64) >> 2] = e;\n                return;\n            }\n            function bK(b, e, f, g) {\n                b = b | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0;\n                h = i;\n                i = (i + 8) | 0;\n                j = h | 0;\n                k = b;\n                b = e;\n                e = f;\n                c[j >> 2] = g;\n                g = (k + 1724 + ((e * 236) | 0)) | 0;\n                if ((d[g | 0] | 0 | 0) == 4) {\n                    if ((c[j >> 2] | 0) >= 20) {\n                        c[j >> 2] = 20;\n                    }\n                    l = cy(k, e, j) | 0;\n                    bL(k, l, b, e, c[j >> 2] | 0);\n                    a[g | 0] = 0;\n                    i = h;\n                    return;\n                }\n                l = cy(k, e, j) | 0;\n                if (((c[(k + 8) >> 2] & 1) | 0) != 0) {\n                    do {\n                        if ((c[(g + 32) >> 2] | 0) != 0) {\n                            m = 402;\n                        } else {\n                            if ((c[(g + 48) >> 2] | 0) != 0) {\n                                m = 402;\n                                break;\n                            }\n                            bN(k, l, b, e, c[j >> 2] | 0);\n                        }\n                    } while (0);\n                    if ((m | 0) == 402) {\n                        bM(k, l, b, e, c[j >> 2] | 0);\n                    }\n                } else {\n                    if ((c[(g + 232) >> 2] | 0) == 0) {\n                        do {\n                            if ((c[(g + 32) >> 2] | 0) != 0) {\n                                m = 408;\n                            } else {\n                                if ((c[(g + 48) >> 2] | 0) != 0) {\n                                    m = 408;\n                                    break;\n                                }\n                                bP(k, l, b, e, c[j >> 2] | 0);\n                            }\n                        } while (0);\n                        if ((m | 0) == 408) {\n                            bO(k, l, b, e, c[j >> 2] | 0);\n                        }\n                    } else {\n                        if ((c[(g + 232) >> 2] | 0) == 3) {\n                            do {\n                                if ((c[(g + 32) >> 2] | 0) != 0) {\n                                    m = 414;\n                                } else {\n                                    if ((c[(g + 48) >> 2] | 0) != 0) {\n                                        m = 414;\n                                        break;\n                                    }\n                                    bR(k, l, b, e, c[j >> 2] | 0);\n                                }\n                            } while (0);\n                            if ((m | 0) == 414) {\n                                bQ(k, l, b, e, c[j >> 2] | 0);\n                            }\n                        } else {\n                            if ((c[(g + 232) >> 2] | 0) == 2) {\n                                b = (b + 4) | 0;\n                            }\n                            do {\n                                if ((c[(g + 32) >> 2] | 0) != 0) {\n                                    m = 421;\n                                } else {\n                                    if ((c[(g + 48) >> 2] | 0) != 0) {\n                                        m = 421;\n                                        break;\n                                    }\n                                    bT(k, l, b, e, c[j >> 2] | 0);\n                                }\n                            } while (0);\n                            if ((m | 0) == 421) {\n                                bS(k, l, b, e, c[j >> 2] | 0);\n                            }\n                        }\n                    }\n                }\n                i = h;\n                return;\n            }\n            function bL(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0;\n                h = a;\n                a = d;\n                d = e;\n                e = f;\n                f = g;\n                g = 0;\n                if ((f | 0) == 0) {\n                    f = 1;\n                }\n                i = c[(h + 1724 + ((e * 236) | 0) + 60) >> 2] | 0;\n                j = -(((i | 0) / (f | 0)) | 0) | 0;\n                if ((j | 0) == 0) {\n                    j = -1;\n                }\n                if (((c[(h + 8) >> 2] & 1) | 0) != 0) {\n                    while (1) {\n                        k = f;\n                        f = (k - 1) | 0;\n                        if ((k | 0) == 0) {\n                            l = 474;\n                            break;\n                        }\n                        i = (i + j) | 0;\n                        if ((i | 0) < 0) {\n                            l = 472;\n                            break;\n                        }\n                        k = a;\n                        a = (k + 2) | 0;\n                        g = b[k >> 1] | 0;\n                        k = _(i, (g << 16) >> 16) | 0;\n                        m = d;\n                        d = (m + 4) | 0;\n                        c[m >> 2] = (c[m >> 2] | 0) + k;\n                    }\n                    if ((l | 0) == 472) {\n                        return;\n                    } else if ((l | 0) == 474) {\n                        return;\n                    }\n                }\n                if ((c[(h + 1724 + ((e * 236) | 0) + 232) >> 2] | 0) == 0) {\n                    k = c[(h + 1724 + ((e * 236) | 0) + 64) >> 2] | 0;\n                    m = -(((k | 0) / (f | 0)) | 0) | 0;\n                    while (1) {\n                        n = f;\n                        f = (n - 1) | 0;\n                        if ((n | 0) == 0) {\n                            break;\n                        }\n                        i = (i + j) | 0;\n                        if ((i | 0) < 0) {\n                            i = 0;\n                        }\n                        k = (k + m) | 0;\n                        if ((k | 0) < 0) {\n                            k = 0;\n                        }\n                        n = a;\n                        a = (n + 2) | 0;\n                        g = b[n >> 1] | 0;\n                        n = _(i, (g << 16) >> 16) | 0;\n                        o = d;\n                        d = (o + 4) | 0;\n                        c[o >> 2] = (c[o >> 2] | 0) + n;\n                        n = _(k, (g << 16) >> 16) | 0;\n                        o = d;\n                        d = (o + 4) | 0;\n                        c[o >> 2] = (c[o >> 2] | 0) + n;\n                    }\n                } else {\n                    do {\n                        if (\n                            (c[(h + 1724 + ((e * 236) | 0) + 232) >> 2] | 0) ==\n                            3\n                        ) {\n                            while (1) {\n                                k = f;\n                                f = (k - 1) | 0;\n                                if ((k | 0) == 0) {\n                                    l = 450;\n                                    break;\n                                }\n                                i = (i + j) | 0;\n                                if ((i | 0) < 0) {\n                                    break;\n                                }\n                                k = a;\n                                a = (k + 2) | 0;\n                                g = b[k >> 1] | 0;\n                                k = _(i, (g << 16) >> 16) | 0;\n                                m = d;\n                                d = (m + 4) | 0;\n                                c[m >> 2] = (c[m >> 2] | 0) + k;\n                                k = _(i, (g << 16) >> 16) | 0;\n                                m = d;\n                                d = (m + 4) | 0;\n                                c[m >> 2] = (c[m >> 2] | 0) + k;\n                            }\n                            if ((l | 0) == 450) {\n                                break;\n                            }\n                            return;\n                        } else {\n                            do {\n                                if (\n                                    (c[\n                                        (h + 1724 + ((e * 236) | 0) + 232) >> 2\n                                    ] |\n                                        0) ==\n                                    1\n                                ) {\n                                    while (1) {\n                                        k = f;\n                                        f = (k - 1) | 0;\n                                        if ((k | 0) == 0) {\n                                            l = 457;\n                                            break;\n                                        }\n                                        i = (i + j) | 0;\n                                        if ((i | 0) < 0) {\n                                            break;\n                                        }\n                                        k = a;\n                                        a = (k + 2) | 0;\n                                        g = b[k >> 1] | 0;\n                                        k = _(i, (g << 16) >> 16) | 0;\n                                        m = d;\n                                        d = (m + 4) | 0;\n                                        c[m >> 2] = (c[m >> 2] | 0) + k;\n                                        d = (d + 4) | 0;\n                                    }\n                                    if ((l | 0) == 457) {\n                                        break;\n                                    }\n                                    return;\n                                } else {\n                                    do {\n                                        if (\n                                            (c[\n                                                (h +\n                                                    1724 +\n                                                    ((e * 236) | 0) +\n                                                    232) >>\n                                                    2\n                                            ] |\n                                                0) ==\n                                            2\n                                        ) {\n                                            while (1) {\n                                                k = f;\n                                                f = (k - 1) | 0;\n                                                if ((k | 0) == 0) {\n                                                    l = 464;\n                                                    break;\n                                                }\n                                                i = (i + j) | 0;\n                                                if ((i | 0) < 0) {\n                                                    break;\n                                                }\n                                                k = a;\n                                                a = (k + 2) | 0;\n                                                g = b[k >> 1] | 0;\n                                                d = (d + 4) | 0;\n                                                k = _(i, (g << 16) >> 16) | 0;\n                                                m = d;\n                                                d = (m + 4) | 0;\n                                                c[m >> 2] = (c[m >> 2] | 0) + k;\n                                            }\n                                            if ((l | 0) == 464) {\n                                                break;\n                                            }\n                                            return;\n                                        }\n                                    } while (0);\n                                }\n                            } while (0);\n                        }\n                    } while (0);\n                }\n                return;\n            }\n            function bM(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0;\n                h = a;\n                a = d;\n                d = e;\n                e = f;\n                f = g;\n                g = (h + 1724 + ((e * 236) | 0)) | 0;\n                i = c[(g + 60) >> 2] | 0;\n                j = c[(g + 224) >> 2] | 0;\n                k = j;\n                do {\n                    if ((j | 0) == 0) {\n                        k = c[(h + 13060) >> 2] | 0;\n                        if ((bU(h, e) | 0) == 0) {\n                            i = c[(g + 60) >> 2] | 0;\n                            break;\n                        }\n                        return;\n                    }\n                } while (0);\n                while (1) {\n                    if ((f | 0) == 0) {\n                        l = 502;\n                        break;\n                    }\n                    if ((k | 0) >= (f | 0)) {\n                        l = 495;\n                        break;\n                    }\n                    f = (f - k) | 0;\n                    while (1) {\n                        j = k;\n                        k = (j - 1) | 0;\n                        if ((j | 0) == 0) {\n                            break;\n                        }\n                        j = a;\n                        a = (j + 2) | 0;\n                        m = b[j >> 1] | 0;\n                        j = _(i, (m << 16) >> 16) | 0;\n                        n = d;\n                        d = (n + 4) | 0;\n                        c[n >> 2] = (c[n >> 2] | 0) + j;\n                    }\n                    k = c[(h + 13060) >> 2] | 0;\n                    if ((bU(h, e) | 0) != 0) {\n                        l = 493;\n                        break;\n                    }\n                    i = c[(g + 60) >> 2] | 0;\n                }\n                if ((l | 0) == 502) {\n                    return;\n                } else if ((l | 0) == 493) {\n                    return;\n                } else if ((l | 0) == 495) {\n                    c[(g + 224) >> 2] = k - f;\n                    while (1) {\n                        k = f;\n                        f = (k - 1) | 0;\n                        if ((k | 0) == 0) {\n                            break;\n                        }\n                        k = a;\n                        a = (k + 2) | 0;\n                        m = b[k >> 1] | 0;\n                        k = _(i, (m << 16) >> 16) | 0;\n                        g = d;\n                        d = (g + 4) | 0;\n                        c[g >> 2] = (c[g >> 2] | 0) + k;\n                    }\n                    return;\n                }\n            }\n            function bN(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0;\n                h = d;\n                d = e;\n                e = g;\n                g = c[(a + 1724 + ((f * 236) | 0) + 60) >> 2] | 0;\n                while (1) {\n                    f = e;\n                    e = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    f = h;\n                    h = (f + 2) | 0;\n                    a = _(g, b[f >> 1] | 0) | 0;\n                    f = d;\n                    d = (f + 4) | 0;\n                    c[f >> 2] = (c[f >> 2] | 0) + a;\n                }\n                return;\n            }\n            function bO(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0;\n                h = a;\n                a = d;\n                d = e;\n                e = f;\n                f = g;\n                g = (h + 1724 + ((e * 236) | 0)) | 0;\n                i = c[(g + 60) >> 2] | 0;\n                j = c[(g + 64) >> 2] | 0;\n                k = c[(g + 224) >> 2] | 0;\n                l = k;\n                do {\n                    if ((k | 0) == 0) {\n                        l = c[(h + 13060) >> 2] | 0;\n                        if ((bU(h, e) | 0) == 0) {\n                            i = c[(g + 60) >> 2] | 0;\n                            j = c[(g + 64) >> 2] | 0;\n                            break;\n                        }\n                        return;\n                    }\n                } while (0);\n                while (1) {\n                    if ((f | 0) == 0) {\n                        m = 530;\n                        break;\n                    }\n                    if ((l | 0) >= (f | 0)) {\n                        m = 522;\n                        break;\n                    }\n                    f = (f - l) | 0;\n                    while (1) {\n                        k = l;\n                        l = (k - 1) | 0;\n                        if ((k | 0) == 0) {\n                            break;\n                        }\n                        k = a;\n                        a = (k + 2) | 0;\n                        n = b[k >> 1] | 0;\n                        k = _(i, (n << 16) >> 16) | 0;\n                        o = d;\n                        d = (o + 4) | 0;\n                        c[o >> 2] = (c[o >> 2] | 0) + k;\n                        k = _(j, (n << 16) >> 16) | 0;\n                        o = d;\n                        d = (o + 4) | 0;\n                        c[o >> 2] = (c[o >> 2] | 0) + k;\n                    }\n                    l = c[(h + 13060) >> 2] | 0;\n                    if ((bU(h, e) | 0) != 0) {\n                        m = 520;\n                        break;\n                    }\n                    i = c[(g + 60) >> 2] | 0;\n                    j = c[(g + 64) >> 2] | 0;\n                }\n                if ((m | 0) == 522) {\n                    c[(g + 224) >> 2] = l - f;\n                    while (1) {\n                        l = f;\n                        f = (l - 1) | 0;\n                        if ((l | 0) == 0) {\n                            break;\n                        }\n                        l = a;\n                        a = (l + 2) | 0;\n                        n = b[l >> 1] | 0;\n                        l = _(i, (n << 16) >> 16) | 0;\n                        g = d;\n                        d = (g + 4) | 0;\n                        c[g >> 2] = (c[g >> 2] | 0) + l;\n                        l = _(j, (n << 16) >> 16) | 0;\n                        g = d;\n                        d = (g + 4) | 0;\n                        c[g >> 2] = (c[g >> 2] | 0) + l;\n                    }\n                    return;\n                } else if ((m | 0) == 520) {\n                    return;\n                } else if ((m | 0) == 530) {\n                    return;\n                }\n            }\n            function bP(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0;\n                h = a;\n                a = d;\n                d = e;\n                e = f;\n                f = g;\n                g = c[(h + 1724 + ((e * 236) | 0) + 60) >> 2] | 0;\n                i = c[(h + 1724 + ((e * 236) | 0) + 64) >> 2] | 0;\n                while (1) {\n                    e = f;\n                    f = (e - 1) | 0;\n                    if ((e | 0) == 0) {\n                        break;\n                    }\n                    e = a;\n                    a = (e + 2) | 0;\n                    h = b[e >> 1] | 0;\n                    e = _(g, (h << 16) >> 16) | 0;\n                    j = d;\n                    d = (j + 4) | 0;\n                    c[j >> 2] = (c[j >> 2] | 0) + e;\n                    e = _(i, (h << 16) >> 16) | 0;\n                    h = d;\n                    d = (h + 4) | 0;\n                    c[h >> 2] = (c[h >> 2] | 0) + e;\n                }\n                return;\n            }\n            function bQ(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0;\n                h = a;\n                a = d;\n                d = e;\n                e = f;\n                f = g;\n                g = (h + 1724 + ((e * 236) | 0)) | 0;\n                i = c[(g + 60) >> 2] | 0;\n                j = c[(g + 224) >> 2] | 0;\n                k = j;\n                do {\n                    if ((j | 0) == 0) {\n                        k = c[(h + 13060) >> 2] | 0;\n                        if ((bU(h, e) | 0) == 0) {\n                            i = c[(g + 60) >> 2] | 0;\n                            break;\n                        }\n                        return;\n                    }\n                } while (0);\n                while (1) {\n                    if ((f | 0) == 0) {\n                        l = 556;\n                        break;\n                    }\n                    if ((k | 0) >= (f | 0)) {\n                        l = 549;\n                        break;\n                    }\n                    f = (f - k) | 0;\n                    while (1) {\n                        j = k;\n                        k = (j - 1) | 0;\n                        if ((j | 0) == 0) {\n                            break;\n                        }\n                        j = a;\n                        a = (j + 2) | 0;\n                        m = b[j >> 1] | 0;\n                        j = _(i, (m << 16) >> 16) | 0;\n                        n = d;\n                        d = (n + 4) | 0;\n                        c[n >> 2] = (c[n >> 2] | 0) + j;\n                        j = _(i, (m << 16) >> 16) | 0;\n                        n = d;\n                        d = (n + 4) | 0;\n                        c[n >> 2] = (c[n >> 2] | 0) + j;\n                    }\n                    k = c[(h + 13060) >> 2] | 0;\n                    if ((bU(h, e) | 0) != 0) {\n                        l = 547;\n                        break;\n                    }\n                    i = c[(g + 60) >> 2] | 0;\n                }\n                if ((l | 0) == 549) {\n                    c[(g + 224) >> 2] = k - f;\n                    while (1) {\n                        k = f;\n                        f = (k - 1) | 0;\n                        if ((k | 0) == 0) {\n                            break;\n                        }\n                        k = a;\n                        a = (k + 2) | 0;\n                        m = b[k >> 1] | 0;\n                        k = _(i, (m << 16) >> 16) | 0;\n                        g = d;\n                        d = (g + 4) | 0;\n                        c[g >> 2] = (c[g >> 2] | 0) + k;\n                        k = _(i, (m << 16) >> 16) | 0;\n                        g = d;\n                        d = (g + 4) | 0;\n                        c[g >> 2] = (c[g >> 2] | 0) + k;\n                    }\n                    return;\n                } else if ((l | 0) == 556) {\n                    return;\n                } else if ((l | 0) == 547) {\n                    return;\n                }\n            }\n            function bR(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0;\n                h = d;\n                d = e;\n                e = g;\n                g = c[(a + 1724 + ((f * 236) | 0) + 60) >> 2] | 0;\n                while (1) {\n                    f = e;\n                    e = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    f = h;\n                    h = (f + 2) | 0;\n                    a = b[f >> 1] | 0;\n                    f = _(g, (a << 16) >> 16) | 0;\n                    i = d;\n                    d = (i + 4) | 0;\n                    c[i >> 2] = (c[i >> 2] | 0) + f;\n                    f = _(g, (a << 16) >> 16) | 0;\n                    a = d;\n                    d = (a + 4) | 0;\n                    c[a >> 2] = (c[a >> 2] | 0) + f;\n                }\n                return;\n            }\n            function bS(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0;\n                h = a;\n                a = d;\n                d = e;\n                e = f;\n                f = g;\n                g = (h + 1724 + ((e * 236) | 0)) | 0;\n                i = c[(g + 60) >> 2] | 0;\n                j = c[(g + 224) >> 2] | 0;\n                k = j;\n                do {\n                    if ((j | 0) == 0) {\n                        k = c[(h + 13060) >> 2] | 0;\n                        if ((bU(h, e) | 0) == 0) {\n                            i = c[(g + 60) >> 2] | 0;\n                            break;\n                        }\n                        return;\n                    }\n                } while (0);\n                while (1) {\n                    if ((f | 0) == 0) {\n                        l = 582;\n                        break;\n                    }\n                    if ((k | 0) >= (f | 0)) {\n                        l = 576;\n                        break;\n                    }\n                    f = (f - k) | 0;\n                    while (1) {\n                        j = k;\n                        k = (j - 1) | 0;\n                        if ((j | 0) == 0) {\n                            break;\n                        }\n                        j = a;\n                        a = (j + 2) | 0;\n                        m = b[j >> 1] | 0;\n                        j = _(i, (m << 16) >> 16) | 0;\n                        n = d;\n                        d = (n + 4) | 0;\n                        c[n >> 2] = (c[n >> 2] | 0) + j;\n                        d = (d + 4) | 0;\n                    }\n                    k = c[(h + 13060) >> 2] | 0;\n                    if ((bU(h, e) | 0) != 0) {\n                        l = 574;\n                        break;\n                    }\n                    i = c[(g + 60) >> 2] | 0;\n                }\n                if ((l | 0) == 582) {\n                    return;\n                } else if ((l | 0) == 576) {\n                    c[(g + 224) >> 2] = k - f;\n                    while (1) {\n                        k = f;\n                        f = (k - 1) | 0;\n                        if ((k | 0) == 0) {\n                            break;\n                        }\n                        k = a;\n                        a = (k + 2) | 0;\n                        m = b[k >> 1] | 0;\n                        k = _(i, (m << 16) >> 16) | 0;\n                        g = d;\n                        d = (g + 4) | 0;\n                        c[g >> 2] = (c[g >> 2] | 0) + k;\n                        d = (d + 4) | 0;\n                    }\n                    return;\n                } else if ((l | 0) == 574) {\n                    return;\n                }\n            }\n            function bT(a, d, e, f, g) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0;\n                h = d;\n                d = e;\n                e = g;\n                g = c[(a + 1724 + ((f * 236) | 0) + 60) >> 2] | 0;\n                while (1) {\n                    f = e;\n                    e = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    f = h;\n                    h = (f + 2) | 0;\n                    a = _(g, b[f >> 1] | 0) | 0;\n                    f = d;\n                    d = (f + 4) | 0;\n                    c[f >> 2] = (c[f >> 2] | 0) + a;\n                    d = (d + 4) | 0;\n                }\n                return;\n            }\n            function bU(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0;\n                d = a;\n                a = b;\n                do {\n                    if ((c[(d + 1724 + ((a * 236) | 0) + 32) >> 2] | 0) != 0) {\n                        if ((bV(d, a) | 0) == 0) {\n                            break;\n                        }\n                        e = 1;\n                        f = e;\n                        return f | 0;\n                    }\n                } while (0);\n                if ((c[(d + 1724 + ((a * 236) | 0) + 48) >> 2] | 0) != 0) {\n                    bW(d, a);\n                }\n                bJ(d, a);\n                e = 0;\n                f = e;\n                return f | 0;\n            }\n            function bV(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0;\n                d = a;\n                a = b;\n                b = (d + 1724 + ((a * 236) | 0) + 24) | 0;\n                c[b >> 2] =\n                    (c[b >> 2] | 0) +\n                    (c[(d + 1724 + ((a * 236) | 0) + 32) >> 2] | 0);\n                if ((c[(d + 1724 + ((a * 236) | 0) + 32) >> 2] | 0) < 0) {\n                    if (\n                        (c[(d + 1724 + ((a * 236) | 0) + 24) >> 2] | 0) <=\n                        (c[(d + 1724 + ((a * 236) | 0) + 28) >> 2] | 0)\n                    ) {\n                        e = 603;\n                    } else {\n                        e = 601;\n                    }\n                } else {\n                    e = 601;\n                }\n                do {\n                    if ((e | 0) == 601) {\n                        if (\n                            (c[(d + 1724 + ((a * 236) | 0) + 32) >> 2] | 0) <=\n                            0\n                        ) {\n                            break;\n                        }\n                        if (\n                            (c[(d + 1724 + ((a * 236) | 0) + 24) >> 2] | 0) >=\n                            (c[(d + 1724 + ((a * 236) | 0) + 28) >> 2] | 0)\n                        ) {\n                            e = 603;\n                        }\n                    }\n                } while (0);\n                do {\n                    if ((e | 0) == 603) {\n                        c[(d + 1724 + ((a * 236) | 0) + 24) >> 2] =\n                            c[(d + 1724 + ((a * 236) | 0) + 28) >> 2];\n                        if ((bI(d, a) | 0) == 0) {\n                            break;\n                        }\n                        f = 1;\n                        g = f;\n                        return g | 0;\n                    }\n                } while (0);\n                f = 0;\n                g = f;\n                return g | 0;\n            }\n            function bW(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let e = 0,\n                    f = 0;\n                e = a;\n                a = b;\n                b =\n                    (d[\n                        ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] | 0) + 108) |\n                            0\n                    ] |\n                        0) <<\n                    7;\n                if ((c[(e + 1724 + ((a * 236) | 0) + 36) >> 2] | 0) != 0) {\n                    f = (e + 1724 + ((a * 236) | 0) + 40) | 0;\n                    c[f >> 2] =\n                        (c[f >> 2] | 0) +\n                        (c[(e + 1724 + ((a * 236) | 0) + 36) >> 2] | 0);\n                    if (\n                        (c[(e + 1724 + ((a * 236) | 0) + 40) >> 2] | 0) >=\n                        65536\n                    ) {\n                        c[(e + 1724 + ((a * 236) | 0) + 36) >> 2] = 0;\n                    } else {\n                        b =\n                            _(\n                                b,\n                                c[(e + 1724 + ((a * 236) | 0) + 40) >> 2] | 0\n                            ) | 0;\n                        b = b >> 16;\n                    }\n                }\n                f = (e + 1724 + ((a * 236) | 0) + 44) | 0;\n                c[f >> 2] =\n                    (c[f >> 2] | 0) +\n                    (c[(e + 1724 + ((a * 236) | 0) + 48) >> 2] | 0);\n                g[(e + 1724 + ((a * 236) | 0) + 76) >> 2] =\n                    1.0 -\n                    (+R(\n                        +(\n                            +(\n                                (c[(e + 1724 + ((a * 236) | 0) + 44) >> 2] >>\n                                    5) |\n                                0\n                            ) * 0.006135923151542565\n                        )\n                    ) +\n                        1.0) *\n                        +(b | 0) *\n                        1.0 *\n                        762939453125.0e-17;\n                return;\n            }\n            function bX(b, d, e) {\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0;\n                f = d;\n                d = e;\n                e = b;\n                while (1) {\n                    b = d;\n                    d = (b - 1) | 0;\n                    if ((b | 0) == 0) {\n                        break;\n                    }\n                    b = f;\n                    f = (b + 4) | 0;\n                    g = c[b >> 2] >> 21;\n                    if ((g | 0) > 127) {\n                        g = 127;\n                    } else {\n                        if ((g | 0) < -128) {\n                            g = -128;\n                        }\n                    }\n                    b = e;\n                    e = (b + 1) | 0;\n                    a[b] = g & 255;\n                }\n                return;\n            }\n            function bY(b, d, e) {\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0;\n                f = d;\n                d = e;\n                e = b;\n                while (1) {\n                    b = d;\n                    d = (b - 1) | 0;\n                    if ((b | 0) == 0) {\n                        break;\n                    }\n                    b = f;\n                    f = (b + 4) | 0;\n                    g = c[b >> 2] >> 21;\n                    if ((g | 0) > 127) {\n                        g = 127;\n                    } else {\n                        if ((g | 0) < -128) {\n                            g = -128;\n                        }\n                    }\n                    b = e;\n                    e = (b + 1) | 0;\n                    a[b] = (128 ^ (g & 255)) & 255;\n                }\n                return;\n            }\n            function bZ(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0;\n                f = d;\n                d = e;\n                e = a;\n                while (1) {\n                    a = d;\n                    d = (a - 1) | 0;\n                    if ((a | 0) == 0) {\n                        break;\n                    }\n                    a = f;\n                    f = (a + 4) | 0;\n                    g = c[a >> 2] >> 13;\n                    if ((g | 0) > 32767) {\n                        g = 32767;\n                    } else {\n                        if ((g | 0) < -32768) {\n                            g = -32768;\n                        }\n                    }\n                    a = e;\n                    e = (a + 2) | 0;\n                    b[a >> 1] = g & 65535;\n                }\n                return;\n            }\n            function b_(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0;\n                f = d;\n                d = e;\n                e = a;\n                while (1) {\n                    a = d;\n                    d = (a - 1) | 0;\n                    if ((a | 0) == 0) {\n                        break;\n                    }\n                    a = f;\n                    f = (a + 4) | 0;\n                    g = c[a >> 2] >> 13;\n                    if ((g | 0) > 32767) {\n                        g = 32767;\n                    } else {\n                        if ((g | 0) < -32768) {\n                            g = -32768;\n                        }\n                    }\n                    a = e;\n                    e = (a + 2) | 0;\n                    b[a >> 1] = (32768 ^ (g & 65535)) & 65535;\n                }\n                return;\n            }\n            function b$(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0;\n                f = d;\n                d = e;\n                e = a;\n                while (1) {\n                    a = d;\n                    d = (a - 1) | 0;\n                    if ((a | 0) == 0) {\n                        break;\n                    }\n                    a = f;\n                    f = (a + 4) | 0;\n                    g = c[a >> 2] >> 13;\n                    if ((g | 0) > 32767) {\n                        g = 32767;\n                    } else {\n                        if ((g | 0) < -32768) {\n                            g = -32768;\n                        }\n                    }\n                    a = e;\n                    e = (a + 2) | 0;\n                    b[a >> 1] =\n                        ((((((g & 65535) << 16) >> 16) & 255) << 8) |\n                            (((((g & 65535) << 16) >> 16) >> 8) & 255)) &\n                        65535;\n                }\n                return;\n            }\n            function b0(b, d, e, f) {\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                let g = 0,\n                    h = 0;\n                g = i;\n                i = (i + 8) | 0;\n                h = g | 0;\n                c[h >> 2] = 0;\n                a[(h + 5) | 0] = 1;\n                a[(h + 4) | 0] = d & 255;\n                a[(h + 6) | 0] = e & 255;\n                a[(h + 7) | 0] = f & 255;\n                b1(b, h);\n                i = g;\n                return;\n            }\n            function b1(b, e) {\n                b = b | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0;\n                f = b;\n                b = e;\n                e = c[(f + 13052) >> 2] | 0;\n                g = -1;\n                h = 2147483647;\n                if (0 == (b | 0)) {\n                    i = c[(f + 13080) >> 2] | 0;\n                } else {\n                    i = b;\n                }\n                while (1) {\n                    b = e;\n                    e = (b - 1) | 0;\n                    if ((b | 0) == 0) {\n                        break;\n                    }\n                    if ((d[(f + 1724 + ((e * 236) | 0)) | 0] | 0 | 0) == 0) {\n                        g = e;\n                    } else {\n                        do {\n                            if (\n                                (d[(f + 1724 + ((e * 236) | 0) + 1) | 0] |\n                                    0 |\n                                    0) ==\n                                (d[(i + 4) | 0] | 0 | 0)\n                            ) {\n                                if (\n                                    (d[(f + 1724 + ((e * 236) | 0) + 2) | 0] |\n                                        0 |\n                                        0) !=\n                                    (d[(i + 6) | 0] | 0 | 0)\n                                ) {\n                                    if (\n                                        (c[\n                                            (f +\n                                                1084 +\n                                                (((d[\n                                                    (f +\n                                                        1724 +\n                                                        ((e * 236) | 0) +\n                                                        1) |\n                                                        0\n                                                ] |\n                                                    0) *\n                                                    40) |\n                                                    0) +\n                                                28) >>\n                                                2\n                                        ] |\n                                            0) ==\n                                        0\n                                    ) {\n                                        break;\n                                    }\n                                }\n                                ch(f, e);\n                            }\n                        } while (0);\n                    }\n                }\n                if ((g | 0) != -1) {\n                    cn(f, i, g);\n                    return;\n                }\n                e = c[(f + 13052) >> 2] | 0;\n                while (1) {\n                    b = e;\n                    e = (b - 1) | 0;\n                    if ((b | 0) == 0) {\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(f + 1724 + ((e * 236) | 0)) | 0] | 0 | 0) !=\n                            1\n                        ) {\n                            if (\n                                (d[(f + 1724 + ((e * 236) | 0)) | 0] | 0 | 0) ==\n                                4\n                            ) {\n                                break;\n                            }\n                            b = c[(f + 1724 + ((e * 236) | 0) + 60) >> 2] | 0;\n                            do {\n                                if (\n                                    (c[\n                                        (f + 1724 + ((e * 236) | 0) + 232) >> 2\n                                    ] |\n                                        0) ==\n                                    0\n                                ) {\n                                    if (\n                                        (c[\n                                            (f + 1724 + ((e * 236) | 0) + 64) >>\n                                                2\n                                        ] |\n                                            0) <=\n                                        (b | 0)\n                                    ) {\n                                        break;\n                                    }\n                                    b =\n                                        c[\n                                            (f + 1724 + ((e * 236) | 0) + 64) >>\n                                                2\n                                        ] | 0;\n                                }\n                            } while (0);\n                            if ((b | 0) < (h | 0)) {\n                                h = b;\n                                g = e;\n                            }\n                        }\n                    } while (0);\n                }\n                if ((g | 0) != -1) {\n                    e = (f + 13068) | 0;\n                    c[e >> 2] = (c[e >> 2] | 0) + 1;\n                    a[(f + 1724 + ((g * 236) | 0)) | 0] = 0;\n                    cn(f, i, g);\n                    return;\n                } else {\n                    g = (f + 13064) | 0;\n                    c[g >> 2] = (c[g >> 2] | 0) + 1;\n                    return;\n                }\n            }\n            function b2(b, e) {\n                b = b | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0;\n                f = b;\n                b = e;\n                e = c[(f + 13052) >> 2] | 0;\n                if (0 == (b | 0)) {\n                    g = c[(f + 13080) >> 2] | 0;\n                } else {\n                    g = b;\n                }\n                L890: while (1) {\n                    b = e;\n                    e = (b - 1) | 0;\n                    if ((b | 0) == 0) {\n                        h = 709;\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(f + 1724 + ((e * 236) | 0)) | 0] | 0 | 0) ==\n                            1\n                        ) {\n                            if (\n                                (d[(f + 1724 + ((e * 236) | 0) + 1) | 0] |\n                                    0 |\n                                    0) !=\n                                (d[(g + 4) | 0] | 0 | 0)\n                            ) {\n                                break;\n                            }\n                            if (\n                                (d[(f + 1724 + ((e * 236) | 0) + 2) | 0] |\n                                    0 |\n                                    0) ==\n                                (d[(g + 6) | 0] | 0 | 0)\n                            ) {\n                                break L890;\n                            }\n                        }\n                    } while (0);\n                }\n                if ((h | 0) == 709) {\n                    return;\n                }\n                if (\n                    (c[\n                        (f + 1084 + (((d[(g + 4) | 0] | 0) * 40) | 0) + 12) >> 2\n                    ] |\n                        0) !=\n                    0\n                ) {\n                    a[(f + 1724 + ((e * 236) | 0)) | 0] = 2;\n                } else {\n                    ci(f, e);\n                }\n                return;\n            }\n            function b3(a) {\n                a = a | 0;\n                let b = 0;\n                b = a;\n                c[b >> 2] = 1;\n                b4(b);\n                b5(b, 0);\n                return;\n            }\n            function b4(a) {\n                a = a | 0;\n                let b = 0;\n                b = a;\n                g[(b + 16) >> 2] = +(c[(b + 20) >> 2] | 0) / 100.0;\n                return;\n            }\n            function b5(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0;\n                d = a;\n                a = b;\n                if ((c[(d + 13088) >> 2] | 0) > (a | 0)) {\n                    c[(d + 13088) >> 2] = 0;\n                }\n                ck(d);\n                c[(d + 13080) >> 2] = c[(d + 13076) >> 2];\n                c[392] = 5e5;\n                if ((a | 0) == 0) {\n                    return;\n                }\n                cl(d, a);\n                return;\n            }\n            function b6(b, e, f, h) {\n                b = b | 0;\n                e = e | 0;\n                f = f | 0;\n                h = h | 0;\n                let j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0;\n                j = i;\n                i = (i + 8) | 0;\n                k = j | 0;\n                l = b;\n                c[k >> 2] = e;\n                e = h;\n                if ((c[l >> 2] | 0) == 0) {\n                    m = 0;\n                    n = m;\n                    i = j;\n                    return n | 0;\n                }\n                h = ((f >>> 0) / ((c[(l + 12) >> 2] | 0) >>> 0)) | 0;\n                f = c[(l + 13088) >> 2] | 0;\n                b = ((c[(l + 13088) >> 2] | 0) + h) | 0;\n                L920: while (1) {\n                    if ((c[(l + 13088) >> 2] | 0) >= (b | 0)) {\n                        o = 758;\n                        break;\n                    }\n                    while (1) {\n                        if (\n                            ~~(+(c[c[(l + 13080) >> 2] >> 2] | 0) / +g[258]) >>>\n                                0 >\n                            (c[(l + 13088) >> 2] | 0) >>> 0\n                        ) {\n                            break;\n                        }\n                        switch (d[((c[(l + 13080) >> 2] | 0) + 5) | 0] | 0) {\n                            case 99: {\n                                if (0 == (e | 0)) {\n                                    o = 752;\n                                    break L920;\n                                }\n                                break;\n                            }\n                            case 6: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        12) >>\n                                        2\n                                ] = d[((c[(l + 13080) >> 2] | 0) + 6) | 0] | 0;\n                                if (\n                                    (a[((c[(l + 13080) >> 2] | 0) + 6) | 0] |\n                                        0) ==\n                                    0\n                                ) {\n                                    ca(l);\n                                }\n                                break;\n                            }\n                            case 3: {\n                                b7(l);\n                                break;\n                            }\n                            case 11: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        32) >>\n                                        2\n                                ] = d[((c[(l + 13080) >> 2] | 0) + 6) | 0] | 0;\n                                g[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        36) >>\n                                        2\n                                ] = 0.0;\n                                break;\n                            }\n                            case 14: {\n                                cc(l);\n                                break;\n                            }\n                            case 12: {\n                                cd(l);\n                                break;\n                            }\n                            case 13: {\n                                cb(\n                                    l,\n                                    d[((c[(l + 13080) >> 2] | 0) + 4) | 0] | 0\n                                );\n                                break;\n                            }\n                            case 9: {\n                                if (\n                                    ((c[(l + 13056) >> 2] &\n                                        (1 <<\n                                            d[\n                                                ((c[(l + 13080) >> 2] | 0) +\n                                                    4) |\n                                                    0\n                                            ])) |\n                                        0) !=\n                                    0\n                                ) {\n                                    c[\n                                        (l +\n                                            1084 +\n                                            (((d[\n                                                ((c[(l + 13080) >> 2] | 0) +\n                                                    4) |\n                                                    0\n                                            ] |\n                                                0) *\n                                                40) |\n                                                0)) >>\n                                            2\n                                    ] =\n                                        d[((c[(l + 13080) >> 2] | 0) + 6) | 0] |\n                                        0;\n                                } else {\n                                    c[\n                                        (l +\n                                            1084 +\n                                            (((d[\n                                                ((c[(l + 13080) >> 2] | 0) +\n                                                    4) |\n                                                    0\n                                            ] |\n                                                0) *\n                                                40) |\n                                                0) +\n                                            4) >>\n                                            2\n                                    ] =\n                                        d[((c[(l + 13080) >> 2] | 0) + 6) | 0] |\n                                        0;\n                                }\n                                break;\n                            }\n                            case 5: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        16) >>\n                                        2\n                                ] = d[((c[(l + 13080) >> 2] | 0) + 6) | 0] | 0;\n                                break;\n                            }\n                            case 7: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        24) >>\n                                        2\n                                ] = d[((c[(l + 13080) >> 2] | 0) + 6) | 0] | 0;\n                                b9(l);\n                                break;\n                            }\n                            case 1: {\n                                if (\n                                    (a[((c[(l + 13080) >> 2] | 0) + 7) | 0] |\n                                        0) !=\n                                    0\n                                ) {\n                                    b1(l, 0);\n                                } else {\n                                    b2(l, 0);\n                                }\n                                break;\n                            }\n                            case 15: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0)) >>\n                                        2\n                                ] = d[((c[(l + 13080) >> 2] | 0) + 6) | 0] | 0;\n                                break;\n                            }\n                            case 10: {\n                                c[392] =\n                                    (d[((c[(l + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) +\n                                    (d[((c[(l + 13080) >> 2] | 0) + 7) | 0] <<\n                                        8) +\n                                    (d[((c[(l + 13080) >> 2] | 0) + 6) | 0] <<\n                                        16);\n                                break;\n                            }\n                            case 8: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        20) >>\n                                        2\n                                ] =\n                                    (d[((c[(l + 13080) >> 2] | 0) + 6) | 0] |\n                                        0) +\n                                    (d[((c[(l + 13080) >> 2] | 0) + 7) | 0] <<\n                                        7);\n                                g[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        36) >>\n                                        2\n                                ] = 0.0;\n                                b8(l);\n                                break;\n                            }\n                            case 4: {\n                                c[\n                                    (l +\n                                        1084 +\n                                        (((d[\n                                            ((c[(l + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        8) >>\n                                        2\n                                ] = d[((c[(l + 13080) >> 2] | 0) + 6) | 0] | 0;\n                                b9(l);\n                                break;\n                            }\n                            case 2: {\n                                b2(l, 0);\n                                break;\n                            }\n                            default: {\n                            }\n                        }\n                        p = (l + 13080) | 0;\n                        c[p >> 2] = (c[p >> 2] | 0) + 8;\n                    }\n                    if (\n                        ~~(+(c[c[(l + 13080) >> 2] >> 2] | 0) / +g[258]) >>> 0 >\n                        b >>> 0\n                    ) {\n                        ce(l, k, (b - (c[(l + 13088) >> 2] | 0)) | 0);\n                    } else {\n                        ce(\n                            l,\n                            k,\n                            (~~(+(c[c[(l + 13080) >> 2] >> 2] | 0) / +g[258]) -\n                                (c[(l + 13088) >> 2] | 0)) |\n                                0\n                        );\n                    }\n                }\n                if ((o | 0) == 752) {\n                    c[l >> 2] = 0;\n                    m =\n                        _(\n                            ((c[(l + 13088) >> 2] | 0) - f) | 0,\n                            c[(l + 12) >> 2] | 0\n                        ) | 0;\n                    n = m;\n                    i = j;\n                    return n | 0;\n                } else if ((o | 0) == 758) {\n                    m = _(h, c[(l + 12) >> 2] | 0) | 0;\n                    n = m;\n                    i = j;\n                    return n | 0;\n                }\n                return 0;\n            }\n            function b7(b) {\n                b = b | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0;\n                e = b;\n                b = c[(e + 13080) >> 2] | 0;\n                f = c[(e + 13052) >> 2] | 0;\n                L967: while (1) {\n                    g = f;\n                    f = (g - 1) | 0;\n                    if ((g | 0) == 0) {\n                        h = 772;\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(e + 1724 + ((f * 236) | 0)) | 0] | 0 | 0) ==\n                            1\n                        ) {\n                            if (\n                                (d[(e + 1724 + ((f * 236) | 0) + 1) | 0] |\n                                    0 |\n                                    0) !=\n                                (d[(b + 4) | 0] | 0 | 0)\n                            ) {\n                                break;\n                            }\n                            if (\n                                (d[(e + 1724 + ((f * 236) | 0) + 2) | 0] |\n                                    0 |\n                                    0) ==\n                                (d[(b + 6) | 0] | 0 | 0)\n                            ) {\n                                break L967;\n                            }\n                        }\n                    } while (0);\n                }\n                if ((h | 0) == 772) {\n                    return;\n                }\n                a[(e + 1724 + ((f * 236) | 0) + 3) | 0] = a[(b + 7) | 0] | 0;\n                cf(e, f);\n                bJ(e, f);\n                return;\n            }\n            function b8(a) {\n                a = a | 0;\n                let b = 0,\n                    e = 0,\n                    f = 0;\n                b = a;\n                a = d[((c[(b + 13080) >> 2] | 0) + 4) | 0] | 0;\n                e = c[(b + 13052) >> 2] | 0;\n                while (1) {\n                    f = e;\n                    e = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(b + 1724 + ((e * 236) | 0)) | 0] | 0 | 0) !=\n                            0\n                        ) {\n                            if (\n                                (d[(b + 1724 + ((e * 236) | 0) + 1) | 0] |\n                                    0 |\n                                    0) !=\n                                (a | 0)\n                            ) {\n                                break;\n                            }\n                            cj(b, e);\n                        }\n                    } while (0);\n                }\n                return;\n            }\n            function b9(a) {\n                a = a | 0;\n                let b = 0,\n                    e = 0,\n                    f = 0;\n                b = a;\n                a = d[((c[(b + 13080) >> 2] | 0) + 4) | 0] | 0;\n                e = c[(b + 13052) >> 2] | 0;\n                while (1) {\n                    f = e;\n                    e = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(b + 1724 + ((e * 236) | 0) + 1) | 0] | 0 | 0) ==\n                            (a | 0)\n                        ) {\n                            if (\n                                (d[(b + 1724 + ((e * 236) | 0)) | 0] | 0 | 0) !=\n                                1\n                            ) {\n                                if (\n                                    (d[(b + 1724 + ((e * 236) | 0)) | 0] |\n                                        0 |\n                                        0) !=\n                                    2\n                                ) {\n                                    break;\n                                }\n                            }\n                            cf(b, e);\n                            bJ(b, e);\n                        }\n                    } while (0);\n                }\n                return;\n            }\n            function ca(a) {\n                a = a | 0;\n                let b = 0,\n                    e = 0,\n                    f = 0;\n                b = a;\n                a = c[(b + 13052) >> 2] | 0;\n                e = d[((c[(b + 13080) >> 2] | 0) + 4) | 0] | 0;\n                while (1) {\n                    f = a;\n                    a = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(b + 1724 + ((a * 236) | 0)) | 0] | 0 | 0) ==\n                            2\n                        ) {\n                            if (\n                                (d[(b + 1724 + ((a * 236) | 0) + 1) | 0] |\n                                    0 |\n                                    0) !=\n                                (e | 0)\n                            ) {\n                                break;\n                            }\n                            ci(b, a);\n                        }\n                    } while (0);\n                }\n                return;\n            }\n            function cb(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0;\n                d = a;\n                a = b;\n                c[(d + 1084 + ((a * 40) | 0) + 8) >> 2] = 90;\n                c[(d + 1084 + ((a * 40) | 0) + 24) >> 2] = 127;\n                c[(d + 1084 + ((a * 40) | 0) + 12) >> 2] = 0;\n                c[(d + 1084 + ((a * 40) | 0) + 20) >> 2] = 8192;\n                g[(d + 1084 + ((a * 40) | 0) + 36) >> 2] = 0.0;\n                return;\n            }\n            function cc(b) {\n                b = b | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0;\n                e = b;\n                b = c[(e + 13052) >> 2] | 0;\n                f = d[((c[(e + 13080) >> 2] | 0) + 4) | 0] | 0;\n                while (1) {\n                    g = b;\n                    b = (g - 1) | 0;\n                    if ((g | 0) == 0) {\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(e + 1724 + ((b * 236) | 0)) | 0] | 0 | 0) ==\n                            1\n                        ) {\n                            if (\n                                (d[(e + 1724 + ((b * 236) | 0) + 1) | 0] |\n                                    0 |\n                                    0) !=\n                                (f | 0)\n                            ) {\n                                break;\n                            }\n                            if (\n                                (c[(e + 1084 + ((f * 40) | 0) + 12) >> 2] |\n                                    0) !=\n                                0\n                            ) {\n                                a[(e + 1724 + ((b * 236) | 0)) | 0] = 2;\n                            } else {\n                                ci(e, b);\n                            }\n                        }\n                    } while (0);\n                }\n                return;\n            }\n            function cd(a) {\n                a = a | 0;\n                let b = 0,\n                    e = 0,\n                    f = 0;\n                b = a;\n                a = c[(b + 13052) >> 2] | 0;\n                e = d[((c[(b + 13080) >> 2] | 0) + 4) | 0] | 0;\n                while (1) {\n                    f = a;\n                    a = (f - 1) | 0;\n                    if ((f | 0) == 0) {\n                        break;\n                    }\n                    do {\n                        if (\n                            (d[(b + 1724 + ((a * 236) | 0) + 1) | 0] | 0 | 0) ==\n                            (e | 0)\n                        ) {\n                            if (\n                                (d[(b + 1724 + ((a * 236) | 0)) | 0] | 0 | 0) ==\n                                0\n                            ) {\n                                break;\n                            }\n                            if (\n                                (d[(b + 1724 + ((a * 236) | 0)) | 0] | 0 | 0) ==\n                                4\n                            ) {\n                                break;\n                            }\n                            ch(b, a);\n                        }\n                    } while (0);\n                }\n                return;\n            }\n            function ce(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0;\n                e = a;\n                a = b;\n                b = d;\n                if (((c[(e + 8) >> 2] & 1) | 0) != 0) {\n                    f = 1;\n                } else {\n                    f = 2;\n                }\n                while (1) {\n                    if ((b | 0) == 0) {\n                        break;\n                    }\n                    d = b;\n                    if ((d | 0) > (c[(e + 1064) >> 2] | 0)) {\n                        d = c[(e + 1064) >> 2] | 0;\n                    }\n                    cg(e, d);\n                    g = c[(e + 1060) >> 2] | 0;\n                    h = c[a >> 2] | 0;\n                    i = c[(e + 1072) >> 2] | 0;\n                    j = _(f, d) | 0;\n                    aZ[g & 15](h, i, j);\n                    j = _(c[(e + 12) >> 2] | 0, d) | 0;\n                    i = a;\n                    c[i >> 2] = (c[i >> 2] | 0) + j;\n                    b = (b - d) | 0;\n                }\n                return;\n            }\n            function cf(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let e = 0,\n                    f = 0,\n                    h = 0;\n                e = a;\n                a = b;\n                b =\n                    _(\n                        d[(e + 1724 + ((a * 236) | 0) + 3) | 0] | 0,\n                        c[\n                            (e +\n                                1084 +\n                                (((d[(e + 1724 + ((a * 236) | 0) + 1) | 0] |\n                                    0) *\n                                    40) |\n                                    0) +\n                                8) >>\n                                2\n                        ] | 0\n                    ) | 0;\n                f =\n                    _(\n                        b,\n                        c[\n                            (e +\n                                1084 +\n                                (((d[(e + 1724 + ((a * 236) | 0) + 1) | 0] |\n                                    0) *\n                                    40) |\n                                    0) +\n                                24) >>\n                                2\n                        ] | 0\n                    ) | 0;\n                if (((c[(e + 8) >> 2] & 1) | 0) != 0) {\n                    c[(e + 1724 + ((a * 236) | 0) + 232) >> 2] = 3;\n                    g[(e + 1724 + ((a * 236) | 0) + 68) >> 2] =\n                        +(f | 0) *\n                        +g[\n                            ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] | 0) +\n                                84) >>\n                                2\n                        ] *\n                        +g[(e + 16) >> 2] *\n                        4.76837158203125e-7;\n                    return;\n                }\n                do {\n                    if ((c[(e + 1724 + ((a * 236) | 0) + 228) >> 2] | 0) > 60) {\n                        if (\n                            (c[(e + 1724 + ((a * 236) | 0) + 228) >> 2] | 0) >=\n                            68\n                        ) {\n                            h = 827;\n                            break;\n                        }\n                        c[(e + 1724 + ((a * 236) | 0) + 232) >> 2] = 3;\n                        g[(e + 1724 + ((a * 236) | 0) + 68) >> 2] =\n                            +(f | 0) *\n                            +g[\n                                ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] |\n                                    0) +\n                                    84) >>\n                                    2\n                            ] *\n                            +g[(e + 16) >> 2] *\n                            4.76837158203125e-7;\n                    } else {\n                        h = 827;\n                    }\n                } while (0);\n                if ((h | 0) == 827) {\n                    if ((c[(e + 1724 + ((a * 236) | 0) + 228) >> 2] | 0) < 5) {\n                        c[(e + 1724 + ((a * 236) | 0) + 232) >> 2] = 1;\n                        g[(e + 1724 + ((a * 236) | 0) + 68) >> 2] =\n                            +(f | 0) *\n                            +g[\n                                ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] |\n                                    0) +\n                                    84) >>\n                                    2\n                            ] *\n                            +g[(e + 16) >> 2] *\n                            9.5367431640625e-7;\n                    } else {\n                        if (\n                            (c[(e + 1724 + ((a * 236) | 0) + 228) >> 2] | 0) >\n                            123\n                        ) {\n                            c[(e + 1724 + ((a * 236) | 0) + 232) >> 2] = 2;\n                            g[(e + 1724 + ((a * 236) | 0) + 68) >> 2] =\n                                +(f | 0) *\n                                +g[\n                                    ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] |\n                                        0) +\n                                        84) >>\n                                        2\n                                ] *\n                                +g[(e + 16) >> 2] *\n                                9.5367431640625e-7;\n                        } else {\n                            c[(e + 1724 + ((a * 236) | 0) + 232) >> 2] = 0;\n                            g[(e + 1724 + ((a * 236) | 0) + 68) >> 2] =\n                                +(f | 0) *\n                                +g[\n                                    ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] |\n                                        0) +\n                                        84) >>\n                                        2\n                                ] *\n                                +g[(e + 16) >> 2] *\n                                7.450580596923828e-9;\n                            g[(e + 1724 + ((a * 236) | 0) + 72) >> 2] =\n                                +g[(e + 1724 + ((a * 236) | 0) + 68) >> 2] *\n                                +(\n                                    c[(e + 1724 + ((a * 236) | 0) + 228) >> 2] |\n                                    0\n                                );\n                            f = (e + 1724 + ((a * 236) | 0) + 68) | 0;\n                            g[f >> 2] =\n                                +g[f >> 2] *\n                                +(\n                                    (127 -\n                                        (c[\n                                            (e +\n                                                1724 +\n                                                ((a * 236) | 0) +\n                                                228) >>\n                                                2\n                                        ] |\n                                            0)) |\n                                    0\n                                );\n                        }\n                    }\n                }\n                return;\n            }\n            function cg(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let e = 0,\n                    f = 0;\n                e = a;\n                a = b;\n                if (((c[(e + 8) >> 2] & 1) | 0) != 0) {\n                    f = a << 2;\n                } else {\n                    f = a << 3;\n                }\n                c5(c[(e + 1072) >> 2] | 0, 0, f | 0);\n                f = 0;\n                while (1) {\n                    if ((f | 0) >= (c[(e + 13052) >> 2] | 0)) {\n                        break;\n                    }\n                    if ((d[(e + 1724 + ((f * 236) | 0)) | 0] | 0 | 0) != 0) {\n                        bK(e, c[(e + 1072) >> 2] | 0, f, a);\n                    }\n                    f = (f + 1) | 0;\n                }\n                f = (e + 13088) | 0;\n                c[f >> 2] = (c[f >> 2] | 0) + a;\n                return;\n            }\n            function ch(b, c) {\n                b = b | 0;\n                c = c | 0;\n                a[(b + 1724 + ((c * 236) | 0)) | 0] = 4;\n                return;\n            }\n            function ci(b, d) {\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0;\n                e = b;\n                b = d;\n                if (\n                    ((a[\n                        ((c[(e + 1724 + ((b * 236) | 0) + 4) >> 2] | 0) + 110) |\n                            0\n                    ] &\n                        64) |\n                        0) !=\n                    0\n                ) {\n                    c[(e + 1724 + ((b * 236) | 0) + 220) >> 2] = 3;\n                    a[(e + 1724 + ((b * 236) | 0)) | 0] = 3;\n                    d = e;\n                    f = b;\n                    bI(d, f) | 0;\n                    bJ(e, b);\n                    return;\n                } else {\n                    a[(e + 1724 + ((b * 236) | 0)) | 0] = 3;\n                    return;\n                }\n            }\n            function cj(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let e = 0,\n                    f = 0,\n                    i = 0,\n                    j = 0,\n                    l = 0,\n                    m = 0.0;\n                e = a;\n                a = b;\n                b = ((c[(e + 1724 + ((a * 236) | 0) + 20) >> 2] | 0) < 0) | 0;\n                f =\n                    c[\n                        (e +\n                            1084 +\n                            (((d[(e + 1724 + ((a * 236) | 0) + 1) | 0] | 0) *\n                                40) |\n                                0) +\n                            20) >>\n                            2\n                    ] | 0;\n                if (\n                    (c[\n                        ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] | 0) + 12) >>\n                            2\n                    ] |\n                        0) ==\n                    0\n                ) {\n                    return;\n                }\n                if ((c[(e + 1724 + ((a * 236) | 0) + 212) >> 2] | 0) != 0) {\n                    i = 32;\n                    while (1) {\n                        j = i;\n                        i = (j - 1) | 0;\n                        if ((j | 0) == 0) {\n                            break;\n                        }\n                        c[\n                            (e + 1724 + ((a * 236) | 0) + 80 + (i << 2)) >> 2\n                        ] = 0;\n                    }\n                }\n                do {\n                    if ((f | 0) == 8192) {\n                        l = 866;\n                    } else {\n                        if ((f | 0) < 0) {\n                            l = 866;\n                            break;\n                        }\n                        if ((f | 0) > 16383) {\n                            l = 866;\n                            break;\n                        }\n                        f = (f - 8192) | 0;\n                        if (\n                            +g[\n                                (e +\n                                    1084 +\n                                    (((d[(e + 1724 + ((a * 236) | 0) + 1) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    36) >>\n                                    2\n                            ] == 0.0\n                        ) {\n                            i =\n                                _(\n                                    f,\n                                    c[\n                                        (e +\n                                            1084 +\n                                            (((d[\n                                                (e +\n                                                    1724 +\n                                                    ((a * 236) | 0) +\n                                                    1) |\n                                                    0\n                                            ] |\n                                                0) *\n                                                40) |\n                                                0) +\n                                            32) >>\n                                            2\n                                    ] | 0\n                                ) | 0;\n                            if ((f | 0) < 0) {\n                                i = -i | 0;\n                            }\n                            j = (1704 + (((i >> 5) & 255) << 3)) | 0;\n                            m =\n                                ((c[k >> 2] =\n                                    d[j] |\n                                    (d[(j + 1) | 0] << 8) |\n                                    (d[(j + 2) | 0] << 16) |\n                                    (d[(j + 3) | 0] << 24)),\n                                (c[(k + 4) >> 2] =\n                                    d[(j + 4) | 0] |\n                                    (d[(j + 5) | 0] << 8) |\n                                    (d[(j + 6) | 0] << 16) |\n                                    (d[(j + 7) | 0] << 24)),\n                                +h[k >> 3]);\n                            j = (3752 + ((i >> 13) << 3)) | 0;\n                            g[\n                                (e +\n                                    1084 +\n                                    (((d[(e + 1724 + ((a * 236) | 0) + 1) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    36) >>\n                                    2\n                            ] =\n                                m *\n                                ((c[k >> 2] =\n                                    d[j] |\n                                    (d[(j + 1) | 0] << 8) |\n                                    (d[(j + 2) | 0] << 16) |\n                                    (d[(j + 3) | 0] << 24)),\n                                (c[(k + 4) >> 2] =\n                                    d[(j + 4) | 0] |\n                                    (d[(j + 5) | 0] << 8) |\n                                    (d[(j + 6) | 0] << 16) |\n                                    (d[(j + 7) | 0] << 24)),\n                                +h[k >> 3]);\n                        }\n                        if ((f | 0) > 0) {\n                            c[(e + 1724 + ((a * 236) | 0) + 12) >> 2] = ~~(\n                                +g[\n                                    (e +\n                                        1084 +\n                                        (((d[\n                                            (e + 1724 + ((a * 236) | 0) + 1) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        36) >>\n                                        2\n                                ] *\n                                +(c[(e + 1724 + ((a * 236) | 0) + 8) >> 2] | 0)\n                            );\n                        } else {\n                            c[(e + 1724 + ((a * 236) | 0) + 12) >> 2] = ~~(\n                                +(\n                                    c[(e + 1724 + ((a * 236) | 0) + 8) >> 2] | 0\n                                ) /\n                                +g[\n                                    (e +\n                                        1084 +\n                                        (((d[\n                                            (e + 1724 + ((a * 236) | 0) + 1) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        36) >>\n                                        2\n                                ]\n                            );\n                        }\n                    }\n                } while (0);\n                if ((l | 0) == 866) {\n                    c[(e + 1724 + ((a * 236) | 0) + 12) >> 2] =\n                        c[(e + 1724 + ((a * 236) | 0) + 8) >> 2];\n                }\n                m =\n                    ((+(\n                        c[\n                            ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] | 0) +\n                                12) >>\n                                2\n                        ] | 0\n                    ) *\n                        +(c[(e + 1724 + ((a * 236) | 0) + 12) >> 2] | 0)) /\n                        (+(\n                            c[\n                                ((c[(e + 1724 + ((a * 236) | 0) + 4) >> 2] |\n                                    0) +\n                                    32) >>\n                                    2\n                            ] | 0\n                        ) *\n                            +(c[(e + 4) >> 2] | 0))) *\n                    4096.0;\n                if ((b | 0) != 0) {\n                    m = -0.0 - m;\n                }\n                c[(e + 1724 + ((a * 236) | 0) + 20) >> 2] = ~~m;\n                return;\n            }\n            function ck(a) {\n                a = a | 0;\n                let b = 0;\n                b = a;\n                a = 0;\n                while (1) {\n                    if ((a | 0) >= 16) {\n                        break;\n                    }\n                    cb(b, a);\n                    c[(b + 1084 + ((a * 40) | 0) + 4) >> 2] =\n                        c[(b + 1056) >> 2];\n                    c[(b + 1084 + ((a * 40) | 0) + 16) >> 2] = -1;\n                    c[(b + 1084 + ((a * 40) | 0) + 32) >> 2] = 2;\n                    c[(b + 1084 + ((a * 40) | 0)) >> 2] = 0;\n                    a = (a + 1) | 0;\n                }\n                cm(b);\n                return;\n            }\n            function cl(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let e = 0,\n                    f = 0;\n                e = a;\n                a = b;\n                cm(e);\n                L1123: while (1) {\n                    if (\n                        +(c[c[(e + 13080) >> 2] >> 2] | 0) / +g[258] >=\n                        +(a | 0)\n                    ) {\n                        break;\n                    }\n                    switch (d[((c[(e + 13080) >> 2] | 0) + 5) | 0] | 0 | 0) {\n                        case 7: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    24) >>\n                                    2\n                            ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            break;\n                        }\n                        case 13: {\n                            cb(e, d[((c[(e + 13080) >> 2] | 0) + 4) | 0] | 0);\n                            break;\n                        }\n                        case 4: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    8) >>\n                                    2\n                            ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            break;\n                        }\n                        case 11: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    32) >>\n                                    2\n                            ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            g[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    36) >>\n                                    2\n                            ] = 0.0;\n                            break;\n                        }\n                        case 99: {\n                            f = 902;\n                            break L1123;\n                            break;\n                        }\n                        case 9: {\n                            if (\n                                ((c[(e + 13056) >> 2] &\n                                    (1 <<\n                                        (d[\n                                            ((c[(e + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0))) |\n                                    0) !=\n                                0\n                            ) {\n                                c[\n                                    (e +\n                                        1084 +\n                                        (((d[\n                                            ((c[(e + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0)) >>\n                                        2\n                                ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            } else {\n                                c[\n                                    (e +\n                                        1084 +\n                                        (((d[\n                                            ((c[(e + 13080) >> 2] | 0) + 4) | 0\n                                        ] |\n                                            0) *\n                                            40) |\n                                            0) +\n                                        4) >>\n                                        2\n                                ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            }\n                            break;\n                        }\n                        case 8: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    20) >>\n                                    2\n                            ] =\n                                (d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0) +\n                                ((d[((c[(e + 13080) >> 2] | 0) + 7) | 0] | 0) <<\n                                    7);\n                            g[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    36) >>\n                                    2\n                            ] = 0.0;\n                            break;\n                        }\n                        case 15: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0)) >>\n                                    2\n                            ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            break;\n                        }\n                        case 10: {\n                            c[392] =\n                                (d[((c[(e + 13080) >> 2] | 0) + 4) | 0] | 0) +\n                                ((d[((c[(e + 13080) >> 2] | 0) + 7) | 0] | 0) <<\n                                    8) +\n                                ((d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0) <<\n                                    16);\n                            break;\n                        }\n                        case 5: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    16) >>\n                                    2\n                            ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            break;\n                        }\n                        case 6: {\n                            c[\n                                (e +\n                                    1084 +\n                                    (((d[((c[(e + 13080) >> 2] | 0) + 4) | 0] |\n                                        0) *\n                                        40) |\n                                        0) +\n                                    12) >>\n                                    2\n                            ] = d[((c[(e + 13080) >> 2] | 0) + 6) | 0] | 0;\n                            break;\n                        }\n                        default: {\n                        }\n                    }\n                    b = (e + 13080) | 0;\n                    c[b >> 2] = (c[b >> 2] | 0) + 8;\n                }\n                if ((f | 0) == 902) {\n                    c[(e + 13088) >> 2] = ~~(\n                        +(c[c[(e + 13080) >> 2] >> 2] | 0) / +g[258]\n                    );\n                    return;\n                }\n                if ((c[(e + 13080) >> 2] | 0) != (c[(e + 13076) >> 2] | 0)) {\n                    f = (e + 13080) | 0;\n                    c[f >> 2] = (c[f >> 2] | 0) - 8;\n                }\n                c[(e + 13088) >> 2] = a;\n                return;\n            }\n            function cm(b) {\n                b = b | 0;\n                let c = 0;\n                c = b;\n                b = 0;\n                while (1) {\n                    if ((b | 0) >= 48) {\n                        break;\n                    }\n                    a[(c + 1724 + ((b * 236) | 0)) | 0] = 0;\n                    b = (b + 1) | 0;\n                }\n                return;\n            }\n            function cn(b, e, f) {\n                b = b | 0;\n                e = e | 0;\n                f = f | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0;\n                h = b;\n                b = e;\n                e = f;\n                if (((c[(h + 13056) >> 2] & (1 << d[(b + 4) | 0])) | 0) != 0) {\n                    f =\n                        c[\n                            ((c[\n                                (h +\n                                    540 +\n                                    (c[\n                                        (h +\n                                            1084 +\n                                            (((d[(b + 4) | 0] | 0) * 40) |\n                                                0)) >>\n                                            2\n                                    ] <<\n                                        2)) >>\n                                    2\n                            ] |\n                                0) +\n                                4 +\n                                (d[(b + 6) | 0] << 2)) >>\n                                2\n                        ] | 0;\n                    i = f;\n                    do {\n                        if ((f | 0) == 0) {\n                            j =\n                                c[\n                                    ((c[(h + 540) >> 2] | 0) +\n                                        4 +\n                                        (d[(b + 6) | 0] << 2)) >>\n                                        2\n                                ] | 0;\n                            i = j;\n                            if ((j | 0) != 0) {\n                                break;\n                            }\n                            return;\n                        }\n                    } while (0);\n                    (c[i >> 2] | 0) != 1;\n                    if ((a[((c[(i + 4) >> 2] | 0) + 112) | 0] | 0) != 0) {\n                        f =\n                            (1056 +\n                                (a[((c[(i + 4) >> 2] | 0) + 112) | 0] << 2)) |\n                            0;\n                        c[(h + 1724 + ((e * 236) | 0) + 8) >> 2] =\n                            d[f] |\n                            (d[(f + 1) | 0] << 8) |\n                            (d[(f + 2) | 0] << 16) |\n                            (d[(f + 3) | 0] << 24);\n                    } else {\n                        f = (1056 + ((a[(b + 6) | 0] & 127) << 2)) | 0;\n                        c[(h + 1724 + ((e * 236) | 0) + 8) >> 2] =\n                            d[f] |\n                            (d[(f + 1) | 0] << 8) |\n                            (d[(f + 2) | 0] << 16) |\n                            (d[(f + 3) | 0] << 24);\n                    }\n                    c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] = c[(i + 4) >> 2];\n                } else {\n                    if (-1 != (c[(1640 + (d[(b + 4) | 0] << 2)) >> 2] | 0)) {\n                        f =\n                            c[\n                                (h +\n                                    28 +\n                                    (c[\n                                        (h +\n                                            1084 +\n                                            (((d[(b + 4) | 0] | 0) * 40) |\n                                                0)) >>\n                                            2\n                                    ] <<\n                                        2)) >>\n                                    2\n                            ] | 0;\n                        j = c[(1640 + (d[(b + 4) | 0] << 2)) >> 2] | 0;\n                        if (0 == (c[(f + 4 + (j << 2)) >> 2] | 0)) {\n                            k = 0;\n                            l = h;\n                            m = c[((c[f >> 2] | 0) + ((j * 28) | 0)) >> 2] | 0;\n                            n = (k | 0) != 0 ? 1 : 0;\n                            o =\n                                c[\n                                    ((c[f >> 2] | 0) + ((j * 28) | 0) + 12) >> 2\n                                ] | 0;\n                            p =\n                                c[((c[f >> 2] | 0) + ((j * 28) | 0) + 8) >> 2] |\n                                0;\n                            if (\n                                (c[\n                                    ((c[f >> 2] | 0) + ((j * 28) | 0) + 4) >> 2\n                                ] |\n                                    0) !=\n                                -1\n                            ) {\n                                q =\n                                    c[\n                                        ((c[f >> 2] | 0) +\n                                            ((j * 28) | 0) +\n                                            4) >>\n                                            2\n                                    ] | 0;\n                            } else {\n                                if ((k | 0) != 0) {\n                                    r = j;\n                                } else {\n                                    r = -1;\n                                }\n                                q = r;\n                            }\n                            if (\n                                (c[\n                                    ((c[f >> 2] | 0) + ((j * 28) | 0) + 16) >> 2\n                                ] |\n                                    0) !=\n                                -1\n                            ) {\n                                s =\n                                    c[\n                                        ((c[f >> 2] | 0) +\n                                            ((j * 28) | 0) +\n                                            16) >>\n                                            2\n                                    ] | 0;\n                            } else {\n                                s = (k | 0) != 0 ? 1 : -1;\n                            }\n                            if (\n                                (c[\n                                    ((c[f >> 2] | 0) + ((j * 28) | 0) + 20) >> 2\n                                ] |\n                                    0) !=\n                                -1\n                            ) {\n                                t =\n                                    c[\n                                        ((c[f >> 2] | 0) +\n                                            ((j * 28) | 0) +\n                                            20) >>\n                                            2\n                                    ] | 0;\n                            } else {\n                                t = (k | 0) != 0 ? 1 : -1;\n                            }\n                            c[(f + 4 + (j << 2)) >> 2] =\n                                bl(\n                                    l,\n                                    m,\n                                    n,\n                                    o,\n                                    p,\n                                    q,\n                                    s,\n                                    t,\n                                    c[\n                                        ((c[f >> 2] | 0) +\n                                            ((j * 28) | 0) +\n                                            24) >>\n                                            2\n                                    ] | 0\n                                ) | 0;\n                        }\n                        i = c[(f + 4 + (j << 2)) >> 2] | 0;\n                    } else {\n                        if (\n                            (c[\n                                (h +\n                                    1084 +\n                                    (((d[(b + 4) | 0] | 0) * 40) | 0) +\n                                    4) >>\n                                    2\n                            ] |\n                                0) ==\n                            -1\n                        ) {\n                            i = c[(h + 1052) >> 2] | 0;\n                        } else {\n                            j =\n                                c[\n                                    ((c[\n                                        (h +\n                                            28 +\n                                            (c[\n                                                (h +\n                                                    1084 +\n                                                    (((d[(b + 4) | 0] | 0) *\n                                                        40) |\n                                                        0)) >>\n                                                    2\n                                            ] <<\n                                                2)) >>\n                                            2\n                                    ] |\n                                        0) +\n                                        4 +\n                                        (c[\n                                            (h +\n                                                1084 +\n                                                (((d[(b + 4) | 0] | 0) * 40) |\n                                                    0) +\n                                                4) >>\n                                                2\n                                        ] <<\n                                            2)) >>\n                                        2\n                                ] | 0;\n                            i = j;\n                            do {\n                                if ((j | 0) == 0) {\n                                    f =\n                                        c[\n                                            ((c[(h + 28) >> 2] | 0) +\n                                                4 +\n                                                (c[\n                                                    (h +\n                                                        1084 +\n                                                        (((d[(b + 4) | 0] | 0) *\n                                                            40) |\n                                                            0) +\n                                                        4) >>\n                                                        2\n                                                ] <<\n                                                    2)) >>\n                                                2\n                                        ] | 0;\n                                    i = f;\n                                    if ((f | 0) != 0) {\n                                        break;\n                                    }\n                                    return;\n                                }\n                            } while (0);\n                        }\n                    }\n                    if ((a[((c[(i + 4) >> 2] | 0) + 112) | 0] | 0) != 0) {\n                        j =\n                            (1056 +\n                                (a[((c[(i + 4) >> 2] | 0) + 112) | 0] << 2)) |\n                            0;\n                        c[(h + 1724 + ((e * 236) | 0) + 8) >> 2] =\n                            d[j] |\n                            (d[(j + 1) | 0] << 8) |\n                            (d[(j + 2) | 0] << 16) |\n                            (d[(j + 3) | 0] << 24);\n                    } else {\n                        j =\n                            (1056 +\n                                ((((d[(b + 6) | 0] | 0) + (c[1662] | 0)) &\n                                    127) <<\n                                    2)) |\n                            0;\n                        c[(h + 1724 + ((e * 236) | 0) + 8) >> 2] =\n                            d[j] |\n                            (d[(j + 1) | 0] << 8) |\n                            (d[(j + 2) | 0] << 16) |\n                            (d[(j + 3) | 0] << 24);\n                    }\n                    c[(h + 1724 + ((e * 236) | 0) + 8) >> 2] = ~~(\n                        (+(c[(h + 1724 + ((e * 236) | 0) + 8) >> 2] | 0) *\n                            +g[260]) /\n                        440.0\n                    );\n                    co(h, e, i, d[(b + 7) | 0] | 0);\n                }\n                a[(h + 1724 + ((e * 236) | 0)) | 0] = 1;\n                a[(h + 1724 + ((e * 236) | 0) + 1) | 0] = a[(b + 4) | 0] | 0;\n                a[(h + 1724 + ((e * 236) | 0) + 2) | 0] = a[(b + 6) | 0] | 0;\n                a[(h + 1724 + ((e * 236) | 0) + 3) | 0] =\n                    cp(\n                        a[(b + 7) | 0] | 0,\n                        +g[(1576 + (d[(b + 4) | 0] << 2)) >> 2]\n                    ) | 0;\n                c[(h + 1724 + ((e * 236) | 0) + 16) >> 2] = 0;\n                c[(h + 1724 + ((e * 236) | 0) + 20) >> 2] = 0;\n                c[(h + 1724 + ((e * 236) | 0) + 44) >> 2] = 0;\n                c[(h + 1724 + ((e * 236) | 0) + 48) >> 2] =\n                    c[\n                        ((c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] | 0) + 96) >>\n                            2\n                    ];\n                c[(h + 1724 + ((e * 236) | 0) + 36) >> 2] =\n                    c[\n                        ((c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] | 0) + 92) >>\n                            2\n                    ];\n                c[(h + 1724 + ((e * 236) | 0) + 40) >> 2] = 0;\n                c[(h + 1724 + ((e * 236) | 0) + 52) >> 2] =\n                    c[\n                        ((c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] | 0) +\n                            100) >>\n                            2\n                    ];\n                c[(h + 1724 + ((e * 236) | 0) + 56) >> 2] = 0;\n                c[(h + 1724 + ((e * 236) | 0) + 212) >> 2] =\n                    c[\n                        ((c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] | 0) +\n                            104) >>\n                            2\n                    ];\n                c[(h + 1724 + ((e * 236) | 0) + 208) >> 2] = 0;\n                c[(h + 1724 + ((e * 236) | 0) + 216) >> 2] = 0;\n                i = 0;\n                while (1) {\n                    if ((i | 0) >= 32) {\n                        break;\n                    }\n                    c[(h + 1724 + ((e * 236) | 0) + 80 + (i << 2)) >> 2] = 0;\n                    i = (i + 1) | 0;\n                }\n                if (\n                    (c[\n                        (h + 1084 + (((d[(b + 4) | 0] | 0) * 40) | 0) + 16) >> 2\n                    ] |\n                        0) !=\n                    -1\n                ) {\n                    c[(h + 1724 + ((e * 236) | 0) + 228) >> 2] =\n                        c[\n                            (h +\n                                1084 +\n                                (((d[(b + 4) | 0] | 0) * 40) | 0) +\n                                16) >>\n                                2\n                        ];\n                } else {\n                    c[(h + 1724 + ((e * 236) | 0) + 228) >> 2] =\n                        a[\n                            ((c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] | 0) +\n                                111) |\n                                0\n                        ] | 0;\n                }\n                cj(h, e);\n                cf(h, e);\n                if (\n                    ((a[\n                        ((c[(h + 1724 + ((e * 236) | 0) + 4) >> 2] | 0) + 110) |\n                            0\n                    ] &\n                        64) |\n                        0) !=\n                    0\n                ) {\n                    c[(h + 1724 + ((e * 236) | 0) + 220) >> 2] = 0;\n                    c[(h + 1724 + ((e * 236) | 0) + 24) >> 2] = 0;\n                    c[(h + 1724 + ((e * 236) | 0) + 224) >> 2] = 0;\n                    b = h;\n                    i = e;\n                    bI(b, i) | 0;\n                    bJ(h, e);\n                    return;\n                } else {\n                    c[(h + 1724 + ((e * 236) | 0) + 32) >> 2] = 0;\n                    bJ(h, e);\n                    return;\n                }\n            }\n            function co(a, b, d, e) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0;\n                f = a;\n                a = b;\n                b = d;\n                d = e;\n                e = c[b >> 2] | 0;\n                g = c[(b + 4) >> 2] | 0;\n                if ((e | 0) == 1) {\n                    c[(f + 1724 + ((a * 236) | 0) + 4) >> 2] = g;\n                    return;\n                }\n                h = c[(f + 1724 + ((a * 236) | 0) + 8) >> 2] | 0;\n                i = 0;\n                L1232: while (1) {\n                    if ((i | 0) >= (e | 0)) {\n                        break;\n                    }\n                    do {\n                        if ((c[(g + 16) >> 2] | 0) <= (d | 0)) {\n                            if ((c[(g + 20) >> 2] | 0) < (d | 0)) {\n                                break;\n                            }\n                            if ((c[(g + 24) >> 2] | 0) > (h | 0)) {\n                                break;\n                            }\n                            if ((c[(g + 28) >> 2] | 0) >= (h | 0)) {\n                                j = 977;\n                                break L1232;\n                            }\n                        }\n                    } while (0);\n                    g = (g + 116) | 0;\n                    i = (i + 1) | 0;\n                }\n                if ((j | 0) == 977) {\n                    c[(f + 1724 + ((a * 236) | 0) + 4) >> 2] = g;\n                    return;\n                }\n                j = 2147483647;\n                d = c[(b + 4) >> 2] | 0;\n                g = d;\n                b = d;\n                i = 0;\n                while (1) {\n                    if ((i | 0) >= (e | 0)) {\n                        break;\n                    }\n                    d = ((c[(g + 32) >> 2] | 0) - h) | 0;\n                    if ((d | 0) < 0) {\n                        d = -d | 0;\n                    }\n                    if ((d | 0) < (j | 0)) {\n                        j = d;\n                        b = g;\n                    }\n                    g = (g + 116) | 0;\n                    i = (i + 1) | 0;\n                }\n                c[(f + 1724 + ((a * 236) | 0) + 4) >> 2] = b;\n                return;\n            }\n            function cp(a, b) {\n                a = a | 0;\n                b = +b;\n                let d = 0,\n                    e = 0,\n                    f = 0.0,\n                    g = 0,\n                    h = 0,\n                    j = 0,\n                    k = 0;\n                d = i;\n                e = a;\n                f = b;\n                if (f <= 1.0) {\n                    g = ~~(+((e & 255) | 0) * f);\n                    h = g;\n                    i = d;\n                    return h | 0;\n                } else {\n                    a =\n                        ((e & 255) +\n                            (~~(+((127 - (e & 255)) | 0) * (f - 1.0)) & 255)) &\n                        255;\n                    j = e & 255;\n                    e = a & 255;\n                    aG(\n                        4784,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = j),\n                        (c[(k + 8) >> 2] = e),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    g = a;\n                    h = g;\n                    i = d;\n                    return h | 0;\n                }\n                return 0;\n            }\n            function cq(d, e, f, g) {\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0;\n                h = i;\n                i = (i + 40) | 0;\n                j = h | 0;\n                k = (h + 8) | 0;\n                l = (h + 16) | 0;\n                m = (h + 24) | 0;\n                n = (h + 32) | 0;\n                o = d;\n                d = e;\n                e = f;\n                f = g;\n                c[(d + 13092) >> 2] = 0;\n                c[(d + 13096) >> 2] = 0;\n                c[(d + 13084) >> 2] = 0;\n                do {\n                    if ((cP(o, n | 0, 1, 4) | 0) == 4) {\n                        if ((cP(o, j, 4, 1) | 0) != 1) {\n                            break;\n                        }\n                        c[j >> 2] =\n                            ((c[j >> 2] & 255) << 24) |\n                            ((c[j >> 2] & 65280) << 8) |\n                            ((c[j >> 2] & 16711680) >> 8) |\n                            ((c[j >> 2] >> 24) & 255);\n                        do {\n                            if ((c4(n | 0, 4776, 4) | 0) == 0) {\n                                if ((c[j >> 2] | 0) < 6) {\n                                    break;\n                                }\n                                g = o;\n                                p = k;\n                                cP(g, p, 2, 1) | 0;\n                                p = o;\n                                g = l;\n                                cP(p, g, 2, 1) | 0;\n                                g = o;\n                                p = m;\n                                cP(g, p, 2, 1) | 0;\n                                b[k >> 1] =\n                                    (((b[k >> 1] & 255) << 8) |\n                                        ((b[k >> 1] >> 8) & 255)) &\n                                    65535;\n                                b[l >> 1] =\n                                    (((b[l >> 1] & 255) << 8) |\n                                        ((b[l >> 1] >> 8) & 255)) &\n                                    65535;\n                                b[m >> 1] =\n                                    (((b[m >> 1] & 255) << 8) |\n                                        ((b[m >> 1] >> 8) & 255)) &\n                                    65535;\n                                if ((b[m >> 1] | 0) < 0) {\n                                    q =\n                                        _(\n                                            -(((b[m >> 1] | 0) / 256) | 0) | 0,\n                                            b[m >> 1] & 255\n                                        ) | 0;\n                                } else {\n                                    q = b[m >> 1] | 0;\n                                }\n                                if ((c[j >> 2] | 0) > 6) {\n                                    cQ(o, ((c[j >> 2] | 0) - 6) | 0);\n                                }\n                                do {\n                                    if ((b[k >> 1] | 0) >= 0) {\n                                        if ((b[k >> 1] | 0) > 2) {\n                                            break;\n                                        }\n                                        c[(d + 13084) >> 2] = bi(12) | 0;\n                                        c[c[(d + 13084) >> 2] >> 2] = 0;\n                                        a[\n                                            ((c[(d + 13084) >> 2] | 0) + 5) | 0\n                                        ] = 0;\n                                        c[\n                                            ((c[(d + 13084) >> 2] | 0) + 8) >> 2\n                                        ] = 0;\n                                        p = (d + 13092) | 0;\n                                        c[p >> 2] = (c[p >> 2] | 0) + 1;\n                                        p = b[k >> 1] | 0;\n                                        do {\n                                            if ((p | 0) == 1) {\n                                                r = 0;\n                                                while (1) {\n                                                    if (\n                                                        (r | 0) >=\n                                                        (b[l >> 1] | 0)\n                                                    ) {\n                                                        s = 1023;\n                                                        break;\n                                                    }\n                                                    if (\n                                                        (cr(o, d, 0) | 0) !=\n                                                        0\n                                                    ) {\n                                                        break;\n                                                    }\n                                                    r = (r + 1) | 0;\n                                                }\n                                                if ((s | 0) == 1023) {\n                                                    break;\n                                                }\n                                                cs(d);\n                                                t = 0;\n                                                u = t;\n                                                i = h;\n                                                return u | 0;\n                                            } else if ((p | 0) == 2) {\n                                                r = 0;\n                                                while (1) {\n                                                    if (\n                                                        (r | 0) >=\n                                                        (b[l >> 1] | 0)\n                                                    ) {\n                                                        s = 1030;\n                                                        break;\n                                                    }\n                                                    if (\n                                                        (cr(o, d, 1) | 0) !=\n                                                        0\n                                                    ) {\n                                                        break;\n                                                    }\n                                                    r = (r + 1) | 0;\n                                                }\n                                                if ((s | 0) == 1030) {\n                                                    break;\n                                                }\n                                                cs(d);\n                                                t = 0;\n                                                u = t;\n                                                i = h;\n                                                return u | 0;\n                                            } else if ((p | 0) == 0) {\n                                                if ((cr(o, d, 0) | 0) == 0) {\n                                                    break;\n                                                }\n                                                cs(d);\n                                                t = 0;\n                                                u = t;\n                                                i = h;\n                                                return u | 0;\n                                            }\n                                        } while (0);\n                                        t = ct(d, q, e, f) | 0;\n                                        u = t;\n                                        i = h;\n                                        return u | 0;\n                                    }\n                                } while (0);\n                                t = 0;\n                                u = t;\n                                i = h;\n                                return u | 0;\n                            }\n                        } while (0);\n                        t = 0;\n                        u = t;\n                        i = h;\n                        return u | 0;\n                    }\n                } while (0);\n                t = 0;\n                u = t;\n                i = h;\n                return u | 0;\n            }\n            function cr(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0;\n                e = i;\n                i = (i + 16) | 0;\n                f = e | 0;\n                g = (e + 8) | 0;\n                h = a;\n                a = b;\n                b = c[(a + 13084) >> 2] | 0;\n                do {\n                    if ((d | 0) != 0) {\n                        if ((b | 0) == 0) {\n                            j = 1047;\n                            break;\n                        }\n                        while (1) {\n                            if ((c[(b + 8) >> 2] | 0) == 0) {\n                                break;\n                            }\n                            b = c[(b + 8) >> 2] | 0;\n                        }\n                        c[(a + 13096) >> 2] = c[b >> 2];\n                    } else {\n                        j = 1047;\n                    }\n                } while (0);\n                if ((j | 0) == 1047) {\n                    c[(a + 13096) >> 2] = 0;\n                }\n                do {\n                    if ((cP(h, g | 0, 1, 4) | 0) == 4) {\n                        if ((cP(h, f, 4, 1) | 0) != 1) {\n                            break;\n                        }\n                        c[f >> 2] =\n                            ((c[f >> 2] & 255) << 24) |\n                            ((c[f >> 2] & 65280) << 8) |\n                            ((c[f >> 2] & 16711680) >> 8) |\n                            ((c[f >> 2] >> 24) & 255);\n                        if ((c4(g | 0, 6272, 4) | 0) != 0) {\n                            k = -2;\n                            l = k;\n                            i = e;\n                            return l | 0;\n                        }\n                        while (1) {\n                            d = cv(h, a) | 0;\n                            m = d;\n                            if ((d | 0) == 0) {\n                                j = 1055;\n                                break;\n                            }\n                            if ((m | 0) == -1) {\n                                j = 1057;\n                                break;\n                            }\n                            d = c[(b + 8) >> 2] | 0;\n                            while (1) {\n                                if ((d | 0) != 0) {\n                                    n = (c[d >> 2] | 0) < (c[m >> 2] | 0);\n                                } else {\n                                    n = 0;\n                                }\n                                if (!n) {\n                                    break;\n                                }\n                                b = d;\n                                d = c[(b + 8) >> 2] | 0;\n                            }\n                            c[(m + 8) >> 2] = d;\n                            c[(b + 8) >> 2] = m;\n                            o = (a + 13092) | 0;\n                            c[o >> 2] = (c[o >> 2] | 0) + 1;\n                            b = m;\n                        }\n                        if ((j | 0) == 1055) {\n                            k = -2;\n                            l = k;\n                            i = e;\n                            return l | 0;\n                        } else if ((j | 0) == 1057) {\n                            k = 0;\n                            l = k;\n                            i = e;\n                            return l | 0;\n                        }\n                    }\n                } while (0);\n                k = -1;\n                l = k;\n                i = e;\n                return l | 0;\n            }\n            function cs(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0;\n                b = a;\n                a = c[(b + 13084) >> 2] | 0;\n                d = a;\n                if ((a | 0) == 0) {\n                    return;\n                }\n                while (1) {\n                    if ((d | 0) == 0) {\n                        break;\n                    }\n                    a = c[(d + 8) >> 2] | 0;\n                    c0(d);\n                    d = a;\n                }\n                c[(b + 13084) >> 2] = 0;\n                return;\n            }\n            function ct(b, e, f, g) {\n                b = b | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0,\n                    B = 0;\n                h = i;\n                i = (i + 192) | 0;\n                j = h | 0;\n                k = (h + 64) | 0;\n                l = (h + 128) | 0;\n                m = b;\n                b = e;\n                e = f;\n                f = g;\n                g = 0;\n                while (1) {\n                    if ((g | 0) >= 16) {\n                        break;\n                    }\n                    c[(j + (g << 2)) >> 2] = 0;\n                    c[(k + (g << 2)) >> 2] = 0;\n                    c[(l + (g << 2)) >> 2] = c[(m + 1056) >> 2];\n                    g = (g + 1) | 0;\n                }\n                n = 5e5;\n                cu(m, n, b);\n                o = bi(((c[(m + 13092) >> 2] | 0) + 1) << 3) | 0;\n                p = o;\n                q = o;\n                o = c[(m + 13084) >> 2] | 0;\n                r = 0;\n                s = 0;\n                t = 0;\n                u = 0;\n                v = 0;\n                g = 0;\n                while (1) {\n                    if ((g | 0) >= (c[(m + 13092) >> 2] | 0)) {\n                        break;\n                    }\n                    w = 0;\n                    x = d[(o + 5) | 0] | 0;\n                    do {\n                        if ((x | 0) == 9) {\n                            if (\n                                ((c[(m + 13056) >> 2] &\n                                    (1 << (d[(o + 4) | 0] | 0))) |\n                                    0) !=\n                                0\n                            ) {\n                                if (\n                                    (c[\n                                        (m +\n                                            540 +\n                                            ((d[(o + 6) | 0] | 0) << 2)) >>\n                                            2\n                                    ] |\n                                        0) !=\n                                    0\n                                ) {\n                                    y = d[(o + 6) | 0] | 0;\n                                } else {\n                                    a[(o + 6) | 0] = 0;\n                                    y = 0;\n                                }\n                                if (\n                                    (c[(k + ((d[(o + 4) | 0] | 0) << 2)) >> 2] |\n                                        0) !=\n                                    (y | 0)\n                                ) {\n                                    c[\n                                        (k + ((d[(o + 4) | 0] | 0) << 2)) >> 2\n                                    ] = y;\n                                } else {\n                                    w = 1;\n                                }\n                            } else {\n                                y = d[(o + 6) | 0] | 0;\n                                do {\n                                    if (\n                                        (c[\n                                            (l + ((d[(o + 4) | 0] | 0) << 2)) >>\n                                                2\n                                        ] |\n                                            0) !=\n                                        -1\n                                    ) {\n                                        if (\n                                            (c[\n                                                (l +\n                                                    ((d[(o + 4) | 0] | 0) <<\n                                                        2)) >>\n                                                    2\n                                            ] |\n                                                0) ==\n                                            (y | 0)\n                                        ) {\n                                            z = 1096;\n                                            break;\n                                        }\n                                        c[\n                                            (l + ((d[(o + 4) | 0] | 0) << 2)) >>\n                                                2\n                                        ] = y;\n                                    } else {\n                                        z = 1096;\n                                    }\n                                } while (0);\n                                if ((z | 0) == 1096) {\n                                    z = 0;\n                                    w = 1;\n                                }\n                            }\n                        } else if ((x | 0) == 15) {\n                            if (\n                                ((c[(m + 13056) >> 2] &\n                                    (1 << (d[(o + 4) | 0] | 0))) |\n                                    0) !=\n                                0\n                            ) {\n                                w = 1;\n                                break;\n                            }\n                            if (\n                                (c[\n                                    (m + 28 + ((d[(o + 6) | 0] | 0) << 2)) >> 2\n                                ] |\n                                    0) !=\n                                0\n                            ) {\n                                y = d[(o + 6) | 0] | 0;\n                            } else {\n                                a[(o + 6) | 0] = 0;\n                                y = 0;\n                            }\n                            if (\n                                (c[(j + ((d[(o + 4) | 0] | 0) << 2)) >> 2] |\n                                    0) !=\n                                (y | 0)\n                            ) {\n                                c[(j + ((d[(o + 4) | 0] | 0) << 2)) >> 2] = y;\n                            } else {\n                                w = 1;\n                            }\n                        } else if ((x | 0) == 1) {\n                            if ((v | 0) != 0) {\n                                v = 1;\n                            }\n                            if (\n                                ((c[(m + 13056) >> 2] &\n                                    (1 << (d[(o + 4) | 0] | 0))) |\n                                    0) !=\n                                0\n                            ) {\n                                if (\n                                    (c[\n                                        ((c[\n                                            (m +\n                                                540 +\n                                                (c[\n                                                    (k +\n                                                        ((d[(o + 4) | 0] | 0) <<\n                                                            2)) >>\n                                                        2\n                                                ] <<\n                                                    2)) >>\n                                                2\n                                        ] |\n                                            0) +\n                                            4 +\n                                            ((d[(o + 6) | 0] | 0) << 2)) >>\n                                            2\n                                    ] |\n                                        0) ==\n                                    0\n                                ) {\n                                    c[\n                                        ((c[\n                                            (m +\n                                                540 +\n                                                (c[\n                                                    (k +\n                                                        ((d[(o + 4) | 0] | 0) <<\n                                                            2)) >>\n                                                        2\n                                                ] <<\n                                                    2)) >>\n                                                2\n                                        ] |\n                                            0) +\n                                            4 +\n                                            ((d[(o + 6) | 0] | 0) << 2)) >>\n                                            2\n                                    ] = -1;\n                                }\n                            } else {\n                                if (\n                                    (c[(l + ((d[(o + 4) | 0] | 0) << 2)) >> 2] |\n                                        0) ==\n                                    -1\n                                ) {\n                                    break;\n                                }\n                                if (\n                                    (c[\n                                        ((c[\n                                            (m +\n                                                28 +\n                                                (c[\n                                                    (j +\n                                                        ((d[(o + 4) | 0] | 0) <<\n                                                            2)) >>\n                                                        2\n                                                ] <<\n                                                    2)) >>\n                                                2\n                                        ] |\n                                            0) +\n                                            4 +\n                                            (c[\n                                                (l +\n                                                    ((d[(o + 4) | 0] | 0) <<\n                                                        2)) >>\n                                                    2\n                                            ] <<\n                                                2)) >>\n                                            2\n                                    ] |\n                                        0) ==\n                                    0\n                                ) {\n                                    c[\n                                        ((c[\n                                            (m +\n                                                28 +\n                                                (c[\n                                                    (j +\n                                                        ((d[(o + 4) | 0] | 0) <<\n                                                            2)) >>\n                                                        2\n                                                ] <<\n                                                    2)) >>\n                                                2\n                                        ] |\n                                            0) +\n                                            4 +\n                                            (c[\n                                                (l +\n                                                    ((d[(o + 4) | 0] | 0) <<\n                                                        2)) >>\n                                                    2\n                                            ] <<\n                                                2)) >>\n                                            2\n                                    ] = -1;\n                                }\n                            }\n                        }\n                    } while (0);\n                    x = ((c[o >> 2] | 0) - t) | 0;\n                    A = x;\n                    do {\n                        if ((x | 0) != 0) {\n                            if ((v | 0) != 0) {\n                                z = 1125;\n                                break;\n                            }\n                            B = _(c[(m + 1076) >> 2] | 0, A) | 0;\n                            s = (s + (_(c[(m + 1080) >> 2] | 0, A) | 0)) | 0;\n                            if (((s & -65536) | 0) != 0) {\n                                B = (B + ((s >> 16) & 65535)) | 0;\n                                s = s & 65535;\n                            }\n                            u = (u + B) | 0;\n                        } else {\n                            z = 1125;\n                        }\n                    } while (0);\n                    if ((z | 0) == 1125) {\n                        z = 0;\n                        if ((v | 0) == 1) {\n                            v = 0;\n                        }\n                    }\n                    if ((d[(o + 5) | 0] | 0 | 0) == 10) {\n                        n =\n                            ((d[(o + 4) | 0] | 0) +\n                                ((d[(o + 7) | 0] | 0) << 8) +\n                                ((d[(o + 6) | 0] | 0) << 16)) |\n                            0;\n                        cu(m, n, b);\n                    }\n                    if ((w | 0) == 0) {\n                        A = p;\n                        x = o | 0;\n                        c[A >> 2] = c[x >> 2];\n                        c[(A + 4) >> 2] = c[(x + 4) >> 2];\n                        c[p >> 2] = u;\n                        p = (p + 8) | 0;\n                        r = (r + 1) | 0;\n                    }\n                    t = c[o >> 2] | 0;\n                    o = c[(o + 8) >> 2] | 0;\n                    g = (g + 1) | 0;\n                }\n                c[p >> 2] = u;\n                a[(p + 5) | 0] = 99;\n                r = (r + 1) | 0;\n                cs(m);\n                c[e >> 2] = r;\n                c[f >> 2] = u;\n                i = h;\n                return q | 0;\n            }\n            function cu(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0.0;\n                e = a;\n                f = (+(b | 0) * +(c[(e + 4) >> 2] | 0) * 0.065536) / +(d | 0);\n                c[(e + 1080) >> 2] = ~~f & 65535;\n                c[(e + 1076) >> 2] = ~~f >> 16;\n                return;\n            }\n            function cv(b, e) {\n                b = b | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0;\n                f = i;\n                i = (i + 40) | 0;\n                g = f | 0;\n                h = (f + 8) | 0;\n                j = (f + 16) | 0;\n                k = (f + 24) | 0;\n                l = (f + 32) | 0;\n                m = b;\n                b = e;\n                L1442: while (1) {\n                    e = cw(m) | 0;\n                    n = (b + 13096) | 0;\n                    c[n >> 2] = (c[n >> 2] | 0) + e;\n                    if ((cP(m, g, 1, 1) | 0) != 1) {\n                        o = 1138;\n                        break;\n                    }\n                    do {\n                        if ((d[g] | 0) == 240) {\n                            o = 1141;\n                        } else {\n                            if ((d[g] | 0) == 247) {\n                                o = 1141;\n                                break;\n                            }\n                            if ((d[g] | 0) == 255) {\n                                e = m;\n                                cP(e, h, 1, 1) | 0;\n                                p = cw(m) | 0;\n                                do {\n                                    if ((d[h] | 0) > 0) {\n                                        if ((d[h] | 0) >= 16) {\n                                            o = 1146;\n                                            break;\n                                        }\n                                        e = m;\n                                        n = p;\n                                        q = a[h] | 0;\n                                        r = b;\n                                        cx(e, n, q, r) | 0;\n                                    } else {\n                                        o = 1146;\n                                    }\n                                } while (0);\n                                if ((o | 0) == 1146) {\n                                    o = 0;\n                                    r = d[h] | 0;\n                                    if ((r | 0) == 47) {\n                                        o = 1147;\n                                        break L1442;\n                                    } else if ((r | 0) == 81) {\n                                        o = 1148;\n                                        break L1442;\n                                    }\n                                    cQ(m, p);\n                                }\n                            } else {\n                                a[j] = a[g] | 0;\n                                if (((a[j] & 128) | 0) != 0) {\n                                    a[6632] = d[j] & 15;\n                                    a[6624] = (d[j] >> 4) & 7;\n                                    r = m;\n                                    cP(r, j, 1, 1) | 0;\n                                    a[j] = d[j] & 127;\n                                }\n                                switch (d[6624] | 0) {\n                                    case 1: {\n                                        o = 1156;\n                                        break L1442;\n                                        break;\n                                    }\n                                    case 6: {\n                                        o = 1188;\n                                        break L1442;\n                                        break;\n                                    }\n                                    case 4: {\n                                        o = 1186;\n                                        break L1442;\n                                        break;\n                                    }\n                                    case 5: {\n                                        break;\n                                    }\n                                    case 0: {\n                                        o = 1155;\n                                        break L1442;\n                                        break;\n                                    }\n                                    case 2: {\n                                        o = 1157;\n                                        break L1442;\n                                        break;\n                                    }\n                                    case 3: {\n                                        cP(m, k, 1, 1) | 0;\n                                        a[k] = d[k] & 127;\n                                        s = 255;\n                                        L1466: do {\n                                            switch (d[j] | 0) {\n                                                case 98: {\n                                                    a[6616] = 1;\n                                                    a[\n                                                        (6600 + (d[6632] | 0)) |\n                                                            0\n                                                    ] = a[k] | 0;\n                                                    break;\n                                                }\n                                                case 6: {\n                                                    if ((a[6616] | 0) != 0) {\n                                                        break L1466;\n                                                    }\n                                                    r =\n                                                        (d[\n                                                            (6584 +\n                                                                (d[6632] | 0)) |\n                                                                0\n                                                        ] <<\n                                                            8) |\n                                                        d[\n                                                            (6600 +\n                                                                (d[6632] | 0)) |\n                                                                0\n                                                        ];\n                                                    if ((r | 0) == 0) {\n                                                        s = 11;\n                                                    } else if (\n                                                        (r | 0) ==\n                                                        32639\n                                                    ) {\n                                                        o = 1179;\n                                                        break L1442;\n                                                    }\n                                                    break;\n                                                }\n                                                case 7: {\n                                                    s = 4;\n                                                    break;\n                                                }\n                                                case 10: {\n                                                    s = 5;\n                                                    break;\n                                                }\n                                                case 11: {\n                                                    s = 7;\n                                                    break;\n                                                }\n                                                case 64: {\n                                                    s = 6;\n                                                    break;\n                                                }\n                                                case 120: {\n                                                    s = 12;\n                                                    break;\n                                                }\n                                                case 121: {\n                                                    s = 13;\n                                                    break;\n                                                }\n                                                case 123: {\n                                                    s = 14;\n                                                    break;\n                                                }\n                                                case 0: {\n                                                    s = 15;\n                                                    break;\n                                                }\n                                                case 32: {\n                                                    if ((d[k] | 0) == 0) {\n                                                        s = 15;\n                                                    }\n                                                    break;\n                                                }\n                                                case 100: {\n                                                    a[6616] = 0;\n                                                    a[\n                                                        (6584 + (d[6632] | 0)) |\n                                                            0\n                                                    ] = a[k] | 0;\n                                                    break;\n                                                }\n                                                case 101: {\n                                                    a[6616] = 0;\n                                                    a[\n                                                        (6600 + (d[6632] | 0)) |\n                                                            0\n                                                    ] = a[k] | 0;\n                                                    break;\n                                                }\n                                                case 99: {\n                                                    a[6616] = 1;\n                                                    a[\n                                                        (6584 + (d[6632] | 0)) |\n                                                            0\n                                                    ] = a[k] | 0;\n                                                    break;\n                                                }\n                                                default: {\n                                                }\n                                            }\n                                        } while (0);\n                                        if ((s | 0) != 255) {\n                                            o = 1184;\n                                            break L1442;\n                                        }\n                                        break;\n                                    }\n                                    default: {\n                                    }\n                                }\n                            }\n                        }\n                    } while (0);\n                    if ((o | 0) == 1141) {\n                        o = 0;\n                        p = cw(m) | 0;\n                        cQ(m, p);\n                    }\n                }\n                if ((o | 0) == 1184) {\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = s & 255;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = a[k] | 0;\n                    a[(t + 7) | 0] = 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1156) {\n                    cP(m, k, 1, 1) | 0;\n                    a[k] = d[k] & 127;\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 1;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = a[j] | 0;\n                    a[(t + 7) | 0] = a[k] | 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1179) {\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 11;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = 2;\n                    a[(t + 7) | 0] = 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1138) {\n                    u = 0;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1188) {\n                    cP(m, k, 1, 1) | 0;\n                    a[k] = d[k] & 127;\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 8;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = a[j] | 0;\n                    a[(t + 7) | 0] = a[k] | 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1186) {\n                    a[j] = d[j] & 127;\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 9;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = a[j] | 0;\n                    a[(t + 7) | 0] = 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1147) {\n                    u = -1;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1148) {\n                    cP(m, j, 1, 1) | 0;\n                    cP(m, k, 1, 1) | 0;\n                    cP(m, l, 1, 1) | 0;\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 10;\n                    a[(t + 4) | 0] = a[l] | 0;\n                    a[(t + 6) | 0] = a[j] | 0;\n                    a[(t + 7) | 0] = a[k] | 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1155) {\n                    cP(m, k, 1, 1) | 0;\n                    a[k] = d[k] & 127;\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 2;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = a[j] | 0;\n                    a[(t + 7) | 0] = a[k] | 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                } else if ((o | 0) == 1157) {\n                    cP(m, k, 1, 1) | 0;\n                    a[k] = d[k] & 127;\n                    t = bi(12) | 0;\n                    c[t >> 2] = c[(b + 13096) >> 2];\n                    a[(t + 5) | 0] = 3;\n                    a[(t + 4) | 0] = a[6632] | 0;\n                    a[(t + 6) | 0] = a[j] | 0;\n                    a[(t + 7) | 0] = a[k] | 0;\n                    c[(t + 8) >> 2] = 0;\n                    u = t;\n                    v = u;\n                    i = f;\n                    return v | 0;\n                }\n                return 0;\n            }\n            function cw(b) {\n                b = b | 0;\n                let c = 0,\n                    d = 0,\n                    e = 0;\n                c = i;\n                i = (i + 8) | 0;\n                d = c | 0;\n                e = b;\n                b = 0;\n                while (1) {\n                    cP(e, d, 1, 1) | 0;\n                    b = (b + (a[d] & 127)) | 0;\n                    if (((a[d] & 128) | 0) == 0) {\n                        break;\n                    }\n                    b = b << 7;\n                }\n                i = c;\n                return b | 0;\n            }\n\n            function cx(b, e, f, g) {\n                b = b | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                let h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0;\n                h = e;\n                e = f;\n                f = g;\n                g = bi((h + 1) | 0) | 0;\n                if ((h | 0) != (cP(b, g, 1, h) | 0)) {\n                    c0(g);\n                    i = -1;\n                    j = i;\n                    return j | 0;\n                }\n                a[(g + h) | 0] = 0;\n                while (1) {\n                    b = h;\n                    h = (b - 1) | 0;\n                    if ((b | 0) == 0) {\n                        break;\n                    }\n                    if ((d[(g + h) | 0] | 0 | 0) < 32) {\n                        a[(g + h) | 0] = 46;\n                    }\n                }\n                h = e & 255;\n                if ((h | 0) == 1) {\n                    k = 0;\n                } else if ((h | 0) == 2) {\n                    k = 1;\n                } else {\n                    c0(g);\n                    g = 0;\n                }\n                if ((g | 0) != 0) {\n                    if ((c[(f + 13104 + (k << 2)) >> 2] | 0) != 0) {\n                        c0(c[(f + 13104 + (k << 2)) >> 2] | 0);\n                    }\n                    c[(f + 13104 + (k << 2)) >> 2] = g;\n                }\n                i = 0;\n                j = i;\n                return j | 0;\n            }\n\n            function cy(b, e, f) {\n                b = b | 0;\n                e = e | 0;\n                f = f | 0;\n                let g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0;\n                g = b;\n                b = e;\n                e = f;\n                f = (g + 1724 + ((b * 236) | 0)) | 0;\n                if ((c[((c[(f + 4) >> 2] | 0) + 12) >> 2] | 0) == 0) {\n                    h = c[(f + 16) >> 2] >> 12;\n                    if (\n                        (c[e >> 2] | 0) >=\n                        (((c[((c[(f + 4) >> 2] | 0) + 8) >> 2] >> 12) - h) | 0)\n                    ) {\n                        a[f | 0] = 0;\n                        c[e >> 2] =\n                            (c[((c[(f + 4) >> 2] | 0) + 8) >> 2] >> 12) - h;\n                    } else {\n                        i = (f + 16) | 0;\n                        c[i >> 2] = (c[i >> 2] | 0) + (c[e >> 2] << 12);\n                    }\n                    j =\n                        ((c[((c[(f + 4) >> 2] | 0) + 88) >> 2] | 0) +\n                            (h << 1)) |\n                        0;\n                    k = j;\n                    return k | 0;\n                }\n                h = a[((c[(f + 4) >> 2] | 0) + 110) | 0] | 0;\n                if ((c[(f + 212) >> 2] | 0) != 0) {\n                    L1575: do {\n                        if (((h & 4) | 0) != 0) {\n                            do {\n                                if (((h & 64) | 0) == 0) {\n                                    if ((d[f | 0] | 0 | 0) == 1) {\n                                        break;\n                                    }\n                                    if ((d[f | 0] | 0 | 0) != 2) {\n                                        break L1575;\n                                    }\n                                }\n                            } while (0);\n                            if (((h & 8) | 0) != 0) {\n                                j = cz(g, f, c[e >> 2] | 0) | 0;\n                                k = j;\n                                return k | 0;\n                            } else {\n                                j = cA(g, f, c[e >> 2] | 0) | 0;\n                                k = j;\n                                return k | 0;\n                            }\n                        }\n                    } while (0);\n                    j = cB(g, b, e) | 0;\n                    k = j;\n                    return k | 0;\n                } else {\n                    L1561: do {\n                        if (((h & 4) | 0) != 0) {\n                            do {\n                                if (((h & 64) | 0) == 0) {\n                                    if ((d[f | 0] | 0 | 0) == 1) {\n                                        break;\n                                    }\n                                    if ((d[f | 0] | 0 | 0) != 2) {\n                                        break L1561;\n                                    }\n                                }\n                            } while (0);\n                            if (((h & 8) | 0) != 0) {\n                                j = cC(g, f, c[e >> 2] | 0) | 0;\n                                k = j;\n                                return k | 0;\n                            } else {\n                                j = cD(g, f, c[e >> 2] | 0) | 0;\n                                k = j;\n                                return k | 0;\n                            }\n                        }\n                    } while (0);\n                    j = cE(g, b, e) | 0;\n                    k = j;\n                    return k | 0;\n                }\n                return 0;\n            }\n            function cz(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0;\n                f = a;\n                a = d;\n                d = e;\n                e = c[(a + 16) >> 2] | 0;\n                g = c[(a + 20) >> 2] | 0;\n                h = c[((c[(a + 4) >> 2] | 0) + 4) >> 2] | 0;\n                i = c[c[(a + 4) >> 2] >> 2] | 0;\n                j = c[(f + 1068) >> 2] | 0;\n                k = c[((c[(a + 4) >> 2] | 0) + 88) >> 2] | 0;\n                l = c[(a + 216) >> 2] | 0;\n                m = h << 1;\n                n = i << 1;\n                o = 0;\n                while (1) {\n                    if ((d | 0) != 0) {\n                        p = (e | 0) <= (i | 0);\n                    } else {\n                        p = 0;\n                    }\n                    if (!p) {\n                        break;\n                    }\n                    q = (((((i - e) | 0) / (g | 0)) | 0) + 1) | 0;\n                    if ((q | 0) > (d | 0)) {\n                        q = d;\n                    }\n                    if ((q | 0) > (l | 0)) {\n                        q = l;\n                        o = 1;\n                    } else {\n                        l = (l - q) | 0;\n                    }\n                    d = (d - q) | 0;\n                    while (1) {\n                        r = q;\n                        q = (r - 1) | 0;\n                        if ((r | 0) == 0) {\n                            break;\n                        }\n                        s = b[(k + ((e >> 12) << 1)) >> 1] | 0;\n                        t = b[(k + (((e >> 12) + 1) << 1)) >> 1] | 0;\n                        r = j;\n                        j = (r + 2) | 0;\n                        b[r >> 1] =\n                            (((s << 16) >> 16) +\n                                ((_(\n                                    (((t << 16) >> 16) - ((s << 16) >> 16)) | 0,\n                                    e & 4095\n                                ) |\n                                    0) >>>\n                                    12)) &\n                            65535;\n                        e = (e + g) | 0;\n                    }\n                    if ((o | 0) != 0) {\n                        l = c[(a + 212) >> 2] | 0;\n                        g = cG(f, a, 0) | 0;\n                        o = 0;\n                    }\n                }\n                while (1) {\n                    if ((d | 0) == 0) {\n                        break;\n                    }\n                    if ((g | 0) > 0) {\n                        u = h;\n                    } else {\n                        u = i;\n                    }\n                    q = (((((u - e) | 0) / (g | 0)) | 0) + 1) | 0;\n                    if ((q | 0) > (d | 0)) {\n                        q = d;\n                    }\n                    if ((q | 0) > (l | 0)) {\n                        q = l;\n                        o = 1;\n                    } else {\n                        l = (l - q) | 0;\n                    }\n                    d = (d - q) | 0;\n                    while (1) {\n                        p = q;\n                        q = (p - 1) | 0;\n                        if ((p | 0) == 0) {\n                            break;\n                        }\n                        s = b[(k + ((e >> 12) << 1)) >> 1] | 0;\n                        t = b[(k + (((e >> 12) + 1) << 1)) >> 1] | 0;\n                        p = j;\n                        j = (p + 2) | 0;\n                        b[p >> 1] =\n                            (((s << 16) >> 16) +\n                                ((_(\n                                    (((t << 16) >> 16) - ((s << 16) >> 16)) | 0,\n                                    e & 4095\n                                ) |\n                                    0) >>>\n                                    12)) &\n                            65535;\n                        e = (e + g) | 0;\n                    }\n                    if ((o | 0) != 0) {\n                        l = c[(a + 212) >> 2] | 0;\n                        g = cG(f, a, ((g | 0) < 0) | 0) | 0;\n                        o = 0;\n                    }\n                    if ((e | 0) >= (h | 0)) {\n                        e = (m - e) | 0;\n                        g = (g * -1) | 0;\n                    } else {\n                        if ((e | 0) <= (i | 0)) {\n                            e = (n - e) | 0;\n                            g = (g * -1) | 0;\n                        }\n                    }\n                }\n                c[(a + 216) >> 2] = l;\n                c[(a + 20) >> 2] = g;\n                c[(a + 16) >> 2] = e;\n                return c[(f + 1068) >> 2] | 0;\n            }\n            function cA(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0;\n                f = a;\n                a = d;\n                d = e;\n                e = c[(a + 16) >> 2] | 0;\n                g = c[(a + 20) >> 2] | 0;\n                h = c[((c[(a + 4) >> 2] | 0) + 4) >> 2] | 0;\n                i = (h - (c[c[(a + 4) >> 2] >> 2] | 0)) | 0;\n                j = c[(f + 1068) >> 2] | 0;\n                k = c[((c[(a + 4) >> 2] | 0) + 88) >> 2] | 0;\n                l = c[(a + 216) >> 2] | 0;\n                m = 0;\n                while (1) {\n                    if ((d | 0) == 0) {\n                        break;\n                    }\n                    if ((e | 0) >= (h | 0)) {\n                        e = (e - i) | 0;\n                    }\n                    n = (((((h - e) | 0) / (g | 0)) | 0) + 1) | 0;\n                    if ((n | 0) > (d | 0)) {\n                        n = d;\n                    }\n                    if ((n | 0) > (l | 0)) {\n                        n = l;\n                        m = 1;\n                    } else {\n                        l = (l - n) | 0;\n                    }\n                    d = (d - n) | 0;\n                    while (1) {\n                        o = n;\n                        n = (o - 1) | 0;\n                        if ((o | 0) == 0) {\n                            break;\n                        }\n                        o = b[(k + ((e >> 12) << 1)) >> 1] | 0;\n                        p = j;\n                        j = (p + 2) | 0;\n                        b[p >> 1] =\n                            (((o << 16) >> 16) +\n                                ((_(\n                                    ((b[(k + (((e >> 12) + 1) << 1)) >> 1] |\n                                        0) -\n                                        ((o << 16) >> 16)) |\n                                        0,\n                                    e & 4095\n                                ) |\n                                    0) >>>\n                                    12)) &\n                            65535;\n                        e = (e + g) | 0;\n                    }\n                    if ((m | 0) != 0) {\n                        l = c[(a + 212) >> 2] | 0;\n                        g = cG(f, a, 0) | 0;\n                        m = 0;\n                    }\n                }\n                c[(a + 216) >> 2] = l;\n                c[(a + 20) >> 2] = g;\n                c[(a + 16) >> 2] = e;\n                return c[(f + 1068) >> 2] | 0;\n            }\n            function cB(d, e, f) {\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                let g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0,\n                    B = 0;\n                g = d;\n                d = f;\n                f = (g + 1724 + ((e * 236) | 0)) | 0;\n                e = c[(g + 1068) >> 2] | 0;\n                h = c[((c[(f + 4) >> 2] | 0) + 88) >> 2] | 0;\n                i = c[((c[(f + 4) >> 2] | 0) + 8) >> 2] | 0;\n                j = c[(f + 16) >> 2] | 0;\n                k = c[(f + 20) >> 2] | 0;\n                l = c[d >> 2] | 0;\n                m = c[(f + 216) >> 2] | 0;\n                if ((k | 0) < 0) {\n                    k = -k | 0;\n                }\n                do {\n                    n = l;\n                    l = (n - 1) | 0;\n                    if ((n | 0) == 0) {\n                        o = 1322;\n                        break;\n                    }\n                    n = m;\n                    m = (n - 1) | 0;\n                    if ((n | 0) == 0) {\n                        m = c[(f + 212) >> 2] | 0;\n                        k = cG(g, f, 0) | 0;\n                    }\n                    n = b[(h + ((j >> 12) << 1)) >> 1] | 0;\n                    p = e;\n                    e = (p + 2) | 0;\n                    b[p >> 1] =\n                        (((n << 16) >> 16) +\n                            ((_(\n                                ((b[(h + (((j >> 12) + 1) << 1)) >> 1] | 0) -\n                                    ((n << 16) >> 16)) |\n                                    0,\n                                j & 4095\n                            ) |\n                                0) >>>\n                                12)) &\n                        65535;\n                    j = (j + k) | 0;\n                } while ((j | 0) < (i | 0));\n                if ((o | 0) == 1322) {\n                    q = m;\n                    r = f;\n                    s = (r + 216) | 0;\n                    c[s >> 2] = q;\n                    t = k;\n                    u = f;\n                    v = (u + 20) | 0;\n                    c[v >> 2] = t;\n                    w = j;\n                    x = f;\n                    y = (x + 16) | 0;\n                    c[y >> 2] = w;\n                    z = g;\n                    A = (z + 1068) | 0;\n                    B = c[A >> 2] | 0;\n                    return B | 0;\n                }\n                if ((j | 0) == (i | 0)) {\n                    i = e;\n                    e = (i + 2) | 0;\n                    b[i >> 1] = b[(h + ((j >> 12) << 1)) >> 1] | 0;\n                }\n                a[f | 0] = 0;\n                h = d;\n                c[h >> 2] = (c[h >> 2] | 0) - (l + 1);\n                q = m;\n                r = f;\n                s = (r + 216) | 0;\n                c[s >> 2] = q;\n                t = k;\n                u = f;\n                v = (u + 20) | 0;\n                c[v >> 2] = t;\n                w = j;\n                x = f;\n                y = (x + 16) | 0;\n                c[y >> 2] = w;\n                z = g;\n                A = (z + 1068) | 0;\n                B = c[A >> 2] | 0;\n                return B | 0;\n            }\n            function cC(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0;\n                f = a;\n                a = d;\n                d = e;\n                e = c[(a + 16) >> 2] | 0;\n                g = c[(a + 20) >> 2] | 0;\n                h = c[((c[(a + 4) >> 2] | 0) + 4) >> 2] | 0;\n                i = c[c[(a + 4) >> 2] >> 2] | 0;\n                j = c[(f + 1068) >> 2] | 0;\n                k = c[((c[(a + 4) >> 2] | 0) + 88) >> 2] | 0;\n                l = h << 1;\n                m = i << 1;\n                if ((e | 0) <= (i | 0)) {\n                    n = (((((i - e) | 0) / (g | 0)) | 0) + 1) | 0;\n                    if ((n | 0) > (d | 0)) {\n                        n = d;\n                        d = 0;\n                    } else {\n                        d = (d - n) | 0;\n                    }\n                    while (1) {\n                        o = n;\n                        n = (o - 1) | 0;\n                        if ((o | 0) == 0) {\n                            break;\n                        }\n                        p = b[(k + ((e >> 12) << 1)) >> 1] | 0;\n                        q = b[(k + (((e >> 12) + 1) << 1)) >> 1] | 0;\n                        o = j;\n                        j = (o + 2) | 0;\n                        b[o >> 1] =\n                            (((p << 16) >> 16) +\n                                ((_(\n                                    (((q << 16) >> 16) - ((p << 16) >> 16)) | 0,\n                                    e & 4095\n                                ) |\n                                    0) >>>\n                                    12)) &\n                            65535;\n                        e = (e + g) | 0;\n                    }\n                }\n                while (1) {\n                    if ((d | 0) == 0) {\n                        break;\n                    }\n                    if ((g | 0) > 0) {\n                        r = h;\n                    } else {\n                        r = i;\n                    }\n                    n = (((((r - e) | 0) / (g | 0)) | 0) + 1) | 0;\n                    if ((n | 0) > (d | 0)) {\n                        n = d;\n                        d = 0;\n                    } else {\n                        d = (d - n) | 0;\n                    }\n                    while (1) {\n                        o = n;\n                        n = (o - 1) | 0;\n                        if ((o | 0) == 0) {\n                            break;\n                        }\n                        p = b[(k + ((e >> 12) << 1)) >> 1] | 0;\n                        q = b[(k + (((e >> 12) + 1) << 1)) >> 1] | 0;\n                        o = j;\n                        j = (o + 2) | 0;\n                        b[o >> 1] =\n                            (((p << 16) >> 16) +\n                                ((_(\n                                    (((q << 16) >> 16) - ((p << 16) >> 16)) | 0,\n                                    e & 4095\n                                ) |\n                                    0) >>>\n                                    12)) &\n                            65535;\n                        e = (e + g) | 0;\n                    }\n                    if ((e | 0) >= (h | 0)) {\n                        e = (l - e) | 0;\n                        g = (g * -1) | 0;\n                    } else {\n                        if ((e | 0) <= (i | 0)) {\n                            e = (m - e) | 0;\n                            g = (g * -1) | 0;\n                        }\n                    }\n                }\n                c[(a + 20) >> 2] = g;\n                c[(a + 16) >> 2] = e;\n                return c[(f + 1068) >> 2] | 0;\n            }\n            function cD(a, d, e) {\n                a = a | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0;\n                f = a;\n                a = d;\n                d = e;\n                e = c[(a + 16) >> 2] | 0;\n                g = c[(a + 20) >> 2] | 0;\n                h = c[((c[(a + 4) >> 2] | 0) + 4) >> 2] | 0;\n                i = (h - (c[c[(a + 4) >> 2] >> 2] | 0)) | 0;\n                j = c[(f + 1068) >> 2] | 0;\n                k = c[((c[(a + 4) >> 2] | 0) + 88) >> 2] | 0;\n                while (1) {\n                    if ((d | 0) == 0) {\n                        break;\n                    }\n                    if ((e | 0) >= (h | 0)) {\n                        e = (e - i) | 0;\n                    }\n                    l = (((((h - e) | 0) / (g | 0)) | 0) + 1) | 0;\n                    if ((l | 0) > (d | 0)) {\n                        l = d;\n                        d = 0;\n                    } else {\n                        d = (d - l) | 0;\n                    }\n                    while (1) {\n                        m = l;\n                        l = (m - 1) | 0;\n                        if ((m | 0) == 0) {\n                            break;\n                        }\n                        m = b[(k + ((e >> 12) << 1)) >> 1] | 0;\n                        n = j;\n                        j = (n + 2) | 0;\n                        b[n >> 1] =\n                            (((m << 16) >> 16) +\n                                ((_(\n                                    ((b[(k + (((e >> 12) + 1) << 1)) >> 1] |\n                                        0) -\n                                        ((m << 16) >> 16)) |\n                                        0,\n                                    e & 4095\n                                ) |\n                                    0) >>>\n                                    12)) &\n                            65535;\n                        e = (e + g) | 0;\n                    }\n                }\n                c[(a + 16) >> 2] = e;\n                return c[(f + 1068) >> 2] | 0;\n            }\n            function cE(d, e, f) {\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                let g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0;\n                g = d;\n                d = f;\n                f = (g + 1724 + ((e * 236) | 0)) | 0;\n                e = c[(g + 1068) >> 2] | 0;\n                h = c[((c[(f + 4) >> 2] | 0) + 88) >> 2] | 0;\n                i = c[(f + 16) >> 2] | 0;\n                j = c[(f + 20) >> 2] | 0;\n                k = c[((c[(f + 4) >> 2] | 0) + 8) >> 2] | 0;\n                l = c[d >> 2] | 0;\n                if ((j | 0) < 0) {\n                    j = -j | 0;\n                }\n                m = (((((k - i) | 0) / (j | 0)) | 0) + 1) | 0;\n                if ((m | 0) > (l | 0)) {\n                    m = l;\n                    l = 0;\n                } else {\n                    l = (l - m) | 0;\n                }\n                while (1) {\n                    n = m;\n                    m = (n - 1) | 0;\n                    if ((n | 0) == 0) {\n                        break;\n                    }\n                    n = b[(h + ((i >> 12) << 1)) >> 1] | 0;\n                    o = e;\n                    e = (o + 2) | 0;\n                    b[o >> 1] =\n                        (((n << 16) >> 16) +\n                            ((_(\n                                ((b[(h + (((i >> 12) + 1) << 1)) >> 1] | 0) -\n                                    ((n << 16) >> 16)) |\n                                    0,\n                                i & 4095\n                            ) |\n                                0) >>>\n                                12)) &\n                        65535;\n                    i = (i + j) | 0;\n                }\n                if ((i | 0) < (k | 0)) {\n                    p = i;\n                    q = f;\n                    r = (q + 16) | 0;\n                    c[r >> 2] = p;\n                    s = g;\n                    t = (s + 1068) | 0;\n                    u = c[t >> 2] | 0;\n                    return u | 0;\n                }\n                if ((i | 0) == (k | 0)) {\n                    k = e;\n                    e = (k + 2) | 0;\n                    b[k >> 1] = b[(h + ((i >> 12) << 1)) >> 1] | 0;\n                }\n                a[f | 0] = 0;\n                h = d;\n                c[h >> 2] = (c[h >> 2] | 0) - (l + 1);\n                p = i;\n                q = f;\n                r = (q + 16) | 0;\n                c[r >> 2] = p;\n                s = g;\n                t = (s + 1068) | 0;\n                u = c[t >> 2] | 0;\n                return u | 0;\n            }\n            function cF(e, f) {\n                e = e | 0;\n                f = f | 0;\n                let g = 0,\n                    h = 0,\n                    i = 0.0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0.0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0.0,\n                    B = 0.0,\n                    C = 0.0,\n                    D = 0,\n                    E = 0,\n                    F = 0,\n                    G = 0,\n                    H = 0,\n                    I = 0,\n                    J = 0.0,\n                    K = 0.0,\n                    L = 0.0,\n                    M = 0,\n                    N = 0,\n                    O = 0,\n                    P = 0,\n                    Q = 0,\n                    R = 0,\n                    S = 0,\n                    T = 0,\n                    U = 0,\n                    V = 0,\n                    W = 0,\n                    X = 0;\n                g = f;\n                f = c[(g + 88) >> 2] | 0;\n                h = (1056 + (a[(g + 112) | 0] << 2)) | 0;\n                i =\n                    (+(c[(g + 12) >> 2] | 0) *\n                        +(\n                            d[h] |\n                            (d[(h + 1) | 0] << 8) |\n                            (d[(h + 2) | 0] << 16) |\n                            (d[(h + 3) | 0] << 24) |\n                            0\n                        )) /\n                    (+(c[(g + 32) >> 2] | 0) * +(c[(e + 4) >> 2] | 0));\n                e = ~~(+(c[(g + 8) >> 2] | 0) / i);\n                h = bi(e >> 11) | 0;\n                j = h;\n                k = h;\n                h = ((e >> 12) - 1) | 0;\n                l = ((((c[(g + 8) >> 2] | 0) - 4096) | 0) / (h | 0)) | 0;\n                m = l;\n                n = l;\n                l = (h - 1) | 0;\n                h = l;\n                if ((l | 0) != 0) {\n                    l = k;\n                    k = (l + 2) | 0;\n                    b[l >> 1] = b[f >> 1] | 0;\n                }\n                while (1) {\n                    l = (h - 1) | 0;\n                    h = l;\n                    if ((l | 0) == 0) {\n                        break;\n                    }\n                    l = (f + ((n >> 12) << 1)) | 0;\n                    if (l >>> 0 > f >>> 0) {\n                        o = b[(l - 2) >> 1] | 0;\n                    } else {\n                        o = 0;\n                    }\n                    p = o & 65535;\n                    q = b[l >> 1] | 0;\n                    r = b[(l + 2) >> 1] | 0;\n                    s = b[(l + 4) >> 1] | 0;\n                    t = +(((n & 4095) >>> 0) >>> 0) * 0.000244140625;\n                    l = k;\n                    k = (l + 2) | 0;\n                    b[l >> 1] = ~~(\n                        +(((q << 16) >> 16) | 0) +\n                        (t / 6.0) *\n                            (+(\n                                (((((p << 16) >> 16) * -2) | 0) -\n                                    ((((q << 16) >> 16) * 3) | 0) +\n                                    ((((r << 16) >> 16) * 6) | 0) -\n                                    ((s << 16) >> 16)) |\n                                0\n                            ) +\n                                t *\n                                    (+(\n                                        (((((p << 16) >> 16) -\n                                            (((q << 16) >> 16) << 1) +\n                                            ((r << 16) >> 16)) |\n                                            0) *\n                                            3) |\n                                        0 |\n                                        0\n                                    ) +\n                                        t *\n                                            +(\n                                                ((-((p << 16) >> 16) | 0) +\n                                                    ((((((q << 16) >> 16) -\n                                                        ((r << 16) >> 16)) |\n                                                        0) *\n                                                        3) |\n                                                        0) +\n                                                    ((s << 16) >> 16)) |\n                                                0\n                                            )))\n                    );\n                    n = (n + m) | 0;\n                }\n                if (((n & 4095) | 0) != 0) {\n                    p = b[(f + ((n >> 12) << 1)) >> 1] | 0;\n                    q = b[(f + (((n >> 12) + 1) << 1)) >> 1] | 0;\n                    m = k;\n                    k = (m + 2) | 0;\n                    b[m >> 1] =\n                        (((p << 16) >> 16) +\n                            ((_(\n                                (((q << 16) >> 16) - ((p << 16) >> 16)) | 0,\n                                n & 4095\n                            ) |\n                                0) >>>\n                                12)) &\n                        65535;\n                    u = e;\n                    v = g;\n                    w = (v + 8) | 0;\n                    c[w >> 2] = u;\n                    x = g;\n                    y = x | 0;\n                    z = c[y >> 2] | 0;\n                    A = +(z | 0);\n                    B = i;\n                    C = A / B;\n                    D = ~~C;\n                    E = g;\n                    F = E | 0;\n                    c[F >> 2] = D;\n                    G = g;\n                    H = (G + 4) | 0;\n                    I = c[H >> 2] | 0;\n                    J = +(I | 0);\n                    K = i;\n                    L = J / K;\n                    M = ~~L;\n                    N = g;\n                    O = (N + 4) | 0;\n                    c[O >> 2] = M;\n                    P = g;\n                    Q = (P + 88) | 0;\n                    R = c[Q >> 2] | 0;\n                    S = R;\n                    c0(S);\n                    T = j;\n                    U = g;\n                    V = (U + 88) | 0;\n                    c[V >> 2] = T;\n                    W = g;\n                    X = (W + 12) | 0;\n                    c[X >> 2] = 0;\n                    return;\n                } else {\n                    p = k;\n                    k = (p + 2) | 0;\n                    b[p >> 1] = b[(f + ((n >> 12) << 1)) >> 1] | 0;\n                    u = e;\n                    v = g;\n                    w = (v + 8) | 0;\n                    c[w >> 2] = u;\n                    x = g;\n                    y = x | 0;\n                    z = c[y >> 2] | 0;\n                    A = +(z | 0);\n                    B = i;\n                    C = A / B;\n                    D = ~~C;\n                    E = g;\n                    F = E | 0;\n                    c[F >> 2] = D;\n                    G = g;\n                    H = (G + 4) | 0;\n                    I = c[H >> 2] | 0;\n                    J = +(I | 0);\n                    K = i;\n                    L = J / K;\n                    M = ~~L;\n                    N = g;\n                    O = (N + 4) | 0;\n                    c[O >> 2] = M;\n                    P = g;\n                    Q = (P + 88) | 0;\n                    R = c[Q >> 2] | 0;\n                    S = R;\n                    c0(S);\n                    T = j;\n                    U = g;\n                    V = (U + 88) | 0;\n                    c[V >> 2] = T;\n                    W = g;\n                    X = (W + 12) | 0;\n                    c[X >> 2] = 0;\n                    return;\n                }\n            }\n            function cG(a, b, e) {\n                a = a | 0;\n                b = b | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    i = 0,\n                    j = 0,\n                    l = 0,\n                    m = 0.0,\n                    n = 0.0;\n                f = a;\n                a = b;\n                b = e;\n                e = (a + 208) | 0;\n                g = c[e >> 2] | 0;\n                c[e >> 2] = g + 1;\n                if ((g | 0) >= 63) {\n                    c[(a + 208) >> 2] = 0;\n                }\n                g = cH(c[(a + 208) >> 2] | 0) | 0;\n                if ((c[(a + 80 + (g << 2)) >> 2] | 0) != 0) {\n                    if ((b | 0) != 0) {\n                        i = -(c[(a + 80 + (g << 2)) >> 2] | 0) | 0;\n                        j = i;\n                        return j | 0;\n                    } else {\n                        i = c[(a + 80 + (g << 2)) >> 2] | 0;\n                        j = i;\n                        return j | 0;\n                    }\n                }\n                e = (d[((c[(a + 4) >> 2] | 0) + 109) | 0] | 0) << 7;\n                if ((c[(a + 52) >> 2] | 0) != 0) {\n                    l = (a + 56) | 0;\n                    c[l >> 2] = (c[l >> 2] | 0) + (c[(a + 52) >> 2] | 0);\n                    if ((c[(a + 56) >> 2] | 0) >= 65536) {\n                        c[(a + 52) >> 2] = 0;\n                    } else {\n                        e = _(e, c[(a + 56) >> 2] | 0) | 0;\n                        e = e >> 16;\n                    }\n                }\n                m =\n                    ((+(c[((c[(a + 4) >> 2] | 0) + 12) >> 2] | 0) *\n                        +(c[(a + 12) >> 2] | 0)) /\n                        (+(c[((c[(a + 4) >> 2] | 0) + 32) >> 2] | 0) *\n                            +(c[(f + 4) >> 2] | 0))) *\n                    4096.0;\n                f = ~~(\n                    +R(\n                        +(\n                            +((c[(a + 208) >> 2] << 4) | 0) *\n                            0.006135923151542565\n                        )\n                    ) *\n                    +(e | 0) *\n                    1.0\n                );\n                if ((f | 0) < 0) {\n                    f = -f | 0;\n                    e = (1704 + (((f >> 5) & 255) << 3)) | 0;\n                    n =\n                        ((c[k >> 2] =\n                            d[e] |\n                            (d[(e + 1) | 0] << 8) |\n                            (d[(e + 2) | 0] << 16) |\n                            (d[(e + 3) | 0] << 24)),\n                        (c[(k + 4) >> 2] =\n                            d[(e + 4) | 0] |\n                            (d[(e + 5) | 0] << 8) |\n                            (d[(e + 6) | 0] << 16) |\n                            (d[(e + 7) | 0] << 24)),\n                        +h[k >> 3]);\n                    e = (3752 + ((f >> 13) << 3)) | 0;\n                    m =\n                        m /\n                        (n *\n                            ((c[k >> 2] =\n                                d[e] |\n                                (d[(e + 1) | 0] << 8) |\n                                (d[(e + 2) | 0] << 16) |\n                                (d[(e + 3) | 0] << 24)),\n                            (c[(k + 4) >> 2] =\n                                d[(e + 4) | 0] |\n                                (d[(e + 5) | 0] << 8) |\n                                (d[(e + 6) | 0] << 16) |\n                                (d[(e + 7) | 0] << 24)),\n                            +h[k >> 3]));\n                } else {\n                    e = (1704 + (((f >> 5) & 255) << 3)) | 0;\n                    n =\n                        ((c[k >> 2] =\n                            d[e] |\n                            (d[(e + 1) | 0] << 8) |\n                            (d[(e + 2) | 0] << 16) |\n                            (d[(e + 3) | 0] << 24)),\n                        (c[(k + 4) >> 2] =\n                            d[(e + 4) | 0] |\n                            (d[(e + 5) | 0] << 8) |\n                            (d[(e + 6) | 0] << 16) |\n                            (d[(e + 7) | 0] << 24)),\n                        +h[k >> 3]);\n                    e = (3752 + ((f >> 13) << 3)) | 0;\n                    m =\n                        m *\n                        n *\n                        ((c[k >> 2] =\n                            d[e] |\n                            (d[(e + 1) | 0] << 8) |\n                            (d[(e + 2) | 0] << 16) |\n                            (d[(e + 3) | 0] << 24)),\n                        (c[(k + 4) >> 2] =\n                            d[(e + 4) | 0] |\n                            (d[(e + 5) | 0] << 8) |\n                            (d[(e + 6) | 0] << 16) |\n                            (d[(e + 7) | 0] << 24)),\n                        +h[k >> 3]);\n                }\n                if ((c[(a + 52) >> 2] | 0) == 0) {\n                    c[(a + 80 + (g << 2)) >> 2] = ~~m;\n                }\n                if ((b | 0) != 0) {\n                    m = -0.0 - m;\n                }\n                i = ~~m;\n                j = i;\n                return j | 0;\n            }\n            function cH(a) {\n                a = a | 0;\n                let b = 0,\n                    c = 0;\n                b = a;\n                do {\n                    if ((b | 0) < 16) {\n                        c = (15 - b) | 0;\n                    } else {\n                        if ((b | 0) >= 48) {\n                            c = (79 - b) | 0;\n                            break;\n                        } else {\n                            c = (b - 16) | 0;\n                            break;\n                        }\n                    }\n                } while (0);\n                return c | 0;\n            }\n            function cI(a, b, d, e) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                return an(b | 0, d | 0, e | 0, c[a >> 2] | 0) | 0;\n            }\n            function cJ(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0,\n                    e = 0;\n                b = a;\n                a = 0;\n                if ((c[(b + 4) >> 2] | 0) == 0) {\n                    d = b;\n                    c0(d);\n                    e = a;\n                    return e | 0;\n                }\n                a = ao(c[b >> 2] | 0) | 0;\n                d = b;\n                c0(d);\n                e = a;\n                return e | 0;\n            }\n            function cK(a, b, d, e) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0;\n                f = d;\n                d = a;\n                a = e;\n                e = c[(d + 4) >> 2] | 0;\n                g = (e + (_(a, f) | 0)) | 0;\n                if (g >>> 0 > (c[(d + 8) >> 2] | 0) >>> 0) {\n                    a =\n                        (((((c[(d + 8) >> 2] | 0) - (c[(d + 4) >> 2] | 0)) |\n                            0) >>>\n                            0) /\n                            (f >>> 0)) |\n                        0;\n                }\n                g = b;\n                b = c[(d + 4) >> 2] | 0;\n                e = _(a, f) | 0;\n                c6(g | 0, b | 0, e) | 0;\n                e = _(a, f) | 0;\n                f = (d + 4) | 0;\n                c[f >> 2] = (c[f >> 2] | 0) + e;\n                return a | 0;\n            }\n            function cL(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0;\n                b = a;\n                if ((c[(b + 12) >> 2] | 0) == 0) {\n                    d = b;\n                    c0(d);\n                    return 0;\n                }\n                c0(c[b >> 2] | 0);\n                d = b;\n                c0(d);\n                return 0;\n            }\n            function cM(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0;\n                d = bi(12) | 0;\n                if ((d | 0) == 0) {\n                    e = 0;\n                    f = e;\n                    return f | 0;\n                }\n                g = bi(8) | 0;\n                if ((g | 0) == 0) {\n                    c0(d);\n                    e = 0;\n                    f = e;\n                    return f | 0;\n                } else {\n                    c[g >> 2] = a;\n                    c[(g + 4) >> 2] = b;\n                    c[(d + 8) >> 2] = g;\n                    c[d >> 2] = 2;\n                    c[(d + 4) >> 2] = 4;\n                    e = d;\n                    f = e;\n                    return f | 0;\n                }\n                return 0;\n            }\n            function cN(a) {\n                a = a | 0;\n                let b = 0,\n                    c = 0,\n                    d = 0;\n                b = av(a | 0, 6544) | 0;\n                if ((b | 0) == 0) {\n                    c = 0;\n                    d = c;\n                    return d | 0;\n                } else {\n                    c = cM(b, 1) | 0;\n                    d = c;\n                    return d | 0;\n                }\n                return 0;\n            }\n            function cO(a, b, d) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0;\n                e = a;\n                a = bi(12) | 0;\n                if ((a | 0) == 0) {\n                    f = 0;\n                    g = f;\n                    return g | 0;\n                }\n                h = bi(16) | 0;\n                if ((h | 0) == 0) {\n                    c0(a);\n                    f = 0;\n                    g = f;\n                    return g | 0;\n                } else {\n                    c[h >> 2] = e;\n                    c[(h + 4) >> 2] = e;\n                    c[(h + 8) >> 2] = e + b;\n                    c[(h + 12) >> 2] = d;\n                    c[(a + 8) >> 2] = h;\n                    c[a >> 2] = 4;\n                    c[(a + 4) >> 2] = 2;\n                    f = a;\n                    g = f;\n                    return g | 0;\n                }\n                return 0;\n            }\n            function cP(a, b, d, e) {\n                a = a | 0;\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0;\n                f = a;\n                return aY[c[f >> 2] & 7](c[(f + 8) >> 2] | 0, b, d, e) | 0;\n            }\n            function cQ(a, b) {\n                a = a | 0;\n                b = b | 0;\n                let c = 0,\n                    d = 0,\n                    e = 0;\n                c = i;\n                i = (i + 1024) | 0;\n                d = c | 0;\n                e = a;\n                a = b;\n                while (1) {\n                    if (a >>> 0 <= 0) {\n                        break;\n                    }\n                    b = a;\n                    if (b >>> 0 > 1024) {\n                        b = 1024;\n                    }\n                    a = (a - b) | 0;\n                    (b | 0) != (cP(e, d | 0, 1, b) | 0);\n                }\n                i = c;\n                return;\n            }\n            function cR(a) {\n                a = a | 0;\n                let b = 0;\n                b = a;\n                a = aW[c[(b + 4) >> 2] & 7](c[(b + 8) >> 2] | 0) | 0;\n                c0(b);\n                return a | 0;\n            }\n            function cS() {\n                let a = 0;\n                c[1676] = bi(516) | 0;\n                c5(c[1676] | 0, 0, 516);\n                a = bi(3584) | 0;\n                c[c[1676] >> 2] = a;\n                c5(c[c[1676] >> 2] | 0, 0, 3584);\n                c[1804] = bi(516) | 0;\n                c5(c[1804] | 0, 0, 516);\n                a = bi(3584) | 0;\n                c[c[1804] >> 2] = a;\n                c5(c[c[1804] >> 2] | 0, 0, 3584);\n                return 0;\n            }\n            function cT(b) {\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    j = 0;\n                d = i;\n                i = (i + 1024) | 0;\n                e = d | 0;\n                f = b;\n                do {\n                    if ((f | 0) != 0) {\n                        if ((c1(f | 0) | 0) >>> 0 >= 1024) {\n                            break;\n                        }\n                        b = e | 0;\n                        g = f;\n                        c2(b | 0, g | 0) | 0;\n                        g = aE(f | 0, 47) | 0;\n                        if ((g | 0) != 0) {\n                            a[(e + (g - f)) | 0] = 0;\n                            g = c[m >> 2] | 0;\n                            b = e | 0;\n                            ar(\n                                g | 0,\n                                6480,\n                                ((g = i),\n                                (i = (i + 8) | 0),\n                                (c[g >> 2] = b),\n                                g) | 0\n                            ) | 0;\n                            i = g;\n                            bj(e | 0);\n                        }\n                    }\n                } while (0);\n                cS() | 0;\n                do {\n                    if ((f | 0) != 0) {\n                        if ((a[f] | 0) == 0) {\n                            break;\n                        }\n                        h = f;\n                        j = cU(h) | 0;\n                        i = d;\n                        return j | 0;\n                    }\n                } while (0);\n                f = 6520;\n                h = f;\n                j = cU(h) | 0;\n                i = d;\n                return j | 0;\n            }\n            function cU(b) {\n                b = b | 0;\n                let d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0;\n                d = i;\n                i = (i + 1064) | 0;\n                e = d | 0;\n                f = (d + 1024) | 0;\n                g = b;\n                b = 0;\n                h = 0;\n                if ((c[1660] | 0) > 50) {\n                    j = c[m >> 2] | 0;\n                    ar(\n                        j | 0,\n                        5792,\n                        ((k = i),\n                        (i = (i + 1) | 0),\n                        (i = (i + 7) & -8),\n                        (c[k >> 2] = 0),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -1;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                }\n                j = bh(g) | 0;\n                o = j;\n                if ((j | 0) == 0) {\n                    j = c[m >> 2] | 0;\n                    p = g;\n                    ar(\n                        j | 0,\n                        5392,\n                        ((k = i), (i = (i + 8) | 0), (c[k >> 2] = p), k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -1;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                }\n                L1881: while (1) {\n                    if ((c_(e | 0, 1024, o) | 0) == 0) {\n                        q = 1646;\n                        break;\n                    }\n                    h = (h + 1) | 0;\n                    p = 0;\n                    c[f >> 2] = ay(e | 0, 5096) | 0;\n                    if ((c[f >> 2] | 0) == 0) {\n                        continue;\n                    }\n                    do {\n                        if ((aV(c[f >> 2] | 0, 4840) | 0) == 0) {\n                            p = -1;\n                        } else {\n                            if ((a[c[f >> 2] | 0] | 0) == 35) {\n                                continue L1881;\n                            } else {\n                                break;\n                            }\n                        }\n                    } while (0);\n                    while (1) {\n                        do {\n                            if ((c[(f + (p << 2)) >> 2] | 0) != 0) {\n                                if ((a[c[(f + (p << 2)) >> 2] | 0] | 0) == 35) {\n                                    r = 0;\n                                    break;\n                                }\n                                r = (p | 0) < 10;\n                            } else {\n                                r = 0;\n                            }\n                        } while (0);\n                        if (!r) {\n                            break;\n                        }\n                        j = (p + 1) | 0;\n                        p = j;\n                        c[(f + (j << 2)) >> 2] = ay(0, 5096) | 0;\n                    }\n                    do {\n                        if ((aV(c[f >> 2] | 0, 4832) | 0) != 0) {\n                            if ((aV(c[f >> 2] | 0, 4816) | 0) == 0) {\n                                q = 1504;\n                                break;\n                            }\n                            if ((aV(c[f >> 2] | 0, 4800) | 0) == 0) {\n                                q = 1504;\n                                break;\n                            }\n                            if ((aV(c[f >> 2] | 0, 6552) | 0) == 0) {\n                                q = 1504;\n                                break;\n                            }\n                            if ((aV(c[f >> 2] | 0, 6536) | 0) == 0) {\n                                q = 1504;\n                                break;\n                            }\n                            if ((aV(c[f >> 2] | 0, 6504) | 0) != 0) {\n                                do {\n                                    if ((aV(c[f >> 2] | 0, 6416) | 0) != 0) {\n                                        if (\n                                            (aV(c[f >> 2] | 0, 6400) | 0) ==\n                                            0\n                                        ) {\n                                            q = 1509;\n                                            break;\n                                        }\n                                        if (\n                                            (aV(c[f >> 2] | 0, 6344) | 0) !=\n                                            0\n                                        ) {\n                                            if (\n                                                (aV(c[f >> 2] | 0, 6280) | 0) !=\n                                                0\n                                            ) {\n                                                do {\n                                                    if (\n                                                        (aV(\n                                                            c[f >> 2] | 0,\n                                                            6176\n                                                        ) |\n                                                            0) !=\n                                                        0\n                                                    ) {\n                                                        if (\n                                                            (aV(\n                                                                c[f >> 2] | 0,\n                                                                6136\n                                                            ) |\n                                                                0) ==\n                                                            0\n                                                        ) {\n                                                            q = 1516;\n                                                            break;\n                                                        }\n                                                        if (\n                                                            (aV(\n                                                                c[f >> 2] | 0,\n                                                                6072\n                                                            ) |\n                                                                0) !=\n                                                            0\n                                                        ) {\n                                                            if (\n                                                                (aV(\n                                                                    c[f >> 2] |\n                                                                        0,\n                                                                    6008\n                                                                ) |\n                                                                    0) !=\n                                                                0\n                                                            ) {\n                                                                if (\n                                                                    (aV(\n                                                                        c[\n                                                                            f >>\n                                                                                2\n                                                                        ] | 0,\n                                                                        5952\n                                                                    ) |\n                                                                        0) !=\n                                                                    0\n                                                                ) {\n                                                                    if (\n                                                                        (aV(\n                                                                            c[\n                                                                                f >>\n                                                                                    2\n                                                                            ] |\n                                                                                0,\n                                                                            5880\n                                                                        ) |\n                                                                            0) !=\n                                                                        0\n                                                                    ) {\n                                                                        if (\n                                                                            (aV(\n                                                                                c[\n                                                                                    f >>\n                                                                                        2\n                                                                                ] |\n                                                                                    0,\n                                                                                5784\n                                                                            ) |\n                                                                                0) !=\n                                                                            0\n                                                                        ) {\n                                                                            if (\n                                                                                (aV(\n                                                                                    c[\n                                                                                        f >>\n                                                                                            2\n                                                                                    ] |\n                                                                                        0,\n                                                                                    5720\n                                                                                ) |\n                                                                                    0) !=\n                                                                                0\n                                                                            ) {\n                                                                                if (\n                                                                                    (aV(\n                                                                                        c[\n                                                                                            f >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0,\n                                                                                        5616\n                                                                                    ) |\n                                                                                        0) !=\n                                                                                    0\n                                                                                ) {\n                                                                                    if (\n                                                                                        (p |\n                                                                                            0) <\n                                                                                        2\n                                                                                    ) {\n                                                                                        q = 1562;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (a[\n                                                                                            c[\n                                                                                                f >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0\n                                                                                        ] |\n                                                                                            0) <\n                                                                                        48\n                                                                                    ) {\n                                                                                        q = 1562;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (a[\n                                                                                            c[\n                                                                                                f >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0\n                                                                                        ] |\n                                                                                            0) >\n                                                                                        57\n                                                                                    ) {\n                                                                                        q = 1562;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    s =\n                                                                                        aL(\n                                                                                            c[\n                                                                                                f >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0\n                                                                                        ) |\n                                                                                        0;\n                                                                                    if (\n                                                                                        (s |\n                                                                                            0) <\n                                                                                        0\n                                                                                    ) {\n                                                                                        q = 1565;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (s |\n                                                                                            0) >\n                                                                                        127\n                                                                                    ) {\n                                                                                        q = 1565;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (b |\n                                                                                            0) ==\n                                                                                        0\n                                                                                    ) {\n                                                                                        q = 1567;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (c[\n                                                                                            ((c[\n                                                                                                b >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0) +\n                                                                                                ((s *\n                                                                                                    28) |\n                                                                                                    0)) >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) !=\n                                                                                        0\n                                                                                    ) {\n                                                                                        c0(\n                                                                                            c[\n                                                                                                ((c[\n                                                                                                    b >>\n                                                                                                        2\n                                                                                                ] |\n                                                                                                    0) +\n                                                                                                    ((s *\n                                                                                                        28) |\n                                                                                                        0)) >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0\n                                                                                        );\n                                                                                    }\n                                                                                    j =\n                                                                                        bi(\n                                                                                            ((c1(\n                                                                                                c[\n                                                                                                    (f +\n                                                                                                        4) >>\n                                                                                                        2\n                                                                                                ] |\n                                                                                                    0\n                                                                                            ) |\n                                                                                                0) +\n                                                                                                1) |\n                                                                                                0\n                                                                                        ) |\n                                                                                        0;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0)) >>\n                                                                                            2\n                                                                                    ] = j;\n                                                                                    t =\n                                                                                        c[\n                                                                                            (f +\n                                                                                                4) >>\n                                                                                                2\n                                                                                        ] |\n                                                                                        0;\n                                                                                    c2(\n                                                                                        j |\n                                                                                            0,\n                                                                                        t |\n                                                                                            0\n                                                                                    ) |\n                                                                                        0;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0) +\n                                                                                            24) >>\n                                                                                            2\n                                                                                    ] = -1;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0) +\n                                                                                            20) >>\n                                                                                            2\n                                                                                    ] = -1;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0) +\n                                                                                            16) >>\n                                                                                            2\n                                                                                    ] = -1;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0) +\n                                                                                            12) >>\n                                                                                            2\n                                                                                    ] = -1;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0) +\n                                                                                            8) >>\n                                                                                            2\n                                                                                    ] = -1;\n                                                                                    c[\n                                                                                        ((c[\n                                                                                            b >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) +\n                                                                                            ((s *\n                                                                                                28) |\n                                                                                                0) +\n                                                                                            4) >>\n                                                                                            2\n                                                                                    ] = -1;\n                                                                                    u = 2;\n                                                                                    while (\n                                                                                        1\n                                                                                    ) {\n                                                                                        if (\n                                                                                            (u |\n                                                                                                0) >=\n                                                                                            (p |\n                                                                                                0)\n                                                                                        ) {\n                                                                                            break;\n                                                                                        }\n                                                                                        t =\n                                                                                            aH(\n                                                                                                c[\n                                                                                                    (f +\n                                                                                                        (u <<\n                                                                                                            2)) >>\n                                                                                                        2\n                                                                                                ] |\n                                                                                                    0,\n                                                                                                61\n                                                                                            ) |\n                                                                                            0;\n                                                                                        j = t;\n                                                                                        if (\n                                                                                            (t |\n                                                                                                0) ==\n                                                                                            0\n                                                                                        ) {\n                                                                                            q = 1573;\n                                                                                            break L1881;\n                                                                                        }\n                                                                                        t = j;\n                                                                                        j =\n                                                                                            (t +\n                                                                                                1) |\n                                                                                            0;\n                                                                                        a[\n                                                                                            t\n                                                                                        ] = 0;\n                                                                                        if (\n                                                                                            (aV(\n                                                                                                c[\n                                                                                                    (f +\n                                                                                                        (u <<\n                                                                                                            2)) >>\n                                                                                                        2\n                                                                                                ] |\n                                                                                                    0,\n                                                                                                5272\n                                                                                            ) |\n                                                                                                0) !=\n                                                                                            0\n                                                                                        ) {\n                                                                                            if (\n                                                                                                (aV(\n                                                                                                    c[\n                                                                                                        (f +\n                                                                                                            (u <<\n                                                                                                                2)) >>\n                                                                                                            2\n                                                                                                    ] |\n                                                                                                        0,\n                                                                                                    5208\n                                                                                                ) |\n                                                                                                    0) !=\n                                                                                                0\n                                                                                            ) {\n                                                                                                if (\n                                                                                                    (aV(\n                                                                                                        c[\n                                                                                                            (f +\n                                                                                                                (u <<\n                                                                                                                    2)) >>\n                                                                                                                2\n                                                                                                        ] |\n                                                                                                            0,\n                                                                                                        5152\n                                                                                                    ) |\n                                                                                                        0) !=\n                                                                                                    0\n                                                                                                ) {\n                                                                                                    if (\n                                                                                                        (aV(\n                                                                                                            c[\n                                                                                                                (f +\n                                                                                                                    (u <<\n                                                                                                                        2)) >>\n                                                                                                                    2\n                                                                                                            ] |\n                                                                                                                0,\n                                                                                                            5008\n                                                                                                        ) |\n                                                                                                            0) !=\n                                                                                                        0\n                                                                                                    ) {\n                                                                                                        if (\n                                                                                                            (aV(\n                                                                                                                c[\n                                                                                                                    (f +\n                                                                                                                        (u <<\n                                                                                                                            2)) >>\n                                                                                                                        2\n                                                                                                                ] |\n                                                                                                                    0,\n                                                                                                                4944\n                                                                                                            ) |\n                                                                                                                0) !=\n                                                                                                            0\n                                                                                                        ) {\n                                                                                                            q = 1625;\n                                                                                                            break L1881;\n                                                                                                        }\n                                                                                                        if (\n                                                                                                            (aV(\n                                                                                                                j |\n                                                                                                                    0,\n                                                                                                                5e3\n                                                                                                            ) |\n                                                                                                                0) !=\n                                                                                                            0\n                                                                                                        ) {\n                                                                                                            if (\n                                                                                                                (aV(\n                                                                                                                    j |\n                                                                                                                        0,\n                                                                                                                    4992\n                                                                                                                ) |\n                                                                                                                    0) !=\n                                                                                                                0\n                                                                                                            ) {\n                                                                                                                if (\n                                                                                                                    (aV(\n                                                                                                                        j |\n                                                                                                                            0,\n                                                                                                                        4936\n                                                                                                                    ) |\n                                                                                                                        0) !=\n                                                                                                                    0\n                                                                                                                ) {\n                                                                                                                    q = 1621;\n                                                                                                                    break L1881;\n                                                                                                                }\n                                                                                                                c[\n                                                                                                                    ((c[\n                                                                                                                        b >>\n                                                                                                                            2\n                                                                                                                    ] |\n                                                                                                                        0) +\n                                                                                                                        ((s *\n                                                                                                                            28) |\n                                                                                                                            0) +\n                                                                                                                        24) >>\n                                                                                                                        2\n                                                                                                                ] = 1;\n                                                                                                            } else {\n                                                                                                                c[\n                                                                                                                    ((c[\n                                                                                                                        b >>\n                                                                                                                            2\n                                                                                                                    ] |\n                                                                                                                        0) +\n                                                                                                                        ((s *\n                                                                                                                            28) |\n                                                                                                                            0) +\n                                                                                                                        16) >>\n                                                                                                                        2\n                                                                                                                ] = 1;\n                                                                                                            }\n                                                                                                        } else {\n                                                                                                            c[\n                                                                                                                ((c[\n                                                                                                                    b >>\n                                                                                                                        2\n                                                                                                                ] |\n                                                                                                                    0) +\n                                                                                                                    ((s *\n                                                                                                                        28) |\n                                                                                                                        0) +\n                                                                                                                    20) >>\n                                                                                                                    2\n                                                                                                            ] = 1;\n                                                                                                        }\n                                                                                                    } else {\n                                                                                                        if (\n                                                                                                            (aV(\n                                                                                                                j |\n                                                                                                                    0,\n                                                                                                                5e3\n                                                                                                            ) |\n                                                                                                                0) !=\n                                                                                                            0\n                                                                                                        ) {\n                                                                                                            if (\n                                                                                                                (aV(\n                                                                                                                    j |\n                                                                                                                        0,\n                                                                                                                    4992\n                                                                                                                ) |\n                                                                                                                    0) !=\n                                                                                                                0\n                                                                                                            ) {\n                                                                                                                q = 1611;\n                                                                                                                break L1881;\n                                                                                                            }\n                                                                                                            c[\n                                                                                                                ((c[\n                                                                                                                    b >>\n                                                                                                                        2\n                                                                                                                ] |\n                                                                                                                    0) +\n                                                                                                                    ((s *\n                                                                                                                        28) |\n                                                                                                                        0) +\n                                                                                                                    16) >>\n                                                                                                                    2\n                                                                                                            ] = 0;\n                                                                                                        } else {\n                                                                                                            c[\n                                                                                                                ((c[\n                                                                                                                    b >>\n                                                                                                                        2\n                                                                                                                ] |\n                                                                                                                    0) +\n                                                                                                                    ((s *\n                                                                                                                        28) |\n                                                                                                                        0) +\n                                                                                                                    20) >>\n                                                                                                                    2\n                                                                                                            ] = 0;\n                                                                                                        }\n                                                                                                    }\n                                                                                                } else {\n                                                                                                    if (\n                                                                                                        (aV(\n                                                                                                            j |\n                                                                                                                0,\n                                                                                                            5144\n                                                                                                        ) |\n                                                                                                            0) !=\n                                                                                                        0\n                                                                                                    ) {\n                                                                                                        if (\n                                                                                                            (aV(\n                                                                                                                j |\n                                                                                                                    0,\n                                                                                                                5112\n                                                                                                            ) |\n                                                                                                                0) !=\n                                                                                                            0\n                                                                                                        ) {\n                                                                                                            if (\n                                                                                                                (aV(\n                                                                                                                    j |\n                                                                                                                        0,\n                                                                                                                    5104\n                                                                                                                ) |\n                                                                                                                    0) !=\n                                                                                                                0\n                                                                                                            ) {\n                                                                                                                v =\n                                                                                                                    ((((((aL(\n                                                                                                                        j |\n                                                                                                                            0\n                                                                                                                    ) |\n                                                                                                                        0) +\n                                                                                                                        100) |\n                                                                                                                        0) *\n                                                                                                                        100) |\n                                                                                                                        0 |\n                                                                                                                        0) /\n                                                                                                                        157) |\n                                                                                                                    0;\n                                                                                                            } else {\n                                                                                                                v = 127;\n                                                                                                            }\n                                                                                                        } else {\n                                                                                                            v = 0;\n                                                                                                        }\n                                                                                                    } else {\n                                                                                                        v = 64;\n                                                                                                    }\n                                                                                                    if (\n                                                                                                        (v |\n                                                                                                            0) <\n                                                                                                        0\n                                                                                                    ) {\n                                                                                                        q = 1604;\n                                                                                                        break L1881;\n                                                                                                    }\n                                                                                                    if (\n                                                                                                        (v |\n                                                                                                            0) >\n                                                                                                        127\n                                                                                                    ) {\n                                                                                                        q = 1604;\n                                                                                                        break L1881;\n                                                                                                    }\n                                                                                                    do {\n                                                                                                        if (\n                                                                                                            (v |\n                                                                                                                0) ==\n                                                                                                            0\n                                                                                                        ) {\n                                                                                                            if (\n                                                                                                                (a[\n                                                                                                                    j\n                                                                                                                ] |\n                                                                                                                    0) ==\n                                                                                                                45\n                                                                                                            ) {\n                                                                                                                break;\n                                                                                                            }\n                                                                                                            if (\n                                                                                                                (a[\n                                                                                                                    j\n                                                                                                                ] |\n                                                                                                                    0) <\n                                                                                                                48\n                                                                                                            ) {\n                                                                                                                q = 1604;\n                                                                                                                break L1881;\n                                                                                                            }\n                                                                                                            if (\n                                                                                                                (a[\n                                                                                                                    j\n                                                                                                                ] |\n                                                                                                                    0) >\n                                                                                                                57\n                                                                                                            ) {\n                                                                                                                q = 1604;\n                                                                                                                break L1881;\n                                                                                                            }\n                                                                                                        }\n                                                                                                    } while (\n                                                                                                        0\n                                                                                                    );\n                                                                                                    c[\n                                                                                                        ((c[\n                                                                                                            b >>\n                                                                                                                2\n                                                                                                        ] |\n                                                                                                            0) +\n                                                                                                            ((s *\n                                                                                                                28) |\n                                                                                                                0) +\n                                                                                                            12) >>\n                                                                                                            2\n                                                                                                    ] = v;\n                                                                                                }\n                                                                                            } else {\n                                                                                                v =\n                                                                                                    aL(\n                                                                                                        j |\n                                                                                                            0\n                                                                                                    ) |\n                                                                                                    0;\n                                                                                                if (\n                                                                                                    (v |\n                                                                                                        0) <\n                                                                                                    0\n                                                                                                ) {\n                                                                                                    q = 1586;\n                                                                                                    break L1881;\n                                                                                                }\n                                                                                                if (\n                                                                                                    (v |\n                                                                                                        0) >\n                                                                                                    127\n                                                                                                ) {\n                                                                                                    q = 1586;\n                                                                                                    break L1881;\n                                                                                                }\n                                                                                                if (\n                                                                                                    (a[\n                                                                                                        j\n                                                                                                    ] |\n                                                                                                        0) <\n                                                                                                    48\n                                                                                                ) {\n                                                                                                    q = 1586;\n                                                                                                    break L1881;\n                                                                                                }\n                                                                                                if (\n                                                                                                    (a[\n                                                                                                        j\n                                                                                                    ] |\n                                                                                                        0) >\n                                                                                                    57\n                                                                                                ) {\n                                                                                                    q = 1586;\n                                                                                                    break L1881;\n                                                                                                }\n                                                                                                c[\n                                                                                                    ((c[\n                                                                                                        b >>\n                                                                                                            2\n                                                                                                    ] |\n                                                                                                        0) +\n                                                                                                        ((s *\n                                                                                                            28) |\n                                                                                                            0) +\n                                                                                                        4) >>\n                                                                                                        2\n                                                                                                ] = v;\n                                                                                            }\n                                                                                        } else {\n                                                                                            v =\n                                                                                                aL(\n                                                                                                    j |\n                                                                                                        0\n                                                                                                ) |\n                                                                                                0;\n                                                                                            if (\n                                                                                                (v |\n                                                                                                    0) <\n                                                                                                0\n                                                                                            ) {\n                                                                                                q = 1579;\n                                                                                                break L1881;\n                                                                                            }\n                                                                                            if (\n                                                                                                (v |\n                                                                                                    0) >\n                                                                                                800\n                                                                                            ) {\n                                                                                                q = 1579;\n                                                                                                break L1881;\n                                                                                            }\n                                                                                            if (\n                                                                                                (a[\n                                                                                                    j\n                                                                                                ] |\n                                                                                                    0) <\n                                                                                                48\n                                                                                            ) {\n                                                                                                q = 1579;\n                                                                                                break L1881;\n                                                                                            }\n                                                                                            if (\n                                                                                                (a[\n                                                                                                    j\n                                                                                                ] |\n                                                                                                    0) >\n                                                                                                57\n                                                                                            ) {\n                                                                                                q = 1579;\n                                                                                                break L1881;\n                                                                                            }\n                                                                                            c[\n                                                                                                ((c[\n                                                                                                    b >>\n                                                                                                        2\n                                                                                                ] |\n                                                                                                    0) +\n                                                                                                    ((s *\n                                                                                                        28) |\n                                                                                                        0) +\n                                                                                                    8) >>\n                                                                                                    2\n                                                                                            ] = v;\n                                                                                        }\n                                                                                        u =\n                                                                                            (u +\n                                                                                                1) |\n                                                                                            0;\n                                                                                    }\n                                                                                } else {\n                                                                                    if (\n                                                                                        (p |\n                                                                                            0) <\n                                                                                        2\n                                                                                    ) {\n                                                                                        q = 1552;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    s =\n                                                                                        aL(\n                                                                                            c[\n                                                                                                (f +\n                                                                                                    4) >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0\n                                                                                        ) |\n                                                                                        0;\n                                                                                    if (\n                                                                                        (s |\n                                                                                            0) <\n                                                                                        0\n                                                                                    ) {\n                                                                                        q = 1555;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (s |\n                                                                                            0) >\n                                                                                        127\n                                                                                    ) {\n                                                                                        q = 1555;\n                                                                                        break L1881;\n                                                                                    }\n                                                                                    if (\n                                                                                        (c[\n                                                                                            (6704 +\n                                                                                                (s <<\n                                                                                                    2)) >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0) ==\n                                                                                        0\n                                                                                    ) {\n                                                                                        c[\n                                                                                            (6704 +\n                                                                                                (s <<\n                                                                                                    2)) >>\n                                                                                                2\n                                                                                        ] =\n                                                                                            bi(\n                                                                                                516\n                                                                                            ) |\n                                                                                            0;\n                                                                                        c5(\n                                                                                            c[\n                                                                                                (6704 +\n                                                                                                    (s <<\n                                                                                                        2)) >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0,\n                                                                                            0,\n                                                                                            516\n                                                                                        );\n                                                                                        t =\n                                                                                            bi(\n                                                                                                3584\n                                                                                            ) |\n                                                                                            0;\n                                                                                        c[\n                                                                                            c[\n                                                                                                (6704 +\n                                                                                                    (s <<\n                                                                                                        2)) >>\n                                                                                                    2\n                                                                                            ] >>\n                                                                                                2\n                                                                                        ] = t;\n                                                                                        c5(\n                                                                                            c[\n                                                                                                c[\n                                                                                                    (6704 +\n                                                                                                        (s <<\n                                                                                                            2)) >>\n                                                                                                        2\n                                                                                                ] >>\n                                                                                                    2\n                                                                                            ] |\n                                                                                                0,\n                                                                                            0,\n                                                                                            3584\n                                                                                        );\n                                                                                    }\n                                                                                    b =\n                                                                                        c[\n                                                                                            (6704 +\n                                                                                                (s <<\n                                                                                                    2)) >>\n                                                                                                2\n                                                                                        ] |\n                                                                                        0;\n                                                                                }\n                                                                            } else {\n                                                                                if (\n                                                                                    (p |\n                                                                                        0) <\n                                                                                    2\n                                                                                ) {\n                                                                                    q = 1543;\n                                                                                    break L1881;\n                                                                                }\n                                                                                s =\n                                                                                    aL(\n                                                                                        c[\n                                                                                            (f +\n                                                                                                4) >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0\n                                                                                    ) |\n                                                                                    0;\n                                                                                if (\n                                                                                    (s |\n                                                                                        0) <\n                                                                                    0\n                                                                                ) {\n                                                                                    q = 1546;\n                                                                                    break L1881;\n                                                                                }\n                                                                                if (\n                                                                                    (s |\n                                                                                        0) >\n                                                                                    127\n                                                                                ) {\n                                                                                    q = 1546;\n                                                                                    break L1881;\n                                                                                }\n                                                                                if (\n                                                                                    (c[\n                                                                                        (7216 +\n                                                                                            (s <<\n                                                                                                2)) >>\n                                                                                            2\n                                                                                    ] |\n                                                                                        0) ==\n                                                                                    0\n                                                                                ) {\n                                                                                    c[\n                                                                                        (7216 +\n                                                                                            (s <<\n                                                                                                2)) >>\n                                                                                            2\n                                                                                    ] =\n                                                                                        bi(\n                                                                                            516\n                                                                                        ) |\n                                                                                        0;\n                                                                                    c5(\n                                                                                        c[\n                                                                                            (7216 +\n                                                                                                (s <<\n                                                                                                    2)) >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0,\n                                                                                        0,\n                                                                                        516\n                                                                                    );\n                                                                                    t =\n                                                                                        bi(\n                                                                                            3584\n                                                                                        ) |\n                                                                                        0;\n                                                                                    c[\n                                                                                        c[\n                                                                                            (7216 +\n                                                                                                (s <<\n                                                                                                    2)) >>\n                                                                                                2\n                                                                                        ] >>\n                                                                                            2\n                                                                                    ] = t;\n                                                                                    c5(\n                                                                                        c[\n                                                                                            c[\n                                                                                                (7216 +\n                                                                                                    (s <<\n                                                                                                        2)) >>\n                                                                                                    2\n                                                                                            ] >>\n                                                                                                2\n                                                                                        ] |\n                                                                                            0,\n                                                                                        0,\n                                                                                        3584\n                                                                                    );\n                                                                                }\n                                                                                b =\n                                                                                    c[\n                                                                                        (7216 +\n                                                                                            (s <<\n                                                                                                2)) >>\n                                                                                            2\n                                                                                    ] |\n                                                                                    0;\n                                                                            }\n                                                                        } else {\n                                                                            if (\n                                                                                (p |\n                                                                                    0) !=\n                                                                                2\n                                                                            ) {\n                                                                                q = 1539;\n                                                                                break L1881;\n                                                                            }\n                                                                            t =\n                                                                                c[\n                                                                                    (f +\n                                                                                        4) >>\n                                                                                        2\n                                                                                ] |\n                                                                                0;\n                                                                            c7(\n                                                                                7728,\n                                                                                t |\n                                                                                    0,\n                                                                                255\n                                                                            ) |\n                                                                                0;\n                                                                            a[7983] = 0;\n                                                                        }\n                                                                    } else {\n                                                                        if (\n                                                                            (p |\n                                                                                0) <\n                                                                            2\n                                                                        ) {\n                                                                            q = 1531;\n                                                                            break L1881;\n                                                                        }\n                                                                        s = 1;\n                                                                        while (\n                                                                            1\n                                                                        ) {\n                                                                            if (\n                                                                                (s |\n                                                                                    0) >=\n                                                                                (p |\n                                                                                    0)\n                                                                            ) {\n                                                                                break;\n                                                                            }\n                                                                            c[1660] =\n                                                                                (c[1660] |\n                                                                                    0) +\n                                                                                1;\n                                                                            cU(\n                                                                                c[\n                                                                                    (f +\n                                                                                        (s <<\n                                                                                            2)) >>\n                                                                                        2\n                                                                                ] |\n                                                                                    0\n                                                                            ) |\n                                                                                0;\n                                                                            c[1660] =\n                                                                                (c[1660] |\n                                                                                    0) -\n                                                                                1;\n                                                                            s =\n                                                                                (s +\n                                                                                    1) |\n                                                                                0;\n                                                                        }\n                                                                    }\n                                                                } else {\n                                                                    if (\n                                                                        (p |\n                                                                            0) <\n                                                                        2\n                                                                    ) {\n                                                                        q = 1523;\n                                                                        break L1881;\n                                                                    }\n                                                                    s = 1;\n                                                                    while (1) {\n                                                                        if (\n                                                                            (s |\n                                                                                0) >=\n                                                                            (p |\n                                                                                0)\n                                                                        ) {\n                                                                            break;\n                                                                        }\n                                                                        bj(\n                                                                            c[\n                                                                                (f +\n                                                                                    (s <<\n                                                                                        2)) >>\n                                                                                    2\n                                                                            ] |\n                                                                                0\n                                                                        );\n                                                                        s =\n                                                                            (s +\n                                                                                1) |\n                                                                            0;\n                                                                    }\n                                                                }\n                                                            } else {\n                                                                t =\n                                                                    c[m >> 2] |\n                                                                    0;\n                                                                ar(\n                                                                    t | 0,\n                                                                    5960,\n                                                                    ((k = i),\n                                                                    (i =\n                                                                        (i +\n                                                                            1) |\n                                                                        0),\n                                                                    (i =\n                                                                        (i +\n                                                                            7) &\n                                                                        -8),\n                                                                    (c[\n                                                                        k >> 2\n                                                                    ] = 0),\n                                                                    k) | 0\n                                                                ) | 0;\n                                                                i = k;\n                                                            }\n                                                        } else {\n                                                            t = c[m >> 2] | 0;\n                                                            ar(\n                                                                t | 0,\n                                                                6016,\n                                                                ((k = i),\n                                                                (i =\n                                                                    (i + 1) |\n                                                                    0),\n                                                                (i =\n                                                                    (i + 7) &\n                                                                    -8),\n                                                                (c[k >> 2] = 0),\n                                                                k) | 0\n                                                            ) | 0;\n                                                            i = k;\n                                                        }\n                                                    } else {\n                                                        q = 1516;\n                                                    }\n                                                } while (0);\n                                                if ((q | 0) == 1516) {\n                                                    q = 0;\n                                                    t = c[m >> 2] | 0;\n                                                    w = c[f >> 2] | 0;\n                                                    ar(\n                                                        t | 0,\n                                                        6088,\n                                                        ((k = i),\n                                                        (i = (i + 8) | 0),\n                                                        (c[k >> 2] = w),\n                                                        k) | 0\n                                                    ) | 0;\n                                                    i = k;\n                                                }\n                                            } else {\n                                                w = c[m >> 2] | 0;\n                                                ar(\n                                                    w | 0,\n                                                    6192,\n                                                    ((k = i),\n                                                    (i = (i + 1) | 0),\n                                                    (i = (i + 7) & -8),\n                                                    (c[k >> 2] = 0),\n                                                    k) | 0\n                                                ) | 0;\n                                                i = k;\n                                            }\n                                        } else {\n                                            w = c[m >> 2] | 0;\n                                            ar(\n                                                w | 0,\n                                                6296,\n                                                ((k = i),\n                                                (i = (i + 1) | 0),\n                                                (i = (i + 7) & -8),\n                                                (c[k >> 2] = 0),\n                                                k) | 0\n                                            ) | 0;\n                                            i = k;\n                                        }\n                                    } else {\n                                        q = 1509;\n                                    }\n                                } while (0);\n                                if ((q | 0) == 1509) {\n                                    q = 0;\n                                    w = c[m >> 2] | 0;\n                                    t = c[f >> 2] | 0;\n                                    ar(\n                                        w | 0,\n                                        6352,\n                                        ((k = i),\n                                        (i = (i + 8) | 0),\n                                        (c[k >> 2] = t),\n                                        k) | 0\n                                    ) | 0;\n                                    i = k;\n                                }\n                            } else {\n                                t = c[m >> 2] | 0;\n                                ar(\n                                    t | 0,\n                                    6432,\n                                    ((k = i),\n                                    (i = (i + 1) | 0),\n                                    (i = (i + 7) & -8),\n                                    (c[k >> 2] = 0),\n                                    k) | 0\n                                ) | 0;\n                                i = k;\n                            }\n                        } else {\n                            q = 1504;\n                        }\n                    } while (0);\n                    if ((q | 0) == 1504) {\n                        q = 0;\n                    }\n                }\n                if ((q | 0) == 1523) {\n                    s = c[m >> 2] | 0;\n                    b = g;\n                    v = h;\n                    ar(\n                        s | 0,\n                        5912,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = b),\n                        (c[(k + 8) >> 2] = v),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1555) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5520,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1562) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5480,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1565) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5432,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1567) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5320,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1539) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5728,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1531) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5840,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1552) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5576,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1579) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5216,\n                        ((k = i),\n                        (i = (i + 24) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        (c[(k + 16) >> 2] = 800),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1586) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5160,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1611) {\n                    ar(\n                        c[m >> 2] | 0,\n                        4952,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1621) {\n                    ar(\n                        c[m >> 2] | 0,\n                        4888,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1625) {\n                    v = c[(f + (u << 2)) >> 2] | 0;\n                    ar(\n                        c[m >> 2] | 0,\n                        5280,\n                        ((k = i),\n                        (i = (i + 24) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        (c[(k + 16) >> 2] = v),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1546) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5624,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1543) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5680,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1604) {\n                    ar(\n                        c[m >> 2] | 0,\n                        5016,\n                        ((k = i),\n                        (i = (i + 16) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1573) {\n                    v = c[(f + (u << 2)) >> 2] | 0;\n                    ar(\n                        c[m >> 2] | 0,\n                        5280,\n                        ((k = i),\n                        (i = (i + 24) | 0),\n                        (c[k >> 2] = g),\n                        (c[(k + 8) >> 2] = h),\n                        (c[(k + 16) >> 2] = v),\n                        k) | 0\n                    ) | 0;\n                    i = k;\n                    l = -2;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                } else if ((q | 0) == 1646) {\n                    ao(o | 0) | 0;\n                    l = 0;\n                    n = l;\n                    i = d;\n                    return n | 0;\n                }\n                return 0;\n            }\n            function cV(d, e, f, g) {\n                d = d | 0;\n                e = e | 0;\n                f = f | 0;\n                g = g | 0;\n                c[1672] = d;\n                b[3346] = e;\n                a[6694] = f;\n                b[3348] = g;\n                return 6688;\n            }\n            function cW(f, g, h) {\n                f = f | 0;\n                g = g | 0;\n                h = h | 0;\n                let j = 0,\n                    k = 0,\n                    l = 0,\n                    n = 0;\n                j = i;\n                k = f;\n                f = h;\n                if ((k | 0) == 0) {\n                    l = 0;\n                    n = l;\n                    i = j;\n                    return n | 0;\n                }\n                h = bi(14164) | 0;\n                c5(h | 0, 0, 14164);\n                c[(h + 24) >> 2] = g;\n                g = 0;\n                while (1) {\n                    if ((g | 0) >= 128) {\n                        break;\n                    }\n                    if ((c[(6704 + (g << 2)) >> 2] | 0) != 0) {\n                        c[(h + 28 + (g << 2)) >> 2] = bi(516) | 0;\n                        c5(c[(h + 28 + (g << 2)) >> 2] | 0, 0, 516);\n                        c[c[(h + 28 + (g << 2)) >> 2] >> 2] =\n                            c[c[(6704 + (g << 2)) >> 2] >> 2];\n                    }\n                    if ((c[(7216 + (g << 2)) >> 2] | 0) != 0) {\n                        c[(h + 540 + (g << 2)) >> 2] = bi(516) | 0;\n                        c5(c[(h + 540 + (g << 2)) >> 2] | 0, 0, 516);\n                        c[c[(h + 540 + (g << 2)) >> 2] >> 2] =\n                            c[c[(7216 + (g << 2)) >> 2] >> 2];\n                    }\n                    g = (g + 1) | 0;\n                }\n                c[(h + 20) >> 2] = 70;\n                c[(h + 13052) >> 2] = 32;\n                c[(h + 13056) >> 2] = 33280;\n                c[(h + 4) >> 2] = c[f >> 2];\n                c[(h + 8) >> 2] = 0;\n                if (((b[(f + 4) >> 1] & 255) | 0) == 16) {\n                    g = (h + 8) | 0;\n                    c[g >> 2] = c[g >> 2] | 4;\n                }\n                if (((b[(f + 4) >> 1] & 32768) | 0) != 0) {\n                    g = (h + 8) | 0;\n                    c[g >> 2] = c[g >> 2] | 2;\n                }\n                if ((d[(f + 6) | 0] | 0) == 1) {\n                    g = (h + 8) | 0;\n                    c[g >> 2] = c[g >> 2] | 1;\n                }\n                g = e[(f + 4) >> 1] | 0;\n                if ((g | 0) == 36880) {\n                    c[(h + 1060) >> 2] = 4;\n                } else if ((g | 0) == 16) {\n                    c[(h + 1060) >> 2] = 6;\n                } else if ((g | 0) == 32776) {\n                    c[(h + 1060) >> 2] = 10;\n                } else if ((g | 0) == 8) {\n                    c[(h + 1060) >> 2] = 8;\n                } else if ((g | 0) == 32784) {\n                    c[(h + 1060) >> 2] = 2;\n                } else {\n                    ar(\n                        c[m >> 2] | 0,\n                        6144,\n                        ((g = i),\n                        (i = (i + 1) | 0),\n                        (i = (i + 7) & -8),\n                        (c[g >> 2] = 0),\n                        g) | 0\n                    ) | 0;\n                    i = g;\n                    c[(h + 1060) >> 2] = 6;\n                }\n                c[(h + 1064) >> 2] = e[(f + 8) >> 1] | 0;\n                c[(h + 1068) >> 2] = bi(e[(f + 8) >> 1] << 1) | 0;\n                c[(h + 1072) >> 2] = bi((e[(f + 8) >> 1] << 1) << 2) | 0;\n                c[(h + 12) >> 2] =\n                    _(\n                        ((c[(h + 8) >> 2] & 1) | 0) != 0 ? 1 : 2,\n                        ((c[(h + 8) >> 2] & 4) | 0) != 0 ? 2 : 1\n                    ) | 0;\n                c[(h + 13060) >> 2] = ((c[f >> 2] | 0) / 1e3) | 0;\n                if ((c[(h + 13060) >> 2] | 0) < 1) {\n                    c[(h + 13060) >> 2] = 1;\n                } else {\n                    if ((c[(h + 13060) >> 2] | 0) > 255) {\n                        c[(h + 13060) >> 2] = 255;\n                    }\n                }\n                c[(h + 13064) >> 2] = 0;\n                c[(h + 13068) >> 2] = 0;\n                c[(h + 13076) >> 2] =\n                    cq(k, h, (h + 13100) | 0, (h + 13072) | 0) | 0;\n                if ((c[(h + 13076) >> 2] | 0) == 0) {\n                    c0(h);\n                    l = 0;\n                    n = l;\n                    i = j;\n                    return n | 0;\n                }\n                c[(h + 1052) >> 2] = 0;\n                c[(h + 1056) >> 2] = 0;\n                if ((a[7728] | 0) != 0) {\n                    k = h;\n                    bz(k, 7728) | 0;\n                }\n                bv(h) | 0;\n                l = h;\n                n = l;\n                i = j;\n                return n | 0;\n            }\n            // mid_song_load\n            function cX(a, b) {\n                a = a | 0;\n                b = b | 0;\n                return cW(a, 0, b) | 0;\n            }\n            // mid_song_free\n            function cY(a) {\n                a = a | 0;\n                let b = 0;\n                b = a;\n                bx(b);\n                a = 0;\n                while (1) {\n                    if ((a | 0) >= 128) {\n                        break;\n                    }\n                    if ((c[(b + 28 + (a << 2)) >> 2] | 0) != 0) {\n                        c0(c[(b + 28 + (a << 2)) >> 2] | 0);\n                    }\n                    if ((c[(b + 540 + (a << 2)) >> 2] | 0) != 0) {\n                        c0(c[(b + 540 + (a << 2)) >> 2] | 0);\n                    }\n                    a = (a + 1) | 0;\n                }\n                c0(c[(b + 1072) >> 2] | 0);\n                c0(c[(b + 1068) >> 2] | 0);\n                c0(c[(b + 13076) >> 2] | 0);\n                a = 0;\n                while (1) {\n                    if (a >>> 0 >= 8) {\n                        break;\n                    }\n                    if ((c[(b + 13104 + (a << 2)) >> 2] | 0) != 0) {\n                        c0(c[(b + 13104 + (a << 2)) >> 2] | 0);\n                    }\n                    a = (a + 1) | 0;\n                }\n                c0(b);\n                return;\n            }\n            // mid_exit\n            function cZ() {\n                let a = 0,\n                    b = 0,\n                    d = 0,\n                    e = 0;\n                a = 0;\n                while (1) {\n                    if ((a | 0) >= 128) {\n                        break;\n                    }\n                    if ((c[(6704 + (a << 2)) >> 2] | 0) != 0) {\n                        b = c[c[(6704 + (a << 2)) >> 2] >> 2] | 0;\n                        if ((b | 0) != 0) {\n                            d = 0;\n                            while (1) {\n                                if ((d | 0) >= 128) {\n                                    break;\n                                }\n                                if ((c[(b + ((d * 28) | 0)) >> 2] | 0) != 0) {\n                                    c0(c[(b + ((d * 28) | 0)) >> 2] | 0);\n                                }\n                                d = (d + 1) | 0;\n                            }\n                            c0(b);\n                        }\n                        c0(c[(6704 + (a << 2)) >> 2] | 0);\n                    }\n                    if ((c[(7216 + (a << 2)) >> 2] | 0) != 0) {\n                        e = c[c[(7216 + (a << 2)) >> 2] >> 2] | 0;\n                        if ((e | 0) != 0) {\n                            d = 0;\n                            while (1) {\n                                if ((d | 0) >= 128) {\n                                    break;\n                                }\n                                if ((c[(e + ((d * 28) | 0)) >> 2] | 0) != 0) {\n                                    c0(c[(e + ((d * 28) | 0)) >> 2] | 0);\n                                }\n                                d = (d + 1) | 0;\n                            }\n                            c0(e);\n                        }\n                        c0(c[(7216 + (a << 2)) >> 2] | 0);\n                    }\n                    a = (a + 1) | 0;\n                }\n                bk();\n                return;\n            }\n            function c_(b, c, d) {\n                b = b | 0;\n                c = c | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0;\n                e = b;\n                b = c;\n                c = d;\n                d = 0;\n                f = 0;\n                while (1) {\n                    if ((d | 0) < (b | 0)) {\n                        g = ((f | 0) != 0) ^ 1;\n                    } else {\n                        g = 0;\n                    }\n                    if (!g) {\n                        break;\n                    }\n                    if ((an((e + d) | 0, 1, 1, c | 0) | 0) != 1) {\n                        h = 1752;\n                        break;\n                    }\n                    if ((a[(e + d) | 0] | 0) == 10) {\n                        h = 1755;\n                    } else {\n                        if ((a[(e + d) | 0] | 0) == 13) {\n                            h = 1755;\n                        }\n                    }\n                    if ((h | 0) == 1755) {\n                        h = 0;\n                        a[(e + d) | 0] = 0;\n                        f = 1;\n                    }\n                    d = (d + 1) | 0;\n                }\n                a[(e + d) | 0] = 0;\n                if ((d | 0) != 0) {\n                    i = e;\n                    return i | 0;\n                } else {\n                    i = 0;\n                    return i | 0;\n                }\n                return 0;\n            }\n            // malloc\n            function c$(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0,\n                    B = 0,\n                    C = 0,\n                    D = 0,\n                    E = 0,\n                    F = 0,\n                    G = 0,\n                    H = 0,\n                    I = 0,\n                    J = 0,\n                    K = 0,\n                    L = 0,\n                    M = 0,\n                    N = 0,\n                    O = 0,\n                    P = 0,\n                    Q = 0,\n                    R = 0,\n                    S = 0,\n                    T = 0,\n                    U = 0,\n                    V = 0,\n                    W = 0,\n                    X = 0,\n                    Y = 0,\n                    Z = 0,\n                    _ = 0,\n                    $ = 0,\n                    aa = 0,\n                    ab = 0,\n                    ac = 0,\n                    ad = 0,\n                    ae = 0,\n                    af = 0,\n                    ag = 0,\n                    ah = 0,\n                    ai = 0,\n                    aj = 0,\n                    ak = 0,\n                    al = 0,\n                    an = 0,\n                    ao = 0,\n                    ap = 0,\n                    ar = 0,\n                    as = 0,\n                    at = 0,\n                    au = 0,\n                    av = 0,\n                    aw = 0,\n                    ax = 0,\n                    ay = 0,\n                    az = 0,\n                    aA = 0,\n                    aB = 0,\n                    aC = 0,\n                    aD = 0,\n                    aE = 0,\n                    aF = 0,\n                    aG = 0,\n                    aH = 0,\n                    aI = 0;\n                do {\n                    if (a >>> 0 < 245) {\n                        if (a >>> 0 < 11) {\n                            b = 16;\n                        } else {\n                            b = (a + 11) & -8;\n                        }\n                        d = b >>> 3;\n                        e = c[1996] | 0;\n                        f = e >>> (d >>> 0);\n                        if (((f & 3) | 0) != 0) {\n                            g = (((f & 1) ^ 1) + d) | 0;\n                            h = g << 1;\n                            i = (8024 + (h << 2)) | 0;\n                            j = (8024 + ((h + 2) << 2)) | 0;\n                            h = c[j >> 2] | 0;\n                            k = (h + 8) | 0;\n                            l = c[k >> 2] | 0;\n                            do {\n                                if ((i | 0) == (l | 0)) {\n                                    c[1996] = e & ~(1 << g);\n                                } else {\n                                    if (l >>> 0 < (c[2e3] | 0) >>> 0) {\n                                        aq();\n                                        return 0;\n                                    }\n                                    m = (l + 12) | 0;\n                                    if ((c[m >> 2] | 0) == (h | 0)) {\n                                        c[m >> 2] = i;\n                                        c[j >> 2] = l;\n                                        break;\n                                    } else {\n                                        aq();\n                                        return 0;\n                                    }\n                                }\n                            } while (0);\n                            l = g << 3;\n                            c[(h + 4) >> 2] = l | 3;\n                            j = (h + (l | 4)) | 0;\n                            c[j >> 2] = c[j >> 2] | 1;\n                            n = k;\n                            return n | 0;\n                        }\n                        if (b >>> 0 <= (c[1998] | 0) >>> 0) {\n                            o = b;\n                            break;\n                        }\n                        if ((f | 0) != 0) {\n                            j = 2 << d;\n                            l = (f << d) & (j | -j);\n                            j = ((l & -l) - 1) | 0;\n                            l = (j >>> 12) & 16;\n                            i = j >>> (l >>> 0);\n                            j = (i >>> 5) & 8;\n                            m = i >>> (j >>> 0);\n                            i = (m >>> 2) & 4;\n                            p = m >>> (i >>> 0);\n                            m = (p >>> 1) & 2;\n                            q = p >>> (m >>> 0);\n                            p = (q >>> 1) & 1;\n                            r = ((j | l | i | m | p) + (q >>> (p >>> 0))) | 0;\n                            p = r << 1;\n                            q = (8024 + (p << 2)) | 0;\n                            m = (8024 + ((p + 2) << 2)) | 0;\n                            p = c[m >> 2] | 0;\n                            i = (p + 8) | 0;\n                            l = c[i >> 2] | 0;\n                            do {\n                                if ((q | 0) == (l | 0)) {\n                                    c[1996] = e & ~(1 << r);\n                                } else {\n                                    if (l >>> 0 < (c[2e3] | 0) >>> 0) {\n                                        aq();\n                                        return 0;\n                                    }\n                                    j = (l + 12) | 0;\n                                    if ((c[j >> 2] | 0) == (p | 0)) {\n                                        c[j >> 2] = q;\n                                        c[m >> 2] = l;\n                                        break;\n                                    } else {\n                                        aq();\n                                        return 0;\n                                    }\n                                }\n                            } while (0);\n                            l = r << 3;\n                            m = (l - b) | 0;\n                            c[(p + 4) >> 2] = b | 3;\n                            q = p;\n                            e = (q + b) | 0;\n                            c[(q + (b | 4)) >> 2] = m | 1;\n                            c[(q + l) >> 2] = m;\n                            l = c[1998] | 0;\n                            if ((l | 0) != 0) {\n                                q = c[2001] | 0;\n                                d = l >>> 3;\n                                l = d << 1;\n                                f = (8024 + (l << 2)) | 0;\n                                k = c[1996] | 0;\n                                h = 1 << d;\n                                do {\n                                    if (((k & h) | 0) == 0) {\n                                        c[1996] = k | h;\n                                        s = f;\n                                        t = (8024 + ((l + 2) << 2)) | 0;\n                                    } else {\n                                        d = (8024 + ((l + 2) << 2)) | 0;\n                                        g = c[d >> 2] | 0;\n                                        if (g >>> 0 >= (c[2e3] | 0) >>> 0) {\n                                            s = g;\n                                            t = d;\n                                            break;\n                                        }\n                                        aq();\n                                        return 0;\n                                    }\n                                } while (0);\n                                c[t >> 2] = q;\n                                c[(s + 12) >> 2] = q;\n                                c[(q + 8) >> 2] = s;\n                                c[(q + 12) >> 2] = f;\n                            }\n                            c[1998] = m;\n                            c[2001] = e;\n                            n = i;\n                            return n | 0;\n                        }\n                        l = c[1997] | 0;\n                        if ((l | 0) == 0) {\n                            o = b;\n                            break;\n                        }\n                        h = ((l & -l) - 1) | 0;\n                        l = (h >>> 12) & 16;\n                        k = h >>> (l >>> 0);\n                        h = (k >>> 5) & 8;\n                        p = k >>> (h >>> 0);\n                        k = (p >>> 2) & 4;\n                        r = p >>> (k >>> 0);\n                        p = (r >>> 1) & 2;\n                        d = r >>> (p >>> 0);\n                        r = (d >>> 1) & 1;\n                        g =\n                            c[\n                                (8288 +\n                                    (((h | l | k | p | r) +\n                                        (d >>> (r >>> 0))) <<\n                                        2)) >>\n                                    2\n                            ] | 0;\n                        r = g;\n                        d = g;\n                        p = ((c[(g + 4) >> 2] & -8) - b) | 0;\n                        while (1) {\n                            g = c[(r + 16) >> 2] | 0;\n                            if ((g | 0) == 0) {\n                                k = c[(r + 20) >> 2] | 0;\n                                if ((k | 0) == 0) {\n                                    break;\n                                } else {\n                                    u = k;\n                                }\n                            } else {\n                                u = g;\n                            }\n                            g = ((c[(u + 4) >> 2] & -8) - b) | 0;\n                            k = g >>> 0 < p >>> 0;\n                            r = u;\n                            d = k ? u : d;\n                            p = k ? g : p;\n                        }\n                        r = d;\n                        i = c[2e3] | 0;\n                        if (r >>> 0 < i >>> 0) {\n                            aq();\n                            return 0;\n                        }\n                        e = (r + b) | 0;\n                        m = e;\n                        if (r >>> 0 >= e >>> 0) {\n                            aq();\n                            return 0;\n                        }\n                        e = c[(d + 24) >> 2] | 0;\n                        f = c[(d + 12) >> 2] | 0;\n                        do {\n                            if ((f | 0) == (d | 0)) {\n                                q = (d + 20) | 0;\n                                g = c[q >> 2] | 0;\n                                if ((g | 0) == 0) {\n                                    k = (d + 16) | 0;\n                                    l = c[k >> 2] | 0;\n                                    if ((l | 0) == 0) {\n                                        v = 0;\n                                        break;\n                                    } else {\n                                        w = l;\n                                        x = k;\n                                    }\n                                } else {\n                                    w = g;\n                                    x = q;\n                                }\n                                while (1) {\n                                    q = (w + 20) | 0;\n                                    g = c[q >> 2] | 0;\n                                    if ((g | 0) != 0) {\n                                        w = g;\n                                        x = q;\n                                        continue;\n                                    }\n                                    q = (w + 16) | 0;\n                                    g = c[q >> 2] | 0;\n                                    if ((g | 0) == 0) {\n                                        break;\n                                    } else {\n                                        w = g;\n                                        x = q;\n                                    }\n                                }\n                                if (x >>> 0 < i >>> 0) {\n                                    aq();\n                                    return 0;\n                                } else {\n                                    c[x >> 2] = 0;\n                                    v = w;\n                                    break;\n                                }\n                            } else {\n                                q = c[(d + 8) >> 2] | 0;\n                                if (q >>> 0 < i >>> 0) {\n                                    aq();\n                                    return 0;\n                                }\n                                g = (q + 12) | 0;\n                                if ((c[g >> 2] | 0) != (d | 0)) {\n                                    aq();\n                                    return 0;\n                                }\n                                k = (f + 8) | 0;\n                                if ((c[k >> 2] | 0) == (d | 0)) {\n                                    c[g >> 2] = f;\n                                    c[k >> 2] = q;\n                                    v = f;\n                                    break;\n                                } else {\n                                    aq();\n                                    return 0;\n                                }\n                            }\n                        } while (0);\n                        L2304: do {\n                            if ((e | 0) != 0) {\n                                f = (d + 28) | 0;\n                                i = (8288 + (c[f >> 2] << 2)) | 0;\n                                do {\n                                    if ((d | 0) == (c[i >> 2] | 0)) {\n                                        c[i >> 2] = v;\n                                        if ((v | 0) != 0) {\n                                            break;\n                                        }\n                                        c[1997] = c[1997] & ~(1 << c[f >> 2]);\n                                        break L2304;\n                                    } else {\n                                        if (e >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                            return 0;\n                                        }\n                                        q = (e + 16) | 0;\n                                        if ((c[q >> 2] | 0) == (d | 0)) {\n                                            c[q >> 2] = v;\n                                        } else {\n                                            c[(e + 20) >> 2] = v;\n                                        }\n                                        if ((v | 0) == 0) {\n                                            break L2304;\n                                        }\n                                    }\n                                } while (0);\n                                if (v >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                    return 0;\n                                }\n                                c[(v + 24) >> 2] = e;\n                                f = c[(d + 16) >> 2] | 0;\n                                do {\n                                    if ((f | 0) != 0) {\n                                        if (f >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                            return 0;\n                                        } else {\n                                            c[(v + 16) >> 2] = f;\n                                            c[(f + 24) >> 2] = v;\n                                            break;\n                                        }\n                                    }\n                                } while (0);\n                                f = c[(d + 20) >> 2] | 0;\n                                if ((f | 0) == 0) {\n                                    break;\n                                }\n                                if (f >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                    return 0;\n                                } else {\n                                    c[(v + 20) >> 2] = f;\n                                    c[(f + 24) >> 2] = v;\n                                    break;\n                                }\n                            }\n                        } while (0);\n                        if (p >>> 0 < 16) {\n                            e = (p + b) | 0;\n                            c[(d + 4) >> 2] = e | 3;\n                            f = (r + (e + 4)) | 0;\n                            c[f >> 2] = c[f >> 2] | 1;\n                        } else {\n                            c[(d + 4) >> 2] = b | 3;\n                            c[(r + (b | 4)) >> 2] = p | 1;\n                            c[(r + (p + b)) >> 2] = p;\n                            f = c[1998] | 0;\n                            if ((f | 0) != 0) {\n                                e = c[2001] | 0;\n                                i = f >>> 3;\n                                f = i << 1;\n                                q = (8024 + (f << 2)) | 0;\n                                k = c[1996] | 0;\n                                g = 1 << i;\n                                do {\n                                    if (((k & g) | 0) == 0) {\n                                        c[1996] = k | g;\n                                        y = q;\n                                        z = (8024 + ((f + 2) << 2)) | 0;\n                                    } else {\n                                        i = (8024 + ((f + 2) << 2)) | 0;\n                                        l = c[i >> 2] | 0;\n                                        if (l >>> 0 >= (c[2e3] | 0) >>> 0) {\n                                            y = l;\n                                            z = i;\n                                            break;\n                                        }\n                                        aq();\n                                        return 0;\n                                    }\n                                } while (0);\n                                c[z >> 2] = e;\n                                c[(y + 12) >> 2] = e;\n                                c[(e + 8) >> 2] = y;\n                                c[(e + 12) >> 2] = q;\n                            }\n                            c[1998] = p;\n                            c[2001] = m;\n                        }\n                        f = (d + 8) | 0;\n                        if ((f | 0) == 0) {\n                            o = b;\n                            break;\n                        } else {\n                            n = f;\n                        }\n                        return n | 0;\n                    } else {\n                        if (a >>> 0 > 4294967231) {\n                            o = -1;\n                            break;\n                        }\n                        f = (a + 11) | 0;\n                        g = f & -8;\n                        k = c[1997] | 0;\n                        if ((k | 0) == 0) {\n                            o = g;\n                            break;\n                        }\n                        r = -g | 0;\n                        i = f >>> 8;\n                        do {\n                            if ((i | 0) == 0) {\n                                A = 0;\n                            } else {\n                                if (g >>> 0 > 16777215) {\n                                    A = 31;\n                                    break;\n                                }\n                                f = (((i + 1048320) | 0) >>> 16) & 8;\n                                l = i << f;\n                                h = (((l + 520192) | 0) >>> 16) & 4;\n                                j = l << h;\n                                l = (((j + 245760) | 0) >>> 16) & 2;\n                                B = (14 - (h | f | l) + ((j << l) >>> 15)) | 0;\n                                A =\n                                    ((g >>> (((B + 7) | 0) >>> 0)) & 1) |\n                                    (B << 1);\n                            }\n                        } while (0);\n                        i = c[(8288 + (A << 2)) >> 2] | 0;\n                        L2352: do {\n                            if ((i | 0) == 0) {\n                                C = 0;\n                                D = r;\n                                E = 0;\n                            } else {\n                                if ((A | 0) == 31) {\n                                    F = 0;\n                                } else {\n                                    F = (25 - (A >>> 1)) | 0;\n                                }\n                                d = 0;\n                                m = r;\n                                p = i;\n                                q = g << F;\n                                e = 0;\n                                while (1) {\n                                    B = c[(p + 4) >> 2] & -8;\n                                    l = (B - g) | 0;\n                                    if (l >>> 0 < m >>> 0) {\n                                        if ((B | 0) == (g | 0)) {\n                                            C = p;\n                                            D = l;\n                                            E = p;\n                                            break L2352;\n                                        } else {\n                                            G = p;\n                                            H = l;\n                                        }\n                                    } else {\n                                        G = d;\n                                        H = m;\n                                    }\n                                    l = c[(p + 20) >> 2] | 0;\n                                    B =\n                                        c[(p + 16 + ((q >>> 31) << 2)) >> 2] |\n                                        0;\n                                    j =\n                                        ((l | 0) == 0) | ((l | 0) == (B | 0))\n                                            ? e\n                                            : l;\n                                    if ((B | 0) == 0) {\n                                        C = G;\n                                        D = H;\n                                        E = j;\n                                        break;\n                                    } else {\n                                        d = G;\n                                        m = H;\n                                        p = B;\n                                        q = q << 1;\n                                        e = j;\n                                    }\n                                }\n                            }\n                        } while (0);\n                        if (((E | 0) == 0) & ((C | 0) == 0)) {\n                            i = 2 << A;\n                            r = k & (i | -i);\n                            if ((r | 0) == 0) {\n                                o = g;\n                                break;\n                            }\n                            i = ((r & -r) - 1) | 0;\n                            r = (i >>> 12) & 16;\n                            e = i >>> (r >>> 0);\n                            i = (e >>> 5) & 8;\n                            q = e >>> (i >>> 0);\n                            e = (q >>> 2) & 4;\n                            p = q >>> (e >>> 0);\n                            q = (p >>> 1) & 2;\n                            m = p >>> (q >>> 0);\n                            p = (m >>> 1) & 1;\n                            I =\n                                c[\n                                    (8288 +\n                                        (((i | r | e | q | p) +\n                                            (m >>> (p >>> 0))) <<\n                                            2)) >>\n                                        2\n                                ] | 0;\n                        } else {\n                            I = E;\n                        }\n                        if ((I | 0) == 0) {\n                            J = D;\n                            K = C;\n                        } else {\n                            p = I;\n                            m = D;\n                            q = C;\n                            while (1) {\n                                e = ((c[(p + 4) >> 2] & -8) - g) | 0;\n                                r = e >>> 0 < m >>> 0;\n                                i = r ? e : m;\n                                e = r ? p : q;\n                                r = c[(p + 16) >> 2] | 0;\n                                if ((r | 0) != 0) {\n                                    p = r;\n                                    m = i;\n                                    q = e;\n                                    continue;\n                                }\n                                r = c[(p + 20) >> 2] | 0;\n                                if ((r | 0) == 0) {\n                                    J = i;\n                                    K = e;\n                                    break;\n                                } else {\n                                    p = r;\n                                    m = i;\n                                    q = e;\n                                }\n                            }\n                        }\n                        if ((K | 0) == 0) {\n                            o = g;\n                            break;\n                        }\n                        if (J >>> 0 >= (((c[1998] | 0) - g) | 0) >>> 0) {\n                            o = g;\n                            break;\n                        }\n                        q = K;\n                        m = c[2e3] | 0;\n                        if (q >>> 0 < m >>> 0) {\n                            aq();\n                            return 0;\n                        }\n                        p = (q + g) | 0;\n                        k = p;\n                        if (q >>> 0 >= p >>> 0) {\n                            aq();\n                            return 0;\n                        }\n                        e = c[(K + 24) >> 2] | 0;\n                        i = c[(K + 12) >> 2] | 0;\n                        do {\n                            if ((i | 0) == (K | 0)) {\n                                r = (K + 20) | 0;\n                                d = c[r >> 2] | 0;\n                                if ((d | 0) == 0) {\n                                    j = (K + 16) | 0;\n                                    B = c[j >> 2] | 0;\n                                    if ((B | 0) == 0) {\n                                        L = 0;\n                                        break;\n                                    } else {\n                                        M = B;\n                                        N = j;\n                                    }\n                                } else {\n                                    M = d;\n                                    N = r;\n                                }\n                                while (1) {\n                                    r = (M + 20) | 0;\n                                    d = c[r >> 2] | 0;\n                                    if ((d | 0) != 0) {\n                                        M = d;\n                                        N = r;\n                                        continue;\n                                    }\n                                    r = (M + 16) | 0;\n                                    d = c[r >> 2] | 0;\n                                    if ((d | 0) == 0) {\n                                        break;\n                                    } else {\n                                        M = d;\n                                        N = r;\n                                    }\n                                }\n                                if (N >>> 0 < m >>> 0) {\n                                    aq();\n                                    return 0;\n                                } else {\n                                    c[N >> 2] = 0;\n                                    L = M;\n                                    break;\n                                }\n                            } else {\n                                r = c[(K + 8) >> 2] | 0;\n                                if (r >>> 0 < m >>> 0) {\n                                    aq();\n                                    return 0;\n                                }\n                                d = (r + 12) | 0;\n                                if ((c[d >> 2] | 0) != (K | 0)) {\n                                    aq();\n                                    return 0;\n                                }\n                                j = (i + 8) | 0;\n                                if ((c[j >> 2] | 0) == (K | 0)) {\n                                    c[d >> 2] = i;\n                                    c[j >> 2] = r;\n                                    L = i;\n                                    break;\n                                } else {\n                                    aq();\n                                    return 0;\n                                }\n                            }\n                        } while (0);\n                        L2402: do {\n                            if ((e | 0) != 0) {\n                                i = (K + 28) | 0;\n                                m = (8288 + (c[i >> 2] << 2)) | 0;\n                                do {\n                                    if ((K | 0) == (c[m >> 2] | 0)) {\n                                        c[m >> 2] = L;\n                                        if ((L | 0) != 0) {\n                                            break;\n                                        }\n                                        c[1997] = c[1997] & ~(1 << c[i >> 2]);\n                                        break L2402;\n                                    } else {\n                                        if (e >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                            return 0;\n                                        }\n                                        r = (e + 16) | 0;\n                                        if ((c[r >> 2] | 0) == (K | 0)) {\n                                            c[r >> 2] = L;\n                                        } else {\n                                            c[(e + 20) >> 2] = L;\n                                        }\n                                        if ((L | 0) == 0) {\n                                            break L2402;\n                                        }\n                                    }\n                                } while (0);\n                                if (L >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                    return 0;\n                                }\n                                c[(L + 24) >> 2] = e;\n                                i = c[(K + 16) >> 2] | 0;\n                                do {\n                                    if ((i | 0) != 0) {\n                                        if (i >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                            return 0;\n                                        } else {\n                                            c[(L + 16) >> 2] = i;\n                                            c[(i + 24) >> 2] = L;\n                                            break;\n                                        }\n                                    }\n                                } while (0);\n                                i = c[(K + 20) >> 2] | 0;\n                                if ((i | 0) == 0) {\n                                    break;\n                                }\n                                if (i >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                    return 0;\n                                } else {\n                                    c[(L + 20) >> 2] = i;\n                                    c[(i + 24) >> 2] = L;\n                                    break;\n                                }\n                            }\n                        } while (0);\n                        do {\n                            if (J >>> 0 < 16) {\n                                e = (J + g) | 0;\n                                c[(K + 4) >> 2] = e | 3;\n                                i = (q + (e + 4)) | 0;\n                                c[i >> 2] = c[i >> 2] | 1;\n                            } else {\n                                c[(K + 4) >> 2] = g | 3;\n                                c[(q + (g | 4)) >> 2] = J | 1;\n                                c[(q + (J + g)) >> 2] = J;\n                                i = J >>> 3;\n                                if (J >>> 0 < 256) {\n                                    e = i << 1;\n                                    m = (8024 + (e << 2)) | 0;\n                                    r = c[1996] | 0;\n                                    j = 1 << i;\n                                    do {\n                                        if (((r & j) | 0) == 0) {\n                                            c[1996] = r | j;\n                                            O = m;\n                                            P = (8024 + ((e + 2) << 2)) | 0;\n                                        } else {\n                                            i = (8024 + ((e + 2) << 2)) | 0;\n                                            d = c[i >> 2] | 0;\n                                            if (d >>> 0 >= (c[2e3] | 0) >>> 0) {\n                                                O = d;\n                                                P = i;\n                                                break;\n                                            }\n                                            aq();\n                                            return 0;\n                                        }\n                                    } while (0);\n                                    c[P >> 2] = k;\n                                    c[(O + 12) >> 2] = k;\n                                    c[(q + (g + 8)) >> 2] = O;\n                                    c[(q + (g + 12)) >> 2] = m;\n                                    break;\n                                }\n                                e = p;\n                                j = J >>> 8;\n                                do {\n                                    if ((j | 0) == 0) {\n                                        Q = 0;\n                                    } else {\n                                        if (J >>> 0 > 16777215) {\n                                            Q = 31;\n                                            break;\n                                        }\n                                        r = (((j + 1048320) | 0) >>> 16) & 8;\n                                        i = j << r;\n                                        d = (((i + 520192) | 0) >>> 16) & 4;\n                                        B = i << d;\n                                        i = (((B + 245760) | 0) >>> 16) & 2;\n                                        l =\n                                            (14 -\n                                                (d | r | i) +\n                                                ((B << i) >>> 15)) |\n                                            0;\n                                        Q =\n                                            ((J >>> (((l + 7) | 0) >>> 0)) &\n                                                1) |\n                                            (l << 1);\n                                    }\n                                } while (0);\n                                j = (8288 + (Q << 2)) | 0;\n                                c[(q + (g + 28)) >> 2] = Q;\n                                c[(q + (g + 20)) >> 2] = 0;\n                                c[(q + (g + 16)) >> 2] = 0;\n                                m = c[1997] | 0;\n                                l = 1 << Q;\n                                if (((m & l) | 0) == 0) {\n                                    c[1997] = m | l;\n                                    c[j >> 2] = e;\n                                    c[(q + (g + 24)) >> 2] = j;\n                                    c[(q + (g + 12)) >> 2] = e;\n                                    c[(q + (g + 8)) >> 2] = e;\n                                    break;\n                                }\n                                if ((Q | 0) == 31) {\n                                    R = 0;\n                                } else {\n                                    R = (25 - (Q >>> 1)) | 0;\n                                }\n                                l = J << R;\n                                m = c[j >> 2] | 0;\n                                while (1) {\n                                    if (\n                                        ((c[(m + 4) >> 2] & -8) | 0) ==\n                                        (J | 0)\n                                    ) {\n                                        break;\n                                    }\n                                    S = (m + 16 + ((l >>> 31) << 2)) | 0;\n                                    j = c[S >> 2] | 0;\n                                    if ((j | 0) == 0) {\n                                        T = 1913;\n                                        break;\n                                    } else {\n                                        l = l << 1;\n                                        m = j;\n                                    }\n                                }\n                                if ((T | 0) == 1913) {\n                                    if (S >>> 0 < (c[2e3] | 0) >>> 0) {\n                                        aq();\n                                        return 0;\n                                    } else {\n                                        c[S >> 2] = e;\n                                        c[(q + (g + 24)) >> 2] = m;\n                                        c[(q + (g + 12)) >> 2] = e;\n                                        c[(q + (g + 8)) >> 2] = e;\n                                        break;\n                                    }\n                                }\n                                l = (m + 8) | 0;\n                                j = c[l >> 2] | 0;\n                                i = c[2e3] | 0;\n                                if (m >>> 0 < i >>> 0) {\n                                    aq();\n                                    return 0;\n                                }\n                                if (j >>> 0 < i >>> 0) {\n                                    aq();\n                                    return 0;\n                                } else {\n                                    c[(j + 12) >> 2] = e;\n                                    c[l >> 2] = e;\n                                    c[(q + (g + 8)) >> 2] = j;\n                                    c[(q + (g + 12)) >> 2] = m;\n                                    c[(q + (g + 24)) >> 2] = 0;\n                                    break;\n                                }\n                            }\n                        } while (0);\n                        q = (K + 8) | 0;\n                        if ((q | 0) == 0) {\n                            o = g;\n                            break;\n                        } else {\n                            n = q;\n                        }\n                        return n | 0;\n                    }\n                } while (0);\n                K = c[1998] | 0;\n                if (o >>> 0 <= K >>> 0) {\n                    S = (K - o) | 0;\n                    J = c[2001] | 0;\n                    if (S >>> 0 > 15) {\n                        R = J;\n                        c[2001] = R + o;\n                        c[1998] = S;\n                        c[(R + (o + 4)) >> 2] = S | 1;\n                        c[(R + K) >> 2] = S;\n                        c[(J + 4) >> 2] = o | 3;\n                    } else {\n                        c[1998] = 0;\n                        c[2001] = 0;\n                        c[(J + 4) >> 2] = K | 3;\n                        S = (J + (K + 4)) | 0;\n                        c[S >> 2] = c[S >> 2] | 1;\n                    }\n                    n = (J + 8) | 0;\n                    return n | 0;\n                }\n                J = c[1999] | 0;\n                if (o >>> 0 < J >>> 0) {\n                    S = (J - o) | 0;\n                    c[1999] = S;\n                    J = c[2002] | 0;\n                    K = J;\n                    c[2002] = K + o;\n                    c[(K + (o + 4)) >> 2] = S | 1;\n                    c[(J + 4) >> 2] = o | 3;\n                    n = (J + 8) | 0;\n                    return n | 0;\n                }\n                do {\n                    if ((c[1666] | 0) == 0) {\n                        J = am(30) | 0;\n                        if ((((J - 1) & J) | 0) == 0) {\n                            c[1668] = J;\n                            c[1667] = J;\n                            c[1669] = -1;\n                            c[1670] = -1;\n                            c[1671] = 0;\n                            c[2107] = 0;\n                            c[1666] = ((aJ(0) | 0) & -16) ^ 1431655768;\n                            break;\n                        } else {\n                            aq();\n                            return 0;\n                        }\n                    }\n                } while (0);\n                J = (o + 48) | 0;\n                S = c[1668] | 0;\n                K = (o + 47) | 0;\n                R = (S + K) | 0;\n                Q = -S | 0;\n                S = R & Q;\n                if (S >>> 0 <= o >>> 0) {\n                    n = 0;\n                    return n | 0;\n                }\n                O = c[2106] | 0;\n                do {\n                    if ((O | 0) != 0) {\n                        P = c[2104] | 0;\n                        L = (P + S) | 0;\n                        if ((L >>> 0 <= P >>> 0) | (L >>> 0 > O >>> 0)) {\n                            n = 0;\n                        } else {\n                            break;\n                        }\n                        return n | 0;\n                    }\n                } while (0);\n                L2494: do {\n                    if (((c[2107] & 4) | 0) == 0) {\n                        O = c[2002] | 0;\n                        L2496: do {\n                            if ((O | 0) == 0) {\n                                T = 1943;\n                            } else {\n                                L = O;\n                                P = 8432;\n                                while (1) {\n                                    U = P | 0;\n                                    M = c[U >> 2] | 0;\n                                    if (M >>> 0 <= L >>> 0) {\n                                        V = (P + 4) | 0;\n                                        if (\n                                            ((M + (c[V >> 2] | 0)) | 0) >>> 0 >\n                                            L >>> 0\n                                        ) {\n                                            break;\n                                        }\n                                    }\n                                    M = c[(P + 8) >> 2] | 0;\n                                    if ((M | 0) == 0) {\n                                        T = 1943;\n                                        break L2496;\n                                    } else {\n                                        P = M;\n                                    }\n                                }\n                                if ((P | 0) == 0) {\n                                    T = 1943;\n                                    break;\n                                }\n                                L = (R - (c[1999] | 0)) & Q;\n                                if (L >>> 0 >= 2147483647) {\n                                    W = 0;\n                                    break;\n                                }\n                                m = aS(L | 0) | 0;\n                                e =\n                                    (m | 0) ==\n                                    (((c[U >> 2] | 0) + (c[V >> 2] | 0)) | 0);\n                                X = e ? m : -1;\n                                Y = e ? L : 0;\n                                Z = m;\n                                _ = L;\n                                T = 1952;\n                            }\n                        } while (0);\n                        do {\n                            if ((T | 0) == 1943) {\n                                O = aS(0) | 0;\n                                if ((O | 0) == -1) {\n                                    W = 0;\n                                    break;\n                                }\n                                g = O;\n                                L = c[1667] | 0;\n                                m = (L - 1) | 0;\n                                if (((m & g) | 0) == 0) {\n                                    $ = S;\n                                } else {\n                                    $ = (S - g + ((m + g) & -L)) | 0;\n                                }\n                                L = c[2104] | 0;\n                                g = (L + $) | 0;\n                                if (\n                                    !(\n                                        ($ >>> 0 > o >>> 0) &\n                                        ($ >>> 0 < 2147483647)\n                                    )\n                                ) {\n                                    W = 0;\n                                    break;\n                                }\n                                m = c[2106] | 0;\n                                if ((m | 0) != 0) {\n                                    if (\n                                        (g >>> 0 <= L >>> 0) |\n                                        (g >>> 0 > m >>> 0)\n                                    ) {\n                                        W = 0;\n                                        break;\n                                    }\n                                }\n                                m = aS($ | 0) | 0;\n                                g = (m | 0) == (O | 0);\n                                X = g ? O : -1;\n                                Y = g ? $ : 0;\n                                Z = m;\n                                _ = $;\n                                T = 1952;\n                            }\n                        } while (0);\n                        L2516: do {\n                            if ((T | 0) == 1952) {\n                                m = -_ | 0;\n                                if ((X | 0) != -1) {\n                                    aa = Y;\n                                    ab = X;\n                                    T = 1963;\n                                    break L2494;\n                                }\n                                do {\n                                    if (\n                                        ((Z | 0) != -1) &\n                                        (_ >>> 0 < 2147483647) &\n                                        (_ >>> 0 < J >>> 0)\n                                    ) {\n                                        g = c[1668] | 0;\n                                        O = (K - _ + g) & -g;\n                                        if (O >>> 0 >= 2147483647) {\n                                            ac = _;\n                                            break;\n                                        }\n                                        if ((aS(O | 0) | 0) == -1) {\n                                            aS(m | 0) | 0;\n                                            W = Y;\n                                            break L2516;\n                                        } else {\n                                            ac = (O + _) | 0;\n                                            break;\n                                        }\n                                    } else {\n                                        ac = _;\n                                    }\n                                } while (0);\n                                if ((Z | 0) == -1) {\n                                    W = Y;\n                                } else {\n                                    aa = ac;\n                                    ab = Z;\n                                    T = 1963;\n                                    break L2494;\n                                }\n                            }\n                        } while (0);\n                        c[2107] = c[2107] | 4;\n                        ad = W;\n                        T = 1960;\n                    } else {\n                        ad = 0;\n                        T = 1960;\n                    }\n                } while (0);\n                do {\n                    if ((T | 0) == 1960) {\n                        if (S >>> 0 >= 2147483647) {\n                            break;\n                        }\n                        W = aS(S | 0) | 0;\n                        Z = aS(0) | 0;\n                        if (\n                            !(\n                                ((Z | 0) != -1) &\n                                ((W | 0) != -1) &\n                                (W >>> 0 < Z >>> 0)\n                            )\n                        ) {\n                            break;\n                        }\n                        ac = (Z - W) | 0;\n                        Z = ac >>> 0 > ((o + 40) | 0) >>> 0;\n                        Y = Z ? W : -1;\n                        if ((Y | 0) != -1) {\n                            aa = Z ? ac : ad;\n                            ab = Y;\n                            T = 1963;\n                        }\n                    }\n                } while (0);\n                do {\n                    if ((T | 0) == 1963) {\n                        ad = ((c[2104] | 0) + aa) | 0;\n                        c[2104] = ad;\n                        if (ad >>> 0 > (c[2105] | 0) >>> 0) {\n                            c[2105] = ad;\n                        }\n                        ad = c[2002] | 0;\n                        L2536: do {\n                            if ((ad | 0) == 0) {\n                                S = c[2e3] | 0;\n                                if (((S | 0) == 0) | (ab >>> 0 < S >>> 0)) {\n                                    c[2e3] = ab;\n                                }\n                                c[2108] = ab;\n                                c[2109] = aa;\n                                c[2111] = 0;\n                                c[2005] = c[1666];\n                                c[2004] = -1;\n                                S = 0;\n                                do {\n                                    Y = S << 1;\n                                    ac = (8024 + (Y << 2)) | 0;\n                                    c[(8024 + ((Y + 3) << 2)) >> 2] = ac;\n                                    c[(8024 + ((Y + 2) << 2)) >> 2] = ac;\n                                    S = (S + 1) | 0;\n                                } while (S >>> 0 < 32);\n                                S = (ab + 8) | 0;\n                                if (((S & 7) | 0) == 0) {\n                                    ae = 0;\n                                } else {\n                                    ae = -S & 7;\n                                }\n                                S = (aa - 40 - ae) | 0;\n                                c[2002] = ab + ae;\n                                c[1999] = S;\n                                c[(ab + (ae + 4)) >> 2] = S | 1;\n                                c[(ab + (aa - 36)) >> 2] = 40;\n                                c[2003] = c[1670];\n                            } else {\n                                S = 8432;\n                                while (1) {\n                                    af = c[S >> 2] | 0;\n                                    ag = (S + 4) | 0;\n                                    ah = c[ag >> 2] | 0;\n                                    if ((ab | 0) == ((af + ah) | 0)) {\n                                        T = 1975;\n                                        break;\n                                    }\n                                    ac = c[(S + 8) >> 2] | 0;\n                                    if ((ac | 0) == 0) {\n                                        break;\n                                    } else {\n                                        S = ac;\n                                    }\n                                }\n                                do {\n                                    if ((T | 0) == 1975) {\n                                        if (((c[(S + 12) >> 2] & 8) | 0) != 0) {\n                                            break;\n                                        }\n                                        ac = ad;\n                                        if (\n                                            !(\n                                                (ac >>> 0 >= af >>> 0) &\n                                                (ac >>> 0 < ab >>> 0)\n                                            )\n                                        ) {\n                                            break;\n                                        }\n                                        c[ag >> 2] = ah + aa;\n                                        ac = c[2002] | 0;\n                                        Y = ((c[1999] | 0) + aa) | 0;\n                                        Z = ac;\n                                        W = (ac + 8) | 0;\n                                        if (((W & 7) | 0) == 0) {\n                                            ai = 0;\n                                        } else {\n                                            ai = -W & 7;\n                                        }\n                                        W = (Y - ai) | 0;\n                                        c[2002] = Z + ai;\n                                        c[1999] = W;\n                                        c[(Z + (ai + 4)) >> 2] = W | 1;\n                                        c[(Z + (Y + 4)) >> 2] = 40;\n                                        c[2003] = c[1670];\n                                        break L2536;\n                                    }\n                                } while (0);\n                                if (ab >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    c[2e3] = ab;\n                                }\n                                S = (ab + aa) | 0;\n                                Y = 8432;\n                                while (1) {\n                                    aj = Y | 0;\n                                    if ((c[aj >> 2] | 0) == (S | 0)) {\n                                        T = 1985;\n                                        break;\n                                    }\n                                    Z = c[(Y + 8) >> 2] | 0;\n                                    if ((Z | 0) == 0) {\n                                        break;\n                                    } else {\n                                        Y = Z;\n                                    }\n                                }\n                                do {\n                                    if ((T | 0) == 1985) {\n                                        if (((c[(Y + 12) >> 2] & 8) | 0) != 0) {\n                                            break;\n                                        }\n                                        c[aj >> 2] = ab;\n                                        S = (Y + 4) | 0;\n                                        c[S >> 2] = (c[S >> 2] | 0) + aa;\n                                        S = (ab + 8) | 0;\n                                        if (((S & 7) | 0) == 0) {\n                                            ak = 0;\n                                        } else {\n                                            ak = -S & 7;\n                                        }\n                                        S = (ab + (aa + 8)) | 0;\n                                        if (((S & 7) | 0) == 0) {\n                                            al = 0;\n                                        } else {\n                                            al = -S & 7;\n                                        }\n                                        S = (ab + (al + aa)) | 0;\n                                        Z = S;\n                                        W = (ak + o) | 0;\n                                        ac = (ab + W) | 0;\n                                        _ = ac;\n                                        K = (S - (ab + ak) - o) | 0;\n                                        c[(ab + (ak + 4)) >> 2] = o | 3;\n                                        do {\n                                            if ((Z | 0) == (c[2002] | 0)) {\n                                                J = ((c[1999] | 0) + K) | 0;\n                                                c[1999] = J;\n                                                c[2002] = _;\n                                                c[(ab + (W + 4)) >> 2] = J | 1;\n                                            } else {\n                                                if ((Z | 0) == (c[2001] | 0)) {\n                                                    J = ((c[1998] | 0) + K) | 0;\n                                                    c[1998] = J;\n                                                    c[2001] = _;\n                                                    c[(ab + (W + 4)) >> 2] =\n                                                        J | 1;\n                                                    c[(ab + (J + W)) >> 2] = J;\n                                                    break;\n                                                }\n                                                J = (aa + 4) | 0;\n                                                X = c[(ab + (J + al)) >> 2] | 0;\n                                                if (((X & 3) | 0) == 1) {\n                                                    $ = X & -8;\n                                                    V = X >>> 3;\n                                                    L2571: do {\n                                                        if (X >>> 0 < 256) {\n                                                            U =\n                                                                c[\n                                                                    (ab +\n                                                                        ((al |\n                                                                            8) +\n                                                                            aa)) >>\n                                                                        2\n                                                                ] | 0;\n                                                            Q =\n                                                                c[\n                                                                    (ab +\n                                                                        (aa +\n                                                                            12 +\n                                                                            al)) >>\n                                                                        2\n                                                                ] | 0;\n                                                            R =\n                                                                (8024 +\n                                                                    ((V << 1) <<\n                                                                        2)) |\n                                                                0;\n                                                            do {\n                                                                if (\n                                                                    (U | 0) !=\n                                                                    (R | 0)\n                                                                ) {\n                                                                    if (\n                                                                        U >>>\n                                                                            0 <\n                                                                        (c[2e3] |\n                                                                            0) >>>\n                                                                            0\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    }\n                                                                    if (\n                                                                        (c[\n                                                                            (U +\n                                                                                12) >>\n                                                                                2\n                                                                        ] |\n                                                                            0) ==\n                                                                        (Z | 0)\n                                                                    ) {\n                                                                        break;\n                                                                    }\n                                                                    aq();\n                                                                    return 0;\n                                                                }\n                                                            } while (0);\n                                                            if (\n                                                                (Q | 0) ==\n                                                                (U | 0)\n                                                            ) {\n                                                                c[1996] =\n                                                                    c[1996] &\n                                                                    ~(1 << V);\n                                                                break;\n                                                            }\n                                                            do {\n                                                                if (\n                                                                    (Q | 0) ==\n                                                                    (R | 0)\n                                                                ) {\n                                                                    an =\n                                                                        (Q +\n                                                                            8) |\n                                                                        0;\n                                                                } else {\n                                                                    if (\n                                                                        Q >>>\n                                                                            0 <\n                                                                        (c[2e3] |\n                                                                            0) >>>\n                                                                            0\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    }\n                                                                    m =\n                                                                        (Q +\n                                                                            8) |\n                                                                        0;\n                                                                    if (\n                                                                        (c[\n                                                                            m >>\n                                                                                2\n                                                                        ] |\n                                                                            0) ==\n                                                                        (Z | 0)\n                                                                    ) {\n                                                                        an = m;\n                                                                        break;\n                                                                    }\n                                                                    aq();\n                                                                    return 0;\n                                                                }\n                                                            } while (0);\n                                                            c[\n                                                                (U + 12) >> 2\n                                                            ] = Q;\n                                                            c[an >> 2] = U;\n                                                        } else {\n                                                            R = S;\n                                                            m =\n                                                                c[\n                                                                    (ab +\n                                                                        ((al |\n                                                                            24) +\n                                                                            aa)) >>\n                                                                        2\n                                                                ] | 0;\n                                                            P =\n                                                                c[\n                                                                    (ab +\n                                                                        (aa +\n                                                                            12 +\n                                                                            al)) >>\n                                                                        2\n                                                                ] | 0;\n                                                            do {\n                                                                if (\n                                                                    (P | 0) ==\n                                                                    (R | 0)\n                                                                ) {\n                                                                    O = al | 16;\n                                                                    g =\n                                                                        (ab +\n                                                                            (J +\n                                                                                O)) |\n                                                                        0;\n                                                                    L =\n                                                                        c[\n                                                                            g >>\n                                                                                2\n                                                                        ] | 0;\n                                                                    if (\n                                                                        (L |\n                                                                            0) ==\n                                                                        0\n                                                                    ) {\n                                                                        e =\n                                                                            (ab +\n                                                                                (O +\n                                                                                    aa)) |\n                                                                            0;\n                                                                        O =\n                                                                            c[\n                                                                                e >>\n                                                                                    2\n                                                                            ] |\n                                                                            0;\n                                                                        if (\n                                                                            (O |\n                                                                                0) ==\n                                                                            0\n                                                                        ) {\n                                                                            ao = 0;\n                                                                            break;\n                                                                        } else {\n                                                                            ap = O;\n                                                                            ar = e;\n                                                                        }\n                                                                    } else {\n                                                                        ap = L;\n                                                                        ar = g;\n                                                                    }\n                                                                    while (1) {\n                                                                        g =\n                                                                            (ap +\n                                                                                20) |\n                                                                            0;\n                                                                        L =\n                                                                            c[\n                                                                                g >>\n                                                                                    2\n                                                                            ] |\n                                                                            0;\n                                                                        if (\n                                                                            (L |\n                                                                                0) !=\n                                                                            0\n                                                                        ) {\n                                                                            ap = L;\n                                                                            ar = g;\n                                                                            continue;\n                                                                        }\n                                                                        g =\n                                                                            (ap +\n                                                                                16) |\n                                                                            0;\n                                                                        L =\n                                                                            c[\n                                                                                g >>\n                                                                                    2\n                                                                            ] |\n                                                                            0;\n                                                                        if (\n                                                                            (L |\n                                                                                0) ==\n                                                                            0\n                                                                        ) {\n                                                                            break;\n                                                                        } else {\n                                                                            ap = L;\n                                                                            ar = g;\n                                                                        }\n                                                                    }\n                                                                    if (\n                                                                        ar >>>\n                                                                            0 <\n                                                                        (c[2e3] |\n                                                                            0) >>>\n                                                                            0\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    } else {\n                                                                        c[\n                                                                            ar >>\n                                                                                2\n                                                                        ] = 0;\n                                                                        ao = ap;\n                                                                        break;\n                                                                    }\n                                                                } else {\n                                                                    g =\n                                                                        c[\n                                                                            (ab +\n                                                                                ((al |\n                                                                                    8) +\n                                                                                    aa)) >>\n                                                                                2\n                                                                        ] | 0;\n                                                                    if (\n                                                                        g >>>\n                                                                            0 <\n                                                                        (c[2e3] |\n                                                                            0) >>>\n                                                                            0\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    }\n                                                                    L =\n                                                                        (g +\n                                                                            12) |\n                                                                        0;\n                                                                    if (\n                                                                        (c[\n                                                                            L >>\n                                                                                2\n                                                                        ] |\n                                                                            0) !=\n                                                                        (R | 0)\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    }\n                                                                    e =\n                                                                        (P +\n                                                                            8) |\n                                                                        0;\n                                                                    if (\n                                                                        (c[\n                                                                            e >>\n                                                                                2\n                                                                        ] |\n                                                                            0) ==\n                                                                        (R | 0)\n                                                                    ) {\n                                                                        c[\n                                                                            L >>\n                                                                                2\n                                                                        ] = P;\n                                                                        c[\n                                                                            e >>\n                                                                                2\n                                                                        ] = g;\n                                                                        ao = P;\n                                                                        break;\n                                                                    } else {\n                                                                        aq();\n                                                                        return 0;\n                                                                    }\n                                                                }\n                                                            } while (0);\n                                                            if ((m | 0) == 0) {\n                                                                break;\n                                                            }\n                                                            P =\n                                                                (ab +\n                                                                    (aa +\n                                                                        28 +\n                                                                        al)) |\n                                                                0;\n                                                            U =\n                                                                (8288 +\n                                                                    (c[\n                                                                        P >> 2\n                                                                    ] <<\n                                                                        2)) |\n                                                                0;\n                                                            do {\n                                                                if (\n                                                                    (R | 0) ==\n                                                                    (c[U >> 2] |\n                                                                        0)\n                                                                ) {\n                                                                    c[\n                                                                        U >> 2\n                                                                    ] = ao;\n                                                                    if (\n                                                                        (ao |\n                                                                            0) !=\n                                                                        0\n                                                                    ) {\n                                                                        break;\n                                                                    }\n                                                                    c[1997] =\n                                                                        c[1997] &\n                                                                        ~(\n                                                                            1 <<\n                                                                            c[\n                                                                                P >>\n                                                                                    2\n                                                                            ]\n                                                                        );\n                                                                    break L2571;\n                                                                } else {\n                                                                    if (\n                                                                        m >>>\n                                                                            0 <\n                                                                        (c[2e3] |\n                                                                            0) >>>\n                                                                            0\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    }\n                                                                    Q =\n                                                                        (m +\n                                                                            16) |\n                                                                        0;\n                                                                    if (\n                                                                        (c[\n                                                                            Q >>\n                                                                                2\n                                                                        ] |\n                                                                            0) ==\n                                                                        (R | 0)\n                                                                    ) {\n                                                                        c[\n                                                                            Q >>\n                                                                                2\n                                                                        ] = ao;\n                                                                    } else {\n                                                                        c[\n                                                                            (m +\n                                                                                20) >>\n                                                                                2\n                                                                        ] = ao;\n                                                                    }\n                                                                    if (\n                                                                        (ao |\n                                                                            0) ==\n                                                                        0\n                                                                    ) {\n                                                                        break L2571;\n                                                                    }\n                                                                }\n                                                            } while (0);\n                                                            if (\n                                                                ao >>> 0 <\n                                                                (c[2e3] | 0) >>>\n                                                                    0\n                                                            ) {\n                                                                aq();\n                                                                return 0;\n                                                            }\n                                                            c[\n                                                                (ao + 24) >> 2\n                                                            ] = m;\n                                                            R = al | 16;\n                                                            P =\n                                                                c[\n                                                                    (ab +\n                                                                        (R +\n                                                                            aa)) >>\n                                                                        2\n                                                                ] | 0;\n                                                            do {\n                                                                if (\n                                                                    (P | 0) !=\n                                                                    0\n                                                                ) {\n                                                                    if (\n                                                                        P >>>\n                                                                            0 <\n                                                                        (c[2e3] |\n                                                                            0) >>>\n                                                                            0\n                                                                    ) {\n                                                                        aq();\n                                                                        return 0;\n                                                                    } else {\n                                                                        c[\n                                                                            (ao +\n                                                                                16) >>\n                                                                                2\n                                                                        ] = P;\n                                                                        c[\n                                                                            (P +\n                                                                                24) >>\n                                                                                2\n                                                                        ] = ao;\n                                                                        break;\n                                                                    }\n                                                                }\n                                                            } while (0);\n                                                            P =\n                                                                c[\n                                                                    (ab +\n                                                                        (J +\n                                                                            R)) >>\n                                                                        2\n                                                                ] | 0;\n                                                            if ((P | 0) == 0) {\n                                                                break;\n                                                            }\n                                                            if (\n                                                                P >>> 0 <\n                                                                (c[2e3] | 0) >>>\n                                                                    0\n                                                            ) {\n                                                                aq();\n                                                                return 0;\n                                                            } else {\n                                                                c[\n                                                                    (ao + 20) >>\n                                                                        2\n                                                                ] = P;\n                                                                c[\n                                                                    (P + 24) >>\n                                                                        2\n                                                                ] = ao;\n                                                                break;\n                                                            }\n                                                        }\n                                                    } while (0);\n                                                    as =\n                                                        (ab + (($ | al) + aa)) |\n                                                        0;\n                                                    at = ($ + K) | 0;\n                                                } else {\n                                                    as = Z;\n                                                    at = K;\n                                                }\n                                                J = (as + 4) | 0;\n                                                c[J >> 2] = c[J >> 2] & -2;\n                                                c[(ab + (W + 4)) >> 2] = at | 1;\n                                                c[(ab + (at + W)) >> 2] = at;\n                                                J = at >>> 3;\n                                                if (at >>> 0 < 256) {\n                                                    V = J << 1;\n                                                    X = (8024 + (V << 2)) | 0;\n                                                    P = c[1996] | 0;\n                                                    m = 1 << J;\n                                                    do {\n                                                        if (\n                                                            ((P & m) | 0) ==\n                                                            0\n                                                        ) {\n                                                            c[1996] = P | m;\n                                                            au = X;\n                                                            av =\n                                                                (8024 +\n                                                                    ((V + 2) <<\n                                                                        2)) |\n                                                                0;\n                                                        } else {\n                                                            J =\n                                                                (8024 +\n                                                                    ((V + 2) <<\n                                                                        2)) |\n                                                                0;\n                                                            U = c[J >> 2] | 0;\n                                                            if (\n                                                                U >>> 0 >=\n                                                                (c[2e3] | 0) >>>\n                                                                    0\n                                                            ) {\n                                                                au = U;\n                                                                av = J;\n                                                                break;\n                                                            }\n                                                            aq();\n                                                            return 0;\n                                                        }\n                                                    } while (0);\n                                                    c[av >> 2] = _;\n                                                    c[(au + 12) >> 2] = _;\n                                                    c[(ab + (W + 8)) >> 2] = au;\n                                                    c[(ab + (W + 12)) >> 2] = X;\n                                                    break;\n                                                }\n                                                V = ac;\n                                                m = at >>> 8;\n                                                do {\n                                                    if ((m | 0) == 0) {\n                                                        aw = 0;\n                                                    } else {\n                                                        if (\n                                                            at >>> 0 >\n                                                            16777215\n                                                        ) {\n                                                            aw = 31;\n                                                            break;\n                                                        }\n                                                        P =\n                                                            (((m + 1048320) |\n                                                                0) >>>\n                                                                16) &\n                                                            8;\n                                                        $ = m << P;\n                                                        J =\n                                                            ((($ + 520192) |\n                                                                0) >>>\n                                                                16) &\n                                                            4;\n                                                        U = $ << J;\n                                                        $ =\n                                                            (((U + 245760) |\n                                                                0) >>>\n                                                                16) &\n                                                            2;\n                                                        Q =\n                                                            (14 -\n                                                                (J | P | $) +\n                                                                ((U << $) >>>\n                                                                    15)) |\n                                                            0;\n                                                        aw =\n                                                            ((at >>>\n                                                                (((Q + 7) |\n                                                                    0) >>>\n                                                                    0)) &\n                                                                1) |\n                                                            (Q << 1);\n                                                    }\n                                                } while (0);\n                                                m = (8288 + (aw << 2)) | 0;\n                                                c[(ab + (W + 28)) >> 2] = aw;\n                                                c[(ab + (W + 20)) >> 2] = 0;\n                                                c[(ab + (W + 16)) >> 2] = 0;\n                                                X = c[1997] | 0;\n                                                Q = 1 << aw;\n                                                if (((X & Q) | 0) == 0) {\n                                                    c[1997] = X | Q;\n                                                    c[m >> 2] = V;\n                                                    c[(ab + (W + 24)) >> 2] = m;\n                                                    c[(ab + (W + 12)) >> 2] = V;\n                                                    c[(ab + (W + 8)) >> 2] = V;\n                                                    break;\n                                                }\n                                                if ((aw | 0) == 31) {\n                                                    ax = 0;\n                                                } else {\n                                                    ax = (25 - (aw >>> 1)) | 0;\n                                                }\n                                                Q = at << ax;\n                                                X = c[m >> 2] | 0;\n                                                while (1) {\n                                                    if (\n                                                        ((c[(X + 4) >> 2] &\n                                                            -8) |\n                                                            0) ==\n                                                        (at | 0)\n                                                    ) {\n                                                        break;\n                                                    }\n                                                    ay =\n                                                        (X +\n                                                            16 +\n                                                            ((Q >>> 31) << 2)) |\n                                                        0;\n                                                    m = c[ay >> 2] | 0;\n                                                    if ((m | 0) == 0) {\n                                                        T = 2058;\n                                                        break;\n                                                    } else {\n                                                        Q = Q << 1;\n                                                        X = m;\n                                                    }\n                                                }\n                                                if ((T | 0) == 2058) {\n                                                    if (\n                                                        ay >>> 0 <\n                                                        (c[2e3] | 0) >>> 0\n                                                    ) {\n                                                        aq();\n                                                        return 0;\n                                                    } else {\n                                                        c[ay >> 2] = V;\n                                                        c[\n                                                            (ab + (W + 24)) >> 2\n                                                        ] = X;\n                                                        c[\n                                                            (ab + (W + 12)) >> 2\n                                                        ] = V;\n                                                        c[\n                                                            (ab + (W + 8)) >> 2\n                                                        ] = V;\n                                                        break;\n                                                    }\n                                                }\n                                                Q = (X + 8) | 0;\n                                                m = c[Q >> 2] | 0;\n                                                $ = c[2e3] | 0;\n                                                if (X >>> 0 < $ >>> 0) {\n                                                    aq();\n                                                    return 0;\n                                                }\n                                                if (m >>> 0 < $ >>> 0) {\n                                                    aq();\n                                                    return 0;\n                                                } else {\n                                                    c[(m + 12) >> 2] = V;\n                                                    c[Q >> 2] = V;\n                                                    c[(ab + (W + 8)) >> 2] = m;\n                                                    c[(ab + (W + 12)) >> 2] = X;\n                                                    c[(ab + (W + 24)) >> 2] = 0;\n                                                    break;\n                                                }\n                                            }\n                                        } while (0);\n                                        n = (ab + (ak | 8)) | 0;\n                                        return n | 0;\n                                    }\n                                } while (0);\n                                Y = ad;\n                                W = 8432;\n                                while (1) {\n                                    az = c[W >> 2] | 0;\n                                    if (az >>> 0 <= Y >>> 0) {\n                                        aA = c[(W + 4) >> 2] | 0;\n                                        aB = (az + aA) | 0;\n                                        if (aB >>> 0 > Y >>> 0) {\n                                            break;\n                                        }\n                                    }\n                                    W = c[(W + 8) >> 2] | 0;\n                                }\n                                W = (az + (aA - 39)) | 0;\n                                if (((W & 7) | 0) == 0) {\n                                    aC = 0;\n                                } else {\n                                    aC = -W & 7;\n                                }\n                                W = (az + (aA - 47 + aC)) | 0;\n                                ac = W >>> 0 < ((ad + 16) | 0) >>> 0 ? Y : W;\n                                W = (ac + 8) | 0;\n                                _ = (ab + 8) | 0;\n                                if (((_ & 7) | 0) == 0) {\n                                    aD = 0;\n                                } else {\n                                    aD = -_ & 7;\n                                }\n                                _ = (aa - 40 - aD) | 0;\n                                c[2002] = ab + aD;\n                                c[1999] = _;\n                                c[(ab + (aD + 4)) >> 2] = _ | 1;\n                                c[(ab + (aa - 36)) >> 2] = 40;\n                                c[2003] = c[1670];\n                                c[(ac + 4) >> 2] = 27;\n                                c[W >> 2] = c[2108];\n                                c[(W + 4) >> 2] = c[2109];\n                                c[(W + 8) >> 2] = c[2110];\n                                c[(W + 12) >> 2] = c[2111];\n                                c[2108] = ab;\n                                c[2109] = aa;\n                                c[2111] = 0;\n                                c[2110] = W;\n                                W = (ac + 28) | 0;\n                                c[W >> 2] = 7;\n                                if (((ac + 32) | 0) >>> 0 < aB >>> 0) {\n                                    _ = W;\n                                    while (1) {\n                                        W = (_ + 4) | 0;\n                                        c[W >> 2] = 7;\n                                        if (((_ + 8) | 0) >>> 0 < aB >>> 0) {\n                                            _ = W;\n                                        } else {\n                                            break;\n                                        }\n                                    }\n                                }\n                                if ((ac | 0) == (Y | 0)) {\n                                    break;\n                                }\n                                _ = (ac - ad) | 0;\n                                W = (Y + (_ + 4)) | 0;\n                                c[W >> 2] = c[W >> 2] & -2;\n                                c[(ad + 4) >> 2] = _ | 1;\n                                c[(Y + _) >> 2] = _;\n                                W = _ >>> 3;\n                                if (_ >>> 0 < 256) {\n                                    K = W << 1;\n                                    Z = (8024 + (K << 2)) | 0;\n                                    S = c[1996] | 0;\n                                    m = 1 << W;\n                                    do {\n                                        if (((S & m) | 0) == 0) {\n                                            c[1996] = S | m;\n                                            aE = Z;\n                                            aF = (8024 + ((K + 2) << 2)) | 0;\n                                        } else {\n                                            W = (8024 + ((K + 2) << 2)) | 0;\n                                            Q = c[W >> 2] | 0;\n                                            if (Q >>> 0 >= (c[2e3] | 0) >>> 0) {\n                                                aE = Q;\n                                                aF = W;\n                                                break;\n                                            }\n                                            aq();\n                                            return 0;\n                                        }\n                                    } while (0);\n                                    c[aF >> 2] = ad;\n                                    c[(aE + 12) >> 2] = ad;\n                                    c[(ad + 8) >> 2] = aE;\n                                    c[(ad + 12) >> 2] = Z;\n                                    break;\n                                }\n                                K = ad;\n                                m = _ >>> 8;\n                                do {\n                                    if ((m | 0) == 0) {\n                                        aG = 0;\n                                    } else {\n                                        if (_ >>> 0 > 16777215) {\n                                            aG = 31;\n                                            break;\n                                        }\n                                        S = (((m + 1048320) | 0) >>> 16) & 8;\n                                        Y = m << S;\n                                        ac = (((Y + 520192) | 0) >>> 16) & 4;\n                                        W = Y << ac;\n                                        Y = (((W + 245760) | 0) >>> 16) & 2;\n                                        Q =\n                                            (14 -\n                                                (ac | S | Y) +\n                                                ((W << Y) >>> 15)) |\n                                            0;\n                                        aG =\n                                            ((_ >>> (((Q + 7) | 0) >>> 0)) &\n                                                1) |\n                                            (Q << 1);\n                                    }\n                                } while (0);\n                                m = (8288 + (aG << 2)) | 0;\n                                c[(ad + 28) >> 2] = aG;\n                                c[(ad + 20) >> 2] = 0;\n                                c[(ad + 16) >> 2] = 0;\n                                Z = c[1997] | 0;\n                                Q = 1 << aG;\n                                if (((Z & Q) | 0) == 0) {\n                                    c[1997] = Z | Q;\n                                    c[m >> 2] = K;\n                                    c[(ad + 24) >> 2] = m;\n                                    c[(ad + 12) >> 2] = ad;\n                                    c[(ad + 8) >> 2] = ad;\n                                    break;\n                                }\n                                if ((aG | 0) == 31) {\n                                    aH = 0;\n                                } else {\n                                    aH = (25 - (aG >>> 1)) | 0;\n                                }\n                                Q = _ << aH;\n                                Z = c[m >> 2] | 0;\n                                while (1) {\n                                    if (\n                                        ((c[(Z + 4) >> 2] & -8) | 0) ==\n                                        (_ | 0)\n                                    ) {\n                                        break;\n                                    }\n                                    aI = (Z + 16 + ((Q >>> 31) << 2)) | 0;\n                                    m = c[aI >> 2] | 0;\n                                    if ((m | 0) == 0) {\n                                        T = 2093;\n                                        break;\n                                    } else {\n                                        Q = Q << 1;\n                                        Z = m;\n                                    }\n                                }\n                                if ((T | 0) == 2093) {\n                                    if (aI >>> 0 < (c[2e3] | 0) >>> 0) {\n                                        aq();\n                                        return 0;\n                                    } else {\n                                        c[aI >> 2] = K;\n                                        c[(ad + 24) >> 2] = Z;\n                                        c[(ad + 12) >> 2] = ad;\n                                        c[(ad + 8) >> 2] = ad;\n                                        break;\n                                    }\n                                }\n                                Q = (Z + 8) | 0;\n                                _ = c[Q >> 2] | 0;\n                                m = c[2e3] | 0;\n                                if (Z >>> 0 < m >>> 0) {\n                                    aq();\n                                    return 0;\n                                }\n                                if (_ >>> 0 < m >>> 0) {\n                                    aq();\n                                    return 0;\n                                } else {\n                                    c[(_ + 12) >> 2] = K;\n                                    c[Q >> 2] = K;\n                                    c[(ad + 8) >> 2] = _;\n                                    c[(ad + 12) >> 2] = Z;\n                                    c[(ad + 24) >> 2] = 0;\n                                    break;\n                                }\n                            }\n                        } while (0);\n                        ad = c[1999] | 0;\n                        if (ad >>> 0 <= o >>> 0) {\n                            break;\n                        }\n                        _ = (ad - o) | 0;\n                        c[1999] = _;\n                        ad = c[2002] | 0;\n                        Q = ad;\n                        c[2002] = Q + o;\n                        c[(Q + (o + 4)) >> 2] = _ | 1;\n                        c[(ad + 4) >> 2] = o | 3;\n                        n = (ad + 8) | 0;\n                        return n | 0;\n                    }\n                } while (0);\n                c[(aQ() | 0) >> 2] = 12;\n                n = 0;\n                return n | 0;\n            }\n            // free\n            function c0(a) {\n                a = a | 0;\n                let b = 0,\n                    d = 0,\n                    e = 0,\n                    f = 0,\n                    g = 0,\n                    h = 0,\n                    i = 0,\n                    j = 0,\n                    k = 0,\n                    l = 0,\n                    m = 0,\n                    n = 0,\n                    o = 0,\n                    p = 0,\n                    q = 0,\n                    r = 0,\n                    s = 0,\n                    t = 0,\n                    u = 0,\n                    v = 0,\n                    w = 0,\n                    x = 0,\n                    y = 0,\n                    z = 0,\n                    A = 0,\n                    B = 0,\n                    C = 0,\n                    D = 0,\n                    E = 0,\n                    F = 0,\n                    G = 0,\n                    H = 0,\n                    I = 0,\n                    J = 0,\n                    K = 0,\n                    L = 0,\n                    M = 0,\n                    N = 0,\n                    O = 0;\n                if ((a | 0) == 0) {\n                    return;\n                }\n                b = (a - 8) | 0;\n                d = b;\n                e = c[2e3] | 0;\n                if (b >>> 0 < e >>> 0) {\n                    aq();\n                }\n                f = c[(a - 4) >> 2] | 0;\n                g = f & 3;\n                if ((g | 0) == 1) {\n                    aq();\n                }\n                h = f & -8;\n                i = (a + (h - 8)) | 0;\n                j = i;\n                L2753: do {\n                    if (((f & 1) | 0) == 0) {\n                        k = c[b >> 2] | 0;\n                        if ((g | 0) == 0) {\n                            return;\n                        }\n                        l = (-8 - k) | 0;\n                        m = (a + l) | 0;\n                        n = m;\n                        o = (k + h) | 0;\n                        if (m >>> 0 < e >>> 0) {\n                            aq();\n                        }\n                        if ((n | 0) == (c[2001] | 0)) {\n                            p = (a + (h - 4)) | 0;\n                            if (((c[p >> 2] & 3) | 0) != 3) {\n                                q = n;\n                                r = o;\n                                break;\n                            }\n                            c[1998] = o;\n                            c[p >> 2] = c[p >> 2] & -2;\n                            c[(a + (l + 4)) >> 2] = o | 1;\n                            c[i >> 2] = o;\n                            return;\n                        }\n                        p = k >>> 3;\n                        if (k >>> 0 < 256) {\n                            k = c[(a + (l + 8)) >> 2] | 0;\n                            s = c[(a + (l + 12)) >> 2] | 0;\n                            t = (8024 + ((p << 1) << 2)) | 0;\n                            do {\n                                if ((k | 0) != (t | 0)) {\n                                    if (k >>> 0 < e >>> 0) {\n                                        aq();\n                                    }\n                                    if ((c[(k + 12) >> 2] | 0) == (n | 0)) {\n                                        break;\n                                    }\n                                    aq();\n                                }\n                            } while (0);\n                            if ((s | 0) == (k | 0)) {\n                                c[1996] = c[1996] & ~(1 << p);\n                                q = n;\n                                r = o;\n                                break;\n                            }\n                            do {\n                                if ((s | 0) == (t | 0)) {\n                                    u = (s + 8) | 0;\n                                } else {\n                                    if (s >>> 0 < e >>> 0) {\n                                        aq();\n                                    }\n                                    v = (s + 8) | 0;\n                                    if ((c[v >> 2] | 0) == (n | 0)) {\n                                        u = v;\n                                        break;\n                                    }\n                                    aq();\n                                }\n                            } while (0);\n                            c[(k + 12) >> 2] = s;\n                            c[u >> 2] = k;\n                            q = n;\n                            r = o;\n                            break;\n                        }\n                        t = m;\n                        p = c[(a + (l + 24)) >> 2] | 0;\n                        v = c[(a + (l + 12)) >> 2] | 0;\n                        do {\n                            if ((v | 0) == (t | 0)) {\n                                w = (a + (l + 20)) | 0;\n                                x = c[w >> 2] | 0;\n                                if ((x | 0) == 0) {\n                                    y = (a + (l + 16)) | 0;\n                                    z = c[y >> 2] | 0;\n                                    if ((z | 0) == 0) {\n                                        A = 0;\n                                        break;\n                                    } else {\n                                        B = z;\n                                        C = y;\n                                    }\n                                } else {\n                                    B = x;\n                                    C = w;\n                                }\n                                while (1) {\n                                    w = (B + 20) | 0;\n                                    x = c[w >> 2] | 0;\n                                    if ((x | 0) != 0) {\n                                        B = x;\n                                        C = w;\n                                        continue;\n                                    }\n                                    w = (B + 16) | 0;\n                                    x = c[w >> 2] | 0;\n                                    if ((x | 0) == 0) {\n                                        break;\n                                    } else {\n                                        B = x;\n                                        C = w;\n                                    }\n                                }\n                                if (C >>> 0 < e >>> 0) {\n                                    aq();\n                                } else {\n                                    c[C >> 2] = 0;\n                                    A = B;\n                                    break;\n                                }\n                            } else {\n                                w = c[(a + (l + 8)) >> 2] | 0;\n                                if (w >>> 0 < e >>> 0) {\n                                    aq();\n                                }\n                                x = (w + 12) | 0;\n                                if ((c[x >> 2] | 0) != (t | 0)) {\n                                    aq();\n                                }\n                                y = (v + 8) | 0;\n                                if ((c[y >> 2] | 0) == (t | 0)) {\n                                    c[x >> 2] = v;\n                                    c[y >> 2] = w;\n                                    A = v;\n                                    break;\n                                } else {\n                                    aq();\n                                }\n                            }\n                        } while (0);\n                        if ((p | 0) == 0) {\n                            q = n;\n                            r = o;\n                            break;\n                        }\n                        v = (a + (l + 28)) | 0;\n                        m = (8288 + (c[v >> 2] << 2)) | 0;\n                        do {\n                            if ((t | 0) == (c[m >> 2] | 0)) {\n                                c[m >> 2] = A;\n                                if ((A | 0) != 0) {\n                                    break;\n                                }\n                                c[1997] = c[1997] & ~(1 << c[v >> 2]);\n                                q = n;\n                                r = o;\n                                break L2753;\n                            } else {\n                                if (p >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                }\n                                k = (p + 16) | 0;\n                                if ((c[k >> 2] | 0) == (t | 0)) {\n                                    c[k >> 2] = A;\n                                } else {\n                                    c[(p + 20) >> 2] = A;\n                                }\n                                if ((A | 0) == 0) {\n                                    q = n;\n                                    r = o;\n                                    break L2753;\n                                }\n                            }\n                        } while (0);\n                        if (A >>> 0 < (c[2e3] | 0) >>> 0) {\n                            aq();\n                        }\n                        c[(A + 24) >> 2] = p;\n                        t = c[(a + (l + 16)) >> 2] | 0;\n                        do {\n                            if ((t | 0) != 0) {\n                                if (t >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                } else {\n                                    c[(A + 16) >> 2] = t;\n                                    c[(t + 24) >> 2] = A;\n                                    break;\n                                }\n                            }\n                        } while (0);\n                        t = c[(a + (l + 20)) >> 2] | 0;\n                        if ((t | 0) == 0) {\n                            q = n;\n                            r = o;\n                            break;\n                        }\n                        if (t >>> 0 < (c[2e3] | 0) >>> 0) {\n                            aq();\n                        } else {\n                            c[(A + 20) >> 2] = t;\n                            c[(t + 24) >> 2] = A;\n                            q = n;\n                            r = o;\n                            break;\n                        }\n                    } else {\n                        q = d;\n                        r = h;\n                    }\n                } while (0);\n                d = q;\n                if (d >>> 0 >= i >>> 0) {\n                    aq();\n                }\n                A = (a + (h - 4)) | 0;\n                e = c[A >> 2] | 0;\n                if (((e & 1) | 0) == 0) {\n                    aq();\n                }\n                do {\n                    if (((e & 2) | 0) == 0) {\n                        if ((j | 0) == (c[2002] | 0)) {\n                            B = ((c[1999] | 0) + r) | 0;\n                            c[1999] = B;\n                            c[2002] = q;\n                            c[(q + 4) >> 2] = B | 1;\n                            if ((q | 0) != (c[2001] | 0)) {\n                                return;\n                            }\n                            c[2001] = 0;\n                            c[1998] = 0;\n                            return;\n                        }\n                        if ((j | 0) == (c[2001] | 0)) {\n                            B = ((c[1998] | 0) + r) | 0;\n                            c[1998] = B;\n                            c[2001] = q;\n                            c[(q + 4) >> 2] = B | 1;\n                            c[(d + B) >> 2] = B;\n                            return;\n                        }\n                        B = ((e & -8) + r) | 0;\n                        C = e >>> 3;\n                        L2856: do {\n                            if (e >>> 0 < 256) {\n                                u = c[(a + h) >> 2] | 0;\n                                g = c[(a + (h | 4)) >> 2] | 0;\n                                b = (8024 + ((C << 1) << 2)) | 0;\n                                do {\n                                    if ((u | 0) != (b | 0)) {\n                                        if (u >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                        }\n                                        if ((c[(u + 12) >> 2] | 0) == (j | 0)) {\n                                            break;\n                                        }\n                                        aq();\n                                    }\n                                } while (0);\n                                if ((g | 0) == (u | 0)) {\n                                    c[1996] = c[1996] & ~(1 << C);\n                                    break;\n                                }\n                                do {\n                                    if ((g | 0) == (b | 0)) {\n                                        D = (g + 8) | 0;\n                                    } else {\n                                        if (g >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                        }\n                                        f = (g + 8) | 0;\n                                        if ((c[f >> 2] | 0) == (j | 0)) {\n                                            D = f;\n                                            break;\n                                        }\n                                        aq();\n                                    }\n                                } while (0);\n                                c[(u + 12) >> 2] = g;\n                                c[D >> 2] = u;\n                            } else {\n                                b = i;\n                                f = c[(a + (h + 16)) >> 2] | 0;\n                                t = c[(a + (h | 4)) >> 2] | 0;\n                                do {\n                                    if ((t | 0) == (b | 0)) {\n                                        p = (a + (h + 12)) | 0;\n                                        v = c[p >> 2] | 0;\n                                        if ((v | 0) == 0) {\n                                            m = (a + (h + 8)) | 0;\n                                            k = c[m >> 2] | 0;\n                                            if ((k | 0) == 0) {\n                                                E = 0;\n                                                break;\n                                            } else {\n                                                F = k;\n                                                G = m;\n                                            }\n                                        } else {\n                                            F = v;\n                                            G = p;\n                                        }\n                                        while (1) {\n                                            p = (F + 20) | 0;\n                                            v = c[p >> 2] | 0;\n                                            if ((v | 0) != 0) {\n                                                F = v;\n                                                G = p;\n                                                continue;\n                                            }\n                                            p = (F + 16) | 0;\n                                            v = c[p >> 2] | 0;\n                                            if ((v | 0) == 0) {\n                                                break;\n                                            } else {\n                                                F = v;\n                                                G = p;\n                                            }\n                                        }\n                                        if (G >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                        } else {\n                                            c[G >> 2] = 0;\n                                            E = F;\n                                            break;\n                                        }\n                                    } else {\n                                        p = c[(a + h) >> 2] | 0;\n                                        if (p >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                        }\n                                        v = (p + 12) | 0;\n                                        if ((c[v >> 2] | 0) != (b | 0)) {\n                                            aq();\n                                        }\n                                        m = (t + 8) | 0;\n                                        if ((c[m >> 2] | 0) == (b | 0)) {\n                                            c[v >> 2] = t;\n                                            c[m >> 2] = p;\n                                            E = t;\n                                            break;\n                                        } else {\n                                            aq();\n                                        }\n                                    }\n                                } while (0);\n                                if ((f | 0) == 0) {\n                                    break;\n                                }\n                                t = (a + (h + 20)) | 0;\n                                u = (8288 + (c[t >> 2] << 2)) | 0;\n                                do {\n                                    if ((b | 0) == (c[u >> 2] | 0)) {\n                                        c[u >> 2] = E;\n                                        if ((E | 0) != 0) {\n                                            break;\n                                        }\n                                        c[1997] = c[1997] & ~(1 << c[t >> 2]);\n                                        break L2856;\n                                    } else {\n                                        if (f >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                        }\n                                        g = (f + 16) | 0;\n                                        if ((c[g >> 2] | 0) == (b | 0)) {\n                                            c[g >> 2] = E;\n                                        } else {\n                                            c[(f + 20) >> 2] = E;\n                                        }\n                                        if ((E | 0) == 0) {\n                                            break L2856;\n                                        }\n                                    }\n                                } while (0);\n                                if (E >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                }\n                                c[(E + 24) >> 2] = f;\n                                b = c[(a + (h + 8)) >> 2] | 0;\n                                do {\n                                    if ((b | 0) != 0) {\n                                        if (b >>> 0 < (c[2e3] | 0) >>> 0) {\n                                            aq();\n                                        } else {\n                                            c[(E + 16) >> 2] = b;\n                                            c[(b + 24) >> 2] = E;\n                                            break;\n                                        }\n                                    }\n                                } while (0);\n                                b = c[(a + (h + 12)) >> 2] | 0;\n                                if ((b | 0) == 0) {\n                                    break;\n                                }\n                                if (b >>> 0 < (c[2e3] | 0) >>> 0) {\n                                    aq();\n                                } else {\n                                    c[(E + 20) >> 2] = b;\n                                    c[(b + 24) >> 2] = E;\n                                    break;\n                                }\n                            }\n                        } while (0);\n                        c[(q + 4) >> 2] = B | 1;\n                        c[(d + B) >> 2] = B;\n                        if ((q | 0) != (c[2001] | 0)) {\n                            H = B;\n                            break;\n                        }\n                        c[1998] = B;\n                        return;\n                    } else {\n                        c[A >> 2] = e & -2;\n                        c[(q + 4) >> 2] = r | 1;\n                        c[(d + r) >> 2] = r;\n                        H = r;\n                    }\n                } while (0);\n                r = H >>> 3;\n                if (H >>> 0 < 256) {\n                    d = r << 1;\n                    e = (8024 + (d << 2)) | 0;\n                    A = c[1996] | 0;\n                    E = 1 << r;\n                    do {\n                        if (((A & E) | 0) == 0) {\n                            c[1996] = A | E;\n                            I = e;\n                            J = (8024 + ((d + 2) << 2)) | 0;\n                        } else {\n                            r = (8024 + ((d + 2) << 2)) | 0;\n                            h = c[r >> 2] | 0;\n                            if (h >>> 0 >= (c[2e3] | 0) >>> 0) {\n                                I = h;\n                                J = r;\n                                break;\n                            }\n                            aq();\n                        }\n                    } while (0);\n                    c[J >> 2] = q;\n                    c[(I + 12) >> 2] = q;\n                    c[(q + 8) >> 2] = I;\n                    c[(q + 12) >> 2] = e;\n                    return;\n                }\n                e = q;\n                I = H >>> 8;\n                do {\n                    if ((I | 0) == 0) {\n                        K = 0;\n                    } else {\n                        if (H >>> 0 > 16777215) {\n                            K = 31;\n                            break;\n                        }\n                        J = (((I + 1048320) | 0) >>> 16) & 8;\n                        d = I << J;\n                        E = (((d + 520192) | 0) >>> 16) & 4;\n                        A = d << E;\n                        d = (((A + 245760) | 0) >>> 16) & 2;\n                        r = (14 - (E | J | d) + ((A << d) >>> 15)) | 0;\n                        K = ((H >>> (((r + 7) | 0) >>> 0)) & 1) | (r << 1);\n                    }\n                } while (0);\n                I = (8288 + (K << 2)) | 0;\n                c[(q + 28) >> 2] = K;\n                c[(q + 20) >> 2] = 0;\n                c[(q + 16) >> 2] = 0;\n                r = c[1997] | 0;\n                d = 1 << K;\n                do {\n                    if (((r & d) | 0) == 0) {\n                        c[1997] = r | d;\n                        c[I >> 2] = e;\n                        c[(q + 24) >> 2] = I;\n                        c[(q + 12) >> 2] = q;\n                        c[(q + 8) >> 2] = q;\n                    } else {\n                        if ((K | 0) == 31) {\n                            L = 0;\n                        } else {\n                            L = (25 - (K >>> 1)) | 0;\n                        }\n                        A = H << L;\n                        J = c[I >> 2] | 0;\n                        while (1) {\n                            if (((c[(J + 4) >> 2] & -8) | 0) == (H | 0)) {\n                                break;\n                            }\n                            M = (J + 16 + ((A >>> 31) << 2)) | 0;\n                            E = c[M >> 2] | 0;\n                            if ((E | 0) == 0) {\n                                N = 2270;\n                                break;\n                            } else {\n                                A = A << 1;\n                                J = E;\n                            }\n                        }\n                        if ((N | 0) == 2270) {\n                            if (M >>> 0 < (c[2e3] | 0) >>> 0) {\n                                aq();\n                            } else {\n                                c[M >> 2] = e;\n                                c[(q + 24) >> 2] = J;\n                                c[(q + 12) >> 2] = q;\n                                c[(q + 8) >> 2] = q;\n                                break;\n                            }\n                        }\n                        A = (J + 8) | 0;\n                        B = c[A >> 2] | 0;\n                        E = c[2e3] | 0;\n                        if (J >>> 0 < E >>> 0) {\n                            aq();\n                        }\n                        if (B >>> 0 < E >>> 0) {\n                            aq();\n                        } else {\n                            c[(B + 12) >> 2] = e;\n                            c[A >> 2] = e;\n                            c[(q + 8) >> 2] = B;\n                            c[(q + 12) >> 2] = J;\n                            c[(q + 24) >> 2] = 0;\n                            break;\n                        }\n                    }\n                } while (0);\n                q = ((c[2004] | 0) - 1) | 0;\n                c[2004] = q;\n                if ((q | 0) == 0) {\n                    O = 8440;\n                } else {\n                    return;\n                }\n                while (1) {\n                    q = c[O >> 2] | 0;\n                    if ((q | 0) == 0) {\n                        break;\n                    } else {\n                        O = (q + 8) | 0;\n                    }\n                }\n                c[2004] = -1;\n                return;\n            }\n            function c1(b) {\n                b = b | 0;\n                let c = 0;\n                c = b;\n                while (a[c] | 0) {\n                    c = (c + 1) | 0;\n                }\n                return (c - b) | 0;\n            }\n            function c2(b, c) {\n                b = b | 0;\n                c = c | 0;\n                let d = 0;\n                do {\n                    a[(b + d) | 0] = a[(c + d) | 0];\n                    d = (d + 1) | 0;\n                } while (a[(c + (d - 1)) | 0] | 0);\n                return b | 0;\n            }\n            function c3(b, c) {\n                b = b | 0;\n                c = c | 0;\n                let d = 0,\n                    e = 0;\n                d = (b + (c1(b) | 0)) | 0;\n                do {\n                    a[(d + e) | 0] = a[(c + e) | 0];\n                    e = (e + 1) | 0;\n                } while (a[(c + (e - 1)) | 0] | 0);\n                return b | 0;\n            }\n            function c4(a, b, c) {\n                a = a | 0;\n                b = b | 0;\n                c = c | 0;\n                let e = 0,\n                    f = 0,\n                    g = 0;\n                while ((e | 0) < (c | 0)) {\n                    f = d[(a + e) | 0] | 0;\n                    g = d[(b + e) | 0] | 0;\n                    if ((f | 0) != (g | 0))\n                        return ((f | 0) > (g | 0) ? 1 : -1) | 0;\n                    e = (e + 1) | 0;\n                }\n                return 0;\n            }\n            function c5(b, d, e) {\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0,\n                    g = 0,\n                    h = 0;\n                f = (b + e) | 0;\n                if ((e | 0) >= 20) {\n                    d = d & 255;\n                    e = b & 3;\n                    g = d | (d << 8) | (d << 16) | (d << 24);\n                    h = f & ~3;\n                    if (e) {\n                        e = (b + 4 - e) | 0;\n                        while ((b | 0) < (e | 0)) {\n                            a[b] = d;\n                            b = (b + 1) | 0;\n                        }\n                    }\n                    while ((b | 0) < (h | 0)) {\n                        c[b >> 2] = g;\n                        b = (b + 4) | 0;\n                    }\n                }\n                while ((b | 0) < (f | 0)) {\n                    a[b] = d;\n                    b = (b + 1) | 0;\n                }\n            }\n            function c6(b, d, e) {\n                b = b | 0;\n                d = d | 0;\n                e = e | 0;\n                let f = 0;\n                f = b | 0;\n                if ((b & 3) == (d & 3)) {\n                    while (b & 3) {\n                        if ((e | 0) == 0) return f | 0;\n                        a[b] = a[d] | 0;\n                        b = (b + 1) | 0;\n                        d = (d + 1) | 0;\n                        e = (e - 1) | 0;\n                    }\n                    while ((e | 0) >= 4) {\n                        c[b >> 2] = c[d >> 2];\n                        b = (b + 4) | 0;\n                        d = (d + 4) | 0;\n                        e = (e - 4) | 0;\n                    }\n                }\n                while ((e | 0) > 0) {\n                    a[b] = a[d] | 0;\n                    b = (b + 1) | 0;\n                    d = (d + 1) | 0;\n                    e = (e - 1) | 0;\n                }\n                return f | 0;\n            }\n            function c7(b, c, d) {\n                b = b | 0;\n                c = c | 0;\n                d = d | 0;\n                let e = 0,\n                    f = 0;\n                while ((e | 0) < (d | 0)) {\n                    a[(b + e) | 0] = f ? 0 : a[(c + e) | 0] | 0;\n                    f = f ? 1 : (a[(c + e) | 0] | 0) == 0;\n                    e = (e + 1) | 0;\n                }\n                return b | 0;\n            }\n            function c8(a, b) {\n                a = a | 0;\n                b = b | 0;\n                return aW[a & 7](b | 0) | 0;\n            }\n            function c9(a, b) {\n                a = a | 0;\n                b = b | 0;\n                aX[a & 1](b | 0);\n            }\n            function da(a, b, c, d, e) {\n                a = a | 0;\n                b = b | 0;\n                c = c | 0;\n                d = d | 0;\n                e = e | 0;\n                return aY[a & 7](b | 0, c | 0, d | 0, e | 0) | 0;\n            }\n            function db(a, b, c, d) {\n                a = a | 0;\n                b = b | 0;\n                c = c | 0;\n                d = d | 0;\n                aZ[a & 15](b | 0, c | 0, d | 0);\n            }\n            function dc(a) {\n                a = a | 0;\n                a_[a & 1]();\n            }\n            function dd(a, b, c) {\n                a = a | 0;\n                b = b | 0;\n                c = c | 0;\n                return a$[a & 1](b | 0, c | 0) | 0;\n            }\n            function de(a) {\n                a = a | 0;\n                $(0);\n                return 0;\n            }\n            function df(a) {\n                a = a | 0;\n                $(1);\n            }\n            function dg(a, b, c, d) {\n                a = a | 0;\n                b = b | 0;\n                c = c | 0;\n                d = d | 0;\n                $(2);\n                return 0;\n            }\n            function dh(a, b, c) {\n                a = a | 0;\n                b = b | 0;\n                c = c | 0;\n                $(3);\n            }\n            function di() {\n                $(4);\n            }\n            function dj(a, b) {\n                a = a | 0;\n                b = b | 0;\n                $(5);\n                return 0;\n            }\n\n            // EMSCRIPTEN_END_FUNCS\n\n            var aW = [de, de, cL, de, cJ, de, de, de];\n            var aX = [df, df];\n            var aY = [dg, dg, cI, dg, cK, dg, dg, dg];\n            var aZ = [\n                dh,\n                dh,\n                bZ,\n                dh,\n                b$,\n                dh,\n                b_,\n                dh,\n                bY,\n                dh,\n                bX,\n                dh,\n                dh,\n                dh,\n                dh,\n                dh\n            ];\n            var a_ = [di, di];\n            var a$ = [dj, dj];\n            return {\n                _strlen: c1,\n                _strcat: c3,\n                _mid_create_options: cV,\n                _mid_istream_open_mem: cO,\n                _mid_istream_open_file: cN,\n                _mid_song_read_wave: b6,\n                _mid_exit: cZ,\n                _mid_song_note_on: b0,\n                _strncpy: c7,\n                _memset: c5,\n                _memcpy: c6,\n                _mid_song_get_missing_instrument: bu,\n                _mid_istream_close: cR,\n                _mid_song_free: cY,\n                _mid_init: cT,\n                _mid_song_load: cX,\n                _mid_song_start: b3,\n                _mid_song_get_num_missing_instruments: bt,\n                _memcmp: c4,\n                _free: c0,\n                _malloc: c$,\n                _strcpy: c2,\n                runPostSets: bg,\n                stackAlloc: a0,\n                stackSave: a1,\n                stackRestore: a2,\n                setThrew: a3,\n                setTempRet0: a6,\n                setTempRet1: a7,\n                setTempRet2: a8,\n                setTempRet3: a9,\n                setTempRet4: ba,\n                setTempRet5: bb,\n                setTempRet6: bc,\n                setTempRet7: bd,\n                setTempRet8: be,\n                setTempRet9: bf,\n                dynCall_ii: c8,\n                dynCall_vi: c9,\n                dynCall_iiiii: da,\n                dynCall_viii: db,\n                dynCall_v: dc,\n                dynCall_iii: dd\n            };\n        })(\n            // EMSCRIPTEN_END_ASM\n\n            {\n                Math: Math,\n                Int8Array: Int8Array,\n                Int16Array: Int16Array,\n                Int32Array: Int32Array,\n                Uint8Array: Uint8Array,\n                Uint16Array: Uint16Array,\n                Uint32Array: Uint32Array,\n                Float32Array: Float32Array,\n                Float64Array: Float64Array\n            },\n            {\n                abort: abort,\n                assert: assert,\n                asmPrintInt: asmPrintInt,\n                asmPrintFloat: asmPrintFloat,\n                min: Math_min,\n                invoke_ii: invoke_ii,\n                invoke_vi: invoke_vi,\n                invoke_iiiii: invoke_iiiii,\n                invoke_viii: invoke_viii,\n                invoke_v: invoke_v,\n                invoke_iii: invoke_iii,\n                _strncmp: _strncmp,\n                _lseek: _lseek,\n                _sysconf: _sysconf,\n                _fread: _fread,\n                _fclose: _fclose,\n                _strtok_r: _strtok_r,\n                _abort: _abort,\n                _fprintf: _fprintf,\n                _close: _close,\n                _pread: _pread,\n                _fflush: _fflush,\n                _fopen: _fopen,\n                _open: _open,\n                _strtol: _strtol,\n                _strtok: _strtok,\n                ___setErrNo: ___setErrNo,\n                __reallyNegative: __reallyNegative,\n                _fseek: _fseek,\n                _send: _send,\n                _write: _write,\n                _strrchr: _strrchr,\n                _sin: _sin,\n                _printf: _printf,\n                _strchr: _strchr,\n                _read: _read,\n                _time: _time,\n                __formatString: __formatString,\n                _atoi: _atoi,\n                _recv: _recv,\n                _pwrite: _pwrite,\n                _llvm_pow_f64: _llvm_pow_f64,\n                _fsync: _fsync,\n                ___errno_location: ___errno_location,\n                _isspace: _isspace,\n                _sbrk: _sbrk,\n                __parseInt: __parseInt,\n                _fwrite: _fwrite,\n                _strcmp: _strcmp,\n                STACKTOP: STACKTOP,\n                STACK_MAX: STACK_MAX,\n                tempDoublePtr: tempDoublePtr,\n                ABORT: ABORT,\n                NaN: NaN,\n                Infinity: Infinity,\n                _stderr: _stderr\n            },\n            buffer\n        );\n        var _strlen = (Module['_strlen'] = asm['_strlen']);\n        var _strcat = (Module['_strcat'] = asm['_strcat']);\n        Module['_mid_create_options'] = asm['_mid_create_options'];\n        Module['_mid_istream_open_mem'] = asm['_mid_istream_open_mem'];\n        Module['_mid_istream_open_file'] = asm['_mid_istream_open_file'];\n        Module['_mid_song_read_wave'] = asm['_mid_song_read_wave'];\n        Module['_mid_exit'] = asm['_mid_exit'];\n        Module['_mid_song_note_on'] = asm['_mid_song_note_on'];\n        var _strncpy = (Module['_strncpy'] = asm['_strncpy']);\n        var _memset = (Module['_memset'] = asm['_memset']);\n        var _memcpy = (Module['_memcpy'] = asm['_memcpy']);\n        Module['_mid_song_get_missing_instrument'] =\n            asm['_mid_song_get_missing_instrument'];\n        Module['_mid_istream_close'] = asm['_mid_istream_close'];\n        Module['_mid_song_free'] = asm['_mid_song_free'];\n        Module['_mid_init'] = asm['_mid_init'];\n        Module['_mid_song_load'] = asm['_mid_song_load'];\n        Module['_mid_song_start'] = asm['_mid_song_start'];\n        Module['_mid_song_get_num_missing_instruments'] =\n            asm['_mid_song_get_num_missing_instruments'];\n        var _memcmp = (Module['_memcmp'] = asm['_memcmp']);\n        Module['_free'] = asm['_free'];\n        var _malloc = (Module._malloc = asm['_malloc']);\n        var _strcpy = (Module['_strcpy'] = asm['_strcpy']);\n        const runPostSets = (Module['runPostSets'] = asm['runPostSets']);\n\n        Module['dynCall_ii'] = asm['dynCall_ii'];\n        Module['dynCall_vi'] = asm['dynCall_vi'];\n        Module['dynCall_iiiii'] = asm['dynCall_iiiii'];\n        Module['dynCall_viii'] = asm['dynCall_viii'];\n        Module['dynCall_v'] = asm['dynCall_v'];\n        Module['dynCall_iii'] = asm['dynCall_iii'];\n\n        Runtime.stackAlloc = function(size) {\n            return asm['stackAlloc'](size);\n        };\n        Runtime.stackSave = function() {\n            return asm['stackSave']();\n        };\n        Runtime.stackRestore = function(top) {\n            asm['stackRestore'](top);\n        };\n\n        // Warning: printing of i64 values may be slightly rounded! No deep i64 math used, so precise i64 code not included\n        var i64Math = null;\n\n        // === Auto-generated postamble setup entry stuff ===\n\n        if (memoryInitializer) {\n            function applyData(data) {\n                HEAPU8.set(data, STATIC_BASE);\n            }\n            addRunDependency('memory initializer');\n        }\n\n        var initialStackTop;\n        let calledRun = false;\n        dependenciesFulfilled = function runCaller() {\n            // If run has never been called, and we should call run (INVOKE_RUN is true, and Module.noInitialRun is not false)\n            if (!calledRun && shouldRunNow) run();\n            if (!calledRun) dependenciesFulfilled = runCaller; // try this again later, after new deps are fulfilled\n        };\n\n        Module['callMain'] = Module.callMain = function callMain(args) {\n            assert(\n                runDependencies == 0,\n                'cannot call main when async dependencies remain! (listen on __ATMAIN__)'\n            );\n            assert(\n                __ATPRERUN__.length == 0,\n                'cannot call main when preRun functions remain to be called'\n            );\n            args = args || [];\n            ensureInitRuntime();\n            const argc = args.length + 1;\n            function pad() {\n                for (let i = 0; i < 4 - 1; i++) {\n                    argv.push(0);\n                }\n            }\n            var argv = [\n                allocate(\n                    intArrayFromString('/bin/this.program'),\n                    'i8',\n                    ALLOC_NORMAL\n                )\n            ];\n            pad();\n            for (var i = 0; i < argc - 1; i = i + 1) {\n                argv.push(\n                    allocate(intArrayFromString(args[i]), 'i8', ALLOC_NORMAL)\n                );\n                pad();\n            }\n            argv.push(0);\n            argv = allocate(argv, 'i32', ALLOC_NORMAL);\n            initialStackTop = STACKTOP;\n            try {\n                const ret = Module['_main'](argc, argv, 0);\n                // if we're not running an evented main loop, it's time to exit\n                if (!Module['noExitRuntime']) {\n                    exit(ret);\n                }\n            } catch (e) {\n                if (e instanceof ExitStatus) {\n                    // exit() throws this once it's done to make sure execution has been stopped completely\n                    return;\n                } else if (e == 'SimulateInfiniteLoop') {\n                    // running an evented main loop, don't immediately exit\n                    Module['noExitRuntime'] = true;\n                    return;\n                } else {\n                    throw e;\n                }\n            }\n        };\n\n        function run(args) {\n            args = args || Module['arguments'];\n            if (runDependencies > 0) {\n                console.warn(\n                    'run() called, but dependencies remain, so not running'\n                );\n                return FS;\n            }\n            preRun();\n            if (runDependencies > 0) {\n                // a preRun added a dependency, run will be called later\n                return FS;\n            }\n            function doRun() {\n                ensureInitRuntime();\n                preMain();\n                calledRun = true;\n                if (Module['_main'] && shouldRunNow) {\n                    Module['callMain'](args);\n                }\n                postRun();\n            }\n            if (Module['setStatus']) {\n                Module['setStatus']('Running...');\n                setTimeout(function() {\n                    setTimeout(function() {\n                        Module['setStatus']('');\n                    }, 1);\n                    if (!ABORT) doRun();\n                }, 1);\n            } else {\n                doRun();\n            }\n\n            return FS;\n        }\n\n        Module.run = run;\n\n        /**\n         * Initializes the library.\n         * @function init\n         * @memberof LibTiMidity\n         * @param {boolean} [throwError = true] Throw an error if file/folder creation failed.\n         * @instance\n         */\n        Module.init = function(throwError = true) {\n            // creates folders for instrument patches\n            Module.createPath('/', LIBTIMIDITY_PATCH_DIRECTORY, throwError);\n            Module.createPath(\n                `/${LIBTIMIDITY_PATCH_DIRECTORY}`,\n                LIBTIMIDITY_PATCH_DRUM_DIRECTORY,\n                throwError\n            );\n\n            // creates config file\n            Module.createDataFile(\n                '/',\n                LIBTIMIDITY_CONFIG_FILE,\n                LIBTIMIDITY_CONFIG_DATA,\n                true,\n                true,\n                undefined,\n                throwError\n            );\n        };\n\n        // shouldRunNow refers to calling main(), not run().\n        var shouldRunNow = true;\n\n        if (Module['noInitialRun']) {\n            shouldRunNow = false;\n        }\n\n        Module.FS = run();\n\n        this.Module = Module;\n    }\n}\n\nconst libtimidity = new LibTiMidity();\n\nexport default libtimidity.Module;\n","export const MIDI_INIT = 'MIDI_INIT';\n\nexport const MIDI_ERROR = 'MIDI_ERROR';\n\nexport const MIDI_STATUS = 'MIDI_STATUS';\n\nexport const MIDI_PRELOAD = 'MIDI_PRELOAD';\n\nexport const MIDI_LOAD_FILE = 'MIDI_LOAD_FILE';\n\nexport const MIDI_LOAD_PATCH = 'MIDI_LOAD_PATCH';\n\nexport const MIDI_PLAY = 'MIDI_PLAY';\n\nexport const MIDI_PAUSE = 'MIDI_PAUSE';\n\nexport const MIDI_RESUME = 'MIDI_RESUME';\n\nexport const MIDI_STOP = 'MIDI_STOP';\n\nexport const MIDI_END = 'MIDI_END';\n","import {\n    MIDI_INIT,\n    MIDI_LOAD_FILE,\n    MIDI_LOAD_PATCH,\n    MIDI_PLAY,\n    MIDI_PAUSE,\n    MIDI_RESUME,\n    MIDI_STOP,\n    MIDI_END,\n    MIDI_ERROR\n} from './events';\n\nexport default class EventHandler {\n    /**\n     * @class EventHandler\n     * @param {object} [configuration]\n     * @param {string} [configuration.playerId = undefined] The ID of the Midi Player that sends events.\n     * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\n     * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\n     * @return {object} An `EventHandler` instance.\n     */\n    constructor({\n        eventLogger = undefined,\n        logging = false,\n        playerId = undefined\n    }) {\n        this.playerId = playerId;\n        this.logging = logging;\n        this.eventLogger = eventLogger;\n    }\n\n    /**\n     * Emits an event that indicates that the MIDI player is initialized.\n     * @function\n     * @param {undefined}\n     */\n    emitInit() {\n        this.emitEvent({\n            event: MIDI_INIT,\n            message: 'MIDI player initialized.'\n        });\n    }\n\n    /**\n     * Emits an event that indicates that a MIDI file is being loaded.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.message] A message about the MIDI file being loaded.\n     */\n    emitLoadFile = ({ message = 'Loading MIDI file...' }) => {\n        this.emitEvent({\n            event: MIDI_LOAD_FILE,\n            message\n        });\n    };\n\n    /**\n     * Emits an event that indicates that a MIDI instrument patch is being loaded.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.message] A message about the instrument patch being loaded.\n     */\n    emitLoadPatch = ({ message = 'Loading instrument patch...' }) => {\n        this.emitEvent({\n            event: MIDI_LOAD_PATCH,\n            message\n        });\n    };\n\n    /**\n     * Emits an event that indicates that the MIDI player currently playing a MIDI file.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.time] The playback position.\n     */\n    emitPlay({ time }) {\n        this.emitEvent({\n            event: MIDI_PLAY,\n            time\n        });\n    }\n\n    /**\n     * Emits an event that indicates that the MIDI player has paused the playback of a file.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.time] The playback position.\n     */\n    emitPause({ time }) {\n        this.emitEvent({\n            event: MIDI_PAUSE,\n            time\n        });\n    }\n\n    /**\n     * Emits an event that indicates that the MIDI player has resumed the playback of a file.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.time] The playback position.\n     */\n    emitResume({ time }) {\n        this.emitEvent({\n            event: MIDI_RESUME,\n            time\n        });\n    }\n\n    /**\n     * Emits an event that indicates that the MIDI player has stopped the playback of a file.\n     * @function\n     * @param {undefined}\n     */\n    emitStop() {\n        this.emitEvent({\n            event: MIDI_STOP,\n            time: 0\n        });\n    }\n\n    /**\n     * Emits an event that indicates that the MIDI player has reached the end of a file.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.time] The playback position.\n     */\n    emitEnd({ time }) {\n        this.emitEvent({\n            event: MIDI_END,\n            time\n        });\n    }\n\n    /**\n     * Emits an event that indicates that an error prevented the MIDI player to continue.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.message] A message that indicates that an error occurred.\n     * @param {string} [payload.error] A message that describes the details of the error.\n     */\n    emitError = ({ message = 'An error occurred.', error = '' }) => {\n        this.emitEvent({\n            event: MIDI_ERROR,\n            message,\n            error\n        });\n    };\n\n    /**\n     * Send payloads to the event logger.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.event] The name of the event.\n     * @param {string} [payload.message] A message that describes the event.\n     */\n    emitEvent = payload => {\n        const payloadWithId = {\n            ...payload,\n            playerId: this.playerId\n        };\n\n        if (this.eventLogger) {\n            this.eventLogger(payloadWithId);\n        } else if (this.logging) {\n            if (payloadWithId.event === MIDI_ERROR) {\n                console.error(payloadWithId);\n            } else {\n                console.log(payloadWithId);\n            }\n        }\n    };\n\n    /**\n     * Updates the configuration of the logger.\n     * @function\n     * @param {object} [configuration]\n     * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\n     * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\n     */\n    setLogger({ eventLogger = undefined, logging = false }) {\n        this.eventLogger = eventLogger;\n\n        this.logging = logging;\n    }\n}\n","import uuid from 'uuid/v4';\n\nimport {\n    MIDI_AUDIO_BUFFER_SIZE,\n    MIDI_DEFAULT_PATCH_URL,\n    MIDI_AUDIO_S16LSB,\n    MAX_I16\n} from './constants';\n\nimport LibTiMidity from './LibTiMidity';\nimport EventHandler from './EventHandler';\n\nlet isFirstInstance = true;\n\nexport default class MidiPlayer {\n    /**\n     * @class MidiPlayer\n     * @param {object} [configuration]\n     * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\n     * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\n     * @param {string} [configuration.patchUrl = https://cdn.jsdelivr.net/npm/midi-instrument-patches@latest/] The public path where MIDI instrument patches can be found.\n     * @property {string} playerId ID of this instance of Midi Player.\n     * @property {object} context The AudioContext instance.\n     * @property {number} sampleRate The sample rate of the AudioContext.\n     * @property {function} eventLogger The function that is called to emit events.\n     * @property {boolean} logging Whether console logging is ON or OFF.\n     * @property {arrayBuffer} midiFileArray A typed array that represents the content of the MIDI.\n     * @property {*} midiFileBuffer The buffer with the MIDI data.\n     * @property {string} patchUrl The URL used to load MIDI instrument patches.\n     * @property {object} source The source that plays the audio signal.\n     * @property {number} startTime The time when MIDI playback started.\n     * @property {number} stream The MIDI stream.\n     * @property {*} waveBuffer The buffer with the MIDI data converted to WAV.\n     * @property {boolean} isFirstInstance Whether this is the first instance of the Midi Player or not.\n     *\n     * @return {object} A `MidiPlayer` instance.\n     * @example\n     * import MidiPlayer from 'web-midi-player';\n     *\n     * const eventLogger = (payload) => {\n     *   console.log('Received event:', payload.event);\n     * }\n     *\n     * const midiPlayer = new MidiPlayer({ eventLogger });\n     */\n    constructor({\n        eventLogger = undefined,\n        logging = false,\n        patchUrl = MIDI_DEFAULT_PATCH_URL\n    } = {}) {\n        try {\n            const playerId = uuid();\n            this.playerId = playerId;\n            this.eventHandler = new EventHandler({\n                eventLogger,\n                logging,\n                playerId\n            });\n        } catch (error) {\n            console.error('Fatal error. Could not initialize event handler.');\n            return;\n        }\n\n        try {\n            this.eventLogger = eventLogger;\n            this.logging = logging;\n            this.patchUrl = patchUrl;\n            this.startTime = 0;\n\n            LibTiMidity.init(isFirstInstance);\n\n            this.isFirstInstance = isFirstInstance;\n            if (isFirstInstance) {\n                isFirstInstance = false;\n            }\n\n            this.eventHandler.emitInit();\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not initialize instance of MidiPlayer.',\n                error\n            });\n        }\n    }\n\n    /**\n     * Formats the name of a MIDI for display purposes.\n     * @param {String} name Name of the MIDI song.\n     * @return {String}\n     */\n    static formatMidiName(name) {\n        return name ? ` '${name}'` : '';\n    }\n\n    /**\n     * Loads instrument patches for a list of MIDI input.\n     *\n     * Please note that you can not use `parameters.items.arrayBuffer` and `parameters.items.url` concurrently.\n     * @param {object} parameters\n     * @param {object} [parameters.items] An array.\n     * @param {arrayBuffer} [parameters.items.arrayBuffer] An array buffer containing MIDI data to play.\n     * @param {string} [parameters.items.url] The URL where the MIDI file to play is located.\n     * @param {object} [parameters.audioContext] An instance of the Web Audio API AudioContext interface.\n     * @return {boolean} Whether instrument patches were successfully preloaded or not.\n     * @example\n     * const name1 = 'My MIDI file from URL';\n     * const url = 'media/file.midi';\n     * const name2 = 'My MIDI file from ArrayBuffer';\n     * const arrayBuffer = new ArrayBuffer();\n     *\n     * midiPlayer.preload({\n     *   items: [\n     *     { url, name: name1 },\n     *     { arrayBuffer, name: name2 }\n     *   ]\n     * });\n     */\n    async preload({ items = [], audioContext } = {}) {\n        for (let i = 0; i < items.length; i++) {\n            const item = items[i];\n            const { url, arrayBuffer } = item;\n\n            const initialized = this.initAudioContext({ audioContext });\n\n            if (!initialized) {\n                return false;\n            }\n\n            if (!this.isSourceValid({ url, arrayBuffer })) {\n                return false;\n            }\n\n            const data = await this.getSource({ url, arrayBuffer });\n\n            if (!data) {\n                return false;\n            }\n\n            this.midiFileArray = new Int8Array(data);\n            this.handleStream();\n            await this.getInstrumentPatches();\n        }\n    }\n\n    /**\n     * Starts playback of MIDI input.\n     *\n     * Please note that you can not use `input.arrayBuffer` and `input.url` concurrently.\n     * @param {object} input\n     * @param {arrayBuffer} [input.arrayBuffer] An array buffer containing MIDI data to play.\n     * @param {string} [input.url] The URL where the MIDI file to play is located.\n     * @param {string} [input.name] A human-friendly name for the song.\n     * @param {object} [input.audioContext] An instance of the Web Audio API AudioContext interface.\n     * @return {boolean} Whether playback was successfully initiated or not.\n     * @example\n     * const name1 = 'My MIDI file from URL';\n     * const url = 'media/file.midi';\n     * midiPlayer.play({ url, name: name1 });\n     *\n     * const name2 = 'My MIDI file from ArrayBuffer';\n     * const arrayBuffer = new ArrayBuffer();\n     * midiPlayer.play({ arrayBuffer, name: name2 });\n     */\n    async play({ arrayBuffer, url, name, audioContext } = {}) {\n        this.stop();\n\n        const initialized = this.initAudioContext({ audioContext });\n\n        if (!initialized) {\n            return false;\n        }\n\n        if (!this.isSourceValid({ url, arrayBuffer })) {\n            return false;\n        }\n\n        this.eventHandler.emitLoadFile({\n            message: `Loading${MidiPlayer.formatMidiName(name)}...`\n        });\n\n        const data = await this.getSource({ url, arrayBuffer });\n\n        if (!data) {\n            return false;\n        }\n\n        const loaded = await this.loadSong({ arrayBuffer: data });\n\n        if (loaded) {\n            return this.initPlayback();\n        }\n    }\n\n    initAudioContext({ audioContext }) {\n        try {\n            // AudioContext must be fired close to the touch/click event initiated by the user to work in Safari\n            this.context =\n                audioContext ||\n                new (window.AudioContext || window.webkitAudioContext)();\n            this.sampleRate = this.context.sampleRate;\n            let gainNode = this.context.createGain();\n            gainNode.gain.value = 1; // volume\n            return true;\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: `Could not set AudioContext.`,\n                error\n            });\n            return false;\n        }\n    }\n\n    isSourceValid({ arrayBuffer, url }) {\n        if (!arrayBuffer && !url) {\n            this.eventHandler.emitError({\n                message:\n                    \"Unknown source. URL or array buffer can't be both undefined to start playback.\"\n            });\n            return false;\n        }\n\n        if (arrayBuffer && url) {\n            this.eventHandler.emitError({\n                message:\n                    'Ambiguous source. MIDI data must originate either from a URL or an array buffer to start playback. Not both.'\n            });\n            return false;\n        }\n\n        return true;\n    }\n\n    async getSource({ arrayBuffer, url }) {\n        if (arrayBuffer) {\n            return arrayBuffer;\n        }\n\n        try {\n            const response = await fetch(url);\n            if (response.status !== 200) {\n                this.eventHandler.emitError({\n                    message: `Could not retrieve MIDI${MidiPlayer.formatMidiName(\n                        name\n                    )}.`,\n                    error: `Status code: ${response.status}.`\n                });\n\n                return false;\n            }\n\n            return response.arrayBuffer();\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: `Could not retrieve MIDI${MidiPlayer.formatMidiName(\n                    name\n                )}.`,\n                error\n            });\n            return null;\n        }\n    }\n\n    async loadSong({ arrayBuffer }) {\n        this.midiFileArray = new Int8Array(arrayBuffer);\n\n        try {\n            const options = this.handleStream();\n            await this.getInstrumentPatches();\n\n            // we need to reload the MIDI once the instrument patches have been loaded\n            this.stream = LibTiMidity.call(\n                'mid_istream_open_mem',\n                'number',\n                ['number', 'number', 'number'],\n                [this.midiFileBuffer, this.midiFileArray.length, false]\n            );\n\n            this.song = LibTiMidity.call(\n                'mid_song_load',\n                'number',\n                ['number', 'number'],\n                [this.stream, options]\n            );\n\n            LibTiMidity.call(\n                'mid_istream_close',\n                'number',\n                ['number'],\n                [this.stream]\n            );\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not load song.',\n                error\n            });\n            return false;\n        }\n\n        return true;\n    }\n\n    handleStream() {\n        this.midiFileBuffer = LibTiMidity._malloc(this.midiFileArray.length);\n\n        LibTiMidity.writeArrayToMemory(this.midiFileArray, this.midiFileBuffer);\n        LibTiMidity.call('mid_init', 'number', [], []);\n\n        this.stream = LibTiMidity.call(\n            'mid_istream_open_mem',\n            'number',\n            ['number', 'number', 'number'],\n            [this.midiFileBuffer, this.midiFileArray.length, false]\n        );\n\n        const options = LibTiMidity.call(\n            'mid_create_options',\n            'number',\n            ['number', 'number', 'number', 'number'],\n            [this.sampleRate, MIDI_AUDIO_S16LSB, 1, MIDI_AUDIO_BUFFER_SIZE * 2]\n        );\n\n        this.song = LibTiMidity.call(\n            'mid_song_load',\n            'number',\n            ['number', 'number'],\n            [this.stream, options]\n        );\n\n        LibTiMidity.call(\n            'mid_istream_close',\n            'number',\n            ['number'],\n            [this.stream]\n        );\n\n        return options;\n    }\n\n    async getInstrumentPatches() {\n        const missingPatchCount = LibTiMidity.call(\n            'mid_song_get_num_missing_instruments',\n            'number',\n            ['number'],\n            [this.song]\n        );\n\n        if (missingPatchCount > 0) {\n            this.eventHandler.emitLoadPatch({\n                message: `Loading ${missingPatchCount} instrument patches...`\n            });\n\n            for (let i = 0; i < missingPatchCount; i++) {\n                const missingPatch = LibTiMidity.call(\n                    'mid_song_get_missing_instrument',\n                    'string',\n                    ['number', 'number'],\n                    [this.song, i]\n                );\n\n                try {\n                    await LibTiMidity.loadPatchFromUrl(\n                        this.patchUrl,\n                        missingPatch\n                    );\n                } catch (error) {\n                    this.eventHandler.emitError({\n                        message: `Could not retrieve missing instrument patch ${\n                            missingPatch ? `'${missingPatch}'` : `#${i}`\n                        }.`,\n                        error\n                    });\n                    return false;\n                }\n            }\n        }\n    }\n\n    initPlayback = () => {\n        LibTiMidity.call('mid_song_start', 'void', ['number'], [this.song]);\n\n        try {\n            this.connectSource();\n            this.waveBuffer = LibTiMidity._malloc(MIDI_AUDIO_BUFFER_SIZE * 2);\n            this.startTime = this.context.currentTime;\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not initialize playback.',\n                error\n            });\n            return;\n        }\n\n        this.eventHandler.emitPlay({ time: 0 });\n    };\n\n    // creates script processor with auto buffer size and a single output channel\n    connectSource = () => {\n        // Warning! This feature has been marked as deprecated: https://developer.mozilla.org/en-US/docs/Web/API/BaseAudioContext/createScriptProcessor\n        // See issue: https://github.com/yvesgurcan/web-midi-player/issues/29\n        this.source = this.context.createScriptProcessor(\n            MIDI_AUDIO_BUFFER_SIZE,\n            0,\n            1\n        );\n\n        // event handler for next buffer full of audio data\n        this.source.onaudioprocess = event => this.handleOutput(event);\n\n        // connects the source to the context's destination (the speakers)\n        this.source.connect(this.context.destination);\n    };\n\n    handleOutput({ outputBuffer }) {\n        try {\n            const time = this.context.currentTime - this.startTime;\n\n            this.eventHandler.emitPlay({ time });\n\n            // collect new wave data from LibTiMidity into waveBuffer\n            const readWaveBytes = LibTiMidity.call(\n                'mid_song_read_wave',\n                'number',\n                ['number', 'number', 'number', 'number'],\n                [this.song, this.waveBuffer, MIDI_AUDIO_BUFFER_SIZE * 2, false]\n            );\n\n            if (readWaveBytes === 0) {\n                this.stop();\n                this.eventHandler.emitEnd({ time });\n                return;\n            }\n\n            // loop through the samples\n            for (let i = 0; i < MIDI_AUDIO_BUFFER_SIZE; i++) {\n                if (i < readWaveBytes) {\n                    // converts PCM data from sint16 in C to number in JavaScript (range: -1.0 .. +1.0)\n                    outputBuffer.getChannelData(0)[i] =\n                        LibTiMidity.getValue(this.waveBuffer + 2 * i, 'i16') /\n                        MAX_I16;\n                } else {\n                    // fill end of buffer with zeroes, may happen at the end of a piece\n                    outputBuffer.getChannelData(0)[i] = 0;\n                }\n            }\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not process audio.',\n                error\n            });\n        }\n    }\n\n    /**\n     * Pauses playback of MIDI input.\n     * @param {undefined}\n     * @return {boolean} Whether playback was successfully paused or not.\n     * @example\n     * midiPlayer.pause();\n     */\n    pause() {\n        try {\n            let time = 0;\n            if (this.context) {\n                this.context.suspend();\n                time = this.context.currentTime - this.startTime;\n            }\n            this.eventHandler.emitPause({ time });\n            return true;\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not pause playback.',\n                error\n            });\n\n            return false;\n        }\n    }\n\n    /**\n     * Resumes playback of MIDI input.\n     * @param {undefined}\n     * @return {boolean} Whether playback was successfully ressumed or not.\n     * @example\n     * midiPlayer.resume();\n     */\n    resume() {\n        try {\n            let time = 0;\n            if (this.context) {\n                this.context.resume();\n                time = this.context.currentTime - this.startTime;\n            }\n            this.eventHandler.emitResume({\n                time\n            });\n            return true;\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not resume playback.',\n                error\n            });\n\n            return false;\n        }\n    }\n\n    /**\n     * Stops playback of MIDI input.\n     * @param {undefined}\n     * @return {boolean} Whether playback was successfully stopped or not.\n     * @example\n     * midiPlayer.stop();\n     */\n    stop() {\n        try {\n            if (this.source) {\n                this.context.close();\n                this.disconnectSource();\n                this.freeMemory();\n                LibTiMidity.call('mid_exit', 'void', [], []);\n                this.song = 0;\n            }\n\n            this.startTime = 0;\n\n            this.eventHandler.emitStop();\n\n            return true;\n        } catch (error) {\n            this.eventHandler.emitError({\n                message: 'Could not stop playback.',\n                error\n            });\n\n            return false;\n        }\n    }\n\n    freeMemory() {\n        LibTiMidity._free(this.waveBuffer);\n        LibTiMidity._free(this.midiFileBuffer);\n        LibTiMidity.call('mid_song_free', 'void', ['number'], [this.song]);\n    }\n\n    // terminate playback\n    disconnectSource() {\n        this.source.disconnect();\n        this.source = null;\n    }\n\n    /**\n     * Send custom payloads to the event logger.\n     * @function\n     * @param {object} payload\n     * @param {string} [payload.event] The name of the event.\n     * @param {string} [payload.message] A message that described the event.\n     * @example\n     * const event = 'MIDI_CUSTOM_EVENT';\n     * const message = 'Something happened.';\n     * midiPlayer.emitEvent({ event, message });\n     */\n    emitEvent = payload => this.eventHandler.emitEvent(payload);\n\n    /**\n     * Updates the configuration of the logger.\n     * @param {object} [configuration]\n     * @param {function} [configuration.eventLogger = undefined] The function that receives event payloads.\n     * @param {boolean} [configuration.logging = false] Turns ON or OFF logging to the console.\n     * @example\n     *  const eventLogger = (payload) => {\n     *   console.log('Received event:', payload.event);\n     * }\n     * midiPlayer.setLogger({ eventLogger });\n     */\n    setLogger({ eventLogger = undefined, logging = false }) {\n        this.eventLogger = eventLogger;\n        this.logging = logging;\n        this.eventHandler.setLogger({ eventLogger, logging });\n    }\n}\n","import MidiPlayer from './MidiPlayer';\n\nexport default MidiPlayer;\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAEA;AAEA;AAEA;AAGA;AAEA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAzHA;AA4HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAvHA;AACA;AA0HA;;;;;;ACxQA;AAWA;;;;;AAWA;AAkBA;AACA;AAoBA;AAyCA;AAEA;AAiBA;AAIA;AACA;AAkBA;AAaA;AAqDA;AAiCA;AAKA;AAGA;AAGA;AA0BA;AAgEA;AACA;AASA;AAGA;AAmBA;;;;;AAaA;AA4BA;;;;;;AAoBA;AAIA;;;;;;AAcA;;;;;;;AAgBA;;;;;;;;;;AAoBA;AAWA;;;;;;;;AAwCA;AAGA;;;;;;;AAsDA;AAGA;AAwBA;AACA;AACA;AACA;AACA;;;;;;;;AAgBA;AA4DA;AAEA;;;;;;AAmBA;AAEA;AACA;AAcA;;;;;AA6BA;AAQA;;;;;;;AAeA;AAGA;AACA;AAGA;;;;;;AAaA;AAQA;;;;;;;AAuBA;AAIA;AACA;AAUA;;;;;AAYA;AAqBA;AACA;AACA;AACA;AACA;AAIA;AA0BA;;;;;AAiBA;;;;;AAaA;;;;;AAaA;;;;;AAaA;;;;;AAaA;;;;;;;AAh9BA;AAg+BA;AACA;AACA;;;;;AAwBA;;;;;;;AA1/BA;AAkhCA;;;;;;AAoBA;;;;;;;AAiBA;AAaA;AAUA;AAKA;AACA;AACA;AACA;AAuBA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;;;;;AAOA;;;;;AAsBA;AAoBA;AAQA;AAeA;AAUA;AAWA;AAcA;AAWA;AAoBA;AAIA;AAMA;AAmCA;AAWA;AA8DA;AA2FA;AAkDA;AAgBA;AAoBA;AA6BA;AAYA;AAiDA;AA6BA;AAOA;AAqBA;AAGA;AAyBA;AAMA;AACA;AAIA;AAiCA;AACA;AACA;AAYA;AAKA;AAiBA;AAGA;AAOA;AAMA;AAKA;AAIA;AACA;AACA;AAcA;AA+DA;AAeA;AAIA;AAGA;AACA;AAsGA;AAqDA;AA4BA;AAmCA;AAEA;AAuCA;AAcA;AAQA;AAIA;AAIA;AAKA;AAgEA;AAUA;AAIA;AAEA;AAKA;AAKA;AAMA;AACA;AAIA;AAMA;AACA;AAgBA;AAOA;AAEA;AAMA;AACA;AAqCA;AAoEA;AAkFA;AACA;AAGA;AAKA;AAOA;AAIA;AAKA;AAIA;AAEA;AAIA;AAKA;AAOA;AAiFA;AAsCA;AAqFA;AAEA;AAUA;AACA;AACA;AAKA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AAgBA;AAiCA;AA2CA;;;;;;;;AAsDA;AAYA;;;;;;;;;AAeA;;;;;;;;;;;;AAuBA;AAuCA;;;;;;;AAiBA;AA6BA;AAMA;AA2DA;AAiGA;AAgDA;AACA;AAYA;AACA;AAiCA;AAaA;AAEA;AAWA;AAIA;AAQA;AAwBA;AA8BA;AAAA;AAmBA;AAGA;AAgBA;AACA;AACA;AAsCA;AACA;AAQA;AACA;AACA;AAeA;AAoBA;AACA;AAIA;AAUA;AAKA;AAIA;AA4BA;AAOA;AAgBA;AAIA;AACA;AAEA;AAKA;AACA;AAiCA;AAQA;AAKA;AAeA;AAOA;AAGA;AAQA;AA8BA;AAKA;AAKA;AAIA;AAMA;AAcA;AAQA;AAMA;AAMA;AAkBA;AAQA;AAEA;AAYA;AAOA;AAGA;AAOA;AAeA;AAuBA;AACA;AAeA;AACA;AAeA;AACA;AAmBA;AACA;AASA;AAEA;AAiBA;AAiCA;AAaA;AAsBA;AAEA;AAOA;AAEA;AAOA;AAEA;AAGA;AACA;AACA;AAGA;AACA;AACA;AAQA;AASA;AAMA;AAQA;AAQA;AAsDA;AAkCA;AAQA;AAKA;AAYA;AAaA;AAeA;AACA;AAmCA;AAoBA;AAUA;AAMA;AAOA;AAEA;AASA;AAiBA;AAEA;AAOA;AAgCA;AASA;AAMA;AAKA;AAmBA;AACA;AAqBA;AACA;AAeA;AACA;AAeA;AACA;AAuBA;AACA;AAcA;AACA;AAUA;AACA;AAeA;AACA;AAGA;AAQA;AACA;AAKA;AACA;AA0FA;AAEA;AAQA;AA0BA;AAYA;AAEA;AAIA;AASA;AA6BA;;;;;AA0BA;AAGA;AAUA;AAGA;AACA;AAiNA;AAkEA;AAmGA;AAuPA;AA0jBA;AACA;AACA;AAMA;AAWA;AAIA;AAWA;AAgBA;AAIA;AA2KA;AAuxPA;AAMA;AAmCA;AAqGA;AAimEA;AAoxBA;AAuEA;AAmHA;AAIA;AAWA;AAEA;AAuCA;AAMA;AAGA;AAmBA;;;;;;AAmCA;AAEA;AAQA;AAYA;;ACvwiBA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;;;;;;;;;;ACpBA;AACA;AAWA;;;AACA;;;;;;;;AAQA;AAIA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AACA;AADA;AAwBA;AAAA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AACA;AA9BA;AAqCA;AAAA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AACA;AA3CA;AAmHA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAHA;AAKA;AACA;AA1HA;AAmIA;AAEA;AAFA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAjJA;AACA;AACA;AACA;AAEA;;;;;;;;;AAKA;AACA;AACA;AACA;AAFA;AAIA;AAEA;;;;;;;;;;AA0BA;;;;;;AAMA;AAAA;AACA;AACA;AACA;AAFA;AAIA;AAEA;;;;;;;;;AAMA;AAAA;AACA;AACA;AACA;AAFA;AAIA;AAEA;;;;;;;;;AAMA;AAAA;AACA;AACA;AACA;AAFA;AAIA;AAEA;;;;;;;;AAKA;AACA;AACA;AACA;AAFA;AAIA;AAEA;;;;;;;;;AAMA;AAAA;AACA;AACA;AACA;AAFA;AAIA;AAEA;;;;;;;;;;;AAuCA;;;;;;;AAOA;AAAA;AAAA;AAAA;AAAA;AACA;AAEA;AACA;;;;;;;;;;;;;ACvLA;AAEA;AAOA;AACA;AAEA;AACA;AACA;;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BA;AAIA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AACA;AADA;AAyUA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAFA;AACA;AAGA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAzVA;AA4VA;AACA;AACA;AACA;AAMA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AA1WA;AAggBA;AAAA;AACA;AAhgBA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAEA;;;;;;;;;;AASA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA;AACA;AACA;;AADA;;;;;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;;;;;AACA;AACA;;AAEA;AAAA;AAAA;AAAA;;;;;AACA;AACA;;;AAEA;AAAA;AAAA;AAAA;AACA;;AADA;AACA;AACA;;;;;AACA;AACA;;AAEA;AACA;;AACA;AACA;;AAvBA;;;;;;;;;;;;;;;;;;AA0BA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmBA;AACA;AAEA;AAAA;AAAA;AACA;AACA;;;;;AACA;AACA;;AAEA;AAAA;AAAA;AAAA;;;;;AACA;AACA;;AAEA;AACA;AADA;;AAIA;AAAA;AAAA;AAAA;AACA;;AADA;AACA;AACA;;;;;AACA;AACA;;;AAEA;AAAA;AAAA;AACA;;AADA;AACA;AACA;;;;;AACA;AACA;;;;;;;;;;;;;;;;;AAGA;AAAA;AACA;AAAA;AACA;AACA;AAGA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;;;AAEA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AADA;AAIA;AACA;AACA;AACA;AACA;AACA;AADA;AAIA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AAEA;AACA;AAAA;;;;;AACA;AACA;;;;AAGA;AACA;;AADA;AACA;AAAA;;;;;AACA;AACA;AAGA;AAJA;AAOA;AACA;;AAEA;AACA;;;;AACA;AACA;AAGA;AAJA;AAMA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA;AACA;;AAGA;;AACA;AACA;;AACA;AACA;AAOA;AAOA;;;;;;;AAOA;AACA;AACA;AAFA;AAIA;AACA;;AAEA;AACA;;;;;;;;;;;;;;;;;AAEA;AACA;AAEA;AACA;AAEA;AAOA;AAOA;AAOA;AAOA;AACA;;;;;;;;;;;;AAGA;AACA;AAMA;;;;;AACA;AACA;AADA;AAIA;AACA;;AADA;;;;;AACA;;;AAQA;AACA;;;;;;;;AAIA;AACA;AAGA;AAJA;AAMA;AACA;;AArBA;;;;;;;;;;;;;;;;;;;;AA6DA;AAAA;AACA;AAAA;AACA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AAMA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAEA;;;;;;;;;;AAOA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AAFA;AAKA;AACA;AACA;AAEA;;;;;;;;;;AAOA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AAFA;AAKA;AACA;AACA;AAEA;;;;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAKA;AACA;AACA;;;AAEA;AACA;AACA;AAAA;AACA;AAAA;AACA;AACA;;;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;;AAaA;;;;;;;;;;;AAWA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;;;AAxeA;AACA;AACA;;;;;;;;AC5FA;AAEA","sourceRoot":""}\\n//# sourceURL=webpack-internal:///11\\n\");}]);});\n\n//# sourceURL=webpack:////Users/owner/Projects/web-midi-player/index.js?"); + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js": +/*!**************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js ***! + \**************************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return _assertThisInitialized; });\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\n//# sourceURL=webpack:///./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js?"); + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/extends.js": +/*!************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/extends.js ***! + \************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return _extends; });\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\n//# sourceURL=webpack:///./node_modules/@babel/runtime/helpers/esm/extends.js?"); + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/inheritsLoose.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/inheritsLoose.js ***! + \******************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return _inheritsLoose; });\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\n//# sourceURL=webpack:///./node_modules/@babel/runtime/helpers/esm/inheritsLoose.js?"); + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js": +/*!*********************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js ***! + \*********************************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return _objectWithoutPropertiesLoose; });\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\n//# sourceURL=webpack:///./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js?"); + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/inheritsLoose.js": +/*!**************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/inheritsLoose.js ***! + \**************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +eval("function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nmodule.exports = _inheritsLoose;\n\n//# sourceURL=webpack:///./node_modules/@babel/runtime/helpers/inheritsLoose.js?"); + +/***/ }), + +/***/ "./node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js ***! + \*******************************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _emotion_memoize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @emotion/memoize */ \"./node_modules/@emotion/memoize/dist/memoize.browser.esm.js\");\n\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|download|draggable|encType|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|itemProp|itemScope|itemType|itemID|itemRef|on|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar index = Object(_emotion_memoize__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (index);\n\n\n//# sourceURL=webpack:///./node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js?"); + +/***/ }), + +/***/ "./node_modules/@emotion/memoize/dist/memoize.browser.esm.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@emotion/memoize/dist/memoize.browser.esm.js ***! + \*******************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\nfunction memoize(fn) {\n var cache = {};\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (memoize);\n\n\n//# sourceURL=webpack:///./node_modules/@emotion/memoize/dist/memoize.browser.esm.js?"); + +/***/ }), + +/***/ "./node_modules/@emotion/unitless/dist/unitless.browser.esm.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@emotion/unitless/dist/unitless.browser.esm.js ***! + \*********************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\nvar unitlessKeys = {\n animationIterationCount: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (unitlessKeys);\n\n\n//# sourceURL=webpack:///./node_modules/@emotion/unitless/dist/unitless.browser.esm.js?"); + +/***/ }), + +/***/ "./node_modules/ansi-html/index.js": +/*!*****************************************!*\ + !*** ./node_modules/ansi-html/index.js ***! + \*****************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\nmodule.exports = ansiHTML\n\n// Reference to https://github.com/sindresorhus/ansi-regex\nvar _regANSI = /(?:(?:\\u001b\\[)|\\u009b)(?:(?:[0-9]{1,3})?(?:(?:;[0-9]{0,3})*)?[A-M|f-m])|\\u001b[A-M]/\n\nvar _defColors = {\n reset: ['fff', '000'], // [FOREGROUD_COLOR, BACKGROUND_COLOR]\n black: '000',\n red: 'ff0000',\n green: '209805',\n yellow: 'e8bf03',\n blue: '0000ff',\n magenta: 'ff00ff',\n cyan: '00ffee',\n lightgrey: 'f0f0f0',\n darkgrey: '888'\n}\nvar _styles = {\n 30: 'black',\n 31: 'red',\n 32: 'green',\n 33: 'yellow',\n 34: 'blue',\n 35: 'magenta',\n 36: 'cyan',\n 37: 'lightgrey'\n}\nvar _openTags = {\n '1': 'font-weight:bold', // bold\n '2': 'opacity:0.5', // dim\n '3': '', // italic\n '4': '', // underscore\n '8': 'display:none', // hidden\n '9': '' // delete\n}\nvar _closeTags = {\n '23': '', // reset italic\n '24': '', // reset underscore\n '29': '' // reset delete\n}\n\n;[0, 21, 22, 27, 28, 39, 49].forEach(function (n) {\n _closeTags[n] = ''\n})\n\n/**\n * Converts text with ANSI color codes to HTML markup.\n * @param {String} text\n * @returns {*}\n */\nfunction ansiHTML (text) {\n // Returns the text if the string has no ANSI escape code.\n if (!_regANSI.test(text)) {\n return text\n }\n\n // Cache opened sequence.\n var ansiCodes = []\n // Replace with markup.\n var ret = text.replace(/\\033\\[(\\d+)*m/g, function (match, seq) {\n var ot = _openTags[seq]\n if (ot) {\n // If current sequence has been opened, close it.\n if (!!~ansiCodes.indexOf(seq)) { // eslint-disable-line no-extra-boolean-cast\n ansiCodes.pop()\n return ''\n }\n // Open tag.\n ansiCodes.push(seq)\n return ot[0] === '<' ? ot : ''\n }\n\n var ct = _closeTags[seq]\n if (ct) {\n // Pop sequence\n ansiCodes.pop()\n return ct\n }\n return ''\n })\n\n // Make sure tags are closed.\n var l = ansiCodes.length\n ;(l > 0) && (ret += Array(l + 1).join(''))\n\n return ret\n}\n\n/**\n * Customize colors.\n * @param {Object} colors reference to _defColors\n */\nansiHTML.setColors = function (colors) {\n if (typeof colors !== 'object') {\n throw new Error('`colors` parameter must be an Object.')\n }\n\n var _finalColors = {}\n for (var key in _defColors) {\n var hex = colors.hasOwnProperty(key) ? colors[key] : null\n if (!hex) {\n _finalColors[key] = _defColors[key]\n continue\n }\n if ('reset' === key) {\n if (typeof hex === 'string') {\n hex = [hex]\n }\n if (!Array.isArray(hex) || hex.length === 0 || hex.some(function (h) {\n return typeof h !== 'string'\n })) {\n throw new Error('The value of `' + key + '` property must be an Array and each item could only be a hex string, e.g.: FF0000')\n }\n var defHexColor = _defColors[key]\n if (!hex[0]) {\n hex[0] = defHexColor[0]\n }\n if (hex.length === 1 || !hex[1]) {\n hex = [hex[0]]\n hex.push(defHexColor[1])\n }\n\n hex = hex.slice(0, 2)\n } else if (typeof hex !== 'string') {\n throw new Error('The value of `' + key + '` property must be a hex string, e.g.: FF0000')\n }\n _finalColors[key] = hex\n }\n _setTags(_finalColors)\n}\n\n/**\n * Reset colors.\n */\nansiHTML.reset = function () {\n _setTags(_defColors)\n}\n\n/**\n * Expose tags, including open and close.\n * @type {Object}\n */\nansiHTML.tags = {}\n\nif (Object.defineProperty) {\n Object.defineProperty(ansiHTML.tags, 'open', {\n get: function () { return _openTags }\n })\n Object.defineProperty(ansiHTML.tags, 'close', {\n get: function () { return _closeTags }\n })\n} else {\n ansiHTML.tags.open = _openTags\n ansiHTML.tags.close = _closeTags\n}\n\nfunction _setTags (colors) {\n // reset all\n _openTags['0'] = 'font-weight:normal;opacity:1;color:#' + colors.reset[0] + ';background:#' + colors.reset[1]\n // inverse\n _openTags['7'] = 'color:#' + colors.reset[1] + ';background:#' + colors.reset[0]\n // dark grey\n _openTags['90'] = 'color:#' + colors.darkgrey\n\n for (var code in _styles) {\n var color = _styles[code]\n var oriColor = colors[color] || '000'\n _openTags[code] = 'color:#' + oriColor\n code = parseInt(code)\n _openTags[(code + 10).toString()] = 'background:#' + oriColor\n }\n}\n\nansiHTML.reset()\n\n\n//# sourceURL=webpack:///./node_modules/ansi-html/index.js?"); + +/***/ }), + +/***/ "./node_modules/ansi-regex/index.js": +/*!******************************************!*\ + !*** ./node_modules/ansi-regex/index.js ***! + \******************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\nmodule.exports = function () {\n\treturn /[\\u001b\\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-PRZcf-nqry=><]/g;\n};\n\n\n//# sourceURL=webpack:///./node_modules/ansi-regex/index.js?"); + +/***/ }), + +/***/ "./node_modules/dom-helpers/esm/addClass.js": +/*!**************************************************!*\ + !*** ./node_modules/dom-helpers/esm/addClass.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return addClass; });\n/* harmony import */ var _hasClass__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./hasClass */ \"./node_modules/dom-helpers/esm/hasClass.js\");\n\nfunction addClass(element, className) {\n if (element.classList) element.classList.add(className);else if (!Object(_hasClass__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(element, className)) if (typeof element.className === 'string') element.className = element.className + \" \" + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + \" \" + className);\n}\n\n//# sourceURL=webpack:///./node_modules/dom-helpers/esm/addClass.js?"); + +/***/ }), + +/***/ "./node_modules/dom-helpers/esm/hasClass.js": +/*!**************************************************!*\ + !*** ./node_modules/dom-helpers/esm/hasClass.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return hasClass; });\nfunction hasClass(element, className) {\n if (element.classList) return !!className && element.classList.contains(className);\n return (\" \" + (element.className.baseVal || element.className) + \" \").indexOf(\" \" + className + \" \") !== -1;\n}\n\n//# sourceURL=webpack:///./node_modules/dom-helpers/esm/hasClass.js?"); + +/***/ }), + +/***/ "./node_modules/dom-helpers/esm/removeClass.js": +/*!*****************************************************!*\ + !*** ./node_modules/dom-helpers/esm/removeClass.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return removeClass; });\nfunction replaceClassName(origClass, classToRemove) {\n return origClass.replace(new RegExp(\"(^|\\\\s)\" + classToRemove + \"(?:\\\\s|$)\", 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n\nfunction removeClass(element, className) {\n if (element.classList) {\n element.classList.remove(className);\n } else if (typeof element.className === 'string') {\n ;\n element.className = replaceClassName(element.className, className);\n } else {\n element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n }\n}\n\n//# sourceURL=webpack:///./node_modules/dom-helpers/esm/removeClass.js?"); + +/***/ }), + +/***/ "./node_modules/events/events.js": +/*!***************************************!*\ + !*** ./node_modules/events/events.js ***! + \***************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction $getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return $getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = $getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) args.push(arguments[i]);\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n ReflectApply(this.listener, this.target, args);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\n\n//# sourceURL=webpack:///./node_modules/events/events.js?"); + +/***/ }), + +/***/ "./node_modules/gud/index.js": +/*!***********************************!*\ + !*** ./node_modules/gud/index.js ***! + \***********************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("/* WEBPACK VAR INJECTION */(function(global) {// @flow\n\n\nvar key = '__global_unique_id__';\n\nmodule.exports = function() {\n return global[key] = (global[key] || 0) + 1;\n};\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\")))\n\n//# sourceURL=webpack:///./node_modules/gud/index.js?"); + +/***/ }), + +/***/ "./node_modules/history/esm/history.js": +/*!*********************************************!*\ + !*** ./node_modules/history/esm/history.js ***! + \*********************************************/ +/*! exports provided: createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"createBrowserHistory\", function() { return createBrowserHistory; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"createHashHistory\", function() { return createHashHistory; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"createMemoryHistory\", function() { return createMemoryHistory; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"createLocation\", function() { return createLocation; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"locationsAreEqual\", function() { return locationsAreEqual; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parsePath\", function() { return parsePath; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"createPath\", function() { return createPath; });\n/* harmony import */ var _babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/extends */ \"./node_modules/@babel/runtime/helpers/esm/extends.js\");\n/* harmony import */ var resolve_pathname__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! resolve-pathname */ \"./node_modules/resolve-pathname/esm/resolve-pathname.js\");\n/* harmony import */ var value_equal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! value-equal */ \"./node_modules/value-equal/esm/value-equal.js\");\n/* harmony import */ var tiny_warning__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! tiny-warning */ \"./node_modules/tiny-warning/dist/tiny-warning.esm.js\");\n/* harmony import */ var tiny_invariant__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! tiny-invariant */ \"./node_modules/tiny-invariant/dist/tiny-invariant.esm.js\");\n\n\n\n\n\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\n}\nfunction parsePath(path) {\n var pathname = path || '/';\n var search = '';\n var hash = '';\n var hashIndex = pathname.indexOf('#');\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf('?');\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === '?' ? '' : search,\n hash: hash === '#' ? '' : hash\n };\n}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = Object(_babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__[\"default\"])({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = Object(resolve_pathname__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && Object(value_equal__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(prompt == null, 'A history supports only one prompt at a time') : undefined;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : undefined;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? true ? Object(tiny_invariant__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(false, 'Browser history needs a DOM') : undefined : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : undefined;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n Object(_babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : undefined;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : undefined;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : undefined;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : undefined;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? true ? Object(tiny_invariant__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(false, 'Hash history needs a DOM') : undefined : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : undefined;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n Object(_babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(state === undefined, 'Hash history cannot push state; it is ignored') : undefined;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : undefined;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(state === undefined, 'Hash history cannot replace state; it is ignored') : undefined;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : undefined;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n Object(_babel_runtime_helpers_esm_extends__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : undefined;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n true ? Object(tiny_warning__WEBPACK_IMPORTED_MODULE_3__[\"default\"])(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : undefined;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\n\n\n\n//# sourceURL=webpack:///./node_modules/history/esm/history.js?"); + +/***/ }), + +/***/ "./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js": +/*!**********************************************************************************!*\ + !*** ./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js ***! + \**********************************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\nvar reactIs = __webpack_require__(/*! react-is */ \"./node_modules/react-is/index.js\");\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\n\nfunction getStatics(component) {\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n }\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n\n\n//# sourceURL=webpack:///./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js?"); + +/***/ }), + +/***/ "./node_modules/html-entities/index.js": +/*!*********************************************!*\ + !*** ./node_modules/html-entities/index.js ***! + \*********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +eval("module.exports = {\n XmlEntities: __webpack_require__(/*! ./lib/xml-entities.js */ \"./node_modules/html-entities/lib/xml-entities.js\"),\n Html4Entities: __webpack_require__(/*! ./lib/html4-entities.js */ \"./node_modules/html-entities/lib/html4-entities.js\"),\n Html5Entities: __webpack_require__(/*! ./lib/html5-entities.js */ \"./node_modules/html-entities/lib/html5-entities.js\"),\n AllHtmlEntities: __webpack_require__(/*! ./lib/html5-entities.js */ \"./node_modules/html-entities/lib/html5-entities.js\")\n};\n\n\n//# sourceURL=webpack:///./node_modules/html-entities/index.js?"); + +/***/ }), + +/***/ "./node_modules/html-entities/lib/html4-entities.js": +/*!**********************************************************!*\ + !*** ./node_modules/html-entities/lib/html4-entities.js ***! + \**********************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +eval("var HTML_ALPHA = ['apos', 'nbsp', 'iexcl', 'cent', 'pound', 'curren', 'yen', 'brvbar', 'sect', 'uml', 'copy', 'ordf', 'laquo', 'not', 'shy', 'reg', 'macr', 'deg', 'plusmn', 'sup2', 'sup3', 'acute', 'micro', 'para', 'middot', 'cedil', 'sup1', 'ordm', 'raquo', 'frac14', 'frac12', 'frac34', 'iquest', 'Agrave', 'Aacute', 'Acirc', 'Atilde', 'Auml', 'Aring', 'Aelig', 'Ccedil', 'Egrave', 'Eacute', 'Ecirc', 'Euml', 'Igrave', 'Iacute', 'Icirc', 'Iuml', 'ETH', 'Ntilde', 'Ograve', 'Oacute', 'Ocirc', 'Otilde', 'Ouml', 'times', 'Oslash', 'Ugrave', 'Uacute', 'Ucirc', 'Uuml', 'Yacute', 'THORN', 'szlig', 'agrave', 'aacute', 'acirc', 'atilde', 'auml', 'aring', 'aelig', 'ccedil', 'egrave', 'eacute', 'ecirc', 'euml', 'igrave', 'iacute', 'icirc', 'iuml', 'eth', 'ntilde', 'ograve', 'oacute', 'ocirc', 'otilde', 'ouml', 'divide', 'oslash', 'ugrave', 'uacute', 'ucirc', 'uuml', 'yacute', 'thorn', 'yuml', 'quot', 'amp', 'lt', 'gt', 'OElig', 'oelig', 'Scaron', 'scaron', 'Yuml', 'circ', 'tilde', 'ensp', 'emsp', 'thinsp', 'zwnj', 'zwj', 'lrm', 'rlm', 'ndash', 'mdash', 'lsquo', 'rsquo', 'sbquo', 'ldquo', 'rdquo', 'bdquo', 'dagger', 'Dagger', 'permil', 'lsaquo', 'rsaquo', 'euro', 'fnof', 'Alpha', 'Beta', 'Gamma', 'Delta', 'Epsilon', 'Zeta', 'Eta', 'Theta', 'Iota', 'Kappa', 'Lambda', 'Mu', 'Nu', 'Xi', 'Omicron', 'Pi', 'Rho', 'Sigma', 'Tau', 'Upsilon', 'Phi', 'Chi', 'Psi', 'Omega', 'alpha', 'beta', 'gamma', 'delta', 'epsilon', 'zeta', 'eta', 'theta', 'iota', 'kappa', 'lambda', 'mu', 'nu', 'xi', 'omicron', 'pi', 'rho', 'sigmaf', 'sigma', 'tau', 'upsilon', 'phi', 'chi', 'psi', 'omega', 'thetasym', 'upsih', 'piv', 'bull', 'hellip', 'prime', 'Prime', 'oline', 'frasl', 'weierp', 'image', 'real', 'trade', 'alefsym', 'larr', 'uarr', 'rarr', 'darr', 'harr', 'crarr', 'lArr', 'uArr', 'rArr', 'dArr', 'hArr', 'forall', 'part', 'exist', 'empty', 'nabla', 'isin', 'notin', 'ni', 'prod', 'sum', 'minus', 'lowast', 'radic', 'prop', 'infin', 'ang', 'and', 'or', 'cap', 'cup', 'int', 'there4', 'sim', 'cong', 'asymp', 'ne', 'equiv', 'le', 'ge', 'sub', 'sup', 'nsub', 'sube', 'supe', 'oplus', 'otimes', 'perp', 'sdot', 'lceil', 'rceil', 'lfloor', 'rfloor', 'lang', 'rang', 'loz', 'spades', 'clubs', 'hearts', 'diams'];\nvar HTML_CODES = [39, 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255, 34, 38, 60, 62, 338, 339, 352, 353, 376, 710, 732, 8194, 8195, 8201, 8204, 8205, 8206, 8207, 8211, 8212, 8216, 8217, 8218, 8220, 8221, 8222, 8224, 8225, 8240, 8249, 8250, 8364, 402, 913, 914, 915, 916, 917, 918, 919, 920, 921, 922, 923, 924, 925, 926, 927, 928, 929, 931, 932, 933, 934, 935, 936, 937, 945, 946, 947, 948, 949, 950, 951, 952, 953, 954, 955, 956, 957, 958, 959, 960, 961, 962, 963, 964, 965, 966, 967, 968, 969, 977, 978, 982, 8226, 8230, 8242, 8243, 8254, 8260, 8472, 8465, 8476, 8482, 8501, 8592, 8593, 8594, 8595, 8596, 8629, 8656, 8657, 8658, 8659, 8660, 8704, 8706, 8707, 8709, 8711, 8712, 8713, 8715, 8719, 8721, 8722, 8727, 8730, 8733, 8734, 8736, 8743, 8744, 8745, 8746, 8747, 8756, 8764, 8773, 8776, 8800, 8801, 8804, 8805, 8834, 8835, 8836, 8838, 8839, 8853, 8855, 8869, 8901, 8968, 8969, 8970, 8971, 9001, 9002, 9674, 9824, 9827, 9829, 9830];\n\nvar alphaIndex = {};\nvar numIndex = {};\n\nvar i = 0;\nvar length = HTML_ALPHA.length;\nwhile (i < length) {\n var a = HTML_ALPHA[i];\n var c = HTML_CODES[i];\n alphaIndex[a] = String.fromCharCode(c);\n numIndex[c] = a;\n i++;\n}\n\n/**\n * @constructor\n */\nfunction Html4Entities() {}\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.prototype.decode = function(str) {\n if (!str || !str.length) {\n return '';\n }\n return str.replace(/&(#?[\\w\\d]+);?/g, function(s, entity) {\n var chr;\n if (entity.charAt(0) === \"#\") {\n var code = entity.charAt(1).toLowerCase() === 'x' ?\n parseInt(entity.substr(2), 16) :\n parseInt(entity.substr(1));\n\n if (!(isNaN(code) || code < -32768 || code > 65535)) {\n chr = String.fromCharCode(code);\n }\n } else {\n chr = alphaIndex[entity];\n }\n return chr || s;\n });\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.decode = function(str) {\n return new Html4Entities().decode(str);\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.prototype.encode = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var alpha = numIndex[str.charCodeAt(i)];\n result += alpha ? \"&\" + alpha + \";\" : str.charAt(i);\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.encode = function(str) {\n return new Html4Entities().encode(str);\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.prototype.encodeNonUTF = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var cc = str.charCodeAt(i);\n var alpha = numIndex[cc];\n if (alpha) {\n result += \"&\" + alpha + \";\";\n } else if (cc < 32 || cc > 126) {\n result += \"&#\" + cc + \";\";\n } else {\n result += str.charAt(i);\n }\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.encodeNonUTF = function(str) {\n return new Html4Entities().encodeNonUTF(str);\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.prototype.encodeNonASCII = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var c = str.charCodeAt(i);\n if (c <= 255) {\n result += str[i++];\n continue;\n }\n result += '&#' + c + ';';\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml4Entities.encodeNonASCII = function(str) {\n return new Html4Entities().encodeNonASCII(str);\n};\n\nmodule.exports = Html4Entities;\n\n\n//# sourceURL=webpack:///./node_modules/html-entities/lib/html4-entities.js?"); + +/***/ }), + +/***/ "./node_modules/html-entities/lib/html5-entities.js": +/*!**********************************************************!*\ + !*** ./node_modules/html-entities/lib/html5-entities.js ***! + \**********************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +eval("var ENTITIES = [['Aacute', [193]], ['aacute', [225]], ['Abreve', [258]], ['abreve', [259]], ['ac', [8766]], ['acd', [8767]], ['acE', [8766, 819]], ['Acirc', [194]], ['acirc', [226]], ['acute', [180]], ['Acy', [1040]], ['acy', [1072]], ['AElig', [198]], ['aelig', [230]], ['af', [8289]], ['Afr', [120068]], ['afr', [120094]], ['Agrave', [192]], ['agrave', [224]], ['alefsym', [8501]], ['aleph', [8501]], ['Alpha', [913]], ['alpha', [945]], ['Amacr', [256]], ['amacr', [257]], ['amalg', [10815]], ['amp', [38]], ['AMP', [38]], ['andand', [10837]], ['And', [10835]], ['and', [8743]], ['andd', [10844]], ['andslope', [10840]], ['andv', [10842]], ['ang', [8736]], ['ange', [10660]], ['angle', [8736]], ['angmsdaa', [10664]], ['angmsdab', [10665]], ['angmsdac', [10666]], ['angmsdad', [10667]], ['angmsdae', [10668]], ['angmsdaf', [10669]], ['angmsdag', [10670]], ['angmsdah', [10671]], ['angmsd', [8737]], ['angrt', [8735]], ['angrtvb', [8894]], ['angrtvbd', [10653]], ['angsph', [8738]], ['angst', [197]], ['angzarr', [9084]], ['Aogon', [260]], ['aogon', [261]], ['Aopf', [120120]], ['aopf', [120146]], ['apacir', [10863]], ['ap', [8776]], ['apE', [10864]], ['ape', [8778]], ['apid', [8779]], ['apos', [39]], ['ApplyFunction', [8289]], ['approx', [8776]], ['approxeq', [8778]], ['Aring', [197]], ['aring', [229]], ['Ascr', [119964]], ['ascr', [119990]], ['Assign', [8788]], ['ast', [42]], ['asymp', [8776]], ['asympeq', [8781]], ['Atilde', [195]], ['atilde', [227]], ['Auml', [196]], ['auml', [228]], ['awconint', [8755]], ['awint', [10769]], ['backcong', [8780]], ['backepsilon', [1014]], ['backprime', [8245]], ['backsim', [8765]], ['backsimeq', [8909]], ['Backslash', [8726]], ['Barv', [10983]], ['barvee', [8893]], ['barwed', [8965]], ['Barwed', [8966]], ['barwedge', [8965]], ['bbrk', [9141]], ['bbrktbrk', [9142]], ['bcong', [8780]], ['Bcy', [1041]], ['bcy', [1073]], ['bdquo', [8222]], ['becaus', [8757]], ['because', [8757]], ['Because', [8757]], ['bemptyv', [10672]], ['bepsi', [1014]], ['bernou', [8492]], ['Bernoullis', [8492]], ['Beta', [914]], ['beta', [946]], ['beth', [8502]], ['between', [8812]], ['Bfr', [120069]], ['bfr', [120095]], ['bigcap', [8898]], ['bigcirc', [9711]], ['bigcup', [8899]], ['bigodot', [10752]], ['bigoplus', [10753]], ['bigotimes', [10754]], ['bigsqcup', [10758]], ['bigstar', [9733]], ['bigtriangledown', [9661]], ['bigtriangleup', [9651]], ['biguplus', [10756]], ['bigvee', [8897]], ['bigwedge', [8896]], ['bkarow', [10509]], ['blacklozenge', [10731]], ['blacksquare', [9642]], ['blacktriangle', [9652]], ['blacktriangledown', [9662]], ['blacktriangleleft', [9666]], ['blacktriangleright', [9656]], ['blank', [9251]], ['blk12', [9618]], ['blk14', [9617]], ['blk34', [9619]], ['block', [9608]], ['bne', [61, 8421]], ['bnequiv', [8801, 8421]], ['bNot', [10989]], ['bnot', [8976]], ['Bopf', [120121]], ['bopf', [120147]], ['bot', [8869]], ['bottom', [8869]], ['bowtie', [8904]], ['boxbox', [10697]], ['boxdl', [9488]], ['boxdL', [9557]], ['boxDl', [9558]], ['boxDL', [9559]], ['boxdr', [9484]], ['boxdR', [9554]], ['boxDr', [9555]], ['boxDR', [9556]], ['boxh', [9472]], ['boxH', [9552]], ['boxhd', [9516]], ['boxHd', [9572]], ['boxhD', [9573]], ['boxHD', [9574]], ['boxhu', [9524]], ['boxHu', [9575]], ['boxhU', [9576]], ['boxHU', [9577]], ['boxminus', [8863]], ['boxplus', [8862]], ['boxtimes', [8864]], ['boxul', [9496]], ['boxuL', [9563]], ['boxUl', [9564]], ['boxUL', [9565]], ['boxur', [9492]], ['boxuR', [9560]], ['boxUr', [9561]], ['boxUR', [9562]], ['boxv', [9474]], ['boxV', [9553]], ['boxvh', [9532]], ['boxvH', [9578]], ['boxVh', [9579]], ['boxVH', [9580]], ['boxvl', [9508]], ['boxvL', [9569]], ['boxVl', [9570]], ['boxVL', [9571]], ['boxvr', [9500]], ['boxvR', [9566]], ['boxVr', [9567]], ['boxVR', [9568]], ['bprime', [8245]], ['breve', [728]], ['Breve', [728]], ['brvbar', [166]], ['bscr', [119991]], ['Bscr', [8492]], ['bsemi', [8271]], ['bsim', [8765]], ['bsime', [8909]], ['bsolb', [10693]], ['bsol', [92]], ['bsolhsub', [10184]], ['bull', [8226]], ['bullet', [8226]], ['bump', [8782]], ['bumpE', [10926]], ['bumpe', [8783]], ['Bumpeq', [8782]], ['bumpeq', [8783]], ['Cacute', [262]], ['cacute', [263]], ['capand', [10820]], ['capbrcup', [10825]], ['capcap', [10827]], ['cap', [8745]], ['Cap', [8914]], ['capcup', [10823]], ['capdot', [10816]], ['CapitalDifferentialD', [8517]], ['caps', [8745, 65024]], ['caret', [8257]], ['caron', [711]], ['Cayleys', [8493]], ['ccaps', [10829]], ['Ccaron', [268]], ['ccaron', [269]], ['Ccedil', [199]], ['ccedil', [231]], ['Ccirc', [264]], ['ccirc', [265]], ['Cconint', [8752]], ['ccups', [10828]], ['ccupssm', [10832]], ['Cdot', [266]], ['cdot', [267]], ['cedil', [184]], ['Cedilla', [184]], ['cemptyv', [10674]], ['cent', [162]], ['centerdot', [183]], ['CenterDot', [183]], ['cfr', [120096]], ['Cfr', [8493]], ['CHcy', [1063]], ['chcy', [1095]], ['check', [10003]], ['checkmark', [10003]], ['Chi', [935]], ['chi', [967]], ['circ', [710]], ['circeq', [8791]], ['circlearrowleft', [8634]], ['circlearrowright', [8635]], ['circledast', [8859]], ['circledcirc', [8858]], ['circleddash', [8861]], ['CircleDot', [8857]], ['circledR', [174]], ['circledS', [9416]], ['CircleMinus', [8854]], ['CirclePlus', [8853]], ['CircleTimes', [8855]], ['cir', [9675]], ['cirE', [10691]], ['cire', [8791]], ['cirfnint', [10768]], ['cirmid', [10991]], ['cirscir', [10690]], ['ClockwiseContourIntegral', [8754]], ['clubs', [9827]], ['clubsuit', [9827]], ['colon', [58]], ['Colon', [8759]], ['Colone', [10868]], ['colone', [8788]], ['coloneq', [8788]], ['comma', [44]], ['commat', [64]], ['comp', [8705]], ['compfn', [8728]], ['complement', [8705]], ['complexes', [8450]], ['cong', [8773]], ['congdot', [10861]], ['Congruent', [8801]], ['conint', [8750]], ['Conint', [8751]], ['ContourIntegral', [8750]], ['copf', [120148]], ['Copf', [8450]], ['coprod', [8720]], ['Coproduct', [8720]], ['copy', [169]], ['COPY', [169]], ['copysr', [8471]], ['CounterClockwiseContourIntegral', [8755]], ['crarr', [8629]], ['cross', [10007]], ['Cross', [10799]], ['Cscr', [119966]], ['cscr', [119992]], ['csub', [10959]], ['csube', [10961]], ['csup', [10960]], ['csupe', [10962]], ['ctdot', [8943]], ['cudarrl', [10552]], ['cudarrr', [10549]], ['cuepr', [8926]], ['cuesc', [8927]], ['cularr', [8630]], ['cularrp', [10557]], ['cupbrcap', [10824]], ['cupcap', [10822]], ['CupCap', [8781]], ['cup', [8746]], ['Cup', [8915]], ['cupcup', [10826]], ['cupdot', [8845]], ['cupor', [10821]], ['cups', [8746, 65024]], ['curarr', [8631]], ['curarrm', [10556]], ['curlyeqprec', [8926]], ['curlyeqsucc', [8927]], ['curlyvee', [8910]], ['curlywedge', [8911]], ['curren', [164]], ['curvearrowleft', [8630]], ['curvearrowright', [8631]], ['cuvee', [8910]], ['cuwed', [8911]], ['cwconint', [8754]], ['cwint', [8753]], ['cylcty', [9005]], ['dagger', [8224]], ['Dagger', [8225]], ['daleth', [8504]], ['darr', [8595]], ['Darr', [8609]], ['dArr', [8659]], ['dash', [8208]], ['Dashv', [10980]], ['dashv', [8867]], ['dbkarow', [10511]], ['dblac', [733]], ['Dcaron', [270]], ['dcaron', [271]], ['Dcy', [1044]], ['dcy', [1076]], ['ddagger', [8225]], ['ddarr', [8650]], ['DD', [8517]], ['dd', [8518]], ['DDotrahd', [10513]], ['ddotseq', [10871]], ['deg', [176]], ['Del', [8711]], ['Delta', [916]], ['delta', [948]], ['demptyv', [10673]], ['dfisht', [10623]], ['Dfr', [120071]], ['dfr', [120097]], ['dHar', [10597]], ['dharl', [8643]], ['dharr', [8642]], ['DiacriticalAcute', [180]], ['DiacriticalDot', [729]], ['DiacriticalDoubleAcute', [733]], ['DiacriticalGrave', [96]], ['DiacriticalTilde', [732]], ['diam', [8900]], ['diamond', [8900]], ['Diamond', [8900]], ['diamondsuit', [9830]], ['diams', [9830]], ['die', [168]], ['DifferentialD', [8518]], ['digamma', [989]], ['disin', [8946]], ['div', [247]], ['divide', [247]], ['divideontimes', [8903]], ['divonx', [8903]], ['DJcy', [1026]], ['djcy', [1106]], ['dlcorn', [8990]], ['dlcrop', [8973]], ['dollar', [36]], ['Dopf', [120123]], ['dopf', [120149]], ['Dot', [168]], ['dot', [729]], ['DotDot', [8412]], ['doteq', [8784]], ['doteqdot', [8785]], ['DotEqual', [8784]], ['dotminus', [8760]], ['dotplus', [8724]], ['dotsquare', [8865]], ['doublebarwedge', [8966]], ['DoubleContourIntegral', [8751]], ['DoubleDot', [168]], ['DoubleDownArrow', [8659]], ['DoubleLeftArrow', [8656]], ['DoubleLeftRightArrow', [8660]], ['DoubleLeftTee', [10980]], ['DoubleLongLeftArrow', [10232]], ['DoubleLongLeftRightArrow', [10234]], ['DoubleLongRightArrow', [10233]], ['DoubleRightArrow', [8658]], ['DoubleRightTee', [8872]], ['DoubleUpArrow', [8657]], ['DoubleUpDownArrow', [8661]], ['DoubleVerticalBar', [8741]], ['DownArrowBar', [10515]], ['downarrow', [8595]], ['DownArrow', [8595]], ['Downarrow', [8659]], ['DownArrowUpArrow', [8693]], ['DownBreve', [785]], ['downdownarrows', [8650]], ['downharpoonleft', [8643]], ['downharpoonright', [8642]], ['DownLeftRightVector', [10576]], ['DownLeftTeeVector', [10590]], ['DownLeftVectorBar', [10582]], ['DownLeftVector', [8637]], ['DownRightTeeVector', [10591]], ['DownRightVectorBar', [10583]], ['DownRightVector', [8641]], ['DownTeeArrow', [8615]], ['DownTee', [8868]], ['drbkarow', [10512]], ['drcorn', [8991]], ['drcrop', [8972]], ['Dscr', [119967]], ['dscr', [119993]], ['DScy', [1029]], ['dscy', [1109]], ['dsol', [10742]], ['Dstrok', [272]], ['dstrok', [273]], ['dtdot', [8945]], ['dtri', [9663]], ['dtrif', [9662]], ['duarr', [8693]], ['duhar', [10607]], ['dwangle', [10662]], ['DZcy', [1039]], ['dzcy', [1119]], ['dzigrarr', [10239]], ['Eacute', [201]], ['eacute', [233]], ['easter', [10862]], ['Ecaron', [282]], ['ecaron', [283]], ['Ecirc', [202]], ['ecirc', [234]], ['ecir', [8790]], ['ecolon', [8789]], ['Ecy', [1069]], ['ecy', [1101]], ['eDDot', [10871]], ['Edot', [278]], ['edot', [279]], ['eDot', [8785]], ['ee', [8519]], ['efDot', [8786]], ['Efr', [120072]], ['efr', [120098]], ['eg', [10906]], ['Egrave', [200]], ['egrave', [232]], ['egs', [10902]], ['egsdot', [10904]], ['el', [10905]], ['Element', [8712]], ['elinters', [9191]], ['ell', [8467]], ['els', [10901]], ['elsdot', [10903]], ['Emacr', [274]], ['emacr', [275]], ['empty', [8709]], ['emptyset', [8709]], ['EmptySmallSquare', [9723]], ['emptyv', [8709]], ['EmptyVerySmallSquare', [9643]], ['emsp13', [8196]], ['emsp14', [8197]], ['emsp', [8195]], ['ENG', [330]], ['eng', [331]], ['ensp', [8194]], ['Eogon', [280]], ['eogon', [281]], ['Eopf', [120124]], ['eopf', [120150]], ['epar', [8917]], ['eparsl', [10723]], ['eplus', [10865]], ['epsi', [949]], ['Epsilon', [917]], ['epsilon', [949]], ['epsiv', [1013]], ['eqcirc', [8790]], ['eqcolon', [8789]], ['eqsim', [8770]], ['eqslantgtr', [10902]], ['eqslantless', [10901]], ['Equal', [10869]], ['equals', [61]], ['EqualTilde', [8770]], ['equest', [8799]], ['Equilibrium', [8652]], ['equiv', [8801]], ['equivDD', [10872]], ['eqvparsl', [10725]], ['erarr', [10609]], ['erDot', [8787]], ['escr', [8495]], ['Escr', [8496]], ['esdot', [8784]], ['Esim', [10867]], ['esim', [8770]], ['Eta', [919]], ['eta', [951]], ['ETH', [208]], ['eth', [240]], ['Euml', [203]], ['euml', [235]], ['euro', [8364]], ['excl', [33]], ['exist', [8707]], ['Exists', [8707]], ['expectation', [8496]], ['exponentiale', [8519]], ['ExponentialE', [8519]], ['fallingdotseq', [8786]], ['Fcy', [1060]], ['fcy', [1092]], ['female', [9792]], ['ffilig', [64259]], ['fflig', [64256]], ['ffllig', [64260]], ['Ffr', [120073]], ['ffr', [120099]], ['filig', [64257]], ['FilledSmallSquare', [9724]], ['FilledVerySmallSquare', [9642]], ['fjlig', [102, 106]], ['flat', [9837]], ['fllig', [64258]], ['fltns', [9649]], ['fnof', [402]], ['Fopf', [120125]], ['fopf', [120151]], ['forall', [8704]], ['ForAll', [8704]], ['fork', [8916]], ['forkv', [10969]], ['Fouriertrf', [8497]], ['fpartint', [10765]], ['frac12', [189]], ['frac13', [8531]], ['frac14', [188]], ['frac15', [8533]], ['frac16', [8537]], ['frac18', [8539]], ['frac23', [8532]], ['frac25', [8534]], ['frac34', [190]], ['frac35', [8535]], ['frac38', [8540]], ['frac45', [8536]], ['frac56', [8538]], ['frac58', [8541]], ['frac78', [8542]], ['frasl', [8260]], ['frown', [8994]], ['fscr', [119995]], ['Fscr', [8497]], ['gacute', [501]], ['Gamma', [915]], ['gamma', [947]], ['Gammad', [988]], ['gammad', [989]], ['gap', [10886]], ['Gbreve', [286]], ['gbreve', [287]], ['Gcedil', [290]], ['Gcirc', [284]], ['gcirc', [285]], ['Gcy', [1043]], ['gcy', [1075]], ['Gdot', [288]], ['gdot', [289]], ['ge', [8805]], ['gE', [8807]], ['gEl', [10892]], ['gel', [8923]], ['geq', [8805]], ['geqq', [8807]], ['geqslant', [10878]], ['gescc', [10921]], ['ges', [10878]], ['gesdot', [10880]], ['gesdoto', [10882]], ['gesdotol', [10884]], ['gesl', [8923, 65024]], ['gesles', [10900]], ['Gfr', [120074]], ['gfr', [120100]], ['gg', [8811]], ['Gg', [8921]], ['ggg', [8921]], ['gimel', [8503]], ['GJcy', [1027]], ['gjcy', [1107]], ['gla', [10917]], ['gl', [8823]], ['glE', [10898]], ['glj', [10916]], ['gnap', [10890]], ['gnapprox', [10890]], ['gne', [10888]], ['gnE', [8809]], ['gneq', [10888]], ['gneqq', [8809]], ['gnsim', [8935]], ['Gopf', [120126]], ['gopf', [120152]], ['grave', [96]], ['GreaterEqual', [8805]], ['GreaterEqualLess', [8923]], ['GreaterFullEqual', [8807]], ['GreaterGreater', [10914]], ['GreaterLess', [8823]], ['GreaterSlantEqual', [10878]], ['GreaterTilde', [8819]], ['Gscr', [119970]], ['gscr', [8458]], ['gsim', [8819]], ['gsime', [10894]], ['gsiml', [10896]], ['gtcc', [10919]], ['gtcir', [10874]], ['gt', [62]], ['GT', [62]], ['Gt', [8811]], ['gtdot', [8919]], ['gtlPar', [10645]], ['gtquest', [10876]], ['gtrapprox', [10886]], ['gtrarr', [10616]], ['gtrdot', [8919]], ['gtreqless', [8923]], ['gtreqqless', [10892]], ['gtrless', [8823]], ['gtrsim', [8819]], ['gvertneqq', [8809, 65024]], ['gvnE', [8809, 65024]], ['Hacek', [711]], ['hairsp', [8202]], ['half', [189]], ['hamilt', [8459]], ['HARDcy', [1066]], ['hardcy', [1098]], ['harrcir', [10568]], ['harr', [8596]], ['hArr', [8660]], ['harrw', [8621]], ['Hat', [94]], ['hbar', [8463]], ['Hcirc', [292]], ['hcirc', [293]], ['hearts', [9829]], ['heartsuit', [9829]], ['hellip', [8230]], ['hercon', [8889]], ['hfr', [120101]], ['Hfr', [8460]], ['HilbertSpace', [8459]], ['hksearow', [10533]], ['hkswarow', [10534]], ['hoarr', [8703]], ['homtht', [8763]], ['hookleftarrow', [8617]], ['hookrightarrow', [8618]], ['hopf', [120153]], ['Hopf', [8461]], ['horbar', [8213]], ['HorizontalLine', [9472]], ['hscr', [119997]], ['Hscr', [8459]], ['hslash', [8463]], ['Hstrok', [294]], ['hstrok', [295]], ['HumpDownHump', [8782]], ['HumpEqual', [8783]], ['hybull', [8259]], ['hyphen', [8208]], ['Iacute', [205]], ['iacute', [237]], ['ic', [8291]], ['Icirc', [206]], ['icirc', [238]], ['Icy', [1048]], ['icy', [1080]], ['Idot', [304]], ['IEcy', [1045]], ['iecy', [1077]], ['iexcl', [161]], ['iff', [8660]], ['ifr', [120102]], ['Ifr', [8465]], ['Igrave', [204]], ['igrave', [236]], ['ii', [8520]], ['iiiint', [10764]], ['iiint', [8749]], ['iinfin', [10716]], ['iiota', [8489]], ['IJlig', [306]], ['ijlig', [307]], ['Imacr', [298]], ['imacr', [299]], ['image', [8465]], ['ImaginaryI', [8520]], ['imagline', [8464]], ['imagpart', [8465]], ['imath', [305]], ['Im', [8465]], ['imof', [8887]], ['imped', [437]], ['Implies', [8658]], ['incare', [8453]], ['in', [8712]], ['infin', [8734]], ['infintie', [10717]], ['inodot', [305]], ['intcal', [8890]], ['int', [8747]], ['Int', [8748]], ['integers', [8484]], ['Integral', [8747]], ['intercal', [8890]], ['Intersection', [8898]], ['intlarhk', [10775]], ['intprod', [10812]], ['InvisibleComma', [8291]], ['InvisibleTimes', [8290]], ['IOcy', [1025]], ['iocy', [1105]], ['Iogon', [302]], ['iogon', [303]], ['Iopf', [120128]], ['iopf', [120154]], ['Iota', [921]], ['iota', [953]], ['iprod', [10812]], ['iquest', [191]], ['iscr', [119998]], ['Iscr', [8464]], ['isin', [8712]], ['isindot', [8949]], ['isinE', [8953]], ['isins', [8948]], ['isinsv', [8947]], ['isinv', [8712]], ['it', [8290]], ['Itilde', [296]], ['itilde', [297]], ['Iukcy', [1030]], ['iukcy', [1110]], ['Iuml', [207]], ['iuml', [239]], ['Jcirc', [308]], ['jcirc', [309]], ['Jcy', [1049]], ['jcy', [1081]], ['Jfr', [120077]], ['jfr', [120103]], ['jmath', [567]], ['Jopf', [120129]], ['jopf', [120155]], ['Jscr', [119973]], ['jscr', [119999]], ['Jsercy', [1032]], ['jsercy', [1112]], ['Jukcy', [1028]], ['jukcy', [1108]], ['Kappa', [922]], ['kappa', [954]], ['kappav', [1008]], ['Kcedil', [310]], ['kcedil', [311]], ['Kcy', [1050]], ['kcy', [1082]], ['Kfr', [120078]], ['kfr', [120104]], ['kgreen', [312]], ['KHcy', [1061]], ['khcy', [1093]], ['KJcy', [1036]], ['kjcy', [1116]], ['Kopf', [120130]], ['kopf', [120156]], ['Kscr', [119974]], ['kscr', [120000]], ['lAarr', [8666]], ['Lacute', [313]], ['lacute', [314]], ['laemptyv', [10676]], ['lagran', [8466]], ['Lambda', [923]], ['lambda', [955]], ['lang', [10216]], ['Lang', [10218]], ['langd', [10641]], ['langle', [10216]], ['lap', [10885]], ['Laplacetrf', [8466]], ['laquo', [171]], ['larrb', [8676]], ['larrbfs', [10527]], ['larr', [8592]], ['Larr', [8606]], ['lArr', [8656]], ['larrfs', [10525]], ['larrhk', [8617]], ['larrlp', [8619]], ['larrpl', [10553]], ['larrsim', [10611]], ['larrtl', [8610]], ['latail', [10521]], ['lAtail', [10523]], ['lat', [10923]], ['late', [10925]], ['lates', [10925, 65024]], ['lbarr', [10508]], ['lBarr', [10510]], ['lbbrk', [10098]], ['lbrace', [123]], ['lbrack', [91]], ['lbrke', [10635]], ['lbrksld', [10639]], ['lbrkslu', [10637]], ['Lcaron', [317]], ['lcaron', [318]], ['Lcedil', [315]], ['lcedil', [316]], ['lceil', [8968]], ['lcub', [123]], ['Lcy', [1051]], ['lcy', [1083]], ['ldca', [10550]], ['ldquo', [8220]], ['ldquor', [8222]], ['ldrdhar', [10599]], ['ldrushar', [10571]], ['ldsh', [8626]], ['le', [8804]], ['lE', [8806]], ['LeftAngleBracket', [10216]], ['LeftArrowBar', [8676]], ['leftarrow', [8592]], ['LeftArrow', [8592]], ['Leftarrow', [8656]], ['LeftArrowRightArrow', [8646]], ['leftarrowtail', [8610]], ['LeftCeiling', [8968]], ['LeftDoubleBracket', [10214]], ['LeftDownTeeVector', [10593]], ['LeftDownVectorBar', [10585]], ['LeftDownVector', [8643]], ['LeftFloor', [8970]], ['leftharpoondown', [8637]], ['leftharpoonup', [8636]], ['leftleftarrows', [8647]], ['leftrightarrow', [8596]], ['LeftRightArrow', [8596]], ['Leftrightarrow', [8660]], ['leftrightarrows', [8646]], ['leftrightharpoons', [8651]], ['leftrightsquigarrow', [8621]], ['LeftRightVector', [10574]], ['LeftTeeArrow', [8612]], ['LeftTee', [8867]], ['LeftTeeVector', [10586]], ['leftthreetimes', [8907]], ['LeftTriangleBar', [10703]], ['LeftTriangle', [8882]], ['LeftTriangleEqual', [8884]], ['LeftUpDownVector', [10577]], ['LeftUpTeeVector', [10592]], ['LeftUpVectorBar', [10584]], ['LeftUpVector', [8639]], ['LeftVectorBar', [10578]], ['LeftVector', [8636]], ['lEg', [10891]], ['leg', [8922]], ['leq', [8804]], ['leqq', [8806]], ['leqslant', [10877]], ['lescc', [10920]], ['les', [10877]], ['lesdot', [10879]], ['lesdoto', [10881]], ['lesdotor', [10883]], ['lesg', [8922, 65024]], ['lesges', [10899]], ['lessapprox', [10885]], ['lessdot', [8918]], ['lesseqgtr', [8922]], ['lesseqqgtr', [10891]], ['LessEqualGreater', [8922]], ['LessFullEqual', [8806]], ['LessGreater', [8822]], ['lessgtr', [8822]], ['LessLess', [10913]], ['lesssim', [8818]], ['LessSlantEqual', [10877]], ['LessTilde', [8818]], ['lfisht', [10620]], ['lfloor', [8970]], ['Lfr', [120079]], ['lfr', [120105]], ['lg', [8822]], ['lgE', [10897]], ['lHar', [10594]], ['lhard', [8637]], ['lharu', [8636]], ['lharul', [10602]], ['lhblk', [9604]], ['LJcy', [1033]], ['ljcy', [1113]], ['llarr', [8647]], ['ll', [8810]], ['Ll', [8920]], ['llcorner', [8990]], ['Lleftarrow', [8666]], ['llhard', [10603]], ['lltri', [9722]], ['Lmidot', [319]], ['lmidot', [320]], ['lmoustache', [9136]], ['lmoust', [9136]], ['lnap', [10889]], ['lnapprox', [10889]], ['lne', [10887]], ['lnE', [8808]], ['lneq', [10887]], ['lneqq', [8808]], ['lnsim', [8934]], ['loang', [10220]], ['loarr', [8701]], ['lobrk', [10214]], ['longleftarrow', [10229]], ['LongLeftArrow', [10229]], ['Longleftarrow', [10232]], ['longleftrightarrow', [10231]], ['LongLeftRightArrow', [10231]], ['Longleftrightarrow', [10234]], ['longmapsto', [10236]], ['longrightarrow', [10230]], ['LongRightArrow', [10230]], ['Longrightarrow', [10233]], ['looparrowleft', [8619]], ['looparrowright', [8620]], ['lopar', [10629]], ['Lopf', [120131]], ['lopf', [120157]], ['loplus', [10797]], ['lotimes', [10804]], ['lowast', [8727]], ['lowbar', [95]], ['LowerLeftArrow', [8601]], ['LowerRightArrow', [8600]], ['loz', [9674]], ['lozenge', [9674]], ['lozf', [10731]], ['lpar', [40]], ['lparlt', [10643]], ['lrarr', [8646]], ['lrcorner', [8991]], ['lrhar', [8651]], ['lrhard', [10605]], ['lrm', [8206]], ['lrtri', [8895]], ['lsaquo', [8249]], ['lscr', [120001]], ['Lscr', [8466]], ['lsh', [8624]], ['Lsh', [8624]], ['lsim', [8818]], ['lsime', [10893]], ['lsimg', [10895]], ['lsqb', [91]], ['lsquo', [8216]], ['lsquor', [8218]], ['Lstrok', [321]], ['lstrok', [322]], ['ltcc', [10918]], ['ltcir', [10873]], ['lt', [60]], ['LT', [60]], ['Lt', [8810]], ['ltdot', [8918]], ['lthree', [8907]], ['ltimes', [8905]], ['ltlarr', [10614]], ['ltquest', [10875]], ['ltri', [9667]], ['ltrie', [8884]], ['ltrif', [9666]], ['ltrPar', [10646]], ['lurdshar', [10570]], ['luruhar', [10598]], ['lvertneqq', [8808, 65024]], ['lvnE', [8808, 65024]], ['macr', [175]], ['male', [9794]], ['malt', [10016]], ['maltese', [10016]], ['Map', [10501]], ['map', [8614]], ['mapsto', [8614]], ['mapstodown', [8615]], ['mapstoleft', [8612]], ['mapstoup', [8613]], ['marker', [9646]], ['mcomma', [10793]], ['Mcy', [1052]], ['mcy', [1084]], ['mdash', [8212]], ['mDDot', [8762]], ['measuredangle', [8737]], ['MediumSpace', [8287]], ['Mellintrf', [8499]], ['Mfr', [120080]], ['mfr', [120106]], ['mho', [8487]], ['micro', [181]], ['midast', [42]], ['midcir', [10992]], ['mid', [8739]], ['middot', [183]], ['minusb', [8863]], ['minus', [8722]], ['minusd', [8760]], ['minusdu', [10794]], ['MinusPlus', [8723]], ['mlcp', [10971]], ['mldr', [8230]], ['mnplus', [8723]], ['models', [8871]], ['Mopf', [120132]], ['mopf', [120158]], ['mp', [8723]], ['mscr', [120002]], ['Mscr', [8499]], ['mstpos', [8766]], ['Mu', [924]], ['mu', [956]], ['multimap', [8888]], ['mumap', [8888]], ['nabla', [8711]], ['Nacute', [323]], ['nacute', [324]], ['nang', [8736, 8402]], ['nap', [8777]], ['napE', [10864, 824]], ['napid', [8779, 824]], ['napos', [329]], ['napprox', [8777]], ['natural', [9838]], ['naturals', [8469]], ['natur', [9838]], ['nbsp', [160]], ['nbump', [8782, 824]], ['nbumpe', [8783, 824]], ['ncap', [10819]], ['Ncaron', [327]], ['ncaron', [328]], ['Ncedil', [325]], ['ncedil', [326]], ['ncong', [8775]], ['ncongdot', [10861, 824]], ['ncup', [10818]], ['Ncy', [1053]], ['ncy', [1085]], ['ndash', [8211]], ['nearhk', [10532]], ['nearr', [8599]], ['neArr', [8663]], ['nearrow', [8599]], ['ne', [8800]], ['nedot', [8784, 824]], ['NegativeMediumSpace', [8203]], ['NegativeThickSpace', [8203]], ['NegativeThinSpace', [8203]], ['NegativeVeryThinSpace', [8203]], ['nequiv', [8802]], ['nesear', [10536]], ['nesim', [8770, 824]], ['NestedGreaterGreater', [8811]], ['NestedLessLess', [8810]], ['nexist', [8708]], ['nexists', [8708]], ['Nfr', [120081]], ['nfr', [120107]], ['ngE', [8807, 824]], ['nge', [8817]], ['ngeq', [8817]], ['ngeqq', [8807, 824]], ['ngeqslant', [10878, 824]], ['nges', [10878, 824]], ['nGg', [8921, 824]], ['ngsim', [8821]], ['nGt', [8811, 8402]], ['ngt', [8815]], ['ngtr', [8815]], ['nGtv', [8811, 824]], ['nharr', [8622]], ['nhArr', [8654]], ['nhpar', [10994]], ['ni', [8715]], ['nis', [8956]], ['nisd', [8954]], ['niv', [8715]], ['NJcy', [1034]], ['njcy', [1114]], ['nlarr', [8602]], ['nlArr', [8653]], ['nldr', [8229]], ['nlE', [8806, 824]], ['nle', [8816]], ['nleftarrow', [8602]], ['nLeftarrow', [8653]], ['nleftrightarrow', [8622]], ['nLeftrightarrow', [8654]], ['nleq', [8816]], ['nleqq', [8806, 824]], ['nleqslant', [10877, 824]], ['nles', [10877, 824]], ['nless', [8814]], ['nLl', [8920, 824]], ['nlsim', [8820]], ['nLt', [8810, 8402]], ['nlt', [8814]], ['nltri', [8938]], ['nltrie', [8940]], ['nLtv', [8810, 824]], ['nmid', [8740]], ['NoBreak', [8288]], ['NonBreakingSpace', [160]], ['nopf', [120159]], ['Nopf', [8469]], ['Not', [10988]], ['not', [172]], ['NotCongruent', [8802]], ['NotCupCap', [8813]], ['NotDoubleVerticalBar', [8742]], ['NotElement', [8713]], ['NotEqual', [8800]], ['NotEqualTilde', [8770, 824]], ['NotExists', [8708]], ['NotGreater', [8815]], ['NotGreaterEqual', [8817]], ['NotGreaterFullEqual', [8807, 824]], ['NotGreaterGreater', [8811, 824]], ['NotGreaterLess', [8825]], ['NotGreaterSlantEqual', [10878, 824]], ['NotGreaterTilde', [8821]], ['NotHumpDownHump', [8782, 824]], ['NotHumpEqual', [8783, 824]], ['notin', [8713]], ['notindot', [8949, 824]], ['notinE', [8953, 824]], ['notinva', [8713]], ['notinvb', [8951]], ['notinvc', [8950]], ['NotLeftTriangleBar', [10703, 824]], ['NotLeftTriangle', [8938]], ['NotLeftTriangleEqual', [8940]], ['NotLess', [8814]], ['NotLessEqual', [8816]], ['NotLessGreater', [8824]], ['NotLessLess', [8810, 824]], ['NotLessSlantEqual', [10877, 824]], ['NotLessTilde', [8820]], ['NotNestedGreaterGreater', [10914, 824]], ['NotNestedLessLess', [10913, 824]], ['notni', [8716]], ['notniva', [8716]], ['notnivb', [8958]], ['notnivc', [8957]], ['NotPrecedes', [8832]], ['NotPrecedesEqual', [10927, 824]], ['NotPrecedesSlantEqual', [8928]], ['NotReverseElement', [8716]], ['NotRightTriangleBar', [10704, 824]], ['NotRightTriangle', [8939]], ['NotRightTriangleEqual', [8941]], ['NotSquareSubset', [8847, 824]], ['NotSquareSubsetEqual', [8930]], ['NotSquareSuperset', [8848, 824]], ['NotSquareSupersetEqual', [8931]], ['NotSubset', [8834, 8402]], ['NotSubsetEqual', [8840]], ['NotSucceeds', [8833]], ['NotSucceedsEqual', [10928, 824]], ['NotSucceedsSlantEqual', [8929]], ['NotSucceedsTilde', [8831, 824]], ['NotSuperset', [8835, 8402]], ['NotSupersetEqual', [8841]], ['NotTilde', [8769]], ['NotTildeEqual', [8772]], ['NotTildeFullEqual', [8775]], ['NotTildeTilde', [8777]], ['NotVerticalBar', [8740]], ['nparallel', [8742]], ['npar', [8742]], ['nparsl', [11005, 8421]], ['npart', [8706, 824]], ['npolint', [10772]], ['npr', [8832]], ['nprcue', [8928]], ['nprec', [8832]], ['npreceq', [10927, 824]], ['npre', [10927, 824]], ['nrarrc', [10547, 824]], ['nrarr', [8603]], ['nrArr', [8655]], ['nrarrw', [8605, 824]], ['nrightarrow', [8603]], ['nRightarrow', [8655]], ['nrtri', [8939]], ['nrtrie', [8941]], ['nsc', [8833]], ['nsccue', [8929]], ['nsce', [10928, 824]], ['Nscr', [119977]], ['nscr', [120003]], ['nshortmid', [8740]], ['nshortparallel', [8742]], ['nsim', [8769]], ['nsime', [8772]], ['nsimeq', [8772]], ['nsmid', [8740]], ['nspar', [8742]], ['nsqsube', [8930]], ['nsqsupe', [8931]], ['nsub', [8836]], ['nsubE', [10949, 824]], ['nsube', [8840]], ['nsubset', [8834, 8402]], ['nsubseteq', [8840]], ['nsubseteqq', [10949, 824]], ['nsucc', [8833]], ['nsucceq', [10928, 824]], ['nsup', [8837]], ['nsupE', [10950, 824]], ['nsupe', [8841]], ['nsupset', [8835, 8402]], ['nsupseteq', [8841]], ['nsupseteqq', [10950, 824]], ['ntgl', [8825]], ['Ntilde', [209]], ['ntilde', [241]], ['ntlg', [8824]], ['ntriangleleft', [8938]], ['ntrianglelefteq', [8940]], ['ntriangleright', [8939]], ['ntrianglerighteq', [8941]], ['Nu', [925]], ['nu', [957]], ['num', [35]], ['numero', [8470]], ['numsp', [8199]], ['nvap', [8781, 8402]], ['nvdash', [8876]], ['nvDash', [8877]], ['nVdash', [8878]], ['nVDash', [8879]], ['nvge', [8805, 8402]], ['nvgt', [62, 8402]], ['nvHarr', [10500]], ['nvinfin', [10718]], ['nvlArr', [10498]], ['nvle', [8804, 8402]], ['nvlt', [60, 8402]], ['nvltrie', [8884, 8402]], ['nvrArr', [10499]], ['nvrtrie', [8885, 8402]], ['nvsim', [8764, 8402]], ['nwarhk', [10531]], ['nwarr', [8598]], ['nwArr', [8662]], ['nwarrow', [8598]], ['nwnear', [10535]], ['Oacute', [211]], ['oacute', [243]], ['oast', [8859]], ['Ocirc', [212]], ['ocirc', [244]], ['ocir', [8858]], ['Ocy', [1054]], ['ocy', [1086]], ['odash', [8861]], ['Odblac', [336]], ['odblac', [337]], ['odiv', [10808]], ['odot', [8857]], ['odsold', [10684]], ['OElig', [338]], ['oelig', [339]], ['ofcir', [10687]], ['Ofr', [120082]], ['ofr', [120108]], ['ogon', [731]], ['Ograve', [210]], ['ograve', [242]], ['ogt', [10689]], ['ohbar', [10677]], ['ohm', [937]], ['oint', [8750]], ['olarr', [8634]], ['olcir', [10686]], ['olcross', [10683]], ['oline', [8254]], ['olt', [10688]], ['Omacr', [332]], ['omacr', [333]], ['Omega', [937]], ['omega', [969]], ['Omicron', [927]], ['omicron', [959]], ['omid', [10678]], ['ominus', [8854]], ['Oopf', [120134]], ['oopf', [120160]], ['opar', [10679]], ['OpenCurlyDoubleQuote', [8220]], ['OpenCurlyQuote', [8216]], ['operp', [10681]], ['oplus', [8853]], ['orarr', [8635]], ['Or', [10836]], ['or', [8744]], ['ord', [10845]], ['order', [8500]], ['orderof', [8500]], ['ordf', [170]], ['ordm', [186]], ['origof', [8886]], ['oror', [10838]], ['orslope', [10839]], ['orv', [10843]], ['oS', [9416]], ['Oscr', [119978]], ['oscr', [8500]], ['Oslash', [216]], ['oslash', [248]], ['osol', [8856]], ['Otilde', [213]], ['otilde', [245]], ['otimesas', [10806]], ['Otimes', [10807]], ['otimes', [8855]], ['Ouml', [214]], ['ouml', [246]], ['ovbar', [9021]], ['OverBar', [8254]], ['OverBrace', [9182]], ['OverBracket', [9140]], ['OverParenthesis', [9180]], ['para', [182]], ['parallel', [8741]], ['par', [8741]], ['parsim', [10995]], ['parsl', [11005]], ['part', [8706]], ['PartialD', [8706]], ['Pcy', [1055]], ['pcy', [1087]], ['percnt', [37]], ['period', [46]], ['permil', [8240]], ['perp', [8869]], ['pertenk', [8241]], ['Pfr', [120083]], ['pfr', [120109]], ['Phi', [934]], ['phi', [966]], ['phiv', [981]], ['phmmat', [8499]], ['phone', [9742]], ['Pi', [928]], ['pi', [960]], ['pitchfork', [8916]], ['piv', [982]], ['planck', [8463]], ['planckh', [8462]], ['plankv', [8463]], ['plusacir', [10787]], ['plusb', [8862]], ['pluscir', [10786]], ['plus', [43]], ['plusdo', [8724]], ['plusdu', [10789]], ['pluse', [10866]], ['PlusMinus', [177]], ['plusmn', [177]], ['plussim', [10790]], ['plustwo', [10791]], ['pm', [177]], ['Poincareplane', [8460]], ['pointint', [10773]], ['popf', [120161]], ['Popf', [8473]], ['pound', [163]], ['prap', [10935]], ['Pr', [10939]], ['pr', [8826]], ['prcue', [8828]], ['precapprox', [10935]], ['prec', [8826]], ['preccurlyeq', [8828]], ['Precedes', [8826]], ['PrecedesEqual', [10927]], ['PrecedesSlantEqual', [8828]], ['PrecedesTilde', [8830]], ['preceq', [10927]], ['precnapprox', [10937]], ['precneqq', [10933]], ['precnsim', [8936]], ['pre', [10927]], ['prE', [10931]], ['precsim', [8830]], ['prime', [8242]], ['Prime', [8243]], ['primes', [8473]], ['prnap', [10937]], ['prnE', [10933]], ['prnsim', [8936]], ['prod', [8719]], ['Product', [8719]], ['profalar', [9006]], ['profline', [8978]], ['profsurf', [8979]], ['prop', [8733]], ['Proportional', [8733]], ['Proportion', [8759]], ['propto', [8733]], ['prsim', [8830]], ['prurel', [8880]], ['Pscr', [119979]], ['pscr', [120005]], ['Psi', [936]], ['psi', [968]], ['puncsp', [8200]], ['Qfr', [120084]], ['qfr', [120110]], ['qint', [10764]], ['qopf', [120162]], ['Qopf', [8474]], ['qprime', [8279]], ['Qscr', [119980]], ['qscr', [120006]], ['quaternions', [8461]], ['quatint', [10774]], ['quest', [63]], ['questeq', [8799]], ['quot', [34]], ['QUOT', [34]], ['rAarr', [8667]], ['race', [8765, 817]], ['Racute', [340]], ['racute', [341]], ['radic', [8730]], ['raemptyv', [10675]], ['rang', [10217]], ['Rang', [10219]], ['rangd', [10642]], ['range', [10661]], ['rangle', [10217]], ['raquo', [187]], ['rarrap', [10613]], ['rarrb', [8677]], ['rarrbfs', [10528]], ['rarrc', [10547]], ['rarr', [8594]], ['Rarr', [8608]], ['rArr', [8658]], ['rarrfs', [10526]], ['rarrhk', [8618]], ['rarrlp', [8620]], ['rarrpl', [10565]], ['rarrsim', [10612]], ['Rarrtl', [10518]], ['rarrtl', [8611]], ['rarrw', [8605]], ['ratail', [10522]], ['rAtail', [10524]], ['ratio', [8758]], ['rationals', [8474]], ['rbarr', [10509]], ['rBarr', [10511]], ['RBarr', [10512]], ['rbbrk', [10099]], ['rbrace', [125]], ['rbrack', [93]], ['rbrke', [10636]], ['rbrksld', [10638]], ['rbrkslu', [10640]], ['Rcaron', [344]], ['rcaron', [345]], ['Rcedil', [342]], ['rcedil', [343]], ['rceil', [8969]], ['rcub', [125]], ['Rcy', [1056]], ['rcy', [1088]], ['rdca', [10551]], ['rdldhar', [10601]], ['rdquo', [8221]], ['rdquor', [8221]], ['CloseCurlyDoubleQuote', [8221]], ['rdsh', [8627]], ['real', [8476]], ['realine', [8475]], ['realpart', [8476]], ['reals', [8477]], ['Re', [8476]], ['rect', [9645]], ['reg', [174]], ['REG', [174]], ['ReverseElement', [8715]], ['ReverseEquilibrium', [8651]], ['ReverseUpEquilibrium', [10607]], ['rfisht', [10621]], ['rfloor', [8971]], ['rfr', [120111]], ['Rfr', [8476]], ['rHar', [10596]], ['rhard', [8641]], ['rharu', [8640]], ['rharul', [10604]], ['Rho', [929]], ['rho', [961]], ['rhov', [1009]], ['RightAngleBracket', [10217]], ['RightArrowBar', [8677]], ['rightarrow', [8594]], ['RightArrow', [8594]], ['Rightarrow', [8658]], ['RightArrowLeftArrow', [8644]], ['rightarrowtail', [8611]], ['RightCeiling', [8969]], ['RightDoubleBracket', [10215]], ['RightDownTeeVector', [10589]], ['RightDownVectorBar', [10581]], ['RightDownVector', [8642]], ['RightFloor', [8971]], ['rightharpoondown', [8641]], ['rightharpoonup', [8640]], ['rightleftarrows', [8644]], ['rightleftharpoons', [8652]], ['rightrightarrows', [8649]], ['rightsquigarrow', [8605]], ['RightTeeArrow', [8614]], ['RightTee', [8866]], ['RightTeeVector', [10587]], ['rightthreetimes', [8908]], ['RightTriangleBar', [10704]], ['RightTriangle', [8883]], ['RightTriangleEqual', [8885]], ['RightUpDownVector', [10575]], ['RightUpTeeVector', [10588]], ['RightUpVectorBar', [10580]], ['RightUpVector', [8638]], ['RightVectorBar', [10579]], ['RightVector', [8640]], ['ring', [730]], ['risingdotseq', [8787]], ['rlarr', [8644]], ['rlhar', [8652]], ['rlm', [8207]], ['rmoustache', [9137]], ['rmoust', [9137]], ['rnmid', [10990]], ['roang', [10221]], ['roarr', [8702]], ['robrk', [10215]], ['ropar', [10630]], ['ropf', [120163]], ['Ropf', [8477]], ['roplus', [10798]], ['rotimes', [10805]], ['RoundImplies', [10608]], ['rpar', [41]], ['rpargt', [10644]], ['rppolint', [10770]], ['rrarr', [8649]], ['Rrightarrow', [8667]], ['rsaquo', [8250]], ['rscr', [120007]], ['Rscr', [8475]], ['rsh', [8625]], ['Rsh', [8625]], ['rsqb', [93]], ['rsquo', [8217]], ['rsquor', [8217]], ['CloseCurlyQuote', [8217]], ['rthree', [8908]], ['rtimes', [8906]], ['rtri', [9657]], ['rtrie', [8885]], ['rtrif', [9656]], ['rtriltri', [10702]], ['RuleDelayed', [10740]], ['ruluhar', [10600]], ['rx', [8478]], ['Sacute', [346]], ['sacute', [347]], ['sbquo', [8218]], ['scap', [10936]], ['Scaron', [352]], ['scaron', [353]], ['Sc', [10940]], ['sc', [8827]], ['sccue', [8829]], ['sce', [10928]], ['scE', [10932]], ['Scedil', [350]], ['scedil', [351]], ['Scirc', [348]], ['scirc', [349]], ['scnap', [10938]], ['scnE', [10934]], ['scnsim', [8937]], ['scpolint', [10771]], ['scsim', [8831]], ['Scy', [1057]], ['scy', [1089]], ['sdotb', [8865]], ['sdot', [8901]], ['sdote', [10854]], ['searhk', [10533]], ['searr', [8600]], ['seArr', [8664]], ['searrow', [8600]], ['sect', [167]], ['semi', [59]], ['seswar', [10537]], ['setminus', [8726]], ['setmn', [8726]], ['sext', [10038]], ['Sfr', [120086]], ['sfr', [120112]], ['sfrown', [8994]], ['sharp', [9839]], ['SHCHcy', [1065]], ['shchcy', [1097]], ['SHcy', [1064]], ['shcy', [1096]], ['ShortDownArrow', [8595]], ['ShortLeftArrow', [8592]], ['shortmid', [8739]], ['shortparallel', [8741]], ['ShortRightArrow', [8594]], ['ShortUpArrow', [8593]], ['shy', [173]], ['Sigma', [931]], ['sigma', [963]], ['sigmaf', [962]], ['sigmav', [962]], ['sim', [8764]], ['simdot', [10858]], ['sime', [8771]], ['simeq', [8771]], ['simg', [10910]], ['simgE', [10912]], ['siml', [10909]], ['simlE', [10911]], ['simne', [8774]], ['simplus', [10788]], ['simrarr', [10610]], ['slarr', [8592]], ['SmallCircle', [8728]], ['smallsetminus', [8726]], ['smashp', [10803]], ['smeparsl', [10724]], ['smid', [8739]], ['smile', [8995]], ['smt', [10922]], ['smte', [10924]], ['smtes', [10924, 65024]], ['SOFTcy', [1068]], ['softcy', [1100]], ['solbar', [9023]], ['solb', [10692]], ['sol', [47]], ['Sopf', [120138]], ['sopf', [120164]], ['spades', [9824]], ['spadesuit', [9824]], ['spar', [8741]], ['sqcap', [8851]], ['sqcaps', [8851, 65024]], ['sqcup', [8852]], ['sqcups', [8852, 65024]], ['Sqrt', [8730]], ['sqsub', [8847]], ['sqsube', [8849]], ['sqsubset', [8847]], ['sqsubseteq', [8849]], ['sqsup', [8848]], ['sqsupe', [8850]], ['sqsupset', [8848]], ['sqsupseteq', [8850]], ['square', [9633]], ['Square', [9633]], ['SquareIntersection', [8851]], ['SquareSubset', [8847]], ['SquareSubsetEqual', [8849]], ['SquareSuperset', [8848]], ['SquareSupersetEqual', [8850]], ['SquareUnion', [8852]], ['squarf', [9642]], ['squ', [9633]], ['squf', [9642]], ['srarr', [8594]], ['Sscr', [119982]], ['sscr', [120008]], ['ssetmn', [8726]], ['ssmile', [8995]], ['sstarf', [8902]], ['Star', [8902]], ['star', [9734]], ['starf', [9733]], ['straightepsilon', [1013]], ['straightphi', [981]], ['strns', [175]], ['sub', [8834]], ['Sub', [8912]], ['subdot', [10941]], ['subE', [10949]], ['sube', [8838]], ['subedot', [10947]], ['submult', [10945]], ['subnE', [10955]], ['subne', [8842]], ['subplus', [10943]], ['subrarr', [10617]], ['subset', [8834]], ['Subset', [8912]], ['subseteq', [8838]], ['subseteqq', [10949]], ['SubsetEqual', [8838]], ['subsetneq', [8842]], ['subsetneqq', [10955]], ['subsim', [10951]], ['subsub', [10965]], ['subsup', [10963]], ['succapprox', [10936]], ['succ', [8827]], ['succcurlyeq', [8829]], ['Succeeds', [8827]], ['SucceedsEqual', [10928]], ['SucceedsSlantEqual', [8829]], ['SucceedsTilde', [8831]], ['succeq', [10928]], ['succnapprox', [10938]], ['succneqq', [10934]], ['succnsim', [8937]], ['succsim', [8831]], ['SuchThat', [8715]], ['sum', [8721]], ['Sum', [8721]], ['sung', [9834]], ['sup1', [185]], ['sup2', [178]], ['sup3', [179]], ['sup', [8835]], ['Sup', [8913]], ['supdot', [10942]], ['supdsub', [10968]], ['supE', [10950]], ['supe', [8839]], ['supedot', [10948]], ['Superset', [8835]], ['SupersetEqual', [8839]], ['suphsol', [10185]], ['suphsub', [10967]], ['suplarr', [10619]], ['supmult', [10946]], ['supnE', [10956]], ['supne', [8843]], ['supplus', [10944]], ['supset', [8835]], ['Supset', [8913]], ['supseteq', [8839]], ['supseteqq', [10950]], ['supsetneq', [8843]], ['supsetneqq', [10956]], ['supsim', [10952]], ['supsub', [10964]], ['supsup', [10966]], ['swarhk', [10534]], ['swarr', [8601]], ['swArr', [8665]], ['swarrow', [8601]], ['swnwar', [10538]], ['szlig', [223]], ['Tab', [9]], ['target', [8982]], ['Tau', [932]], ['tau', [964]], ['tbrk', [9140]], ['Tcaron', [356]], ['tcaron', [357]], ['Tcedil', [354]], ['tcedil', [355]], ['Tcy', [1058]], ['tcy', [1090]], ['tdot', [8411]], ['telrec', [8981]], ['Tfr', [120087]], ['tfr', [120113]], ['there4', [8756]], ['therefore', [8756]], ['Therefore', [8756]], ['Theta', [920]], ['theta', [952]], ['thetasym', [977]], ['thetav', [977]], ['thickapprox', [8776]], ['thicksim', [8764]], ['ThickSpace', [8287, 8202]], ['ThinSpace', [8201]], ['thinsp', [8201]], ['thkap', [8776]], ['thksim', [8764]], ['THORN', [222]], ['thorn', [254]], ['tilde', [732]], ['Tilde', [8764]], ['TildeEqual', [8771]], ['TildeFullEqual', [8773]], ['TildeTilde', [8776]], ['timesbar', [10801]], ['timesb', [8864]], ['times', [215]], ['timesd', [10800]], ['tint', [8749]], ['toea', [10536]], ['topbot', [9014]], ['topcir', [10993]], ['top', [8868]], ['Topf', [120139]], ['topf', [120165]], ['topfork', [10970]], ['tosa', [10537]], ['tprime', [8244]], ['trade', [8482]], ['TRADE', [8482]], ['triangle', [9653]], ['triangledown', [9663]], ['triangleleft', [9667]], ['trianglelefteq', [8884]], ['triangleq', [8796]], ['triangleright', [9657]], ['trianglerighteq', [8885]], ['tridot', [9708]], ['trie', [8796]], ['triminus', [10810]], ['TripleDot', [8411]], ['triplus', [10809]], ['trisb', [10701]], ['tritime', [10811]], ['trpezium', [9186]], ['Tscr', [119983]], ['tscr', [120009]], ['TScy', [1062]], ['tscy', [1094]], ['TSHcy', [1035]], ['tshcy', [1115]], ['Tstrok', [358]], ['tstrok', [359]], ['twixt', [8812]], ['twoheadleftarrow', [8606]], ['twoheadrightarrow', [8608]], ['Uacute', [218]], ['uacute', [250]], ['uarr', [8593]], ['Uarr', [8607]], ['uArr', [8657]], ['Uarrocir', [10569]], ['Ubrcy', [1038]], ['ubrcy', [1118]], ['Ubreve', [364]], ['ubreve', [365]], ['Ucirc', [219]], ['ucirc', [251]], ['Ucy', [1059]], ['ucy', [1091]], ['udarr', [8645]], ['Udblac', [368]], ['udblac', [369]], ['udhar', [10606]], ['ufisht', [10622]], ['Ufr', [120088]], ['ufr', [120114]], ['Ugrave', [217]], ['ugrave', [249]], ['uHar', [10595]], ['uharl', [8639]], ['uharr', [8638]], ['uhblk', [9600]], ['ulcorn', [8988]], ['ulcorner', [8988]], ['ulcrop', [8975]], ['ultri', [9720]], ['Umacr', [362]], ['umacr', [363]], ['uml', [168]], ['UnderBar', [95]], ['UnderBrace', [9183]], ['UnderBracket', [9141]], ['UnderParenthesis', [9181]], ['Union', [8899]], ['UnionPlus', [8846]], ['Uogon', [370]], ['uogon', [371]], ['Uopf', [120140]], ['uopf', [120166]], ['UpArrowBar', [10514]], ['uparrow', [8593]], ['UpArrow', [8593]], ['Uparrow', [8657]], ['UpArrowDownArrow', [8645]], ['updownarrow', [8597]], ['UpDownArrow', [8597]], ['Updownarrow', [8661]], ['UpEquilibrium', [10606]], ['upharpoonleft', [8639]], ['upharpoonright', [8638]], ['uplus', [8846]], ['UpperLeftArrow', [8598]], ['UpperRightArrow', [8599]], ['upsi', [965]], ['Upsi', [978]], ['upsih', [978]], ['Upsilon', [933]], ['upsilon', [965]], ['UpTeeArrow', [8613]], ['UpTee', [8869]], ['upuparrows', [8648]], ['urcorn', [8989]], ['urcorner', [8989]], ['urcrop', [8974]], ['Uring', [366]], ['uring', [367]], ['urtri', [9721]], ['Uscr', [119984]], ['uscr', [120010]], ['utdot', [8944]], ['Utilde', [360]], ['utilde', [361]], ['utri', [9653]], ['utrif', [9652]], ['uuarr', [8648]], ['Uuml', [220]], ['uuml', [252]], ['uwangle', [10663]], ['vangrt', [10652]], ['varepsilon', [1013]], ['varkappa', [1008]], ['varnothing', [8709]], ['varphi', [981]], ['varpi', [982]], ['varpropto', [8733]], ['varr', [8597]], ['vArr', [8661]], ['varrho', [1009]], ['varsigma', [962]], ['varsubsetneq', [8842, 65024]], ['varsubsetneqq', [10955, 65024]], ['varsupsetneq', [8843, 65024]], ['varsupsetneqq', [10956, 65024]], ['vartheta', [977]], ['vartriangleleft', [8882]], ['vartriangleright', [8883]], ['vBar', [10984]], ['Vbar', [10987]], ['vBarv', [10985]], ['Vcy', [1042]], ['vcy', [1074]], ['vdash', [8866]], ['vDash', [8872]], ['Vdash', [8873]], ['VDash', [8875]], ['Vdashl', [10982]], ['veebar', [8891]], ['vee', [8744]], ['Vee', [8897]], ['veeeq', [8794]], ['vellip', [8942]], ['verbar', [124]], ['Verbar', [8214]], ['vert', [124]], ['Vert', [8214]], ['VerticalBar', [8739]], ['VerticalLine', [124]], ['VerticalSeparator', [10072]], ['VerticalTilde', [8768]], ['VeryThinSpace', [8202]], ['Vfr', [120089]], ['vfr', [120115]], ['vltri', [8882]], ['vnsub', [8834, 8402]], ['vnsup', [8835, 8402]], ['Vopf', [120141]], ['vopf', [120167]], ['vprop', [8733]], ['vrtri', [8883]], ['Vscr', [119985]], ['vscr', [120011]], ['vsubnE', [10955, 65024]], ['vsubne', [8842, 65024]], ['vsupnE', [10956, 65024]], ['vsupne', [8843, 65024]], ['Vvdash', [8874]], ['vzigzag', [10650]], ['Wcirc', [372]], ['wcirc', [373]], ['wedbar', [10847]], ['wedge', [8743]], ['Wedge', [8896]], ['wedgeq', [8793]], ['weierp', [8472]], ['Wfr', [120090]], ['wfr', [120116]], ['Wopf', [120142]], ['wopf', [120168]], ['wp', [8472]], ['wr', [8768]], ['wreath', [8768]], ['Wscr', [119986]], ['wscr', [120012]], ['xcap', [8898]], ['xcirc', [9711]], ['xcup', [8899]], ['xdtri', [9661]], ['Xfr', [120091]], ['xfr', [120117]], ['xharr', [10231]], ['xhArr', [10234]], ['Xi', [926]], ['xi', [958]], ['xlarr', [10229]], ['xlArr', [10232]], ['xmap', [10236]], ['xnis', [8955]], ['xodot', [10752]], ['Xopf', [120143]], ['xopf', [120169]], ['xoplus', [10753]], ['xotime', [10754]], ['xrarr', [10230]], ['xrArr', [10233]], ['Xscr', [119987]], ['xscr', [120013]], ['xsqcup', [10758]], ['xuplus', [10756]], ['xutri', [9651]], ['xvee', [8897]], ['xwedge', [8896]], ['Yacute', [221]], ['yacute', [253]], ['YAcy', [1071]], ['yacy', [1103]], ['Ycirc', [374]], ['ycirc', [375]], ['Ycy', [1067]], ['ycy', [1099]], ['yen', [165]], ['Yfr', [120092]], ['yfr', [120118]], ['YIcy', [1031]], ['yicy', [1111]], ['Yopf', [120144]], ['yopf', [120170]], ['Yscr', [119988]], ['yscr', [120014]], ['YUcy', [1070]], ['yucy', [1102]], ['yuml', [255]], ['Yuml', [376]], ['Zacute', [377]], ['zacute', [378]], ['Zcaron', [381]], ['zcaron', [382]], ['Zcy', [1047]], ['zcy', [1079]], ['Zdot', [379]], ['zdot', [380]], ['zeetrf', [8488]], ['ZeroWidthSpace', [8203]], ['Zeta', [918]], ['zeta', [950]], ['zfr', [120119]], ['Zfr', [8488]], ['ZHcy', [1046]], ['zhcy', [1078]], ['zigrarr', [8669]], ['zopf', [120171]], ['Zopf', [8484]], ['Zscr', [119989]], ['zscr', [120015]], ['zwj', [8205]], ['zwnj', [8204]]];\n\nvar alphaIndex = {};\nvar charIndex = {};\n\ncreateIndexes(alphaIndex, charIndex);\n\n/**\n * @constructor\n */\nfunction Html5Entities() {}\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml5Entities.prototype.decode = function(str) {\n if (!str || !str.length) {\n return '';\n }\n return str.replace(/&(#?[\\w\\d]+);?/g, function(s, entity) {\n var chr;\n if (entity.charAt(0) === \"#\") {\n var code = entity.charAt(1) === 'x' ?\n parseInt(entity.substr(2).toLowerCase(), 16) :\n parseInt(entity.substr(1));\n\n if (!(isNaN(code) || code < -32768 || code > 65535)) {\n chr = String.fromCharCode(code);\n }\n } else {\n chr = alphaIndex[entity];\n }\n return chr || s;\n });\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n Html5Entities.decode = function(str) {\n return new Html5Entities().decode(str);\n };\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml5Entities.prototype.encode = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var charInfo = charIndex[str.charCodeAt(i)];\n if (charInfo) {\n var alpha = charInfo[str.charCodeAt(i + 1)];\n if (alpha) {\n i++;\n } else {\n alpha = charInfo[''];\n }\n if (alpha) {\n result += \"&\" + alpha + \";\";\n i++;\n continue;\n }\n }\n result += str.charAt(i);\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n Html5Entities.encode = function(str) {\n return new Html5Entities().encode(str);\n };\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml5Entities.prototype.encodeNonUTF = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var c = str.charCodeAt(i);\n var charInfo = charIndex[c];\n if (charInfo) {\n var alpha = charInfo[str.charCodeAt(i + 1)];\n if (alpha) {\n i++;\n } else {\n alpha = charInfo[''];\n }\n if (alpha) {\n result += \"&\" + alpha + \";\";\n i++;\n continue;\n }\n }\n if (c < 32 || c > 126) {\n result += '&#' + c + ';';\n } else {\n result += str.charAt(i);\n }\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n Html5Entities.encodeNonUTF = function(str) {\n return new Html5Entities().encodeNonUTF(str);\n };\n\n/**\n * @param {String} str\n * @returns {String}\n */\nHtml5Entities.prototype.encodeNonASCII = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var c = str.charCodeAt(i);\n if (c <= 255) {\n result += str[i++];\n continue;\n }\n result += '&#' + c + ';';\n i++\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n Html5Entities.encodeNonASCII = function(str) {\n return new Html5Entities().encodeNonASCII(str);\n };\n\n/**\n * @param {Object} alphaIndex Passed by reference.\n * @param {Object} charIndex Passed by reference.\n */\nfunction createIndexes(alphaIndex, charIndex) {\n var i = ENTITIES.length;\n var _results = [];\n while (i--) {\n var e = ENTITIES[i];\n var alpha = e[0];\n var chars = e[1];\n var chr = chars[0];\n var addChar = (chr < 32 || chr > 126) || chr === 62 || chr === 60 || chr === 38 || chr === 34 || chr === 39;\n var charInfo;\n if (addChar) {\n charInfo = charIndex[chr] = charIndex[chr] || {};\n }\n if (chars[1]) {\n var chr2 = chars[1];\n alphaIndex[alpha] = String.fromCharCode(chr) + String.fromCharCode(chr2);\n _results.push(addChar && (charInfo[chr2] = alpha));\n } else {\n alphaIndex[alpha] = String.fromCharCode(chr);\n _results.push(addChar && (charInfo[''] = alpha));\n }\n }\n}\n\nmodule.exports = Html5Entities;\n\n\n//# sourceURL=webpack:///./node_modules/html-entities/lib/html5-entities.js?"); + +/***/ }), + +/***/ "./node_modules/html-entities/lib/xml-entities.js": +/*!********************************************************!*\ + !*** ./node_modules/html-entities/lib/xml-entities.js ***! + \********************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +eval("var ALPHA_INDEX = {\n '<': '<',\n '>': '>',\n '"': '\"',\n '&apos': '\\'',\n '&': '&',\n '<': '<',\n '>': '>',\n '"': '\"',\n ''': '\\'',\n '&': '&'\n};\n\nvar CHAR_INDEX = {\n 60: 'lt',\n 62: 'gt',\n 34: 'quot',\n 39: 'apos',\n 38: 'amp'\n};\n\nvar CHAR_S_INDEX = {\n '<': '<',\n '>': '>',\n '\"': '"',\n '\\'': ''',\n '&': '&'\n};\n\n/**\n * @constructor\n */\nfunction XmlEntities() {}\n\n/**\n * @param {String} str\n * @returns {String}\n */\nXmlEntities.prototype.encode = function(str) {\n if (!str || !str.length) {\n return '';\n }\n return str.replace(/<|>|\"|'|&/g, function(s) {\n return CHAR_S_INDEX[s];\n });\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n XmlEntities.encode = function(str) {\n return new XmlEntities().encode(str);\n };\n\n/**\n * @param {String} str\n * @returns {String}\n */\nXmlEntities.prototype.decode = function(str) {\n if (!str || !str.length) {\n return '';\n }\n return str.replace(/&#?[0-9a-zA-Z]+;?/g, function(s) {\n if (s.charAt(1) === '#') {\n var code = s.charAt(2).toLowerCase() === 'x' ?\n parseInt(s.substr(3), 16) :\n parseInt(s.substr(2));\n\n if (isNaN(code) || code < -32768 || code > 65535) {\n return '';\n }\n return String.fromCharCode(code);\n }\n return ALPHA_INDEX[s] || s;\n });\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n XmlEntities.decode = function(str) {\n return new XmlEntities().decode(str);\n };\n\n/**\n * @param {String} str\n * @returns {String}\n */\nXmlEntities.prototype.encodeNonUTF = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLength = str.length;\n var result = '';\n var i = 0;\n while (i < strLength) {\n var c = str.charCodeAt(i);\n var alpha = CHAR_INDEX[c];\n if (alpha) {\n result += \"&\" + alpha + \";\";\n i++;\n continue;\n }\n if (c < 32 || c > 126) {\n result += '&#' + c + ';';\n } else {\n result += str.charAt(i);\n }\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n XmlEntities.encodeNonUTF = function(str) {\n return new XmlEntities().encodeNonUTF(str);\n };\n\n/**\n * @param {String} str\n * @returns {String}\n */\nXmlEntities.prototype.encodeNonASCII = function(str) {\n if (!str || !str.length) {\n return '';\n }\n var strLenght = str.length;\n var result = '';\n var i = 0;\n while (i < strLenght) {\n var c = str.charCodeAt(i);\n if (c <= 255) {\n result += str[i++];\n continue;\n }\n result += '&#' + c + ';';\n i++;\n }\n return result;\n};\n\n/**\n * @param {String} str\n * @returns {String}\n */\n XmlEntities.encodeNonASCII = function(str) {\n return new XmlEntities().encodeNonASCII(str);\n };\n\nmodule.exports = XmlEntities;\n\n\n//# sourceURL=webpack:///./node_modules/html-entities/lib/xml-entities.js?"); + +/***/ }), + +/***/ "./node_modules/is-what/dist/index.esm.js": +/*!************************************************!*\ + !*** ./node_modules/is-what/dist/index.esm.js ***! + \************************************************/ +/*! exports provided: getType, isAnyObject, isArray, isBlob, isBoolean, isDate, isEmptyString, isFile, isFullString, isFunction, isNull, isNullOrUndefined, isNumber, isObject, isObjectLike, isPlainObject, isPrimitive, isRegExp, isString, isSymbol, isType, isUndefined */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getType\", function() { return getType; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isAnyObject\", function() { return isAnyObject; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isArray\", function() { return isArray; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isBlob\", function() { return isBlob; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isBoolean\", function() { return isBoolean; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isDate\", function() { return isDate; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isEmptyString\", function() { return isEmptyString; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isFile\", function() { return isFile; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isFullString\", function() { return isFullString; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isFunction\", function() { return isFunction; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isNull\", function() { return isNull; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isNullOrUndefined\", function() { return isNullOrUndefined; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isNumber\", function() { return isNumber; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isObject\", function() { return isObject; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isObjectLike\", function() { return isObjectLike; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isPlainObject\", function() { return isPlainObject; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isPrimitive\", function() { return isPrimitive; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isRegExp\", function() { return isRegExp; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isString\", function() { return isString; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isSymbol\", function() { return isSymbol; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isType\", function() { return isType; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isUndefined\", function() { return isUndefined; });\n/**\r\n * Returns the object type of the given payload\r\n *\r\n * @param {*} payload\r\n * @returns {string}\r\n */\r\nfunction getType(payload) {\r\n return Object.prototype.toString.call(payload).slice(8, -1);\r\n}\r\n/**\r\n * Returns whether the payload is undefined\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isUndefined(payload) {\r\n return getType(payload) === 'Undefined';\r\n}\r\n/**\r\n * Returns whether the payload is null\r\n *\r\n * @param {*} payload\r\n * @returns {payload is null}\r\n */\r\nfunction isNull(payload) {\r\n return getType(payload) === 'Null';\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is {[key: string]: any}}\r\n */\r\nfunction isPlainObject(payload) {\r\n if (getType(payload) !== 'Object')\r\n return false;\r\n return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype;\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is {[key: string]: any}}\r\n */\r\nfunction isObject(payload) {\r\n return isPlainObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is {[key: string]: any}}\r\n */\r\nfunction isAnyObject(payload) {\r\n return getType(payload) === 'Object';\r\n}\r\n/**\r\n * Returns whether the payload is an object like a type passed in < >\r\n *\r\n * Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an `id` prop.\r\n *\r\n * @template T this must be passed in < >\r\n * @param {*} payload\r\n * @returns {payload is T}\r\n */\r\nfunction isObjectLike(payload) {\r\n return isAnyObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a function\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Function}\r\n */\r\nfunction isFunction(payload) {\r\n return getType(payload) === 'Function';\r\n}\r\n/**\r\n * Returns whether the payload is an array\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isArray(payload) {\r\n return getType(payload) === 'Array';\r\n}\r\n/**\r\n * Returns whether the payload is a string\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isString(payload) {\r\n return getType(payload) === 'String';\r\n}\r\n/**\r\n * Returns whether the payload is a string, BUT returns false for ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isFullString(payload) {\r\n return isString(payload) && payload !== '';\r\n}\r\n/**\r\n * Returns whether the payload is ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isEmptyString(payload) {\r\n return payload === '';\r\n}\r\n/**\r\n * Returns whether the payload is a number\r\n *\r\n * This will return false for NaN\r\n *\r\n * @param {*} payload\r\n * @returns {payload is number}\r\n */\r\nfunction isNumber(payload) {\r\n return getType(payload) === 'Number' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a boolean\r\n *\r\n * @param {*} payload\r\n * @returns {payload is boolean}\r\n */\r\nfunction isBoolean(payload) {\r\n return getType(payload) === 'Boolean';\r\n}\r\n/**\r\n * Returns whether the payload is a regular expression\r\n *\r\n * @param {*} payload\r\n * @returns {payload is RegExp}\r\n */\r\nfunction isRegExp(payload) {\r\n return getType(payload) === 'RegExp';\r\n}\r\n/**\r\n * Returns whether the payload is a Symbol\r\n *\r\n * @param {*} payload\r\n * @returns {payload is symbol}\r\n */\r\nfunction isSymbol(payload) {\r\n return getType(payload) === 'Symbol';\r\n}\r\n/**\r\n * Returns whether the payload is a date, and that the date is Valid\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Date}\r\n */\r\nfunction isDate(payload) {\r\n return getType(payload) === 'Date' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a blob\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Blob}\r\n */\r\nfunction isBlob(payload) {\r\n return getType(payload) === 'Blob';\r\n}\r\n/**\r\n * Returns whether the payload is a file\r\n *\r\n * @param {*} payload\r\n * @returns {payload is File}\r\n */\r\nfunction isFile(payload) {\r\n return getType(payload) === 'File';\r\n}\r\n/**\r\n * Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is boolean | null | undefined | number | string | symbol)}\r\n */\r\nfunction isPrimitive(payload) {\r\n return (isBoolean(payload) ||\r\n isNull(payload) ||\r\n isUndefined(payload) ||\r\n isNumber(payload) ||\r\n isString(payload) ||\r\n isSymbol(payload));\r\n}\r\n/**\r\n * Returns true whether the payload is null or undefined\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is null | undefined)}\r\n */\r\nfunction isNullOrUndefined(payload) {\r\n return isNull(payload) || isUndefined(payload);\r\n}\r\n/**\r\n * Does a generic check to check that the given payload is of a given type.\r\n * In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!);\r\n * It will, however, differentiate between object and null\r\n *\r\n * @template T\r\n * @param {*} payload\r\n * @param {T} type\r\n * @throws {TypeError} Will throw type error if type is an invalid type\r\n * @returns {payload is T}\r\n */\r\nfunction isType(payload, type) {\r\n if (!(type instanceof Function)) {\r\n throw new TypeError('Type must be a function');\r\n }\r\n if (!type.hasOwnProperty('prototype')) {\r\n throw new TypeError('Type is not a class');\r\n }\r\n // Classes usually have names (as functions usually have names)\r\n var name = type.name;\r\n return getType(payload) === name || Boolean(payload && payload.constructor === type);\r\n}\n\n\n\n\n//# sourceURL=webpack:///./node_modules/is-what/dist/index.esm.js?"); + +/***/ }), + +/***/ "./node_modules/isarray/index.js": +/*!***************************************!*\ + !*** ./node_modules/isarray/index.js ***! + \***************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +eval("module.exports = Array.isArray || function (arr) {\n return Object.prototype.toString.call(arr) == '[object Array]';\n};\n\n\n//# sourceURL=webpack:///./node_modules/isarray/index.js?"); + +/***/ }), + +/***/ "./node_modules/loglevel/lib/loglevel.js": +/*!***********************************************!*\ + !*** ./node_modules/loglevel/lib/loglevel.js ***! + \***********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +eval("var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/*\n* loglevel - https://github.com/pimterry/loglevel\n*\n* Copyright (c) 2013 Tim Perry\n* Licensed under the MIT license.\n*/\n(function (root, definition) {\n \"use strict\";\n if (true) {\n !(__WEBPACK_AMD_DEFINE_FACTORY__ = (definition),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\n\t\t\t\t__WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n } else {}\n}(this, function () {\n \"use strict\";\n\n // Slightly dubious tricks to cut down minimized file size\n var noop = function() {};\n var undefinedType = \"undefined\";\n var isIE = (typeof window !== undefinedType) && (\n /Trident\\/|MSIE /.test(window.navigator.userAgent)\n );\n\n var logMethods = [\n \"trace\",\n \"debug\",\n \"info\",\n \"warn\",\n \"error\"\n ];\n\n // Cross-browser bind equivalent that works at least back to IE6\n function bindMethod(obj, methodName) {\n var method = obj[methodName];\n if (typeof method.bind === 'function') {\n return method.bind(obj);\n } else {\n try {\n return Function.prototype.bind.call(method, obj);\n } catch (e) {\n // Missing bind shim or IE8 + Modernizr, fallback to wrapping\n return function() {\n return Function.prototype.apply.apply(method, [obj, arguments]);\n };\n }\n }\n }\n\n // Trace() doesn't print the message in IE, so for that case we need to wrap it\n function traceForIE() {\n if (console.log) {\n if (console.log.apply) {\n console.log.apply(console, arguments);\n } else {\n // In old IE, native console methods themselves don't have apply().\n Function.prototype.apply.apply(console.log, [console, arguments]);\n }\n }\n if (console.trace) console.trace();\n }\n\n // Build the best logging method possible for this env\n // Wherever possible we want to bind, not wrap, to preserve stack traces\n function realMethod(methodName) {\n if (methodName === 'debug') {\n methodName = 'log';\n }\n\n if (typeof console === undefinedType) {\n return false; // No method possible, for now - fixed later by enableLoggingWhenConsoleArrives\n } else if (methodName === 'trace' && isIE) {\n return traceForIE;\n } else if (console[methodName] !== undefined) {\n return bindMethod(console, methodName);\n } else if (console.log !== undefined) {\n return bindMethod(console, 'log');\n } else {\n return noop;\n }\n }\n\n // These private functions always need `this` to be set properly\n\n function replaceLoggingMethods(level, loggerName) {\n /*jshint validthis:true */\n for (var i = 0; i < logMethods.length; i++) {\n var methodName = logMethods[i];\n this[methodName] = (i < level) ?\n noop :\n this.methodFactory(methodName, level, loggerName);\n }\n\n // Define log.log as an alias for log.debug\n this.log = this.debug;\n }\n\n // In old IE versions, the console isn't present until you first open it.\n // We build realMethod() replacements here that regenerate logging methods\n function enableLoggingWhenConsoleArrives(methodName, level, loggerName) {\n return function () {\n if (typeof console !== undefinedType) {\n replaceLoggingMethods.call(this, level, loggerName);\n this[methodName].apply(this, arguments);\n }\n };\n }\n\n // By default, we use closely bound real methods wherever possible, and\n // otherwise we wait for a console to appear, and then try again.\n function defaultMethodFactory(methodName, level, loggerName) {\n /*jshint validthis:true */\n return realMethod(methodName) ||\n enableLoggingWhenConsoleArrives.apply(this, arguments);\n }\n\n function Logger(name, defaultLevel, factory) {\n var self = this;\n var currentLevel;\n var storageKey = \"loglevel\";\n if (name) {\n storageKey += \":\" + name;\n }\n\n function persistLevelIfPossible(levelNum) {\n var levelName = (logMethods[levelNum] || 'silent').toUpperCase();\n\n if (typeof window === undefinedType) return;\n\n // Use localStorage if available\n try {\n window.localStorage[storageKey] = levelName;\n return;\n } catch (ignore) {}\n\n // Use session cookie as fallback\n try {\n window.document.cookie =\n encodeURIComponent(storageKey) + \"=\" + levelName + \";\";\n } catch (ignore) {}\n }\n\n function getPersistedLevel() {\n var storedLevel;\n\n if (typeof window === undefinedType) return;\n\n try {\n storedLevel = window.localStorage[storageKey];\n } catch (ignore) {}\n\n // Fallback to cookies if local storage gives us nothing\n if (typeof storedLevel === undefinedType) {\n try {\n var cookie = window.document.cookie;\n var location = cookie.indexOf(\n encodeURIComponent(storageKey) + \"=\");\n if (location !== -1) {\n storedLevel = /^([^;]+)/.exec(cookie.slice(location))[1];\n }\n } catch (ignore) {}\n }\n\n // If the stored level is not valid, treat it as if nothing was stored.\n if (self.levels[storedLevel] === undefined) {\n storedLevel = undefined;\n }\n\n return storedLevel;\n }\n\n /*\n *\n * Public logger API - see https://github.com/pimterry/loglevel for details\n *\n */\n\n self.name = name;\n\n self.levels = { \"TRACE\": 0, \"DEBUG\": 1, \"INFO\": 2, \"WARN\": 3,\n \"ERROR\": 4, \"SILENT\": 5};\n\n self.methodFactory = factory || defaultMethodFactory;\n\n self.getLevel = function () {\n return currentLevel;\n };\n\n self.setLevel = function (level, persist) {\n if (typeof level === \"string\" && self.levels[level.toUpperCase()] !== undefined) {\n level = self.levels[level.toUpperCase()];\n }\n if (typeof level === \"number\" && level >= 0 && level <= self.levels.SILENT) {\n currentLevel = level;\n if (persist !== false) { // defaults to true\n persistLevelIfPossible(level);\n }\n replaceLoggingMethods.call(self, level, name);\n if (typeof console === undefinedType && level < self.levels.SILENT) {\n return \"No console available for logging\";\n }\n } else {\n throw \"log.setLevel() called with invalid level: \" + level;\n }\n };\n\n self.setDefaultLevel = function (level) {\n if (!getPersistedLevel()) {\n self.setLevel(level, false);\n }\n };\n\n self.enableAll = function(persist) {\n self.setLevel(self.levels.TRACE, persist);\n };\n\n self.disableAll = function(persist) {\n self.setLevel(self.levels.SILENT, persist);\n };\n\n // Initialize with the right level\n var initialLevel = getPersistedLevel();\n if (initialLevel == null) {\n initialLevel = defaultLevel == null ? \"WARN\" : defaultLevel;\n }\n self.setLevel(initialLevel, false);\n }\n\n /*\n *\n * Top-level API\n *\n */\n\n var defaultLogger = new Logger();\n\n var _loggersByName = {};\n defaultLogger.getLogger = function getLogger(name) {\n if (typeof name !== \"string\" || name === \"\") {\n throw new TypeError(\"You must supply a name when creating a logger.\");\n }\n\n var logger = _loggersByName[name];\n if (!logger) {\n logger = _loggersByName[name] = new Logger(\n name, defaultLogger.getLevel(), defaultLogger.methodFactory);\n }\n return logger;\n };\n\n // Grab the current global log variable in case of overwrite\n var _log = (typeof window !== undefinedType) ? window.log : undefined;\n defaultLogger.noConflict = function() {\n if (typeof window !== undefinedType &&\n window.log === defaultLogger) {\n window.log = _log;\n }\n\n return defaultLogger;\n };\n\n defaultLogger.getLoggers = function getLoggers() {\n return _loggersByName;\n };\n\n return defaultLogger;\n}));\n\n\n//# sourceURL=webpack:///./node_modules/loglevel/lib/loglevel.js?"); + +/***/ }), + +/***/ "./node_modules/memoize-one/dist/memoize-one.esm.js": +/*!**********************************************************!*\ + !*** ./node_modules/memoize-one/dist/memoize-one.esm.js ***! + \**********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (newInputs[i] !== lastInputs[i]) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n }\n return memoized;\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (memoizeOne);\n\n\n//# sourceURL=webpack:///./node_modules/memoize-one/dist/memoize-one.esm.js?"); + +/***/ }), + +/***/ "./node_modules/merge-anything/dist/index.esm.js": +/*!*******************************************************!*\ + !*** ./node_modules/merge-anything/dist/index.esm.js ***! + \*******************************************************/ +/*! exports provided: default, concatArrays, merge */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"concatArrays\", function() { return concatArrays; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"merge\", function() { return merge; });\n/* harmony import */ var is_what__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! is-what */ \"./node_modules/is-what/dist/index.esm.js\");\n\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\n\nfunction assignProp(carry, key, newVal, originalObject) {\r\n var propType = originalObject.propertyIsEnumerable(key)\r\n ? 'enumerable'\r\n : 'nonenumerable';\r\n if (propType === 'enumerable')\r\n carry[key] = newVal;\r\n if (propType === 'nonenumerable') {\r\n Object.defineProperty(carry, key, {\r\n value: newVal,\r\n enumerable: false,\r\n writable: true,\r\n configurable: true\r\n });\r\n }\r\n}\r\nfunction mergeRecursively(origin, newComer, extensions) {\r\n // work directly on newComer if its not an object\r\n if (!Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isPlainObject\"])(newComer)) {\r\n // extend merge rules\r\n if (extensions && Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isArray\"])(extensions)) {\r\n extensions.forEach(function (extend) {\r\n newComer = extend(origin, newComer);\r\n });\r\n }\r\n return newComer;\r\n }\r\n // define newObject to merge all values upon\r\n var newObject = {};\r\n if (Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isPlainObject\"])(origin)) {\r\n var props_1 = Object.getOwnPropertyNames(origin);\r\n var symbols_1 = Object.getOwnPropertySymbols(origin);\r\n newObject = __spreadArrays(props_1, symbols_1).reduce(function (carry, key) {\r\n // @ts-ignore\r\n var targetVal = origin[key];\r\n if ((!Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isSymbol\"])(key) && !Object.getOwnPropertyNames(newComer).includes(key)) ||\r\n (Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isSymbol\"])(key) && !Object.getOwnPropertySymbols(newComer).includes(key))) {\r\n assignProp(carry, key, targetVal, origin);\r\n }\r\n return carry;\r\n }, {});\r\n }\r\n var props = Object.getOwnPropertyNames(newComer);\r\n var symbols = Object.getOwnPropertySymbols(newComer);\r\n var result = __spreadArrays(props, symbols).reduce(function (carry, key) {\r\n // re-define the origin and newComer as targetVal and newVal\r\n var newVal = newComer[key];\r\n var targetVal = (Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isPlainObject\"])(origin))\r\n // @ts-ignore\r\n ? origin[key]\r\n : undefined;\r\n // extend merge rules\r\n if (extensions && Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isArray\"])(extensions)) {\r\n extensions.forEach(function (extend) {\r\n newVal = extend(targetVal, newVal);\r\n });\r\n }\r\n // When newVal is an object do the merge recursively\r\n if (targetVal !== undefined && Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isPlainObject\"])(newVal)) {\r\n newVal = mergeRecursively(targetVal, newVal, extensions);\r\n }\r\n assignProp(carry, key, newVal, newComer);\r\n return carry;\r\n }, newObject);\r\n return result;\r\n}\r\n/**\r\n * Merge anything recursively.\r\n * Objects get merged, special objects (classes etc.) are re-assigned \"as is\".\r\n * Basic types overwrite objects or other basic types.\r\n *\r\n * @param {(IConfig | any)} origin\r\n * @param {...any[]} newComers\r\n * @returns the result\r\n */\r\nfunction merge(origin) {\r\n var newComers = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n newComers[_i - 1] = arguments[_i];\r\n }\r\n var extensions = null;\r\n var base = origin;\r\n if (Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isPlainObject\"])(origin) && origin.extensions && Object.keys(origin).length === 1) {\r\n base = {};\r\n extensions = origin.extensions;\r\n }\r\n return newComers.reduce(function (result, newComer) {\r\n return mergeRecursively(result, newComer, extensions);\r\n }, base);\r\n}\n\nfunction concatArrays(originVal, newVal) {\r\n if (Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isArray\"])(originVal) && Object(is_what__WEBPACK_IMPORTED_MODULE_0__[\"isArray\"])(newVal)) {\r\n // concat logic\r\n return originVal.concat(newVal);\r\n }\r\n return newVal; // always return newVal as fallback!!\r\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (merge);\n\n\n\n//# sourceURL=webpack:///./node_modules/merge-anything/dist/index.esm.js?"); + +/***/ }), + +/***/ "./node_modules/mini-create-react-context/dist/esm/index.js": +/*!******************************************************************!*\ + !*** ./node_modules/mini-create-react-context/dist/esm/index.js ***! + \******************************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _babel_runtime_helpers_inheritsLoose__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/inheritsLoose */ \"./node_modules/@babel/runtime/helpers/inheritsLoose.js\");\n/* harmony import */ var _babel_runtime_helpers_inheritsLoose__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_inheritsLoose__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var gud__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! gud */ \"./node_modules/gud/index.js\");\n/* harmony import */ var gud__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(gud__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var tiny_warning__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! tiny-warning */ \"./node_modules/tiny-warning/dist/tiny-warning.esm.js\");\n\n\n\n\n\n\nvar MAX_SIGNED_31_BIT_INT = 1073741823;\n\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n var handlers = [];\n return {\n on: function on(handler) {\n handlers.push(handler);\n },\n off: function off(handler) {\n handlers = handlers.filter(function (h) {\n return h !== handler;\n });\n },\n get: function get() {\n return value;\n },\n set: function set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(function (handler) {\n return handler(value, changedBits);\n });\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nfunction createReactContext(defaultValue, calculateChangedBits) {\n var _Provider$childContex, _Consumer$contextType;\n\n var contextProp = '__create-react-context-' + gud__WEBPACK_IMPORTED_MODULE_3___default()() + '__';\n\n var Provider =\n /*#__PURE__*/\n function (_Component) {\n _babel_runtime_helpers_inheritsLoose__WEBPACK_IMPORTED_MODULE_1___default()(Provider, _Component);\n\n function Provider() {\n var _this;\n\n _this = _Component.apply(this, arguments) || this;\n _this.emitter = createEventEmitter(_this.props.value);\n return _this;\n }\n\n var _proto = Provider.prototype;\n\n _proto.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[contextProp] = this.emitter, _ref;\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n var oldValue = this.props.value;\n var newValue = nextProps.value;\n var changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0;\n } else {\n changedBits = typeof calculateChangedBits === 'function' ? calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n\n if (true) {\n Object(tiny_warning__WEBPACK_IMPORTED_MODULE_4__[\"default\"])((changedBits & MAX_SIGNED_31_BIT_INT) === changedBits, 'calculateChangedBits: Expected the return value to be a ' + '31-bit integer. Instead received: ' + changedBits);\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n };\n\n _proto.render = function render() {\n return this.props.children;\n };\n\n return Provider;\n }(react__WEBPACK_IMPORTED_MODULE_0__[\"Component\"]);\n\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[contextProp] = prop_types__WEBPACK_IMPORTED_MODULE_2___default.a.object.isRequired, _Provider$childContex);\n\n var Consumer =\n /*#__PURE__*/\n function (_Component2) {\n _babel_runtime_helpers_inheritsLoose__WEBPACK_IMPORTED_MODULE_1___default()(Consumer, _Component2);\n\n function Consumer() {\n var _this2;\n\n _this2 = _Component2.apply(this, arguments) || this;\n _this2.state = {\n value: _this2.getValue()\n };\n\n _this2.onUpdate = function (newValue, changedBits) {\n var observedBits = _this2.observedBits | 0;\n\n if ((observedBits & changedBits) !== 0) {\n _this2.setState({\n value: _this2.getValue()\n });\n }\n };\n\n return _this2;\n }\n\n var _proto2 = Consumer.prototype;\n\n _proto2.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var observedBits = nextProps.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentDidMount = function componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n\n var observedBits = this.props.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentWillUnmount = function componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n };\n\n _proto2.getValue = function getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n };\n\n _proto2.render = function render() {\n return onlyChild(this.props.children)(this.state.value);\n };\n\n return Consumer;\n }(react__WEBPACK_IMPORTED_MODULE_0__[\"Component\"]);\n\n Consumer.contextTypes = (_Consumer$contextType = {}, _Consumer$contextType[contextProp] = prop_types__WEBPACK_IMPORTED_MODULE_2___default.a.object, _Consumer$contextType);\n return {\n Provider: Provider,\n Consumer: Consumer\n };\n}\n\nvar index = react__WEBPACK_IMPORTED_MODULE_0___default.a.createContext || createReactContext;\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (index);\n\n\n//# sourceURL=webpack:///./node_modules/mini-create-react-context/dist/esm/index.js?"); + +/***/ }), + +/***/ "./node_modules/node-libs-browser/node_modules/punycode/punycode.js": +/*!**************************************************************************!*\ + !*** ./node_modules/node-libs-browser/node_modules/punycode/punycode.js ***! + \**************************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +eval("/* WEBPACK VAR INJECTION */(function(module, global) {var __WEBPACK_AMD_DEFINE_RESULT__;/*! https://mths.be/punycode v1.4.1 by @mathias */\n;(function(root) {\n\n\t/** Detect free variables */\n\tvar freeExports = true && exports &&\n\t\t!exports.nodeType && exports;\n\tvar freeModule = true && module &&\n\t\t!module.nodeType && module;\n\tvar freeGlobal = typeof global == 'object' && global;\n\tif (\n\t\tfreeGlobal.global === freeGlobal ||\n\t\tfreeGlobal.window === freeGlobal ||\n\t\tfreeGlobal.self === freeGlobal\n\t) {\n\t\troot = freeGlobal;\n\t}\n\n\t/**\n\t * The `punycode` object.\n\t * @name punycode\n\t * @type Object\n\t */\n\tvar punycode,\n\n\t/** Highest positive signed 32-bit float value */\n\tmaxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1\n\n\t/** Bootstring parameters */\n\tbase = 36,\n\ttMin = 1,\n\ttMax = 26,\n\tskew = 38,\n\tdamp = 700,\n\tinitialBias = 72,\n\tinitialN = 128, // 0x80\n\tdelimiter = '-', // '\\x2D'\n\n\t/** Regular expressions */\n\tregexPunycode = /^xn--/,\n\tregexNonASCII = /[^\\x20-\\x7E]/, // unprintable ASCII chars + non-ASCII chars\n\tregexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g, // RFC 3490 separators\n\n\t/** Error messages */\n\terrors = {\n\t\t'overflow': 'Overflow: input needs wider integers to process',\n\t\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t\t'invalid-input': 'Invalid input'\n\t},\n\n\t/** Convenience shortcuts */\n\tbaseMinusTMin = base - tMin,\n\tfloor = Math.floor,\n\tstringFromCharCode = String.fromCharCode,\n\n\t/** Temporary variable */\n\tkey;\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/**\n\t * A generic error utility function.\n\t * @private\n\t * @param {String} type The error type.\n\t * @returns {Error} Throws a `RangeError` with the applicable error message.\n\t */\n\tfunction error(type) {\n\t\tthrow new RangeError(errors[type]);\n\t}\n\n\t/**\n\t * A generic `Array#map` utility function.\n\t * @private\n\t * @param {Array} array The array to iterate over.\n\t * @param {Function} callback The function that gets called for every array\n\t * item.\n\t * @returns {Array} A new array of values returned by the callback function.\n\t */\n\tfunction map(array, fn) {\n\t\tvar length = array.length;\n\t\tvar result = [];\n\t\twhile (length--) {\n\t\t\tresult[length] = fn(array[length]);\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * A simple `Array#map`-like wrapper to work with domain name strings or email\n\t * addresses.\n\t * @private\n\t * @param {String} domain The domain name or email address.\n\t * @param {Function} callback The function that gets called for every\n\t * character.\n\t * @returns {Array} A new string of characters returned by the callback\n\t * function.\n\t */\n\tfunction mapDomain(string, fn) {\n\t\tvar parts = string.split('@');\n\t\tvar result = '';\n\t\tif (parts.length > 1) {\n\t\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t\t// the local part (i.e. everything up to `@`) intact.\n\t\t\tresult = parts[0] + '@';\n\t\t\tstring = parts[1];\n\t\t}\n\t\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\t\tstring = string.replace(regexSeparators, '\\x2E');\n\t\tvar labels = string.split('.');\n\t\tvar encoded = map(labels, fn).join('.');\n\t\treturn result + encoded;\n\t}\n\n\t/**\n\t * Creates an array containing the numeric code points of each Unicode\n\t * character in the string. While JavaScript uses UCS-2 internally,\n\t * this function will convert a pair of surrogate halves (each of which\n\t * UCS-2 exposes as separate characters) into a single code point,\n\t * matching UTF-16.\n\t * @see `punycode.ucs2.encode`\n\t * @see \n\t * @memberOf punycode.ucs2\n\t * @name decode\n\t * @param {String} string The Unicode input string (UCS-2).\n\t * @returns {Array} The new array of code points.\n\t */\n\tfunction ucs2decode(string) {\n\t\tvar output = [],\n\t\t counter = 0,\n\t\t length = string.length,\n\t\t value,\n\t\t extra;\n\t\twhile (counter < length) {\n\t\t\tvalue = string.charCodeAt(counter++);\n\t\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t\t// high surrogate, and there is a next character\n\t\t\t\textra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) { // low surrogate\n\t\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t\t} else {\n\t\t\t\t\t// unmatched surrogate; only append this code unit, in case the next\n\t\t\t\t\t// code unit is the high surrogate of a surrogate pair\n\t\t\t\t\toutput.push(value);\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\toutput.push(value);\n\t\t\t}\n\t\t}\n\t\treturn output;\n\t}\n\n\t/**\n\t * Creates a string based on an array of numeric code points.\n\t * @see `punycode.ucs2.decode`\n\t * @memberOf punycode.ucs2\n\t * @name encode\n\t * @param {Array} codePoints The array of numeric code points.\n\t * @returns {String} The new Unicode string (UCS-2).\n\t */\n\tfunction ucs2encode(array) {\n\t\treturn map(array, function(value) {\n\t\t\tvar output = '';\n\t\t\tif (value > 0xFFFF) {\n\t\t\t\tvalue -= 0x10000;\n\t\t\t\toutput += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n\t\t\t\tvalue = 0xDC00 | value & 0x3FF;\n\t\t\t}\n\t\t\toutput += stringFromCharCode(value);\n\t\t\treturn output;\n\t\t}).join('');\n\t}\n\n\t/**\n\t * Converts a basic code point into a digit/integer.\n\t * @see `digitToBasic()`\n\t * @private\n\t * @param {Number} codePoint The basic numeric code point value.\n\t * @returns {Number} The numeric value of a basic code point (for use in\n\t * representing integers) in the range `0` to `base - 1`, or `base` if\n\t * the code point does not represent a value.\n\t */\n\tfunction basicToDigit(codePoint) {\n\t\tif (codePoint - 48 < 10) {\n\t\t\treturn codePoint - 22;\n\t\t}\n\t\tif (codePoint - 65 < 26) {\n\t\t\treturn codePoint - 65;\n\t\t}\n\t\tif (codePoint - 97 < 26) {\n\t\t\treturn codePoint - 97;\n\t\t}\n\t\treturn base;\n\t}\n\n\t/**\n\t * Converts a digit/integer into a basic code point.\n\t * @see `basicToDigit()`\n\t * @private\n\t * @param {Number} digit The numeric value of a basic code point.\n\t * @returns {Number} The basic code point whose value (when used for\n\t * representing integers) is `digit`, which needs to be in the range\n\t * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n\t * used; else, the lowercase form is used. The behavior is undefined\n\t * if `flag` is non-zero and `digit` has no uppercase form.\n\t */\n\tfunction digitToBasic(digit, flag) {\n\t\t// 0..25 map to ASCII a..z or A..Z\n\t\t// 26..35 map to ASCII 0..9\n\t\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n\t}\n\n\t/**\n\t * Bias adaptation function as per section 3.4 of RFC 3492.\n\t * https://tools.ietf.org/html/rfc3492#section-3.4\n\t * @private\n\t */\n\tfunction adapt(delta, numPoints, firstTime) {\n\t\tvar k = 0;\n\t\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\t\tdelta += floor(delta / numPoints);\n\t\tfor (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\t\tdelta = floor(delta / baseMinusTMin);\n\t\t}\n\t\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n\t}\n\n\t/**\n\t * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n\t * symbols.\n\t * @memberOf punycode\n\t * @param {String} input The Punycode string of ASCII-only symbols.\n\t * @returns {String} The resulting string of Unicode symbols.\n\t */\n\tfunction decode(input) {\n\t\t// Don't use UCS-2\n\t\tvar output = [],\n\t\t inputLength = input.length,\n\t\t out,\n\t\t i = 0,\n\t\t n = initialN,\n\t\t bias = initialBias,\n\t\t basic,\n\t\t j,\n\t\t index,\n\t\t oldi,\n\t\t w,\n\t\t k,\n\t\t digit,\n\t\t t,\n\t\t /** Cached calculation results */\n\t\t baseMinusT;\n\n\t\t// Handle the basic code points: let `basic` be the number of input code\n\t\t// points before the last delimiter, or `0` if there is none, then copy\n\t\t// the first basic code points to the output.\n\n\t\tbasic = input.lastIndexOf(delimiter);\n\t\tif (basic < 0) {\n\t\t\tbasic = 0;\n\t\t}\n\n\t\tfor (j = 0; j < basic; ++j) {\n\t\t\t// if it's not a basic code point\n\t\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\t\terror('not-basic');\n\t\t\t}\n\t\t\toutput.push(input.charCodeAt(j));\n\t\t}\n\n\t\t// Main decoding loop: start just after the last delimiter if any basic code\n\t\t// points were copied; start at the beginning otherwise.\n\n\t\tfor (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) {\n\n\t\t\t// `index` is the index of the next character to be consumed.\n\t\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t\t// which gets added to `i`. The overflow checking is easier\n\t\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t\t// value at the end to obtain `delta`.\n\t\t\tfor (oldi = i, w = 1, k = base; /* no condition */; k += base) {\n\n\t\t\t\tif (index >= inputLength) {\n\t\t\t\t\terror('invalid-input');\n\t\t\t\t}\n\n\t\t\t\tdigit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\t\tif (digit >= base || digit > floor((maxInt - i) / w)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\ti += digit * w;\n\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\n\t\t\t\tif (digit < t) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tbaseMinusT = base - t;\n\t\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tw *= baseMinusT;\n\n\t\t\t}\n\n\t\t\tout = output.length + 1;\n\t\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t\t// incrementing `n` each time, so we'll fix that now:\n\t\t\tif (floor(i / out) > maxInt - n) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tn += floor(i / out);\n\t\t\ti %= out;\n\n\t\t\t// Insert `n` at position `i` of the output\n\t\t\toutput.splice(i++, 0, n);\n\n\t\t}\n\n\t\treturn ucs2encode(output);\n\t}\n\n\t/**\n\t * Converts a string of Unicode symbols (e.g. a domain name label) to a\n\t * Punycode string of ASCII-only symbols.\n\t * @memberOf punycode\n\t * @param {String} input The string of Unicode symbols.\n\t * @returns {String} The resulting Punycode string of ASCII-only symbols.\n\t */\n\tfunction encode(input) {\n\t\tvar n,\n\t\t delta,\n\t\t handledCPCount,\n\t\t basicLength,\n\t\t bias,\n\t\t j,\n\t\t m,\n\t\t q,\n\t\t k,\n\t\t t,\n\t\t currentValue,\n\t\t output = [],\n\t\t /** `inputLength` will hold the number of code points in `input`. */\n\t\t inputLength,\n\t\t /** Cached calculation results */\n\t\t handledCPCountPlusOne,\n\t\t baseMinusT,\n\t\t qMinusT;\n\n\t\t// Convert the input in UCS-2 to Unicode\n\t\tinput = ucs2decode(input);\n\n\t\t// Cache the length\n\t\tinputLength = input.length;\n\n\t\t// Initialize the state\n\t\tn = initialN;\n\t\tdelta = 0;\n\t\tbias = initialBias;\n\n\t\t// Handle the basic code points\n\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\tcurrentValue = input[j];\n\t\t\tif (currentValue < 0x80) {\n\t\t\t\toutput.push(stringFromCharCode(currentValue));\n\t\t\t}\n\t\t}\n\n\t\thandledCPCount = basicLength = output.length;\n\n\t\t// `handledCPCount` is the number of code points that have been handled;\n\t\t// `basicLength` is the number of basic code points.\n\n\t\t// Finish the basic string - if it is not empty - with a delimiter\n\t\tif (basicLength) {\n\t\t\toutput.push(delimiter);\n\t\t}\n\n\t\t// Main encoding loop:\n\t\twhile (handledCPCount < inputLength) {\n\n\t\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t\t// larger one:\n\t\t\tfor (m = maxInt, j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\t\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\t\tm = currentValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Increase `delta` enough to advance the decoder's state to ,\n\t\t\t// but guard against overflow\n\t\t\thandledCPCountPlusOne = handledCPCount + 1;\n\t\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\t\tn = m;\n\n\t\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\n\t\t\t\tif (currentValue < n && ++delta > maxInt) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tif (currentValue == n) {\n\t\t\t\t\t// Represent delta as a generalized variable-length integer\n\t\t\t\t\tfor (q = delta, k = base; /* no condition */; k += base) {\n\t\t\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\t\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tqMinusT = q - t;\n\t\t\t\t\t\tbaseMinusT = base - t;\n\t\t\t\t\t\toutput.push(\n\t\t\t\t\t\t\tstringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0))\n\t\t\t\t\t\t);\n\t\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n\t\t\t\t\tdelta = 0;\n\t\t\t\t\t++handledCPCount;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t++delta;\n\t\t\t++n;\n\n\t\t}\n\t\treturn output.join('');\n\t}\n\n\t/**\n\t * Converts a Punycode string representing a domain name or an email address\n\t * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n\t * it doesn't matter if you call it on a string that has already been\n\t * converted to Unicode.\n\t * @memberOf punycode\n\t * @param {String} input The Punycoded domain name or email address to\n\t * convert to Unicode.\n\t * @returns {String} The Unicode representation of the given Punycode\n\t * string.\n\t */\n\tfunction toUnicode(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexPunycode.test(string)\n\t\t\t\t? decode(string.slice(4).toLowerCase())\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/**\n\t * Converts a Unicode string representing a domain name or an email address to\n\t * Punycode. Only the non-ASCII parts of the domain name will be converted,\n\t * i.e. it doesn't matter if you call it with a domain that's already in\n\t * ASCII.\n\t * @memberOf punycode\n\t * @param {String} input The domain name or email address to convert, as a\n\t * Unicode string.\n\t * @returns {String} The Punycode representation of the given domain name or\n\t * email address.\n\t */\n\tfunction toASCII(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexNonASCII.test(string)\n\t\t\t\t? 'xn--' + encode(string)\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/** Define the public API */\n\tpunycode = {\n\t\t/**\n\t\t * A string representing the current Punycode.js version number.\n\t\t * @memberOf punycode\n\t\t * @type String\n\t\t */\n\t\t'version': '1.4.1',\n\t\t/**\n\t\t * An object of methods to convert from JavaScript's internal character\n\t\t * representation (UCS-2) to Unicode code points, and back.\n\t\t * @see \n\t\t * @memberOf punycode\n\t\t * @type Object\n\t\t */\n\t\t'ucs2': {\n\t\t\t'decode': ucs2decode,\n\t\t\t'encode': ucs2encode\n\t\t},\n\t\t'decode': decode,\n\t\t'encode': encode,\n\t\t'toASCII': toASCII,\n\t\t'toUnicode': toUnicode\n\t};\n\n\t/** Expose `punycode` */\n\t// Some AMD build optimizers, like r.js, check for specific condition patterns\n\t// like the following:\n\tif (\n\t\ttrue\n\t) {\n\t\t!(__WEBPACK_AMD_DEFINE_RESULT__ = (function() {\n\t\t\treturn punycode;\n\t\t}).call(exports, __webpack_require__, exports, module),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n\t} else {}\n\n}(this));\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../../webpack/buildin/module.js */ \"./node_modules/webpack/buildin/module.js\")(module), __webpack_require__(/*! ./../../../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\")))\n\n//# sourceURL=webpack:///./node_modules/node-libs-browser/node_modules/punycode/punycode.js?"); + +/***/ }), + +/***/ "./node_modules/object-assign/index.js": +/*!*********************************************!*\ + !*** ./node_modules/object-assign/index.js ***! + \*********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n\n\n//# sourceURL=webpack:///./node_modules/object-assign/index.js?"); + +/***/ }), + +/***/ "./node_modules/path-to-regexp/index.js": +/*!**********************************************!*\ + !*** ./node_modules/path-to-regexp/index.js ***! + \**********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +eval("var isarray = __webpack_require__(/*! isarray */ \"./node_modules/isarray/index.js\")\n\n/**\n * Expose `pathToRegexp`.\n */\nmodule.exports = pathToRegexp\nmodule.exports.parse = parse\nmodule.exports.compile = compile\nmodule.exports.tokensToFunction = tokensToFunction\nmodule.exports.tokensToRegExp = tokensToRegExp\n\n/**\n * The main path matching regexp utility.\n *\n * @type {RegExp}\n */\nvar PATH_REGEXP = new RegExp([\n // Match escaped characters that would otherwise appear in future matches.\n // This allows the user to escape special characters that won't transform.\n '(\\\\\\\\.)',\n // Match Express-style parameters and un-named parameters with a prefix\n // and optional suffixes. Matches appear as:\n //\n // \"/:test(\\\\d+)?\" => [\"/\", \"test\", \"\\d+\", undefined, \"?\", undefined]\n // \"/route(\\\\d+)\" => [undefined, undefined, undefined, \"\\d+\", undefined, undefined]\n // \"/*\" => [\"/\", undefined, undefined, undefined, undefined, \"*\"]\n '([\\\\/.])?(?:(?:\\\\:(\\\\w+)(?:\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))?|\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))([+*?])?|(\\\\*))'\n].join('|'), 'g')\n\n/**\n * Parse a string for the raw tokens.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!Array}\n */\nfunction parse (str, options) {\n var tokens = []\n var key = 0\n var index = 0\n var path = ''\n var defaultDelimiter = options && options.delimiter || '/'\n var res\n\n while ((res = PATH_REGEXP.exec(str)) != null) {\n var m = res[0]\n var escaped = res[1]\n var offset = res.index\n path += str.slice(index, offset)\n index = offset + m.length\n\n // Ignore already escaped sequences.\n if (escaped) {\n path += escaped[1]\n continue\n }\n\n var next = str[index]\n var prefix = res[2]\n var name = res[3]\n var capture = res[4]\n var group = res[5]\n var modifier = res[6]\n var asterisk = res[7]\n\n // Push the current path onto the tokens.\n if (path) {\n tokens.push(path)\n path = ''\n }\n\n var partial = prefix != null && next != null && next !== prefix\n var repeat = modifier === '+' || modifier === '*'\n var optional = modifier === '?' || modifier === '*'\n var delimiter = res[2] || defaultDelimiter\n var pattern = capture || group\n\n tokens.push({\n name: name || key++,\n prefix: prefix || '',\n delimiter: delimiter,\n optional: optional,\n repeat: repeat,\n partial: partial,\n asterisk: !!asterisk,\n pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?')\n })\n }\n\n // Match any characters still remaining.\n if (index < str.length) {\n path += str.substr(index)\n }\n\n // If the path exists, push it onto the end.\n if (path) {\n tokens.push(path)\n }\n\n return tokens\n}\n\n/**\n * Compile a string to a template function for the path.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!function(Object=, Object=)}\n */\nfunction compile (str, options) {\n return tokensToFunction(parse(str, options), options)\n}\n\n/**\n * Prettier encoding of URI path segments.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeURIComponentPretty (str) {\n return encodeURI(str).replace(/[\\/?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeAsterisk (str) {\n return encodeURI(str).replace(/[?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Expose a method for transforming tokens into the path function.\n */\nfunction tokensToFunction (tokens, options) {\n // Compile all the tokens into regexps.\n var matches = new Array(tokens.length)\n\n // Compile all the patterns before compilation.\n for (var i = 0; i < tokens.length; i++) {\n if (typeof tokens[i] === 'object') {\n matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$', flags(options))\n }\n }\n\n return function (obj, opts) {\n var path = ''\n var data = obj || {}\n var options = opts || {}\n var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n path += token\n\n continue\n }\n\n var value = data[token.name]\n var segment\n\n if (value == null) {\n if (token.optional) {\n // Prepend partial segment prefixes.\n if (token.partial) {\n path += token.prefix\n }\n\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to be defined')\n }\n }\n\n if (isarray(value)) {\n if (!token.repeat) {\n throw new TypeError('Expected \"' + token.name + '\" to not repeat, but received `' + JSON.stringify(value) + '`')\n }\n\n if (value.length === 0) {\n if (token.optional) {\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to not be empty')\n }\n }\n\n for (var j = 0; j < value.length; j++) {\n segment = encode(value[j])\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected all \"' + token.name + '\" to match \"' + token.pattern + '\", but received `' + JSON.stringify(segment) + '`')\n }\n\n path += (j === 0 ? token.prefix : token.delimiter) + segment\n }\n\n continue\n }\n\n segment = token.asterisk ? encodeAsterisk(value) : encode(value)\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected \"' + token.name + '\" to match \"' + token.pattern + '\", but received \"' + segment + '\"')\n }\n\n path += token.prefix + segment\n }\n\n return path\n }\n}\n\n/**\n * Escape a regular expression string.\n *\n * @param {string} str\n * @return {string}\n */\nfunction escapeString (str) {\n return str.replace(/([.+*?=^!:${}()[\\]|\\/\\\\])/g, '\\\\$1')\n}\n\n/**\n * Escape the capturing group by escaping special characters and meaning.\n *\n * @param {string} group\n * @return {string}\n */\nfunction escapeGroup (group) {\n return group.replace(/([=!:$\\/()])/g, '\\\\$1')\n}\n\n/**\n * Attach the keys as a property of the regexp.\n *\n * @param {!RegExp} re\n * @param {Array} keys\n * @return {!RegExp}\n */\nfunction attachKeys (re, keys) {\n re.keys = keys\n return re\n}\n\n/**\n * Get the flags for a regexp from the options.\n *\n * @param {Object} options\n * @return {string}\n */\nfunction flags (options) {\n return options && options.sensitive ? '' : 'i'\n}\n\n/**\n * Pull out keys from a regexp.\n *\n * @param {!RegExp} path\n * @param {!Array} keys\n * @return {!RegExp}\n */\nfunction regexpToRegexp (path, keys) {\n // Use a negative lookahead to match only capturing groups.\n var groups = path.source.match(/\\((?!\\?)/g)\n\n if (groups) {\n for (var i = 0; i < groups.length; i++) {\n keys.push({\n name: i,\n prefix: null,\n delimiter: null,\n optional: false,\n repeat: false,\n partial: false,\n asterisk: false,\n pattern: null\n })\n }\n }\n\n return attachKeys(path, keys)\n}\n\n/**\n * Transform an array into a regexp.\n *\n * @param {!Array} path\n * @param {Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction arrayToRegexp (path, keys, options) {\n var parts = []\n\n for (var i = 0; i < path.length; i++) {\n parts.push(pathToRegexp(path[i], keys, options).source)\n }\n\n var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options))\n\n return attachKeys(regexp, keys)\n}\n\n/**\n * Create a path regexp from string input.\n *\n * @param {string} path\n * @param {!Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction stringToRegexp (path, keys, options) {\n return tokensToRegExp(parse(path, options), keys, options)\n}\n\n/**\n * Expose a function for taking tokens and returning a RegExp.\n *\n * @param {!Array} tokens\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction tokensToRegExp (tokens, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n var strict = options.strict\n var end = options.end !== false\n var route = ''\n\n // Iterate over the tokens and create our regexp string.\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n route += escapeString(token)\n } else {\n var prefix = escapeString(token.prefix)\n var capture = '(?:' + token.pattern + ')'\n\n keys.push(token)\n\n if (token.repeat) {\n capture += '(?:' + prefix + capture + ')*'\n }\n\n if (token.optional) {\n if (!token.partial) {\n capture = '(?:' + prefix + '(' + capture + '))?'\n } else {\n capture = prefix + '(' + capture + ')?'\n }\n } else {\n capture = prefix + '(' + capture + ')'\n }\n\n route += capture\n }\n }\n\n var delimiter = escapeString(options.delimiter || '/')\n var endsWithDelimiter = route.slice(-delimiter.length) === delimiter\n\n // In non-strict mode we allow a slash at the end of match. If the path to\n // match already ends with a slash, we remove it for consistency. The slash\n // is valid at the end of a path match, not in the middle. This is important\n // in non-ending mode, where \"/test/\" shouldn't match \"/test//route\".\n if (!strict) {\n route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?'\n }\n\n if (end) {\n route += '$'\n } else {\n // In non-ending mode, we need the capturing groups to match as much as\n // possible by using a positive lookahead to the end or next path segment.\n route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)'\n }\n\n return attachKeys(new RegExp('^' + route, flags(options)), keys)\n}\n\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n *\n * @param {(string|RegExp|Array)} path\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction pathToRegexp (path, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n if (path instanceof RegExp) {\n return regexpToRegexp(path, /** @type {!Array} */ (keys))\n }\n\n if (isarray(path)) {\n return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)\n }\n\n return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)\n}\n\n\n//# sourceURL=webpack:///./node_modules/path-to-regexp/index.js?"); + +/***/ }), + +/***/ "./node_modules/process/browser.js": +/*!*****************************************!*\ + !*** ./node_modules/process/browser.js ***! + \*****************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +eval("// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n\n//# sourceURL=webpack:///./node_modules/process/browser.js?"); + +/***/ }), + +/***/ "./node_modules/prop-types/checkPropTypes.js": +/*!***************************************************!*\ + !*** ./node_modules/prop-types/checkPropTypes.js ***! + \***************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\nvar printWarning = function() {};\n\nif (true) {\n var ReactPropTypesSecret = __webpack_require__(/*! ./lib/ReactPropTypesSecret */ \"./node_modules/prop-types/lib/ReactPropTypesSecret.js\");\n var loggedTypeFailures = {};\n var has = Function.call.bind(Object.prototype.hasOwnProperty);\n\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n}\n\n/**\n * Assert that the values match with the type specs.\n * Error messages are memorized and will only be shown once.\n *\n * @param {object} typeSpecs Map of name to a ReactPropType\n * @param {object} values Runtime values that need to be type-checked\n * @param {string} location e.g. \"prop\", \"context\", \"child context\"\n * @param {string} componentName Name of the component for error messages.\n * @param {?Function} getStack Returns the component stack.\n * @private\n */\nfunction checkPropTypes(typeSpecs, values, location, componentName, getStack) {\n if (true) {\n for (var typeSpecName in typeSpecs) {\n if (has(typeSpecs, typeSpecName)) {\n var error;\n // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error(\n (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.'\n );\n err.name = 'Invariant Violation';\n throw err;\n }\n error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);\n } catch (ex) {\n error = ex;\n }\n if (error && !(error instanceof Error)) {\n printWarning(\n (componentName || 'React class') + ': type specification of ' +\n location + ' `' + typeSpecName + '` is invalid; the type checker ' +\n 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' +\n 'You may have forgotten to pass an argument to the type checker ' +\n 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' +\n 'shape all require an argument).'\n );\n }\n if (error instanceof Error && !(error.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error.message] = true;\n\n var stack = getStack ? getStack() : '';\n\n printWarning(\n 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '')\n );\n }\n }\n }\n }\n}\n\n/**\n * Resets warning cache when testing.\n *\n * @private\n */\ncheckPropTypes.resetWarningCache = function() {\n if (true) {\n loggedTypeFailures = {};\n }\n}\n\nmodule.exports = checkPropTypes;\n\n\n//# sourceURL=webpack:///./node_modules/prop-types/checkPropTypes.js?"); + +/***/ }), + +/***/ "./node_modules/prop-types/factoryWithTypeCheckers.js": +/*!************************************************************!*\ + !*** ./node_modules/prop-types/factoryWithTypeCheckers.js ***! + \************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\nvar ReactIs = __webpack_require__(/*! react-is */ \"./node_modules/react-is/index.js\");\nvar assign = __webpack_require__(/*! object-assign */ \"./node_modules/object-assign/index.js\");\n\nvar ReactPropTypesSecret = __webpack_require__(/*! ./lib/ReactPropTypesSecret */ \"./node_modules/prop-types/lib/ReactPropTypesSecret.js\");\nvar checkPropTypes = __webpack_require__(/*! ./checkPropTypes */ \"./node_modules/prop-types/checkPropTypes.js\");\n\nvar has = Function.call.bind(Object.prototype.hasOwnProperty);\nvar printWarning = function() {};\n\nif (true) {\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n}\n\nfunction emptyFunctionThatReturnsNull() {\n return null;\n}\n\nmodule.exports = function(isValidElement, throwOnDirectAccess) {\n /* global Symbol */\n var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.\n\n /**\n * Returns the iterator method function contained on the iterable object.\n *\n * Be sure to invoke the function with the iterable as context:\n *\n * var iteratorFn = getIteratorFn(myIterable);\n * if (iteratorFn) {\n * var iterator = iteratorFn.call(myIterable);\n * ...\n * }\n *\n * @param {?object} maybeIterable\n * @return {?function}\n */\n function getIteratorFn(maybeIterable) {\n var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);\n if (typeof iteratorFn === 'function') {\n return iteratorFn;\n }\n }\n\n /**\n * Collection of methods that allow declaration and validation of props that are\n * supplied to React components. Example usage:\n *\n * var Props = require('ReactPropTypes');\n * var MyArticle = React.createClass({\n * propTypes: {\n * // An optional string prop named \"description\".\n * description: Props.string,\n *\n * // A required enum prop named \"category\".\n * category: Props.oneOf(['News','Photos']).isRequired,\n *\n * // A prop named \"dialog\" that requires an instance of Dialog.\n * dialog: Props.instanceOf(Dialog).isRequired\n * },\n * render: function() { ... }\n * });\n *\n * A more formal specification of how these methods are used:\n *\n * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...)\n * decl := ReactPropTypes.{type}(.isRequired)?\n *\n * Each and every declaration produces a function with the same signature. This\n * allows the creation of custom validation functions. For example:\n *\n * var MyLink = React.createClass({\n * propTypes: {\n * // An optional string or URI prop named \"href\".\n * href: function(props, propName, componentName) {\n * var propValue = props[propName];\n * if (propValue != null && typeof propValue !== 'string' &&\n * !(propValue instanceof URI)) {\n * return new Error(\n * 'Expected a string or an URI for ' + propName + ' in ' +\n * componentName\n * );\n * }\n * }\n * },\n * render: function() {...}\n * });\n *\n * @internal\n */\n\n var ANONYMOUS = '<>';\n\n // Important!\n // Keep this list in sync with production version in `./factoryWithThrowingShims.js`.\n var ReactPropTypes = {\n array: createPrimitiveTypeChecker('array'),\n bool: createPrimitiveTypeChecker('boolean'),\n func: createPrimitiveTypeChecker('function'),\n number: createPrimitiveTypeChecker('number'),\n object: createPrimitiveTypeChecker('object'),\n string: createPrimitiveTypeChecker('string'),\n symbol: createPrimitiveTypeChecker('symbol'),\n\n any: createAnyTypeChecker(),\n arrayOf: createArrayOfTypeChecker,\n element: createElementTypeChecker(),\n elementType: createElementTypeTypeChecker(),\n instanceOf: createInstanceTypeChecker,\n node: createNodeChecker(),\n objectOf: createObjectOfTypeChecker,\n oneOf: createEnumTypeChecker,\n oneOfType: createUnionTypeChecker,\n shape: createShapeTypeChecker,\n exact: createStrictShapeTypeChecker,\n };\n\n /**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\n /*eslint-disable no-self-compare*/\n function is(x, y) {\n // SameValue algorithm\n if (x === y) {\n // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n return x !== 0 || 1 / x === 1 / y;\n } else {\n // Step 6.a: NaN == NaN\n return x !== x && y !== y;\n }\n }\n /*eslint-enable no-self-compare*/\n\n /**\n * We use an Error-like object for backward compatibility as people may call\n * PropTypes directly and inspect their output. However, we don't use real\n * Errors anymore. We don't inspect their stack anyway, and creating them\n * is prohibitively expensive if they are created too often, such as what\n * happens in oneOfType() for any type before the one that matched.\n */\n function PropTypeError(message) {\n this.message = message;\n this.stack = '';\n }\n // Make `instanceof Error` still work for returned errors.\n PropTypeError.prototype = Error.prototype;\n\n function createChainableTypeChecker(validate) {\n if (true) {\n var manualPropTypeCallCache = {};\n var manualPropTypeWarningCount = 0;\n }\n function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {\n componentName = componentName || ANONYMOUS;\n propFullName = propFullName || propName;\n\n if (secret !== ReactPropTypesSecret) {\n if (throwOnDirectAccess) {\n // New behavior only for users of `prop-types` package\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use `PropTypes.checkPropTypes()` to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n } else if ( true && typeof console !== 'undefined') {\n // Old behavior for people using React.PropTypes\n var cacheKey = componentName + ':' + propName;\n if (\n !manualPropTypeCallCache[cacheKey] &&\n // Avoid spamming the console because they are often not actionable except for lib authors\n manualPropTypeWarningCount < 3\n ) {\n printWarning(\n 'You are manually calling a React.PropTypes validation ' +\n 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' +\n 'and will throw in the standalone `prop-types` package. ' +\n 'You may be seeing this warning due to a third-party PropTypes ' +\n 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.'\n );\n manualPropTypeCallCache[cacheKey] = true;\n manualPropTypeWarningCount++;\n }\n }\n }\n if (props[propName] == null) {\n if (isRequired) {\n if (props[propName] === null) {\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.'));\n }\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.'));\n }\n return null;\n } else {\n return validate(props, propName, componentName, location, propFullName);\n }\n }\n\n var chainedCheckType = checkType.bind(null, false);\n chainedCheckType.isRequired = checkType.bind(null, true);\n\n return chainedCheckType;\n }\n\n function createPrimitiveTypeChecker(expectedType) {\n function validate(props, propName, componentName, location, propFullName, secret) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== expectedType) {\n // `propValue` being instance of, say, date/regexp, pass the 'object'\n // check, but we can offer a more precise error message here rather than\n // 'of type `object`'.\n var preciseType = getPreciseType(propValue);\n\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createAnyTypeChecker() {\n return createChainableTypeChecker(emptyFunctionThatReturnsNull);\n }\n\n function createArrayOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.');\n }\n var propValue = props[propName];\n if (!Array.isArray(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.'));\n }\n for (var i = 0; i < propValue.length; i++) {\n var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!isValidElement(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!ReactIs.isValidElementType(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createInstanceTypeChecker(expectedClass) {\n function validate(props, propName, componentName, location, propFullName) {\n if (!(props[propName] instanceof expectedClass)) {\n var expectedClassName = expectedClass.name || ANONYMOUS;\n var actualClassName = getClassName(props[propName]);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createEnumTypeChecker(expectedValues) {\n if (!Array.isArray(expectedValues)) {\n if (true) {\n if (arguments.length > 1) {\n printWarning(\n 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' +\n 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).'\n );\n } else {\n printWarning('Invalid argument supplied to oneOf, expected an array.');\n }\n }\n return emptyFunctionThatReturnsNull;\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n for (var i = 0; i < expectedValues.length; i++) {\n if (is(propValue, expectedValues[i])) {\n return null;\n }\n }\n\n var valuesString = JSON.stringify(expectedValues, function replacer(key, value) {\n var type = getPreciseType(value);\n if (type === 'symbol') {\n return String(value);\n }\n return value;\n });\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createObjectOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.');\n }\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.'));\n }\n for (var key in propValue) {\n if (has(propValue, key)) {\n var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createUnionTypeChecker(arrayOfTypeCheckers) {\n if (!Array.isArray(arrayOfTypeCheckers)) {\n true ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : undefined;\n return emptyFunctionThatReturnsNull;\n }\n\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n if (typeof checker !== 'function') {\n printWarning(\n 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' +\n 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.'\n );\n return emptyFunctionThatReturnsNull;\n }\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n if (checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret) == null) {\n return null;\n }\n }\n\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createNodeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n if (!isNode(props[propName])) {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n for (var key in shapeTypes) {\n var checker = shapeTypes[key];\n if (!checker) {\n continue;\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createStrictShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n // We need to check all keys in case some are required but missing from\n // props.\n var allKeys = assign({}, props[propName], shapeTypes);\n for (var key in allKeys) {\n var checker = shapeTypes[key];\n if (!checker) {\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' +\n '\\nBad object: ' + JSON.stringify(props[propName], null, ' ') +\n '\\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ')\n );\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n\n return createChainableTypeChecker(validate);\n }\n\n function isNode(propValue) {\n switch (typeof propValue) {\n case 'number':\n case 'string':\n case 'undefined':\n return true;\n case 'boolean':\n return !propValue;\n case 'object':\n if (Array.isArray(propValue)) {\n return propValue.every(isNode);\n }\n if (propValue === null || isValidElement(propValue)) {\n return true;\n }\n\n var iteratorFn = getIteratorFn(propValue);\n if (iteratorFn) {\n var iterator = iteratorFn.call(propValue);\n var step;\n if (iteratorFn !== propValue.entries) {\n while (!(step = iterator.next()).done) {\n if (!isNode(step.value)) {\n return false;\n }\n }\n } else {\n // Iterator will provide entry [k,v] tuples rather than values.\n while (!(step = iterator.next()).done) {\n var entry = step.value;\n if (entry) {\n if (!isNode(entry[1])) {\n return false;\n }\n }\n }\n }\n } else {\n return false;\n }\n\n return true;\n default:\n return false;\n }\n }\n\n function isSymbol(propType, propValue) {\n // Native Symbol.\n if (propType === 'symbol') {\n return true;\n }\n\n // falsy value can't be a Symbol\n if (!propValue) {\n return false;\n }\n\n // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol'\n if (propValue['@@toStringTag'] === 'Symbol') {\n return true;\n }\n\n // Fallback for non-spec compliant Symbols which are polyfilled.\n if (typeof Symbol === 'function' && propValue instanceof Symbol) {\n return true;\n }\n\n return false;\n }\n\n // Equivalent of `typeof` but with special handling for array and regexp.\n function getPropType(propValue) {\n var propType = typeof propValue;\n if (Array.isArray(propValue)) {\n return 'array';\n }\n if (propValue instanceof RegExp) {\n // Old webkits (at least until Android 4.0) return 'function' rather than\n // 'object' for typeof a RegExp. We'll normalize this here so that /bla/\n // passes PropTypes.object.\n return 'object';\n }\n if (isSymbol(propType, propValue)) {\n return 'symbol';\n }\n return propType;\n }\n\n // This handles more types than `getPropType`. Only used for error messages.\n // See `createPrimitiveTypeChecker`.\n function getPreciseType(propValue) {\n if (typeof propValue === 'undefined' || propValue === null) {\n return '' + propValue;\n }\n var propType = getPropType(propValue);\n if (propType === 'object') {\n if (propValue instanceof Date) {\n return 'date';\n } else if (propValue instanceof RegExp) {\n return 'regexp';\n }\n }\n return propType;\n }\n\n // Returns a string that is postfixed to a warning about an invalid type.\n // For example, \"undefined\" or \"of type array\"\n function getPostfixForTypeWarning(value) {\n var type = getPreciseType(value);\n switch (type) {\n case 'array':\n case 'object':\n return 'an ' + type;\n case 'boolean':\n case 'date':\n case 'regexp':\n return 'a ' + type;\n default:\n return type;\n }\n }\n\n // Returns class name of the object, if any.\n function getClassName(propValue) {\n if (!propValue.constructor || !propValue.constructor.name) {\n return ANONYMOUS;\n }\n return propValue.constructor.name;\n }\n\n ReactPropTypes.checkPropTypes = checkPropTypes;\n ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache;\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n\n\n//# sourceURL=webpack:///./node_modules/prop-types/factoryWithTypeCheckers.js?"); + +/***/ }), + +/***/ "./node_modules/prop-types/index.js": +/*!******************************************!*\ + !*** ./node_modules/prop-types/index.js ***! + \******************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (true) {\n var ReactIs = __webpack_require__(/*! react-is */ \"./node_modules/react-is/index.js\");\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = __webpack_require__(/*! ./factoryWithTypeCheckers */ \"./node_modules/prop-types/factoryWithTypeCheckers.js\")(ReactIs.isElement, throwOnDirectAccess);\n} else {}\n\n\n//# sourceURL=webpack:///./node_modules/prop-types/index.js?"); + +/***/ }), + +/***/ "./node_modules/prop-types/lib/ReactPropTypesSecret.js": +/*!*************************************************************!*\ + !*** ./node_modules/prop-types/lib/ReactPropTypesSecret.js ***! + \*************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n\n\n//# sourceURL=webpack:///./node_modules/prop-types/lib/ReactPropTypesSecret.js?"); + +/***/ }), + +/***/ "./node_modules/querystring-es3/decode.js": +/*!************************************************!*\ + !*** ./node_modules/querystring-es3/decode.js ***! + \************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n\n\n// If obj.hasOwnProperty has been overridden, then calling\n// obj.hasOwnProperty(prop) will break.\n// See: https://github.com/joyent/node/issues/1707\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = function(qs, sep, eq, options) {\n sep = sep || '&';\n eq = eq || '=';\n var obj = {};\n\n if (typeof qs !== 'string' || qs.length === 0) {\n return obj;\n }\n\n var regexp = /\\+/g;\n qs = qs.split(sep);\n\n var maxKeys = 1000;\n if (options && typeof options.maxKeys === 'number') {\n maxKeys = options.maxKeys;\n }\n\n var len = qs.length;\n // maxKeys <= 0 means that we should not limit keys count\n if (maxKeys > 0 && len > maxKeys) {\n len = maxKeys;\n }\n\n for (var i = 0; i < len; ++i) {\n var x = qs[i].replace(regexp, '%20'),\n idx = x.indexOf(eq),\n kstr, vstr, k, v;\n\n if (idx >= 0) {\n kstr = x.substr(0, idx);\n vstr = x.substr(idx + 1);\n } else {\n kstr = x;\n vstr = '';\n }\n\n k = decodeURIComponent(kstr);\n v = decodeURIComponent(vstr);\n\n if (!hasOwnProperty(obj, k)) {\n obj[k] = v;\n } else if (isArray(obj[k])) {\n obj[k].push(v);\n } else {\n obj[k] = [obj[k], v];\n }\n }\n\n return obj;\n};\n\nvar isArray = Array.isArray || function (xs) {\n return Object.prototype.toString.call(xs) === '[object Array]';\n};\n\n\n//# sourceURL=webpack:///./node_modules/querystring-es3/decode.js?"); + +/***/ }), + +/***/ "./node_modules/querystring-es3/encode.js": +/*!************************************************!*\ + !*** ./node_modules/querystring-es3/encode.js ***! + \************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n\n\nvar stringifyPrimitive = function(v) {\n switch (typeof v) {\n case 'string':\n return v;\n\n case 'boolean':\n return v ? 'true' : 'false';\n\n case 'number':\n return isFinite(v) ? v : '';\n\n default:\n return '';\n }\n};\n\nmodule.exports = function(obj, sep, eq, name) {\n sep = sep || '&';\n eq = eq || '=';\n if (obj === null) {\n obj = undefined;\n }\n\n if (typeof obj === 'object') {\n return map(objectKeys(obj), function(k) {\n var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;\n if (isArray(obj[k])) {\n return map(obj[k], function(v) {\n return ks + encodeURIComponent(stringifyPrimitive(v));\n }).join(sep);\n } else {\n return ks + encodeURIComponent(stringifyPrimitive(obj[k]));\n }\n }).join(sep);\n\n }\n\n if (!name) return '';\n return encodeURIComponent(stringifyPrimitive(name)) + eq +\n encodeURIComponent(stringifyPrimitive(obj));\n};\n\nvar isArray = Array.isArray || function (xs) {\n return Object.prototype.toString.call(xs) === '[object Array]';\n};\n\nfunction map (xs, f) {\n if (xs.map) return xs.map(f);\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n res.push(f(xs[i], i));\n }\n return res;\n}\n\nvar objectKeys = Object.keys || function (obj) {\n var res = [];\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) res.push(key);\n }\n return res;\n};\n\n\n//# sourceURL=webpack:///./node_modules/querystring-es3/encode.js?"); + +/***/ }), + +/***/ "./node_modules/querystring-es3/index.js": +/*!***********************************************!*\ + !*** ./node_modules/querystring-es3/index.js ***! + \***********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\nexports.decode = exports.parse = __webpack_require__(/*! ./decode */ \"./node_modules/querystring-es3/decode.js\");\nexports.encode = exports.stringify = __webpack_require__(/*! ./encode */ \"./node_modules/querystring-es3/encode.js\");\n\n\n//# sourceURL=webpack:///./node_modules/querystring-es3/index.js?"); + +/***/ }), + +/***/ "./node_modules/react-dom/cjs/react-dom.development.js": +/*!*************************************************************!*\ + !*** ./node_modules/react-dom/cjs/react-dom.development.js ***! + \*************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("/** @license React v16.12.0\n * react-dom.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\n\n\nif (true) {\n (function() {\n'use strict';\n\nvar React = __webpack_require__(/*! react */ \"./node_modules/react/index.js\");\nvar _assign = __webpack_require__(/*! object-assign */ \"./node_modules/object-assign/index.js\");\nvar Scheduler = __webpack_require__(/*! scheduler */ \"./node_modules/scheduler/index.js\");\nvar checkPropTypes = __webpack_require__(/*! prop-types/checkPropTypes */ \"./node_modules/prop-types/checkPropTypes.js\");\nvar tracing = __webpack_require__(/*! scheduler/tracing */ \"./node_modules/scheduler/tracing.js\");\n\n// Do not require this module directly! Use normal `invariant` calls with\n// template literal strings. The messages will be replaced with error codes\n// during build.\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nif (!React) {\n {\n throw Error(\"ReactDOM was loaded before React. Make sure you load the React package before loading ReactDOM.\");\n }\n}\n\n/**\n * Injectable ordering of event plugins.\n */\nvar eventPluginOrder = null;\n/**\n * Injectable mapping from names to event plugin modules.\n */\n\nvar namesToPlugins = {};\n/**\n * Recomputes the plugin list using the injected plugins and plugin ordering.\n *\n * @private\n */\n\nfunction recomputePluginOrdering() {\n if (!eventPluginOrder) {\n // Wait until an `eventPluginOrder` is injected.\n return;\n }\n\n for (var pluginName in namesToPlugins) {\n var pluginModule = namesToPlugins[pluginName];\n var pluginIndex = eventPluginOrder.indexOf(pluginName);\n\n if (!(pluginIndex > -1)) {\n {\n throw Error(\"EventPluginRegistry: Cannot inject event plugins that do not exist in the plugin ordering, `\" + pluginName + \"`.\");\n }\n }\n\n if (plugins[pluginIndex]) {\n continue;\n }\n\n if (!pluginModule.extractEvents) {\n {\n throw Error(\"EventPluginRegistry: Event plugins must implement an `extractEvents` method, but `\" + pluginName + \"` does not.\");\n }\n }\n\n plugins[pluginIndex] = pluginModule;\n var publishedEvents = pluginModule.eventTypes;\n\n for (var eventName in publishedEvents) {\n if (!publishEventForPlugin(publishedEvents[eventName], pluginModule, eventName)) {\n {\n throw Error(\"EventPluginRegistry: Failed to publish event `\" + eventName + \"` for plugin `\" + pluginName + \"`.\");\n }\n }\n }\n }\n}\n/**\n * Publishes an event so that it can be dispatched by the supplied plugin.\n *\n * @param {object} dispatchConfig Dispatch configuration for the event.\n * @param {object} PluginModule Plugin publishing the event.\n * @return {boolean} True if the event was successfully published.\n * @private\n */\n\n\nfunction publishEventForPlugin(dispatchConfig, pluginModule, eventName) {\n if (!!eventNameDispatchConfigs.hasOwnProperty(eventName)) {\n {\n throw Error(\"EventPluginHub: More than one plugin attempted to publish the same event name, `\" + eventName + \"`.\");\n }\n }\n\n eventNameDispatchConfigs[eventName] = dispatchConfig;\n var phasedRegistrationNames = dispatchConfig.phasedRegistrationNames;\n\n if (phasedRegistrationNames) {\n for (var phaseName in phasedRegistrationNames) {\n if (phasedRegistrationNames.hasOwnProperty(phaseName)) {\n var phasedRegistrationName = phasedRegistrationNames[phaseName];\n publishRegistrationName(phasedRegistrationName, pluginModule, eventName);\n }\n }\n\n return true;\n } else if (dispatchConfig.registrationName) {\n publishRegistrationName(dispatchConfig.registrationName, pluginModule, eventName);\n return true;\n }\n\n return false;\n}\n/**\n * Publishes a registration name that is used to identify dispatched events.\n *\n * @param {string} registrationName Registration name to add.\n * @param {object} PluginModule Plugin publishing the event.\n * @private\n */\n\n\nfunction publishRegistrationName(registrationName, pluginModule, eventName) {\n if (!!registrationNameModules[registrationName]) {\n {\n throw Error(\"EventPluginHub: More than one plugin attempted to publish the same registration name, `\" + registrationName + \"`.\");\n }\n }\n\n registrationNameModules[registrationName] = pluginModule;\n registrationNameDependencies[registrationName] = pluginModule.eventTypes[eventName].dependencies;\n\n {\n var lowerCasedName = registrationName.toLowerCase();\n possibleRegistrationNames[lowerCasedName] = registrationName;\n\n if (registrationName === 'onDoubleClick') {\n possibleRegistrationNames.ondblclick = registrationName;\n }\n }\n}\n/**\n * Registers plugins so that they can extract and dispatch events.\n *\n * @see {EventPluginHub}\n */\n\n/**\n * Ordered list of injected plugins.\n */\n\n\nvar plugins = [];\n/**\n * Mapping from event name to dispatch config\n */\n\nvar eventNameDispatchConfigs = {};\n/**\n * Mapping from registration name to plugin module\n */\n\nvar registrationNameModules = {};\n/**\n * Mapping from registration name to event name\n */\n\nvar registrationNameDependencies = {};\n/**\n * Mapping from lowercase registration names to the properly cased version,\n * used to warn in the case of missing event handlers. Available\n * only in true.\n * @type {Object}\n */\n\nvar possibleRegistrationNames = {}; // Trust the developer to only use possibleRegistrationNames in true\n\n/**\n * Injects an ordering of plugins (by plugin name). This allows the ordering\n * to be decoupled from injection of the actual plugins so that ordering is\n * always deterministic regardless of packaging, on-the-fly injection, etc.\n *\n * @param {array} InjectedEventPluginOrder\n * @internal\n * @see {EventPluginHub.injection.injectEventPluginOrder}\n */\n\nfunction injectEventPluginOrder(injectedEventPluginOrder) {\n if (!!eventPluginOrder) {\n {\n throw Error(\"EventPluginRegistry: Cannot inject event plugin ordering more than once. You are likely trying to load more than one copy of React.\");\n }\n } // Clone the ordering so it cannot be dynamically mutated.\n\n\n eventPluginOrder = Array.prototype.slice.call(injectedEventPluginOrder);\n recomputePluginOrdering();\n}\n/**\n * Injects plugins to be used by `EventPluginHub`. The plugin names must be\n * in the ordering injected by `injectEventPluginOrder`.\n *\n * Plugins can be injected as part of page initialization or on-the-fly.\n *\n * @param {object} injectedNamesToPlugins Map from names to plugin modules.\n * @internal\n * @see {EventPluginHub.injection.injectEventPluginsByName}\n */\n\nfunction injectEventPluginsByName(injectedNamesToPlugins) {\n var isOrderingDirty = false;\n\n for (var pluginName in injectedNamesToPlugins) {\n if (!injectedNamesToPlugins.hasOwnProperty(pluginName)) {\n continue;\n }\n\n var pluginModule = injectedNamesToPlugins[pluginName];\n\n if (!namesToPlugins.hasOwnProperty(pluginName) || namesToPlugins[pluginName] !== pluginModule) {\n if (!!namesToPlugins[pluginName]) {\n {\n throw Error(\"EventPluginRegistry: Cannot inject two different event plugins using the same name, `\" + pluginName + \"`.\");\n }\n }\n\n namesToPlugins[pluginName] = pluginModule;\n isOrderingDirty = true;\n }\n }\n\n if (isOrderingDirty) {\n recomputePluginOrdering();\n }\n}\n\nvar invokeGuardedCallbackImpl = function (name, func, context, a, b, c, d, e, f) {\n var funcArgs = Array.prototype.slice.call(arguments, 3);\n\n try {\n func.apply(context, funcArgs);\n } catch (error) {\n this.onError(error);\n }\n};\n\n{\n // In DEV mode, we swap out invokeGuardedCallback for a special version\n // that plays more nicely with the browser's DevTools. The idea is to preserve\n // \"Pause on exceptions\" behavior. Because React wraps all user-provided\n // functions in invokeGuardedCallback, and the production version of\n // invokeGuardedCallback uses a try-catch, all user exceptions are treated\n // like caught exceptions, and the DevTools won't pause unless the developer\n // takes the extra step of enabling pause on caught exceptions. This is\n // unintuitive, though, because even though React has caught the error, from\n // the developer's perspective, the error is uncaught.\n //\n // To preserve the expected \"Pause on exceptions\" behavior, we don't use a\n // try-catch in DEV. Instead, we synchronously dispatch a fake event to a fake\n // DOM node, and call the user-provided callback from inside an event handler\n // for that fake event. If the callback throws, the error is \"captured\" using\n // a global event handler. But because the error happens in a different\n // event loop context, it does not interrupt the normal program flow.\n // Effectively, this gives us try-catch behavior without actually using\n // try-catch. Neat!\n // Check that the browser supports the APIs we need to implement our special\n // DEV version of invokeGuardedCallback\n if (typeof window !== 'undefined' && typeof window.dispatchEvent === 'function' && typeof document !== 'undefined' && typeof document.createEvent === 'function') {\n var fakeNode = document.createElement('react');\n\n var invokeGuardedCallbackDev = function (name, func, context, a, b, c, d, e, f) {\n // If document doesn't exist we know for sure we will crash in this method\n // when we call document.createEvent(). However this can cause confusing\n // errors: https://github.com/facebookincubator/create-react-app/issues/3482\n // So we preemptively throw with a better message instead.\n if (!(typeof document !== 'undefined')) {\n {\n throw Error(\"The `document` global was defined when React was initialized, but is not defined anymore. This can happen in a test environment if a component schedules an update from an asynchronous callback, but the test has already finished running. To solve this, you can either unmount the component at the end of your test (and ensure that any asynchronous operations get canceled in `componentWillUnmount`), or you can change the test itself to be asynchronous.\");\n }\n }\n\n var evt = document.createEvent('Event'); // Keeps track of whether the user-provided callback threw an error. We\n // set this to true at the beginning, then set it to false right after\n // calling the function. If the function errors, `didError` will never be\n // set to false. This strategy works even if the browser is flaky and\n // fails to call our global error handler, because it doesn't rely on\n // the error event at all.\n\n var didError = true; // Keeps track of the value of window.event so that we can reset it\n // during the callback to let user code access window.event in the\n // browsers that support it.\n\n var windowEvent = window.event; // Keeps track of the descriptor of window.event to restore it after event\n // dispatching: https://github.com/facebook/react/issues/13688\n\n var windowEventDescriptor = Object.getOwnPropertyDescriptor(window, 'event'); // Create an event handler for our fake event. We will synchronously\n // dispatch our fake event using `dispatchEvent`. Inside the handler, we\n // call the user-provided callback.\n\n var funcArgs = Array.prototype.slice.call(arguments, 3);\n\n function callCallback() {\n // We immediately remove the callback from event listeners so that\n // nested `invokeGuardedCallback` calls do not clash. Otherwise, a\n // nested call would trigger the fake event handlers of any call higher\n // in the stack.\n fakeNode.removeEventListener(evtType, callCallback, false); // We check for window.hasOwnProperty('event') to prevent the\n // window.event assignment in both IE <= 10 as they throw an error\n // \"Member not found\" in strict mode, and in Firefox which does not\n // support window.event.\n\n if (typeof window.event !== 'undefined' && window.hasOwnProperty('event')) {\n window.event = windowEvent;\n }\n\n func.apply(context, funcArgs);\n didError = false;\n } // Create a global error event handler. We use this to capture the value\n // that was thrown. It's possible that this error handler will fire more\n // than once; for example, if non-React code also calls `dispatchEvent`\n // and a handler for that event throws. We should be resilient to most of\n // those cases. Even if our error event handler fires more than once, the\n // last error event is always used. If the callback actually does error,\n // we know that the last error event is the correct one, because it's not\n // possible for anything else to have happened in between our callback\n // erroring and the code that follows the `dispatchEvent` call below. If\n // the callback doesn't error, but the error event was fired, we know to\n // ignore it because `didError` will be false, as described above.\n\n\n var error; // Use this to track whether the error event is ever called.\n\n var didSetError = false;\n var isCrossOriginError = false;\n\n function handleWindowError(event) {\n error = event.error;\n didSetError = true;\n\n if (error === null && event.colno === 0 && event.lineno === 0) {\n isCrossOriginError = true;\n }\n\n if (event.defaultPrevented) {\n // Some other error handler has prevented default.\n // Browsers silence the error report if this happens.\n // We'll remember this to later decide whether to log it or not.\n if (error != null && typeof error === 'object') {\n try {\n error._suppressLogging = true;\n } catch (inner) {// Ignore.\n }\n }\n }\n } // Create a fake event type.\n\n\n var evtType = \"react-\" + (name ? name : 'invokeguardedcallback'); // Attach our event handlers\n\n window.addEventListener('error', handleWindowError);\n fakeNode.addEventListener(evtType, callCallback, false); // Synchronously dispatch our fake event. If the user-provided function\n // errors, it will trigger our global error handler.\n\n evt.initEvent(evtType, false, false);\n fakeNode.dispatchEvent(evt);\n\n if (windowEventDescriptor) {\n Object.defineProperty(window, 'event', windowEventDescriptor);\n }\n\n if (didError) {\n if (!didSetError) {\n // The callback errored, but the error event never fired.\n error = new Error('An error was thrown inside one of your components, but React ' + \"doesn't know what it was. This is likely due to browser \" + 'flakiness. React does its best to preserve the \"Pause on ' + 'exceptions\" behavior of the DevTools, which requires some ' + \"DEV-mode only tricks. It's possible that these don't work in \" + 'your browser. Try triggering the error in production mode, ' + 'or switching to a modern browser. If you suspect that this is ' + 'actually an issue with React, please file an issue.');\n } else if (isCrossOriginError) {\n error = new Error(\"A cross-origin error was thrown. React doesn't have access to \" + 'the actual error object in development. ' + 'See https://fb.me/react-crossorigin-error for more information.');\n }\n\n this.onError(error);\n } // Remove our event listeners\n\n\n window.removeEventListener('error', handleWindowError);\n };\n\n invokeGuardedCallbackImpl = invokeGuardedCallbackDev;\n }\n}\n\nvar invokeGuardedCallbackImpl$1 = invokeGuardedCallbackImpl;\n\nvar hasError = false;\nvar caughtError = null; // Used by event system to capture/rethrow the first error.\n\nvar hasRethrowError = false;\nvar rethrowError = null;\nvar reporter = {\n onError: function (error) {\n hasError = true;\n caughtError = error;\n }\n};\n/**\n * Call a function while guarding against errors that happens within it.\n * Returns an error if it throws, otherwise null.\n *\n * In production, this is implemented using a try-catch. The reason we don't\n * use a try-catch directly is so that we can swap out a different\n * implementation in DEV mode.\n *\n * @param {String} name of the guard to use for logging or debugging\n * @param {Function} func The function to invoke\n * @param {*} context The context to use when calling the function\n * @param {...*} args Arguments for function\n */\n\nfunction invokeGuardedCallback(name, func, context, a, b, c, d, e, f) {\n hasError = false;\n caughtError = null;\n invokeGuardedCallbackImpl$1.apply(reporter, arguments);\n}\n/**\n * Same as invokeGuardedCallback, but instead of returning an error, it stores\n * it in a global so it can be rethrown by `rethrowCaughtError` later.\n * TODO: See if caughtError and rethrowError can be unified.\n *\n * @param {String} name of the guard to use for logging or debugging\n * @param {Function} func The function to invoke\n * @param {*} context The context to use when calling the function\n * @param {...*} args Arguments for function\n */\n\nfunction invokeGuardedCallbackAndCatchFirstError(name, func, context, a, b, c, d, e, f) {\n invokeGuardedCallback.apply(this, arguments);\n\n if (hasError) {\n var error = clearCaughtError();\n\n if (!hasRethrowError) {\n hasRethrowError = true;\n rethrowError = error;\n }\n }\n}\n/**\n * During execution of guarded functions we will capture the first error which\n * we will rethrow to be handled by the top level error handler.\n */\n\nfunction rethrowCaughtError() {\n if (hasRethrowError) {\n var error = rethrowError;\n hasRethrowError = false;\n rethrowError = null;\n throw error;\n }\n}\nfunction hasCaughtError() {\n return hasError;\n}\nfunction clearCaughtError() {\n if (hasError) {\n var error = caughtError;\n hasError = false;\n caughtError = null;\n return error;\n } else {\n {\n {\n throw Error(\"clearCaughtError was called but no error was captured. This error is likely caused by a bug in React. Please file an issue.\");\n }\n }\n }\n}\n\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\nvar warningWithoutStack = function () {};\n\n{\n warningWithoutStack = function (condition, format) {\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n if (format === undefined) {\n throw new Error('`warningWithoutStack(condition, format, ...args)` requires a warning ' + 'message argument');\n }\n\n if (args.length > 8) {\n // Check before the condition to catch violations early.\n throw new Error('warningWithoutStack() currently supports at most 8 arguments.');\n }\n\n if (condition) {\n return;\n }\n\n if (typeof console !== 'undefined') {\n var argsWithFormat = args.map(function (item) {\n return '' + item;\n });\n argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n // breaks IE9: https://github.com/facebook/react/issues/13610\n\n Function.prototype.apply.call(console.error, console, argsWithFormat);\n }\n\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n var argIndex = 0;\n var message = 'Warning: ' + format.replace(/%s/g, function () {\n return args[argIndex++];\n });\n throw new Error(message);\n } catch (x) {}\n };\n}\n\nvar warningWithoutStack$1 = warningWithoutStack;\n\nvar getFiberCurrentPropsFromNode = null;\nvar getInstanceFromNode = null;\nvar getNodeFromInstance = null;\nfunction setComponentTree(getFiberCurrentPropsFromNodeImpl, getInstanceFromNodeImpl, getNodeFromInstanceImpl) {\n getFiberCurrentPropsFromNode = getFiberCurrentPropsFromNodeImpl;\n getInstanceFromNode = getInstanceFromNodeImpl;\n getNodeFromInstance = getNodeFromInstanceImpl;\n\n {\n !(getNodeFromInstance && getInstanceFromNode) ? warningWithoutStack$1(false, 'EventPluginUtils.setComponentTree(...): Injected ' + 'module is missing getNodeFromInstance or getInstanceFromNode.') : void 0;\n }\n}\nvar validateEventDispatches;\n\n{\n validateEventDispatches = function (event) {\n var dispatchListeners = event._dispatchListeners;\n var dispatchInstances = event._dispatchInstances;\n var listenersIsArr = Array.isArray(dispatchListeners);\n var listenersLen = listenersIsArr ? dispatchListeners.length : dispatchListeners ? 1 : 0;\n var instancesIsArr = Array.isArray(dispatchInstances);\n var instancesLen = instancesIsArr ? dispatchInstances.length : dispatchInstances ? 1 : 0;\n !(instancesIsArr === listenersIsArr && instancesLen === listenersLen) ? warningWithoutStack$1(false, 'EventPluginUtils: Invalid `event`.') : void 0;\n };\n}\n/**\n * Dispatch the event to the listener.\n * @param {SyntheticEvent} event SyntheticEvent to handle\n * @param {function} listener Application-level callback\n * @param {*} inst Internal component instance\n */\n\n\nfunction executeDispatch(event, listener, inst) {\n var type = event.type || 'unknown-event';\n event.currentTarget = getNodeFromInstance(inst);\n invokeGuardedCallbackAndCatchFirstError(type, listener, undefined, event);\n event.currentTarget = null;\n}\n/**\n * Standard/simple iteration through an event's collected dispatches.\n */\n\nfunction executeDispatchesInOrder(event) {\n var dispatchListeners = event._dispatchListeners;\n var dispatchInstances = event._dispatchInstances;\n\n {\n validateEventDispatches(event);\n }\n\n if (Array.isArray(dispatchListeners)) {\n for (var i = 0; i < dispatchListeners.length; i++) {\n if (event.isPropagationStopped()) {\n break;\n } // Listeners and Instances are two parallel arrays that are always in sync.\n\n\n executeDispatch(event, dispatchListeners[i], dispatchInstances[i]);\n }\n } else if (dispatchListeners) {\n executeDispatch(event, dispatchListeners, dispatchInstances);\n }\n\n event._dispatchListeners = null;\n event._dispatchInstances = null;\n}\n/**\n * @see executeDispatchesInOrderStopAtTrueImpl\n */\n\n\n\n/**\n * Execution of a \"direct\" dispatch - there must be at most one dispatch\n * accumulated on the event or it is considered an error. It doesn't really make\n * sense for an event with multiple dispatches (bubbled) to keep track of the\n * return values at each dispatch execution, but it does tend to make sense when\n * dealing with \"direct\" dispatches.\n *\n * @return {*} The return value of executing the single dispatch.\n */\n\n\n/**\n * @param {SyntheticEvent} event\n * @return {boolean} True iff number of dispatches accumulated is greater than 0.\n */\n\n/**\n * Accumulates items that must not be null or undefined into the first one. This\n * is used to conserve memory by avoiding array allocations, and thus sacrifices\n * API cleanness. Since `current` can be null before being passed in and not\n * null after this function, make sure to assign it back to `current`:\n *\n * `a = accumulateInto(a, b);`\n *\n * This API should be sparingly used. Try `accumulate` for something cleaner.\n *\n * @return {*|array<*>} An accumulation of items.\n */\n\nfunction accumulateInto(current, next) {\n if (!(next != null)) {\n {\n throw Error(\"accumulateInto(...): Accumulated items must not be null or undefined.\");\n }\n }\n\n if (current == null) {\n return next;\n } // Both are not empty. Warning: Never call x.concat(y) when you are not\n // certain that x is an Array (x could be a string with concat method).\n\n\n if (Array.isArray(current)) {\n if (Array.isArray(next)) {\n current.push.apply(current, next);\n return current;\n }\n\n current.push(next);\n return current;\n }\n\n if (Array.isArray(next)) {\n // A bit too dangerous to mutate `next`.\n return [current].concat(next);\n }\n\n return [current, next];\n}\n\n/**\n * @param {array} arr an \"accumulation\" of items which is either an Array or\n * a single item. Useful when paired with the `accumulate` module. This is a\n * simple utility that allows us to reason about a collection of items, but\n * handling the case when there is exactly one item (and we do not need to\n * allocate an array).\n * @param {function} cb Callback invoked with each element or a collection.\n * @param {?} [scope] Scope used as `this` in a callback.\n */\nfunction forEachAccumulated(arr, cb, scope) {\n if (Array.isArray(arr)) {\n arr.forEach(cb, scope);\n } else if (arr) {\n cb.call(scope, arr);\n }\n}\n\n/**\n * Internal queue of events that have accumulated their dispatches and are\n * waiting to have their dispatches executed.\n */\n\nvar eventQueue = null;\n/**\n * Dispatches an event and releases it back into the pool, unless persistent.\n *\n * @param {?object} event Synthetic event to be dispatched.\n * @private\n */\n\nvar executeDispatchesAndRelease = function (event) {\n if (event) {\n executeDispatchesInOrder(event);\n\n if (!event.isPersistent()) {\n event.constructor.release(event);\n }\n }\n};\n\nvar executeDispatchesAndReleaseTopLevel = function (e) {\n return executeDispatchesAndRelease(e);\n};\n\nfunction runEventsInBatch(events) {\n if (events !== null) {\n eventQueue = accumulateInto(eventQueue, events);\n } // Set `eventQueue` to null before processing it so that we can tell if more\n // events get enqueued while processing.\n\n\n var processingEventQueue = eventQueue;\n eventQueue = null;\n\n if (!processingEventQueue) {\n return;\n }\n\n forEachAccumulated(processingEventQueue, executeDispatchesAndReleaseTopLevel);\n\n if (!!eventQueue) {\n {\n throw Error(\"processEventQueue(): Additional events were enqueued while processing an event queue. Support for this has not yet been implemented.\");\n }\n } // This would be a good time to rethrow if any of the event handlers threw.\n\n\n rethrowCaughtError();\n}\n\nfunction isInteractive(tag) {\n return tag === 'button' || tag === 'input' || tag === 'select' || tag === 'textarea';\n}\n\nfunction shouldPreventMouseEvent(name, type, props) {\n switch (name) {\n case 'onClick':\n case 'onClickCapture':\n case 'onDoubleClick':\n case 'onDoubleClickCapture':\n case 'onMouseDown':\n case 'onMouseDownCapture':\n case 'onMouseMove':\n case 'onMouseMoveCapture':\n case 'onMouseUp':\n case 'onMouseUpCapture':\n return !!(props.disabled && isInteractive(type));\n\n default:\n return false;\n }\n}\n/**\n * This is a unified interface for event plugins to be installed and configured.\n *\n * Event plugins can implement the following properties:\n *\n * `extractEvents` {function(string, DOMEventTarget, string, object): *}\n * Required. When a top-level event is fired, this method is expected to\n * extract synthetic events that will in turn be queued and dispatched.\n *\n * `eventTypes` {object}\n * Optional, plugins that fire events must publish a mapping of registration\n * names that are used to register listeners. Values of this mapping must\n * be objects that contain `registrationName` or `phasedRegistrationNames`.\n *\n * `executeDispatch` {function(object, function, string)}\n * Optional, allows plugins to override how an event gets dispatched. By\n * default, the listener is simply invoked.\n *\n * Each plugin that is injected into `EventsPluginHub` is immediately operable.\n *\n * @public\n */\n\n/**\n * Methods for injecting dependencies.\n */\n\n\nvar injection = {\n /**\n * @param {array} InjectedEventPluginOrder\n * @public\n */\n injectEventPluginOrder: injectEventPluginOrder,\n\n /**\n * @param {object} injectedNamesToPlugins Map from names to plugin modules.\n */\n injectEventPluginsByName: injectEventPluginsByName\n};\n/**\n * @param {object} inst The instance, which is the source of events.\n * @param {string} registrationName Name of listener (e.g. `onClick`).\n * @return {?function} The stored callback.\n */\n\nfunction getListener(inst, registrationName) {\n var listener; // TODO: shouldPreventMouseEvent is DOM-specific and definitely should not\n // live here; needs to be moved to a better place soon\n\n var stateNode = inst.stateNode;\n\n if (!stateNode) {\n // Work in progress (ex: onload events in incremental mode).\n return null;\n }\n\n var props = getFiberCurrentPropsFromNode(stateNode);\n\n if (!props) {\n // Work in progress.\n return null;\n }\n\n listener = props[registrationName];\n\n if (shouldPreventMouseEvent(registrationName, inst.type, props)) {\n return null;\n }\n\n if (!(!listener || typeof listener === 'function')) {\n {\n throw Error(\"Expected `\" + registrationName + \"` listener to be a function, instead got a value of `\" + typeof listener + \"` type.\");\n }\n }\n\n return listener;\n}\n/**\n * Allows registered plugins an opportunity to extract events from top-level\n * native browser events.\n *\n * @return {*} An accumulation of synthetic events.\n * @internal\n */\n\nfunction extractPluginEvents(topLevelType, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags) {\n var events = null;\n\n for (var i = 0; i < plugins.length; i++) {\n // Not every plugin in the ordering may be loaded at runtime.\n var possiblePlugin = plugins[i];\n\n if (possiblePlugin) {\n var extractedEvents = possiblePlugin.extractEvents(topLevelType, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags);\n\n if (extractedEvents) {\n events = accumulateInto(events, extractedEvents);\n }\n }\n }\n\n return events;\n}\n\nfunction runExtractedPluginEventsInBatch(topLevelType, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags) {\n var events = extractPluginEvents(topLevelType, targetInst, nativeEvent, nativeEventTarget, eventSystemFlags);\n runEventsInBatch(events);\n}\n\nvar FunctionComponent = 0;\nvar ClassComponent = 1;\nvar IndeterminateComponent = 2; // Before we know whether it is function or class\n\nvar HostRoot = 3; // Root of a host tree. Could be nested inside another node.\n\nvar HostPortal = 4; // A subtree. Could be an entry point to a different renderer.\n\nvar HostComponent = 5;\nvar HostText = 6;\nvar Fragment = 7;\nvar Mode = 8;\nvar ContextConsumer = 9;\nvar ContextProvider = 10;\nvar ForwardRef = 11;\nvar Profiler = 12;\nvar SuspenseComponent = 13;\nvar MemoComponent = 14;\nvar SimpleMemoComponent = 15;\nvar LazyComponent = 16;\nvar IncompleteClassComponent = 17;\nvar DehydratedFragment = 18;\nvar SuspenseListComponent = 19;\nvar FundamentalComponent = 20;\nvar ScopeComponent = 21;\n\nvar ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED; // Prevent newer renderers from RTE when used with older react package versions.\n// Current owner and dispatcher used to share the same ref,\n// but PR #14548 split them out to better support the react-debug-tools package.\n\nif (!ReactSharedInternals.hasOwnProperty('ReactCurrentDispatcher')) {\n ReactSharedInternals.ReactCurrentDispatcher = {\n current: null\n };\n}\n\nif (!ReactSharedInternals.hasOwnProperty('ReactCurrentBatchConfig')) {\n ReactSharedInternals.ReactCurrentBatchConfig = {\n suspense: null\n };\n}\n\nvar BEFORE_SLASH_RE = /^(.*)[\\\\\\/]/;\nvar describeComponentFrame = function (name, source, ownerName) {\n var sourceInfo = '';\n\n if (source) {\n var path = source.fileName;\n var fileName = path.replace(BEFORE_SLASH_RE, '');\n\n {\n // In DEV, include code for a common special case:\n // prefer \"folder/index.js\" instead of just \"index.js\".\n if (/^index\\./.test(fileName)) {\n var match = path.match(BEFORE_SLASH_RE);\n\n if (match) {\n var pathBeforeSlash = match[1];\n\n if (pathBeforeSlash) {\n var folderName = pathBeforeSlash.replace(BEFORE_SLASH_RE, '');\n fileName = folderName + '/' + fileName;\n }\n }\n }\n }\n\n sourceInfo = ' (at ' + fileName + ':' + source.lineNumber + ')';\n } else if (ownerName) {\n sourceInfo = ' (created by ' + ownerName + ')';\n }\n\n return '\\n in ' + (name || 'Unknown') + sourceInfo;\n};\n\n// The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar hasSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7;\nvar REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca;\nvar REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb;\nvar REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc;\nvar REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2;\nvar REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd;\nvar REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary\n// (unstable) APIs that have been removed. Can we remove the symbols?\n\n\nvar REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf;\nvar REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0;\nvar REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1;\nvar REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8;\nvar REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3;\nvar REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4;\nvar REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5;\nvar REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6;\nvar REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7;\nvar MAYBE_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\nvar FAUX_ITERATOR_SYMBOL = '@@iterator';\nfunction getIteratorFn(maybeIterable) {\n if (maybeIterable === null || typeof maybeIterable !== 'object') {\n return null;\n }\n\n var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n\n if (typeof maybeIterator === 'function') {\n return maybeIterator;\n }\n\n return null;\n}\n\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar warning = warningWithoutStack$1;\n\n{\n warning = function (condition, format) {\n if (condition) {\n return;\n }\n\n var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n var stack = ReactDebugCurrentFrame.getStackAddendum(); // eslint-disable-next-line react-internal/warning-and-invariant-args\n\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n warningWithoutStack$1.apply(void 0, [false, format + '%s'].concat(args, [stack]));\n };\n}\n\nvar warning$1 = warning;\n\nvar Uninitialized = -1;\nvar Pending = 0;\nvar Resolved = 1;\nvar Rejected = 2;\nfunction refineResolvedLazyComponent(lazyComponent) {\n return lazyComponent._status === Resolved ? lazyComponent._result : null;\n}\nfunction initializeLazyComponentType(lazyComponent) {\n if (lazyComponent._status === Uninitialized) {\n lazyComponent._status = Pending;\n var ctor = lazyComponent._ctor;\n var thenable = ctor();\n lazyComponent._result = thenable;\n thenable.then(function (moduleObject) {\n if (lazyComponent._status === Pending) {\n var defaultExport = moduleObject.default;\n\n {\n if (defaultExport === undefined) {\n warning$1(false, 'lazy: Expected the result of a dynamic import() call. ' + 'Instead received: %s\\n\\nYour code should look like: \\n ' + \"const MyComponent = lazy(() => import('./MyComponent'))\", moduleObject);\n }\n }\n\n lazyComponent._status = Resolved;\n lazyComponent._result = defaultExport;\n }\n }, function (error) {\n if (lazyComponent._status === Pending) {\n lazyComponent._status = Rejected;\n lazyComponent._result = error;\n }\n });\n }\n}\n\nfunction getWrappedName(outerType, innerType, wrapperName) {\n var functionName = innerType.displayName || innerType.name || '';\n return outerType.displayName || (functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName);\n}\n\nfunction getComponentName(type) {\n if (type == null) {\n // Host root, text node or just invalid type.\n return null;\n }\n\n {\n if (typeof type.tag === 'number') {\n warningWithoutStack$1(false, 'Received an unexpected object in getComponentName(). ' + 'This is likely a bug in React. Please file an issue.');\n }\n }\n\n if (typeof type === 'function') {\n return type.displayName || type.name || null;\n }\n\n if (typeof type === 'string') {\n return type;\n }\n\n switch (type) {\n case REACT_FRAGMENT_TYPE:\n return 'Fragment';\n\n case REACT_PORTAL_TYPE:\n return 'Portal';\n\n case REACT_PROFILER_TYPE:\n return \"Profiler\";\n\n case REACT_STRICT_MODE_TYPE:\n return 'StrictMode';\n\n case REACT_SUSPENSE_TYPE:\n return 'Suspense';\n\n case REACT_SUSPENSE_LIST_TYPE:\n return 'SuspenseList';\n }\n\n if (typeof type === 'object') {\n switch (type.$$typeof) {\n case REACT_CONTEXT_TYPE:\n return 'Context.Consumer';\n\n case REACT_PROVIDER_TYPE:\n return 'Context.Provider';\n\n case REACT_FORWARD_REF_TYPE:\n return getWrappedName(type, type.render, 'ForwardRef');\n\n case REACT_MEMO_TYPE:\n return getComponentName(type.type);\n\n case REACT_LAZY_TYPE:\n {\n var thenable = type;\n var resolvedThenable = refineResolvedLazyComponent(thenable);\n\n if (resolvedThenable) {\n return getComponentName(resolvedThenable);\n }\n\n break;\n }\n }\n }\n\n return null;\n}\n\nvar ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n\nfunction describeFiber(fiber) {\n switch (fiber.tag) {\n case HostRoot:\n case HostPortal:\n case HostText:\n case Fragment:\n case ContextProvider:\n case ContextConsumer:\n return '';\n\n default:\n var owner = fiber._debugOwner;\n var source = fiber._debugSource;\n var name = getComponentName(fiber.type);\n var ownerName = null;\n\n if (owner) {\n ownerName = getComponentName(owner.type);\n }\n\n return describeComponentFrame(name, source, ownerName);\n }\n}\n\nfunction getStackByFiberInDevAndProd(workInProgress) {\n var info = '';\n var node = workInProgress;\n\n do {\n info += describeFiber(node);\n node = node.return;\n } while (node);\n\n return info;\n}\nvar current = null;\nvar phase = null;\nfunction getCurrentFiberOwnerNameInDevOrNull() {\n {\n if (current === null) {\n return null;\n }\n\n var owner = current._debugOwner;\n\n if (owner !== null && typeof owner !== 'undefined') {\n return getComponentName(owner.type);\n }\n }\n\n return null;\n}\nfunction getCurrentFiberStackInDev() {\n {\n if (current === null) {\n return '';\n } // Safe because if current fiber exists, we are reconciling,\n // and it is guaranteed to be the work-in-progress version.\n\n\n return getStackByFiberInDevAndProd(current);\n }\n\n return '';\n}\nfunction resetCurrentFiber() {\n {\n ReactDebugCurrentFrame.getCurrentStack = null;\n current = null;\n phase = null;\n }\n}\nfunction setCurrentFiber(fiber) {\n {\n ReactDebugCurrentFrame.getCurrentStack = getCurrentFiberStackInDev;\n current = fiber;\n phase = null;\n }\n}\nfunction setCurrentPhase(lifeCyclePhase) {\n {\n phase = lifeCyclePhase;\n }\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined');\n\nfunction endsWith(subject, search) {\n var length = subject.length;\n return subject.substring(length - search.length, length) === search;\n}\n\nvar PLUGIN_EVENT_SYSTEM = 1;\nvar RESPONDER_EVENT_SYSTEM = 1 << 1;\nvar IS_PASSIVE = 1 << 2;\nvar IS_ACTIVE = 1 << 3;\nvar PASSIVE_NOT_SUPPORTED = 1 << 4;\nvar IS_REPLAYED = 1 << 5;\n\nvar restoreImpl = null;\nvar restoreTarget = null;\nvar restoreQueue = null;\n\nfunction restoreStateOfTarget(target) {\n // We perform this translation at the end of the event loop so that we\n // always receive the correct fiber here\n var internalInstance = getInstanceFromNode(target);\n\n if (!internalInstance) {\n // Unmounted\n return;\n }\n\n if (!(typeof restoreImpl === 'function')) {\n {\n throw Error(\"setRestoreImplementation() needs to be called to handle a target for controlled events. This error is likely caused by a bug in React. Please file an issue.\");\n }\n }\n\n var props = getFiberCurrentPropsFromNode(internalInstance.stateNode);\n restoreImpl(internalInstance.stateNode, internalInstance.type, props);\n}\n\nfunction setRestoreImplementation(impl) {\n restoreImpl = impl;\n}\nfunction enqueueStateRestore(target) {\n if (restoreTarget) {\n if (restoreQueue) {\n restoreQueue.push(target);\n } else {\n restoreQueue = [target];\n }\n } else {\n restoreTarget = target;\n }\n}\nfunction needsStateRestore() {\n return restoreTarget !== null || restoreQueue !== null;\n}\nfunction restoreStateIfNeeded() {\n if (!restoreTarget) {\n return;\n }\n\n var target = restoreTarget;\n var queuedTargets = restoreQueue;\n restoreTarget = null;\n restoreQueue = null;\n restoreStateOfTarget(target);\n\n if (queuedTargets) {\n for (var i = 0; i < queuedTargets.length; i++) {\n restoreStateOfTarget(queuedTargets[i]);\n }\n }\n}\n\nvar enableUserTimingAPI = true; // Helps identify side effects in render-phase lifecycle hooks and setState\n// reducers by double invoking them in Strict Mode.\n\nvar debugRenderPhaseSideEffectsForStrictMode = true; // To preserve the \"Pause on caught exceptions\" behavior of the debugger, we\n// replay the begin phase of a failed component inside invokeGuardedCallback.\n\nvar replayFailedUnitOfWorkWithInvokeGuardedCallback = true; // Warn about deprecated, async-unsafe lifecycles; relates to RFC #6:\n\nvar warnAboutDeprecatedLifecycles = true; // Gather advanced timing metrics for Profiler subtrees.\n\nvar enableProfilerTimer = true; // Trace which interactions trigger each commit.\n\nvar enableSchedulerTracing = true; // SSR experiments\n\nvar enableSuspenseServerRenderer = false;\nvar enableSelectiveHydration = false; // Only used in www builds.\n\n // Only used in www builds.\n\n // Disable javascript: URL strings in href for XSS protection.\n\nvar disableJavaScriptURLs = false; // React Fire: prevent the value and checked attributes from syncing\n// with their related DOM properties\n\nvar disableInputAttributeSyncing = false; // These APIs will no longer be \"unstable\" in the upcoming 16.7 release,\n// Control this behavior with a flag to support 16.6 minor releases in the meanwhile.\n\nvar exposeConcurrentModeAPIs = false;\nvar warnAboutShorthandPropertyCollision = false; // Experimental React Flare event system and event components support.\n\nvar enableFlareAPI = false; // Experimental Host Component support.\n\nvar enableFundamentalAPI = false; // Experimental Scope support.\n\nvar enableScopeAPI = false; // New API for JSX transforms to target - https://github.com/reactjs/rfcs/pull/107\n\n // We will enforce mocking scheduler with scheduler/unstable_mock at some point. (v17?)\n// Till then, we warn about the missing mock, but still fallback to a legacy mode compatible version\n\nvar warnAboutUnmockedScheduler = false; // For tests, we flush suspense fallbacks in an act scope;\n// *except* in some of our own tests, where we test incremental loading states.\n\nvar flushSuspenseFallbacksInTests = true; // Add a callback property to suspense to notify which promises are currently\n// in the update queue. This allows reporting and tracing of what is causing\n// the user to see a loading state.\n// Also allows hydration callbacks to fire when a dehydrated boundary gets\n// hydrated or deleted.\n\nvar enableSuspenseCallback = false; // Part of the simplification of React.createElement so we can eventually move\n// from React.createElement to React.jsx\n// https://github.com/reactjs/rfcs/blob/createlement-rfc/text/0000-create-element-changes.md\n\nvar warnAboutDefaultPropsOnFunctionComponents = false;\nvar warnAboutStringRefs = false;\nvar disableLegacyContext = false;\nvar disableSchedulerTimeoutBasedOnReactExpirationTime = false;\nvar enableTrustedTypesIntegration = false; // Flag to turn event.target and event.currentTarget in ReactNative from a reactTag to a component instance\n\n// the renderer. Such as when we're dispatching events or if third party\n// libraries need to call batchedUpdates. Eventually, this API will go away when\n// everything is batched by default. We'll then have a similar API to opt-out of\n// scheduled work and instead do synchronous work.\n// Defaults\n\nvar batchedUpdatesImpl = function (fn, bookkeeping) {\n return fn(bookkeeping);\n};\n\nvar discreteUpdatesImpl = function (fn, a, b, c) {\n return fn(a, b, c);\n};\n\nvar flushDiscreteUpdatesImpl = function () {};\n\nvar batchedEventUpdatesImpl = batchedUpdatesImpl;\nvar isInsideEventHandler = false;\nvar isBatchingEventUpdates = false;\n\nfunction finishEventHandler() {\n // Here we wait until all updates have propagated, which is important\n // when using controlled components within layers:\n // https://github.com/facebook/react/issues/1698\n // Then we restore state of any controlled component.\n var controlledComponentsHavePendingUpdates = needsStateRestore();\n\n if (controlledComponentsHavePendingUpdates) {\n // If a controlled event was fired, we may need to restore the state of\n // the DOM node back to the controlled value. This is necessary when React\n // bails out of the update without touching the DOM.\n flushDiscreteUpdatesImpl();\n restoreStateIfNeeded();\n }\n}\n\nfunction batchedUpdates(fn, bookkeeping) {\n if (isInsideEventHandler) {\n // If we are currently inside another batch, we need to wait until it\n // fully completes before restoring state.\n return fn(bookkeeping);\n }\n\n isInsideEventHandler = true;\n\n try {\n return batchedUpdatesImpl(fn, bookkeeping);\n } finally {\n isInsideEventHandler = false;\n finishEventHandler();\n }\n}\nfunction batchedEventUpdates(fn, a, b) {\n if (isBatchingEventUpdates) {\n // If we are currently inside another batch, we need to wait until it\n // fully completes before restoring state.\n return fn(a, b);\n }\n\n isBatchingEventUpdates = true;\n\n try {\n return batchedEventUpdatesImpl(fn, a, b);\n } finally {\n isBatchingEventUpdates = false;\n finishEventHandler();\n }\n} // This is for the React Flare event system\n\nfunction executeUserEventHandler(fn, value) {\n var previouslyInEventHandler = isInsideEventHandler;\n\n try {\n isInsideEventHandler = true;\n var type = typeof value === 'object' && value !== null ? value.type : '';\n invokeGuardedCallbackAndCatchFirstError(type, fn, undefined, value);\n } finally {\n isInsideEventHandler = previouslyInEventHandler;\n }\n}\nfunction discreteUpdates(fn, a, b, c) {\n var prevIsInsideEventHandler = isInsideEventHandler;\n isInsideEventHandler = true;\n\n try {\n return discreteUpdatesImpl(fn, a, b, c);\n } finally {\n isInsideEventHandler = prevIsInsideEventHandler;\n\n if (!isInsideEventHandler) {\n finishEventHandler();\n }\n }\n}\nvar lastFlushedEventTimeStamp = 0;\nfunction flushDiscreteUpdatesIfNeeded(timeStamp) {\n // event.timeStamp isn't overly reliable due to inconsistencies in\n // how different browsers have historically provided the time stamp.\n // Some browsers provide high-resolution time stamps for all events,\n // some provide low-resolution time stamps for all events. FF < 52\n // even mixes both time stamps together. Some browsers even report\n // negative time stamps or time stamps that are 0 (iOS9) in some cases.\n // Given we are only comparing two time stamps with equality (!==),\n // we are safe from the resolution differences. If the time stamp is 0\n // we bail-out of preventing the flush, which can affect semantics,\n // such as if an earlier flush removes or adds event listeners that\n // are fired in the subsequent flush. However, this is the same\n // behaviour as we had before this change, so the risks are low.\n if (!isInsideEventHandler && (!enableFlareAPI || timeStamp === 0 || lastFlushedEventTimeStamp !== timeStamp)) {\n lastFlushedEventTimeStamp = timeStamp;\n flushDiscreteUpdatesImpl();\n }\n}\nfunction setBatchingImplementation(_batchedUpdatesImpl, _discreteUpdatesImpl, _flushDiscreteUpdatesImpl, _batchedEventUpdatesImpl) {\n batchedUpdatesImpl = _batchedUpdatesImpl;\n discreteUpdatesImpl = _discreteUpdatesImpl;\n flushDiscreteUpdatesImpl = _flushDiscreteUpdatesImpl;\n batchedEventUpdatesImpl = _batchedEventUpdatesImpl;\n}\n\nvar DiscreteEvent = 0;\nvar UserBlockingEvent = 1;\nvar ContinuousEvent = 2;\n\n// CommonJS interop named imports.\n\nvar UserBlockingPriority = Scheduler.unstable_UserBlockingPriority;\nvar runWithPriority = Scheduler.unstable_runWithPriority;\nvar listenToResponderEventTypesImpl;\nfunction setListenToResponderEventTypes(_listenToResponderEventTypesImpl) {\n listenToResponderEventTypesImpl = _listenToResponderEventTypesImpl;\n}\nvar rootEventTypesToEventResponderInstances = new Map();\nvar DoNotPropagateToNextResponder = 0;\nvar PropagateToNextResponder = 1;\nvar currentTimeStamp = 0;\nvar currentInstance = null;\nvar currentDocument = null;\nvar currentPropagationBehavior = DoNotPropagateToNextResponder;\nvar eventResponderContext = {\n dispatchEvent: function (eventValue, eventListener, eventPriority) {\n validateResponderContext();\n validateEventValue(eventValue);\n\n switch (eventPriority) {\n case DiscreteEvent:\n {\n flushDiscreteUpdatesIfNeeded(currentTimeStamp);\n discreteUpdates(function () {\n return executeUserEventHandler(eventListener, eventValue);\n });\n break;\n }\n\n case UserBlockingEvent:\n {\n runWithPriority(UserBlockingPriority, function () {\n return executeUserEventHandler(eventListener, eventValue);\n });\n break;\n }\n\n case ContinuousEvent:\n {\n executeUserEventHandler(eventListener, eventValue);\n break;\n }\n }\n },\n isTargetWithinResponder: function (target) {\n validateResponderContext();\n\n if (target != null) {\n var fiber = getClosestInstanceFromNode(target);\n var responderFiber = currentInstance.fiber;\n\n while (fiber !== null) {\n if (fiber === responderFiber || fiber.alternate === responderFiber) {\n return true;\n }\n\n fiber = fiber.return;\n }\n }\n\n return false;\n },\n isTargetWithinResponderScope: function (target) {\n validateResponderContext();\n var componentInstance = currentInstance;\n var responder = componentInstance.responder;\n\n if (target != null) {\n var fiber = getClosestInstanceFromNode(target);\n var responderFiber = currentInstance.fiber;\n\n while (fiber !== null) {\n if (fiber === responderFiber || fiber.alternate === responderFiber) {\n return true;\n }\n\n if (doesFiberHaveResponder(fiber, responder)) {\n return false;\n }\n\n fiber = fiber.return;\n }\n }\n\n return false;\n },\n isTargetWithinNode: function (childTarget, parentTarget) {\n validateResponderContext();\n var childFiber = getClosestInstanceFromNode(childTarget);\n var parentFiber = getClosestInstanceFromNode(parentTarget);\n\n if (childFiber != null && parentFiber != null) {\n var parentAlternateFiber = parentFiber.alternate;\n var node = childFiber;\n\n while (node !== null) {\n if (node === parentFiber || node === parentAlternateFiber) {\n return true;\n }\n\n node = node.return;\n }\n\n return false;\n } // Fallback to DOM APIs\n\n\n return parentTarget.contains(childTarget);\n },\n addRootEventTypes: function (rootEventTypes) {\n validateResponderContext();\n listenToResponderEventTypesImpl(rootEventTypes, currentDocument);\n\n for (var i = 0; i < rootEventTypes.length; i++) {\n var rootEventType = rootEventTypes[i];\n var eventResponderInstance = currentInstance;\n registerRootEventType(rootEventType, eventResponderInstance);\n }\n },\n removeRootEventTypes: function (rootEventTypes) {\n validateResponderContext();\n\n for (var i = 0; i < rootEventTypes.length; i++) {\n var rootEventType = rootEventTypes[i];\n var rootEventResponders = rootEventTypesToEventResponderInstances.get(rootEventType);\n var rootEventTypesSet = currentInstance.rootEventTypes;\n\n if (rootEventTypesSet !== null) {\n rootEventTypesSet.delete(rootEventType);\n }\n\n if (rootEventResponders !== undefined) {\n rootEventResponders.delete(currentInstance);\n }\n }\n },\n getActiveDocument: getActiveDocument,\n objectAssign: _assign,\n getTimeStamp: function () {\n validateResponderContext();\n return currentTimeStamp;\n },\n isTargetWithinHostComponent: function (target, elementType) {\n validateResponderContext();\n var fiber = getClosestInstanceFromNode(target);\n\n while (fiber !== null) {\n if (fiber.tag === HostComponent && fiber.type === elementType) {\n return true;\n }\n\n fiber = fiber.return;\n }\n\n return false;\n },\n continuePropagation: function () {\n currentPropagationBehavior = PropagateToNextResponder;\n },\n enqueueStateRestore: enqueueStateRestore,\n getResponderNode: function () {\n validateResponderContext();\n var responderFiber = currentInstance.fiber;\n\n if (responderFiber.tag === ScopeComponent) {\n return null;\n }\n\n return responderFiber.stateNode;\n }\n};\n\nfunction validateEventValue(eventValue) {\n if (typeof eventValue === 'object' && eventValue !== null) {\n var target = eventValue.target,\n type = eventValue.type,\n timeStamp = eventValue.timeStamp;\n\n if (target == null || type == null || timeStamp == null) {\n throw new Error('context.dispatchEvent: \"target\", \"timeStamp\", and \"type\" fields on event object are required.');\n }\n\n var showWarning = function (name) {\n {\n warning$1(false, '%s is not available on event objects created from event responder modules (React Flare). ' + 'Try wrapping in a conditional, i.e. `if (event.type !== \"press\") { event.%s }`', name, name);\n }\n };\n\n eventValue.isDefaultPrevented = function () {\n {\n showWarning('isDefaultPrevented()');\n }\n };\n\n eventValue.isPropagationStopped = function () {\n {\n showWarning('isPropagationStopped()');\n }\n }; // $FlowFixMe: we don't need value, Flow thinks we do\n\n\n Object.defineProperty(eventValue, 'nativeEvent', {\n get: function () {\n {\n showWarning('nativeEvent');\n }\n }\n });\n }\n}\n\nfunction doesFiberHaveResponder(fiber, responder) {\n var tag = fiber.tag;\n\n if (tag === HostComponent || tag === ScopeComponent) {\n var dependencies = fiber.dependencies;\n\n if (dependencies !== null) {\n var respondersMap = dependencies.responders;\n\n if (respondersMap !== null && respondersMap.has(responder)) {\n return true;\n }\n }\n }\n\n return false;\n}\n\nfunction getActiveDocument() {\n return currentDocument;\n}\n\nfunction createDOMResponderEvent(topLevelType, nativeEvent, nativeEventTarget, passive, passiveSupported) {\n var _ref = nativeEvent,\n buttons = _ref.buttons,\n pointerType = _ref.pointerType;\n var eventPointerType = '';\n\n if (pointerType !== undefined) {\n eventPointerType = pointerType;\n } else if (nativeEvent.key !== undefined) {\n eventPointerType = 'keyboard';\n } else if (buttons !== undefined) {\n eventPointerType = 'mouse';\n } else if (nativeEvent.changedTouches !== undefined) {\n eventPointerType = 'touch';\n }\n\n return {\n nativeEvent: nativeEvent,\n passive: passive,\n passiveSupported: passiveSupported,\n pointerType: eventPointerType,\n target: nativeEventTarget,\n type: topLevelType\n };\n}\n\nfunction responderEventTypesContainType(eventTypes, type) {\n for (var i = 0, len = eventTypes.length; i < len; i++) {\n if (eventTypes[i] === type) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction validateResponderTargetEventTypes(eventType, responder) {\n var targetEventTypes = responder.targetEventTypes; // Validate the target event type exists on the responder\n\n if (targetEventTypes !== null) {\n return responderEventTypesContainType(targetEventTypes, eventType);\n }\n\n return false;\n}\n\nfunction traverseAndHandleEventResponderInstances(topLevelType, targetFiber, nativeEvent, nativeEventTarget, eventSystemFlags) {\n var isPassiveEvent = (eventSystemFlags & IS_PASSIVE) !== 0;\n var isPassiveSupported = (eventSystemFlags & PASSIVE_NOT_SUPPORTED) === 0;\n var isPassive = isPassiveEvent || !isPassiveSupported;\n var eventType = isPassive ? topLevelType : topLevelType + '_active'; // Trigger event responders in this order:\n // - Bubble target responder phase\n // - Root responder phase\n\n var visitedResponders = new Set();\n var responderEvent = createDOMResponderEvent(topLevelType, nativeEvent, nativeEventTarget, isPassiveEvent, isPassiveSupported);\n var node = targetFiber;\n var insidePortal = false;\n\n while (node !== null) {\n var _node = node,\n dependencies = _node.dependencies,\n tag = _node.tag;\n\n if (tag === HostPortal) {\n insidePortal = true;\n } else if ((tag === HostComponent || tag === ScopeComponent) && dependencies !== null) {\n var respondersMap = dependencies.responders;\n\n if (respondersMap !== null) {\n var responderInstances = Array.from(respondersMap.values());\n\n for (var i = 0, length = responderInstances.length; i < length; i++) {\n var responderInstance = responderInstances[i];\n var props = responderInstance.props,\n responder = responderInstance.responder,\n state = responderInstance.state;\n\n if (!visitedResponders.has(responder) && validateResponderTargetEventTypes(eventType, responder) && (!insidePortal || responder.targetPortalPropagation)) {\n visitedResponders.add(responder);\n var onEvent = responder.onEvent;\n\n if (onEvent !== null) {\n currentInstance = responderInstance;\n onEvent(responderEvent, eventResponderContext, props, state);\n\n if (currentPropagationBehavior === PropagateToNextResponder) {\n visitedResponders.delete(responder);\n currentPropagationBehavior = DoNotPropagateToNextResponder;\n }\n }\n }\n }\n }\n }\n\n node = node.return;\n } // Root phase\n\n\n var rootEventResponderInstances = rootEventTypesToEventResponderInstances.get(eventType);\n\n if (rootEventResponderInstances !== undefined) {\n var _responderInstances = Array.from(rootEventResponderInstances);\n\n for (var _i = 0; _i < _responderInstances.length; _i++) {\n var _responderInstance = _responderInstances[_i];\n var props = _responderInstance.props,\n responder = _responderInstance.responder,\n state = _responderInstance.state;\n var onRootEvent = responder.onRootEvent;\n\n if (onRootEvent !== null) {\n currentInstance = _responderInstance;\n onRootEvent(responderEvent, eventResponderContext, props, state);\n }\n }\n }\n}\n\nfunction mountEventResponder(responder, responderInstance, props, state) {\n var onMount = responder.onMount;\n\n if (onMount !== null) {\n var previousInstance = currentInstance;\n currentInstance = responderInstance;\n\n try {\n batchedEventUpdates(function () {\n onMount(eventResponderContext, props, state);\n });\n } finally {\n currentInstance = previousInstance;\n }\n }\n}\nfunction unmountEventResponder(responderInstance) {\n var responder = responderInstance.responder;\n var onUnmount = responder.onUnmount;\n\n if (onUnmount !== null) {\n var props = responderInstance.props,\n state = responderInstance.state;\n var previousInstance = currentInstance;\n currentInstance = responderInstance;\n\n try {\n batchedEventUpdates(function () {\n onUnmount(eventResponderContext, props, state);\n });\n } finally {\n currentInstance = previousInstance;\n }\n }\n\n var rootEventTypesSet = responderInstance.rootEventTypes;\n\n if (rootEventTypesSet !== null) {\n var rootEventTypes = Array.from(rootEventTypesSet);\n\n for (var i = 0; i < rootEventTypes.length; i++) {\n var topLevelEventType = rootEventTypes[i];\n var rootEventResponderInstances = rootEventTypesToEventResponderInstances.get(topLevelEventType);\n\n if (rootEventResponderInstances !== undefined) {\n rootEventResponderInstances.delete(responderInstance);\n }\n }\n }\n}\n\nfunction validateResponderContext() {\n if (!(currentInstance !== null)) {\n {\n throw Error(\"An event responder context was used outside of an event cycle.\");\n }\n }\n}\n\nfunction dispatchEventForResponderEventSystem(topLevelType, targetFiber, nativeEvent, nativeEventTarget, eventSystemFlags) {\n if (enableFlareAPI) {\n var previousInstance = currentInstance;\n var previousTimeStamp = currentTimeStamp;\n var previousDocument = currentDocument;\n var previousPropagationBehavior = currentPropagationBehavior;\n currentPropagationBehavior = DoNotPropagateToNextResponder; // nodeType 9 is DOCUMENT_NODE\n\n currentDocument = nativeEventTarget.nodeType === 9 ? nativeEventTarget : nativeEventTarget.ownerDocument; // We might want to control timeStamp another way here\n\n currentTimeStamp = nativeEvent.timeStamp;\n\n try {\n batchedEventUpdates(function () {\n traverseAndHandleEventResponderInstances(topLevelType, targetFiber, nativeEvent, nativeEventTarget, eventSystemFlags);\n });\n } finally {\n currentInstance = previousInstance;\n currentTimeStamp = previousTimeStamp;\n currentDocument = previousDocument;\n currentPropagationBehavior = previousPropagationBehavior;\n }\n }\n}\nfunction addRootEventTypesForResponderInstance(responderInstance, rootEventTypes) {\n for (var i = 0; i < rootEventTypes.length; i++) {\n var rootEventType = rootEventTypes[i];\n registerRootEventType(rootEventType, responderInstance);\n }\n}\n\nfunction registerRootEventType(rootEventType, eventResponderInstance) {\n var rootEventResponderInstances = rootEventTypesToEventResponderInstances.get(rootEventType);\n\n if (rootEventResponderInstances === undefined) {\n rootEventResponderInstances = new Set();\n rootEventTypesToEventResponderInstances.set(rootEventType, rootEventResponderInstances);\n }\n\n var rootEventTypesSet = eventResponderInstance.rootEventTypes;\n\n if (rootEventTypesSet === null) {\n rootEventTypesSet = eventResponderInstance.rootEventTypes = new Set();\n }\n\n if (!!rootEventTypesSet.has(rootEventType)) {\n {\n throw Error(\"addRootEventTypes() found a duplicate root event type of \\\"\" + rootEventType + \"\\\". This might be because the event type exists in the event responder \\\"rootEventTypes\\\" array or because of a previous addRootEventTypes() using this root event type.\");\n }\n }\n\n rootEventTypesSet.add(rootEventType);\n rootEventResponderInstances.add(eventResponderInstance);\n}\n\n// A reserved attribute.\n// It is handled by React separately and shouldn't be written to the DOM.\nvar RESERVED = 0; // A simple string attribute.\n// Attributes that aren't in the whitelist are presumed to have this type.\n\nvar STRING = 1; // A string attribute that accepts booleans in React. In HTML, these are called\n// \"enumerated\" attributes with \"true\" and \"false\" as possible values.\n// When true, it should be set to a \"true\" string.\n// When false, it should be set to a \"false\" string.\n\nvar BOOLEANISH_STRING = 2; // A real boolean attribute.\n// When true, it should be present (set either to an empty string or its name).\n// When false, it should be omitted.\n\nvar BOOLEAN = 3; // An attribute that can be used as a flag as well as with a value.\n// When true, it should be present (set either to an empty string or its name).\n// When false, it should be omitted.\n// For any other value, should be present with that value.\n\nvar OVERLOADED_BOOLEAN = 4; // An attribute that must be numeric or parse as a numeric.\n// When falsy, it should be removed.\n\nvar NUMERIC = 5; // An attribute that must be positive numeric or parse as a positive numeric.\n// When falsy, it should be removed.\n\nvar POSITIVE_NUMERIC = 6;\n\n/* eslint-disable max-len */\nvar ATTRIBUTE_NAME_START_CHAR = \":A-Z_a-z\\\\u00C0-\\\\u00D6\\\\u00D8-\\\\u00F6\\\\u00F8-\\\\u02FF\\\\u0370-\\\\u037D\\\\u037F-\\\\u1FFF\\\\u200C-\\\\u200D\\\\u2070-\\\\u218F\\\\u2C00-\\\\u2FEF\\\\u3001-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFFD\";\n/* eslint-enable max-len */\n\nvar ATTRIBUTE_NAME_CHAR = ATTRIBUTE_NAME_START_CHAR + \"\\\\-.0-9\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040\";\n\nvar ROOT_ATTRIBUTE_NAME = 'data-reactroot';\nvar VALID_ATTRIBUTE_NAME_REGEX = new RegExp('^[' + ATTRIBUTE_NAME_START_CHAR + '][' + ATTRIBUTE_NAME_CHAR + ']*$');\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar illegalAttributeNameCache = {};\nvar validatedAttributeNameCache = {};\nfunction isAttributeNameSafe(attributeName) {\n if (hasOwnProperty.call(validatedAttributeNameCache, attributeName)) {\n return true;\n }\n\n if (hasOwnProperty.call(illegalAttributeNameCache, attributeName)) {\n return false;\n }\n\n if (VALID_ATTRIBUTE_NAME_REGEX.test(attributeName)) {\n validatedAttributeNameCache[attributeName] = true;\n return true;\n }\n\n illegalAttributeNameCache[attributeName] = true;\n\n {\n warning$1(false, 'Invalid attribute name: `%s`', attributeName);\n }\n\n return false;\n}\nfunction shouldIgnoreAttribute(name, propertyInfo, isCustomComponentTag) {\n if (propertyInfo !== null) {\n return propertyInfo.type === RESERVED;\n }\n\n if (isCustomComponentTag) {\n return false;\n }\n\n if (name.length > 2 && (name[0] === 'o' || name[0] === 'O') && (name[1] === 'n' || name[1] === 'N')) {\n return true;\n }\n\n return false;\n}\nfunction shouldRemoveAttributeWithWarning(name, value, propertyInfo, isCustomComponentTag) {\n if (propertyInfo !== null && propertyInfo.type === RESERVED) {\n return false;\n }\n\n switch (typeof value) {\n case 'function': // $FlowIssue symbol is perfectly valid here\n\n case 'symbol':\n // eslint-disable-line\n return true;\n\n case 'boolean':\n {\n if (isCustomComponentTag) {\n return false;\n }\n\n if (propertyInfo !== null) {\n return !propertyInfo.acceptsBooleans;\n } else {\n var prefix = name.toLowerCase().slice(0, 5);\n return prefix !== 'data-' && prefix !== 'aria-';\n }\n }\n\n default:\n return false;\n }\n}\nfunction shouldRemoveAttribute(name, value, propertyInfo, isCustomComponentTag) {\n if (value === null || typeof value === 'undefined') {\n return true;\n }\n\n if (shouldRemoveAttributeWithWarning(name, value, propertyInfo, isCustomComponentTag)) {\n return true;\n }\n\n if (isCustomComponentTag) {\n return false;\n }\n\n if (propertyInfo !== null) {\n switch (propertyInfo.type) {\n case BOOLEAN:\n return !value;\n\n case OVERLOADED_BOOLEAN:\n return value === false;\n\n case NUMERIC:\n return isNaN(value);\n\n case POSITIVE_NUMERIC:\n return isNaN(value) || value < 1;\n }\n }\n\n return false;\n}\nfunction getPropertyInfo(name) {\n return properties.hasOwnProperty(name) ? properties[name] : null;\n}\n\nfunction PropertyInfoRecord(name, type, mustUseProperty, attributeName, attributeNamespace, sanitizeURL) {\n this.acceptsBooleans = type === BOOLEANISH_STRING || type === BOOLEAN || type === OVERLOADED_BOOLEAN;\n this.attributeName = attributeName;\n this.attributeNamespace = attributeNamespace;\n this.mustUseProperty = mustUseProperty;\n this.propertyName = name;\n this.type = type;\n this.sanitizeURL = sanitizeURL;\n} // When adding attributes to this list, be sure to also add them to\n// the `possibleStandardNames` module to ensure casing and incorrect\n// name warnings.\n\n\nvar properties = {}; // These props are reserved by React. They shouldn't be written to the DOM.\n\n['children', 'dangerouslySetInnerHTML', // TODO: This prevents the assignment of defaultValue to regular\n// elements (not just inputs). Now that ReactDOMInput assigns to the\n// defaultValue property -- do we need this?\n'defaultValue', 'defaultChecked', 'innerHTML', 'suppressContentEditableWarning', 'suppressHydrationWarning', 'style'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, RESERVED, false, // mustUseProperty\n name, // attributeName\n null, // attributeNamespace\n false);\n}); // A few React string attributes have a different name.\n// This is a mapping from React prop names to the attribute names.\n\n[['acceptCharset', 'accept-charset'], ['className', 'class'], ['htmlFor', 'for'], ['httpEquiv', 'http-equiv']].forEach(function (_ref) {\n var name = _ref[0],\n attributeName = _ref[1];\n properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty\n attributeName, // attributeName\n null, // attributeNamespace\n false);\n}); // These are \"enumerated\" HTML attributes that accept \"true\" and \"false\".\n// In React, we let users pass `true` and `false` even though technically\n// these aren't boolean attributes (they are coerced to strings).\n\n['contentEditable', 'draggable', 'spellCheck', 'value'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEANISH_STRING, false, // mustUseProperty\n name.toLowerCase(), // attributeName\n null, // attributeNamespace\n false);\n}); // These are \"enumerated\" SVG attributes that accept \"true\" and \"false\".\n// In React, we let users pass `true` and `false` even though technically\n// these aren't boolean attributes (they are coerced to strings).\n// Since these are SVG attributes, their attribute names are case-sensitive.\n\n['autoReverse', 'externalResourcesRequired', 'focusable', 'preserveAlpha'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEANISH_STRING, false, // mustUseProperty\n name, // attributeName\n null, // attributeNamespace\n false);\n}); // These are HTML boolean attributes.\n\n['allowFullScreen', 'async', // Note: there is a special case that prevents it from being written to the DOM\n// on the client side because the browsers are inconsistent. Instead we call focus().\n'autoFocus', 'autoPlay', 'controls', 'default', 'defer', 'disabled', 'disablePictureInPicture', 'formNoValidate', 'hidden', 'loop', 'noModule', 'noValidate', 'open', 'playsInline', 'readOnly', 'required', 'reversed', 'scoped', 'seamless', // Microdata\n'itemScope'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEAN, false, // mustUseProperty\n name.toLowerCase(), // attributeName\n null, // attributeNamespace\n false);\n}); // These are the few React props that we set as DOM properties\n// rather than attributes. These are all booleans.\n\n['checked', // Note: `option.selected` is not updated if `select.multiple` is\n// disabled with `removeAttribute`. We have special logic for handling this.\n'multiple', 'muted', 'selected'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, BOOLEAN, true, // mustUseProperty\n name, // attributeName\n null, // attributeNamespace\n false);\n}); // These are HTML attributes that are \"overloaded booleans\": they behave like\n// booleans, but can also accept a string value.\n\n['capture', 'download'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, OVERLOADED_BOOLEAN, false, // mustUseProperty\n name, // attributeName\n null, // attributeNamespace\n false);\n}); // These are HTML attributes that must be positive numbers.\n\n['cols', 'rows', 'size', 'span'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, POSITIVE_NUMERIC, false, // mustUseProperty\n name, // attributeName\n null, // attributeNamespace\n false);\n}); // These are HTML attributes that must be numbers.\n\n['rowSpan', 'start'].forEach(function (name) {\n properties[name] = new PropertyInfoRecord(name, NUMERIC, false, // mustUseProperty\n name.toLowerCase(), // attributeName\n null, // attributeNamespace\n false);\n});\nvar CAMELIZE = /[\\-\\:]([a-z])/g;\n\nvar capitalize = function (token) {\n return token[1].toUpperCase();\n}; // This is a list of all SVG attributes that need special casing, namespacing,\n// or boolean value assignment. Regular attributes that just accept strings\n// and have the same names are omitted, just like in the HTML whitelist.\n// Some of these attributes can be hard to find. This list was created by\n// scrapping the MDN documentation.\n\n\n['accent-height', 'alignment-baseline', 'arabic-form', 'baseline-shift', 'cap-height', 'clip-path', 'clip-rule', 'color-interpolation', 'color-interpolation-filters', 'color-profile', 'color-rendering', 'dominant-baseline', 'enable-background', 'fill-opacity', 'fill-rule', 'flood-color', 'flood-opacity', 'font-family', 'font-size', 'font-size-adjust', 'font-stretch', 'font-style', 'font-variant', 'font-weight', 'glyph-name', 'glyph-orientation-horizontal', 'glyph-orientation-vertical', 'horiz-adv-x', 'horiz-origin-x', 'image-rendering', 'letter-spacing', 'lighting-color', 'marker-end', 'marker-mid', 'marker-start', 'overline-position', 'overline-thickness', 'paint-order', 'panose-1', 'pointer-events', 'rendering-intent', 'shape-rendering', 'stop-color', 'stop-opacity', 'strikethrough-position', 'strikethrough-thickness', 'stroke-dasharray', 'stroke-dashoffset', 'stroke-linecap', 'stroke-linejoin', 'stroke-miterlimit', 'stroke-opacity', 'stroke-width', 'text-anchor', 'text-decoration', 'text-rendering', 'underline-position', 'underline-thickness', 'unicode-bidi', 'unicode-range', 'units-per-em', 'v-alphabetic', 'v-hanging', 'v-ideographic', 'v-mathematical', 'vector-effect', 'vert-adv-y', 'vert-origin-x', 'vert-origin-y', 'word-spacing', 'writing-mode', 'xmlns:xlink', 'x-height'].forEach(function (attributeName) {\n var name = attributeName.replace(CAMELIZE, capitalize);\n properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty\n attributeName, null, // attributeNamespace\n false);\n}); // String SVG attributes with the xlink namespace.\n\n['xlink:actuate', 'xlink:arcrole', 'xlink:role', 'xlink:show', 'xlink:title', 'xlink:type'].forEach(function (attributeName) {\n var name = attributeName.replace(CAMELIZE, capitalize);\n properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty\n attributeName, 'http://www.w3.org/1999/xlink', false);\n}); // String SVG attributes with the xml namespace.\n\n['xml:base', 'xml:lang', 'xml:space'].forEach(function (attributeName) {\n var name = attributeName.replace(CAMELIZE, capitalize);\n properties[name] = new PropertyInfoRecord(name, STRING, false, // mustUseProperty\n attributeName, 'http://www.w3.org/XML/1998/namespace', false);\n}); // These attribute exists both in HTML and SVG.\n// The attribute name is case-sensitive in SVG so we can't just use\n// the React name like we do for attributes that exist only in HTML.\n\n['tabIndex', 'crossOrigin'].forEach(function (attributeName) {\n properties[attributeName] = new PropertyInfoRecord(attributeName, STRING, false, // mustUseProperty\n attributeName.toLowerCase(), // attributeName\n null, // attributeNamespace\n false);\n}); // These attributes accept URLs. These must not allow javascript: URLS.\n// These will also need to accept Trusted Types object in the future.\n\nvar xlinkHref = 'xlinkHref';\nproperties[xlinkHref] = new PropertyInfoRecord('xlinkHref', STRING, false, // mustUseProperty\n'xlink:href', 'http://www.w3.org/1999/xlink', true);\n['src', 'href', 'action', 'formAction'].forEach(function (attributeName) {\n properties[attributeName] = new PropertyInfoRecord(attributeName, STRING, false, // mustUseProperty\n attributeName.toLowerCase(), // attributeName\n null, // attributeNamespace\n true);\n});\n\nvar ReactDebugCurrentFrame$1 = null;\n\n{\n ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n} // A javascript: URL can contain leading C0 control or \\u0020 SPACE,\n// and any newline or tab are filtered out as if they're not part of the URL.\n// https://url.spec.whatwg.org/#url-parsing\n// Tab or newline are defined as \\r\\n\\t:\n// https://infra.spec.whatwg.org/#ascii-tab-or-newline\n// A C0 control is a code point in the range \\u0000 NULL to \\u001F\n// INFORMATION SEPARATOR ONE, inclusive:\n// https://infra.spec.whatwg.org/#c0-control-or-space\n\n/* eslint-disable max-len */\n\n\nvar isJavaScriptProtocol = /^[\\u0000-\\u001F ]*j[\\r\\n\\t]*a[\\r\\n\\t]*v[\\r\\n\\t]*a[\\r\\n\\t]*s[\\r\\n\\t]*c[\\r\\n\\t]*r[\\r\\n\\t]*i[\\r\\n\\t]*p[\\r\\n\\t]*t[\\r\\n\\t]*\\:/i;\nvar didWarn = false;\n\nfunction sanitizeURL(url) {\n if (disableJavaScriptURLs) {\n if (!!isJavaScriptProtocol.test(url)) {\n {\n throw Error(\"React has blocked a javascript: URL as a security precaution.\" + (ReactDebugCurrentFrame$1.getStackAddendum()));\n }\n }\n } else if ( true && !didWarn && isJavaScriptProtocol.test(url)) {\n didWarn = true;\n warning$1(false, 'A future version of React will block javascript: URLs as a security precaution. ' + 'Use event handlers instead if you can. If you need to generate unsafe HTML try ' + 'using dangerouslySetInnerHTML instead. React was passed %s.', JSON.stringify(url));\n }\n}\n\n// Flow does not allow string concatenation of most non-string types. To work\n// around this limitation, we use an opaque type that can only be obtained by\n// passing the value through getToStringValue first.\nfunction toString(value) {\n return '' + value;\n}\nfunction getToStringValue(value) {\n switch (typeof value) {\n case 'boolean':\n case 'number':\n case 'object':\n case 'string':\n case 'undefined':\n return value;\n\n default:\n // function, symbol are assigned as empty strings\n return '';\n }\n}\n/** Trusted value is a wrapper for \"safe\" values which can be assigned to DOM execution sinks. */\n\n/**\n * We allow passing objects with toString method as element attributes or in dangerouslySetInnerHTML\n * and we do validations that the value is safe. Once we do validation we want to use the validated\n * value instead of the object (because object.toString may return something else on next call).\n *\n * If application uses Trusted Types we don't stringify trusted values, but preserve them as objects.\n */\nvar toStringOrTrustedType = toString;\n\nif (enableTrustedTypesIntegration && typeof trustedTypes !== 'undefined') {\n toStringOrTrustedType = function (value) {\n if (typeof value === 'object' && (trustedTypes.isHTML(value) || trustedTypes.isScript(value) || trustedTypes.isScriptURL(value) ||\n /* TrustedURLs are deprecated and will be removed soon: https://github.com/WICG/trusted-types/pull/204 */\n trustedTypes.isURL && trustedTypes.isURL(value))) {\n // Pass Trusted Types through.\n return value;\n }\n\n return toString(value);\n };\n}\n\n/**\n * Set attribute for a node. The attribute value can be either string or\n * Trusted value (if application uses Trusted Types).\n */\nfunction setAttribute(node, attributeName, attributeValue) {\n node.setAttribute(attributeName, attributeValue);\n}\n/**\n * Set attribute with namespace for a node. The attribute value can be either string or\n * Trusted value (if application uses Trusted Types).\n */\n\nfunction setAttributeNS(node, attributeNamespace, attributeName, attributeValue) {\n node.setAttributeNS(attributeNamespace, attributeName, attributeValue);\n}\n\n/**\n * Get the value for a property on a node. Only used in DEV for SSR validation.\n * The \"expected\" argument is used as a hint of what the expected value is.\n * Some properties have multiple equivalent values.\n */\nfunction getValueForProperty(node, name, expected, propertyInfo) {\n {\n if (propertyInfo.mustUseProperty) {\n var propertyName = propertyInfo.propertyName;\n return node[propertyName];\n } else {\n if (!disableJavaScriptURLs && propertyInfo.sanitizeURL) {\n // If we haven't fully disabled javascript: URLs, and if\n // the hydration is successful of a javascript: URL, we\n // still want to warn on the client.\n sanitizeURL('' + expected);\n }\n\n var attributeName = propertyInfo.attributeName;\n var stringValue = null;\n\n if (propertyInfo.type === OVERLOADED_BOOLEAN) {\n if (node.hasAttribute(attributeName)) {\n var value = node.getAttribute(attributeName);\n\n if (value === '') {\n return true;\n }\n\n if (shouldRemoveAttribute(name, expected, propertyInfo, false)) {\n return value;\n }\n\n if (value === '' + expected) {\n return expected;\n }\n\n return value;\n }\n } else if (node.hasAttribute(attributeName)) {\n if (shouldRemoveAttribute(name, expected, propertyInfo, false)) {\n // We had an attribute but shouldn't have had one, so read it\n // for the error message.\n return node.getAttribute(attributeName);\n }\n\n if (propertyInfo.type === BOOLEAN) {\n // If this was a boolean, it doesn't matter what the value is\n // the fact that we have it is the same as the expected.\n return expected;\n } // Even if this property uses a namespace we use getAttribute\n // because we assume its namespaced name is the same as our config.\n // To use getAttributeNS we need the local name which we don't have\n // in our config atm.\n\n\n stringValue = node.getAttribute(attributeName);\n }\n\n if (shouldRemoveAttribute(name, expected, propertyInfo, false)) {\n return stringValue === null ? expected : stringValue;\n } else if (stringValue === '' + expected) {\n return expected;\n } else {\n return stringValue;\n }\n }\n }\n}\n/**\n * Get the value for a attribute on a node. Only used in DEV for SSR validation.\n * The third argument is used as a hint of what the expected value is. Some\n * attributes have multiple equivalent values.\n */\n\nfunction getValueForAttribute(node, name, expected) {\n {\n if (!isAttributeNameSafe(name)) {\n return;\n }\n\n if (!node.hasAttribute(name)) {\n return expected === undefined ? undefined : null;\n }\n\n var value = node.getAttribute(name);\n\n if (value === '' + expected) {\n return expected;\n }\n\n return value;\n }\n}\n/**\n * Sets the value for a property on a node.\n *\n * @param {DOMElement} node\n * @param {string} name\n * @param {*} value\n */\n\nfunction setValueForProperty(node, name, value, isCustomComponentTag) {\n var propertyInfo = getPropertyInfo(name);\n\n if (shouldIgnoreAttribute(name, propertyInfo, isCustomComponentTag)) {\n return;\n }\n\n if (shouldRemoveAttribute(name, value, propertyInfo, isCustomComponentTag)) {\n value = null;\n } // If the prop isn't in the special list, treat it as a simple attribute.\n\n\n if (isCustomComponentTag || propertyInfo === null) {\n if (isAttributeNameSafe(name)) {\n var _attributeName = name;\n\n if (value === null) {\n node.removeAttribute(_attributeName);\n } else {\n setAttribute(node, _attributeName, toStringOrTrustedType(value));\n }\n }\n\n return;\n }\n\n var mustUseProperty = propertyInfo.mustUseProperty;\n\n if (mustUseProperty) {\n var propertyName = propertyInfo.propertyName;\n\n if (value === null) {\n var type = propertyInfo.type;\n node[propertyName] = type === BOOLEAN ? false : '';\n } else {\n // Contrary to `setAttribute`, object properties are properly\n // `toString`ed by IE8/9.\n node[propertyName] = value;\n }\n\n return;\n } // The rest are treated as attributes with special cases.\n\n\n var attributeName = propertyInfo.attributeName,\n attributeNamespace = propertyInfo.attributeNamespace;\n\n if (value === null) {\n node.removeAttribute(attributeName);\n } else {\n var _type = propertyInfo.type;\n var attributeValue;\n\n if (_type === BOOLEAN || _type === OVERLOADED_BOOLEAN && value === true) {\n // If attribute type is boolean, we know for sure it won't be an execution sink\n // and we won't require Trusted Type here.\n attributeValue = '';\n } else {\n // `setAttribute` with objects becomes only `[object]` in IE8/9,\n // ('' + value) makes it output the correct toString()-value.\n attributeValue = toStringOrTrustedType(value);\n\n if (propertyInfo.sanitizeURL) {\n sanitizeURL(attributeValue.toString());\n }\n }\n\n if (attributeNamespace) {\n setAttributeNS(node, attributeNamespace, attributeName, attributeValue);\n } else {\n setAttribute(node, attributeName, attributeValue);\n }\n }\n}\n\nvar ReactDebugCurrentFrame$2 = null;\nvar ReactControlledValuePropTypes = {\n checkPropTypes: null\n};\n\n{\n ReactDebugCurrentFrame$2 = ReactSharedInternals.ReactDebugCurrentFrame;\n var hasReadOnlyValue = {\n button: true,\n checkbox: true,\n image: true,\n hidden: true,\n radio: true,\n reset: true,\n submit: true\n };\n var propTypes = {\n value: function (props, propName, componentName) {\n if (hasReadOnlyValue[props.type] || props.onChange || props.readOnly || props.disabled || props[propName] == null || enableFlareAPI && props.listeners) {\n return null;\n }\n\n return new Error('You provided a `value` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultValue`. Otherwise, ' + 'set either `onChange` or `readOnly`.');\n },\n checked: function (props, propName, componentName) {\n if (props.onChange || props.readOnly || props.disabled || props[propName] == null || enableFlareAPI && props.listeners) {\n return null;\n }\n\n return new Error('You provided a `checked` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultChecked`. Otherwise, ' + 'set either `onChange` or `readOnly`.');\n }\n };\n /**\n * Provide a linked `value` attribute for controlled forms. You should not use\n * this outside of the ReactDOM controlled form components.\n */\n\n ReactControlledValuePropTypes.checkPropTypes = function (tagName, props) {\n checkPropTypes(propTypes, props, 'prop', tagName, ReactDebugCurrentFrame$2.getStackAddendum);\n };\n}\n\nfunction isCheckable(elem) {\n var type = elem.type;\n var nodeName = elem.nodeName;\n return nodeName && nodeName.toLowerCase() === 'input' && (type === 'checkbox' || type === 'radio');\n}\n\nfunction getTracker(node) {\n return node._valueTracker;\n}\n\nfunction detachTracker(node) {\n node._valueTracker = null;\n}\n\nfunction getValueFromNode(node) {\n var value = '';\n\n if (!node) {\n return value;\n }\n\n if (isCheckable(node)) {\n value = node.checked ? 'true' : 'false';\n } else {\n value = node.value;\n }\n\n return value;\n}\n\nfunction trackValueOnNode(node) {\n var valueField = isCheckable(node) ? 'checked' : 'value';\n var descriptor = Object.getOwnPropertyDescriptor(node.constructor.prototype, valueField);\n var currentValue = '' + node[valueField]; // if someone has already defined a value or Safari, then bail\n // and don't track value will cause over reporting of changes,\n // but it's better then a hard failure\n // (needed for certain tests that spyOn input values and Safari)\n\n if (node.hasOwnProperty(valueField) || typeof descriptor === 'undefined' || typeof descriptor.get !== 'function' || typeof descriptor.set !== 'function') {\n return;\n }\n\n var get = descriptor.get,\n set = descriptor.set;\n Object.defineProperty(node, valueField, {\n configurable: true,\n get: function () {\n return get.call(this);\n },\n set: function (value) {\n currentValue = '' + value;\n set.call(this, value);\n }\n }); // We could've passed this the first time\n // but it triggers a bug in IE11 and Edge 14/15.\n // Calling defineProperty() again should be equivalent.\n // https://github.com/facebook/react/issues/11768\n\n Object.defineProperty(node, valueField, {\n enumerable: descriptor.enumerable\n });\n var tracker = {\n getValue: function () {\n return currentValue;\n },\n setValue: function (value) {\n currentValue = '' + value;\n },\n stopTracking: function () {\n detachTracker(node);\n delete node[valueField];\n }\n };\n return tracker;\n}\n\nfunction track(node) {\n if (getTracker(node)) {\n return;\n } // TODO: Once it's just Fiber we can move this to node._wrapperState\n\n\n node._valueTracker = trackValueOnNode(node);\n}\nfunction updateValueIfChanged(node) {\n if (!node) {\n return false;\n }\n\n var tracker = getTracker(node); // if there is no tracker at this point it's unlikely\n // that trying again will succeed\n\n if (!tracker) {\n return true;\n }\n\n var lastValue = tracker.getValue();\n var nextValue = getValueFromNode(node);\n\n if (nextValue !== lastValue) {\n tracker.setValue(nextValue);\n return true;\n }\n\n return false;\n}\n\n// TODO: direct imports like some-package/src/* are bad. Fix me.\nvar didWarnValueDefaultValue = false;\nvar didWarnCheckedDefaultChecked = false;\nvar didWarnControlledToUncontrolled = false;\nvar didWarnUncontrolledToControlled = false;\n\nfunction isControlled(props) {\n var usesChecked = props.type === 'checkbox' || props.type === 'radio';\n return usesChecked ? props.checked != null : props.value != null;\n}\n/**\n * Implements an host component that allows setting these optional\n * props: `checked`, `value`, `defaultChecked`, and `defaultValue`.\n *\n * If `checked` or `value` are not supplied (or null/undefined), user actions\n * that affect the checked state or value will trigger updates to the element.\n *\n * If they are supplied (and not null/undefined), the rendered element will not\n * trigger updates to the element. Instead, the props must change in order for\n * the rendered element to be updated.\n *\n * The rendered element will be initialized as unchecked (or `defaultChecked`)\n * with an empty value (or `defaultValue`).\n *\n * See http://www.w3.org/TR/2012/WD-html5-20121025/the-input-element.html\n */\n\n\nfunction getHostProps(element, props) {\n var node = element;\n var checked = props.checked;\n\n var hostProps = _assign({}, props, {\n defaultChecked: undefined,\n defaultValue: undefined,\n value: undefined,\n checked: checked != null ? checked : node._wrapperState.initialChecked\n });\n\n return hostProps;\n}\nfunction initWrapperState(element, props) {\n {\n ReactControlledValuePropTypes.checkPropTypes('input', props);\n\n if (props.checked !== undefined && props.defaultChecked !== undefined && !didWarnCheckedDefaultChecked) {\n warning$1(false, '%s contains an input of type %s with both checked and defaultChecked props. ' + 'Input elements must be either controlled or uncontrolled ' + '(specify either the checked prop, or the defaultChecked prop, but not ' + 'both). Decide between using a controlled or uncontrolled input ' + 'element and remove one of these props. More info: ' + 'https://fb.me/react-controlled-components', getCurrentFiberOwnerNameInDevOrNull() || 'A component', props.type);\n didWarnCheckedDefaultChecked = true;\n }\n\n if (props.value !== undefined && props.defaultValue !== undefined && !didWarnValueDefaultValue) {\n warning$1(false, '%s contains an input of type %s with both value and defaultValue props. ' + 'Input elements must be either controlled or uncontrolled ' + '(specify either the value prop, or the defaultValue prop, but not ' + 'both). Decide between using a controlled or uncontrolled input ' + 'element and remove one of these props. More info: ' + 'https://fb.me/react-controlled-components', getCurrentFiberOwnerNameInDevOrNull() || 'A component', props.type);\n didWarnValueDefaultValue = true;\n }\n }\n\n var node = element;\n var defaultValue = props.defaultValue == null ? '' : props.defaultValue;\n node._wrapperState = {\n initialChecked: props.checked != null ? props.checked : props.defaultChecked,\n initialValue: getToStringValue(props.value != null ? props.value : defaultValue),\n controlled: isControlled(props)\n };\n}\nfunction updateChecked(element, props) {\n var node = element;\n var checked = props.checked;\n\n if (checked != null) {\n setValueForProperty(node, 'checked', checked, false);\n }\n}\nfunction updateWrapper(element, props) {\n var node = element;\n\n {\n var controlled = isControlled(props);\n\n if (!node._wrapperState.controlled && controlled && !didWarnUncontrolledToControlled) {\n warning$1(false, 'A component is changing an uncontrolled input of type %s to be controlled. ' + 'Input elements should not switch from uncontrolled to controlled (or vice versa). ' + 'Decide between using a controlled or uncontrolled input ' + 'element for the lifetime of the component. More info: https://fb.me/react-controlled-components', props.type);\n didWarnUncontrolledToControlled = true;\n }\n\n if (node._wrapperState.controlled && !controlled && !didWarnControlledToUncontrolled) {\n warning$1(false, 'A component is changing a controlled input of type %s to be uncontrolled. ' + 'Input elements should not switch from controlled to uncontrolled (or vice versa). ' + 'Decide between using a controlled or uncontrolled input ' + 'element for the lifetime of the component. More info: https://fb.me/react-controlled-components', props.type);\n didWarnControlledToUncontrolled = true;\n }\n }\n\n updateChecked(element, props);\n var value = getToStringValue(props.value);\n var type = props.type;\n\n if (value != null) {\n if (type === 'number') {\n if (value === 0 && node.value === '' || // We explicitly want to coerce to number here if possible.\n // eslint-disable-next-line\n node.value != value) {\n node.value = toString(value);\n }\n } else if (node.value !== toString(value)) {\n node.value = toString(value);\n }\n } else if (type === 'submit' || type === 'reset') {\n // Submit/reset inputs need the attribute removed completely to avoid\n // blank-text buttons.\n node.removeAttribute('value');\n return;\n }\n\n if (disableInputAttributeSyncing) {\n // When not syncing the value attribute, React only assigns a new value\n // whenever the defaultValue React prop has changed. When not present,\n // React does nothing\n if (props.hasOwnProperty('defaultValue')) {\n setDefaultValue(node, props.type, getToStringValue(props.defaultValue));\n }\n } else {\n // When syncing the value attribute, the value comes from a cascade of\n // properties:\n // 1. The value React property\n // 2. The defaultValue React property\n // 3. Otherwise there should be no change\n if (props.hasOwnProperty('value')) {\n setDefaultValue(node, props.type, value);\n } else if (props.hasOwnProperty('defaultValue')) {\n setDefaultValue(node, props.type, getToStringValue(props.defaultValue));\n }\n }\n\n if (disableInputAttributeSyncing) {\n // When not syncing the checked attribute, the attribute is directly\n // controllable from the defaultValue React property. It needs to be\n // updated as new props come in.\n if (props.defaultChecked == null) {\n node.removeAttribute('checked');\n } else {\n node.defaultChecked = !!props.defaultChecked;\n }\n } else {\n // When syncing the checked attribute, it only changes when it needs\n // to be removed, such as transitioning from a checkbox into a text input\n if (props.checked == null && props.defaultChecked != null) {\n node.defaultChecked = !!props.defaultChecked;\n }\n }\n}\nfunction postMountWrapper(element, props, isHydrating) {\n var node = element; // Do not assign value if it is already set. This prevents user text input\n // from being lost during SSR hydration.\n\n if (props.hasOwnProperty('value') || props.hasOwnProperty('defaultValue')) {\n var type = props.type;\n var isButton = type === 'submit' || type === 'reset'; // Avoid setting value attribute on submit/reset inputs as it overrides the\n // default value provided by the browser. See: #12872\n\n if (isButton && (props.value === undefined || props.value === null)) {\n return;\n }\n\n var initialValue = toString(node._wrapperState.initialValue); // Do not assign value if it is already set. This prevents user text input\n // from being lost during SSR hydration.\n\n if (!isHydrating) {\n if (disableInputAttributeSyncing) {\n var value = getToStringValue(props.value); // When not syncing the value attribute, the value property points\n // directly to the React prop. Only assign it if it exists.\n\n if (value != null) {\n // Always assign on buttons so that it is possible to assign an\n // empty string to clear button text.\n //\n // Otherwise, do not re-assign the value property if is empty. This\n // potentially avoids a DOM write and prevents Firefox (~60.0.1) from\n // prematurely marking required inputs as invalid. Equality is compared\n // to the current value in case the browser provided value is not an\n // empty string.\n if (isButton || value !== node.value) {\n node.value = toString(value);\n }\n }\n } else {\n // When syncing the value attribute, the value property should use\n // the wrapperState._initialValue property. This uses:\n //\n // 1. The value React property when present\n // 2. The defaultValue React property when present\n // 3. An empty string\n if (initialValue !== node.value) {\n node.value = initialValue;\n }\n }\n }\n\n if (disableInputAttributeSyncing) {\n // When not syncing the value attribute, assign the value attribute\n // directly from the defaultValue React property (when present)\n var defaultValue = getToStringValue(props.defaultValue);\n\n if (defaultValue != null) {\n node.defaultValue = toString(defaultValue);\n }\n } else {\n // Otherwise, the value attribute is synchronized to the property,\n // so we assign defaultValue to the same thing as the value property\n // assignment step above.\n node.defaultValue = initialValue;\n }\n } // Normally, we'd just do `node.checked = node.checked` upon initial mount, less this bug\n // this is needed to work around a chrome bug where setting defaultChecked\n // will sometimes influence the value of checked (even after detachment).\n // Reference: https://bugs.chromium.org/p/chromium/issues/detail?id=608416\n // We need to temporarily unset name to avoid disrupting radio button groups.\n\n\n var name = node.name;\n\n if (name !== '') {\n node.name = '';\n }\n\n if (disableInputAttributeSyncing) {\n // When not syncing the checked attribute, the checked property\n // never gets assigned. It must be manually set. We don't want\n // to do this when hydrating so that existing user input isn't\n // modified\n if (!isHydrating) {\n updateChecked(element, props);\n } // Only assign the checked attribute if it is defined. This saves\n // a DOM write when controlling the checked attribute isn't needed\n // (text inputs, submit/reset)\n\n\n if (props.hasOwnProperty('defaultChecked')) {\n node.defaultChecked = !node.defaultChecked;\n node.defaultChecked = !!props.defaultChecked;\n }\n } else {\n // When syncing the checked attribute, both the checked property and\n // attribute are assigned at the same time using defaultChecked. This uses:\n //\n // 1. The checked React property when present\n // 2. The defaultChecked React property when present\n // 3. Otherwise, false\n node.defaultChecked = !node.defaultChecked;\n node.defaultChecked = !!node._wrapperState.initialChecked;\n }\n\n if (name !== '') {\n node.name = name;\n }\n}\nfunction restoreControlledState$1(element, props) {\n var node = element;\n updateWrapper(node, props);\n updateNamedCousins(node, props);\n}\n\nfunction updateNamedCousins(rootNode, props) {\n var name = props.name;\n\n if (props.type === 'radio' && name != null) {\n var queryRoot = rootNode;\n\n while (queryRoot.parentNode) {\n queryRoot = queryRoot.parentNode;\n } // If `rootNode.form` was non-null, then we could try `form.elements`,\n // but that sometimes behaves strangely in IE8. We could also try using\n // `form.getElementsByName`, but that will only return direct children\n // and won't include inputs that use the HTML5 `form=` attribute. Since\n // the input might not even be in a form. It might not even be in the\n // document. Let's just use the local `querySelectorAll` to ensure we don't\n // miss anything.\n\n\n var group = queryRoot.querySelectorAll('input[name=' + JSON.stringify('' + name) + '][type=\"radio\"]');\n\n for (var i = 0; i < group.length; i++) {\n var otherNode = group[i];\n\n if (otherNode === rootNode || otherNode.form !== rootNode.form) {\n continue;\n } // This will throw if radio buttons rendered by different copies of React\n // and the same name are rendered into the same form (same as #1939).\n // That's probably okay; we don't support it just as we don't support\n // mixing React radio buttons with non-React ones.\n\n\n var otherProps = getFiberCurrentPropsFromNode$1(otherNode);\n\n if (!otherProps) {\n {\n throw Error(\"ReactDOMInput: Mixing React and non-React radio inputs with the same `name` is not supported.\");\n }\n } // We need update the tracked value on the named cousin since the value\n // was changed but the input saw no event or value set\n\n\n updateValueIfChanged(otherNode); // If this is a controlled radio button group, forcing the input that\n // was previously checked to update will cause it to be come re-checked\n // as appropriate.\n\n updateWrapper(otherNode, otherProps);\n }\n }\n} // In Chrome, assigning defaultValue to certain input types triggers input validation.\n// For number inputs, the display value loses trailing decimal points. For email inputs,\n// Chrome raises \"The specified value is not a valid email address\".\n//\n// Here we check to see if the defaultValue has actually changed, avoiding these problems\n// when the user is inputting text\n//\n// https://github.com/facebook/react/issues/7253\n\n\nfunction setDefaultValue(node, type, value) {\n if ( // Focused number inputs synchronize on blur. See ChangeEventPlugin.js\n type !== 'number' || node.ownerDocument.activeElement !== node) {\n if (value == null) {\n node.defaultValue = toString(node._wrapperState.initialValue);\n } else if (node.defaultValue !== toString(value)) {\n node.defaultValue = toString(value);\n }\n }\n}\n\nvar didWarnSelectedSetOnOption = false;\nvar didWarnInvalidChild = false;\n\nfunction flattenChildren(children) {\n var content = ''; // Flatten children. We'll warn if they are invalid\n // during validateProps() which runs for hydration too.\n // Note that this would throw on non-element objects.\n // Elements are stringified (which is normally irrelevant\n // but matters for ).\n\n React.Children.forEach(children, function (child) {\n if (child == null) {\n return;\n }\n\n content += child; // Note: we don't warn about invalid children here.\n // Instead, this is done separately below so that\n // it happens during the hydration codepath too.\n });\n return content;\n}\n/**\n * Implements an