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

Side by Side Diff: test/emscripten/core/test_llvm_intrinsics-O2.js

Issue 1099813007: Revert "[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
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+560;__ATINIT__.push();allocate([37,120,44,37,120,1 0,0,0,37,120,44,37,120,44,37,120,44,37,120,10,0,0,0,0,37,100,44,37,100,10,0,0,37 ,100,10,0,0,0,0,0,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],"i8", ALLOC_NONE,Runtime.GLOBAL_BASE);var tempDoublePtr=Runtime.alignMemory(allocate(1 2,"i8",ALLOC_STATIC),8);assert(tempDoublePtr%8==0);function copyTempFloat(ptr){H EAP8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDou blePtr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3]}function copyTempDoub le(ptr){HEAP8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP 8[tempDoublePtr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3];HEAP8[tempDo ublePtr+4]=HEAP8[ptr+4];HEAP8[tempDoublePtr+5]=HEAP8[ptr+5];HEAP8[tempDoublePtr+ 6]=HEAP8[ptr+6];HEAP8[tempDoublePtr+7]=HEAP8[ptr+7]}var ___errno_state=0;functio n ___setErrNo(value){HEAP32[___errno_state>>2]=value;return value}var ERRNO_CODE S={EPERM:1,ENOENT:2,ESRCH:3,EINTR:4,EIO:5,ENXIO:6,E2BIG:7,ENOEXEC:8,EBADF:9,ECHI LD:10,EAGAIN:11,EWOULDBLOCK: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,EFBIG:27,ENOSPC:28,ESPIPE:29,EROFS:30,EMLINK:31,EPIPE:32,E DOM:33,ERANGE:34,ENOMSG:42,EIDRM:43,ECHRNG:44,EL2NSYNC:45,EL3HLT:46,EL3RST:47,EL NRNG:48,EUNATCH:49,ENOCSI:50,EL2HLT:51,EDEADLK:35,ENOLCK:37,EBADE:52,EBADR:53,EX FULL:54,ENOANO:55,EBADRQC:56,EBADSLT:57,EDEADLOCK:35,EBFONT:59,ENOSTR:60,ENODATA :61,ETIME:62,ENOSR:63,ENONET:64,ENOPKG:65,EREMOTE:66,ENOLINK:67,EADV:68,ESRMNT:6 9,ECOMM:70,EPROTO:71,EMULTIHOP:72,EDOTDOT:73,EBADMSG:74,ENOTUNIQ:76,EBADFD:77,ER EMCHG:78,ELIBACC:79,ELIBBAD:80,ELIBSCN:81,ELIBMAX:82,ELIBEXEC:83,ENOSYS:38,ENOTE MPTY:39,ENAMETOOLONG:36,ELOOP:40,EOPNOTSUPP:95,EPFNOSUPPORT:96,ECONNRESET:104,EN OBUFS:105,EAFNOSUPPORT:97,EPROTOTYPE:91,ENOTSOCK:88,ENOPROTOOPT:92,ESHUTDOWN:108 ,ECONNREFUSED:111,EADDRINUSE:98,ECONNABORTED:103,ENETUNREACH:101,ENETDOWN:100,ET IMEDOUT:110,EHOSTDOWN:112,EHOSTUNREACH:113,EINPROGRESS:115,EALREADY:114,EDESTADD RREQ:89,EMSGSIZE:90,EPROTONOSUPPORT:93,ESOCKTNOSUPPORT:94,EADDRNOTAVAIL:99,ENETR ESET:102,EISCONN:106,ENOTCONN:107,ETOOMANYREFS:109,EUSERS:87,EDQUOT:122,ESTALE:1 16,ENOTSUP:95,ENOMEDIUM:123,EILSEQ:84,EOVERFLOW:75,ECANCELED:125,ENOTRECOVERABLE :131,EOWNERDEAD:130,ESTRPIPE:86};function _sysconf(name){switch(name){case 30:re turn PAGE_SIZE;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:c ase 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 80 :case 81:case 79:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 4 8:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 1 28:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 18 4:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168 :case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:c ase 35:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74: case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;cas e 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 655 36;case 28:return 32768;case 44:return 32767;case 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:return 16;case 6:return 6;case 73:re turn 4;case 84:{if(typeof navigator==="object")return navigator["hardwareConcurr ency"]||1;return 1}}___setErrNo(ERRNO_CODES.EINVAL);return-1}var _llvm_ctlz_i32= true;Module["_memset"]=_memset;function _llvm_ctpop_i32(x){var ret=0;while(x){if (x&1)ret++;x>>>=1}return ret}function _llvm_ctpop_i64(l,h){return _llvm_ctpop_i3 2(l)+_llvm_ctpop_i32(h)}function _abort(){Module["abort"]()}var ERRNO_MESSAGES={ 0:"Success",1:"Not super-user",2:"No such file or directory",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 number",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:"File exists",18:"Cross-devic e 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:"Too many links",32:"Broken pi pe",33:"Math arg out of domain of func",34:"Math result not representable",35:"F ile locking deadlock error",36:"File or path name too long",37:"No record locks available",38:"Function not implemented",39:"Directory not empty",40:"Too many s ymbolic links",42:"No message of desired type",43:"Identifier removed",44:"Chann el number out of range",45:"Level 2 not synchronized",46:"Level 3 halted",47:"Le vel 3 reset",48:"Link number out of range",49:"Protocol driver not attached",50: "No CSI structure available",51:"Level 2 halted",52:"Invalid exchange",53:"Inval id request descriptor",54:"Exchange full",55:"No anode",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 streams 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:"Srmount error",70:"Communica tion error on send",71:"Protocol error",72:"Multihop attempted",73:"Cross mount point (not really error)",74:"Trying to read unreadable message",75:"Value too l arge for defined data type",76:"Given log. name not unique",77:"f.d. invalid for this operation",78:"Remote address changed",79:"Can access a needed shared li b",80:"Accessing a corrupted shared lib",81:".lib section 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:"Socke t operation on non-socket",89:"Destination address required",90:"Message too lon g",91:"Protocol wrong type for socket",92:"Protocol not available",93:"Unknown p rotocol",94:"Socket type not supported",95:"Not supported",96:"Protocol family n ot supported",97:"Address family not supported by protocol family",98:"Address a lready in use",99:"Address not available",100:"Network interface is not configur ed",101:"Network is unreachable",102:"Connection reset by network",103:"Connecti on aborted",104:"Connection reset by peer",105:"No buffer space available",106:" Socket is already connected",107:"Socket is not connected",108:"Can't send after socket shutdown",109:"Too many references",110:"Connection timed out",111:"Conn ection refused",112:"Host is down",113:"Host is unreachable",114:"Socket already connected",115:"Connection already in progress",116:"Stale file handle",122:"Qu ota exceeded",123:"No medium (in tape drive)",125:"Operation canceled",130:"Prev ious owner died",131:"State not recoverable"};var PATH={splitPath:(function(file name){var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/ ]*)$/;return splitPathRe.exec(filename).slice(1)}),normalizeArray:(function(part s,allowAboveRoot){var up=0;for(var i=parts.length-1;i>=0;i--){var last=parts[i]; if(last==="."){parts.splice(i,1)}else if(last===".."){parts.splice(i,1);up++}els e if(up){parts.splice(i,1);up--}}if(allowAboveRoot){for(;up--;up){parts.unshift( "..")}}return parts}),normalize:(function(path){var isAbsolute=path.charAt(0)=== "/",trailingSlash=path.substr(-1)==="/";path=PATH.normalizeArray(path.split("/") .filter((function(p){return!!p})),!isAbsolute).join("/");if(!path&&!isAbsolute){ path="."}if(path&&trailingSlash){path+="/"}return(isAbsolute?"/":"")+path}),dirn ame:(function(path){var result=PATH.splitPath(path),root=result[0],dir=result[1] ;if(!root&&!dir){return"."}if(dir){dir=dir.substr(0,dir.length-1)}return root+di r}),basename:(function(path){if(path==="/")return"/";var lastSlash=path.lastInde xOf("/");if(lastSlash===-1)return path;return path.substr(lastSlash+1)}),extname :(function(path){return PATH.splitPath(path)[3]}),join:(function(){var paths=Arr ay.prototype.slice.call(arguments,0);return PATH.normalize(paths.join("/"))}),jo in2:(function(l,r){return PATH.normalize(l+"/"+r)}),resolve:(function(){var reso lvedPath="",resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolved Absolute;i--){var path=i>=0?arguments[i]:FS.cwd();if(typeof path!=="string"){thr ow new TypeError("Arguments to path.resolve must be strings")}else if(!path){ret urn""}resolvedPath=path+"/"+resolvedPath;resolvedAbsolute=path.charAt(0)==="/"}r esolvedPath=PATH.normalizeArray(resolvedPath.split("/").filter((function(p){retu rn!!p})),!resolvedAbsolute).join("/");return(resolvedAbsolute?"/":"")+resolvedPa th||"."}),relative:(function(from,to){from=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=arr.length-1;for(;end>=0;end--){if(arr[end] !=="")break}if(start>end)return[];return arr.slice(start,end-start+1)}var fromPa rts=trim(from.split("/"));var toParts=trim(to.split("/"));var length=Math.min(fr omParts.length,toParts.length);var samePartsLength=length;for(var i=0;i<length;i ++){if(fromParts[i]!==toParts[i]){samePartsLength=i;break}}var outputParts=[];fo r(var i=samePartsLength;i<fromParts.length;i++){outputParts.push("..")}outputPar ts=outputParts.concat(toParts.slice(samePartsLength));return outputParts.join("/ ")})};var TTY={ttys:[],init:(function(){}),shutdown:(function(){}),register:(fun ction(dev,ops){TTY.ttys[dev]={input:[],output:[],ops:ops};FS.registerDevice(dev, TTY.stream_ops)}),stream_ops:{open:(function(stream){var tty=TTY.ttys[stream.nod e.rdev];if(!tty){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}stream.tty=tty;stre am.seekable=false}),close:(function(stream){stream.tty.ops.flush(stream.tty)}),f lush:(function(stream){stream.tty.ops.flush(stream.tty)}),read:(function(stream, buffer,offset,length,pos){if(!stream.tty||!stream.tty.ops.get_char){throw new FS .ErrnoError(ERRNO_CODES.ENXIO)}var bytesRead=0;for(var i=0;i<length;i++){var res ult;try{result=stream.tty.ops.get_char(stream.tty)}catch(e){throw new FS.ErrnoEr ror(ERRNO_CODES.EIO)}if(result===undefined&&bytesRead===0){throw new FS.ErrnoErr or(ERRNO_CODES.EAGAIN)}if(result===null||result===undefined)break;bytesRead++;bu ffer[offset+i]=result}if(bytesRead){stream.node.timestamp=Date.now()}return byte sRead}),write:(function(stream,buffer,offset,length,pos){if(!stream.tty||!stream .tty.ops.put_char){throw new FS.ErrnoError(ERRNO_CODES.ENXIO)}for(var i=0;i<leng th;i++){try{stream.tty.ops.put_char(stream.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 r esult=null;if(ENVIRONMENT_IS_NODE){var BUFSIZE=256;var buf=new Buffer(BUFSIZE);v ar bytesRead=0;var fd=process.stdin.fd;var usingDevice=false;try{fd=fs.openSync( "/dev/stdin","r");usingDevice=true}catch(e){}bytesRead=fs.readSync(fd,buf,0,BUFS IZE,null);if(usingDevice){fs.closeSync(fd)}if(bytesRead>0){result=buf.slice(0,by tesRead).toString("utf-8")}else{result=null}}else if(typeof window!="undefined"& &typeof window.prompt=="function"){result=window.prompt("Input: ");if(result!==n ull){result+="\n"}}else if(typeof readline=="function"){result=readline();if(res ult!==null){result+="\n"}}if(!result){return null}tty.input=intArrayFromString(r esult,true)}return tty.input.shift()}),put_char:(function(tty,val){if(val===null ||val===10){Module["print"](UTF8ArrayToString(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"](UTF8ArrayToString(tty.output,0));tty.output=[]}})},de fault_tty1_ops:{put_char:(function(tty,val){if(val===null||val===10){Module["pri ntErr"](UTF8ArrayToString(tty.output,0));tty.output=[]}else{if(val!=0)tty.output .push(val)}}),flush:(function(tty){if(tty.output&&tty.output.length>0){Module["p rintErr"](UTF8ArrayToString(tty.output,0));tty.output=[]}})}};var MEMFS={ops_tab le:null,mount:(function(mount){return MEMFS.createNode(null,"/",16384|511,0)}),c reateNode:(function(parent,name,mode,dev){if(FS.isBlkdev(mode)||FS.isFIFO(mode)) {throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(!MEMFS.ops_table){MEMFS.ops_table ={dir:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,looku p:MEMFS.node_ops.lookup,mknod:MEMFS.node_ops.mknod,rename:MEMFS.node_ops.rename, unlink:MEMFS.node_ops.unlink,rmdir:MEMFS.node_ops.rmdir,readdir:MEMFS.node_ops.r eaddir,symlink:MEMFS.node_ops.symlink},stream:{llseek:MEMFS.stream_ops.llseek}}, file:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},strea m:{llseek:MEMFS.stream_ops.llseek,read:MEMFS.stream_ops.read,write:MEMFS.stream_ ops.write,allocate:MEMFS.stream_ops.allocate,mmap:MEMFS.stream_ops.mmap}},link:{ node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,readlink:MEM FS.node_ops.readlink},stream:{}},chrdev:{node:{getattr:MEMFS.node_ops.getattr,se tattr:MEMFS.node_ops.setattr},stream:FS.chrdev_stream_ops}}}var node=FS.createNo de(parent,name,mode,dev);if(FS.isDir(node.mode)){node.node_ops=MEMFS.ops_table.d ir.node;node.stream_ops=MEMFS.ops_table.dir.stream;node.contents={}}else if(FS.i sFile(node.mode)){node.node_ops=MEMFS.ops_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.link.node;node.stream_ops=MEMFS.ops_table. link.stream}else if(FS.isChrdev(node.mode)){node.node_ops=MEMFS.ops_table.chrdev .node;node.stream_ops=MEMFS.ops_table.chrdev.stream}node.timestamp=Date.now();if (parent){parent.contents[name]=node}return node}),getFileDataAsRegularArray:(fun ction(node){if(node.contents&&node.contents.subarray){var arr=[];for(var i=0;i<n ode.usedBytes;++i)arr.push(node.contents[i]);return arr}return node.contents}),g etFileDataAsTypedArray:(function(node){if(!node.contents)return new Uint8Array;i f(node.contents.subarray)return node.contents.subarray(0,node.usedBytes);return new Uint8Array(node.contents)}),expandFileStorage:(function(node,newCapacity){if (node.contents&&node.contents.subarray&&newCapacity>node.contents.length){node.c ontents=MEMFS.getFileDataAsRegularArray(node);node.usedBytes=node.contents.lengt h}if(!node.contents||node.contents.subarray){var prevCapacity=node.contents?node .contents.buffer.byteLength:0;if(prevCapacity>=newCapacity)return;var CAPACITY_D OUBLING_MAX=1024*1024;newCapacity=Math.max(newCapacity,prevCapacity*(prevCapacit y<CAPACITY_DOUBLING_MAX?2:1.125)|0);if(prevCapacity!=0)newCapacity=Math.max(newC apacity,256);var oldContents=node.contents;node.contents=new Uint8Array(newCapac ity);if(node.usedBytes>0)node.contents.set(oldContents.subarray(0,node.usedBytes ),0);return}if(!node.contents&&newCapacity>0)node.contents=[];while(node.content s.length<newCapacity)node.contents.push(0)}),resizeFileStorage:(function(node,ne wSize){if(node.usedBytes==newSize)return;if(newSize==0){node.contents=null;node. usedBytes=0;return}if(!node.contents||node.contents.subarray){var oldContents=no de.contents;node.contents=new Uint8Array(new ArrayBuffer(newSize));if(oldContent s){node.contents.set(oldContents.subarray(0,Math.min(newSize,node.usedBytes)))}n ode.usedBytes=newSize;return}if(!node.contents)node.contents=[];if(node.contents .length>newSize)node.contents.length=newSize;else while(node.contents.length<new Size)node.contents.push(0);node.usedBytes=newSize}),node_ops:{getattr:(function( node){var attr={};attr.dev=FS.isChrdev(node.mode)?node.id:1;attr.ino=node.id;att r.mode=node.mode;attr.nlink=1;attr.uid=0;attr.gid=0;attr.rdev=node.rdev;if(FS.is Dir(node.mode)){attr.size=4096}else if(FS.isFile(node.mode)){attr.size=node.used Bytes}else if(FS.isLink(node.mode)){attr.size=node.link.length}else{attr.size=0} attr.atime=new Date(node.timestamp);attr.mtime=new Date(node.timestamp);attr.cti me=new Date(node.timestamp);attr.blksize=4096;attr.blocks=Math.ceil(attr.size/at tr.blksize);return attr}),setattr:(function(node,attr){if(attr.mode!==undefined) {node.mode=attr.mode}if(attr.timestamp!==undefined){node.timestamp=attr.timestam p}if(attr.size!==undefined){MEMFS.resizeFileStorage(node,attr.size)}}),lookup:(f unction(parent,name){throw FS.genericErrors[ERRNO_CODES.ENOENT]}),mknod:(functio n(parent,name,mode,dev){return MEMFS.createNode(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_name)}catch(e){}if(new_node){for(var i in ne w_node.contents){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}}}delete old_nod e.parent.contents[old_node.name];old_node.name=new_name;new_dir.contents[new_nam e]=old_node;old_node.parent=new_dir}),unlink:(function(parent,name){delete paren t.contents[name]}),rmdir:(function(parent,name){var node=FS.lookupNode(parent,na me);for(var i in node.contents){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}d elete parent.contents[name]}),readdir:(function(node){var entries=[".",".."];for (var key in node.contents){if(!node.contents.hasOwnProperty(key)){continue}entri es.push(key)}return entries}),symlink:(function(parent,newname,oldpath){var node =MEMFS.createNode(parent,newname,511|40960,0);node.link=oldpath;return node}),re adlink:(function(node){if(!FS.isLink(node.mode)){throw new FS.ErrnoError(ERRNO_C ODES.EINVAL)}return node.link})},stream_ops:{read:(function(stream,buffer,offset ,length,position){var contents=stream.node.contents;if(position>=stream.node.use dBytes)return 0;var size=Math.min(stream.node.usedBytes-position,length);assert( size>=0);if(size>8&&contents.subarray){buffer.set(contents.subarray(position,pos ition+size),offset)}else{for(var i=0;i<size;i++)buffer[offset+i]=contents[positi on+i]}return size}),write:(function(stream,buffer,offset,length,position,canOwn) {if(!length)return 0;var node=stream.node;node.timestamp=Date.now();if(buffer.su barray&&(!node.contents||node.contents.subarray)){if(canOwn){node.contents=buffe r.subarray(offset,offset+length);node.usedBytes=length;return length}else if(nod e.usedBytes===0&&position===0){node.contents=new Uint8Array(buffer.subarray(offs et,offset+length));node.usedBytes=length;return length}else if(position+length<= node.usedBytes){node.contents.set(buffer.subarray(offset,offset+length),position );return length}}MEMFS.expandFileStorage(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[offs et+i]}node.usedBytes=Math.max(node.usedBytes,position+length);return length}),ll seek:(function(stream,offset,whence){var position=offset;if(whence===1){position +=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){position+= stream.node.usedBytes}}if(position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL )}return position}),allocate:(function(stream,offset,length){MEMFS.expandFileSto rage(stream.node,offset+length);stream.node.usedBytes=Math.max(stream.node.usedB ytes,offset+length)}),mmap:(function(stream,buffer,offset,length,position,prot,f lags){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENODE V)}var ptr;var allocated;var contents=stream.node.contents;if(!(flags&2)&&(conte nts.buffer===buffer||contents.buffer===buffer.buffer)){allocated=false;ptr=conte nts.byteOffset}else{if(position>0||position+length<stream.node.usedBytes){if(con tents.subarray){contents=contents.subarray(position,position+length)}else{conten ts=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,allocated:allocated}})}};var IDBFS={dbs:{},ind exedDB:(function(){if(typeof indexedDB!=="undefined")return indexedDB;var ret=nu ll;if(typeof window==="object")ret=window.indexedDB||window.mozIndexedDB||window .webkitIndexedDB||window.msIndexedDB;assert(ret,"IDBFS used, but indexedDB not s upported");return ret}),DB_VERSION:21,DB_STORE_NAME:"FILE_DATA",mount:(function( mount){return MEMFS.mount.apply(null,arguments)}),syncfs:(function(mount,populat e,callback){IDBFS.getLocalSet(mount,(function(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=populate?local:remote;IDBFS.reconcile(src, dst,callback)}))}))}),getDB:(function(name,callback){var db=IDBFS.dbs[name];if(d b){return callback(null,db)}var req;try{req=IDBFS.indexedDB().open(name,IDBFS.DB _VERSION)}catch(e){return callback(e)}req.onupgradeneeded=(function(e){var db=e. target.result;var transaction=e.target.transaction;var fileStore;if(db.objectSto reNames.contains(IDBFS.DB_STORE_NAME)){fileStore=transaction.objectStore(IDBFS.D B_STORE_NAME)}else{fileStore=db.createObjectStore(IDBFS.DB_STORE_NAME)}if(!fileS tore.indexNames.contains("timestamp")){fileStore.createIndex("timestamp","timest amp",{unique:false})}});req.onsuccess=(function(){db=req.result;IDBFS.dbs[name]= db;callback(null,db)});req.onerror=(function(e){callback(this.error);e.preventDe fault()})}),getLocalSet:(function(mount,callback){var entries={};function isReal Dir(p){return p!=="."&&p!==".."}function toAbsolute(root){return(function(p){ret urn PATH.join2(root,p)})}var check=FS.readdir(mount.mountpoint).filter(isRealDir ).map(toAbsolute(mount.mountpoint));while(check.length){var path=check.pop();var stat;try{stat=FS.stat(path)}catch(e){return 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",entrie s:entries})}),getRemoteSet:(function(mount,callback){var entries={};IDBFS.getDB( mount.mountpoint,(function(err,db){if(err)return callback(err);var transaction=d b.transaction([IDBFS.DB_STORE_NAME],"readonly");transaction.onerror=(function(e) {callback(this.error);e.preventDefault()});var store=transaction.objectStore(IDB FS.DB_STORE_NAME);var index=store.index("timestamp");index.openKeyCursor().onsuc cess=(function(event){var cursor=event.target.result;if(!cursor){return callback (null,{type:"remote",db:db,entries:entries})}entries[cursor.primaryKey]={timesta mp:cursor.key};cursor.continue()})}))}),loadLocalEntry:(function(path,callback){ var stat,node;try{var lookup=FS.lookupPath(path);node=lookup.node;stat=FS.stat(p ath)}catch(e){return callback(e)}if(FS.isDir(stat.mode)){return callback(null,{t imestamp:stat.mtime,mode:stat.mode})}else if(FS.isFile(stat.mode)){node.contents =MEMFS.getFileDataAsTypedArray(node);return callback(null,{timestamp:stat.mtime, mode:stat.mode,contents:node.contents})}else{return callback(new Error("node typ e not supported"))}}),storeLocalEntry:(function(path,entry,callback){try{if(FS.i sDir(entry.mode)){FS.mkdir(path,entry.mode)}else if(FS.isFile(entry.mode)){FS.wr iteFile(path,entry.contents,{encoding:"binary",canOwn:true})}else{return callbac k(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)}),re moveLocalEntry:(function(path,callback){try{var lookup=FS.lookupPath(path);var s tat=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)}),loadRemoteE ntry:(function(store,path,callback){var req=store.get(path);req.onsuccess=(funct ion(event){callback(null,event.target.result)});req.onerror=(function(e){callbac k(this.error);e.preventDefault()})}),storeRemoteEntry:(function(store,path,entry ,callback){var req=store.put(entry,path);req.onsuccess=(function(){callback(null )});req.onerror=(function(e){callback(this.error);e.preventDefault()})}),removeR emoteEntry:(function(store,path,callback){var req=store.delete(path);req.onsucce ss=(function(){callback(null)});req.onerror=(function(e){callback(this.error);e. preventDefault()})}),reconcile:(function(src,dst,callback){var total=0;var creat e=[];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.entries).forEach((function(key){var e=dst.entri es[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==="remot e"?src.db:dst.db;var transaction=db.transaction([IDBFS.DB_STORE_NAME],"readwrite ");var store=transaction.objectStore(IDBFS.DB_STORE_NAME);function done(err){if( err){if(!done.errored){done.errored=true;return callback(err)}return}if(++comple ted>=total){return callback(null)}}transaction.onerror=(function(e){done(this.er ror);e.preventDefault()});create.sort().forEach((function(path){if(dst.type==="l ocal"){IDBFS.loadRemoteEntry(store,path,(function(err,entry){if(err)return done( err);IDBFS.storeLocalEntry(path,entry,done)}))}else{IDBFS.loadLocalEntry(path,(f unction(err,entry){if(err)return done(err);IDBFS.storeRemoteEntry(store,path,ent ry,done)}))}}));remove.sort().reverse().forEach((function(path){if(dst.type==="l ocal"){IDBFS.removeLocalEntry(path,done)}else{IDBFS.removeRemoteEntry(store,path ,done)}}))})};var NODEFS={isWindows:false,staticInit:(function(){NODEFS.isWindow s=!!process.platform.match(/^win/)}),mount:(function(mount){assert(ENVIRONMENT_I S_NODE);return NODEFS.createNode(null,"/",NODEFS.getMode(mount.opts.root),0)}),c reateNode:(function(parent,name,mode,dev){if(!FS.isDir(mode)&&!FS.isFile(mode)&& !FS.isLink(mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=FS.create Node(parent,name,mode);node.node_ops=NODEFS.node_ops;node.stream_ops=NODEFS.stre am_ops;return node}),getMode:(function(path){var stat;try{stat=fs.lstatSync(path );if(NODEFS.isWindows){stat.mode=stat.mode|(stat.mode&146)>>1}}catch(e){if(!e.co de)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return stat.mode}),realP ath:(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.j oin.apply(null,parts)}),flagsToPermissionStringMap:{0:"r",1:"r+",2:"r+",64:"r",6 5:"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",1090:"a+",1153:"ax",1154:"ax+",1217:"ax",12 18:"ax+",4096:"rs",4098:"rs+"},flagsToPermissionString:(function(flags){if(flags in NODEFS.flagsToPermissionStringMap){return NODEFS.flagsToPermissionStringMap[ flags]}else{return flags}}),node_ops:{getattr:(function(node){var path=NODEFS.re alPath(node);var stat;try{stat=fs.lstatSync(path)}catch(e){if(!e.code)throw e;th row new FS.ErrnoError(ERRNO_CODES[e.code])}if(NODEFS.isWindows&&!stat.blksize){s tat.blksize=4096}if(NODEFS.isWindows&&!stat.blocks){stat.blocks=(stat.size+stat. blksize-1)/stat.blksize|0}return{dev:stat.dev,ino:stat.ino,mode:stat.mode,nlink: stat.nlink,uid:stat.uid,gid:stat.gid,rdev:stat.rdev,size:stat.size,atime:stat.at ime,mtime:stat.mtime,ctime:stat.ctime,blksize: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.timestamp);fs.utimesSync(path,date,date)}if(at tr.size!==undefined){fs.truncateSync(path,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(parent),name);var mode=NODEFS.getMode(path); return NODEFS.createNode(parent,name,mode)}),mknod:(function(parent,name,mode,de v){var node=NODEFS.createNode(parent,name,mode,dev);var path=NODEFS.realPath(nod e);try{if(FS.isDir(node.mode)){fs.mkdirSync(path,node.mode)}else{fs.writeFileSyn c(path,"",{mode:node.mode})}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError (ERRNO_CODES[e.code])}return node}),rename:(function(oldNode,newDir,newName){var oldPath=NODEFS.realPath(oldNode);var newPath=PATH.join2(NODEFS.realPath(newDir) ,newName);try{fs.renameSync(oldPath,newPath)}catch(e){if(!e.code)throw e;throw n ew 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(ERRNO_CODES[e.code])}}),rmdir:(function(par ent,name){var path=PATH.join2(NODEFS.realPath(parent),name);try{fs.rmdirSync(pat h)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),r eaddir:(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,oldPath){var newPath=PATH.join2(NODEFS.realPa th(parent),newName);try{fs.symlinkSync(oldPath,newPath)}catch(e){if(!e.code)thro w 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.rela tive(NODEJS_PATH.resolve(node.mount.opts.root),path);return path}catch(e){if(!e. code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}})},stream_ops:{open:( function(stream){var path=NODEFS.realPath(stream.node);try{if(FS.isFile(stream.n ode.mode)){stream.nfd=fs.openSync(path,NODEFS.flagsToPermissionString(stream.fla gs))}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}} ),close:(function(stream){try{if(FS.isFile(stream.node.mode)&&stream.nfd){fs.clo seSync(stream.nfd)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CO DES[e.code])}}),read:(function(stream,buffer,offset,length,position){if(length== =0)return 0;var nbuffer=new Buffer(length);var res;try{res=fs.readSync(stream.nf d,nbuffer,0,length,position)}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code ])}if(res>0){for(var i=0;i<res;i++){buffer[offset+i]=nbuffer[i]}}return res}),wr ite:(function(stream,buffer,offset,length,position){var nbuffer=new Buffer(buffe r.subarray(offset,offset+length));var res;try{res=fs.writeSync(stream.nfd,nbuffe r,0,length,position)}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}retur n res}),llseek:(function(stream,offset,whence){var position=offset;if(whence===1 ){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){ try{var stat=fs.fstatSync(stream.nfd);position+=stat.size}catch(e){throw new FS. ErrnoError(ERRNO_CODES[e.code])}}}if(position<0){throw new FS.ErrnoError(ERRNO_C ODES.EINVAL)}return position})}};var _stdin=allocate(1,"i32*",ALLOC_STATIC);var _stdout=allocate(1,"i32*",ALLOC_STATIC);var _stderr=allocate(1,"i32*",ALLOC_STAT IC);function _fflush(stream){}var FS={root:null,mounts:[],devices:[null],streams :[],nextInode:1,nameTable:null,currentPath:"/",initialized:false,ignorePermissio ns:true,trackingDelegate:{},tracking:{openFlags:{READ:1,WRITE:2}},ErrnoError:nul l,genericErrors:{},handleFSError:(function(e){if(!(e instanceof FS.ErrnoError))t hrow e+" : "+stackTrace();return ___setErrNo(e.errno)}),lookupPath:(function(pat h,opts){path=PATH.resolve(FS.cwd(),path);opts=opts||{};if(!path)return{path:"",n ode:null};var defaults={follow_mount:true,recurse_count:0};for(var key in defaul ts){if(opts[key]===undefined){opts[key]=defaults[key]}}if(opts.recurse_count>8){ throw new FS.ErrnoError(ERRNO_CODES.ELOOP)}var parts=PATH.normalizeArray(path.sp lit("/").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(islas t&&opts.parent){break}current=FS.lookupNode(current,parts[i]);current_path=PATH. join2(current_path,parts[i]);if(FS.isMountpoint(current)){if(!islast||islast&&op ts.follow_mount){current=current.mounted.root}}if(!islast||opts.follow){var coun t=0;while(FS.isLink(current.mode)){var link=FS.readlink(current_path);current_pa th=PATH.resolve(PATH.dirname(current_path),link);var lookup=FS.lookupPath(curren t_path,{recurse_count:opts.recurse_count});current=lookup.node;if(count++>40){th row new FS.ErrnoError(ERRNO_CODES.ELOOP)}}}}return{path:current_path,node:curren t}}),getPath:(function(node){var path;while(true){if(FS.isRoot(node)){var mount= node.mount.mountpoint;if(!path)return mount;return mount[mount.length-1]!=="/"?m ount+"/"+path:mount+path}path=path?node.name+"/"+path:node.name;node=node.parent }}),hashName:(function(parentid,name){var 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){var hash=FS.hashName(node.parent.id,node.na me);node.name_next=FS.nameTable[hash];FS.nameTable[hash]=node}),hashRemoveNode:( function(node){var hash=FS.hashName(node.parent.id,node.name);if(FS.nameTable[ha sh]===node){FS.nameTable[hash]=node.name_next}else{var current=FS.nameTable[hash ];while(current){if(current.name_next===node){current.name_next=node.name_next;b reak}current=current.name_next}}}),lookupNode:(function(parent,name){var err=FS. mayLookup(parent);if(err){throw new FS.ErrnoError(err,parent)}var hash=FS.hashNa me(parent.id,name);for(var node=FS.nameTable[hash];node;node=node.name_next){var nodeName=node.name;if(node.parent.id===parent.id&&nodeName===name){return node} }return FS.lookup(parent,name)}),createNode:(function(parent,name,mode,rdev){if( !FS.FSNode){FS.FSNode=(function(parent,name,mode,rdev){if(!parent){parent=this}t his.parent=parent;this.mount=parent.mount;this.mounted=null;this.id=FS.nextInode ++;this.name=name;this.mode=mode;this.node_ops={};this.stream_ops={};this.rdev=r dev});FS.FSNode.prototype={};var readMode=292|73;var writeMode=146;Object.define Properties(FS.FSNode.prototype,{read:{get:(function(){return(this.mode&readMode) ===readMode}),set:(function(val){val?this.mode|=readMode:this.mode&=~readMode})} ,write:{get:(function(){return(this.mode&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(parent,name,mode,rdev);FS.hashAddNode(node);r eturn node}),destroyNode:(function(node){FS.hashRemoveNode(node)}),isRoot:(funct ion(node){return node===node.parent}),isMountpoint:(function(node){return!!node. mounted}),isFile:(function(mode){return(mode&61440)===32768}),isDir:(function(mo de){return(mode&61440)===16384}),isLink:(function(mode){return(mode&61440)===409 60}),isChrdev:(function(mode){return(mode&61440)===8192}),isBlkdev:(function(mod e){return(mode&61440)===24576}),isFIFO:(function(mode){return(mode&61440)===4096 }),isSocket:(function(mode){return(mode&49152)===49152}),flagModes:{"r":0,"rs":1 052672,"r+":2,"w":577,"wx":705,"xw":705,"w+":578,"wx+":706,"xw+":706,"a":1089,"a x":1217,"xa":1217,"a+":1090,"ax+":1218,"xa+":1218},modeStringToFlags:(function(s tr){var flags=FS.flagModes[str];if(typeof flags==="undefined"){throw new Error(" Unknown file open mode: "+str)}return flags}),flagsToPermissionString:(function( flag){var accmode=flag&2097155;var perms=["r","w","rw"][accmode];if(flag&512){pe rms+="w"}return perms}),nodePermissions:(function(node,perms){if(FS.ignorePermis sions){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.EA CCES}else if(perms.indexOf("x")!==-1&&!(node.mode&73)){return ERRNO_CODES.EACCES }return 0}),mayLookup:(function(dir){var err=FS.nodePermissions(dir,"x");if(err) return err;if(!dir.node_ops.lookup)return ERRNO_CODES.EACCES;return 0}),mayCreat e:(function(dir,name){try{var node=FS.lookupNode(dir,name);return ERRNO_CODES.EE XIST}catch(e){}return FS.nodePermissions(dir,"wx")}),mayDelete:(function(dir,nam e,isdir){var node;try{node=FS.lookupNode(dir,name)}catch(e){return e.errno}var e rr=FS.nodePermissions(dir,"wx");if(err){return err}if(isdir){if(!FS.isDir(node.m ode)){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.EISD IR}}return 0}),mayOpen:(function(node,flags){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){return ERRNO_CODES.EISDIR}}return FS.nodePerm issions(node,FS.flagsToPermissionString(flags))}),MAX_OPEN_FDS:4096,nextfd:(func tion(fd_start,fd_end){fd_start=fd_start||0;fd_end=fd_end||FS.MAX_OPEN_FDS;for(va r fd=fd_start;fd<=fd_end;fd++){if(!FS.streams[fd]){return fd}}throw new FS.Errno Error(ERRNO_CODES.EMFILE)}),getStream:(function(fd){return FS.streams[fd]}),crea teStream:(function(stream,fd_start,fd_end){if(!FS.FSStream){FS.FSStream=(functio n(){});FS.FSStream.prototype={};Object.defineProperties(FS.FSStream.prototype,{o bject:{get:(function(){return this.node}),set:(function(val){this.node=val})},is Read:{get:(function(){return(this.flags&2097155)!==1})},isWrite:{get:(function() {return(this.flags&2097155)!==0})},isAppend:{get:(function(){return this.flags&1 024})}})}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:(function(fd){FS.streams[fd]=null}),getStre amFromPtr:(function(ptr){return FS.streams[ptr-1]}),getPtrForStream:(function(st ream){return stream?stream.fd+1:0}),chrdev_stream_ops:{open:(function(stream){va r device=FS.getDevice(stream.node.rdev);stream.stream_ops=device.stream_ops;if(s tream.stream_ops.open){stream.stream_ops.open(stream)}}),llseek:(function(){thro w new FS.ErrnoError(ERRNO_CODES.ESPIPE)})},major:(function(dev){return dev>>8}), minor:(function(dev){return dev&255}),makedev:(function(ma,mi){return ma<<8|mi}) ,registerDevice:(function(dev,ops){FS.devices[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.pu sh.apply(check,m.mounts)}return mounts}),syncfs:(function(populate,callback){if( typeof populate==="function"){callback=populate;populate=false}var mounts=FS.get Mounts(FS.root.mount);var completed=0;function done(err){if(err){if(!done.errore d){done.errored=true;return callback(err)}return}if(++completed>=mounts.length){ callback(null)}}mounts.forEach((function(mount){if(!mount.type.syncfs){return do ne(null)}mount.type.syncfs(mount,populate,done)}))}),mount:(function(type,opts,m ountpoint){var root=mountpoint==="/";var pseudo=!mountpoint;var node;if(root&&FS .root){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}else if(!root&&!pseudo){var lo okup=FS.lookupPath(mountpoint,{follow_mount:false});mountpoint=lookup.path;node= lookup.node;if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY) }if(!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}}var moun t={type:type,opts:opts,mountpoint:mountpoint,mounts:[]};var mountRoot=type.mount (mount);mountRoot.mount=mount;mount.root=mountRoot;if(root){FS.root=mountRoot}el se if(node){node.mounted=mount;if(node.mount){node.mount.mounts.push(mount)}}ret urn mountRoot}),unmount:(function(mountpoint){var lookup=FS.lookupPath(mountpoin t,{follow_mount:false});if(!FS.isMountpoint(lookup.node)){throw new FS.ErrnoErro r(ERRNO_CODES.EINVAL)}var node=lookup.node;var mount=node.mounted;var mounts=FS. getMounts(mount);Object.keys(FS.nameTable).forEach((function(hash){var current=F S.nameTable[hash];while(current){var next=current.name_next;if(mounts.indexOf(cu rrent.mount)!==-1){FS.destroyNode(current)}current=next}}));node.mounted=null;va r 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,nam e)}),mknod:(function(path,mode,dev){var lookup=FS.lookupPath(path,{parent:true}) ;var parent=lookup.node;var name=PATH.basename(path);if(!name||name==="."||name= ==".."){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var err=FS.mayCreate(parent, name);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.mknod){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.mknod(parent,name,mode,d ev)}),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!==un defined?mode:511;mode&=511|512;mode|=16384;return FS.mknod(path,mode,0)}),mkdev: (function(path,mode,dev){if(typeof dev==="undefined"){dev=mode;mode=438}mode|=81 92;return FS.mknod(path,mode,dev)}),symlink:(function(oldpath,newpath){if(!PATH. resolve(oldpath)){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}var lookup=FS.look upPath(newpath,{parent:true});var parent=lookup.node;if(!parent){throw new FS.Er rnoError(ERRNO_CODES.ENOENT)}var newname=PATH.basename(newpath);var err=FS.mayCr eate(parent,newname);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.sy mlink){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.symlink (parent,newname,oldpath)}),rename:(function(old_path,new_path){var old_dirname=P ATH.dirname(old_path);var new_dirname=PATH.dirname(new_path);var old_name=PATH.b asename(old_path);var new_name=PATH.basename(new_path);var lookup,old_dir,new_di r;try{lookup=FS.lookupPath(old_path,{parent:true});old_dir=lookup.node;lookup=FS .lookupPath(new_path,{parent:true});new_dir=lookup.node}catch(e){throw new FS.Er rnoError(ERRNO_CODES.EBUSY)}if(!old_dir||!new_dir)throw new FS.ErrnoError(ERRNO_ CODES.ENOENT);if(old_dir.mount!==new_dir.mount){throw new FS.ErrnoError(ERRNO_CO DES.EXDEV)}var old_node=FS.lookupNode(old_dir,old_name);var relative=PATH.relati ve(old_path,new_dirname);if(relative.charAt(0)!=="."){throw new FS.ErrnoError(ER RNO_CODES.EINVAL)}relative=PATH.relative(new_path,old_dirname);if(relative.charA t(0)!=="."){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}var new_node;try{new_ node=FS.lookupNode(new_dir,new_name)}catch(e){}if(old_node===new_node){return}va r isdir=FS.isDir(old_node.mode);var err=FS.mayDelete(old_dir,old_name,isdir);if( err){throw new FS.ErrnoError(err)}err=new_node?FS.mayDelete(new_dir,new_name,isd ir):FS.mayCreate(new_dir,new_name);if(err){throw new FS.ErrnoError(err)}if(!old_ dir.node_ops.rename){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoi nt(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.tra ckingDelegate["willMovePath"](old_path,new_path)}}catch(e){console.log("FS.track ingDelegate['willMovePath']('"+old_path+"', '"+new_path+"') threw an exception: "+e.message)}FS.hashRemoveNode(old_node);try{old_dir.node_ops.rename(old_node,ne w_dir,new_name)}catch(e){throw e}finally{FS.hashAddNode(old_node)}try{if(FS.trac kingDelegate["onMovePath"])FS.trackingDelegate["onMovePath"](old_path,new_path)} catch(e){console.log("FS.trackingDelegate['onMovePath']('"+old_path+"', '"+new_p ath+"') threw an exception: "+e.message)}}),rmdir:(function(path){var lookup=FS. lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(pat h);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.Errno Error(ERRNO_CODES.EPERM)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO _CODES.EBUSY)}try{if(FS.trackingDelegate["willDeletePath"]){FS.trackingDelegate[ "willDeletePath"](path)}}catch(e){console.log("FS.trackingDelegate['willDeletePa th']('"+path+"') threw an exception: "+e.message)}parent.node_ops.rmdir(parent,n ame);FS.destroyNode(node);try{if(FS.trackingDelegate["onDeletePath"])FS.tracking Delegate["onDeletePath"](path)}catch(e){console.log("FS.trackingDelegate['onDele tePath']('"+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(ERRNO_CODES.ENOTDIR)}return node.node_ops. readdir(node)}),unlink:(function(path){var lookup=FS.lookupPath(path,{parent:tru e});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(p arent,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.u nlink){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(node)){thro w new FS.ErrnoError(ERRNO_CODES.EBUSY)}try{if(FS.trackingDelegate["willDeletePat h"]){FS.trackingDelegate["willDeletePath"](path)}}catch(e){console.log("FS.track ingDelegate['willDeletePath']('"+path+"') threw an exception: "+e.message)}paren t.node_ops.unlink(parent,name);FS.destroyNode(node);try{if(FS.trackingDelegate[" onDeletePath"])FS.trackingDelegate["onDeletePath"](path)}catch(e){console.log("F S.trackingDelegate['onDeletePath']('"+path+"') 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.EINVAL)}return PATH.resolve(FS.getPath(loo kup.node.parent),link.node_ops.readlink(link))}),stat:(function(path,dontFollow) {var lookup=FS.lookupPath(path,{follow:!dontFollow});var node=lookup.node;if(!no de){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(!node.node_ops.getattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return node.node_ops.getattr(node)}),lstat :(function(path){return FS.stat(path,true)}),chmod:(function(path,mode,dontFollo w){var node;if(typeof path==="string"){var lookup=FS.lookupPath(path,{follow:!do ntFollow});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.node_ops.setattr(node,{mode:mode&4095|node .mode&~4095,timestamp:Date.now()})}),lchmod:(function(path,mode){FS.chmod(path,m ode,true)}),fchmod:(function(fd,mode){var stream=FS.getStream(fd);if(!stream){th row new FS.ErrnoError(ERRNO_CODES.EBADF)}FS.chmod(stream.node,mode)}),chown:(fun ction(path,uid,gid,dontFollow){var node;if(typeof path==="string"){var lookup=FS .lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}if(!node. node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.node_ops.setat tr(node,{timestamp:Date.now()})}),lchown:(function(path,uid,gid){FS.chown(path,u id,gid,true)}),fchown:(function(fd,uid,gid){var stream=FS.getStream(fd);if(!stre am){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}FS.chown(stream.node,uid,gid)}),t runcate:(function(path,len){if(len<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL )}var node;if(typeof path==="string"){var lookup=FS.lookupPath(path,{follow:true });node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.Errno Error(ERRNO_CODES.EPERM)}if(FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_C ODES.EISDIR)}if(!FS.isFile(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVA L)}var err=FS.nodePermissions(node,"w");if(err){throw new FS.ErrnoError(err)}nod e.node_ops.setattr(node,{size:len,timestamp:Date.now()})}),ftruncate:(function(f d,len){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_COD ES.EBADF)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EIN VAL)}FS.truncate(stream.node,len)}),utime:(function(path,atime,mtime){var lookup =FS.lookupPath(path,{follow:true});var node=lookup.node;node.node_ops.setattr(no de,{timestamp:Math.max(atime,mtime)})}),open:(function(path,flags,mode,fd_start, fd_end){if(path===""){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}flags=typeof f lags==="string"?FS.modeStringToFlags(flags):flags;mode=typeof mode==="undefined" ?438:mode;if(flags&64){mode=mode&4095|32768}else{mode=0}var node;if(typeof path= =="object"){node=path}else{path=PATH.normalize(path);try{var lookup=FS.lookupPat h(path,{follow:!(flags&131072)});node=lookup.node}catch(e){}}var created=false;i f(flags&64){if(node){if(flags&128){throw 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 new FS.ErrnoError(err)}}if(flags&512){FS.tr uncate(node,0)}flags&=~(128|512);var stream=FS.createStream({node:node,path:FS.g etPath(node),flags:flags,seekable:true,position:0,stream_ops:node.stream_ops,ung otten:[],error:false},fd_start,fd_end);if(stream.stream_ops.open){stream.stream_ ops.open(stream)}if(Module["logReadFiles"]&&!(flags&1)){if(!FS.readFiles)FS.read Files={};if(!(path in FS.readFiles)){FS.readFiles[path]=1;Module["printErr"]("re ad file: "+path)}}try{if(FS.trackingDelegate["onOpenFile"]){var trackingFlags=0; if((flags&2097155)!==1){trackingFlags|=FS.tracking.openFlags.READ}if((flags&2097 155)!==0){trackingFlags|=FS.tracking.openFlags.WRITE}FS.trackingDelegate["onOpen File"](path,trackingFlags)}}catch(e){console.log("FS.trackingDelegate['onOpenFil e']('"+path+"', flags) threw an exception: "+e.message)}return stream}),close:(f unction(stream){try{if(stream.stream_ops.close){stream.stream_ops.close(stream)} }catch(e){throw e}finally{FS.closeStream(stream.fd)}}),llseek:(function(stream,o ffset,whence){if(!stream.seekable||!stream.stream_ops.llseek){throw new FS.Errno Error(ERRNO_CODES.ESPIPE)}stream.position=stream.stream_ops.llseek(stream,offset ,whence);stream.ungotten=[];return stream.position}),read:(function(stream,buffe r,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_CODE S.EBADF)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISD IR)}if(!stream.stream_ops.read){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var seeking=true;if(typeof position==="undefined"){position=stream.position;seeking= false}else if(!stream.seekable){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesRead=stream.stream_ops.read(stream,buffer,offset,length,position);if(!seeki ng)stream.position+=bytesRead;return bytesRead}),write:(function(stream,buffer,o ffset,length,position,canOwn){if(length<0||position<0){throw new FS.ErrnoError(E RRNO_CODES.EINVAL)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_ CODES.EBADF)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES. EISDIR)}if(!stream.stream_ops.write){throw new FS.ErrnoError(ERRNO_CODES.EINVAL) }if(stream.flags&1024){FS.llseek(stream,0,2)}var seeking=true;if(typeof position ==="undefined"){position=stream.position;seeking=false}else if(!stream.seekable) {throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesWritten=stream.stream_ops. write(stream,buffer,offset,length,position,canOwn);if(!seeking)stream.position+= bytesWritten;try{if(stream.path&&FS.trackingDelegate["onWriteToFile"])FS.trackin gDelegate["onWriteToFile"](stream.path)}catch(e){console.log("FS.trackingDelegat e['onWriteToFile']('"+path+"') threw an exception: "+e.message)}return bytesWrit ten}),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.E rrnoError(ERRNO_CODES.EBADF)}if(!FS.isFile(stream.node.mode)&&!FS.isDir(node.mod e)){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}if(!stream.stream_ops.allocate){ throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP)}stream.stream_ops.allocate(strea m,offset,length)}),mmap:(function(stream,buffer,offset,length,position,prot,flag s){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 str eam.stream_ops.mmap(stream,buffer,offset,length,position,prot,flags)}),ioctl:(fu nction(stream,cmd,arg){if(!stream.stream_ops.ioctl){throw new FS.ErrnoError(ERRN O_CODES.ENOTTY)}return stream.stream_ops.ioctl(stream,cmd,arg)}),readFile:(funct ion(path,opts){opts=opts||{};opts.flags=opts.flags||"r";opts.encoding=opts.encod ing||"binary";if(opts.encoding!=="utf8"&&opts.encoding!=="binary"){throw new Err or('Invalid encoding type "'+opts.encoding+'"')}var ret;var stream=FS.open(path, opts.flags);var stat=FS.stat(path);var length=stat.size;var buf=new Uint8Array(l ength);FS.read(stream,buf,0,length,0);if(opts.encoding==="utf8"){ret=UTF8ArrayTo String(buf,0)}else if(opts.encoding==="binary"){ret=buf}FS.close(stream);return ret}),writeFile:(function(path,data,opts){opts=opts||{};opts.flags=opts.flags||" w";opts.encoding=opts.encoding||"utf8";if(opts.encoding!=="utf8"&&opts.encoding! =="binary"){throw new Error('Invalid encoding type "'+opts.encoding+'"')}var str eam=FS.open(path,opts.flags,opts.mode);if(opts.encoding==="utf8"){var buf=new Ui nt8Array(lengthBytesUTF8(data)+1);var actualNumBytes=stringToUTF8Array(data,buf, 0,buf.length);FS.write(stream,buf,0,actualNumBytes,0,opts.canOwn)}else if(opts.e ncoding==="binary"){FS.write(stream,data,0,data.length,0,opts.canOwn)}FS.close(s tream)}),cwd:(function(){return FS.currentPath}),chdir:(function(path){var looku p=FS.lookupPath(path,{follow:true});if(!FS.isDir(lookup.node.mode)){throw new FS .ErrnoError(ERRNO_CODES.ENOTDIR)}var err=FS.nodePermissions(lookup.node,"x");if( err){throw new FS.ErrnoError(err)}FS.currentPath=lookup.path}),createDefaultDire ctories:(function(){FS.mkdir("/tmp");FS.mkdir("/home");FS.mkdir("/home/web_user" )}),createDefaultDevices:(function(){FS.mkdir("/dev");FS.registerDevice(FS.maked ev(1,3),{read:(function(){return 0}),write:(function(){return 0})});FS.mkdev("/d ev/null",FS.makedev(1,3));TTY.register(FS.makedev(5,0),TTY.default_tty_ops);TTY. register(FS.makedev(6,0),TTY.default_tty1_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 Uint8Array(1);random_device=(function(){crypto. getRandomValues(randomBuffer);return randomBuffer[0]})}else if(ENVIRONMENT_IS_NO DE){random_device=(function(){return require("crypto").randomBytes(1)[0]})}else{ random_device=(function(){return Math.random()*256|0})}FS.createDevice("/dev","r andom",random_device);FS.createDevice("/dev","urandom",random_device);FS.mkdir(" /dev/shm");FS.mkdir("/dev/shm/tmp")}),createStandardStreams:(function(){if(Modul e["stdin"]){FS.createDevice("/dev","stdin",Module["stdin"])}else{FS.symlink("/de v/tty","/dev/stdin")}if(Module["stdout"]){FS.createDevice("/dev","stdout",null,M odule["stdout"])}else{FS.symlink("/dev/tty","/dev/stdout")}if(Module["stderr"]){ FS.createDevice("/dev","stderr",null,Module["stderr"])}else{FS.symlink("/dev/tty 1","/dev/stderr")}var stdin=FS.open("/dev/stdin","r");HEAP32[_stdin>>2]=FS.getPt rForStream(stdin);assert(stdin.fd===0,"invalid handle for stdin ("+stdin.fd+")") ;var stdout=FS.open("/dev/stdout","w");HEAP32[_stdout>>2]=FS.getPtrForStream(std out);assert(stdout.fd===1,"invalid handle for stdout ("+stdout.fd+")");var stder r=FS.open("/dev/stderr","w");HEAP32[_stderr>>2]=FS.getPtrForStream(stderr);asser t(stderr.fd===2,"invalid handle for stderr ("+stderr.fd+")")}),ensureErrnoError: (function(){if(FS.ErrnoError)return;FS.ErrnoError=function ErrnoError(errno,node ){this.node=node;this.setErrno=(function(errno){this.errno=errno;for(var key in ERRNO_CODES){if(ERRNO_CODES[key]===errno){this.code=key;break}}});this.setErrno( errno);this.message=ERRNO_MESSAGES[errno]};FS.ErrnoError.prototype=new Error;FS. ErrnoError.prototype.constructor=FS.ErrnoError;[ERRNO_CODES.ENOENT].forEach((fun ction(code){FS.genericErrors[code]=new FS.ErrnoError(code);FS.genericErrors[code ].stack="<generic error, no stack>"}))}),staticInit:(function(){FS.ensureErrnoEr ror();FS.nameTable=new Array(4096);FS.mount(MEMFS,{},"/");FS.createDefaultDirect ories();FS.createDefaultDevices()}),init:(function(input,output,error){assert(!F S.init.initialized,"FS.init was previously called. If you want to initialize lat er with custom parameters, remove any earlier calls (note that one is automatica lly added to the generated code)");FS.init.initialized=true;FS.ensureErrnoError( );Module["stdin"]=input||Module["stdin"];Module["stdout"]=output||Module["stdout "];Module["stderr"]=error||Module["stderr"];FS.createStandardStreams()}),quit:(f unction(){FS.init.initialized=false;for(var i=0;i<FS.streams.length;i++){var str eam=FS.streams[i];if(!stream){continue}FS.close(stream)}}),getMode:(function(can Read,canWrite){var mode=0;if(canRead)mode|=292|73;if(canWrite)mode|=146;return m ode}),joinPath:(function(parts,forceRelative){var path=PATH.join.apply(null,part s);if(forceRelative&&path[0]=="/")path=path.substr(1);return path}),absolutePath :(function(relative,base){return PATH.resolve(base,relative)}),standardizePath:( function(path){return PATH.normalize(path)}),findObject:(function(path,dontResol veLastLink){var ret=FS.analyzePath(path,dontResolveLastLink);if(ret.exists){retu rn ret.object}else{___setErrNo(ret.error);return null}}),analyzePath:(function(p ath,dontResolveLastLink){try{var lookup=FS.lookupPath(path,{follow:!dontResolveL astLink});path=lookup.path}catch(e){}var ret={isRoot:false,exists:false,error:0, name:null,path:null,object:null,parentExists:false,parentPath:null,parentObject: null};try{var lookup=FS.lookupPath(path,{parent:true});ret.parentExists=true;ret .parentPath=lookup.path;ret.parentObject=lookup.node;ret.name=PATH.basename(path );lookup=FS.lookupPath(path,{follow:!dontResolveLastLink});ret.exists=true;ret.p ath=lookup.path;ret.object=lookup.node;ret.name=lookup.node.name;ret.isRoot=look up.path==="/"}catch(e){ret.error=e.errno}return ret}),createFolder:(function(par ent,name,canRead,canWrite){var path=PATH.join2(typeof parent==="string"?parent:F S.getPath(parent),name);var mode=FS.getMode(canRead,canWrite);return FS.mkdir(pa th,mode)}),createPath:(function(parent,path,canRead,canWrite){parent=typeof pare nt==="string"?parent:FS.getPath(parent);var parts=path.split("/").reverse();whil e(parts.length){var part=parts.pop();if(!part)continue;var current=PATH.join2(pa rent,part);try{FS.mkdir(current)}catch(e){}parent=current}return current}),creat eFile:(function(parent,name,properties,canRead,canWrite){var path=PATH.join2(typ eof parent==="string"?parent:FS.getPath(parent),name);var mode=FS.getMode(canRea d,canWrite);return FS.create(path,mode)}),createDataFile:(function(parent,name,d ata,canRead,canWrite,canOwn){var path=name?PATH.join2(typeof parent==="string"?p arent:FS.getPath(parent),name):parent;var mode=FS.getMode(canRead,canWrite);var node=FS.create(path,mode);if(data){if(typeof data==="string"){var arr=new Array( data.length);for(var i=0,len=data.length;i<len;++i)arr[i]=data.charCodeAt(i);dat a=arr}FS.chmod(node,mode|146);var stream=FS.open(node,"w");FS.write(stream,data, 0,data.length,0,canOwn);FS.close(stream);FS.chmod(node,mode)}return node}),creat eDevice:(function(parent,name,input,output){var path=PATH.join2(typeof parent=== "string"?parent:FS.getPath(parent),name);var mode=FS.getMode(!!input,!!output);i f(!FS.createDevice.major)FS.createDevice.major=64;var dev=FS.makedev(FS.createDe vice.major++,0);FS.registerDevice(dev,{open:(function(stream){stream.seekable=fa lse}),close:(function(stream){if(output&&output.buffer&&output.buffer.length){ou tput(10)}}),read:(function(stream,buffer,offset,length,pos){var bytesRead=0;for( var i=0;i<length;i++){var result;try{result=input()}catch(e){throw new FS.ErrnoE rror(ERRNO_CODES.EIO)}if(result===undefined&&bytesRead===0){throw new FS.ErrnoEr ror(ERRNO_CODES.EAGAIN)}if(result===null||result===undefined)break;bytesRead++;b uffer[offset+i]=result}if(bytesRead){stream.node.timestamp=Date.now()}return byt esRead}),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.EI O)}}if(length){stream.node.timestamp=Date.now()}return i})});return FS.mkdev(pat h,mode,dev)}),createLink:(function(parent,name,target,canRead,canWrite){var path =PATH.join2(typeof parent==="string"?parent:FS.getPath(parent),name);return FS.s ymlink(target,path)}),forceLoadFile:(function(obj){if(obj.isDevice||obj.isFolder ||obj.link||obj.contents)return true;var success=true;if(typeof XMLHttpRequest!= ="undefined"){throw new Error("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.")}else if(Module ["read"]){try{obj.contents=intArrayFromString(Module["read"](obj.url),true);obj. usedBytes=obj.contents.length}catch(e){success=false}}else{throw new Error("Cann ot load without read() or XMLHttpRequest.")}if(!success)___setErrNo(ERRNO_CODES. EIO);return success}),createLazyFile:(function(parent,name,url,canRead,canWrite) {function LazyUint8Array(){this.lengthKnown=false;this.chunks=[]}LazyUint8Array. prototype.get=function LazyUint8Array_get(idx){if(idx>this.length-1||idx<0){retu rn undefined}var chunkOffset=idx%this.chunkSize;var chunkNum=idx/this.chunkSize| 0;return this.getter(chunkNum)[chunkOffset]};LazyUint8Array.prototype.setDataGet ter=function LazyUint8Array_setDataGetter(getter){this.getter=getter};LazyUint8A rray.prototype.cacheLength=function LazyUint8Array_cacheLength(){var xhr=new XML HttpRequest;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.getResponseHeader("Content-length"));var h eader;var hasByteServing=(header=xhr.getResponseHeader("Accept-Ranges"))&&header ==="bytes";var chunkSize=1024*1024;if(!hasByteServing)chunkSize=datalength;var d oXHR=(function(from,to){if(from>to)throw new Error("invalid range ("+from+", "+t o+") or no bytes requested!");if(to>datalength-1)throw new Error("only "+datalen gth+" bytes available! programmer error!");var xhr=new XMLHttpRequest;xhr.open(" GET",url,false);if(datalength!==chunkSize)xhr.setRequestHeader("Range","bytes="+ from+"-"+to);if(typeof Uint8Array!="undefined")xhr.responseType="arraybuffer";if (xhr.overrideMimeType){xhr.overrideMimeType("text/plain; charset=x-user-defined" )}xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw n ew Error("Couldn't load "+url+". Status: "+xhr.status);if(xhr.response!==undefin ed){return new Uint8Array(xhr.response||[])}else{return intArrayFromString(xhr.r esponseText||"",true)}});var lazyArray=this;lazyArray.setDataGetter((function(ch unkNum){var start=chunkNum*chunkSize;var end=(chunkNum+1)*chunkSize-1;end=Math.m in(end,datalength-1);if(typeof lazyArray.chunks[chunkNum]==="undefined"){lazyArr ay.chunks[chunkNum]=doXHR(start,end)}if(typeof lazyArray.chunks[chunkNum]==="und efined")throw new Error("doXHR failed!");return lazyArray.chunks[chunkNum]}));th is._length=datalength;this._chunkSize=chunkSize;this.lengthKnown=true};if(typeof XMLHttpRequest!=="undefined"){if(!ENVIRONMENT_IS_WORKER)throw"Cannot do synchro nous binary XHRs outside webworkers in modern browsers. Use --embed-file or --pr eload-file in emcc";var lazyArray=new LazyUint8Array;Object.defineProperty(lazyA rray,"length",{get:(function(){if(!this.lengthKnown){this.cacheLength()}return t his._length})});Object.defineProperty(lazyArray,"chunkSize",{get:(function(){if( !this.lengthKnown){this.cacheLength()}return this._chunkSize})});var properties= {isDevice:false,contents:lazyArray}}else{var properties={isDevice:false,url:url} }var node=FS.createFile(parent,name,properties,canRead,canWrite);if(properties.c ontents){node.contents=properties.contents}else if(properties.url){node.contents =null;node.url=properties.url}Object.defineProperty(node,"usedBytes",{get:(funct ion(){return this.contents.length})});var stream_ops={};var keys=Object.keys(nod e.stream_ops);keys.forEach((function(key){var fn=node.stream_ops[key];stream_ops [key]=function forceLoadLazyFile(){if(!FS.forceLoadFile(node)){throw new FS.Errn oError(ERRNO_CODES.EIO)}return fn.apply(null,arguments)}}));stream_ops.read=func tion stream_ops_read(stream,buffer,offset,length,position){if(!FS.forceLoadFile( node)){throw new FS.ErrnoError(ERRNO_CODES.EIO)}var contents=stream.node.content s;if(position>=contents.length)return 0;var size=Math.min(contents.length-positi on,length);assert(size>=0);if(contents.slice){for(var i=0;i<size;i++){buffer[off set+i]=contents[position+i]}}else{for(var i=0;i<size;i++){buffer[offset+i]=conte nts.get(position+i)}}return size};node.stream_ops=stream_ops;return node}),creat ePreloadedFile:(function(parent,name,url,canRead,canWrite,onload,onerror,dontCre ateFile,canOwn){Browser.init();var fullname=name?PATH.resolve(PATH.join2(parent, name)):parent;function processData(byteArray){function finish(byteArray){if(!don tCreateFile){FS.createDataFile(parent,name,byteArray,canRead,canWrite,canOwn)}if (onload)onload();removeRunDependency("cp "+fullname)}var handled=false;Module["p reloadPlugins"].forEach((function(plugin){if(handled)return;if(plugin["canHandle "](fullname)){plugin["handle"](byteArray,fullname,finish,(function(){if(onerror) onerror();removeRunDependency("cp "+fullname)}));handled=true}}));if(!handled)fi nish(byteArray)}addRunDependency("cp "+fullname);if(typeof url=="string"){Browse r.asyncLoad(url,(function(byteArray){processData(byteArray)}),onerror)}else{proc essData(url)}}),indexedDB:(function(){return window.indexedDB||window.mozIndexed DB||window.webkitIndexedDB||window.msIndexedDB}),DB_NAME:(function(){return"EM_F S_"+window.location.pathname}),DB_VERSION:20,DB_STORE_NAME:"FILE_DATA",saveFiles ToDB:(function(paths,onload,onerror){onload=onload||(function(){});onerror=onerr or||(function(){});var indexedDB=FS.indexedDB();try{var openRequest=indexedDB.op en(FS.DB_NAME(),FS.DB_VERSION)}catch(e){return onerror(e)}openRequest.onupgraden eeded=function openRequest_onupgradeneeded(){console.log("creating db");var db=o penRequest.result;db.createObjectStore(FS.DB_STORE_NAME)};openRequest.onsuccess= function openRequest_onsuccess(){var db=openRequest.result;var transaction=db.tr ansaction([FS.DB_STORE_NAME],"readwrite");var files=transaction.objectStore(FS.D B_STORE_NAME);var ok=0,fail=0,total=paths.length;function finish(){if(fail==0)on load();else onerror()}paths.forEach((function(path){var putRequest=files.put(FS. analyzePath(path).object.contents,path);putRequest.onsuccess=function putRequest _onsuccess(){ok++;if(ok+fail==total)finish()};putRequest.onerror=function putReq uest_onerror(){fail++;if(ok+fail==total)finish()}}));transaction.onerror=onerror };openRequest.onerror=onerror}),loadFilesFromDB:(function(paths,onload,onerror){ onload=onload||(function(){});onerror=onerror||(function(){});var indexedDB=FS.i ndexedDB();try{var openRequest=indexedDB.open(FS.DB_NAME(),FS.DB_VERSION)}catch( e){return onerror(e)}openRequest.onupgradeneeded=onerror;openRequest.onsuccess=f unction openRequest_onsuccess(){var db=openRequest.result;try{var transaction=db .transaction([FS.DB_STORE_NAME],"readonly")}catch(e){onerror(e);return}var files =transaction.objectStore(FS.DB_STORE_NAME);var ok=0,fail=0,total=paths.length;fu nction finish(){if(fail==0)onload();else onerror()}paths.forEach((function(path) {var getRequest=files.get(path);getRequest.onsuccess=function getRequest_onsucce ss(){if(FS.analyzePath(path).exists){FS.unlink(path)}FS.createDataFile(PATH.dirn ame(path),PATH.basename(path),getRequest.result,true,true,true);ok++;if(ok+fail= =total)finish()};getRequest.onerror=function getRequest_onerror(){fail++;if(ok+f ail==total)finish()}}));transaction.onerror=onerror};openRequest.onerror=onerror })};function _mkport(){throw"TODO"}var SOCKFS={mount:(function(mount){Module["we bsocket"]=Module["websocket"]&&"object"===typeof Module["websocket"]?Module["web socket"]:{};Module["websocket"]._callbacks={};Module["websocket"]["on"]=(functio n(event,callback){if("function"===typeof callback){this._callbacks[event]=callba ck}return this});Module["websocket"].emit=(function(event,param){if("function"== =typeof this._callbacks[event]){this._callbacks[event].call(this,param)}});retur n FS.createNode(null,"/",16384|511,0)}),createSocket:(function(family,type,proto col){var streaming=type==1;if(protocol){assert(streaming==(protocol==6))}var soc k={family:family,type:type,protocol:protocol,server:null,error:null,peers:{},pen ding:[],recv_queue:[],sock_ops:SOCKFS.websocket_sock_ops};var name=SOCKFS.nextna me();var node=FS.createNode(SOCKFS.root,name,49152,0);node.sock=sock;var stream= FS.createStream({path:name,node:node,flags:FS.modeStringToFlags("r+"),seekable:f alse,stream_ops:SOCKFS.stream_ops});sock.stream=stream;return sock}),getSocket:( function(fd){var stream=FS.getStream(fd);if(!stream||!FS.isSocket(stream.node.mo de)){return null}return stream.node.sock}),stream_ops:{poll:(function(stream){va r sock=stream.node.sock;return sock.sock_ops.poll(sock)}),ioctl:(function(stream ,request,varargs){var sock=stream.node.sock;return sock.sock_ops.ioctl(sock,requ est,varargs)}),read:(function(stream,buffer,offset,length,position){var sock=str eam.node.sock;var msg=sock.sock_ops.recvmsg(sock,length);if(!msg){return 0}buffe r.set(msg.buffer,offset);return msg.buffer.length}),write:(function(stream,buffe r,offset,length,position){var sock=stream.node.sock;return sock.sock_ops.sendmsg (sock,buffer,offset,length)}),close:(function(stream){var sock=stream.node.sock; sock.sock_ops.close(sock)})},nextname:(function(){if(!SOCKFS.nextname.current){S OCKFS.nextname.current=0}return"socket["+SOCKFS.nextname.current++ +"]"}),websoc ket_sock_ops:{createPeer:(function(sock,addr,port){var ws;if(typeof addr==="obje ct"){ws=addr;addr=null;port=null}if(ws){if(ws._socket){addr=ws._socket.remoteAdd ress;port=ws._socket.remotePort}else{var result=/ws[s]?:\/\/([^:]+):(\d+)/.exec( ws.url);if(!result){throw new Error("WebSocket URL must be in the format ws(s):/ /address:port")}addr=result[1];port=parseInt(result[2],10)}}else{try{var runtime Config=Module["websocket"]&&"object"===typeof Module["websocket"];var url="ws:#" .replace("#","//");if(runtimeConfig){if("string"===typeof Module["websocket"]["u rl"]){url=Module["websocket"]["url"]}}if(url==="ws://"||url==="wss://"){var part s=addr.split("/");url=url+parts[0]+":"+port+"/"+parts.slice(1).join("/")}var sub Protocols="binary";if(runtimeConfig){if("string"===typeof Module["websocket"]["s ubprotocol"]){subProtocols=Module["websocket"]["subprotocol"]}}subProtocols=subP rotocols.replace(/^ +| +$/g,"").split(/ *, */);var opts=ENVIRONMENT_IS_NODE?{"pr otocol":subProtocols.toString()}:subProtocols;var WebSocket=ENVIRONMENT_IS_NODE? require("ws"):window["WebSocket"];ws=new WebSocket(url,opts);ws.binaryType="arra ybuffer"}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EHOSTUNREACH)}}var peer={a ddr:addr,port:port,socket:ws,dgram_send_queue:[]};SOCKFS.websocket_sock_ops.addP eer(sock,peer);SOCKFS.websocket_sock_ops.handlePeerEvents(sock,peer);if(sock.typ e===2&&typeof sock.sport!=="undefined"){peer.dgram_send_queue.push(new Uint8Arra y([255,255,255,255,"p".charCodeAt(0),"o".charCodeAt(0),"r".charCodeAt(0),"t".cha rCodeAt(0),(sock.sport&65280)>>8,sock.sport&255]))}return peer}),getPeer:(functi on(sock,addr,port){return sock.peers[addr+":"+port]}),addPeer:(function(sock,pee r){sock.peers[peer.addr+":"+peer.port]=peer}),removePeer:(function(sock,peer){de lete sock.peers[peer.addr+":"+peer.port]}),handlePeerEvents:(function(sock,peer) {var first=true;var handleOpen=(function(){Module["websocket"].emit("open",sock. stream.fd);try{var queued=peer.dgram_send_queue.shift();while(queued){peer.socke t.send(queued);queued=peer.dgram_send_queue.shift()}}catch(e){peer.socket.close( )}});function handleMessage(data){assert(typeof data!=="string"&&data.byteLength !==undefined);data=new Uint8Array(data);var wasfirst=first;first=false;if(wasfir st&&data.length===10&&data[0]===255&&data[1]===255&&data[2]===255&&data[3]===255 &&data[4]==="p".charCodeAt(0)&&data[5]==="o".charCodeAt(0)&&data[6]==="r".charCo deAt(0)&&data[7]==="t".charCodeAt(0)){var newport=data[8]<<8|data[9];SOCKFS.webs ocket_sock_ops.removePeer(sock,peer);peer.port=newport;SOCKFS.websocket_sock_ops .addPeer(sock,peer);return}sock.recv_queue.push({addr:peer.addr,port:peer.port,d ata:data});Module["websocket"].emit("message",sock.stream.fd)}if(ENVIRONMENT_IS_ NODE){peer.socket.on("open",handleOpen);peer.socket.on("message",(function(data, flags){if(!flags.binary){return}handleMessage((new Uint8Array(data)).buffer)})); peer.socket.on("close",(function(){Module["websocket"].emit("close",sock.stream. fd)}));peer.socket.on("error",(function(error){sock.error=ERRNO_CODES.ECONNREFUS ED;Module["websocket"].emit("error",[sock.stream.fd,sock.error,"ECONNREFUSED: Co nnection refused"])}))}else{peer.socket.onopen=handleOpen;peer.socket.onclose=(f unction(){Module["websocket"].emit("close",sock.stream.fd)});peer.socket.onmessa ge=function peer_socket_onmessage(event){handleMessage(event.data)};peer.socket. onerror=(function(error){sock.error=ERRNO_CODES.ECONNREFUSED;Module["websocket"] .emit("error",[sock.stream.fd,sock.error,"ECONNREFUSED: Connection refused"])})} }),poll:(function(sock){if(sock.type===1&&sock.server){return sock.pending.lengt h?64|1:0}var mask=0;var dest=sock.type===1?SOCKFS.websocket_sock_ops.getPeer(soc k,sock.daddr,sock.dport):null;if(sock.recv_queue.length||!dest||dest&&dest.socke t.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.C LOSED){mask|=64|1}if(!dest||dest&&dest.socket.readyState===dest.socket.OPEN){mas k|=4}if(dest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.re adyState===dest.socket.CLOSED){mask|=16}return mask}),ioctl:(function(sock,reque st,arg){switch(request){case 21531:var bytes=0;if(sock.recv_queue.length){bytes= sock.recv_queue[0].data.length}HEAP32[arg>>2]=bytes;return 0;default:return ERRN O_CODES.EINVAL}}),close:(function(sock){if(sock.server){try{sock.server.close()} catch(e){}sock.server=null}var peers=Object.keys(sock.peers);for(var i=0;i<peers .length;i++){var peer=sock.peers[peers[i]];try{peer.socket.close()}catch(e){}SOC KFS.websocket_sock_ops.removePeer(sock,peer)}return 0}),bind:(function(sock,addr ,port){if(typeof sock.saddr!=="undefined"||typeof sock.sport!=="undefined"){thro w new FS.ErrnoError(ERRNO_CODES.EINVAL)}sock.saddr=addr;sock.sport=port||_mkport ();if(sock.type===2){if(sock.server){sock.server.close();sock.server=null}try{so ck.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){i f(sock.server){throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP)}if(typeof sock.da ddr!=="undefined"&&typeof sock.dport!=="undefined"){var dest=SOCKFS.websocket_so ck_ops.getPeer(sock,sock.daddr,sock.dport);if(dest){if(dest.socket.readyState=== dest.socket.CONNECTING){throw new FS.ErrnoError(ERRNO_CODES.EALREADY)}else{throw new FS.ErrnoError(ERRNO_CODES.EISCONN)}}}var peer=SOCKFS.websocket_sock_ops.cre atePeer(sock,addr,port);sock.daddr=peer.addr;sock.dport=peer.port;throw new FS.E rrnoError(ERRNO_CODES.EINPROGRESS)}),listen:(function(sock,backlog){if(!ENVIRONM ENT_IS_NODE){throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP)}if(sock.server){thr ow new FS.ErrnoError(ERRNO_CODES.EINVAL)}var WebSocketServer=require("ws").Serve r;var host=sock.saddr;sock.server=new WebSocketServer({host:host,port:sock.sport });Module["websocket"].emit("listen",sock.stream.fd);sock.server.on("connection" ,(function(ws){if(sock.type===1){var newsock=SOCKFS.createSocket(sock.family,soc k.type,sock.protocol);var peer=SOCKFS.websocket_sock_ops.createPeer(newsock,ws); newsock.daddr=peer.addr;newsock.dport=peer.port;sock.pending.push(newsock);Modul e["websocket"].emit("connection",newsock.stream.fd)}else{SOCKFS.websocket_sock_o ps.createPeer(sock,ws);Module["websocket"].emit("connection",sock.stream.fd)}})) ;sock.server.on("closed",(function(){Module["websocket"].emit("close",sock.strea m.fd);sock.server=null}));sock.server.on("error",(function(error){sock.error=ERR NO_CODES.EHOSTUNREACH;Module["websocket"].emit("error",[sock.stream.fd,sock.erro r,"EHOSTUNREACH: Host is unreachable"])}))}),accept:(function(listensock){if(!li stensock.server){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var newsock=listens ock.pending.shift();newsock.stream.flags=listensock.stream.flags;return newsock} ),getname:(function(sock,peer){var addr,port;if(peer){if(sock.daddr===undefined| |sock.dport===undefined){throw new FS.ErrnoError(ERRNO_CODES.ENOTCONN)}addr=sock .daddr;port=sock.dport}else{addr=sock.saddr||0;port=sock.sport||0}return{addr:ad dr,port:port}}),sendmsg:(function(sock,buffer,offset,length,addr,port){if(sock.t ype===2){if(addr===undefined||port===undefined){addr=sock.daddr;port=sock.dport} if(addr===undefined||port===undefined){throw new FS.ErrnoError(ERRNO_CODES.EDEST ADDRREQ)}}else{addr=sock.daddr;port=sock.dport}var dest=SOCKFS.websocket_sock_op s.getPeer(sock,addr,port);if(sock.type===1){if(!dest||dest.socket.readyState===d est.socket.CLOSING||dest.socket.readyState===dest.socket.CLOSED){throw new FS.Er rnoError(ERRNO_CODES.ENOTCONN)}else if(dest.socket.readyState===dest.socket.CONN ECTING){throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}}var data;if(buffer instance of Array||buffer instanceof ArrayBuffer){data=buffer.slice(offset,offset+length) }else{data=buffer.buffer.slice(buffer.byteOffset+offset,buffer.byteOffset+offset +length)}if(sock.type===2){if(!dest||dest.socket.readyState!==dest.socket.OPEN){ if(!dest||dest.socket.readyState===dest.socket.CLOSING||dest.socket.readyState== =dest.socket.CLOSED){dest=SOCKFS.websocket_sock_ops.createPeer(sock,addr,port)}d est.dgram_send_queue.push(data);return length}}try{dest.socket.send(data);return length}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}}),recvmsg:(functio n(sock,length){if(sock.type===1&&sock.server){throw new FS.ErrnoError(ERRNO_CODE S.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){th row new FS.ErrnoError(ERRNO_CODES.ENOTCONN)}else if(dest.socket.readyState===des t.socket.CLOSING||dest.socket.readyState===dest.socket.CLOSED){return null}else{ throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}}else{throw new FS.ErrnoError(ERRNO_ CODES.EAGAIN)}}var queuedLength=queued.data.byteLength||queued.data.length;var q ueuedOffset=queued.data.byteOffset||0;var queuedBuffer=queued.data.buffer||queue d.data;var bytesRead=Math.min(length,queuedLength);var res={buffer:new Uint8Arra y(queuedBuffer,queuedOffset,bytesRead),addr:queued.addr,port:queued.port};if(soc k.type===1&&bytesRead<queuedLength){var bytesRemaining=queuedLength-bytesRead;qu eued.data=new Uint8Array(queuedBuffer,queuedOffset+bytesRead,bytesRemaining);soc k.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}ret urn _write(fd,buf,len)}function _pwrite(fildes,buf,nbyte,offset){var stream=FS.g etStream(fildes);if(!stream){___setErrNo(ERRNO_CODES.EBADF);return-1}try{var sla b=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);i f(!stream){___setErrNo(ERRNO_CODES.EBADF);return-1}try{var slab=HEAP8;return FS. write(stream,slab,buf,nbyte)}catch(e){FS.handleFSError(e);return-1}}function _fi leno(stream){stream=FS.getStreamFromPtr(stream);if(!stream)return-1;return strea m.fd}function _fwrite(ptr,size,nitems,stream){var bytesToWrite=nitems*size;if(by tesToWrite==0)return 0;var fd=_fileno(stream);var bytesWritten=_write(fd,ptr,byt esToWrite);if(bytesWritten==-1){var streamObj=FS.getStreamFromPtr(stream);if(str eamObj)streamObj.error=true;return 0}else{return bytesWritten/size|0}}Module["_s trlen"]=_strlen;function __reallyNegative(x){return x<0||x===0&&1/x===-Infinity} function __formatString(format,varargs){var textIndex=format;var argIndex=0;func tion getNextArg(type){var ret;if(type==="double"){ret=(HEAP32[tempDoublePtr>>2]= HEAP32[varargs+argIndex>>2],HEAP32[tempDoublePtr+4>>2]=HEAP32[varargs+(argIndex+ 4)>>2],+HEAPF64[tempDoublePtr>>3])}else if(type=="i64"){ret=[HEAP32[varargs+argI ndex>>2],HEAP32[varargs+(argIndex+4)>>2]]}else{type="i32";ret=HEAP32[varargs+arg Index>>2]}argIndex+=Runtime.getNativeFieldSize(type);return ret}var ret=[];var c urr,next,currArg;while(1){var startTextIndex=textIndex;curr=HEAP8[textIndex>>0]; if(curr===0)break;next=HEAP8[textIndex+1>>0];if(curr==37){var flagAlwaysSigned=f alse;var flagLeftAlign=false;var flagAlternative=false;var flagZeroPad=false;var flagPadSign=false;flagsLoop:while(1){switch(next){case 43:flagAlwaysSigned=true ;break;case 45:flagLeftAlign=true;break;case 35:flagAlternative=true;break;case 48:if(flagZeroPad){break flagsLoop}else{flagZeroPad=true;break};case 32:flagPadS ign=true;break;default:break flagsLoop}textIndex++;next=HEAP8[textIndex+1>>0]}va r width=0;if(next==42){width=getNextArg("i32");textIndex++;next=HEAP8[textIndex+ 1>>0]}else{while(next>=48&&next<=57){width=width*10+(next-48);textIndex++;next=H EAP8[textIndex+1>>0]}}var precisionSet=false,precision=-1;if(next==46){precision =0;precisionSet=true;textIndex++;next=HEAP8[textIndex+1>>0];if(next==42){precisi on=getNextArg("i32");textIndex++}else{while(1){var precisionChr=HEAP8[textIndex+ 1>>0];if(precisionChr<48||precisionChr>57)break;precision=precision*10+(precisio nChr-48);textIndex++}}next=HEAP8[textIndex+1>>0]}if(precision<0){precision=6;pre cisionSet=false}var argSize;switch(String.fromCharCode(next)){case"h":var nextNe xt=HEAP8[textIndex+2>>0];if(nextNext==104){textIndex++;argSize=1}else{argSize=2} break;case"l":var nextNext=HEAP8[textIndex+2>>0];if(nextNext==108){textIndex++;a rgSize=8}else{argSize=4}break;case"L":case"q":case"j":argSize=8;break;case"z":ca se"t":case"I":argSize=4;break;default:argSize=null}if(argSize)textIndex++;next=H EAP8[textIndex+1>>0];switch(String.fromCharCode(next)){case"d":case"i":case"u":c ase"o":case"x":case"X":case"p":{var signed=next==100||next==105;argSize=argSize| |4;var currArg=getNextArg("i"+argSize*8);var origArg=currArg;var argText;if(argS ize==8){currArg=Runtime.makeBigInt(currArg[0],currArg[1],next==117)}if(argSize<= 4){var limit=Math.pow(256,argSize)-1;currArg=(signed?reSign:unSign)(currArg&limi t,argSize*8)}var currAbsArg=Math.abs(currArg);var prefix="";if(next==100||next== 105){if(argSize==8&&i64Math)argText=i64Math.stringify(origArg[0],origArg[1],null );else argText=reSign(currArg,8*argSize,1).toString(10)}else if(next==117){if(ar gSize==8&&i64Math)argText=i64Math.stringify(origArg[0],origArg[1],true);else arg Text=unSign(currArg,8*argSize,1).toString(10);currArg=Math.abs(currArg)}else if( next==111){argText=(flagAlternative?"0":"")+currAbsArg.toString(8)}else if(next= =120||next==88){prefix=flagAlternative&&currArg!=0?"0x":"";if(argSize==8&&i64Mat h){if(origArg[1]){argText=(origArg[1]>>>0).toString(16);var lower=(origArg[0]>>> 0).toString(16);while(lower.length<8)lower="0"+lower;argText+=lower}else{argText =(origArg[0]>>>0).toString(16)}}else if(currArg<0){currArg=-currArg;argText=(cur rAbsArg-1).toString(16);var buffer=[];for(var i=0;i<argText.length;i++){buffer.p ush((15-parseInt(argText[i],16)).toString(16))}argText=buffer.join("");while(arg Text.length<argSize*2)argText="f"+argText}else{argText=currAbsArg.toString(16)}i f(next==88){prefix=prefix.toUpperCase();argText=argText.toUpperCase()}}else if(n ext==112){if(currAbsArg===0){argText="(nil)"}else{prefix="0x";argText=currAbsArg .toString(16)}}if(precisionSet){while(argText.length<precision){argText="0"+argT ext}}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.length<width){if(flagLeftAlign){argText+=" "}else{if(flagZeroPad){argText="0"+argText}else{prefix=" "+prefix}}}argText=pre fix+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=getNextA rg("double");var argText;if(isNaN(currArg)){argText="nan";flagZeroPad=false}else if(!isFinite(currArg)){argText=(currArg<0?"-":"")+"inf";flagZeroPad=false}else{ var isGeneral=false;var effectivePrecision=Math.min(precision,20);if(next==103|| next==71){isGeneral=true;precision=precision||1;var exponent=parseInt(currArg.to Exponential(effectivePrecision).split("e")[1],10);if(precision>exponent&&exponen t>=-4){next=(next==103?"f":"F").charCodeAt(0);precision-=exponent+1}else{next=(n ext==103?"e":"E").charCodeAt(0);precision--}effectivePrecision=Math.min(precisio n,20)}if(next==101||next==69){argText=currArg.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(c urrArg===0&&__reallyNegative(currArg)){argText="-"+argText}}var parts=argText.sp lit("e");if(isGeneral&&!flagAlternative){while(parts[0].length>1&&parts[0].index Of(".")!=-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++)parts[0]+="0"}argText=parts[0]+(parts.lengt h>1?"e"+parts[1]:"");if(next==69)argText=argText.toUpperCase();if(currArg>=0){if (flagAlwaysSigned){argText="+"+argText}else if(flagPadSign){argText=" "+argText} }}while(argText.length<width){if(flagLeftAlign){argText+=" "}else{if(flagZeroPad &&(argText[0]=="-"||argText[0]=="+")){argText=argText[0]+"0"+argText.slice(1)}el se{argText=(flagZeroPad?"0":" ")+argText}}}if(next<97)argText=argText.toUpperCas e();argText.split("").forEach((function(chr){ret.push(chr.charCodeAt(0))}));brea k};case"s":{var arg=getNextArg("i8*");var argLength=arg?_strlen(arg):"(null)".le ngth;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.concat(intArrayFromString("(null)".substr(0 ,argLength),true))}if(flagLeftAlign){while(argLength<width--){ret.push(32)}}brea k};case"c":{if(flagLeftAlign)ret.push(getNextArg("i8"));while(--width>0){ret.pus h(32)}if(!flagLeftAlign)ret.push(getNextArg("i8"));break};case"n":{var ptr=getNe xtArg("i32*");HEAP32[ptr>>2]=ret.length;break};case"%":{ret.push(curr);break};de fault:{for(var i=startTextIndex;i<textIndex+2;i++){ret.push(HEAP8[i>>0])}}}textI ndex+=2}else{ret.push(curr);textIndex+=1}}return ret}function _fprintf(stream,fo rmat,varargs){var result=__formatString(format,varargs);var stack=Runtime.stackS ave();var ret=_fwrite(allocate(result,"i8",ALLOC_STACK),1,result.length,stream); Runtime.stackRestore(stack);return ret}function _printf(format,varargs){var stdo ut=HEAP32[_stdout>>2];return _fprintf(stdout,format,varargs)}var _llvm_expect_i3 2=undefined;var cttz_i8=allocate([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_ST ATIC);Module["_llvm_cttz_i32"]=_llvm_cttz_i32;function _llvm_cttz_i64(l,h){var r et=_llvm_cttz_i32(l);if(ret==32)ret+=_llvm_cttz_i32(h);return(asm["setTempRet0"] (0),ret)|0}function _sbrk(bytes){var self=_sbrk;if(!self.called){DYNAMICTOP=alig nMemoryPage(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){var success= self.alloc(bytes);if(!success)return-1>>>0}return ret}function ___errno_location (){return ___errno_state}function _emscripten_memcpy_big(dest,src,num){HEAPU8.se t(HEAPU8.subarray(src,src+num),dest);return dest}Module["_memcpy"]=_memcpy;funct ion _emscripten_set_main_loop_timing(mode,value){Browser.mainLoop.timingMode=mod e;Browser.mainLoop.timingValue=value;if(!Browser.mainLoop.func){return 1}if(mode ==0){Browser.mainLoop.scheduler=function Browser_mainLoop_scheduler(){setTimeout (Browser.mainLoop.runner,value)};Browser.mainLoop.method="timeout"}else if(mode= =1){Browser.mainLoop.scheduler=function Browser_mainLoop_scheduler(){Browser.req uestAnimationFrame(Browser.mainLoop.runner)};Browser.mainLoop.method="rAF"}retur n 0}function _emscripten_set_main_loop(func,fps,simulateInfiniteLoop,arg,noSetTi ming){Module["noExitRuntime"]=true;assert(!Browser.mainLoop.func,"emscripten_set _main_loop: there can only be one main loop function at once: call emscripten_ca ncel_main_loop to cancel the previous one before setting a new one with differen t parameters.");Browser.mainLoop.func=func;Browser.mainLoop.arg=arg;var thisMain LoopId=Browser.mainLoop.currentlyRunningMainloop;Browser.mainLoop.runner=functio n Browser_mainLoop_runner(){if(ABORT)return;if(Browser.mainLoop.queue.length>0){ var start=Date.now();var blocker=Browser.mainLoop.queue.shift();blocker.func(blo cker.arg);if(Browser.mainLoop.remainingBlockers){var remaining=Browser.mainLoop. remainingBlockers;var next=remaining%1==0?remaining-1:Math.floor(remaining);if(b locker.counted){Browser.mainLoop.remainingBlockers=next}else{next=next+.5;Browse r.mainLoop.remainingBlockers=(8*remaining+next)/9}}console.log('main loop blocke r "'+blocker.name+'" took '+(Date.now()-start)+" ms");Browser.mainLoop.updateSta tus();setTimeout(Browser.mainLoop.runner,0);return}if(thisMainLoopId<Browser.mai nLoop.currentlyRunningMainloop)return;Browser.mainLoop.currentFrameNumber=Browse r.mainLoop.currentFrameNumber+1|0;if(Browser.mainLoop.timingMode==1&&Browser.mai nLoop.timingValue>1&&Browser.mainLoop.currentFrameNumber%Browser.mainLoop.timing Value!=0){Browser.mainLoop.scheduler();return}if(Browser.mainLoop.method==="time out"&&Module.ctx){Module.printErr("Looks like you are rendering without using re questAnimationFrame for the main loop. You should use 0 for the frame rate in em scripten_set_main_loop in order to use requestAnimationFrame, as that can greatl y improve your frame rates!");Browser.mainLoop.method=""}Browser.mainLoop.runIte r((function(){if(typeof arg!=="undefined"){Runtime.dynCall("vi",func,[arg])}else {Runtime.dynCall("v",func)}}));if(thisMainLoopId<Browser.mainLoop.currentlyRunni ngMainloop)return;if(typeof SDL==="object"&&SDL.audio&&SDL.audio.queueNewAudioDa ta)SDL.audio.queueNewAudioData();Browser.mainLoop.scheduler()};if(!noSetTiming){ if(fps&&fps>0)_emscripten_set_main_loop_timing(0,1e3/fps);else _emscripten_set_m ain_loop_timing(1,1);Browser.mainLoop.scheduler()}if(simulateInfiniteLoop){throw "SimulateInfiniteLoop"}}var Browser={mainLoop:{scheduler:null,method:"",currentl yRunningMainloop:0,func:null,arg:0,timingMode:0,timingValue:0,currentFrameNumber :0,queue:[],pause:(function(){Browser.mainLoop.scheduler=null;Browser.mainLoop.c urrentlyRunningMainloop++}),resume:(function(){Browser.mainLoop.currentlyRunning Mainloop++;var timingMode=Browser.mainLoop.timingMode;var timingValue=Browser.ma inLoop.timingValue;var func=Browser.mainLoop.func;Browser.mainLoop.func=null;_em scripten_set_main_loop(func,0,false,Browser.mainLoop.arg,true);_emscripten_set_m ain_loop_timing(timingMode,timingValue);Browser.mainLoop.scheduler()}),updateSta tus:(function(){if(Module["setStatus"]){var message=Module["statusMessage"]||"Pl ease wait...";var remaining=Browser.mainLoop.remainingBlockers;var expected=Brow ser.mainLoop.expectedBlockers;if(remaining){if(remaining<expected){Module["setSt atus"](message+" ("+(expected-remaining)+"/"+expected+")")}else{Module["setStatu s"](message)}}else{Module["setStatus"]("")}}}),runIter:(function(func){if(ABORT) return;if(Module["preMainLoop"]){var preRet=Module["preMainLoop"]();if(preRet=== false){return}}try{func()}catch(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["postMainLoop"])Module["postMainLoop"]()})},isFullScreen:fals e,pointerLock:false,moduleContextCreatedCallbacks:[],workers:[],init:(function() {if(!Module["preloadPlugins"])Module["preloadPlugins"]=[];if(Browser.initted)ret urn;Browser.initted=true;try{new Blob;Browser.hasBlobConstructor=true}catch(e){B rowser.hasBlobConstructor=false;console.log("warning: no blob constructor, canno t create blobs with mimetypes")}Browser.BlobBuilder=typeof MozBlobBuilder!="unde fined"?MozBlobBuilder:typeof WebKitBlobBuilder!="undefined"?WebKitBlobBuilder:!B rowser.hasBlobConstructor?console.log("warning: no BlobBuilder"):null;Browser.UR LObject=typeof window!="undefined"?window.URL?window.URL:window.webkitURL:undefi ned;if(!Module.noImageDecoding&&typeof Browser.URLObject==="undefined"){console. log("warning: Browser does not support creating object URLs. Built-in browser im age decoding will not be available.");Module.noImageDecoding=true}var imagePlugi n={};imagePlugin["canHandle"]=function imagePlugin_canHandle(name){return!Module .noImageDecoding&&/\.(jpg|jpeg|png|bmp)$/i.test(name)};imagePlugin["handle"]=fun ction imagePlugin_handle(byteArray,name,onload,onerror){var b=null;if(Browser.ha sBlobConstructor){try{b=new Blob([byteArray],{type:Browser.getMimetype(name)});i f(b.size!==byteArray.length){b=new Blob([(new Uint8Array(byteArray)).buffer],{ty pe:Browser.getMimetype(name)})}}catch(e){Runtime.warnOnce("Blob constructor pres ent but fails: "+e+"; falling back to blob builder")}}if(!b){var bb=new Browser. BlobBuilder;bb.append((new Uint8Array(byteArray)).buffer);b=bb.getBlob()}var url =Browser.URLObject.createObjectURL(b);var img=new Image;img.onload=function img_ onload(){assert(img.complete,"Image "+name+" could not be decoded");var canvas=d ocument.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.URLObject.revokeObjectURL(url);if(onload)onload(byteArray) };img.onerror=function img_onerror(event){console.log("Image "+url+" could not b e decoded");if(onerror)onerror()};img.src=url};Module["preloadPlugins"].push(ima gePlugin);var audioPlugin={};audioPlugin["canHandle"]=function audioPlugin_canHa ndle(name){return!Module.noAudioDecoding&&name.substr(-4)in{".ogg":1,".wav":1,". mp3":1}};audioPlugin["handle"]=function audioPlugin_handle(byteArray,name,onload ,onerror){var done=false;function finish(audio){if(done)return;done=true;Module[ "preloadedAudios"][name]=audio;if(onload)onload(byteArray)}function fail(){if(do ne)return;done=true;Module["preloadedAudios"][name]=new Audio;if(onerror)onerror ()}if(Browser.hasBlobConstructor){try{var b=new Blob([byteArray],{type:Browser.g etMimetype(name)})}catch(e){return fail()}var url=Browser.URLObject.createObject URL(b);var audio=new Audio;audio.addEventListener("canplaythrough",(function(){f inish(audio)}),false);audio.onerror=function audio_onerror(event){if(done)return ;console.log("warning: browser could not fully decode audio "+name+", trying slo wer base64 approach");function encode64(data){var BASE="ABCDEFGHIJKLMNOPQRSTUVWX YZabcdefghijklmnopqrstuvwxyz0123456789+/";var PAD="=";var ret="";var leftchar=0; var leftbits=0;for(var i=0;i<data.length;i++){leftchar=leftchar<<8|data[i];leftb its+=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-"+n ame.substr(-3)+";base64,"+encode64(byteArray);finish(audio)};audio.src=url;Brows er.safeSetTimeout((function(){finish(audio)}),1e4)}else{return fail()}};Module[" preloadPlugins"].push(audioPlugin);var canvas=Module["canvas"];function pointerL ockChange(){Browser.pointerLock=document["pointerLockElement"]===canvas||documen t["mozPointerLockElement"]===canvas||document["webkitPointerLockElement"]===canv as||document["msPointerLockElement"]===canvas}if(canvas){canvas.requestPointerLo ck=canvas["requestPointerLock"]||canvas["mozRequestPointerLock"]||canvas["webkit RequestPointerLock"]||canvas["msRequestPointerLock"]||(function(){});canvas.exit PointerLock=document["exitPointerLock"]||document["mozExitPointerLock"]||documen t["webkitExitPointerLock"]||document["msExitPointerLock"]||(function(){});canvas .exitPointerLock=canvas.exitPointerLock.bind(document);document.addEventListener ("pointerlockchange",pointerLockChange,false);document.addEventListener("mozpoin terlockchange",pointerLockChange,false);document.addEventListener("webkitpointer lockchange",pointerLockChange,false);document.addEventListener("mspointerlockcha nge",pointerLockChange,false);if(Module["elementPointerLock"]){canvas.addEventLi stener("click",(function(ev){if(!Browser.pointerLock&&canvas.requestPointerLock) {canvas.requestPointerLock();ev.preventDefault()}}),false)}}}),createContext:(fu nction(canvas,useWebGL,setInModule,webGLContextAttributes){if(useWebGL&&Module.c tx&&canvas==Module.canvas)return Module.ctx;var ctx;var contextHandle;if(useWebG L){var contextAttributes={antialias:false,alpha:false};if(webGLContextAttributes ){for(var attribute in webGLContextAttributes){contextAttributes[attribute]=webG LContextAttributes[attribute]}}contextHandle=GL.createContext(canvas,contextAttr ibutes);if(contextHandle){ctx=GL.getContext(contextHandle).GLctx}canvas.style.ba ckgroundColor="black"}else{ctx=canvas.getContext("2d")}if(!ctx)return null;if(se tInModule){if(!useWebGL)assert(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.makeContextCurrent(contextHandle);Module.useWebGL=useWebGL;B rowser.moduleContextCreatedCallbacks.forEach((function(callback){callback()}));B rowser.init()}return ctx}),destroyContext:(function(canvas,useWebGL,setInModule) {}),fullScreenHandlersInstalled:false,lockPointer:undefined,resizeCanvas:undefin ed,requestFullScreen:(function(lockPointer,resizeCanvas,vrDevice){Browser.lockPo inter=lockPointer;Browser.resizeCanvas=resizeCanvas;Browser.vrDevice=vrDevice;if (typeof Browser.lockPointer==="undefined")Browser.lockPointer=true;if(typeof Bro wser.resizeCanvas==="undefined")Browser.resizeCanvas=false;if(typeof Browser.vrD evice==="undefined")Browser.vrDevice=null;var canvas=Module["canvas"];function f ullScreenChange(){Browser.isFullScreen=false;var canvasContainer=canvas.parentNo de;if((document["webkitFullScreenElement"]||document["webkitFullscreenElement"]| |document["mozFullScreenElement"]||document["mozFullscreenElement"]||document["f ullScreenElement"]||document["fullscreenElement"]||document["msFullScreenElement "]||document["msFullscreenElement"]||document["webkitCurrentFullScreenElement"]) ===canvasContainer){canvas.cancelFullScreen=document["cancelFullScreen"]||docume nt["mozCancelFullScreen"]||document["webkitCancelFullScreen"]||document["msExitF ullscreen"]||document["exitFullscreen"]||(function(){});canvas.cancelFullScreen= canvas.cancelFullScreen.bind(document);if(Browser.lockPointer)canvas.requestPoin terLock();Browser.isFullScreen=true;if(Browser.resizeCanvas)Browser.setFullScree nCanvasSize()}else{canvasContainer.parentNode.insertBefore(canvas,canvasContaine r);canvasContainer.parentNode.removeChild(canvasContainer);if(Browser.resizeCanv as)Browser.setWindowedCanvasSize()}if(Module["onFullScreen"])Module["onFullScree n"](Browser.isFullScreen);Browser.updateCanvasDimensions(canvas)}if(!Browser.ful lScreenHandlersInstalled){Browser.fullScreenHandlersInstalled=true;document.addE ventListener("fullscreenchange",fullScreenChange,false);document.addEventListene r("mozfullscreenchange",fullScreenChange,false);document.addEventListener("webki tfullscreenchange",fullScreenChange,false);document.addEventListener("MSFullscre enChange",fullScreenChange,false)}var canvasContainer=document.createElement("di v");canvas.parentNode.insertBefore(canvasContainer,canvas);canvasContainer.appen dChild(canvas);canvasContainer.requestFullScreen=canvasContainer["requestFullScr een"]||canvasContainer["mozRequestFullScreen"]||canvasContainer["msRequestFullsc reen"]||(canvasContainer["webkitRequestFullScreen"]?(function(){canvasContainer[ "webkitRequestFullScreen"](Element["ALLOW_KEYBOARD_INPUT"])}):null);if(vrDevice) {canvasContainer.requestFullScreen({vrDisplay:vrDevice})}else{canvasContainer.re questFullScreen()}}),nextRAF:0,fakeRequestAnimationFrame:(function(func){var now =Date.now();if(Browser.nextRAF===0){Browser.nextRAF=now+1e3/60}else{while(now+2> =Browser.nextRAF){Browser.nextRAF+=1e3/60}}var delay=Math.max(Browser.nextRAF-no w,0);setTimeout(func,delay)}),requestAnimationFrame:function requestAnimationFra me(func){if(typeof window==="undefined"){Browser.fakeRequestAnimationFrame(func) }else{if(!window.requestAnimationFrame){window.requestAnimationFrame=window["req uestAnimationFrame"]||window["mozRequestAnimationFrame"]||window["webkitRequestA nimationFrame"]||window["msRequestAnimationFrame"]||window["oRequestAnimationFra me"]||Browser.fakeRequestAnimationFrame}window.requestAnimationFrame(func)}},saf eCallback:(function(func){return(function(){if(!ABORT)return func.apply(null,arg uments)})}),allowAsyncCallbacks:true,queuedAsyncCallbacks:[],pauseAsyncCallbacks :(function(){Browser.allowAsyncCallbacks=false}),resumeAsyncCallbacks:(function( ){Browser.allowAsyncCallbacks=true;if(Browser.queuedAsyncCallbacks.length>0){var callbacks=Browser.queuedAsyncCallbacks;Browser.queuedAsyncCallbacks=[];callback s.forEach((function(func){func()}))}}),safeRequestAnimationFrame:(function(func) {return Browser.requestAnimationFrame((function(){if(ABORT)return;if(Browser.all owAsyncCallbacks){func()}else{Browser.queuedAsyncCallbacks.push(func)}}))}),safe SetTimeout:(function(func,timeout){Module["noExitRuntime"]=true;return setTimeou t((function(){if(ABORT)return;if(Browser.allowAsyncCallbacks){func()}else{Browse r.queuedAsyncCallbacks.push(func)}}),timeout)}),safeSetInterval:(function(func,t imeout){Module["noExitRuntime"]=true;return setInterval((function(){if(ABORT)ret urn;if(Browser.allowAsyncCallbacks){func()}}),timeout)}),getMimetype:(function(n ame){return{"jpg":"image/jpeg","jpeg":"image/jpeg","png":"image/png","bmp":"imag e/bmp","ogg":"audio/ogg","wav":"audio/wav","mp3":"audio/mpeg"}[name.substr(name. lastIndexOf(".")+1)]}),getUserMedia:(function(func){if(!window.getUserMedia){win dow.getUserMedia=navigator["getUserMedia"]||navigator["mozGetUserMedia"]}window. getUserMedia(func)}),getMovementX:(function(event){return event["movementX"]||ev ent["mozMovementX"]||event["webkitMovementX"]||0}),getMovementY:(function(event) {return event["movementY"]||event["mozMovementY"]||event["webkitMovementY"]||0}) ,getMouseWheelDelta:(function(event){var delta=0;switch(event.type){case"DOMMous eScroll":delta=event.detail;break;case"mousewheel":delta=event.wheelDelta;break; case"wheel":delta=event["deltaY"];break;default:throw"unrecognized mouse wheel e vent: "+event.type}return delta}),mouseX:0,mouseY:0,mouseMovementX:0,mouseMoveme ntY:0,touches:{},lastTouches:{},calculateMouseEvent:(function(event){if(Browser. pointerLock){if(event.type!="mousemove"&&"mozMovementX"in event){Browser.mouseMo vementX=Browser.mouseMovementY=0}else{Browser.mouseMovementX=Browser.getMovement X(event);Browser.mouseMovementY=Browser.getMovementY(event)}if(typeof SDL!="unde fined"){Browser.mouseX=SDL.mouseX+Browser.mouseMovementX;Browser.mouseY=SDL.mous eY+Browser.mouseMovementY}else{Browser.mouseX+=Browser.mouseMovementX;Browser.mo useY+=Browser.mouseMovementY}}else{var rect=Module["canvas"].getBoundingClientRe ct();var cw=Module["canvas"].width;var ch=Module["canvas"].height;var scrollX=ty peof window.scrollX!=="undefined"?window.scrollX:window.pageXOffset;var scrollY= typeof window.scrollY!=="undefined"?window.scrollY:window.pageYOffset;if(event.t ype==="touchstart"||event.type==="touchend"||event.type==="touchmove"){var touch =event.touch;if(touch===undefined){return}var adjustedX=touch.pageX-(scrollX+rec t.left);var adjustedY=touch.pageY-(scrollY+rect.top);adjustedX=adjustedX*(cw/rec t.width);adjustedY=adjustedY*(ch/rect.height);var coords={x:adjustedX,y:adjusted Y};if(event.type==="touchstart"){Browser.lastTouches[touch.identifier]=coords;Br owser.touches[touch.identifier]=coords}else if(event.type==="touchend"||event.ty pe==="touchmove"){Browser.lastTouches[touch.identifier]=Browser.touches[touch.id entifier];Browser.touches[touch.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.height);Browser.mouseMovementX=x-Browser.mouseX;Browser .mouseMovementY=y-Browser.mouseY;Browser.mouseX=x;Browser.mouseY=y}}),xhrLoad:(f unction(url,onload,onerror){var xhr=new XMLHttpRequest;xhr.open("GET",url,true); xhr.responseType="arraybuffer";xhr.onload=function xhr_onload(){if(xhr.status==2 00||xhr.status==0&&xhr.response){onload(xhr.response)}else{onerror()}};xhr.onerr or=onerror;xhr.send(null)}),asyncLoad:(function(url,onload,onerror,noRunDep){Bro wser.xhrLoad(url,(function(arrayBuffer){assert(arrayBuffer,'Loading data file "' +url+'" failed (no arrayBuffer).');onload(new Uint8Array(arrayBuffer));if(!noRun Dep)removeRunDependency("al "+url)}),(function(event){if(onerror){onerror()}else {throw'Loading data file "'+url+'" failed.'}}));if(!noRunDep)addRunDependency("a l "+url)}),resizeListeners:[],updateResizeListeners:(function(){var canvas=Modul e["canvas"];Browser.resizeListeners.forEach((function(listener){listener(canvas. width,canvas.height)}))}),setCanvasSize:(function(width,height,noUpdates){var ca nvas=Module["canvas"];Browser.updateCanvasDimensions(canvas,width,height);if(!no Updates)Browser.updateResizeListeners()}),windowedWidth:0,windowedHeight:0,setFu llScreenCanvasSize:(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.updateResizeListeners()}),setWindowedCanvasSiz e:(function(){if(typeof SDL!="undefined"){var flags=HEAPU32[SDL.screen+Runtime.Q UANTUM_SIZE*0>>2];flags=flags&~8388608;HEAP32[SDL.screen+Runtime.QUANTUM_SIZE*0> >2]=flags}Browser.updateResizeListeners()}),updateCanvasDimensions:(function(can vas,wNative,hNative){if(wNative&&hNative){canvas.widthNative=wNative;canvas.heig htNative=hNative}else{wNative=canvas.widthNative;hNative=canvas.heightNative}var w=wNative;var h=hNative;if(Module["forcedAspectRatio"]&&Module["forcedAspectRat io"]>0){if(w/h<Module["forcedAspectRatio"]){w=Math.round(h*Module["forcedAspectR atio"])}else{h=Math.round(w/Module["forcedAspectRatio"])}}if((document["webkitFu llScreenElement"]||document["webkitFullscreenElement"]||document["mozFullScreenE lement"]||document["mozFullscreenElement"]||document["fullScreenElement"]||docum ent["fullscreenElement"]||document["msFullScreenElement"]||document["msFullscree nElement"]||document["webkitCurrentFullScreenElement"])===canvas.parentNode&&typ eof screen!="undefined"){var factor=Math.min(screen.width/w,screen.height/h);w=M ath.round(w*factor);h=Math.round(h*factor)}if(Browser.resizeCanvas){if(canvas.wi dth!=w)canvas.width=w;if(canvas.height!=h)canvas.height=h;if(typeof canvas.style !="undefined"){canvas.style.removeProperty("width");canvas.style.removeProperty( "height")}}else{if(canvas.width!=wNative)canvas.width=wNative;if(canvas.height!= hNative)canvas.height=hNative;if(typeof canvas.style!="undefined"){if(w!=wNative ||h!=hNative){canvas.style.setProperty("width",w+"px","important");canvas.style. setProperty("height",h+"px","important")}else{canvas.style.removeProperty("width ");canvas.style.removeProperty("height")}}}}),wgetRequests:{},nextWgetRequestHan dle:0,getNextWgetRequestHandle:(function(){var handle=Browser.nextWgetRequestHan dle;Browser.nextWgetRequestHandle++;return handle})};Module["_llvm_bswap_i16"]=_ llvm_bswap_i16;function _time(ptr){var ret=Date.now()/1e3|0;if(ptr){HEAP32[ptr>> 2]=ret}return ret}Module["_llvm_bswap_i32"]=_llvm_bswap_i32;Module["_llvm_ctlz_i 64"]=_llvm_ctlz_i64;___errno_state=Runtime.staticAlloc(4);HEAP32[___errno_state> >2]=0;FS.staticInit();__ATINIT__.unshift({func:(function(){if(!Module["noFSInit" ]&&!FS.init.initialized)FS.init()})});__ATMAIN__.push({func:(function(){FS.ignor ePermissions=false})});__ATEXIT__.push({func:(function(){FS.quit()})});Module["F S_createFolder"]=FS.createFolder;Module["FS_createPath"]=FS.createPath;Module["F S_createDataFile"]=FS.createDataFile;Module["FS_createPreloadedFile"]=FS.createP reloadedFile;Module["FS_createLazyFile"]=FS.createLazyFile;Module["FS_createLink "]=FS.createLink;Module["FS_createDevice"]=FS.createDevice;__ATINIT__.unshift({f unc:(function(){TTY.init()})});__ATEXIT__.push({func:(function(){TTY.shutdown()} )});if(ENVIRONMENT_IS_NODE){var fs=require("fs");var NODEJS_PATH=require("path") ;NODEFS.staticInit()}__ATINIT__.push({func:(function(){SOCKFS.root=FS.mount(SOCK FS,{},null)})});Module["requestFullScreen"]=function Module_requestFullScreen(lo ckPointer,resizeCanvas,vrDevice){Browser.requestFullScreen(lockPointer,resizeCan vas,vrDevice)};Module["requestAnimationFrame"]=function Module_requestAnimationF rame(func){Browser.requestAnimationFrame(func)};Module["setCanvasSize"]=function Module_setCanvasSize(width,height,noUpdates){Browser.setCanvasSize(width,height ,noUpdates)};Module["pauseMainLoop"]=function Module_pauseMainLoop(){Browser.mai nLoop.pause()};Module["resumeMainLoop"]=function Module_resumeMainLoop(){Browser .mainLoop.resume()};Module["getUserMedia"]=function Module_getUserMedia(){Browse r.getUserMedia()};STACK_BASE=STACKTOP=Runtime.alignMemory(STATICTOP);staticSeale d=true;STACK_MAX=STACK_BASE+TOTAL_STACK;DYNAMIC_BASE=DYNAMICTOP=Runtime.alignMem ory(STACK_MAX);assert(DYNAMIC_BASE<TOTAL_MEMORY,"TOTAL_MEMORY not big enough for stack");Module.asmGlobalArg={"Math":Math,"Int8Array":Int8Array,"Int16Array":Int 16Array,"Int32Array":Int32Array,"Uint8Array":Uint8Array,"Uint16Array":Uint16Arra y,"Uint32Array":Uint32Array,"Float32Array":Float32Array,"Float64Array":Float64Ar ray,"NaN":NaN,"Infinity":Infinity};Module.asmLibraryArg={"abort":abort,"assert": assert,"_send":_send,"_emscripten_set_main_loop_timing":_emscripten_set_main_loo p_timing,"_llvm_ctpop_i32":_llvm_ctpop_i32,"_fflush":_fflush,"_pwrite":_pwrite," __reallyNegative":__reallyNegative,"_sbrk":_sbrk,"_llvm_ctpop_i64":_llvm_ctpop_i 64,"_emscripten_memcpy_big":_emscripten_memcpy_big,"_fileno":_fileno,"_sysconf": _sysconf,"___setErrNo":___setErrNo,"_printf":_printf,"_write":_write,"_emscripte n_set_main_loop":_emscripten_set_main_loop,"___errno_location":___errno_location ,"_llvm_cttz_i64":_llvm_cttz_i64,"_mkport":_mkport,"_abort":_abort,"_fwrite":_fw rite,"_time":_time,"_fprintf":_fprintf,"__formatString":__formatString,"STACKTOP ":STACKTOP,"STACK_MAX":STACK_MAX,"tempDoublePtr":tempDoublePtr,"ABORT":ABORT,"ct tz_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._send; var ea=env._emscripten_set_main_loop_timing;var fa=env._llvm_ctpop_i32;var ga=en v._fflush;var ha=env._pwrite;var ia=env.__reallyNegative;var ja=env._sbrk;var ka =env._llvm_ctpop_i64;var la=env._emscripten_memcpy_big;var ma=env._fileno;var na =env._sysconf;var oa=env.___setErrNo;var pa=env._printf;var qa=env._write;var ra =env._emscripten_set_main_loop;var sa=env.___errno_location;var ta=env._llvm_ctt z_i64;var ua=env._mkport;var va=env._abort;var wa=env._fwrite;var xa=env._time;v ar ya=env._fprintf;var za=env.__formatString;var Aa=0.0;
4 // EMSCRIPTEN_START_FUNCS
5 function Ba(a){a=a|0;var b=0;b=i;i=i+a|0;i=i+15&-16;return b|0}function Ca(){ret urn i|0}function Da(a){a=a|0;i=a}function Ea(a,b){a=a|0;b=b|0;if(!n){n=a;o=b}}fu nction Fa(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 Ga(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 Ha(a){a=a|0;C=a}function Ia(){return C| 0}function Ja(){var a=0,b=0,d=0,e=0,f=0;a=i;i=i+16|0;b=a;c[b>>2]=239;c[b+4>>2]=2 00;pa(8,b|0)|0;d=Ra(-14097)|0;e=d&65535;c[b>>2]=e&255;c[b+4>>2]=e>>>8;pa(8,b|0)| 0;c[b>>2]=138;c[b+4>>2]=21;c[b+8>>2]=222;c[b+12>>2]=197;pa(16,b|0)|0;e=Sa(-97530 1238)|0;c[b>>2]=e&255;c[b+4>>2]=e>>>8&255;c[b+8>>2]=e>>>16&255;c[b+12>>2]=e>>>24 ;pa(16,b|0)|0;e=Ta(0,256)|0;f=aa(1024)|0;c[b>>2]=e;c[b+4>>2]=f;pa(32,b|0)|0;f=ta (0,256)|0;e=Pa(1024)|0;c[b>>2]=f;c[b+4>>2]=e;pa(32,b|0)|0;e=ka(1,12545)|0;f=fa(1 2545)|0;c[b>>2]=e;c[b+4>>2]=f;pa(32,b|0)|0;c[b>>2]=fa(-594093059)|0;pa(40,b|0)|0 ;c[b>>2]=((d&65535)%27|0)&65535;pa(40,b|0)|0;d=b;c[d>>2]=0;c[d+4>>2]=16777216;pa (48,b|0)|0;i=a;return 0}function Ka(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0 ,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0 ,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0 ,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ka=0,la=0,ma=0,oa= 0,pa=0,qa=0,ra=0,ta=0,ua=0,wa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha= 0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa= 0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0;do if(a>>>0<245){if(a>>>0<11)b=16;else b=a+ 11&-8;d=b>>>3;e=c[14]|0;f=e>>>d;if(f&3){g=(f&1^1)+d|0;h=g<<1;i=96+(h<<2)|0;j=96+ (h+2<<2)|0;h=c[j>>2]|0;k=h+8|0;l=c[k>>2]|0;do if((i|0)!=(l|0)){if(l>>>0<(c[18]|0 )>>>0)va();m=l+12|0;if((c[m>>2]|0)==(h|0)){c[m>>2]=i;c[j>>2]=l;break}else va()}e lse c[14]=e&~(1<<g);while(0);l=g<<3;c[h+4>>2]=l|3;j=h+(l|4)|0;c[j>>2]=c[j>>2]|1; n=k;return n|0}j=c[16]|0;if(b>>>0>j>>>0){if(f){l=2<<d;i=f<<d&(l|0-l);l=(i&0-i)+- 1|0;i=l>>>12&16;m=l>>>i;l=m>>>5&8;o=m>>>l;m=o>>>2&4;p=o>>>m;o=p>>>1&2;q=p>>>o;p= q>>>1&1;r=(l|i|m|o|p)+(q>>>p)|0;p=r<<1;q=96+(p<<2)|0;o=96+(p+2<<2)|0;p=c[o>>2]|0 ;m=p+8|0;i=c[m>>2]|0;do if((q|0)!=(i|0)){if(i>>>0<(c[18]|0)>>>0)va();l=i+12|0;if ((c[l>>2]|0)==(p|0)){c[l>>2]=q;c[o>>2]=i;s=c[16]|0;break}else va()}else{c[14]=e& ~(1<<r);s=j}while(0);j=r<<3;e=j-b|0;c[p+4>>2]=b|3;i=p+b|0;c[p+(b|4)>>2]=e|1;c[p+ j>>2]=e;if(s){j=c[19]|0;o=s>>>3;q=o<<1;d=96+(q<<2)|0;f=c[14]|0;k=1<<o;if(f&k){o= 96+(q+2<<2)|0;h=c[o>>2]|0;if(h>>>0<(c[18]|0)>>>0)va();else{t=o;u=h}}else{c[14]=f |k;t=96+(q+2<<2)|0;u=d}c[t>>2]=j;c[u+12>>2]=j;c[j+8>>2]=u;c[j+12>>2]=d}c[16]=e;c [19]=i;n=m;return n|0}i=c[15]|0;if(i){e=(i&0-i)+-1|0;i=e>>>12&16;d=e>>>i;e=d>>>5 &8;j=d>>>e;d=j>>>2&4;q=j>>>d;j=q>>>1&2;k=q>>>j;q=k>>>1&1;f=c[360+((e|i|d|j|q)+(k >>>q)<<2)>>2]|0;q=(c[f+4>>2]&-8)-b|0;k=f;j=f;while(1){f=c[k+16>>2]|0;if(!f){d=c[ k+20>>2]|0;if(!d){v=q;w=j;break}else x=d}else x=f;f=(c[x+4>>2]&-8)-b|0;d=f>>>0<q >>>0;q=d?f:q;k=x;j=d?x:j}j=c[18]|0;if(w>>>0<j>>>0)va();k=w+b|0;if(w>>>0>=k>>>0)v a();q=c[w+24>>2]|0;m=c[w+12>>2]|0;do if((m|0)==(w|0)){p=w+20|0;r=c[p>>2]|0;if(!r ){d=w+16|0;f=c[d>>2]|0;if(!f){y=0;break}else{z=f;A=d}}else{z=r;A=p}while(1){p=z+ 20|0;r=c[p>>2]|0;if(r){z=r;A=p;continue}p=z+16|0;r=c[p>>2]|0;if(!r){B=z;C=A;brea k}else{z=r;A=p}}if(C>>>0<j>>>0)va();else{c[C>>2]=0;y=B;break}}else{p=c[w+8>>2]|0 ;if(p>>>0<j>>>0)va();r=p+12|0;if((c[r>>2]|0)!=(w|0))va();d=m+8|0;if((c[d>>2]|0)= =(w|0)){c[r>>2]=m;c[d>>2]=p;y=m;break}else va()}while(0);do if(q){m=c[w+28>>2]|0 ;j=360+(m<<2)|0;if((w|0)==(c[j>>2]|0)){c[j>>2]=y;if(!y){c[15]=c[15]&~(1<<m);brea k}}else{if(q>>>0<(c[18]|0)>>>0)va();m=q+16|0;if((c[m>>2]|0)==(w|0))c[m>>2]=y;els e c[q+20>>2]=y;if(!y)break}m=c[18]|0;if(y>>>0<m>>>0)va();c[y+24>>2]=q;j=c[w+16>> 2]|0;do if(j)if(j>>>0<m>>>0)va();else{c[y+16>>2]=j;c[j+24>>2]=y;break}while(0);j =c[w+20>>2]|0;if(j)if(j>>>0<(c[18]|0)>>>0)va();else{c[y+20>>2]=j;c[j+24>>2]=y;br eak}}while(0);if(v>>>0<16){q=v+b|0;c[w+4>>2]=q|3;j=w+(q+4)|0;c[j>>2]=c[j>>2]|1}e lse{c[w+4>>2]=b|3;c[w+(b|4)>>2]=v|1;c[w+(v+b)>>2]=v;j=c[16]|0;if(j){q=c[19]|0;m= j>>>3;j=m<<1;p=96+(j<<2)|0;d=c[14]|0;r=1<<m;if(d&r){m=96+(j+2<<2)|0;f=c[m>>2]|0; if(f>>>0<(c[18]|0)>>>0)va();else{D=m;E=f}}else{c[14]=d|r;D=96+(j+2<<2)|0;E=p}c[D >>2]=q;c[E+12>>2]=q;c[q+8>>2]=E;c[q+12>>2]=p}c[16]=v;c[19]=k}n=w+8|0;return n|0} else F=b}else F=b}else if(a>>>0<=4294967231){p=a+11|0;q=p&-8;j=c[15]|0;if(j){r=0 -q|0;d=p>>>8;if(d)if(q>>>0>16777215)G=31;else{p=(d+1048320|0)>>>16&8;f=d<<p;d=(f +520192|0)>>>16&4;m=f<<d;f=(m+245760|0)>>>16&2;i=14-(d|p|f)+(m<<f>>>15)|0;G=q>>> (i+7|0)&1|i<<1}else G=0;i=c[360+(G<<2)>>2]|0;a:do if(!i){H=r;I=0;J=0}else{if((G| 0)==31)K=0;else K=25-(G>>>1)|0;f=r;m=0;p=q<<K;d=i;e=0;while(1){h=c[d+4>>2]&-8;o= h-q|0;if(o>>>0<f>>>0)if((h|0)==(q|0)){H=o;I=d;J=d;break a}else{L=o;M=d}else{L=f; M=e}o=c[d+20>>2]|0;d=c[d+(p>>>31<<2)+16>>2]|0;h=(o|0)==0|(o|0)==(d|0)?m:o;if(!d) {H=L;I=h;J=M;break}else{f=L;m=h;p=p<<1;e=M}}}while(0);if((I|0)==0&(J|0)==0){i=2< <G;r=j&(i|0-i);if(!r){F=q;break}i=(r&0-r)+-1|0;r=i>>>12&16;k=i>>>r;i=k>>>5&8;e=k >>>i;k=e>>>2&4;p=e>>>k;e=p>>>1&2;m=p>>>e;p=m>>>1&1;N=c[360+((i|r|k|e|p)+(m>>>p)< <2)>>2]|0}else N=I;if(!N){O=H;P=J}else{p=H;m=N;e=J;while(1){k=(c[m+4>>2]&-8)-q|0 ;r=k>>>0<p>>>0;i=r?k:p;k=r?m:e;r=c[m+16>>2]|0;if(r){p=i;m=r;e=k;continue}m=c[m+2 0>>2]|0;if(!m){O=i;P=k;break}else{p=i;e=k}}}if((P|0)!=0?O>>>0<((c[16]|0)-q|0)>>> 0:0){e=c[18]|0;if(P>>>0<e>>>0)va();p=P+q|0;if(P>>>0>=p>>>0)va();m=c[P+24>>2]|0;j =c[P+12>>2]|0;do if((j|0)==(P|0)){k=P+20|0;i=c[k>>2]|0;if(!i){r=P+16|0;f=c[r>>2] |0;if(!f){Q=0;break}else{R=f;S=r}}else{R=i;S=k}while(1){k=R+20|0;i=c[k>>2]|0;if( i){R=i;S=k;continue}k=R+16|0;i=c[k>>2]|0;if(!i){T=R;U=S;break}else{R=i;S=k}}if(U >>>0<e>>>0)va();else{c[U>>2]=0;Q=T;break}}else{k=c[P+8>>2]|0;if(k>>>0<e>>>0)va() ;i=k+12|0;if((c[i>>2]|0)!=(P|0))va();r=j+8|0;if((c[r>>2]|0)==(P|0)){c[i>>2]=j;c[ r>>2]=k;Q=j;break}else va()}while(0);do if(m){j=c[P+28>>2]|0;e=360+(j<<2)|0;if(( P|0)==(c[e>>2]|0)){c[e>>2]=Q;if(!Q){c[15]=c[15]&~(1<<j);break}}else{if(m>>>0<(c[ 18]|0)>>>0)va();j=m+16|0;if((c[j>>2]|0)==(P|0))c[j>>2]=Q;else c[m+20>>2]=Q;if(!Q )break}j=c[18]|0;if(Q>>>0<j>>>0)va();c[Q+24>>2]=m;e=c[P+16>>2]|0;do if(e)if(e>>> 0<j>>>0)va();else{c[Q+16>>2]=e;c[e+24>>2]=Q;break}while(0);e=c[P+20>>2]|0;if(e)i f(e>>>0<(c[18]|0)>>>0)va();else{c[Q+20>>2]=e;c[e+24>>2]=Q;break}}while(0);b:do i f(O>>>0>=16){c[P+4>>2]=q|3;c[P+(q|4)>>2]=O|1;c[P+(O+q)>>2]=O;m=O>>>3;if(O>>>0<25 6){e=m<<1;j=96+(e<<2)|0;k=c[14]|0;r=1<<m;do if(!(k&r)){c[14]=k|r;V=96+(e+2<<2)|0 ;W=j}else{m=96+(e+2<<2)|0;i=c[m>>2]|0;if(i>>>0>=(c[18]|0)>>>0){V=m;W=i;break}va( )}while(0);c[V>>2]=p;c[W+12>>2]=p;c[P+(q+8)>>2]=W;c[P+(q+12)>>2]=j;break}e=O>>>8 ;if(e)if(O>>>0>16777215)X=31;else{r=(e+1048320|0)>>>16&8;k=e<<r;e=(k+520192|0)>> >16&4;i=k<<e;k=(i+245760|0)>>>16&2;m=14-(e|r|k)+(i<<k>>>15)|0;X=O>>>(m+7|0)&1|m< <1}else X=0;m=360+(X<<2)|0;c[P+(q+28)>>2]=X;c[P+(q+20)>>2]=0;c[P+(q+16)>>2]=0;k= c[15]|0;i=1<<X;if(!(k&i)){c[15]=k|i;c[m>>2]=p;c[P+(q+24)>>2]=m;c[P+(q+12)>>2]=p; c[P+(q+8)>>2]=p;break}i=c[m>>2]|0;if((X|0)==31)Y=0;else Y=25-(X>>>1)|0;c:do if(( c[i+4>>2]&-8|0)!=(O|0)){m=O<<Y;k=i;while(1){r=k+(m>>>31<<2)+16|0;e=c[r>>2]|0;if( !e){Z=r;_=k;break}if((c[e+4>>2]&-8|0)==(O|0)){$=e;break c}else{m=m<<1;k=e}}if(Z> >>0<(c[18]|0)>>>0)va();else{c[Z>>2]=p;c[P+(q+24)>>2]=_;c[P+(q+12)>>2]=p;c[P+(q+8 )>>2]=p;break b}}else $=i;while(0);i=$+8|0;j=c[i>>2]|0;k=c[18]|0;if($>>>0>=k>>>0 &j>>>0>=k>>>0){c[j+12>>2]=p;c[i>>2]=p;c[P+(q+8)>>2]=j;c[P+(q+12)>>2]=$;c[P+(q+24 )>>2]=0;break}else va()}else{j=O+q|0;c[P+4>>2]=j|3;i=P+(j+4)|0;c[i>>2]=c[i>>2]|1 }while(0);n=P+8|0;return n|0}else F=q}else F=q}else F=-1;while(0);P=c[16]|0;if(P >>>0>=F>>>0){O=P-F|0;$=c[19]|0;if(O>>>0>15){c[19]=$+F;c[16]=O;c[$+(F+4)>>2]=O|1; c[$+P>>2]=O;c[$+4>>2]=F|3}else{c[16]=0;c[19]=0;c[$+4>>2]=P|3;O=$+(P+4)|0;c[O>>2] =c[O>>2]|1}n=$+8|0;return n|0}$=c[17]|0;if($>>>0>F>>>0){O=$-F|0;c[17]=O;$=c[20]| 0;c[20]=$+F;c[$+(F+4)>>2]=O|1;c[$+4>>2]=F|3;n=$+8|0;return n|0}do if(!(c[132]|0) ){$=na(30)|0;if(!($+-1&$)){c[134]=$;c[133]=$;c[135]=-1;c[136]=-1;c[137]=0;c[125] =0;c[132]=(xa(0)|0)&-16^1431655768;break}else va()}while(0);$=F+48|0;O=c[134]|0; P=F+47|0;_=O+P|0;Z=0-O|0;O=_&Z;if(O>>>0<=F>>>0){n=0;return n|0}Y=c[124]|0;if((Y| 0)!=0?(X=c[122]|0,W=X+O|0,W>>>0<=X>>>0|W>>>0>Y>>>0):0){n=0;return n|0}d:do if(!( c[125]&4)){Y=c[20]|0;e:do if(Y){W=504|0;while(1){X=c[W>>2]|0;if(X>>>0<=Y>>>0?(V= W+4|0,(X+(c[V>>2]|0)|0)>>>0>Y>>>0):0){aa=W;ba=V;ca=W;break}W=c[W+8>>2]|0;if(!W){ da=181;break e}}if(ca){W=_-(c[17]|0)&Z;if(W>>>0<2147483647){V=ja(W|0)|0;if((V|0) ==((c[aa>>2]|0)+(c[ba>>2]|0)|0)){ea=V;fa=W;da=190}else{ga=V;ha=W;da=191}}else ia =0}else da=181}else da=181;while(0);do if((da|0)==181){Y=ja(0)|0;if((Y|0)!=(-1|0 )){q=Y;W=c[133]|0;V=W+-1|0;if(!(V&q))ka=O;else ka=O-q+(V+q&0-W)|0;W=c[122]|0;q=W +ka|0;if(ka>>>0>F>>>0&ka>>>0<2147483647){V=c[124]|0;if((V|0)!=0?q>>>0<=W>>>0|q>> >0>V>>>0:0){ia=0;break}V=ja(ka|0)|0;if((V|0)==(Y|0)){ea=Y;fa=ka;da=190}else{ga=V ;ha=ka;da=191}}else ia=0}else ia=0}while(0);f:do if((da|0)==190)if((ea|0)==(-1|0 ))ia=fa;else{la=ea;ma=fa;da=201;break d}else if((da|0)==191){V=0-ha|0;do if((ga| 0)!=(-1|0)&ha>>>0<2147483647&$>>>0>ha>>>0?(Y=c[134]|0,q=P-ha+Y&0-Y,q>>>0<2147483 647):0)if((ja(q|0)|0)==(-1|0)){ja(V|0)|0;ia=0;break f}else{oa=q+ha|0;break}else oa=ha;while(0);if((ga|0)==(-1|0))ia=0;else{la=ga;ma=oa;da=201;break d}}while(0); c[125]=c[125]|4;pa=ia;da=198}else{pa=0;da=198}while(0);if((((da|0)==198?O>>>0<21 47483647:0)?(ia=ja(O|0)|0,O=ja(0)|0,(ia|0)!=(-1|0)&(O|0)!=(-1|0)&ia>>>0<O>>>0):0 )?(oa=O-ia|0,O=oa>>>0>(F+40|0)>>>0,O):0){la=ia;ma=O?oa:pa;da=201}if((da|0)==201) {pa=(c[122]|0)+ma|0;c[122]=pa;if(pa>>>0>(c[123]|0)>>>0)c[123]=pa;pa=c[20]|0;g:do if(pa){oa=504|0;do{O=c[oa>>2]|0;ia=oa+4|0;ga=c[ia>>2]|0;if((la|0)==(O+ga|0)){qa =O;ra=ia;ta=ga;ua=oa;da=213;break}oa=c[oa+8>>2]|0}while((oa|0)!=0);if(((da|0)==2 13?(c[ua+12>>2]&8|0)==0:0)?pa>>>0>=qa>>>0&pa>>>0<la>>>0:0){c[ra>>2]=ta+ma;oa=(c[ 17]|0)+ma|0;ga=pa+8|0;if(!(ga&7))wa=0;else wa=0-ga&7;ga=oa-wa|0;c[20]=pa+wa;c[17 ]=ga;c[pa+(wa+4)>>2]=ga|1;c[pa+(oa+4)>>2]=40;c[21]=c[136];break}oa=c[18]|0;if(la >>>0<oa>>>0){c[18]=la;ya=la}else ya=oa;oa=la+ma|0;ga=504|0;do{if((c[ga>>2]|0)==( oa|0)){za=ga;Aa=ga;da=223;break}ga=c[ga+8>>2]|0}while((ga|0)!=0);if((da|0)==223? (c[Aa+12>>2]&8|0)==0:0){c[za>>2]=la;ga=Aa+4|0;c[ga>>2]=(c[ga>>2]|0)+ma;ga=la+8|0 ;if(!(ga&7))Ba=0;else Ba=0-ga&7;ga=la+(ma+8)|0;if(!(ga&7))Ca=0;else Ca=0-ga&7;ga =la+(Ca+ma)|0;oa=Ba+F|0;ia=la+oa|0;O=ga-(la+Ba)-F|0;c[la+(Ba+4)>>2]=F|3;h:do if( (ga|0)!=(pa|0)){if((ga|0)==(c[19]|0)){ha=(c[16]|0)+O|0;c[16]=ha;c[19]=ia;c[la+(o a+4)>>2]=ha|1;c[la+(ha+oa)>>2]=ha;break}ha=ma+4|0;P=c[la+(ha+Ca)>>2]|0;if((P&3|0 )==1){$=P&-8;fa=P>>>3;i:do if(P>>>0>=256){ea=c[la+((Ca|24)+ma)>>2]|0;ka=c[la+(ma +12+Ca)>>2]|0;do if((ka|0)==(ga|0)){ba=Ca|16;aa=la+(ha+ba)|0;Z=c[aa>>2]|0;if(!Z) {_=la+(ba+ma)|0;ba=c[_>>2]|0;if(!ba){Da=0;break}else{Ea=ba;Fa=_}}else{Ea=Z;Fa=aa }while(1){aa=Ea+20|0;Z=c[aa>>2]|0;if(Z){Ea=Z;Fa=aa;continue}aa=Ea+16|0;Z=c[aa>>2 ]|0;if(!Z){Ga=Ea;Ha=Fa;break}else{Ea=Z;Fa=aa}}if(Ha>>>0<ya>>>0)va();else{c[Ha>>2 ]=0;Da=Ga;break}}else{aa=c[la+((Ca|8)+ma)>>2]|0;if(aa>>>0<ya>>>0)va();Z=aa+12|0; if((c[Z>>2]|0)!=(ga|0))va();_=ka+8|0;if((c[_>>2]|0)==(ga|0)){c[Z>>2]=ka;c[_>>2]= aa;Da=ka;break}else va()}while(0);if(!ea)break;ka=c[la+(ma+28+Ca)>>2]|0;aa=360+( ka<<2)|0;do if((ga|0)!=(c[aa>>2]|0)){if(ea>>>0<(c[18]|0)>>>0)va();_=ea+16|0;if(( c[_>>2]|0)==(ga|0))c[_>>2]=Da;else c[ea+20>>2]=Da;if(!Da)break i}else{c[aa>>2]=D a;if(Da)break;c[15]=c[15]&~(1<<ka);break i}while(0);ka=c[18]|0;if(Da>>>0<ka>>>0) va();c[Da+24>>2]=ea;aa=Ca|16;_=c[la+(aa+ma)>>2]|0;do if(_)if(_>>>0<ka>>>0)va();e lse{c[Da+16>>2]=_;c[_+24>>2]=Da;break}while(0);_=c[la+(ha+aa)>>2]|0;if(!_)break; if(_>>>0<(c[18]|0)>>>0)va();else{c[Da+20>>2]=_;c[_+24>>2]=Da;break}}else{_=c[la+ ((Ca|8)+ma)>>2]|0;ka=c[la+(ma+12+Ca)>>2]|0;ea=96+(fa<<1<<2)|0;do if((_|0)!=(ea|0 )){if(_>>>0<ya>>>0)va();if((c[_+12>>2]|0)==(ga|0))break;va()}while(0);if((ka|0)= =(_|0)){c[14]=c[14]&~(1<<fa);break}do if((ka|0)==(ea|0))Ia=ka+8|0;else{if(ka>>>0 <ya>>>0)va();aa=ka+8|0;if((c[aa>>2]|0)==(ga|0)){Ia=aa;break}va()}while(0);c[_+12 >>2]=ka;c[Ia>>2]=_}while(0);Ja=la+(($|Ca)+ma)|0;Ka=$+O|0}else{Ja=ga;Ka=O}fa=Ja+4 |0;c[fa>>2]=c[fa>>2]&-2;c[la+(oa+4)>>2]=Ka|1;c[la+(Ka+oa)>>2]=Ka;fa=Ka>>>3;if(Ka >>>0<256){ha=fa<<1;P=96+(ha<<2)|0;ea=c[14]|0;aa=1<<fa;do if(!(ea&aa)){c[14]=ea|a a;La=96+(ha+2<<2)|0;Ma=P}else{fa=96+(ha+2<<2)|0;Z=c[fa>>2]|0;if(Z>>>0>=(c[18]|0) >>>0){La=fa;Ma=Z;break}va()}while(0);c[La>>2]=ia;c[Ma+12>>2]=ia;c[la+(oa+8)>>2]= Ma;c[la+(oa+12)>>2]=P;break}ha=Ka>>>8;do if(!ha)Na=0;else{if(Ka>>>0>16777215){Na =31;break}aa=(ha+1048320|0)>>>16&8;ea=ha<<aa;$=(ea+520192|0)>>>16&4;Z=ea<<$;ea=( Z+245760|0)>>>16&2;fa=14-($|aa|ea)+(Z<<ea>>>15)|0;Na=Ka>>>(fa+7|0)&1|fa<<1}while (0);ha=360+(Na<<2)|0;c[la+(oa+28)>>2]=Na;c[la+(oa+20)>>2]=0;c[la+(oa+16)>>2]=0;P =c[15]|0;fa=1<<Na;if(!(P&fa)){c[15]=P|fa;c[ha>>2]=ia;c[la+(oa+24)>>2]=ha;c[la+(o a+12)>>2]=ia;c[la+(oa+8)>>2]=ia;break}fa=c[ha>>2]|0;if((Na|0)==31)Oa=0;else Oa=2 5-(Na>>>1)|0;j:do if((c[fa+4>>2]&-8|0)!=(Ka|0)){ha=Ka<<Oa;P=fa;while(1){ea=P+(ha >>>31<<2)+16|0;Z=c[ea>>2]|0;if(!Z){Pa=ea;Qa=P;break}if((c[Z+4>>2]&-8|0)==(Ka|0)) {Ra=Z;break j}else{ha=ha<<1;P=Z}}if(Pa>>>0<(c[18]|0)>>>0)va();else{c[Pa>>2]=ia;c [la+(oa+24)>>2]=Qa;c[la+(oa+12)>>2]=ia;c[la+(oa+8)>>2]=ia;break h}}else Ra=fa;wh ile(0);fa=Ra+8|0;P=c[fa>>2]|0;ha=c[18]|0;if(Ra>>>0>=ha>>>0&P>>>0>=ha>>>0){c[P+12 >>2]=ia;c[fa>>2]=ia;c[la+(oa+8)>>2]=P;c[la+(oa+12)>>2]=Ra;c[la+(oa+24)>>2]=0;bre ak}else va()}else{P=(c[17]|0)+O|0;c[17]=P;c[20]=ia;c[la+(oa+4)>>2]=P|1}while(0); n=la+(Ba|8)|0;return n|0}oa=504|0;while(1){ia=c[oa>>2]|0;if(ia>>>0<=pa>>>0?(O=c[ oa+4>>2]|0,ga=ia+O|0,ga>>>0>pa>>>0):0){Sa=ia;Ta=O;Ua=ga;break}oa=c[oa+8>>2]|0}oa =Sa+(Ta+-39)|0;if(!(oa&7))Va=0;else Va=0-oa&7;oa=Sa+(Ta+-47+Va)|0;ga=oa>>>0<(pa+ 16|0)>>>0?pa:oa;oa=ga+8|0;O=la+8|0;if(!(O&7))Wa=0;else Wa=0-O&7;O=ma+-40-Wa|0;c[ 20]=la+Wa;c[17]=O;c[la+(Wa+4)>>2]=O|1;c[la+(ma+-36)>>2]=40;c[21]=c[136];c[ga+4>> 2]=27;c[oa+0>>2]=c[126];c[oa+4>>2]=c[127];c[oa+8>>2]=c[128];c[oa+12>>2]=c[129];c [126]=la;c[127]=ma;c[129]=0;c[128]=oa;oa=ga+28|0;c[oa>>2]=7;if((ga+32|0)>>>0<Ua> >>0){O=oa;do{oa=O;O=O+4|0;c[O>>2]=7}while((oa+8|0)>>>0<Ua>>>0)}if((ga|0)!=(pa|0) ){O=ga-pa|0;oa=pa+(O+4)|0;c[oa>>2]=c[oa>>2]&-2;c[pa+4>>2]=O|1;c[pa+O>>2]=O;oa=O> >>3;if(O>>>0<256){ia=oa<<1;P=96+(ia<<2)|0;fa=c[14]|0;ha=1<<oa;do if(!(fa&ha)){c[ 14]=fa|ha;Xa=96+(ia+2<<2)|0;Ya=P}else{oa=96+(ia+2<<2)|0;_=c[oa>>2]|0;if(_>>>0>=( c[18]|0)>>>0){Xa=oa;Ya=_;break}va()}while(0);c[Xa>>2]=pa;c[Ya+12>>2]=pa;c[pa+8>> 2]=Ya;c[pa+12>>2]=P;break}ia=O>>>8;if(ia)if(O>>>0>16777215)Za=31;else{ha=(ia+104 8320|0)>>>16&8;fa=ia<<ha;ia=(fa+520192|0)>>>16&4;ga=fa<<ia;fa=(ga+245760|0)>>>16 &2;_=14-(ia|ha|fa)+(ga<<fa>>>15)|0;Za=O>>>(_+7|0)&1|_<<1}else Za=0;_=360+(Za<<2) |0;c[pa+28>>2]=Za;c[pa+20>>2]=0;c[pa+16>>2]=0;fa=c[15]|0;ga=1<<Za;if(!(fa&ga)){c [15]=fa|ga;c[_>>2]=pa;c[pa+24>>2]=_;c[pa+12>>2]=pa;c[pa+8>>2]=pa;break}ga=c[_>>2 ]|0;if((Za|0)==31)_a=0;else _a=25-(Za>>>1)|0;k:do if((c[ga+4>>2]&-8|0)!=(O|0)){_ =O<<_a;fa=ga;while(1){ha=fa+(_>>>31<<2)+16|0;ia=c[ha>>2]|0;if(!ia){$a=ha;ab=fa;b reak}if((c[ia+4>>2]&-8|0)==(O|0)){bb=ia;break k}else{_=_<<1;fa=ia}}if($a>>>0<(c[ 18]|0)>>>0)va();else{c[$a>>2]=pa;c[pa+24>>2]=ab;c[pa+12>>2]=pa;c[pa+8>>2]=pa;bre ak g}}else bb=ga;while(0);ga=bb+8|0;O=c[ga>>2]|0;P=c[18]|0;if(bb>>>0>=P>>>0&O>>> 0>=P>>>0){c[O+12>>2]=pa;c[ga>>2]=pa;c[pa+8>>2]=O;c[pa+12>>2]=bb;c[pa+24>>2]=0;br eak}else va()}}else{O=c[18]|0;if((O|0)==0|la>>>0<O>>>0)c[18]=la;c[126]=la;c[127] =ma;c[129]=0;c[23]=c[132];c[22]=-1;O=0;do{ga=O<<1;P=96+(ga<<2)|0;c[96+(ga+3<<2)> >2]=P;c[96+(ga+2<<2)>>2]=P;O=O+1|0}while((O|0)!=32);O=la+8|0;if(!(O&7))cb=0;else cb=0-O&7;O=ma+-40-cb|0;c[20]=la+cb;c[17]=O;c[la+(cb+4)>>2]=O|1;c[la+(ma+-36)>>2 ]=40;c[21]=c[136]}while(0);ma=c[17]|0;if(ma>>>0>F>>>0){la=ma-F|0;c[17]=la;ma=c[2 0]|0;c[20]=ma+F;c[ma+(F+4)>>2]=la|1;c[ma+4>>2]=F|3;n=ma+8|0;return n|0}}c[(sa()| 0)>>2]=12;n=0;return n|0}function La(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;if(!a)return;b=a+-8|0;d=c[18]|0;if(b>> >0<d>>>0)va();e=c[a+-4>>2]|0;f=e&3;if((f|0)==1)va();g=e&-8;h=a+(g+-8)|0;do if(!( e&1)){i=c[b>>2]|0;if(!f)return;j=-8-i|0;k=a+j|0;l=i+g|0;if(k>>>0<d>>>0)va();if(( k|0)==(c[19]|0)){m=a+(g+-4)|0;n=c[m>>2]|0;if((n&3|0)!=3){o=k;p=l;break}c[16]=l;c [m>>2]=n&-2;c[a+(j+4)>>2]=l|1;c[h>>2]=l;return}n=i>>>3;if(i>>>0<256){i=c[a+(j+8) >>2]|0;m=c[a+(j+12)>>2]|0;q=96+(n<<1<<2)|0;if((i|0)!=(q|0)){if(i>>>0<d>>>0)va(); if((c[i+12>>2]|0)!=(k|0))va()}if((m|0)==(i|0)){c[14]=c[14]&~(1<<n);o=k;p=l;break }if((m|0)!=(q|0)){if(m>>>0<d>>>0)va();q=m+8|0;if((c[q>>2]|0)==(k|0))r=q;else va( )}else r=m+8|0;c[i+12>>2]=m;c[r>>2]=i;o=k;p=l;break}i=c[a+(j+24)>>2]|0;m=c[a+(j+ 12)>>2]|0;do if((m|0)==(k|0)){q=a+(j+20)|0;n=c[q>>2]|0;if(!n){s=a+(j+16)|0;t=c[s >>2]|0;if(!t){u=0;break}else{v=t;w=s}}else{v=n;w=q}while(1){q=v+20|0;n=c[q>>2]|0 ;if(n){v=n;w=q;continue}q=v+16|0;n=c[q>>2]|0;if(!n){x=v;y=w;break}else{v=n;w=q}} if(y>>>0<d>>>0)va();else{c[y>>2]=0;u=x;break}}else{q=c[a+(j+8)>>2]|0;if(q>>>0<d> >>0)va();n=q+12|0;if((c[n>>2]|0)!=(k|0))va();s=m+8|0;if((c[s>>2]|0)==(k|0)){c[n> >2]=m;c[s>>2]=q;u=m;break}else va()}while(0);if(i){m=c[a+(j+28)>>2]|0;q=360+(m<< 2)|0;if((k|0)==(c[q>>2]|0)){c[q>>2]=u;if(!u){c[15]=c[15]&~(1<<m);o=k;p=l;break}} else{if(i>>>0<(c[18]|0)>>>0)va();m=i+16|0;if((c[m>>2]|0)==(k|0))c[m>>2]=u;else c [i+20>>2]=u;if(!u){o=k;p=l;break}}m=c[18]|0;if(u>>>0<m>>>0)va();c[u+24>>2]=i;q=c [a+(j+16)>>2]|0;do if(q)if(q>>>0<m>>>0)va();else{c[u+16>>2]=q;c[q+24>>2]=u;break }while(0);q=c[a+(j+20)>>2]|0;if(q)if(q>>>0<(c[18]|0)>>>0)va();else{c[u+20>>2]=q; c[q+24>>2]=u;o=k;p=l;break}else{o=k;p=l}}else{o=k;p=l}}else{o=b;p=g}while(0);if( o>>>0>=h>>>0)va();b=a+(g+-4)|0;u=c[b>>2]|0;if(!(u&1))va();if(!(u&2)){if((h|0)==( c[20]|0)){d=(c[17]|0)+p|0;c[17]=d;c[20]=o;c[o+4>>2]=d|1;if((o|0)!=(c[19]|0))retu rn;c[19]=0;c[16]=0;return}if((h|0)==(c[19]|0)){d=(c[16]|0)+p|0;c[16]=d;c[19]=o;c [o+4>>2]=d|1;c[o+d>>2]=d;return}d=(u&-8)+p|0;x=u>>>3;do if(u>>>0>=256){y=c[a+(g+ 16)>>2]|0;w=c[a+(g|4)>>2]|0;do if((w|0)==(h|0)){v=a+(g+12)|0;r=c[v>>2]|0;if(!r){ f=a+(g+8)|0;e=c[f>>2]|0;if(!e){z=0;break}else{A=e;B=f}}else{A=r;B=v}while(1){v=A +20|0;r=c[v>>2]|0;if(r){A=r;B=v;continue}v=A+16|0;r=c[v>>2]|0;if(!r){C=A;D=B;bre ak}else{A=r;B=v}}if(D>>>0<(c[18]|0)>>>0)va();else{c[D>>2]=0;z=C;break}}else{v=c[ a+g>>2]|0;if(v>>>0<(c[18]|0)>>>0)va();r=v+12|0;if((c[r>>2]|0)!=(h|0))va();f=w+8| 0;if((c[f>>2]|0)==(h|0)){c[r>>2]=w;c[f>>2]=v;z=w;break}else va()}while(0);if(y){ w=c[a+(g+20)>>2]|0;l=360+(w<<2)|0;if((h|0)==(c[l>>2]|0)){c[l>>2]=z;if(!z){c[15]= c[15]&~(1<<w);break}}else{if(y>>>0<(c[18]|0)>>>0)va();w=y+16|0;if((c[w>>2]|0)==( h|0))c[w>>2]=z;else c[y+20>>2]=z;if(!z)break}w=c[18]|0;if(z>>>0<w>>>0)va();c[z+2 4>>2]=y;l=c[a+(g+8)>>2]|0;do if(l)if(l>>>0<w>>>0)va();else{c[z+16>>2]=l;c[l+24>> 2]=z;break}while(0);l=c[a+(g+12)>>2]|0;if(l)if(l>>>0<(c[18]|0)>>>0)va();else{c[z +20>>2]=l;c[l+24>>2]=z;break}}}else{l=c[a+g>>2]|0;w=c[a+(g|4)>>2]|0;y=96+(x<<1<< 2)|0;if((l|0)!=(y|0)){if(l>>>0<(c[18]|0)>>>0)va();if((c[l+12>>2]|0)!=(h|0))va()} if((w|0)==(l|0)){c[14]=c[14]&~(1<<x);break}if((w|0)!=(y|0)){if(w>>>0<(c[18]|0)>> >0)va();y=w+8|0;if((c[y>>2]|0)==(h|0))E=y;else va()}else E=w+8|0;c[l+12>>2]=w;c[ E>>2]=l}while(0);c[o+4>>2]=d|1;c[o+d>>2]=d;if((o|0)==(c[19]|0)){c[16]=d;return}e lse F=d}else{c[b>>2]=u&-2;c[o+4>>2]=p|1;c[o+p>>2]=p;F=p}p=F>>>3;if(F>>>0<256){u= p<<1;b=96+(u<<2)|0;d=c[14]|0;E=1<<p;if(d&E){p=96+(u+2<<2)|0;h=c[p>>2]|0;if(h>>>0 <(c[18]|0)>>>0)va();else{G=p;H=h}}else{c[14]=d|E;G=96+(u+2<<2)|0;H=b}c[G>>2]=o;c [H+12>>2]=o;c[o+8>>2]=H;c[o+12>>2]=b;return}b=F>>>8;if(b)if(F>>>0>16777215)I=31; else{H=(b+1048320|0)>>>16&8;G=b<<H;b=(G+520192|0)>>>16&4;u=G<<b;G=(u+245760|0)>> >16&2;E=14-(b|H|G)+(u<<G>>>15)|0;I=F>>>(E+7|0)&1|E<<1}else I=0;E=360+(I<<2)|0;c[ o+28>>2]=I;c[o+20>>2]=0;c[o+16>>2]=0;G=c[15]|0;u=1<<I;a:do if(G&u){H=c[E>>2]|0;i f((I|0)==31)J=0;else J=25-(I>>>1)|0;b:do if((c[H+4>>2]&-8|0)!=(F|0)){b=F<<J;d=H; while(1){h=d+(b>>>31<<2)+16|0;p=c[h>>2]|0;if(!p){K=h;L=d;break}if((c[p+4>>2]&-8| 0)==(F|0)){M=p;break b}else{b=b<<1;d=p}}if(K>>>0<(c[18]|0)>>>0)va();else{c[K>>2] =o;c[o+24>>2]=L;c[o+12>>2]=o;c[o+8>>2]=o;break a}}else M=H;while(0);H=M+8|0;d=c[ H>>2]|0;b=c[18]|0;if(M>>>0>=b>>>0&d>>>0>=b>>>0){c[d+12>>2]=o;c[H>>2]=o;c[o+8>>2] =d;c[o+12>>2]=M;c[o+24>>2]=0;break}else va()}else{c[15]=G|u;c[E>>2]=o;c[o+24>>2] =E;c[o+12>>2]=o;c[o+8>>2]=o}while(0);o=(c[22]|0)+-1|0;c[22]=o;if(!o)N=512|0;else return;while(1){o=c[N>>2]|0;if(!o)break;else N=o+8|0}c[22]=-1;return}function M a(){}function Na(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;g=b&3;h=d|d<<8|d<<16|d<<24;i=f&~3;if(g){g=b+4-g|0;while((b|0)<(g|0)) {a[b>>0]=d;b=b+1|0}}while((b|0)<(i|0)){c[b>>2]=h;b=b+4|0}}while((b|0)<(f|0)){a[b >>0]=d;b=b+1|0}return b-e|0}function Oa(b){b=b|0;var c=0;c=b;while(a[c>>0]|0)c=c +1|0;return c-b|0}function Pa(b){b=b|0;var c=0;c=a[m+(b&255)>>0]|0;if((c|0)<8)re turn 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 Qa(b,d,e){b=b |0;d=d|0;e=e|0;var f=0;if((e|0)>=4096)return la(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}whil e((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 Ra(a){a=a|0;return (a&255)<<8| a>>8&255|0}function Sa(a){a=a|0;return (a&255)<<24|(a>>8&255)<<16|(a>>16&255)<<8 |a>>>24|0}function Ta(a,b){a=a|0;b=b|0;var c=0;c=aa(b)|0;if((c|0)==32)c=c+(aa(a) |0)|0;C=0;return c|0}function Ua(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;var e=0;e=a+c> >>0;return (C=b+d+(e>>>0<a>>>0|0)>>>0,e|0)|0}function Va(a,b,c,d){a=a|0;b=b|0;c= c|0;d=d|0;var e=0;e=b-d>>>0;e=b-d-(c>>>0>a>>>0|0)>>>0;return (C=e,a-c>>>0|0)|0}f unction Wa(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 Xa(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<3 2){C=b>>>c;return a>>>c|(b&(1<<c)-1)<<32-c}C=0;return b>>>c-32|0}function Ya(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 Za(a,b){a=a|0;b=b|0;var c=0,d=0,e=0,f=0;c=a&6 5535;d=b&65535;e=_(d,c)|0;f=a>>>16;a=(e>>>16)+(_(d,f)|0)|0;d=b>>>16;b=_(d,c)|0;r eturn (C=(a>>>16)+(_(d,f)|0)+(((a&65535)+b|0)>>>16)|0,a+b<<16|e&65535|0)|0}funct ion _a(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;e=b>>31|((b|0)<0 ?-1:0)<<1;f=((b|0)<0?-1:0)>>31|((b|0)<0?-1:0)<<1;g=d>>31|((d|0)<0?-1:0)<<1;h=((d |0)<0?-1:0)>>31|((d|0)<0?-1:0)<<1;i=Va(e^a,f^b,e,f)|0;b=C;a=g^e;e=h^f;f=Va((db(i ,b,Va(g^c,h^d,g,h)|0,C,0)|0)^a,C^e,a,e)|0;return f|0}function $a(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,m=0;f=i;i=i+8|0;g=f|0;h=b>>31|((b| 0)<0?-1:0)<<1;j=((b|0)<0?-1:0)>>31|((b|0)<0?-1:0)<<1;k=e>>31|((e|0)<0?-1:0)<<1;l =((e|0)<0?-1:0)>>31|((e|0)<0?-1:0)<<1;m=Va(h^a,j^b,h,j)|0;b=C;db(m,b,Va(k^d,l^e, k,l)|0,C,g)|0;l=Va(c[g>>2]^h,c[g+4>>2]^j,h,j)|0;j=C;i=f;return (C=j,l)|0}functio n ab(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;var e=0,f=0;e=a;a=c;c=Za(e,a)|0;f=C;return (C=(_(b,a)|0)+(_(d,e)|0)+f|f&0,c|0|0)|0}function bb(a,b,c,d){a=a|0;b=b|0;c=c|0; d=d|0;var e=0;e=db(a,b,c,d,0)|0;return e|0}function cb(a,b,d,e){a=a|0;b=b|0;d=d| 0;e=e|0;var f=0,g=0;f=i;i=i+8|0;g=f|0;db(a,b,d,e,g)|0;i=f;return (C=c[g+4>>2]|0, c[g>>2]|0)|0}function db(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,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D= 0,E=0,F=0,G=0,H=0;g=a;h=b;i=h;j=d;k=e;l=k;if(!i){m=(f|0)!=0;if(!l){if(m){c[f>>2] =(g>>>0)%(j>>>0);c[f+4>>2]=0}n=0;o=(g>>>0)/(j>>>0)>>>0;return (C=n,o)|0}else{if( !m){n=0;o=0;return (C=n,o)|0}c[f>>2]=a|0;c[f+4>>2]=b&0;n=0;o=0;return (C=n,o)|0} }m=(l|0)==0;do if(j){if(!m){p=(aa(l|0)|0)-(aa(i|0)|0)|0;if(p>>>0<=31){q=p+1|0;r= 31-p|0;s=p-31>>31;t=q;u=g>>>(q>>>0)&s|i<<r;v=i>>>(q>>>0)&s;w=0;x=g<<r;break}if(! f){n=0;o=0;return (C=n,o)|0}c[f>>2]=a|0;c[f+4>>2]=h|b&0;n=0;o=0;return (C=n,o)|0 }r=j-1|0;if(r&j){s=(aa(j|0)|0)+33-(aa(i|0)|0)|0;q=64-s|0;p=32-s|0;y=p>>31;z=s-32 |0;A=z>>31;t=s;u=p-1>>31&i>>>(z>>>0)|(i<<p|g>>>(s>>>0))&A;v=A&i>>>(s>>>0);w=g<<q &y;x=(i<<q|g>>>(z>>>0))&y|g<<p&s-33>>31;break}if(f){c[f>>2]=r&g;c[f+4>>2]=0}if(( j|0)==1){n=h|b&0;o=a|0|0;return (C=n,o)|0}else{r=Pa(j|0)|0;n=i>>>(r>>>0)|0;o=i<< 32-r|g>>>(r>>>0)|0;return (C=n,o)|0}}else{if(m){if(f){c[f>>2]=(i>>>0)%(j>>>0);c[ f+4>>2]=0}n=0;o=(i>>>0)/(j>>>0)>>>0;return (C=n,o)|0}if(!g){if(f){c[f>>2]=0;c[f+ 4>>2]=(i>>>0)%(l>>>0)}n=0;o=(i>>>0)/(l>>>0)>>>0;return (C=n,o)|0}r=l-1|0;if(!(r& l)){if(f){c[f>>2]=a|0;c[f+4>>2]=r&i|b&0}n=0;o=i>>>((Pa(l|0)|0)>>>0);return (C=n, o)|0}r=(aa(l|0)|0)-(aa(i|0)|0)|0;if(r>>>0<=30){s=r+1|0;p=31-r|0;t=s;u=i<<p|g>>>( s>>>0);v=i>>>(s>>>0);w=0;x=g<<p;break}if(!f){n=0;o=0;return (C=n,o)|0}c[f>>2]=a| 0;c[f+4>>2]=h|b&0;n=0;o=0;return (C=n,o)|0}while(0);if(!t){B=x;D=w;E=v;F=u;G=0;H =0}else{b=d|0|0;d=k|e&0;e=Ua(b,d,-1,-1)|0;k=C;h=x;x=w;w=v;v=u;u=t;t=0;do{a=h;h=x >>>31|h<<1;x=t|x<<1;g=v<<1|a>>>31|0;a=v>>>31|w<<1|0;Va(e,k,g,a)|0;i=C;l=i>>31|(( i|0)<0?-1:0)<<1;t=l&1;v=Va(g,a,l&b,(((i|0)<0?-1:0)>>31|((i|0)<0?-1:0)<<1)&d)|0;w =C;u=u-1|0}while((u|0)!=0);B=h;D=x;E=w;F=v;G=0;H=t}t=D;D=0;if(f){c[f>>2]=F;c[f+4 >>2]=E}n=(t|0)>>>31|(B|D)<<1|(D<<1|t>>>31)&0|G;o=(t<<1|0>>>31)&-2|H;return (C=n, o)|0}
6
7 // EMSCRIPTEN_END_FUNCS
8 return{_llvm_bswap_i16:Ra,_strlen:Oa,_free:La,_main:Ja,_llvm_ctlz_i64:Ta,_memset :Na,_llvm_cttz_i32:Pa,_malloc:Ka,_memcpy:Qa,_llvm_bswap_i32:Sa,runPostSets:Ma,st ackAlloc:Ba,stackSave:Ca,stackRestore:Da,setThrew:Ea,setTempRet0:Ha,getTempRet0: Ia}})
9
10
11 // EMSCRIPTEN_END_ASM
12 (Module.asmGlobalArg,Module.asmLibraryArg,buffer);var _llvm_bswap_i16=Module["_l lvm_bswap_i16"]=asm["_llvm_bswap_i16"];var _strlen=Module["_strlen"]=asm["_strle n"];var _free=Module["_free"]=asm["_free"];var _main=Module["_main"]=asm["_main" ];var _llvm_ctlz_i64=Module["_llvm_ctlz_i64"]=asm["_llvm_ctlz_i64"];var _memset= Module["_memset"]=asm["_memset"];var _llvm_cttz_i32=Module["_llvm_cttz_i32"]=asm ["_llvm_cttz_i32"];var _malloc=Module["_malloc"]=asm["_malloc"];var _memcpy=Modu le["_memcpy"]=asm["_memcpy"];var _llvm_bswap_i32=Module["_llvm_bswap_i32"]=asm[" _llvm_bswap_i32"];var runPostSets=Module["runPostSets"]=asm["runPostSets"];Runti me.stackAlloc=asm["stackAlloc"];Runtime.stackSave=asm["stackSave"];Runtime.stack Restore=asm["stackRestore"];Runtime.setTempRet0=asm["setTempRet0"];Runtime.getTe mpRet0=asm["getTempRet0"];var i64Math=(function(){var goog={math:{}};goog.math.L ong=(function(low,high){this.low_=low|0;this.high_=high|0});goog.math.Long.IntCa che_={};goog.math.Long.fromInt=(function(value){if(-128<=value&&value<128){var c achedObj=goog.math.Long.IntCache_[value];if(cachedObj){return cachedObj}}var obj =new goog.math.Long(value|0,value<0?-1:0);if(-128<=value&&value<128){goog.math.L ong.IntCache_[value]=obj}return obj});goog.math.Long.fromNumber=(function(value) {if(isNaN(value)||!isFinite(value)){return goog.math.Long.ZERO}else if(value<=-g oog.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.fromNumber(-value).negate()}else{return new goog.math.Lon g(value%goog.math.Long.TWO_PWR_32_DBL_|0,value/goog.math.Long.TWO_PWR_32_DBL_|0) }});goog.math.Long.fromBits=(function(lowBits,highBits){return new goog.math.Lon g(lowBits,highBits)});goog.math.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){throw Error("radix out of range: "+radix)}if(str.charA t(0)=="-"){return goog.math.Long.fromString(str.substring(1),radix).negate()}els e if(str.indexOf("-")>=0){throw Error('number format error: interior "-" charact er: '+str)}var radixToPower=goog.math.Long.fromNumber(Math.pow(radix,8));var res ult=goog.math.Long.ZERO;for(var i=0;i<str.length;i+=8){var size=Math.min(8,str.l ength-i);var value=parseInt(str.substring(i,i+size),radix);if(size<8){var power= goog.math.Long.fromNumber(Math.pow(radix,size));result=result.multiply(power).ad d(goog.math.Long.fromNumber(value))}else{result=result.multiply(radixToPower);re sult=result.add(goog.math.Long.fromNumber(value))}}return result});goog.math.Lon g.TWO_PWR_16_DBL_=1<<16;goog.math.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.m ath.Long.TWO_PWR_31_DBL_=goog.math.Long.TWO_PWR_32_DBL_/2;goog.math.Long.TWO_PWR _48_DBL_=goog.math.Long.TWO_PWR_32_DBL_*goog.math.Long.TWO_PWR_16_DBL_;goog.math .Long.TWO_PWR_64_DBL_=goog.math.Long.TWO_PWR_32_DBL_*goog.math.Long.TWO_PWR_32_D BL_;goog.math.Long.TWO_PWR_63_DBL_=goog.math.Long.TWO_PWR_64_DBL_/2;goog.math.Lo ng.ZERO=goog.math.Long.fromInt(0);goog.math.Long.ONE=goog.math.Long.fromInt(1);g oog.math.Long.NEG_ONE=goog.math.Long.fromInt(-1);goog.math.Long.MAX_VALUE=goog.m ath.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.prototype.toInt=(function(){return this.low_});goog.math.L ong.prototype.toNumber=(function(){return this.high_*goog.math.Long.TWO_PWR_32_D BL_+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 r ange: "+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 di v=this.div(radixLong);var rem=div.multiply(radixLong).subtract(this);return div. toString(radix)+rem.toInt().toString(radix)}else{return"-"+this.negate().toStrin g(radix)}}var radixToPower=goog.math.Long.fromNumber(Math.pow(radix,6));var rem= this;var result="";while(true){var remDiv=rem.div(radixToPower);var intval=rem.s ubtract(remDiv.multiply(radixToPower)).toInt();var digits=intval.toString(radix) ;rem=remDiv;if(rem.isZero()){return digits+result}else{while(digits.length<6){di gits="0"+digits}result=""+digits+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(){retu rn this.low_>=0?this.low_:goog.math.Long.TWO_PWR_32_DBL_+this.low_});goog.math.L ong.prototype.getNumBitsAbs=(function(){if(this.isNegative()){if(this.equals(goo g.math.Long.MIN_VALUE)){return 64}else{return this.negate().getNumBitsAbs()}}els e{var val=this.high_!=0?this.high_:this.low_;for(var bit=31;bit>0;bit--){if((val &1<<bit)!=0){break}}return this.high_!=0?bit+33:bit+1}});goog.math.Long.prototyp e.isZero=(function(){return this.high_==0&&this.low_==0});goog.math.Long.prototy pe.isNegative=(function(){return this.high_<0});goog.math.Long.prototype.isOdd=( function(){return(this.low_&1)==1});goog.math.Long.prototype.equals=(function(ot her){return this.high_==other.high_&&this.low_==other.low_});goog.math.Long.prot otype.notEquals=(function(other){return this.high_!=other.high_||this.low_!=othe r.low_});goog.math.Long.prototype.lessThan=(function(other){return this.compare( other)<0});goog.math.Long.prototype.lessThanOrEqual=(function(other){return this .compare(other)<=0});goog.math.Long.prototype.greaterThan=(function(other){retur n this.compare(other)>0});goog.math.Long.prototype.greaterThanOrEqual=(function( other){return this.compare(other)>=0});goog.math.Long.prototype.compare=(functio n(other){if(this.equals(other)){return 0}var thisNeg=this.isNegative();var other Neg=other.isNegative();if(thisNeg&&!otherNeg){return-1}if(!thisNeg&&otherNeg){re turn 1}if(this.subtract(other).isNegative()){return-1}else{return 1}});goog.math .Long.prototype.negate=(function(){if(this.equals(goog.math.Long.MIN_VALUE)){ret urn goog.math.Long.MIN_VALUE}else{return this.not().add(goog.math.Long.ONE)}});g oog.math.Long.prototype.add=(function(other){var a48=this.high_>>>16;var a32=thi s.high_&65535;var a16=this.low_>>>16;var a00=this.low_&65535;var 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&=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.fromBits(c16<<16|c00,c48<<16|c32)});goog.math.Long. prototype.subtract=(function(other){return this.add(other.negate())});goog.math. Long.prototype.multiply=(function(other){if(this.isZero()){return goog.math.Long .ZERO}else if(other.isZero()){return goog.math.Long.ZERO}if(this.equals(goog.mat h.Long.MIN_VALUE)){return other.isOdd()?goog.math.Long.MIN_VALUE:goog.math.Long. ZERO}else if(other.equals(goog.math.Long.MIN_VALUE)){return this.isOdd()?goog.ma th.Long.MIN_VALUE:goog.math.Long.ZERO}if(this.isNegative()){if(other.isNegative( )){return this.negate().multiply(other.negate())}else{return this.negate().multi ply(other).negate()}}else if(other.isNegative()){return this.multiply(other.nega te()).negate()}if(this.lessThan(goog.math.Long.TWO_PWR_24_)&&other.lessThan(goog .math.Long.TWO_PWR_24_)){return 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;var b48=other.high_>>>16;var b32=other.high_&65535;v ar 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&=65535;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&=65535;return goog.math.Long.fromBits(c16<<16|c00,c48<< 16|c32)});goog.math.Long.prototype.div=(function(other){if(other.isZero()){throw Error("division by zero")}else if(this.isZero()){return goog.math.Long.ZERO}if( this.equals(goog.math.Long.MIN_VALUE)){if(other.equals(goog.math.Long.ONE)||othe r.equals(goog.math.Long.NEG_ONE)){return goog.math.Long.MIN_VALUE}else if(other. equals(goog.math.Long.MIN_VALUE)){return goog.math.Long.ONE}else{var halfThis=th is.shiftRight(1);var approx=halfThis.div(other).shiftLeft(1);if(approx.equals(go og.math.Long.ZERO)){return other.isNegative()?goog.math.Long.ONE:goog.math.Long. NEG_ONE}else{var rem=this.subtract(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()){return this.div(other.negate()).negate()}var res=go og.math.Long.ZERO;var rem=this;while(rem.greaterThanOrEqual(other)){var approx=M ath.max(1,Math.floor(rem.toNumber()/other.toNumber()));var log2=Math.ceil(Math.l og(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(appr oxRem.isNegative()||approxRem.greaterThan(rem)){approx-=delta;approxRes=goog.mat h.Long.fromNumber(approx);approxRem=approxRes.multiply(other)}if(approxRes.isZer o()){approxRes=goog.math.Long.ONE}res=res.add(approxRes);rem=rem.subtract(approx Rem)}return res});goog.math.Long.prototype.modulo=(function(other){return this.s ubtract(this.div(other).multiply(other))});goog.math.Long.prototype.not=(functio n(){return goog.math.Long.fromBits(~this.low_,~this.high_)});goog.math.Long.prot otype.and=(function(other){return goog.math.Long.fromBits(this.low_&other.low_,t his.high_&other.high_)});goog.math.Long.prototype.or=(function(other){return goo g.math.Long.fromBits(this.low_|other.low_,this.high_|other.high_)});goog.math.Lo ng.prototype.xor=(function(other){return goog.math.Long.fromBits(this.low_^other .low_,this.high_^other.high_)});goog.math.Long.prototype.shiftLeft=(function(num Bits){numBits&=63;if(numBits==0){return this}else{var low=this.low_;if(numBits<3 2){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)}}});go og.math.Long.prototype.shiftRight=(function(numBits){numBits&=63;if(numBits==0){ return this}else{var high=this.high_;if(numBits<32){var low=this.low_;return goo g.math.Long.fromBits(low>>>numBits|high<<32-numBits,high>>numBits)}else{return g oog.math.Long.fromBits(high>>numBits-32,high>=0?0:-1)}}});goog.math.Long.prototy pe.shiftRightUnsigned=(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>>>numBits|high<<32-numBits,high>>>numBits)}else if(numBits==32){ret urn goog.math.Long.fromBits(high,0)}else{return goog.math.Long.fromBits(high>>>n umBits-32,0)}}});var navigator={appName:"Modern Browser"};var dbits;var canary=0 xdeadbeefcafe;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,256);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;while(--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&1073741823}return c}function am3(i,x,w,j,c,n){var xl=x& 16383,xh=x>>14;while(--n>=0){var 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}ret urn c}if(j_lm&&navigator.appName=="Microsoft Internet Explorer"){BigInteger.prot otype.am=am2;dbits=30}else if(j_lm&&navigator.appName!="Netscape"){BigInteger.pr ototype.am=am1;dbits=26}else{BigInteger.prototype.am=am3;dbits=28}BigInteger.pro totype.DB=dbits;BigInteger.prototype.DM=(1<<dbits)-1;BigInteger.prototype.DV=1<< dbits;var BI_FP=52;BigInteger.prototype.FV=Math.pow(2,BI_FP);BigInteger.prototyp e.F1=BI_FP-dbits;BigInteger.prototype.F2=2*dbits-BI_FP;var BI_RM="0123456789abcd efghijklmnopqrstuvwxyz";var BI_RC=new Array;var rr,vv;rr="0".charCodeAt(0);for(v v=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);for(vv=10;vv<36;++vv)BI_RC[rr++]=vv;function int2cha r(n){return BI_RM.charAt(n)}function intAt(s,i){var c=BI_RC[s.charCodeAt(i)];ret urn c==null?-1:c}function bnpCopyTo(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)thi s[0]=x;else if(x<-1)this[0]=x+DV;else this.t=0}function nbv(i){var r=nbi();r.fro mInt(i);return r}function bnpFromString(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{thi s.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}if(k==8&&(s[0]&128)!=0){this.s=-1;if(sh>0)this[this .t-1]|=(1<<this.DB-sh)-1<<sh}this.clamp();if(mi)BigInteger.ZERO.subTo(this,this) }function bnpClamp(){var c=this.s&this.DM;while(this.t>0&&this[this.t-1]==c)--th is.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=th is.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 bnNegate(){var r=nbi();BigInteger.ZERO.subTo(this,r);r eturn r}function bnAbs(){return this.s<0?this.negate():this}function bnCompareTo (a){var r=this.s-a.s;if(r!=0)return r;var i=this.t;r=i-a.t;if(r!=0)return this.s <0?-r:r;while(--i>=0)if((r=this[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 bnBi tLength(){if(this.t<=0)return 0;return this.DB*(this.t-1)+nbits(this[this.t-1]^t his.s&this.DM)}function bnpDLShiftTo(n,r){var i;for(i=this.t-1;i>=0;--i)r[i+n]=t his[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=Mat h.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]|=(t his[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);w hile(i<m){c+=this[i]-a[i];r[i++]=c&this.DM;c>>=this.DB}if(a.t<this.t){c-=a.s;whi le(i<this.t){c+=this[i];r[i++]=c&this.DM;c>>=this.DB}c+=this.s}else{c+=this.s;wh ile(i<a.t){c-=a[i];r[i++]=c&this.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){va r 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.ZER O.subTo(r,r)}function bnpSquareTo(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 pt=this.abs();if(pt.t<pm.t){if(q!=null)q.fromInt(0) ;if(r!=null)this.copyTo(r);return}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.copyTo(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.compare To(t)>=0){r[r.t++]=1;r.subTo(t,r)}BigInteger.ONE.dlShiftTo(ys,t);t.subTo(y,y);wh ile(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)BigIntege r.ZERO.subTo(q,q)}r.t=ys;r.clamp();if(nsh>0)r.rShiftTo(nsh,r);if(ts<0)BigInteger .ZERO.subTo(r,r)}function bnMod(a){var r=nbi();this.abs().divRemTo(a,null,r);if( this.s<0&&r.compareTo(BigInteger.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(t his.m);else return x}function cRevert(x){return x}function cReduce(x){x.divRemTo (this.m,null,x)}function cMulTo(x,y,r){x.multiplyTo(y,r);this.reduce(r)}function cSqrTo(x,r){x.squareTo(r);this.reduce(r)}Classic.prototype.convert=cConvert;Cla ssic.prototype.revert=cRevert;Classic.prototype.reduce=cReduce;Classic.prototype .mulTo=cMulTo;Classic.prototype.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&65535)*y&65535))&65535;y=y*(2-x*y%this.DV)%this.DV;re turn y>0?this.DV-y:-y}function Montgomery(m){this.m=m;this.mp=m.invDigit();this. mpl=this.mp&32767;this.mph=this.mp>>15;this.um=(1<<m.DB-15)-1;this.mt2=2*m.t}fun ction 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}fun ction montRevert(x){var r=nbi();x.copyTo(r);this.reduce(r);return r}function mon tReduce(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*this.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(this.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.reduce(r)}Montgomery.prototype.convert=montConvert;Mon tgomery.prototype.revert=montRevert;Montgomery.prototype.reduce=montReduce;Montg omery.prototype.mulTo=montMulTo;Montgomery.prototype.sqrTo=montSqrTo;function bn pIsEven(){return(this.t>0?this[0]&1:this.s)==0}function bnpExp(e,z){if(e>4294967 295||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{va r t=r;r=r2;r2=t}}return z.revert(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)}BigInteg er.prototype.copyTo=bnpCopyTo;BigInteger.prototype.fromInt=bnpFromInt;BigInteger .prototype.fromString=bnpFromString;BigInteger.prototype.clamp=bnpClamp;BigInteg er.prototype.dlShiftTo=bnpDLShiftTo;BigInteger.prototype.drShiftTo=bnpDRShiftTo; BigInteger.prototype.lShiftTo=bnpLShiftTo;BigInteger.prototype.rShiftTo=bnpRShif tTo;BigInteger.prototype.subTo=bnpSubTo;BigInteger.prototype.multiplyTo=bnpMulti plyTo;BigInteger.prototype.squareTo=bnpSquareTo;BigInteger.prototype.divRemTo=bn pDivRemTo;BigInteger.prototype.invDigit=bnpInvDigit;BigInteger.prototype.isEven= bnpIsEven;BigInteger.prototype.exp=bnpExp;BigInteger.prototype.toString=bnToStri ng;BigInteger.prototype.negate=bnNegate;BigInteger.prototype.abs=bnAbs;BigIntege r.prototype.compareTo=bnCompareTo;BigInteger.prototype.bitLength=bnBitLength;Big Integer.prototype.mod=bnMod;BigInteger.prototype.modPowInt=bnModPowInt;BigIntege r.ZERO=nbv(0);BigInteger.ONE=nbv(1);function bnpFromRadix(s,b){this.fromInt(0);i f(b==null)b=10;var cs=this.chunkSize(b);var d=Math.pow(b,cs),mi=false,j=0,w=0;fo r(var i=0;i<s.length;++i){var x=intAt(s,i);if(x<0){if(s.charAt(i)=="-"&&this.sig num()==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.dMultiply(Math.pow(b,j));this.dAddOffset(w,0)}if(mi)B igInteger.ZERO.subTo(this,this)}function bnpChunkSize(r){return Math.floor(Math. LN2*this.DB/Math.log(r))}function bnSigNum(){if(this.s<0)return-1;else if(this.t <=0||this.t==1&&this[0]<=0)return 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 bnpDAddOff set(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;if(++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=t his.chunkSize(b);var a=Math.pow(b,cs);var d=nbv(a),y=nbi(),z=nbi(),r="";this.div RemTo(d,y,z);while(y.signum()>0){r=(a+z.intValue()).toString(b).substr(1)+r;y.di vRemTo(d,y,z)}return z.intValue().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(this.t==0)return 0;return(this[1]&(1<<32-this.DB)-1)< <this.DB|this[0]}function bnpAddTo(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&this.DM;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=bnp FromRadix;BigInteger.prototype.chunkSize=bnpChunkSize;BigInteger.prototype.signu m=bnSigNum;BigInteger.prototype.dMultiply=bnpDMultiply;BigInteger.prototype.dAdd Offset=bnpDAddOffset;BigInteger.prototype.toRadix=bnpToRadix;BigInteger.prototyp e.intValue=bnIntValue;BigInteger.prototype.addTo=bnpAddTo;var Wrapper={abs:(func tion(l,h){var x=new goog.math.Long(l,h);var ret;if(x.isNegative()){ret=x.negate( )}else{ret=x}HEAP32[tempDoublePtr>>2]=ret.low_;HEAP32[tempDoublePtr+4>>2]=ret.hi gh_}),ensureTemps:(function(){if(Wrapper.ensuredTemps)return;Wrapper.ensuredTemp s=true;Wrapper.two32=new BigInteger;Wrapper.two32.fromString("4294967296",10);Wr apper.two64=new BigInteger;Wrapper.two64.fromString("18446744073709551616",10);W rapper.temp1=new BigInteger;Wrapper.temp2=new BigInteger}),lh2bignum:(function(l ,h){var a=new BigInteger;a.fromString(h.toString(),10);var b=new BigInteger;a.mu ltiplyTo(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.ensur eTemps();var bignum=new BigInteger;bignum.fromString(ret,10);ret=new BigInteger; Wrapper.two64.addTo(bignum,ret);ret=ret.toString(10)}return ret}),fromString:(fu nction(str,base,min,max,unsigned){Wrapper.ensureTemps();var bignum=new BigIntege r;bignum.fromString(str,base);var bigmin=new BigInteger;bigmin.fromString(min,10 );var bigmax=new BigInteger;bigmax.fromString(max,10);if(unsigned&&bignum.compar eTo(BigInteger.ZERO)<0){var temp=new BigInteger;bignum.addTo(Wrapper.two64,temp) ;bignum=temp}var error=false;if(bignum.compareTo(bigmin)<0){bignum=bigmin;error= true}else if(bignum.compareTo(bigmax)>0){bignum=bigmax;error=true}var ret=goog.m ath.Long.fromString(bignum.toString());HEAP32[tempDoublePtr>>2]=ret.low_;HEAP32[ tempDoublePtr+4>>2]=ret.high_;if(error)throw"range error"})};return Wrapper})(); if(memoryInitializer){if(typeof Module["locateFile"]==="function"){memoryInitial izer=Module["locateFile"](memoryInitializer)}else if(Module["memoryInitializerPr efixURL"]){memoryInitializer=Module["memoryInitializerPrefixURL"]+memoryInitiali zer}if(ENVIRONMENT_IS_NODE||ENVIRONMENT_IS_SHELL){var data=Module["readBinary"]( memoryInitializer);HEAPU8.set(data,STATIC_BASE)}else{addRunDependency("memory in itializer");function applyMemoryInitializer(data){if(data.byteLength)data=new Ui nt8Array(data);HEAPU8.set(data,STATIC_BASE);removeRunDependency("memory initiali zer")}var request=Module["memoryInitializerRequest"];if(request){if(request.resp onse){setTimeout((function(){applyMemoryInitializer(request.response)}),0)}else{ request.addEventListener("load",(function(){if(request.status!==200&&request.sta tus!==0){console.warn("a problem seems to have happened with Module.memoryInitia lizerRequest, status: "+request.status)}if(!request.response||typeof request.res ponse!=="object"||!request.response.byteLength){console.warn("a problem seems to have happened with Module.memoryInitializerRequest response (expected ArrayBuff er): "+request.response)}applyMemoryInitializer(request.response)}))}}else{Brows er.asyncLoad(memoryInitializer,applyMemoryInitializer,(function(){throw"could no t load memory initializer "+memoryInitializer}))}}}function ExitStatus(status){t his.name="ExitStatus";this.message="Program terminated with exit("+status+")";th is.status=status}ExitStatus.prototype=new Error;ExitStatus.prototype.constructor =ExitStatus;var initialStackTop;var preloadStartTime=null;var calledMain=false;d ependenciesFulfilled=function runCaller(){if(!Module["calledRun"])run();if(!Modu le["calledRun"])dependenciesFulfilled=runCaller};Module["callMain"]=Module.callM ain=function callMain(args){assert(runDependencies==0,"cannot call main when asy nc dependencies remain! (listen on __ATMAIN__)");assert(__ATPRERUN__.length==0," cannot call main when preRun functions remain to be called");args=args||[];ensur eInitRuntime();var argc=args.length+1;function pad(){for(var i=0;i<4-1;i++){argv .push(0)}}var argv=[allocate(intArrayFromString(Module["thisProgram"]),"i8",ALLO C_NORMAL)];pad();for(var i=0;i<argc-1;i=i+1){argv.push(allocate(intArrayFromStri ng(args[i]),"i8",ALLOC_NORMAL));pad()}argv.push(0);argv=allocate(argv,"i32",ALLO C_NORMAL);initialStackTop=STACKTOP;try{var ret=Module["_main"](argc,argv,0);exit (ret)}catch(e){if(e instanceof ExitStatus){return}else if(e=="SimulateInfiniteLo op"){Module["noExitRuntime"]=true;return}else{if(e&&typeof e==="object"&&e.stack )Module.printErr("exception thrown: "+[e,e.stack]);throw e}}finally{calledMain=t rue}};function run(args){args=args||Module["arguments"];if(preloadStartTime===nu ll)preloadStartTime=Date.now();if(runDependencies>0){return}preRun();if(runDepen dencies>0)return;if(Module["calledRun"])return;function doRun(){if(Module["calle dRun"])return;Module["calledRun"]=true;if(ABORT)return;ensureInitRuntime();preMa in();if(ENVIRONMENT_IS_WEB&&preloadStartTime!==null){Module.printErr("pre-main p rep time: "+(Date.now()-preloadStartTime)+" ms")}if(Module["onRuntimeInitialized "])Module["onRuntimeInitialized"]();if(Module["_main"]&&shouldRunNow)Module["cal lMain"](args);postRun()}if(Module["setStatus"]){Module["setStatus"]("Running..." );setTimeout((function(){setTimeout((function(){Module["setStatus"]("")}),1);doR un()}),1)}else{doRun()}}Module["run"]=Module.run=run;function exit(status){if(Mo dule["noExitRuntime"]){return}ABORT=true;EXITSTATUS=status;STACKTOP=initialStack Top;exitRuntime();if(Module["onExit"])Module["onExit"](status);if(ENVIRONMENT_IS _NODE){process["stdout"]["once"]("drain",(function(){process["exit"](status)})); console.log(" ");setTimeout((function(){process["exit"](status)}),500)}else if(E NVIRONMENT_IS_SHELL&&typeof quit==="function"){quit(status)}throw new ExitStatus (status)}Module["exit"]=Module.exit=exit;var abortDecorators=[];function abort(w hat){if(what!==undefined){Module.print(what);Module.printErr(what);what=JSON.str ingify(what)}else{what=""}ABORT=true;EXITSTATUS=1;var extra="\nIf this abort() i s unexpected, build with -s ASSERTIONS=1 which can give more information.";var o utput="abort("+what+") at "+stackTrace()+extra;abortDecorators.forEach((function (decorator){output=decorator(output,what)}));throw output}Module["abort"]=Module .abort=abort;if(Module["preInit"]){if(typeof Module["preInit"]=="function")Modul e["preInit"]=[Module["preInit"]];while(Module["preInit"].length>0){Module["preIn it"].pop()()}}var shouldRunNow=true;if(Module["noInitialRun"]){shouldRunNow=fals e}run()
13
14
15
16
OLDNEW
« no previous file with comments | « test/emscripten/core/test_llrint-Os.out ('k') | test/emscripten/core/test_llvm_intrinsics-O2.out » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698