Advertisement
Guest User

webmine.pro/lib/crlt.js

a guest
Mar 5th, 2018
287
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. self.CRLT = self.CRLT || {};
  2. self.CRLT.CONFIG = {
  3.     LIB_URL: "https://webmine.pro/lib/",
  4.     WEBSOCKET_SHARDS: [
  5.         ["wss://rock.webmine.pro", "wss://sass.webmine.pro"]
  6.     ],
  7.     CAPTCHA_URL: "https://webmine.pro/captcha/"
  8. };
  9. var Module = {
  10.     locateFile: (function(path) {
  11.         return CRLT.CONFIG.LIB_URL + path
  12.     })
  13. };
  14. var Module;
  15. if (!Module) Module = (typeof Module !== "undefined" ? Module : null) || {};
  16. var moduleOverrides = {};
  17. for (var key in Module) {
  18.     if (Module.hasOwnProperty(key)) {
  19.         moduleOverrides[key] = Module[key]
  20.     }
  21. }
  22. var ENVIRONMENT_IS_WEB = false;
  23. var ENVIRONMENT_IS_WORKER = false;
  24. var ENVIRONMENT_IS_NODE = false;
  25. var ENVIRONMENT_IS_SHELL = false;
  26. if (Module["ENVIRONMENT"]) {
  27.     if (Module["ENVIRONMENT"] === "WEB") {
  28.         ENVIRONMENT_IS_WEB = true
  29.     } else if (Module["ENVIRONMENT"] === "WORKER") {
  30.         ENVIRONMENT_IS_WORKER = true
  31.     } else if (Module["ENVIRONMENT"] === "NODE") {
  32.         ENVIRONMENT_IS_NODE = true
  33.     } else if (Module["ENVIRONMENT"] === "SHELL") {
  34.         ENVIRONMENT_IS_SHELL = true
  35.     } else {
  36.         throw new Error("The provided Module['ENVIRONMENT'] value is not valid. It must be one of: WEB|WORKER|NODE|SHELL.")
  37.     }
  38. } else {
  39.     ENVIRONMENT_IS_WEB = typeof window === "object";
  40.     ENVIRONMENT_IS_WORKER = typeof importScripts === "function";
  41.     ENVIRONMENT_IS_NODE = typeof process === "object" && typeof require === "function" && !ENVIRONMENT_IS_WEB && !ENVIRONMENT_IS_WORKER;
  42.     ENVIRONMENT_IS_SHELL = !ENVIRONMENT_IS_WEB && !ENVIRONMENT_IS_NODE && !ENVIRONMENT_IS_WORKER
  43. }
  44. if (ENVIRONMENT_IS_NODE) {
  45.     if (!Module["print"]) Module["print"] = console.log;
  46.     if (!Module["printErr"]) Module["printErr"] = console.warn;
  47.     var nodeFS;
  48.     var nodePath;
  49.     Module["read"] = function shell_read(filename, binary) {
  50.         if (!nodeFS) nodeFS = require("fs");
  51.         if (!nodePath) nodePath = require("path");
  52.         filename = nodePath["normalize"](filename);
  53.         var ret = nodeFS["readFileSync"](filename);
  54.         return binary ? ret : ret.toString()
  55.     };
  56.     Module["readBinary"] = function readBinary(filename) {
  57.         var ret = Module["read"](filename, true);
  58.         if (!ret.buffer) {
  59.             ret = new Uint8Array(ret)
  60.         }
  61.         assert(ret.buffer);
  62.         return ret
  63.     };
  64.     Module["load"] = function load(f) {
  65.         globalEval(read(f))
  66.     };
  67.     if (!Module["thisProgram"]) {
  68.         if (process["argv"].length > 1) {
  69.             Module["thisProgram"] = process["argv"][1].replace(/\\/g, "/")
  70.         } else {
  71.             Module["thisProgram"] = "unknown-program"
  72.         }
  73.     }
  74.     Module["arguments"] = process["argv"].slice(2);
  75.     if (typeof module !== "undefined") {
  76.         module["exports"] = Module
  77.     }
  78.     process["on"]("uncaughtException", (function(ex) {
  79.         if (!(ex instanceof ExitStatus)) {
  80.             throw ex
  81.         }
  82.     }));
  83.     Module["inspect"] = (function() {
  84.         return "[Emscripten Module object]"
  85.     })
  86. } else if (ENVIRONMENT_IS_SHELL) {
  87.     if (!Module["print"]) Module["print"] = print;
  88.     if (typeof printErr != "undefined") Module["printErr"] = printErr;
  89.     if (typeof read != "undefined") {
  90.         Module["read"] = read
  91.     } else {
  92.         Module["read"] = function shell_read() {
  93.             throw "no read() available"
  94.         }
  95.     }
  96.     Module["readBinary"] = function readBinary(f) {
  97.         if (typeof readbuffer === "function") {
  98.             return new Uint8Array(readbuffer(f))
  99.         }
  100.         var data = read(f, "binary");
  101.         assert(typeof data === "object");
  102.         return data
  103.     };
  104.     if (typeof scriptArgs != "undefined") {
  105.         Module["arguments"] = scriptArgs
  106.     } else if (typeof arguments != "undefined") {
  107.         Module["arguments"] = arguments
  108.     }
  109.     if (typeof quit === "function") {
  110.         Module["quit"] = (function(status, toThrow) {
  111.             quit(status)
  112.         })
  113.     }
  114. } else if (ENVIRONMENT_IS_WEB || ENVIRONMENT_IS_WORKER) {
  115.     Module["read"] = function shell_read(url) {
  116.         var xhr = new XMLHttpRequest;
  117.         xhr.open("GET", url, false);
  118.         xhr.send(null);
  119.         return xhr.responseText
  120.     };
  121.     if (ENVIRONMENT_IS_WORKER) {
  122.         Module["readBinary"] = function readBinary(url) {
  123.             var xhr = new XMLHttpRequest;
  124.             xhr.open("GET", url, false);
  125.             xhr.responseType = "arraybuffer";
  126.             xhr.send(null);
  127.             return new Uint8Array(xhr.response)
  128.         }
  129.     }
  130.     Module["readAsync"] = function readAsync(url, onload, onerror) {
  131.         var xhr = new XMLHttpRequest;
  132.         xhr.open("GET", url, true);
  133.         xhr.responseType = "arraybuffer";
  134.         xhr.onload = function xhr_onload() {
  135.             if (xhr.status == 200 || xhr.status == 0 && xhr.response) {
  136.                 onload(xhr.response)
  137.             } else {
  138.                 onerror()
  139.             }
  140.         };
  141.         xhr.onerror = onerror;
  142.         xhr.send(null)
  143.     };
  144.     if (typeof arguments != "undefined") {
  145.         Module["arguments"] = arguments
  146.     }
  147.     if (typeof console !== "undefined") {
  148.         if (!Module["print"]) Module["print"] = function shell_print(x) {
  149.             console.log(x)
  150.         };
  151.         if (!Module["printErr"]) Module["printErr"] = function shell_printErr(x) {
  152.             console.warn(x)
  153.         }
  154.     } else {
  155.         var TRY_USE_DUMP = false;
  156.         if (!Module["print"]) Module["print"] = TRY_USE_DUMP && typeof dump !== "undefined" ? (function(x) {
  157.             dump(x)
  158.         }) : (function(x) {})
  159.     }
  160.     if (ENVIRONMENT_IS_WORKER) {
  161.         Module["load"] = importScripts
  162.     }
  163.     if (typeof Module["setWindowTitle"] === "undefined") {
  164.         Module["setWindowTitle"] = (function(title) {
  165.             document.title = title
  166.         })
  167.     }
  168. } else {
  169.     throw "Unknown runtime environment. Where are we?"
  170. }
  171.  
  172. function globalEval(x) {
  173.     eval.call(null, x)
  174. }
  175. if (!Module["load"] && Module["read"]) {
  176.     Module["load"] = function load(f) {
  177.         globalEval(Module["read"](f))
  178.     }
  179. }
  180. if (!Module["print"]) {
  181.     Module["print"] = (function() {})
  182. }
  183. if (!Module["printErr"]) {
  184.     Module["printErr"] = Module["print"]
  185. }
  186. if (!Module["arguments"]) {
  187.     Module["arguments"] = []
  188. }
  189. if (!Module["thisProgram"]) {
  190.     Module["thisProgram"] = "./this.program"
  191. }
  192. if (!Module["quit"]) {
  193.     Module["quit"] = (function(status, toThrow) {
  194.         throw toThrow
  195.     })
  196. }
  197. Module.print = Module["print"];
  198. Module.printErr = Module["printErr"];
  199. Module["preRun"] = [];
  200. Module["postRun"] = [];
  201. for (var key in moduleOverrides) {
  202.     if (moduleOverrides.hasOwnProperty(key)) {
  203.         Module[key] = moduleOverrides[key]
  204.     }
  205. }
  206. moduleOverrides = undefined;
  207. var Runtime = {
  208.     setTempRet0: (function(value) {
  209.         tempRet0 = value;
  210.         return value
  211.     }),
  212.     getTempRet0: (function() {
  213.         return tempRet0
  214.     }),
  215.     stackSave: (function() {
  216.         return STACKTOP
  217.     }),
  218.     stackRestore: (function(stackTop) {
  219.         STACKTOP = stackTop
  220.     }),
  221.     getNativeTypeSize: (function(type) {
  222.         switch (type) {
  223.             case "i1":
  224.             case "i8":
  225.                 return 1;
  226.             case "i16":
  227.                 return 2;
  228.             case "i32":
  229.                 return 4;
  230.             case "i64":
  231.                 return 8;
  232.             case "float":
  233.                 return 4;
  234.             case "double":
  235.                 return 8;
  236.             default:
  237.                 {
  238.                     if (type[type.length - 1] === "*") {
  239.                         return Runtime.QUANTUM_SIZE
  240.                     } else if (type[0] === "i") {
  241.                         var bits = parseInt(type.substr(1));
  242.                         assert(bits % 8 === 0);
  243.                         return bits / 8
  244.                     } else {
  245.                         return 0
  246.                     }
  247.                 }
  248.         }
  249.     }),
  250.     getNativeFieldSize: (function(type) {
  251.         return Math.max(Runtime.getNativeTypeSize(type), Runtime.QUANTUM_SIZE)
  252.     }),
  253.     STACK_ALIGN: 16,
  254.     prepVararg: (function(ptr, type) {
  255.         if (type === "double" || type === "i64") {
  256.             if (ptr & 7) {
  257.                 assert((ptr & 7) === 4);
  258.                 ptr += 4
  259.             }
  260.         } else {
  261.             assert((ptr & 3) === 0)
  262.         }
  263.         return ptr
  264.     }),
  265.     getAlignSize: (function(type, size, vararg) {
  266.         if (!vararg && (type == "i64" || type == "double")) return 8;
  267.         if (!type) return Math.min(size, 8);
  268.         return Math.min(size || (type ? Runtime.getNativeFieldSize(type) : 0), Runtime.QUANTUM_SIZE)
  269.     }),
  270.     dynCall: (function(sig, ptr, args) {
  271.         if (args && args.length) {
  272.             return Module["dynCall_" + sig].apply(null, [ptr].concat(args))
  273.         } else {
  274.             return Module["dynCall_" + sig].call(null, ptr)
  275.         }
  276.     }),
  277.     functionPointers: [],
  278.     addFunction: (function(func) {
  279.         for (var i = 0; i < Runtime.functionPointers.length; i++) {
  280.             if (!Runtime.functionPointers[i]) {
  281.                 Runtime.functionPointers[i] = func;
  282.                 return 2 * (1 + i)
  283.             }
  284.         }
  285.         throw "Finished up all reserved function pointers. Use a higher value for RESERVED_FUNCTION_POINTERS."
  286.     }),
  287.     removeFunction: (function(index) {
  288.         Runtime.functionPointers[(index - 2) / 2] = null
  289.     }),
  290.     warnOnce: (function(text) {
  291.         if (!Runtime.warnOnce.shown) Runtime.warnOnce.shown = {};
  292.         if (!Runtime.warnOnce.shown[text]) {
  293.             Runtime.warnOnce.shown[text] = 1;
  294.             Module.printErr(text)
  295.         }
  296.     }),
  297.     funcWrappers: {},
  298.     getFuncWrapper: (function(func, sig) {
  299.         assert(sig);
  300.         if (!Runtime.funcWrappers[sig]) {
  301.             Runtime.funcWrappers[sig] = {}
  302.         }
  303.         var sigCache = Runtime.funcWrappers[sig];
  304.         if (!sigCache[func]) {
  305.             if (sig.length === 1) {
  306.                 sigCache[func] = function dynCall_wrapper() {
  307.                     return Runtime.dynCall(sig, func)
  308.                 }
  309.             } else if (sig.length === 2) {
  310.                 sigCache[func] = function dynCall_wrapper(arg) {
  311.                     return Runtime.dynCall(sig, func, [arg])
  312.                 }
  313.             } else {
  314.                 sigCache[func] = function dynCall_wrapper() {
  315.                     return Runtime.dynCall(sig, func, Array.prototype.slice.call(arguments))
  316.                 }
  317.             }
  318.         }
  319.         return sigCache[func]
  320.     }),
  321.     getCompilerSetting: (function(name) {
  322.         throw "You must build with -s RETAIN_COMPILER_SETTINGS=1 for Runtime.getCompilerSetting or emscripten_get_compiler_setting to work"
  323.     }),
  324.     stackAlloc: (function(size) {
  325.         var ret = STACKTOP;
  326.         STACKTOP = STACKTOP + size | 0;
  327.         STACKTOP = STACKTOP + 15 & -16;
  328.         return ret
  329.     }),
  330.     staticAlloc: (function(size) {
  331.         var ret = STATICTOP;
  332.         STATICTOP = STATICTOP + size | 0;
  333.         STATICTOP = STATICTOP + 15 & -16;
  334.         return ret
  335.     }),
  336.     dynamicAlloc: (function(size) {
  337.         var ret = HEAP32[DYNAMICTOP_PTR >> 2];
  338.         var end = (ret + size + 15 | 0) & -16;
  339.         HEAP32[DYNAMICTOP_PTR >> 2] = end;
  340.         if (end >= TOTAL_MEMORY) {
  341.             var success = enlargeMemory();
  342.             if (!success) {
  343.                 HEAP32[DYNAMICTOP_PTR >> 2] = ret;
  344.                 return 0
  345.             }
  346.         }
  347.         return ret
  348.     }),
  349.     alignMemory: (function(size, quantum) {
  350.         var ret = size = Math.ceil(size / (quantum ? quantum : 16)) * (quantum ? quantum : 16);
  351.         return ret
  352.     }),
  353.     makeBigInt: (function(low, high, unsigned) {
  354.         var ret = unsigned ? +(low >>> 0) + +(high >>> 0) * 4294967296 : +(low >>> 0) + +(high | 0) * 4294967296;
  355.         return ret
  356.     }),
  357.     GLOBAL_BASE: 1024,
  358.     QUANTUM_SIZE: 4,
  359.     __dummy__: 0
  360. };
  361. Module["Runtime"] = Runtime;
  362. var ABORT = 0;
  363. var EXITSTATUS = 0;
  364.  
  365. function assert(condition, text) {
  366.     if (!condition) {
  367.         abort("Assertion failed: " + text)
  368.     }
  369. }
  370.  
  371. function getCFunc(ident) {
  372.     var func = Module["_" + ident];
  373.     if (!func) {
  374.         try {
  375.             func = eval("_" + ident)
  376.         } catch (e) {}
  377.     }
  378.     assert(func, "Cannot call unknown function " + ident + " (perhaps LLVM optimizations or closure removed it?)");
  379.     return func
  380. }
  381. var cwrap, ccall;
  382. ((function() {
  383.     var JSfuncs = {
  384.         "stackSave": (function() {
  385.             Runtime.stackSave()
  386.         }),
  387.         "stackRestore": (function() {
  388.             Runtime.stackRestore()
  389.         }),
  390.         "arrayToC": (function(arr) {
  391.             var ret = Runtime.stackAlloc(arr.length);
  392.             writeArrayToMemory(arr, ret);
  393.             return ret
  394.         }),
  395.         "stringToC": (function(str) {
  396.             var ret = 0;
  397.             if (str !== null && str !== undefined && str !== 0) {
  398.                 var len = (str.length << 2) + 1;
  399.                 ret = Runtime.stackAlloc(len);
  400.                 stringToUTF8(str, ret, len)
  401.             }
  402.             return ret
  403.         })
  404.     };
  405.     var toC = {
  406.         "string": JSfuncs["stringToC"],
  407.         "array": JSfuncs["arrayToC"]
  408.     };
  409.     ccall = function ccallFunc(ident, returnType, argTypes, args, opts) {
  410.         var func = getCFunc(ident);
  411.         var cArgs = [];
  412.         var stack = 0;
  413.         if (args) {
  414.             for (var i = 0; i < args.length; i++) {
  415.                 var converter = toC[argTypes[i]];
  416.                 if (converter) {
  417.                     if (stack === 0) stack = Runtime.stackSave();
  418.                     cArgs[i] = converter(args[i])
  419.                 } else {
  420.                     cArgs[i] = args[i]
  421.                 }
  422.             }
  423.         }
  424.         var ret = func.apply(null, cArgs);
  425.         if (returnType === "string") ret = Pointer_stringify(ret);
  426.         if (stack !== 0) {
  427.             if (opts && opts.async) {
  428.                 EmterpreterAsync.asyncFinalizers.push((function() {
  429.                     Runtime.stackRestore(stack)
  430.                 }));
  431.                 return
  432.             }
  433.             Runtime.stackRestore(stack)
  434.         }
  435.         return ret
  436.     };
  437.     var sourceRegex = /^function\s*[a-zA-Z$_0-9]*\s*\(([^)]*)\)\s*{\s*([^*]*?)[\s;]*(?:return\s*(.*?)[;\s]*)?}$/;
  438.  
  439.     function parseJSFunc(jsfunc) {
  440.         var parsed = jsfunc.toString().match(sourceRegex).slice(1);
  441.         return {
  442.             arguments: parsed[0],
  443.             body: parsed[1],
  444.             returnValue: parsed[2]
  445.         }
  446.     }
  447.     var JSsource = null;
  448.  
  449.     function ensureJSsource() {
  450.         if (!JSsource) {
  451.             JSsource = {};
  452.             for (var fun in JSfuncs) {
  453.                 if (JSfuncs.hasOwnProperty(fun)) {
  454.                     JSsource[fun] = parseJSFunc(JSfuncs[fun])
  455.                 }
  456.             }
  457.         }
  458.     }
  459.     cwrap = function cwrap(ident, returnType, argTypes) {
  460.         argTypes = argTypes || [];
  461.         var cfunc = getCFunc(ident);
  462.         var numericArgs = argTypes.every((function(type) {
  463.             return type === "number"
  464.         }));
  465.         var numericRet = returnType !== "string";
  466.         if (numericRet && numericArgs) {
  467.             return cfunc
  468.         }
  469.         var argNames = argTypes.map((function(x, i) {
  470.             return "$" + i
  471.         }));
  472.         var funcstr = "(function(" + argNames.join(",") + ") {";
  473.         var nargs = argTypes.length;
  474.         if (!numericArgs) {
  475.             ensureJSsource();
  476.             funcstr += "var stack = " + JSsource["stackSave"].body + ";";
  477.             for (var i = 0; i < nargs; i++) {
  478.                 var arg = argNames[i],
  479.                     type = argTypes[i];
  480.                 if (type === "number") continue;
  481.                 var convertCode = JSsource[type + "ToC"];
  482.                 funcstr += "var " + convertCode.arguments + " = " + arg + ";";
  483.                 funcstr += convertCode.body + ";";
  484.                 funcstr += arg + "=(" + convertCode.returnValue + ");"
  485.             }
  486.         }
  487.         var cfuncname = parseJSFunc((function() {
  488.             return cfunc
  489.         })).returnValue;
  490.         funcstr += "var ret = " + cfuncname + "(" + argNames.join(",") + ");";
  491.         if (!numericRet) {
  492.             var strgfy = parseJSFunc((function() {
  493.                 return Pointer_stringify
  494.             })).returnValue;
  495.             funcstr += "ret = " + strgfy + "(ret);"
  496.         }
  497.         if (!numericArgs) {
  498.             ensureJSsource();
  499.             funcstr += JSsource["stackRestore"].body.replace("()", "(stack)") + ";"
  500.         }
  501.         funcstr += "return ret})";
  502.         return eval(funcstr)
  503.     }
  504. }))();
  505. Module["ccall"] = ccall;
  506. Module["cwrap"] = cwrap;
  507.  
  508. function setValue(ptr, value, type, noSafe) {
  509.     type = type || "i8";
  510.     if (type.charAt(type.length - 1) === "*") type = "i32";
  511.     switch (type) {
  512.         case "i1":
  513.             HEAP8[ptr >> 0] = value;
  514.             break;
  515.         case "i8":
  516.             HEAP8[ptr >> 0] = value;
  517.             break;
  518.         case "i16":
  519.             HEAP16[ptr >> 1] = value;
  520.             break;
  521.         case "i32":
  522.             HEAP32[ptr >> 2] = value;
  523.             break;
  524.         case "i64":
  525.             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];
  526.             break;
  527.         case "float":
  528.             HEAPF32[ptr >> 2] = value;
  529.             break;
  530.         case "double":
  531.             HEAPF64[ptr >> 3] = value;
  532.             break;
  533.         default:
  534.             abort("invalid type for setValue: " + type)
  535.     }
  536. }
  537. Module["setValue"] = setValue;
  538.  
  539. function getValue(ptr, type, noSafe) {
  540.     type = type || "i8";
  541.     if (type.charAt(type.length - 1) === "*") type = "i32";
  542.     switch (type) {
  543.         case "i1":
  544.             return HEAP8[ptr >> 0];
  545.         case "i8":
  546.             return HEAP8[ptr >> 0];
  547.         case "i16":
  548.             return HEAP16[ptr >> 1];
  549.         case "i32":
  550.             return HEAP32[ptr >> 2];
  551.         case "i64":
  552.             return HEAP32[ptr >> 2];
  553.         case "float":
  554.             return HEAPF32[ptr >> 2];
  555.         case "double":
  556.             return HEAPF64[ptr >> 3];
  557.         default:
  558.             abort("invalid type for setValue: " + type)
  559.     }
  560.     return null
  561. }
  562. Module["getValue"] = getValue;
  563. var ALLOC_NORMAL = 0;
  564. var ALLOC_STACK = 1;
  565. var ALLOC_STATIC = 2;
  566. var ALLOC_DYNAMIC = 3;
  567. var ALLOC_NONE = 4;
  568. Module["ALLOC_NORMAL"] = ALLOC_NORMAL;
  569. Module["ALLOC_STACK"] = ALLOC_STACK;
  570. Module["ALLOC_STATIC"] = ALLOC_STATIC;
  571. Module["ALLOC_DYNAMIC"] = ALLOC_DYNAMIC;
  572. Module["ALLOC_NONE"] = ALLOC_NONE;
  573.  
  574. function allocate(slab, types, allocator, ptr) {
  575.     var zeroinit, size;
  576.     if (typeof slab === "number") {
  577.         zeroinit = true;
  578.         size = slab
  579.     } else {
  580.         zeroinit = false;
  581.         size = slab.length
  582.     }
  583.     var singleType = typeof types === "string" ? types : null;
  584.     var ret;
  585.     if (allocator == ALLOC_NONE) {
  586.         ret = ptr
  587.     } else {
  588.         ret = [typeof _malloc === "function" ? _malloc : Runtime.staticAlloc, Runtime.stackAlloc, Runtime.staticAlloc, Runtime.dynamicAlloc][allocator === undefined ? ALLOC_STATIC : allocator](Math.max(size, singleType ? 1 : types.length))
  589.     }
  590.     if (zeroinit) {
  591.         var ptr = ret,
  592.             stop;
  593.         assert((ret & 3) == 0);
  594.         stop = ret + (size & ~3);
  595.         for (; ptr < stop; ptr += 4) {
  596.             HEAP32[ptr >> 2] = 0
  597.         }
  598.         stop = ret + size;
  599.         while (ptr < stop) {
  600.             HEAP8[ptr++ >> 0] = 0
  601.         }
  602.         return ret
  603.     }
  604.     if (singleType === "i8") {
  605.         if (slab.subarray || slab.slice) {
  606.             HEAPU8.set(slab, ret)
  607.         } else {
  608.             HEAPU8.set(new Uint8Array(slab), ret)
  609.         }
  610.         return ret
  611.     }
  612.     var i = 0,
  613.         type, typeSize, previousType;
  614.     while (i < size) {
  615.         var curr = slab[i];
  616.         if (typeof curr === "function") {
  617.             curr = Runtime.getFunctionIndex(curr)
  618.         }
  619.         type = singleType || types[i];
  620.         if (type === 0) {
  621.             i++;
  622.             continue
  623.         }
  624.         if (type == "i64") type = "i32";
  625.         setValue(ret + i, curr, type);
  626.         if (previousType !== type) {
  627.             typeSize = Runtime.getNativeTypeSize(type);
  628.             previousType = type
  629.         }
  630.         i += typeSize
  631.     }
  632.     return ret
  633. }
  634. Module["allocate"] = allocate;
  635.  
  636. function getMemory(size) {
  637.     if (!staticSealed) return Runtime.staticAlloc(size);
  638.     if (!runtimeInitialized) return Runtime.dynamicAlloc(size);
  639.     return _malloc(size)
  640. }
  641. Module["getMemory"] = getMemory;
  642.  
  643. function Pointer_stringify(ptr, length) {
  644.     if (length === 0 || !ptr) return "";
  645.     var hasUtf = 0;
  646.     var t;
  647.     var i = 0;
  648.     while (1) {
  649.         t = HEAPU8[ptr + i >> 0];
  650.         hasUtf |= t;
  651.         if (t == 0 && !length) break;
  652.         i++;
  653.         if (length && i == length) break
  654.     }
  655.     if (!length) length = i;
  656.     var ret = "";
  657.     if (hasUtf < 128) {
  658.         var MAX_CHUNK = 1024;
  659.         var curr;
  660.         while (length > 0) {
  661.             curr = String.fromCharCode.apply(String, HEAPU8.subarray(ptr, ptr + Math.min(length, MAX_CHUNK)));
  662.             ret = ret ? ret + curr : curr;
  663.             ptr += MAX_CHUNK;
  664.             length -= MAX_CHUNK
  665.         }
  666.         return ret
  667.     }
  668.     return Module["UTF8ToString"](ptr)
  669. }
  670. Module["Pointer_stringify"] = Pointer_stringify;
  671.  
  672. function AsciiToString(ptr) {
  673.     var str = "";
  674.     while (1) {
  675.         var ch = HEAP8[ptr++ >> 0];
  676.         if (!ch) return str;
  677.         str += String.fromCharCode(ch)
  678.     }
  679. }
  680. Module["AsciiToString"] = AsciiToString;
  681.  
  682. function stringToAscii(str, outPtr) {
  683.     return writeAsciiToMemory(str, outPtr, false)
  684. }
  685. Module["stringToAscii"] = stringToAscii;
  686. var UTF8Decoder = typeof TextDecoder !== "undefined" ? new TextDecoder("utf8") : undefined;
  687.  
  688. function UTF8ArrayToString(u8Array, idx) {
  689.     var endPtr = idx;
  690.     while (u8Array[endPtr]) ++endPtr;
  691.     if (endPtr - idx > 16 && u8Array.subarray && UTF8Decoder) {
  692.         return UTF8Decoder.decode(u8Array.subarray(idx, endPtr))
  693.     } else {
  694.         var u0, u1, u2, u3, u4, u5;
  695.         var str = "";
  696.         while (1) {
  697.             u0 = u8Array[idx++];
  698.             if (!u0) return str;
  699.             if (!(u0 & 128)) {
  700.                 str += String.fromCharCode(u0);
  701.                 continue
  702.             }
  703.             u1 = u8Array[idx++] & 63;
  704.             if ((u0 & 224) == 192) {
  705.                 str += String.fromCharCode((u0 & 31) << 6 | u1);
  706.                 continue
  707.             }
  708.             u2 = u8Array[idx++] & 63;
  709.             if ((u0 & 240) == 224) {
  710.                 u0 = (u0 & 15) << 12 | u1 << 6 | u2
  711.             } else {
  712.                 u3 = u8Array[idx++] & 63;
  713.                 if ((u0 & 248) == 240) {
  714.                     u0 = (u0 & 7) << 18 | u1 << 12 | u2 << 6 | u3
  715.                 } else {
  716.                     u4 = u8Array[idx++] & 63;
  717.                     if ((u0 & 252) == 248) {
  718.                         u0 = (u0 & 3) << 24 | u1 << 18 | u2 << 12 | u3 << 6 | u4
  719.                     } else {
  720.                         u5 = u8Array[idx++] & 63;
  721.                         u0 = (u0 & 1) << 30 | u1 << 24 | u2 << 18 | u3 << 12 | u4 << 6 | u5
  722.                     }
  723.                 }
  724.             }
  725.             if (u0 < 65536) {
  726.                 str += String.fromCharCode(u0)
  727.             } else {
  728.                 var ch = u0 - 65536;
  729.                 str += String.fromCharCode(55296 | ch >> 10, 56320 | ch & 1023)
  730.             }
  731.         }
  732.     }
  733. }
  734. Module["UTF8ArrayToString"] = UTF8ArrayToString;
  735.  
  736. function UTF8ToString(ptr) {
  737.     return UTF8ArrayToString(HEAPU8, ptr)
  738. }
  739. Module["UTF8ToString"] = UTF8ToString;
  740.  
  741. function stringToUTF8Array(str, outU8Array, outIdx, maxBytesToWrite) {
  742.     if (!(maxBytesToWrite > 0)) return 0;
  743.     var startIdx = outIdx;
  744.     var endIdx = outIdx + maxBytesToWrite - 1;
  745.     for (var i = 0; i < str.length; ++i) {
  746.         var u = str.charCodeAt(i);
  747.         if (u >= 55296 && u <= 57343) u = 65536 + ((u & 1023) << 10) | str.charCodeAt(++i) & 1023;
  748.         if (u <= 127) {
  749.             if (outIdx >= endIdx) break;
  750.             outU8Array[outIdx++] = u
  751.         } else if (u <= 2047) {
  752.             if (outIdx + 1 >= endIdx) break;
  753.             outU8Array[outIdx++] = 192 | u >> 6;
  754.             outU8Array[outIdx++] = 128 | u & 63
  755.         } else if (u <= 65535) {
  756.             if (outIdx + 2 >= endIdx) break;
  757.             outU8Array[outIdx++] = 224 | u >> 12;
  758.             outU8Array[outIdx++] = 128 | u >> 6 & 63;
  759.             outU8Array[outIdx++] = 128 | u & 63
  760.         } else if (u <= 2097151) {
  761.             if (outIdx + 3 >= endIdx) break;
  762.             outU8Array[outIdx++] = 240 | u >> 18;
  763.             outU8Array[outIdx++] = 128 | u >> 12 & 63;
  764.             outU8Array[outIdx++] = 128 | u >> 6 & 63;
  765.             outU8Array[outIdx++] = 128 | u & 63
  766.         } else if (u <= 67108863) {
  767.             if (outIdx + 4 >= endIdx) break;
  768.             outU8Array[outIdx++] = 248 | u >> 24;
  769.             outU8Array[outIdx++] = 128 | u >> 18 & 63;
  770.             outU8Array[outIdx++] = 128 | u >> 12 & 63;
  771.             outU8Array[outIdx++] = 128 | u >> 6 & 63;
  772.             outU8Array[outIdx++] = 128 | u & 63
  773.         } else {
  774.             if (outIdx + 5 >= endIdx) break;
  775.             outU8Array[outIdx++] = 252 | u >> 30;
  776.             outU8Array[outIdx++] = 128 | u >> 24 & 63;
  777.             outU8Array[outIdx++] = 128 | u >> 18 & 63;
  778.             outU8Array[outIdx++] = 128 | u >> 12 & 63;
  779.             outU8Array[outIdx++] = 128 | u >> 6 & 63;
  780.             outU8Array[outIdx++] = 128 | u & 63
  781.         }
  782.     }
  783.     outU8Array[outIdx] = 0;
  784.     return outIdx - startIdx
  785. }
  786. Module["stringToUTF8Array"] = stringToUTF8Array;
  787.  
  788. function stringToUTF8(str, outPtr, maxBytesToWrite) {
  789.     return stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite)
  790. }
  791. Module["stringToUTF8"] = stringToUTF8;
  792.  
  793. function lengthBytesUTF8(str) {
  794.     var len = 0;
  795.     for (var i = 0; i < str.length; ++i) {
  796.         var u = str.charCodeAt(i);
  797.         if (u >= 55296 && u <= 57343) u = 65536 + ((u & 1023) << 10) | str.charCodeAt(++i) & 1023;
  798.         if (u <= 127) {
  799.             ++len
  800.         } else if (u <= 2047) {
  801.             len += 2
  802.         } else if (u <= 65535) {
  803.             len += 3
  804.         } else if (u <= 2097151) {
  805.             len += 4
  806.         } else if (u <= 67108863) {
  807.             len += 5
  808.         } else {
  809.             len += 6
  810.         }
  811.     }
  812.     return len
  813. }
  814. Module["lengthBytesUTF8"] = lengthBytesUTF8;
  815. var UTF16Decoder = typeof TextDecoder !== "undefined" ? new TextDecoder("utf-16le") : undefined;
  816.  
  817. function demangle(func) {
  818.     var __cxa_demangle_func = Module["___cxa_demangle"] || Module["__cxa_demangle"];
  819.     if (__cxa_demangle_func) {
  820.         try {
  821.             var s = func.substr(1);
  822.             var len = lengthBytesUTF8(s) + 1;
  823.             var buf = _malloc(len);
  824.             stringToUTF8(s, buf, len);
  825.             var status = _malloc(4);
  826.             var ret = __cxa_demangle_func(buf, 0, 0, status);
  827.             if (getValue(status, "i32") === 0 && ret) {
  828.                 return Pointer_stringify(ret)
  829.             }
  830.         } catch (e) {} finally {
  831.             if (buf) _free(buf);
  832.             if (status) _free(status);
  833.             if (ret) _free(ret)
  834.         }
  835.         return func
  836.     }
  837.     Runtime.warnOnce("warning: build with -s DEMANGLE_SUPPORT=1 to link in libcxxabi demangling");
  838.     return func
  839. }
  840.  
  841. function demangleAll(text) {
  842.     var regex = /__Z[\w\d_]+/g;
  843.     return text.replace(regex, (function(x) {
  844.         var y = demangle(x);
  845.         return x === y ? x : x + " [" + y + "]"
  846.     }))
  847. }
  848.  
  849. function jsStackTrace() {
  850.     var err = new Error;
  851.     if (!err.stack) {
  852.         try {
  853.             throw new Error(0)
  854.         } catch (e) {
  855.             err = e
  856.         }
  857.         if (!err.stack) {
  858.             return "(no stack trace available)"
  859.         }
  860.     }
  861.     return err.stack.toString()
  862. }
  863.  
  864. function stackTrace() {
  865.     var js = jsStackTrace();
  866.     if (Module["extraStackTrace"]) js += "\n" + Module["extraStackTrace"]();
  867.     return demangleAll(js)
  868. }
  869. Module["stackTrace"] = stackTrace;
  870. var WASM_PAGE_SIZE = 65536;
  871. var ASMJS_PAGE_SIZE = 16777216;
  872.  
  873. function alignUp(x, multiple) {
  874.     if (x % multiple > 0) {
  875.         x += multiple - x % multiple
  876.     }
  877.     return x
  878. }
  879. var HEAP, buffer, HEAP8, HEAPU8, HEAP16, HEAPU16, HEAP32, HEAPU32, HEAPF32, HEAPF64;
  880.  
  881. function updateGlobalBuffer(buf) {
  882.     Module["buffer"] = buffer = buf
  883. }
  884.  
  885. function updateGlobalBufferViews() {
  886.     Module["HEAP8"] = HEAP8 = new Int8Array(buffer);
  887.     Module["HEAP16"] = HEAP16 = new Int16Array(buffer);
  888.     Module["HEAP32"] = HEAP32 = new Int32Array(buffer);
  889.     Module["HEAPU8"] = HEAPU8 = new Uint8Array(buffer);
  890.     Module["HEAPU16"] = HEAPU16 = new Uint16Array(buffer);
  891.     Module["HEAPU32"] = HEAPU32 = new Uint32Array(buffer);
  892.     Module["HEAPF32"] = HEAPF32 = new Float32Array(buffer);
  893.     Module["HEAPF64"] = HEAPF64 = new Float64Array(buffer)
  894. }
  895. var STATIC_BASE, STATICTOP, staticSealed;
  896. var STACK_BASE, STACKTOP, STACK_MAX;
  897. var DYNAMIC_BASE, DYNAMICTOP_PTR;
  898. STATIC_BASE = STATICTOP = STACK_BASE = STACKTOP = STACK_MAX = DYNAMIC_BASE = DYNAMICTOP_PTR = 0;
  899. staticSealed = false;
  900.  
  901. function abortOnCannotGrowMemory() {
  902.     abort("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_MEMORY=X with X higher than the current value " + TOTAL_MEMORY + ", (2) compile with -s ALLOW_MEMORY_GROWTH=1 which allows increasing the size at runtime, or (3) if you want malloc to return NULL (0) instead of this abort, compile with -s ABORTING_MALLOC=0 ")
  903. }
  904.  
  905. function enlargeMemory() {
  906.     abortOnCannotGrowMemory()
  907. }
  908. var TOTAL_STACK = Module["TOTAL_STACK"] || 5242880;
  909. var TOTAL_MEMORY = Module["TOTAL_MEMORY"] || 16777216;
  910. if (TOTAL_MEMORY < TOTAL_STACK) Module.printErr("TOTAL_MEMORY should be larger than TOTAL_STACK, was " + TOTAL_MEMORY + "! (TOTAL_STACK=" + TOTAL_STACK + ")");
  911. if (Module["buffer"]) {
  912.     buffer = Module["buffer"]
  913. } else {
  914.     if (typeof WebAssembly === "object" && typeof WebAssembly.Memory === "function") {
  915.         Module["wasmMemory"] = new WebAssembly.Memory({
  916.             "initial": TOTAL_MEMORY / WASM_PAGE_SIZE,
  917.             "maximum": TOTAL_MEMORY / WASM_PAGE_SIZE
  918.         });
  919.         buffer = Module["wasmMemory"].buffer
  920.     } else {
  921.         buffer = new ArrayBuffer(TOTAL_MEMORY)
  922.     }
  923. }
  924. updateGlobalBufferViews();
  925.  
  926. function getTotalMemory() {
  927.     return TOTAL_MEMORY
  928. }
  929. HEAP32[0] = 1668509029;
  930. HEAP16[1] = 25459;
  931. if (HEAPU8[2] !== 115 || HEAPU8[3] !== 99) throw "Runtime error: expected the system to be little-endian!";
  932. Module["HEAP"] = HEAP;
  933. Module["buffer"] = buffer;
  934. Module["HEAP8"] = HEAP8;
  935. Module["HEAP16"] = HEAP16;
  936. Module["HEAP32"] = HEAP32;
  937. Module["HEAPU8"] = HEAPU8;
  938. Module["HEAPU16"] = HEAPU16;
  939. Module["HEAPU32"] = HEAPU32;
  940. Module["HEAPF32"] = HEAPF32;
  941. Module["HEAPF64"] = HEAPF64;
  942.  
  943. function callRuntimeCallbacks(callbacks) {
  944.     while (callbacks.length > 0) {
  945.         var callback = callbacks.shift();
  946.         if (typeof callback == "function") {
  947.             callback();
  948.             continue
  949.         }
  950.         var func = callback.func;
  951.         if (typeof func === "number") {
  952.             if (callback.arg === undefined) {
  953.                 Module["dynCall_v"](func)
  954.             } else {
  955.                 Module["dynCall_vi"](func, callback.arg)
  956.             }
  957.         } else {
  958.             func(callback.arg === undefined ? null : callback.arg)
  959.         }
  960.     }
  961. }
  962. var __ATPRERUN__ = [];
  963. var __ATINIT__ = [];
  964. var __ATMAIN__ = [];
  965. var __ATEXIT__ = [];
  966. var __ATPOSTRUN__ = [];
  967. var runtimeInitialized = false;
  968. var runtimeExited = false;
  969.  
  970. function preRun() {
  971.     if (Module["preRun"]) {
  972.         if (typeof Module["preRun"] == "function") Module["preRun"] = [Module["preRun"]];
  973.         while (Module["preRun"].length) {
  974.             addOnPreRun(Module["preRun"].shift())
  975.         }
  976.     }
  977.     callRuntimeCallbacks(__ATPRERUN__)
  978. }
  979.  
  980. function ensureInitRuntime() {
  981.     if (runtimeInitialized) return;
  982.     runtimeInitialized = true;
  983.     callRuntimeCallbacks(__ATINIT__)
  984. }
  985.  
  986. function preMain() {
  987.     callRuntimeCallbacks(__ATMAIN__)
  988. }
  989.  
  990. function exitRuntime() {
  991.     callRuntimeCallbacks(__ATEXIT__);
  992.     runtimeExited = true
  993. }
  994.  
  995. function postRun() {
  996.     if (Module["postRun"]) {
  997.         if (typeof Module["postRun"] == "function") Module["postRun"] = [Module["postRun"]];
  998.         while (Module["postRun"].length) {
  999.             addOnPostRun(Module["postRun"].shift())
  1000.         }
  1001.     }
  1002.     callRuntimeCallbacks(__ATPOSTRUN__)
  1003. }
  1004.  
  1005. function addOnPreRun(cb) {
  1006.     __ATPRERUN__.unshift(cb)
  1007. }
  1008. Module["addOnPreRun"] = addOnPreRun;
  1009.  
  1010. function addOnInit(cb) {
  1011.     __ATINIT__.unshift(cb)
  1012. }
  1013. Module["addOnInit"] = addOnInit;
  1014.  
  1015. function addOnPreMain(cb) {
  1016.     __ATMAIN__.unshift(cb)
  1017. }
  1018. Module["addOnPreMain"] = addOnPreMain;
  1019.  
  1020. function addOnExit(cb) {
  1021.     __ATEXIT__.unshift(cb)
  1022. }
  1023. Module["addOnExit"] = addOnExit;
  1024.  
  1025. function addOnPostRun(cb) {
  1026.     __ATPOSTRUN__.unshift(cb)
  1027. }
  1028. Module["addOnPostRun"] = addOnPostRun;
  1029.  
  1030. function intArrayFromString(stringy, dontAddNull, length) {
  1031.     var len = length > 0 ? length : lengthBytesUTF8(stringy) + 1;
  1032.     var u8array = new Array(len);
  1033.     var numBytesWritten = stringToUTF8Array(stringy, u8array, 0, u8array.length);
  1034.     if (dontAddNull) u8array.length = numBytesWritten;
  1035.     return u8array
  1036. }
  1037. Module["intArrayFromString"] = intArrayFromString;
  1038.  
  1039. function intArrayToString(array) {
  1040.     var ret = [];
  1041.     for (var i = 0; i < array.length; i++) {
  1042.         var chr = array[i];
  1043.         if (chr > 255) {
  1044.             chr &= 255
  1045.         }
  1046.         ret.push(String.fromCharCode(chr))
  1047.     }
  1048.     return ret.join("")
  1049. }
  1050. Module["intArrayToString"] = intArrayToString;
  1051.  
  1052. function writeStringToMemory(string, buffer, dontAddNull) {
  1053.     Runtime.warnOnce("writeStringToMemory is deprecated and should not be called! Use stringToUTF8() instead!");
  1054.     var lastChar, end;
  1055.     if (dontAddNull) {
  1056.         end = buffer + lengthBytesUTF8(string);
  1057.         lastChar = HEAP8[end]
  1058.     }
  1059.     stringToUTF8(string, buffer, Infinity);
  1060.     if (dontAddNull) HEAP8[end] = lastChar
  1061. }
  1062. Module["writeStringToMemory"] = writeStringToMemory;
  1063.  
  1064. function writeArrayToMemory(array, buffer) {
  1065.     HEAP8.set(array, buffer)
  1066. }
  1067. Module["writeArrayToMemory"] = writeArrayToMemory;
  1068.  
  1069. function writeAsciiToMemory(str, buffer, dontAddNull) {
  1070.     for (var i = 0; i < str.length; ++i) {
  1071.         HEAP8[buffer++ >> 0] = str.charCodeAt(i)
  1072.     }
  1073.     if (!dontAddNull) HEAP8[buffer >> 0] = 0
  1074. }
  1075. Module["writeAsciiToMemory"] = writeAsciiToMemory;
  1076. if (!Math["imul"] || Math["imul"](4294967295, 5) !== -5) Math["imul"] = function imul(a, b) {
  1077.     var ah = a >>> 16;
  1078.     var al = a & 65535;
  1079.     var bh = b >>> 16;
  1080.     var bl = b & 65535;
  1081.     return al * bl + (ah * bl + al * bh << 16) | 0
  1082. };
  1083. Math.imul = Math["imul"];
  1084. if (!Math["fround"]) {
  1085.     var froundBuffer = new Float32Array(1);
  1086.     Math["fround"] = (function(x) {
  1087.         froundBuffer[0] = x;
  1088.         return froundBuffer[0]
  1089.     })
  1090. }
  1091. Math.fround = Math["fround"];
  1092. if (!Math["clz32"]) Math["clz32"] = (function(x) {
  1093.     x = x >>> 0;
  1094.     for (var i = 0; i < 32; i++) {
  1095.         if (x & 1 << 31 - i) return i
  1096.     }
  1097.     return 32
  1098. });
  1099. Math.clz32 = Math["clz32"];
  1100. if (!Math["trunc"]) Math["trunc"] = (function(x) {
  1101.     return x < 0 ? Math.ceil(x) : Math.floor(x)
  1102. });
  1103. Math.trunc = Math["trunc"];
  1104. var Math_abs = Math.abs;
  1105. var Math_cos = Math.cos;
  1106. var Math_sin = Math.sin;
  1107. var Math_tan = Math.tan;
  1108. var Math_acos = Math.acos;
  1109. var Math_asin = Math.asin;
  1110. var Math_atan = Math.atan;
  1111. var Math_atan2 = Math.atan2;
  1112. var Math_exp = Math.exp;
  1113. var Math_log = Math.log;
  1114. var Math_sqrt = Math.sqrt;
  1115. var Math_ceil = Math.ceil;
  1116. var Math_floor = Math.floor;
  1117. var Math_pow = Math.pow;
  1118. var Math_imul = Math.imul;
  1119. var Math_fround = Math.fround;
  1120. var Math_round = Math.round;
  1121. var Math_min = Math.min;
  1122. var Math_clz32 = Math.clz32;
  1123. var Math_trunc = Math.trunc;
  1124. var runDependencies = 0;
  1125. var runDependencyWatcher = null;
  1126. var dependenciesFulfilled = null;
  1127.  
  1128. function getUniqueRunDependency(id) {
  1129.     return id
  1130. }
  1131.  
  1132. function addRunDependency(id) {
  1133.     runDependencies++;
  1134.     if (Module["monitorRunDependencies"]) {
  1135.         Module["monitorRunDependencies"](runDependencies)
  1136.     }
  1137. }
  1138. Module["addRunDependency"] = addRunDependency;
  1139.  
  1140. function removeRunDependency(id) {
  1141.     runDependencies--;
  1142.     if (Module["monitorRunDependencies"]) {
  1143.         Module["monitorRunDependencies"](runDependencies)
  1144.     }
  1145.     if (runDependencies == 0) {
  1146.         if (runDependencyWatcher !== null) {
  1147.             clearInterval(runDependencyWatcher);
  1148.             runDependencyWatcher = null
  1149.         }
  1150.         if (dependenciesFulfilled) {
  1151.             var callback = dependenciesFulfilled;
  1152.             dependenciesFulfilled = null;
  1153.             callback()
  1154.         }
  1155.     }
  1156. }
  1157. Module["removeRunDependency"] = removeRunDependency;
  1158. Module["preloadedImages"] = {};
  1159. Module["preloadedAudios"] = {};
  1160. var memoryInitializer = null;
  1161.  
  1162. function integrateWasmJS(Module) {
  1163.     var method = Module["wasmJSMethod"] || "native-wasm";
  1164.     Module["wasmJSMethod"] = method;
  1165.     var wasmTextFile = Module["wasmTextFile"] || "cn.wast";
  1166.     var wasmBinaryFile = Module["wasmBinaryFile"] || "cn.wasm";
  1167.     var asmjsCodeFile = Module["asmjsCodeFile"] || "cn.temp.asm.js";
  1168.     if (typeof Module["locateFile"] === "function") {
  1169.         wasmTextFile = Module["locateFile"](wasmTextFile);
  1170.         wasmBinaryFile = Module["locateFile"](wasmBinaryFile);
  1171.         asmjsCodeFile = Module["locateFile"](asmjsCodeFile)
  1172.     }
  1173.     var wasmPageSize = 64 * 1024;
  1174.     var asm2wasmImports = {
  1175.         "f64-rem": (function(x, y) {
  1176.             return x % y
  1177.         }),
  1178.         "f64-to-int": (function(x) {
  1179.             return x | 0
  1180.         }),
  1181.         "i32s-div": (function(x, y) {
  1182.             return (x | 0) / (y | 0) | 0
  1183.         }),
  1184.         "i32u-div": (function(x, y) {
  1185.             return (x >>> 0) / (y >>> 0) >>> 0
  1186.         }),
  1187.         "i32s-rem": (function(x, y) {
  1188.             return (x | 0) % (y | 0) | 0
  1189.         }),
  1190.         "i32u-rem": (function(x, y) {
  1191.             return (x >>> 0) % (y >>> 0) >>> 0
  1192.         }),
  1193.         "debugger": (function() {
  1194.             debugger
  1195.         })
  1196.     };
  1197.     var info = {
  1198.         "global": null,
  1199.         "env": null,
  1200.         "asm2wasm": asm2wasmImports,
  1201.         "parent": Module
  1202.     };
  1203.     var exports = null;
  1204.  
  1205.     function lookupImport(mod, base) {
  1206.         var lookup = info;
  1207.         if (mod.indexOf(".") < 0) {
  1208.             lookup = (lookup || {})[mod]
  1209.         } else {
  1210.             var parts = mod.split(".");
  1211.             lookup = (lookup || {})[parts[0]];
  1212.             lookup = (lookup || {})[parts[1]]
  1213.         }
  1214.         if (base) {
  1215.             lookup = (lookup || {})[base]
  1216.         }
  1217.         if (lookup === undefined) {
  1218.             abort("bad lookupImport to (" + mod + ")." + base)
  1219.         }
  1220.         return lookup
  1221.     }
  1222.  
  1223.     function mergeMemory(newBuffer) {
  1224.         var oldBuffer = Module["buffer"];
  1225.         if (newBuffer.byteLength < oldBuffer.byteLength) {
  1226.             Module["printErr"]("the new buffer in mergeMemory is smaller than the previous one. in native wasm, we should grow memory here")
  1227.         }
  1228.         var oldView = new Int8Array(oldBuffer);
  1229.         var newView = new Int8Array(newBuffer);
  1230.         if (!memoryInitializer) {
  1231.             oldView.set(newView.subarray(Module["STATIC_BASE"], Module["STATIC_BASE"] + Module["STATIC_BUMP"]), Module["STATIC_BASE"])
  1232.         }
  1233.         newView.set(oldView);
  1234.         updateGlobalBuffer(newBuffer);
  1235.         updateGlobalBufferViews()
  1236.     }
  1237.     var WasmTypes = {
  1238.         none: 0,
  1239.         i32: 1,
  1240.         i64: 2,
  1241.         f32: 3,
  1242.         f64: 4
  1243.     };
  1244.  
  1245.     function fixImports(imports) {
  1246.         if (!0) return imports;
  1247.         var ret = {};
  1248.         for (var i in imports) {
  1249.             var fixed = i;
  1250.             if (fixed[0] == "_") fixed = fixed.substr(1);
  1251.             ret[fixed] = imports[i]
  1252.         }
  1253.         return ret
  1254.     }
  1255.  
  1256.     function getBinary() {
  1257.         try {
  1258.             var binary;
  1259.             if (Module["wasmBinary"]) {
  1260.                 binary = Module["wasmBinary"];
  1261.                 binary = new Uint8Array(binary)
  1262.             } else if (Module["readBinary"]) {
  1263.                 binary = Module["readBinary"](wasmBinaryFile)
  1264.             } else {
  1265.                 throw "on the web, we need the wasm binary to be preloaded and set on Module['wasmBinary']. emcc.py will do that for you when generating HTML (but not JS)"
  1266.             }
  1267.             return binary
  1268.         } catch (err) {
  1269.             abort(err)
  1270.         }
  1271.     }
  1272.  
  1273.     function getBinaryPromise() {
  1274.         if (!Module["wasmBinary"] && typeof fetch === "function") {
  1275.             return fetch(wasmBinaryFile, {
  1276.                 credentials: "same-origin"
  1277.             }).then((function(response) {
  1278.                 if (!response["ok"]) {
  1279.                     throw "failed to load wasm binary file at '" + wasmBinaryFile + "'"
  1280.                 }
  1281.                 return response["arrayBuffer"]()
  1282.             }))
  1283.         }
  1284.         return new Promise((function(resolve, reject) {
  1285.             resolve(getBinary())
  1286.         }))
  1287.     }
  1288.  
  1289.     function doNativeWasm(global, env, providedBuffer) {
  1290.         if (typeof WebAssembly !== "object") {
  1291.             Module["printErr"]("no native wasm support detected");
  1292.             return false
  1293.         }
  1294.         if (!(Module["wasmMemory"] instanceof WebAssembly.Memory)) {
  1295.             Module["printErr"]("no native wasm Memory in use");
  1296.             return false
  1297.         }
  1298.         env["memory"] = Module["wasmMemory"];
  1299.         info["global"] = {
  1300.             "NaN": NaN,
  1301.             "Infinity": Infinity
  1302.         };
  1303.         info["global.Math"] = global.Math;
  1304.         info["env"] = env;
  1305.  
  1306.         function receiveInstance(instance) {
  1307.             exports = instance.exports;
  1308.             if (exports.memory) mergeMemory(exports.memory);
  1309.             Module["asm"] = exports;
  1310.             Module["usingWasm"] = true;
  1311.             removeRunDependency("wasm-instantiate")
  1312.         }
  1313.         addRunDependency("wasm-instantiate");
  1314.         if (Module["instantiateWasm"]) {
  1315.             try {
  1316.                 return Module["instantiateWasm"](info, receiveInstance)
  1317.             } catch (e) {
  1318.                 Module["printErr"]("Module.instantiateWasm callback failed with error: " + e);
  1319.                 return false
  1320.             }
  1321.         }
  1322.         getBinaryPromise().then((function(binary) {
  1323.             return WebAssembly.instantiate(binary, info)
  1324.         })).then((function(output) {
  1325.             receiveInstance(output["instance"])
  1326.         })).catch((function(reason) {
  1327.             Module["printErr"]("failed to asynchronously prepare wasm: " + reason);
  1328.             abort(reason)
  1329.         }));
  1330.         return {}
  1331.     }
  1332.     Module["asmPreload"] = Module["asm"];
  1333.     var asmjsReallocBuffer = Module["reallocBuffer"];
  1334.     var wasmReallocBuffer = (function(size) {
  1335.         var PAGE_MULTIPLE = Module["usingWasm"] ? WASM_PAGE_SIZE : ASMJS_PAGE_SIZE;
  1336.         size = alignUp(size, PAGE_MULTIPLE);
  1337.         var old = Module["buffer"];
  1338.         var oldSize = old.byteLength;
  1339.         if (Module["usingWasm"]) {
  1340.             try {
  1341.                 var result = Module["wasmMemory"].grow((size - oldSize) / wasmPageSize);
  1342.                 if (result !== (-1 | 0)) {
  1343.                     return Module["buffer"] = Module["wasmMemory"].buffer
  1344.                 } else {
  1345.                     return null
  1346.                 }
  1347.             } catch (e) {
  1348.                 return null
  1349.             }
  1350.         } else {
  1351.             exports["__growWasmMemory"]((size - oldSize) / wasmPageSize);
  1352.             return Module["buffer"] !== old ? Module["buffer"] : null
  1353.         }
  1354.     });
  1355.     Module["reallocBuffer"] = (function(size) {
  1356.         if (finalMethod === "asmjs") {
  1357.             return asmjsReallocBuffer(size)
  1358.         } else {
  1359.             return wasmReallocBuffer(size)
  1360.         }
  1361.     });
  1362.     var finalMethod = "";
  1363.     Module["asm"] = (function(global, env, providedBuffer) {
  1364.         global = fixImports(global);
  1365.         env = fixImports(env);
  1366.         if (!env["table"]) {
  1367.             var TABLE_SIZE = Module["wasmTableSize"];
  1368.             if (TABLE_SIZE === undefined) TABLE_SIZE = 1024;
  1369.             var MAX_TABLE_SIZE = Module["wasmMaxTableSize"];
  1370.             if (typeof WebAssembly === "object" && typeof WebAssembly.Table === "function") {
  1371.                 if (MAX_TABLE_SIZE !== undefined) {
  1372.                     env["table"] = new WebAssembly.Table({
  1373.                         "initial": TABLE_SIZE,
  1374.                         "maximum": MAX_TABLE_SIZE,
  1375.                         "element": "anyfunc"
  1376.                     })
  1377.                 } else {
  1378.                     env["table"] = new WebAssembly.Table({
  1379.                         "initial": TABLE_SIZE,
  1380.                         element: "anyfunc"
  1381.                     })
  1382.                 }
  1383.             } else {
  1384.                 env["table"] = new Array(TABLE_SIZE)
  1385.             }
  1386.             Module["wasmTable"] = env["table"]
  1387.         }
  1388.         if (!env["memoryBase"]) {
  1389.             env["memoryBase"] = Module["STATIC_BASE"]
  1390.         }
  1391.         if (!env["tableBase"]) {
  1392.             env["tableBase"] = 0
  1393.         }
  1394.         var exports;
  1395.         exports = doNativeWasm(global, env, providedBuffer);
  1396.         return exports
  1397.     });
  1398.     var methodHandler = Module["asm"]
  1399. }
  1400. integrateWasmJS(Module);
  1401. var ASM_CONSTS = [];
  1402. STATIC_BASE = Runtime.GLOBAL_BASE;
  1403. STATICTOP = STATIC_BASE + 12512;
  1404. __ATINIT__.push();
  1405. memoryInitializer = Module["wasmJSMethod"].indexOf("asmjs") >= 0 || Module["wasmJSMethod"].indexOf("interpret-asm2wasm") >= 0 ? "cn.js.mem" : null;
  1406. var STATIC_BUMP = 12512;
  1407. Module["STATIC_BASE"] = STATIC_BASE;
  1408. Module["STATIC_BUMP"] = STATIC_BUMP;
  1409. var tempDoublePtr = STATICTOP;
  1410. STATICTOP += 16;
  1411.  
  1412. function ___assert_fail(condition, filename, line, func) {
  1413.     ABORT = true;
  1414.     throw "Assertion failed: " + Pointer_stringify(condition) + ", at: " + [filename ? Pointer_stringify(filename) : "unknown filename", line, func ? Pointer_stringify(func) : "unknown function"] + " at " + stackTrace()
  1415. }
  1416. var PROCINFO = {
  1417.     ppid: 1,
  1418.     pid: 42,
  1419.     sid: 42,
  1420.     pgid: 42
  1421. };
  1422. var ERRNO_CODES = {
  1423.     EPERM: 1,
  1424.     ENOENT: 2,
  1425.     ESRCH: 3,
  1426.     EINTR: 4,
  1427.     EIO: 5,
  1428.     ENXIO: 6,
  1429.     E2BIG: 7,
  1430.     ENOEXEC: 8,
  1431.     EBADF: 9,
  1432.     ECHILD: 10,
  1433.     EAGAIN: 11,
  1434.     EWOULDBLOCK: 11,
  1435.     ENOMEM: 12,
  1436.     EACCES: 13,
  1437.     EFAULT: 14,
  1438.     ENOTBLK: 15,
  1439.     EBUSY: 16,
  1440.     EEXIST: 17,
  1441.     EXDEV: 18,
  1442.     ENODEV: 19,
  1443.     ENOTDIR: 20,
  1444.     EISDIR: 21,
  1445.     EINVAL: 22,
  1446.     ENFILE: 23,
  1447.     EMFILE: 24,
  1448.     ENOTTY: 25,
  1449.     ETXTBSY: 26,
  1450.     EFBIG: 27,
  1451.     ENOSPC: 28,
  1452.     ESPIPE: 29,
  1453.     EROFS: 30,
  1454.     EMLINK: 31,
  1455.     EPIPE: 32,
  1456.     EDOM: 33,
  1457.     ERANGE: 34,
  1458.     ENOMSG: 42,
  1459.     EIDRM: 43,
  1460.     ECHRNG: 44,
  1461.     EL2NSYNC: 45,
  1462.     EL3HLT: 46,
  1463.     EL3RST: 47,
  1464.     ELNRNG: 48,
  1465.     EUNATCH: 49,
  1466.     ENOCSI: 50,
  1467.     EL2HLT: 51,
  1468.     EDEADLK: 35,
  1469.     ENOLCK: 37,
  1470.     EBADE: 52,
  1471.     EBADR: 53,
  1472.     EXFULL: 54,
  1473.     ENOANO: 55,
  1474.     EBADRQC: 56,
  1475.     EBADSLT: 57,
  1476.     EDEADLOCK: 35,
  1477.     EBFONT: 59,
  1478.     ENOSTR: 60,
  1479.     ENODATA: 61,
  1480.     ETIME: 62,
  1481.     ENOSR: 63,
  1482.     ENONET: 64,
  1483.     ENOPKG: 65,
  1484.     EREMOTE: 66,
  1485.     ENOLINK: 67,
  1486.     EADV: 68,
  1487.     ESRMNT: 69,
  1488.     ECOMM: 70,
  1489.     EPROTO: 71,
  1490.     EMULTIHOP: 72,
  1491.     EDOTDOT: 73,
  1492.     EBADMSG: 74,
  1493.     ENOTUNIQ: 76,
  1494.     EBADFD: 77,
  1495.     EREMCHG: 78,
  1496.     ELIBACC: 79,
  1497.     ELIBBAD: 80,
  1498.     ELIBSCN: 81,
  1499.     ELIBMAX: 82,
  1500.     ELIBEXEC: 83,
  1501.     ENOSYS: 38,
  1502.     ENOTEMPTY: 39,
  1503.     ENAMETOOLONG: 36,
  1504.     ELOOP: 40,
  1505.     EOPNOTSUPP: 95,
  1506.     EPFNOSUPPORT: 96,
  1507.     ECONNRESET: 104,
  1508.     ENOBUFS: 105,
  1509.     EAFNOSUPPORT: 97,
  1510.     EPROTOTYPE: 91,
  1511.     ENOTSOCK: 88,
  1512.     ENOPROTOOPT: 92,
  1513.     ESHUTDOWN: 108,
  1514.     ECONNREFUSED: 111,
  1515.     EADDRINUSE: 98,
  1516.     ECONNABORTED: 103,
  1517.     ENETUNREACH: 101,
  1518.     ENETDOWN: 100,
  1519.     ETIMEDOUT: 110,
  1520.     EHOSTDOWN: 112,
  1521.     EHOSTUNREACH: 113,
  1522.     EINPROGRESS: 115,
  1523.     EALREADY: 114,
  1524.     EDESTADDRREQ: 89,
  1525.     EMSGSIZE: 90,
  1526.     EPROTONOSUPPORT: 93,
  1527.     ESOCKTNOSUPPORT: 94,
  1528.     EADDRNOTAVAIL: 99,
  1529.     ENETRESET: 102,
  1530.     EISCONN: 106,
  1531.     ENOTCONN: 107,
  1532.     ETOOMANYREFS: 109,
  1533.     EUSERS: 87,
  1534.     EDQUOT: 122,
  1535.     ESTALE: 116,
  1536.     ENOTSUP: 95,
  1537.     ENOMEDIUM: 123,
  1538.     EILSEQ: 84,
  1539.     EOVERFLOW: 75,
  1540.     ECANCELED: 125,
  1541.     ENOTRECOVERABLE: 131,
  1542.     EOWNERDEAD: 130,
  1543.     ESTRPIPE: 86
  1544. };
  1545. var ERRNO_MESSAGES = {
  1546.     0: "Success",
  1547.     1: "Not super-user",
  1548.     2: "No such file or directory",
  1549.     3: "No such process",
  1550.     4: "Interrupted system call",
  1551.     5: "I/O error",
  1552.     6: "No such device or address",
  1553.     7: "Arg list too long",
  1554.     8: "Exec format error",
  1555.     9: "Bad file number",
  1556.     10: "No children",
  1557.     11: "No more processes",
  1558.     12: "Not enough core",
  1559.     13: "Permission denied",
  1560.     14: "Bad address",
  1561.     15: "Block device required",
  1562.     16: "Mount device busy",
  1563.     17: "File exists",
  1564.     18: "Cross-device link",
  1565.     19: "No such device",
  1566.     20: "Not a directory",
  1567.     21: "Is a directory",
  1568.     22: "Invalid argument",
  1569.     23: "Too many open files in system",
  1570.     24: "Too many open files",
  1571.     25: "Not a typewriter",
  1572.     26: "Text file busy",
  1573.     27: "File too large",
  1574.     28: "No space left on device",
  1575.     29: "Illegal seek",
  1576.     30: "Read only file system",
  1577.     31: "Too many links",
  1578.     32: "Broken pipe",
  1579.     33: "Math arg out of domain of func",
  1580.     34: "Math result not representable",
  1581.     35: "File locking deadlock error",
  1582.     36: "File or path name too long",
  1583.     37: "No record locks available",
  1584.     38: "Function not implemented",
  1585.     39: "Directory not empty",
  1586.     40: "Too many symbolic links",
  1587.     42: "No message of desired type",
  1588.     43: "Identifier removed",
  1589.     44: "Channel number out of range",
  1590.     45: "Level 2 not synchronized",
  1591.     46: "Level 3 halted",
  1592.     47: "Level 3 reset",
  1593.     48: "Link number out of range",
  1594.     49: "Protocol driver not attached",
  1595.     50: "No CSI structure available",
  1596.     51: "Level 2 halted",
  1597.     52: "Invalid exchange",
  1598.     53: "Invalid request descriptor",
  1599.     54: "Exchange full",
  1600.     55: "No anode",
  1601.     56: "Invalid request code",
  1602.     57: "Invalid slot",
  1603.     59: "Bad font file fmt",
  1604.     60: "Device not a stream",
  1605.     61: "No data (for no delay io)",
  1606.     62: "Timer expired",
  1607.     63: "Out of streams resources",
  1608.     64: "Machine is not on the network",
  1609.     65: "Package not installed",
  1610.     66: "The object is remote",
  1611.     67: "The link has been severed",
  1612.     68: "Advertise error",
  1613.     69: "Srmount error",
  1614.     70: "Communication error on send",
  1615.     71: "Protocol error",
  1616.     72: "Multihop attempted",
  1617.     73: "Cross mount point (not really error)",
  1618.     74: "Trying to read unreadable message",
  1619.     75: "Value too large for defined data type",
  1620.     76: "Given log. name not unique",
  1621.     77: "f.d. invalid for this operation",
  1622.     78: "Remote address changed",
  1623.     79: "Can access a needed shared lib",
  1624.     80: "Accessing a corrupted shared lib",
  1625.     81: ".lib section in a.out corrupted",
  1626.     82: "Attempting to link in too many libs",
  1627.     83: "Attempting to exec a shared library",
  1628.     84: "Illegal byte sequence",
  1629.     86: "Streams pipe error",
  1630.     87: "Too many users",
  1631.     88: "Socket operation on non-socket",
  1632.     89: "Destination address required",
  1633.     90: "Message too long",
  1634.     91: "Protocol wrong type for socket",
  1635.     92: "Protocol not available",
  1636.     93: "Unknown protocol",
  1637.     94: "Socket type not supported",
  1638.     95: "Not supported",
  1639.     96: "Protocol family not supported",
  1640.     97: "Address family not supported by protocol family",
  1641.     98: "Address already in use",
  1642.     99: "Address not available",
  1643.     100: "Network interface is not configured",
  1644.     101: "Network is unreachable",
  1645.     102: "Connection reset by network",
  1646.     103: "Connection aborted",
  1647.     104: "Connection reset by peer",
  1648.     105: "No buffer space available",
  1649.     106: "Socket is already connected",
  1650.     107: "Socket is not connected",
  1651.     108: "Can't send after socket shutdown",
  1652.     109: "Too many references",
  1653.     110: "Connection timed out",
  1654.     111: "Connection refused",
  1655.     112: "Host is down",
  1656.     113: "Host is unreachable",
  1657.     114: "Socket already connected",
  1658.     115: "Connection already in progress",
  1659.     116: "Stale file handle",
  1660.     122: "Quota exceeded",
  1661.     123: "No medium (in tape drive)",
  1662.     125: "Operation canceled",
  1663.     130: "Previous owner died",
  1664.     131: "State not recoverable"
  1665. };
  1666.  
  1667. function ___setErrNo(value) {
  1668.     if (Module["___errno_location"]) HEAP32[Module["___errno_location"]() >> 2] = value;
  1669.     return value
  1670. }
  1671. var PATH = {
  1672.     splitPath: (function(filename) {
  1673.         var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;
  1674.         return splitPathRe.exec(filename).slice(1)
  1675.     }),
  1676.     normalizeArray: (function(parts, allowAboveRoot) {
  1677.         var up = 0;
  1678.         for (var i = parts.length - 1; i >= 0; i--) {
  1679.             var last = parts[i];
  1680.             if (last === ".") {
  1681.                 parts.splice(i, 1)
  1682.             } else if (last === "..") {
  1683.                 parts.splice(i, 1);
  1684.                 up++
  1685.             } else if (up) {
  1686.                 parts.splice(i, 1);
  1687.                 up--
  1688.             }
  1689.         }
  1690.         if (allowAboveRoot) {
  1691.             for (; up; up--) {
  1692.                 parts.unshift("..")
  1693.             }
  1694.         }
  1695.         return parts
  1696.     }),
  1697.     normalize: (function(path) {
  1698.         var isAbsolute = path.charAt(0) === "/",
  1699.             trailingSlash = path.substr(-1) === "/";
  1700.         path = PATH.normalizeArray(path.split("/").filter((function(p) {
  1701.             return !!p
  1702.         })), !isAbsolute).join("/");
  1703.         if (!path && !isAbsolute) {
  1704.             path = "."
  1705.         }
  1706.         if (path && trailingSlash) {
  1707.             path += "/"
  1708.         }
  1709.         return (isAbsolute ? "/" : "") + path
  1710.     }),
  1711.     dirname: (function(path) {
  1712.         var result = PATH.splitPath(path),
  1713.             root = result[0],
  1714.             dir = result[1];
  1715.         if (!root && !dir) {
  1716.             return "."
  1717.         }
  1718.         if (dir) {
  1719.             dir = dir.substr(0, dir.length - 1)
  1720.         }
  1721.         return root + dir
  1722.     }),
  1723.     basename: (function(path) {
  1724.         if (path === "/") return "/";
  1725.         var lastSlash = path.lastIndexOf("/");
  1726.         if (lastSlash === -1) return path;
  1727.         return path.substr(lastSlash + 1)
  1728.     }),
  1729.     extname: (function(path) {
  1730.         return PATH.splitPath(path)[3]
  1731.     }),
  1732.     join: (function() {
  1733.         var paths = Array.prototype.slice.call(arguments, 0);
  1734.         return PATH.normalize(paths.join("/"))
  1735.     }),
  1736.     join2: (function(l, r) {
  1737.         return PATH.normalize(l + "/" + r)
  1738.     }),
  1739.     resolve: (function() {
  1740.         var resolvedPath = "",
  1741.             resolvedAbsolute = false;
  1742.         for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {
  1743.             var path = i >= 0 ? arguments[i] : FS.cwd();
  1744.             if (typeof path !== "string") {
  1745.                 throw new TypeError("Arguments to path.resolve must be strings")
  1746.             } else if (!path) {
  1747.                 return ""
  1748.             }
  1749.             resolvedPath = path + "/" + resolvedPath;
  1750.             resolvedAbsolute = path.charAt(0) === "/"
  1751.         }
  1752.         resolvedPath = PATH.normalizeArray(resolvedPath.split("/").filter((function(p) {
  1753.             return !!p
  1754.         })), !resolvedAbsolute).join("/");
  1755.         return (resolvedAbsolute ? "/" : "") + resolvedPath || "."
  1756.     }),
  1757.     relative: (function(from, to) {
  1758.         from = PATH.resolve(from).substr(1);
  1759.         to = PATH.resolve(to).substr(1);
  1760.  
  1761.         function trim(arr) {
  1762.             var start = 0;
  1763.             for (; start < arr.length; start++) {
  1764.                 if (arr[start] !== "") break
  1765.             }
  1766.             var end = arr.length - 1;
  1767.             for (; end >= 0; end--) {
  1768.                 if (arr[end] !== "") break
  1769.             }
  1770.             if (start > end) return [];
  1771.             return arr.slice(start, end - start + 1)
  1772.         }
  1773.         var fromParts = trim(from.split("/"));
  1774.         var toParts = trim(to.split("/"));
  1775.         var length = Math.min(fromParts.length, toParts.length);
  1776.         var samePartsLength = length;
  1777.         for (var i = 0; i < length; i++) {
  1778.             if (fromParts[i] !== toParts[i]) {
  1779.                 samePartsLength = i;
  1780.                 break
  1781.             }
  1782.         }
  1783.         var outputParts = [];
  1784.         for (var i = samePartsLength; i < fromParts.length; i++) {
  1785.             outputParts.push("..")
  1786.         }
  1787.         outputParts = outputParts.concat(toParts.slice(samePartsLength));
  1788.         return outputParts.join("/")
  1789.     })
  1790. };
  1791. var TTY = {
  1792.     ttys: [],
  1793.     init: (function() {}),
  1794.     shutdown: (function() {}),
  1795.     register: (function(dev, ops) {
  1796.         TTY.ttys[dev] = {
  1797.             input: [],
  1798.             output: [],
  1799.             ops: ops
  1800.         };
  1801.         FS.registerDevice(dev, TTY.stream_ops)
  1802.     }),
  1803.     stream_ops: {
  1804.         open: (function(stream) {
  1805.             var tty = TTY.ttys[stream.node.rdev];
  1806.             if (!tty) {
  1807.                 throw new FS.ErrnoError(ERRNO_CODES.ENODEV)
  1808.             }
  1809.             stream.tty = tty;
  1810.             stream.seekable = false
  1811.         }),
  1812.         close: (function(stream) {
  1813.             stream.tty.ops.flush(stream.tty)
  1814.         }),
  1815.         flush: (function(stream) {
  1816.             stream.tty.ops.flush(stream.tty)
  1817.         }),
  1818.         read: (function(stream, buffer, offset, length, pos) {
  1819.             if (!stream.tty || !stream.tty.ops.get_char) {
  1820.                 throw new FS.ErrnoError(ERRNO_CODES.ENXIO)
  1821.             }
  1822.             var bytesRead = 0;
  1823.             for (var i = 0; i < length; i++) {
  1824.                 var result;
  1825.                 try {
  1826.                     result = stream.tty.ops.get_char(stream.tty)
  1827.                 } catch (e) {
  1828.                     throw new FS.ErrnoError(ERRNO_CODES.EIO)
  1829.                 }
  1830.                 if (result === undefined && bytesRead === 0) {
  1831.                     throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)
  1832.                 }
  1833.                 if (result === null || result === undefined) break;
  1834.                 bytesRead++;
  1835.                 buffer[offset + i] = result
  1836.             }
  1837.             if (bytesRead) {
  1838.                 stream.node.timestamp = Date.now()
  1839.             }
  1840.             return bytesRead
  1841.         }),
  1842.         write: (function(stream, buffer, offset, length, pos) {
  1843.             if (!stream.tty || !stream.tty.ops.put_char) {
  1844.                 throw new FS.ErrnoError(ERRNO_CODES.ENXIO)
  1845.             }
  1846.             for (var i = 0; i < length; i++) {
  1847.                 try {
  1848.                     stream.tty.ops.put_char(stream.tty, buffer[offset + i])
  1849.                 } catch (e) {
  1850.                     throw new FS.ErrnoError(ERRNO_CODES.EIO)
  1851.                 }
  1852.             }
  1853.             if (length) {
  1854.                 stream.node.timestamp = Date.now()
  1855.             }
  1856.             return i
  1857.         })
  1858.     },
  1859.     default_tty_ops: {
  1860.         get_char: (function(tty) {
  1861.             if (!tty.input.length) {
  1862.                 var result = null;
  1863.                 if (ENVIRONMENT_IS_NODE) {
  1864.                     var BUFSIZE = 256;
  1865.                     var buf = new Buffer(BUFSIZE);
  1866.                     var bytesRead = 0;
  1867.                     var isPosixPlatform = process.platform != "win32";
  1868.                     var fd = process.stdin.fd;
  1869.                     if (isPosixPlatform) {
  1870.                         var usingDevice = false;
  1871.                         try {
  1872.                             fd = fs.openSync("/dev/stdin", "r");
  1873.                             usingDevice = true
  1874.                         } catch (e) {}
  1875.                     }
  1876.                     try {
  1877.                         bytesRead = fs.readSync(fd, buf, 0, BUFSIZE, null)
  1878.                     } catch (e) {
  1879.                         if (e.toString().indexOf("EOF") != -1) bytesRead = 0;
  1880.                         else throw e
  1881.                     }
  1882.                     if (usingDevice) {
  1883.                         fs.closeSync(fd)
  1884.                     }
  1885.                     if (bytesRead > 0) {
  1886.                         result = buf.slice(0, bytesRead).toString("utf-8")
  1887.                     } else {
  1888.                         result = null
  1889.                     }
  1890.                 } else if (typeof window != "undefined" && typeof window.prompt == "function") {
  1891.                     result = window.prompt("Input: ");
  1892.                     if (result !== null) {
  1893.                         result += "\n"
  1894.                     }
  1895.                 } else if (typeof readline == "function") {
  1896.                     result = readline();
  1897.                     if (result !== null) {
  1898.                         result += "\n"
  1899.                     }
  1900.                 }
  1901.                 if (!result) {
  1902.                     return null
  1903.                 }
  1904.                 tty.input = intArrayFromString(result, true)
  1905.             }
  1906.             return tty.input.shift()
  1907.         }),
  1908.         put_char: (function(tty, val) {
  1909.             if (val === null || val === 10) {
  1910.                 Module["print"](UTF8ArrayToString(tty.output, 0));
  1911.                 tty.output = []
  1912.             } else {
  1913.                 if (val != 0) tty.output.push(val)
  1914.             }
  1915.         }),
  1916.         flush: (function(tty) {
  1917.             if (tty.output && tty.output.length > 0) {
  1918.                 Module["print"](UTF8ArrayToString(tty.output, 0));
  1919.                 tty.output = []
  1920.             }
  1921.         })
  1922.     },
  1923.     default_tty1_ops: {
  1924.         put_char: (function(tty, val) {
  1925.             if (val === null || val === 10) {
  1926.                 Module["printErr"](UTF8ArrayToString(tty.output, 0));
  1927.                 tty.output = []
  1928.             } else {
  1929.                 if (val != 0) tty.output.push(val)
  1930.             }
  1931.         }),
  1932.         flush: (function(tty) {
  1933.             if (tty.output && tty.output.length > 0) {
  1934.                 Module["printErr"](UTF8ArrayToString(tty.output, 0));
  1935.                 tty.output = []
  1936.             }
  1937.         })
  1938.     }
  1939. };
  1940. var MEMFS = {
  1941.     ops_table: null,
  1942.     mount: (function(mount) {
  1943.         return MEMFS.createNode(null, "/", 16384 | 511, 0)
  1944.     }),
  1945.     createNode: (function(parent, name, mode, dev) {
  1946.         if (FS.isBlkdev(mode) || FS.isFIFO(mode)) {
  1947.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  1948.         }
  1949.         if (!MEMFS.ops_table) {
  1950.             MEMFS.ops_table = {
  1951.                 dir: {
  1952.                     node: {
  1953.                         getattr: MEMFS.node_ops.getattr,
  1954.                         setattr: MEMFS.node_ops.setattr,
  1955.                         lookup: MEMFS.node_ops.lookup,
  1956.                         mknod: MEMFS.node_ops.mknod,
  1957.                         rename: MEMFS.node_ops.rename,
  1958.                         unlink: MEMFS.node_ops.unlink,
  1959.                         rmdir: MEMFS.node_ops.rmdir,
  1960.                         readdir: MEMFS.node_ops.readdir,
  1961.                         symlink: MEMFS.node_ops.symlink
  1962.                     },
  1963.                     stream: {
  1964.                         llseek: MEMFS.stream_ops.llseek
  1965.                     }
  1966.                 },
  1967.                 file: {
  1968.                     node: {
  1969.                         getattr: MEMFS.node_ops.getattr,
  1970.                         setattr: MEMFS.node_ops.setattr
  1971.                     },
  1972.                     stream: {
  1973.                         llseek: MEMFS.stream_ops.llseek,
  1974.                         read: MEMFS.stream_ops.read,
  1975.                         write: MEMFS.stream_ops.write,
  1976.                         allocate: MEMFS.stream_ops.allocate,
  1977.                         mmap: MEMFS.stream_ops.mmap,
  1978.                         msync: MEMFS.stream_ops.msync
  1979.                     }
  1980.                 },
  1981.                 link: {
  1982.                     node: {
  1983.                         getattr: MEMFS.node_ops.getattr,
  1984.                         setattr: MEMFS.node_ops.setattr,
  1985.                         readlink: MEMFS.node_ops.readlink
  1986.                     },
  1987.                     stream: {}
  1988.                 },
  1989.                 chrdev: {
  1990.                     node: {
  1991.                         getattr: MEMFS.node_ops.getattr,
  1992.                         setattr: MEMFS.node_ops.setattr
  1993.                     },
  1994.                     stream: FS.chrdev_stream_ops
  1995.                 }
  1996.             }
  1997.         }
  1998.         var node = FS.createNode(parent, name, mode, dev);
  1999.         if (FS.isDir(node.mode)) {
  2000.             node.node_ops = MEMFS.ops_table.dir.node;
  2001.             node.stream_ops = MEMFS.ops_table.dir.stream;
  2002.             node.contents = {}
  2003.         } else if (FS.isFile(node.mode)) {
  2004.             node.node_ops = MEMFS.ops_table.file.node;
  2005.             node.stream_ops = MEMFS.ops_table.file.stream;
  2006.             node.usedBytes = 0;
  2007.             node.contents = null
  2008.         } else if (FS.isLink(node.mode)) {
  2009.             node.node_ops = MEMFS.ops_table.link.node;
  2010.             node.stream_ops = MEMFS.ops_table.link.stream
  2011.         } else if (FS.isChrdev(node.mode)) {
  2012.             node.node_ops = MEMFS.ops_table.chrdev.node;
  2013.             node.stream_ops = MEMFS.ops_table.chrdev.stream
  2014.         }
  2015.         node.timestamp = Date.now();
  2016.         if (parent) {
  2017.             parent.contents[name] = node
  2018.         }
  2019.         return node
  2020.     }),
  2021.     getFileDataAsRegularArray: (function(node) {
  2022.         if (node.contents && node.contents.subarray) {
  2023.             var arr = [];
  2024.             for (var i = 0; i < node.usedBytes; ++i) arr.push(node.contents[i]);
  2025.             return arr
  2026.         }
  2027.         return node.contents
  2028.     }),
  2029.     getFileDataAsTypedArray: (function(node) {
  2030.         if (!node.contents) return new Uint8Array;
  2031.         if (node.contents.subarray) return node.contents.subarray(0, node.usedBytes);
  2032.         return new Uint8Array(node.contents)
  2033.     }),
  2034.     expandFileStorage: (function(node, newCapacity) {
  2035.         if (node.contents && node.contents.subarray && newCapacity > node.contents.length) {
  2036.             node.contents = MEMFS.getFileDataAsRegularArray(node);
  2037.             node.usedBytes = node.contents.length
  2038.         }
  2039.         if (!node.contents || node.contents.subarray) {
  2040.             var prevCapacity = node.contents ? node.contents.length : 0;
  2041.             if (prevCapacity >= newCapacity) return;
  2042.             var CAPACITY_DOUBLING_MAX = 1024 * 1024;
  2043.             newCapacity = Math.max(newCapacity, prevCapacity * (prevCapacity < CAPACITY_DOUBLING_MAX ? 2 : 1.125) | 0);
  2044.             if (prevCapacity != 0) newCapacity = Math.max(newCapacity, 256);
  2045.             var oldContents = node.contents;
  2046.             node.contents = new Uint8Array(newCapacity);
  2047.             if (node.usedBytes > 0) node.contents.set(oldContents.subarray(0, node.usedBytes), 0);
  2048.             return
  2049.         }
  2050.         if (!node.contents && newCapacity > 0) node.contents = [];
  2051.         while (node.contents.length < newCapacity) node.contents.push(0)
  2052.     }),
  2053.     resizeFileStorage: (function(node, newSize) {
  2054.         if (node.usedBytes == newSize) return;
  2055.         if (newSize == 0) {
  2056.             node.contents = null;
  2057.             node.usedBytes = 0;
  2058.             return
  2059.         }
  2060.         if (!node.contents || node.contents.subarray) {
  2061.             var oldContents = node.contents;
  2062.             node.contents = new Uint8Array(new ArrayBuffer(newSize));
  2063.             if (oldContents) {
  2064.                 node.contents.set(oldContents.subarray(0, Math.min(newSize, node.usedBytes)))
  2065.             }
  2066.             node.usedBytes = newSize;
  2067.             return
  2068.         }
  2069.         if (!node.contents) node.contents = [];
  2070.         if (node.contents.length > newSize) node.contents.length = newSize;
  2071.         else
  2072.             while (node.contents.length < newSize) node.contents.push(0);
  2073.         node.usedBytes = newSize
  2074.     }),
  2075.     node_ops: {
  2076.         getattr: (function(node) {
  2077.             var attr = {};
  2078.             attr.dev = FS.isChrdev(node.mode) ? node.id : 1;
  2079.             attr.ino = node.id;
  2080.             attr.mode = node.mode;
  2081.             attr.nlink = 1;
  2082.             attr.uid = 0;
  2083.             attr.gid = 0;
  2084.             attr.rdev = node.rdev;
  2085.             if (FS.isDir(node.mode)) {
  2086.                 attr.size = 4096
  2087.             } else if (FS.isFile(node.mode)) {
  2088.                 attr.size = node.usedBytes
  2089.             } else if (FS.isLink(node.mode)) {
  2090.                 attr.size = node.link.length
  2091.             } else {
  2092.                 attr.size = 0
  2093.             }
  2094.             attr.atime = new Date(node.timestamp);
  2095.             attr.mtime = new Date(node.timestamp);
  2096.             attr.ctime = new Date(node.timestamp);
  2097.             attr.blksize = 4096;
  2098.             attr.blocks = Math.ceil(attr.size / attr.blksize);
  2099.             return attr
  2100.         }),
  2101.         setattr: (function(node, attr) {
  2102.             if (attr.mode !== undefined) {
  2103.                 node.mode = attr.mode
  2104.             }
  2105.             if (attr.timestamp !== undefined) {
  2106.                 node.timestamp = attr.timestamp
  2107.             }
  2108.             if (attr.size !== undefined) {
  2109.                 MEMFS.resizeFileStorage(node, attr.size)
  2110.             }
  2111.         }),
  2112.         lookup: (function(parent, name) {
  2113.             throw FS.genericErrors[ERRNO_CODES.ENOENT]
  2114.         }),
  2115.         mknod: (function(parent, name, mode, dev) {
  2116.             return MEMFS.createNode(parent, name, mode, dev)
  2117.         }),
  2118.         rename: (function(old_node, new_dir, new_name) {
  2119.             if (FS.isDir(old_node.mode)) {
  2120.                 var new_node;
  2121.                 try {
  2122.                     new_node = FS.lookupNode(new_dir, new_name)
  2123.                 } catch (e) {}
  2124.                 if (new_node) {
  2125.                     for (var i in new_node.contents) {
  2126.                         throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)
  2127.                     }
  2128.                 }
  2129.             }
  2130.             delete old_node.parent.contents[old_node.name];
  2131.             old_node.name = new_name;
  2132.             new_dir.contents[new_name] = old_node;
  2133.             old_node.parent = new_dir
  2134.         }),
  2135.         unlink: (function(parent, name) {
  2136.             delete parent.contents[name]
  2137.         }),
  2138.         rmdir: (function(parent, name) {
  2139.             var node = FS.lookupNode(parent, name);
  2140.             for (var i in node.contents) {
  2141.                 throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)
  2142.             }
  2143.             delete parent.contents[name]
  2144.         }),
  2145.         readdir: (function(node) {
  2146.             var entries = [".", ".."];
  2147.             for (var key in node.contents) {
  2148.                 if (!node.contents.hasOwnProperty(key)) {
  2149.                     continue
  2150.                 }
  2151.                 entries.push(key)
  2152.             }
  2153.             return entries
  2154.         }),
  2155.         symlink: (function(parent, newname, oldpath) {
  2156.             var node = MEMFS.createNode(parent, newname, 511 | 40960, 0);
  2157.             node.link = oldpath;
  2158.             return node
  2159.         }),
  2160.         readlink: (function(node) {
  2161.             if (!FS.isLink(node.mode)) {
  2162.                 throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  2163.             }
  2164.             return node.link
  2165.         })
  2166.     },
  2167.     stream_ops: {
  2168.         read: (function(stream, buffer, offset, length, position) {
  2169.             var contents = stream.node.contents;
  2170.             if (position >= stream.node.usedBytes) return 0;
  2171.             var size = Math.min(stream.node.usedBytes - position, length);
  2172.             assert(size >= 0);
  2173.             if (size > 8 && contents.subarray) {
  2174.                 buffer.set(contents.subarray(position, position + size), offset)
  2175.             } else {
  2176.                 for (var i = 0; i < size; i++) buffer[offset + i] = contents[position + i]
  2177.             }
  2178.             return size
  2179.         }),
  2180.         write: (function(stream, buffer, offset, length, position, canOwn) {
  2181.             if (!length) return 0;
  2182.             var node = stream.node;
  2183.             node.timestamp = Date.now();
  2184.             if (buffer.subarray && (!node.contents || node.contents.subarray)) {
  2185.                 if (canOwn) {
  2186.                     node.contents = buffer.subarray(offset, offset + length);
  2187.                     node.usedBytes = length;
  2188.                     return length
  2189.                 } else if (node.usedBytes === 0 && position === 0) {
  2190.                     node.contents = new Uint8Array(buffer.subarray(offset, offset + length));
  2191.                     node.usedBytes = length;
  2192.                     return length
  2193.                 } else if (position + length <= node.usedBytes) {
  2194.                     node.contents.set(buffer.subarray(offset, offset + length), position);
  2195.                     return length
  2196.                 }
  2197.             }
  2198.             MEMFS.expandFileStorage(node, position + length);
  2199.             if (node.contents.subarray && buffer.subarray) node.contents.set(buffer.subarray(offset, offset + length), position);
  2200.             else {
  2201.                 for (var i = 0; i < length; i++) {
  2202.                     node.contents[position + i] = buffer[offset + i]
  2203.                 }
  2204.             }
  2205.             node.usedBytes = Math.max(node.usedBytes, position + length);
  2206.             return length
  2207.         }),
  2208.         llseek: (function(stream, offset, whence) {
  2209.             var position = offset;
  2210.             if (whence === 1) {
  2211.                 position += stream.position
  2212.             } else if (whence === 2) {
  2213.                 if (FS.isFile(stream.node.mode)) {
  2214.                     position += stream.node.usedBytes
  2215.                 }
  2216.             }
  2217.             if (position < 0) {
  2218.                 throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  2219.             }
  2220.             return position
  2221.         }),
  2222.         allocate: (function(stream, offset, length) {
  2223.             MEMFS.expandFileStorage(stream.node, offset + length);
  2224.             stream.node.usedBytes = Math.max(stream.node.usedBytes, offset + length)
  2225.         }),
  2226.         mmap: (function(stream, buffer, offset, length, position, prot, flags) {
  2227.             if (!FS.isFile(stream.node.mode)) {
  2228.                 throw new FS.ErrnoError(ERRNO_CODES.ENODEV)
  2229.             }
  2230.             var ptr;
  2231.             var allocated;
  2232.             var contents = stream.node.contents;
  2233.             if (!(flags & 2) && (contents.buffer === buffer || contents.buffer === buffer.buffer)) {
  2234.                 allocated = false;
  2235.                 ptr = contents.byteOffset
  2236.             } else {
  2237.                 if (position > 0 || position + length < stream.node.usedBytes) {
  2238.                     if (contents.subarray) {
  2239.                         contents = contents.subarray(position, position + length)
  2240.                     } else {
  2241.                         contents = Array.prototype.slice.call(contents, position, position + length)
  2242.                     }
  2243.                 }
  2244.                 allocated = true;
  2245.                 ptr = _malloc(length);
  2246.                 if (!ptr) {
  2247.                     throw new FS.ErrnoError(ERRNO_CODES.ENOMEM)
  2248.                 }
  2249.                 buffer.set(contents, ptr)
  2250.             }
  2251.             return {
  2252.                 ptr: ptr,
  2253.                 allocated: allocated
  2254.             }
  2255.         }),
  2256.         msync: (function(stream, buffer, offset, length, mmapFlags) {
  2257.             if (!FS.isFile(stream.node.mode)) {
  2258.                 throw new FS.ErrnoError(ERRNO_CODES.ENODEV)
  2259.             }
  2260.             if (mmapFlags & 2) {
  2261.                 return 0
  2262.             }
  2263.             var bytesWritten = MEMFS.stream_ops.write(stream, buffer, 0, length, offset, false);
  2264.             return 0
  2265.         })
  2266.     }
  2267. };
  2268. var IDBFS = {
  2269.     dbs: {},
  2270.     indexedDB: (function() {
  2271.         if (typeof indexedDB !== "undefined") return indexedDB;
  2272.         var ret = null;
  2273.         if (typeof window === "object") ret = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB;
  2274.         assert(ret, "IDBFS used, but indexedDB not supported");
  2275.         return ret
  2276.     }),
  2277.     DB_VERSION: 21,
  2278.     DB_STORE_NAME: "FILE_DATA",
  2279.     mount: (function(mount) {
  2280.         return MEMFS.mount.apply(null, arguments)
  2281.     }),
  2282.     syncfs: (function(mount, populate, callback) {
  2283.         IDBFS.getLocalSet(mount, (function(err, local) {
  2284.             if (err) return callback(err);
  2285.             IDBFS.getRemoteSet(mount, (function(err, remote) {
  2286.                 if (err) return callback(err);
  2287.                 var src = populate ? remote : local;
  2288.                 var dst = populate ? local : remote;
  2289.                 IDBFS.reconcile(src, dst, callback)
  2290.             }))
  2291.         }))
  2292.     }),
  2293.     getDB: (function(name, callback) {
  2294.         var db = IDBFS.dbs[name];
  2295.         if (db) {
  2296.             return callback(null, db)
  2297.         }
  2298.         var req;
  2299.         try {
  2300.             req = IDBFS.indexedDB().open(name, IDBFS.DB_VERSION)
  2301.         } catch (e) {
  2302.             return callback(e)
  2303.         }
  2304.         if (!req) {
  2305.             return callback("Unable to connect to IndexedDB")
  2306.         }
  2307.         req.onupgradeneeded = (function(e) {
  2308.             var db = e.target.result;
  2309.             var transaction = e.target.transaction;
  2310.             var fileStore;
  2311.             if (db.objectStoreNames.contains(IDBFS.DB_STORE_NAME)) {
  2312.                 fileStore = transaction.objectStore(IDBFS.DB_STORE_NAME)
  2313.             } else {
  2314.                 fileStore = db.createObjectStore(IDBFS.DB_STORE_NAME)
  2315.             }
  2316.             if (!fileStore.indexNames.contains("timestamp")) {
  2317.                 fileStore.createIndex("timestamp", "timestamp", {
  2318.                     unique: false
  2319.                 })
  2320.             }
  2321.         });
  2322.         req.onsuccess = (function() {
  2323.             db = req.result;
  2324.             IDBFS.dbs[name] = db;
  2325.             callback(null, db)
  2326.         });
  2327.         req.onerror = (function(e) {
  2328.             callback(this.error);
  2329.             e.preventDefault()
  2330.         })
  2331.     }),
  2332.     getLocalSet: (function(mount, callback) {
  2333.         var entries = {};
  2334.  
  2335.         function isRealDir(p) {
  2336.             return p !== "." && p !== ".."
  2337.         }
  2338.  
  2339.         function toAbsolute(root) {
  2340.             return (function(p) {
  2341.                 return PATH.join2(root, p)
  2342.             })
  2343.         }
  2344.         var check = FS.readdir(mount.mountpoint).filter(isRealDir).map(toAbsolute(mount.mountpoint));
  2345.         while (check.length) {
  2346.             var path = check.pop();
  2347.             var stat;
  2348.             try {
  2349.                 stat = FS.stat(path)
  2350.             } catch (e) {
  2351.                 return callback(e)
  2352.             }
  2353.             if (FS.isDir(stat.mode)) {
  2354.                 check.push.apply(check, FS.readdir(path).filter(isRealDir).map(toAbsolute(path)))
  2355.             }
  2356.             entries[path] = {
  2357.                 timestamp: stat.mtime
  2358.             }
  2359.         }
  2360.         return callback(null, {
  2361.             type: "local",
  2362.             entries: entries
  2363.         })
  2364.     }),
  2365.     getRemoteSet: (function(mount, callback) {
  2366.         var entries = {};
  2367.         IDBFS.getDB(mount.mountpoint, (function(err, db) {
  2368.             if (err) return callback(err);
  2369.             var transaction = db.transaction([IDBFS.DB_STORE_NAME], "readonly");
  2370.             transaction.onerror = (function(e) {
  2371.                 callback(this.error);
  2372.                 e.preventDefault()
  2373.             });
  2374.             var store = transaction.objectStore(IDBFS.DB_STORE_NAME);
  2375.             var index = store.index("timestamp");
  2376.             index.openKeyCursor().onsuccess = (function(event) {
  2377.                 var cursor = event.target.result;
  2378.                 if (!cursor) {
  2379.                     return callback(null, {
  2380.                         type: "remote",
  2381.                         db: db,
  2382.                         entries: entries
  2383.                     })
  2384.                 }
  2385.                 entries[cursor.primaryKey] = {
  2386.                     timestamp: cursor.key
  2387.                 };
  2388.                 cursor.continue()
  2389.             })
  2390.         }))
  2391.     }),
  2392.     loadLocalEntry: (function(path, callback) {
  2393.         var stat, node;
  2394.         try {
  2395.             var lookup = FS.lookupPath(path);
  2396.             node = lookup.node;
  2397.             stat = FS.stat(path)
  2398.         } catch (e) {
  2399.             return callback(e)
  2400.         }
  2401.         if (FS.isDir(stat.mode)) {
  2402.             return callback(null, {
  2403.                 timestamp: stat.mtime,
  2404.                 mode: stat.mode
  2405.             })
  2406.         } else if (FS.isFile(stat.mode)) {
  2407.             node.contents = MEMFS.getFileDataAsTypedArray(node);
  2408.             return callback(null, {
  2409.                 timestamp: stat.mtime,
  2410.                 mode: stat.mode,
  2411.                 contents: node.contents
  2412.             })
  2413.         } else {
  2414.             return callback(new Error("node type not supported"))
  2415.         }
  2416.     }),
  2417.     storeLocalEntry: (function(path, entry, callback) {
  2418.         try {
  2419.             if (FS.isDir(entry.mode)) {
  2420.                 FS.mkdir(path, entry.mode)
  2421.             } else if (FS.isFile(entry.mode)) {
  2422.                 FS.writeFile(path, entry.contents, {
  2423.                     encoding: "binary",
  2424.                     canOwn: true
  2425.                 })
  2426.             } else {
  2427.                 return callback(new Error("node type not supported"))
  2428.             }
  2429.             FS.chmod(path, entry.mode);
  2430.             FS.utime(path, entry.timestamp, entry.timestamp)
  2431.         } catch (e) {
  2432.             return callback(e)
  2433.         }
  2434.         callback(null)
  2435.     }),
  2436.     removeLocalEntry: (function(path, callback) {
  2437.         try {
  2438.             var lookup = FS.lookupPath(path);
  2439.             var stat = FS.stat(path);
  2440.             if (FS.isDir(stat.mode)) {
  2441.                 FS.rmdir(path)
  2442.             } else if (FS.isFile(stat.mode)) {
  2443.                 FS.unlink(path)
  2444.             }
  2445.         } catch (e) {
  2446.             return callback(e)
  2447.         }
  2448.         callback(null)
  2449.     }),
  2450.     loadRemoteEntry: (function(store, path, callback) {
  2451.         var req = store.get(path);
  2452.         req.onsuccess = (function(event) {
  2453.             callback(null, event.target.result)
  2454.         });
  2455.         req.onerror = (function(e) {
  2456.             callback(this.error);
  2457.             e.preventDefault()
  2458.         })
  2459.     }),
  2460.     storeRemoteEntry: (function(store, path, entry, callback) {
  2461.         var req = store.put(entry, path);
  2462.         req.onsuccess = (function() {
  2463.             callback(null)
  2464.         });
  2465.         req.onerror = (function(e) {
  2466.             callback(this.error);
  2467.             e.preventDefault()
  2468.         })
  2469.     }),
  2470.     removeRemoteEntry: (function(store, path, callback) {
  2471.         var req = store.delete(path);
  2472.         req.onsuccess = (function() {
  2473.             callback(null)
  2474.         });
  2475.         req.onerror = (function(e) {
  2476.             callback(this.error);
  2477.             e.preventDefault()
  2478.         })
  2479.     }),
  2480.     reconcile: (function(src, dst, callback) {
  2481.         var total = 0;
  2482.         var create = [];
  2483.         Object.keys(src.entries).forEach((function(key) {
  2484.             var e = src.entries[key];
  2485.             var e2 = dst.entries[key];
  2486.             if (!e2 || e.timestamp > e2.timestamp) {
  2487.                 create.push(key);
  2488.                 total++
  2489.             }
  2490.         }));
  2491.         var remove = [];
  2492.         Object.keys(dst.entries).forEach((function(key) {
  2493.             var e = dst.entries[key];
  2494.             var e2 = src.entries[key];
  2495.             if (!e2) {
  2496.                 remove.push(key);
  2497.                 total++
  2498.             }
  2499.         }));
  2500.         if (!total) {
  2501.             return callback(null)
  2502.         }
  2503.         var completed = 0;
  2504.         var db = src.type === "remote" ? src.db : dst.db;
  2505.         var transaction = db.transaction([IDBFS.DB_STORE_NAME], "readwrite");
  2506.         var store = transaction.objectStore(IDBFS.DB_STORE_NAME);
  2507.  
  2508.         function done(err) {
  2509.             if (err) {
  2510.                 if (!done.errored) {
  2511.                     done.errored = true;
  2512.                     return callback(err)
  2513.                 }
  2514.                 return
  2515.             }
  2516.             if (++completed >= total) {
  2517.                 return callback(null)
  2518.             }
  2519.         }
  2520.         transaction.onerror = (function(e) {
  2521.             done(this.error);
  2522.             e.preventDefault()
  2523.         });
  2524.         create.sort().forEach((function(path) {
  2525.             if (dst.type === "local") {
  2526.                 IDBFS.loadRemoteEntry(store, path, (function(err, entry) {
  2527.                     if (err) return done(err);
  2528.                     IDBFS.storeLocalEntry(path, entry, done)
  2529.                 }))
  2530.             } else {
  2531.                 IDBFS.loadLocalEntry(path, (function(err, entry) {
  2532.                     if (err) return done(err);
  2533.                     IDBFS.storeRemoteEntry(store, path, entry, done)
  2534.                 }))
  2535.             }
  2536.         }));
  2537.         remove.sort().reverse().forEach((function(path) {
  2538.             if (dst.type === "local") {
  2539.                 IDBFS.removeLocalEntry(path, done)
  2540.             } else {
  2541.                 IDBFS.removeRemoteEntry(store, path, done)
  2542.             }
  2543.         }))
  2544.     })
  2545. };
  2546. var NODEFS = {
  2547.     isWindows: false,
  2548.     staticInit: (function() {
  2549.         NODEFS.isWindows = !!process.platform.match(/^win/)
  2550.     }),
  2551.     mount: (function(mount) {
  2552.         assert(ENVIRONMENT_IS_NODE);
  2553.         return NODEFS.createNode(null, "/", NODEFS.getMode(mount.opts.root), 0)
  2554.     }),
  2555.     createNode: (function(parent, name, mode, dev) {
  2556.         if (!FS.isDir(mode) && !FS.isFile(mode) && !FS.isLink(mode)) {
  2557.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  2558.         }
  2559.         var node = FS.createNode(parent, name, mode);
  2560.         node.node_ops = NODEFS.node_ops;
  2561.         node.stream_ops = NODEFS.stream_ops;
  2562.         return node
  2563.     }),
  2564.     getMode: (function(path) {
  2565.         var stat;
  2566.         try {
  2567.             stat = fs.lstatSync(path);
  2568.             if (NODEFS.isWindows) {
  2569.                 stat.mode = stat.mode | (stat.mode & 146) >> 1
  2570.             }
  2571.         } catch (e) {
  2572.             if (!e.code) throw e;
  2573.             throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2574.         }
  2575.         return stat.mode
  2576.     }),
  2577.     realPath: (function(node) {
  2578.         var parts = [];
  2579.         while (node.parent !== node) {
  2580.             parts.push(node.name);
  2581.             node = node.parent
  2582.         }
  2583.         parts.push(node.mount.opts.root);
  2584.         parts.reverse();
  2585.         return PATH.join.apply(null, parts)
  2586.     }),
  2587.     flagsToPermissionStringMap: {
  2588.         0: "r",
  2589.         1: "r+",
  2590.         2: "r+",
  2591.         64: "r",
  2592.         65: "r+",
  2593.         66: "r+",
  2594.         129: "rx+",
  2595.         193: "rx+",
  2596.         514: "w+",
  2597.         577: "w",
  2598.         578: "w+",
  2599.         705: "wx",
  2600.         706: "wx+",
  2601.         1024: "a",
  2602.         1025: "a",
  2603.         1026: "a+",
  2604.         1089: "a",
  2605.         1090: "a+",
  2606.         1153: "ax",
  2607.         1154: "ax+",
  2608.         1217: "ax",
  2609.         1218: "ax+",
  2610.         4096: "rs",
  2611.         4098: "rs+"
  2612.     },
  2613.     flagsToPermissionString: (function(flags) {
  2614.         flags &= ~2097152;
  2615.         flags &= ~2048;
  2616.         flags &= ~32768;
  2617.         flags &= ~524288;
  2618.         if (flags in NODEFS.flagsToPermissionStringMap) {
  2619.             return NODEFS.flagsToPermissionStringMap[flags]
  2620.         } else {
  2621.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  2622.         }
  2623.     }),
  2624.     node_ops: {
  2625.         getattr: (function(node) {
  2626.             var path = NODEFS.realPath(node);
  2627.             var stat;
  2628.             try {
  2629.                 stat = fs.lstatSync(path)
  2630.             } catch (e) {
  2631.                 if (!e.code) throw e;
  2632.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2633.             }
  2634.             if (NODEFS.isWindows && !stat.blksize) {
  2635.                 stat.blksize = 4096
  2636.             }
  2637.             if (NODEFS.isWindows && !stat.blocks) {
  2638.                 stat.blocks = (stat.size + stat.blksize - 1) / stat.blksize | 0
  2639.             }
  2640.             return {
  2641.                 dev: stat.dev,
  2642.                 ino: stat.ino,
  2643.                 mode: stat.mode,
  2644.                 nlink: stat.nlink,
  2645.                 uid: stat.uid,
  2646.                 gid: stat.gid,
  2647.                 rdev: stat.rdev,
  2648.                 size: stat.size,
  2649.                 atime: stat.atime,
  2650.                 mtime: stat.mtime,
  2651.                 ctime: stat.ctime,
  2652.                 blksize: stat.blksize,
  2653.                 blocks: stat.blocks
  2654.             }
  2655.         }),
  2656.         setattr: (function(node, attr) {
  2657.             var path = NODEFS.realPath(node);
  2658.             try {
  2659.                 if (attr.mode !== undefined) {
  2660.                     fs.chmodSync(path, attr.mode);
  2661.                     node.mode = attr.mode
  2662.                 }
  2663.                 if (attr.timestamp !== undefined) {
  2664.                     var date = new Date(attr.timestamp);
  2665.                     fs.utimesSync(path, date, date)
  2666.                 }
  2667.                 if (attr.size !== undefined) {
  2668.                     fs.truncateSync(path, attr.size)
  2669.                 }
  2670.             } catch (e) {
  2671.                 if (!e.code) throw e;
  2672.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2673.             }
  2674.         }),
  2675.         lookup: (function(parent, name) {
  2676.             var path = PATH.join2(NODEFS.realPath(parent), name);
  2677.             var mode = NODEFS.getMode(path);
  2678.             return NODEFS.createNode(parent, name, mode)
  2679.         }),
  2680.         mknod: (function(parent, name, mode, dev) {
  2681.             var node = NODEFS.createNode(parent, name, mode, dev);
  2682.             var path = NODEFS.realPath(node);
  2683.             try {
  2684.                 if (FS.isDir(node.mode)) {
  2685.                     fs.mkdirSync(path, node.mode)
  2686.                 } else {
  2687.                     fs.writeFileSync(path, "", {
  2688.                         mode: node.mode
  2689.                     })
  2690.                 }
  2691.             } catch (e) {
  2692.                 if (!e.code) throw e;
  2693.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2694.             }
  2695.             return node
  2696.         }),
  2697.         rename: (function(oldNode, newDir, newName) {
  2698.             var oldPath = NODEFS.realPath(oldNode);
  2699.             var newPath = PATH.join2(NODEFS.realPath(newDir), newName);
  2700.             try {
  2701.                 fs.renameSync(oldPath, newPath)
  2702.             } catch (e) {
  2703.                 if (!e.code) throw e;
  2704.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2705.             }
  2706.         }),
  2707.         unlink: (function(parent, name) {
  2708.             var path = PATH.join2(NODEFS.realPath(parent), name);
  2709.             try {
  2710.                 fs.unlinkSync(path)
  2711.             } catch (e) {
  2712.                 if (!e.code) throw e;
  2713.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2714.             }
  2715.         }),
  2716.         rmdir: (function(parent, name) {
  2717.             var path = PATH.join2(NODEFS.realPath(parent), name);
  2718.             try {
  2719.                 fs.rmdirSync(path)
  2720.             } catch (e) {
  2721.                 if (!e.code) throw e;
  2722.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2723.             }
  2724.         }),
  2725.         readdir: (function(node) {
  2726.             var path = NODEFS.realPath(node);
  2727.             try {
  2728.                 return fs.readdirSync(path)
  2729.             } catch (e) {
  2730.                 if (!e.code) throw e;
  2731.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2732.             }
  2733.         }),
  2734.         symlink: (function(parent, newName, oldPath) {
  2735.             var newPath = PATH.join2(NODEFS.realPath(parent), newName);
  2736.             try {
  2737.                 fs.symlinkSync(oldPath, newPath)
  2738.             } catch (e) {
  2739.                 if (!e.code) throw e;
  2740.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2741.             }
  2742.         }),
  2743.         readlink: (function(node) {
  2744.             var path = NODEFS.realPath(node);
  2745.             try {
  2746.                 path = fs.readlinkSync(path);
  2747.                 path = NODEJS_PATH.relative(NODEJS_PATH.resolve(node.mount.opts.root), path);
  2748.                 return path
  2749.             } catch (e) {
  2750.                 if (!e.code) throw e;
  2751.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2752.             }
  2753.         })
  2754.     },
  2755.     stream_ops: {
  2756.         open: (function(stream) {
  2757.             var path = NODEFS.realPath(stream.node);
  2758.             try {
  2759.                 if (FS.isFile(stream.node.mode)) {
  2760.                     stream.nfd = fs.openSync(path, NODEFS.flagsToPermissionString(stream.flags))
  2761.                 }
  2762.             } catch (e) {
  2763.                 if (!e.code) throw e;
  2764.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2765.             }
  2766.         }),
  2767.         close: (function(stream) {
  2768.             try {
  2769.                 if (FS.isFile(stream.node.mode) && stream.nfd) {
  2770.                     fs.closeSync(stream.nfd)
  2771.                 }
  2772.             } catch (e) {
  2773.                 if (!e.code) throw e;
  2774.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2775.             }
  2776.         }),
  2777.         read: (function(stream, buffer, offset, length, position) {
  2778.             if (length === 0) return 0;
  2779.             var nbuffer = new Buffer(length);
  2780.             var res;
  2781.             try {
  2782.                 res = fs.readSync(stream.nfd, nbuffer, 0, length, position)
  2783.             } catch (e) {
  2784.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2785.             }
  2786.             if (res > 0) {
  2787.                 for (var i = 0; i < res; i++) {
  2788.                     buffer[offset + i] = nbuffer[i]
  2789.                 }
  2790.             }
  2791.             return res
  2792.         }),
  2793.         write: (function(stream, buffer, offset, length, position) {
  2794.             var nbuffer = new Buffer(buffer.subarray(offset, offset + length));
  2795.             var res;
  2796.             try {
  2797.                 res = fs.writeSync(stream.nfd, nbuffer, 0, length, position)
  2798.             } catch (e) {
  2799.                 throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2800.             }
  2801.             return res
  2802.         }),
  2803.         llseek: (function(stream, offset, whence) {
  2804.             var position = offset;
  2805.             if (whence === 1) {
  2806.                 position += stream.position
  2807.             } else if (whence === 2) {
  2808.                 if (FS.isFile(stream.node.mode)) {
  2809.                     try {
  2810.                         var stat = fs.fstatSync(stream.nfd);
  2811.                         position += stat.size
  2812.                     } catch (e) {
  2813.                         throw new FS.ErrnoError(ERRNO_CODES[e.code])
  2814.                     }
  2815.                 }
  2816.             }
  2817.             if (position < 0) {
  2818.                 throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  2819.             }
  2820.             return position
  2821.         })
  2822.     }
  2823. };
  2824. var WORKERFS = {
  2825.     DIR_MODE: 16895,
  2826.     FILE_MODE: 33279,
  2827.     reader: null,
  2828.     mount: (function(mount) {
  2829.         assert(ENVIRONMENT_IS_WORKER);
  2830.         if (!WORKERFS.reader) WORKERFS.reader = new FileReaderSync;
  2831.         var root = WORKERFS.createNode(null, "/", WORKERFS.DIR_MODE, 0);
  2832.         var createdParents = {};
  2833.  
  2834.         function ensureParent(path) {
  2835.             var parts = path.split("/");
  2836.             var parent = root;
  2837.             for (var i = 0; i < parts.length - 1; i++) {
  2838.                 var curr = parts.slice(0, i + 1).join("/");
  2839.                 if (!createdParents[curr]) {
  2840.                     createdParents[curr] = WORKERFS.createNode(parent, parts[i], WORKERFS.DIR_MODE, 0)
  2841.                 }
  2842.                 parent = createdParents[curr]
  2843.             }
  2844.             return parent
  2845.         }
  2846.  
  2847.         function base(path) {
  2848.             var parts = path.split("/");
  2849.             return parts[parts.length - 1]
  2850.         }
  2851.         Array.prototype.forEach.call(mount.opts["files"] || [], (function(file) {
  2852.             WORKERFS.createNode(ensureParent(file.name), base(file.name), WORKERFS.FILE_MODE, 0, file, file.lastModifiedDate)
  2853.         }));
  2854.         (mount.opts["blobs"] || []).forEach((function(obj) {
  2855.             WORKERFS.createNode(ensureParent(obj["name"]), base(obj["name"]), WORKERFS.FILE_MODE, 0, obj["data"])
  2856.         }));
  2857.         (mount.opts["packages"] || []).forEach((function(pack) {
  2858.             pack["metadata"].files.forEach((function(file) {
  2859.                 var name = file.filename.substr(1);
  2860.                 WORKERFS.createNode(ensureParent(name), base(name), WORKERFS.FILE_MODE, 0, pack["blob"].slice(file.start, file.end))
  2861.             }))
  2862.         }));
  2863.         return root
  2864.     }),
  2865.     createNode: (function(parent, name, mode, dev, contents, mtime) {
  2866.         var node = FS.createNode(parent, name, mode);
  2867.         node.mode = mode;
  2868.         node.node_ops = WORKERFS.node_ops;
  2869.         node.stream_ops = WORKERFS.stream_ops;
  2870.         node.timestamp = (mtime || new Date).getTime();
  2871.         assert(WORKERFS.FILE_MODE !== WORKERFS.DIR_MODE);
  2872.         if (mode === WORKERFS.FILE_MODE) {
  2873.             node.size = contents.size;
  2874.             node.contents = contents
  2875.         } else {
  2876.             node.size = 4096;
  2877.             node.contents = {}
  2878.         }
  2879.         if (parent) {
  2880.             parent.contents[name] = node
  2881.         }
  2882.         return node
  2883.     }),
  2884.     node_ops: {
  2885.         getattr: (function(node) {
  2886.             return {
  2887.                 dev: 1,
  2888.                 ino: undefined,
  2889.                 mode: node.mode,
  2890.                 nlink: 1,
  2891.                 uid: 0,
  2892.                 gid: 0,
  2893.                 rdev: undefined,
  2894.                 size: node.size,
  2895.                 atime: new Date(node.timestamp),
  2896.                 mtime: new Date(node.timestamp),
  2897.                 ctime: new Date(node.timestamp),
  2898.                 blksize: 4096,
  2899.                 blocks: Math.ceil(node.size / 4096)
  2900.             }
  2901.         }),
  2902.         setattr: (function(node, attr) {
  2903.             if (attr.mode !== undefined) {
  2904.                 node.mode = attr.mode
  2905.             }
  2906.             if (attr.timestamp !== undefined) {
  2907.                 node.timestamp = attr.timestamp
  2908.             }
  2909.         }),
  2910.         lookup: (function(parent, name) {
  2911.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  2912.         }),
  2913.         mknod: (function(parent, name, mode, dev) {
  2914.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  2915.         }),
  2916.         rename: (function(oldNode, newDir, newName) {
  2917.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  2918.         }),
  2919.         unlink: (function(parent, name) {
  2920.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  2921.         }),
  2922.         rmdir: (function(parent, name) {
  2923.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  2924.         }),
  2925.         readdir: (function(node) {
  2926.             var entries = [".", ".."];
  2927.             for (var key in node.contents) {
  2928.                 if (!node.contents.hasOwnProperty(key)) {
  2929.                     continue
  2930.                 }
  2931.                 entries.push(key)
  2932.             }
  2933.             return entries
  2934.         }),
  2935.         symlink: (function(parent, newName, oldPath) {
  2936.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  2937.         }),
  2938.         readlink: (function(node) {
  2939.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  2940.         })
  2941.     },
  2942.     stream_ops: {
  2943.         read: (function(stream, buffer, offset, length, position) {
  2944.             if (position >= stream.node.size) return 0;
  2945.             var chunk = stream.node.contents.slice(position, position + length);
  2946.             var ab = WORKERFS.reader.readAsArrayBuffer(chunk);
  2947.             buffer.set(new Uint8Array(ab), offset);
  2948.             return chunk.size
  2949.         }),
  2950.         write: (function(stream, buffer, offset, length, position) {
  2951.             throw new FS.ErrnoError(ERRNO_CODES.EIO)
  2952.         }),
  2953.         llseek: (function(stream, offset, whence) {
  2954.             var position = offset;
  2955.             if (whence === 1) {
  2956.                 position += stream.position
  2957.             } else if (whence === 2) {
  2958.                 if (FS.isFile(stream.node.mode)) {
  2959.                     position += stream.node.size
  2960.                 }
  2961.             }
  2962.             if (position < 0) {
  2963.                 throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  2964.             }
  2965.             return position
  2966.         })
  2967.     }
  2968. };
  2969. STATICTOP += 16;
  2970. STATICTOP += 16;
  2971. STATICTOP += 16;
  2972. var FS = {
  2973.     root: null,
  2974.     mounts: [],
  2975.     devices: [null],
  2976.     streams: [],
  2977.     nextInode: 1,
  2978.     nameTable: null,
  2979.     currentPath: "/",
  2980.     initialized: false,
  2981.     ignorePermissions: true,
  2982.     trackingDelegate: {},
  2983.     tracking: {
  2984.         openFlags: {
  2985.             READ: 1,
  2986.             WRITE: 2
  2987.         }
  2988.     },
  2989.     ErrnoError: null,
  2990.     genericErrors: {},
  2991.     filesystems: null,
  2992.     syncFSRequests: 0,
  2993.     handleFSError: (function(e) {
  2994.         if (!(e instanceof FS.ErrnoError)) throw e + " : " + stackTrace();
  2995.         return ___setErrNo(e.errno)
  2996.     }),
  2997.     lookupPath: (function(path, opts) {
  2998.         path = PATH.resolve(FS.cwd(), path);
  2999.         opts = opts || {};
  3000.         if (!path) return {
  3001.             path: "",
  3002.             node: null
  3003.         };
  3004.         var defaults = {
  3005.             follow_mount: true,
  3006.             recurse_count: 0
  3007.         };
  3008.         for (var key in defaults) {
  3009.             if (opts[key] === undefined) {
  3010.                 opts[key] = defaults[key]
  3011.             }
  3012.         }
  3013.         if (opts.recurse_count > 8) {
  3014.             throw new FS.ErrnoError(ERRNO_CODES.ELOOP)
  3015.         }
  3016.         var parts = PATH.normalizeArray(path.split("/").filter((function(p) {
  3017.             return !!p
  3018.         })), false);
  3019.         var current = FS.root;
  3020.         var current_path = "/";
  3021.         for (var i = 0; i < parts.length; i++) {
  3022.             var islast = i === parts.length - 1;
  3023.             if (islast && opts.parent) {
  3024.                 break
  3025.             }
  3026.             current = FS.lookupNode(current, parts[i]);
  3027.             current_path = PATH.join2(current_path, parts[i]);
  3028.             if (FS.isMountpoint(current)) {
  3029.                 if (!islast || islast && opts.follow_mount) {
  3030.                     current = current.mounted.root
  3031.                 }
  3032.             }
  3033.             if (!islast || opts.follow) {
  3034.                 var count = 0;
  3035.                 while (FS.isLink(current.mode)) {
  3036.                     var link = FS.readlink(current_path);
  3037.                     current_path = PATH.resolve(PATH.dirname(current_path), link);
  3038.                     var lookup = FS.lookupPath(current_path, {
  3039.                         recurse_count: opts.recurse_count
  3040.                     });
  3041.                     current = lookup.node;
  3042.                     if (count++ > 40) {
  3043.                         throw new FS.ErrnoError(ERRNO_CODES.ELOOP)
  3044.                     }
  3045.                 }
  3046.             }
  3047.         }
  3048.         return {
  3049.             path: current_path,
  3050.             node: current
  3051.         }
  3052.     }),
  3053.     getPath: (function(node) {
  3054.         var path;
  3055.         while (true) {
  3056.             if (FS.isRoot(node)) {
  3057.                 var mount = node.mount.mountpoint;
  3058.                 if (!path) return mount;
  3059.                 return mount[mount.length - 1] !== "/" ? mount + "/" + path : mount + path
  3060.             }
  3061.             path = path ? node.name + "/" + path : node.name;
  3062.             node = node.parent
  3063.         }
  3064.     }),
  3065.     hashName: (function(parentid, name) {
  3066.         var hash = 0;
  3067.         for (var i = 0; i < name.length; i++) {
  3068.             hash = (hash << 5) - hash + name.charCodeAt(i) | 0
  3069.         }
  3070.         return (parentid + hash >>> 0) % FS.nameTable.length
  3071.     }),
  3072.     hashAddNode: (function(node) {
  3073.         var hash = FS.hashName(node.parent.id, node.name);
  3074.         node.name_next = FS.nameTable[hash];
  3075.         FS.nameTable[hash] = node
  3076.     }),
  3077.     hashRemoveNode: (function(node) {
  3078.         var hash = FS.hashName(node.parent.id, node.name);
  3079.         if (FS.nameTable[hash] === node) {
  3080.             FS.nameTable[hash] = node.name_next
  3081.         } else {
  3082.             var current = FS.nameTable[hash];
  3083.             while (current) {
  3084.                 if (current.name_next === node) {
  3085.                     current.name_next = node.name_next;
  3086.                     break
  3087.                 }
  3088.                 current = current.name_next
  3089.             }
  3090.         }
  3091.     }),
  3092.     lookupNode: (function(parent, name) {
  3093.         var err = FS.mayLookup(parent);
  3094.         if (err) {
  3095.             throw new FS.ErrnoError(err, parent)
  3096.         }
  3097.         var hash = FS.hashName(parent.id, name);
  3098.         for (var node = FS.nameTable[hash]; node; node = node.name_next) {
  3099.             var nodeName = node.name;
  3100.             if (node.parent.id === parent.id && nodeName === name) {
  3101.                 return node
  3102.             }
  3103.         }
  3104.         return FS.lookup(parent, name)
  3105.     }),
  3106.     createNode: (function(parent, name, mode, rdev) {
  3107.         if (!FS.FSNode) {
  3108.             FS.FSNode = (function(parent, name, mode, rdev) {
  3109.                 if (!parent) {
  3110.                     parent = this
  3111.                 }
  3112.                 this.parent = parent;
  3113.                 this.mount = parent.mount;
  3114.                 this.mounted = null;
  3115.                 this.id = FS.nextInode++;
  3116.                 this.name = name;
  3117.                 this.mode = mode;
  3118.                 this.node_ops = {};
  3119.                 this.stream_ops = {};
  3120.                 this.rdev = rdev
  3121.             });
  3122.             FS.FSNode.prototype = {};
  3123.             var readMode = 292 | 73;
  3124.             var writeMode = 146;
  3125.             Object.defineProperties(FS.FSNode.prototype, {
  3126.                 read: {
  3127.                     get: (function() {
  3128.                         return (this.mode & readMode) === readMode
  3129.                     }),
  3130.                     set: (function(val) {
  3131.                         val ? this.mode |= readMode : this.mode &= ~readMode
  3132.                     })
  3133.                 },
  3134.                 write: {
  3135.                     get: (function() {
  3136.                         return (this.mode & writeMode) === writeMode
  3137.                     }),
  3138.                     set: (function(val) {
  3139.                         val ? this.mode |= writeMode : this.mode &= ~writeMode
  3140.                     })
  3141.                 },
  3142.                 isFolder: {
  3143.                     get: (function() {
  3144.                         return FS.isDir(this.mode)
  3145.                     })
  3146.                 },
  3147.                 isDevice: {
  3148.                     get: (function() {
  3149.                         return FS.isChrdev(this.mode)
  3150.                     })
  3151.                 }
  3152.             })
  3153.         }
  3154.         var node = new FS.FSNode(parent, name, mode, rdev);
  3155.         FS.hashAddNode(node);
  3156.         return node
  3157.     }),
  3158.     destroyNode: (function(node) {
  3159.         FS.hashRemoveNode(node)
  3160.     }),
  3161.     isRoot: (function(node) {
  3162.         return node === node.parent
  3163.     }),
  3164.     isMountpoint: (function(node) {
  3165.         return !!node.mounted
  3166.     }),
  3167.     isFile: (function(mode) {
  3168.         return (mode & 61440) === 32768
  3169.     }),
  3170.     isDir: (function(mode) {
  3171.         return (mode & 61440) === 16384
  3172.     }),
  3173.     isLink: (function(mode) {
  3174.         return (mode & 61440) === 40960
  3175.     }),
  3176.     isChrdev: (function(mode) {
  3177.         return (mode & 61440) === 8192
  3178.     }),
  3179.     isBlkdev: (function(mode) {
  3180.         return (mode & 61440) === 24576
  3181.     }),
  3182.     isFIFO: (function(mode) {
  3183.         return (mode & 61440) === 4096
  3184.     }),
  3185.     isSocket: (function(mode) {
  3186.         return (mode & 49152) === 49152
  3187.     }),
  3188.     flagModes: {
  3189.         "r": 0,
  3190.         "rs": 1052672,
  3191.         "r+": 2,
  3192.         "w": 577,
  3193.         "wx": 705,
  3194.         "xw": 705,
  3195.         "w+": 578,
  3196.         "wx+": 706,
  3197.         "xw+": 706,
  3198.         "a": 1089,
  3199.         "ax": 1217,
  3200.         "xa": 1217,
  3201.         "a+": 1090,
  3202.         "ax+": 1218,
  3203.         "xa+": 1218
  3204.     },
  3205.     modeStringToFlags: (function(str) {
  3206.         var flags = FS.flagModes[str];
  3207.         if (typeof flags === "undefined") {
  3208.             throw new Error("Unknown file open mode: " + str)
  3209.         }
  3210.         return flags
  3211.     }),
  3212.     flagsToPermissionString: (function(flag) {
  3213.         var perms = ["r", "w", "rw"][flag & 3];
  3214.         if (flag & 512) {
  3215.             perms += "w"
  3216.         }
  3217.         return perms
  3218.     }),
  3219.     nodePermissions: (function(node, perms) {
  3220.         if (FS.ignorePermissions) {
  3221.             return 0
  3222.         }
  3223.         if (perms.indexOf("r") !== -1 && !(node.mode & 292)) {
  3224.             return ERRNO_CODES.EACCES
  3225.         } else if (perms.indexOf("w") !== -1 && !(node.mode & 146)) {
  3226.             return ERRNO_CODES.EACCES
  3227.         } else if (perms.indexOf("x") !== -1 && !(node.mode & 73)) {
  3228.             return ERRNO_CODES.EACCES
  3229.         }
  3230.         return 0
  3231.     }),
  3232.     mayLookup: (function(dir) {
  3233.         var err = FS.nodePermissions(dir, "x");
  3234.         if (err) return err;
  3235.         if (!dir.node_ops.lookup) return ERRNO_CODES.EACCES;
  3236.         return 0
  3237.     }),
  3238.     mayCreate: (function(dir, name) {
  3239.         try {
  3240.             var node = FS.lookupNode(dir, name);
  3241.             return ERRNO_CODES.EEXIST
  3242.         } catch (e) {}
  3243.         return FS.nodePermissions(dir, "wx")
  3244.     }),
  3245.     mayDelete: (function(dir, name, isdir) {
  3246.         var node;
  3247.         try {
  3248.             node = FS.lookupNode(dir, name)
  3249.         } catch (e) {
  3250.             return e.errno
  3251.         }
  3252.         var err = FS.nodePermissions(dir, "wx");
  3253.         if (err) {
  3254.             return err
  3255.         }
  3256.         if (isdir) {
  3257.             if (!FS.isDir(node.mode)) {
  3258.                 return ERRNO_CODES.ENOTDIR
  3259.             }
  3260.             if (FS.isRoot(node) || FS.getPath(node) === FS.cwd()) {
  3261.                 return ERRNO_CODES.EBUSY
  3262.             }
  3263.         } else {
  3264.             if (FS.isDir(node.mode)) {
  3265.                 return ERRNO_CODES.EISDIR
  3266.             }
  3267.         }
  3268.         return 0
  3269.     }),
  3270.     mayOpen: (function(node, flags) {
  3271.         if (!node) {
  3272.             return ERRNO_CODES.ENOENT
  3273.         }
  3274.         if (FS.isLink(node.mode)) {
  3275.             return ERRNO_CODES.ELOOP
  3276.         } else if (FS.isDir(node.mode)) {
  3277.             if (FS.flagsToPermissionString(flags) !== "r" || flags & 512) {
  3278.                 return ERRNO_CODES.EISDIR
  3279.             }
  3280.         }
  3281.         return FS.nodePermissions(node, FS.flagsToPermissionString(flags))
  3282.     }),
  3283.     MAX_OPEN_FDS: 4096,
  3284.     nextfd: (function(fd_start, fd_end) {
  3285.         fd_start = fd_start || 0;
  3286.         fd_end = fd_end || FS.MAX_OPEN_FDS;
  3287.         for (var fd = fd_start; fd <= fd_end; fd++) {
  3288.             if (!FS.streams[fd]) {
  3289.                 return fd
  3290.             }
  3291.         }
  3292.         throw new FS.ErrnoError(ERRNO_CODES.EMFILE)
  3293.     }),
  3294.     getStream: (function(fd) {
  3295.         return FS.streams[fd]
  3296.     }),
  3297.     createStream: (function(stream, fd_start, fd_end) {
  3298.         if (!FS.FSStream) {
  3299.             FS.FSStream = (function() {});
  3300.             FS.FSStream.prototype = {};
  3301.             Object.defineProperties(FS.FSStream.prototype, {
  3302.                 object: {
  3303.                     get: (function() {
  3304.                         return this.node
  3305.                     }),
  3306.                     set: (function(val) {
  3307.                         this.node = val
  3308.                     })
  3309.                 },
  3310.                 isRead: {
  3311.                     get: (function() {
  3312.                         return (this.flags & 2097155) !== 1
  3313.                     })
  3314.                 },
  3315.                 isWrite: {
  3316.                     get: (function() {
  3317.                         return (this.flags & 2097155) !== 0
  3318.                     })
  3319.                 },
  3320.                 isAppend: {
  3321.                     get: (function() {
  3322.                         return this.flags & 1024
  3323.                     })
  3324.                 }
  3325.             })
  3326.         }
  3327.         var newStream = new FS.FSStream;
  3328.         for (var p in stream) {
  3329.             newStream[p] = stream[p]
  3330.         }
  3331.         stream = newStream;
  3332.         var fd = FS.nextfd(fd_start, fd_end);
  3333.         stream.fd = fd;
  3334.         FS.streams[fd] = stream;
  3335.         return stream
  3336.     }),
  3337.     closeStream: (function(fd) {
  3338.         FS.streams[fd] = null
  3339.     }),
  3340.     chrdev_stream_ops: {
  3341.         open: (function(stream) {
  3342.             var device = FS.getDevice(stream.node.rdev);
  3343.             stream.stream_ops = device.stream_ops;
  3344.             if (stream.stream_ops.open) {
  3345.                 stream.stream_ops.open(stream)
  3346.             }
  3347.         }),
  3348.         llseek: (function() {
  3349.             throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)
  3350.         })
  3351.     },
  3352.     major: (function(dev) {
  3353.         return dev >> 8
  3354.     }),
  3355.     minor: (function(dev) {
  3356.         return dev & 255
  3357.     }),
  3358.     makedev: (function(ma, mi) {
  3359.         return ma << 8 | mi
  3360.     }),
  3361.     registerDevice: (function(dev, ops) {
  3362.         FS.devices[dev] = {
  3363.             stream_ops: ops
  3364.         }
  3365.     }),
  3366.     getDevice: (function(dev) {
  3367.         return FS.devices[dev]
  3368.     }),
  3369.     getMounts: (function(mount) {
  3370.         var mounts = [];
  3371.         var check = [mount];
  3372.         while (check.length) {
  3373.             var m = check.pop();
  3374.             mounts.push(m);
  3375.             check.push.apply(check, m.mounts)
  3376.         }
  3377.         return mounts
  3378.     }),
  3379.     syncfs: (function(populate, callback) {
  3380.         if (typeof populate === "function") {
  3381.             callback = populate;
  3382.             populate = false
  3383.         }
  3384.         FS.syncFSRequests++;
  3385.         if (FS.syncFSRequests > 1) {
  3386.             console.log("warning: " + FS.syncFSRequests + " FS.syncfs operations in flight at once, probably just doing extra work")
  3387.         }
  3388.         var mounts = FS.getMounts(FS.root.mount);
  3389.         var completed = 0;
  3390.  
  3391.         function doCallback(err) {
  3392.             assert(FS.syncFSRequests > 0);
  3393.             FS.syncFSRequests--;
  3394.             return callback(err)
  3395.         }
  3396.  
  3397.         function done(err) {
  3398.             if (err) {
  3399.                 if (!done.errored) {
  3400.                     done.errored = true;
  3401.                     return doCallback(err)
  3402.                 }
  3403.                 return
  3404.             }
  3405.             if (++completed >= mounts.length) {
  3406.                 doCallback(null)
  3407.             }
  3408.         }
  3409.         mounts.forEach((function(mount) {
  3410.             if (!mount.type.syncfs) {
  3411.                 return done(null)
  3412.             }
  3413.             mount.type.syncfs(mount, populate, done)
  3414.         }))
  3415.     }),
  3416.     mount: (function(type, opts, mountpoint) {
  3417.         var root = mountpoint === "/";
  3418.         var pseudo = !mountpoint;
  3419.         var node;
  3420.         if (root && FS.root) {
  3421.             throw new FS.ErrnoError(ERRNO_CODES.EBUSY)
  3422.         } else if (!root && !pseudo) {
  3423.             var lookup = FS.lookupPath(mountpoint, {
  3424.                 follow_mount: false
  3425.             });
  3426.             mountpoint = lookup.path;
  3427.             node = lookup.node;
  3428.             if (FS.isMountpoint(node)) {
  3429.                 throw new FS.ErrnoError(ERRNO_CODES.EBUSY)
  3430.             }
  3431.             if (!FS.isDir(node.mode)) {
  3432.                 throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)
  3433.             }
  3434.         }
  3435.         var mount = {
  3436.             type: type,
  3437.             opts: opts,
  3438.             mountpoint: mountpoint,
  3439.             mounts: []
  3440.         };
  3441.         var mountRoot = type.mount(mount);
  3442.         mountRoot.mount = mount;
  3443.         mount.root = mountRoot;
  3444.         if (root) {
  3445.             FS.root = mountRoot
  3446.         } else if (node) {
  3447.             node.mounted = mount;
  3448.             if (node.mount) {
  3449.                 node.mount.mounts.push(mount)
  3450.             }
  3451.         }
  3452.         return mountRoot
  3453.     }),
  3454.     unmount: (function(mountpoint) {
  3455.         var lookup = FS.lookupPath(mountpoint, {
  3456.             follow_mount: false
  3457.         });
  3458.         if (!FS.isMountpoint(lookup.node)) {
  3459.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3460.         }
  3461.         var node = lookup.node;
  3462.         var mount = node.mounted;
  3463.         var mounts = FS.getMounts(mount);
  3464.         Object.keys(FS.nameTable).forEach((function(hash) {
  3465.             var current = FS.nameTable[hash];
  3466.             while (current) {
  3467.                 var next = current.name_next;
  3468.                 if (mounts.indexOf(current.mount) !== -1) {
  3469.                     FS.destroyNode(current)
  3470.                 }
  3471.                 current = next
  3472.             }
  3473.         }));
  3474.         node.mounted = null;
  3475.         var idx = node.mount.mounts.indexOf(mount);
  3476.         assert(idx !== -1);
  3477.         node.mount.mounts.splice(idx, 1)
  3478.     }),
  3479.     lookup: (function(parent, name) {
  3480.         return parent.node_ops.lookup(parent, name)
  3481.     }),
  3482.     mknod: (function(path, mode, dev) {
  3483.         var lookup = FS.lookupPath(path, {
  3484.             parent: true
  3485.         });
  3486.         var parent = lookup.node;
  3487.         var name = PATH.basename(path);
  3488.         if (!name || name === "." || name === "..") {
  3489.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3490.         }
  3491.         var err = FS.mayCreate(parent, name);
  3492.         if (err) {
  3493.             throw new FS.ErrnoError(err)
  3494.         }
  3495.         if (!parent.node_ops.mknod) {
  3496.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3497.         }
  3498.         return parent.node_ops.mknod(parent, name, mode, dev)
  3499.     }),
  3500.     create: (function(path, mode) {
  3501.         mode = mode !== undefined ? mode : 438;
  3502.         mode &= 4095;
  3503.         mode |= 32768;
  3504.         return FS.mknod(path, mode, 0)
  3505.     }),
  3506.     mkdir: (function(path, mode) {
  3507.         mode = mode !== undefined ? mode : 511;
  3508.         mode &= 511 | 512;
  3509.         mode |= 16384;
  3510.         return FS.mknod(path, mode, 0)
  3511.     }),
  3512.     mkdirTree: (function(path, mode) {
  3513.         var dirs = path.split("/");
  3514.         var d = "";
  3515.         for (var i = 0; i < dirs.length; ++i) {
  3516.             if (!dirs[i]) continue;
  3517.             d += "/" + dirs[i];
  3518.             try {
  3519.                 FS.mkdir(d, mode)
  3520.             } catch (e) {
  3521.                 if (e.errno != ERRNO_CODES.EEXIST) throw e
  3522.             }
  3523.         }
  3524.     }),
  3525.     mkdev: (function(path, mode, dev) {
  3526.         if (typeof dev === "undefined") {
  3527.             dev = mode;
  3528.             mode = 438
  3529.         }
  3530.         mode |= 8192;
  3531.         return FS.mknod(path, mode, dev)
  3532.     }),
  3533.     symlink: (function(oldpath, newpath) {
  3534.         if (!PATH.resolve(oldpath)) {
  3535.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  3536.         }
  3537.         var lookup = FS.lookupPath(newpath, {
  3538.             parent: true
  3539.         });
  3540.         var parent = lookup.node;
  3541.         if (!parent) {
  3542.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  3543.         }
  3544.         var newname = PATH.basename(newpath);
  3545.         var err = FS.mayCreate(parent, newname);
  3546.         if (err) {
  3547.             throw new FS.ErrnoError(err)
  3548.         }
  3549.         if (!parent.node_ops.symlink) {
  3550.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3551.         }
  3552.         return parent.node_ops.symlink(parent, newname, oldpath)
  3553.     }),
  3554.     rename: (function(old_path, new_path) {
  3555.         var old_dirname = PATH.dirname(old_path);
  3556.         var new_dirname = PATH.dirname(new_path);
  3557.         var old_name = PATH.basename(old_path);
  3558.         var new_name = PATH.basename(new_path);
  3559.         var lookup, old_dir, new_dir;
  3560.         try {
  3561.             lookup = FS.lookupPath(old_path, {
  3562.                 parent: true
  3563.             });
  3564.             old_dir = lookup.node;
  3565.             lookup = FS.lookupPath(new_path, {
  3566.                 parent: true
  3567.             });
  3568.             new_dir = lookup.node
  3569.         } catch (e) {
  3570.             throw new FS.ErrnoError(ERRNO_CODES.EBUSY)
  3571.         }
  3572.         if (!old_dir || !new_dir) throw new FS.ErrnoError(ERRNO_CODES.ENOENT);
  3573.         if (old_dir.mount !== new_dir.mount) {
  3574.             throw new FS.ErrnoError(ERRNO_CODES.EXDEV)
  3575.         }
  3576.         var old_node = FS.lookupNode(old_dir, old_name);
  3577.         var relative = PATH.relative(old_path, new_dirname);
  3578.         if (relative.charAt(0) !== ".") {
  3579.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3580.         }
  3581.         relative = PATH.relative(new_path, old_dirname);
  3582.         if (relative.charAt(0) !== ".") {
  3583.             throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)
  3584.         }
  3585.         var new_node;
  3586.         try {
  3587.             new_node = FS.lookupNode(new_dir, new_name)
  3588.         } catch (e) {}
  3589.         if (old_node === new_node) {
  3590.             return
  3591.         }
  3592.         var isdir = FS.isDir(old_node.mode);
  3593.         var err = FS.mayDelete(old_dir, old_name, isdir);
  3594.         if (err) {
  3595.             throw new FS.ErrnoError(err)
  3596.         }
  3597.         err = new_node ? FS.mayDelete(new_dir, new_name, isdir) : FS.mayCreate(new_dir, new_name);
  3598.         if (err) {
  3599.             throw new FS.ErrnoError(err)
  3600.         }
  3601.         if (!old_dir.node_ops.rename) {
  3602.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3603.         }
  3604.         if (FS.isMountpoint(old_node) || new_node && FS.isMountpoint(new_node)) {
  3605.             throw new FS.ErrnoError(ERRNO_CODES.EBUSY)
  3606.         }
  3607.         if (new_dir !== old_dir) {
  3608.             err = FS.nodePermissions(old_dir, "w");
  3609.             if (err) {
  3610.                 throw new FS.ErrnoError(err)
  3611.             }
  3612.         }
  3613.         try {
  3614.             if (FS.trackingDelegate["willMovePath"]) {
  3615.                 FS.trackingDelegate["willMovePath"](old_path, new_path)
  3616.             }
  3617.         } catch (e) {
  3618.             console.log("FS.trackingDelegate['willMovePath']('" + old_path + "', '" + new_path + "') threw an exception: " + e.message)
  3619.         }
  3620.         FS.hashRemoveNode(old_node);
  3621.         try {
  3622.             old_dir.node_ops.rename(old_node, new_dir, new_name)
  3623.         } catch (e) {
  3624.             throw e
  3625.         } finally {
  3626.             FS.hashAddNode(old_node)
  3627.         }
  3628.         try {
  3629.             if (FS.trackingDelegate["onMovePath"]) FS.trackingDelegate["onMovePath"](old_path, new_path)
  3630.         } catch (e) {
  3631.             console.log("FS.trackingDelegate['onMovePath']('" + old_path + "', '" + new_path + "') threw an exception: " + e.message)
  3632.         }
  3633.     }),
  3634.     rmdir: (function(path) {
  3635.         var lookup = FS.lookupPath(path, {
  3636.             parent: true
  3637.         });
  3638.         var parent = lookup.node;
  3639.         var name = PATH.basename(path);
  3640.         var node = FS.lookupNode(parent, name);
  3641.         var err = FS.mayDelete(parent, name, true);
  3642.         if (err) {
  3643.             throw new FS.ErrnoError(err)
  3644.         }
  3645.         if (!parent.node_ops.rmdir) {
  3646.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3647.         }
  3648.         if (FS.isMountpoint(node)) {
  3649.             throw new FS.ErrnoError(ERRNO_CODES.EBUSY)
  3650.         }
  3651.         try {
  3652.             if (FS.trackingDelegate["willDeletePath"]) {
  3653.                 FS.trackingDelegate["willDeletePath"](path)
  3654.             }
  3655.         } catch (e) {
  3656.             console.log("FS.trackingDelegate['willDeletePath']('" + path + "') threw an exception: " + e.message)
  3657.         }
  3658.         parent.node_ops.rmdir(parent, name);
  3659.         FS.destroyNode(node);
  3660.         try {
  3661.             if (FS.trackingDelegate["onDeletePath"]) FS.trackingDelegate["onDeletePath"](path)
  3662.         } catch (e) {
  3663.             console.log("FS.trackingDelegate['onDeletePath']('" + path + "') threw an exception: " + e.message)
  3664.         }
  3665.     }),
  3666.     readdir: (function(path) {
  3667.         var lookup = FS.lookupPath(path, {
  3668.             follow: true
  3669.         });
  3670.         var node = lookup.node;
  3671.         if (!node.node_ops.readdir) {
  3672.             throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)
  3673.         }
  3674.         return node.node_ops.readdir(node)
  3675.     }),
  3676.     unlink: (function(path) {
  3677.         var lookup = FS.lookupPath(path, {
  3678.             parent: true
  3679.         });
  3680.         var parent = lookup.node;
  3681.         var name = PATH.basename(path);
  3682.         var node = FS.lookupNode(parent, name);
  3683.         var err = FS.mayDelete(parent, name, false);
  3684.         if (err) {
  3685.             throw new FS.ErrnoError(err)
  3686.         }
  3687.         if (!parent.node_ops.unlink) {
  3688.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3689.         }
  3690.         if (FS.isMountpoint(node)) {
  3691.             throw new FS.ErrnoError(ERRNO_CODES.EBUSY)
  3692.         }
  3693.         try {
  3694.             if (FS.trackingDelegate["willDeletePath"]) {
  3695.                 FS.trackingDelegate["willDeletePath"](path)
  3696.             }
  3697.         } catch (e) {
  3698.             console.log("FS.trackingDelegate['willDeletePath']('" + path + "') threw an exception: " + e.message)
  3699.         }
  3700.         parent.node_ops.unlink(parent, name);
  3701.         FS.destroyNode(node);
  3702.         try {
  3703.             if (FS.trackingDelegate["onDeletePath"]) FS.trackingDelegate["onDeletePath"](path)
  3704.         } catch (e) {
  3705.             console.log("FS.trackingDelegate['onDeletePath']('" + path + "') threw an exception: " + e.message)
  3706.         }
  3707.     }),
  3708.     readlink: (function(path) {
  3709.         var lookup = FS.lookupPath(path);
  3710.         var link = lookup.node;
  3711.         if (!link) {
  3712.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  3713.         }
  3714.         if (!link.node_ops.readlink) {
  3715.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3716.         }
  3717.         return PATH.resolve(FS.getPath(link.parent), link.node_ops.readlink(link))
  3718.     }),
  3719.     stat: (function(path, dontFollow) {
  3720.         var lookup = FS.lookupPath(path, {
  3721.             follow: !dontFollow
  3722.         });
  3723.         var node = lookup.node;
  3724.         if (!node) {
  3725.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  3726.         }
  3727.         if (!node.node_ops.getattr) {
  3728.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3729.         }
  3730.         return node.node_ops.getattr(node)
  3731.     }),
  3732.     lstat: (function(path) {
  3733.         return FS.stat(path, true)
  3734.     }),
  3735.     chmod: (function(path, mode, dontFollow) {
  3736.         var node;
  3737.         if (typeof path === "string") {
  3738.             var lookup = FS.lookupPath(path, {
  3739.                 follow: !dontFollow
  3740.             });
  3741.             node = lookup.node
  3742.         } else {
  3743.             node = path
  3744.         }
  3745.         if (!node.node_ops.setattr) {
  3746.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3747.         }
  3748.         node.node_ops.setattr(node, {
  3749.             mode: mode & 4095 | node.mode & ~4095,
  3750.             timestamp: Date.now()
  3751.         })
  3752.     }),
  3753.     lchmod: (function(path, mode) {
  3754.         FS.chmod(path, mode, true)
  3755.     }),
  3756.     fchmod: (function(fd, mode) {
  3757.         var stream = FS.getStream(fd);
  3758.         if (!stream) {
  3759.             throw new FS.ErrnoError(ERRNO_CODES.EBADF)
  3760.         }
  3761.         FS.chmod(stream.node, mode)
  3762.     }),
  3763.     chown: (function(path, uid, gid, dontFollow) {
  3764.         var node;
  3765.         if (typeof path === "string") {
  3766.             var lookup = FS.lookupPath(path, {
  3767.                 follow: !dontFollow
  3768.             });
  3769.             node = lookup.node
  3770.         } else {
  3771.             node = path
  3772.         }
  3773.         if (!node.node_ops.setattr) {
  3774.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3775.         }
  3776.         node.node_ops.setattr(node, {
  3777.             timestamp: Date.now()
  3778.         })
  3779.     }),
  3780.     lchown: (function(path, uid, gid) {
  3781.         FS.chown(path, uid, gid, true)
  3782.     }),
  3783.     fchown: (function(fd, uid, gid) {
  3784.         var stream = FS.getStream(fd);
  3785.         if (!stream) {
  3786.             throw new FS.ErrnoError(ERRNO_CODES.EBADF)
  3787.         }
  3788.         FS.chown(stream.node, uid, gid)
  3789.     }),
  3790.     truncate: (function(path, len) {
  3791.         if (len < 0) {
  3792.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3793.         }
  3794.         var node;
  3795.         if (typeof path === "string") {
  3796.             var lookup = FS.lookupPath(path, {
  3797.                 follow: true
  3798.             });
  3799.             node = lookup.node
  3800.         } else {
  3801.             node = path
  3802.         }
  3803.         if (!node.node_ops.setattr) {
  3804.             throw new FS.ErrnoError(ERRNO_CODES.EPERM)
  3805.         }
  3806.         if (FS.isDir(node.mode)) {
  3807.             throw new FS.ErrnoError(ERRNO_CODES.EISDIR)
  3808.         }
  3809.         if (!FS.isFile(node.mode)) {
  3810.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3811.         }
  3812.         var err = FS.nodePermissions(node, "w");
  3813.         if (err) {
  3814.             throw new FS.ErrnoError(err)
  3815.         }
  3816.         node.node_ops.setattr(node, {
  3817.             size: len,
  3818.             timestamp: Date.now()
  3819.         })
  3820.     }),
  3821.     ftruncate: (function(fd, len) {
  3822.         var stream = FS.getStream(fd);
  3823.         if (!stream) {
  3824.             throw new FS.ErrnoError(ERRNO_CODES.EBADF)
  3825.         }
  3826.         if ((stream.flags & 2097155) === 0) {
  3827.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3828.         }
  3829.         FS.truncate(stream.node, len)
  3830.     }),
  3831.     utime: (function(path, atime, mtime) {
  3832.         var lookup = FS.lookupPath(path, {
  3833.             follow: true
  3834.         });
  3835.         var node = lookup.node;
  3836.         node.node_ops.setattr(node, {
  3837.             timestamp: Math.max(atime, mtime)
  3838.         })
  3839.     }),
  3840.     open: (function(path, flags, mode, fd_start, fd_end) {
  3841.         if (path === "") {
  3842.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  3843.         }
  3844.         flags = typeof flags === "string" ? FS.modeStringToFlags(flags) : flags;
  3845.         mode = typeof mode === "undefined" ? 438 : mode;
  3846.         if (flags & 64) {
  3847.             mode = mode & 4095 | 32768
  3848.         } else {
  3849.             mode = 0
  3850.         }
  3851.         var node;
  3852.         if (typeof path === "object") {
  3853.             node = path
  3854.         } else {
  3855.             path = PATH.normalize(path);
  3856.             try {
  3857.                 var lookup = FS.lookupPath(path, {
  3858.                     follow: !(flags & 131072)
  3859.                 });
  3860.                 node = lookup.node
  3861.             } catch (e) {}
  3862.         }
  3863.         var created = false;
  3864.         if (flags & 64) {
  3865.             if (node) {
  3866.                 if (flags & 128) {
  3867.                     throw new FS.ErrnoError(ERRNO_CODES.EEXIST)
  3868.                 }
  3869.             } else {
  3870.                 node = FS.mknod(path, mode, 0);
  3871.                 created = true
  3872.             }
  3873.         }
  3874.         if (!node) {
  3875.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  3876.         }
  3877.         if (FS.isChrdev(node.mode)) {
  3878.             flags &= ~512
  3879.         }
  3880.         if (flags & 65536 && !FS.isDir(node.mode)) {
  3881.             throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)
  3882.         }
  3883.         if (!created) {
  3884.             var err = FS.mayOpen(node, flags);
  3885.             if (err) {
  3886.                 throw new FS.ErrnoError(err)
  3887.             }
  3888.         }
  3889.         if (flags & 512) {
  3890.             FS.truncate(node, 0)
  3891.         }
  3892.         flags &= ~(128 | 512);
  3893.         var stream = FS.createStream({
  3894.             node: node,
  3895.             path: FS.getPath(node),
  3896.             flags: flags,
  3897.             seekable: true,
  3898.             position: 0,
  3899.             stream_ops: node.stream_ops,
  3900.             ungotten: [],
  3901.             error: false
  3902.         }, fd_start, fd_end);
  3903.         if (stream.stream_ops.open) {
  3904.             stream.stream_ops.open(stream)
  3905.         }
  3906.         if (Module["logReadFiles"] && !(flags & 1)) {
  3907.             if (!FS.readFiles) FS.readFiles = {};
  3908.             if (!(path in FS.readFiles)) {
  3909.                 FS.readFiles[path] = 1;
  3910.                 Module["printErr"]("read file: " + path)
  3911.             }
  3912.         }
  3913.         try {
  3914.             if (FS.trackingDelegate["onOpenFile"]) {
  3915.                 var trackingFlags = 0;
  3916.                 if ((flags & 2097155) !== 1) {
  3917.                     trackingFlags |= FS.tracking.openFlags.READ
  3918.                 }
  3919.                 if ((flags & 2097155) !== 0) {
  3920.                     trackingFlags |= FS.tracking.openFlags.WRITE
  3921.                 }
  3922.                 FS.trackingDelegate["onOpenFile"](path, trackingFlags)
  3923.             }
  3924.         } catch (e) {
  3925.             console.log("FS.trackingDelegate['onOpenFile']('" + path + "', flags) threw an exception: " + e.message)
  3926.         }
  3927.         return stream
  3928.     }),
  3929.     close: (function(stream) {
  3930.         if (stream.getdents) stream.getdents = null;
  3931.         try {
  3932.             if (stream.stream_ops.close) {
  3933.                 stream.stream_ops.close(stream)
  3934.             }
  3935.         } catch (e) {
  3936.             throw e
  3937.         } finally {
  3938.             FS.closeStream(stream.fd)
  3939.         }
  3940.     }),
  3941.     llseek: (function(stream, offset, whence) {
  3942.         if (!stream.seekable || !stream.stream_ops.llseek) {
  3943.             throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)
  3944.         }
  3945.         stream.position = stream.stream_ops.llseek(stream, offset, whence);
  3946.         stream.ungotten = [];
  3947.         return stream.position
  3948.     }),
  3949.     read: (function(stream, buffer, offset, length, position) {
  3950.         if (length < 0 || position < 0) {
  3951.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3952.         }
  3953.         if ((stream.flags & 2097155) === 1) {
  3954.             throw new FS.ErrnoError(ERRNO_CODES.EBADF)
  3955.         }
  3956.         if (FS.isDir(stream.node.mode)) {
  3957.             throw new FS.ErrnoError(ERRNO_CODES.EISDIR)
  3958.         }
  3959.         if (!stream.stream_ops.read) {
  3960.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3961.         }
  3962.         var seeking = true;
  3963.         if (typeof position === "undefined") {
  3964.             position = stream.position;
  3965.             seeking = false
  3966.         } else if (!stream.seekable) {
  3967.             throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)
  3968.         }
  3969.         var bytesRead = stream.stream_ops.read(stream, buffer, offset, length, position);
  3970.         if (!seeking) stream.position += bytesRead;
  3971.         return bytesRead
  3972.     }),
  3973.     write: (function(stream, buffer, offset, length, position, canOwn) {
  3974.         if (length < 0 || position < 0) {
  3975.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3976.         }
  3977.         if ((stream.flags & 2097155) === 0) {
  3978.             throw new FS.ErrnoError(ERRNO_CODES.EBADF)
  3979.         }
  3980.         if (FS.isDir(stream.node.mode)) {
  3981.             throw new FS.ErrnoError(ERRNO_CODES.EISDIR)
  3982.         }
  3983.         if (!stream.stream_ops.write) {
  3984.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  3985.         }
  3986.         if (stream.flags & 1024) {
  3987.             FS.llseek(stream, 0, 2)
  3988.         }
  3989.         var seeking = true;
  3990.         if (typeof position === "undefined") {
  3991.             position = stream.position;
  3992.             seeking = false
  3993.         } else if (!stream.seekable) {
  3994.             throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)
  3995.         }
  3996.         var bytesWritten = stream.stream_ops.write(stream, buffer, offset, length, position, canOwn);
  3997.         if (!seeking) stream.position += bytesWritten;
  3998.         try {
  3999.             if (stream.path && FS.trackingDelegate["onWriteToFile"]) FS.trackingDelegate["onWriteToFile"](stream.path)
  4000.         } catch (e) {
  4001.             console.log("FS.trackingDelegate['onWriteToFile']('" + path + "') threw an exception: " + e.message)
  4002.         }
  4003.         return bytesWritten
  4004.     }),
  4005.     allocate: (function(stream, offset, length) {
  4006.         if (offset < 0 || length <= 0) {
  4007.             throw new FS.ErrnoError(ERRNO_CODES.EINVAL)
  4008.         }
  4009.         if ((stream.flags & 2097155) === 0) {
  4010.             throw new FS.ErrnoError(ERRNO_CODES.EBADF)
  4011.         }
  4012.         if (!FS.isFile(stream.node.mode) && !FS.isDir(stream.node.mode)) {
  4013.             throw new FS.ErrnoError(ERRNO_CODES.ENODEV)
  4014.         }
  4015.         if (!stream.stream_ops.allocate) {
  4016.             throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP)
  4017.         }
  4018.         stream.stream_ops.allocate(stream, offset, length)
  4019.     }),
  4020.     mmap: (function(stream, buffer, offset, length, position, prot, flags) {
  4021.         if ((stream.flags & 2097155) === 1) {
  4022.             throw new FS.ErrnoError(ERRNO_CODES.EACCES)
  4023.         }
  4024.         if (!stream.stream_ops.mmap) {
  4025.             throw new FS.ErrnoError(ERRNO_CODES.ENODEV)
  4026.         }
  4027.         return stream.stream_ops.mmap(stream, buffer, offset, length, position, prot, flags)
  4028.     }),
  4029.     msync: (function(stream, buffer, offset, length, mmapFlags) {
  4030.         if (!stream || !stream.stream_ops.msync) {
  4031.             return 0
  4032.         }
  4033.         return stream.stream_ops.msync(stream, buffer, offset, length, mmapFlags)
  4034.     }),
  4035.     munmap: (function(stream) {
  4036.         return 0
  4037.     }),
  4038.     ioctl: (function(stream, cmd, arg) {
  4039.         if (!stream.stream_ops.ioctl) {
  4040.             throw new FS.ErrnoError(ERRNO_CODES.ENOTTY)
  4041.         }
  4042.         return stream.stream_ops.ioctl(stream, cmd, arg)
  4043.     }),
  4044.     readFile: (function(path, opts) {
  4045.         opts = opts || {};
  4046.         opts.flags = opts.flags || "r";
  4047.         opts.encoding = opts.encoding || "binary";
  4048.         if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
  4049.             throw new Error('Invalid encoding type "' + opts.encoding + '"')
  4050.         }
  4051.         var ret;
  4052.         var stream = FS.open(path, opts.flags);
  4053.         var stat = FS.stat(path);
  4054.         var length = stat.size;
  4055.         var buf = new Uint8Array(length);
  4056.         FS.read(stream, buf, 0, length, 0);
  4057.         if (opts.encoding === "utf8") {
  4058.             ret = UTF8ArrayToString(buf, 0)
  4059.         } else if (opts.encoding === "binary") {
  4060.             ret = buf
  4061.         }
  4062.         FS.close(stream);
  4063.         return ret
  4064.     }),
  4065.     writeFile: (function(path, data, opts) {
  4066.         opts = opts || {};
  4067.         opts.flags = opts.flags || "w";
  4068.         opts.encoding = opts.encoding || "utf8";
  4069.         if (opts.encoding !== "utf8" && opts.encoding !== "binary") {
  4070.             throw new Error('Invalid encoding type "' + opts.encoding + '"')
  4071.         }
  4072.         var stream = FS.open(path, opts.flags, opts.mode);
  4073.         if (opts.encoding === "utf8") {
  4074.             var buf = new Uint8Array(lengthBytesUTF8(data) + 1);
  4075.             var actualNumBytes = stringToUTF8Array(data, buf, 0, buf.length);
  4076.             FS.write(stream, buf, 0, actualNumBytes, 0, opts.canOwn)
  4077.         } else if (opts.encoding === "binary") {
  4078.             FS.write(stream, data, 0, data.length, 0, opts.canOwn)
  4079.         }
  4080.         FS.close(stream)
  4081.     }),
  4082.     cwd: (function() {
  4083.         return FS.currentPath
  4084.     }),
  4085.     chdir: (function(path) {
  4086.         var lookup = FS.lookupPath(path, {
  4087.             follow: true
  4088.         });
  4089.         if (lookup.node === null) {
  4090.             throw new FS.ErrnoError(ERRNO_CODES.ENOENT)
  4091.         }
  4092.         if (!FS.isDir(lookup.node.mode)) {
  4093.             throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)
  4094.         }
  4095.         var err = FS.nodePermissions(lookup.node, "x");
  4096.         if (err) {
  4097.             throw new FS.ErrnoError(err)
  4098.         }
  4099.         FS.currentPath = lookup.path
  4100.     }),
  4101.     createDefaultDirectories: (function() {
  4102.         FS.mkdir("/tmp");
  4103.         FS.mkdir("/home");
  4104.         FS.mkdir("/home/web_user")
  4105.     }),
  4106.     createDefaultDevices: (function() {
  4107.         FS.mkdir("/dev");
  4108.         FS.registerDevice(FS.makedev(1, 3), {
  4109.             read: (function() {
  4110.                 return 0
  4111.             }),
  4112.             write: (function(stream, buffer, offset, length, pos) {
  4113.                 return length
  4114.             })
  4115.         });
  4116.         FS.mkdev("/dev/null", FS.makedev(1, 3));
  4117.         TTY.register(FS.makedev(5, 0), TTY.default_tty_ops);
  4118.         TTY.register(FS.makedev(6, 0), TTY.default_tty1_ops);
  4119.         FS.mkdev("/dev/tty", FS.makedev(5, 0));
  4120.         FS.mkdev("/dev/tty1", FS.makedev(6, 0));
  4121.         var random_device;
  4122.         if (typeof crypto !== "undefined") {
  4123.             var randomBuffer = new Uint8Array(1);
  4124.             random_device = (function() {
  4125.                 crypto.getRandomValues(randomBuffer);
  4126.                 return randomBuffer[0]
  4127.             })
  4128.         } else if (ENVIRONMENT_IS_NODE) {
  4129.             random_device = (function() {
  4130.                 return require("crypto").randomBytes(1)[0]
  4131.             })
  4132.         } else {
  4133.             random_device = (function() {
  4134.                 return Math.random() * 256 | 0
  4135.             })
  4136.         }
  4137.         FS.createDevice("/dev", "random", random_device);
  4138.         FS.createDevice("/dev", "urandom", random_device);
  4139.         FS.mkdir("/dev/shm");
  4140.         FS.mkdir("/dev/shm/tmp")
  4141.     }),
  4142.     createSpecialDirectories: (function() {
  4143.         FS.mkdir("/proc");
  4144.         FS.mkdir("/proc/self");
  4145.         FS.mkdir("/proc/self/fd");
  4146.         FS.mount({
  4147.             mount: (function() {
  4148.                 var node = FS.createNode("/proc/self", "fd", 16384 | 511, 73);
  4149.                 node.node_ops = {
  4150.                     lookup: (function(parent, name) {
  4151.                         var fd = +name;
  4152.                         var stream = FS.getStream(fd);
  4153.                         if (!stream) throw new FS.ErrnoError(ERRNO_CODES.EBADF);
  4154.                         var ret = {
  4155.                             parent: null,
  4156.                             mount: {
  4157.                                 mountpoint: "fake"
  4158.                             },
  4159.                             node_ops: {
  4160.                                 readlink: (function() {
  4161.                                     return stream.path
  4162.                                 })
  4163.                             }
  4164.                         };
  4165.                         ret.parent = ret;
  4166.                         return ret
  4167.                     })
  4168.                 };
  4169.                 return node
  4170.             })
  4171.         }, {}, "/proc/self/fd")
  4172.     }),
  4173.     createStandardStreams: (function() {
  4174.         if (Module["stdin"]) {
  4175.             FS.createDevice("/dev", "stdin", Module["stdin"])
  4176.         } else {
  4177.             FS.symlink("/dev/tty", "/dev/stdin")
  4178.         }
  4179.         if (Module["stdout"]) {
  4180.             FS.createDevice("/dev", "stdout", null, Module["stdout"])
  4181.         } else {
  4182.             FS.symlink("/dev/tty", "/dev/stdout")
  4183.         }
  4184.         if (Module["stderr"]) {
  4185.             FS.createDevice("/dev", "stderr", null, Module["stderr"])
  4186.         } else {
  4187.             FS.symlink("/dev/tty1", "/dev/stderr")
  4188.         }
  4189.         var stdin = FS.open("/dev/stdin", "r");
  4190.         assert(stdin.fd === 0, "invalid handle for stdin (" + stdin.fd + ")");
  4191.         var stdout = FS.open("/dev/stdout", "w");
  4192.         assert(stdout.fd === 1, "invalid handle for stdout (" + stdout.fd + ")");
  4193.         var stderr = FS.open("/dev/stderr", "w");
  4194.         assert(stderr.fd === 2, "invalid handle for stderr (" + stderr.fd + ")")
  4195.     }),
  4196.     ensureErrnoError: (function() {
  4197.         if (FS.ErrnoError) return;
  4198.         FS.ErrnoError = function ErrnoError(errno, node) {
  4199.             this.node = node;
  4200.             this.setErrno = (function(errno) {
  4201.                 this.errno = errno;
  4202.                 for (var key in ERRNO_CODES) {
  4203.                     if (ERRNO_CODES[key] === errno) {
  4204.                         this.code = key;
  4205.                         break
  4206.                     }
  4207.                 }
  4208.             });
  4209.             this.setErrno(errno);
  4210.             this.message = ERRNO_MESSAGES[errno]
  4211.         };
  4212.         FS.ErrnoError.prototype = new Error;
  4213.         FS.ErrnoError.prototype.constructor = FS.ErrnoError;
  4214.         [ERRNO_CODES.ENOENT].forEach((function(code) {
  4215.             FS.genericErrors[code] = new FS.ErrnoError(code);
  4216.             FS.genericErrors[code].stack = "<generic error, no stack>"
  4217.         }))
  4218.     }),
  4219.     staticInit: (function() {
  4220.         FS.ensureErrnoError();
  4221.         FS.nameTable = new Array(4096);
  4222.         FS.mount(MEMFS, {}, "/");
  4223.         FS.createDefaultDirectories();
  4224.         FS.createDefaultDevices();
  4225.         FS.createSpecialDirectories();
  4226.         FS.filesystems = {
  4227.             "MEMFS": MEMFS,
  4228.             "IDBFS": IDBFS,
  4229.             "NODEFS": NODEFS,
  4230.             "WORKERFS": WORKERFS
  4231.         }
  4232.     }),
  4233.     init: (function(input, output, error) {
  4234.         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)");
  4235.         FS.init.initialized = true;
  4236.         FS.ensureErrnoError();
  4237.         Module["stdin"] = input || Module["stdin"];
  4238.         Module["stdout"] = output || Module["stdout"];
  4239.         Module["stderr"] = error || Module["stderr"];
  4240.         FS.createStandardStreams()
  4241.     }),
  4242.     quit: (function() {
  4243.         FS.init.initialized = false;
  4244.         var fflush = Module["_fflush"];
  4245.         if (fflush) fflush(0);
  4246.         for (var i = 0; i < FS.streams.length; i++) {
  4247.             var stream = FS.streams[i];
  4248.             if (!stream) {
  4249.                 continue
  4250.             }
  4251.             FS.close(stream)
  4252.         }
  4253.     }),
  4254.     getMode: (function(canRead, canWrite) {
  4255.         var mode = 0;
  4256.         if (canRead) mode |= 292 | 73;
  4257.         if (canWrite) mode |= 146;
  4258.         return mode
  4259.     }),
  4260.     joinPath: (function(parts, forceRelative) {
  4261.         var path = PATH.join.apply(null, parts);
  4262.         if (forceRelative && path[0] == "/") path = path.substr(1);
  4263.         return path
  4264.     }),
  4265.     absolutePath: (function(relative, base) {
  4266.         return PATH.resolve(base, relative)
  4267.     }),
  4268.     standardizePath: (function(path) {
  4269.         return PATH.normalize(path)
  4270.     }),
  4271.     findObject: (function(path, dontResolveLastLink) {
  4272.         var ret = FS.analyzePath(path, dontResolveLastLink);
  4273.         if (ret.exists) {
  4274.             return ret.object
  4275.         } else {
  4276.             ___setErrNo(ret.error);
  4277.             return null
  4278.         }
  4279.     }),
  4280.     analyzePath: (function(path, dontResolveLastLink) {
  4281.         try {
  4282.             var lookup = FS.lookupPath(path, {
  4283.                 follow: !dontResolveLastLink
  4284.             });
  4285.             path = lookup.path
  4286.         } catch (e) {}
  4287.         var ret = {
  4288.             isRoot: false,
  4289.             exists: false,
  4290.             error: 0,
  4291.             name: null,
  4292.             path: null,
  4293.             object: null,
  4294.             parentExists: false,
  4295.             parentPath: null,
  4296.             parentObject: null
  4297.         };
  4298.         try {
  4299.             var lookup = FS.lookupPath(path, {
  4300.                 parent: true
  4301.             });
  4302.             ret.parentExists = true;
  4303.             ret.parentPath = lookup.path;
  4304.             ret.parentObject = lookup.node;
  4305.             ret.name = PATH.basename(path);
  4306.             lookup = FS.lookupPath(path, {
  4307.                 follow: !dontResolveLastLink
  4308.             });
  4309.             ret.exists = true;
  4310.             ret.path = lookup.path;
  4311.             ret.object = lookup.node;
  4312.             ret.name = lookup.node.name;
  4313.             ret.isRoot = lookup.path === "/"
  4314.         } catch (e) {
  4315.             ret.error = e.errno
  4316.         }
  4317.         return ret
  4318.     }),
  4319.     createFolder: (function(parent, name, canRead, canWrite) {
  4320.         var path = PATH.join2(typeof parent === "string" ? parent : FS.getPath(parent), name);
  4321.         var mode = FS.getMode(canRead, canWrite);
  4322.         return FS.mkdir(path, mode)
  4323.     }),
  4324.     createPath: (function(parent, path, canRead, canWrite) {
  4325.         parent = typeof parent === "string" ? parent : FS.getPath(parent);
  4326.         var parts = path.split("/").reverse();
  4327.         while (parts.length) {
  4328.             var part = parts.pop();
  4329.             if (!part) continue;
  4330.             var current = PATH.join2(parent, part);
  4331.             try {
  4332.                 FS.mkdir(current)
  4333.             } catch (e) {}
  4334.             parent = current
  4335.         }
  4336.         return current
  4337.     }),
  4338.     createFile: (function(parent, name, properties, canRead, canWrite) {
  4339.         var path = PATH.join2(typeof parent === "string" ? parent : FS.getPath(parent), name);
  4340.         var mode = FS.getMode(canRead, canWrite);
  4341.         return FS.create(path, mode)
  4342.     }),
  4343.     createDataFile: (function(parent, name, data, canRead, canWrite, canOwn) {
  4344.         var path = name ? PATH.join2(typeof parent === "string" ? parent : FS.getPath(parent), name) : parent;
  4345.         var mode = FS.getMode(canRead, canWrite);
  4346.         var node = FS.create(path, mode);
  4347.         if (data) {
  4348.             if (typeof data === "string") {
  4349.                 var arr = new Array(data.length);
  4350.                 for (var i = 0, len = data.length; i < len; ++i) arr[i] = data.charCodeAt(i);
  4351.                 data = arr
  4352.             }
  4353.             FS.chmod(node, mode | 146);
  4354.             var stream = FS.open(node, "w");
  4355.             FS.write(stream, data, 0, data.length, 0, canOwn);
  4356.             FS.close(stream);
  4357.             FS.chmod(node, mode)
  4358.         }
  4359.         return node
  4360.     }),
  4361.     createDevice: (function(parent, name, input, output) {
  4362.         var path = PATH.join2(typeof parent === "string" ? parent : FS.getPath(parent), name);
  4363.         var mode = FS.getMode(!!input, !!output);
  4364.         if (!FS.createDevice.major) FS.createDevice.major = 64;
  4365.         var dev = FS.makedev(FS.createDevice.major++, 0);
  4366.         FS.registerDevice(dev, {
  4367.             open: (function(stream) {
  4368.                 stream.seekable = false
  4369.             }),
  4370.             close: (function(stream) {
  4371.                 if (output && output.buffer && output.buffer.length) {
  4372.                     output(10)
  4373.                 }
  4374.             }),
  4375.             read: (function(stream, buffer, offset, length, pos) {
  4376.                 var bytesRead = 0;
  4377.                 for (var i = 0; i < length; i++) {
  4378.                     var result;
  4379.                     try {
  4380.                         result = input()
  4381.                     } catch (e) {
  4382.                         throw new FS.ErrnoError(ERRNO_CODES.EIO)
  4383.                     }
  4384.                     if (result === undefined && bytesRead === 0) {
  4385.                         throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)
  4386.                     }
  4387.                     if (result === null || result === undefined) break;
  4388.                     bytesRead++;
  4389.                     buffer[offset + i] = result
  4390.                 }
  4391.                 if (bytesRead) {
  4392.                     stream.node.timestamp = Date.now()
  4393.                 }
  4394.                 return bytesRead
  4395.             }),
  4396.             write: (function(stream, buffer, offset, length, pos) {
  4397.                 for (var i = 0; i < length; i++) {
  4398.                     try {
  4399.                         output(buffer[offset + i])
  4400.                     } catch (e) {
  4401.                         throw new FS.ErrnoError(ERRNO_CODES.EIO)
  4402.                     }
  4403.                 }
  4404.                 if (length) {
  4405.                     stream.node.timestamp = Date.now()
  4406.                 }
  4407.                 return i
  4408.             })
  4409.         });
  4410.         return FS.mkdev(path, mode, dev)
  4411.     }),
  4412.     createLink: (function(parent, name, target, canRead, canWrite) {
  4413.         var path = PATH.join2(typeof parent === "string" ? parent : FS.getPath(parent), name);
  4414.         return FS.symlink(target, path)
  4415.     }),
  4416.     forceLoadFile: (function(obj) {
  4417.         if (obj.isDevice || obj.isFolder || obj.link || obj.contents) return true;
  4418.         var success = true;
  4419.         if (typeof XMLHttpRequest !== "undefined") {
  4420.             throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.")
  4421.         } else if (Module["read"]) {
  4422.             try {
  4423.                 obj.contents = intArrayFromString(Module["read"](obj.url), true);
  4424.                 obj.usedBytes = obj.contents.length
  4425.             } catch (e) {
  4426.                 success = false
  4427.             }
  4428.         } else {
  4429.             throw new Error("Cannot load without read() or XMLHttpRequest.")
  4430.         }
  4431.         if (!success) ___setErrNo(ERRNO_CODES.EIO);
  4432.         return success
  4433.     }),
  4434.     createLazyFile: (function(parent, name, url, canRead, canWrite) {
  4435.         function LazyUint8Array() {
  4436.             this.lengthKnown = false;
  4437.             this.chunks = []
  4438.         }
  4439.         LazyUint8Array.prototype.get = function LazyUint8Array_get(idx) {
  4440.             if (idx > this.length - 1 || idx < 0) {
  4441.                 return undefined
  4442.             }
  4443.             var chunkOffset = idx % this.chunkSize;
  4444.             var chunkNum = idx / this.chunkSize | 0;
  4445.             return this.getter(chunkNum)[chunkOffset]
  4446.         };
  4447.         LazyUint8Array.prototype.setDataGetter = function LazyUint8Array_setDataGetter(getter) {
  4448.             this.getter = getter
  4449.         };
  4450.         LazyUint8Array.prototype.cacheLength = function LazyUint8Array_cacheLength() {
  4451.             var xhr = new XMLHttpRequest;
  4452.             xhr.open("HEAD", url, false);
  4453.             xhr.send(null);
  4454.             if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304)) throw new Error("Couldn't load " + url + ". Status: " + xhr.status);
  4455.             var datalength = Number(xhr.getResponseHeader("Content-length"));
  4456.             var header;
  4457.             var hasByteServing = (header = xhr.getResponseHeader("Accept-Ranges")) && header === "bytes";
  4458.             var usesGzip = (header = xhr.getResponseHeader("Content-Encoding")) && header === "gzip";
  4459.             var chunkSize = 1024 * 1024;
  4460.             if (!hasByteServing) chunkSize = datalength;
  4461.             var doXHR = (function(from, to) {
  4462.                 if (from > to) throw new Error("invalid range (" + from + ", " + to + ") or no bytes requested!");
  4463.                 if (to > datalength - 1) throw new Error("only " + datalength + " bytes available! programmer error!");
  4464.                 var xhr = new XMLHttpRequest;
  4465.                 xhr.open("GET", url, false);
  4466.                 if (datalength !== chunkSize) xhr.setRequestHeader("Range", "bytes=" + from + "-" + to);
  4467.                 if (typeof Uint8Array != "undefined") xhr.responseType = "arraybuffer";
  4468.                 if (xhr.overrideMimeType) {
  4469.                     xhr.overrideMimeType("text/plain; charset=x-user-defined")
  4470.                 }
  4471.                 xhr.send(null);
  4472.                 if (!(xhr.status >= 200 && xhr.status < 300 || xhr.status === 304)) throw new Error("Couldn't load " + url + ". Status: " + xhr.status);
  4473.                 if (xhr.response !== undefined) {
  4474.                     return new Uint8Array(xhr.response || [])
  4475.                 } else {
  4476.                     return intArrayFromString(xhr.responseText || "", true)
  4477.                 }
  4478.             });
  4479.             var lazyArray = this;
  4480.             lazyArray.setDataGetter((function(chunkNum) {
  4481.                 var start = chunkNum * chunkSize;
  4482.                 var end = (chunkNum + 1) * chunkSize - 1;
  4483.                 end = Math.min(end, datalength - 1);
  4484.                 if (typeof lazyArray.chunks[chunkNum] === "undefined") {
  4485.                     lazyArray.chunks[chunkNum] = doXHR(start, end)
  4486.                 }
  4487.                 if (typeof lazyArray.chunks[chunkNum] === "undefined") throw new Error("doXHR failed!");
  4488.                 return lazyArray.chunks[chunkNum]
  4489.             }));
  4490.             if (usesGzip || !datalength) {
  4491.                 chunkSize = datalength = 1;
  4492.                 datalength = this.getter(0).length;
  4493.                 chunkSize = datalength;
  4494.                 console.log("LazyFiles on gzip forces download of the whole file when length is accessed")
  4495.             }
  4496.             this._length = datalength;
  4497.             this._chunkSize = chunkSize;
  4498.             this.lengthKnown = true
  4499.         };
  4500.         if (typeof XMLHttpRequest !== "undefined") {
  4501.             if (!ENVIRONMENT_IS_WORKER) throw "Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";
  4502.             var lazyArray = new LazyUint8Array;
  4503.             Object.defineProperties(lazyArray, {
  4504.                 length: {
  4505.                     get: (function() {
  4506.                         if (!this.lengthKnown) {
  4507.                             this.cacheLength()
  4508.                         }
  4509.                         return this._length
  4510.                     })
  4511.                 },
  4512.                 chunkSize: {
  4513.                     get: (function() {
  4514.                         if (!this.lengthKnown) {
  4515.                             this.cacheLength()
  4516.                         }
  4517.                         return this._chunkSize
  4518.                     })
  4519.                 }
  4520.             });
  4521.             var properties = {
  4522.                 isDevice: false,
  4523.                 contents: lazyArray
  4524.             }
  4525.         } else {
  4526.             var properties = {
  4527.                 isDevice: false,
  4528.                 url: url
  4529.             }
  4530.         }
  4531.         var node = FS.createFile(parent, name, properties, canRead, canWrite);
  4532.         if (properties.contents) {
  4533.             node.contents = properties.contents
  4534.         } else if (properties.url) {
  4535.             node.contents = null;
  4536.             node.url = properties.url
  4537.         }
  4538.         Object.defineProperties(node, {
  4539.             usedBytes: {
  4540.                 get: (function() {
  4541.                     return this.contents.length
  4542.                 })
  4543.             }
  4544.         });
  4545.         var stream_ops = {};
  4546.         var keys = Object.keys(node.stream_ops);
  4547.         keys.forEach((function(key) {
  4548.             var fn = node.stream_ops[key];
  4549.             stream_ops[key] = function forceLoadLazyFile() {
  4550.                 if (!FS.forceLoadFile(node)) {
  4551.                     throw new FS.ErrnoError(ERRNO_CODES.EIO)
  4552.                 }
  4553.                 return fn.apply(null, arguments)
  4554.             }
  4555.         }));
  4556.         stream_ops.read = function stream_ops_read(stream, buffer, offset, length, position) {
  4557.             if (!FS.forceLoadFile(node)) {
  4558.                 throw new FS.ErrnoError(ERRNO_CODES.EIO)
  4559.             }
  4560.             var contents = stream.node.contents;
  4561.             if (position >= contents.length) return 0;
  4562.             var size = Math.min(contents.length - position, length);
  4563.             assert(size >= 0);
  4564.             if (contents.slice) {
  4565.                 for (var i = 0; i < size; i++) {
  4566.                     buffer[offset + i] = contents[position + i]
  4567.                 }
  4568.             } else {
  4569.                 for (var i = 0; i < size; i++) {
  4570.                     buffer[offset + i] = contents.get(position + i)
  4571.                 }
  4572.             }
  4573.             return size
  4574.         };
  4575.         node.stream_ops = stream_ops;
  4576.         return node
  4577.     }),
  4578.     createPreloadedFile: (function(parent, name, url, canRead, canWrite, onload, onerror, dontCreateFile, canOwn, preFinish) {
  4579.         Browser.init();
  4580.         var fullname = name ? PATH.resolve(PATH.join2(parent, name)) : parent;
  4581.         var dep = getUniqueRunDependency("cp " + fullname);
  4582.  
  4583.         function processData(byteArray) {
  4584.             function finish(byteArray) {
  4585.                 if (preFinish) preFinish();
  4586.                 if (!dontCreateFile) {
  4587.                     FS.createDataFile(parent, name, byteArray, canRead, canWrite, canOwn)
  4588.                 }
  4589.                 if (onload) onload();
  4590.                 removeRunDependency(dep)
  4591.             }
  4592.             var handled = false;
  4593.             Module["preloadPlugins"].forEach((function(plugin) {
  4594.                 if (handled) return;
  4595.                 if (plugin["canHandle"](fullname)) {
  4596.                     plugin["handle"](byteArray, fullname, finish, (function() {
  4597.                         if (onerror) onerror();
  4598.                         removeRunDependency(dep)
  4599.                     }));
  4600.                     handled = true
  4601.                 }
  4602.             }));
  4603.             if (!handled) finish(byteArray)
  4604.         }
  4605.         addRunDependency(dep);
  4606.         if (typeof url == "string") {
  4607.             Browser.asyncLoad(url, (function(byteArray) {
  4608.                 processData(byteArray)
  4609.             }), onerror)
  4610.         } else {
  4611.             processData(url)
  4612.         }
  4613.     }),
  4614.     indexedDB: (function() {
  4615.         return window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB
  4616.     }),
  4617.     DB_NAME: (function() {
  4618.         return "EM_FS_" + window.location.pathname
  4619.     }),
  4620.     DB_VERSION: 20,
  4621.     DB_STORE_NAME: "FILE_DATA",
  4622.     saveFilesToDB: (function(paths, onload, onerror) {
  4623.         onload = onload || (function() {});
  4624.         onerror = onerror || (function() {});
  4625.         var indexedDB = FS.indexedDB();
  4626.         try {
  4627.             var openRequest = indexedDB.open(FS.DB_NAME(), FS.DB_VERSION)
  4628.         } catch (e) {
  4629.             return onerror(e)
  4630.         }
  4631.         openRequest.onupgradeneeded = function openRequest_onupgradeneeded() {
  4632.             console.log("creating db");
  4633.             var db = openRequest.result;
  4634.             db.createObjectStore(FS.DB_STORE_NAME)
  4635.         };
  4636.         openRequest.onsuccess = function openRequest_onsuccess() {
  4637.             var db = openRequest.result;
  4638.             var transaction = db.transaction([FS.DB_STORE_NAME], "readwrite");
  4639.             var files = transaction.objectStore(FS.DB_STORE_NAME);
  4640.             var ok = 0,
  4641.                 fail = 0,
  4642.                 total = paths.length;
  4643.  
  4644.             function finish() {
  4645.                 if (fail == 0) onload();
  4646.                 else onerror()
  4647.             }
  4648.             paths.forEach((function(path) {
  4649.                 var putRequest = files.put(FS.analyzePath(path).object.contents, path);
  4650.                 putRequest.onsuccess = function putRequest_onsuccess() {
  4651.                     ok++;
  4652.                     if (ok + fail == total) finish()
  4653.                 };
  4654.                 putRequest.onerror = function putRequest_onerror() {
  4655.                     fail++;
  4656.                     if (ok + fail == total) finish()
  4657.                 }
  4658.             }));
  4659.             transaction.onerror = onerror
  4660.         };
  4661.         openRequest.onerror = onerror
  4662.     }),
  4663.     loadFilesFromDB: (function(paths, onload, onerror) {
  4664.         onload = onload || (function() {});
  4665.         onerror = onerror || (function() {});
  4666.         var indexedDB = FS.indexedDB();
  4667.         try {
  4668.             var openRequest = indexedDB.open(FS.DB_NAME(), FS.DB_VERSION)
  4669.         } catch (e) {
  4670.             return onerror(e)
  4671.         }
  4672.         openRequest.onupgradeneeded = onerror;
  4673.         openRequest.onsuccess = function openRequest_onsuccess() {
  4674.             var db = openRequest.result;
  4675.             try {
  4676.                 var transaction = db.transaction([FS.DB_STORE_NAME], "readonly")
  4677.             } catch (e) {
  4678.                 onerror(e);
  4679.                 return
  4680.             }
  4681.             var files = transaction.objectStore(FS.DB_STORE_NAME);
  4682.             var ok = 0,
  4683.                 fail = 0,
  4684.                 total = paths.length;
  4685.  
  4686.             function finish() {
  4687.                 if (fail == 0) onload();
  4688.                 else onerror()
  4689.             }
  4690.             paths.forEach((function(path) {
  4691.                 var getRequest = files.get(path);
  4692.                 getRequest.onsuccess = function getRequest_onsuccess() {
  4693.                     if (FS.analyzePath(path).exists) {
  4694.                         FS.unlink(path)
  4695.                     }
  4696.                     FS.createDataFile(PATH.dirname(path), PATH.basename(path), getRequest.result, true, true, true);
  4697.                     ok++;
  4698.                     if (ok + fail == total) finish()
  4699.                 };
  4700.                 getRequest.onerror = function getRequest_onerror() {
  4701.                     fail++;
  4702.                     if (ok + fail == total) finish()
  4703.                 }
  4704.             }));
  4705.             transaction.onerror = onerror
  4706.         };
  4707.         openRequest.onerror = onerror
  4708.     })
  4709. };
  4710. var SYSCALLS = {
  4711.     DEFAULT_POLLMASK: 5,
  4712.     mappings: {},
  4713.     umask: 511,
  4714.     calculateAt: (function(dirfd, path) {
  4715.         if (path[0] !== "/") {
  4716.             var dir;
  4717.             if (dirfd === -100) {
  4718.                 dir = FS.cwd()
  4719.             } else {
  4720.                 var dirstream = FS.getStream(dirfd);
  4721.                 if (!dirstream) throw new FS.ErrnoError(ERRNO_CODES.EBADF);
  4722.                 dir = dirstream.path
  4723.             }
  4724.             path = PATH.join2(dir, path)
  4725.         }
  4726.         return path
  4727.     }),
  4728.     doStat: (function(func, path, buf) {
  4729.         try {
  4730.             var stat = func(path)
  4731.         } catch (e) {
  4732.             if (e && e.node && PATH.normalize(path) !== PATH.normalize(FS.getPath(e.node))) {
  4733.                 return -ERRNO_CODES.ENOTDIR
  4734.             }
  4735.             throw e
  4736.         }
  4737.         HEAP32[buf >> 2] = stat.dev;
  4738.         HEAP32[buf + 4 >> 2] = 0;
  4739.         HEAP32[buf + 8 >> 2] = stat.ino;
  4740.         HEAP32[buf + 12 >> 2] = stat.mode;
  4741.         HEAP32[buf + 16 >> 2] = stat.nlink;
  4742.         HEAP32[buf + 20 >> 2] = stat.uid;
  4743.         HEAP32[buf + 24 >> 2] = stat.gid;
  4744.         HEAP32[buf + 28 >> 2] = stat.rdev;
  4745.         HEAP32[buf + 32 >> 2] = 0;
  4746.         HEAP32[buf + 36 >> 2] = stat.size;
  4747.         HEAP32[buf + 40 >> 2] = 4096;
  4748.         HEAP32[buf + 44 >> 2] = stat.blocks;
  4749.         HEAP32[buf + 48 >> 2] = stat.atime.getTime() / 1e3 | 0;
  4750.         HEAP32[buf + 52 >> 2] = 0;
  4751.         HEAP32[buf + 56 >> 2] = stat.mtime.getTime() / 1e3 | 0;
  4752.         HEAP32[buf + 60 >> 2] = 0;
  4753.         HEAP32[buf + 64 >> 2] = stat.ctime.getTime() / 1e3 | 0;
  4754.         HEAP32[buf + 68 >> 2] = 0;
  4755.         HEAP32[buf + 72 >> 2] = stat.ino;
  4756.         return 0
  4757.     }),
  4758.     doMsync: (function(addr, stream, len, flags) {
  4759.         var buffer = new Uint8Array(HEAPU8.subarray(addr, addr + len));
  4760.         FS.msync(stream, buffer, 0, len, flags)
  4761.     }),
  4762.     doMkdir: (function(path, mode) {
  4763.         path = PATH.normalize(path);
  4764.         if (path[path.length - 1] === "/") path = path.substr(0, path.length - 1);
  4765.         FS.mkdir(path, mode, 0);
  4766.         return 0
  4767.     }),
  4768.     doMknod: (function(path, mode, dev) {
  4769.         switch (mode & 61440) {
  4770.             case 32768:
  4771.             case 8192:
  4772.             case 24576:
  4773.             case 4096:
  4774.             case 49152:
  4775.                 break;
  4776.             default:
  4777.                 return -ERRNO_CODES.EINVAL
  4778.         }
  4779.         FS.mknod(path, mode, dev);
  4780.         return 0
  4781.     }),
  4782.     doReadlink: (function(path, buf, bufsize) {
  4783.         if (bufsize <= 0) return -ERRNO_CODES.EINVAL;
  4784.         var ret = FS.readlink(path);
  4785.         var len = Math.min(bufsize, lengthBytesUTF8(ret));
  4786.         var endChar = HEAP8[buf + len];
  4787.         stringToUTF8(ret, buf, bufsize + 1);
  4788.         HEAP8[buf + len] = endChar;
  4789.         return len
  4790.     }),
  4791.     doAccess: (function(path, amode) {
  4792.         if (amode & ~7) {
  4793.             return -ERRNO_CODES.EINVAL
  4794.         }
  4795.         var node;
  4796.         var lookup = FS.lookupPath(path, {
  4797.             follow: true
  4798.         });
  4799.         node = lookup.node;
  4800.         var perms = "";
  4801.         if (amode & 4) perms += "r";
  4802.         if (amode & 2) perms += "w";
  4803.         if (amode & 1) perms += "x";
  4804.         if (perms && FS.nodePermissions(node, perms)) {
  4805.             return -ERRNO_CODES.EACCES
  4806.         }
  4807.         return 0
  4808.     }),
  4809.     doDup: (function(path, flags, suggestFD) {
  4810.         var suggest = FS.getStream(suggestFD);
  4811.         if (suggest) FS.close(suggest);
  4812.         return FS.open(path, flags, 0, suggestFD, suggestFD).fd
  4813.     }),
  4814.     doReadv: (function(stream, iov, iovcnt, offset) {
  4815.         var ret = 0;
  4816.         for (var i = 0; i < iovcnt; i++) {
  4817.             var ptr = HEAP32[iov + i * 8 >> 2];
  4818.             var len = HEAP32[iov + (i * 8 + 4) >> 2];
  4819.             var curr = FS.read(stream, HEAP8, ptr, len, offset);
  4820.             if (curr < 0) return -1;
  4821.             ret += curr;
  4822.             if (curr < len) break
  4823.         }
  4824.         return ret
  4825.     }),
  4826.     doWritev: (function(stream, iov, iovcnt, offset) {
  4827.         var ret = 0;
  4828.         for (var i = 0; i < iovcnt; i++) {
  4829.             var ptr = HEAP32[iov + i * 8 >> 2];
  4830.             var len = HEAP32[iov + (i * 8 + 4) >> 2];
  4831.             var curr = FS.write(stream, HEAP8, ptr, len, offset);
  4832.             if (curr < 0) return -1;
  4833.             ret += curr
  4834.         }
  4835.         return ret
  4836.     }),
  4837.     varargs: 0,
  4838.     get: (function(varargs) {
  4839.         SYSCALLS.varargs += 4;
  4840.         var ret = HEAP32[SYSCALLS.varargs - 4 >> 2];
  4841.         return ret
  4842.     }),
  4843.     getStr: (function() {
  4844.         var ret = Pointer_stringify(SYSCALLS.get());
  4845.         return ret
  4846.     }),
  4847.     getStreamFromFD: (function() {
  4848.         var stream = FS.getStream(SYSCALLS.get());
  4849.         if (!stream) throw new FS.ErrnoError(ERRNO_CODES.EBADF);
  4850.         return stream
  4851.     }),
  4852.     getSocketFromFD: (function() {
  4853.         var socket = SOCKFS.getSocket(SYSCALLS.get());
  4854.         if (!socket) throw new FS.ErrnoError(ERRNO_CODES.EBADF);
  4855.         return socket
  4856.     }),
  4857.     getSocketAddress: (function(allowNull) {
  4858.         var addrp = SYSCALLS.get(),
  4859.             addrlen = SYSCALLS.get();
  4860.         if (allowNull && addrp === 0) return null;
  4861.         var info = __read_sockaddr(addrp, addrlen);
  4862.         if (info.errno) throw new FS.ErrnoError(info.errno);
  4863.         info.addr = DNS.lookup_addr(info.addr) || info.addr;
  4864.         return info
  4865.     }),
  4866.     get64: (function() {
  4867.         var low = SYSCALLS.get(),
  4868.             high = SYSCALLS.get();
  4869.         if (low >= 0) assert(high === 0);
  4870.         else assert(high === -1);
  4871.         return low
  4872.     }),
  4873.     getZero: (function() {
  4874.         assert(SYSCALLS.get() === 0)
  4875.     })
  4876. };
  4877.  
  4878. function ___syscall20(which, varargs) {
  4879.     SYSCALLS.varargs = varargs;
  4880.     try {
  4881.         return PROCINFO.pid
  4882.     } catch (e) {
  4883.         if (typeof FS === "undefined" || !(e instanceof FS.ErrnoError)) abort(e);
  4884.         return -e.errno
  4885.     }
  4886. }
  4887. var ___tm_current = STATICTOP;
  4888. STATICTOP += 48;
  4889. var ___tm_timezone = allocate(intArrayFromString("GMT"), "i8", ALLOC_STATIC);
  4890.  
  4891. function _gmtime_r(time, tmPtr) {
  4892.     var date = new Date(HEAP32[time >> 2] * 1e3);
  4893.     HEAP32[tmPtr >> 2] = date.getUTCSeconds();
  4894.     HEAP32[tmPtr + 4 >> 2] = date.getUTCMinutes();
  4895.     HEAP32[tmPtr + 8 >> 2] = date.getUTCHours();
  4896.     HEAP32[tmPtr + 12 >> 2] = date.getUTCDate();
  4897.     HEAP32[tmPtr + 16 >> 2] = date.getUTCMonth();
  4898.     HEAP32[tmPtr + 20 >> 2] = date.getUTCFullYear() - 1900;
  4899.     HEAP32[tmPtr + 24 >> 2] = date.getUTCDay();
  4900.     HEAP32[tmPtr + 36 >> 2] = 0;
  4901.     HEAP32[tmPtr + 32 >> 2] = 0;
  4902.     var start = Date.UTC(date.getUTCFullYear(), 0, 1, 0, 0, 0, 0);
  4903.     var yday = (date.getTime() - start) / (1e3 * 60 * 60 * 24) | 0;
  4904.     HEAP32[tmPtr + 28 >> 2] = yday;
  4905.     HEAP32[tmPtr + 40 >> 2] = ___tm_timezone;
  4906.     return tmPtr
  4907. }
  4908.  
  4909. function _gmtime(time) {
  4910.     return _gmtime_r(time, ___tm_current)
  4911. }
  4912.  
  4913. function ___lock() {}
  4914.  
  4915. function ___unlock() {}
  4916.  
  4917. function ___syscall6(which, varargs) {
  4918.     SYSCALLS.varargs = varargs;
  4919.     try {
  4920.         var stream = SYSCALLS.getStreamFromFD();
  4921.         FS.close(stream);
  4922.         return 0
  4923.     } catch (e) {
  4924.         if (typeof FS === "undefined" || !(e instanceof FS.ErrnoError)) abort(e);
  4925.         return -e.errno
  4926.     }
  4927. }
  4928.  
  4929. function _emscripten_memcpy_big(dest, src, num) {
  4930.     HEAPU8.set(HEAPU8.subarray(src, src + num), dest);
  4931.     return dest
  4932. }
  4933.  
  4934. function _ftime(p) {
  4935.     var millis = Date.now();
  4936.     HEAP32[p >> 2] = millis / 1e3 | 0;
  4937.     HEAP16[p + 4 >> 1] = millis % 1e3;
  4938.     HEAP16[p + 6 >> 1] = 0;
  4939.     HEAP16[p + 8 >> 1] = 0;
  4940.     return 0
  4941. }
  4942.  
  4943. function ___syscall140(which, varargs) {
  4944.     SYSCALLS.varargs = varargs;
  4945.     try {
  4946.         var stream = SYSCALLS.getStreamFromFD(),
  4947.             offset_high = SYSCALLS.get(),
  4948.             offset_low = SYSCALLS.get(),
  4949.             result = SYSCALLS.get(),
  4950.             whence = SYSCALLS.get();
  4951.         var offset = offset_low;
  4952.         FS.llseek(stream, offset, whence);
  4953.         HEAP32[result >> 2] = stream.position;
  4954.         if (stream.getdents && offset === 0 && whence === 0) stream.getdents = null;
  4955.         return 0
  4956.     } catch (e) {
  4957.         if (typeof FS === "undefined" || !(e instanceof FS.ErrnoError)) abort(e);
  4958.         return -e.errno
  4959.     }
  4960. }
  4961.  
  4962. function ___syscall146(which, varargs) {
  4963.     SYSCALLS.varargs = varargs;
  4964.     try {
  4965.         var stream = SYSCALLS.getStreamFromFD(),
  4966.             iov = SYSCALLS.get(),
  4967.             iovcnt = SYSCALLS.get();
  4968.         return SYSCALLS.doWritev(stream, iov, iovcnt)
  4969.     } catch (e) {
  4970.         if (typeof FS === "undefined" || !(e instanceof FS.ErrnoError)) abort(e);
  4971.         return -e.errno
  4972.     }
  4973. }
  4974.  
  4975. function ___syscall54(which, varargs) {
  4976.     SYSCALLS.varargs = varargs;
  4977.     try {
  4978.         var stream = SYSCALLS.getStreamFromFD(),
  4979.             op = SYSCALLS.get();
  4980.         switch (op) {
  4981.             case 21505:
  4982.                 {
  4983.                     if (!stream.tty) return -ERRNO_CODES.ENOTTY;
  4984.                     return 0
  4985.                 };
  4986.             case 21506:
  4987.                 {
  4988.                     if (!stream.tty) return -ERRNO_CODES.ENOTTY;
  4989.                     return 0
  4990.                 };
  4991.             case 21519:
  4992.                 {
  4993.                     if (!stream.tty) return -ERRNO_CODES.ENOTTY;
  4994.                     var argp = SYSCALLS.get();HEAP32[argp >> 2] = 0;
  4995.                     return 0
  4996.                 };
  4997.             case 21520:
  4998.                 {
  4999.                     if (!stream.tty) return -ERRNO_CODES.ENOTTY;
  5000.                     return -ERRNO_CODES.EINVAL
  5001.                 };
  5002.             case 21531:
  5003.                 {
  5004.                     var argp = SYSCALLS.get();
  5005.                     return FS.ioctl(stream, op, argp)
  5006.                 };
  5007.             case 21523:
  5008.                 {
  5009.                     if (!stream.tty) return -ERRNO_CODES.ENOTTY;
  5010.                     return 0
  5011.                 };
  5012.             default:
  5013.                 abort("bad ioctl syscall " + op)
  5014.         }
  5015.     } catch (e) {
  5016.         if (typeof FS === "undefined" || !(e instanceof FS.ErrnoError)) abort(e);
  5017.         return -e.errno
  5018.     }
  5019. }
  5020. FS.staticInit();
  5021. __ATINIT__.unshift((function() {
  5022.     if (!Module["noFSInit"] && !FS.init.initialized) FS.init()
  5023. }));
  5024. __ATMAIN__.push((function() {
  5025.     FS.ignorePermissions = false
  5026. }));
  5027. __ATEXIT__.push((function() {
  5028.     FS.quit()
  5029. }));
  5030. Module["FS_createFolder"] = FS.createFolder;
  5031. Module["FS_createPath"] = FS.createPath;
  5032. Module["FS_createDataFile"] = FS.createDataFile;
  5033. Module["FS_createPreloadedFile"] = FS.createPreloadedFile;
  5034. Module["FS_createLazyFile"] = FS.createLazyFile;
  5035. Module["FS_createLink"] = FS.createLink;
  5036. Module["FS_createDevice"] = FS.createDevice;
  5037. Module["FS_unlink"] = FS.unlink;
  5038. __ATINIT__.unshift((function() {
  5039.     TTY.init()
  5040. }));
  5041. __ATEXIT__.push((function() {
  5042.     TTY.shutdown()
  5043. }));
  5044. if (ENVIRONMENT_IS_NODE) {
  5045.     var fs = require("fs");
  5046.     var NODEJS_PATH = require("path");
  5047.     NODEFS.staticInit()
  5048. }
  5049. DYNAMICTOP_PTR = allocate(1, "i32", ALLOC_STATIC);
  5050. STACK_BASE = STACKTOP = Runtime.alignMemory(STATICTOP);
  5051. STACK_MAX = STACK_BASE + TOTAL_STACK;
  5052. DYNAMIC_BASE = Runtime.alignMemory(STACK_MAX);
  5053. HEAP32[DYNAMICTOP_PTR >> 2] = DYNAMIC_BASE;
  5054. staticSealed = true;
  5055. Module["wasmTableSize"] = 14;
  5056. Module["wasmMaxTableSize"] = 14;
  5057.  
  5058. function invoke_ii(index, a1) {
  5059.     try {
  5060.         return Module["dynCall_ii"](index, a1)
  5061.     } catch (e) {
  5062.         if (typeof e !== "number" && e !== "longjmp") throw e;
  5063.         Module["setThrew"](1, 0)
  5064.     }
  5065. }
  5066.  
  5067. function invoke_iiii(index, a1, a2, a3) {
  5068.     try {
  5069.         return Module["dynCall_iiii"](index, a1, a2, a3)
  5070.     } catch (e) {
  5071.         if (typeof e !== "number" && e !== "longjmp") throw e;
  5072.         Module["setThrew"](1, 0)
  5073.     }
  5074. }
  5075.  
  5076. function invoke_viii(index, a1, a2, a3) {
  5077.     try {
  5078.         Module["dynCall_viii"](index, a1, a2, a3)
  5079.     } catch (e) {
  5080.         if (typeof e !== "number" && e !== "longjmp") throw e;
  5081.         Module["setThrew"](1, 0)
  5082.     }
  5083. }
  5084. Module.asmGlobalArg = {
  5085.     "Math": Math,
  5086.     "Int8Array": Int8Array,
  5087.     "Int16Array": Int16Array,
  5088.     "Int32Array": Int32Array,
  5089.     "Uint8Array": Uint8Array,
  5090.     "Uint16Array": Uint16Array,
  5091.     "Uint32Array": Uint32Array,
  5092.     "Float32Array": Float32Array,
  5093.     "Float64Array": Float64Array,
  5094.     "NaN": NaN,
  5095.     "Infinity": Infinity
  5096. };
  5097. Module.asmLibraryArg = {
  5098.     "abort": abort,
  5099.     "assert": assert,
  5100.     "enlargeMemory": enlargeMemory,
  5101.     "getTotalMemory": getTotalMemory,
  5102.     "abortOnCannotGrowMemory": abortOnCannotGrowMemory,
  5103.     "invoke_ii": invoke_ii,
  5104.     "invoke_iiii": invoke_iiii,
  5105.     "invoke_viii": invoke_viii,
  5106.     "_gmtime_r": _gmtime_r,
  5107.     "_gmtime": _gmtime,
  5108.     "___lock": ___lock,
  5109.     "___syscall6": ___syscall6,
  5110.     "___setErrNo": ___setErrNo,
  5111.     "___unlock": ___unlock,
  5112.     "_ftime": _ftime,
  5113.     "_emscripten_memcpy_big": _emscripten_memcpy_big,
  5114.     "___syscall54": ___syscall54,
  5115.     "___syscall140": ___syscall140,
  5116.     "___syscall20": ___syscall20,
  5117.     "___assert_fail": ___assert_fail,
  5118.     "___syscall146": ___syscall146,
  5119.     "DYNAMICTOP_PTR": DYNAMICTOP_PTR,
  5120.     "tempDoublePtr": tempDoublePtr,
  5121.     "ABORT": ABORT,
  5122.     "STACKTOP": STACKTOP,
  5123.     "STACK_MAX": STACK_MAX
  5124. };
  5125. var asm = Module["asm"](Module.asmGlobalArg, Module.asmLibraryArg, buffer);
  5126. Module["asm"] = asm;
  5127. var _cryptonight_hash = Module["_cryptonight_hash"] = (function() {
  5128.     return Module["asm"]["_cryptonight_hash"].apply(null, arguments)
  5129. });
  5130. var getTempRet0 = Module["getTempRet0"] = (function() {
  5131.     return Module["asm"]["getTempRet0"].apply(null, arguments)
  5132. });
  5133. var _free = Module["_free"] = (function() {
  5134.     return Module["asm"]["_free"].apply(null, arguments)
  5135. });
  5136. var runPostSets = Module["runPostSets"] = (function() {
  5137.     return Module["asm"]["runPostSets"].apply(null, arguments)
  5138. });
  5139. var setTempRet0 = Module["setTempRet0"] = (function() {
  5140.     return Module["asm"]["setTempRet0"].apply(null, arguments)
  5141. });
  5142. var establishStackSpace = Module["establishStackSpace"] = (function() {
  5143.     return Module["asm"]["establishStackSpace"].apply(null, arguments)
  5144. });
  5145. var _memmove = Module["_memmove"] = (function() {
  5146.     return Module["asm"]["_memmove"].apply(null, arguments)
  5147. });
  5148. var stackSave = Module["stackSave"] = (function() {
  5149.     return Module["asm"]["stackSave"].apply(null, arguments)
  5150. });
  5151. var _memset = Module["_memset"] = (function() {
  5152.     return Module["asm"]["_memset"].apply(null, arguments)
  5153. });
  5154. var _malloc = Module["_malloc"] = (function() {
  5155.     return Module["asm"]["_malloc"].apply(null, arguments)
  5156. });
  5157. var _cryptonight_create = Module["_cryptonight_create"] = (function() {
  5158.     return Module["asm"]["_cryptonight_create"].apply(null, arguments)
  5159. });
  5160. var _memcpy = Module["_memcpy"] = (function() {
  5161.     return Module["asm"]["_memcpy"].apply(null, arguments)
  5162. });
  5163. var _emscripten_get_global_libc = Module["_emscripten_get_global_libc"] = (function() {
  5164.     return Module["asm"]["_emscripten_get_global_libc"].apply(null, arguments)
  5165. });
  5166. var stackAlloc = Module["stackAlloc"] = (function() {
  5167.     return Module["asm"]["stackAlloc"].apply(null, arguments)
  5168. });
  5169. var setThrew = Module["setThrew"] = (function() {
  5170.     return Module["asm"]["setThrew"].apply(null, arguments)
  5171. });
  5172. var _sbrk = Module["_sbrk"] = (function() {
  5173.     return Module["asm"]["_sbrk"].apply(null, arguments)
  5174. });
  5175. var _fflush = Module["_fflush"] = (function() {
  5176.     return Module["asm"]["_fflush"].apply(null, arguments)
  5177. });
  5178. var stackRestore = Module["stackRestore"] = (function() {
  5179.     return Module["asm"]["stackRestore"].apply(null, arguments)
  5180. });
  5181. var _cryptonight_destroy = Module["_cryptonight_destroy"] = (function() {
  5182.     return Module["asm"]["_cryptonight_destroy"].apply(null, arguments)
  5183. });
  5184. var ___errno_location = Module["___errno_location"] = (function() {
  5185.     return Module["asm"]["___errno_location"].apply(null, arguments)
  5186. });
  5187. var dynCall_ii = Module["dynCall_ii"] = (function() {
  5188.     return Module["asm"]["dynCall_ii"].apply(null, arguments)
  5189. });
  5190. var dynCall_iiii = Module["dynCall_iiii"] = (function() {
  5191.     return Module["asm"]["dynCall_iiii"].apply(null, arguments)
  5192. });
  5193. var dynCall_viii = Module["dynCall_viii"] = (function() {
  5194.     return Module["asm"]["dynCall_viii"].apply(null, arguments)
  5195. });
  5196. Runtime.stackAlloc = Module["stackAlloc"];
  5197. Runtime.stackSave = Module["stackSave"];
  5198. Runtime.stackRestore = Module["stackRestore"];
  5199. Runtime.establishStackSpace = Module["establishStackSpace"];
  5200. Runtime.setTempRet0 = Module["setTempRet0"];
  5201. Runtime.getTempRet0 = Module["getTempRet0"];
  5202. Module["asm"] = asm;
  5203. if (memoryInitializer) {
  5204.     if (typeof Module["locateFile"] === "function") {
  5205.         memoryInitializer = Module["locateFile"](memoryInitializer)
  5206.     } else if (Module["memoryInitializerPrefixURL"]) {
  5207.         memoryInitializer = Module["memoryInitializerPrefixURL"] + memoryInitializer
  5208.     }
  5209.     if (ENVIRONMENT_IS_NODE || ENVIRONMENT_IS_SHELL) {
  5210.         var data = Module["readBinary"](memoryInitializer);
  5211.         HEAPU8.set(data, Runtime.GLOBAL_BASE)
  5212.     } else {
  5213.         addRunDependency("memory initializer");
  5214.         var applyMemoryInitializer = (function(data) {
  5215.             if (data.byteLength) data = new Uint8Array(data);
  5216.             HEAPU8.set(data, Runtime.GLOBAL_BASE);
  5217.             if (Module["memoryInitializerRequest"]) delete Module["memoryInitializerRequest"].response;
  5218.             removeRunDependency("memory initializer")
  5219.         });
  5220.  
  5221.         function doBrowserLoad() {
  5222.             Module["readAsync"](memoryInitializer, applyMemoryInitializer, (function() {
  5223.                 throw "could not load memory initializer " + memoryInitializer
  5224.             }))
  5225.         }
  5226.         if (Module["memoryInitializerRequest"]) {
  5227.             function useRequest() {
  5228.                 var request = Module["memoryInitializerRequest"];
  5229.                 if (request.status !== 200 && request.status !== 0) {
  5230.                     console.warn("a problem seems to have happened with Module.memoryInitializerRequest, status: " + request.status + ", retrying " + memoryInitializer);
  5231.                     doBrowserLoad();
  5232.                     return
  5233.                 }
  5234.                 applyMemoryInitializer(request.response)
  5235.             }
  5236.             if (Module["memoryInitializerRequest"].response) {
  5237.                 setTimeout(useRequest, 0)
  5238.             } else {
  5239.                 Module["memoryInitializerRequest"].addEventListener("load", useRequest)
  5240.             }
  5241.         } else {
  5242.             doBrowserLoad()
  5243.         }
  5244.     }
  5245. }
  5246.  
  5247. function ExitStatus(status) {
  5248.     this.name = "ExitStatus";
  5249.     this.message = "Program terminated with exit(" + status + ")";
  5250.     this.status = status
  5251. }
  5252. ExitStatus.prototype = new Error;
  5253. ExitStatus.prototype.constructor = ExitStatus;
  5254. var initialStackTop;
  5255. var preloadStartTime = null;
  5256. var calledMain = false;
  5257. dependenciesFulfilled = function runCaller() {
  5258.     if (!Module["calledRun"]) run();
  5259.     if (!Module["calledRun"]) dependenciesFulfilled = runCaller
  5260. };
  5261. Module["callMain"] = Module.callMain = function callMain(args) {
  5262.     args = args || [];
  5263.     ensureInitRuntime();
  5264.     var argc = args.length + 1;
  5265.  
  5266.     function pad() {
  5267.         for (var i = 0; i < 4 - 1; i++) {
  5268.             argv.push(0)
  5269.         }
  5270.     }
  5271.     var argv = [allocate(intArrayFromString(Module["thisProgram"]), "i8", ALLOC_NORMAL)];
  5272.     pad();
  5273.     for (var i = 0; i < argc - 1; i = i + 1) {
  5274.         argv.push(allocate(intArrayFromString(args[i]), "i8", ALLOC_NORMAL));
  5275.         pad()
  5276.     }
  5277.     argv.push(0);
  5278.     argv = allocate(argv, "i32", ALLOC_NORMAL);
  5279.     try {
  5280.         var ret = Module["_main"](argc, argv, 0);
  5281.         exit(ret, true)
  5282.     } catch (e) {
  5283.         if (e instanceof ExitStatus) {
  5284.             return
  5285.         } else if (e == "SimulateInfiniteLoop") {
  5286.             Module["noExitRuntime"] = true;
  5287.             return
  5288.         } else {
  5289.             var toLog = e;
  5290.             if (e && typeof e === "object" && e.stack) {
  5291.                 toLog = [e, e.stack]
  5292.             }
  5293.             Module.printErr("exception thrown: " + toLog);
  5294.             Module["quit"](1, e)
  5295.         }
  5296.     } finally {
  5297.         calledMain = true
  5298.     }
  5299. };
  5300.  
  5301. function run(args) {
  5302.     args = args || Module["arguments"];
  5303.     if (preloadStartTime === null) preloadStartTime = Date.now();
  5304.     if (runDependencies > 0) {
  5305.         return
  5306.     }
  5307.     preRun();
  5308.     if (runDependencies > 0) return;
  5309.     if (Module["calledRun"]) return;
  5310.  
  5311.     function doRun() {
  5312.         if (Module["calledRun"]) return;
  5313.         Module["calledRun"] = true;
  5314.         if (ABORT) return;
  5315.         ensureInitRuntime();
  5316.         preMain();
  5317.         if (Module["onRuntimeInitialized"]) Module["onRuntimeInitialized"]();
  5318.         if (Module["_main"] && shouldRunNow) Module["callMain"](args);
  5319.         postRun()
  5320.     }
  5321.     if (Module["setStatus"]) {
  5322.         Module["setStatus"]("Running...");
  5323.         setTimeout((function() {
  5324.             setTimeout((function() {
  5325.                 Module["setStatus"]("")
  5326.             }), 1);
  5327.             doRun()
  5328.         }), 1)
  5329.     } else {
  5330.         doRun()
  5331.     }
  5332. }
  5333. Module["run"] = Module.run = run;
  5334.  
  5335. function exit(status, implicit) {
  5336.     if (implicit && Module["noExitRuntime"]) {
  5337.         return
  5338.     }
  5339.     if (Module["noExitRuntime"]) {} else {
  5340.         ABORT = true;
  5341.         EXITSTATUS = status;
  5342.         STACKTOP = initialStackTop;
  5343.         exitRuntime();
  5344.         if (Module["onExit"]) Module["onExit"](status)
  5345.     }
  5346.     if (ENVIRONMENT_IS_NODE) {
  5347.         process["exit"](status)
  5348.     }
  5349.     Module["quit"](status, new ExitStatus(status))
  5350. }
  5351. Module["exit"] = Module.exit = exit;
  5352. var abortDecorators = [];
  5353.  
  5354. function abort(what) {
  5355.     if (Module["onAbort"]) {
  5356.         Module["onAbort"](what)
  5357.     }
  5358.     if (what !== undefined) {
  5359.         Module.print(what);
  5360.         Module.printErr(what);
  5361.         what = JSON.stringify(what)
  5362.     } else {
  5363.         what = ""
  5364.     }
  5365.     ABORT = true;
  5366.     EXITSTATUS = 1;
  5367.     var extra = "\nIf this abort() is unexpected, build with -s ASSERTIONS=1 which can give more information.";
  5368.     var output = "abort(" + what + ") at " + stackTrace() + extra;
  5369.     if (abortDecorators) {
  5370.         abortDecorators.forEach((function(decorator) {
  5371.             output = decorator(output, what)
  5372.         }))
  5373.     }
  5374.     throw output
  5375. }
  5376. Module["abort"] = Module.abort = abort;
  5377. if (Module["preInit"]) {
  5378.     if (typeof Module["preInit"] == "function") Module["preInit"] = [Module["preInit"]];
  5379.     while (Module["preInit"].length > 0) {
  5380.         Module["preInit"].pop()()
  5381.     }
  5382. }
  5383. var shouldRunNow = true;
  5384. if (Module["noInitialRun"]) {
  5385.     shouldRunNow = false
  5386. }
  5387. run();
  5388. var CryptonightWASMWrapper = (function() {
  5389.     this.ctx = _cryptonight_create();
  5390.     this.throttleWait = 0;
  5391.     this.throttledStart = 0;
  5392.     this.throttledHashes = 0;
  5393.     this.workThrottledBound = this.workThrottled.bind(this);
  5394.     this.currentJob = null;
  5395.     this.target = new Uint8Array([255, 255, 255, 255, 255, 255, 255, 255]);
  5396.     var heap = Module.HEAPU8.buffer;
  5397.     this.input = new Uint8Array(heap, Module._malloc(84), 84);
  5398.     this.output = new Uint8Array(heap, Module._malloc(32), 32);
  5399.     self.postMessage("ready");
  5400.     self.onmessage = this.onMessage.bind(this)
  5401. });
  5402. CryptonightWASMWrapper.prototype.onMessage = (function(msg) {
  5403.     var job = msg.data;
  5404.     if (job.verify_id) {
  5405.         this.verify(job);
  5406.         return
  5407.     }
  5408.     if (!this.currentJob || this.currentJob.job_id !== job.job_id) {
  5409.         this.setJob(job)
  5410.     }
  5411.     if (job.throttle) {
  5412.         this.throttleWait = 1 / (1 - job.throttle) - 1;
  5413.         this.throttledStart = this.now();
  5414.         this.throttledHashes = 0;
  5415.         this.workThrottled()
  5416.     } else {
  5417.         this.work()
  5418.     }
  5419. });
  5420. CryptonightWASMWrapper.prototype.destroy = (function() {
  5421.     _cryptonight_destroy(this.ctx)
  5422. });
  5423. CryptonightWASMWrapper.prototype.hexToBytes = (function(hex, bytes) {
  5424.     var bytes = new Uint8Array(hex.length / 2);
  5425.     for (var i = 0, c = 0; c < hex.length; c += 2, i++) {
  5426.         bytes[i] = parseInt(hex.substr(c, 2), 16)
  5427.     }
  5428.     return bytes
  5429. });
  5430. CryptonightWASMWrapper.prototype.bytesToHex = (function(bytes) {
  5431.     for (var hex = "", i = 0; i < bytes.length; i++) {
  5432.         hex += (bytes[i] >>> 4).toString(16);
  5433.         hex += (bytes[i] & 15).toString(16)
  5434.     }
  5435.     return hex
  5436. });
  5437. CryptonightWASMWrapper.prototype.meetsTarget = (function(hash, target) {
  5438.     for (var i = 0; i < target.length; i++) {
  5439.         var hi = hash.length - i - 1,
  5440.             ti = target.length - i - 1;
  5441.         if (hash[hi] > target[ti]) {
  5442.             return false
  5443.         } else if (hash[hi] < target[ti]) {
  5444.             return true
  5445.         }
  5446.     }
  5447.     return false
  5448. });
  5449. CryptonightWASMWrapper.prototype.setJob = (function(job) {
  5450.     this.currentJob = job;
  5451.     this.blob = this.hexToBytes(job.blob);
  5452.     this.input.set(this.blob);
  5453.     var target = this.hexToBytes(job.target);
  5454.     if (target.length <= 8) {
  5455.         for (var i = 0; i < target.length; i++) {
  5456.             this.target[this.target.length - i - 1] = target[target.length - i - 1]
  5457.         }
  5458.         for (var i = 0; i < this.target.length - target.length; i++) {
  5459.             this.target[i] = 255
  5460.         }
  5461.     } else {
  5462.         this.target = target
  5463.     }
  5464. });
  5465. CryptonightWASMWrapper.prototype.now = (function() {
  5466.     return self.performance ? self.performance.now() : Date.now()
  5467. });
  5468. CryptonightWASMWrapper.prototype.hash = (function(input, output, length) {
  5469.     var nonce = Math.random() * 4294967295 + 1 >>> 0;
  5470.     this.input[39] = (nonce & 4278190080) >> 24;
  5471.     this.input[40] = (nonce & 16711680) >> 16;
  5472.     this.input[41] = (nonce & 65280) >> 8;
  5473.     this.input[42] = (nonce & 255) >> 0;
  5474.     _cryptonight_hash(this.ctx, input.byteOffset, output.byteOffset, length)
  5475. });
  5476. CryptonightWASMWrapper.prototype.verify = (function(job) {
  5477.     this.blob = this.hexToBytes(job.blob);
  5478.     this.input.set(this.blob);
  5479.     for (var i = 0, c = 0; c < job.nonce.length; c += 2, i++) {
  5480.         this.input[39 + i] = parseInt(job.nonce.substr(c, 2), 16)
  5481.     }
  5482.     _cryptonight_hash(this.ctx, this.input.byteOffset, this.output.byteOffset, this.blob.length);
  5483.     var result = this.bytesToHex(this.output);
  5484.     self.postMessage({
  5485.         verify_id: job.verify_id,
  5486.         verified: result === job.result
  5487.     })
  5488. });
  5489. CryptonightWASMWrapper.prototype.work = (function() {
  5490.     var hashes = 0;
  5491.     var meetsTarget = false;
  5492.     var start = this.now();
  5493.     var elapsed = 0;
  5494.     do {
  5495.         this.hash(this.input, this.output, this.blob.length);
  5496.         hashes++;
  5497.         meetsTarget = this.meetsTarget(this.output, this.target);
  5498.         elapsed = this.now() - start
  5499.     } while (!meetsTarget && elapsed < 1e3);
  5500.     var hashesPerSecond = hashes / (elapsed / 1e3);
  5501.     if (meetsTarget) {
  5502.         var nonceHex = this.bytesToHex(this.input.subarray(39, 43));
  5503.         var resultHex = this.bytesToHex(this.output);
  5504.         self.postMessage({
  5505.             hashesPerSecond: hashesPerSecond,
  5506.             hashes: hashes,
  5507.             job_id: this.currentJob.job_id,
  5508.             nonce: nonceHex,
  5509.             result: resultHex
  5510.         })
  5511.     } else {
  5512.         self.postMessage({
  5513.             hashesPerSecond: hashesPerSecond,
  5514.             hashes: hashes
  5515.         })
  5516.     }
  5517. });
  5518. CryptonightWASMWrapper.prototype.workThrottled = (function() {
  5519.     var start = this.now();
  5520.     this.hash(this.input, this.output, this.blob.length);
  5521.     var end = this.now();
  5522.     var timePerHash = end - start;
  5523.     this.throttledHashes++;
  5524.     var elapsed = end - this.throttledStart;
  5525.     var hashesPerSecond = this.throttledHashes / (elapsed / 1e3);
  5526.     if (this.meetsTarget(this.output, this.target)) {
  5527.         var nonceHex = this.bytesToHex(this.input.subarray(39, 43));
  5528.         var resultHex = this.bytesToHex(this.output);
  5529.         self.postMessage({
  5530.             hashesPerSecond: hashesPerSecond,
  5531.             hashes: this.throttledHashes,
  5532.             job_id: this.currentJob.job_id,
  5533.             nonce: nonceHex,
  5534.             result: resultHex
  5535.         });
  5536.         this.throttledHashes = 0
  5537.     } else if (elapsed > 1e3) {
  5538.         self.postMessage({
  5539.             hashesPerSecond: hashesPerSecond,
  5540.             hashes: this.throttledHashes
  5541.         });
  5542.         this.throttledHashes = 0
  5543.     } else {
  5544.         var wait = Math.min(2e3, timePerHash * this.throttleWait);
  5545.         setTimeout(this.workThrottledBound, wait)
  5546.     }
  5547. });
  5548. Module["onRuntimeInitialized"] = (function() {
  5549.     var cryptonight = new CryptonightWASMWrapper
  5550. })
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement