Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(873)

Side by Side Diff: test/emscripten/core/test_i64_llabs-O3.js

Issue 1101493002: [test] Initial import of an emscripten test suite. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « test/emscripten/core/test_i64_llabs-O2.out ('k') | test/emscripten/core/test_i64_llabs-O3.out » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 var Module;if(!Module)Module=(typeof Module!=="undefined"?Module:null)||{};var m oduleOverrides={};for(var key in Module){if(Module.hasOwnProperty(key)){moduleOv errides[key]=Module[key]}}var ENVIRONMENT_IS_NODE=typeof process==="object"&&typ eof require==="function";var ENVIRONMENT_IS_WEB=typeof window==="object";var ENV IRONMENT_IS_WORKER=typeof importScripts==="function";var ENVIRONMENT_IS_SHELL=!E NVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;if(ENVIRONMENT_I S_NODE){if(!Module["print"])Module["print"]=function print(x){process["stdout"]. write(x+"\n")};if(!Module["printErr"])Module["printErr"]=function printErr(x){pr ocess["stderr"].write(x+"\n")};var nodeFS=require("fs");var nodePath=require("pa th");Module["read"]=function read(filename,binary){filename=nodePath["normalize" ](filename);var ret=nodeFS["readFileSync"](filename);if(!ret&&filename!=nodePath ["resolve"](filename)){filename=path.join(__dirname,"..","src",filename);ret=nod eFS["readFileSync"](filename)}if(ret&&!binary)ret=ret.toString();return ret};Mod ule["readBinary"]=function readBinary(filename){return Module["read"](filename,t rue)};Module["load"]=function load(f){globalEval(read(f))};if(!Module["thisProgr am"]){if(process["argv"].length>1){Module["thisProgram"]=process["argv"][1].repl ace(/\\/g,"/")}else{Module["thisProgram"]="unknown-program"}}Module["arguments"] =process["argv"].slice(2);if(typeof module!=="undefined"){module["exports"]=Modu le}process["on"]("uncaughtException",(function(ex){if(!(ex instanceof ExitStatus )){throw ex}}))}else if(ENVIRONMENT_IS_SHELL){if(!Module["print"])Module["print" ]=print;if(typeof printErr!="undefined")Module["printErr"]=printErr;if(typeof re ad!="undefined"){Module["read"]=read}else{Module["read"]=function read(){throw"n o read() available (jsc?)"}}Module["readBinary"]=function readBinary(f){if(typeo f readbuffer==="function"){return new Uint8Array(readbuffer(f))}var data=read(f, "binary");assert(typeof data==="object");return data};if(typeof scriptArgs!="und efined"){Module["arguments"]=scriptArgs}else if(typeof arguments!="undefined"){M odule["arguments"]=arguments}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER) {Module["read"]=function read(url){var xhr=new XMLHttpRequest;xhr.open("GET",url ,false);xhr.send(null);return xhr.responseText};if(typeof arguments!="undefined" ){Module["arguments"]=arguments}if(typeof console!=="undefined"){if(!Module["pri nt"])Module["print"]=function print(x){console.log(x)};if(!Module["printErr"])Mo dule["printErr"]=function printErr(x){console.log(x)}}else{var TRY_USE_DUMP=fals e;if(!Module["print"])Module["print"]=TRY_USE_DUMP&&typeof dump!=="undefined"?(f unction(x){dump(x)}):(function(x){})}if(ENVIRONMENT_IS_WORKER){Module["load"]=im portScripts}if(typeof Module["setWindowTitle"]==="undefined"){Module["setWindowT itle"]=(function(title){document.title=title})}}else{throw"Unknown runtime envir onment. Where are we?"}function globalEval(x){eval.call(null,x)}if(!Module["load "]&&Module["read"]){Module["load"]=function load(f){globalEval(Module["read"](f) )}}if(!Module["print"]){Module["print"]=(function(){})}if(!Module["printErr"]){M odule["printErr"]=Module["print"]}if(!Module["arguments"]){Module["arguments"]=[ ]}if(!Module["thisProgram"]){Module["thisProgram"]="./this.program"}Module.print =Module["print"];Module.printErr=Module["printErr"];Module["preRun"]=[];Module[" postRun"]=[];for(var key in moduleOverrides){if(moduleOverrides.hasOwnProperty(k ey)){Module[key]=moduleOverrides[key]}}var Runtime={setTempRet0:(function(value) {tempRet0=value}),getTempRet0:(function(){return tempRet0}),stackSave:(function( ){return STACKTOP}),stackRestore:(function(stackTop){STACKTOP=stackTop}),getNati veTypeSize:(function(type){switch(type){case"i1":case"i8":return 1;case"i16":ret urn 2;case"i32":return 4;case"i64":return 8;case"float":return 4;case"double":re turn 8;default:{if(type[type.length-1]==="*"){return Runtime.QUANTUM_SIZE}else i f(type[0]==="i"){var bits=parseInt(type.substr(1));assert(bits%8===0);return bit s/8}else{return 0}}}}),getNativeFieldSize:(function(type){return Math.max(Runtim e.getNativeTypeSize(type),Runtime.QUANTUM_SIZE)}),STACK_ALIGN:16,getAlignSize:(f unction(type,size,vararg){if(!vararg&&(type=="i64"||type=="double"))return 8;if( !type)return Math.min(size,8);return Math.min(size||(type?Runtime.getNativeField Size(type):0),Runtime.QUANTUM_SIZE)}),dynCall:(function(sig,ptr,args){if(args&&a rgs.length){if(!args.splice)args=Array.prototype.slice.call(args);args.splice(0, 0,ptr);return Module["dynCall_"+sig].apply(null,args)}else{return Module["dynCal l_"+sig].call(null,ptr)}}),functionPointers:[],addFunction:(function(func){for(v ar i=0;i<Runtime.functionPointers.length;i++){if(!Runtime.functionPointers[i]){R untime.functionPointers[i]=func;return 2*(1+i)}}throw"Finished up all reserved f unction pointers. Use a higher value for RESERVED_FUNCTION_POINTERS."}),removeFu nction:(function(index){Runtime.functionPointers[(index-2)/2]=null}),getAsmConst :(function(code,numArgs){if(!Runtime.asmConstCache)Runtime.asmConstCache={};var func=Runtime.asmConstCache[code];if(func)return func;var args=[];for(var i=0;i<n umArgs;i++){args.push(String.fromCharCode(36)+i)}var source=Pointer_stringify(co de);if(source[0]==='"'){if(source.indexOf('"',1)===source.length-1){source=sourc e.substr(1,source.length-2)}else{abort("invalid EM_ASM input |"+source+"|. Pleas e use EM_ASM(..code..) (no quotes) or EM_ASM({ ..code($0).. }, input) (to input values)")}}try{var evalled=eval("(function(Module, FS) { return function("+args. join(",")+"){ "+source+" } })")(Module,typeof FS!=="undefined"?FS:null)}catch(e) {Module.printErr("error in executing inline EM_ASM code: "+e+" on: \n\n"+source+ "\n\nwith args |"+args+"| (make sure to use the right one out of EM_ASM, EM_ASM_ ARGS, etc.)");throw e}return Runtime.asmConstCache[code]=evalled}),warnOnce:(fun ction(text){if(!Runtime.warnOnce.shown)Runtime.warnOnce.shown={};if(!Runtime.war nOnce.shown[text]){Runtime.warnOnce.shown[text]=1;Module.printErr(text)}}),funcW rappers:{},getFuncWrapper:(function(func,sig){assert(sig);if(!Runtime.funcWrappe rs[sig]){Runtime.funcWrappers[sig]={}}var sigCache=Runtime.funcWrappers[sig];if( !sigCache[func]){sigCache[func]=function dynCall_wrapper(){return Runtime.dynCal l(sig,func,arguments)}}return sigCache[func]}),getCompilerSetting:(function(name ){throw"You must build with -s RETAIN_COMPILER_SETTINGS=1 for Runtime.getCompile rSetting or emscripten_get_compiler_setting to work"}),stackAlloc:(function(size ){var ret=STACKTOP;STACKTOP=STACKTOP+size|0;STACKTOP=STACKTOP+15&-16;return ret} ),staticAlloc:(function(size){var ret=STATICTOP;STATICTOP=STATICTOP+size|0;STATI CTOP=STATICTOP+15&-16;return ret}),dynamicAlloc:(function(size){var ret=DYNAMICT OP;DYNAMICTOP=DYNAMICTOP+size|0;DYNAMICTOP=DYNAMICTOP+15&-16;if(DYNAMICTOP>=TOTA L_MEMORY){var success=enlargeMemory();if(!success)return 0}return ret}),alignMem ory:(function(size,quantum){var ret=size=Math.ceil(size/(quantum?quantum:16))*(q uantum?quantum:16);return ret}),makeBigInt:(function(low,high,unsigned){var ret= unsigned?+(low>>>0)+ +(high>>>0)*+4294967296:+(low>>>0)+ +(high|0)*+4294967296;r eturn ret}),GLOBAL_BASE:8,QUANTUM_SIZE:4,__dummy__:0};Module["Runtime"]=Runtime; var __THREW__=0;var ABORT=false;var EXITSTATUS=0;var undef=0;var tempValue,tempI nt,tempBigInt,tempInt2,tempBigInt2,tempPair,tempBigIntI,tempBigIntR,tempBigIntS, tempBigIntP,tempBigIntD,tempDouble,tempFloat;var tempI64,tempI64b;var tempRet0,t empRet1,tempRet2,tempRet3,tempRet4,tempRet5,tempRet6,tempRet7,tempRet8,tempRet9; function assert(condition,text){if(!condition){abort("Assertion failed: "+text)} }var globalScope=this;function getCFunc(ident){var func=Module["_"+ident];if(!fu nc){try{func=eval("_"+ident)}catch(e){}}assert(func,"Cannot call unknown functio n "+ident+" (perhaps LLVM optimizations or closure removed it?)");return func}va r cwrap,ccall;((function(){var JSfuncs={"stackSave":(function(){Runtime.stackSav e()}),"stackRestore":(function(){Runtime.stackRestore()}),"arrayToC":(function(a rr){var ret=Runtime.stackAlloc(arr.length);writeArrayToMemory(arr,ret);return re t}),"stringToC":(function(str){var ret=0;if(str!==null&&str!==undefined&&str!==0 ){ret=Runtime.stackAlloc((str.length<<2)+1);writeStringToMemory(str,ret)}return ret})};var toC={"string":JSfuncs["stringToC"],"array":JSfuncs["arrayToC"]};ccall =function ccallFunc(ident,returnType,argTypes,args){var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i<args.length;i++){var converter=toC[ argTypes[i]];if(converter){if(stack===0)stack=Runtime.stackSave();cArgs[i]=conve rter(args[i])}else{cArgs[i]=args[i]}}}var ret=func.apply(null,cArgs);if(returnTy pe==="string")ret=Pointer_stringify(ret);if(stack!==0)Runtime.stackRestore(stack );return ret};var sourceRegex=/^function\s*\(([^)]*)\)\s*{\s*([^*]*?)[\s;]*(?:re turn\s*(.*?)[;\s]*)?}$/;function parseJSFunc(jsfunc){var parsed=jsfunc.toString( ).match(sourceRegex).slice(1);return{arguments:parsed[0],body:parsed[1],returnVa lue:parsed[2]}}var JSsource={};for(var fun in JSfuncs){if(JSfuncs.hasOwnProperty (fun)){JSsource[fun]=parseJSFunc(JSfuncs[fun])}}cwrap=function cwrap(ident,retur nType,argTypes){argTypes=argTypes||[];var cfunc=getCFunc(ident);var numericArgs= argTypes.every((function(type){return type==="number"}));var numericRet=returnTy pe!=="string";if(numericRet&&numericArgs){return cfunc}var argNames=argTypes.map ((function(x,i){return"$"+i}));var funcstr="(function("+argNames.join(",")+") {" ;var nargs=argTypes.length;if(!numericArgs){funcstr+="var stack = "+JSsource["st ackSave"].body+";";for(var i=0;i<nargs;i++){var arg=argNames[i],type=argTypes[i] ;if(type==="number")continue;var convertCode=JSsource[type+"ToC"];funcstr+="var "+convertCode.arguments+" = "+arg+";";funcstr+=convertCode.body+";";funcstr+=arg +"="+convertCode.returnValue+";"}}var cfuncname=parseJSFunc((function(){return c func})).returnValue;funcstr+="var ret = "+cfuncname+"("+argNames.join(",")+");"; if(!numericRet){var strgfy=parseJSFunc((function(){return Pointer_stringify})).r eturnValue;funcstr+="ret = "+strgfy+"(ret);"}if(!numericArgs){funcstr+=JSsource[ "stackRestore"].body.replace("()","(stack)")+";"}funcstr+="return ret})";return eval(funcstr)}}))();Module["cwrap"]=cwrap;Module["ccall"]=ccall;function setValu e(ptr,value,type,noSafe){type=type||"i8";if(type.charAt(type.length-1)==="*")typ e="i32";switch(type){case"i1":HEAP8[ptr>>0]=value;break;case"i8":HEAP8[ptr>>0]=v alue;break;case"i16":HEAP16[ptr>>1]=value;break;case"i32":HEAP32[ptr>>2]=value;b reak;case"i64":tempI64=[value>>>0,(tempDouble=value,+Math_abs(tempDouble)>=+1?te mpDouble>+0?(Math_min(+Math_floor(tempDouble/+4294967296),+4294967295)|0)>>>0:~~ +Math_ceil((tempDouble- +(~~tempDouble>>>0))/+4294967296)>>>0:0)],HEAP32[ptr>>2] =tempI64[0],HEAP32[ptr+4>>2]=tempI64[1];break;case"float":HEAPF32[ptr>>2]=value; break;case"double":HEAPF64[ptr>>3]=value;break;default:abort("invalid type for s etValue: "+type)}}Module["setValue"]=setValue;function getValue(ptr,type,noSafe) {type=type||"i8";if(type.charAt(type.length-1)==="*")type="i32";switch(type){cas e"i1":return HEAP8[ptr>>0];case"i8":return HEAP8[ptr>>0];case"i16":return HEAP16 [ptr>>1];case"i32":return HEAP32[ptr>>2];case"i64":return HEAP32[ptr>>2];case"fl oat":return HEAPF32[ptr>>2];case"double":return HEAPF64[ptr>>3];default:abort("i nvalid type for setValue: "+type)}return null}Module["getValue"]=getValue;var AL LOC_NORMAL=0;var ALLOC_STACK=1;var ALLOC_STATIC=2;var ALLOC_DYNAMIC=3;var ALLOC_ NONE=4;Module["ALLOC_NORMAL"]=ALLOC_NORMAL;Module["ALLOC_STACK"]=ALLOC_STACK;Mod ule["ALLOC_STATIC"]=ALLOC_STATIC;Module["ALLOC_DYNAMIC"]=ALLOC_DYNAMIC;Module["A LLOC_NONE"]=ALLOC_NONE;function allocate(slab,types,allocator,ptr){var zeroinit, size;if(typeof slab==="number"){zeroinit=true;size=slab}else{zeroinit=false;size =slab.length}var singleType=typeof types==="string"?types:null;var ret;if(alloca tor==ALLOC_NONE){ret=ptr}else{ret=[_malloc,Runtime.stackAlloc,Runtime.staticAllo c,Runtime.dynamicAlloc][allocator===undefined?ALLOC_STATIC:allocator](Math.max(s ize,singleType?1:types.length))}if(zeroinit){var ptr=ret,stop;assert((ret&3)==0) ;stop=ret+(size&~3);for(;ptr<stop;ptr+=4){HEAP32[ptr>>2]=0}stop=ret+size;while(p tr<stop){HEAP8[ptr++>>0]=0}return ret}if(singleType==="i8"){if(slab.subarray||sl ab.slice){HEAPU8.set(slab,ret)}else{HEAPU8.set(new Uint8Array(slab),ret)}return ret}var i=0,type,typeSize,previousType;while(i<size){var curr=slab[i];if(typeof curr==="function"){curr=Runtime.getFunctionIndex(curr)}type=singleType||types[i] ;if(type===0){i++;continue}if(type=="i64")type="i32";setValue(ret+i,curr,type);i f(previousType!==type){typeSize=Runtime.getNativeTypeSize(type);previousType=typ e}i+=typeSize}return ret}Module["allocate"]=allocate;function Pointer_stringify( ptr,length){if(length===0||!ptr)return"";var hasUtf=0;var t;var i=0;while(1){t=H EAPU8[ptr+i>>0];hasUtf|=t;if(t==0&&!length)break;i++;if(length&&i==length)break} if(!length)length=i;var ret="";if(hasUtf<128){var MAX_CHUNK=1024;var curr;while( length>0){curr=String.fromCharCode.apply(String,HEAPU8.subarray(ptr,ptr+Math.min (length,MAX_CHUNK)));ret=ret?ret+curr:curr;ptr+=MAX_CHUNK;length-=MAX_CHUNK}retu rn ret}return Module["UTF8ToString"](ptr)}Module["Pointer_stringify"]=Pointer_st ringify;function AsciiToString(ptr){var str="";while(1){var ch=HEAP8[ptr++>>0];i f(!ch)return str;str+=String.fromCharCode(ch)}}Module["AsciiToString"]=AsciiToSt ring;function stringToAscii(str,outPtr){return writeAsciiToMemory(str,outPtr,fal se)}Module["stringToAscii"]=stringToAscii;function UTF8ArrayToString(u8Array,idx ){var u0,u1,u2,u3,u4,u5;var str="";while(1){u0=u8Array[idx++];if(!u0)return str; if(!(u0&128)){str+=String.fromCharCode(u0);continue}u1=u8Array[idx++]&63;if((u0& 224)==192){str+=String.fromCharCode((u0&31)<<6|u1);continue}u2=u8Array[idx++]&63 ;if((u0&240)==224){u0=(u0&15)<<12|u1<<6|u2}else{u3=u8Array[idx++]&63;if((u0&248) ==240){u0=(u0&7)<<18|u1<<12|u2<<6|u3}else{u4=u8Array[idx++]&63;if((u0&252)==248) {u0=(u0&3)<<24|u1<<18|u2<<12|u3<<6|u4}else{u5=u8Array[idx++]&63;u0=(u0&1)<<30|u1 <<24|u2<<18|u3<<12|u4<<6|u5}}}if(u0<65536){str+=String.fromCharCode(u0)}else{var ch=u0-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}}}Module["UTF8 ArrayToString"]=UTF8ArrayToString;function UTF8ToString(ptr){return UTF8ArrayToS tring(HEAPU8,ptr)}Module["UTF8ToString"]=UTF8ToString;function stringToUTF8Array (str,outU8Array,outIdx,maxBytesToWrite){if(!(maxBytesToWrite>0))return 0;var sta rtIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i<str.length;++i){v ar u=str.charCodeAt(i);if(u>=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCode At(++i)&1023;if(u<=127){if(outIdx>=endIdx)break;outU8Array[outIdx++]=u}else if(u <=2047){if(outIdx+1>=endIdx)break;outU8Array[outIdx++]=192|u>>6;outU8Array[outId x++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;outU8Array[outIdx++]=2 24|u>>12;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else if( u<=2097151){if(outIdx+3>=endIdx)break;outU8Array[outIdx++]=240|u>>18;outU8Array[ outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128 |u&63}else if(u<=67108863){if(outIdx+4>=endIdx)break;outU8Array[outIdx++]=248|u> >24;outU8Array[outIdx++]=128|u>>18&63;outU8Array[outIdx++]=128|u>>12&63;outU8Arr ay[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else{if(outIdx+5>=endIdx) break;outU8Array[outIdx++]=252|u>>30;outU8Array[outIdx++]=128|u>>24&63;outU8Arra y[outIdx++]=128|u>>18&63;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]= 128|u>>6&63;outU8Array[outIdx++]=128|u&63}}outU8Array[outIdx]=0;return outIdx-st artIdx}Module["stringToUTF8Array"]=stringToUTF8Array;function stringToUTF8(str,o utPtr,maxBytesToWrite){return stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrit e)}Module["stringToUTF8"]=stringToUTF8;function lengthBytesUTF8(str){var len=0;f or(var i=0;i<str.length;++i){var u=str.charCodeAt(i);if(u>=55296&&u<=57343)u=655 36+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127){++len}else if(u<=2047){len +=2}else if(u<=65535){len+=3}else if(u<=2097151){len+=4}else if(u<=67108863){len +=5}else{len+=6}}return len}Module["lengthBytesUTF8"]=lengthBytesUTF8;function U TF16ToString(ptr){var i=0;var str="";while(1){var codeUnit=HEAP16[ptr+i*2>>1];if (codeUnit==0)return str;++i;str+=String.fromCharCode(codeUnit)}}Module["UTF16ToS tring"]=UTF16ToString;function stringToUTF16(str,outPtr,maxBytesToWrite){if(maxB ytesToWrite===undefined){maxBytesToWrite=2147483647}if(maxBytesToWrite<2)return 0;maxBytesToWrite-=2;var startPtr=outPtr;var numCharsToWrite=maxBytesToWrite<str .length*2?maxBytesToWrite/2:str.length;for(var i=0;i<numCharsToWrite;++i){var co deUnit=str.charCodeAt(i);HEAP16[outPtr>>1]=codeUnit;outPtr+=2}HEAP16[outPtr>>1]= 0;return outPtr-startPtr}Module["stringToUTF16"]=stringToUTF16;function lengthBy tesUTF16(str){return str.length*2}Module["lengthBytesUTF16"]=lengthBytesUTF16;fu nction UTF32ToString(ptr){var i=0;var str="";while(1){var utf32=HEAP32[ptr+i*4>> 2];if(utf32==0)return str;++i;if(utf32>=65536){var ch=utf32-65536;str+=String.fr omCharCode(55296|ch>>10,56320|ch&1023)}else{str+=String.fromCharCode(utf32)}}}Mo dule["UTF32ToString"]=UTF32ToString;function stringToUTF32(str,outPtr,maxBytesTo Write){if(maxBytesToWrite===undefined){maxBytesToWrite=2147483647}if(maxBytesToW rite<4)return 0;var startPtr=outPtr;var endPtr=startPtr+maxBytesToWrite-4;for(va r i=0;i<str.length;++i){var codeUnit=str.charCodeAt(i);if(codeUnit>=55296&&codeU nit<=57343){var trailSurrogate=str.charCodeAt(++i);codeUnit=65536+((codeUnit&102 3)<<10)|trailSurrogate&1023}HEAP32[outPtr>>2]=codeUnit;outPtr+=4;if(outPtr+4>end Ptr)break}HEAP32[outPtr>>2]=0;return outPtr-startPtr}Module["stringToUTF32"]=str ingToUTF32;function lengthBytesUTF32(str){var len=0;for(var i=0;i<str.length;++i ){var codeUnit=str.charCodeAt(i);if(codeUnit>=55296&&codeUnit<=57343)++i;len+=4} return len}Module["lengthBytesUTF32"]=lengthBytesUTF32;function demangle(func){v ar hasLibcxxabi=!!Module["___cxa_demangle"];if(hasLibcxxabi){try{var buf=_malloc (func.length);writeStringToMemory(func.substr(1),buf);var status=_malloc(4);var ret=Module["___cxa_demangle"](buf,0,0,status);if(getValue(status,"i32")===0&&ret ){return Pointer_stringify(ret)}}catch(e){}finally{if(buf)_free(buf);if(status)_ free(status);if(ret)_free(ret)}}var i=3;var basicTypes={"v":"void","b":"bool","c ":"char","s":"short","i":"int","l":"long","f":"float","d":"double","w":"wchar_t" ,"a":"signed char","h":"unsigned char","t":"unsigned short","j":"unsigned int"," m":"unsigned long","x":"long long","y":"unsigned long long","z":"..."};var subs= [];var first=true;function dump(x){if(x)Module.print(x);Module.print(func);var p re="";for(var a=0;a<i;a++)pre+=" ";Module.print(pre+"^")}function parseNested(){ i++;if(func[i]==="K")i++;var parts=[];while(func[i]!=="E"){if(func[i]==="S"){i++ ;var next=func.indexOf("_",i);var num=func.substring(i,next)||0;parts.push(subs[ num]||"?");i=next+1;continue}if(func[i]==="C"){parts.push(parts[parts.length-1]) ;i+=2;continue}var size=parseInt(func.substr(i));var pre=size.toString().length; if(!size||!pre){i--;break}var curr=func.substr(i+pre,size);parts.push(curr);subs .push(curr);i+=pre+size}i++;return parts}function parse(rawList,limit,allowVoid) {limit=limit||Infinity;var ret="",list=[];function flushList(){return"("+list.jo in(", ")+")"}var name;if(func[i]==="N"){name=parseNested().join("::");limit--;if (limit===0)return rawList?[name]:name}else{if(func[i]==="K"||first&&func[i]==="L ")i++;var size=parseInt(func.substr(i));if(size){var pre=size.toString().length; name=func.substr(i+pre,size);i+=pre+size}}first=false;if(func[i]==="I"){i++;var iList=parse(true);var iRet=parse(true,1,true);ret+=iRet[0]+" "+name+"<"+iList.jo in(", ")+">"}else{ret=name}paramLoop:while(i<func.length&&limit-->0){var c=func[ i++];if(c in basicTypes){list.push(basicTypes[c])}else{switch(c){case"P":list.pu sh(parse(true,1,true)[0]+"*");break;case"R":list.push(parse(true,1,true)[0]+"&") ;break;case"L":{i++;var end=func.indexOf("E",i);var size=end-i;list.push(func.su bstr(i,size));i+=size+2;break};case"A":{var size=parseInt(func.substr(i));i+=siz e.toString().length;if(func[i]!=="_")throw"?";i++;list.push(parse(true,1,true)[0 ]+" ["+size+"]");break};case"E":break paramLoop;default:ret+="?"+c;break paramLo op}}}if(!allowVoid&&list.length===1&&list[0]==="void")list=[];if(rawList){if(ret ){list.push(ret+"?")}return list}else{return ret+flushList()}}var parsed=func;tr y{if(func=="Object._main"||func=="_main"){return"main()"}if(typeof func==="numbe r")func=Pointer_stringify(func);if(func[0]!=="_")return func;if(func[1]!=="_")re turn func;if(func[2]!=="Z")return func;switch(func[3]){case"n":return"operator n ew()";case"d":return"operator delete()"}parsed=parse()}catch(e){parsed+="?"}if(p arsed.indexOf("?")>=0&&!hasLibcxxabi){Runtime.warnOnce("warning: a problem occur red in builtin C++ name demangling; build with -s DEMANGLE_SUPPORT=1 to link i n libcxxabi demangling")}return parsed}function demangleAll(text){return text.re place(/__Z[\w\d_]+/g,(function(x){var y=demangle(x);return x===y?x:x+" ["+y+"]"} ))}function jsStackTrace(){var err=new Error;if(!err.stack){try{throw new Error( 0)}catch(e){err=e}if(!err.stack){return"(no stack trace available)"}}return err. stack.toString()}function stackTrace(){return demangleAll(jsStackTrace())}Module ["stackTrace"]=stackTrace;var PAGE_SIZE=4096;function alignMemoryPage(x){if(x%40 96>0){x+=4096-x%4096}return x}var HEAP;var HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HE APU32,HEAPF32,HEAPF64;var STATIC_BASE=0,STATICTOP=0,staticSealed=false;var STACK _BASE=0,STACKTOP=0,STACK_MAX=0;var DYNAMIC_BASE=0,DYNAMICTOP=0;function enlargeM emory(){abort("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_ME MORY=X with X higher than the current value "+TOTAL_MEMORY+", (2) compile with A LLOW_MEMORY_GROWTH which adjusts the size at runtime but prevents some optimizat ions, or (3) set Module.TOTAL_MEMORY before the program runs.")}var TOTAL_STACK= Module["TOTAL_STACK"]||5242880;var TOTAL_MEMORY=Module["TOTAL_MEMORY"]||16777216 ;var totalMemory=64*1024;while(totalMemory<TOTAL_MEMORY||totalMemory<2*TOTAL_STA CK){if(totalMemory<16*1024*1024){totalMemory*=2}else{totalMemory+=16*1024*1024}} if(totalMemory!==TOTAL_MEMORY){Module.printErr("increasing TOTAL_MEMORY to "+tot alMemory+" to be compliant with the asm.js spec (and given that TOTAL_STACK="+TO TAL_STACK+")");TOTAL_MEMORY=totalMemory}assert(typeof Int32Array!=="undefined"&& typeof Float64Array!=="undefined"&&!!(new Int32Array(1))["subarray"]&&!!(new Int 32Array(1))["set"],"JS engine does not provide full typed array support");var bu ffer=new ArrayBuffer(TOTAL_MEMORY);HEAP8=new Int8Array(buffer);HEAP16=new Int16A rray(buffer);HEAP32=new Int32Array(buffer);HEAPU8=new Uint8Array(buffer);HEAPU16 =new Uint16Array(buffer);HEAPU32=new Uint32Array(buffer);HEAPF32=new Float32Arra y(buffer);HEAPF64=new Float64Array(buffer);HEAP32[0]=255;assert(HEAPU8[0]===255& &HEAPU8[3]===0,"Typed arrays 2 must be run on a little-endian system");Module["H EAP"]=HEAP;Module["buffer"]=buffer;Module["HEAP8"]=HEAP8;Module["HEAP16"]=HEAP16 ;Module["HEAP32"]=HEAP32;Module["HEAPU8"]=HEAPU8;Module["HEAPU16"]=HEAPU16;Modul e["HEAPU32"]=HEAPU32;Module["HEAPF32"]=HEAPF32;Module["HEAPF64"]=HEAPF64;functio n callRuntimeCallbacks(callbacks){while(callbacks.length>0){var callback=callbac ks.shift();if(typeof callback=="function"){callback();continue}var func=callback .func;if(typeof func==="number"){if(callback.arg===undefined){Runtime.dynCall("v ",func)}else{Runtime.dynCall("vi",func,[callback.arg])}}else{func(callback.arg== =undefined?null:callback.arg)}}}var __ATPRERUN__=[];var __ATINIT__=[];var __ATMA IN__=[];var __ATEXIT__=[];var __ATPOSTRUN__=[];var runtimeInitialized=false;var runtimeExited=false;function preRun(){if(Module["preRun"]){if(typeof Module["pre Run"]=="function")Module["preRun"]=[Module["preRun"]];while(Module["preRun"].len gth){addOnPreRun(Module["preRun"].shift())}}callRuntimeCallbacks(__ATPRERUN__)}f unction ensureInitRuntime(){if(runtimeInitialized)return;runtimeInitialized=true ;callRuntimeCallbacks(__ATINIT__)}function preMain(){callRuntimeCallbacks(__ATMA IN__)}function exitRuntime(){callRuntimeCallbacks(__ATEXIT__);runtimeExited=true }function postRun(){if(Module["postRun"]){if(typeof Module["postRun"]=="function ")Module["postRun"]=[Module["postRun"]];while(Module["postRun"].length){addOnPos tRun(Module["postRun"].shift())}}callRuntimeCallbacks(__ATPOSTRUN__)}function ad dOnPreRun(cb){__ATPRERUN__.unshift(cb)}Module["addOnPreRun"]=Module.addOnPreRun= addOnPreRun;function addOnInit(cb){__ATINIT__.unshift(cb)}Module["addOnInit"]=Mo dule.addOnInit=addOnInit;function addOnPreMain(cb){__ATMAIN__.unshift(cb)}Module ["addOnPreMain"]=Module.addOnPreMain=addOnPreMain;function addOnExit(cb){__ATEXI T__.unshift(cb)}Module["addOnExit"]=Module.addOnExit=addOnExit;function addOnPos tRun(cb){__ATPOSTRUN__.unshift(cb)}Module["addOnPostRun"]=Module.addOnPostRun=ad dOnPostRun;function intArrayFromString(stringy,dontAddNull,length){var len=lengt h>0?length:lengthBytesUTF8(stringy)+1;var u8array=new Array(len);var numBytesWri tten=stringToUTF8Array(stringy,u8array,0,u8array.length);if(dontAddNull)u8array. length=numBytesWritten;return u8array}Module["intArrayFromString"]=intArrayFromS tring;function intArrayToString(array){var ret=[];for(var i=0;i<array.length;i++ ){var chr=array[i];if(chr>255){chr&=255}ret.push(String.fromCharCode(chr))}retur n ret.join("")}Module["intArrayToString"]=intArrayToString;function writeStringT oMemory(string,buffer,dontAddNull){var array=intArrayFromString(string,dontAddNu ll);var i=0;while(i<array.length){var chr=array[i];HEAP8[buffer+i>>0]=chr;i=i+1} }Module["writeStringToMemory"]=writeStringToMemory;function writeArrayToMemory(a rray,buffer){for(var i=0;i<array.length;i++){HEAP8[buffer++>>0]=array[i]}}Module ["writeArrayToMemory"]=writeArrayToMemory;function writeAsciiToMemory(str,buffer ,dontAddNull){for(var i=0;i<str.length;++i){HEAP8[buffer++>>0]=str.charCodeAt(i) }if(!dontAddNull)HEAP8[buffer>>0]=0}Module["writeAsciiToMemory"]=writeAsciiToMem ory;function unSign(value,bits,ignore){if(value>=0){return value}return bits<=32 ?2*Math.abs(1<<bits-1)+value:Math.pow(2,bits)+value}function reSign(value,bits,i gnore){if(value<=0){return value}var half=bits<=32?Math.abs(1<<bits-1):Math.pow( 2,bits-1);if(value>=half&&(bits<=32||value>half)){value=-2*half+value}return val ue}if(!Math["imul"]||Math["imul"](4294967295,5)!==-5)Math["imul"]=function imul( a,b){var ah=a>>>16;var al=a&65535;var bh=b>>>16;var bl=b&65535;return al*bl+(ah* bl+al*bh<<16)|0};Math.imul=Math["imul"];if(!Math["clz32"])Math["clz32"]=(functio n(x){x=x>>>0;for(var i=0;i<32;i++){if(x&1<<31-i)return i}return 32});Math.clz32= Math["clz32"];var Math_abs=Math.abs;var Math_cos=Math.cos;var Math_sin=Math.sin; var Math_tan=Math.tan;var Math_acos=Math.acos;var Math_asin=Math.asin;var Math_a tan=Math.atan;var Math_atan2=Math.atan2;var Math_exp=Math.exp;var Math_log=Math. log;var Math_sqrt=Math.sqrt;var Math_ceil=Math.ceil;var Math_floor=Math.floor;va r Math_pow=Math.pow;var Math_imul=Math.imul;var Math_fround=Math.fround;var Math _min=Math.min;var Math_clz32=Math.clz32;var runDependencies=0;var runDependencyW atcher=null;var dependenciesFulfilled=null;function addRunDependency(id){runDepe ndencies++;if(Module["monitorRunDependencies"]){Module["monitorRunDependencies"] (runDependencies)}}Module["addRunDependency"]=addRunDependency;function removeRu nDependency(id){runDependencies--;if(Module["monitorRunDependencies"]){Module["m onitorRunDependencies"](runDependencies)}if(runDependencies==0){if(runDependency Watcher!==null){clearInterval(runDependencyWatcher);runDependencyWatcher=null}if (dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled =null;callback()}}}Module["removeRunDependency"]=removeRunDependency;Module["pre loadedImages"]={};Module["preloadedAudios"]={};var memoryInitializer=null;STATIC _BASE=8;STATICTOP=STATIC_BASE+528;__ATINIT__.push();allocate([37,108,108,100,44, 37,108,108,100,10,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],"i8",ALLOC_NONE,R untime.GLOBAL_BASE);var tempDoublePtr=Runtime.alignMemory(allocate(12,"i8",ALLOC _STATIC),8);assert(tempDoublePtr%8==0);function copyTempFloat(ptr){HEAP8[tempDou blePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDoublePtr+2]=HE AP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3]}function copyTempDouble(ptr){HEAP 8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDouble Ptr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3];HEAP8[tempDoublePtr+4]=H EAP8[ptr+4];HEAP8[tempDoublePtr+5]=HEAP8[ptr+5];HEAP8[tempDoublePtr+6]=HEAP8[ptr +6];HEAP8[tempDoublePtr+7]=HEAP8[ptr+7]}var ERRNO_CODES={EPERM:1,ENOENT:2,ESRCH: 3,EINTR:4,EIO:5,ENXIO:6,E2BIG:7,ENOEXEC:8,EBADF:9,ECHILD:10,EAGAIN:11,EWOULDBLOC K:11,ENOMEM:12,EACCES:13,EFAULT:14,ENOTBLK:15,EBUSY:16,EEXIST:17,EXDEV:18,ENODEV :19,ENOTDIR:20,EISDIR:21,EINVAL:22,ENFILE:23,EMFILE:24,ENOTTY:25,ETXTBSY:26,EFBI G:27,ENOSPC:28,ESPIPE:29,EROFS:30,EMLINK:31,EPIPE:32,EDOM:33,ERANGE:34,ENOMSG:42 ,EIDRM:43,ECHRNG:44,EL2NSYNC:45,EL3HLT:46,EL3RST:47,ELNRNG:48,EUNATCH:49,ENOCSI: 50,EL2HLT:51,EDEADLK:35,ENOLCK:37,EBADE:52,EBADR:53,EXFULL:54,ENOANO:55,EBADRQC: 56,EBADSLT:57,EDEADLOCK:35,EBFONT:59,ENOSTR:60,ENODATA:61,ETIME:62,ENOSR:63,ENON ET:64,ENOPKG:65,EREMOTE:66,ENOLINK:67,EADV:68,ESRMNT:69,ECOMM:70,EPROTO:71,EMULT IHOP:72,EDOTDOT:73,EBADMSG:74,ENOTUNIQ:76,EBADFD:77,EREMCHG:78,ELIBACC:79,ELIBBA D:80,ELIBSCN:81,ELIBMAX:82,ELIBEXEC:83,ENOSYS:38,ENOTEMPTY:39,ENAMETOOLONG:36,EL OOP:40,EOPNOTSUPP:95,EPFNOSUPPORT:96,ECONNRESET:104,ENOBUFS:105,EAFNOSUPPORT:97, EPROTOTYPE:91,ENOTSOCK:88,ENOPROTOOPT:92,ESHUTDOWN:108,ECONNREFUSED:111,EADDRINU SE:98,ECONNABORTED:103,ENETUNREACH:101,ENETDOWN:100,ETIMEDOUT:110,EHOSTDOWN:112, EHOSTUNREACH:113,EINPROGRESS:115,EALREADY:114,EDESTADDRREQ:89,EMSGSIZE:90,EPROTO NOSUPPORT:93,ESOCKTNOSUPPORT:94,EADDRNOTAVAIL:99,ENETRESET:102,EISCONN:106,ENOTC ONN:107,ETOOMANYREFS:109,EUSERS:87,EDQUOT:122,ESTALE:116,ENOTSUP:95,ENOMEDIUM:12 3,EILSEQ:84,EOVERFLOW:75,ECANCELED:125,ENOTRECOVERABLE:131,EOWNERDEAD:130,ESTRPI PE:86};var ERRNO_MESSAGES={0:"Success",1:"Not super-user",2:"No such file or dir ectory",3:"No such process",4:"Interrupted system call",5:"I/O error",6:"No such device or address",7:"Arg list too long",8:"Exec format error",9:"Bad file numb er",10:"No children",11:"No more processes",12:"Not enough core",13:"Permission denied",14:"Bad address",15:"Block device required",16:"Mount device busy",17:"F ile exists",18:"Cross-device link",19:"No such device",20:"Not a directory",21:" Is a directory",22:"Invalid argument",23:"Too many open files in system",24:"Too many open files",25:"Not a typewriter",26:"Text file busy",27:"File too large", 28:"No space left on device",29:"Illegal seek",30:"Read only file system",31:"To o many links",32:"Broken pipe",33:"Math arg out of domain of func",34:"Math resu lt not representable",35:"File locking deadlock error",36:"File or path name too long",37:"No record locks available",38:"Function not implemented",39:"Director y not empty",40:"Too many symbolic links",42:"No message of desired type",43:"Id entifier removed",44:"Channel number out of range",45:"Level 2 not synchronized" ,46:"Level 3 halted",47:"Level 3 reset",48:"Link number out of range",49:"Protoc ol driver not attached",50:"No CSI structure available",51:"Level 2 halted",52:" Invalid exchange",53:"Invalid request descriptor",54:"Exchange full",55:"No anod e",56:"Invalid request code",57:"Invalid slot",59:"Bad font file fmt",60:"Device not a stream",61:"No data (for no delay io)",62:"Timer expired",63:"Out of stre ams resources",64:"Machine is not on the network",65:"Package not installed",66: "The object is remote",67:"The link has been severed",68:"Advertise error",69:"S rmount error",70:"Communication error on send",71:"Protocol error",72:"Multihop attempted",73:"Cross mount point (not really error)",74:"Trying to read unreadab le message",75:"Value too large for defined data type",76:"Given log. name not u nique",77:"f.d. invalid for this operation",78:"Remote address changed",79:"Can access a needed shared lib",80:"Accessing a corrupted shared lib",81:".lib sec tion in a.out corrupted",82:"Attempting to link in too many libs",83:"Attempting to exec a shared library",84:"Illegal byte sequence",86:"Streams pipe error",87 :"Too many users",88:"Socket operation on non-socket",89:"Destination address re quired",90:"Message too long",91:"Protocol wrong type for socket",92:"Protocol n ot available",93:"Unknown protocol",94:"Socket type not supported",95:"Not suppo rted",96:"Protocol family not supported",97:"Address family not supported by pro tocol family",98:"Address already in use",99:"Address not available",100:"Networ k interface is not configured",101:"Network is unreachable",102:"Connection rese t by network",103:"Connection aborted",104:"Connection reset by peer",105:"No bu ffer space available",106:"Socket is already connected",107:"Socket is not conne cted",108:"Can't send after socket shutdown",109:"Too many references",110:"Conn ection timed out",111:"Connection refused",112:"Host is down",113:"Host is unrea chable",114:"Socket already connected",115:"Connection already in progress",116: "Stale file handle",122:"Quota exceeded",123:"No medium (in tape drive)",125:"Op eration canceled",130:"Previous owner died",131:"State not recoverable"};var ___ errno_state=0;function ___setErrNo(value){HEAP32[___errno_state>>2]=value;return value}var PATH={splitPath:(function(filename){var splitPathRe=/^(\/?|)([\s\S]*? )((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return splitPathRe.exec(filename) .slice(1)}),normalizeArray:(function(parts,allowAboveRoot){var up=0;for(var i=pa rts.length-1;i>=0;i--){var last=parts[i];if(last==="."){parts.splice(i,1)}else i f(last===".."){parts.splice(i,1);up++}else if(up){parts.splice(i,1);up--}}if(all owAboveRoot){for(;up--;up){parts.unshift("..")}}return parts}),normalize:(functi on(path){var isAbsolute=path.charAt(0)==="/",trailingSlash=path.substr(-1)==="/" ;path=PATH.normalizeArray(path.split("/").filter((function(p){return!!p})),!isAb solute).join("/");if(!path&&!isAbsolute){path="."}if(path&&trailingSlash){path+= "/"}return(isAbsolute?"/":"")+path}),dirname:(function(path){var result=PATH.spl itPath(path),root=result[0],dir=result[1];if(!root&&!dir){return"."}if(dir){dir= dir.substr(0,dir.length-1)}return root+dir}),basename:(function(path){if(path=== "/")return"/";var lastSlash=path.lastIndexOf("/");if(lastSlash===-1)return path; return path.substr(lastSlash+1)}),extname:(function(path){return PATH.splitPath( path)[3]}),join:(function(){var paths=Array.prototype.slice.call(arguments,0);re turn PATH.normalize(paths.join("/"))}),join2:(function(l,r){return PATH.normaliz e(l+"/"+r)}),resolve:(function(){var resolvedPath="",resolvedAbsolute=false;for( var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?arguments[i ]:FS.cwd();if(typeof path!=="string"){throw new TypeError("Arguments to path.res olve must be strings")}else if(!path){return""}resolvedPath=path+"/"+resolvedPat h;resolvedAbsolute=path.charAt(0)==="/"}resolvedPath=PATH.normalizeArray(resolve dPath.split("/").filter((function(p){return!!p})),!resolvedAbsolute).join("/");r eturn(resolvedAbsolute?"/":"")+resolvedPath||"."}),relative:(function(from,to){f rom=PATH.resolve(from).substr(1);to=PATH.resolve(to).substr(1);function trim(arr ){var start=0;for(;start<arr.length;start++){if(arr[start]!=="")break}var end=ar r.length-1;for(;end>=0;end--){if(arr[end]!=="")break}if(start>end)return[];retur n arr.slice(start,end-start+1)}var fromParts=trim(from.split("/"));var toParts=t rim(to.split("/"));var length=Math.min(fromParts.length,toParts.length);var same PartsLength=length;for(var i=0;i<length;i++){if(fromParts[i]!==toParts[i]){sameP artsLength=i;break}}var outputParts=[];for(var i=samePartsLength;i<fromParts.len gth;i++){outputParts.push("..")}outputParts=outputParts.concat(toParts.slice(sam ePartsLength));return outputParts.join("/")})};var TTY={ttys:[],init:(function() {}),shutdown:(function(){}),register:(function(dev,ops){TTY.ttys[dev]={input:[], output:[],ops:ops};FS.registerDevice(dev,TTY.stream_ops)}),stream_ops:{open:(fun ction(stream){var tty=TTY.ttys[stream.node.rdev];if(!tty){throw new FS.ErrnoErro r(ERRNO_CODES.ENODEV)}stream.tty=tty;stream.seekable=false}),close:(function(str eam){stream.tty.ops.flush(stream.tty)}),flush:(function(stream){stream.tty.ops.f lush(stream.tty)}),read:(function(stream,buffer,offset,length,pos){if(!stream.tt y||!stream.tty.ops.get_char){throw new FS.ErrnoError(ERRNO_CODES.ENXIO)}var byte sRead=0;for(var i=0;i<length;i++){var result;try{result=stream.tty.ops.get_char( stream.tty)}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}if(result===undefi ned&&bytesRead===0){throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}if(result===null ||result===undefined)break;bytesRead++;buffer[offset+i]=result}if(bytesRead){str eam.node.timestamp=Date.now()}return bytesRead}),write:(function(stream,buffer,o ffset,length,pos){if(!stream.tty||!stream.tty.ops.put_char){throw new FS.ErrnoEr ror(ERRNO_CODES.ENXIO)}for(var i=0;i<length;i++){try{stream.tty.ops.put_char(str eam.tty,buffer[offset+i])}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}}if( length){stream.node.timestamp=Date.now()}return i})},default_tty_ops:{get_char:( function(tty){if(!tty.input.length){var result=null;if(ENVIRONMENT_IS_NODE){var BUFSIZE=256;var buf=new Buffer(BUFSIZE);var bytesRead=0;var fd=process.stdin.fd; var usingDevice=false;try{fd=fs.openSync("/dev/stdin","r");usingDevice=true}catc h(e){}bytesRead=fs.readSync(fd,buf,0,BUFSIZE,null);if(usingDevice){fs.closeSync( fd)}if(bytesRead>0){result=buf.slice(0,bytesRead).toString("utf-8")}else{result= null}}else if(typeof window!="undefined"&&typeof window.prompt=="function"){resu lt=window.prompt("Input: ");if(result!==null){result+="\n"}}else if(typeof readl ine=="function"){result=readline();if(result!==null){result+="\n"}}if(!result){r eturn null}tty.input=intArrayFromString(result,true)}return tty.input.shift()}), put_char:(function(tty,val){if(val===null||val===10){Module["print"](UTF8ArrayTo String(tty.output,0));tty.output=[]}else{if(val!=0)tty.output.push(val)}}),flush :(function(tty){if(tty.output&&tty.output.length>0){Module["print"](UTF8ArrayToS tring(tty.output,0));tty.output=[]}})},default_tty1_ops:{put_char:(function(tty, val){if(val===null||val===10){Module["printErr"](UTF8ArrayToString(tty.output,0) );tty.output=[]}else{if(val!=0)tty.output.push(val)}}),flush:(function(tty){if(t ty.output&&tty.output.length>0){Module["printErr"](UTF8ArrayToString(tty.output, 0));tty.output=[]}})}};var MEMFS={ops_table:null,mount:(function(mount){return M EMFS.createNode(null,"/",16384|511,0)}),createNode:(function(parent,name,mode,de v){if(FS.isBlkdev(mode)||FS.isFIFO(mode)){throw new FS.ErrnoError(ERRNO_CODES.EP ERM)}if(!MEMFS.ops_table){MEMFS.ops_table={dir:{node:{getattr:MEMFS.node_ops.get attr,setattr:MEMFS.node_ops.setattr,lookup:MEMFS.node_ops.lookup,mknod:MEMFS.nod e_ops.mknod,rename:MEMFS.node_ops.rename,unlink:MEMFS.node_ops.unlink,rmdir:MEMF S.node_ops.rmdir,readdir:MEMFS.node_ops.readdir,symlink:MEMFS.node_ops.symlink}, stream:{llseek:MEMFS.stream_ops.llseek}},file:{node:{getattr:MEMFS.node_ops.geta ttr,setattr:MEMFS.node_ops.setattr},stream:{llseek:MEMFS.stream_ops.llseek,read: MEMFS.stream_ops.read,write:MEMFS.stream_ops.write,allocate:MEMFS.stream_ops.all ocate,mmap:MEMFS.stream_ops.mmap}},link:{node:{getattr:MEMFS.node_ops.getattr,se tattr:MEMFS.node_ops.setattr,readlink:MEMFS.node_ops.readlink},stream:{}},chrdev :{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:FS .chrdev_stream_ops}}}var node=FS.createNode(parent,name,mode,dev);if(FS.isDir(no de.mode)){node.node_ops=MEMFS.ops_table.dir.node;node.stream_ops=MEMFS.ops_table .dir.stream;node.contents={}}else if(FS.isFile(node.mode)){node.node_ops=MEMFS.o ps_table.file.node;node.stream_ops=MEMFS.ops_table.file.stream;node.usedBytes=0; node.contents=null}else if(FS.isLink(node.mode)){node.node_ops=MEMFS.ops_table.l ink.node;node.stream_ops=MEMFS.ops_table.link.stream}else if(FS.isChrdev(node.mo de)){node.node_ops=MEMFS.ops_table.chrdev.node;node.stream_ops=MEMFS.ops_table.c hrdev.stream}node.timestamp=Date.now();if(parent){parent.contents[name]=node}ret urn node}),getFileDataAsRegularArray:(function(node){if(node.contents&&node.cont ents.subarray){var arr=[];for(var i=0;i<node.usedBytes;++i)arr.push(node.content s[i]);return arr}return node.contents}),getFileDataAsTypedArray:(function(node){ if(!node.contents)return new Uint8Array;if(node.contents.subarray)return node.co ntents.subarray(0,node.usedBytes);return new Uint8Array(node.contents)}),expandF ileStorage:(function(node,newCapacity){if(node.contents&&node.contents.subarray& &newCapacity>node.contents.length){node.contents=MEMFS.getFileDataAsRegularArray (node);node.usedBytes=node.contents.length}if(!node.contents||node.contents.suba rray){var prevCapacity=node.contents?node.contents.buffer.byteLength:0;if(prevCa pacity>=newCapacity)return;var CAPACITY_DOUBLING_MAX=1024*1024;newCapacity=Math. max(newCapacity,prevCapacity*(prevCapacity<CAPACITY_DOUBLING_MAX?2:1.125)|0);if( prevCapacity!=0)newCapacity=Math.max(newCapacity,256);var oldContents=node.conte nts;node.contents=new Uint8Array(newCapacity);if(node.usedBytes>0)node.contents. set(oldContents.subarray(0,node.usedBytes),0);return}if(!node.contents&&newCapac ity>0)node.contents=[];while(node.contents.length<newCapacity)node.contents.push (0)}),resizeFileStorage:(function(node,newSize){if(node.usedBytes==newSize)retur n;if(newSize==0){node.contents=null;node.usedBytes=0;return}if(!node.contents||n ode.contents.subarray){var oldContents=node.contents;node.contents=new Uint8Arra y(new ArrayBuffer(newSize));if(oldContents){node.contents.set(oldContents.subarr ay(0,Math.min(newSize,node.usedBytes)))}node.usedBytes=newSize;return}if(!node.c ontents)node.contents=[];if(node.contents.length>newSize)node.contents.length=ne wSize;else while(node.contents.length<newSize)node.contents.push(0);node.usedByt es=newSize}),node_ops:{getattr:(function(node){var attr={};attr.dev=FS.isChrdev( node.mode)?node.id:1;attr.ino=node.id;attr.mode=node.mode;attr.nlink=1;attr.uid= 0;attr.gid=0;attr.rdev=node.rdev;if(FS.isDir(node.mode)){attr.size=4096}else if( FS.isFile(node.mode)){attr.size=node.usedBytes}else if(FS.isLink(node.mode)){att r.size=node.link.length}else{attr.size=0}attr.atime=new Date(node.timestamp);att r.mtime=new Date(node.timestamp);attr.ctime=new Date(node.timestamp);attr.blksiz e=4096;attr.blocks=Math.ceil(attr.size/attr.blksize);return attr}),setattr:(func tion(node,attr){if(attr.mode!==undefined){node.mode=attr.mode}if(attr.timestamp! ==undefined){node.timestamp=attr.timestamp}if(attr.size!==undefined){MEMFS.resiz eFileStorage(node,attr.size)}}),lookup:(function(parent,name){throw FS.genericEr rors[ERRNO_CODES.ENOENT]}),mknod:(function(parent,name,mode,dev){return MEMFS.cr eateNode(parent,name,mode,dev)}),rename:(function(old_node,new_dir,new_name){if( FS.isDir(old_node.mode)){var new_node;try{new_node=FS.lookupNode(new_dir,new_nam e)}catch(e){}if(new_node){for(var i in new_node.contents){throw new FS.ErrnoErro r(ERRNO_CODES.ENOTEMPTY)}}}delete old_node.parent.contents[old_node.name];old_no de.name=new_name;new_dir.contents[new_name]=old_node;old_node.parent=new_dir}),u nlink:(function(parent,name){delete parent.contents[name]}),rmdir:(function(pare nt,name){var node=FS.lookupNode(parent,name);for(var i in node.contents){throw n ew FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}delete parent.contents[name]}),readdir:( function(node){var entries=[".",".."];for(var key in node.contents){if(!node.con tents.hasOwnProperty(key)){continue}entries.push(key)}return entries}),symlink:( function(parent,newname,oldpath){var node=MEMFS.createNode(parent,newname,511|40 960,0);node.link=oldpath;return node}),readlink:(function(node){if(!FS.isLink(no de.mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return node.link})},stream _ops:{read:(function(stream,buffer,offset,length,position){var contents=stream.n ode.contents;if(position>=stream.node.usedBytes)return 0;var size=Math.min(strea m.node.usedBytes-position,length);assert(size>=0);if(size>8&&contents.subarray){ buffer.set(contents.subarray(position,position+size),offset)}else{for(var i=0;i< size;i++)buffer[offset+i]=contents[position+i]}return size}),write:(function(str eam,buffer,offset,length,position,canOwn){if(!length)return 0;var node=stream.no de;node.timestamp=Date.now();if(buffer.subarray&&(!node.contents||node.contents. subarray)){if(canOwn){node.contents=buffer.subarray(offset,offset+length);node.u sedBytes=length;return length}else if(node.usedBytes===0&&position===0){node.con tents=new Uint8Array(buffer.subarray(offset,offset+length));node.usedBytes=lengt h;return length}else if(position+length<=node.usedBytes){node.contents.set(buffe r.subarray(offset,offset+length),position);return length}}MEMFS.expandFileStorag e(node,position+length);if(node.contents.subarray&&buffer.subarray)node.contents .set(buffer.subarray(offset,offset+length),position);else for(var i=0;i<length;i ++){node.contents[position+i]=buffer[offset+i]}node.usedBytes=Math.max(node.used Bytes,position+length);return length}),llseek:(function(stream,offset,whence){va r position=offset;if(whence===1){position+=stream.position}else if(whence===2){i f(FS.isFile(stream.node.mode)){position+=stream.node.usedBytes}}if(position<0){t hrow new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position}),allocate:(function( stream,offset,length){MEMFS.expandFileStorage(stream.node,offset+length);stream. node.usedBytes=Math.max(stream.node.usedBytes,offset+length)}),mmap:(function(st ream,buffer,offset,length,position,prot,flags){if(!FS.isFile(stream.node.mode)){ throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}var ptr;var allocated;var contents=s tream.node.contents;if(!(flags&2)&&(contents.buffer===buffer||contents.buffer=== buffer.buffer)){allocated=false;ptr=contents.byteOffset}else{if(position>0||posi tion+length<stream.node.usedBytes){if(contents.subarray){contents=contents.subar ray(position,position+length)}else{contents=Array.prototype.slice.call(contents, position,position+length)}}allocated=true;ptr=_malloc(length);if(!ptr){throw new FS.ErrnoError(ERRNO_CODES.ENOMEM)}buffer.set(contents,ptr)}return{ptr:ptr,alloc ated:allocated}})}};var IDBFS={dbs:{},indexedDB:(function(){if(typeof indexedDB! =="undefined")return indexedDB;var ret=null;if(typeof window==="object")ret=wind ow.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIndexedDB;as sert(ret,"IDBFS used, but indexedDB not supported");return ret}),DB_VERSION:21,D B_STORE_NAME:"FILE_DATA",mount:(function(mount){return MEMFS.mount.apply(null,ar guments)}),syncfs:(function(mount,populate,callback){IDBFS.getLocalSet(mount,(fu nction(err,local){if(err)return callback(err);IDBFS.getRemoteSet(mount,(function (err,remote){if(err)return callback(err);var src=populate?remote:local;var dst=p opulate?local:remote;IDBFS.reconcile(src,dst,callback)}))}))}),getDB:(function(n ame,callback){var db=IDBFS.dbs[name];if(db){return callback(null,db)}var req;try {req=IDBFS.indexedDB().open(name,IDBFS.DB_VERSION)}catch(e){return callback(e)}r eq.onupgradeneeded=(function(e){var db=e.target.result;var transaction=e.target. transaction;var fileStore;if(db.objectStoreNames.contains(IDBFS.DB_STORE_NAME)){ fileStore=transaction.objectStore(IDBFS.DB_STORE_NAME)}else{fileStore=db.createO bjectStore(IDBFS.DB_STORE_NAME)}if(!fileStore.indexNames.contains("timestamp")){ fileStore.createIndex("timestamp","timestamp",{unique:false})}});req.onsuccess=( function(){db=req.result;IDBFS.dbs[name]=db;callback(null,db)});req.onerror=(fun ction(e){callback(this.error);e.preventDefault()})}),getLocalSet:(function(mount ,callback){var entries={};function isRealDir(p){return p!=="."&&p!==".."}functio n toAbsolute(root){return(function(p){return PATH.join2(root,p)})}var check=FS.r eaddir(mount.mountpoint).filter(isRealDir).map(toAbsolute(mount.mountpoint));whi le(check.length){var path=check.pop();var stat;try{stat=FS.stat(path)}catch(e){r eturn callback(e)}if(FS.isDir(stat.mode)){check.push.apply(check,FS.readdir(path ).filter(isRealDir).map(toAbsolute(path)))}entries[path]={timestamp:stat.mtime}} return callback(null,{type:"local",entries:entries})}),getRemoteSet:(function(mo unt,callback){var entries={};IDBFS.getDB(mount.mountpoint,(function(err,db){if(e rr)return callback(err);var transaction=db.transaction([IDBFS.DB_STORE_NAME],"re adonly");transaction.onerror=(function(e){callback(this.error);e.preventDefault( )});var store=transaction.objectStore(IDBFS.DB_STORE_NAME);var index=store.index ("timestamp");index.openKeyCursor().onsuccess=(function(event){var cursor=event. target.result;if(!cursor){return callback(null,{type:"remote",db:db,entries:entr ies})}entries[cursor.primaryKey]={timestamp:cursor.key};cursor.continue()})}))}) ,loadLocalEntry:(function(path,callback){var stat,node;try{var lookup=FS.lookupP ath(path);node=lookup.node;stat=FS.stat(path)}catch(e){return callback(e)}if(FS. isDir(stat.mode)){return callback(null,{timestamp:stat.mtime,mode:stat.mode})}el se if(FS.isFile(stat.mode)){node.contents=MEMFS.getFileDataAsTypedArray(node);re turn callback(null,{timestamp:stat.mtime,mode:stat.mode,contents:node.contents}) }else{return callback(new Error("node type not supported"))}}),storeLocalEntry:( function(path,entry,callback){try{if(FS.isDir(entry.mode)){FS.mkdir(path,entry.m ode)}else if(FS.isFile(entry.mode)){FS.writeFile(path,entry.contents,{encoding:" binary",canOwn:true})}else{return callback(new Error("node type not supported")) }FS.chmod(path,entry.mode);FS.utime(path,entry.timestamp,entry.timestamp)}catch( e){return callback(e)}callback(null)}),removeLocalEntry:(function(path,callback) {try{var lookup=FS.lookupPath(path);var stat=FS.stat(path);if(FS.isDir(stat.mode )){FS.rmdir(path)}else if(FS.isFile(stat.mode)){FS.unlink(path)}}catch(e){return callback(e)}callback(null)}),loadRemoteEntry:(function(store,path,callback){var req=store.get(path);req.onsuccess=(function(event){callback(null,event.target.r esult)});req.onerror=(function(e){callback(this.error);e.preventDefault()})}),st oreRemoteEntry:(function(store,path,entry,callback){var req=store.put(entry,path );req.onsuccess=(function(){callback(null)});req.onerror=(function(e){callback(t his.error);e.preventDefault()})}),removeRemoteEntry:(function(store,path,callbac k){var req=store.delete(path);req.onsuccess=(function(){callback(null)});req.one rror=(function(e){callback(this.error);e.preventDefault()})}),reconcile:(functio n(src,dst,callback){var total=0;var create=[];Object.keys(src.entries).forEach(( function(key){var e=src.entries[key];var e2=dst.entries[key];if(!e2||e.timestamp >e2.timestamp){create.push(key);total++}}));var remove=[];Object.keys(dst.entrie s).forEach((function(key){var e=dst.entries[key];var e2=src.entries[key];if(!e2) {remove.push(key);total++}}));if(!total){return callback(null)}var errored=false ;var completed=0;var db=src.type==="remote"?src.db:dst.db;var transaction=db.tra nsaction([IDBFS.DB_STORE_NAME],"readwrite");var store=transaction.objectStore(ID BFS.DB_STORE_NAME);function done(err){if(err){if(!done.errored){done.errored=tru e;return callback(err)}return}if(++completed>=total){return callback(null)}}tran saction.onerror=(function(e){done(this.error);e.preventDefault()});create.sort() .forEach((function(path){if(dst.type==="local"){IDBFS.loadRemoteEntry(store,path ,(function(err,entry){if(err)return done(err);IDBFS.storeLocalEntry(path,entry,d one)}))}else{IDBFS.loadLocalEntry(path,(function(err,entry){if(err)return done(e rr);IDBFS.storeRemoteEntry(store,path,entry,done)}))}}));remove.sort().reverse() .forEach((function(path){if(dst.type==="local"){IDBFS.removeLocalEntry(path,done )}else{IDBFS.removeRemoteEntry(store,path,done)}}))})};var NODEFS={isWindows:fal se,staticInit:(function(){NODEFS.isWindows=!!process.platform.match(/^win/)}),mo unt:(function(mount){assert(ENVIRONMENT_IS_NODE);return NODEFS.createNode(null," /",NODEFS.getMode(mount.opts.root),0)}),createNode:(function(parent,name,mode,de v){if(!FS.isDir(mode)&&!FS.isFile(mode)&&!FS.isLink(mode)){throw new FS.ErrnoErr or(ERRNO_CODES.EINVAL)}var node=FS.createNode(parent,name,mode);node.node_ops=NO DEFS.node_ops;node.stream_ops=NODEFS.stream_ops;return node}),getMode:(function( path){var stat;try{stat=fs.lstatSync(path);if(NODEFS.isWindows){stat.mode=stat.m ode|(stat.mode&146)>>1}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRN O_CODES[e.code])}return stat.mode}),realPath:(function(node){var parts=[];while( node.parent!==node){parts.push(node.name);node=node.parent}parts.push(node.mount .opts.root);parts.reverse();return PATH.join.apply(null,parts)}),flagsToPermissi onStringMap:{0:"r",1:"r+",2:"r+",64:"r",65:"r+",66:"r+",129:"rx+",193:"rx+",514: "w+",577:"w",578:"w+",705:"wx",706:"wx+",1024:"a",1025:"a",1026:"a+",1089:"a",10 90:"a+",1153:"ax",1154:"ax+",1217:"ax",1218:"ax+",4096:"rs",4098:"rs+"},flagsToP ermissionString:(function(flags){if(flags in NODEFS.flagsToPermissionStringMap){ return NODEFS.flagsToPermissionStringMap[flags]}else{return flags}}),node_ops:{g etattr:(function(node){var path=NODEFS.realPath(node);var stat;try{stat=fs.lstat Sync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.cod e])}if(NODEFS.isWindows&&!stat.blksize){stat.blksize=4096}if(NODEFS.isWindows&&! stat.blocks){stat.blocks=(stat.size+stat.blksize-1)/stat.blksize|0}return{dev:st at.dev,ino:stat.ino,mode:stat.mode,nlink:stat.nlink,uid:stat.uid,gid:stat.gid,rd ev:stat.rdev,size:stat.size,atime:stat.atime,mtime:stat.mtime,ctime:stat.ctime,b lksize:stat.blksize,blocks:stat.blocks}}),setattr:(function(node,attr){var path= NODEFS.realPath(node);try{if(attr.mode!==undefined){fs.chmodSync(path,attr.mode) ;node.mode=attr.mode}if(attr.timestamp!==undefined){var date=new Date(attr.times tamp);fs.utimesSync(path,date,date)}if(attr.size!==undefined){fs.truncateSync(pa th,attr.size)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e .code])}}),lookup:(function(parent,name){var path=PATH.join2(NODEFS.realPath(par ent),name);var mode=NODEFS.getMode(path);return NODEFS.createNode(parent,name,mo de)}),mknod:(function(parent,name,mode,dev){var node=NODEFS.createNode(parent,na me,mode,dev);var path=NODEFS.realPath(node);try{if(FS.isDir(node.mode)){fs.mkdir Sync(path,node.mode)}else{fs.writeFileSync(path,"",{mode:node.mode})}}catch(e){i f(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return node}),ren ame:(function(oldNode,newDir,newName){var oldPath=NODEFS.realPath(oldNode);var n ewPath=PATH.join2(NODEFS.realPath(newDir),newName);try{fs.renameSync(oldPath,new Path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}} ),unlink:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name );try{fs.unlinkSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ER RNO_CODES[e.code])}}),rmdir:(function(parent,name){var path=PATH.join2(NODEFS.re alPath(parent),name);try{fs.rmdirSync(path)}catch(e){if(!e.code)throw e;throw ne w FS.ErrnoError(ERRNO_CODES[e.code])}}),readdir:(function(node){var path=NODEFS. realPath(node);try{return fs.readdirSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),symlink:(function(parent,newName,oldP ath){var newPath=PATH.join2(NODEFS.realPath(parent),newName);try{fs.symlinkSync( oldPath,newPath)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES [e.code])}}),readlink:(function(node){var path=NODEFS.realPath(node);try{path=fs .readlinkSync(path);path=NODEJS_PATH.relative(NODEJS_PATH.resolve(node.mount.opt s.root),path);return path}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ER RNO_CODES[e.code])}})},stream_ops:{open:(function(stream){var path=NODEFS.realPa th(stream.node);try{if(FS.isFile(stream.node.mode)){stream.nfd=fs.openSync(path, NODEFS.flagsToPermissionString(stream.flags))}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),close:(function(stream){try{if(FS.isF ile(stream.node.mode)&&stream.nfd){fs.closeSync(stream.nfd)}}catch(e){if(!e.code )throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),read:(function(stream,b uffer,offset,length,position){if(length===0)return 0;var nbuffer=new Buffer(leng th);var res;try{res=fs.readSync(stream.nfd,nbuffer,0,length,position)}catch(e){t hrow new FS.ErrnoError(ERRNO_CODES[e.code])}if(res>0){for(var i=0;i<res;i++){buf fer[offset+i]=nbuffer[i]}}return res}),write:(function(stream,buffer,offset,leng th,position){var nbuffer=new Buffer(buffer.subarray(offset,offset+length));var r es;try{res=fs.writeSync(stream.nfd,nbuffer,0,length,position)}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}return res}),llseek:(function(stream,offset, whence){var position=offset;if(whence===1){position+=stream.position}else if(whe nce===2){if(FS.isFile(stream.node.mode)){try{var stat=fs.fstatSync(stream.nfd);p osition+=stat.size}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}}}if(po sition<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position})}};var _s tdin=allocate(1,"i32*",ALLOC_STATIC);var _stdout=allocate(1,"i32*",ALLOC_STATIC) ;var _stderr=allocate(1,"i32*",ALLOC_STATIC);function _fflush(stream){}var FS={r oot:null,mounts:[],devices:[null],streams:[],nextInode:1,nameTable:null,currentP ath:"/",initialized:false,ignorePermissions:true,trackingDelegate:{},tracking:{o penFlags:{READ:1,WRITE:2}},ErrnoError:null,genericErrors:{},handleFSError:(funct ion(e){if(!(e instanceof FS.ErrnoError))throw e+" : "+stackTrace();return ___set ErrNo(e.errno)}),lookupPath:(function(path,opts){path=PATH.resolve(FS.cwd(),path );opts=opts||{};if(!path)return{path:"",node:null};var defaults={follow_mount:tr ue,recurse_count:0};for(var key in defaults){if(opts[key]===undefined){opts[key] =defaults[key]}}if(opts.recurse_count>8){throw new FS.ErrnoError(ERRNO_CODES.ELO OP)}var parts=PATH.normalizeArray(path.split("/").filter((function(p){return!!p} )),false);var current=FS.root;var current_path="/";for(var i=0;i<parts.length;i+ +){var islast=i===parts.length-1;if(islast&&opts.parent){break}current=FS.lookup Node(current,parts[i]);current_path=PATH.join2(current_path,parts[i]);if(FS.isMo untpoint(current)){if(!islast||islast&&opts.follow_mount){current=current.mounte d.root}}if(!islast||opts.follow){var count=0;while(FS.isLink(current.mode)){var link=FS.readlink(current_path);current_path=PATH.resolve(PATH.dirname(current_pa th),link);var lookup=FS.lookupPath(current_path,{recurse_count:opts.recurse_coun t});current=lookup.node;if(count++>40){throw new FS.ErrnoError(ERRNO_CODES.ELOOP )}}}}return{path:current_path,node:current}}),getPath:(function(node){var path;w hile(true){if(FS.isRoot(node)){var mount=node.mount.mountpoint;if(!path)return m ount;return mount[mount.length-1]!=="/"?mount+"/"+path:mount+path}path=path?node .name+"/"+path:node.name;node=node.parent}}),hashName:(function(parentid,name){v ar hash=0;for(var i=0;i<name.length;i++){hash=(hash<<5)-hash+name.charCodeAt(i)| 0}return(parentid+hash>>>0)%FS.nameTable.length}),hashAddNode:(function(node){va r hash=FS.hashName(node.parent.id,node.name);node.name_next=FS.nameTable[hash];F S.nameTable[hash]=node}),hashRemoveNode:(function(node){var hash=FS.hashName(nod e.parent.id,node.name);if(FS.nameTable[hash]===node){FS.nameTable[hash]=node.nam e_next}else{var current=FS.nameTable[hash];while(current){if(current.name_next== =node){current.name_next=node.name_next;break}current=current.name_next}}}),look upNode:(function(parent,name){var err=FS.mayLookup(parent);if(err){throw new FS. ErrnoError(err,parent)}var hash=FS.hashName(parent.id,name);for(var node=FS.name Table[hash];node;node=node.name_next){var nodeName=node.name;if(node.parent.id== =parent.id&&nodeName===name){return node}}return FS.lookup(parent,name)}),create Node:(function(parent,name,mode,rdev){if(!FS.FSNode){FS.FSNode=(function(parent, name,mode,rdev){if(!parent){parent=this}this.parent=parent;this.mount=parent.mou nt;this.mounted=null;this.id=FS.nextInode++;this.name=name;this.mode=mode;this.n ode_ops={};this.stream_ops={};this.rdev=rdev});FS.FSNode.prototype={};var readMo de=292|73;var writeMode=146;Object.defineProperties(FS.FSNode.prototype,{read:{g et:(function(){return(this.mode&readMode)===readMode}),set:(function(val){val?th is.mode|=readMode:this.mode&=~readMode})},write:{get:(function(){return(this.mod e&writeMode)===writeMode}),set:(function(val){val?this.mode|=writeMode:this.mode &=~writeMode})},isFolder:{get:(function(){return FS.isDir(this.mode)})},isDevice :{get:(function(){return FS.isChrdev(this.mode)})}})}var node=new FS.FSNode(pare nt,name,mode,rdev);FS.hashAddNode(node);return node}),destroyNode:(function(node ){FS.hashRemoveNode(node)}),isRoot:(function(node){return node===node.parent}),i sMountpoint:(function(node){return!!node.mounted}),isFile:(function(mode){return (mode&61440)===32768}),isDir:(function(mode){return(mode&61440)===16384}),isLink :(function(mode){return(mode&61440)===40960}),isChrdev:(function(mode){return(mo de&61440)===8192}),isBlkdev:(function(mode){return(mode&61440)===24576}),isFIFO: (function(mode){return(mode&61440)===4096}),isSocket:(function(mode){return(mode &49152)===49152}),flagModes:{"r":0,"rs":1052672,"r+":2,"w":577,"wx":705,"xw":705 ,"w+":578,"wx+":706,"xw+":706,"a":1089,"ax":1217,"xa":1217,"a+":1090,"ax+":1218, "xa+":1218},modeStringToFlags:(function(str){var flags=FS.flagModes[str];if(type of flags==="undefined"){throw new Error("Unknown file open mode: "+str)}return f lags}),flagsToPermissionString:(function(flag){var accmode=flag&2097155;var perm s=["r","w","rw"][accmode];if(flag&512){perms+="w"}return perms}),nodePermissions :(function(node,perms){if(FS.ignorePermissions){return 0}if(perms.indexOf("r")!= =-1&&!(node.mode&292)){return ERRNO_CODES.EACCES}else if(perms.indexOf("w")!==-1 &&!(node.mode&146)){return ERRNO_CODES.EACCES}else if(perms.indexOf("x")!==-1&&! (node.mode&73)){return ERRNO_CODES.EACCES}return 0}),mayLookup:(function(dir){va r err=FS.nodePermissions(dir,"x");if(err)return err;if(!dir.node_ops.lookup)retu rn ERRNO_CODES.EACCES;return 0}),mayCreate:(function(dir,name){try{var node=FS.l ookupNode(dir,name);return ERRNO_CODES.EEXIST}catch(e){}return FS.nodePermission s(dir,"wx")}),mayDelete:(function(dir,name,isdir){var node;try{node=FS.lookupNod e(dir,name)}catch(e){return e.errno}var err=FS.nodePermissions(dir,"wx");if(err) {return err}if(isdir){if(!FS.isDir(node.mode)){return ERRNO_CODES.ENOTDIR}if(FS. isRoot(node)||FS.getPath(node)===FS.cwd()){return ERRNO_CODES.EBUSY}}else{if(FS. isDir(node.mode)){return ERRNO_CODES.EISDIR}}return 0}),mayOpen:(function(node,f lags){if(!node){return ERRNO_CODES.ENOENT}if(FS.isLink(node.mode)){return ERRNO_ CODES.ELOOP}else if(FS.isDir(node.mode)){if((flags&2097155)!==0||flags&512){retu rn ERRNO_CODES.EISDIR}}return FS.nodePermissions(node,FS.flagsToPermissionString (flags))}),MAX_OPEN_FDS:4096,nextfd:(function(fd_start,fd_end){fd_start=fd_start ||0;fd_end=fd_end||FS.MAX_OPEN_FDS;for(var fd=fd_start;fd<=fd_end;fd++){if(!FS.s treams[fd]){return fd}}throw new FS.ErrnoError(ERRNO_CODES.EMFILE)}),getStream:( function(fd){return FS.streams[fd]}),createStream:(function(stream,fd_start,fd_e nd){if(!FS.FSStream){FS.FSStream=(function(){});FS.FSStream.prototype={};Object. defineProperties(FS.FSStream.prototype,{object:{get:(function(){return this.node }),set:(function(val){this.node=val})},isRead:{get:(function(){return(this.flags &2097155)!==1})},isWrite:{get:(function(){return(this.flags&2097155)!==0})},isAp pend:{get:(function(){return this.flags&1024})}})}var newStream=new FS.FSStream; for(var p in stream){newStream[p]=stream[p]}stream=newStream;var fd=FS.nextfd(fd _start,fd_end);stream.fd=fd;FS.streams[fd]=stream;return stream}),closeStream:(f unction(fd){FS.streams[fd]=null}),getStreamFromPtr:(function(ptr){return FS.stre ams[ptr-1]}),getPtrForStream:(function(stream){return stream?stream.fd+1:0}),chr dev_stream_ops:{open:(function(stream){var device=FS.getDevice(stream.node.rdev) ;stream.stream_ops=device.stream_ops;if(stream.stream_ops.open){stream.stream_op s.open(stream)}}),llseek:(function(){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE) })},major:(function(dev){return dev>>8}),minor:(function(dev){return dev&255}),m akedev:(function(ma,mi){return ma<<8|mi}),registerDevice:(function(dev,ops){FS.d evices[dev]={stream_ops:ops}}),getDevice:(function(dev){return FS.devices[dev]}) ,getMounts:(function(mount){var mounts=[];var check=[mount];while(check.length){ var m=check.pop();mounts.push(m);check.push.apply(check,m.mounts)}return mounts} ),syncfs:(function(populate,callback){if(typeof populate==="function"){callback= populate;populate=false}var mounts=FS.getMounts(FS.root.mount);var completed=0;f unction done(err){if(err){if(!done.errored){done.errored=true;return callback(er r)}return}if(++completed>=mounts.length){callback(null)}}mounts.forEach((functio n(mount){if(!mount.type.syncfs){return done(null)}mount.type.syncfs(mount,popula te,done)}))}),mount:(function(type,opts,mountpoint){var root=mountpoint==="/";va r pseudo=!mountpoint;var node;if(root&&FS.root){throw new FS.ErrnoError(ERRNO_CO DES.EBUSY)}else if(!root&&!pseudo){var lookup=FS.lookupPath(mountpoint,{follow_m ount:false});mountpoint=lookup.path;node=lookup.node;if(FS.isMountpoint(node)){t hrow new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(!FS.isDir(node.mode)){throw new FS. ErrnoError(ERRNO_CODES.ENOTDIR)}}var mount={type:type,opts:opts,mountpoint:mount point,mounts:[]};var mountRoot=type.mount(mount);mountRoot.mount=mount;mount.roo t=mountRoot;if(root){FS.root=mountRoot}else if(node){node.mounted=mount;if(node. mount){node.mount.mounts.push(mount)}}return mountRoot}),unmount:(function(mount point){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});if(!FS.isMountp oint(lookup.node)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=lookup.n ode;var mount=node.mounted;var mounts=FS.getMounts(mount);Object.keys(FS.nameTab le).forEach((function(hash){var current=FS.nameTable[hash];while(current){var ne xt=current.name_next;if(mounts.indexOf(current.mount)!==-1){FS.destroyNode(curre nt)}current=next}}));node.mounted=null;var idx=node.mount.mounts.indexOf(mount); assert(idx!==-1);node.mount.mounts.splice(idx,1)}),lookup:(function(parent,name) {return parent.node_ops.lookup(parent,name)}),mknod:(function(path,mode,dev){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.b asename(path);if(!name||name==="."||name===".."){throw new FS.ErrnoError(ERRNO_C ODES.EINVAL)}var err=FS.mayCreate(parent,name);if(err){throw new FS.ErrnoError(e rr)}if(!parent.node_ops.mknod){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.mknod(parent,name,mode,dev)}),create:(function(path,mode){mode= mode!==undefined?mode:438;mode&=4095;mode|=32768;return FS.mknod(path,mode,0)}), mkdir:(function(path,mode){mode=mode!==undefined?mode:511;mode&=511|512;mode|=16 384;return FS.mknod(path,mode,0)}),mkdev:(function(path,mode,dev){if(typeof dev= =="undefined"){dev=mode;mode=438}mode|=8192;return FS.mknod(path,mode,dev)}),sym link:(function(oldpath,newpath){if(!PATH.resolve(oldpath)){throw new FS.ErrnoErr or(ERRNO_CODES.ENOENT)}var lookup=FS.lookupPath(newpath,{parent:true});var paren t=lookup.node;if(!parent){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}var newnam e=PATH.basename(newpath);var err=FS.mayCreate(parent,newname);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.symlink){throw new FS.ErrnoError(ERRNO_CO DES.EPERM)}return parent.node_ops.symlink(parent,newname,oldpath)}),rename:(func tion(old_path,new_path){var old_dirname=PATH.dirname(old_path);var new_dirname=P ATH.dirname(new_path);var old_name=PATH.basename(old_path);var new_name=PATH.bas ename(new_path);var lookup,old_dir,new_dir;try{lookup=FS.lookupPath(old_path,{pa rent:true});old_dir=lookup.node;lookup=FS.lookupPath(new_path,{parent:true});new _dir=lookup.node}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(!old_dir ||!new_dir)throw new FS.ErrnoError(ERRNO_CODES.ENOENT);if(old_dir.mount!==new_di r.mount){throw new FS.ErrnoError(ERRNO_CODES.EXDEV)}var old_node=FS.lookupNode(o ld_dir,old_name);var relative=PATH.relative(old_path,new_dirname);if(relative.ch arAt(0)!=="."){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}relative=PATH.relativ e(new_path,old_dirname);if(relative.charAt(0)!=="."){throw new FS.ErrnoError(ERR NO_CODES.ENOTEMPTY)}var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}ca tch(e){}if(old_node===new_node){return}var isdir=FS.isDir(old_node.mode);var err =FS.mayDelete(old_dir,old_name,isdir);if(err){throw new FS.ErrnoError(err)}err=n ew_node?FS.mayDelete(new_dir,new_name,isdir):FS.mayCreate(new_dir,new_name);if(e rr){throw new FS.ErrnoError(err)}if(!old_dir.node_ops.rename){throw new FS.Errno Error(ERRNO_CODES.EPERM)}if(FS.isMountpoint(old_node)||new_node&&FS.isMountpoint (new_node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(new_dir!==old_dir){err =FS.nodePermissions(old_dir,"w");if(err){throw new FS.ErrnoError(err)}}try{if(FS .trackingDelegate["willMovePath"]){FS.trackingDelegate["willMovePath"](old_path, new_path)}}catch(e){console.log("FS.trackingDelegate['willMovePath']('"+old_path +"', '"+new_path+"') threw an exception: "+e.message)}FS.hashRemoveNode(old_node );try{old_dir.node_ops.rename(old_node,new_dir,new_name)}catch(e){throw e}finall y{FS.hashAddNode(old_node)}try{if(FS.trackingDelegate["onMovePath"])FS.trackingD elegate["onMovePath"](old_path,new_path)}catch(e){console.log("FS.trackingDelega te['onMovePath']('"+old_path+"', '"+new_path+"') threw an exception: "+e.message )}}),rmdir:(function(path){var lookup=FS.lookupPath(path,{parent:true});var pare nt=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name); var err=FS.mayDelete(parent,name,true);if(err){throw new FS.ErrnoError(err)}if(! parent.node_ops.rmdir){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountp oint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}try{if(FS.trackingDelegat e["willDeletePath"]){FS.trackingDelegate["willDeletePath"](path)}}catch(e){conso le.log("FS.trackingDelegate['willDeletePath']('"+path+"') threw an exception: "+ e.message)}parent.node_ops.rmdir(parent,name);FS.destroyNode(node);try{if(FS.tra ckingDelegate["onDeletePath"])FS.trackingDelegate["onDeletePath"](path)}catch(e) {console.log("FS.trackingDelegate['onDeletePath']('"+path+"') threw an exception : "+e.message)}}),readdir:(function(path){var lookup=FS.lookupPath(path,{follow: true});var node=lookup.node;if(!node.node_ops.readdir){throw new FS.ErrnoError(E RRNO_CODES.ENOTDIR)}return node.node_ops.readdir(node)}),unlink:(function(path){ var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PAT H.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent ,name,false);if(err){if(err===ERRNO_CODES.EISDIR)err=ERRNO_CODES.EPERM;throw new FS.ErrnoError(err)}if(!parent.node_ops.unlink){throw new FS.ErrnoError(ERRNO_CO DES.EPERM)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)} try{if(FS.trackingDelegate["willDeletePath"]){FS.trackingDelegate["willDeletePat h"](path)}}catch(e){console.log("FS.trackingDelegate['willDeletePath']('"+path+" ') threw an exception: "+e.message)}parent.node_ops.unlink(parent,name);FS.destr oyNode(node);try{if(FS.trackingDelegate["onDeletePath"])FS.trackingDelegate["onD eletePath"](path)}catch(e){console.log("FS.trackingDelegate['onDeletePath']('"+p ath+"') threw an exception: "+e.message)}}),readlink:(function(path){var lookup= FS.lookupPath(path);var link=lookup.node;if(!link){throw new FS.ErrnoError(ERRNO _CODES.ENOENT)}if(!link.node_ops.readlink){throw new FS.ErrnoError(ERRNO_CODES.E INVAL)}return PATH.resolve(FS.getPath(lookup.node.parent),link.node_ops.readlink (link))}),stat:(function(path,dontFollow){var lookup=FS.lookupPath(path,{follow: !dontFollow});var node=lookup.node;if(!node){throw new FS.ErrnoError(ERRNO_CODES .ENOENT)}if(!node.node_ops.getattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}r eturn node.node_ops.getattr(node)}),lstat:(function(path){return FS.stat(path,tr ue)}),chmod:(function(path,mode,dontFollow){var node;if(typeof path==="string"){ var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=p ath}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.n ode_ops.setattr(node,{mode:mode&4095|node.mode&~4095,timestamp:Date.now()})}),lc hmod:(function(path,mode){FS.chmod(path,mode,true)}),fchmod:(function(fd,mode){v ar stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF )}FS.chmod(stream.node,mode)}),chown:(function(path,uid,gid,dontFollow){var node ;if(typeof path==="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow}); node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoErr or(ERRNO_CODES.EPERM)}node.node_ops.setattr(node,{timestamp:Date.now()})}),lchow n:(function(path,uid,gid){FS.chown(path,uid,gid,true)}),fchown:(function(fd,uid, gid){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES .EBADF)}FS.chown(stream.node,uid,gid)}),truncate:(function(path,len){if(len<0){t hrow new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node;if(typeof path==="string"){v ar lookup=FS.lookupPath(path,{follow:true});node=lookup.node}else{node=path}if(! node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isDir(no de.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!FS.isFile(node.mode)){ throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var err=FS.nodePermissions(node,"w") ;if(err){throw new FS.ErrnoError(err)}node.node_ops.setattr(node,{size:len,times tamp:Date.now()})}),ftruncate:(function(fd,len){var stream=FS.getStream(fd);if(! stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if((stream.flags&2097155)===0 ){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}FS.truncate(stream.node,len)}),uti me:(function(path,atime,mtime){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;node.node_ops.setattr(node,{timestamp:Math.max(atime,mtime)})}) ,open:(function(path,flags,mode,fd_start,fd_end){if(path===""){throw new FS.Errn oError(ERRNO_CODES.ENOENT)}flags=typeof flags==="string"?FS.modeStringToFlags(fl ags):flags;mode=typeof mode==="undefined"?438:mode;if(flags&64){mode=mode&4095|3 2768}else{mode=0}var node;if(typeof path==="object"){node=path}else{path=PATH.no rmalize(path);try{var lookup=FS.lookupPath(path,{follow:!(flags&131072)});node=l ookup.node}catch(e){}}var created=false;if(flags&64){if(node){if(flags&128){thro w new FS.ErrnoError(ERRNO_CODES.EEXIST)}}else{node=FS.mknod(path,mode,0);created =true}}if(!node){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(FS.isChrdev(node .mode)){flags&=~512}if(!created){var err=FS.mayOpen(node,flags);if(err){throw ne w FS.ErrnoError(err)}}if(flags&512){FS.truncate(node,0)}flags&=~(128|512);var st ream=FS.createStream({node:node,path:FS.getPath(node),flags:flags,seekable:true, position:0,stream_ops:node.stream_ops,ungotten:[],error:false},fd_start,fd_end); if(stream.stream_ops.open){stream.stream_ops.open(stream)}if(Module["logReadFile s"]&&!(flags&1)){if(!FS.readFiles)FS.readFiles={};if(!(path in FS.readFiles)){FS .readFiles[path]=1;Module["printErr"]("read file: "+path)}}try{if(FS.trackingDel egate["onOpenFile"]){var trackingFlags=0;if((flags&2097155)!==1){trackingFlags|= FS.tracking.openFlags.READ}if((flags&2097155)!==0){trackingFlags|=FS.tracking.op enFlags.WRITE}FS.trackingDelegate["onOpenFile"](path,trackingFlags)}}catch(e){co nsole.log("FS.trackingDelegate['onOpenFile']('"+path+"', flags) threw an excepti on: "+e.message)}return stream}),close:(function(stream){try{if(stream.stream_op s.close){stream.stream_ops.close(stream)}}catch(e){throw e}finally{FS.closeStrea m(stream.fd)}}),llseek:(function(stream,offset,whence){if(!stream.seekable||!str eam.stream_ops.llseek){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}stream.positi on=stream.stream_ops.llseek(stream,offset,whence);stream.ungotten=[];return stre am.position}),read:(function(stream,buffer,offset,length,position){if(length<0|| position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155 )===1){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(FS.isDir(stream.node.mode)) {throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!stream.stream_ops.read){throw n ew FS.ErrnoError(ERRNO_CODES.EINVAL)}var seeking=true;if(typeof position==="unde fined"){position=stream.position;seeking=false}else if(!stream.seekable){throw n ew FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesRead=stream.stream_ops.read(stream ,buffer,offset,length,position);if(!seeking)stream.position+=bytesRead;return by tesRead}),write:(function(stream,buffer,offset,length,position,canOwn){if(length <0||position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&209 7155)===0){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(FS.isDir(stream.node.mo de)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!stream.stream_ops.write){th row new FS.ErrnoError(ERRNO_CODES.EINVAL)}if(stream.flags&1024){FS.llseek(stream ,0,2)}var seeking=true;if(typeof position==="undefined"){position=stream.positio n;seeking=false}else if(!stream.seekable){throw new FS.ErrnoError(ERRNO_CODES.ES PIPE)}var bytesWritten=stream.stream_ops.write(stream,buffer,offset,length,posit ion,canOwn);if(!seeking)stream.position+=bytesWritten;try{if(stream.path&&FS.tra ckingDelegate["onWriteToFile"])FS.trackingDelegate["onWriteToFile"](stream.path) }catch(e){console.log("FS.trackingDelegate['onWriteToFile']('"+path+"') threw an exception: "+e.message)}return bytesWritten}),allocate:(function(stream,offset, length){if(offset<0||length<=0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if(( stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(!FS.isF ile(stream.node.mode)&&!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES .ENODEV)}if(!stream.stream_ops.allocate){throw new FS.ErrnoError(ERRNO_CODES.EOP NOTSUPP)}stream.stream_ops.allocate(stream,offset,length)}),mmap:(function(strea m,buffer,offset,length,position,prot,flags){if((stream.flags&2097155)===1){throw new FS.ErrnoError(ERRNO_CODES.EACCES)}if(!stream.stream_ops.mmap){throw new FS. ErrnoError(ERRNO_CODES.ENODEV)}return stream.stream_ops.mmap(stream,buffer,offse t,length,position,prot,flags)}),ioctl:(function(stream,cmd,arg){if(!stream.strea m_ops.ioctl){throw new FS.ErrnoError(ERRNO_CODES.ENOTTY)}return stream.stream_op s.ioctl(stream,cmd,arg)}),readFile:(function(path,opts){opts=opts||{};opts.flags =opts.flags||"r";opts.encoding=opts.encoding||"binary";if(opts.encoding!=="utf8" &&opts.encoding!=="binary"){throw new Error('Invalid encoding type "'+opts.encod ing+'"')}var ret;var stream=FS.open(path,opts.flags);var stat=FS.stat(path);var length=stat.size;var buf=new Uint8Array(length);FS.read(stream,buf,0,length,0);i f(opts.encoding==="utf8"){ret=UTF8ArrayToString(buf,0)}else if(opts.encoding===" binary"){ret=buf}FS.close(stream);return ret}),writeFile:(function(path,data,opt s){opts=opts||{};opts.flags=opts.flags||"w";opts.encoding=opts.encoding||"utf8"; if(opts.encoding!=="utf8"&&opts.encoding!=="binary"){throw new Error('Invalid en coding type "'+opts.encoding+'"')}var stream=FS.open(path,opts.flags,opts.mode); if(opts.encoding==="utf8"){var buf=new Uint8Array(lengthBytesUTF8(data)+1);var a ctualNumBytes=stringToUTF8Array(data,buf,0,buf.length);FS.write(stream,buf,0,act ualNumBytes,0,opts.canOwn)}else if(opts.encoding==="binary"){FS.write(stream,dat a,0,data.length,0,opts.canOwn)}FS.close(stream)}),cwd:(function(){return FS.curr entPath}),chdir:(function(path){var lookup=FS.lookupPath(path,{follow:true});if( !FS.isDir(lookup.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}var er r=FS.nodePermissions(lookup.node,"x");if(err){throw new FS.ErrnoError(err)}FS.cu rrentPath=lookup.path}),createDefaultDirectories:(function(){FS.mkdir("/tmp");FS .mkdir("/home");FS.mkdir("/home/web_user")}),createDefaultDevices:(function(){FS .mkdir("/dev");FS.registerDevice(FS.makedev(1,3),{read:(function(){return 0}),wr ite:(function(){return 0})});FS.mkdev("/dev/null",FS.makedev(1,3));TTY.register( FS.makedev(5,0),TTY.default_tty_ops);TTY.register(FS.makedev(6,0),TTY.default_tt y1_ops);FS.mkdev("/dev/tty",FS.makedev(5,0));FS.mkdev("/dev/tty1",FS.makedev(6,0 ));var random_device;if(typeof crypto!=="undefined"){var randomBuffer=new Uint8A rray(1);random_device=(function(){crypto.getRandomValues(randomBuffer);return ra ndomBuffer[0]})}else if(ENVIRONMENT_IS_NODE){random_device=(function(){return re quire("crypto").randomBytes(1)[0]})}else{random_device=(function(){return Math.r andom()*256|0})}FS.createDevice("/dev","random",random_device);FS.createDevice(" /dev","urandom",random_device);FS.mkdir("/dev/shm");FS.mkdir("/dev/shm/tmp")}),c reateStandardStreams:(function(){if(Module["stdin"]){FS.createDevice("/dev","std in",Module["stdin"])}else{FS.symlink("/dev/tty","/dev/stdin")}if(Module["stdout" ]){FS.createDevice("/dev","stdout",null,Module["stdout"])}else{FS.symlink("/dev/ tty","/dev/stdout")}if(Module["stderr"]){FS.createDevice("/dev","stderr",null,Mo dule["stderr"])}else{FS.symlink("/dev/tty1","/dev/stderr")}var stdin=FS.open("/d ev/stdin","r");HEAP32[_stdin>>2]=FS.getPtrForStream(stdin);assert(stdin.fd===0," invalid handle for stdin ("+stdin.fd+")");var stdout=FS.open("/dev/stdout","w"); HEAP32[_stdout>>2]=FS.getPtrForStream(stdout);assert(stdout.fd===1,"invalid hand le for stdout ("+stdout.fd+")");var stderr=FS.open("/dev/stderr","w");HEAP32[_st derr>>2]=FS.getPtrForStream(stderr);assert(stderr.fd===2,"invalid handle for std err ("+stderr.fd+")")}),ensureErrnoError:(function(){if(FS.ErrnoError)return;FS. ErrnoError=function ErrnoError(errno,node){this.node=node;this.setErrno=(functio n(errno){this.errno=errno;for(var key in ERRNO_CODES){if(ERRNO_CODES[key]===errn o){this.code=key;break}}});this.setErrno(errno);this.message=ERRNO_MESSAGES[errn o]};FS.ErrnoError.prototype=new Error;FS.ErrnoError.prototype.constructor=FS.Err noError;[ERRNO_CODES.ENOENT].forEach((function(code){FS.genericErrors[code]=new FS.ErrnoError(code);FS.genericErrors[code].stack="<generic error, no stack>"}))} ),staticInit:(function(){FS.ensureErrnoError();FS.nameTable=new Array(4096);FS.m ount(MEMFS,{},"/");FS.createDefaultDirectories();FS.createDefaultDevices()}),ini t:(function(input,output,error){assert(!FS.init.initialized,"FS.init was previou sly called. If you want to initialize later with custom parameters, remove any e arlier calls (note that one is automatically added to the generated code)");FS.i nit.initialized=true;FS.ensureErrnoError();Module["stdin"]=input||Module["stdin" ];Module["stdout"]=output||Module["stdout"];Module["stderr"]=error||Module["stde rr"];FS.createStandardStreams()}),quit:(function(){FS.init.initialized=false;for (var i=0;i<FS.streams.length;i++){var stream=FS.streams[i];if(!stream){continue} FS.close(stream)}}),getMode:(function(canRead,canWrite){var mode=0;if(canRead)mo de|=292|73;if(canWrite)mode|=146;return mode}),joinPath:(function(parts,forceRel ative){var path=PATH.join.apply(null,parts);if(forceRelative&&path[0]=="/")path= path.substr(1);return path}),absolutePath:(function(relative,base){return PATH.r esolve(base,relative)}),standardizePath:(function(path){return PATH.normalize(pa th)}),findObject:(function(path,dontResolveLastLink){var ret=FS.analyzePath(path ,dontResolveLastLink);if(ret.exists){return ret.object}else{___setErrNo(ret.erro r);return null}}),analyzePath:(function(path,dontResolveLastLink){try{var lookup =FS.lookupPath(path,{follow:!dontResolveLastLink});path=lookup.path}catch(e){}va r ret={isRoot:false,exists:false,error:0,name:null,path:null,object:null,parentE xists:false,parentPath:null,parentObject:null};try{var lookup=FS.lookupPath(path ,{parent:true});ret.parentExists=true;ret.parentPath=lookup.path;ret.parentObjec t=lookup.node;ret.name=PATH.basename(path);lookup=FS.lookupPath(path,{follow:!do ntResolveLastLink});ret.exists=true;ret.path=lookup.path;ret.object=lookup.node; ret.name=lookup.node.name;ret.isRoot=lookup.path==="/"}catch(e){ret.error=e.errn o}return ret}),createFolder:(function(parent,name,canRead,canWrite){var path=PAT H.join2(typeof parent==="string"?parent:FS.getPath(parent),name);var mode=FS.get Mode(canRead,canWrite);return FS.mkdir(path,mode)}),createPath:(function(parent, path,canRead,canWrite){parent=typeof parent==="string"?parent:FS.getPath(parent) ;var parts=path.split("/").reverse();while(parts.length){var part=parts.pop();if (!part)continue;var current=PATH.join2(parent,part);try{FS.mkdir(current)}catch( e){}parent=current}return current}),createFile:(function(parent,name,properties, canRead,canWrite){var path=PATH.join2(typeof parent==="string"?parent:FS.getPath (parent),name);var mode=FS.getMode(canRead,canWrite);return FS.create(path,mode) }),createDataFile:(function(parent,name,data,canRead,canWrite,canOwn){var path=n ame?PATH.join2(typeof parent==="string"?parent:FS.getPath(parent),name):parent;v ar mode=FS.getMode(canRead,canWrite);var node=FS.create(path,mode);if(data){if(t ypeof data==="string"){var arr=new Array(data.length);for(var i=0,len=data.lengt h;i<len;++i)arr[i]=data.charCodeAt(i);data=arr}FS.chmod(node,mode|146);var strea m=FS.open(node,"w");FS.write(stream,data,0,data.length,0,canOwn);FS.close(stream );FS.chmod(node,mode)}return node}),createDevice:(function(parent,name,input,out put){var path=PATH.join2(typeof parent==="string"?parent:FS.getPath(parent),name );var mode=FS.getMode(!!input,!!output);if(!FS.createDevice.major)FS.createDevic e.major=64;var dev=FS.makedev(FS.createDevice.major++,0);FS.registerDevice(dev,{ open:(function(stream){stream.seekable=false}),close:(function(stream){if(output &&output.buffer&&output.buffer.length){output(10)}}),read:(function(stream,buffe r,offset,length,pos){var bytesRead=0;for(var i=0;i<length;i++){var result;try{re sult=input()}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}if(result===undef ined&&bytesRead===0){throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}if(result===nul l||result===undefined)break;bytesRead++;buffer[offset+i]=result}if(bytesRead){st ream.node.timestamp=Date.now()}return bytesRead}),write:(function(stream,buffer, offset,length,pos){for(var i=0;i<length;i++){try{output(buffer[offset+i])}catch( e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}}if(length){stream.node.timestamp=Da te.now()}return i})});return FS.mkdev(path,mode,dev)}),createLink:(function(pare nt,name,target,canRead,canWrite){var path=PATH.join2(typeof parent==="string"?pa rent:FS.getPath(parent),name);return FS.symlink(target,path)}),forceLoadFile:(fu nction(obj){if(obj.isDevice||obj.isFolder||obj.link||obj.contents)return true;va r success=true;if(typeof XMLHttpRequest!=="undefined"){throw new Error("Lazy loa ding 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.")}else if(Module["read"]){try{obj.contents=intArrayFrom String(Module["read"](obj.url),true);obj.usedBytes=obj.contents.length}catch(e){ success=false}}else{throw new Error("Cannot load without read() or XMLHttpReques t.")}if(!success)___setErrNo(ERRNO_CODES.EIO);return success}),createLazyFile:(f unction(parent,name,url,canRead,canWrite){function LazyUint8Array(){this.lengthK nown=false;this.chunks=[]}LazyUint8Array.prototype.get=function LazyUint8Array_g et(idx){if(idx>this.length-1||idx<0){return undefined}var chunkOffset=idx%this.c hunkSize;var chunkNum=idx/this.chunkSize|0;return this.getter(chunkNum)[chunkOff set]};LazyUint8Array.prototype.setDataGetter=function LazyUint8Array_setDataGett er(getter){this.getter=getter};LazyUint8Array.prototype.cacheLength=function Laz yUint8Array_cacheLength(){var xhr=new XMLHttpRequest;xhr.open("HEAD",url,false); xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status: "+xhr.status);var datalength=Number(xhr.g etResponseHeader("Content-length"));var header;var hasByteServing=(header=xhr.ge tResponseHeader("Accept-Ranges"))&&header==="bytes";var chunkSize=1024*1024;if(! hasByteServing)chunkSize=datalength;var doXHR=(function(from,to){if(from>to)thro w new Error("invalid range ("+from+", "+to+") or no bytes requested!");if(to>dat alength-1)throw new Error("only "+datalength+" bytes available! programmer error !");var xhr=new XMLHttpRequest;xhr.open("GET",url,false);if(datalength!==chunkSi ze)xhr.setRequestHeader("Range","bytes="+from+"-"+to);if(typeof Uint8Array!="und efined")xhr.responseType="arraybuffer";if(xhr.overrideMimeType){xhr.overrideMime Type("text/plain; charset=x-user-defined")}xhr.send(null);if(!(xhr.status>=200&& xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status : "+xhr.status);if(xhr.response!==undefined){return new Uint8Array(xhr.response| |[])}else{return intArrayFromString(xhr.responseText||"",true)}});var lazyArray= this;lazyArray.setDataGetter((function(chunkNum){var start=chunkNum*chunkSize;va r end=(chunkNum+1)*chunkSize-1;end=Math.min(end,datalength-1);if(typeof lazyArra y.chunks[chunkNum]==="undefined"){lazyArray.chunks[chunkNum]=doXHR(start,end)}if (typeof lazyArray.chunks[chunkNum]==="undefined")throw new Error("doXHR failed!" );return lazyArray.chunks[chunkNum]}));this._length=datalength;this._chunkSize=c hunkSize;this.lengthKnown=true};if(typeof XMLHttpRequest!=="undefined"){if(!ENVI RONMENT_IS_WORKER)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var lazyArray=new L azyUint8Array;Object.defineProperty(lazyArray,"length",{get:(function(){if(!this .lengthKnown){this.cacheLength()}return this._length})});Object.defineProperty(l azyArray,"chunkSize",{get:(function(){if(!this.lengthKnown){this.cacheLength()}r eturn this._chunkSize})});var properties={isDevice:false,contents:lazyArray}}els e{var properties={isDevice:false,url:url}}var node=FS.createFile(parent,name,pro perties,canRead,canWrite);if(properties.contents){node.contents=properties.conte nts}else if(properties.url){node.contents=null;node.url=properties.url}Object.de fineProperty(node,"usedBytes",{get:(function(){return this.contents.length})});v ar stream_ops={};var keys=Object.keys(node.stream_ops);keys.forEach((function(ke y){var fn=node.stream_ops[key];stream_ops[key]=function forceLoadLazyFile(){if(! FS.forceLoadFile(node)){throw new FS.ErrnoError(ERRNO_CODES.EIO)}return fn.apply (null,arguments)}}));stream_ops.read=function stream_ops_read(stream,buffer,offs et,length,position){if(!FS.forceLoadFile(node)){throw new FS.ErrnoError(ERRNO_CO DES.EIO)}var contents=stream.node.contents;if(position>=contents.length)return 0 ;var size=Math.min(contents.length-position,length);assert(size>=0);if(contents. slice){for(var i=0;i<size;i++){buffer[offset+i]=contents[position+i]}}else{for(v ar i=0;i<size;i++){buffer[offset+i]=contents.get(position+i)}}return size};node. stream_ops=stream_ops;return node}),createPreloadedFile:(function(parent,name,ur l,canRead,canWrite,onload,onerror,dontCreateFile,canOwn){Browser.init();var full name=name?PATH.resolve(PATH.join2(parent,name)):parent;function processData(byte Array){function finish(byteArray){if(!dontCreateFile){FS.createDataFile(parent,n ame,byteArray,canRead,canWrite,canOwn)}if(onload)onload();removeRunDependency("c p "+fullname)}var handled=false;Module["preloadPlugins"].forEach((function(plugi n){if(handled)return;if(plugin["canHandle"](fullname)){plugin["handle"](byteArra y,fullname,finish,(function(){if(onerror)onerror();removeRunDependency("cp "+ful lname)}));handled=true}}));if(!handled)finish(byteArray)}addRunDependency("cp "+ fullname);if(typeof url=="string"){Browser.asyncLoad(url,(function(byteArray){pr ocessData(byteArray)}),onerror)}else{processData(url)}}),indexedDB:(function(){r eturn window.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIn dexedDB}),DB_NAME:(function(){return"EM_FS_"+window.location.pathname}),DB_VERSI ON:20,DB_STORE_NAME:"FILE_DATA",saveFilesToDB:(function(paths,onload,onerror){on load=onload||(function(){});onerror=onerror||(function(){});var indexedDB=FS.ind exedDB();try{var openRequest=indexedDB.open(FS.DB_NAME(),FS.DB_VERSION)}catch(e) {return onerror(e)}openRequest.onupgradeneeded=function openRequest_onupgradenee ded(){console.log("creating db");var db=openRequest.result;db.createObjectStore( FS.DB_STORE_NAME)};openRequest.onsuccess=function openRequest_onsuccess(){var db =openRequest.result;var transaction=db.transaction([FS.DB_STORE_NAME],"readwrite ");var files=transaction.objectStore(FS.DB_STORE_NAME);var ok=0,fail=0,total=pat hs.length;function finish(){if(fail==0)onload();else onerror()}paths.forEach((fu nction(path){var putRequest=files.put(FS.analyzePath(path).object.contents,path) ;putRequest.onsuccess=function putRequest_onsuccess(){ok++;if(ok+fail==total)fin ish()};putRequest.onerror=function putRequest_onerror(){fail++;if(ok+fail==total )finish()}}));transaction.onerror=onerror};openRequest.onerror=onerror}),loadFil esFromDB:(function(paths,onload,onerror){onload=onload||(function(){});onerror=o nerror||(function(){});var indexedDB=FS.indexedDB();try{var openRequest=indexedD B.open(FS.DB_NAME(),FS.DB_VERSION)}catch(e){return onerror(e)}openRequest.onupgr adeneeded=onerror;openRequest.onsuccess=function openRequest_onsuccess(){var db= openRequest.result;try{var transaction=db.transaction([FS.DB_STORE_NAME],"readon ly")}catch(e){onerror(e);return}var files=transaction.objectStore(FS.DB_STORE_NA ME);var ok=0,fail=0,total=paths.length;function finish(){if(fail==0)onload();els e onerror()}paths.forEach((function(path){var getRequest=files.get(path);getRequ est.onsuccess=function getRequest_onsuccess(){if(FS.analyzePath(path).exists){FS .unlink(path)}FS.createDataFile(PATH.dirname(path),PATH.basename(path),getReques t.result,true,true,true);ok++;if(ok+fail==total)finish()};getRequest.onerror=fun ction getRequest_onerror(){fail++;if(ok+fail==total)finish()}}));transaction.one rror=onerror};openRequest.onerror=onerror})};function _mkport(){throw"TODO"}var SOCKFS={mount:(function(mount){Module["websocket"]=Module["websocket"]&&"object" ===typeof Module["websocket"]?Module["websocket"]:{};Module["websocket"]._callba cks={};Module["websocket"]["on"]=(function(event,callback){if("function"===typeo f callback){this._callbacks[event]=callback}return this});Module["websocket"].em it=(function(event,param){if("function"===typeof this._callbacks[event]){this._c allbacks[event].call(this,param)}});return FS.createNode(null,"/",16384|511,0)}) ,createSocket:(function(family,type,protocol){var streaming=type==1;if(protocol) {assert(streaming==(protocol==6))}var sock={family:family,type:type,protocol:pro tocol,server:null,error:null,peers:{},pending:[],recv_queue:[],sock_ops:SOCKFS.w ebsocket_sock_ops};var name=SOCKFS.nextname();var node=FS.createNode(SOCKFS.root ,name,49152,0);node.sock=sock;var stream=FS.createStream({path:name,node:node,fl ags:FS.modeStringToFlags("r+"),seekable:false,stream_ops:SOCKFS.stream_ops});soc k.stream=stream;return sock}),getSocket:(function(fd){var stream=FS.getStream(fd );if(!stream||!FS.isSocket(stream.node.mode)){return null}return stream.node.soc k}),stream_ops:{poll:(function(stream){var sock=stream.node.sock;return sock.soc k_ops.poll(sock)}),ioctl:(function(stream,request,varargs){var sock=stream.node. sock;return sock.sock_ops.ioctl(sock,request,varargs)}),read:(function(stream,bu ffer,offset,length,position){var sock=stream.node.sock;var msg=sock.sock_ops.rec vmsg(sock,length);if(!msg){return 0}buffer.set(msg.buffer,offset);return msg.buf fer.length}),write:(function(stream,buffer,offset,length,position){var sock=stre am.node.sock;return sock.sock_ops.sendmsg(sock,buffer,offset,length)}),close:(fu nction(stream){var sock=stream.node.sock;sock.sock_ops.close(sock)})},nextname:( function(){if(!SOCKFS.nextname.current){SOCKFS.nextname.current=0}return"socket[ "+SOCKFS.nextname.current++ +"]"}),websocket_sock_ops:{createPeer:(function(sock ,addr,port){var ws;if(typeof addr==="object"){ws=addr;addr=null;port=null}if(ws) {if(ws._socket){addr=ws._socket.remoteAddress;port=ws._socket.remotePort}else{va r result=/ws[s]?:\/\/([^:]+):(\d+)/.exec(ws.url);if(!result){throw new Error("We bSocket URL must be in the format ws(s)://address:port")}addr=result[1];port=par seInt(result[2],10)}}else{try{var runtimeConfig=Module["websocket"]&&"object"=== typeof Module["websocket"];var url="ws:#".replace("#","//");if(runtimeConfig){if ("string"===typeof Module["websocket"]["url"]){url=Module["websocket"]["url"]}}i f(url==="ws://"||url==="wss://"){var parts=addr.split("/");url=url+parts[0]+":"+ port+"/"+parts.slice(1).join("/")}var subProtocols="binary";if(runtimeConfig){if ("string"===typeof Module["websocket"]["subprotocol"]){subProtocols=Module["webs ocket"]["subprotocol"]}}subProtocols=subProtocols.replace(/^ +| +$/g,"").split(/ *, */);var opts=ENVIRONMENT_IS_NODE?{"protocol":subProtocols.toString()}:subPro tocols;var WebSocket=ENVIRONMENT_IS_NODE?require("ws"):window["WebSocket"];ws=ne w WebSocket(url,opts);ws.binaryType="arraybuffer"}catch(e){throw new FS.ErrnoErr or(ERRNO_CODES.EHOSTUNREACH)}}var peer={addr:addr,port:port,socket:ws,dgram_send _queue:[]};SOCKFS.websocket_sock_ops.addPeer(sock,peer);SOCKFS.websocket_sock_op s.handlePeerEvents(sock,peer);if(sock.type===2&&typeof sock.sport!=="undefined") {peer.dgram_send_queue.push(new Uint8Array([255,255,255,255,"p".charCodeAt(0),"o ".charCodeAt(0),"r".charCodeAt(0),"t".charCodeAt(0),(sock.sport&65280)>>8,sock.s port&255]))}return peer}),getPeer:(function(sock,addr,port){return sock.peers[ad dr+":"+port]}),addPeer:(function(sock,peer){sock.peers[peer.addr+":"+peer.port]= peer}),removePeer:(function(sock,peer){delete sock.peers[peer.addr+":"+peer.port ]}),handlePeerEvents:(function(sock,peer){var first=true;var handleOpen=(functio n(){Module["websocket"].emit("open",sock.stream.fd);try{var queued=peer.dgram_se nd_queue.shift();while(queued){peer.socket.send(queued);queued=peer.dgram_send_q ueue.shift()}}catch(e){peer.socket.close()}});function handleMessage(data){asser t(typeof data!=="string"&&data.byteLength!==undefined);data=new Uint8Array(data) ;var wasfirst=first;first=false;if(wasfirst&&data.length===10&&data[0]===255&&da ta[1]===255&&data[2]===255&&data[3]===255&&data[4]==="p".charCodeAt(0)&&data[5]= =="o".charCodeAt(0)&&data[6]==="r".charCodeAt(0)&&data[7]==="t".charCodeAt(0)){v ar newport=data[8]<<8|data[9];SOCKFS.websocket_sock_ops.removePeer(sock,peer);pe er.port=newport;SOCKFS.websocket_sock_ops.addPeer(sock,peer);return}sock.recv_qu eue.push({addr:peer.addr,port:peer.port,data:data});Module["websocket"].emit("me ssage",sock.stream.fd)}if(ENVIRONMENT_IS_NODE){peer.socket.on("open",handleOpen) ;peer.socket.on("message",(function(data,flags){if(!flags.binary){return}handleM essage((new Uint8Array(data)).buffer)}));peer.socket.on("close",(function(){Modu le["websocket"].emit("close",sock.stream.fd)}));peer.socket.on("error",(function (error){sock.error=ERRNO_CODES.ECONNREFUSED;Module["websocket"].emit("error",[so ck.stream.fd,sock.error,"ECONNREFUSED: Connection refused"])}))}else{peer.socket .onopen=handleOpen;peer.socket.onclose=(function(){Module["websocket"].emit("clo se",sock.stream.fd)});peer.socket.onmessage=function peer_socket_onmessage(event ){handleMessage(event.data)};peer.socket.onerror=(function(error){sock.error=ERR NO_CODES.ECONNREFUSED;Module["websocket"].emit("error",[sock.stream.fd,sock.erro r,"ECONNREFUSED: Connection refused"])})}}),poll:(function(sock){if(sock.type=== 1&&sock.server){return sock.pending.length?64|1:0}var mask=0;var dest=sock.type= ==1?SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dport):null;if(sock.r ecv_queue.length||!dest||dest&&dest.socket.readyState===dest.socket.CLOSING||des t&&dest.socket.readyState===dest.socket.CLOSED){mask|=64|1}if(!dest||dest&&dest. socket.readyState===dest.socket.OPEN){mask|=4}if(dest&&dest.socket.readyState=== dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){mask|=16 }return mask}),ioctl:(function(sock,request,arg){switch(request){case 21531:var bytes=0;if(sock.recv_queue.length){bytes=sock.recv_queue[0].data.length}HEAP32[a rg>>2]=bytes;return 0;default:return ERRNO_CODES.EINVAL}}),close:(function(sock) {if(sock.server){try{sock.server.close()}catch(e){}sock.server=null}var peers=Ob ject.keys(sock.peers);for(var i=0;i<peers.length;i++){var peer=sock.peers[peers[ i]];try{peer.socket.close()}catch(e){}SOCKFS.websocket_sock_ops.removePeer(sock, peer)}return 0}),bind:(function(sock,addr,port){if(typeof sock.saddr!=="undefine d"||typeof sock.sport!=="undefined"){throw new FS.ErrnoError(ERRNO_CODES.EINVAL) }sock.saddr=addr;sock.sport=port||_mkport();if(sock.type===2){if(sock.server){so ck.server.close();sock.server=null}try{sock.sock_ops.listen(sock,0)}catch(e){if( !(e instanceof FS.ErrnoError))throw e;if(e.errno!==ERRNO_CODES.EOPNOTSUPP)throw e}}}),connect:(function(sock,addr,port){if(sock.server){throw new FS.ErrnoError( ERRNO_CODES.EOPNOTSUPP)}if(typeof sock.daddr!=="undefined"&&typeof sock.dport!== "undefined"){var dest=SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dpo rt);if(dest){if(dest.socket.readyState===dest.socket.CONNECTING){throw new FS.Er rnoError(ERRNO_CODES.EALREADY)}else{throw new FS.ErrnoError(ERRNO_CODES.EISCONN) }}}var peer=SOCKFS.websocket_sock_ops.createPeer(sock,addr,port);sock.daddr=peer .addr;sock.dport=peer.port;throw new FS.ErrnoError(ERRNO_CODES.EINPROGRESS)}),li sten:(function(sock,backlog){if(!ENVIRONMENT_IS_NODE){throw new FS.ErrnoError(ER RNO_CODES.EOPNOTSUPP)}if(sock.server){throw new FS.ErrnoError(ERRNO_CODES.EINVAL )}var WebSocketServer=require("ws").Server;var host=sock.saddr;sock.server=new W ebSocketServer({host:host,port:sock.sport});Module["websocket"].emit("listen",so ck.stream.fd);sock.server.on("connection",(function(ws){if(sock.type===1){var ne wsock=SOCKFS.createSocket(sock.family,sock.type,sock.protocol);var peer=SOCKFS.w ebsocket_sock_ops.createPeer(newsock,ws);newsock.daddr=peer.addr;newsock.dport=p eer.port;sock.pending.push(newsock);Module["websocket"].emit("connection",newsoc k.stream.fd)}else{SOCKFS.websocket_sock_ops.createPeer(sock,ws);Module["websocke t"].emit("connection",sock.stream.fd)}}));sock.server.on("closed",(function(){Mo dule["websocket"].emit("close",sock.stream.fd);sock.server=null}));sock.server.o n("error",(function(error){sock.error=ERRNO_CODES.EHOSTUNREACH;Module["websocket "].emit("error",[sock.stream.fd,sock.error,"EHOSTUNREACH: Host is unreachable"]) }))}),accept:(function(listensock){if(!listensock.server){throw new FS.ErrnoErro r(ERRNO_CODES.EINVAL)}var newsock=listensock.pending.shift();newsock.stream.flag s=listensock.stream.flags;return newsock}),getname:(function(sock,peer){var addr ,port;if(peer){if(sock.daddr===undefined||sock.dport===undefined){throw new FS.E rrnoError(ERRNO_CODES.ENOTCONN)}addr=sock.daddr;port=sock.dport}else{addr=sock.s addr||0;port=sock.sport||0}return{addr:addr,port:port}}),sendmsg:(function(sock, buffer,offset,length,addr,port){if(sock.type===2){if(addr===undefined||port===un defined){addr=sock.daddr;port=sock.dport}if(addr===undefined||port===undefined){ throw new FS.ErrnoError(ERRNO_CODES.EDESTADDRREQ)}}else{addr=sock.daddr;port=soc k.dport}var dest=SOCKFS.websocket_sock_ops.getPeer(sock,addr,port);if(sock.type= ==1){if(!dest||dest.socket.readyState===dest.socket.CLOSING||dest.socket.readySt ate===dest.socket.CLOSED){throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN)}else if( dest.socket.readyState===dest.socket.CONNECTING){throw new FS.ErrnoError(ERRNO_C ODES.EAGAIN)}}var data;if(buffer instanceof Array||buffer instanceof ArrayBuffer ){data=buffer.slice(offset,offset+length)}else{data=buffer.buffer.slice(buffer.b yteOffset+offset,buffer.byteOffset+offset+length)}if(sock.type===2){if(!dest||de st.socket.readyState!==dest.socket.OPEN){if(!dest||dest.socket.readyState===dest .socket.CLOSING||dest.socket.readyState===dest.socket.CLOSED){dest=SOCKFS.websoc ket_sock_ops.createPeer(sock,addr,port)}dest.dgram_send_queue.push(data);return length}}try{dest.socket.send(data);return length}catch(e){throw new FS.ErrnoErro r(ERRNO_CODES.EINVAL)}}),recvmsg:(function(sock,length){if(sock.type===1&&sock.s erver){throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN)}var queued=sock.recv_queue. shift();if(!queued){if(sock.type===1){var dest=SOCKFS.websocket_sock_ops.getPeer (sock,sock.daddr,sock.dport);if(!dest){throw new FS.ErrnoError(ERRNO_CODES.ENOTC ONN)}else if(dest.socket.readyState===dest.socket.CLOSING||dest.socket.readyStat e===dest.socket.CLOSED){return null}else{throw new FS.ErrnoError(ERRNO_CODES.EAG AIN)}}else{throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}}var queuedLength=queued. data.byteLength||queued.data.length;var queuedOffset=queued.data.byteOffset||0;v ar queuedBuffer=queued.data.buffer||queued.data;var bytesRead=Math.min(length,qu euedLength);var res={buffer:new Uint8Array(queuedBuffer,queuedOffset,bytesRead), addr:queued.addr,port:queued.port};if(sock.type===1&&bytesRead<queuedLength){var bytesRemaining=queuedLength-bytesRead;queued.data=new Uint8Array(queuedBuffer,q ueuedOffset+bytesRead,bytesRemaining);sock.recv_queue.unshift(queued)}return res })}};function _send(fd,buf,len,flags){var sock=SOCKFS.getSocket(fd);if(!sock){__ _setErrNo(ERRNO_CODES.EBADF);return-1}return _write(fd,buf,len)}function _pwrite (fildes,buf,nbyte,offset){var stream=FS.getStream(fildes);if(!stream){___setErrN o(ERRNO_CODES.EBADF);return-1}try{var slab=HEAP8;return FS.write(stream,slab,buf ,nbyte,offset)}catch(e){FS.handleFSError(e);return-1}}function _write(fildes,buf ,nbyte){var stream=FS.getStream(fildes);if(!stream){___setErrNo(ERRNO_CODES.EBAD F);return-1}try{var slab=HEAP8;return FS.write(stream,slab,buf,nbyte)}catch(e){F S.handleFSError(e);return-1}}function _fileno(stream){stream=FS.getStreamFromPtr (stream);if(!stream)return-1;return stream.fd}function _fwrite(ptr,size,nitems,s tream){var bytesToWrite=nitems*size;if(bytesToWrite==0)return 0;var fd=_fileno(s tream);var bytesWritten=_write(fd,ptr,bytesToWrite);if(bytesWritten==-1){var str eamObj=FS.getStreamFromPtr(stream);if(streamObj)streamObj.error=true;return 0}el se{return bytesWritten/size|0}}Module["_strlen"]=_strlen;function __reallyNegati ve(x){return x<0||x===0&&1/x===-Infinity}function __formatString(format,varargs) {var textIndex=format;var argIndex=0;function getNextArg(type){var ret;if(type== ="double"){ret=(HEAP32[tempDoublePtr>>2]=HEAP32[varargs+argIndex>>2],HEAP32[temp DoublePtr+4>>2]=HEAP32[varargs+(argIndex+4)>>2],+HEAPF64[tempDoublePtr>>3])}else if(type=="i64"){ret=[HEAP32[varargs+argIndex>>2],HEAP32[varargs+(argIndex+4)>>2 ]]}else{type="i32";ret=HEAP32[varargs+argIndex>>2]}argIndex+=Runtime.getNativeFi eldSize(type);return ret}var ret=[];var curr,next,currArg;while(1){var startText Index=textIndex;curr=HEAP8[textIndex>>0];if(curr===0)break;next=HEAP8[textIndex+ 1>>0];if(curr==37){var flagAlwaysSigned=false;var flagLeftAlign=false;var flagAl ternative=false;var flagZeroPad=false;var flagPadSign=false;flagsLoop:while(1){s witch(next){case 43:flagAlwaysSigned=true;break;case 45:flagLeftAlign=true;break ;case 35:flagAlternative=true;break;case 48:if(flagZeroPad){break flagsLoop}else {flagZeroPad=true;break};case 32:flagPadSign=true;break;default:break flagsLoop} textIndex++;next=HEAP8[textIndex+1>>0]}var width=0;if(next==42){width=getNextArg ("i32");textIndex++;next=HEAP8[textIndex+1>>0]}else{while(next>=48&&next<=57){wi dth=width*10+(next-48);textIndex++;next=HEAP8[textIndex+1>>0]}}var precisionSet= false,precision=-1;if(next==46){precision=0;precisionSet=true;textIndex++;next=H EAP8[textIndex+1>>0];if(next==42){precision=getNextArg("i32");textIndex++}else{w hile(1){var precisionChr=HEAP8[textIndex+1>>0];if(precisionChr<48||precisionChr> 57)break;precision=precision*10+(precisionChr-48);textIndex++}}next=HEAP8[textIn dex+1>>0]}if(precision<0){precision=6;precisionSet=false}var argSize;switch(Stri ng.fromCharCode(next)){case"h":var nextNext=HEAP8[textIndex+2>>0];if(nextNext==1 04){textIndex++;argSize=1}else{argSize=2}break;case"l":var nextNext=HEAP8[textIn dex+2>>0];if(nextNext==108){textIndex++;argSize=8}else{argSize=4}break;case"L":c ase"q":case"j":argSize=8;break;case"z":case"t":case"I":argSize=4;break;default:a rgSize=null}if(argSize)textIndex++;next=HEAP8[textIndex+1>>0];switch(String.from CharCode(next)){case"d":case"i":case"u":case"o":case"x":case"X":case"p":{var sig ned=next==100||next==105;argSize=argSize||4;var currArg=getNextArg("i"+argSize*8 );var origArg=currArg;var argText;if(argSize==8){currArg=Runtime.makeBigInt(curr Arg[0],currArg[1],next==117)}if(argSize<=4){var limit=Math.pow(256,argSize)-1;cu rrArg=(signed?reSign:unSign)(currArg&limit,argSize*8)}var currAbsArg=Math.abs(cu rrArg);var prefix="";if(next==100||next==105){if(argSize==8&&i64Math)argText=i64 Math.stringify(origArg[0],origArg[1],null);else argText=reSign(currArg,8*argSize ,1).toString(10)}else if(next==117){if(argSize==8&&i64Math)argText=i64Math.strin gify(origArg[0],origArg[1],true);else argText=unSign(currArg,8*argSize,1).toStri ng(10);currArg=Math.abs(currArg)}else if(next==111){argText=(flagAlternative?"0" :"")+currAbsArg.toString(8)}else if(next==120||next==88){prefix=flagAlternative& &currArg!=0?"0x":"";if(argSize==8&&i64Math){if(origArg[1]){argText=(origArg[1]>> >0).toString(16);var lower=(origArg[0]>>>0).toString(16);while(lower.length<8)lo wer="0"+lower;argText+=lower}else{argText=(origArg[0]>>>0).toString(16)}}else if (currArg<0){currArg=-currArg;argText=(currAbsArg-1).toString(16);var buffer=[];f or(var i=0;i<argText.length;i++){buffer.push((15-parseInt(argText[i],16)).toStri ng(16))}argText=buffer.join("");while(argText.length<argSize*2)argText="f"+argTe xt}else{argText=currAbsArg.toString(16)}if(next==88){prefix=prefix.toUpperCase() ;argText=argText.toUpperCase()}}else if(next==112){if(currAbsArg===0){argText="( nil)"}else{prefix="0x";argText=currAbsArg.toString(16)}}if(precisionSet){while(a rgText.length<precision){argText="0"+argText}}if(currArg>=0){if(flagAlwaysSigned ){prefix="+"+prefix}else if(flagPadSign){prefix=" "+prefix}}if(argText.charAt(0) =="-"){prefix="-"+prefix;argText=argText.substr(1)}while(prefix.length+argText.l ength<width){if(flagLeftAlign){argText+=" "}else{if(flagZeroPad){argText="0"+arg Text}else{prefix=" "+prefix}}}argText=prefix+argText;argText.split("").forEach(( function(chr){ret.push(chr.charCodeAt(0))}));break};case"f":case"F":case"e":case "E":case"g":case"G":{var currArg=getNextArg("double");var argText;if(isNaN(currA rg)){argText="nan";flagZeroPad=false}else if(!isFinite(currArg)){argText=(currAr g<0?"-":"")+"inf";flagZeroPad=false}else{var isGeneral=false;var effectivePrecis ion=Math.min(precision,20);if(next==103||next==71){isGeneral=true;precision=prec ision||1;var exponent=parseInt(currArg.toExponential(effectivePrecision).split(" e")[1],10);if(precision>exponent&&exponent>=-4){next=(next==103?"f":"F").charCod eAt(0);precision-=exponent+1}else{next=(next==103?"e":"E").charCodeAt(0);precisi on--}effectivePrecision=Math.min(precision,20)}if(next==101||next==69){argText=c urrArg.toExponential(effectivePrecision);if(/[eE][-+]\d$/.test(argText)){argText =argText.slice(0,-1)+"0"+argText.slice(-1)}}else if(next==102||next==70){argText =currArg.toFixed(effectivePrecision);if(currArg===0&&__reallyNegative(currArg)){ argText="-"+argText}}var parts=argText.split("e");if(isGeneral&&!flagAlternative ){while(parts[0].length>1&&parts[0].indexOf(".")!=-1&&(parts[0].slice(-1)=="0"|| parts[0].slice(-1)==".")){parts[0]=parts[0].slice(0,-1)}}else{if(flagAlternative &&argText.indexOf(".")==-1)parts[0]+=".";while(precision>effectivePrecision++)pa rts[0]+="0"}argText=parts[0]+(parts.length>1?"e"+parts[1]:"");if(next==69)argTex t=argText.toUpperCase();if(currArg>=0){if(flagAlwaysSigned){argText="+"+argText} else if(flagPadSign){argText=" "+argText}}}while(argText.length<width){if(flagLe ftAlign){argText+=" "}else{if(flagZeroPad&&(argText[0]=="-"||argText[0]=="+")){a rgText=argText[0]+"0"+argText.slice(1)}else{argText=(flagZeroPad?"0":" ")+argTex t}}}if(next<97)argText=argText.toUpperCase();argText.split("").forEach((function (chr){ret.push(chr.charCodeAt(0))}));break};case"s":{var arg=getNextArg("i8*");v ar argLength=arg?_strlen(arg):"(null)".length;if(precisionSet)argLength=Math.min (argLength,precision);if(!flagLeftAlign){while(argLength<width--){ret.push(32)}} if(arg){for(var i=0;i<argLength;i++){ret.push(HEAPU8[arg++>>0])}}else{ret=ret.co ncat(intArrayFromString("(null)".substr(0,argLength),true))}if(flagLeftAlign){wh ile(argLength<width--){ret.push(32)}}break};case"c":{if(flagLeftAlign)ret.push(g etNextArg("i8"));while(--width>0){ret.push(32)}if(!flagLeftAlign)ret.push(getNex tArg("i8"));break};case"n":{var ptr=getNextArg("i32*");HEAP32[ptr>>2]=ret.length ;break};case"%":{ret.push(curr);break};default:{for(var i=startTextIndex;i<textI ndex+2;i++){ret.push(HEAP8[i>>0])}}}textIndex+=2}else{ret.push(curr);textIndex+= 1}}return ret}function _fprintf(stream,format,varargs){var result=__formatString (format,varargs);var stack=Runtime.stackSave();var ret=_fwrite(allocate(result," i8",ALLOC_STACK),1,result.length,stream);Runtime.stackRestore(stack);return ret} function _printf(format,varargs){var stdout=HEAP32[_stdout>>2];return _fprintf(s tdout,format,varargs)}function _sbrk(bytes){var self=_sbrk;if(!self.called){DYNA MICTOP=alignMemoryPage(DYNAMICTOP);self.called=true;assert(Runtime.dynamicAlloc) ;self.alloc=Runtime.dynamicAlloc;Runtime.dynamicAlloc=(function(){abort("cannot dynamically allocate, sbrk now has control")})}var ret=DYNAMICTOP;if(bytes!=0){v ar success=self.alloc(bytes);if(!success)return-1>>>0}return ret}function _sysco nf(name){switch(name){case 30:return PAGE_SIZE;case 132:case 133:case 12:case 13 7:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:cas e 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14: case 77:case 78:case 139:case 80:case 81:case 79:case 82:case 68:case 67:case 16 4:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809; case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:ca se 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:c ase 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:ca se 97:case 76:case 32:case 173:case 35:return-1;case 176:case 177:case 7:case 15 5:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:c ase 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:c ase 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0: return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;cas e 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:retu rn 16;case 6:return 6;case 73:return 4;case 84:{if(typeof navigator==="object")r eturn navigator["hardwareConcurrency"]||1;return 1}}___setErrNo(ERRNO_CODES.EINV AL);return-1}Module["_memset"]=_memset;function ___errno_location(){return ___er rno_state}function _abort(){Module["abort"]()}function _emscripten_set_main_loop _timing(mode,value){Browser.mainLoop.timingMode=mode;Browser.mainLoop.timingValu e=value;if(!Browser.mainLoop.func){return 1}if(mode==0){Browser.mainLoop.schedul er=function Browser_mainLoop_scheduler(){setTimeout(Browser.mainLoop.runner,valu e)};Browser.mainLoop.method="timeout"}else if(mode==1){Browser.mainLoop.schedule r=function Browser_mainLoop_scheduler(){Browser.requestAnimationFrame(Browser.ma inLoop.runner)};Browser.mainLoop.method="rAF"}return 0}function _emscripten_set_ main_loop(func,fps,simulateInfiniteLoop,arg,noSetTiming){Module["noExitRuntime"] =true;assert(!Browser.mainLoop.func,"emscripten_set_main_loop: there can only be one main loop function at once: call emscripten_cancel_main_loop to cancel the previous one before setting a new one with different parameters.");Browser.mainL oop.func=func;Browser.mainLoop.arg=arg;var thisMainLoopId=Browser.mainLoop.curre ntlyRunningMainloop;Browser.mainLoop.runner=function Browser_mainLoop_runner(){i f(ABORT)return;if(Browser.mainLoop.queue.length>0){var start=Date.now();var bloc ker=Browser.mainLoop.queue.shift();blocker.func(blocker.arg);if(Browser.mainLoop .remainingBlockers){var remaining=Browser.mainLoop.remainingBlockers;var next=re maining%1==0?remaining-1:Math.floor(remaining);if(blocker.counted){Browser.mainL oop.remainingBlockers=next}else{next=next+.5;Browser.mainLoop.remainingBlockers= (8*remaining+next)/9}}console.log('main loop blocker "'+blocker.name+'" took '+( Date.now()-start)+" ms");Browser.mainLoop.updateStatus();setTimeout(Browser.main Loop.runner,0);return}if(thisMainLoopId<Browser.mainLoop.currentlyRunningMainloo p)return;Browser.mainLoop.currentFrameNumber=Browser.mainLoop.currentFrameNumber +1|0;if(Browser.mainLoop.timingMode==1&&Browser.mainLoop.timingValue>1&&Browser. mainLoop.currentFrameNumber%Browser.mainLoop.timingValue!=0){Browser.mainLoop.sc heduler();return}if(Browser.mainLoop.method==="timeout"&&Module.ctx){Module.prin tErr("Looks like you are rendering without using requestAnimationFrame for the m ain loop. You should use 0 for the frame rate in emscripten_set_main_loop in ord er to use requestAnimationFrame, as that can greatly improve your frame rates!") ;Browser.mainLoop.method=""}Browser.mainLoop.runIter((function(){if(typeof arg!= ="undefined"){Runtime.dynCall("vi",func,[arg])}else{Runtime.dynCall("v",func)}}) );if(thisMainLoopId<Browser.mainLoop.currentlyRunningMainloop)return;if(typeof S DL==="object"&&SDL.audio&&SDL.audio.queueNewAudioData)SDL.audio.queueNewAudioDat a();Browser.mainLoop.scheduler()};if(!noSetTiming){if(fps&&fps>0)_emscripten_set _main_loop_timing(0,1e3/fps);else _emscripten_set_main_loop_timing(1,1);Browser. mainLoop.scheduler()}if(simulateInfiniteLoop){throw"SimulateInfiniteLoop"}}var B rowser={mainLoop:{scheduler:null,method:"",currentlyRunningMainloop:0,func:null, arg:0,timingMode:0,timingValue:0,currentFrameNumber:0,queue:[],pause:(function() {Browser.mainLoop.scheduler=null;Browser.mainLoop.currentlyRunningMainloop++}),r esume:(function(){Browser.mainLoop.currentlyRunningMainloop++;var timingMode=Bro wser.mainLoop.timingMode;var timingValue=Browser.mainLoop.timingValue;var func=B rowser.mainLoop.func;Browser.mainLoop.func=null;_emscripten_set_main_loop(func,0 ,false,Browser.mainLoop.arg,true);_emscripten_set_main_loop_timing(timingMode,ti mingValue);Browser.mainLoop.scheduler()}),updateStatus:(function(){if(Module["se tStatus"]){var message=Module["statusMessage"]||"Please wait...";var remaining=B rowser.mainLoop.remainingBlockers;var expected=Browser.mainLoop.expectedBlockers ;if(remaining){if(remaining<expected){Module["setStatus"](message+" ("+(expected -remaining)+"/"+expected+")")}else{Module["setStatus"](message)}}else{Module["se tStatus"]("")}}}),runIter:(function(func){if(ABORT)return;if(Module["preMainLoop "]){var preRet=Module["preMainLoop"]();if(preRet===false){return}}try{func()}cat ch(e){if(e instanceof ExitStatus){return}else{if(e&&typeof e==="object"&&e.stack )Module.printErr("exception thrown: "+[e,e.stack]);throw e}}if(Module["postMainL oop"])Module["postMainLoop"]()})},isFullScreen:false,pointerLock:false,moduleCon textCreatedCallbacks:[],workers:[],init:(function(){if(!Module["preloadPlugins"] )Module["preloadPlugins"]=[];if(Browser.initted)return;Browser.initted=true;try{ new Blob;Browser.hasBlobConstructor=true}catch(e){Browser.hasBlobConstructor=fal se;console.log("warning: no blob constructor, cannot create blobs with mimetypes ")}Browser.BlobBuilder=typeof MozBlobBuilder!="undefined"?MozBlobBuilder:typeof WebKitBlobBuilder!="undefined"?WebKitBlobBuilder:!Browser.hasBlobConstructor?con sole.log("warning: no BlobBuilder"):null;Browser.URLObject=typeof window!="undef ined"?window.URL?window.URL:window.webkitURL:undefined;if(!Module.noImageDecodin g&&typeof Browser.URLObject==="undefined"){console.log("warning: Browser does no t support creating object URLs. Built-in browser image decoding will not be avai lable.");Module.noImageDecoding=true}var imagePlugin={};imagePlugin["canHandle"] =function imagePlugin_canHandle(name){return!Module.noImageDecoding&&/\.(jpg|jpe g|png|bmp)$/i.test(name)};imagePlugin["handle"]=function imagePlugin_handle(byte Array,name,onload,onerror){var b=null;if(Browser.hasBlobConstructor){try{b=new B lob([byteArray],{type:Browser.getMimetype(name)});if(b.size!==byteArray.length){ b=new Blob([(new Uint8Array(byteArray)).buffer],{type:Browser.getMimetype(name)} )}}catch(e){Runtime.warnOnce("Blob constructor present but fails: "+e+"; falling back to blob builder")}}if(!b){var bb=new Browser.BlobBuilder;bb.append((new Ui nt8Array(byteArray)).buffer);b=bb.getBlob()}var url=Browser.URLObject.createObje ctURL(b);var img=new Image;img.onload=function img_onload(){assert(img.complete, "Image "+name+" could not be decoded");var canvas=document.createElement("canvas ");canvas.width=img.width;canvas.height=img.height;var ctx=canvas.getContext("2d ");ctx.drawImage(img,0,0);Module["preloadedImages"][name]=canvas;Browser.URLObje ct.revokeObjectURL(url);if(onload)onload(byteArray)};img.onerror=function img_on error(event){console.log("Image "+url+" could not be decoded");if(onerror)onerro r()};img.src=url};Module["preloadPlugins"].push(imagePlugin);var audioPlugin={}; audioPlugin["canHandle"]=function audioPlugin_canHandle(name){return!Module.noAu dioDecoding&&name.substr(-4)in{".ogg":1,".wav":1,".mp3":1}};audioPlugin["handle" ]=function audioPlugin_handle(byteArray,name,onload,onerror){var done=false;func tion finish(audio){if(done)return;done=true;Module["preloadedAudios"][name]=audi o;if(onload)onload(byteArray)}function fail(){if(done)return;done=true;Module["p reloadedAudios"][name]=new Audio;if(onerror)onerror()}if(Browser.hasBlobConstruc tor){try{var b=new Blob([byteArray],{type:Browser.getMimetype(name)})}catch(e){r eturn fail()}var url=Browser.URLObject.createObjectURL(b);var audio=new Audio;au dio.addEventListener("canplaythrough",(function(){finish(audio)}),false);audio.o nerror=function audio_onerror(event){if(done)return;console.log("warning: browse r could not fully decode audio "+name+", trying slower base64 approach");functio n encode64(data){var BASE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0 123456789+/";var PAD="=";var ret="";var leftchar=0;var leftbits=0;for(var i=0;i< data.length;i++){leftchar=leftchar<<8|data[i];leftbits+=8;while(leftbits>=6){var curr=leftchar>>leftbits-6&63;leftbits-=6;ret+=BASE[curr]}}if(leftbits==2){ret+= BASE[(leftchar&3)<<4];ret+=PAD+PAD}else if(leftbits==4){ret+=BASE[(leftchar&15)< <2];ret+=PAD}return ret}audio.src="data:audio/x-"+name.substr(-3)+";base64,"+enc ode64(byteArray);finish(audio)};audio.src=url;Browser.safeSetTimeout((function() {finish(audio)}),1e4)}else{return fail()}};Module["preloadPlugins"].push(audioPl ugin);var canvas=Module["canvas"];function pointerLockChange(){Browser.pointerLo ck=document["pointerLockElement"]===canvas||document["mozPointerLockElement"]=== canvas||document["webkitPointerLockElement"]===canvas||document["msPointerLockEl ement"]===canvas}if(canvas){canvas.requestPointerLock=canvas["requestPointerLock "]||canvas["mozRequestPointerLock"]||canvas["webkitRequestPointerLock"]||canvas[ "msRequestPointerLock"]||(function(){});canvas.exitPointerLock=document["exitPoi nterLock"]||document["mozExitPointerLock"]||document["webkitExitPointerLock"]||d ocument["msExitPointerLock"]||(function(){});canvas.exitPointerLock=canvas.exitP ointerLock.bind(document);document.addEventListener("pointerlockchange",pointerL ockChange,false);document.addEventListener("mozpointerlockchange",pointerLockCha nge,false);document.addEventListener("webkitpointerlockchange",pointerLockChange ,false);document.addEventListener("mspointerlockchange",pointerLockChange,false) ;if(Module["elementPointerLock"]){canvas.addEventListener("click",(function(ev){ if(!Browser.pointerLock&&canvas.requestPointerLock){canvas.requestPointerLock(); ev.preventDefault()}}),false)}}}),createContext:(function(canvas,useWebGL,setInM odule,webGLContextAttributes){if(useWebGL&&Module.ctx&&canvas==Module.canvas)ret urn Module.ctx;var ctx;var contextHandle;if(useWebGL){var contextAttributes={ant ialias:false,alpha:false};if(webGLContextAttributes){for(var attribute in webGLC ontextAttributes){contextAttributes[attribute]=webGLContextAttributes[attribute] }}contextHandle=GL.createContext(canvas,contextAttributes);if(contextHandle){ctx =GL.getContext(contextHandle).GLctx}canvas.style.backgroundColor="black"}else{ct x=canvas.getContext("2d")}if(!ctx)return null;if(setInModule){if(!useWebGL)asser t(typeof GLctx==="undefined","cannot set in module if GLctx is used, but we are a non-GL context that would replace it");Module.ctx=ctx;if(useWebGL)GL.makeConte xtCurrent(contextHandle);Module.useWebGL=useWebGL;Browser.moduleContextCreatedCa llbacks.forEach((function(callback){callback()}));Browser.init()}return ctx}),de stroyContext:(function(canvas,useWebGL,setInModule){}),fullScreenHandlersInstall ed:false,lockPointer:undefined,resizeCanvas:undefined,requestFullScreen:(functio n(lockPointer,resizeCanvas,vrDevice){Browser.lockPointer=lockPointer;Browser.res izeCanvas=resizeCanvas;Browser.vrDevice=vrDevice;if(typeof Browser.lockPointer== ="undefined")Browser.lockPointer=true;if(typeof Browser.resizeCanvas==="undefine d")Browser.resizeCanvas=false;if(typeof Browser.vrDevice==="undefined")Browser.v rDevice=null;var canvas=Module["canvas"];function fullScreenChange(){Browser.isF ullScreen=false;var canvasContainer=canvas.parentNode;if((document["webkitFullSc reenElement"]||document["webkitFullscreenElement"]||document["mozFullScreenEleme nt"]||document["mozFullscreenElement"]||document["fullScreenElement"]||document[ "fullscreenElement"]||document["msFullScreenElement"]||document["msFullscreenEle ment"]||document["webkitCurrentFullScreenElement"])===canvasContainer){canvas.ca ncelFullScreen=document["cancelFullScreen"]||document["mozCancelFullScreen"]||do cument["webkitCancelFullScreen"]||document["msExitFullscreen"]||document["exitFu llscreen"]||(function(){});canvas.cancelFullScreen=canvas.cancelFullScreen.bind( document);if(Browser.lockPointer)canvas.requestPointerLock();Browser.isFullScree n=true;if(Browser.resizeCanvas)Browser.setFullScreenCanvasSize()}else{canvasCont ainer.parentNode.insertBefore(canvas,canvasContainer);canvasContainer.parentNode .removeChild(canvasContainer);if(Browser.resizeCanvas)Browser.setWindowedCanvasS ize()}if(Module["onFullScreen"])Module["onFullScreen"](Browser.isFullScreen);Bro wser.updateCanvasDimensions(canvas)}if(!Browser.fullScreenHandlersInstalled){Bro wser.fullScreenHandlersInstalled=true;document.addEventListener("fullscreenchang e",fullScreenChange,false);document.addEventListener("mozfullscreenchange",fullS creenChange,false);document.addEventListener("webkitfullscreenchange",fullScreen Change,false);document.addEventListener("MSFullscreenChange",fullScreenChange,fa lse)}var canvasContainer=document.createElement("div");canvas.parentNode.insertB efore(canvasContainer,canvas);canvasContainer.appendChild(canvas);canvasContaine r.requestFullScreen=canvasContainer["requestFullScreen"]||canvasContainer["mozRe questFullScreen"]||canvasContainer["msRequestFullscreen"]||(canvasContainer["web kitRequestFullScreen"]?(function(){canvasContainer["webkitRequestFullScreen"](El ement["ALLOW_KEYBOARD_INPUT"])}):null);if(vrDevice){canvasContainer.requestFullS creen({vrDisplay:vrDevice})}else{canvasContainer.requestFullScreen()}}),nextRAF: 0,fakeRequestAnimationFrame:(function(func){var now=Date.now();if(Browser.nextRA F===0){Browser.nextRAF=now+1e3/60}else{while(now+2>=Browser.nextRAF){Browser.nex tRAF+=1e3/60}}var delay=Math.max(Browser.nextRAF-now,0);setTimeout(func,delay)}) ,requestAnimationFrame:function requestAnimationFrame(func){if(typeof window===" undefined"){Browser.fakeRequestAnimationFrame(func)}else{if(!window.requestAnima tionFrame){window.requestAnimationFrame=window["requestAnimationFrame"]||window[ "mozRequestAnimationFrame"]||window["webkitRequestAnimationFrame"]||window["msRe questAnimationFrame"]||window["oRequestAnimationFrame"]||Browser.fakeRequestAnim ationFrame}window.requestAnimationFrame(func)}},safeCallback:(function(func){ret urn(function(){if(!ABORT)return func.apply(null,arguments)})}),allowAsyncCallbac ks:true,queuedAsyncCallbacks:[],pauseAsyncCallbacks:(function(){Browser.allowAsy ncCallbacks=false}),resumeAsyncCallbacks:(function(){Browser.allowAsyncCallbacks =true;if(Browser.queuedAsyncCallbacks.length>0){var callbacks=Browser.queuedAsyn cCallbacks;Browser.queuedAsyncCallbacks=[];callbacks.forEach((function(func){fun c()}))}}),safeRequestAnimationFrame:(function(func){return Browser.requestAnimat ionFrame((function(){if(ABORT)return;if(Browser.allowAsyncCallbacks){func()}else {Browser.queuedAsyncCallbacks.push(func)}}))}),safeSetTimeout:(function(func,tim eout){Module["noExitRuntime"]=true;return setTimeout((function(){if(ABORT)return ;if(Browser.allowAsyncCallbacks){func()}else{Browser.queuedAsyncCallbacks.push(f unc)}}),timeout)}),safeSetInterval:(function(func,timeout){Module["noExitRuntime "]=true;return setInterval((function(){if(ABORT)return;if(Browser.allowAsyncCall backs){func()}}),timeout)}),getMimetype:(function(name){return{"jpg":"image/jpeg ","jpeg":"image/jpeg","png":"image/png","bmp":"image/bmp","ogg":"audio/ogg","wav ":"audio/wav","mp3":"audio/mpeg"}[name.substr(name.lastIndexOf(".")+1)]}),getUse rMedia:(function(func){if(!window.getUserMedia){window.getUserMedia=navigator["g etUserMedia"]||navigator["mozGetUserMedia"]}window.getUserMedia(func)}),getMovem entX:(function(event){return event["movementX"]||event["mozMovementX"]||event["w ebkitMovementX"]||0}),getMovementY:(function(event){return event["movementY"]||e vent["mozMovementY"]||event["webkitMovementY"]||0}),getMouseWheelDelta:(function (event){var delta=0;switch(event.type){case"DOMMouseScroll":delta=event.detail;b reak;case"mousewheel":delta=event.wheelDelta;break;case"wheel":delta=event["delt aY"];break;default:throw"unrecognized mouse wheel event: "+event.type}return del ta}),mouseX:0,mouseY:0,mouseMovementX:0,mouseMovementY:0,touches:{},lastTouches: {},calculateMouseEvent:(function(event){if(Browser.pointerLock){if(event.type!=" mousemove"&&"mozMovementX"in event){Browser.mouseMovementX=Browser.mouseMovement Y=0}else{Browser.mouseMovementX=Browser.getMovementX(event);Browser.mouseMovemen tY=Browser.getMovementY(event)}if(typeof SDL!="undefined"){Browser.mouseX=SDL.mo useX+Browser.mouseMovementX;Browser.mouseY=SDL.mouseY+Browser.mouseMovementY}els e{Browser.mouseX+=Browser.mouseMovementX;Browser.mouseY+=Browser.mouseMovementY} }else{var rect=Module["canvas"].getBoundingClientRect();var cw=Module["canvas"]. width;var ch=Module["canvas"].height;var scrollX=typeof window.scrollX!=="undefi ned"?window.scrollX:window.pageXOffset;var scrollY=typeof window.scrollY!=="unde fined"?window.scrollY:window.pageYOffset;if(event.type==="touchstart"||event.typ e==="touchend"||event.type==="touchmove"){var touch=event.touch;if(touch===undef ined){return}var adjustedX=touch.pageX-(scrollX+rect.left);var adjustedY=touch.p ageY-(scrollY+rect.top);adjustedX=adjustedX*(cw/rect.width);adjustedY=adjustedY* (ch/rect.height);var coords={x:adjustedX,y:adjustedY};if(event.type==="touchstar t"){Browser.lastTouches[touch.identifier]=coords;Browser.touches[touch.identifie r]=coords}else if(event.type==="touchend"||event.type==="touchmove"){Browser.las tTouches[touch.identifier]=Browser.touches[touch.identifier];Browser.touches[tou ch.identifier]={x:adjustedX,y:adjustedY}}return}var x=event.pageX-(scrollX+rect. left);var y=event.pageY-(scrollY+rect.top);x=x*(cw/rect.width);y=y*(ch/rect.heig ht);Browser.mouseMovementX=x-Browser.mouseX;Browser.mouseMovementY=y-Browser.mou seY;Browser.mouseX=x;Browser.mouseY=y}}),xhrLoad:(function(url,onload,onerror){v ar xhr=new XMLHttpRequest;xhr.open("GET",url,true);xhr.responseType="arraybuffer ";xhr.onload=function xhr_onload(){if(xhr.status==200||xhr.status==0&&xhr.respon se){onload(xhr.response)}else{onerror()}};xhr.onerror=onerror;xhr.send(null)}),a syncLoad:(function(url,onload,onerror,noRunDep){Browser.xhrLoad(url,(function(ar rayBuffer){assert(arrayBuffer,'Loading data file "'+url+'" failed (no arrayBuffe r).');onload(new Uint8Array(arrayBuffer));if(!noRunDep)removeRunDependency("al " +url)}),(function(event){if(onerror){onerror()}else{throw'Loading data file "'+u rl+'" failed.'}}));if(!noRunDep)addRunDependency("al "+url)}),resizeListeners:[] ,updateResizeListeners:(function(){var canvas=Module["canvas"];Browser.resizeLis teners.forEach((function(listener){listener(canvas.width,canvas.height)}))}),set CanvasSize:(function(width,height,noUpdates){var canvas=Module["canvas"];Browser .updateCanvasDimensions(canvas,width,height);if(!noUpdates)Browser.updateResizeL isteners()}),windowedWidth:0,windowedHeight:0,setFullScreenCanvasSize:(function( ){if(typeof SDL!="undefined"){var flags=HEAPU32[SDL.screen+Runtime.QUANTUM_SIZE* 0>>2];flags=flags|8388608;HEAP32[SDL.screen+Runtime.QUANTUM_SIZE*0>>2]=flags}Bro wser.updateResizeListeners()}),setWindowedCanvasSize:(function(){if(typeof SDL!= "undefined"){var flags=HEAPU32[SDL.screen+Runtime.QUANTUM_SIZE*0>>2];flags=flags &~8388608;HEAP32[SDL.screen+Runtime.QUANTUM_SIZE*0>>2]=flags}Browser.updateResiz eListeners()}),updateCanvasDimensions:(function(canvas,wNative,hNative){if(wNati ve&&hNative){canvas.widthNative=wNative;canvas.heightNative=hNative}else{wNative =canvas.widthNative;hNative=canvas.heightNative}var w=wNative;var h=hNative;if(M odule["forcedAspectRatio"]&&Module["forcedAspectRatio"]>0){if(w/h<Module["forced AspectRatio"]){w=Math.round(h*Module["forcedAspectRatio"])}else{h=Math.round(w/M odule["forcedAspectRatio"])}}if((document["webkitFullScreenElement"]||document[" webkitFullscreenElement"]||document["mozFullScreenElement"]||document["mozFullsc reenElement"]||document["fullScreenElement"]||document["fullscreenElement"]||doc ument["msFullScreenElement"]||document["msFullscreenElement"]||document["webkitC urrentFullScreenElement"])===canvas.parentNode&&typeof screen!="undefined"){var factor=Math.min(screen.width/w,screen.height/h);w=Math.round(w*factor);h=Math.ro und(h*factor)}if(Browser.resizeCanvas){if(canvas.width!=w)canvas.width=w;if(canv as.height!=h)canvas.height=h;if(typeof canvas.style!="undefined"){canvas.style.r emoveProperty("width");canvas.style.removeProperty("height")}}else{if(canvas.wid th!=wNative)canvas.width=wNative;if(canvas.height!=hNative)canvas.height=hNative ;if(typeof canvas.style!="undefined"){if(w!=wNative||h!=hNative){canvas.style.se tProperty("width",w+"px","important");canvas.style.setProperty("height",h+"px"," important")}else{canvas.style.removeProperty("width");canvas.style.removePropert y("height")}}}}),wgetRequests:{},nextWgetRequestHandle:0,getNextWgetRequestHandl e:(function(){var handle=Browser.nextWgetRequestHandle;Browser.nextWgetRequestHa ndle++;return handle})};function _time(ptr){var ret=Date.now()/1e3|0;if(ptr){HEA P32[ptr>>2]=ret}return ret}function _emscripten_memcpy_big(dest,src,num){HEAPU8. set(HEAPU8.subarray(src,src+num),dest);return dest}Module["_memcpy"]=_memcpy;FS. staticInit();__ATINIT__.unshift({func:(function(){if(!Module["noFSInit"]&&!FS.in it.initialized)FS.init()})});__ATMAIN__.push({func:(function(){FS.ignorePermissi ons=false})});__ATEXIT__.push({func:(function(){FS.quit()})});Module["FS_createF older"]=FS.createFolder;Module["FS_createPath"]=FS.createPath;Module["FS_createD ataFile"]=FS.createDataFile;Module["FS_createPreloadedFile"]=FS.createPreloadedF ile;Module["FS_createLazyFile"]=FS.createLazyFile;Module["FS_createLink"]=FS.cre ateLink;Module["FS_createDevice"]=FS.createDevice;___errno_state=Runtime.staticA lloc(4);HEAP32[___errno_state>>2]=0;__ATINIT__.unshift({func:(function(){TTY.ini t()})});__ATEXIT__.push({func:(function(){TTY.shutdown()})});if(ENVIRONMENT_IS_N ODE){var fs=require("fs");var NODEJS_PATH=require("path");NODEFS.staticInit()}__ ATINIT__.push({func:(function(){SOCKFS.root=FS.mount(SOCKFS,{},null)})});Module[ "requestFullScreen"]=function Module_requestFullScreen(lockPointer,resizeCanvas, vrDevice){Browser.requestFullScreen(lockPointer,resizeCanvas,vrDevice)};Module[" requestAnimationFrame"]=function Module_requestAnimationFrame(func){Browser.requ estAnimationFrame(func)};Module["setCanvasSize"]=function Module_setCanvasSize(w idth,height,noUpdates){Browser.setCanvasSize(width,height,noUpdates)};Module["pa useMainLoop"]=function Module_pauseMainLoop(){Browser.mainLoop.pause()};Module[" resumeMainLoop"]=function Module_resumeMainLoop(){Browser.mainLoop.resume()};Mod ule["getUserMedia"]=function Module_getUserMedia(){Browser.getUserMedia()};STACK _BASE=STACKTOP=Runtime.alignMemory(STATICTOP);staticSealed=true;STACK_MAX=STACK_ BASE+TOTAL_STACK;DYNAMIC_BASE=DYNAMICTOP=Runtime.alignMemory(STACK_MAX);assert(D YNAMIC_BASE<TOTAL_MEMORY,"TOTAL_MEMORY not big enough for stack");var cttz_i8=al locate([8,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0, 2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,6,0,1,0,2,0,1,0,3,0,1,0, 2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0, 2,0,1,0,3,0,1,0,2,0,1,0,7,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0, 2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,6,0,1,0, 2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0, 2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0],"i8",ALLOC_DYNAMIC);Module.asmGlobalArg ={"Math":Math,"Int8Array":Int8Array,"Int16Array":Int16Array,"Int32Array":Int32Ar ray,"Uint8Array":Uint8Array,"Uint16Array":Uint16Array,"Uint32Array":Uint32Array, "Float32Array":Float32Array,"Float64Array":Float64Array,"NaN":NaN,"Infinity":Inf inity};Module.asmLibraryArg={"abort":abort,"assert":assert,"_fflush":_fflush,"__ formatString":__formatString,"_printf":_printf,"_send":_send,"_pwrite":_pwrite," _emscripten_set_main_loop":_emscripten_set_main_loop,"_abort":_abort,"_emscripte n_set_main_loop_timing":_emscripten_set_main_loop_timing,"_fwrite":_fwrite,"_sbr k":_sbrk,"_mkport":_mkport,"_fprintf":_fprintf,"__reallyNegative":__reallyNegati ve,"_emscripten_memcpy_big":_emscripten_memcpy_big,"_fileno":_fileno,"_write":_w rite,"_time":_time,"_sysconf":_sysconf,"___errno_location":___errno_location,"__ _setErrNo":___setErrNo,"STACKTOP":STACKTOP,"STACK_MAX":STACK_MAX,"tempDoublePtr" :tempDoublePtr,"ABORT":ABORT,"cttz_i8":cttz_i8};// EMSCRIPTEN_START_ASM
2 var asm=(function(global,env,buffer) {
3 "use asm";var a=new global.Int8Array(buffer);var b=new global.Int16Array(buffer) ;var c=new global.Int32Array(buffer);var d=new global.Uint8Array(buffer);var e=n ew global.Uint16Array(buffer);var f=new global.Uint32Array(buffer);var g=new glo bal.Float32Array(buffer);var h=new global.Float64Array(buffer);var i=env.STACKTO P|0;var j=env.STACK_MAX|0;var k=env.tempDoublePtr|0;var l=env.ABORT|0;var m=env. cttz_i8|0;var n=0;var o=0;var p=0;var q=0;var r=global.NaN,s=global.Infinity;var t=0,u=0,v=0,w=0,x=0.0,y=0,z=0,A=0,B=0.0;var C=0;var D=0;var E=0;var F=0;var G=0 ;var H=0;var I=0;var J=0;var K=0;var L=0;var M=global.Math.floor;var N=global.Ma th.abs;var O=global.Math.sqrt;var P=global.Math.pow;var Q=global.Math.cos;var R= global.Math.sin;var S=global.Math.tan;var T=global.Math.acos;var U=global.Math.a sin;var V=global.Math.atan;var W=global.Math.atan2;var X=global.Math.exp;var Y=g lobal.Math.log;var Z=global.Math.ceil;var _=global.Math.imul;var $=global.Math.m in;var aa=global.Math.clz32;var ba=env.abort;var ca=env.assert;var da=env._fflus h;var ea=env.__formatString;var fa=env._printf;var ga=env._send;var ha=env._pwri te;var ia=env._emscripten_set_main_loop;var ja=env._abort;var ka=env._emscripten _set_main_loop_timing;var la=env._fwrite;var ma=env._sbrk;var na=env._mkport;var oa=env._fprintf;var pa=env.__reallyNegative;var qa=env._emscripten_memcpy_big;v ar ra=env._fileno;var sa=env._write;var ta=env._time;var ua=env._sysconf;var va= env.___errno_location;var wa=env.___setErrNo;var xa=0.0;
4 // EMSCRIPTEN_START_FUNCS
5 function ya(a){a=a|0;var b=0;b=i;i=i+a|0;i=i+15&-16;return b|0}function za(){ret urn i|0}function Aa(a){a=a|0;i=a}function Ba(a,b){a=a|0;b=b|0;if(!n){n=a;o=b}}fu nction Ca(b){b=b|0;a[k>>0]=a[b>>0];a[k+1>>0]=a[b+1>>0];a[k+2>>0]=a[b+2>>0];a[k+3 >>0]=a[b+3>>0]}function Da(b){b=b|0;a[k>>0]=a[b>>0];a[k+1>>0]=a[b+1>>0];a[k+2>>0 ]=a[b+2>>0];a[k+3>>0]=a[b+3>>0];a[k+4>>0]=a[b+4>>0];a[k+5>>0]=a[b+5>>0];a[k+6>>0 ]=a[b+6>>0];a[k+7>>0]=a[b+7>>0]}function Ea(a){a=a|0;C=a}function Fa(){return C| 0}function Ga(a,b){a=a|0;b=b|0;var d=0;a=i;i=i+16|0;b=a;d=b;c[d>>2]=1;c[d+4>>2]= 134217728;d=b+8|0;c[d>>2]=1;c[d+4>>2]=134217728;fa(8,b|0)|0;i=a;return 0}functio n Ha(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r= 0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L= 0,M=0,N=0,O=0,P=0,Q=0;do if(a>>>0<245){if(a>>>0<11)p=16;else p=a+11&-8;a=p>>>3;l =c[6]|0;i=l>>>a;if(i&3){e=(i&1^1)+a|0;f=e<<1;b=64+(f<<2)|0;f=64+(f+2<<2)|0;g=c[f >>2]|0;h=g+8|0;i=c[h>>2]|0;do if((b|0)!=(i|0)){if(i>>>0<(c[10]|0)>>>0)ja();d=i+1 2|0;if((c[d>>2]|0)==(g|0)){c[d>>2]=b;c[f>>2]=i;break}else ja()}else c[6]=l&~(1<< e);while(0);w=e<<3;c[g+4>>2]=w|3;w=g+(w|4)|0;c[w>>2]=c[w>>2]|1;w=h;return w|0}k= c[8]|0;if(p>>>0>k>>>0){if(i){f=2<<a;f=i<<a&(f|0-f);f=(f&0-f)+-1|0;a=f>>>12&16;f= f>>>a;e=f>>>5&8;f=f>>>e;d=f>>>2&4;f=f>>>d;g=f>>>1&2;f=f>>>g;h=f>>>1&1;h=(e|a|d|g |h)+(f>>>h)|0;f=h<<1;g=64+(f<<2)|0;f=64+(f+2<<2)|0;d=c[f>>2]|0;a=d+8|0;e=c[a>>2] |0;do if((g|0)!=(e|0)){if(e>>>0<(c[10]|0)>>>0)ja();i=e+12|0;if((c[i>>2]|0)==(d|0 )){c[i>>2]=g;c[f>>2]=e;m=c[8]|0;break}else ja()}else{c[6]=l&~(1<<h);m=k}while(0) ;w=h<<3;b=w-p|0;c[d+4>>2]=p|3;j=d+p|0;c[d+(p|4)>>2]=b|1;c[d+w>>2]=b;if(m){e=c[11 ]|0;g=m>>>3;i=g<<1;f=64+(i<<2)|0;h=c[6]|0;g=1<<g;if(h&g){h=64+(i+2<<2)|0;i=c[h>> 2]|0;if(i>>>0<(c[10]|0)>>>0)ja();else{n=h;o=i}}else{c[6]=h|g;n=64+(i+2<<2)|0;o=f }c[n>>2]=e;c[o+12>>2]=e;c[e+8>>2]=o;c[e+12>>2]=f}c[8]=b;c[11]=j;w=a;return w|0}a =c[7]|0;if(a){h=(a&0-a)+-1|0;v=h>>>12&16;h=h>>>v;u=h>>>5&8;h=h>>>u;w=h>>>2&4;h=h >>>w;i=h>>>1&2;h=h>>>i;g=h>>>1&1;g=c[328+((u|v|w|i|g)+(h>>>g)<<2)>>2]|0;h=(c[g+4 >>2]&-8)-p|0;i=g;while(1){d=c[i+16>>2]|0;if(!d){d=c[i+20>>2]|0;if(!d){l=h;k=g;br eak}}i=(c[d+4>>2]&-8)-p|0;w=i>>>0<h>>>0;h=w?i:h;i=d;g=w?d:g}a=c[10]|0;if(k>>>0<a >>>0)ja();b=k+p|0;if(k>>>0>=b>>>0)ja();j=c[k+24>>2]|0;g=c[k+12>>2]|0;do if((g|0) ==(k|0)){h=k+20|0;i=c[h>>2]|0;if(!i){h=k+16|0;i=c[h>>2]|0;if(!i){e=0;break}}whil e(1){g=i+20|0;f=c[g>>2]|0;if(f){i=f;h=g;continue}g=i+16|0;f=c[g>>2]|0;if(!f)brea k;else{i=f;h=g}}if(h>>>0<a>>>0)ja();else{c[h>>2]=0;e=i;break}}else{f=c[k+8>>2]|0 ;if(f>>>0<a>>>0)ja();i=f+12|0;if((c[i>>2]|0)!=(k|0))ja();h=g+8|0;if((c[h>>2]|0)= =(k|0)){c[i>>2]=g;c[h>>2]=f;e=g;break}else ja()}while(0);do if(j){i=c[k+28>>2]|0 ;h=328+(i<<2)|0;if((k|0)==(c[h>>2]|0)){c[h>>2]=e;if(!e){c[7]=c[7]&~(1<<i);break} }else{if(j>>>0<(c[10]|0)>>>0)ja();i=j+16|0;if((c[i>>2]|0)==(k|0))c[i>>2]=e;else c[j+20>>2]=e;if(!e)break}h=c[10]|0;if(e>>>0<h>>>0)ja();c[e+24>>2]=j;i=c[k+16>>2] |0;do if(i)if(i>>>0<h>>>0)ja();else{c[e+16>>2]=i;c[i+24>>2]=e;break}while(0);i=c [k+20>>2]|0;if(i)if(i>>>0<(c[10]|0)>>>0)ja();else{c[e+20>>2]=i;c[i+24>>2]=e;brea k}}while(0);if(l>>>0<16){w=l+p|0;c[k+4>>2]=w|3;w=k+(w+4)|0;c[w>>2]=c[w>>2]|1}els e{c[k+4>>2]=p|3;c[k+(p|4)>>2]=l|1;c[k+(l+p)>>2]=l;d=c[8]|0;if(d){e=c[11]|0;g=d>> >3;i=g<<1;f=64+(i<<2)|0;h=c[6]|0;g=1<<g;if(h&g){i=64+(i+2<<2)|0;h=c[i>>2]|0;if(h >>>0<(c[10]|0)>>>0)ja();else{q=i;r=h}}else{c[6]=h|g;q=64+(i+2<<2)|0;r=f}c[q>>2]= e;c[r+12>>2]=e;c[e+8>>2]=r;c[e+12>>2]=f}c[8]=l;c[11]=b}w=k+8|0;return w|0}else r =p}else r=p}else if(a>>>0<=4294967231){a=a+11|0;r=a&-8;k=c[7]|0;if(k){h=0-r|0;a= a>>>8;if(a)if(r>>>0>16777215)d=31;else{p=(a+1048320|0)>>>16&8;q=a<<p;o=(q+520192 |0)>>>16&4;q=q<<o;d=(q+245760|0)>>>16&2;d=14-(o|p|d)+(q<<d>>>15)|0;d=r>>>(d+7|0) &1|d<<1}else d=0;f=c[328+(d<<2)>>2]|0;a:do if(!f){a=0;i=0}else{if((d|0)==31)i=0; else i=25-(d>>>1)|0;l=h;a=0;b=r<<i;i=0;while(1){e=c[f+4>>2]&-8;h=e-r|0;if(h>>>0< l>>>0)if((e|0)==(r|0)){a=f;i=f;break a}else i=f;else h=l;q=c[f+20>>2]|0;f=c[f+(b >>>31<<2)+16>>2]|0;a=(q|0)==0|(q|0)==(f|0)?a:q;if(!f)break;else{l=h;b=b<<1}}}whi le(0);if((a|0)==0&(i|0)==0){a=2<<d;a=k&(a|0-a);if(!a)break;q=(a&0-a)+-1|0;n=q>>> 12&16;q=q>>>n;m=q>>>5&8;q=q>>>m;o=q>>>2&4;q=q>>>o;p=q>>>1&2;q=q>>>p;a=q>>>1&1;a= c[328+((m|n|o|p|a)+(q>>>a)<<2)>>2]|0}if(!a){o=h;p=i}else while(1){q=(c[a+4>>2]&- 8)-r|0;f=q>>>0<h>>>0;h=f?q:h;i=f?a:i;f=c[a+16>>2]|0;if(f){a=f;continue}a=c[a+20> >2]|0;if(!a){o=h;p=i;break}}if((p|0)!=0?o>>>0<((c[8]|0)-r|0)>>>0:0){a=c[10]|0;if (p>>>0<a>>>0)ja();m=p+r|0;if(p>>>0>=m>>>0)ja();j=c[p+24>>2]|0;g=c[p+12>>2]|0;do if((g|0)==(p|0)){h=p+20|0;i=c[h>>2]|0;if(!i){h=p+16|0;i=c[h>>2]|0;if(!i){t=0;bre ak}}while(1){g=i+20|0;f=c[g>>2]|0;if(f){i=f;h=g;continue}g=i+16|0;f=c[g>>2]|0;if (!f)break;else{i=f;h=g}}if(h>>>0<a>>>0)ja();else{c[h>>2]=0;t=i;break}}else{f=c[p +8>>2]|0;if(f>>>0<a>>>0)ja();i=f+12|0;if((c[i>>2]|0)!=(p|0))ja();h=g+8|0;if((c[h >>2]|0)==(p|0)){c[i>>2]=g;c[h>>2]=f;t=g;break}else ja()}while(0);do if(j){i=c[p+ 28>>2]|0;h=328+(i<<2)|0;if((p|0)==(c[h>>2]|0)){c[h>>2]=t;if(!t){c[7]=c[7]&~(1<<i );break}}else{if(j>>>0<(c[10]|0)>>>0)ja();i=j+16|0;if((c[i>>2]|0)==(p|0))c[i>>2] =t;else c[j+20>>2]=t;if(!t)break}h=c[10]|0;if(t>>>0<h>>>0)ja();c[t+24>>2]=j;i=c[ p+16>>2]|0;do if(i)if(i>>>0<h>>>0)ja();else{c[t+16>>2]=i;c[i+24>>2]=t;break}whil e(0);i=c[p+20>>2]|0;if(i)if(i>>>0<(c[10]|0)>>>0)ja();else{c[t+20>>2]=i;c[i+24>>2 ]=t;break}}while(0);b:do if(o>>>0>=16){c[p+4>>2]=r|3;c[p+(r|4)>>2]=o|1;c[p+(o+r) >>2]=o;i=o>>>3;if(o>>>0<256){h=i<<1;f=64+(h<<2)|0;g=c[6]|0;i=1<<i;do if(!(g&i)){ c[6]=g|i;u=64+(h+2<<2)|0;v=f}else{i=64+(h+2<<2)|0;h=c[i>>2]|0;if(h>>>0>=(c[10]|0 )>>>0){u=i;v=h;break}ja()}while(0);c[u>>2]=m;c[v+12>>2]=m;c[p+(r+8)>>2]=v;c[p+(r +12)>>2]=f;break}d=o>>>8;if(d)if(o>>>0>16777215)f=31;else{v=(d+1048320|0)>>>16&8 ;w=d<<v;u=(w+520192|0)>>>16&4;w=w<<u;f=(w+245760|0)>>>16&2;f=14-(u|v|f)+(w<<f>>> 15)|0;f=o>>>(f+7|0)&1|f<<1}else f=0;i=328+(f<<2)|0;c[p+(r+28)>>2]=f;c[p+(r+20)>> 2]=0;c[p+(r+16)>>2]=0;h=c[7]|0;g=1<<f;if(!(h&g)){c[7]=h|g;c[i>>2]=m;c[p+(r+24)>> 2]=i;c[p+(r+12)>>2]=m;c[p+(r+8)>>2]=m;break}d=c[i>>2]|0;if((f|0)==31)b=0;else b= 25-(f>>>1)|0;c:do if((c[d+4>>2]&-8|0)!=(o|0)){h=o<<b;while(1){b=d+(h>>>31<<2)+16 |0;i=c[b>>2]|0;if(!i)break;if((c[i+4>>2]&-8|0)==(o|0)){B=i;break c}else{h=h<<1;d =i}}if(b>>>0<(c[10]|0)>>>0)ja();else{c[b>>2]=m;c[p+(r+24)>>2]=d;c[p+(r+12)>>2]=m ;c[p+(r+8)>>2]=m;break b}}else B=d;while(0);d=B+8|0;b=c[d>>2]|0;w=c[10]|0;if(B>> >0>=w>>>0&b>>>0>=w>>>0){c[b+12>>2]=m;c[d>>2]=m;c[p+(r+8)>>2]=b;c[p+(r+12)>>2]=B; c[p+(r+24)>>2]=0;break}else ja()}else{w=o+r|0;c[p+4>>2]=w|3;w=p+(w+4)|0;c[w>>2]= c[w>>2]|1}while(0);w=p+8|0;return w|0}}}else r=-1;while(0);a=c[8]|0;if(a>>>0>=r> >>0){b=a-r|0;d=c[11]|0;if(b>>>0>15){c[11]=d+r;c[8]=b;c[d+(r+4)>>2]=b|1;c[d+a>>2] =b;c[d+4>>2]=r|3}else{c[8]=0;c[11]=0;c[d+4>>2]=a|3;w=d+(a+4)|0;c[w>>2]=c[w>>2]|1 }w=d+8|0;return w|0}a=c[9]|0;if(a>>>0>r>>>0){v=a-r|0;c[9]=v;w=c[12]|0;c[12]=w+r; c[w+(r+4)>>2]=v|1;c[w+4>>2]=r|3;w=w+8|0;return w|0}do if(!(c[124]|0)){a=ua(30)|0 ;if(!(a+-1&a)){c[126]=a;c[125]=a;c[127]=-1;c[128]=-1;c[129]=0;c[117]=0;c[124]=(t a(0)|0)&-16^1431655768;break}else ja()}while(0);l=r+48|0;b=c[126]|0;k=r+47|0;d=b +k|0;b=0-b|0;m=d&b;if(m>>>0<=r>>>0){w=0;return w|0}a=c[116]|0;if((a|0)!=0?(u=c[1 14]|0,v=u+m|0,v>>>0<=u>>>0|v>>>0>a>>>0):0){w=0;return w|0}d:do if(!(c[117]&4)){a =c[12]|0;e:do if(a){f=472|0;while(1){i=c[f>>2]|0;if(i>>>0<=a>>>0?(s=f+4|0,(i+(c[ s>>2]|0)|0)>>>0>a>>>0):0){e=f;h=s;a=f;break}f=c[f+8>>2]|0;if(!f){G=181;break e}} if(a){a=d-(c[9]|0)&b;if(a>>>0<2147483647){i=ma(a|0)|0;if((i|0)==((c[e>>2]|0)+(c[ h>>2]|0)|0))G=190;else G=191}else a=0}else G=181}else G=181;while(0);do if((G|0) ==181){i=ma(0)|0;if((i|0)!=(-1|0)){a=i;h=c[125]|0;f=h+-1|0;if(!(f&a))a=m;else a= m-a+(f+a&0-h)|0;h=c[114]|0;f=h+a|0;if(a>>>0>r>>>0&a>>>0<2147483647){v=c[116]|0;i f((v|0)!=0?f>>>0<=h>>>0|f>>>0>v>>>0:0){a=0;break}h=ma(a|0)|0;if((h|0)==(i|0))G=1 90;else{i=h;G=191}}else a=0}else a=0}while(0);f:do if((G|0)==190){if((i|0)!=(-1| 0)){x=i;G=201;break d}}else if((G|0)==191){h=0-a|0;do if((i|0)!=(-1|0)&a>>>0<214 7483647&l>>>0>a>>>0?(w=c[126]|0,w=k-a+w&0-w,w>>>0<2147483647):0)if((ma(w|0)|0)== (-1|0)){ma(h|0)|0;a=0;break f}else{a=w+a|0;break}while(0);if((i|0)==(-1|0))a=0;e lse{x=i;G=201;break d}}while(0);c[117]=c[117]|4;G=198}else{a=0;G=198}while(0);if ((((G|0)==198?m>>>0<2147483647:0)?(x=ma(m|0)|0,y=ma(0)|0,(x|0)!=(-1|0)&(y|0)!=(- 1|0)&x>>>0<y>>>0):0)?(z=y-x|0,A=z>>>0>(r+40|0)>>>0,A):0){a=A?z:a;G=201}if((G|0)= =201){i=(c[114]|0)+a|0;c[114]=i;if(i>>>0>(c[115]|0)>>>0)c[115]=i;l=c[12]|0;g:do if(l){e=472|0;do{i=c[e>>2]|0;h=e+4|0;f=c[h>>2]|0;if((x|0)==(i+f|0)){C=i;D=h;E=f; F=e;G=213;break}e=c[e+8>>2]|0}while((e|0)!=0);if(((G|0)==213?(c[F+12>>2]&8|0)==0 :0)?l>>>0>=C>>>0&l>>>0<x>>>0:0){c[D>>2]=E+a;b=(c[9]|0)+a|0;d=l+8|0;if(!(d&7))d=0 ;else d=0-d&7;w=b-d|0;c[12]=l+d;c[9]=w;c[l+(d+4)>>2]=w|1;c[l+(b+4)>>2]=40;c[13]= c[128];break}i=c[10]|0;if(x>>>0<i>>>0){c[10]=x;k=x}else k=i;i=x+a|0;h=472|0;do{i f((c[h>>2]|0)==(i|0)){H=h;I=h;G=223;break}h=c[h+8>>2]|0}while((h|0)!=0);if((G|0) ==223?(c[I+12>>2]&8|0)==0:0){c[H>>2]=x;i=I+4|0;c[i>>2]=(c[i>>2]|0)+a;i=x+8|0;if( !(i&7))p=0;else p=0-i&7;i=x+(a+8)|0;if(!(i&7))d=0;else d=0-i&7;i=x+(d+a)|0;o=p+r |0;n=x+o|0;m=i-(x+p)-r|0;c[x+(p+4)>>2]=r|3;h:do if((i|0)!=(l|0)){if((i|0)==(c[11 ]|0)){w=(c[8]|0)+m|0;c[8]=w;c[11]=n;c[x+(o+4)>>2]=w|1;c[x+(w+o)>>2]=w;break}l=a+ 4|0;j=c[x+(l+d)>>2]|0;if((j&3|0)==1){b=j&-8;f=j>>>3;i:do if(j>>>0>=256){e=c[x+(( d|24)+a)>>2]|0;g=c[x+(a+12+d)>>2]|0;do if((g|0)==(i|0)){g=d|16;h=x+(l+g)|0;j=c[h >>2]|0;if(!j){h=x+(g+a)|0;j=c[h>>2]|0;if(!j){N=0;break}}while(1){g=j+20|0;f=c[g> >2]|0;if(f){j=f;h=g;continue}g=j+16|0;f=c[g>>2]|0;if(!f)break;else{j=f;h=g}}if(h >>>0<k>>>0)ja();else{c[h>>2]=0;N=j;break}}else{f=c[x+((d|8)+a)>>2]|0;if(f>>>0<k> >>0)ja();j=f+12|0;if((c[j>>2]|0)!=(i|0))ja();h=g+8|0;if((c[h>>2]|0)==(i|0)){c[j> >2]=g;c[h>>2]=f;N=g;break}else ja()}while(0);if(!e)break;j=c[x+(a+28+d)>>2]|0;h= 328+(j<<2)|0;do if((i|0)!=(c[h>>2]|0)){if(e>>>0<(c[10]|0)>>>0)ja();j=e+16|0;if(( c[j>>2]|0)==(i|0))c[j>>2]=N;else c[e+20>>2]=N;if(!N)break i}else{c[h>>2]=N;if(N) break;c[7]=c[7]&~(1<<j);break i}while(0);h=c[10]|0;if(N>>>0<h>>>0)ja();c[N+24>>2 ]=e;j=d|16;i=c[x+(j+a)>>2]|0;do if(i)if(i>>>0<h>>>0)ja();else{c[N+16>>2]=i;c[i+2 4>>2]=N;break}while(0);i=c[x+(l+j)>>2]|0;if(!i)break;if(i>>>0<(c[10]|0)>>>0)ja() ;else{c[N+20>>2]=i;c[i+24>>2]=N;break}}else{h=c[x+((d|8)+a)>>2]|0;g=c[x+(a+12+d) >>2]|0;j=64+(f<<1<<2)|0;do if((h|0)!=(j|0)){if(h>>>0<k>>>0)ja();if((c[h+12>>2]|0 )==(i|0))break;ja()}while(0);if((g|0)==(h|0)){c[6]=c[6]&~(1<<f);break}do if((g|0 )==(j|0))J=g+8|0;else{if(g>>>0<k>>>0)ja();j=g+8|0;if((c[j>>2]|0)==(i|0)){J=j;bre ak}ja()}while(0);c[h+12>>2]=g;c[J>>2]=h}while(0);i=x+((b|d)+a)|0;j=b+m|0}else j= m;i=i+4|0;c[i>>2]=c[i>>2]&-2;c[x+(o+4)>>2]=j|1;c[x+(j+o)>>2]=j;i=j>>>3;if(j>>>0< 256){h=i<<1;f=64+(h<<2)|0;g=c[6]|0;i=1<<i;do if(!(g&i)){c[6]=g|i;O=64+(h+2<<2)|0 ;P=f}else{i=64+(h+2<<2)|0;h=c[i>>2]|0;if(h>>>0>=(c[10]|0)>>>0){O=i;P=h;break}ja( )}while(0);c[O>>2]=n;c[P+12>>2]=n;c[x+(o+8)>>2]=P;c[x+(o+12)>>2]=f;break}d=j>>>8 ;do if(!d)f=0;else{if(j>>>0>16777215){f=31;break}v=(d+1048320|0)>>>16&8;w=d<<v;u =(w+520192|0)>>>16&4;w=w<<u;f=(w+245760|0)>>>16&2;f=14-(u|v|f)+(w<<f>>>15)|0;f=j >>>(f+7|0)&1|f<<1}while(0);i=328+(f<<2)|0;c[x+(o+28)>>2]=f;c[x+(o+20)>>2]=0;c[x+ (o+16)>>2]=0;h=c[7]|0;g=1<<f;if(!(h&g)){c[7]=h|g;c[i>>2]=n;c[x+(o+24)>>2]=i;c[x+ (o+12)>>2]=n;c[x+(o+8)>>2]=n;break}d=c[i>>2]|0;if((f|0)==31)i=0;else i=25-(f>>>1 )|0;j:do if((c[d+4>>2]&-8|0)!=(j|0)){h=j<<i;while(1){b=d+(h>>>31<<2)+16|0;i=c[b> >2]|0;if(!i)break;if((c[i+4>>2]&-8|0)==(j|0)){Q=i;break j}else{h=h<<1;d=i}}if(b> >>0<(c[10]|0)>>>0)ja();else{c[b>>2]=n;c[x+(o+24)>>2]=d;c[x+(o+12)>>2]=n;c[x+(o+8 )>>2]=n;break h}}else Q=d;while(0);d=Q+8|0;b=c[d>>2]|0;w=c[10]|0;if(Q>>>0>=w>>>0 &b>>>0>=w>>>0){c[b+12>>2]=n;c[d>>2]=n;c[x+(o+8)>>2]=b;c[x+(o+12)>>2]=Q;c[x+(o+24 )>>2]=0;break}else ja()}else{w=(c[9]|0)+m|0;c[9]=w;c[12]=n;c[x+(o+4)>>2]=w|1}whi le(0);w=x+(p|8)|0;return w|0}h=472|0;while(1){i=c[h>>2]|0;if(i>>>0<=l>>>0?(g=c[h +4>>2]|0,j=i+g|0,j>>>0>l>>>0):0)break;h=c[h+8>>2]|0}h=i+(g+-39)|0;if(!(h&7))h=0; else h=0-h&7;g=i+(g+-47+h)|0;g=g>>>0<(l+16|0)>>>0?l:g;h=g+8|0;i=x+8|0;if(!(i&7)) i=0;else i=0-i&7;w=a+-40-i|0;c[12]=x+i;c[9]=w;c[x+(i+4)>>2]=w|1;c[x+(a+-36)>>2]= 40;c[13]=c[128];c[g+4>>2]=27;c[h+0>>2]=c[118];c[h+4>>2]=c[119];c[h+8>>2]=c[120]; c[h+12>>2]=c[121];c[118]=x;c[119]=a;c[121]=0;c[120]=h;i=g+28|0;c[i>>2]=7;if((g+3 2|0)>>>0<j>>>0)do{w=i;i=i+4|0;c[i>>2]=7}while((w+8|0)>>>0<j>>>0);if((g|0)!=(l|0) ){j=g-l|0;i=l+(j+4)|0;c[i>>2]=c[i>>2]&-2;c[l+4>>2]=j|1;c[l+j>>2]=j;i=j>>>3;if(j> >>0<256){h=i<<1;f=64+(h<<2)|0;g=c[6]|0;i=1<<i;do if(!(g&i)){c[6]=g|i;K=64+(h+2<< 2)|0;L=f}else{d=64+(h+2<<2)|0;b=c[d>>2]|0;if(b>>>0>=(c[10]|0)>>>0){K=d;L=b;break }ja()}while(0);c[K>>2]=l;c[L+12>>2]=l;c[l+8>>2]=L;c[l+12>>2]=f;break}d=j>>>8;if( d)if(j>>>0>16777215)i=31;else{v=(d+1048320|0)>>>16&8;w=d<<v;u=(w+520192|0)>>>16& 4;w=w<<u;i=(w+245760|0)>>>16&2;i=14-(u|v|i)+(w<<i>>>15)|0;i=j>>>(i+7|0)&1|i<<1}e lse i=0;d=328+(i<<2)|0;c[l+28>>2]=i;c[l+20>>2]=0;c[l+16>>2]=0;b=c[7]|0;e=1<<i;if (!(b&e)){c[7]=b|e;c[d>>2]=l;c[l+24>>2]=d;c[l+12>>2]=l;c[l+8>>2]=l;break}d=c[d>>2 ]|0;if((i|0)==31)b=0;else b=25-(i>>>1)|0;k:do if((c[d+4>>2]&-8|0)!=(j|0)){i=j<<b ;while(1){b=d+(i>>>31<<2)+16|0;e=c[b>>2]|0;if(!e)break;if((c[e+4>>2]&-8|0)==(j|0 )){M=e;break k}else{i=i<<1;d=e}}if(b>>>0<(c[10]|0)>>>0)ja();else{c[b>>2]=l;c[l+2 4>>2]=d;c[l+12>>2]=l;c[l+8>>2]=l;break g}}else M=d;while(0);d=M+8|0;b=c[d>>2]|0; w=c[10]|0;if(M>>>0>=w>>>0&b>>>0>=w>>>0){c[b+12>>2]=l;c[d>>2]=l;c[l+8>>2]=b;c[l+1 2>>2]=M;c[l+24>>2]=0;break}else ja()}}else{w=c[10]|0;if((w|0)==0|x>>>0<w>>>0)c[1 0]=x;c[118]=x;c[119]=a;c[121]=0;c[15]=c[124];c[14]=-1;d=0;do{w=d<<1;v=64+(w<<2)| 0;c[64+(w+3<<2)>>2]=v;c[64+(w+2<<2)>>2]=v;d=d+1|0}while((d|0)!=32);d=x+8|0;if(!( d&7))d=0;else d=0-d&7;w=a+-40-d|0;c[12]=x+d;c[9]=w;c[x+(d+4)>>2]=w|1;c[x+(a+-36) >>2]=40;c[13]=c[128]}while(0);b=c[9]|0;if(b>>>0>r>>>0){v=b-r|0;c[9]=v;w=c[12]|0; c[12]=w+r;c[w+(r+4)>>2]=v|1;c[w+4>>2]=r|3;w=w+8|0;return w|0}}c[(va()|0)>>2]=12; w=0;return w|0}function Ia(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0, m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;if(!a)return;g=a+-8|0;h=c[10]|0;if(g>>>0<h>> >0)ja();f=c[a+-4>>2]|0;e=f&3;if((e|0)==1)ja();o=f&-8;q=a+(o+-8)|0;do if(!(f&1)){ g=c[g>>2]|0;if(!e)return;i=-8-g|0;l=a+i|0;m=g+o|0;if(l>>>0<h>>>0)ja();if((l|0)== (c[11]|0)){g=a+(o+-4)|0;f=c[g>>2]|0;if((f&3|0)!=3){u=l;k=m;break}c[8]=m;c[g>>2]= f&-2;c[a+(i+4)>>2]=m|1;c[q>>2]=m;return}d=g>>>3;if(g>>>0<256){e=c[a+(i+8)>>2]|0; f=c[a+(i+12)>>2]|0;g=64+(d<<1<<2)|0;if((e|0)!=(g|0)){if(e>>>0<h>>>0)ja();if((c[e +12>>2]|0)!=(l|0))ja()}if((f|0)==(e|0)){c[6]=c[6]&~(1<<d);u=l;k=m;break}if((f|0) !=(g|0)){if(f>>>0<h>>>0)ja();g=f+8|0;if((c[g>>2]|0)==(l|0))b=g;else ja()}else b= f+8|0;c[e+12>>2]=f;c[b>>2]=e;u=l;k=m;break}b=c[a+(i+24)>>2]|0;e=c[a+(i+12)>>2]|0 ;do if((e|0)==(l|0)){f=a+(i+20)|0;g=c[f>>2]|0;if(!g){f=a+(i+16)|0;g=c[f>>2]|0;if (!g){j=0;break}}while(1){e=g+20|0;d=c[e>>2]|0;if(d){g=d;f=e;continue}e=g+16|0;d= c[e>>2]|0;if(!d)break;else{g=d;f=e}}if(f>>>0<h>>>0)ja();else{c[f>>2]=0;j=g;break }}else{d=c[a+(i+8)>>2]|0;if(d>>>0<h>>>0)ja();g=d+12|0;if((c[g>>2]|0)!=(l|0))ja() ;f=e+8|0;if((c[f>>2]|0)==(l|0)){c[g>>2]=e;c[f>>2]=d;j=e;break}else ja()}while(0) ;if(b){g=c[a+(i+28)>>2]|0;f=328+(g<<2)|0;if((l|0)==(c[f>>2]|0)){c[f>>2]=j;if(!j) {c[7]=c[7]&~(1<<g);u=l;k=m;break}}else{if(b>>>0<(c[10]|0)>>>0)ja();g=b+16|0;if(( c[g>>2]|0)==(l|0))c[g>>2]=j;else c[b+20>>2]=j;if(!j){u=l;k=m;break}}f=c[10]|0;if (j>>>0<f>>>0)ja();c[j+24>>2]=b;g=c[a+(i+16)>>2]|0;do if(g)if(g>>>0<f>>>0)ja();el se{c[j+16>>2]=g;c[g+24>>2]=j;break}while(0);g=c[a+(i+20)>>2]|0;if(g)if(g>>>0<(c[ 10]|0)>>>0)ja();else{c[j+20>>2]=g;c[g+24>>2]=j;u=l;k=m;break}else{u=l;k=m}}else{ u=l;k=m}}else{u=g;k=o}while(0);if(u>>>0>=q>>>0)ja();g=a+(o+-4)|0;f=c[g>>2]|0;if( !(f&1))ja();if(!(f&2)){if((q|0)==(c[12]|0)){l=(c[9]|0)+k|0;c[9]=l;c[12]=u;c[u+4> >2]=l|1;if((u|0)!=(c[11]|0))return;c[11]=0;c[8]=0;return}if((q|0)==(c[11]|0)){l= (c[8]|0)+k|0;c[8]=l;c[11]=u;c[u+4>>2]=l|1;c[u+l>>2]=l;return}h=(f&-8)+k|0;b=f>>> 3;do if(f>>>0>=256){b=c[a+(o+16)>>2]|0;g=c[a+(o|4)>>2]|0;do if((g|0)==(q|0)){f=a +(o+12)|0;g=c[f>>2]|0;if(!g){f=a+(o+8)|0;g=c[f>>2]|0;if(!g){p=0;break}}while(1){ e=g+20|0;d=c[e>>2]|0;if(d){g=d;f=e;continue}e=g+16|0;d=c[e>>2]|0;if(!d)break;els e{g=d;f=e}}if(f>>>0<(c[10]|0)>>>0)ja();else{c[f>>2]=0;p=g;break}}else{f=c[a+o>>2 ]|0;if(f>>>0<(c[10]|0)>>>0)ja();e=f+12|0;if((c[e>>2]|0)!=(q|0))ja();d=g+8|0;if(( c[d>>2]|0)==(q|0)){c[e>>2]=g;c[d>>2]=f;p=g;break}else ja()}while(0);if(b){g=c[a+ (o+20)>>2]|0;f=328+(g<<2)|0;if((q|0)==(c[f>>2]|0)){c[f>>2]=p;if(!p){c[7]=c[7]&~( 1<<g);break}}else{if(b>>>0<(c[10]|0)>>>0)ja();g=b+16|0;if((c[g>>2]|0)==(q|0))c[g >>2]=p;else c[b+20>>2]=p;if(!p)break}g=c[10]|0;if(p>>>0<g>>>0)ja();c[p+24>>2]=b; f=c[a+(o+8)>>2]|0;do if(f)if(f>>>0<g>>>0)ja();else{c[p+16>>2]=f;c[f+24>>2]=p;bre ak}while(0);d=c[a+(o+12)>>2]|0;if(d)if(d>>>0<(c[10]|0)>>>0)ja();else{c[p+20>>2]= d;c[d+24>>2]=p;break}}}else{d=c[a+o>>2]|0;e=c[a+(o|4)>>2]|0;g=64+(b<<1<<2)|0;if( (d|0)!=(g|0)){if(d>>>0<(c[10]|0)>>>0)ja();if((c[d+12>>2]|0)!=(q|0))ja()}if((e|0) ==(d|0)){c[6]=c[6]&~(1<<b);break}if((e|0)!=(g|0)){if(e>>>0<(c[10]|0)>>>0)ja();f= e+8|0;if((c[f>>2]|0)==(q|0))n=f;else ja()}else n=e+8|0;c[d+12>>2]=e;c[n>>2]=d}wh ile(0);c[u+4>>2]=h|1;c[u+h>>2]=h;if((u|0)==(c[11]|0)){c[8]=h;return}else g=h}els e{c[g>>2]=f&-2;c[u+4>>2]=k|1;c[u+k>>2]=k;g=k}f=g>>>3;if(g>>>0<256){e=f<<1;g=64+( e<<2)|0;b=c[6]|0;d=1<<f;if(b&d){d=64+(e+2<<2)|0;b=c[d>>2]|0;if(b>>>0<(c[10]|0)>> >0)ja();else{r=d;s=b}}else{c[6]=b|d;r=64+(e+2<<2)|0;s=g}c[r>>2]=u;c[s+12>>2]=u;c [u+8>>2]=s;c[u+12>>2]=g;return}b=g>>>8;if(b)if(g>>>0>16777215)f=31;else{k=(b+104 8320|0)>>>16&8;l=b<<k;j=(l+520192|0)>>>16&4;l=l<<j;f=(l+245760|0)>>>16&2;f=14-(j |k|f)+(l<<f>>>15)|0;f=g>>>(f+7|0)&1|f<<1}else f=0;d=328+(f<<2)|0;c[u+28>>2]=f;c[ u+20>>2]=0;c[u+16>>2]=0;b=c[7]|0;e=1<<f;a:do if(b&e){d=c[d>>2]|0;if((f|0)==31)b= 0;else b=25-(f>>>1)|0;b:do if((c[d+4>>2]&-8|0)!=(g|0)){f=g<<b;while(1){b=d+(f>>> 31<<2)+16|0;e=c[b>>2]|0;if(!e)break;if((c[e+4>>2]&-8|0)==(g|0)){t=e;break b}else {f=f<<1;d=e}}if(b>>>0<(c[10]|0)>>>0)ja();else{c[b>>2]=u;c[u+24>>2]=d;c[u+12>>2]= u;c[u+8>>2]=u;break a}}else t=d;while(0);b=t+8|0;d=c[b>>2]|0;l=c[10]|0;if(t>>>0> =l>>>0&d>>>0>=l>>>0){c[d+12>>2]=u;c[b>>2]=u;c[u+8>>2]=d;c[u+12>>2]=t;c[u+24>>2]= 0;break}else ja()}else{c[7]=b|e;c[d>>2]=u;c[u+24>>2]=d;c[u+12>>2]=u;c[u+8>>2]=u} while(0);l=(c[14]|0)+-1|0;c[14]=l;if(!l)b=480|0;else return;while(1){b=c[b>>2]|0 ;if(!b)break;else b=b+8|0}c[14]=-1;return}function Ja(){}function Ka(b){b=b|0;va r c=0;c=b;while(a[c>>0]|0)c=c+1|0;return c-b|0}function La(b,d,e){b=b|0;d=d|0;e= e|0;var f=0,g=0,h=0,i=0;f=b+e|0;if((e|0)>=20){d=d&255;h=b&3;i=d|d<<8|d<<16|d<<24 ;g=f&~3;if(h){h=b+4-h|0;while((b|0)<(h|0)){a[b>>0]=d;b=b+1|0}}while((b|0)<(g|0)) {c[b>>2]=i;b=b+4|0}}while((b|0)<(f|0)){a[b>>0]=d;b=b+1|0}return b-e|0}function M a(b,d,e){b=b|0;d=d|0;e=e|0;var f=0;if((e|0)>=4096)return qa(b|0,d|0,e|0)|0;f=b|0 ;if((b&3)==(d&3)){while(b&3){if(!e)return f|0;a[b>>0]=a[d>>0]|0;b=b+1|0;d=d+1|0; e=e-1|0}while((e|0)>=4){c[b>>2]=c[d>>2];b=b+4|0;d=d+4|0;e=e-4|0}}while((e|0)>0){ a[b>>0]=a[d>>0]|0;b=b+1|0;d=d+1|0;e=e-1|0}return f|0}function Na(a,b,c,d){a=a|0; b=b|0;c=c|0;d=d|0;c=a+c>>>0;return (C=b+d+(c>>>0<a>>>0|0)>>>0,c|0)|0}function Oa (a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;b=b-d-(c>>>0>a>>>0|0)>>>0;return (C=b,a-c>>>0| 0)|0}function Pa(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b<<c|(a&(1<<c)-1<<32-c) >>>32-c;return a<<c}C=a<<c-32;return 0}function Qa(a,b,c){a=a|0;b=b|0;c=c|0;if(( c|0)<32){C=b>>>c;return a>>>c|(b&(1<<c)-1)<<32-c}C=0;return b>>>c-32|0}function Ra(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b>>c;return a>>>c|(b&(1<<c)-1)<<32-c} C=(b|0)<0?-1:0;return b>>c-32|0}function Sa(b){b=b|0;var c=0;c=a[m+(b&255)>>0]|0 ;if((c|0)<8)return c|0;c=a[m+(b>>8&255)>>0]|0;if((c|0)<8)return c+8|0;c=a[m+(b>> 16&255)>>0]|0;if((c|0)<8)return c+16|0;return (a[m+(b>>>24)>>0]|0)+24|0}function Ta(a,b){a=a|0;b=b|0;var c=0,d=0,e=0,f=0;f=a&65535;d=b&65535;c=_(d,f)|0;e=a>>>16 ;d=(c>>>16)+(_(d,e)|0)|0;b=b>>>16;a=_(b,f)|0;return (C=(d>>>16)+(_(b,e)|0)+(((d& 65535)+a|0)>>>16)|0,d+a<<16|c&65535|0)|0}function Ua(a,b,c,d){a=a|0;b=b|0;c=c|0; d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0;j=b>>31|((b|0)<0?-1:0)<<1;i=((b|0)<0?-1:0)>>31 |((b|0)<0?-1:0)<<1;f=d>>31|((d|0)<0?-1:0)<<1;e=((d|0)<0?-1:0)>>31|((d|0)<0?-1:0) <<1;h=Oa(j^a,i^b,j,i)|0;g=C;b=f^j;a=e^i;a=Oa((Za(h,g,Oa(f^c,e^d,f,e)|0,C,0)|0)^b ,C^a,b,a)|0;return a|0}function Va(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0, h=0,j=0,k=0,l=0;f=i;i=i+8|0;j=f|0;h=b>>31|((b|0)<0?-1:0)<<1;g=((b|0)<0?-1:0)>>31 |((b|0)<0?-1:0)<<1;l=e>>31|((e|0)<0?-1:0)<<1;k=((e|0)<0?-1:0)>>31|((e|0)<0?-1:0) <<1;b=Oa(h^a,g^b,h,g)|0;a=C;Za(b,a,Oa(l^d,k^e,l,k)|0,C,j)|0;a=Oa(c[j>>2]^h,c[j+4 >>2]^g,h,g)|0;b=C;i=f;return (C=b,a)|0}function Wa(a,b,c,d){a=a|0;b=b|0;c=c|0;d= d|0;var e=0,f=0;e=a;f=c;a=Ta(e,f)|0;c=C;return (C=(_(b,f)|0)+(_(d,e)|0)+c|c&0,a| 0|0)|0}function Xa(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;a=Za(a,b,c,d,0)|0;return a|0 }function Ya(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0;g=i;i=i+8|0;f=g|0;Za(a ,b,d,e,f)|0;i=g;return (C=c[f+4>>2]|0,c[f>>2]|0)|0}function Za(a,b,d,e,f){a=a|0; b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0;n=a;l=b;m=l; k=d;o=e;i=o;if(!m){g=(f|0)!=0;if(!i){if(g){c[f>>2]=(n>>>0)%(k>>>0);c[f+4>>2]=0}l =0;m=(n>>>0)/(k>>>0)>>>0;return (C=l,m)|0}else{if(!g){l=0;m=0;return (C=l,m)|0}c [f>>2]=a|0;c[f+4>>2]=b&0;l=0;m=0;return (C=l,m)|0}}j=(i|0)==0;do if(k){if(!j){h= (aa(i|0)|0)-(aa(m|0)|0)|0;if(h>>>0<=31){g=h+1|0;l=31-h|0;k=h-31>>31;i=g;j=n>>>(g >>>0)&k|m<<l;k=m>>>(g>>>0)&k;g=0;h=n<<l;break}if(!f){l=0;m=0;return (C=l,m)|0}c[ f>>2]=a|0;c[f+4>>2]=l|b&0;l=0;m=0;return (C=l,m)|0}j=k-1|0;if(j&k){h=(aa(k|0)|0) +33-(aa(m|0)|0)|0;p=64-h|0;l=32-h|0;a=l>>31;b=h-32|0;k=b>>31;i=h;j=l-1>>31&m>>>( b>>>0)|(m<<l|n>>>(h>>>0))&k;k=k&m>>>(h>>>0);g=n<<p&a;h=(m<<p|n>>>(b>>>0))&a|n<<l &h-33>>31;break}if(f){c[f>>2]=j&n;c[f+4>>2]=0}if((k|0)==1){l=l|b&0;m=a|0|0;retur n (C=l,m)|0}else{a=Sa(k|0)|0;l=m>>>(a>>>0)|0;m=m<<32-a|n>>>(a>>>0)|0;return (C=l ,m)|0}}else{if(j){if(f){c[f>>2]=(m>>>0)%(k>>>0);c[f+4>>2]=0}l=0;m=(m>>>0)/(k>>>0 )>>>0;return (C=l,m)|0}if(!n){if(f){c[f>>2]=0;c[f+4>>2]=(m>>>0)%(i>>>0)}l=0;m=(m >>>0)/(i>>>0)>>>0;return (C=l,m)|0}j=i-1|0;if(!(j&i)){if(f){c[f>>2]=a|0;c[f+4>>2 ]=j&m|b&0}l=0;m=m>>>((Sa(i|0)|0)>>>0);return (C=l,m)|0}h=(aa(i|0)|0)-(aa(m|0)|0) |0;if(h>>>0<=30){k=h+1|0;h=31-h|0;i=k;j=m<<h|n>>>(k>>>0);k=m>>>(k>>>0);g=0;h=n<< h;break}if(!f){l=0;m=0;return (C=l,m)|0}c[f>>2]=a|0;c[f+4>>2]=l|b&0;l=0;m=0;retu rn (C=l,m)|0}while(0);if(!i){l=h;i=0;h=0}else{m=d|0|0;l=o|e&0;b=Na(m,l,-1,-1)|0; a=C;d=h;h=0;do{p=d;d=g>>>31|d<<1;g=h|g<<1;p=j<<1|p>>>31|0;o=j>>>31|k<<1|0;Oa(b,a ,p,o)|0;n=C;e=n>>31|((n|0)<0?-1:0)<<1;h=e&1;j=Oa(p,o,e&m,(((n|0)<0?-1:0)>>31|((n |0)<0?-1:0)<<1)&l)|0;k=C;i=i-1|0}while((i|0)!=0);l=d;i=0}d=0;if(f){c[f>>2]=j;c[f +4>>2]=k}l=(g|0)>>>31|(l|d)<<1|(d<<1|g>>>31)&0|i;m=(g<<1|0>>>31)&-2|h;return (C= l,m)|0}
6
7 // EMSCRIPTEN_END_FUNCS
8 return{_strlen:Ka,_free:Ia,_main:Ga,_memset:La,_malloc:Ha,_memcpy:Ma,runPostSets :Ja,stackAlloc:ya,stackSave:za,stackRestore:Aa,setThrew:Ba,setTempRet0:Ea,getTem pRet0:Fa}})
9
10
11 // EMSCRIPTEN_END_ASM
12 (Module.asmGlobalArg,Module.asmLibraryArg,buffer);var _strlen=Module["_strlen"]= asm["_strlen"];var _free=Module["_free"]=asm["_free"];var _main=Module["_main"]= asm["_main"];var _memset=Module["_memset"]=asm["_memset"];var _malloc=Module["_m alloc"]=asm["_malloc"];var _memcpy=Module["_memcpy"]=asm["_memcpy"];var runPostS ets=Module["runPostSets"]=asm["runPostSets"];Runtime.stackAlloc=asm["stackAlloc" ];Runtime.stackSave=asm["stackSave"];Runtime.stackRestore=asm["stackRestore"];Ru ntime.setTempRet0=asm["setTempRet0"];Runtime.getTempRet0=asm["getTempRet0"];var i64Math=(function(){var goog={math:{}};goog.math.Long=(function(low,high){this.l ow_=low|0;this.high_=high|0});goog.math.Long.IntCache_={};goog.math.Long.fromInt =(function(value){if(-128<=value&&value<128){var cachedObj=goog.math.Long.IntCac he_[value];if(cachedObj){return cachedObj}}var obj=new goog.math.Long(value|0,va lue<0?-1:0);if(-128<=value&&value<128){goog.math.Long.IntCache_[value]=obj}retur n obj});goog.math.Long.fromNumber=(function(value){if(isNaN(value)||!isFinite(va lue)){return goog.math.Long.ZERO}else if(value<=-goog.math.Long.TWO_PWR_63_DBL_) {return goog.math.Long.MIN_VALUE}else if(value+1>=goog.math.Long.TWO_PWR_63_DBL_ ){return goog.math.Long.MAX_VALUE}else if(value<0){return goog.math.Long.fromNum ber(-value).negate()}else{return new goog.math.Long(value%goog.math.Long.TWO_PWR _32_DBL_|0,value/goog.math.Long.TWO_PWR_32_DBL_|0)}});goog.math.Long.fromBits=(f unction(lowBits,highBits){return new goog.math.Long(lowBits,highBits)});goog.mat h.Long.fromString=(function(str,opt_radix){if(str.length==0){throw Error("number format error: empty string")}var radix=opt_radix||10;if(radix<2||36<radix){thro w Error("radix out of range: "+radix)}if(str.charAt(0)=="-"){return goog.math.Lo ng.fromString(str.substring(1),radix).negate()}else if(str.indexOf("-")>=0){thro w Error('number format error: interior "-" character: '+str)}var radixToPower=go og.math.Long.fromNumber(Math.pow(radix,8));var result=goog.math.Long.ZERO;for(va r i=0;i<str.length;i+=8){var size=Math.min(8,str.length-i);var value=parseInt(st r.substring(i,i+size),radix);if(size<8){var power=goog.math.Long.fromNumber(Math .pow(radix,size));result=result.multiply(power).add(goog.math.Long.fromNumber(va lue))}else{result=result.multiply(radixToPower);result=result.add(goog.math.Long .fromNumber(value))}}return result});goog.math.Long.TWO_PWR_16_DBL_=1<<16;goog.m ath.Long.TWO_PWR_24_DBL_=1<<24;goog.math.Long.TWO_PWR_32_DBL_=goog.math.Long.TWO _PWR_16_DBL_*goog.math.Long.TWO_PWR_16_DBL_;goog.math.Long.TWO_PWR_31_DBL_=goog. math.Long.TWO_PWR_32_DBL_/2;goog.math.Long.TWO_PWR_48_DBL_=goog.math.Long.TWO_PW R_32_DBL_*goog.math.Long.TWO_PWR_16_DBL_;goog.math.Long.TWO_PWR_64_DBL_=goog.mat h.Long.TWO_PWR_32_DBL_*goog.math.Long.TWO_PWR_32_DBL_;goog.math.Long.TWO_PWR_63_ DBL_=goog.math.Long.TWO_PWR_64_DBL_/2;goog.math.Long.ZERO=goog.math.Long.fromInt (0);goog.math.Long.ONE=goog.math.Long.fromInt(1);goog.math.Long.NEG_ONE=goog.mat h.Long.fromInt(-1);goog.math.Long.MAX_VALUE=goog.math.Long.fromBits(4294967295|0 ,2147483647|0);goog.math.Long.MIN_VALUE=goog.math.Long.fromBits(0,2147483648|0); goog.math.Long.TWO_PWR_24_=goog.math.Long.fromInt(1<<24);goog.math.Long.prototyp e.toInt=(function(){return this.low_});goog.math.Long.prototype.toNumber=(functi on(){return this.high_*goog.math.Long.TWO_PWR_32_DBL_+this.getLowBitsUnsigned()} );goog.math.Long.prototype.toString=(function(opt_radix){var radix=opt_radix||10 ;if(radix<2||36<radix){throw Error("radix out of range: "+radix)}if(this.isZero( )){return"0"}if(this.isNegative()){if(this.equals(goog.math.Long.MIN_VALUE)){var radixLong=goog.math.Long.fromNumber(radix);var div=this.div(radixLong);var rem= div.multiply(radixLong).subtract(this);return div.toString(radix)+rem.toInt().to String(radix)}else{return"-"+this.negate().toString(radix)}}var radixToPower=goo g.math.Long.fromNumber(Math.pow(radix,6));var rem=this;var result="";while(true) {var remDiv=rem.div(radixToPower);var intval=rem.subtract(remDiv.multiply(radixT oPower)).toInt();var digits=intval.toString(radix);rem=remDiv;if(rem.isZero()){r eturn digits+result}else{while(digits.length<6){digits="0"+digits}result=""+digi ts+result}}});goog.math.Long.prototype.getHighBits=(function(){return this.high_ });goog.math.Long.prototype.getLowBits=(function(){return this.low_});goog.math. Long.prototype.getLowBitsUnsigned=(function(){return this.low_>=0?this.low_:goog .math.Long.TWO_PWR_32_DBL_+this.low_});goog.math.Long.prototype.getNumBitsAbs=(f unction(){if(this.isNegative()){if(this.equals(goog.math.Long.MIN_VALUE)){return 64}else{return this.negate().getNumBitsAbs()}}else{var val=this.high_!=0?this.h igh_:this.low_;for(var bit=31;bit>0;bit--){if((val&1<<bit)!=0){break}}return thi s.high_!=0?bit+33:bit+1}});goog.math.Long.prototype.isZero=(function(){return th is.high_==0&&this.low_==0});goog.math.Long.prototype.isNegative=(function(){retu rn this.high_<0});goog.math.Long.prototype.isOdd=(function(){return(this.low_&1) ==1});goog.math.Long.prototype.equals=(function(other){return this.high_==other. high_&&this.low_==other.low_});goog.math.Long.prototype.notEquals=(function(othe r){return this.high_!=other.high_||this.low_!=other.low_});goog.math.Long.protot ype.lessThan=(function(other){return this.compare(other)<0});goog.math.Long.prot otype.lessThanOrEqual=(function(other){return this.compare(other)<=0});goog.math .Long.prototype.greaterThan=(function(other){return this.compare(other)>0});goog .math.Long.prototype.greaterThanOrEqual=(function(other){return this.compare(oth er)>=0});goog.math.Long.prototype.compare=(function(other){if(this.equals(other) ){return 0}var thisNeg=this.isNegative();var otherNeg=other.isNegative();if(this Neg&&!otherNeg){return-1}if(!thisNeg&&otherNeg){return 1}if(this.subtract(other) .isNegative()){return-1}else{return 1}});goog.math.Long.prototype.negate=(functi on(){if(this.equals(goog.math.Long.MIN_VALUE)){return goog.math.Long.MIN_VALUE}e lse{return this.not().add(goog.math.Long.ONE)}});goog.math.Long.prototype.add=(f unction(other){var a48=this.high_>>>16;var a32=this.high_&65535;var a16=this.low _>>>16;var a00=this.low_&65535;var b48=other.high_>>>16;var b32=other.high_&6553 5;var b16=other.low_>>>16;var b00=other.low_&65535;var c48=0,c32=0,c16=0,c00=0;c 00+=a00+b00;c16+=c00>>>16;c00&=65535;c16+=a16+b16;c32+=c16>>>16;c16&=65535;c32+= a32+b32;c48+=c32>>>16;c32&=65535;c48+=a48+b48;c48&=65535;return goog.math.Long.f romBits(c16<<16|c00,c48<<16|c32)});goog.math.Long.prototype.subtract=(function(o ther){return this.add(other.negate())});goog.math.Long.prototype.multiply=(funct ion(other){if(this.isZero()){return goog.math.Long.ZERO}else if(other.isZero()){ return goog.math.Long.ZERO}if(this.equals(goog.math.Long.MIN_VALUE)){return othe r.isOdd()?goog.math.Long.MIN_VALUE:goog.math.Long.ZERO}else if(other.equals(goog .math.Long.MIN_VALUE)){return this.isOdd()?goog.math.Long.MIN_VALUE:goog.math.Lo ng.ZERO}if(this.isNegative()){if(other.isNegative()){return this.negate().multip ly(other.negate())}else{return this.negate().multiply(other).negate()}}else if(o ther.isNegative()){return this.multiply(other.negate()).negate()}if(this.lessTha n(goog.math.Long.TWO_PWR_24_)&&other.lessThan(goog.math.Long.TWO_PWR_24_)){retur n goog.math.Long.fromNumber(this.toNumber()*other.toNumber())}var a48=this.high_ >>>16;var a32=this.high_&65535;var a16=this.low_>>>16;var a00=this.low_&65535;va r b48=other.high_>>>16;var b32=other.high_&65535;var b16=other.low_>>>16;var b00 =other.low_&65535;var c48=0,c32=0,c16=0,c00=0;c00+=a00*b00;c16+=c00>>>16;c00&=65 535;c16+=a16*b00;c32+=c16>>>16;c16&=65535;c16+=a00*b16;c32+=c16>>>16;c16&=65535; c32+=a32*b00;c48+=c32>>>16;c32&=65535;c32+=a16*b16;c48+=c32>>>16;c32&=65535;c32+ =a00*b32;c48+=c32>>>16;c32&=65535;c48+=a48*b00+a32*b16+a16*b32+a00*b48;c48&=6553 5;return goog.math.Long.fromBits(c16<<16|c00,c48<<16|c32)});goog.math.Long.proto type.div=(function(other){if(other.isZero()){throw Error("division by zero")}els e if(this.isZero()){return goog.math.Long.ZERO}if(this.equals(goog.math.Long.MIN _VALUE)){if(other.equals(goog.math.Long.ONE)||other.equals(goog.math.Long.NEG_ON E)){return goog.math.Long.MIN_VALUE}else if(other.equals(goog.math.Long.MIN_VALU E)){return goog.math.Long.ONE}else{var halfThis=this.shiftRight(1);var approx=ha lfThis.div(other).shiftLeft(1);if(approx.equals(goog.math.Long.ZERO)){return oth er.isNegative()?goog.math.Long.ONE:goog.math.Long.NEG_ONE}else{var rem=this.subt ract(other.multiply(approx));var result=approx.add(rem.div(other));return result }}}else if(other.equals(goog.math.Long.MIN_VALUE)){return goog.math.Long.ZERO}if (this.isNegative()){if(other.isNegative()){return this.negate().div(other.negate ())}else{return this.negate().div(other).negate()}}else if(other.isNegative()){r eturn this.div(other.negate()).negate()}var res=goog.math.Long.ZERO;var rem=this ;while(rem.greaterThanOrEqual(other)){var approx=Math.max(1,Math.floor(rem.toNum ber()/other.toNumber()));var log2=Math.ceil(Math.log(approx)/Math.LN2);var delta =log2<=48?1:Math.pow(2,log2-48);var approxRes=goog.math.Long.fromNumber(approx); var approxRem=approxRes.multiply(other);while(approxRem.isNegative()||approxRem. greaterThan(rem)){approx-=delta;approxRes=goog.math.Long.fromNumber(approx);appr oxRem=approxRes.multiply(other)}if(approxRes.isZero()){approxRes=goog.math.Long. ONE}res=res.add(approxRes);rem=rem.subtract(approxRem)}return res});goog.math.Lo ng.prototype.modulo=(function(other){return this.subtract(this.div(other).multip ly(other))});goog.math.Long.prototype.not=(function(){return goog.math.Long.from Bits(~this.low_,~this.high_)});goog.math.Long.prototype.and=(function(other){ret urn goog.math.Long.fromBits(this.low_&other.low_,this.high_&other.high_)});goog. math.Long.prototype.or=(function(other){return goog.math.Long.fromBits(this.low_ |other.low_,this.high_|other.high_)});goog.math.Long.prototype.xor=(function(oth er){return goog.math.Long.fromBits(this.low_^other.low_,this.high_^other.high_)} );goog.math.Long.prototype.shiftLeft=(function(numBits){numBits&=63;if(numBits== 0){return this}else{var low=this.low_;if(numBits<32){var high=this.high_;return goog.math.Long.fromBits(low<<numBits,high<<numBits|low>>>32-numBits)}else{return goog.math.Long.fromBits(0,low<<numBits-32)}}});goog.math.Long.prototype.shiftRi ght=(function(numBits){numBits&=63;if(numBits==0){return this}else{var high=this .high_;if(numBits<32){var low=this.low_;return goog.math.Long.fromBits(low>>>num Bits|high<<32-numBits,high>>numBits)}else{return goog.math.Long.fromBits(high>>n umBits-32,high>=0?0:-1)}}});goog.math.Long.prototype.shiftRightUnsigned=(functio n(numBits){numBits&=63;if(numBits==0){return this}else{var high=this.high_;if(nu mBits<32){var low=this.low_;return goog.math.Long.fromBits(low>>>numBits|high<<3 2-numBits,high>>>numBits)}else if(numBits==32){return goog.math.Long.fromBits(hi gh,0)}else{return goog.math.Long.fromBits(high>>>numBits-32,0)}}});var navigator ={appName:"Modern Browser"};var dbits;var canary=0xdeadbeefcafe;var j_lm=(canary &16777215)==15715070;function BigInteger(a,b,c){if(a!=null)if("number"==typeof a )this.fromNumber(a,b,c);else if(b==null&&"string"!=typeof a)this.fromString(a,25 6);else this.fromString(a,b)}function nbi(){return new BigInteger(null)}function am1(i,x,w,j,c,n){while(--n>=0){var v=x*this[i++]+w[j]+c;c=Math.floor(v/67108864 );w[j++]=v&67108863}return c}function am2(i,x,w,j,c,n){var xl=x&32767,xh=x>>15;w hile(--n>=0){var l=this[i]&32767;var h=this[i++]>>15;var m=xh*l+h*xl;l=xl*l+((m& 32767)<<15)+w[j]+(c&1073741823);c=(l>>>30)+(m>>>15)+xh*h+(c>>>30);w[j++]=l&10737 41823}return c}function am3(i,x,w,j,c,n){var xl=x&16383,xh=x>>14;while(--n>=0){v ar l=this[i]&16383;var h=this[i++]>>14;var m=xh*l+h*xl;l=xl*l+((m&16383)<<14)+w[ j]+c;c=(l>>28)+(m>>14)+xh*h;w[j++]=l&268435455}return c}if(j_lm&&navigator.appNa me=="Microsoft Internet Explorer"){BigInteger.prototype.am=am2;dbits=30}else if( j_lm&&navigator.appName!="Netscape"){BigInteger.prototype.am=am1;dbits=26}else{B igInteger.prototype.am=am3;dbits=28}BigInteger.prototype.DB=dbits;BigInteger.pro totype.DM=(1<<dbits)-1;BigInteger.prototype.DV=1<<dbits;var BI_FP=52;BigInteger. prototype.FV=Math.pow(2,BI_FP);BigInteger.prototype.F1=BI_FP-dbits;BigInteger.pr ototype.F2=2*dbits-BI_FP;var BI_RM="0123456789abcdefghijklmnopqrstuvwxyz";var BI _RC=new Array;var rr,vv;rr="0".charCodeAt(0);for(vv=0;vv<=9;++vv)BI_RC[rr++]=vv; rr="a".charCodeAt(0);for(vv=10;vv<36;++vv)BI_RC[rr++]=vv;rr="A".charCodeAt(0);fo r(vv=10;vv<36;++vv)BI_RC[rr++]=vv;function int2char(n){return BI_RM.charAt(n)}fu nction intAt(s,i){var c=BI_RC[s.charCodeAt(i)];return c==null?-1:c}function bnpC opyTo(r){for(var i=this.t-1;i>=0;--i)r[i]=this[i];r.t=this.t;r.s=this.s}function bnpFromInt(x){this.t=1;this.s=x<0?-1:0;if(x>0)this[0]=x;else if(x<-1)this[0]=x+ DV;else this.t=0}function nbv(i){var r=nbi();r.fromInt(i);return r}function bnpF romString(s,b){var k;if(b==16)k=4;else if(b==8)k=3;else if(b==256)k=8;else if(b= =2)k=1;else if(b==32)k=5;else if(b==4)k=2;else{this.fromRadix(s,b);return}this.t =0;this.s=0;var i=s.length,mi=false,sh=0;while(--i>=0){var x=k==8?s[i]&255:intAt (s,i);if(x<0){if(s.charAt(i)=="-")mi=true;continue}mi=false;if(sh==0)this[this.t ++]=x;else if(sh+k>this.DB){this[this.t-1]|=(x&(1<<this.DB-sh)-1)<<sh;this[this. t++]=x>>this.DB-sh}else this[this.t-1]|=x<<sh;sh+=k;if(sh>=this.DB)sh-=this.DB}i f(k==8&&(s[0]&128)!=0){this.s=-1;if(sh>0)this[this.t-1]|=(1<<this.DB-sh)-1<<sh}t his.clamp();if(mi)BigInteger.ZERO.subTo(this,this)}function bnpClamp(){var c=thi s.s&this.DM;while(this.t>0&&this[this.t-1]==c)--this.t}function bnToString(b){if (this.s<0)return"-"+this.negate().toString(b);var k;if(b==16)k=4;else if(b==8)k= 3;else if(b==2)k=1;else if(b==32)k=5;else if(b==4)k=2;else return this.toRadix(b );var km=(1<<k)-1,d,m=false,r="",i=this.t;var p=this.DB-i*this.DB%k;if(i-->0){if (p<this.DB&&(d=this[i]>>p)>0){m=true;r=int2char(d)}while(i>=0){if(p<k){d=(this[i ]&(1<<p)-1)<<k-p;d|=this[--i]>>(p+=this.DB-k)}else{d=this[i]>>(p-=k)&km;if(p<=0) {p+=this.DB;--i}}if(d>0)m=true;if(m)r+=int2char(d)}}return m?r:"0"}function bnNe gate(){var r=nbi();BigInteger.ZERO.subTo(this,r);return r}function bnAbs(){retur n this.s<0?this.negate():this}function bnCompareTo(a){var r=this.s-a.s;if(r!=0)r eturn r;var i=this.t;r=i-a.t;if(r!=0)return this.s<0?-r:r;while(--i>=0)if((r=thi s[i]-a[i])!=0)return r;return 0}function nbits(x){var r=1,t;if((t=x>>>16)!=0){x= t;r+=16}if((t=x>>8)!=0){x=t;r+=8}if((t=x>>4)!=0){x=t;r+=4}if((t=x>>2)!=0){x=t;r+ =2}if((t=x>>1)!=0){x=t;r+=1}return r}function bnBitLength(){if(this.t<=0)return 0;return this.DB*(this.t-1)+nbits(this[this.t-1]^this.s&this.DM)}function bnpDLS hiftTo(n,r){var i;for(i=this.t-1;i>=0;--i)r[i+n]=this[i];for(i=n-1;i>=0;--i)r[i] =0;r.t=this.t+n;r.s=this.s}function bnpDRShiftTo(n,r){for(var i=n;i<this.t;++i)r [i-n]=this[i];r.t=Math.max(this.t-n,0);r.s=this.s}function bnpLShiftTo(n,r){var bs=n%this.DB;var cbs=this.DB-bs;var bm=(1<<cbs)-1;var ds=Math.floor(n/this.DB),c =this.s<<bs&this.DM,i;for(i=this.t-1;i>=0;--i){r[i+ds+1]=this[i]>>cbs|c;c=(this[ i]&bm)<<bs}for(i=ds-1;i>=0;--i)r[i]=0;r[ds]=c;r.t=this.t+ds+1;r.s=this.s;r.clamp ()}function bnpRShiftTo(n,r){r.s=this.s;var ds=Math.floor(n/this.DB);if(ds>=this .t){r.t=0;return}var bs=n%this.DB;var cbs=this.DB-bs;var bm=(1<<bs)-1;r[0]=this[ ds]>>bs;for(var i=ds+1;i<this.t;++i){r[i-ds-1]|=(this[i]&bm)<<cbs;r[i-ds]=this[i ]>>bs}if(bs>0)r[this.t-ds-1]|=(this.s&bm)<<cbs;r.t=this.t-ds;r.clamp()}function bnpSubTo(a,r){var i=0,c=0,m=Math.min(a.t,this.t);while(i<m){c+=this[i]-a[i];r[i+ +]=c&this.DM;c>>=this.DB}if(a.t<this.t){c-=a.s;while(i<this.t){c+=this[i];r[i++] =c&this.DM;c>>=this.DB}c+=this.s}else{c+=this.s;while(i<a.t){c-=a[i];r[i++]=c&th is.DM;c>>=this.DB}c-=a.s}r.s=c<0?-1:0;if(c<-1)r[i++]=this.DV+c;else if(c>0)r[i++ ]=c;r.t=i;r.clamp()}function bnpMultiplyTo(a,r){var x=this.abs(),y=a.abs();var i =x.t;r.t=i+y.t;while(--i>=0)r[i]=0;for(i=0;i<y.t;++i)r[i+x.t]=x.am(0,y[i],r,i,0, x.t);r.s=0;r.clamp();if(this.s!=a.s)BigInteger.ZERO.subTo(r,r)}function bnpSquar eTo(r){var x=this.abs();var i=r.t=2*x.t;while(--i>=0)r[i]=0;for(i=0;i<x.t-1;++i) {var c=x.am(i,x[i],r,2*i,0,1);if((r[i+x.t]+=x.am(i+1,2*x[i],r,2*i+1,c,x.t-i-1))> =x.DV){r[i+x.t]-=x.DV;r[i+x.t+1]=1}}if(r.t>0)r[r.t-1]+=x.am(i,x[i],r,2*i,0,1);r. s=0;r.clamp()}function bnpDivRemTo(m,q,r){var pm=m.abs();if(pm.t<=0)return;var p t=this.abs();if(pt.t<pm.t){if(q!=null)q.fromInt(0);if(r!=null)this.copyTo(r);ret urn}if(r==null)r=nbi();var y=nbi(),ts=this.s,ms=m.s;var nsh=this.DB-nbits(pm[pm. t-1]);if(nsh>0){pm.lShiftTo(nsh,y);pt.lShiftTo(nsh,r)}else{pm.copyTo(y);pt.copyT o(r)}var ys=y.t;var y0=y[ys-1];if(y0==0)return;var yt=y0*(1<<this.F1)+(ys>1?y[ys -2]>>this.F2:0);var d1=this.FV/yt,d2=(1<<this.F1)/yt,e=1<<this.F2;var i=r.t,j=i- ys,t=q==null?nbi():q;y.dlShiftTo(j,t);if(r.compareTo(t)>=0){r[r.t++]=1;r.subTo(t ,r)}BigInteger.ONE.dlShiftTo(ys,t);t.subTo(y,y);while(y.t<ys)y[y.t++]=0;while(-- j>=0){var qd=r[--i]==y0?this.DM:Math.floor(r[i]*d1+(r[i-1]+e)*d2);if((r[i]+=y.am (0,qd,r,j,0,ys))<qd){y.dlShiftTo(j,t);r.subTo(t,r);while(r[i]<--qd)r.subTo(t,r)} }if(q!=null){r.drShiftTo(ys,q);if(ts!=ms)BigInteger.ZERO.subTo(q,q)}r.t=ys;r.cla mp();if(nsh>0)r.rShiftTo(nsh,r);if(ts<0)BigInteger.ZERO.subTo(r,r)}function bnMo d(a){var r=nbi();this.abs().divRemTo(a,null,r);if(this.s<0&&r.compareTo(BigInteg er.ZERO)>0)a.subTo(r,r);return r}function Classic(m){this.m=m}function cConvert( x){if(x.s<0||x.compareTo(this.m)>=0)return x.mod(this.m);else return x}function cRevert(x){return x}function cReduce(x){x.divRemTo(this.m,null,x)}function cMulT o(x,y,r){x.multiplyTo(y,r);this.reduce(r)}function cSqrTo(x,r){x.squareTo(r);thi s.reduce(r)}Classic.prototype.convert=cConvert;Classic.prototype.revert=cRevert; Classic.prototype.reduce=cReduce;Classic.prototype.mulTo=cMulTo;Classic.prototyp e.sqrTo=cSqrTo;function bnpInvDigit(){if(this.t<1)return 0;var x=this[0];if((x&1 )==0)return 0;var y=x&3;y=y*(2-(x&15)*y)&15;y=y*(2-(x&255)*y)&255;y=y*(2-((x&655 35)*y&65535))&65535;y=y*(2-x*y%this.DV)%this.DV;return y>0?this.DV-y:-y}function Montgomery(m){this.m=m;this.mp=m.invDigit();this.mpl=this.mp&32767;this.mph=thi s.mp>>15;this.um=(1<<m.DB-15)-1;this.mt2=2*m.t}function montConvert(x){var r=nbi ();x.abs().dlShiftTo(this.m.t,r);r.divRemTo(this.m,null,r);if(x.s<0&&r.compareTo (BigInteger.ZERO)>0)this.m.subTo(r,r);return r}function montRevert(x){var r=nbi( );x.copyTo(r);this.reduce(r);return r}function montReduce(x){while(x.t<=this.mt2 )x[x.t++]=0;for(var i=0;i<this.m.t;++i){var j=x[i]&32767;var u0=j*this.mpl+((j*t his.mph+(x[i]>>15)*this.mpl&this.um)<<15)&x.DM;j=i+this.m.t;x[j]+=this.m.am(0,u0 ,x,i,0,this.m.t);while(x[j]>=x.DV){x[j]-=x.DV;x[++j]++}}x.clamp();x.drShiftTo(th is.m.t,x);if(x.compareTo(this.m)>=0)x.subTo(this.m,x)}function montSqrTo(x,r){x. squareTo(r);this.reduce(r)}function montMulTo(x,y,r){x.multiplyTo(y,r);this.redu ce(r)}Montgomery.prototype.convert=montConvert;Montgomery.prototype.revert=montR evert;Montgomery.prototype.reduce=montReduce;Montgomery.prototype.mulTo=montMulT o;Montgomery.prototype.sqrTo=montSqrTo;function bnpIsEven(){return(this.t>0?this [0]&1:this.s)==0}function bnpExp(e,z){if(e>4294967295||e<1)return BigInteger.ONE ;var r=nbi(),r2=nbi(),g=z.convert(this),i=nbits(e)-1;g.copyTo(r);while(--i>=0){z .sqrTo(r,r2);if((e&1<<i)>0)z.mulTo(r2,g,r);else{var t=r;r=r2;r2=t}}return z.reve rt(r)}function bnModPowInt(e,m){var z;if(e<256||m.isEven())z=new Classic(m);else z=new Montgomery(m);return this.exp(e,z)}BigInteger.prototype.copyTo=bnpCopyTo; BigInteger.prototype.fromInt=bnpFromInt;BigInteger.prototype.fromString=bnpFromS tring;BigInteger.prototype.clamp=bnpClamp;BigInteger.prototype.dlShiftTo=bnpDLSh iftTo;BigInteger.prototype.drShiftTo=bnpDRShiftTo;BigInteger.prototype.lShiftTo= bnpLShiftTo;BigInteger.prototype.rShiftTo=bnpRShiftTo;BigInteger.prototype.subTo =bnpSubTo;BigInteger.prototype.multiplyTo=bnpMultiplyTo;BigInteger.prototype.squ areTo=bnpSquareTo;BigInteger.prototype.divRemTo=bnpDivRemTo;BigInteger.prototype .invDigit=bnpInvDigit;BigInteger.prototype.isEven=bnpIsEven;BigInteger.prototype .exp=bnpExp;BigInteger.prototype.toString=bnToString;BigInteger.prototype.negate =bnNegate;BigInteger.prototype.abs=bnAbs;BigInteger.prototype.compareTo=bnCompar eTo;BigInteger.prototype.bitLength=bnBitLength;BigInteger.prototype.mod=bnMod;Bi gInteger.prototype.modPowInt=bnModPowInt;BigInteger.ZERO=nbv(0);BigInteger.ONE=n bv(1);function bnpFromRadix(s,b){this.fromInt(0);if(b==null)b=10;var cs=this.chu nkSize(b);var d=Math.pow(b,cs),mi=false,j=0,w=0;for(var i=0;i<s.length;++i){var x=intAt(s,i);if(x<0){if(s.charAt(i)=="-"&&this.signum()==0)mi=true;continue}w=b* w+x;if(++j>=cs){this.dMultiply(d);this.dAddOffset(w,0);j=0;w=0}}if(j>0){this.dMu ltiply(Math.pow(b,j));this.dAddOffset(w,0)}if(mi)BigInteger.ZERO.subTo(this,this )}function bnpChunkSize(r){return Math.floor(Math.LN2*this.DB/Math.log(r))}funct ion bnSigNum(){if(this.s<0)return-1;else if(this.t<=0||this.t==1&&this[0]<=0)ret urn 0;else return 1}function bnpDMultiply(n){this[this.t]=this.am(0,n-1,this,0,0 ,this.t);++this.t;this.clamp()}function bnpDAddOffset(n,w){if(n==0)return;while( this.t<=w)this[this.t++]=0;this[w]+=n;while(this[w]>=this.DV){this[w]-=this.DV;i f(++w>=this.t)this[this.t++]=0;++this[w]}}function bnpToRadix(b){if(b==null)b=10 ;if(this.signum()==0||b<2||b>36)return"0";var cs=this.chunkSize(b);var a=Math.po w(b,cs);var d=nbv(a),y=nbi(),z=nbi(),r="";this.divRemTo(d,y,z);while(y.signum()> 0){r=(a+z.intValue()).toString(b).substr(1)+r;y.divRemTo(d,y,z)}return z.intValu e().toString(b)+r}function bnIntValue(){if(this.s<0){if(this.t==1)return this[0] -this.DV;else if(this.t==0)return-1}else if(this.t==1)return this[0];else if(thi s.t==0)return 0;return(this[1]&(1<<32-this.DB)-1)<<this.DB|this[0]}function bnpA ddTo(a,r){var i=0,c=0,m=Math.min(a.t,this.t);while(i<m){c+=this[i]+a[i];r[i++]=c &this.DM;c>>=this.DB}if(a.t<this.t){c+=a.s;while(i<this.t){c+=this[i];r[i++]=c&t his.DM;c>>=this.DB}c+=this.s}else{c+=this.s;while(i<a.t){c+=a[i];r[i++]=c&this.D M;c>>=this.DB}c+=a.s}r.s=c<0?-1:0;if(c>0)r[i++]=c;else if(c<-1)r[i++]=this.DV+c; r.t=i;r.clamp()}BigInteger.prototype.fromRadix=bnpFromRadix;BigInteger.prototype .chunkSize=bnpChunkSize;BigInteger.prototype.signum=bnSigNum;BigInteger.prototyp e.dMultiply=bnpDMultiply;BigInteger.prototype.dAddOffset=bnpDAddOffset;BigIntege r.prototype.toRadix=bnpToRadix;BigInteger.prototype.intValue=bnIntValue;BigInteg er.prototype.addTo=bnpAddTo;var Wrapper={abs:(function(l,h){var x=new goog.math. Long(l,h);var ret;if(x.isNegative()){ret=x.negate()}else{ret=x}HEAP32[tempDouble Ptr>>2]=ret.low_;HEAP32[tempDoublePtr+4>>2]=ret.high_}),ensureTemps:(function(){ if(Wrapper.ensuredTemps)return;Wrapper.ensuredTemps=true;Wrapper.two32=new BigIn teger;Wrapper.two32.fromString("4294967296",10);Wrapper.two64=new BigInteger;Wra pper.two64.fromString("18446744073709551616",10);Wrapper.temp1=new BigInteger;Wr apper.temp2=new BigInteger}),lh2bignum:(function(l,h){var a=new BigInteger;a.fro mString(h.toString(),10);var b=new BigInteger;a.multiplyTo(Wrapper.two32,b);var c=new BigInteger;c.fromString(l.toString(),10);var d=new BigInteger;c.addTo(b,d) ;return d}),stringify:(function(l,h,unsigned){var ret=(new goog.math.Long(l,h)). toString();if(unsigned&&ret[0]=="-"){Wrapper.ensureTemps();var bignum=new BigInt eger;bignum.fromString(ret,10);ret=new BigInteger;Wrapper.two64.addTo(bignum,ret );ret=ret.toString(10)}return ret}),fromString:(function(str,base,min,max,unsign ed){Wrapper.ensureTemps();var bignum=new BigInteger;bignum.fromString(str,base); var bigmin=new BigInteger;bigmin.fromString(min,10);var bigmax=new BigInteger;bi gmax.fromString(max,10);if(unsigned&&bignum.compareTo(BigInteger.ZERO)<0){var te mp=new BigInteger;bignum.addTo(Wrapper.two64,temp);bignum=temp}var error=false;i f(bignum.compareTo(bigmin)<0){bignum=bigmin;error=true}else if(bignum.compareTo( bigmax)>0){bignum=bigmax;error=true}var ret=goog.math.Long.fromString(bignum.toS tring());HEAP32[tempDoublePtr>>2]=ret.low_;HEAP32[tempDoublePtr+4>>2]=ret.high_; if(error)throw"range error"})};return Wrapper})();if(memoryInitializer){if(typeo f Module["locateFile"]==="function"){memoryInitializer=Module["locateFile"](memo ryInitializer)}else if(Module["memoryInitializerPrefixURL"]){memoryInitializer=M odule["memoryInitializerPrefixURL"]+memoryInitializer}if(ENVIRONMENT_IS_NODE||EN VIRONMENT_IS_SHELL){var data=Module["readBinary"](memoryInitializer);HEAPU8.set( data,STATIC_BASE)}else{addRunDependency("memory initializer");function applyMemo ryInitializer(data){if(data.byteLength)data=new Uint8Array(data);HEAPU8.set(data ,STATIC_BASE);removeRunDependency("memory initializer")}var request=Module["memo ryInitializerRequest"];if(request){if(request.response){setTimeout((function(){a pplyMemoryInitializer(request.response)}),0)}else{request.addEventListener("load ",(function(){if(request.status!==200&&request.status!==0){console.warn("a probl em seems to have happened with Module.memoryInitializerRequest, status: "+reques t.status)}if(!request.response||typeof request.response!=="object"||!request.res ponse.byteLength){console.warn("a problem seems to have happened with Module.mem oryInitializerRequest response (expected ArrayBuffer): "+request.response)}apply MemoryInitializer(request.response)}))}}else{Browser.asyncLoad(memoryInitializer ,applyMemoryInitializer,(function(){throw"could not load memory initializer "+me moryInitializer}))}}}function ExitStatus(status){this.name="ExitStatus";this.mes sage="Program terminated with exit("+status+")";this.status=status}ExitStatus.pr ototype=new Error;ExitStatus.prototype.constructor=ExitStatus;var initialStackTo p;var preloadStartTime=null;var calledMain=false;dependenciesFulfilled=function runCaller(){if(!Module["calledRun"])run();if(!Module["calledRun"])dependenciesFu lfilled=runCaller};Module["callMain"]=Module.callMain=function callMain(args){as sert(runDependencies==0,"cannot call main when async dependencies remain! (liste n on __ATMAIN__)");assert(__ATPRERUN__.length==0,"cannot call main when preRun f unctions remain to be called");args=args||[];ensureInitRuntime();var argc=args.l ength+1;function pad(){for(var i=0;i<4-1;i++){argv.push(0)}}var argv=[allocate(i ntArrayFromString(Module["thisProgram"]),"i8",ALLOC_NORMAL)];pad();for(var i=0;i <argc-1;i=i+1){argv.push(allocate(intArrayFromString(args[i]),"i8",ALLOC_NORMAL) );pad()}argv.push(0);argv=allocate(argv,"i32",ALLOC_NORMAL);initialStackTop=STAC KTOP;try{var ret=Module["_main"](argc,argv,0);exit(ret)}catch(e){if(e instanceof ExitStatus){return}else if(e=="SimulateInfiniteLoop"){Module["noExitRuntime"]=t rue;return}else{if(e&&typeof e==="object"&&e.stack)Module.printErr("exception th rown: "+[e,e.stack]);throw e}}finally{calledMain=true}};function run(args){args= args||Module["arguments"];if(preloadStartTime===null)preloadStartTime=Date.now() ;if(runDependencies>0){return}preRun();if(runDependencies>0)return;if(Module["ca lledRun"])return;function doRun(){if(Module["calledRun"])return;Module["calledRu n"]=true;if(ABORT)return;ensureInitRuntime();preMain();if(ENVIRONMENT_IS_WEB&&pr eloadStartTime!==null){Module.printErr("pre-main prep time: "+(Date.now()-preloa dStartTime)+" ms")}if(Module["onRuntimeInitialized"])Module["onRuntimeInitialize d"]();if(Module["_main"]&&shouldRunNow)Module["callMain"](args);postRun()}if(Mod ule["setStatus"]){Module["setStatus"]("Running...");setTimeout((function(){setTi meout((function(){Module["setStatus"]("")}),1);doRun()}),1)}else{doRun()}}Module ["run"]=Module.run=run;function exit(status){if(Module["noExitRuntime"]){return} ABORT=true;EXITSTATUS=status;STACKTOP=initialStackTop;exitRuntime();if(Module["o nExit"])Module["onExit"](status);if(ENVIRONMENT_IS_NODE){process["stdout"]["once "]("drain",(function(){process["exit"](status)}));console.log(" ");setTimeout((f unction(){process["exit"](status)}),500)}else if(ENVIRONMENT_IS_SHELL&&typeof qu it==="function"){quit(status)}throw new ExitStatus(status)}Module["exit"]=Module .exit=exit;var abortDecorators=[];function abort(what){if(what!==undefined){Modu le.print(what);Module.printErr(what);what=JSON.stringify(what)}else{what=""}ABOR T=true;EXITSTATUS=1;var extra="\nIf this abort() is unexpected, build with -s AS SERTIONS=1 which can give more information.";var output="abort("+what+") at "+st ackTrace()+extra;abortDecorators.forEach((function(decorator){output=decorator(o utput,what)}));throw output}Module["abort"]=Module.abort=abort;if(Module["preIni t"]){if(typeof Module["preInit"]=="function")Module["preInit"]=[Module["preInit" ]];while(Module["preInit"].length>0){Module["preInit"].pop()()}}var shouldRunNow =true;if(Module["noInitialRun"]){shouldRunNow=false}run()
13
14
15
16
OLDNEW
« no previous file with comments | « test/emscripten/core/test_i64_llabs-O2.out ('k') | test/emscripten/core/test_i64_llabs-O3.out » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698