@quake2ts/engine 0.0.795 → 0.0.797
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.global.js +8 -8
- package/dist/browser/index.global.js.map +1 -1
- package/dist/cjs/index.cjs +14 -0
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/esm/index.js +14 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/types/render/camera.d.ts +9 -0
- package/dist/types/render/camera.d.ts.map +1 -1
- package/dist/types/render/frame.d.ts +2 -0
- package/dist/types/render/frame.d.ts.map +1 -1
- package/dist/types/render/types/camera.d.ts +21 -0
- package/dist/types/render/types/camera.d.ts.map +1 -0
- package/dist/types/render/types/coordinates.d.ts +39 -0
- package/dist/types/render/types/coordinates.d.ts.map +1 -0
- package/dist/types/render/types/renderer.d.ts +18 -0
- package/dist/types/render/types/renderer.d.ts.map +1 -0
- package/package.json +5 -5
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
"use strict";var Quake2Engine=(()=>{var bp=Object.create;var Is=Object.defineProperty;var xp=Object.getOwnPropertyDescriptor;var vp=Object.getOwnPropertyNames;var _p=Object.getPrototypeOf,Sp=Object.prototype.hasOwnProperty;var wp=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Na=(t,e)=>{for(var r in e)Is(t,r,{get:e[r],enumerable:!0})},lf=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of vp(e))!Sp.call(t,i)&&i!==r&&Is(t,i,{get:()=>e[i],enumerable:!(n=xp(e,i))||n.enumerable});return t};var Mp=(t,e,r)=>(r=t!=null?bp(_p(t)):{},lf(e||!t||!t.__esModule?Is(r,"default",{value:t,enumerable:!0}):r,t)),Ap=t=>lf(Is({},"__esModule",{value:!0}),t);var $f=wp((K2,Yf)=>{"use strict";Yf.exports=Worker});var JS={};Na(JS,{ATTN_IDLE:()=>qc,ATTN_LOOP_NONE:()=>Yc,ATTN_NONE:()=>$a,ATTN_NORM:()=>$c,ATTN_STATIC:()=>Zc,AssetDependencyError:()=>pi,AssetDependencyTracker:()=>jo,AssetManager:()=>Bl,AssetPreviewGenerator:()=>Ec,AudioApi:()=>zi,AudioContextController:()=>Fl,AudioOcclusion:()=>Jo,AudioRegistry:()=>la,AudioRegistryError:()=>$o,AudioSystem:()=>Hl,BSP_SURFACE_FRAGMENT_SOURCE:()=>zd,BSP_SURFACE_VERTEX_SOURCE:()=>Dd,BSP_VERTEX_LAYOUT:()=>Id,BspLoader:()=>Ni,BspParseError:()=>se,BspSurfacePipeline:()=>fa,Camera:()=>ec,ClientConnection:()=>Tc,Command:()=>Ha,CommandRegistry:()=>Ci,ConfigStringRegistry:()=>Oi,ConnectionState:()=>Qu,Cvar:()=>qa,CvarRegistry:()=>ki,DemoAnalyzer:()=>Ba,DemoCameraMode:()=>$u,DemoClipper:()=>Ac,DemoEventType:()=>Yu,DemoPlaybackController:()=>Ms,DemoReader:()=>fr,DemoRecorder:()=>As,DemoValidator:()=>Mc,DynamicLightManager:()=>Wl,EngineHost:()=>Di,EngineRuntime:()=>Za,FileType:()=>qu,FixedTimestepLoop:()=>Yn,Framebuffer:()=>gi,IndexBuffer:()=>Qe,LruCache:()=>gn,MAX_SOUND_CHANNELS:()=>Ya,MD2_FRAGMENT_SHADER:()=>Wd,MD2_VERTEX_SHADER:()=>Gd,MD3_FRAGMENT_SHADER:()=>du,MD3_VERTEX_SHADER:()=>cu,MapAnalyzer:()=>Lc,Md2Loader:()=>Hi,Md2MeshBuffers:()=>ma,Md2ParseError:()=>qe,Md2Pipeline:()=>pa,Md3Loader:()=>Vi,Md3ModelMesh:()=>xa,Md3ParseError:()=>Yt,Md3Pipeline:()=>va,Md3SurfaceMesh:()=>is,MessageWriter:()=>wc,MusicSystem:()=>Vl,NetworkMessageParser:()=>ct,PARTICLE_FRAGMENT_SHADER:()=>fu,PARTICLE_VERTEX_SHADER:()=>uu,PROTOCOL_VERSION_RERELEASE:()=>Dr,PakArchive:()=>Ui,PakIndexStore:()=>Il,PakIngestionError:()=>pn,PakParseError:()=>Ie,PakValidationError:()=>Jn,PakValidator:()=>Ks,PakWriter:()=>Gs,ParticleRenderer:()=>Sa,ParticleSystem:()=>_a,PlaybackState:()=>Sc,RERELEASE_KNOWN_PAKS:()=>td,ResourceLoadTracker:()=>Ws,ResourceType:()=>ed,SKYBOX_FRAGMENT_SHADER:()=>Hd,SKYBOX_VERTEX_SHADER:()=>Nd,SOUND_FULLVOLUME:()=>Bi,SOUND_LOOP_ATTENUATE:()=>jc,ShaderProgram:()=>le,SkyboxPipeline:()=>ha,SoundChannel:()=>wr,SoundPrecache:()=>zl,SoundRegistry:()=>Dl,SpriteLoader:()=>Gi,SpriteParseError:()=>yn,SpriteRenderer:()=>wa,StreamingPakArchive:()=>Vs,Texture2D:()=>Je,TextureCache:()=>Wi,TextureCubeMap:()=>ca,TgaParseError:()=>Vr,U_ALPHA:()=>yr,U_ANGLE1:()=>xt,U_ANGLE2:()=>mt,U_ANGLE3:()=>pt,U_EFFECTS16:()=>Ge,U_EFFECTS8:()=>Ne,U_EVENT:()=>yt,U_FRAME16:()=>_t,U_FRAME8:()=>gt,U_INSTANCE_BITS:()=>_r,U_LOOP_ATTENUATION_HIGH:()=>un,U_LOOP_VOLUME:()=>Sr,U_MODEL:()=>vt,U_MODEL2:()=>St,U_MODEL3:()=>wt,U_MODEL4:()=>Mt,U_OLDORIGIN:()=>sr,U_OLD_FRAME_HIGH:()=>hn,U_ORIGIN1:()=>ft,U_ORIGIN2:()=>ht,U_ORIGIN3:()=>bt,U_OWNER_HIGH:()=>fn,U_REMOVE:()=>Xa,U_RENDERFX16:()=>Ve,U_RENDERFX8:()=>Ue,U_SCALE:()=>vr,U_SKIN16:()=>We,U_SKIN8:()=>He,U_SOLID:()=>Et,U_SOUND:()=>At,VertexArray:()=>Ee,VertexBuffer:()=>Ae,VirtualFileSystem:()=>Xs,advanceAnimation:()=>Vf,applyEntityDelta:()=>rp,applySurfaceState:()=>es,attenuationToDistanceMultiplier:()=>Fi,boxIntersectsFrustum:()=>yi,buildBspGeometry:()=>Rh,buildMd2Geometry:()=>Xd,buildMd2VertexData:()=>Kd,buildMd3SurfaceGeometry:()=>su,buildMd3VertexData:()=>lu,calculateMaxAudibleDistance:()=>Qn,calculatePakChecksum:()=>Ef,captureRenderTarget:()=>fp,computeFrameBlend:()=>Gf,computeSkyScroll:()=>Kl,createAnimationState:()=>Wf,createAudioGraph:()=>kl,createBspSurfaces:()=>Th,createEmptyEntityState:()=>kr,createEmptyProtocolPlayerState:()=>hr,createEngine:()=>QS,createEngineRuntime:()=>wf,createFaceLightmap:()=>$s,createHeadlessRenderTarget:()=>up,createInitialChannels:()=>Ol,createOcclusionResolver:()=>Mh,createProgramFromSources:()=>Lh,createRenderer:()=>Bm,createWebGLContext:()=>Ah,createWebGPUContext:()=>cp,decodeOgg:()=>Pl,deriveSurfaceRenderState:()=>Ud,detectFileType:()=>Zu,extractFrustumPlanes:()=>kn,filesToPakSources:()=>rd,findLeafForPoint:()=>bi,gatherVisibleFaces:()=>xi,groupMd2Animations:()=>Of,ingestPakFiles:()=>Cf,ingestPaks:()=>Ys,interpolateMd3Tag:()=>mm,interpolateVec3:()=>Xf,isBinaryFile:()=>ip,isTextFile:()=>ju,parseBsp:()=>ja,parseEntLump:()=>op,parseMd2:()=>nd,parseMd3:()=>id,parsePcx:()=>to,parseSprite:()=>ad,parseTga:()=>od,parseWal:()=>Zs,parseWalTexture:()=>Js,parseWav:()=>el,pcxToRgba:()=>js,pickChannel:()=>Ul,preparePcxTexture:()=>Qs,queryCapabilities:()=>dp,removeViewTranslation:()=>Xl,resolveLightStyles:()=>Od,serializeEntLump:()=>sp,spawnBfgExplosion:()=>Em,spawnBlasterImpact:()=>Am,spawnBlood:()=>ym,spawnBulletImpact:()=>pm,spawnExplosion:()=>gm,spawnMuzzleFlash:()=>xm,spawnRailTrail:()=>wm,spawnSparks:()=>Mm,spawnSplash:()=>_m,spawnSteam:()=>Sm,spawnTeleportFlash:()=>bm,spawnTrail:()=>vm,validateEntity:()=>lp,walToRgba:()=>sd,wireDropTarget:()=>Pf,wireFileInput:()=>If});var Ep=()=>typeof performance<"u"?performance.now():Date.now(),Lp=t=>{typeof requestAnimationFrame=="function"?requestAnimationFrame(()=>t()):setTimeout(t,25)},Yn=class{constructor(e,r={}){this.callbacks=e;this.accumulatorMs=0;this.frame=0;this.running=!1;this.tick=()=>{if(!this.running)return;let e=this.options.now(),r=this.lastTimeMs===void 0?0:e-this.lastTimeMs;this.lastTimeMs=e,this.advance(r,e),this.running&&this.options.schedule(this.tick)};let n=r.fixedDeltaMs??25,i=r.maxSubSteps??5;this.options={fixedDeltaMs:n,maxSubSteps:i,maxDeltaMs:r.maxDeltaMs??n*i,startTimeMs:r.startTimeMs,now:r.now??Ep,schedule:r.schedule??Lp}}start(){this.running||(this.running=!0,this.lastTimeMs=this.options.startTimeMs??this.options.now(),this.options.schedule(this.tick))}stop(){this.running=!1}pump(e){let r=(this.lastTimeMs??0)+e;this.lastTimeMs=r,this.advance(e,r)}isRunning(){return this.running}get frameNumber(){return this.frame}advance(e,r){let n=Math.min(Math.max(e,0),this.options.maxDeltaMs);this.accumulatorMs=Math.min(this.accumulatorMs+n,this.options.fixedDeltaMs*this.options.maxSubSteps);let i=0;for(;this.accumulatorMs>=this.options.fixedDeltaMs&&i<this.options.maxSubSteps;)this.frame+=1,this.callbacks.simulate({frame:this.frame,deltaMs:this.options.fixedDeltaMs,nowMs:r}),this.accumulatorMs-=this.options.fixedDeltaMs,i+=1;let a=this.options.fixedDeltaMs===0?0:this.accumulatorMs/this.options.fixedDeltaMs;this.callbacks.render?.({alpha:a,nowMs:r,accumulatorMs:this.accumulatorMs,frame:this.frame})}};var Ha=class{constructor(e,r,n){this.name=e,this.callback=r,this.description=n}execute(e){this.callback(e)}},Ci=class{constructor(){this.commands=new Map;this.history=[];this.historyLimit=64;this.autocompleteProviders=[]}register(e,r,n){let i=new Ha(e,r,n);return this.commands.set(e,i),i}registerCommand(e,r){this.register(e,r)}registerAutocompleteProvider(e){this.autocompleteProviders.push(e)}get(e){return this.commands.get(e)}execute(e){let r=e.trim();if(r.length===0)return!1;(this.history.length===0||this.history[this.history.length-1]!==r)&&(this.history.push(r),this.history.length>this.historyLimit&&this.history.shift());let n=this.tokenize(e);if(n.length===0)return!1;let i=n[0],a=n.slice(1),o=this.get(i);return o?(o.execute(a),!0):(this.onConsoleOutput?.(`Unknown command "${i}"`),!1)}executeCommand(e){this.execute(e)}getHistory(){return[...this.history]}getSuggestions(e){let r=new Set;for(let n of this.commands.keys())n.startsWith(e)&&r.add(n);for(let n of this.autocompleteProviders){let i=n();for(let a of i)a.startsWith(e)&&r.add(a)}return Array.from(r).sort()}tokenize(e){let r=[],n="",i=!1;for(let a=0;a<e.length;a++){let o=e[a];o==='"'?i=!i:o===" "&&!i?n.length>0&&(r.push(n),n=""):n+=o}return n.length>0&&r.push(n),r}list(){return[...this.commands.values()].sort((e,r)=>e.name.localeCompare(r.name))}};var Tp=Object.defineProperty,Rp=(t,e)=>{for(var r in e)Tp(t,r,{get:e[r],enumerable:!0})},cf={x:0,y:0,z:0};var lw=Math.PI/180;function df(t,e){return{x:t.x-e.x,y:t.y-e.y,z:t.z-e.z}}function Cp(t,e){return{x:t.x*e,y:t.y*e,z:t.z*e}}function Pp(t,e){return t.x*e.x+t.y*e.y+t.z*e.z}function Ip(t){return Pp(t,t)}function Dc(t){return Math.sqrt(Ip(t))}function Hr(t){let e=Dc(t);return e===0?t:Cp(t,1/e)}var Bp=Math.PI/180,Fp=180/Math.PI,Pi=Bp,zc=Fp;var or=[[-.525731,0,.850651],[-.442863,.238856,.864188],[-.295242,0,.955423],[-.309017,.5,.809017],[-.16246,.262866,.951056],[0,0,1],[0,.850651,.525731],[-.147621,.716567,.681718],[.147621,.716567,.681718],[0,.525731,.850651],[.309017,.5,.809017],[.525731,0,.850651],[.295242,0,.955423],[.442863,.238856,.864188],[.16246,.262866,.951056],[-.681718,.147621,.716567],[-.809017,.309017,.5],[-.587785,.425325,.688191],[-.850651,.525731,0],[-.864188,.442863,.238856],[-.716567,.681718,.147621],[-.688191,.587785,.425325],[-.5,.809017,.309017],[-.238856,.864188,.442863],[-.425325,.688191,.587785],[-.716567,.681718,-.147621],[-.5,.809017,-.309017],[-.525731,.850651,0],[0,.850651,-.525731],[-.238856,.864188,-.442863],[0,.955423,-.295242],[-.262866,.951056,-.16246],[0,1,0],[0,.955423,.295242],[-.262866,.951056,.16246],[.238856,.864188,.442863],[.262866,.951056,.16246],[.5,.809017,.309017],[.238856,.864188,-.442863],[.262866,.951056,-.16246],[.5,.809017,-.309017],[.850651,.525731,0],[.716567,.681718,.147621],[.716567,.681718,-.147621],[.525731,.850651,0],[.425325,.688191,.587785],[.864188,.442863,.238856],[.688191,.587785,.425325],[.809017,.309017,.5],[.681718,.147621,.716567],[.587785,.425325,.688191],[.955423,.295242,0],[1,0,0],[.951056,.16246,.262866],[.850651,-.525731,0],[.955423,-.295242,0],[.864188,-.442863,.238856],[.951056,-.16246,.262866],[.809017,-.309017,.5],[.681718,-.147621,.716567],[.850651,0,.525731],[.864188,.442863,-.238856],[.809017,.309017,-.5],[.951056,.16246,-.262866],[.525731,0,-.850651],[.681718,.147621,-.716567],[.681718,-.147621,-.716567],[.850651,0,-.525731],[.809017,-.309017,-.5],[.864188,-.442863,-.238856],[.951056,-.16246,-.262866],[.147621,.716567,-.681718],[.309017,.5,-.809017],[.425325,.688191,-.587785],[.442863,.238856,-.864188],[.587785,.425325,-.688191],[.688191,.587785,-.425325],[-.147621,.716567,-.681718],[-.309017,.5,-.809017],[0,.525731,-.850651],[-.525731,0,-.850651],[-.442863,.238856,-.864188],[-.295242,0,-.955423],[-.16246,.262866,-.951056],[0,0,-1],[.295242,0,-.955423],[.16246,.262866,-.951056],[-.442863,-.238856,-.864188],[-.309017,-.5,-.809017],[-.16246,-.262866,-.951056],[0,-.850651,-.525731],[-.147621,-.716567,-.681718],[.147621,-.716567,-.681718],[0,-.525731,-.850651],[.309017,-.5,-.809017],[.442863,-.238856,-.864188],[.16246,-.262866,-.951056],[.238856,-.864188,-.442863],[.5,-.809017,-.309017],[.425325,-.688191,-.587785],[.716567,-.681718,-.147621],[.688191,-.587785,-.425325],[.587785,-.425325,-.688191],[0,-.955423,-.295242],[0,-1,0],[.262866,-.951056,-.16246],[0,-.850651,.525731],[0,-.955423,.295242],[.238856,-.864188,.442863],[.262866,-.951056,.16246],[.5,-.809017,.309017],[.716567,-.681718,.147621],[.525731,-.850651,0],[-.238856,-.864188,-.442863],[-.5,-.809017,-.309017],[-.262866,-.951056,-.16246],[-.850651,-.525731,0],[-.716567,-.681718,-.147621],[-.716567,-.681718,.147621],[-.525731,-.850651,0],[-.5,-.809017,.309017],[-.238856,-.864188,.442863],[-.262866,-.951056,.16246],[-.864188,-.442863,.238856],[-.809017,-.309017,.5],[-.688191,-.587785,.425325],[-.681718,-.147621,.716567],[-.442863,-.238856,.864188],[-.587785,-.425325,.688191],[-.309017,-.5,.809017],[-.147621,-.716567,.681718],[-.425325,-.688191,.587785],[-.16246,-.262866,.951056],[.442863,-.238856,.864188],[.16246,-.262866,.951056],[.309017,-.5,.809017],[.147621,-.716567,.681718],[0,-.525731,.850651],[.425325,-.688191,.587785],[.587785,-.425325,.688191],[.688191,-.587785,.425325],[-.955423,.295242,0],[-.951056,.16246,.262866],[-1,0,0],[-.850651,0,.525731],[-.955423,-.295242,0],[-.951056,-.16246,.262866],[-.864188,.442863,-.238856],[-.951056,.16246,-.262866],[-.809017,.309017,-.5],[-.864188,-.442863,-.238856],[-.951056,-.16246,-.262866],[-.809017,-.309017,-.5],[-.681718,.147621,-.716567],[-.681718,-.147621,-.716567],[-.850651,0,-.525731],[-.688191,.587785,-.425325],[-.587785,.425325,-.688191],[-.425325,.688191,-.587785],[-.425325,-.688191,-.587785],[-.587785,-.425325,-.688191],[-.688191,-.587785,-.425325]];var mr=624,kp=397,Dp=2567483615,zp=2147483648,Op=2147483647,Fc=4294967296,Up=class{constructor(t=5489){this.state=new Uint32Array(mr),this.index=mr,this.seed(t)}seed(t){this.state[0]=t>>>0;for(let e=1;e<mr;e++){let r=this.state[e-1]^this.state[e-1]>>>30,n=Math.imul(r>>>0,1812433253)+e;this.state[e]=n>>>0}this.index=mr}nextUint32(){this.index>=mr&&this.twist();let t=this.state[this.index++];return t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0}twist(){for(let t=0;t<mr;t++){let e=this.state[t]&zp|this.state[(t+1)%mr]&Op,r=this.state[(t+kp)%mr]^e>>>1;(e&1)!==0&&(r^=Dp),this.state[t]=r>>>0}this.index=0}getState(){return{index:this.index,state:Array.from(this.state)}}setState(t){if(t.state.length!==mr)throw new Error(`Expected ${mr} MT state values, received ${t.state.length}`);this.index=t.index,this.state=Uint32Array.from(t.state,e=>e>>>0)}},uf=class{constructor(t={}){this.mt=new Up(t.seed)}seed(t){this.mt.seed(t)}frandom(){return this.mt.nextUint32()/Fc}frandomRange(t,e){return t+(e-t)*this.frandom()}frandomMax(t){return this.frandomRange(0,t)}crandom(){return this.frandomRange(-1,1)}crandomOpen(){let t=Number.EPSILON;return this.frandomRange(-1+t,1)}irandomUint32(){return this.mt.nextUint32()}irandomRange(t,e){if(e-t<=1)return t;let r=e-t,n=Fc-Fc%r,i;do i=this.mt.nextUint32();while(i>=n);return t+i%r}irandom(t){return t<=0?0:this.irandomRange(0,t)}randomTimeRange(t,e){return e<=t?t:this.irandomRange(t,e)}randomTime(t){return this.irandom(t)}randomIndex(t){return this.irandom(t.length)}getState(){return{mt:this.mt.getState()}}setState(t){this.mt.setState(t.mt)}};function Np(){return new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}function Oc(t,e){let r=new Float32Array(16);for(let n=0;n<4;n+=1)for(let i=0;i<4;i+=1)r[i*4+n]=t[0+n]*e[i*4+0]+t[4+n]*e[i*4+1]+t[8+n]*e[i*4+2]+t[12+n]*e[i*4+3];return r}function ff(t,e){let r=e.x,n=e.y,i=e.z;return{x:t[0]*r+t[4]*n+t[8]*i+t[12],y:t[1]*r+t[5]*n+t[9]*i+t[13],z:t[2]*r+t[6]*n+t[10]*i+t[14]}}function hf(t,e){let r=Np();return r[0]=e[0].x,r[1]=e[0].y,r[2]=e[0].z,r[4]=e[1].x,r[5]=e[1].y,r[6]=e[1].z,r[8]=e[2].x,r[9]=e[2].y,r[10]=e[2].z,r[12]=t.x,r[13]=t.y,r[14]=t.z,r}var pr=1,dn=2;var Uc=8,Nc=16,Hp=32;var Vp=16384;var Bs=65536,mf=1<<17,Gp=1<<18,Wp=1<<19,Xp=1<<20,Kp=1<<21,Yp=1<<22,$p=1<<23,cw=1<<24,Fs=1<<25,qp=1<<26,dw=1<<27,uw=1<<28,fw=1<<29,ks=1<<30,hw=1<<31;var Ga=0;var Ds=4,Wa=8,zs=16,Os=32,pf=64;var mw=1<<25,pw=1<<28,gw=1<<29,yw=1<<30,bw=1<<31;var xw=pr|dn,vw=pr|Bs|dn|Fs|ks,_w=pr|Bs|dn,Sw=pr|mf|dn|Fs|ks,ww=Hp|Uc|Nc,Mw=pr|Nc|Uc,Zp=pr|Fs|ks|dn|qp,Aw=Gp|Wp|Xp|Kp|Yp|$p,Ew=pr|Uc|Nc|Fs|ks,Lw=pr|Bs|dn,Tw=pr|dn,Rw=pr|Bs|dn|mf,Cw=Zp|Vp;var Pw=Number.MAX_SAFE_INTEGER-1;var Us=(t=>(t[t.None=0]="None",t[t.Archive=1]="Archive",t[t.UserInfo=2]="UserInfo",t[t.ServerInfo=4]="ServerInfo",t[t.Latch=8]="Latch",t[t.Cheat=16]="Cheat",t))(Us||{});var Ns=256;var Hc=256,Vc=8192,Hs=2048,Gc=512,Wc=256,Xc=Ns*2,Kc=256,kc=32,Va=96;var J=(t=>(t[t.Name=0]="Name",t[t.CdTrack=1]="CdTrack",t[t.Sky=2]="Sky",t[t.SkyAxis=3]="SkyAxis",t[t.SkyRotate=4]="SkyRotate",t[t.StatusBar=5]="StatusBar",t[t.HealthBarName=55]="HealthBarName",t[t.CONFIG_N64_PHYSICS=56]="CONFIG_N64_PHYSICS",t[t.CONFIG_CTF_TEAMS=57]="CONFIG_CTF_TEAMS",t[t.CONFIG_COOP_RESPAWN_STRING=58]="CONFIG_COOP_RESPAWN_STRING",t[t.Story=54]="Story",t[t.AirAccel=59]="AirAccel",t[t.MaxClients=60]="MaxClients",t[t.MapChecksum=61]="MapChecksum",t[t.Models=62]="Models",t[t.Sounds=62+Vc]="Sounds",t[t.Images=t.Sounds+Hs]="Images",t[t.Lights=t.Images+Gc]="Lights",t[t.ShadowLights=t.Lights+Hc]="ShadowLights",t[t.Items=t.ShadowLights+Kc]="Items",t[t.Players=t.Items+Wc]="Players",t[t.PlayerSkins=t.Players]="PlayerSkins",t[t.General=t.Players+Ns]="General",t[t.WheelWeapons=t.General+Xc]="WheelWeapons",t[t.WheelAmmo=t.WheelWeapons+kc]="WheelAmmo",t[t.WheelPowerups=t.WheelAmmo+kc]="WheelPowerups",t[t.CdLoopCount=t.WheelPowerups+kc]="CdLoopCount",t[t.GameStyle=t.CdLoopCount+1]="GameStyle",t[t.MaxConfigStrings=t.GameStyle+1]="MaxConfigStrings",t))(J||{}),gf=J.MaxConfigStrings;function yf(t){return t>=5&&t<59?Va*(59-t):t>=J.General&&t<J.WheelWeapons?Va*(J.MaxConfigStrings-t):Va}var Iw=J.Sounds,Bw=J.Images,Fw=J.Lights,kw=J.Items,Dw=J.Players,zw=J.General,jp={};Rp(jp,{addReplayFrame:()=>tg,createReplaySession:()=>eg,deserializeReplay:()=>Jp,serializeReplay:()=>Qp});function Qp(t){return JSON.stringify(t,null,2)}function Jp(t){let e=JSON.parse(t);if(!e.metadata||!Array.isArray(e.frames))throw new Error("Invalid replay format: missing metadata or frames");return e}function eg(t,e){return{metadata:{map:t,date:new Date().toISOString(),version:"1.0",seed:e},frames:[]}}function tg(t,e,r,n){t.frames.push({serverFrame:r,cmd:e,timestamp:Date.now()-n})}var T=(t=>(t[t.bad=0]="bad",t[t.muzzleflash=1]="muzzleflash",t[t.muzzleflash2=2]="muzzleflash2",t[t.temp_entity=3]="temp_entity",t[t.layout=4]="layout",t[t.inventory=5]="inventory",t[t.nop=6]="nop",t[t.disconnect=7]="disconnect",t[t.reconnect=8]="reconnect",t[t.sound=9]="sound",t[t.print=10]="print",t[t.stufftext=11]="stufftext",t[t.serverdata=12]="serverdata",t[t.configstring=13]="configstring",t[t.spawnbaseline=14]="spawnbaseline",t[t.centerprint=15]="centerprint",t[t.download=16]="download",t[t.playerinfo=17]="playerinfo",t[t.packetentities=18]="packetentities",t[t.deltapacketentities=19]="deltapacketentities",t[t.frame=20]="frame",t[t.splitclient=21]="splitclient",t[t.configblast=22]="configblast",t[t.spawnbaselineblast=23]="spawnbaselineblast",t[t.level_restart=24]="level_restart",t[t.damage=25]="damage",t[t.locprint=26]="locprint",t[t.fog=27]="fog",t[t.waitingforplayers=28]="waitingforplayers",t[t.bot_chat=29]="bot_chat",t[t.poi=30]="poi",t[t.help_path=31]="help_path",t[t.muzzleflash3=32]="muzzleflash3",t[t.achievement=33]="achievement",t))(T||{}),qn=(t=>(t[t.bad=0]="bad",t[t.nop=1]="nop",t[t.move=2]="move",t[t.userinfo=3]="userinfo",t[t.stringcmd=4]="stringcmd",t))(qn||{}),D=(t=>(t[t.GUNSHOT=0]="GUNSHOT",t[t.BLOOD=1]="BLOOD",t[t.BLASTER=2]="BLASTER",t[t.RAILTRAIL=3]="RAILTRAIL",t[t.SHOTGUN=4]="SHOTGUN",t[t.EXPLOSION1=5]="EXPLOSION1",t[t.EXPLOSION2=6]="EXPLOSION2",t[t.ROCKET_EXPLOSION=7]="ROCKET_EXPLOSION",t[t.GRENADE_EXPLOSION=8]="GRENADE_EXPLOSION",t[t.SPARKS=9]="SPARKS",t[t.SPLASH=10]="SPLASH",t[t.BUBBLETRAIL=11]="BUBBLETRAIL",t[t.SCREEN_SPARKS=12]="SCREEN_SPARKS",t[t.SHIELD_SPARKS=13]="SHIELD_SPARKS",t[t.BULLET_SPARKS=14]="BULLET_SPARKS",t[t.LASER_SPARKS=15]="LASER_SPARKS",t[t.PARASITE_ATTACK=16]="PARASITE_ATTACK",t[t.ROCKET_EXPLOSION_WATER=17]="ROCKET_EXPLOSION_WATER",t[t.GRENADE_EXPLOSION_WATER=18]="GRENADE_EXPLOSION_WATER",t[t.MEDIC_CABLE_ATTACK=19]="MEDIC_CABLE_ATTACK",t[t.BFG_EXPLOSION=20]="BFG_EXPLOSION",t[t.BFG_BIGEXPLOSION=21]="BFG_BIGEXPLOSION",t[t.BOSSTPORT=22]="BOSSTPORT",t[t.BFG_LASER=23]="BFG_LASER",t[t.GRAPPLE_CABLE=24]="GRAPPLE_CABLE",t[t.WELDING_SPARKS=25]="WELDING_SPARKS",t[t.GREENBLOOD=26]="GREENBLOOD",t[t.BLUEHYPERBLASTER=27]="BLUEHYPERBLASTER",t[t.PLASMA_EXPLOSION=28]="PLASMA_EXPLOSION",t[t.TUNNEL_SPARKS=29]="TUNNEL_SPARKS",t[t.BLASTER2=30]="BLASTER2",t[t.RAILTRAIL2=31]="RAILTRAIL2",t[t.FLAME=32]="FLAME",t[t.LIGHTNING=33]="LIGHTNING",t[t.DEBUGTRAIL=34]="DEBUGTRAIL",t[t.PLAIN_EXPLOSION=35]="PLAIN_EXPLOSION",t[t.FLASHLIGHT=36]="FLASHLIGHT",t[t.FORCEWALL=37]="FORCEWALL",t[t.HEATBEAM=38]="HEATBEAM",t[t.MONSTER_HEATBEAM=39]="MONSTER_HEATBEAM",t[t.STEAM=40]="STEAM",t[t.BUBBLETRAIL2=41]="BUBBLETRAIL2",t[t.MOREBLOOD=42]="MOREBLOOD",t[t.HEATBEAM_SPARKS=43]="HEATBEAM_SPARKS",t[t.HEATBEAM_STEAM=44]="HEATBEAM_STEAM",t[t.CHAINFIST_SMOKE=45]="CHAINFIST_SMOKE",t[t.ELECTRIC_SPARKS=46]="ELECTRIC_SPARKS",t[t.TRACKER_EXPLOSION=47]="TRACKER_EXPLOSION",t[t.TELEPORT_EFFECT=48]="TELEPORT_EFFECT",t[t.DBALL_GOAL=49]="DBALL_GOAL",t[t.WIDOWBEAMOUT=50]="WIDOWBEAMOUT",t[t.NUKEBLAST=51]="NUKEBLAST",t[t.WIDOWSPLASH=52]="WIDOWSPLASH",t[t.EXPLOSION1_BIG=53]="EXPLOSION1_BIG",t[t.EXPLOSION1_NP=54]="EXPLOSION1_NP",t[t.FLECHETTE=55]="FLECHETTE",t[t.BLUEHYPERBLASTER_KEX=56]="BLUEHYPERBLASTER_KEX",t[t.BFG_ZAP=57]="BFG_ZAP",t[t.BERSERK_SLAM=58]="BERSERK_SLAM",t[t.GRAPPLE_CABLE_2=59]="GRAPPLE_CABLE_2",t[t.POWER_SPLASH=60]="POWER_SPLASH",t[t.LIGHTNING_BEAM=61]="LIGHTNING_BEAM",t[t.EXPLOSION1_NL=62]="EXPLOSION1_NL",t[t.EXPLOSION2_NL=63]="EXPLOSION2_NL",t))(D||{});var bf=64;var rg=12,ng=9,Ow=Math.ceil(rg*ng/16),ig=23,ag=2,Uw=Math.ceil(ig*ag/16);function xf(t,e){t.writeByte(e.msec),t.writeByte(e.buttons),t.writeAngle16(e.angles.x),t.writeAngle16(e.angles.y),t.writeAngle16(e.angles.z),t.writeShort(e.forwardmove),t.writeShort(e.sidemove),t.writeShort(e.upmove),t.writeByte(e.impulse),t.writeByte(0)}var og=[0,145,227,114,7,150,228,117,14,159,237,124,9,152,234,123,28,141,255,110,27,138,248,105,18,131,241,96,21,132,246,103,56,169,219,74,63,174,220,77,54,167,213,68,49,160,210,67,36,181,199,86,35,178,192,81,42,187,201,88,45,188,206,95,112,225,147,2,119,230,148,5,126,239,157,12,121,232,154,11,108,253,143,30,107,250,136,25,98,243,129,16,101,244,134,23,72,217,171,58,79,222,172,61,70,215,165,52,65,208,162,51,84,197,183,38,83,194,176,33,90,203,185,40,93,204,190,47,224,113,3,146,231,118,4,149,238,127,13,156,233,120,10,155,252,109,31,142,251,106,24,137,242,99,17,128,245,100,22,135,216,73,59,170,223,78,60,173,214,71,53,164,209,64,50,163,196,85,39,182,195,82,32,177,202,91,41,184,205,92,46,191,144,1,115,226,151,6,116,229,158,15,125,236,153,8,122,235,140,29,111,254,139,26,104,249,130,19,97,240,133,20,102,247,168,57,75,218,175,62,76,221,166,55,69,212,161,48,66,211,180,37,86,199,179,34,80,193,186,43,89,200,189,44,94,207];function vf(t){let e=0;for(let r=0;r<t.length;r++)e=og[(e^t[r])&255];return e}var ft=1,ht=2,mt=4,pt=8,gt=16,yt=32,Xa=64,gr=128,Zn=256,bt=512,xt=1024,vt=2048,Ue=4096,yr=8192,Ne=16384,br=32768,He=65536,_t=1<<17,Ve=1<<18,Ge=1<<19,St=1<<20,wt=1<<21,Mt=1<<22,xr=1<<23,sr=1<<24,We=1<<25,At=1<<26,Et=1<<27,vr=1<<28,_r=1<<29,Sr=1<<30,Ii=-2147483648,un=1,fn=2,hn=4;var mn=class{constructor(t){t instanceof Uint8Array?this.view=new DataView(t.buffer,t.byteOffset,t.byteLength):this.view=new DataView(t),this.offset=0,this.length=this.view.byteLength}getPosition(){return this.offset}getReadPosition(){return this.offset}getLength(){return this.length}getRemaining(){return this.length-this.offset}seek(t){if(t<0||t>this.length)throw new Error(`Seek out of bounds: ${t} (length: ${this.length})`);this.offset=t}setReadPosition(t){this.seek(t)}hasMore(){return this.offset<this.length}hasBytes(t){return this.offset+t<=this.length}readChar(){let t=this.view.getInt8(this.offset);return this.offset+=1,t}readByte(){let t=this.view.getUint8(this.offset);return this.offset+=1,t}readShort(){let t=this.view.getInt16(this.offset,!0);return this.offset+=2,t}readUShort(){let t=this.view.getUint16(this.offset,!0);return this.offset+=2,t}readLong(){let t=this.view.getInt32(this.offset,!0);return this.offset+=4,t}readULong(){let t=this.view.getUint32(this.offset,!0);return this.offset+=4,t}readFloat(){let t=this.view.getFloat32(this.offset,!0);return this.offset+=4,t}readString(){let t="";for(;this.offset<this.length;){let e=this.readChar();if(e===-1||e===0)break;t+=String.fromCharCode(e)}return t}readStringLine(){let t="";for(;this.offset<this.length;){let e=this.readChar();if(e===-1||e===0||e===10)break;t+=String.fromCharCode(e)}return t}readCoord(){return this.readShort()*(1/8)}readAngle(){return this.readChar()*(360/256)}readAngle16(){return this.readShort()*360/65536}readData(t){if(this.offset+t>this.length)throw new Error(`Read out of bounds: ${this.offset+t} (length: ${this.length})`);let e=new Uint8Array(this.view.buffer,this.view.byteOffset+this.offset,t);return this.offset+=t,new Uint8Array(e)}readPos(t){t.x=this.readCoord(),t.y=this.readCoord(),t.z=this.readCoord()}readDir(t){let e=this.readByte();if(e>=162){t.x=0,t.y=0,t.z=0;return}let r=or[e];t.x=r[0],t.y=r[1],t.z=r[2]}},jn=class{constructor(t=1400){typeof t=="number"?(this.buffer=new Uint8Array(t),this.fixed=!1):(this.buffer=t,this.fixed=!0),this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength),this.offset=0}ensureSpace(t){if(this.offset+t>this.buffer.byteLength){if(this.fixed)throw new Error(`Buffer overflow: capacity ${this.buffer.byteLength}, needed ${this.offset+t}`);let e=Math.max(this.buffer.byteLength*2,this.offset+t),r=new Uint8Array(e);r.set(this.buffer),this.buffer=r,this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength)}}writeByte(t){this.ensureSpace(1),this.view.setUint8(this.offset,t),this.offset+=1}writeBytes(t){this.ensureSpace(t.byteLength),this.buffer.set(t,this.offset),this.offset+=t.byteLength}writeChar(t){this.ensureSpace(1),this.view.setInt8(this.offset,t),this.offset+=1}writeShort(t){this.ensureSpace(2),this.view.setInt16(this.offset,t,!0),this.offset+=2}writeLong(t){this.ensureSpace(4),this.view.setInt32(this.offset,t,!0),this.offset+=4}writeFloat(t){this.ensureSpace(4),this.view.setFloat32(this.offset,t,!0),this.offset+=4}writeString(t){let e=t.length;this.ensureSpace(e+1);for(let r=0;r<e;r++)this.view.setUint8(this.offset+r,t.charCodeAt(r));this.view.setUint8(this.offset+e,0),this.offset+=e+1}writeCoord(t){this.writeShort(Math.trunc(t*8))}writeAngle(t){this.writeByte(Math.trunc(t*256/360)&255)}writeAngle16(t){this.writeShort(Math.trunc(t*65536/360)&65535)}writePos(t){this.writeCoord(t.x),this.writeCoord(t.y),this.writeCoord(t.z)}writeDir(t){let e=-1,r=0;if(t.x===0&&t.y===0&&t.z===0){this.writeByte(0);return}for(let n=0;n<or.length;n++){let i=or[n],a=t.x*i[0]+t.y*i[1]+t.z*i[2];a>e&&(e=a,r=n)}this.writeByte(r)}getData(){return this.buffer.slice(0,this.offset)}getBuffer(){return this.buffer}getOffset(){return this.offset}reset(){this.offset=0}},Ka=class{constructor(t=1024){this.buffer=new Uint8Array(t),this.view=new DataView(this.buffer.buffer),this.offset=0}ensureCapacity(t){if(this.offset+t>this.buffer.length){let e=Math.max(this.buffer.length*2,this.offset+t),r=new Uint8Array(e);r.set(this.buffer),this.buffer=r,this.view=new DataView(this.buffer.buffer)}}getData(){return this.buffer.slice(0,this.offset)}writeByte(t){this.ensureCapacity(1),this.view.setUint8(this.offset,t),this.offset+=1}writeChar(t){this.ensureCapacity(1),this.view.setInt8(this.offset,t),this.offset+=1}writeShort(t){this.ensureCapacity(2),this.view.setInt16(this.offset,t,!0),this.offset+=2}writeUShort(t){this.ensureCapacity(2),this.view.setUint16(this.offset,t,!0),this.offset+=2}writeLong(t){this.ensureCapacity(4),this.view.setInt32(this.offset,t,!0),this.offset+=4}writeFloat(t){this.ensureCapacity(4),this.view.setFloat32(this.offset,t,!0),this.offset+=4}writeString(t){let e=t.length+1;this.ensureCapacity(e);for(let r=0;r<t.length;r++)this.view.setUint8(this.offset+r,t.charCodeAt(r));this.view.setUint8(this.offset+t.length,0),this.offset+=e}writeData(t){this.ensureCapacity(t.length),this.buffer.set(t,this.offset),this.offset+=t.length}writeCoord(t){this.writeShort(Math.round(t*8))}writeAngle(t){this.writeByte(Math.round(t*256/360)&255)}writeAngle16(t){this.writeShort(Math.round(t*65536/360))}writeDir(t,e,r){let n=0,i=-999999,a=Math.sqrt(t*t+e*e+r*r);if(a>0){t/=a,e/=a,r/=a;for(let o=0;o<162;o++){let s=t*or[o][0]+e*or[o][1]+r*or[o][2];s>i&&(i=s,n=o)}}this.writeByte(n)}},$n=class $e{constructor(){this.qport=0,this.incomingSequence=0,this.outgoingSequence=0,this.incomingAcknowledged=0,this.incomingReliableAcknowledged=!1,this.incomingReliableSequence=0,this.outgoingReliableSequence=0,this.reliableLength=0,this.fragmentSendOffset=0,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0,this.lastReceived=0,this.lastSent=0,this.remoteAddress=null,this.reliableMessage=new jn($e.MAX_RELIABLE_BUFFER);let e=Date.now();this.lastReceived=e,this.lastSent=e,this.qport=Math.floor(Math.random()*65536)}setup(e,r=null){this.qport=e,this.remoteAddress=r,this.reset()}reset(){this.incomingSequence=0,this.outgoingSequence=0,this.incomingAcknowledged=0,this.incomingReliableAcknowledged=!1,this.incomingReliableSequence=0,this.outgoingReliableSequence=0,this.reliableLength=0,this.reliableMessage.reset(),this.fragmentSendOffset=0,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0,this.lastReceived=Date.now(),this.lastSent=Date.now()}transmit(e){this.outgoingSequence++,this.lastSent=Date.now();let r=0,n=!1,i=0;this.reliableLength>0&&(this.reliableLength>$e.FRAGMENT_SIZE?(n=!0,this.fragmentSendOffset>=this.reliableLength&&(this.fragmentSendOffset=0),r=this.reliableLength-this.fragmentSendOffset,r>$e.FRAGMENT_SIZE&&(r=$e.FRAGMENT_SIZE),i=this.fragmentSendOffset,this.fragmentSendOffset+=r):r=this.reliableLength);let a=$e.PACKET_HEADER,o=r>0?2+(n?8:0):0,s=e?e.length:0;a+o+r+s>$e.MAX_MSGLEN&&(s=$e.MAX_MSGLEN-a-o-r,s<0&&(s=0));let c=new ArrayBuffer(a+o+r+s),l=new DataView(c),d=new Uint8Array(c),f=this.outgoingSequence;r>0&&(f|=2147483648,(this.outgoingReliableSequence&1)!==0&&(f|=1073741824)),l.setUint32(0,f,!0);let u=this.incomingSequence;(this.incomingReliableSequence&1)!==0&&(u|=2147483648),l.setUint32(4,u,!0),l.setUint16(8,this.qport,!0);let h=a;if(r>0){let m=r;n&&(m|=32768),l.setUint16(h,m,!0),h+=2,n&&(l.setUint32(h,i,!0),h+=4,l.setUint32(h,this.reliableLength,!0),h+=4);let p=this.reliableMessage.getBuffer().subarray(i,i+r);d.set(p,h),h+=r}if(e&&s>0){let m=e.slice(0,s);d.set(m,h)}return d}process(e){if(e.length<4)return null;this.lastReceived=Date.now();let r=new DataView(e.buffer,e.byteOffset,e.byteLength),n=r.getUint32(0,!0);if(n===4294967295)return e.subarray(4);if(e.length<$e.PACKET_HEADER)return null;let i=r.getUint32(4,!0),a=r.getUint16(8,!0);if(this.qport!==a)return null;let o=n&1073741823;if((o-this.incomingSequence|0)<=0)return null;this.incomingSequence=o;let s=i&2147483647,c=(i&2147483648)!==0;if(s>this.incomingAcknowledged&&(this.incomingAcknowledged=s),this.reliableLength>0){let m=c?1:0,g=this.outgoingReliableSequence&1;m!==g&&(this.reliableLength=0,this.reliableMessage.reset(),this.outgoingReliableSequence^=1,this.fragmentSendOffset=0)}let l=(n&2147483648)!==0,d=(n&1073741824)!==0?1:0,f=$e.PACKET_HEADER,u=null;if(l){if(f+2>e.byteLength)return null;let m=r.getUint16(f,!0);f+=2;let g=(m&32768)!==0;m&=32767;let p=this.incomingReliableSequence&1;if(d===p)if(g){if(f+8>e.byteLength)return null;let y=r.getUint32(f,!0);f+=4;let v=r.getUint32(f,!0);if(f+=4,v>$e.MAX_RELIABLE_BUFFER)return console.warn(`NetChan: received invalid fragment total ${v} > ${$e.MAX_RELIABLE_BUFFER}`),null;if((!this.fragmentBuffer||this.fragmentBuffer.length!==v)&&(this.fragmentBuffer=new Uint8Array(v),this.fragmentLength=v,this.fragmentReceived=0),f+m>e.byteLength)return null;let x=e.subarray(f,f+m);y===this.fragmentReceived&&y+m<=v&&(this.fragmentBuffer.set(x,y),this.fragmentReceived+=m,this.fragmentReceived>=v&&(u=this.fragmentBuffer,this.incomingReliableSequence++,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0))}else{if(this.incomingReliableSequence++,f+m>e.byteLength)return null;u=e.slice(f,f+m)}f+=m}let h=e.slice(f);if(u&&u.length>0){let m=u.length+h.length,g=new Uint8Array(m);return g.set(u,0),g.set(h,u.length),g}return h||new Uint8Array(0)}canSendReliable(){return this.reliableLength===0}writeReliableByte(e){if(this.reliableLength+1>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeByte(e),this.reliableLength++}writeReliableShort(e){if(this.reliableLength+2>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeShort(e),this.reliableLength+=2}writeReliableLong(e){if(this.reliableLength+4>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeLong(e),this.reliableLength+=4}writeReliableString(e){let r=e.length+1;if(this.reliableLength+r>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeString(e),this.reliableLength+=r}getReliableData(){return this.reliableLength===0?new Uint8Array(0):this.reliableMessage.getBuffer().subarray(0,this.reliableLength)}needsKeepalive(e){return e-this.lastSent>1e3}isTimedOut(e,r=3e4){return e-this.lastReceived>r}};$n.MAX_MSGLEN=1400;$n.FRAGMENT_SIZE=1024;$n.PACKET_HEADER=10;$n.HEADER_OVERHEAD=$n.PACKET_HEADER+2;$n.MAX_RELIABLE_BUFFER=262144;var _f=$n;var Sf=(t=>(t[t.Bullets=0]="Bullets",t[t.Shells=1]="Shells",t[t.Rockets=2]="Rockets",t[t.Grenades=3]="Grenades",t[t.Cells=4]="Cells",t[t.Slugs=5]="Slugs",t[t.MagSlugs=6]="MagSlugs",t[t.Trap=7]="Trap",t[t.Flechettes=8]="Flechettes",t[t.Tesla=9]="Tesla",t[t.Disruptor=10]="Disruptor",t[t.Prox=11]="Prox",t[t.Nuke=12]="Nuke",t[t.Rounds=13]="Rounds",t))(Sf||{}),Nw=Object.keys(Sf).length/2;var Ya=32,wr=(t=>(t[t.Auto=0]="Auto",t[t.Weapon=1]="Weapon",t[t.Voice=2]="Voice",t[t.Item=3]="Item",t[t.Body=4]="Body",t[t.Aux=5]="Aux",t[t.Footstep=6]="Footstep",t[t.Aux3=7]="Aux3",t[t.NoPhsAdd=8]="NoPhsAdd",t[t.Reliable=16]="Reliable",t[t.ForcePos=32]="ForcePos",t))(wr||{}),Yc=-1,$a=0,$c=1,qc=2,Zc=3,Bi=80,jc=.003;function Fi(t){return t*.001}function Qn(t){let e=Fi(t);return e<=0?Number.POSITIVE_INFINITY:Bi+1/e}var qa=class{constructor({name:e,defaultValue:r,description:n,flags:i=Us.None,onChange:a}){this.modifiedCount=0;this.name=e,this.defaultValue=r,this.description=n,this.flags=i,this._value=r,this.onChange=a}get string(){return this._value}getString(){return this.string}get number(){return Number(this._value)}getFloat(){return this.number}get integer(){return Math.trunc(this.number)}getInt(){return this.integer}get boolean(){return!!this.integer}getBoolean(){return this.boolean}set(e){if(this.flags&Us.Latch){if(e===this._value){this.latched=void 0;return}if(this.latched===e)return;this.latched!==e&&(this.latched=e);return}this.apply(e)}reset(){this.latched=void 0,this.apply(this.defaultValue)}applyLatched(){if(this.latched===void 0)return!1;let e=this.latched;return this.latched=void 0,e===this._value?!1:(this.apply(e),!0)}apply(e){if(this._value===e)return;let r=this._value;this._value=e,this.modifiedCount+=1,this.onChange?.(this,r)}},ki=class{constructor(){this.cvars=new Map}register(e){let r=this.cvars.get(e.name);if(r)return r;let n=e.onChange,i=(o,s)=>{n?.(o,s),this.onCvarChange?.(o.name,o.string)},a=new qa({...e,onChange:i});return this.cvars.set(e.name,a),a}get(e){return this.cvars.get(e)}getCvar(e){return this.get(e)}setValue(e,r){let n=this.get(e);if(!n)throw new Error(`Unknown cvar: ${e}`);return n.set(r),n}setCvar(e,r){this.setValue(e,r)}resetAll(){for(let e of this.cvars.values())e.reset()}applyLatched(){let e=!1;for(let r of this.cvars.values())e=r.applyLatched()||e;return e}list(){return[...this.cvars.values()].sort((e,r)=>e.name.localeCompare(r.name))}listCvars(){return this.list().map(e=>({name:e.name,value:e.string,defaultValue:e.defaultValue,flags:e.flags,description:e.description}))}};var Di=class{constructor(e,r,n={}){this.game=e;this.client=r;this.started=!1;this.paused_=!1;this.commands=new Ci;this.cvars=new ki;this.stepSimulation=e=>{this.previousFrame=this.latestFrame,this.latestFrame=this.game.frame(e,this.latestCommand)};this.renderClient=e=>{this.client&&(this.latestCommand=this.client.render({...e,previous:this.previousFrame,latest:this.latestFrame}))};let i=n.loop?.now?.()??Date.now();this.startTimeMs=n.startTimeMs??n.loop?.startTimeMs??i,this.loop=new Yn({simulate:this.stepSimulation,render:this.renderClient},{...n.loop,startTimeMs:this.startTimeMs}),this.commands.registerAutocompleteProvider(()=>this.cvars.list().map(a=>a.name))}start(){if(!this.started){try{this.latestFrame=this.game.init(this.startTimeMs)??this.latestFrame,this.client?.init(this.latestFrame)}catch(e){throw this.game.shutdown(),this.client?.shutdown(),e}this.started=!0,this.paused_=!1,this.loop.start()}}stop(){this.started&&(this.loop.stop(),this.client?.shutdown(),this.game.shutdown(),this.previousFrame=void 0,this.latestFrame=void 0,this.started=!1,this.paused_=!1)}setPaused(e){this.paused_=e,e?this.loop.stop():this.started&&this.loop.start()}get paused(){return this.paused_}pump(e){this.loop.pump(e)}getLatestFrame(){return this.latestFrame}isRunning(){return this.loop.isRunning()}};var zi=class{constructor(e){this.registry=e.registry,this.system=e.system,this.music=e.music,this.client=e.client}soundindex(e){return this.registry.registerName(e)}sound(e,r,n,i,a,o){this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:a,timeOffsetMs:o}),this.triggerSubtitle(n)}positioned_sound(e,r,n,i){this.system.positionedSound(e,r,n,i),this.triggerSubtitle(r)}loop_sound(e,r,n,i,a){let o=this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:a,looping:!0});return this.triggerSubtitle(n),o}stop_entity_sounds(e){this.system.stopEntitySounds(e)}setPlaybackRate(e){this.system.setPlaybackRate(e)}set_listener(e){this.system.setListener(e)}play_music(e,r=!0){return this.music?this.music.play(e,{loop:r}):Promise.resolve()}play_track(e,r=!0){return this.music?this.music.playTrack(e):Promise.resolve()}pause_music(){this.music?.pause()}resume_music(){return this.music?.resume()??Promise.resolve()}stop_music(){this.music?.stop()}set_music_volume(e){this.music?.setVolume(e)}play_ambient(e,r,n){this.system.ambientSound(e,r,n),this.triggerSubtitle(r)}play_channel(e){this.system.play({...e}),this.triggerSubtitle(e.soundIndex)}triggerSubtitle(e){if(!this.client)return;let r=this.registry.getName(e);if(!r)return;let n=r.match(/\[(.*?)\]/);n&&this.client.showSubtitle(n[1],r)}};var Za=class{constructor(e,r){this.engine=e;this.host=r;this.started=!1}start(){this.started||(this.engine.init(),this.host.start(),this.started=!0)}stop(){this.started&&(this.host.stop(),this.engine.shutdown(),this.started=!1)}pump(e){this.host.pump(e)}getLatestFrame(){return this.host.getLatestFrame()}isRunning(){return this.started&&this.host.isRunning()}};function wf(t,e,r,n,i){let a=new zi({...n,client:r}),o=new Di(e,r,i);return{runtime:new Za(t,o),audio:a}}function sg(t){if(t<0||t>=J.MaxConfigStrings)throw new RangeError(`Configstring index ${t} is out of range (0-${J.MaxConfigStrings-1})`)}function Mf(t,e){let r=yf(t);if(e.length>r)throw new RangeError(`Configstring ${t} exceeds maximum length (${e.length} > ${r}); limit is ${Va} chars per slot`)}var Oi=class{constructor(){this.values=new Map;this.modelCursor=J.Models;this.soundCursor=J.Sounds;this.imageCursor=J.Images;this.lightCursor=J.Lights;this.shadowLightCursor=J.ShadowLights;this.itemCursor=J.Items;this.playerSkinCursor=J.PlayerSkins;this.generalCursor=J.General}set(e,r){return sg(e),Mf(e,r),this.values.set(e,r),e}get(e){return this.values.get(e)}getName(e){return this.get(e)}getAll(){let e=new Array(gf).fill("");for(let[r,n]of this.values.entries())e[r]=n;return e}modelIndex(e){return this.register(e,J.Models,Vc,"modelCursor")}soundIndex(e){return this.register(e,J.Sounds,Hs,"soundCursor")}findSoundIndex(e){for(let r=J.Sounds;r<J.Sounds+Hs;r+=1)if(this.values.get(r)===e)return r}imageIndex(e){return this.register(e,J.Images,Gc,"imageCursor")}lightIndex(e){return this.register(e,J.Lights,Hc,"lightCursor")}shadowLightIndex(e){return this.register(e,J.ShadowLights,Kc,"shadowLightCursor")}itemIndex(e){return this.register(e,J.Items,Wc,"itemCursor")}playerSkinIndex(e){return this.register(e,J.PlayerSkins,Ns,"playerSkinCursor")}generalIndex(e){return this.register(e,J.General,Xc,"generalCursor")}register(e,r,n,i){for(let s=r;s<r+n;s+=1)if(this.values.get(s)===e)return s;let a=this[i],o=r+n;if(a>=o)throw new RangeError(`Out of configstring slots for range starting at ${r}`);return Mf(a,e),this.values.set(a,e),this[i]=a+1,a}};var lg="PACK";function cg(t,e,r){let n=[];for(let i=0;i<r;i+=1){let a=t.getUint8(e+i);if(a===0)break;n.push(a)}return String.fromCharCode(...n)}function _e(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}function dg(){let t=new Uint32Array(256);for(let e=0;e<256;e+=1){let r=e;for(let n=0;n<8;n+=1)r=(r&1)!==0?3988292384^r>>>1:r>>>1;t[e]=r>>>0}return t}var ug=dg();function Af(t){let e=4294967295;for(let r=0;r<t.length;r+=1){let n=t[r];e=ug[(e^n)&255]^e>>>8}return(e^4294967295)>>>0}var Ie=class extends Error{},Ui=class t{constructor(e,r,n,i){this.name=e;this.buffer=r;this.entries=new Map(n.map(a=>[a.name,a])),this.checksum=i,this.size=r.byteLength}static fromArrayBuffer(e,r){let n=new DataView(r);if(r.byteLength<12)throw new Ie("PAK buffer too small to contain header");let i=String.fromCharCode(n.getUint8(0),n.getUint8(1),n.getUint8(2),n.getUint8(3));if(i!==lg)throw new Ie(`Invalid PAK header magic: ${i}`);let a=n.getInt32(4,!0),o=n.getInt32(8,!0);if(a<12)throw new Ie(`Invalid directory offset: ${a}`);if(o<0||o%64!==0)throw new Ie(`Invalid directory length: ${o}`);if(a+o>r.byteLength)throw new Ie("Directory exceeds buffer length");let c=o/64,l=[],d=new Map;for(let f=0;f<c;f+=1){let u=a+f*64,h=cg(n,u,56),m=_e(h),g=n.getInt32(u+56,!0),p=n.getInt32(u+60,!0);if(g<0||p<0||g+p>r.byteLength)throw new Ie(`Invalid entry bounds for ${h||"<unnamed>"} (offset=${g}, length=${p})`);if(!m)throw new Ie(`Entry ${f} has an empty name`);let y={name:m,offset:g,length:p};d.set(m,y)}return l.push(...d.values()),new t(e,r,l,Af(new Uint8Array(r)))}getEntry(e){return this.entries.get(_e(e))}listEntries(){return Array.from(this.entries.values())}list(){return Array.from(this.entries.keys())}readFile(e){let r=this.getEntry(e);if(!r)throw new Ie(`File not found in PAK: ${e}`);return new Uint8Array(this.buffer,r.offset,r.length)}validate(){return{checksum:this.checksum,entries:this.listEntries()}}};function Ef(t){return Af(new Uint8Array(t))}var fg="PACK",Lf=12,Qc=64;function Tf(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}var Vs=class{constructor(e){this.source=e;this.entries=null}async readDirectory(){if(this.entries)return Array.from(this.entries.values());let e=await this.readChunk(0,Lf),r=new DataView(e),n=String.fromCharCode(r.getUint8(0),r.getUint8(1),r.getUint8(2),r.getUint8(3));if(n!==fg)throw new Ie(`Invalid PAK header magic: ${n}`);let i=r.getInt32(4,!0),a=r.getInt32(8,!0);if(i<Lf)throw new Ie(`Invalid directory offset: ${i}`);if(a<0||a%Qc!==0)throw new Ie(`Invalid directory length: ${a}`);let o=await this.readChunk(i,a),s=new DataView(o),c=a/Qc,l=new Map;for(let d=0;d<c;d++){let f=d*Qc,u=this.readCString(s,f,56),h=Tf(u),m=s.getInt32(f+56,!0),g=s.getInt32(f+60,!0);m<0||g<0||m+g>this.source.size,h&&l.set(h,{name:h,offset:m,length:g})}return this.entries=l,Array.from(l.values())}async readFile(e){let r=await this.getEntry(e);if(!r)throw new Ie(`File not found in PAK: ${e}`);return this.source.slice(r.offset,r.offset+r.length).stream()}async getFileBlob(e){let r=await this.getEntry(e);if(!r)throw new Ie(`File not found in PAK: ${e}`);return this.source.slice(r.offset,r.offset+r.length)}async getEntry(e){return this.entries||await this.readDirectory(),this.entries.get(Tf(e))}async readChunk(e,r){let n=this.source.slice(e,e+r);return"arrayBuffer"in n?await n.arrayBuffer():new Response(n).arrayBuffer()}readCString(e,r,n){let i=[];for(let a=0;a<n;a+=1){let o=e.getUint8(r+a);if(o===0)break;i.push(o)}return String.fromCharCode(...i)}};var Jc=12,Rf=64,Gs=class t{constructor(){this.entries=new Map}addFile(e,r){let n=_e(e);if(n.length>56)throw new Error(`Path too long: '${n}' (max 56 chars)`);this.entries.set(n,r)}removeFile(e){return this.entries.delete(_e(e))}build(){let e=0;for(let u of this.entries.values())e+=u.byteLength;let r=this.entries.size*Rf,n=Jc+e+r,i=new Uint8Array(n),a=new DataView(i.buffer);a.setUint8(0,80),a.setUint8(1,65),a.setUint8(2,67),a.setUint8(3,75);let o=Jc+e;a.setInt32(4,o,!0),a.setInt32(8,r,!0);let s=Jc,c=new Map,l=Array.from(this.entries.keys()).sort();for(let u of l){let h=this.entries.get(u);c.set(u,s),i.set(h,s),s+=h.byteLength}let d=o,f=new TextEncoder;for(let u of l){let h=this.entries.get(u),m=f.encode(u);if(m.length>56)throw new Error(`Path too long after encoding: ${u}`);for(let g=0;g<56;g++)g<m.length?a.setUint8(d+g,m[g]):a.setUint8(d+g,0);a.setInt32(d+56,c.get(u),!0),a.setInt32(d+60,h.byteLength,!0),d+=Rf}return i}static buildFromEntries(e){let r=new t;for(let[n,i]of e)r.addFile(n,i);return r.build()}};var ed=(o=>(o.Texture="texture",o.Sound="sound",o.Model="model",o.Map="map",o.Sprite="sprite",o.ConfigString="configString",o))(ed||{}),Ws=class{constructor(){this.tracking=!1;this.entries=[];this.currentFrame=0;this.currentTime=0}startTracking(){this.tracking=!0,this.entries=[]}stopTracking(){this.tracking=!1;let e={byFrame:new Map,byTime:new Map,uniqueResources:new Map};for(let r of this.entries){e.byFrame.has(r.frame)||e.byFrame.set(r.frame,[]),e.byFrame.get(r.frame).push(r),e.byTime.has(r.timestamp)||e.byTime.set(r.timestamp,[]),e.byTime.get(r.timestamp).push(r);let n=`${r.type}:${r.path}`;e.uniqueResources.has(n)||e.uniqueResources.set(n,r)}return e}recordLoad(e,r,n,i){this.tracking&&this.entries.push({type:e,path:r,timestamp:this.currentTime,frame:this.currentFrame,size:n,pakSource:i})}setCurrentFrame(e){this.currentFrame=e}setCurrentTime(e){this.currentTime=e}};var Xs=class{constructor(e=[]){this.mounts=[];this.files=new Map;e.forEach(r=>this.mountPak(r))}mountPak(e,r=0){let n=this.mounts.findIndex(i=>i.pak===e);n!==-1&&this.mounts.splice(n,1),this.mounts.push({pak:e,priority:r}),this.mounts.sort((i,a)=>a.priority-i.priority);for(let i of e.listEntries()){let a=_e(i.name),o={archive:e,entry:i,priority:r};this.files.has(a)||this.files.set(a,[]);let s=this.files.get(a),c=s.findIndex(l=>l.archive===e);c!==-1&&s.splice(c,1),s.unshift(o),s.sort((l,d)=>d.priority-l.priority)}return e}setPriority(e,r){this.mountPak(e,r)}getPaks(){return[...this.mounts].sort((e,r)=>e.priority-r.priority)}get mountedPaks(){return this.mounts.map(e=>e.pak)}hasFile(e){return this.files.has(_e(e))}getSource(e){let r=this.files.get(_e(e));if(!(!r||r.length===0))return r[0]}stat(e){let r=this.getSource(e);if(r)return{path:r.entry.name,size:r.entry.length,sourcePak:r.archive.name}}getFileMetadata(e){let r=this.getSource(e);if(r)return{path:r.entry.name,size:r.entry.length,sourcePak:r.archive.name,offset:r.entry.offset}}async readFile(e){let r=this.getSource(e);if(!r)throw new Error(`File not found in VFS: ${e}`);return r.archive.readFile(e)}async readBinaryFile(e){return this.readFile(e)}streamFile(e,r=1024*1024){let n=this.getSource(e);if(!n)throw new Error(`File not found in VFS: ${e}`);let{archive:i}=n,a=i.readFile(e),o=0,s=a.length;return new ReadableStream({pull(c){if(o>=s){c.close();return}let l=Math.min(o+r,s),d=a.slice(o,l);o=l,c.enqueue(d)}})}async readTextFile(e){let r=await this.readFile(e);return new TextDecoder("utf-8").decode(r)}list(e=""){let r=_e(e).replace(/\/+$|^\//g,""),n=[],i=new Set,a=r?`${r}/`:"";for(let[o,s]of this.files){let c=s[0];if(r&&!c.entry.name.startsWith(a))continue;let l=r?c.entry.name.slice(a.length):c.entry.name,d=l.indexOf("/");d===-1?n.push({path:c.entry.name,size:c.entry.length,sourcePak:c.archive.name}):i.add(l.slice(0,d))}return n.sort((o,s)=>o.path.localeCompare(s.path)),{files:n,directories:[...i].sort()}}async listDirectory(e){return this.list(e).files}findByExtension(e){if(e instanceof RegExp)return this.searchFiles(e);if(Array.isArray(e))return this.listByExtension(e);let r=e.startsWith(".")?e.toLowerCase():`.${e.toLowerCase()}`,n=[];for(let[i,a]of this.files){let o=a[0];o.entry.name.toLowerCase().endsWith(r)&&n.push({path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name})}return n.sort((i,a)=>i.path.localeCompare(a.path))}listByExtension(e){let r=new Set(e.map(i=>i.startsWith(".")?i.toLowerCase():`.${i.toLowerCase()}`)),n=[];for(let[i,a]of this.files){let o=a[0],s=o.entry.name.toLowerCase();for(let c of r)if(s.endsWith(c)){n.push({path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name});break}}return n.sort((i,a)=>i.path.localeCompare(a.path))}searchFiles(e){let r=[];for(let[n,i]of this.files){let a=i[0];e.test(a.entry.name)&&r.push({path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name})}return r.sort((n,i)=>n.path.localeCompare(i.path))}getPakInfo(){return this.mounts.map(e=>({filename:e.pak.name,entryCount:e.pak.listEntries().length,totalSize:e.pak.size,priority:e.priority}))}getDirectoryTree(){let e={name:"",path:"",files:[],directories:[]},r=new Map;r.set("",e);let n=Array.from(this.files.values()).map(i=>{let a=i[0];return{path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name}}).sort((i,a)=>i.path.localeCompare(a.path));for(let i of n){let a=i.path.split("/"),o=a.pop(),s="",c=e;for(let l of a){let d=s;s=s?`${s}/${l}`:l;let f=r.get(s);f||(f={name:l,path:s,files:[],directories:[]},c.directories.push(f),r.set(s,f)),c=f}c.files.push(i)}return e}};var td=Object.freeze([{name:"pak0.pak",checksum:2378051181,description:"Base game assets"},{name:"pak0.pak@baseq2",checksum:2378051181,description:"Base game assets (baseq2)"},{name:"pak0.pak@rogue",checksum:3373211245,description:"Ground Zero (rogue) mission pack"},{name:"pak0.pak@xatrix",checksum:1358269824,description:"The Reckoning (xatrix) mission pack"}]),Jn=class extends Error{constructor(r){super(r.status==="unknown"?`Unknown PAK not allowed: ${r.name}`:`PAK checksum mismatch for ${r.name}`);this.result=r;this.name="PakValidationError"}},Ks=class{constructor(e=td){this.known=new Map;e.forEach(r=>this.known.set(this.normalizePakName(r.name),r))}validateArchive(e,r){let n=this.normalizePakName(r??("name"in e?e.name:"unknown")),i=e.checksum,a="size"in e?e.size:void 0,o=this.known.get(n);return o?o.checksum!==i?{name:n,checksum:i,expectedChecksum:o.checksum,status:"mismatch",size:a,description:o.description}:{name:n,checksum:i,expectedChecksum:o.checksum,status:"valid",size:a,description:o.description}:{name:n,checksum:i,status:"unknown",size:a}}assertValid(e,r){let n=this.validateArchive(e,r);if(n.status==="mismatch")throw new Jn(n);return n}normalizePakName(e){let r=_e(e),n=r.split("/"),i=n.pop()??r,a=n.pop();return a?`${i}@${a}`:i}};var pn=class extends Error{constructor(r,n){super(`Failed to ingest PAK: ${r}`);this.file=r;this.name="PakIngestionError",n instanceof Error&&n.stack&&(this.stack=n.stack),this.cause=n}};async function hg(t,e){if(typeof t.arrayBuffer=="function"){let r=await t.arrayBuffer();return e?.({file:"blob",loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}if(typeof FileReader<"u")return new Promise((r,n)=>{let i=new FileReader;i.onerror=()=>n(i.error??new Error("Unknown FileReader error")),i.onprogress=a=>{e?.({file:"blob",loadedBytes:a.loaded,totalBytes:a.total||t.size,state:"reading"})},i.onload=()=>{let a=i.result;a instanceof ArrayBuffer?r(a):n(new Error("Unexpected FileReader result"))},i.readAsArrayBuffer(t)});if(typeof Response<"u"){let r=await new Response(t).arrayBuffer();return e?.({file:"blob",loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}if(typeof t.stream=="function"){let r=t.stream().getReader(),n=[],i=0;for(;;){let{done:s,value:c}=await r.read();if(s)break;if(!c)continue;let l=c;n.push(l),i+=l.byteLength,e?.({file:"blob",loadedBytes:i,totalBytes:t.size,state:"reading"})}let a=new Uint8Array(i),o=0;for(let s of n)a.set(s,o),o+=s.byteLength;return a.buffer}throw new pn("blob",new Error("Unsupported Blob type"))}async function mg(t,e){if(t.data instanceof ArrayBuffer)return e?.({file:t.name,loadedBytes:t.data.byteLength,totalBytes:t.data.byteLength,state:"reading"}),t.data;if(t.data instanceof Blob){let n=t.data.size;return hg(t.data,i=>e?.({...i,file:t.name,totalBytes:n}))}let r=t.data.buffer.slice(t.data.byteOffset,t.data.byteOffset+t.data.byteLength);return e?.({file:t.name,loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}async function Ys(t,e,r){let n=typeof r=="function"?{onProgress:r}:r??{},i=n.persistIndexes??!!n.pakIndexStore,a=n.enforceValidation??!!n.validator,o=n.allowUnknownPaks??!0,s=n.stopOnError??!1,c=[];for(let l of e)try{let d=await mg(l,n.onProgress),f=Ui.fromArrayBuffer(l.name,d),u=n.validator?.validateArchive(f);if(u){n.onValidationResult?.(u);let h=u.status==="mismatch",m=u.status==="unknown";if(h&&a||m&&!o){let g=new Jn(u);if(n.onError?.(l.name,g),s)throw new pn(l.name,g);c.push({archive:f,mounted:!1,validation:u});continue}}if(t.mountPak(f),i&&n.pakIndexStore)try{await n.pakIndexStore.persist(f)}catch(h){if(n.onError?.(l.name,h),s)throw new pn(l.name,h)}n.onProgress?.({file:l.name,loadedBytes:d.byteLength,totalBytes:d.byteLength,state:"parsed"}),c.push({archive:f,mounted:!0,validation:u})}catch(d){if(n.onProgress?.({file:l.name,loadedBytes:0,totalBytes:0,state:"error"}),n.onError?.(l.name,d),s)throw new pn(l.name,d)}return c}var gn=class{constructor(e,r=1/0,n=()=>0){this._capacity=e;this._maxMemory=r;this.sizeCalculator=n;this.map=new Map;this.currentMemoryUsage=0;if(e<=0)throw new RangeError("LRU cache capacity must be greater than zero")}get size(){return this.map.size}get memoryUsage(){return this.currentMemoryUsage}get capacity(){return this._capacity}set capacity(e){if(e<=0)throw new RangeError("LRU cache capacity must be greater than zero");this._capacity=e,this.evict()}get maxMemory(){return this._maxMemory}set maxMemory(e){this._maxMemory=e,this.evict()}has(e){return this.map.has(e)}get(e){let r=this.map.get(e);if(r!==void 0)return this.map.delete(e),this.map.set(e,r),r}set(e,r){let n=this.sizeCalculator(r);this.map.has(e)&&this.delete(e),this.map.set(e,r),this.currentMemoryUsage+=n,this.evict()}delete(e){let r=this.map.get(e);return r!==void 0?(this.currentMemoryUsage-=this.sizeCalculator(r),this.map.delete(e)):!1}clear(){this.map.clear(),this.currentMemoryUsage=0}entries(){return Array.from(this.map.entries()).reverse().map(([e,r])=>({key:e,value:r}))}evict(){for(;this.map.size>this._capacity;){let e=this.map.keys().next();if(!e.done)this.delete(e.value);else break}for(;this.currentMemoryUsage>this._maxMemory&&this.map.size>0;){let e=this.map.keys().next();if(!e.done)this.delete(e.value);else break}}};function pg(t){return Array.isArray(t)?t:Array.from(t)}function rd(t){return pg(t).map(e=>({name:e.name,data:e}))}async function Cf(t,e,r){let n=rd(e);return Ys(t,n,r??{})}function Pf(t,e){let r=i=>{i.preventDefault(),i.dataTransfer?.dropEffect&&(i.dataTransfer.dropEffect="copy")},n=i=>{i.preventDefault();let a=i.dataTransfer?.files;a&&a.length>0&&e(Array.from(a))};return t.addEventListener("dragover",r),t.addEventListener("drop",n),()=>{t.removeEventListener("dragover",r),t.removeEventListener("drop",n)}}function If(t,e){let r=n=>{let i=n.target;!i||!i.files||i.files.length===0||(e(i.files),i.value="")};return t.addEventListener("change",r),()=>t.removeEventListener("change",r)}var gg="IBSP",yg=38,Ff=19,bg=8+Ff*8;var se=class extends Error{},Ni=class{constructor(e,r={}){this.vfs=e;this.options=r}async load(e){let r=await this.vfs.readFile(e),n=new Uint8Array(r.byteLength);if(n.set(new Uint8Array(r)),this.options.useWorker&&typeof Worker<"u")try{let i=await this.parseInWorker(n.buffer);return kf(i)}catch(i){console.warn("BSP worker parsing failed, falling back to main thread",i)}return ja(n.buffer)}parseInWorker(e){return new Promise((r,n)=>{if(!this.options.workerPath){n(new Error("No worker path provided"));return}let i=new Worker(this.options.workerPath,{type:"module"});i.onmessage=a=>{let{type:o,data:s,message:c}=a.data;o==="success"?(r(this.rehydrateData(s)),i.terminate()):(n(new Error(c)),i.terminate())},i.onerror=a=>{n(a),i.terminate()},i.postMessage(e,[e])})}rehydrateData(e){if(e.entities&&!e.entities.getUniqueClassnames){let r=e.entities;r.getUniqueClassnames=function(){let n=new Set;for(let i of this.entities)i.classname&&n.add(i.classname);return Array.from(n).sort()}}return e}};function ja(t){let e=xg(t);return kf(e)}function kf(t){return{...t,pickEntity(e){let r=null,n=1/0;for(let i of t.entities.entities){let a=i.properties.model;if(!a||!a.startsWith("*"))continue;let o=parseInt(a.substring(1),10);if(isNaN(o)||o<0||o>=t.models.length)continue;let s=t.models[o],c=vg(e.origin,e.direction,s.mins,s.maxs);c!==null&&c<n&&(n=c,r={entity:i,model:s,distance:c})}return r},findLeaf(e){let n=t.models[0].headNode;for(;n>=0;){let i=t.nodes[n],a=t.planes[i.planeIndex];a.normal[0]*e[0]+a.normal[1]*e[1]+a.normal[2]*e[2]-a.dist>=0?n=i.children[0]:n=i.children[1]}return t.leafs[-(n+1)]},calculatePVS(e){let r=this.findLeaf(e);if(!(r.cluster===-1||!t.visibility)&&!(r.cluster<0||r.cluster>=t.visibility.clusters.length))return t.visibility.clusters[r.cluster].pvs}}}function xg(t){if(t.byteLength<bg)throw new se("BSP too small to contain header");let e=new DataView(t),r=String.fromCharCode(e.getUint8(0),e.getUint8(1),e.getUint8(2),e.getUint8(3));if(r!==gg)throw new se(`Invalid BSP magic ${r}`);let n=e.getInt32(4,!0);if(n!==yg)throw new se(`Unsupported BSP version ${n}`);let i=new Map;for(let E=0;E<Ff;E+=1){let L=e.getInt32(8+E*8,!0),M=e.getInt32(12+E*8,!0);if(L<0||M<0||L+M>t.byteLength)throw new se(`Invalid lump bounds for index ${E}`);i.set(E,{offset:L,length:M})}let a={version:n,lumps:i},o=_g(t,i.get(0)),s=wg(t,i.get(1)),c=Mg(t,i.get(2)),l=Ag(t,i.get(4)),d=Eg(t,i.get(5)),f=Lg(t,i.get(6)),u=new Uint8Array(t,i.get(7).offset,i.get(7).length),h=Ug(f,i.get(7)),m=Tg(t,i.get(8)),g=Rg(t,i.get(11)),p=Cg(t,i.get(12)),y=Pg(t,i.get(13)),v=Ig(t,i.get(14)),x=Bg(t,i.get(15)),b=zg(t,i.get(9),i.get(10),m),_=Og(t,i.get(3)),w=Fg(t,i.get(17)),S=kg(t,i.get(18));return{header:a,entities:o,planes:s,vertices:c,nodes:l,texInfo:d,faces:f,lightMaps:u,lightMapInfo:h,leafs:m,leafLists:b,edges:g,surfEdges:p,models:y,brushes:v,brushSides:x,visibility:_,areas:w,areaPortals:S}}function vg(t,e,r,n){let i=0,a=1/0;for(let o=0;o<3;o++)if(Math.abs(e[o])<1e-8){if(t[o]<r[o]||t[o]>n[o])return null}else{let s=1/e[o],c=(r[o]-t[o])*s,l=(n[o]-t[o])*s;if(c>l){let d=c;c=l,l=d}if(i=Math.max(i,c),a=Math.min(a,l),i>a)return null}return i}function _g(t,e){let r=new TextDecoder().decode(new Uint8Array(t,e.offset,e.length)),n=Sg(r),i=n.find(a=>a.classname==="worldspawn");return{raw:r,entities:n,worldspawn:i,getUniqueClassnames(){let a=new Set;for(let o of n)o.classname&&a.add(o.classname);return Array.from(a).sort()}}}function Sg(t){let e=[],r=/\{([^}]*)\}/gms,n;for(;(n=r.exec(t))!==null;){let i=n[1],a={},o=/"([^\"]*)"\s+"([^\"]*)"/g,s;for(;(s=o.exec(i))!==null;)a[s[1]]=s[2];e.push({classname:a.classname,properties:a})}return e}function wg(t,e){let r=new DataView(t,e.offset,e.length),n=e.length/20;if(n%1!==0)throw new se("Plane lump has invalid length");let i=[];for(let a=0;a<n;a+=1){let o=[r.getFloat32(a*20,!0),r.getFloat32(a*20+4,!0),r.getFloat32(a*20+8,!0)],s=r.getFloat32(a*20+12,!0),c=r.getInt32(a*20+16,!0);i.push({normal:o,dist:s,type:c})}return i}function Mg(t,e){let r=new DataView(t,e.offset,e.length),n=e.length/12;if(n%1!==0)throw new se("Vertex lump has invalid length");let i=[];for(let a=0;a<n;a+=1)i.push([r.getFloat32(a*12,!0),r.getFloat32(a*12+4,!0),r.getFloat32(a*12+8,!0)]);return i}function Ag(t,e){let r=new DataView(t,e.offset,e.length),n=28,i=e.length/n;if(i%1!==0)throw new se("Node lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=[r.getInt32(s+4,!0),r.getInt32(s+8,!0)],d=[r.getInt16(s+12,!0),r.getInt16(s+14,!0),r.getInt16(s+16,!0)],f=[r.getInt16(s+18,!0),r.getInt16(s+20,!0),r.getInt16(s+22,!0)],u=r.getUint16(s+24,!0),h=r.getUint16(s+26,!0);a.push({planeIndex:c,children:l,mins:d,maxs:f,firstFace:u,numFaces:h})}return a}function Eg(t,e){let r=new DataView(t,e.offset,e.length),n=76,i=e.length/n;if(i%1!==0)throw new se("TexInfo lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=[r.getFloat32(s,!0),r.getFloat32(s+4,!0),r.getFloat32(s+8,!0)],l=r.getFloat32(s+12,!0),d=[r.getFloat32(s+16,!0),r.getFloat32(s+20,!0),r.getFloat32(s+24,!0)],f=r.getFloat32(s+28,!0),u=r.getInt32(s+32,!0),h=r.getInt32(s+36,!0),m=new Uint8Array(t,e.offset+s+40,32),g=new TextDecoder("utf-8").decode(m).replace(/\0.*$/,""),p=r.getInt32(s+72,!0);a.push({s:c,sOffset:l,t:d,tOffset:f,flags:u,value:h,texture:g,nextTexInfo:p})}return a}function Lg(t,e){let r=new DataView(t,e.offset,e.length),n=20,i=e.length/n;if(i%1!==0)throw new se("Face lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getUint16(s,!0),l=r.getInt16(s+2,!0),d=r.getInt32(s+4,!0),f=r.getInt16(s+8,!0),u=r.getInt16(s+10,!0),h=[r.getUint8(s+12),r.getUint8(s+13),r.getUint8(s+14),r.getUint8(s+15)],m=r.getInt32(s+16,!0);a.push({planeIndex:c,side:l,firstEdge:d,numEdges:f,texInfo:u,styles:h,lightOffset:m})}return a}function Tg(t,e){let r=new DataView(t,e.offset,e.length),n=28,i=e.length/n;if(i%1!==0)throw new se("Leaf lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=r.getInt16(s+4,!0),d=r.getInt16(s+6,!0),f=[r.getInt16(s+8,!0),r.getInt16(s+10,!0),r.getInt16(s+12,!0)],u=[r.getInt16(s+14,!0),r.getInt16(s+16,!0),r.getInt16(s+18,!0)],h=r.getUint16(s+20,!0),m=r.getUint16(s+22,!0),g=r.getUint16(s+24,!0),p=r.getUint16(s+26,!0);a.push({contents:c,cluster:l,area:d,mins:f,maxs:u,firstLeafFace:h,numLeafFaces:m,firstLeafBrush:g,numLeafBrushes:p})}return a}function Rg(t,e){let r=new DataView(t,e.offset,e.length),n=4,i=e.length/n;if(i%1!==0)throw new se("Edge lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n;a.push({vertices:[r.getUint16(s,!0),r.getUint16(s+2,!0)]})}return a}function Cg(t,e){let r=e.length/4;if(r%1!==0)throw new se("SurfEdge lump has invalid length");let n=new DataView(t,e.offset,e.length),i=new Int32Array(r);for(let a=0;a<r;a+=1)i[a]=n.getInt32(a*4,!0);return i}function Pg(t,e){let r=new DataView(t,e.offset,e.length),n=48;if(e.length%n!==0)throw new se("Model lump has invalid length");let i=e.length/n,a=[];for(let o=0;o<i;o+=1){let s=o*n,c=[r.getFloat32(s,!0),r.getFloat32(s+4,!0),r.getFloat32(s+8,!0)],l=[r.getFloat32(s+12,!0),r.getFloat32(s+16,!0),r.getFloat32(s+20,!0)],d=[r.getFloat32(s+24,!0),r.getFloat32(s+28,!0),r.getFloat32(s+32,!0)],f=r.getInt32(s+36,!0),u=r.getInt32(s+40,!0),h=r.getInt32(s+44,!0);a.push({mins:c,maxs:l,origin:d,headNode:f,firstFace:u,numFaces:h})}return a}function Ig(t,e){let r=new DataView(t,e.offset,e.length),n=12,i=e.length/n;if(i%1!==0)throw new se("Brush lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n;a.push({firstSide:r.getInt32(s,!0),numSides:r.getInt32(s+4,!0),contents:r.getInt32(s+8,!0)})}return a}function Bg(t,e){let r=new DataView(t,e.offset,e.length),n=4,i=e.length/n;if(i%1!==0)throw new se("Brush side lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n;a.push({planeIndex:r.getUint16(s,!0),texInfo:r.getInt16(s+2,!0)})}return a}function Fg(t,e){let r=new DataView(t,e.offset,e.length),n=8,i=e.length/n;if(i%1!==0)throw new se("Area lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);a.push({numAreaPortals:c,firstAreaPortal:l})}return a}function kg(t,e){return Dg(t,e)}function Dg(t,e){let r=new DataView(t,e.offset,e.length),n=8,i=e.length/n;if(i%1!==0)throw new se("AreaPortal lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);a.push({portalNumber:c,otherArea:l})}return a}function zg(t,e,r,n){let i=[],a=[],o=e.length/2,s=r.length/2,c=new DataView(t,e.offset,e.length),l=new DataView(t,r.offset,r.length);for(let d of n){if(d.firstLeafFace+d.numLeafFaces>o)throw new se("Leaf faces reference data past lump bounds");if(d.firstLeafBrush+d.numLeafBrushes>s)throw new se("Leaf brushes reference data past lump bounds");let f=[];for(let h=0;h<d.numLeafFaces;h+=1)f.push(c.getUint16((d.firstLeafFace+h)*2,!0));let u=[];for(let h=0;h<d.numLeafBrushes;h+=1)u.push(l.getUint16((d.firstLeafBrush+h)*2,!0));i.push(f),a.push(u)}return{leafFaces:i,leafBrushes:a}}function Og(t,e){if(e.length===0)return;if(e.length<4)throw new se("Visibility lump too small");let r=new DataView(t,e.offset,e.length),n=r.getInt32(0,!0),i=4+n*8;if(n<0||i>e.length)throw new se("Visibility lump truncated");let a=4,o=[];for(let s=0;s<n;s+=1){let c=r.getInt32(a,!0),l=r.getInt32(a+4,!0);a+=8;let d=e.offset+c,f=e.offset+l,u=e.offset+e.length;if(c<0||l<0||d>=u||f>=u)throw new se("Visibility offsets out of range");o.push({pvs:Bf(t,d,n,e),phs:Bf(t,f,n,e)})}return{numClusters:n,clusters:o}}function Bf(t,e,r,n){let i=Math.ceil(r/8),a=new Uint8Array(i),o=new Uint8Array(t),s=e,c=0,l=n.offset+n.length;for(;c<i;){if(s>=l)throw new se("Visibility data truncated");let d=o[s++];if(d!==0){a[c++]=d;continue}if(s>=l)throw new se("Visibility run exceeds lump bounds");let f=o[s++];for(let u=0;u<f&&c<i;u+=1)a[c++]=0}return a}function Ug(t,e){return t.map(r=>{if(!(r.lightOffset<0))return{offset:r.lightOffset,length:Math.max(0,e.length-r.lightOffset)}})}function $s(t,e,r){if(t.lightOffset<0||t.lightOffset>=e.byteLength)return;let n=e.byteLength-t.lightOffset,i=Math.min(r?.length??n,n);if(!(i<=0))return e.subarray(t.lightOffset,t.lightOffset+i)}var Ng=844121161,Hg=8,Df=68,qe=class extends Error{},Hi=class{constructor(e){this.vfs=e;this.cache=new Map}async load(e){if(this.cache.has(e))return this.cache.get(e);let r=await this.vfs.readFile(e),n=new Uint8Array(r.byteLength);n.set(r);let i=nd(n.buffer);return this.cache.set(e,i),i}get(e){return this.cache.get(e)}};function zf(t,e,r){let n=[];for(let i=0;i<r;i+=1){let a=t.getUint8(e+i);if(a===0)break;n.push(a)}return String.fromCharCode(...n)}function Qa(t,e,r,n){if(r!==0&&(e<Df||e+r>t.byteLength))throw new qe(`${n} section is out of bounds`)}function Vg(t){if(t.byteLength<Df)throw new qe("MD2 buffer too small to contain header");let e=new DataView(t),r=e.getInt32(0,!0),n=e.getInt32(4,!0);if(r!==Ng)throw new qe(`Invalid MD2 ident: ${r}`);if(n!==Hg)throw new qe(`Unsupported MD2 version: ${n}`);let i={ident:r,version:n,skinWidth:e.getInt32(8,!0),skinHeight:e.getInt32(12,!0),frameSize:e.getInt32(16,!0),numSkins:e.getInt32(20,!0),numVertices:e.getInt32(24,!0),numTexCoords:e.getInt32(28,!0),numTriangles:e.getInt32(32,!0),numGlCommands:e.getInt32(36,!0),numFrames:e.getInt32(40,!0),offsetSkins:e.getInt32(44,!0),offsetTexCoords:e.getInt32(48,!0),offsetTriangles:e.getInt32(52,!0),offsetFrames:e.getInt32(56,!0),offsetGlCommands:e.getInt32(60,!0),offsetEnd:e.getInt32(64,!0),magic:r},a=40+i.numVertices*4;if(i.frameSize!==a)throw new qe(`Unexpected frame size ${i.frameSize}, expected ${a}`);if(i.offsetEnd>t.byteLength)throw new qe("MD2 offset_end exceeds buffer length");return i}function Gg(t,e){let r=e.numSkins*64;Qa(t,e.offsetSkins,r,"skins");let n=new DataView(t,e.offsetSkins,r),i=[];for(let a=0;a<e.numSkins;a+=1)i.push({name:zf(n,a*64,64)});return i}function Wg(t,e){let r=e.numTexCoords*4;Qa(t,e.offsetTexCoords,r,"texcoords");let n=new DataView(t,e.offsetTexCoords,r),i=[];for(let a=0;a<e.numTexCoords;a+=1){let o=a*4;i.push({s:n.getInt16(o,!0),t:n.getInt16(o+2,!0)})}return i}function Xg(t,e){let r=e.numTriangles*12;Qa(t,e.offsetTriangles,r,"triangles");let n=new DataView(t,e.offsetTriangles,r),i=[];for(let a=0;a<e.numTriangles;a+=1){let o=a*12,s=[n.getUint16(o,!0),n.getUint16(o+2,!0),n.getUint16(o+4,!0)],c=[n.getUint16(o+6,!0),n.getUint16(o+8,!0),n.getUint16(o+10,!0)];if(s.some(l=>l>=e.numVertices)||c.some(l=>l>=e.numTexCoords))throw new qe("Triangle references out of range vertex or texcoord");i.push({vertexIndices:s,texCoordIndices:c})}return i}function Kg(t,e){let r=e.numFrames*e.frameSize;Qa(t,e.offsetFrames,r,"frames");let n=[];for(let i=0;i<e.numFrames;i+=1){let a=e.offsetFrames+i*e.frameSize,o=new DataView(t,a,e.frameSize),s={x:o.getFloat32(0,!0),y:o.getFloat32(4,!0),z:o.getFloat32(8,!0)},c={x:o.getFloat32(12,!0),y:o.getFloat32(16,!0),z:o.getFloat32(20,!0)},l=zf(o,24,16),d=[],f=1/0,u=1/0,h=1/0,m=-1/0,g=-1/0,p=-1/0;for(let y=0;y<e.numVertices;y+=1){let v=40+y*4,x=o.getUint8(v)*s.x+c.x,b=o.getUint8(v+1)*s.y+c.y,_=o.getUint8(v+2)*s.z+c.z;x<f&&(f=x),b<u&&(u=b),_<h&&(h=_),x>m&&(m=x),b>g&&(g=b),_>p&&(p=_);let w={x,y:b,z:_},S=o.getUint8(v+3),E=or[S];if(!E)throw new qe(`Invalid normal index ${S} in frame ${l}`);let L={x:E[0],y:E[1],z:E[2]};d.push({position:w,normalIndex:S,normal:L})}n.push({name:l,vertices:d,minBounds:{x:f,y:u,z:h},maxBounds:{x:m,y:g,z:p}})}return n}function Yg(t,e){let r=e.numGlCommands*4;if(Qa(t,e.offsetGlCommands,r,"gl commands"),r===0)return[];let n=new DataView(t,e.offsetGlCommands,r),i=[],a=0;for(;;){if(a+4>r)throw new qe("GL command list ended unexpectedly");let o=n.getInt32(a,!0);if(a+=4,o===0)break;let s=Math.abs(o),c=[],l=s*12;if(a+l>r)throw new qe("GL command vertex block exceeds buffer");for(let d=0;d<s;d+=1){let f=n.getFloat32(a,!0),u=n.getFloat32(a+4,!0),h=n.getInt32(a+8,!0);if(a+=12,h<0||h>=e.numVertices)throw new qe("GL command references invalid vertex index");c.push({s:f,t:u,vertexIndex:h})}i.push({mode:o>0?"strip":"fan",vertices:c})}if(a!==r)throw new qe("GL command list did not consume expected data");return i}function nd(t){let e=Vg(t),r=Gg(t,e),n=Wg(t,e),i=Xg(t,e),a=Kg(t,e),o=Yg(t,e);return{header:e,skins:r,texCoords:n,triangles:i,frames:a,glCommands:o}}function Of(t){let e=[],r=0;for(;r<t.length;){let n=t[r].name,i=n.replace(/\d+$/,"")||n,a=r;for(;a+1<t.length&&(t[a+1].name.replace(/\d+$/,"")||t[a+1].name)===i;)a+=1;e.push({name:i,firstFrame:r,lastFrame:a}),r=a+1}return e}var Uf=860898377,$g=15,Yt=class extends Error{constructor(e){super(e),this.name="Md3ParseError"}};function Ja(t,e,r){let n=new Uint8Array(t.buffer,t.byteOffset+e,r);return new TextDecoder("utf-8").decode(n).replace(/\0.*$/,"").trim()}function qg(t){let e=(t>>8&255)*(2*Math.PI/255),r=(t&255)*(2*Math.PI/255),n=Math.sin(r);return{x:Math.cos(e)*n,y:Math.sin(e)*n,z:Math.cos(r)}}function qs(t,e,r,n){if(e<0||e+r>n)throw new Yt(`${t} exceeds buffer bounds`)}function Zg(t){let e=t.getInt32(0,!0);if(e!==Uf)throw new Yt(`Invalid MD3 ident: ${e}`);let r=t.getInt32(4,!0);if(r!==$g)throw new Yt(`Unsupported MD3 version: ${r}`);let n=Ja(t,8,64),i=t.getInt32(72,!0),a=t.getInt32(76,!0),o=t.getInt32(80,!0),s=t.getInt32(84,!0),c=t.getInt32(88,!0),l=t.getInt32(92,!0),d=t.getInt32(96,!0),f=t.getInt32(100,!0),u=t.getInt32(104,!0);if(a<=0||s<0||o<0)throw new Yt("Invalid MD3 counts");return{ident:e,version:r,name:n,flags:i,numFrames:a,numTags:o,numSurfaces:s,numSkins:c,ofsFrames:l,ofsTags:d,ofsSurfaces:f,ofsEnd:u,magic:e}}function jg(t,e){let r=[];qs("Frames",e.ofsFrames,e.numFrames*56,t.byteLength);for(let i=0;i<e.numFrames;i+=1){let a=e.ofsFrames+i*56;r.push({minBounds:{x:t.getFloat32(a,!0),y:t.getFloat32(a+4,!0),z:t.getFloat32(a+8,!0)},maxBounds:{x:t.getFloat32(a+12,!0),y:t.getFloat32(a+16,!0),z:t.getFloat32(a+20,!0)},localOrigin:{x:t.getFloat32(a+24,!0),y:t.getFloat32(a+28,!0),z:t.getFloat32(a+32,!0)},radius:t.getFloat32(a+36,!0),name:Ja(t,a+40,16)})}return r}function Qg(t,e){let r=[],i=e.numFrames*e.numTags*112;qs("Tags",e.ofsTags,i,t.byteLength);for(let a=0;a<e.numFrames;a+=1){let o=[];for(let s=0;s<e.numTags;s+=1){let c=e.ofsTags+(a*e.numTags+s)*112,l=c+64,d=l+12;o.push({name:Ja(t,c,64),origin:{x:t.getFloat32(l,!0),y:t.getFloat32(l+4,!0),z:t.getFloat32(l+8,!0)},axis:[{x:t.getFloat32(d,!0),y:t.getFloat32(d+4,!0),z:t.getFloat32(d+8,!0)},{x:t.getFloat32(d+12,!0),y:t.getFloat32(d+16,!0),z:t.getFloat32(d+20,!0)},{x:t.getFloat32(d+24,!0),y:t.getFloat32(d+28,!0),z:t.getFloat32(d+32,!0)}]})}r.push(o)}return r}function Jg(t,e){let r=t.getInt32(e,!0);if(r!==Uf)throw new Yt(`Invalid surface ident at ${e}: ${r}`);let n=Ja(t,e+4,64),i=t.getInt32(e+68,!0),a=t.getInt32(e+72,!0),o=t.getInt32(e+76,!0),s=t.getInt32(e+80,!0),c=t.getInt32(e+84,!0),l=t.getInt32(e+88,!0),d=t.getInt32(e+92,!0),f=t.getInt32(e+96,!0),u=t.getInt32(e+100,!0),h=t.getInt32(e+104,!0);if(a<=0||s<=0||c<=0)throw new Yt(`Invalid surface counts for ${n}`);let m=h;qs(`Surface ${n}`,e,m,t.byteLength);let g=[],p=e+l;for(let S=0;S<c;S+=1){let E=p+S*12;g.push({indices:[t.getInt32(E,!0),t.getInt32(E+4,!0),t.getInt32(E+8,!0)]})}let y=[],v=e+d;for(let S=0;S<o;S+=1){let E=v+S*68;y.push({name:Ja(t,E,64),shaderIndex:t.getInt32(E+64,!0)})}let x=[],b=e+f;for(let S=0;S<s;S+=1){let E=b+S*8;x.push({s:t.getFloat32(E,!0),t:t.getFloat32(E+4,!0)})}let _=[],w=e+u;for(let S=0;S<a;S+=1){let E=[];for(let L=0;L<s;L+=1){let M=w+(S*s+L)*8,R=t.getInt16(M,!0)/64,I=t.getInt16(M+2,!0)/64,B=t.getInt16(M+4,!0)/64,F=t.getUint16(M+6,!0);E.push({position:{x:R,y:I,z:B},latLng:F,normal:qg(F)})}_.push(E)}return{surface:{name:n,flags:i,numFrames:a,shaders:y,triangles:g,texCoords:x,vertices:_},nextOffset:e+h}}function id(t){if(t.byteLength<108)throw new Yt("MD3 buffer too small for header");let e=new DataView(t),r=Zg(e);qs("MD3 end",r.ofsEnd,0,t.byteLength);let n=jg(e,r),i=Qg(e,r),a=[],o=r.ofsSurfaces;for(let s=0;s<r.numSurfaces;s+=1){let{surface:c,nextOffset:l}=Jg(e,o);a.push(c),o=l}if(o!==r.ofsEnd)throw new Yt("Surface parsing did not reach ofsEnd");return{header:r,frames:n,tags:i,surfaces:a}}var Vi=class{constructor(e){this.vfs=e;this.cache=new Map}async load(e){if(this.cache.has(e))return this.cache.get(e);let r=await this.vfs.readFile(e),n=id(r.slice().buffer);return this.cache.set(e,n),n}get(e){return this.cache.get(e)}};var e1=844317769,t1=2,Nf=64,Hf=12,yn=class extends Error{};function r1(t,e,r){let n=[];for(let i=0;i<r;i+=1){let a=t.getUint8(e+i);if(a===0)break;n.push(a)}return String.fromCharCode(...n)}function ad(t){if(t.byteLength<Hf)throw new yn("Sprite buffer too small to contain header");let e=new DataView(t),r=e.getInt32(0,!0),n=e.getInt32(4,!0),i=e.getInt32(8,!0);if(r!==e1)throw new yn(`Invalid Sprite ident: ${r}`);if(n!==t1)throw new yn(`Unsupported Sprite version: ${n}`);let a=[],o=16+Nf,s=Hf;for(let c=0;c<i;c+=1){if(s+o>t.byteLength)throw new yn("Sprite frame data exceeds buffer length");let l=e.getInt32(s,!0),d=e.getInt32(s+4,!0),f=e.getInt32(s+8,!0),u=e.getInt32(s+12,!0),h=r1(e,s+16,Nf);a.push({width:l,height:d,originX:f,originY:u,name:h}),s+=o}return{ident:r,version:n,numFrames:i,frames:a}}var Gi=class{constructor(e){this.vfs=e}async load(e){let r=await this.vfs.readFile(e),n=new Uint8Array(r.byteLength);return n.set(r),ad(n.buffer)}};function Vf(t,e){let r=(t.sequence.end-t.sequence.start+1)/t.sequence.fps,n=t.sequence.loop!==!1,i=t.time+e;return n?i=(i%r+r)%r:i>r&&(i=r),{...t,time:Math.max(0,Math.min(i,r))}}function Gf(t){let e=t.sequence.end-t.sequence.start+1,r=1/t.sequence.fps,n=t.sequence.loop!==!1,i=t.time/r;if(!n&&i>=e)return{frame0:t.sequence.end,frame1:t.sequence.end,lerp:0};let a=n?i%e:Math.min(i,e-1),o=Math.floor(a),s=t.sequence.start+o,c=o+1>=e?n?t.sequence.start:t.sequence.end:s+1,l=!n&&o>=e-1?0:a-o;return{frame0:s,frame1:c,lerp:l}}function Wf(t){return{sequence:t,time:0}}function Xf(t,e,r){return{x:t.x+(e.x-t.x)*r,y:t.y+(e.y-t.y)*r,z:t.z+(e.z-t.z)*r}}var eo=class extends Error{constructor(e){super(e),this.name="WalParseError"}};function Zs(t){if(t.byteLength<100)throw new eo("WAL buffer too small");let e=new DataView(t),r=new Uint8Array(t,0,32),n=new TextDecoder("utf-8").decode(r).replace(/\0.*$/,"").trim(),i=e.getInt32(32,!0),a=e.getInt32(36,!0),o=[e.getInt32(40,!0),e.getInt32(44,!0),e.getInt32(48,!0),e.getInt32(52,!0)],s=new Uint8Array(t,56,32),c=new TextDecoder("utf-8").decode(s).replace(/\0.*$/,"").trim(),l=e.getInt32(88,!0),d=e.getInt32(92,!0),f=e.getInt32(96,!0);if(i<=0||a<=0)throw new eo("Invalid WAL dimensions");let u=[],h=i,m=a;for(let g=0;g<o.length;g+=1){let p=o[g],y=Math.max(1,h*m|0);if(p<=0||p+y>t.byteLength)throw new eo(`Invalid WAL mip offset for level ${g}`);let v=new Uint8Array(t,p,y);u.push({level:g,width:h,height:m,data:v}),h=Math.max(1,h>>1),m=Math.max(1,m>>1)}return{name:n,width:i,height:a,mipmaps:u,animName:c,flags:l,contents:d,value:f}}var ei=class extends Error{constructor(e){super(e),this.name="PcxParseError"}};function to(t){if(t.byteLength<128)throw new ei("PCX buffer too small for header");let e=new DataView(t),r=e.getUint8(0),n=e.getUint8(2),i=e.getUint8(3),a=e.getUint16(4,!0),o=e.getUint16(6,!0),s=e.getUint16(8,!0),c=e.getUint16(10,!0);if(r!==10||n!==1)throw new ei("Unsupported PCX encoding");if(i!==8)throw new ei("Only 8bpp PCX files are supported");let l=s-a+1,d=c-o+1,f=e.getUint16(66,!0),u=t.byteLength-769;if(u<128||new DataView(t,u,1).getUint8(0)!==12)throw new ei("Missing PCX palette");let h=new Uint8Array(t,u+1,768),m=new Uint8Array(t,128,u-128),g=new Uint8Array(l*d),p=0,y=0;for(let v=0;v<d;v+=1){let x=0;for(;x<f&&p<m.length;){let b=1,_=m[p++];if((_&192)===192){if(b=_&63,p>=m.length)throw new ei("Unexpected end of PCX RLE data");_=m[p++]}for(let w=0;w<b&&x<f;w+=1)x<l&&(g[y++]=_),x+=1}}return{width:l,height:d,bitsPerPixel:i,pixels:g,palette:h}}function js(t){let e=new Uint8Array(t.width*t.height*4);for(let r=0;r<t.pixels.length;r+=1){let n=t.pixels[r],i=n*3,a=r*4;e[a]=t.palette[i],e[a+1]=t.palette[i+1],e[a+2]=t.palette[i+2],e[a+3]=n===255?0:255}return e}var Vr=class extends Error{constructor(e){super(e),this.name="TgaParseError"}};function od(t){let e=new DataView(t);if(t.byteLength<18)throw new Vr("Buffer too small for TGA header");let r=e.getUint8(0),n=e.getUint8(1),i=e.getUint8(2),a=e.getUint16(12,!0),o=e.getUint16(14,!0),s=e.getUint8(16),c=e.getUint8(17);if(i!==2&&i!==10&&i!==3&&i!==11)throw new Vr(`Unsupported TGA image type: ${i} (only RGB/Grayscale supported)`);if(s!==24&&s!==32&&s!==8)throw new Vr(`Unsupported pixel depth: ${s} (only 8, 24, 32 bpp supported)`);let l=i>=9,d=i===3||i===11,f=s/8,u=18+r;if(n===1){let x=e.getUint16(5,!0),b=e.getUint8(7);u+=x*(b/8)}let h=a*o,m=new Uint8Array(h*4),g=(c&32)!==0,p=0,y=new Uint8Array(t),v=x=>{if(d){let b=y[u++];m[x]=b,m[x+1]=b,m[x+2]=b,m[x+3]=255}else{let b=y[u++],_=y[u++],w=y[u++],S=s===32?y[u++]:255;m[x]=w,m[x+1]=_,m[x+2]=b,m[x+3]=S}};if(l){let x=0;for(;x<h;){if(u>=t.byteLength)throw new Vr("Unexpected end of TGA RLE data");let b=y[u++],_=(b&127)+1,w=(b&128)!==0;if(x+_>h)throw new Vr("TGA RLE packet exceeds image bounds");if(w){let S=d?y[u]:y[u+2],E=d?y[u]:y[u+1],L=y[u],M=d?255:s===32?y[u+3]:255;u+=f;for(let R=0;R<_;R++){let I=(x+R)*4;m[I]=S,m[I+1]=E,m[I+2]=L,m[I+3]=M}}else for(let S=0;S<_;S++)v((x+S)*4);x+=_}}else for(let x=0;x<h;x++){if(u>=t.byteLength)throw new Vr("Unexpected end of TGA data");v(x*4)}if(!g){let x=a*4,b=new Uint8Array(x);for(let _=0;_<o/2;_++){let w=_*x,S=(o-1-_)*x;b.set(m.subarray(w,w+x)),m.set(m.subarray(S,S+x),w),m.set(b,S)}}return{width:a,height:o,bitsPerPixel:32,pixels:m}}function n1(t){let e=0;for(let r of t.levels)e+=r.rgba.byteLength;return e}var Wi=class{constructor(e={}){this.cache=new gn(e.capacity??128,e.maxMemory??256*1024*1024,n1)}get size(){return this.cache.size}get memoryUsage(){return this.cache.memoryUsage}get(e){return this.cache.get(e.toLowerCase())}set(e,r){this.cache.set(e.toLowerCase(),r)}clear(){this.cache.clear()}get capacity(){return this.cache.capacity}set capacity(e){this.cache.capacity=e}get maxMemory(){return this.cache.maxMemory}set maxMemory(e){this.cache.maxMemory=e}};function sd(t,e){let r=[];for(let n of t.mipmaps){let i=new Uint8Array(n.width*n.height*4);for(let a=0;a<n.data.length;a+=1){let o=n.data[a],s=o*3,c=a*4;i[c]=e[s],i[c+1]=e[s+1],i[c+2]=e[s+2],i[c+3]=o===255?0:255}r.push({level:n.level,width:n.width,height:n.height,rgba:i})}return{width:t.width,height:t.height,levels:r,source:"wal"}}function Qs(t){let e=js(t),r={level:0,width:t.width,height:t.height,rgba:e};return{width:t.width,height:t.height,levels:[r],source:"pcx"}}function Kf(t){let e={level:0,width:t.width,height:t.height,rgba:t.pixels};return{width:t.width,height:t.height,levels:[e],source:"tga"}}function Js(t,e){return sd(Zs(t),e)}var ti=class extends Error{constructor(e){super(e),this.name="WavParseError"}};function ld(t,e,r){return new TextDecoder("ascii").decode(new Uint8Array(t.buffer,t.byteOffset+e,r))}function el(t){if(t.byteLength<44)throw new ti("WAV buffer too small");let e=new DataView(t);if(ld(e,0,4)!=="RIFF"||ld(e,8,4)!=="WAVE")throw new ti("Invalid WAV header");let r=12,n=-1,i=-1,a=0,o=0;for(;r+8<=t.byteLength;){let m=ld(e,r,4),g=e.getUint32(r+4,!0),p=r+8;m==="fmt "?(n=p,a=g):m==="data"&&(i=p,o=g),r=p+g}if(n===-1||i===-1)throw new ti("Missing fmt or data chunk");let s=e.getUint16(n,!0),c=e.getUint16(n+2,!0),l=e.getUint32(n+4,!0),d=e.getUint16(n+14,!0);if(s!==1)throw new ti("Only PCM WAV is supported");let f=d/8,u=o/(f*c),h=new Float32Array(u*c);for(let m=0;m<u;m+=1)for(let g=0;g<c;g+=1){let p=m*c+g,y=i+p*f,v=0;if(d===8)v=e.getUint8(y),h[p]=(v-128)/128;else if(d===16)v=e.getInt16(y,!0),h[p]=v/32768;else if(d===24){let x=e.getUint8(y),b=e.getUint8(y+1),_=e.getInt8(y+2);v=x|b<<8|_<<16,h[p]=v/8388608}else throw new ti(`Unsupported bitsPerSample: ${d}`)}return{sampleRate:l,channels:c,bitsPerSample:d,samples:h}}var i1=(t,e=4294967295,r=79764919)=>{let n=new Int32Array(256),i,a,o,s=e;for(i=0;i<256;i++){for(o=i<<24,a=8;a>0;--a)o=2147483648&o?o<<1^r:o<<1;n[i]=o}for(i=0;i<t.length;i++)s=s<<8^n[255&(s>>24^t[i])];return s};var cd=(t,e=i1)=>{let r=p=>new Uint8Array(p.length/2).map(((y,v)=>parseInt(p.substring(2*v,2*(v+1)),16))),n=p=>r(p)[0],i=new Map;[,8364,,8218,402,8222,8230,8224,8225,710,8240,352,8249,338,,381,,,8216,8217,8220,8221,8226,8211,8212,732,8482,353,8250,339,,382,376].forEach(((p,y)=>i.set(p,y)));let a=new Uint8Array(t.length),o,s,c,l=!1,d=0,f=42,u=t.length>13&&t.substring(0,9)==="dynEncode",h=0;u&&(h=11,s=n(t.substring(9,h)),s<=1&&(h+=2,f=n(t.substring(11,h))),s===1&&(h+=8,c=(p=>new DataView(r(p).buffer).getInt32(0,!0))(t.substring(13,h))));let m=256-f;for(let p=h;p<t.length;p++)if(o=t.charCodeAt(p),o!==61||l){if(o===92&&p<t.length-5&&u){let y=t.charCodeAt(p+1);y!==117&&y!==85||(o=parseInt(t.substring(p+2,p+6),16),p+=5)}if(o>255){let y=i.get(o);y&&(o=y+127)}l&&(l=!1,o-=64),a[d++]=o<f&&o>0?o+m:o-f}else l=!0;let g=a.subarray(0,d);if(u&&s===1){let p=e(g);if(p!==c){let y="Decode failed crc32 validation";throw console.error("`simple-yenc`\n",y+`
|
|
1
|
+
"use strict";var Quake2Engine=(()=>{var bp=Object.create;var Is=Object.defineProperty;var xp=Object.getOwnPropertyDescriptor;var vp=Object.getOwnPropertyNames;var _p=Object.getPrototypeOf,Sp=Object.prototype.hasOwnProperty;var wp=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Na=(t,e)=>{for(var r in e)Is(t,r,{get:e[r],enumerable:!0})},lf=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of vp(e))!Sp.call(t,i)&&i!==r&&Is(t,i,{get:()=>e[i],enumerable:!(n=xp(e,i))||n.enumerable});return t};var Mp=(t,e,r)=>(r=t!=null?bp(_p(t)):{},lf(e||!t||!t.__esModule?Is(r,"default",{value:t,enumerable:!0}):r,t)),Ap=t=>lf(Is({},"__esModule",{value:!0}),t);var $f=wp((K2,Yf)=>{"use strict";Yf.exports=Worker});var JS={};Na(JS,{ATTN_IDLE:()=>qc,ATTN_LOOP_NONE:()=>Yc,ATTN_NONE:()=>$a,ATTN_NORM:()=>$c,ATTN_STATIC:()=>Zc,AssetDependencyError:()=>pi,AssetDependencyTracker:()=>jo,AssetManager:()=>Bl,AssetPreviewGenerator:()=>Ec,AudioApi:()=>zi,AudioContextController:()=>Fl,AudioOcclusion:()=>Jo,AudioRegistry:()=>la,AudioRegistryError:()=>$o,AudioSystem:()=>Hl,BSP_SURFACE_FRAGMENT_SOURCE:()=>zd,BSP_SURFACE_VERTEX_SOURCE:()=>Dd,BSP_VERTEX_LAYOUT:()=>Id,BspLoader:()=>Ni,BspParseError:()=>se,BspSurfacePipeline:()=>fa,Camera:()=>ec,ClientConnection:()=>Tc,Command:()=>Ha,CommandRegistry:()=>Ci,ConfigStringRegistry:()=>Oi,ConnectionState:()=>Qu,Cvar:()=>qa,CvarRegistry:()=>ki,DemoAnalyzer:()=>Ba,DemoCameraMode:()=>$u,DemoClipper:()=>Ac,DemoEventType:()=>Yu,DemoPlaybackController:()=>Ms,DemoReader:()=>fr,DemoRecorder:()=>As,DemoValidator:()=>Mc,DynamicLightManager:()=>Wl,EngineHost:()=>Di,EngineRuntime:()=>Za,FileType:()=>qu,FixedTimestepLoop:()=>Yn,Framebuffer:()=>gi,IndexBuffer:()=>Qe,LruCache:()=>gn,MAX_SOUND_CHANNELS:()=>Ya,MD2_FRAGMENT_SHADER:()=>Wd,MD2_VERTEX_SHADER:()=>Gd,MD3_FRAGMENT_SHADER:()=>du,MD3_VERTEX_SHADER:()=>cu,MapAnalyzer:()=>Lc,Md2Loader:()=>Hi,Md2MeshBuffers:()=>ma,Md2ParseError:()=>qe,Md2Pipeline:()=>pa,Md3Loader:()=>Vi,Md3ModelMesh:()=>xa,Md3ParseError:()=>Yt,Md3Pipeline:()=>va,Md3SurfaceMesh:()=>is,MessageWriter:()=>wc,MusicSystem:()=>Vl,NetworkMessageParser:()=>ct,PARTICLE_FRAGMENT_SHADER:()=>fu,PARTICLE_VERTEX_SHADER:()=>uu,PROTOCOL_VERSION_RERELEASE:()=>Dr,PakArchive:()=>Ui,PakIndexStore:()=>Il,PakIngestionError:()=>pn,PakParseError:()=>Ie,PakValidationError:()=>Jn,PakValidator:()=>Ks,PakWriter:()=>Gs,ParticleRenderer:()=>Sa,ParticleSystem:()=>_a,PlaybackState:()=>Sc,RERELEASE_KNOWN_PAKS:()=>td,ResourceLoadTracker:()=>Ws,ResourceType:()=>ed,SKYBOX_FRAGMENT_SHADER:()=>Hd,SKYBOX_VERTEX_SHADER:()=>Nd,SOUND_FULLVOLUME:()=>Bi,SOUND_LOOP_ATTENUATE:()=>jc,ShaderProgram:()=>le,SkyboxPipeline:()=>ha,SoundChannel:()=>wr,SoundPrecache:()=>zl,SoundRegistry:()=>Dl,SpriteLoader:()=>Gi,SpriteParseError:()=>yn,SpriteRenderer:()=>wa,StreamingPakArchive:()=>Vs,Texture2D:()=>Je,TextureCache:()=>Wi,TextureCubeMap:()=>ca,TgaParseError:()=>Vr,U_ALPHA:()=>yr,U_ANGLE1:()=>xt,U_ANGLE2:()=>mt,U_ANGLE3:()=>pt,U_EFFECTS16:()=>Ge,U_EFFECTS8:()=>Ne,U_EVENT:()=>yt,U_FRAME16:()=>_t,U_FRAME8:()=>gt,U_INSTANCE_BITS:()=>_r,U_LOOP_ATTENUATION_HIGH:()=>un,U_LOOP_VOLUME:()=>Sr,U_MODEL:()=>vt,U_MODEL2:()=>St,U_MODEL3:()=>wt,U_MODEL4:()=>Mt,U_OLDORIGIN:()=>sr,U_OLD_FRAME_HIGH:()=>hn,U_ORIGIN1:()=>ft,U_ORIGIN2:()=>ht,U_ORIGIN3:()=>bt,U_OWNER_HIGH:()=>fn,U_REMOVE:()=>Xa,U_RENDERFX16:()=>Ve,U_RENDERFX8:()=>Ue,U_SCALE:()=>vr,U_SKIN16:()=>We,U_SKIN8:()=>He,U_SOLID:()=>Et,U_SOUND:()=>At,VertexArray:()=>Ee,VertexBuffer:()=>Ae,VirtualFileSystem:()=>Xs,advanceAnimation:()=>Vf,applyEntityDelta:()=>rp,applySurfaceState:()=>es,attenuationToDistanceMultiplier:()=>Fi,boxIntersectsFrustum:()=>yi,buildBspGeometry:()=>Rh,buildMd2Geometry:()=>Xd,buildMd2VertexData:()=>Kd,buildMd3SurfaceGeometry:()=>su,buildMd3VertexData:()=>lu,calculateMaxAudibleDistance:()=>Qn,calculatePakChecksum:()=>Ef,captureRenderTarget:()=>fp,computeFrameBlend:()=>Gf,computeSkyScroll:()=>Kl,createAnimationState:()=>Wf,createAudioGraph:()=>kl,createBspSurfaces:()=>Th,createEmptyEntityState:()=>kr,createEmptyProtocolPlayerState:()=>hr,createEngine:()=>QS,createEngineRuntime:()=>wf,createFaceLightmap:()=>$s,createHeadlessRenderTarget:()=>up,createInitialChannels:()=>Ol,createOcclusionResolver:()=>Mh,createProgramFromSources:()=>Lh,createRenderer:()=>Bm,createWebGLContext:()=>Ah,createWebGPUContext:()=>cp,decodeOgg:()=>Pl,deriveSurfaceRenderState:()=>Ud,detectFileType:()=>Zu,extractFrustumPlanes:()=>kn,filesToPakSources:()=>rd,findLeafForPoint:()=>bi,gatherVisibleFaces:()=>xi,groupMd2Animations:()=>Of,ingestPakFiles:()=>Cf,ingestPaks:()=>Ys,interpolateMd3Tag:()=>mm,interpolateVec3:()=>Xf,isBinaryFile:()=>ip,isTextFile:()=>ju,parseBsp:()=>ja,parseEntLump:()=>op,parseMd2:()=>nd,parseMd3:()=>id,parsePcx:()=>to,parseSprite:()=>ad,parseTga:()=>od,parseWal:()=>Zs,parseWalTexture:()=>Js,parseWav:()=>el,pcxToRgba:()=>js,pickChannel:()=>Ul,preparePcxTexture:()=>Qs,queryCapabilities:()=>dp,removeViewTranslation:()=>Xl,resolveLightStyles:()=>Od,serializeEntLump:()=>sp,spawnBfgExplosion:()=>Em,spawnBlasterImpact:()=>Am,spawnBlood:()=>ym,spawnBulletImpact:()=>pm,spawnExplosion:()=>gm,spawnMuzzleFlash:()=>xm,spawnRailTrail:()=>wm,spawnSparks:()=>Mm,spawnSplash:()=>_m,spawnSteam:()=>Sm,spawnTeleportFlash:()=>bm,spawnTrail:()=>vm,validateEntity:()=>lp,walToRgba:()=>sd,wireDropTarget:()=>Pf,wireFileInput:()=>If});var Ep=()=>typeof performance<"u"?performance.now():Date.now(),Lp=t=>{typeof requestAnimationFrame=="function"?requestAnimationFrame(()=>t()):setTimeout(t,25)},Yn=class{constructor(e,r={}){this.callbacks=e;this.accumulatorMs=0;this.frame=0;this.running=!1;this.tick=()=>{if(!this.running)return;let e=this.options.now(),r=this.lastTimeMs===void 0?0:e-this.lastTimeMs;this.lastTimeMs=e,this.advance(r,e),this.running&&this.options.schedule(this.tick)};let n=r.fixedDeltaMs??25,i=r.maxSubSteps??5;this.options={fixedDeltaMs:n,maxSubSteps:i,maxDeltaMs:r.maxDeltaMs??n*i,startTimeMs:r.startTimeMs,now:r.now??Ep,schedule:r.schedule??Lp}}start(){this.running||(this.running=!0,this.lastTimeMs=this.options.startTimeMs??this.options.now(),this.options.schedule(this.tick))}stop(){this.running=!1}pump(e){let r=(this.lastTimeMs??0)+e;this.lastTimeMs=r,this.advance(e,r)}isRunning(){return this.running}get frameNumber(){return this.frame}advance(e,r){let n=Math.min(Math.max(e,0),this.options.maxDeltaMs);this.accumulatorMs=Math.min(this.accumulatorMs+n,this.options.fixedDeltaMs*this.options.maxSubSteps);let i=0;for(;this.accumulatorMs>=this.options.fixedDeltaMs&&i<this.options.maxSubSteps;)this.frame+=1,this.callbacks.simulate({frame:this.frame,deltaMs:this.options.fixedDeltaMs,nowMs:r}),this.accumulatorMs-=this.options.fixedDeltaMs,i+=1;let a=this.options.fixedDeltaMs===0?0:this.accumulatorMs/this.options.fixedDeltaMs;this.callbacks.render?.({alpha:a,nowMs:r,accumulatorMs:this.accumulatorMs,frame:this.frame})}};var Ha=class{constructor(e,r,n){this.name=e,this.callback=r,this.description=n}execute(e){this.callback(e)}},Ci=class{constructor(){this.commands=new Map;this.history=[];this.historyLimit=64;this.autocompleteProviders=[]}register(e,r,n){let i=new Ha(e,r,n);return this.commands.set(e,i),i}registerCommand(e,r){this.register(e,r)}registerAutocompleteProvider(e){this.autocompleteProviders.push(e)}get(e){return this.commands.get(e)}execute(e){let r=e.trim();if(r.length===0)return!1;(this.history.length===0||this.history[this.history.length-1]!==r)&&(this.history.push(r),this.history.length>this.historyLimit&&this.history.shift());let n=this.tokenize(e);if(n.length===0)return!1;let i=n[0],a=n.slice(1),o=this.get(i);return o?(o.execute(a),!0):(this.onConsoleOutput?.(`Unknown command "${i}"`),!1)}executeCommand(e){this.execute(e)}getHistory(){return[...this.history]}getSuggestions(e){let r=new Set;for(let n of this.commands.keys())n.startsWith(e)&&r.add(n);for(let n of this.autocompleteProviders){let i=n();for(let a of i)a.startsWith(e)&&r.add(a)}return Array.from(r).sort()}tokenize(e){let r=[],n="",i=!1;for(let a=0;a<e.length;a++){let o=e[a];o==='"'?i=!i:o===" "&&!i?n.length>0&&(r.push(n),n=""):n+=o}return n.length>0&&r.push(n),r}list(){return[...this.commands.values()].sort((e,r)=>e.name.localeCompare(r.name))}};var Tp=Object.defineProperty,Rp=(t,e)=>{for(var r in e)Tp(t,r,{get:e[r],enumerable:!0})},cf={x:0,y:0,z:0};var lw=Math.PI/180;function df(t,e){return{x:t.x-e.x,y:t.y-e.y,z:t.z-e.z}}function Cp(t,e){return{x:t.x*e,y:t.y*e,z:t.z*e}}function Pp(t,e){return t.x*e.x+t.y*e.y+t.z*e.z}function Ip(t){return Pp(t,t)}function Dc(t){return Math.sqrt(Ip(t))}function Hr(t){let e=Dc(t);return e===0?t:Cp(t,1/e)}var Bp=Math.PI/180,Fp=180/Math.PI,Pi=Bp,zc=Fp;var or=[[-.525731,0,.850651],[-.442863,.238856,.864188],[-.295242,0,.955423],[-.309017,.5,.809017],[-.16246,.262866,.951056],[0,0,1],[0,.850651,.525731],[-.147621,.716567,.681718],[.147621,.716567,.681718],[0,.525731,.850651],[.309017,.5,.809017],[.525731,0,.850651],[.295242,0,.955423],[.442863,.238856,.864188],[.16246,.262866,.951056],[-.681718,.147621,.716567],[-.809017,.309017,.5],[-.587785,.425325,.688191],[-.850651,.525731,0],[-.864188,.442863,.238856],[-.716567,.681718,.147621],[-.688191,.587785,.425325],[-.5,.809017,.309017],[-.238856,.864188,.442863],[-.425325,.688191,.587785],[-.716567,.681718,-.147621],[-.5,.809017,-.309017],[-.525731,.850651,0],[0,.850651,-.525731],[-.238856,.864188,-.442863],[0,.955423,-.295242],[-.262866,.951056,-.16246],[0,1,0],[0,.955423,.295242],[-.262866,.951056,.16246],[.238856,.864188,.442863],[.262866,.951056,.16246],[.5,.809017,.309017],[.238856,.864188,-.442863],[.262866,.951056,-.16246],[.5,.809017,-.309017],[.850651,.525731,0],[.716567,.681718,.147621],[.716567,.681718,-.147621],[.525731,.850651,0],[.425325,.688191,.587785],[.864188,.442863,.238856],[.688191,.587785,.425325],[.809017,.309017,.5],[.681718,.147621,.716567],[.587785,.425325,.688191],[.955423,.295242,0],[1,0,0],[.951056,.16246,.262866],[.850651,-.525731,0],[.955423,-.295242,0],[.864188,-.442863,.238856],[.951056,-.16246,.262866],[.809017,-.309017,.5],[.681718,-.147621,.716567],[.850651,0,.525731],[.864188,.442863,-.238856],[.809017,.309017,-.5],[.951056,.16246,-.262866],[.525731,0,-.850651],[.681718,.147621,-.716567],[.681718,-.147621,-.716567],[.850651,0,-.525731],[.809017,-.309017,-.5],[.864188,-.442863,-.238856],[.951056,-.16246,-.262866],[.147621,.716567,-.681718],[.309017,.5,-.809017],[.425325,.688191,-.587785],[.442863,.238856,-.864188],[.587785,.425325,-.688191],[.688191,.587785,-.425325],[-.147621,.716567,-.681718],[-.309017,.5,-.809017],[0,.525731,-.850651],[-.525731,0,-.850651],[-.442863,.238856,-.864188],[-.295242,0,-.955423],[-.16246,.262866,-.951056],[0,0,-1],[.295242,0,-.955423],[.16246,.262866,-.951056],[-.442863,-.238856,-.864188],[-.309017,-.5,-.809017],[-.16246,-.262866,-.951056],[0,-.850651,-.525731],[-.147621,-.716567,-.681718],[.147621,-.716567,-.681718],[0,-.525731,-.850651],[.309017,-.5,-.809017],[.442863,-.238856,-.864188],[.16246,-.262866,-.951056],[.238856,-.864188,-.442863],[.5,-.809017,-.309017],[.425325,-.688191,-.587785],[.716567,-.681718,-.147621],[.688191,-.587785,-.425325],[.587785,-.425325,-.688191],[0,-.955423,-.295242],[0,-1,0],[.262866,-.951056,-.16246],[0,-.850651,.525731],[0,-.955423,.295242],[.238856,-.864188,.442863],[.262866,-.951056,.16246],[.5,-.809017,.309017],[.716567,-.681718,.147621],[.525731,-.850651,0],[-.238856,-.864188,-.442863],[-.5,-.809017,-.309017],[-.262866,-.951056,-.16246],[-.850651,-.525731,0],[-.716567,-.681718,-.147621],[-.716567,-.681718,.147621],[-.525731,-.850651,0],[-.5,-.809017,.309017],[-.238856,-.864188,.442863],[-.262866,-.951056,.16246],[-.864188,-.442863,.238856],[-.809017,-.309017,.5],[-.688191,-.587785,.425325],[-.681718,-.147621,.716567],[-.442863,-.238856,.864188],[-.587785,-.425325,.688191],[-.309017,-.5,.809017],[-.147621,-.716567,.681718],[-.425325,-.688191,.587785],[-.16246,-.262866,.951056],[.442863,-.238856,.864188],[.16246,-.262866,.951056],[.309017,-.5,.809017],[.147621,-.716567,.681718],[0,-.525731,.850651],[.425325,-.688191,.587785],[.587785,-.425325,.688191],[.688191,-.587785,.425325],[-.955423,.295242,0],[-.951056,.16246,.262866],[-1,0,0],[-.850651,0,.525731],[-.955423,-.295242,0],[-.951056,-.16246,.262866],[-.864188,.442863,-.238856],[-.951056,.16246,-.262866],[-.809017,.309017,-.5],[-.864188,-.442863,-.238856],[-.951056,-.16246,-.262866],[-.809017,-.309017,-.5],[-.681718,.147621,-.716567],[-.681718,-.147621,-.716567],[-.850651,0,-.525731],[-.688191,.587785,-.425325],[-.587785,.425325,-.688191],[-.425325,.688191,-.587785],[-.425325,-.688191,-.587785],[-.587785,-.425325,-.688191],[-.688191,-.587785,-.425325]];var mr=624,kp=397,Dp=2567483615,zp=2147483648,Op=2147483647,Fc=4294967296,Up=class{constructor(t=5489){this.state=new Uint32Array(mr),this.index=mr,this.seed(t)}seed(t){this.state[0]=t>>>0;for(let e=1;e<mr;e++){let r=this.state[e-1]^this.state[e-1]>>>30,n=Math.imul(r>>>0,1812433253)+e;this.state[e]=n>>>0}this.index=mr}nextUint32(){this.index>=mr&&this.twist();let t=this.state[this.index++];return t^=t>>>11,t^=t<<7&2636928640,t^=t<<15&4022730752,t^=t>>>18,t>>>0}twist(){for(let t=0;t<mr;t++){let e=this.state[t]&zp|this.state[(t+1)%mr]&Op,r=this.state[(t+kp)%mr]^e>>>1;(e&1)!==0&&(r^=Dp),this.state[t]=r>>>0}this.index=0}getState(){return{index:this.index,state:Array.from(this.state)}}setState(t){if(t.state.length!==mr)throw new Error(`Expected ${mr} MT state values, received ${t.state.length}`);this.index=t.index,this.state=Uint32Array.from(t.state,e=>e>>>0)}},uf=class{constructor(t={}){this.mt=new Up(t.seed)}seed(t){this.mt.seed(t)}frandom(){return this.mt.nextUint32()/Fc}frandomRange(t,e){return t+(e-t)*this.frandom()}frandomMax(t){return this.frandomRange(0,t)}crandom(){return this.frandomRange(-1,1)}crandomOpen(){let t=Number.EPSILON;return this.frandomRange(-1+t,1)}irandomUint32(){return this.mt.nextUint32()}irandomRange(t,e){if(e-t<=1)return t;let r=e-t,n=Fc-Fc%r,i;do i=this.mt.nextUint32();while(i>=n);return t+i%r}irandom(t){return t<=0?0:this.irandomRange(0,t)}randomTimeRange(t,e){return e<=t?t:this.irandomRange(t,e)}randomTime(t){return this.irandom(t)}randomIndex(t){return this.irandom(t.length)}getState(){return{mt:this.mt.getState()}}setState(t){this.mt.setState(t.mt)}};function Np(){return new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}function Oc(t,e){let r=new Float32Array(16);for(let n=0;n<4;n+=1)for(let i=0;i<4;i+=1)r[i*4+n]=t[0+n]*e[i*4+0]+t[4+n]*e[i*4+1]+t[8+n]*e[i*4+2]+t[12+n]*e[i*4+3];return r}function ff(t,e){let r=e.x,n=e.y,i=e.z;return{x:t[0]*r+t[4]*n+t[8]*i+t[12],y:t[1]*r+t[5]*n+t[9]*i+t[13],z:t[2]*r+t[6]*n+t[10]*i+t[14]}}function hf(t,e){let r=Np();return r[0]=e[0].x,r[1]=e[0].y,r[2]=e[0].z,r[4]=e[1].x,r[5]=e[1].y,r[6]=e[1].z,r[8]=e[2].x,r[9]=e[2].y,r[10]=e[2].z,r[12]=t.x,r[13]=t.y,r[14]=t.z,r}var pr=1,dn=2;var Uc=8,Nc=16,Hp=32;var Vp=16384;var Bs=65536,mf=1<<17,Gp=1<<18,Wp=1<<19,Xp=1<<20,Kp=1<<21,Yp=1<<22,$p=1<<23,cw=1<<24,Fs=1<<25,qp=1<<26,dw=1<<27,uw=1<<28,fw=1<<29,ks=1<<30,hw=1<<31;var Ga=0;var Ds=4,Wa=8,zs=16,Os=32,pf=64;var mw=1<<25,pw=1<<28,gw=1<<29,yw=1<<30,bw=1<<31;var xw=pr|dn,vw=pr|Bs|dn|Fs|ks,_w=pr|Bs|dn,Sw=pr|mf|dn|Fs|ks,ww=Hp|Uc|Nc,Mw=pr|Nc|Uc,Zp=pr|Fs|ks|dn|qp,Aw=Gp|Wp|Xp|Kp|Yp|$p,Ew=pr|Uc|Nc|Fs|ks,Lw=pr|Bs|dn,Tw=pr|dn,Rw=pr|Bs|dn|mf,Cw=Zp|Vp;var Pw=Number.MAX_SAFE_INTEGER-1;var Us=(t=>(t[t.None=0]="None",t[t.Archive=1]="Archive",t[t.UserInfo=2]="UserInfo",t[t.ServerInfo=4]="ServerInfo",t[t.Latch=8]="Latch",t[t.Cheat=16]="Cheat",t))(Us||{});var Ns=256;var Hc=256,Vc=8192,Hs=2048,Gc=512,Wc=256,Xc=Ns*2,Kc=256,kc=32,Va=96;var J=(t=>(t[t.Name=0]="Name",t[t.CdTrack=1]="CdTrack",t[t.Sky=2]="Sky",t[t.SkyAxis=3]="SkyAxis",t[t.SkyRotate=4]="SkyRotate",t[t.StatusBar=5]="StatusBar",t[t.HealthBarName=55]="HealthBarName",t[t.CONFIG_N64_PHYSICS=56]="CONFIG_N64_PHYSICS",t[t.CONFIG_CTF_TEAMS=57]="CONFIG_CTF_TEAMS",t[t.CONFIG_COOP_RESPAWN_STRING=58]="CONFIG_COOP_RESPAWN_STRING",t[t.Story=54]="Story",t[t.AirAccel=59]="AirAccel",t[t.MaxClients=60]="MaxClients",t[t.MapChecksum=61]="MapChecksum",t[t.Models=62]="Models",t[t.Sounds=62+Vc]="Sounds",t[t.Images=t.Sounds+Hs]="Images",t[t.Lights=t.Images+Gc]="Lights",t[t.ShadowLights=t.Lights+Hc]="ShadowLights",t[t.Items=t.ShadowLights+Kc]="Items",t[t.Players=t.Items+Wc]="Players",t[t.PlayerSkins=t.Players]="PlayerSkins",t[t.General=t.Players+Ns]="General",t[t.WheelWeapons=t.General+Xc]="WheelWeapons",t[t.WheelAmmo=t.WheelWeapons+kc]="WheelAmmo",t[t.WheelPowerups=t.WheelAmmo+kc]="WheelPowerups",t[t.CdLoopCount=t.WheelPowerups+kc]="CdLoopCount",t[t.GameStyle=t.CdLoopCount+1]="GameStyle",t[t.MaxConfigStrings=t.GameStyle+1]="MaxConfigStrings",t))(J||{}),gf=J.MaxConfigStrings;function yf(t){return t>=5&&t<59?Va*(59-t):t>=J.General&&t<J.WheelWeapons?Va*(J.MaxConfigStrings-t):Va}var Iw=J.Sounds,Bw=J.Images,Fw=J.Lights,kw=J.Items,Dw=J.Players,zw=J.General,jp={};Rp(jp,{addReplayFrame:()=>tg,createReplaySession:()=>eg,deserializeReplay:()=>Jp,serializeReplay:()=>Qp});function Qp(t){return JSON.stringify(t,null,2)}function Jp(t){let e=JSON.parse(t);if(!e.metadata||!Array.isArray(e.frames))throw new Error("Invalid replay format: missing metadata or frames");return e}function eg(t,e){return{metadata:{map:t,date:new Date().toISOString(),version:"1.0",seed:e},frames:[]}}function tg(t,e,r,n){t.frames.push({serverFrame:r,cmd:e,timestamp:Date.now()-n})}var T=(t=>(t[t.bad=0]="bad",t[t.muzzleflash=1]="muzzleflash",t[t.muzzleflash2=2]="muzzleflash2",t[t.temp_entity=3]="temp_entity",t[t.layout=4]="layout",t[t.inventory=5]="inventory",t[t.nop=6]="nop",t[t.disconnect=7]="disconnect",t[t.reconnect=8]="reconnect",t[t.sound=9]="sound",t[t.print=10]="print",t[t.stufftext=11]="stufftext",t[t.serverdata=12]="serverdata",t[t.configstring=13]="configstring",t[t.spawnbaseline=14]="spawnbaseline",t[t.centerprint=15]="centerprint",t[t.download=16]="download",t[t.playerinfo=17]="playerinfo",t[t.packetentities=18]="packetentities",t[t.deltapacketentities=19]="deltapacketentities",t[t.frame=20]="frame",t[t.splitclient=21]="splitclient",t[t.configblast=22]="configblast",t[t.spawnbaselineblast=23]="spawnbaselineblast",t[t.level_restart=24]="level_restart",t[t.damage=25]="damage",t[t.locprint=26]="locprint",t[t.fog=27]="fog",t[t.waitingforplayers=28]="waitingforplayers",t[t.bot_chat=29]="bot_chat",t[t.poi=30]="poi",t[t.help_path=31]="help_path",t[t.muzzleflash3=32]="muzzleflash3",t[t.achievement=33]="achievement",t))(T||{}),qn=(t=>(t[t.bad=0]="bad",t[t.nop=1]="nop",t[t.move=2]="move",t[t.userinfo=3]="userinfo",t[t.stringcmd=4]="stringcmd",t))(qn||{}),D=(t=>(t[t.GUNSHOT=0]="GUNSHOT",t[t.BLOOD=1]="BLOOD",t[t.BLASTER=2]="BLASTER",t[t.RAILTRAIL=3]="RAILTRAIL",t[t.SHOTGUN=4]="SHOTGUN",t[t.EXPLOSION1=5]="EXPLOSION1",t[t.EXPLOSION2=6]="EXPLOSION2",t[t.ROCKET_EXPLOSION=7]="ROCKET_EXPLOSION",t[t.GRENADE_EXPLOSION=8]="GRENADE_EXPLOSION",t[t.SPARKS=9]="SPARKS",t[t.SPLASH=10]="SPLASH",t[t.BUBBLETRAIL=11]="BUBBLETRAIL",t[t.SCREEN_SPARKS=12]="SCREEN_SPARKS",t[t.SHIELD_SPARKS=13]="SHIELD_SPARKS",t[t.BULLET_SPARKS=14]="BULLET_SPARKS",t[t.LASER_SPARKS=15]="LASER_SPARKS",t[t.PARASITE_ATTACK=16]="PARASITE_ATTACK",t[t.ROCKET_EXPLOSION_WATER=17]="ROCKET_EXPLOSION_WATER",t[t.GRENADE_EXPLOSION_WATER=18]="GRENADE_EXPLOSION_WATER",t[t.MEDIC_CABLE_ATTACK=19]="MEDIC_CABLE_ATTACK",t[t.BFG_EXPLOSION=20]="BFG_EXPLOSION",t[t.BFG_BIGEXPLOSION=21]="BFG_BIGEXPLOSION",t[t.BOSSTPORT=22]="BOSSTPORT",t[t.BFG_LASER=23]="BFG_LASER",t[t.GRAPPLE_CABLE=24]="GRAPPLE_CABLE",t[t.WELDING_SPARKS=25]="WELDING_SPARKS",t[t.GREENBLOOD=26]="GREENBLOOD",t[t.BLUEHYPERBLASTER=27]="BLUEHYPERBLASTER",t[t.PLASMA_EXPLOSION=28]="PLASMA_EXPLOSION",t[t.TUNNEL_SPARKS=29]="TUNNEL_SPARKS",t[t.BLASTER2=30]="BLASTER2",t[t.RAILTRAIL2=31]="RAILTRAIL2",t[t.FLAME=32]="FLAME",t[t.LIGHTNING=33]="LIGHTNING",t[t.DEBUGTRAIL=34]="DEBUGTRAIL",t[t.PLAIN_EXPLOSION=35]="PLAIN_EXPLOSION",t[t.FLASHLIGHT=36]="FLASHLIGHT",t[t.FORCEWALL=37]="FORCEWALL",t[t.HEATBEAM=38]="HEATBEAM",t[t.MONSTER_HEATBEAM=39]="MONSTER_HEATBEAM",t[t.STEAM=40]="STEAM",t[t.BUBBLETRAIL2=41]="BUBBLETRAIL2",t[t.MOREBLOOD=42]="MOREBLOOD",t[t.HEATBEAM_SPARKS=43]="HEATBEAM_SPARKS",t[t.HEATBEAM_STEAM=44]="HEATBEAM_STEAM",t[t.CHAINFIST_SMOKE=45]="CHAINFIST_SMOKE",t[t.ELECTRIC_SPARKS=46]="ELECTRIC_SPARKS",t[t.TRACKER_EXPLOSION=47]="TRACKER_EXPLOSION",t[t.TELEPORT_EFFECT=48]="TELEPORT_EFFECT",t[t.DBALL_GOAL=49]="DBALL_GOAL",t[t.WIDOWBEAMOUT=50]="WIDOWBEAMOUT",t[t.NUKEBLAST=51]="NUKEBLAST",t[t.WIDOWSPLASH=52]="WIDOWSPLASH",t[t.EXPLOSION1_BIG=53]="EXPLOSION1_BIG",t[t.EXPLOSION1_NP=54]="EXPLOSION1_NP",t[t.FLECHETTE=55]="FLECHETTE",t[t.BLUEHYPERBLASTER_KEX=56]="BLUEHYPERBLASTER_KEX",t[t.BFG_ZAP=57]="BFG_ZAP",t[t.BERSERK_SLAM=58]="BERSERK_SLAM",t[t.GRAPPLE_CABLE_2=59]="GRAPPLE_CABLE_2",t[t.POWER_SPLASH=60]="POWER_SPLASH",t[t.LIGHTNING_BEAM=61]="LIGHTNING_BEAM",t[t.EXPLOSION1_NL=62]="EXPLOSION1_NL",t[t.EXPLOSION2_NL=63]="EXPLOSION2_NL",t))(D||{});var bf=64;var rg=12,ng=9,Ow=Math.ceil(rg*ng/16),ig=23,ag=2,Uw=Math.ceil(ig*ag/16);function xf(t,e){t.writeByte(e.msec),t.writeByte(e.buttons),t.writeAngle16(e.angles.x),t.writeAngle16(e.angles.y),t.writeAngle16(e.angles.z),t.writeShort(e.forwardmove),t.writeShort(e.sidemove),t.writeShort(e.upmove),t.writeByte(e.impulse),t.writeByte(0)}var og=[0,145,227,114,7,150,228,117,14,159,237,124,9,152,234,123,28,141,255,110,27,138,248,105,18,131,241,96,21,132,246,103,56,169,219,74,63,174,220,77,54,167,213,68,49,160,210,67,36,181,199,86,35,178,192,81,42,187,201,88,45,188,206,95,112,225,147,2,119,230,148,5,126,239,157,12,121,232,154,11,108,253,143,30,107,250,136,25,98,243,129,16,101,244,134,23,72,217,171,58,79,222,172,61,70,215,165,52,65,208,162,51,84,197,183,38,83,194,176,33,90,203,185,40,93,204,190,47,224,113,3,146,231,118,4,149,238,127,13,156,233,120,10,155,252,109,31,142,251,106,24,137,242,99,17,128,245,100,22,135,216,73,59,170,223,78,60,173,214,71,53,164,209,64,50,163,196,85,39,182,195,82,32,177,202,91,41,184,205,92,46,191,144,1,115,226,151,6,116,229,158,15,125,236,153,8,122,235,140,29,111,254,139,26,104,249,130,19,97,240,133,20,102,247,168,57,75,218,175,62,76,221,166,55,69,212,161,48,66,211,180,37,86,199,179,34,80,193,186,43,89,200,189,44,94,207];function vf(t){let e=0;for(let r=0;r<t.length;r++)e=og[(e^t[r])&255];return e}var ft=1,ht=2,mt=4,pt=8,gt=16,yt=32,Xa=64,gr=128,Zn=256,bt=512,xt=1024,vt=2048,Ue=4096,yr=8192,Ne=16384,br=32768,He=65536,_t=1<<17,Ve=1<<18,Ge=1<<19,St=1<<20,wt=1<<21,Mt=1<<22,xr=1<<23,sr=1<<24,We=1<<25,At=1<<26,Et=1<<27,vr=1<<28,_r=1<<29,Sr=1<<30,Ii=-2147483648,un=1,fn=2,hn=4;var mn=class{constructor(t){t instanceof Uint8Array?this.view=new DataView(t.buffer,t.byteOffset,t.byteLength):this.view=new DataView(t),this.offset=0,this.length=this.view.byteLength}getPosition(){return this.offset}getReadPosition(){return this.offset}getLength(){return this.length}getRemaining(){return this.length-this.offset}seek(t){if(t<0||t>this.length)throw new Error(`Seek out of bounds: ${t} (length: ${this.length})`);this.offset=t}setReadPosition(t){this.seek(t)}hasMore(){return this.offset<this.length}hasBytes(t){return this.offset+t<=this.length}readChar(){let t=this.view.getInt8(this.offset);return this.offset+=1,t}readByte(){let t=this.view.getUint8(this.offset);return this.offset+=1,t}readShort(){let t=this.view.getInt16(this.offset,!0);return this.offset+=2,t}readUShort(){let t=this.view.getUint16(this.offset,!0);return this.offset+=2,t}readLong(){let t=this.view.getInt32(this.offset,!0);return this.offset+=4,t}readULong(){let t=this.view.getUint32(this.offset,!0);return this.offset+=4,t}readFloat(){let t=this.view.getFloat32(this.offset,!0);return this.offset+=4,t}readString(){let t="";for(;this.offset<this.length;){let e=this.readChar();if(e===-1||e===0)break;t+=String.fromCharCode(e)}return t}readStringLine(){let t="";for(;this.offset<this.length;){let e=this.readChar();if(e===-1||e===0||e===10)break;t+=String.fromCharCode(e)}return t}readCoord(){return this.readShort()*(1/8)}readAngle(){return this.readChar()*(360/256)}readAngle16(){return this.readShort()*360/65536}readData(t){if(this.offset+t>this.length)throw new Error(`Read out of bounds: ${this.offset+t} (length: ${this.length})`);let e=new Uint8Array(this.view.buffer,this.view.byteOffset+this.offset,t);return this.offset+=t,new Uint8Array(e)}readPos(t){t.x=this.readCoord(),t.y=this.readCoord(),t.z=this.readCoord()}readDir(t){let e=this.readByte();if(e>=162){t.x=0,t.y=0,t.z=0;return}let r=or[e];t.x=r[0],t.y=r[1],t.z=r[2]}},jn=class{constructor(t=1400){typeof t=="number"?(this.buffer=new Uint8Array(t),this.fixed=!1):(this.buffer=t,this.fixed=!0),this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength),this.offset=0}ensureSpace(t){if(this.offset+t>this.buffer.byteLength){if(this.fixed)throw new Error(`Buffer overflow: capacity ${this.buffer.byteLength}, needed ${this.offset+t}`);let e=Math.max(this.buffer.byteLength*2,this.offset+t),r=new Uint8Array(e);r.set(this.buffer),this.buffer=r,this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength)}}writeByte(t){this.ensureSpace(1),this.view.setUint8(this.offset,t),this.offset+=1}writeBytes(t){this.ensureSpace(t.byteLength),this.buffer.set(t,this.offset),this.offset+=t.byteLength}writeChar(t){this.ensureSpace(1),this.view.setInt8(this.offset,t),this.offset+=1}writeShort(t){this.ensureSpace(2),this.view.setInt16(this.offset,t,!0),this.offset+=2}writeLong(t){this.ensureSpace(4),this.view.setInt32(this.offset,t,!0),this.offset+=4}writeFloat(t){this.ensureSpace(4),this.view.setFloat32(this.offset,t,!0),this.offset+=4}writeString(t){let e=t.length;this.ensureSpace(e+1);for(let r=0;r<e;r++)this.view.setUint8(this.offset+r,t.charCodeAt(r));this.view.setUint8(this.offset+e,0),this.offset+=e+1}writeCoord(t){this.writeShort(Math.trunc(t*8))}writeAngle(t){this.writeByte(Math.trunc(t*256/360)&255)}writeAngle16(t){this.writeShort(Math.trunc(t*65536/360)&65535)}writePos(t){this.writeCoord(t.x),this.writeCoord(t.y),this.writeCoord(t.z)}writeDir(t){let e=-1,r=0;if(t.x===0&&t.y===0&&t.z===0){this.writeByte(0);return}for(let n=0;n<or.length;n++){let i=or[n],a=t.x*i[0]+t.y*i[1]+t.z*i[2];a>e&&(e=a,r=n)}this.writeByte(r)}getData(){return this.buffer.slice(0,this.offset)}getBuffer(){return this.buffer}getOffset(){return this.offset}reset(){this.offset=0}},Ka=class{constructor(t=1024){this.buffer=new Uint8Array(t),this.view=new DataView(this.buffer.buffer),this.offset=0}ensureCapacity(t){if(this.offset+t>this.buffer.length){let e=Math.max(this.buffer.length*2,this.offset+t),r=new Uint8Array(e);r.set(this.buffer),this.buffer=r,this.view=new DataView(this.buffer.buffer)}}getData(){return this.buffer.slice(0,this.offset)}writeByte(t){this.ensureCapacity(1),this.view.setUint8(this.offset,t),this.offset+=1}writeChar(t){this.ensureCapacity(1),this.view.setInt8(this.offset,t),this.offset+=1}writeShort(t){this.ensureCapacity(2),this.view.setInt16(this.offset,t,!0),this.offset+=2}writeUShort(t){this.ensureCapacity(2),this.view.setUint16(this.offset,t,!0),this.offset+=2}writeLong(t){this.ensureCapacity(4),this.view.setInt32(this.offset,t,!0),this.offset+=4}writeFloat(t){this.ensureCapacity(4),this.view.setFloat32(this.offset,t,!0),this.offset+=4}writeString(t){let e=t.length+1;this.ensureCapacity(e);for(let r=0;r<t.length;r++)this.view.setUint8(this.offset+r,t.charCodeAt(r));this.view.setUint8(this.offset+t.length,0),this.offset+=e}writeData(t){this.ensureCapacity(t.length),this.buffer.set(t,this.offset),this.offset+=t.length}writeCoord(t){this.writeShort(Math.round(t*8))}writeAngle(t){this.writeByte(Math.round(t*256/360)&255)}writeAngle16(t){this.writeShort(Math.round(t*65536/360))}writeDir(t,e,r){let n=0,i=-999999,a=Math.sqrt(t*t+e*e+r*r);if(a>0){t/=a,e/=a,r/=a;for(let o=0;o<162;o++){let s=t*or[o][0]+e*or[o][1]+r*or[o][2];s>i&&(i=s,n=o)}}this.writeByte(n)}},$n=class $e{constructor(){this.qport=0,this.incomingSequence=0,this.outgoingSequence=0,this.incomingAcknowledged=0,this.incomingReliableAcknowledged=!1,this.incomingReliableSequence=0,this.outgoingReliableSequence=0,this.reliableLength=0,this.fragmentSendOffset=0,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0,this.lastReceived=0,this.lastSent=0,this.remoteAddress=null,this.reliableMessage=new jn($e.MAX_RELIABLE_BUFFER);let e=Date.now();this.lastReceived=e,this.lastSent=e,this.qport=Math.floor(Math.random()*65536)}setup(e,r=null){this.qport=e,this.remoteAddress=r,this.reset()}reset(){this.incomingSequence=0,this.outgoingSequence=0,this.incomingAcknowledged=0,this.incomingReliableAcknowledged=!1,this.incomingReliableSequence=0,this.outgoingReliableSequence=0,this.reliableLength=0,this.reliableMessage.reset(),this.fragmentSendOffset=0,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0,this.lastReceived=Date.now(),this.lastSent=Date.now()}transmit(e){this.outgoingSequence++,this.lastSent=Date.now();let r=0,n=!1,i=0;this.reliableLength>0&&(this.reliableLength>$e.FRAGMENT_SIZE?(n=!0,this.fragmentSendOffset>=this.reliableLength&&(this.fragmentSendOffset=0),r=this.reliableLength-this.fragmentSendOffset,r>$e.FRAGMENT_SIZE&&(r=$e.FRAGMENT_SIZE),i=this.fragmentSendOffset,this.fragmentSendOffset+=r):r=this.reliableLength);let a=$e.PACKET_HEADER,o=r>0?2+(n?8:0):0,s=e?e.length:0;a+o+r+s>$e.MAX_MSGLEN&&(s=$e.MAX_MSGLEN-a-o-r,s<0&&(s=0));let c=new ArrayBuffer(a+o+r+s),l=new DataView(c),d=new Uint8Array(c),f=this.outgoingSequence;r>0&&(f|=2147483648,(this.outgoingReliableSequence&1)!==0&&(f|=1073741824)),l.setUint32(0,f,!0);let u=this.incomingSequence;(this.incomingReliableSequence&1)!==0&&(u|=2147483648),l.setUint32(4,u,!0),l.setUint16(8,this.qport,!0);let h=a;if(r>0){let m=r;n&&(m|=32768),l.setUint16(h,m,!0),h+=2,n&&(l.setUint32(h,i,!0),h+=4,l.setUint32(h,this.reliableLength,!0),h+=4);let p=this.reliableMessage.getBuffer().subarray(i,i+r);d.set(p,h),h+=r}if(e&&s>0){let m=e.slice(0,s);d.set(m,h)}return d}process(e){if(e.length<4)return null;this.lastReceived=Date.now();let r=new DataView(e.buffer,e.byteOffset,e.byteLength),n=r.getUint32(0,!0);if(n===4294967295)return e.subarray(4);if(e.length<$e.PACKET_HEADER)return null;let i=r.getUint32(4,!0),a=r.getUint16(8,!0);if(this.qport!==a)return null;let o=n&1073741823;if((o-this.incomingSequence|0)<=0)return null;this.incomingSequence=o;let s=i&2147483647,c=(i&2147483648)!==0;if(s>this.incomingAcknowledged&&(this.incomingAcknowledged=s),this.reliableLength>0){let m=c?1:0,g=this.outgoingReliableSequence&1;m!==g&&(this.reliableLength=0,this.reliableMessage.reset(),this.outgoingReliableSequence^=1,this.fragmentSendOffset=0)}let l=(n&2147483648)!==0,d=(n&1073741824)!==0?1:0,f=$e.PACKET_HEADER,u=null;if(l){if(f+2>e.byteLength)return null;let m=r.getUint16(f,!0);f+=2;let g=(m&32768)!==0;m&=32767;let p=this.incomingReliableSequence&1;if(d===p)if(g){if(f+8>e.byteLength)return null;let y=r.getUint32(f,!0);f+=4;let v=r.getUint32(f,!0);if(f+=4,v>$e.MAX_RELIABLE_BUFFER)return console.warn(`NetChan: received invalid fragment total ${v} > ${$e.MAX_RELIABLE_BUFFER}`),null;if((!this.fragmentBuffer||this.fragmentBuffer.length!==v)&&(this.fragmentBuffer=new Uint8Array(v),this.fragmentLength=v,this.fragmentReceived=0),f+m>e.byteLength)return null;let x=e.subarray(f,f+m);y===this.fragmentReceived&&y+m<=v&&(this.fragmentBuffer.set(x,y),this.fragmentReceived+=m,this.fragmentReceived>=v&&(u=this.fragmentBuffer,this.incomingReliableSequence++,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0))}else{if(this.incomingReliableSequence++,f+m>e.byteLength)return null;u=e.slice(f,f+m)}f+=m}let h=e.slice(f);if(u&&u.length>0){let m=u.length+h.length,g=new Uint8Array(m);return g.set(u,0),g.set(h,u.length),g}return h||new Uint8Array(0)}canSendReliable(){return this.reliableLength===0}writeReliableByte(e){if(this.reliableLength+1>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeByte(e),this.reliableLength++}writeReliableShort(e){if(this.reliableLength+2>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeShort(e),this.reliableLength+=2}writeReliableLong(e){if(this.reliableLength+4>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeLong(e),this.reliableLength+=4}writeReliableString(e){let r=e.length+1;if(this.reliableLength+r>$e.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeString(e),this.reliableLength+=r}getReliableData(){return this.reliableLength===0?new Uint8Array(0):this.reliableMessage.getBuffer().subarray(0,this.reliableLength)}needsKeepalive(e){return e-this.lastSent>1e3}isTimedOut(e,r=3e4){return e-this.lastReceived>r}};$n.MAX_MSGLEN=1400;$n.FRAGMENT_SIZE=1024;$n.PACKET_HEADER=10;$n.HEADER_OVERHEAD=$n.PACKET_HEADER+2;$n.MAX_RELIABLE_BUFFER=262144;var _f=$n;var Sf=(t=>(t[t.Bullets=0]="Bullets",t[t.Shells=1]="Shells",t[t.Rockets=2]="Rockets",t[t.Grenades=3]="Grenades",t[t.Cells=4]="Cells",t[t.Slugs=5]="Slugs",t[t.MagSlugs=6]="MagSlugs",t[t.Trap=7]="Trap",t[t.Flechettes=8]="Flechettes",t[t.Tesla=9]="Tesla",t[t.Disruptor=10]="Disruptor",t[t.Prox=11]="Prox",t[t.Nuke=12]="Nuke",t[t.Rounds=13]="Rounds",t))(Sf||{}),Nw=Object.keys(Sf).length/2;var Ya=32,wr=(t=>(t[t.Auto=0]="Auto",t[t.Weapon=1]="Weapon",t[t.Voice=2]="Voice",t[t.Item=3]="Item",t[t.Body=4]="Body",t[t.Aux=5]="Aux",t[t.Footstep=6]="Footstep",t[t.Aux3=7]="Aux3",t[t.NoPhsAdd=8]="NoPhsAdd",t[t.Reliable=16]="Reliable",t[t.ForcePos=32]="ForcePos",t))(wr||{}),Yc=-1,$a=0,$c=1,qc=2,Zc=3,Bi=80,jc=.003;function Fi(t){return t*.001}function Qn(t){let e=Fi(t);return e<=0?Number.POSITIVE_INFINITY:Bi+1/e}var qa=class{constructor({name:e,defaultValue:r,description:n,flags:i=Us.None,onChange:a}){this.modifiedCount=0;this.name=e,this.defaultValue=r,this.description=n,this.flags=i,this._value=r,this.onChange=a}get string(){return this._value}getString(){return this.string}get number(){return Number(this._value)}getFloat(){return this.number}get integer(){return Math.trunc(this.number)}getInt(){return this.integer}get boolean(){return!!this.integer}getBoolean(){return this.boolean}set(e){if(this.flags&Us.Latch){if(e===this._value){this.latched=void 0;return}if(this.latched===e)return;this.latched!==e&&(this.latched=e);return}this.apply(e)}reset(){this.latched=void 0,this.apply(this.defaultValue)}applyLatched(){if(this.latched===void 0)return!1;let e=this.latched;return this.latched=void 0,e===this._value?!1:(this.apply(e),!0)}apply(e){if(this._value===e)return;let r=this._value;this._value=e,this.modifiedCount+=1,this.onChange?.(this,r)}},ki=class{constructor(){this.cvars=new Map}register(e){let r=this.cvars.get(e.name);if(r)return r;let n=e.onChange,i=(o,s)=>{n?.(o,s),this.onCvarChange?.(o.name,o.string)},a=new qa({...e,onChange:i});return this.cvars.set(e.name,a),a}get(e){return this.cvars.get(e)}getCvar(e){return this.get(e)}setValue(e,r){let n=this.get(e);if(!n)throw new Error(`Unknown cvar: ${e}`);return n.set(r),n}setCvar(e,r){this.setValue(e,r)}resetAll(){for(let e of this.cvars.values())e.reset()}applyLatched(){let e=!1;for(let r of this.cvars.values())e=r.applyLatched()||e;return e}list(){return[...this.cvars.values()].sort((e,r)=>e.name.localeCompare(r.name))}listCvars(){return this.list().map(e=>({name:e.name,value:e.string,defaultValue:e.defaultValue,flags:e.flags,description:e.description}))}};var Di=class{constructor(e,r,n={}){this.game=e;this.client=r;this.started=!1;this.paused_=!1;this.commands=new Ci;this.cvars=new ki;this.stepSimulation=e=>{this.previousFrame=this.latestFrame,this.latestFrame=this.game.frame(e,this.latestCommand)};this.renderClient=e=>{this.client&&(this.latestCommand=this.client.render({...e,previous:this.previousFrame,latest:this.latestFrame}))};let i=n.loop?.now?.()??Date.now();this.startTimeMs=n.startTimeMs??n.loop?.startTimeMs??i,this.loop=new Yn({simulate:this.stepSimulation,render:this.renderClient},{...n.loop,startTimeMs:this.startTimeMs}),this.commands.registerAutocompleteProvider(()=>this.cvars.list().map(a=>a.name))}start(){if(!this.started){try{this.latestFrame=this.game.init(this.startTimeMs)??this.latestFrame,this.client?.init(this.latestFrame)}catch(e){throw this.game.shutdown(),this.client?.shutdown(),e}this.started=!0,this.paused_=!1,this.loop.start()}}stop(){this.started&&(this.loop.stop(),this.client?.shutdown(),this.game.shutdown(),this.previousFrame=void 0,this.latestFrame=void 0,this.started=!1,this.paused_=!1)}setPaused(e){this.paused_=e,e?this.loop.stop():this.started&&this.loop.start()}get paused(){return this.paused_}pump(e){this.loop.pump(e)}getLatestFrame(){return this.latestFrame}isRunning(){return this.loop.isRunning()}};var zi=class{constructor(e){this.registry=e.registry,this.system=e.system,this.music=e.music,this.client=e.client}soundindex(e){return this.registry.registerName(e)}sound(e,r,n,i,a,o){this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:a,timeOffsetMs:o}),this.triggerSubtitle(n)}positioned_sound(e,r,n,i){this.system.positionedSound(e,r,n,i),this.triggerSubtitle(r)}loop_sound(e,r,n,i,a){let o=this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:a,looping:!0});return this.triggerSubtitle(n),o}stop_entity_sounds(e){this.system.stopEntitySounds(e)}setPlaybackRate(e){this.system.setPlaybackRate(e)}set_listener(e){this.system.setListener(e)}play_music(e,r=!0){return this.music?this.music.play(e,{loop:r}):Promise.resolve()}play_track(e,r=!0){return this.music?this.music.playTrack(e):Promise.resolve()}pause_music(){this.music?.pause()}resume_music(){return this.music?.resume()??Promise.resolve()}stop_music(){this.music?.stop()}set_music_volume(e){this.music?.setVolume(e)}play_ambient(e,r,n){this.system.ambientSound(e,r,n),this.triggerSubtitle(r)}play_channel(e){this.system.play({...e}),this.triggerSubtitle(e.soundIndex)}triggerSubtitle(e){if(!this.client)return;let r=this.registry.getName(e);if(!r)return;let n=r.match(/\[(.*?)\]/);n&&this.client.showSubtitle(n[1],r)}};var Za=class{constructor(e,r){this.engine=e;this.host=r;this.started=!1}start(){this.started||(this.engine.init(),this.host.start(),this.started=!0)}stop(){this.started&&(this.host.stop(),this.engine.shutdown(),this.started=!1)}pump(e){this.host.pump(e)}getLatestFrame(){return this.host.getLatestFrame()}isRunning(){return this.started&&this.host.isRunning()}};function wf(t,e,r,n,i){let a=new zi({...n,client:r}),o=new Di(e,r,i);return{runtime:new Za(t,o),audio:a}}function sg(t){if(t<0||t>=J.MaxConfigStrings)throw new RangeError(`Configstring index ${t} is out of range (0-${J.MaxConfigStrings-1})`)}function Mf(t,e){let r=yf(t);if(e.length>r)throw new RangeError(`Configstring ${t} exceeds maximum length (${e.length} > ${r}); limit is ${Va} chars per slot`)}var Oi=class{constructor(){this.values=new Map;this.modelCursor=J.Models;this.soundCursor=J.Sounds;this.imageCursor=J.Images;this.lightCursor=J.Lights;this.shadowLightCursor=J.ShadowLights;this.itemCursor=J.Items;this.playerSkinCursor=J.PlayerSkins;this.generalCursor=J.General}set(e,r){return sg(e),Mf(e,r),this.values.set(e,r),e}get(e){return this.values.get(e)}getName(e){return this.get(e)}getAll(){let e=new Array(gf).fill("");for(let[r,n]of this.values.entries())e[r]=n;return e}modelIndex(e){return this.register(e,J.Models,Vc,"modelCursor")}soundIndex(e){return this.register(e,J.Sounds,Hs,"soundCursor")}findSoundIndex(e){for(let r=J.Sounds;r<J.Sounds+Hs;r+=1)if(this.values.get(r)===e)return r}imageIndex(e){return this.register(e,J.Images,Gc,"imageCursor")}lightIndex(e){return this.register(e,J.Lights,Hc,"lightCursor")}shadowLightIndex(e){return this.register(e,J.ShadowLights,Kc,"shadowLightCursor")}itemIndex(e){return this.register(e,J.Items,Wc,"itemCursor")}playerSkinIndex(e){return this.register(e,J.PlayerSkins,Ns,"playerSkinCursor")}generalIndex(e){return this.register(e,J.General,Xc,"generalCursor")}register(e,r,n,i){for(let s=r;s<r+n;s+=1)if(this.values.get(s)===e)return s;let a=this[i],o=r+n;if(a>=o)throw new RangeError(`Out of configstring slots for range starting at ${r}`);return Mf(a,e),this.values.set(a,e),this[i]=a+1,a}};var lg="PACK";function cg(t,e,r){let n=[];for(let i=0;i<r;i+=1){let a=t.getUint8(e+i);if(a===0)break;n.push(a)}return String.fromCharCode(...n)}function _e(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}function dg(){let t=new Uint32Array(256);for(let e=0;e<256;e+=1){let r=e;for(let n=0;n<8;n+=1)r=(r&1)!==0?3988292384^r>>>1:r>>>1;t[e]=r>>>0}return t}var ug=dg();function Af(t){let e=4294967295;for(let r=0;r<t.length;r+=1){let n=t[r];e=ug[(e^n)&255]^e>>>8}return(e^4294967295)>>>0}var Ie=class extends Error{},Ui=class t{constructor(e,r,n,i){this.name=e;this.buffer=r;this.entries=new Map(n.map(a=>[a.name,a])),this.checksum=i,this.size=r.byteLength}static fromArrayBuffer(e,r){let n=new DataView(r);if(r.byteLength<12)throw new Ie("PAK buffer too small to contain header");let i=String.fromCharCode(n.getUint8(0),n.getUint8(1),n.getUint8(2),n.getUint8(3));if(i!==lg)throw new Ie(`Invalid PAK header magic: ${i}`);let a=n.getInt32(4,!0),o=n.getInt32(8,!0);if(a<12)throw new Ie(`Invalid directory offset: ${a}`);if(o<0||o%64!==0)throw new Ie(`Invalid directory length: ${o}`);if(a+o>r.byteLength)throw new Ie("Directory exceeds buffer length");let c=o/64,l=[],d=new Map;for(let f=0;f<c;f+=1){let u=a+f*64,h=cg(n,u,56),m=_e(h),g=n.getInt32(u+56,!0),p=n.getInt32(u+60,!0);if(g<0||p<0||g+p>r.byteLength)throw new Ie(`Invalid entry bounds for ${h||"<unnamed>"} (offset=${g}, length=${p})`);if(!m)throw new Ie(`Entry ${f} has an empty name`);let y={name:m,offset:g,length:p};d.set(m,y)}return l.push(...d.values()),new t(e,r,l,Af(new Uint8Array(r)))}getEntry(e){return this.entries.get(_e(e))}listEntries(){return Array.from(this.entries.values())}list(){return Array.from(this.entries.keys())}readFile(e){let r=this.getEntry(e);if(!r)throw new Ie(`File not found in PAK: ${e}`);return new Uint8Array(this.buffer,r.offset,r.length)}validate(){return{checksum:this.checksum,entries:this.listEntries()}}};function Ef(t){return Af(new Uint8Array(t))}var fg="PACK",Lf=12,Qc=64;function Tf(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}var Vs=class{constructor(e){this.source=e;this.entries=null}async readDirectory(){if(this.entries)return Array.from(this.entries.values());let e=await this.readChunk(0,Lf),r=new DataView(e),n=String.fromCharCode(r.getUint8(0),r.getUint8(1),r.getUint8(2),r.getUint8(3));if(n!==fg)throw new Ie(`Invalid PAK header magic: ${n}`);let i=r.getInt32(4,!0),a=r.getInt32(8,!0);if(i<Lf)throw new Ie(`Invalid directory offset: ${i}`);if(a<0||a%Qc!==0)throw new Ie(`Invalid directory length: ${a}`);let o=await this.readChunk(i,a),s=new DataView(o),c=a/Qc,l=new Map;for(let d=0;d<c;d++){let f=d*Qc,u=this.readCString(s,f,56),h=Tf(u),m=s.getInt32(f+56,!0),g=s.getInt32(f+60,!0);m<0||g<0||m+g>this.source.size,h&&l.set(h,{name:h,offset:m,length:g})}return this.entries=l,Array.from(l.values())}async readFile(e){let r=await this.getEntry(e);if(!r)throw new Ie(`File not found in PAK: ${e}`);return this.source.slice(r.offset,r.offset+r.length).stream()}async getFileBlob(e){let r=await this.getEntry(e);if(!r)throw new Ie(`File not found in PAK: ${e}`);return this.source.slice(r.offset,r.offset+r.length)}async getEntry(e){return this.entries||await this.readDirectory(),this.entries.get(Tf(e))}async readChunk(e,r){let n=this.source.slice(e,e+r);return"arrayBuffer"in n?await n.arrayBuffer():new Response(n).arrayBuffer()}readCString(e,r,n){let i=[];for(let a=0;a<n;a+=1){let o=e.getUint8(r+a);if(o===0)break;i.push(o)}return String.fromCharCode(...i)}};var Jc=12,Rf=64,Gs=class t{constructor(){this.entries=new Map}addFile(e,r){let n=_e(e);if(n.length>56)throw new Error(`Path too long: '${n}' (max 56 chars)`);this.entries.set(n,r)}removeFile(e){return this.entries.delete(_e(e))}build(){let e=0;for(let u of this.entries.values())e+=u.byteLength;let r=this.entries.size*Rf,n=Jc+e+r,i=new Uint8Array(n),a=new DataView(i.buffer);a.setUint8(0,80),a.setUint8(1,65),a.setUint8(2,67),a.setUint8(3,75);let o=Jc+e;a.setInt32(4,o,!0),a.setInt32(8,r,!0);let s=Jc,c=new Map,l=Array.from(this.entries.keys()).sort();for(let u of l){let h=this.entries.get(u);c.set(u,s),i.set(h,s),s+=h.byteLength}let d=o,f=new TextEncoder;for(let u of l){let h=this.entries.get(u),m=f.encode(u);if(m.length>56)throw new Error(`Path too long after encoding: ${u}`);for(let g=0;g<56;g++)g<m.length?a.setUint8(d+g,m[g]):a.setUint8(d+g,0);a.setInt32(d+56,c.get(u),!0),a.setInt32(d+60,h.byteLength,!0),d+=Rf}return i}static buildFromEntries(e){let r=new t;for(let[n,i]of e)r.addFile(n,i);return r.build()}};var ed=(o=>(o.Texture="texture",o.Sound="sound",o.Model="model",o.Map="map",o.Sprite="sprite",o.ConfigString="configString",o))(ed||{}),Ws=class{constructor(){this.tracking=!1;this.entries=[];this.currentFrame=0;this.currentTime=0}startTracking(){this.tracking=!0,this.entries=[]}stopTracking(){this.tracking=!1;let e={byFrame:new Map,byTime:new Map,uniqueResources:new Map};for(let r of this.entries){e.byFrame.has(r.frame)||e.byFrame.set(r.frame,[]),e.byFrame.get(r.frame).push(r),e.byTime.has(r.timestamp)||e.byTime.set(r.timestamp,[]),e.byTime.get(r.timestamp).push(r);let n=`${r.type}:${r.path}`;e.uniqueResources.has(n)||e.uniqueResources.set(n,r)}return e}recordLoad(e,r,n,i){this.tracking&&this.entries.push({type:e,path:r,timestamp:this.currentTime,frame:this.currentFrame,size:n,pakSource:i})}setCurrentFrame(e){this.currentFrame=e}setCurrentTime(e){this.currentTime=e}};var Xs=class{constructor(e=[]){this.mounts=[];this.files=new Map;e.forEach(r=>this.mountPak(r))}mountPak(e,r=0){let n=this.mounts.findIndex(i=>i.pak===e);n!==-1&&this.mounts.splice(n,1),this.mounts.push({pak:e,priority:r}),this.mounts.sort((i,a)=>a.priority-i.priority);for(let i of e.listEntries()){let a=_e(i.name),o={archive:e,entry:i,priority:r};this.files.has(a)||this.files.set(a,[]);let s=this.files.get(a),c=s.findIndex(l=>l.archive===e);c!==-1&&s.splice(c,1),s.unshift(o),s.sort((l,d)=>d.priority-l.priority)}return e}setPriority(e,r){this.mountPak(e,r)}getPaks(){return[...this.mounts].sort((e,r)=>e.priority-r.priority)}get mountedPaks(){return this.mounts.map(e=>e.pak)}hasFile(e){return this.files.has(_e(e))}getSource(e){let r=this.files.get(_e(e));if(!(!r||r.length===0))return r[0]}stat(e){let r=this.getSource(e);if(r)return{path:r.entry.name,size:r.entry.length,sourcePak:r.archive.name}}getFileMetadata(e){let r=this.getSource(e);if(r)return{path:r.entry.name,size:r.entry.length,sourcePak:r.archive.name,offset:r.entry.offset}}async readFile(e){let r=this.getSource(e);if(!r)throw new Error(`File not found in VFS: ${e}`);return r.archive.readFile(e)}async readBinaryFile(e){return this.readFile(e)}streamFile(e,r=1024*1024){let n=this.getSource(e);if(!n)throw new Error(`File not found in VFS: ${e}`);let{archive:i}=n,a=i.readFile(e),o=0,s=a.length;return new ReadableStream({pull(c){if(o>=s){c.close();return}let l=Math.min(o+r,s),d=a.slice(o,l);o=l,c.enqueue(d)}})}async readTextFile(e){let r=await this.readFile(e);return new TextDecoder("utf-8").decode(r)}list(e=""){let r=_e(e).replace(/\/+$|^\//g,""),n=[],i=new Set,a=r?`${r}/`:"";for(let[o,s]of this.files){let c=s[0];if(r&&!c.entry.name.startsWith(a))continue;let l=r?c.entry.name.slice(a.length):c.entry.name,d=l.indexOf("/");d===-1?n.push({path:c.entry.name,size:c.entry.length,sourcePak:c.archive.name}):i.add(l.slice(0,d))}return n.sort((o,s)=>o.path.localeCompare(s.path)),{files:n,directories:[...i].sort()}}async listDirectory(e){return this.list(e).files}findByExtension(e){if(e instanceof RegExp)return this.searchFiles(e);if(Array.isArray(e))return this.listByExtension(e);let r=e.startsWith(".")?e.toLowerCase():`.${e.toLowerCase()}`,n=[];for(let[i,a]of this.files){let o=a[0];o.entry.name.toLowerCase().endsWith(r)&&n.push({path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name})}return n.sort((i,a)=>i.path.localeCompare(a.path))}listByExtension(e){let r=new Set(e.map(i=>i.startsWith(".")?i.toLowerCase():`.${i.toLowerCase()}`)),n=[];for(let[i,a]of this.files){let o=a[0],s=o.entry.name.toLowerCase();for(let c of r)if(s.endsWith(c)){n.push({path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name});break}}return n.sort((i,a)=>i.path.localeCompare(a.path))}searchFiles(e){let r=[];for(let[n,i]of this.files){let a=i[0];e.test(a.entry.name)&&r.push({path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name})}return r.sort((n,i)=>n.path.localeCompare(i.path))}getPakInfo(){return this.mounts.map(e=>({filename:e.pak.name,entryCount:e.pak.listEntries().length,totalSize:e.pak.size,priority:e.priority}))}getDirectoryTree(){let e={name:"",path:"",files:[],directories:[]},r=new Map;r.set("",e);let n=Array.from(this.files.values()).map(i=>{let a=i[0];return{path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name}}).sort((i,a)=>i.path.localeCompare(a.path));for(let i of n){let a=i.path.split("/"),o=a.pop(),s="",c=e;for(let l of a){let d=s;s=s?`${s}/${l}`:l;let f=r.get(s);f||(f={name:l,path:s,files:[],directories:[]},c.directories.push(f),r.set(s,f)),c=f}c.files.push(i)}return e}};var td=Object.freeze([{name:"pak0.pak",checksum:2378051181,description:"Base game assets"},{name:"pak0.pak@baseq2",checksum:2378051181,description:"Base game assets (baseq2)"},{name:"pak0.pak@rogue",checksum:3373211245,description:"Ground Zero (rogue) mission pack"},{name:"pak0.pak@xatrix",checksum:1358269824,description:"The Reckoning (xatrix) mission pack"}]),Jn=class extends Error{constructor(r){super(r.status==="unknown"?`Unknown PAK not allowed: ${r.name}`:`PAK checksum mismatch for ${r.name}`);this.result=r;this.name="PakValidationError"}},Ks=class{constructor(e=td){this.known=new Map;e.forEach(r=>this.known.set(this.normalizePakName(r.name),r))}validateArchive(e,r){let n=this.normalizePakName(r??("name"in e?e.name:"unknown")),i=e.checksum,a="size"in e?e.size:void 0,o=this.known.get(n);return o?o.checksum!==i?{name:n,checksum:i,expectedChecksum:o.checksum,status:"mismatch",size:a,description:o.description}:{name:n,checksum:i,expectedChecksum:o.checksum,status:"valid",size:a,description:o.description}:{name:n,checksum:i,status:"unknown",size:a}}assertValid(e,r){let n=this.validateArchive(e,r);if(n.status==="mismatch")throw new Jn(n);return n}normalizePakName(e){let r=_e(e),n=r.split("/"),i=n.pop()??r,a=n.pop();return a?`${i}@${a}`:i}};var pn=class extends Error{constructor(r,n){super(`Failed to ingest PAK: ${r}`);this.file=r;this.name="PakIngestionError",n instanceof Error&&n.stack&&(this.stack=n.stack),this.cause=n}};async function hg(t,e){if(typeof t.arrayBuffer=="function"){let r=await t.arrayBuffer();return e?.({file:"blob",loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}if(typeof FileReader<"u")return new Promise((r,n)=>{let i=new FileReader;i.onerror=()=>n(i.error??new Error("Unknown FileReader error")),i.onprogress=a=>{e?.({file:"blob",loadedBytes:a.loaded,totalBytes:a.total||t.size,state:"reading"})},i.onload=()=>{let a=i.result;a instanceof ArrayBuffer?r(a):n(new Error("Unexpected FileReader result"))},i.readAsArrayBuffer(t)});if(typeof Response<"u"){let r=await new Response(t).arrayBuffer();return e?.({file:"blob",loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}if(typeof t.stream=="function"){let r=t.stream().getReader(),n=[],i=0;for(;;){let{done:s,value:c}=await r.read();if(s)break;if(!c)continue;let l=c;n.push(l),i+=l.byteLength,e?.({file:"blob",loadedBytes:i,totalBytes:t.size,state:"reading"})}let a=new Uint8Array(i),o=0;for(let s of n)a.set(s,o),o+=s.byteLength;return a.buffer}throw new pn("blob",new Error("Unsupported Blob type"))}async function mg(t,e){if(t.data instanceof ArrayBuffer)return e?.({file:t.name,loadedBytes:t.data.byteLength,totalBytes:t.data.byteLength,state:"reading"}),t.data;if(t.data instanceof Blob){let n=t.data.size;return hg(t.data,i=>e?.({...i,file:t.name,totalBytes:n}))}let r=t.data.buffer.slice(t.data.byteOffset,t.data.byteOffset+t.data.byteLength);return e?.({file:t.name,loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}async function Ys(t,e,r){let n=typeof r=="function"?{onProgress:r}:r??{},i=n.persistIndexes??!!n.pakIndexStore,a=n.enforceValidation??!!n.validator,o=n.allowUnknownPaks??!0,s=n.stopOnError??!1,c=[];for(let l of e)try{let d=await mg(l,n.onProgress),f=Ui.fromArrayBuffer(l.name,d),u=n.validator?.validateArchive(f);if(u){n.onValidationResult?.(u);let h=u.status==="mismatch",m=u.status==="unknown";if(h&&a||m&&!o){let g=new Jn(u);if(n.onError?.(l.name,g),s)throw new pn(l.name,g);c.push({archive:f,mounted:!1,validation:u});continue}}if(t.mountPak(f),i&&n.pakIndexStore)try{await n.pakIndexStore.persist(f)}catch(h){if(n.onError?.(l.name,h),s)throw new pn(l.name,h)}n.onProgress?.({file:l.name,loadedBytes:d.byteLength,totalBytes:d.byteLength,state:"parsed"}),c.push({archive:f,mounted:!0,validation:u})}catch(d){if(n.onProgress?.({file:l.name,loadedBytes:0,totalBytes:0,state:"error"}),n.onError?.(l.name,d),s)throw new pn(l.name,d)}return c}var gn=class{constructor(e,r=1/0,n=()=>0){this._capacity=e;this._maxMemory=r;this.sizeCalculator=n;this.map=new Map;this.currentMemoryUsage=0;if(e<=0)throw new RangeError("LRU cache capacity must be greater than zero")}get size(){return this.map.size}get memoryUsage(){return this.currentMemoryUsage}get capacity(){return this._capacity}set capacity(e){if(e<=0)throw new RangeError("LRU cache capacity must be greater than zero");this._capacity=e,this.evict()}get maxMemory(){return this._maxMemory}set maxMemory(e){this._maxMemory=e,this.evict()}has(e){return this.map.has(e)}get(e){let r=this.map.get(e);if(r!==void 0)return this.map.delete(e),this.map.set(e,r),r}set(e,r){let n=this.sizeCalculator(r);this.map.has(e)&&this.delete(e),this.map.set(e,r),this.currentMemoryUsage+=n,this.evict()}delete(e){let r=this.map.get(e);return r!==void 0?(this.currentMemoryUsage-=this.sizeCalculator(r),this.map.delete(e)):!1}clear(){this.map.clear(),this.currentMemoryUsage=0}entries(){return Array.from(this.map.entries()).reverse().map(([e,r])=>({key:e,value:r}))}evict(){for(;this.map.size>this._capacity;){let e=this.map.keys().next();if(!e.done)this.delete(e.value);else break}for(;this.currentMemoryUsage>this._maxMemory&&this.map.size>0;){let e=this.map.keys().next();if(!e.done)this.delete(e.value);else break}}};function pg(t){return Array.isArray(t)?t:Array.from(t)}function rd(t){return pg(t).map(e=>({name:e.name,data:e}))}async function Cf(t,e,r){let n=rd(e);return Ys(t,n,r??{})}function Pf(t,e){let r=i=>{i.preventDefault(),i.dataTransfer?.dropEffect&&(i.dataTransfer.dropEffect="copy")},n=i=>{i.preventDefault();let a=i.dataTransfer?.files;a&&a.length>0&&e(Array.from(a))};return t.addEventListener("dragover",r),t.addEventListener("drop",n),()=>{t.removeEventListener("dragover",r),t.removeEventListener("drop",n)}}function If(t,e){let r=n=>{let i=n.target;!i||!i.files||i.files.length===0||(e(i.files),i.value="")};return t.addEventListener("change",r),()=>t.removeEventListener("change",r)}var gg="IBSP",yg=38,Ff=19,bg=8+Ff*8;var se=class extends Error{},Ni=class{constructor(e,r={}){this.vfs=e;this.options=r}async load(e){let r=await this.vfs.readFile(e),n=new Uint8Array(r.byteLength);if(n.set(new Uint8Array(r)),this.options.useWorker&&typeof Worker<"u")try{let i=await this.parseInWorker(n.buffer);return kf(i)}catch(i){console.warn("BSP worker parsing failed, falling back to main thread",i)}return ja(n.buffer)}parseInWorker(e){return new Promise((r,n)=>{if(!this.options.workerPath){n(new Error("No worker path provided"));return}let i=new Worker(this.options.workerPath,{type:"module"});i.onmessage=a=>{let{type:o,data:s,message:c}=a.data;o==="success"?(r(this.rehydrateData(s)),i.terminate()):(n(new Error(c)),i.terminate())},i.onerror=a=>{n(a),i.terminate()},i.postMessage(e,[e])})}rehydrateData(e){if(e.entities&&!e.entities.getUniqueClassnames){let r=e.entities;r.getUniqueClassnames=function(){let n=new Set;for(let i of this.entities)i.classname&&n.add(i.classname);return Array.from(n).sort()}}return e}};function ja(t){let e=xg(t);return kf(e)}function kf(t){return{...t,pickEntity(e){let r=null,n=1/0;for(let i of t.entities.entities){let a=i.properties.model;if(!a||!a.startsWith("*"))continue;let o=parseInt(a.substring(1),10);if(isNaN(o)||o<0||o>=t.models.length)continue;let s=t.models[o],c=vg(e.origin,e.direction,s.mins,s.maxs);c!==null&&c<n&&(n=c,r={entity:i,model:s,distance:c})}return r},findLeaf(e){let n=t.models[0].headNode;for(;n>=0;){let i=t.nodes[n],a=t.planes[i.planeIndex];a.normal[0]*e[0]+a.normal[1]*e[1]+a.normal[2]*e[2]-a.dist>=0?n=i.children[0]:n=i.children[1]}return t.leafs[-(n+1)]},calculatePVS(e){let r=this.findLeaf(e);if(!(r.cluster===-1||!t.visibility)&&!(r.cluster<0||r.cluster>=t.visibility.clusters.length))return t.visibility.clusters[r.cluster].pvs}}}function xg(t){if(t.byteLength<bg)throw new se("BSP too small to contain header");let e=new DataView(t),r=String.fromCharCode(e.getUint8(0),e.getUint8(1),e.getUint8(2),e.getUint8(3));if(r!==gg)throw new se(`Invalid BSP magic ${r}`);let n=e.getInt32(4,!0);if(n!==yg)throw new se(`Unsupported BSP version ${n}`);let i=new Map;for(let E=0;E<Ff;E+=1){let L=e.getInt32(8+E*8,!0),M=e.getInt32(12+E*8,!0);if(L<0||M<0||L+M>t.byteLength)throw new se(`Invalid lump bounds for index ${E}`);i.set(E,{offset:L,length:M})}let a={version:n,lumps:i},o=_g(t,i.get(0)),s=wg(t,i.get(1)),c=Mg(t,i.get(2)),l=Ag(t,i.get(4)),d=Eg(t,i.get(5)),f=Lg(t,i.get(6)),u=new Uint8Array(t,i.get(7).offset,i.get(7).length),h=Ug(f,i.get(7)),m=Tg(t,i.get(8)),g=Rg(t,i.get(11)),p=Cg(t,i.get(12)),y=Pg(t,i.get(13)),v=Ig(t,i.get(14)),x=Bg(t,i.get(15)),b=zg(t,i.get(9),i.get(10),m),_=Og(t,i.get(3)),w=Fg(t,i.get(17)),S=kg(t,i.get(18));return{header:a,entities:o,planes:s,vertices:c,nodes:l,texInfo:d,faces:f,lightMaps:u,lightMapInfo:h,leafs:m,leafLists:b,edges:g,surfEdges:p,models:y,brushes:v,brushSides:x,visibility:_,areas:w,areaPortals:S}}function vg(t,e,r,n){let i=0,a=1/0;for(let o=0;o<3;o++)if(Math.abs(e[o])<1e-8){if(t[o]<r[o]||t[o]>n[o])return null}else{let s=1/e[o],c=(r[o]-t[o])*s,l=(n[o]-t[o])*s;if(c>l){let d=c;c=l,l=d}if(i=Math.max(i,c),a=Math.min(a,l),i>a)return null}return i}function _g(t,e){let r=new TextDecoder().decode(new Uint8Array(t,e.offset,e.length)),n=Sg(r),i=n.find(a=>a.classname==="worldspawn");return{raw:r,entities:n,worldspawn:i,getUniqueClassnames(){let a=new Set;for(let o of n)o.classname&&a.add(o.classname);return Array.from(a).sort()}}}function Sg(t){let e=[],r=/\{([^}]*)\}/gms,n;for(;(n=r.exec(t))!==null;){let i=n[1],a={},o=/"([^\"]*)"\s+"([^\"]*)"/g,s;for(;(s=o.exec(i))!==null;)a[s[1]]=s[2];e.push({classname:a.classname,properties:a})}return e}function wg(t,e){let r=new DataView(t,e.offset,e.length),n=e.length/20;if(n%1!==0)throw new se("Plane lump has invalid length");let i=[];for(let a=0;a<n;a+=1){let o=[r.getFloat32(a*20,!0),r.getFloat32(a*20+4,!0),r.getFloat32(a*20+8,!0)],s=r.getFloat32(a*20+12,!0),c=r.getInt32(a*20+16,!0);i.push({normal:o,dist:s,type:c})}return i}function Mg(t,e){let r=new DataView(t,e.offset,e.length),n=e.length/12;if(n%1!==0)throw new se("Vertex lump has invalid length");let i=[];for(let a=0;a<n;a+=1)i.push([r.getFloat32(a*12,!0),r.getFloat32(a*12+4,!0),r.getFloat32(a*12+8,!0)]);return i}function Ag(t,e){let r=new DataView(t,e.offset,e.length),n=28,i=e.length/n;if(i%1!==0)throw new se("Node lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=[r.getInt32(s+4,!0),r.getInt32(s+8,!0)],d=[r.getInt16(s+12,!0),r.getInt16(s+14,!0),r.getInt16(s+16,!0)],f=[r.getInt16(s+18,!0),r.getInt16(s+20,!0),r.getInt16(s+22,!0)],u=r.getUint16(s+24,!0),h=r.getUint16(s+26,!0);a.push({planeIndex:c,children:l,mins:d,maxs:f,firstFace:u,numFaces:h})}return a}function Eg(t,e){let r=new DataView(t,e.offset,e.length),n=76,i=e.length/n;if(i%1!==0)throw new se("TexInfo lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=[r.getFloat32(s,!0),r.getFloat32(s+4,!0),r.getFloat32(s+8,!0)],l=r.getFloat32(s+12,!0),d=[r.getFloat32(s+16,!0),r.getFloat32(s+20,!0),r.getFloat32(s+24,!0)],f=r.getFloat32(s+28,!0),u=r.getInt32(s+32,!0),h=r.getInt32(s+36,!0),m=new Uint8Array(t,e.offset+s+40,32),g=new TextDecoder("utf-8").decode(m).replace(/\0.*$/,""),p=r.getInt32(s+72,!0);a.push({s:c,sOffset:l,t:d,tOffset:f,flags:u,value:h,texture:g,nextTexInfo:p})}return a}function Lg(t,e){let r=new DataView(t,e.offset,e.length),n=20,i=e.length/n;if(i%1!==0)throw new se("Face lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getUint16(s,!0),l=r.getInt16(s+2,!0),d=r.getInt32(s+4,!0),f=r.getInt16(s+8,!0),u=r.getInt16(s+10,!0),h=[r.getUint8(s+12),r.getUint8(s+13),r.getUint8(s+14),r.getUint8(s+15)],m=r.getInt32(s+16,!0);a.push({planeIndex:c,side:l,firstEdge:d,numEdges:f,texInfo:u,styles:h,lightOffset:m})}return a}function Tg(t,e){let r=new DataView(t,e.offset,e.length),n=28,i=e.length/n;if(i%1!==0)throw new se("Leaf lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=r.getInt16(s+4,!0),d=r.getInt16(s+6,!0),f=[r.getInt16(s+8,!0),r.getInt16(s+10,!0),r.getInt16(s+12,!0)],u=[r.getInt16(s+14,!0),r.getInt16(s+16,!0),r.getInt16(s+18,!0)],h=r.getUint16(s+20,!0),m=r.getUint16(s+22,!0),g=r.getUint16(s+24,!0),p=r.getUint16(s+26,!0);a.push({contents:c,cluster:l,area:d,mins:f,maxs:u,firstLeafFace:h,numLeafFaces:m,firstLeafBrush:g,numLeafBrushes:p})}return a}function Rg(t,e){let r=new DataView(t,e.offset,e.length),n=4,i=e.length/n;if(i%1!==0)throw new se("Edge lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n;a.push({vertices:[r.getUint16(s,!0),r.getUint16(s+2,!0)]})}return a}function Cg(t,e){let r=e.length/4;if(r%1!==0)throw new se("SurfEdge lump has invalid length");let n=new DataView(t,e.offset,e.length),i=new Int32Array(r);for(let a=0;a<r;a+=1)i[a]=n.getInt32(a*4,!0);return i}function Pg(t,e){let r=new DataView(t,e.offset,e.length),n=48;if(e.length%n!==0)throw new se("Model lump has invalid length");let i=e.length/n,a=[];for(let o=0;o<i;o+=1){let s=o*n,c=[r.getFloat32(s,!0),r.getFloat32(s+4,!0),r.getFloat32(s+8,!0)],l=[r.getFloat32(s+12,!0),r.getFloat32(s+16,!0),r.getFloat32(s+20,!0)],d=[r.getFloat32(s+24,!0),r.getFloat32(s+28,!0),r.getFloat32(s+32,!0)],f=r.getInt32(s+36,!0),u=r.getInt32(s+40,!0),h=r.getInt32(s+44,!0);a.push({mins:c,maxs:l,origin:d,headNode:f,firstFace:u,numFaces:h})}return a}function Ig(t,e){let r=new DataView(t,e.offset,e.length),n=12,i=e.length/n;if(i%1!==0)throw new se("Brush lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n;a.push({firstSide:r.getInt32(s,!0),numSides:r.getInt32(s+4,!0),contents:r.getInt32(s+8,!0)})}return a}function Bg(t,e){let r=new DataView(t,e.offset,e.length),n=4,i=e.length/n;if(i%1!==0)throw new se("Brush side lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n;a.push({planeIndex:r.getUint16(s,!0),texInfo:r.getInt16(s+2,!0)})}return a}function Fg(t,e){let r=new DataView(t,e.offset,e.length),n=8,i=e.length/n;if(i%1!==0)throw new se("Area lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);a.push({numAreaPortals:c,firstAreaPortal:l})}return a}function kg(t,e){return Dg(t,e)}function Dg(t,e){let r=new DataView(t,e.offset,e.length),n=8,i=e.length/n;if(i%1!==0)throw new se("AreaPortal lump has invalid length");let a=[];for(let o=0;o<i;o+=1){let s=o*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);a.push({portalNumber:c,otherArea:l})}return a}function zg(t,e,r,n){let i=[],a=[],o=e.length/2,s=r.length/2,c=new DataView(t,e.offset,e.length),l=new DataView(t,r.offset,r.length);for(let d of n){if(d.firstLeafFace+d.numLeafFaces>o)throw new se("Leaf faces reference data past lump bounds");if(d.firstLeafBrush+d.numLeafBrushes>s)throw new se("Leaf brushes reference data past lump bounds");let f=[];for(let h=0;h<d.numLeafFaces;h+=1)f.push(c.getUint16((d.firstLeafFace+h)*2,!0));let u=[];for(let h=0;h<d.numLeafBrushes;h+=1)u.push(l.getUint16((d.firstLeafBrush+h)*2,!0));i.push(f),a.push(u)}return{leafFaces:i,leafBrushes:a}}function Og(t,e){if(e.length===0)return;if(e.length<4)throw new se("Visibility lump too small");let r=new DataView(t,e.offset,e.length),n=r.getInt32(0,!0),i=4+n*8;if(n<0||i>e.length)throw new se("Visibility lump truncated");let a=4,o=[];for(let s=0;s<n;s+=1){let c=r.getInt32(a,!0),l=r.getInt32(a+4,!0);a+=8;let d=e.offset+c,f=e.offset+l,u=e.offset+e.length;if(c<0||l<0||d>=u||f>=u)throw new se("Visibility offsets out of range");o.push({pvs:Bf(t,d,n,e),phs:Bf(t,f,n,e)})}return{numClusters:n,clusters:o}}function Bf(t,e,r,n){let i=Math.ceil(r/8),a=new Uint8Array(i),o=new Uint8Array(t),s=e,c=0,l=n.offset+n.length;for(;c<i;){if(s>=l)throw new se("Visibility data truncated");let d=o[s++];if(d!==0){a[c++]=d;continue}if(s>=l)throw new se("Visibility run exceeds lump bounds");let f=o[s++];for(let u=0;u<f&&c<i;u+=1)a[c++]=0}return a}function Ug(t,e){return t.map(r=>{if(!(r.lightOffset<0))return{offset:r.lightOffset,length:Math.max(0,e.length-r.lightOffset)}})}function $s(t,e,r){if(t.lightOffset<0||t.lightOffset>=e.byteLength)return;let n=e.byteLength-t.lightOffset,i=Math.min(r?.length??n,n);if(!(i<=0))return e.subarray(t.lightOffset,t.lightOffset+i)}var Ng=844121161,Hg=8,Df=68,qe=class extends Error{},Hi=class{constructor(e){this.vfs=e;this.cache=new Map}async load(e){if(this.cache.has(e))return this.cache.get(e);let r=await this.vfs.readFile(e),n=new Uint8Array(r.byteLength);n.set(r);let i=nd(n.buffer);return this.cache.set(e,i),i}get(e){return this.cache.get(e)}};function zf(t,e,r){let n=[];for(let i=0;i<r;i+=1){let a=t.getUint8(e+i);if(a===0)break;n.push(a)}return String.fromCharCode(...n)}function Qa(t,e,r,n){if(r!==0&&(e<Df||e+r>t.byteLength))throw new qe(`${n} section is out of bounds`)}function Vg(t){if(t.byteLength<Df)throw new qe("MD2 buffer too small to contain header");let e=new DataView(t),r=e.getInt32(0,!0),n=e.getInt32(4,!0);if(r!==Ng)throw new qe(`Invalid MD2 ident: ${r}`);if(n!==Hg)throw new qe(`Unsupported MD2 version: ${n}`);let i={ident:r,version:n,skinWidth:e.getInt32(8,!0),skinHeight:e.getInt32(12,!0),frameSize:e.getInt32(16,!0),numSkins:e.getInt32(20,!0),numVertices:e.getInt32(24,!0),numTexCoords:e.getInt32(28,!0),numTriangles:e.getInt32(32,!0),numGlCommands:e.getInt32(36,!0),numFrames:e.getInt32(40,!0),offsetSkins:e.getInt32(44,!0),offsetTexCoords:e.getInt32(48,!0),offsetTriangles:e.getInt32(52,!0),offsetFrames:e.getInt32(56,!0),offsetGlCommands:e.getInt32(60,!0),offsetEnd:e.getInt32(64,!0),magic:r},a=40+i.numVertices*4;if(i.frameSize!==a)throw new qe(`Unexpected frame size ${i.frameSize}, expected ${a}`);if(i.offsetEnd>t.byteLength)throw new qe("MD2 offset_end exceeds buffer length");return i}function Gg(t,e){let r=e.numSkins*64;Qa(t,e.offsetSkins,r,"skins");let n=new DataView(t,e.offsetSkins,r),i=[];for(let a=0;a<e.numSkins;a+=1)i.push({name:zf(n,a*64,64)});return i}function Wg(t,e){let r=e.numTexCoords*4;Qa(t,e.offsetTexCoords,r,"texcoords");let n=new DataView(t,e.offsetTexCoords,r),i=[];for(let a=0;a<e.numTexCoords;a+=1){let o=a*4;i.push({s:n.getInt16(o,!0),t:n.getInt16(o+2,!0)})}return i}function Xg(t,e){let r=e.numTriangles*12;Qa(t,e.offsetTriangles,r,"triangles");let n=new DataView(t,e.offsetTriangles,r),i=[];for(let a=0;a<e.numTriangles;a+=1){let o=a*12,s=[n.getUint16(o,!0),n.getUint16(o+2,!0),n.getUint16(o+4,!0)],c=[n.getUint16(o+6,!0),n.getUint16(o+8,!0),n.getUint16(o+10,!0)];if(s.some(l=>l>=e.numVertices)||c.some(l=>l>=e.numTexCoords))throw new qe("Triangle references out of range vertex or texcoord");i.push({vertexIndices:s,texCoordIndices:c})}return i}function Kg(t,e){let r=e.numFrames*e.frameSize;Qa(t,e.offsetFrames,r,"frames");let n=[];for(let i=0;i<e.numFrames;i+=1){let a=e.offsetFrames+i*e.frameSize,o=new DataView(t,a,e.frameSize),s={x:o.getFloat32(0,!0),y:o.getFloat32(4,!0),z:o.getFloat32(8,!0)},c={x:o.getFloat32(12,!0),y:o.getFloat32(16,!0),z:o.getFloat32(20,!0)},l=zf(o,24,16),d=[],f=1/0,u=1/0,h=1/0,m=-1/0,g=-1/0,p=-1/0;for(let y=0;y<e.numVertices;y+=1){let v=40+y*4,x=o.getUint8(v)*s.x+c.x,b=o.getUint8(v+1)*s.y+c.y,_=o.getUint8(v+2)*s.z+c.z;x<f&&(f=x),b<u&&(u=b),_<h&&(h=_),x>m&&(m=x),b>g&&(g=b),_>p&&(p=_);let w={x,y:b,z:_},S=o.getUint8(v+3),E=or[S];if(!E)throw new qe(`Invalid normal index ${S} in frame ${l}`);let L={x:E[0],y:E[1],z:E[2]};d.push({position:w,normalIndex:S,normal:L})}n.push({name:l,vertices:d,minBounds:{x:f,y:u,z:h},maxBounds:{x:m,y:g,z:p}})}return n}function Yg(t,e){let r=e.numGlCommands*4;if(Qa(t,e.offsetGlCommands,r,"gl commands"),r===0)return[];let n=new DataView(t,e.offsetGlCommands,r),i=[],a=0;for(;;){if(a+4>r)throw new qe("GL command list ended unexpectedly");let o=n.getInt32(a,!0);if(a+=4,o===0)break;let s=Math.abs(o),c=[],l=s*12;if(a+l>r)throw new qe("GL command vertex block exceeds buffer");for(let d=0;d<s;d+=1){let f=n.getFloat32(a,!0),u=n.getFloat32(a+4,!0),h=n.getInt32(a+8,!0);if(a+=12,h<0||h>=e.numVertices)throw new qe("GL command references invalid vertex index");c.push({s:f,t:u,vertexIndex:h})}i.push({mode:o>0?"strip":"fan",vertices:c})}if(a!==r)throw new qe("GL command list did not consume expected data");return i}function nd(t){let e=Vg(t),r=Gg(t,e),n=Wg(t,e),i=Xg(t,e),a=Kg(t,e),o=Yg(t,e);return{header:e,skins:r,texCoords:n,triangles:i,frames:a,glCommands:o}}function Of(t){let e=[],r=0;for(;r<t.length;){let n=t[r].name,i=n.replace(/\d+$/,"")||n,a=r;for(;a+1<t.length&&(t[a+1].name.replace(/\d+$/,"")||t[a+1].name)===i;)a+=1;e.push({name:i,firstFrame:r,lastFrame:a}),r=a+1}return e}var Uf=860898377,$g=15,Yt=class extends Error{constructor(e){super(e),this.name="Md3ParseError"}};function Ja(t,e,r){let n=new Uint8Array(t.buffer,t.byteOffset+e,r);return new TextDecoder("utf-8").decode(n).replace(/\0.*$/,"").trim()}function qg(t){let e=(t>>8&255)*(2*Math.PI/255),r=(t&255)*(2*Math.PI/255),n=Math.sin(r);return{x:Math.cos(e)*n,y:Math.sin(e)*n,z:Math.cos(r)}}function qs(t,e,r,n){if(e<0||e+r>n)throw new Yt(`${t} exceeds buffer bounds`)}function Zg(t){let e=t.getInt32(0,!0);if(e!==Uf)throw new Yt(`Invalid MD3 ident: ${e}`);let r=t.getInt32(4,!0);if(r!==$g)throw new Yt(`Unsupported MD3 version: ${r}`);let n=Ja(t,8,64),i=t.getInt32(72,!0),a=t.getInt32(76,!0),o=t.getInt32(80,!0),s=t.getInt32(84,!0),c=t.getInt32(88,!0),l=t.getInt32(92,!0),d=t.getInt32(96,!0),f=t.getInt32(100,!0),u=t.getInt32(104,!0);if(a<=0||s<0||o<0)throw new Yt("Invalid MD3 counts");return{ident:e,version:r,name:n,flags:i,numFrames:a,numTags:o,numSurfaces:s,numSkins:c,ofsFrames:l,ofsTags:d,ofsSurfaces:f,ofsEnd:u,magic:e}}function jg(t,e){let r=[];qs("Frames",e.ofsFrames,e.numFrames*56,t.byteLength);for(let i=0;i<e.numFrames;i+=1){let a=e.ofsFrames+i*56;r.push({minBounds:{x:t.getFloat32(a,!0),y:t.getFloat32(a+4,!0),z:t.getFloat32(a+8,!0)},maxBounds:{x:t.getFloat32(a+12,!0),y:t.getFloat32(a+16,!0),z:t.getFloat32(a+20,!0)},localOrigin:{x:t.getFloat32(a+24,!0),y:t.getFloat32(a+28,!0),z:t.getFloat32(a+32,!0)},radius:t.getFloat32(a+36,!0),name:Ja(t,a+40,16)})}return r}function Qg(t,e){let r=[],i=e.numFrames*e.numTags*112;qs("Tags",e.ofsTags,i,t.byteLength);for(let a=0;a<e.numFrames;a+=1){let o=[];for(let s=0;s<e.numTags;s+=1){let c=e.ofsTags+(a*e.numTags+s)*112,l=c+64,d=l+12;o.push({name:Ja(t,c,64),origin:{x:t.getFloat32(l,!0),y:t.getFloat32(l+4,!0),z:t.getFloat32(l+8,!0)},axis:[{x:t.getFloat32(d,!0),y:t.getFloat32(d+4,!0),z:t.getFloat32(d+8,!0)},{x:t.getFloat32(d+12,!0),y:t.getFloat32(d+16,!0),z:t.getFloat32(d+20,!0)},{x:t.getFloat32(d+24,!0),y:t.getFloat32(d+28,!0),z:t.getFloat32(d+32,!0)}]})}r.push(o)}return r}function Jg(t,e){let r=t.getInt32(e,!0);if(r!==Uf)throw new Yt(`Invalid surface ident at ${e}: ${r}`);let n=Ja(t,e+4,64),i=t.getInt32(e+68,!0),a=t.getInt32(e+72,!0),o=t.getInt32(e+76,!0),s=t.getInt32(e+80,!0),c=t.getInt32(e+84,!0),l=t.getInt32(e+88,!0),d=t.getInt32(e+92,!0),f=t.getInt32(e+96,!0),u=t.getInt32(e+100,!0),h=t.getInt32(e+104,!0);if(a<=0||s<=0||c<=0)throw new Yt(`Invalid surface counts for ${n}`);let m=h;qs(`Surface ${n}`,e,m,t.byteLength);let g=[],p=e+l;for(let S=0;S<c;S+=1){let E=p+S*12;g.push({indices:[t.getInt32(E,!0),t.getInt32(E+4,!0),t.getInt32(E+8,!0)]})}let y=[],v=e+d;for(let S=0;S<o;S+=1){let E=v+S*68;y.push({name:Ja(t,E,64),shaderIndex:t.getInt32(E+64,!0)})}let x=[],b=e+f;for(let S=0;S<s;S+=1){let E=b+S*8;x.push({s:t.getFloat32(E,!0),t:t.getFloat32(E+4,!0)})}let _=[],w=e+u;for(let S=0;S<a;S+=1){let E=[];for(let L=0;L<s;L+=1){let M=w+(S*s+L)*8,C=t.getInt16(M,!0)/64,I=t.getInt16(M+2,!0)/64,B=t.getInt16(M+4,!0)/64,F=t.getUint16(M+6,!0);E.push({position:{x:C,y:I,z:B},latLng:F,normal:qg(F)})}_.push(E)}return{surface:{name:n,flags:i,numFrames:a,shaders:y,triangles:g,texCoords:x,vertices:_},nextOffset:e+h}}function id(t){if(t.byteLength<108)throw new Yt("MD3 buffer too small for header");let e=new DataView(t),r=Zg(e);qs("MD3 end",r.ofsEnd,0,t.byteLength);let n=jg(e,r),i=Qg(e,r),a=[],o=r.ofsSurfaces;for(let s=0;s<r.numSurfaces;s+=1){let{surface:c,nextOffset:l}=Jg(e,o);a.push(c),o=l}if(o!==r.ofsEnd)throw new Yt("Surface parsing did not reach ofsEnd");return{header:r,frames:n,tags:i,surfaces:a}}var Vi=class{constructor(e){this.vfs=e;this.cache=new Map}async load(e){if(this.cache.has(e))return this.cache.get(e);let r=await this.vfs.readFile(e),n=id(r.slice().buffer);return this.cache.set(e,n),n}get(e){return this.cache.get(e)}};var e1=844317769,t1=2,Nf=64,Hf=12,yn=class extends Error{};function r1(t,e,r){let n=[];for(let i=0;i<r;i+=1){let a=t.getUint8(e+i);if(a===0)break;n.push(a)}return String.fromCharCode(...n)}function ad(t){if(t.byteLength<Hf)throw new yn("Sprite buffer too small to contain header");let e=new DataView(t),r=e.getInt32(0,!0),n=e.getInt32(4,!0),i=e.getInt32(8,!0);if(r!==e1)throw new yn(`Invalid Sprite ident: ${r}`);if(n!==t1)throw new yn(`Unsupported Sprite version: ${n}`);let a=[],o=16+Nf,s=Hf;for(let c=0;c<i;c+=1){if(s+o>t.byteLength)throw new yn("Sprite frame data exceeds buffer length");let l=e.getInt32(s,!0),d=e.getInt32(s+4,!0),f=e.getInt32(s+8,!0),u=e.getInt32(s+12,!0),h=r1(e,s+16,Nf);a.push({width:l,height:d,originX:f,originY:u,name:h}),s+=o}return{ident:r,version:n,numFrames:i,frames:a}}var Gi=class{constructor(e){this.vfs=e}async load(e){let r=await this.vfs.readFile(e),n=new Uint8Array(r.byteLength);return n.set(r),ad(n.buffer)}};function Vf(t,e){let r=(t.sequence.end-t.sequence.start+1)/t.sequence.fps,n=t.sequence.loop!==!1,i=t.time+e;return n?i=(i%r+r)%r:i>r&&(i=r),{...t,time:Math.max(0,Math.min(i,r))}}function Gf(t){let e=t.sequence.end-t.sequence.start+1,r=1/t.sequence.fps,n=t.sequence.loop!==!1,i=t.time/r;if(!n&&i>=e)return{frame0:t.sequence.end,frame1:t.sequence.end,lerp:0};let a=n?i%e:Math.min(i,e-1),o=Math.floor(a),s=t.sequence.start+o,c=o+1>=e?n?t.sequence.start:t.sequence.end:s+1,l=!n&&o>=e-1?0:a-o;return{frame0:s,frame1:c,lerp:l}}function Wf(t){return{sequence:t,time:0}}function Xf(t,e,r){return{x:t.x+(e.x-t.x)*r,y:t.y+(e.y-t.y)*r,z:t.z+(e.z-t.z)*r}}var eo=class extends Error{constructor(e){super(e),this.name="WalParseError"}};function Zs(t){if(t.byteLength<100)throw new eo("WAL buffer too small");let e=new DataView(t),r=new Uint8Array(t,0,32),n=new TextDecoder("utf-8").decode(r).replace(/\0.*$/,"").trim(),i=e.getInt32(32,!0),a=e.getInt32(36,!0),o=[e.getInt32(40,!0),e.getInt32(44,!0),e.getInt32(48,!0),e.getInt32(52,!0)],s=new Uint8Array(t,56,32),c=new TextDecoder("utf-8").decode(s).replace(/\0.*$/,"").trim(),l=e.getInt32(88,!0),d=e.getInt32(92,!0),f=e.getInt32(96,!0);if(i<=0||a<=0)throw new eo("Invalid WAL dimensions");let u=[],h=i,m=a;for(let g=0;g<o.length;g+=1){let p=o[g],y=Math.max(1,h*m|0);if(p<=0||p+y>t.byteLength)throw new eo(`Invalid WAL mip offset for level ${g}`);let v=new Uint8Array(t,p,y);u.push({level:g,width:h,height:m,data:v}),h=Math.max(1,h>>1),m=Math.max(1,m>>1)}return{name:n,width:i,height:a,mipmaps:u,animName:c,flags:l,contents:d,value:f}}var ei=class extends Error{constructor(e){super(e),this.name="PcxParseError"}};function to(t){if(t.byteLength<128)throw new ei("PCX buffer too small for header");let e=new DataView(t),r=e.getUint8(0),n=e.getUint8(2),i=e.getUint8(3),a=e.getUint16(4,!0),o=e.getUint16(6,!0),s=e.getUint16(8,!0),c=e.getUint16(10,!0);if(r!==10||n!==1)throw new ei("Unsupported PCX encoding");if(i!==8)throw new ei("Only 8bpp PCX files are supported");let l=s-a+1,d=c-o+1,f=e.getUint16(66,!0),u=t.byteLength-769;if(u<128||new DataView(t,u,1).getUint8(0)!==12)throw new ei("Missing PCX palette");let h=new Uint8Array(t,u+1,768),m=new Uint8Array(t,128,u-128),g=new Uint8Array(l*d),p=0,y=0;for(let v=0;v<d;v+=1){let x=0;for(;x<f&&p<m.length;){let b=1,_=m[p++];if((_&192)===192){if(b=_&63,p>=m.length)throw new ei("Unexpected end of PCX RLE data");_=m[p++]}for(let w=0;w<b&&x<f;w+=1)x<l&&(g[y++]=_),x+=1}}return{width:l,height:d,bitsPerPixel:i,pixels:g,palette:h}}function js(t){let e=new Uint8Array(t.width*t.height*4);for(let r=0;r<t.pixels.length;r+=1){let n=t.pixels[r],i=n*3,a=r*4;e[a]=t.palette[i],e[a+1]=t.palette[i+1],e[a+2]=t.palette[i+2],e[a+3]=n===255?0:255}return e}var Vr=class extends Error{constructor(e){super(e),this.name="TgaParseError"}};function od(t){let e=new DataView(t);if(t.byteLength<18)throw new Vr("Buffer too small for TGA header");let r=e.getUint8(0),n=e.getUint8(1),i=e.getUint8(2),a=e.getUint16(12,!0),o=e.getUint16(14,!0),s=e.getUint8(16),c=e.getUint8(17);if(i!==2&&i!==10&&i!==3&&i!==11)throw new Vr(`Unsupported TGA image type: ${i} (only RGB/Grayscale supported)`);if(s!==24&&s!==32&&s!==8)throw new Vr(`Unsupported pixel depth: ${s} (only 8, 24, 32 bpp supported)`);let l=i>=9,d=i===3||i===11,f=s/8,u=18+r;if(n===1){let x=e.getUint16(5,!0),b=e.getUint8(7);u+=x*(b/8)}let h=a*o,m=new Uint8Array(h*4),g=(c&32)!==0,p=0,y=new Uint8Array(t),v=x=>{if(d){let b=y[u++];m[x]=b,m[x+1]=b,m[x+2]=b,m[x+3]=255}else{let b=y[u++],_=y[u++],w=y[u++],S=s===32?y[u++]:255;m[x]=w,m[x+1]=_,m[x+2]=b,m[x+3]=S}};if(l){let x=0;for(;x<h;){if(u>=t.byteLength)throw new Vr("Unexpected end of TGA RLE data");let b=y[u++],_=(b&127)+1,w=(b&128)!==0;if(x+_>h)throw new Vr("TGA RLE packet exceeds image bounds");if(w){let S=d?y[u]:y[u+2],E=d?y[u]:y[u+1],L=y[u],M=d?255:s===32?y[u+3]:255;u+=f;for(let C=0;C<_;C++){let I=(x+C)*4;m[I]=S,m[I+1]=E,m[I+2]=L,m[I+3]=M}}else for(let S=0;S<_;S++)v((x+S)*4);x+=_}}else for(let x=0;x<h;x++){if(u>=t.byteLength)throw new Vr("Unexpected end of TGA data");v(x*4)}if(!g){let x=a*4,b=new Uint8Array(x);for(let _=0;_<o/2;_++){let w=_*x,S=(o-1-_)*x;b.set(m.subarray(w,w+x)),m.set(m.subarray(S,S+x),w),m.set(b,S)}}return{width:a,height:o,bitsPerPixel:32,pixels:m}}function n1(t){let e=0;for(let r of t.levels)e+=r.rgba.byteLength;return e}var Wi=class{constructor(e={}){this.cache=new gn(e.capacity??128,e.maxMemory??256*1024*1024,n1)}get size(){return this.cache.size}get memoryUsage(){return this.cache.memoryUsage}get(e){return this.cache.get(e.toLowerCase())}set(e,r){this.cache.set(e.toLowerCase(),r)}clear(){this.cache.clear()}get capacity(){return this.cache.capacity}set capacity(e){this.cache.capacity=e}get maxMemory(){return this.cache.maxMemory}set maxMemory(e){this.cache.maxMemory=e}};function sd(t,e){let r=[];for(let n of t.mipmaps){let i=new Uint8Array(n.width*n.height*4);for(let a=0;a<n.data.length;a+=1){let o=n.data[a],s=o*3,c=a*4;i[c]=e[s],i[c+1]=e[s+1],i[c+2]=e[s+2],i[c+3]=o===255?0:255}r.push({level:n.level,width:n.width,height:n.height,rgba:i})}return{width:t.width,height:t.height,levels:r,source:"wal"}}function Qs(t){let e=js(t),r={level:0,width:t.width,height:t.height,rgba:e};return{width:t.width,height:t.height,levels:[r],source:"pcx"}}function Kf(t){let e={level:0,width:t.width,height:t.height,rgba:t.pixels};return{width:t.width,height:t.height,levels:[e],source:"tga"}}function Js(t,e){return sd(Zs(t),e)}var ti=class extends Error{constructor(e){super(e),this.name="WavParseError"}};function ld(t,e,r){return new TextDecoder("ascii").decode(new Uint8Array(t.buffer,t.byteOffset+e,r))}function el(t){if(t.byteLength<44)throw new ti("WAV buffer too small");let e=new DataView(t);if(ld(e,0,4)!=="RIFF"||ld(e,8,4)!=="WAVE")throw new ti("Invalid WAV header");let r=12,n=-1,i=-1,a=0,o=0;for(;r+8<=t.byteLength;){let m=ld(e,r,4),g=e.getUint32(r+4,!0),p=r+8;m==="fmt "?(n=p,a=g):m==="data"&&(i=p,o=g),r=p+g}if(n===-1||i===-1)throw new ti("Missing fmt or data chunk");let s=e.getUint16(n,!0),c=e.getUint16(n+2,!0),l=e.getUint32(n+4,!0),d=e.getUint16(n+14,!0);if(s!==1)throw new ti("Only PCM WAV is supported");let f=d/8,u=o/(f*c),h=new Float32Array(u*c);for(let m=0;m<u;m+=1)for(let g=0;g<c;g+=1){let p=m*c+g,y=i+p*f,v=0;if(d===8)v=e.getUint8(y),h[p]=(v-128)/128;else if(d===16)v=e.getInt16(y,!0),h[p]=v/32768;else if(d===24){let x=e.getUint8(y),b=e.getUint8(y+1),_=e.getInt8(y+2);v=x|b<<8|_<<16,h[p]=v/8388608}else throw new ti(`Unsupported bitsPerSample: ${d}`)}return{sampleRate:l,channels:c,bitsPerSample:d,samples:h}}var i1=(t,e=4294967295,r=79764919)=>{let n=new Int32Array(256),i,a,o,s=e;for(i=0;i<256;i++){for(o=i<<24,a=8;a>0;--a)o=2147483648&o?o<<1^r:o<<1;n[i]=o}for(i=0;i<t.length;i++)s=s<<8^n[255&(s>>24^t[i])];return s};var cd=(t,e=i1)=>{let r=p=>new Uint8Array(p.length/2).map(((y,v)=>parseInt(p.substring(2*v,2*(v+1)),16))),n=p=>r(p)[0],i=new Map;[,8364,,8218,402,8222,8230,8224,8225,710,8240,352,8249,338,,381,,,8216,8217,8220,8221,8226,8211,8212,732,8482,353,8250,339,,382,376].forEach(((p,y)=>i.set(p,y)));let a=new Uint8Array(t.length),o,s,c,l=!1,d=0,f=42,u=t.length>13&&t.substring(0,9)==="dynEncode",h=0;u&&(h=11,s=n(t.substring(9,h)),s<=1&&(h+=2,f=n(t.substring(11,h))),s===1&&(h+=8,c=(p=>new DataView(r(p).buffer).getInt32(0,!0))(t.substring(13,h))));let m=256-f;for(let p=h;p<t.length;p++)if(o=t.charCodeAt(p),o!==61||l){if(o===92&&p<t.length-5&&u){let y=t.charCodeAt(p+1);y!==117&&y!==85||(o=parseInt(t.substring(p+2,p+6),16),p+=5)}if(o>255){let y=i.get(o);y&&(o=y+127)}l&&(l=!1,o-=64),a[d++]=o<f&&o>0?o+m:o-f}else l=!0;let g=a.subarray(0,d);if(u&&s===1){let p=e(g);if(p!==c){let y="Decode failed crc32 validation";throw console.error("`simple-yenc`\n",y+`
|
|
2
2
|
`,"Expected: "+c+"; Got: "+p+`
|
|
3
3
|
`,"Visit https://github.com/eshaz/simple-yenc for more information"),Error(y)}}return g};function ge(){let t=Uint8Array,e=Float32Array;ge.modules||Object.defineProperties(ge,{modules:{value:new WeakMap},setModule:{value(r,n){ge.modules.set(r,Promise.resolve(n))}},getModule:{value(r,n){let i=ge.modules.get(r);return i||(n?i=WebAssembly.compile(cd(n)):(n=r.wasm,i=ge.inflateDynEncodeString(n).then(a=>WebAssembly.compile(a))),ge.modules.set(r,i)),i}},concatFloat32:{value(r,n){let i=new e(n),a=0,o=0;for(;a<r.length;)i.set(r[a],o),o+=r[a++].length;return i}},getDecodedAudio:{value:(r,n,i,a,o)=>({errors:r,channelData:n,samplesDecoded:i,sampleRate:a,bitDepth:o})},getDecodedAudioMultiChannel:{value(r,n,i,a,o,s){let c=[],l,d;for(l=0;l<i;l++){let f=[];for(d=0;d<n.length;)f.push(n[d++][l]||[]);c.push(ge.concatFloat32(f,a))}return ge.getDecodedAudio(r,c,a,o,s)}},inflateDynEncodeString:{value(r){return r=cd(r),new Promise(n=>{let i=String.raw`dynEncode012804c7886d()((()>+*§§)§,§§§§)§+§§§)§+.-()(*)-+)(.7*§)i¸¸,3§(i¸¸,3/G+.¡*(,(,3+)2å:-),§H(P*DI*H(P*@I++hH)H*r,hH(H(P*<J,i)^*<H,H(P*4U((I-H(H*i0J,^*DH+H-H*I+H,I*4)33H(H*H)^*DH(H+H)^*@H+i§H)i§3æ*).§K(iHI/+§H,iHn,§H+i(H+i(rCJ0I,H*I-+hH,,hH(H-V)(i)J.H.W)(i)c)(H,i)I,H-i*I-4)33i(I.*hH(V)(H+n5(H(i*I-i(I,i)I.+hH,i*J+iHn,hi(I-i*I,+hH,H/H-c)(H,iFn,hi(I,+hH,H0n5-H*V)(J(,hH/H(i)J(H(V)(J(i)c)(H)H(i)H,c)(3H*i*I*H,i)I,4(3(-H(H,W)(H-I-H,i*I,4)3(3(3H,H-I1H+I,H.i)H1V)(J.i(v5(33H.-H(H,i(c)(H,i*I,4)333)-§i*I*+§H*iHn,hi73H,H(i)8(H+J+H)P*(H*V)(J-r,§H)P*,H.i)H+H,i)V)(-H*i*I*H+i)I+H-H.I.H,H-i)I,4)333Ã+)-§iø7i(^*(iü7I,*h+hH+iDn,h*hilI+i)I,+hH+,hH+iô7H,c)(i)H+i´8W)(H,I,H+i*I+4)-+hH(H)8*J-i(p5.*h*h*hH-i')u,hH(P*(J+,hH(P*0J,H(P*,n50H+H,H-b((3H(P*0i)I.4)3H-i¨*n5*H-iÅ*s,hi73H-i)J+V)&+I,H(H+V)æ,8(I.H(H*8*J-i(p51H-i)J+i¸7V)(H(H+iø7V)(8(J/H(P*0J+s,hi73H+H,H.J,I.H(P*(m5(H.H(P*,s5.+hH,m5*H(P*(J.H+H.H+H/U((b((H(H(P*0i)J+^*0H,i)I,4(3(3H(H.^*03H-i¨*o5)33i(73(3(3-H,H+i)c)(H,i*I,H+i)I+4)33i)I-3H-3!2)0§K(i2J,L(H,H(^*(H,H*^*4H,i(^*0H,i(^*DH,j(_*<H,H)P*(^*,H,H+P*(^*8*h*h+hH,i)8(I3i§I**h*h*h*h*h*h*hH,i*8(6+(),03H,j(_*@i*I-H,P*<J.i,J(H,P*8J/s50H,H.i+J0^*<i¦I*H.H,P*4J1J.U(*H.U((J2i')o5/H.U()I.H,H(^*<H0H1U((H.i0J.i§i0i')o5/H/H.H2J*H(J.q50H,P*0J/H*I-H,P*(J0,hH,P*,H-q,hi)I-423+hH*m5+H/H0H(H1U((b((H/i)I/H(i)I(H*i)I*4(3(3H,H.^*<H,H-^*04*3iØ1U((5+i(I(i¨7i1^*(i$6iè1^*(i°7iè6^*(i¬7iÈ6^*(+hH(iÈ*n,hiÈ*I(+hH(i¨,n,hi¨,I(+hH(iØ,n,hiØ,I(+hH(iè,o,hH,i-H(i0c)(H(i*I(4)33iè1i1H,i-iÈ*8)Bi(I(+hH(ido,hH,i-H(i-c)(H(i*I(4)33iÈ6iè6H,i-iF8)BiØ1i)b((41-H,i-H(i/c)(H(i*I(4)3(3(-H,i-H(i1c)(H(i*I(4)3(3(-H,i-H(i0c)(H(i*I(4)3(3(3H,H/^*0H,H(^*<3i(I*4*3H,H,i¸)^*TH,H,iø-^*PH,H,iX^*LH,H,i(^*HH,i-8(I(H,i-8(I-i¥I*H,i,8(I.H(iErH-iEr5)H(i©*I1H-i)I0i(i;H.i,J(i(H(i(rCJ(J*H*i;sCI*i¨1I-H(I/+hH/,hH,i-H-V)(i)H,i+8(c)(H/i)I/H-i*I-H*i)I*4)-H(i)i¨1I/+hH(H*o,hH,i-H/V)(i)i(c)(H/i*I/H(i)I(4)33i¤I*H,iø-H,i¸)H,i-i;8)5+H0H1I2i(I-+hH-H2p,hH,H,iP8*J*i(p5-H*i7u,hH,i-H-i)H*c)(H-i)I-4*3i(I/i+I.i+I(*h*h*hH*i86*(*)3H-m,hi£I*403H-i)H,W)-I/i*I(4)3i3I.i/I(3H2H,H(8(H.J(H-J.p,hi¢I*4.3H,i-H-i)I*+hH(,hH*H/c)(H*i*I*H(i)I(4)-H.I-4+3(3(33H,W)1m,hiI*4,3H,iø-H,i¸)H,i-H18)J(,hi¡I*H(i(p5,H1H,V)ú-H,V)ø-o5,3H,i(H,iXH,i-H1i)H08)J(,hi I*H(i(p5,H0H,V)H,V)o5,3H,H,iPH,iH8+I*4+3(3(3H,i$6i¬78+I*3H*H3m5(3i)I-H*i(r5)3H)H,P*0^*(H+H,P*<^*(H*I-3H,i2L(H-33Á)+(i¨03b+(,(-(.(/(0(1(2(3(5(7(9(;(?(C(G(K(S([(c(k({(((«(Ë(ë((*)(iø03O)()()()(*(*(*(*(+(+(+(+(,(,(,(,(-(-(-(-(i¨13M8(9(:(((0(/(1(.(2(-(3(,(4(+(5(*(6()(7(T7*S7US0U `;ge.getModule(ge,i).then(a=>WebAssembly.instantiate(a,{})).then(({exports:a})=>{let o=new Map(Object.entries(a)),s=o.get("puff"),c=o.get("memory").buffer,l=new t(c),d=new DataView(c),f=o.get("__heap_base"),u=r.length,h=f;f+=4,d.setInt32(h,u,!0);let m=f;f+=u,l.set(r,m);let g=f;f+=4,d.setInt32(g,l.byteLength-f,!0),s(f,g,m,h),n(l.slice(f,f+d.getInt32(g,!0)))})})}}}),Object.defineProperty(this,"wasm",{enumerable:!0,get:()=>this._wasm}),this.getOutputChannels=(r,n,i)=>{let a=[],o=0;for(;o<n;)a.push(r.slice(o*i,o++*i+i));return a},this.allocateTypedArray=(r,n,i=!0)=>{let a=this._wasm.malloc(n.BYTES_PER_ELEMENT*r);return i&&this._pointers.add(a),{ptr:a,len:r,buf:new n(this._wasm.HEAP,a,r)}},this.free=()=>{this._pointers.forEach(r=>{this._wasm.free(r)}),this._pointers.clear()},this.codeToString=r=>{let n=[],i=new Uint8Array(this._wasm.HEAP);for(let a=i[r];a!==0;a=i[++r])n.push(a);return String.fromCharCode.apply(null,n)},this.addError=(r,n,i,a,o,s)=>{r.push({message:n,frameLength:i,frameNumber:a,inputBytes:o,outputSamples:s})},this.instantiate=(r,n)=>(n&&ge.setModule(r,n),this._wasm=new r(ge).instantiate(),this._pointers=new Set,this._wasm.ready.then(()=>this))}var qf=Mp($f(),1);var a1=()=>globalThis.Worker||qf.default,Xi=class extends a1(){constructor(e,r,n,i){ge.modules||new ge;let a=ge.modules.get(n);if(!a){let o="text/javascript",s,c=`'use strict';(${((l,d,f)=>{let u,h,m=new Promise(g=>{h=g});self.onmessage=({data:{id:g,command:p,data:y}})=>{let v=m,x={id:g},b;p==="init"?(Object.defineProperties(l,{WASMAudioDecoderCommon:{value:d},EmscriptenWASM:{value:f},module:{value:y.module},isWebWorker:{value:!0}}),u=new l(y.options),h()):p==="free"?u.free():p==="ready"?v=v.then(()=>u.ready):p==="reset"?v=v.then(()=>u.reset()):(Object.assign(x,u[p](Array.isArray(y)?y.map(_=>new Uint8Array(_)):new Uint8Array(y))),b=x.channelData?x.channelData.map(_=>_.buffer):[]),v.then(()=>self.postMessage(x,b))}}).toString()})(${n}, ${ge}, ${i})`;try{s=typeof process.versions.node<"u"}catch{}a=s?`data:${o};base64,${Buffer.from(c).toString("base64")}`:URL.createObjectURL(new Blob([c],{type:o})),ge.modules.set(n,a)}super(a,{name:r}),this._id=Number.MIN_SAFE_INTEGER,this._enqueuedOperations=new Map,this.onmessage=({data:o})=>{let{id:s,...c}=o;this._enqueuedOperations.get(s)(c),this._enqueuedOperations.delete(s)},new i(ge).getModule().then(o=>{this.postToDecoder("init",{module:o,options:e})})}async postToDecoder(e,r){return new Promise(n=>{this.postMessage({command:e,id:this._id,data:r}),this._enqueuedOperations.set(this._id++,n)})}get ready(){return this.postToDecoder("ready")}async free(){await this.postToDecoder("free").finally(()=>{this.terminate()})}async reset(){await this.postToDecoder("reset")}};var tl=(t,e)=>{Object.defineProperty(t,"name",{value:e})};var ye=Symbol,Zf=", ",V=(()=>{let t="front",e="side",r="rear",n="left",i="center",a="right";return["",t+" ",e+" ",r+" "].map(o=>[[n,a],[n,a,i],[n,i,a],[i,n,a],[i]].flatMap(s=>s.map(c=>o+c).join(Zf)))})(),Mr="LFE",bn="monophonic (mono)",xn="stereo",ro="surround",Se=(t,...e)=>`${[bn,xn,`linear ${ro}`,"quadraphonic",`5.0 ${ro}`,`5.1 ${ro}`,`6.1 ${ro}`,`7.1 ${ro}`][t-1]} (${e.join(Zf)})`,no=[bn,Se(2,V[0][0]),Se(3,V[0][2]),Se(4,V[1][0],V[3][0]),Se(5,V[1][2],V[3][0]),Se(6,V[1][2],V[3][0],Mr),Se(7,V[1][2],V[2][0],V[3][4],Mr),Se(8,V[1][2],V[2][0],V[3][0],Mr)],jf=192e3,Qf=176400,rl=96e3,nl=88200,Jf=64e3,vn=48e3,Ki=44100,Yi=32e3,$i=24e3,qi=22050,Zi=16e3,il=12e3,al=11025,ji=8e3,eh=7350,lr="absoluteGranulePosition",X="bandwidth",tt="bitDepth",rt="bitrate",io=rt+"Maximum",ao=rt+"Minimum",oo=rt+"Nominal",Ar="buffer",so=Ar+"Fullness",me="codec",nt=me+"Frames",lo="coupledStreamCount",Qi="crc",co=Qi+"16",uo=Qi+"32",he="data",H="description",Er="duration",Ji="emphasis",fo="hasOpusPadding",Bt="header",_n="isContinuedPacket",ho="isCopyrighted",Sn="isFirstPage",mo="isHome",Ft="isLastPage",Gr="isOriginal",Wr="isPrivate",po="isVbr",Lt="layer",P="length",W="mode",Xr=W+"Extension",ol="mpeg",Kr=ol+"Version",go="numberAACFrames",yo="outputGain",ri="preSkip",bo="profile",sl=ye(),Yr="protection",dd="rawData",$t="segments",q="subarray",wn="version",ni="vorbis",xo=ni+"Comments",ea=ni+"Setup",ll="block",vo=ll+"ingStrategy",cl=ye(),$r=ll+"Size",Mn=ll+"size0",An=ll+"size1",_o=ye(),dl="channel",qr=dl+"MappingFamily",So=dl+"MappingTable",it=dl+"Mode",wo=ye(),N=dl+"s",th="copyright",Mo=th+"Id",Ao=th+"IdStart",Zr="frame",jr=Zr+"Count",Tt=Zr+"Length",ul="Number",Qr=Zr+ul,Lr=Zr+"Padding",G=Zr+"Size",rh="Rate",Eo="inputSample"+rh,ud="page",ii=ud+"Checksum",ta=ye(),En=ud+"SegmentTable",Te=ud+"Sequence"+ul,fd="sample",Lo=fd+ul,ee=fd+rh,Tr=ye(),te=fd+"s",fl="stream",To=fl+"Count",Ro=fl+"Info",Rr=fl+"Serial"+ul,hd=fl+"StructureVersion",md="total",ai=md+"BytesOut",oi=md+"Duration",si=md+"Samples",ae=ye(),qt=ye(),Co=ye(),Ln=ye(),cr=ye(),hl=ye(),pd=ye(),Tn=ye(),ue=ye(),Zt=ye(),jt=ye(),Cr=ye(),Rn=ye(),ml=ye(),dr=ye(),ur=ye(),Qt=ye(),pl=ye(),at=Uint8Array,Cn=DataView,fe="reserved",ot="bad",ra="free",Po="none",gl="16bit CRC";var gd=(t,e,r)=>{for(let n=0;n<t[P];n++){let i=e(n);for(let a=8;a>0;a--)i=r(i);t[n]=i}return t},s1=gd(new at(256),t=>t,t=>t&128?7^t<<1:t<<1),we=[gd(new Uint16Array(256),t=>t<<8,t=>t<<1^(t&32768?32773:0))],Me=[gd(new Uint32Array(256),t=>t,t=>t>>>1^(t&1)*3988292384)];for(let t=0;t<15;t++){we.push(new Uint16Array(256)),Me.push(new Uint32Array(256));for(let e=0;e<=255;e++)we[t+1][e]=we[0][we[t][e]>>>8]^we[t][e]<<8,Me[t+1][e]=Me[t][e]>>>8^Me[0][Me[t][e]&255]}var ih=t=>{let e=0,r=t[P];for(let n=0;n!==r;n++)e=s1[e^t[n]];return e},ah=t=>{let e=t[P],r=e-16,n=0,i=0;for(;i<=r;)n^=t[i++]<<8|t[i++],n=we[15][n>>8]^we[14][n&255]^we[13][t[i++]]^we[12][t[i++]]^we[11][t[i++]]^we[10][t[i++]]^we[9][t[i++]]^we[8][t[i++]]^we[7][t[i++]]^we[6][t[i++]]^we[5][t[i++]]^we[4][t[i++]]^we[3][t[i++]]^we[2][t[i++]]^we[1][t[i++]]^we[0][t[i++]];for(;i!==e;)n=(n&255)<<8^we[0][n>>8^t[i++]];return n},oh=t=>{let e=t[P],r=e-16,n=0,i=0;for(;i<=r;)n=Me[15][(t[i++]^n)&255]^Me[14][(t[i++]^n>>>8)&255]^Me[13][(t[i++]^n>>>16)&255]^Me[12][t[i++]^n>>>24]^Me[11][t[i++]]^Me[10][t[i++]]^Me[9][t[i++]]^Me[8][t[i++]]^Me[7][t[i++]]^Me[6][t[i++]]^Me[5][t[i++]]^Me[4][t[i++]]^Me[3][t[i++]]^Me[2][t[i++]]^Me[1][t[i++]]^Me[0][t[i++]];for(;i!==e;)n=Me[0][(n^t[i++])&255]^n>>>8;return n^-1},Bo=(...t)=>{let e=new at(t.reduce((r,n)=>r+n[P],0));return t.reduce((r,n)=>(e.set(n,r),r+n[P]),0),e},kt=t=>String.fromCharCode(...t),nh=[0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15],Io=t=>nh[t&15]<<4|nh[t>>4],yl=class{constructor(e){this._data=e,this._pos=e[P]*8}set position(e){this._pos=e}get position(){return this._pos}read(e){let r=Math.floor(this._pos/8),n=this._pos%8;return this._pos-=e,(Io(this._data[r-1])<<8)+Io(this._data[r])>>7-n&255}},sh=(t,e)=>{try{return t.getBigInt64(e,!0)}catch{let r=t.getUint8(e+7)&128?-1:1,n=t.getUint32(e,!0),i=t.getUint32(e+4,!0);return r===-1&&(n=~n+1,i=~i+1),i>1048575&&console.warn("This platform does not support BigInt"),r*(n+i*2**32)}};var Fo=class{constructor(e,r){this._onCodecHeader=e,this._onCodecUpdate=r,this[dr]()}[ur](){this._isEnabled=!0}[dr](){this._headerCache=new Map,this._codecUpdateData=new WeakMap,this._codecHeaderSent=!1,this._codecShouldUpdate=!1,this._bitrate=null,this._isEnabled=!1}[ml](e,r){if(this._onCodecUpdate){this._bitrate!==e&&(this._bitrate=e,this._codecShouldUpdate=!0);let n=this._codecUpdateData.get(this._headerCache.get(this._currentHeader));this._codecShouldUpdate&&n&&this._onCodecUpdate({bitrate:e,...n},r),this._codecShouldUpdate=!1}}[ue](e){let r=this._headerCache.get(e);return r&&this._updateCurrentHeader(e),r}[Zt](e,r,n){this._isEnabled&&(this._codecHeaderSent||(this._onCodecHeader({...r}),this._codecHeaderSent=!0),this._updateCurrentHeader(e),this._headerCache.set(e,r),this._codecUpdateData.set(r,n))}_updateCurrentHeader(e){this._onCodecUpdate&&e!==this._currentHeader&&(this._codecShouldUpdate=!0,this._currentHeader=e)}};var Be=new WeakMap,Ze=new WeakMap;var st=class{constructor(e,r){this._codecParser=e,this._headerCache=r}*[pd](){let e;do{if(e=yield*this.Frame[jt](this._codecParser,this._headerCache,0),e)return e;this._codecParser[qt](1)}while(!0)}*[Tn](e){let r=yield*this[pd](),n=Ze.get(r)[P];if(e||this._codecParser._flushing||(yield*this.Header[ue](this._codecParser,this._headerCache,n)))return this._headerCache[ur](),this._codecParser[qt](n),this._codecParser[Ln](r),r;this._codecParser[cr](`Missing ${Zr} at ${n} bytes from current position.`,`Dropping current ${Zr} and trying again.`),this._headerCache[dr](),this._codecParser[qt](1)}};var li=class{constructor(e,r){Ze.set(this,{[Bt]:e}),this[he]=r}};var Dt=class extends li{static*[jt](e,r,n,i,a){let o=yield*e[ue](n,i,a);if(o){let s=Be.get(o)[Tt],c=Be.get(o)[te],l=(yield*n[ae](s,a))[q](0,s);return new r(o,l,c)}else return null}constructor(e,r,n){super(e,r),this[Bt]=e,this[te]=n,this[Er]=n/e[ee]*1e3,this[Qr]=null,this[ai]=null,this[si]=null,this[oi]=null,Ze.get(this)[P]=r[P]}};var yd="unsynchronizationFlag",bd="extendedHeaderFlag",xd="experimentalFlag",vd="footerPresent",ko=class t{static*getID3v2Header(e,r,n){let a={},o=yield*e[ae](3,n);if(o[0]!==73||o[1]!==68||o[2]!==51||(o=yield*e[ae](10,n),a[wn]=`id3v2.${o[3]}.${o[4]}`,o[5]&15)||(a[yd]=!!(o[5]&128),a[bd]=!!(o[5]&64),a[xd]=!!(o[5]&32),a[vd]=!!(o[5]&16),o[6]&128||o[7]&128||o[8]&128||o[9]&128))return null;let s=o[6]<<21|o[7]<<14|o[8]<<7|o[9];return a[P]=10+s,new t(a)}constructor(e){this[wn]=e[wn],this[yd]=e[yd],this[bd]=e[bd],this[xd]=e[xd],this[vd]=e[vd],this[P]=e[P]}};var zt=class{constructor(e){Be.set(this,e),this[tt]=e[tt],this[rt]=null,this[N]=e[N],this[it]=e[it],this[ee]=e[ee]}};var fh={0:[ra,ra,ra,ra,ra],16:[32,32,32,32,8],240:[ot,ot,ot,ot,ot]},bl=(t,e,r)=>8*((t+r)%e+e)*(1<<(t+r)/e)-8*e*(e/8|0);for(let t=2;t<15;t++)fh[t<<4]=[t*32,bl(t,4,0),bl(t,4,-1),bl(t,8,4),bl(t,8,0)];var l1=0,c1=1,d1=2,u1=3,lh=4,xl="bands ",vl=" to 31",ch={0:xl+4+vl,16:xl+8+vl,32:xl+12+vl,48:xl+16+vl},ci="bitrateIndex",Do="v2",Al="v1",_l="Intensity stereo ",Sl=", MS stereo ",wl="on",Ml="off",f1={0:_l+Ml+Sl+Ml,16:_l+wl+Sl+Ml,32:_l+Ml+Sl+wl,48:_l+wl+Sl+wl},_d={0:{[H]:fe},2:{[H]:"Layer III",[Lr]:1,[Xr]:f1,[Al]:{[ci]:d1,[te]:1152},[Do]:{[ci]:lh,[te]:576}},4:{[H]:"Layer II",[Lr]:1,[Xr]:ch,[te]:1152,[Al]:{[ci]:c1},[Do]:{[ci]:lh}},6:{[H]:"Layer I",[Lr]:4,[Xr]:ch,[te]:384,[Al]:{[ci]:l1},[Do]:{[ci]:u1}}},Sd="MPEG Version ",dh="ISO/IEC ",h1={0:{[H]:`${Sd}2.5 (later extension of MPEG 2)`,[Lt]:Do,[ee]:{0:al,4:il,8:ji,12:fe}},8:{[H]:fe},16:{[H]:`${Sd}2 (${dh}13818-3)`,[Lt]:Do,[ee]:{0:qi,4:$i,8:Zi,12:fe}},24:{[H]:`${Sd}1 (${dh}11172-3)`,[Lt]:Al,[ee]:{0:Ki,4:vn,8:Yi,12:fe}},length:P},m1={0:gl,1:Po},p1={0:Po,1:"50/15 ms",2:fe,3:"CCIT J.17"},uh={0:{[N]:2,[H]:xn},64:{[N]:2,[H]:"joint "+xn},128:{[N]:2,[H]:"dual channel"},192:{[N]:1,[H]:bn}},di=class t extends zt{static*[ue](e,r,n){let i={},a=yield*ko.getID3v2Header(e,r,n);a&&(yield*e[ae](a[P],n),e[qt](a[P]));let o=yield*e[ae](4,n),s=kt(o[q](0,4)),c=r[ue](s);if(c)return new t(c);if(o[0]!==255||o[1]<224)return null;let l=h1[o[1]&24];if(l[H]===fe)return null;let d=o[1]&6;if(_d[d][H]===fe)return null;let f={..._d[d],..._d[d][l[Lt]]};if(i[Kr]=l[H],i[Lt]=f[H],i[te]=f[te],i[Yr]=m1[o[1]&1],i[P]=4,i[rt]=fh[o[2]&240][f[ci]],i[rt]===ot||(i[ee]=l[ee][o[2]&12],i[ee]===fe)||(i[Lr]=o[2]&2&&f[Lr],i[Wr]=!!(o[2]&1),i[Tt]=Math.floor(125*i[rt]*i[te]/i[ee]+i[Lr]),!i[Tt]))return null;let u=o[3]&192;if(i[it]=uh[u][H],i[N]=uh[u][N],i[Xr]=f[Xr][o[3]&48],i[ho]=!!(o[3]&8),i[Gr]=!!(o[3]&4),i[Ji]=p1[o[3]&3],i[Ji]===fe)return null;i[tt]=16;{let{length:h,frameLength:m,samples:g,...p}=i;r[Zt](s,i,p)}return new t(i)}constructor(e){super(e),this[rt]=e[rt],this[Ji]=e[Ji],this[Lr]=e[Lr],this[ho]=e[ho],this[Gr]=e[Gr],this[Wr]=e[Wr],this[Lt]=e[Lt],this[Xr]=e[Xr],this[Kr]=e[Kr],this[Yr]=e[Yr]}};var zo=class t extends Dt{static*[jt](e,r,n){return yield*super[jt](di,t,e,r,n)}constructor(e,r,n){super(e,r,n)}};var Oo=class extends st{constructor(e,r,n){super(e,r),this.Frame=zo,this.Header=di,n(this[me])}get[me](){return ol}*[Cr](){return yield*this[Tn]()}};var g1={0:"MPEG-4",8:"MPEG-2"},y1={0:"valid",2:ot,4:ot,6:ot},b1={0:gl,1:Po},x1={0:"AAC Main",64:"AAC LC (Low Complexity)",128:"AAC SSR (Scalable Sample Rate)",192:"AAC LTP (Long Term Prediction)"},v1={0:rl,4:nl,8:Jf,12:vn,16:Ki,20:Yi,24:$i,28:qi,32:Zi,36:il,40:al,44:ji,48:eh,52:fe,56:fe,60:"frequency is written explicitly"},hh={0:{[N]:0,[H]:"Defined in AOT Specific Config"},64:{[N]:1,[H]:bn},128:{[N]:2,[H]:Se(2,V[0][0])},192:{[N]:3,[H]:Se(3,V[1][3])},256:{[N]:4,[H]:Se(4,V[1][3],V[3][4])},320:{[N]:5,[H]:Se(5,V[1][3],V[3][0])},384:{[N]:6,[H]:Se(6,V[1][3],V[3][0],Mr)},448:{[N]:8,[H]:Se(8,V[1][3],V[2][0],V[3][0],Mr)}},ui=class t extends zt{static*[ue](e,r,n){let i={},a=yield*e[ae](7,n),o=kt([a[0],a[1],a[2],a[3]&252|a[6]&3]),s=r[ue](o);if(s)Object.assign(i,s);else{if(a[0]!==255||a[1]<240||(i[Kr]=g1[a[1]&8],i[Lt]=y1[a[1]&6],i[Lt]===ot))return null;let l=a[1]&1;i[Yr]=b1[l],i[P]=l?7:9,i[sl]=a[2]&192,i[Tr]=a[2]&60;let d=a[2]&2;if(i[bo]=x1[i[sl]],i[ee]=v1[i[Tr]],i[ee]===fe)return null;i[Wr]=!!d,i[wo]=(a[2]<<8|a[3])&448,i[it]=hh[i[wo]][H],i[N]=hh[i[wo]][N],i[Gr]=!!(a[3]&32),i[mo]=!!(a[3]&8),i[Mo]=!!(a[3]&8),i[Ao]=!!(a[3]&4),i[tt]=16,i[te]=1024,i[go]=a[6]&3;{let{length:f,channelModeBits:u,profileBits:h,sampleRateBits:m,frameLength:g,samples:p,numberAACFrames:y,...v}=i;r[Zt](o,i,v)}}if(i[Tt]=(a[3]<<11|a[4]<<3|a[5]>>5)&8191,!i[Tt])return null;let c=(a[5]<<6|a[6]>>2)&2047;return i[so]=c===2047?"VBR":c,new t(i)}constructor(e){super(e),this[Mo]=e[Mo],this[Ao]=e[Ao],this[so]=e[so],this[mo]=e[mo],this[Gr]=e[Gr],this[Wr]=e[Wr],this[Lt]=e[Lt],this[P]=e[P],this[Kr]=e[Kr],this[go]=e[go],this[bo]=e[bo],this[Yr]=e[Yr]}get audioSpecificConfig(){let e=Be.get(this),r=e[sl]+64<<5|e[Tr]<<5|e[wo]>>3,n=new at(2);return new Cn(n[Ar]).setUint16(0,r,!1),n}};var Uo=class t extends Dt{static*[jt](e,r,n){return yield*super[jt](ui,t,e,r,n)}constructor(e,r,n){super(e,r,n)}};var No=class extends st{constructor(e,r,n){super(e,r),this.Frame=Uo,this.Header=ui,n(this[me])}get[me](){return"aac"}*[Cr](){return yield*this[Tn]()}};var Pn=class t extends Dt{static _getFrameFooterCrc16(e){return(e[e[P]-2]<<8)+e[e[P]-1]}static[pl](e){let r=t._getFrameFooterCrc16(e),n=ah(e[q](0,-2));return r===n}constructor(e,r,n){r[Ro]=n,r[co]=t._getFrameFooterCrc16(e),super(r,e,Be.get(r)[te])}};var mh="get from STREAMINFO metadata block",_1={0:"Fixed",1:"Variable"},ph={0:fe,16:192};for(let t=2;t<16;t++)ph[t<<4]=t<6?576*2**(t-2):2**t;var S1={0:mh,1:nl,2:Qf,3:jf,4:ji,5:Zi,6:qi,7:$i,8:Yi,9:Ki,10:vn,11:rl,15:ot},w1={0:{[N]:1,[H]:bn},16:{[N]:2,[H]:Se(2,V[0][0])},32:{[N]:3,[H]:Se(3,V[0][1])},48:{[N]:4,[H]:Se(4,V[1][0],V[3][0])},64:{[N]:5,[H]:Se(5,V[1][1],V[3][0])},80:{[N]:6,[H]:Se(6,V[1][1],Mr,V[3][0])},96:{[N]:7,[H]:Se(7,V[1][1],Mr,V[3][4],V[2][0])},112:{[N]:8,[H]:Se(8,V[1][1],Mr,V[3][0],V[2][0])},128:{[N]:2,[H]:`${xn} (left, diff)`},144:{[N]:2,[H]:`${xn} (diff, right)`},160:{[N]:2,[H]:`${xn} (avg, diff)`},176:fe,192:fe,208:fe,224:fe,240:fe},M1={0:mh,2:8,4:12,6:fe,8:16,10:20,12:24,14:fe},In=class t extends zt{static _decodeUTF8Int(e){if(e[0]>254)return null;if(e[0]<128)return{value:e[0],length:1};let r=1;for(let o=64;o&e[0];o>>=1)r++;let n=r-1,i=0,a=0;for(;n>0;a+=6,n--){if((e[n]&192)!==128)return null;i|=(e[n]&63)<<a}return i|=(e[n]&127>>r)<<a,{value:i,length:r}}static[Qt](e,r){let n={[ae]:function*(){return e}};return t[ue](n,r,0).next().value}static*[ue](e,r,n){let i=yield*e[ae](6,n);if(i[0]!==255||!(i[1]===248||i[1]===249))return null;let a={},o=kt(i[q](0,4)),s=r[ue](o);if(s)Object.assign(a,s);else{if(a[cl]=i[1]&1,a[vo]=_1[a[cl]],a[_o]=i[2]&240,a[Tr]=i[2]&15,a[$r]=ph[a[_o]],a[$r]===fe||(a[ee]=S1[a[Tr]],a[ee]===ot)||i[3]&1)return null;let l=w1[i[3]&240];if(l===fe||(a[N]=l[N],a[it]=l[H],a[tt]=M1[i[3]&14],a[tt]===fe))return null}a[P]=5,i=yield*e[ae](a[P]+8,n);let c=t._decodeUTF8Int(i[q](4));if(!c||(a[cl]?a[Lo]=c.value:a[Qr]=c.value,a[P]+=c[P],a[_o]===96?(i[P]<a[P]&&(i=yield*e[ae](a[P],n)),a[$r]=i[a[P]-1]+1,a[P]+=1):a[_o]===112&&(i[P]<a[P]&&(i=yield*e[ae](a[P],n)),a[$r]=(i[a[P]-1]<<8)+i[a[P]]+1,a[P]+=2),a[te]=a[$r],a[Tr]===12?(i[P]<a[P]&&(i=yield*e[ae](a[P],n)),a[ee]=i[a[P]-1]*1e3,a[P]+=1):a[Tr]===13?(i[P]<a[P]&&(i=yield*e[ae](a[P],n)),a[ee]=(i[a[P]-1]<<8)+i[a[P]],a[P]+=2):a[Tr]===14&&(i[P]<a[P]&&(i=yield*e[ae](a[P],n)),a[ee]=((i[a[P]-1]<<8)+i[a[P]])*10,a[P]+=2),i[P]<a[P]&&(i=yield*e[ae](a[P],n)),a[Qi]=i[a[P]-1],a[Qi]!==ih(i[q](0,a[P]-1))))return null;if(!s){let{blockingStrategyBits:l,frameNumber:d,sampleNumber:f,samples:u,sampleRateBits:h,blockSizeBits:m,crc:g,length:p,...y}=a;r[Zt](o,a,y)}return new t(a)}constructor(e){super(e),this[co]=null,this[vo]=e[vo],this[$r]=e[$r],this[Qr]=e[Qr],this[Lo]=e[Lo],this[Ro]=null}};var A1=2,E1=512*1024,fi=class extends st{constructor(e,r,n){super(e,r),this.Frame=Pn,this.Header=In,n(this[me])}get[me](){return"flac"}*_getNextFrameSyncOffset(e){let r=yield*this._codecParser[ae](2,0),n=r[P]-2;for(;e<n;){if(r[e]===255){let a=r[e+1];if(a===248||a===249)break;a!==255&&e++}e++}return e}*[Cr](){do{let e=yield*In[ue](this._codecParser,this._headerCache,0);if(e){let r=Be.get(e)[P]+A1;for(;r<=E1;){if(this._codecParser._flushing||(yield*In[ue](this._codecParser,this._headerCache,r))){let n=yield*this._codecParser[ae](r);if(this._codecParser._flushing||(n=n[q](0,r)),Pn[pl](n)){let i=new Pn(n,e);return this._headerCache[ur](),this._codecParser[qt](r),this._codecParser[Ln](i),i}}r=yield*this._getNextFrameSyncOffset(r+1)}this._codecParser[cr](`Unable to sync FLAC frame after searching ${r} bytes.`),this._codecParser[qt](r)}else this._codecParser[qt](yield*this._getNextFrameSyncOffset(1))}while(!0)}[Rn](e){return e[Te]===0?(this._headerCache[ur](),this._streamInfo=e[he][q](13)):e[Te]===1||(e[nt]=Ze.get(e)[$t].map(r=>{let n=In[Qt](r,this._headerCache);if(n)return new Pn(r,n,this._streamInfo);this._codecParser[cr]("Failed to parse Ogg FLAC frame","Skipping invalid FLAC frame")}).filter(r=>!!r)),e}};var hi=class t{static*[ue](e,r,n){let i={},a=yield*e[ae](28,n);if(a[0]!==79||a[1]!==103||a[2]!==103||a[3]!==83||(i[hd]=a[4],a[5]&248))return null;i[Ft]=!!(a[5]&4),i[Sn]=!!(a[5]&2),i[_n]=!!(a[5]&1);let s=new Cn(at.from(a[q](0,28))[Ar]);i[lr]=sh(s,6),i[Rr]=s.getInt32(14,!0),i[Te]=s.getInt32(18,!0),i[ii]=s.getInt32(22,!0);let c=a[26];i[P]=c+27,a=yield*e[ae](i[P],n),i[Tt]=0,i[En]=[],i[ta]=at.from(a[q](27,i[P]));for(let l=0,d=0;l<c;l++){let f=i[ta][l];i[Tt]+=f,d+=f,(f!==255||l===c-1)&&(i[En].push(d),d=0)}return new t(i)}constructor(e){Be.set(this,e),this[lr]=e[lr],this[_n]=e[_n],this[Sn]=e[Sn],this[Ft]=e[Ft],this[En]=e[En],this[Te]=e[Te],this[ii]=e[ii],this[Rr]=e[Rr]}};var Ho=class t extends li{static*[jt](e,r,n){let i=yield*hi[ue](e,r,n);if(i){let a=Be.get(i)[Tt],o=Be.get(i)[P],s=o+a,c=(yield*e[ae](s,0))[q](0,s),l=c[q](o,s);return new t(i,l,c)}else return null}constructor(e,r,n){super(e,r),Ze.get(this)[P]=n[P],this[nt]=[],this[dd]=n,this[lr]=e[lr],this[uo]=e[ii],this[Er]=0,this[_n]=e[_n],this[Sn]=e[Sn],this[Ft]=e[Ft],this[Te]=e[Te],this[te]=0,this[Rr]=e[Rr]}};var na=class extends Dt{constructor(e,r,n){super(r,e,n)}};var gh={0:no.slice(0,2),1:no},Jt="SILK-only",je="CELT-only",El="Hybrid",Bn="narrowband",Ll="medium-band",Fn="wideband",ia="super-wideband",aa="fullband",L1={0:{[W]:Jt,[X]:Bn,[G]:10},8:{[W]:Jt,[X]:Bn,[G]:20},16:{[W]:Jt,[X]:Bn,[G]:40},24:{[W]:Jt,[X]:Bn,[G]:60},32:{[W]:Jt,[X]:Ll,[G]:10},40:{[W]:Jt,[X]:Ll,[G]:20},48:{[W]:Jt,[X]:Ll,[G]:40},56:{[W]:Jt,[X]:Ll,[G]:60},64:{[W]:Jt,[X]:Fn,[G]:10},72:{[W]:Jt,[X]:Fn,[G]:20},80:{[W]:Jt,[X]:Fn,[G]:40},88:{[W]:Jt,[X]:Fn,[G]:60},96:{[W]:El,[X]:ia,[G]:10},104:{[W]:El,[X]:ia,[G]:20},112:{[W]:El,[X]:aa,[G]:10},120:{[W]:El,[X]:aa,[G]:20},128:{[W]:je,[X]:Bn,[G]:2.5},136:{[W]:je,[X]:Bn,[G]:5},144:{[W]:je,[X]:Bn,[G]:10},152:{[W]:je,[X]:Bn,[G]:20},160:{[W]:je,[X]:Fn,[G]:2.5},168:{[W]:je,[X]:Fn,[G]:5},176:{[W]:je,[X]:Fn,[G]:10},184:{[W]:je,[X]:Fn,[G]:20},192:{[W]:je,[X]:ia,[G]:2.5},200:{[W]:je,[X]:ia,[G]:5},208:{[W]:je,[X]:ia,[G]:10},216:{[W]:je,[X]:ia,[G]:20},224:{[W]:je,[X]:aa,[G]:2.5},232:{[W]:je,[X]:aa,[G]:5},240:{[W]:je,[X]:aa,[G]:10},248:{[W]:je,[X]:aa,[G]:20}},oa=class t extends zt{static[Qt](e,r,n){let i={};if(i[N]=e[9],i[qr]=e[18],i[P]=i[qr]!==0?21+i[N]:19,e[P]<i[P])throw new Error("Out of data while inside an Ogg Page");let a=r[0]&3,o=a===3?2:1,s=kt(e[q](0,i[P]))+kt(r[q](0,o)),c=n[ue](s);if(c)return new t(c);if(s.substr(0,8)!=="OpusHead"||e[8]!==1)return null;i[he]=at.from(e[q](0,i[P]));let l=new Cn(i[he][Ar]);if(i[tt]=16,i[ri]=l.getUint16(10,!0),i[Eo]=l.getUint32(12,!0),i[ee]=vn,i[yo]=l.getInt16(16,!0),i[qr]in gh&&(i[it]=gh[i[qr]][i[N]-1],!i[it]))return null;i[qr]!==0&&(i[To]=e[19],i[lo]=e[20],i[So]=[...e[q](21,i[N]+21)]);let d=L1[248&r[0]];switch(i[W]=d[W],i[X]=d[X],i[G]=d[G],a){case 0:i[jr]=1;break;case 1:case 2:i[jr]=2;break;case 3:i[po]=!!(128&r[1]),i[fo]=!!(64&r[1]),i[jr]=63&r[1];break;default:return null}{let{length:f,data:u,channelMappingFamily:h,...m}=i;n[Zt](s,i,m)}return new t(i)}constructor(e){super(e),this[he]=e[he],this[X]=e[X],this[qr]=e[qr],this[So]=e[So],this[lo]=e[lo],this[jr]=e[jr],this[G]=e[G],this[fo]=e[fo],this[Eo]=e[Eo],this[po]=e[po],this[W]=e[W],this[yo]=e[yo],this[ri]=e[ri],this[To]=e[To]}};var Vo=class extends st{constructor(e,r,n){super(e,r),this.Frame=na,this.Header=oa,n(this[me]),this._identificationHeader=null,this._preSkipRemaining=null}get[me](){return"opus"}[Rn](e){return e[Te]===0?(this._headerCache[ur](),this._identificationHeader=e[he]):e[Te]===1||(e[nt]=Ze.get(e)[$t].map(r=>{let n=oa[Qt](this._identificationHeader,r,this._headerCache);if(n){this._preSkipRemaining===null&&(this._preSkipRemaining=n[ri]);let i=n[G]*n[jr]/1e3*n[ee];return this._preSkipRemaining>0&&(this._preSkipRemaining-=i,i=this._preSkipRemaining<0?-this._preSkipRemaining:0),new na(r,n,i)}this._codecParser[hl]("Failed to parse Ogg Opus Header","Not a valid Ogg Opus file")})),e}};var sa=class extends Dt{constructor(e,r,n){super(r,e,n)}};var wd={};for(let t=0;t<8;t++)wd[t+6]=2**(6+t);var Go=class t extends zt{static[Qt](e,r,n,i){if(e[P]<30)throw new Error("Out of data while inside an Ogg Page");let a=kt(e[q](0,30)),o=r[ue](a);if(o)return new t(o);let s={[P]:30};if(a.substr(0,7)!=="vorbis")return null;s[he]=at.from(e[q](0,30));let c=new Cn(s[he][Ar]);if(s[wn]=c.getUint32(7,!0),s[wn]!==0||(s[N]=e[11],s[it]=no[s[N]-1]||"application defined",s[ee]=c.getUint32(12,!0),s[io]=c.getInt32(16,!0),s[oo]=c.getInt32(20,!0),s[ao]=c.getInt32(24,!0),s[An]=wd[(e[28]&240)>>4],s[Mn]=wd[e[28]&15],s[Mn]>s[An])||e[29]!==1)return null;s[tt]=32,s[ea]=i,s[xo]=n;{let{length:l,data:d,version:f,vorbisSetup:u,vorbisComments:h,...m}=s;r[Zt](a,s,m)}return new t(s)}constructor(e){super(e),this[io]=e[io],this[ao]=e[ao],this[oo]=e[oo],this[Mn]=e[Mn],this[An]=e[An],this[he]=e[he],this[xo]=e[xo],this[ea]=e[ea]}};var Wo=class extends st{constructor(e,r,n){super(e,r),this.Frame=sa,n(this[me]),this._identificationHeader=null,this._setupComplete=!1,this._prevBlockSize=null}get[me](){return ni}[Rn](e){e[nt]=[];for(let r of Ze.get(e)[$t])if(r[0]===1)this._headerCache[ur](),this._identificationHeader=e[he],this._setupComplete=!1;else if(r[0]===3)this._vorbisComments=r;else if(r[0]===5)this._vorbisSetup=r,this._mode=this._parseSetupHeader(r),this._setupComplete=!0;else if(this._setupComplete){let n=Go[Qt](this._identificationHeader,this._headerCache,this._vorbisComments,this._vorbisSetup);n?e[nt].push(new sa(r,n,this._getSamples(r,n))):this._codecParser[logError]("Failed to parse Ogg Vorbis Header","Not a valid Ogg Vorbis file")}return e}_getSamples(e,r){let i=this._mode.blockFlags[e[0]>>1&this._mode.mask]?r[An]:r[Mn],a=this._prevBlockSize===null?0:(this._prevBlockSize+i)/4;return this._prevBlockSize=i,a}_parseSetupHeader(e){let r=new yl(e),n={count:0,blockFlags:[]};for(;(r.read(1)&1)!==1;);let i;for(;n.count<64&&r.position>0;){Io(r.read(8));let a=0;for(;r.read(8)===0&&a++<3;);if(a===4)i=r.read(7),n.blockFlags.unshift(i&1),r.position+=6,n.count++;else{((Io(i)&126)>>1)+1!==n.count&&this._codecParser[cr]("vorbis derived mode count did not match actual mode count");break}}return n.mask=(1<<Math.log2(n.count))-1,n}};var Md=class{constructor(e,r,n){this._codecParser=e,this._headerCache=r,this._onCodec=n,this._continuedPacket=new at,this._codec=null,this._isSupported=null,this._previousAbsoluteGranulePosition=null}get[me](){return this._codec||""}_updateCodec(e,r){this._codec!==e&&(this._headerCache[dr](),this._parser=new r(this._codecParser,this._headerCache,this._onCodec),this._codec=e)}_checkCodecSupport({data:e}){let r=kt(e[q](0,8));switch(r){case"fishead\0":return!1;case"OpusHead":return this._updateCodec("opus",Vo),!0;case(/^\x7fFLAC/.test(r)&&r):return this._updateCodec("flac",fi),!0;case(/^\x01vorbis/.test(r)&&r):return this._updateCodec(ni,Wo),!0;default:return!1}}_checkPageSequenceNumber(e){e[Te]!==this._pageSequenceNumber+1&&this._pageSequenceNumber>1&&e[Te]>1&&this._codecParser[cr]("Unexpected gap in Ogg Page Sequence Number.",`Expected: ${this._pageSequenceNumber+1}, Got: ${e[Te]}`),this._pageSequenceNumber=e[Te]}_parsePage(e){this._isSupported===null&&(this._pageSequenceNumber=e[Te],this._isSupported=this._checkCodecSupport(e)),this._checkPageSequenceNumber(e);let r=Ze.get(e),n=Be.get(r[Bt]),i=0;if(r[$t]=n[En].map(a=>e[he][q](i,i+=a)),this._continuedPacket[P]&&(r[$t][0]=Bo(this._continuedPacket,r[$t][0]),this._continuedPacket=new at),n[ta][n[ta][P]-1]===255&&(this._continuedPacket=Bo(this._continuedPacket,r[$t].pop())),this._previousAbsoluteGranulePosition!==null&&(e[te]=Number(e[lr]-this._previousAbsoluteGranulePosition)),this._previousAbsoluteGranulePosition=e[lr],this._isSupported){let a=this._parser[Rn](e);return this._codecParser[Ln](a),a}else return e}},Xo=class extends st{constructor(e,r,n){super(e,r),this._onCodec=n,this.Frame=Ho,this.Header=hi,this._streams=new Map,this._currentSerialNumber=null}get[me](){let e=this._streams.get(this._currentSerialNumber);return e?e.codec:""}*[Cr](){let e=yield*this[Tn](!0);this._currentSerialNumber=e[Rr];let r=this._streams.get(this._currentSerialNumber);return r||(r=new Md(this._codecParser,this._headerCache,this._onCodec),this._streams.set(this._currentSerialNumber,r)),e[Ft]&&this._streams.delete(this._currentSerialNumber),r._parsePage(e)}};var Ad=()=>{},Ko=class{constructor(e,{onCodec:r,onCodecHeader:n,onCodecUpdate:i,enableLogging:a=!1,enableFrameCRC32:o=!0}={}){this._inputMimeType=e,this._onCodec=r||Ad,this._onCodecHeader=n||Ad,this._onCodecUpdate=i,this._enableLogging=a,this._crc32=o?oh:Ad,this[dr]()}get[me](){return this._parser?this._parser[me]:""}[dr](){this._headerCache=new Fo(this._onCodecHeader,this._onCodecUpdate),this._generator=this._getGenerator(),this._generator.next()}*flush(){this._flushing=!0;for(let e=this._generator.next();e.value;e=this._generator.next())yield e.value;this._flushing=!1,this[dr]()}*parseChunk(e){for(let r=this._generator.next(e);r.value;r=this._generator.next())yield r.value}parseAll(e){return[...this.parseChunk(e),...this.flush()]}*_getGenerator(){if(this._inputMimeType.match(/aac/))this._parser=new No(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/mpeg/))this._parser=new Oo(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/flac/))this._parser=new fi(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/ogg/))this._parser=new Xo(this,this._headerCache,this._onCodec);else throw new Error(`Unsupported Codec ${mimeType}`);for(this._frameNumber=0,this._currentReadPosition=0,this._totalBytesIn=0,this._totalBytesOut=0,this._totalSamples=0,this._sampleRate=void 0,this._rawData=new Uint8Array(0);;){let e=yield*this._parser[Cr]();e&&(yield e)}}*[ae](e=0,r=0){let n;for(;this._rawData[P]<=e+r;){if(n=yield,this._flushing)return this._rawData[q](r);n&&(this._totalBytesIn+=n[P],this._rawData=Bo(this._rawData,n))}return this._rawData[q](r)}[qt](e){this._currentReadPosition+=e,this._rawData=this._rawData[q](e)}[Co](e){this._sampleRate=e[Bt][ee],e[Bt][rt]=e[Er]>0?Math.round(e[he][P]/e[Er])*8:0,e[Qr]=this._frameNumber++,e[ai]=this._totalBytesOut,e[si]=this._totalSamples,e[oi]=this._totalSamples/this._sampleRate*1e3,e[uo]=this._crc32(e[he]),this._headerCache[ml](e[Bt][rt],e[oi]),this._totalBytesOut+=e[he][P],this._totalSamples+=e[te]}[Ln](e){if(e[nt]){if(e[Ft]){let r=e[te];e[nt].forEach(n=>{let i=n[te];r<i&&(n[te]=r>0?r:0,n[Er]=n[te]/n[Bt][ee]*1e3),r-=i,this[Co](n)})}else e[te]=0,e[nt].forEach(r=>{e[te]+=r[te],this[Co](r)});e[Er]=e[te]/this._sampleRate*1e3||0,e[si]=this._totalSamples,e[oi]=this._totalSamples/this._sampleRate*1e3||0,e[ai]=this._totalBytesOut}else this[Co](e)}_log(e,r){if(this._enableLogging){let n=[`${me}: ${this[me]}`,`inputMimeType: ${this._inputMimeType}`,`readPosition: ${this._currentReadPosition}`,`totalBytesIn: ${this._totalBytesIn}`,`${ai}: ${this._totalBytesOut}`],i=Math.max(...n.map(a=>a[P]));r.push(`--stats--${"-".repeat(i-9)}`,...n,"-".repeat(i)),e("codec-parser",r.reduce((a,o)=>a+`
|
|
4
|
-
`+o,""))}}[cr](...e){this._log(console.warn,e)}[hl](...e){this._log(console.error,e)}};var yh=Ko;var Tl=nt;var Rl=he;var bh=Bt;var xh=Ft;var vh=ea;var _h=si;function Jr(t){var e=e;function r(){}e={};function n(k){throw k}var i,a,o,s,c,l,d,f,u,h,m;function g(){var k=m.buffer;i=new Int8Array(k),a=new Int16Array(k),s=new Uint8Array(k),c=new Uint16Array(k),o=new Int32Array(k),l=new Uint32Array(k),d=new Float32Array(k),f=new Float64Array(k),u=new BigInt64Array(k),h=new BigUint64Array(k)}for(var p=k=>{for(var oe,Ce,Re=0,ir=0,Vt=k.length,ln=new Uint8Array((Vt*3>>2)-(k[Vt-2]=="=")-(k[Vt-1]=="="));Re<Vt;Re+=4,ir+=3)oe=U[k.charCodeAt(Re+1)],Ce=U[k.charCodeAt(Re+2)],ln[ir]=U[k.charCodeAt(Re)]<<2|oe>>4,ln[ir+1]=oe<<4|Ce>>2,ln[ir+2]=Ce<<6|U[k.charCodeAt(Re+3)];return ln},y=()=>n(""),v=()=>{},x={},b=k=>k(),_=()=>performance.now(),w=(k,oe)=>{if(x[k]&&(clearTimeout(x[k].id),delete x[k]),!oe)return 0;var Ce=setTimeout(()=>{delete x[k],b(()=>Or(k,_()))},oe);return x[k]={id:Ce,timeout_ms:oe},0},S=Math.atan,E=Math.cos,L=Math.exp,M=Math.log,
|
|
4
|
+
`+o,""))}}[cr](...e){this._log(console.warn,e)}[hl](...e){this._log(console.error,e)}};var yh=Ko;var Tl=nt;var Rl=he;var bh=Bt;var xh=Ft;var vh=ea;var _h=si;function Jr(t){var e=e;function r(){}e={};function n(k){throw k}var i,a,o,s,c,l,d,f,u,h,m;function g(){var k=m.buffer;i=new Int8Array(k),a=new Int16Array(k),s=new Uint8Array(k),c=new Uint16Array(k),o=new Int32Array(k),l=new Uint32Array(k),d=new Float32Array(k),f=new Float64Array(k),u=new BigInt64Array(k),h=new BigUint64Array(k)}for(var p=k=>{for(var oe,Ce,Re=0,ir=0,Vt=k.length,ln=new Uint8Array((Vt*3>>2)-(k[Vt-2]=="=")-(k[Vt-1]=="="));Re<Vt;Re+=4,ir+=3)oe=U[k.charCodeAt(Re+1)],Ce=U[k.charCodeAt(Re+2)],ln[ir]=U[k.charCodeAt(Re)]<<2|oe>>4,ln[ir+1]=oe<<4|Ce>>2,ln[ir+2]=Ce<<6|U[k.charCodeAt(Re+3)];return ln},y=()=>n(""),v=()=>{},x={},b=k=>k(),_=()=>performance.now(),w=(k,oe)=>{if(x[k]&&(clearTimeout(x[k].id),delete x[k]),!oe)return 0;var Ce=setTimeout(()=>{delete x[k],b(()=>Or(k,_()))},oe);return x[k]={id:Ce,timeout_ms:oe},0},S=Math.atan,E=Math.cos,L=Math.exp,M=Math.log,C=Math.pow,I=Math.sin,B=k=>{var oe=s.length;return k>>>=0,!1},F=k=>{throw`exit(${k})`},U=new Uint8Array(123),ce=25;ce>=0;--ce)U[48+ce]=52+ce,U[65+ce]=ce,U[97+ce]=26+ce;U[43]=62,U[47]=63;var Nt={e:y,d:v,f:w,b:S,a:E,i:L,h:M,g:C,c:I,k:B,j:F};function Ct(k){zr=k.n,on=k.o,dt=k.p,et=k.q,Ht=k.r,Gn=k.s,sn=k.t,Or=k.v}var zr,on,dt,et,Ht,Gn,sn,Or;function Ur(k){k.m()}Jr.wasm||Object.defineProperty(Jr,"wasm",{get:()=>String.raw`dynEncode012091253f87dì%nä= 4&¿nÝØäÂLÚªã9ÚØ[äº\ ¼¡³R=}L]Èÿ2 ÿù¶J1jj¡é,zäV|i¸Qk¹=
|
|
5
5
|
¨¨%ýv²±»oúâLa:ê±ÊäÌÓ.÷Øý×>àW>z¯°8¯ñ\Ñós9\§ôÊ@Ü (tÃø4° ¢7fqÓg²Jè6x[zç®&4=} p.(°tÍÞã¾>÷CõË"*k?¿~7~H2ÛÜâ.ÏQä;6{ÜãFÑá'DD¤±°HQ>MínÎÏÎöʵÑÓ
ÞÌP¼P¨Þ*X²E=M¦qíxMñ=MÌë4/<gNO/¢ ¢>a~Ï®ììììì0ìa笡çëOÓÇM Q9tùµyuéµµÞÏ/±Óõò}E{òÓJ¹Û|·ôfÒ c¬Wêaûÿlʽp¹|)ÖEL¦ }ypÕSϹI]¢ºãæ°ÿo¶7ÛRq¾ÔÅEߨ]æËwÚ{óçVwó1¾EØpàe"Æùû¡Áª Ààð´LõÎxEÓ¢N¦
9ëùi& Ò§Ø!ÇFçS=MbäO?߷縪7ùa}5ðûÕtsUþ£KïgN¾)ø§\V0uSIö:ÌU4ж¯´Õn9ÔèE£ZƼ{hµmÙ¾6ÆÑ+xñ´«þ¸=Mߤ·å®«ïÆGFÝì|H?äE"þ!9«Æïpæ'][¯ù·£W÷O§&#ax$qf=}ø ô bÏ×W÷LôoÝWQÕÓ)u÷½èV|¥Gà¨Ö¸@ê|ÇK5ò A·Â9CS2¸¼¿,äÝÑÝy!ÑR%ÆÝÎ0Âv§ qTcó±hØÉã=}Z=}Ælüën¯ð(-°ÜwVÏï.th¥íS~SÏ»ZZÔZ
|
|
6
6
|
3BÌÛ¬<éæO)ÎyÚ¯O*®uìÛ$öI¥Ý9ôø³\¤ò³Ù¹ÇP¸J×y@ÔyOÇmô½ü¾|S?2àú¤F?½ûoo3ô;<àáûÜ8ì²7ïë¨RäY¹|ÓºÌF,Ð-¸*\P!FJÒ8= o6HwLrúº¶ÐÛ\Ù¬o¢9IqÝ.ôf¶ÎÈ{Ī×N|Mfs
¤ÉÝàâ§*+ã§ô¯î¬7ç×§ä)!Z¨É,Äp~ý·wsSGóäsE\ýïé§Ö:Ò'Cç(_X$\¦½eÒ8$XF|eíÙÓ¡¤Û<ØÞÛ¸9¿ðÃÎ#b~× 4éîÿÏq
|
|
7
7
|
ód|0wU&®è·vh6¨{ÚçÚ18Ó(ÓY\0¦= çèíß)Ø=}[xü-v?N(Kkg0}âÚ´ð¬ÕQNÍ¢usѳ=}. ëg
û= ÍMBp'²¨ x4è@9t§eݵ¾âð½ z?Z¹FH'̯¿<K,üµ<{ ¶JãývåàÆeù0Ð"F¥ÃÒÞþÔÉvCzl}ðN£ Í^P%²¸FX»WÎêô¶
äÉJ^g×SÃã.Ät*'ªG«ÒB<ÜÓ
¿ºp\àuV¯£ÅݽáÞ ùß=}ÎÚ^ÿí>¥!¨ â=M·?*/¤"å)â·ÿîÿî*(%*2[½"üríÔ4l½»a}¯CwpCÓèìGc-ã6®=M32k?Êg
!So-x>³G+ã@ò, ÁïáåN0þÙè.~È÷¡vTr¶Ã[üB±º»ávëw¹{pܺû"Aæ±9Æ^¹³òïRIAy5GÂwÉf4@Tù|qý7ðªwBL|Ôqv!ª°|]KiÐJVQ5¸åõ§å"H¼0e¬<óBîÚSÏUìHPÙA+çÉ'seÌNf°@ÈM,ð½egÖ¬x©û½2~«Ò1;Ö«
¯°4&90èE»Ó׺çʧJ<Æ¿&~Nu¼ãÙµ¢.UÇä(qQô^ö·%!É
|
|
@@ -339,7 +339,7 @@ void main() {
|
|
|
339
339
|
}
|
|
340
340
|
|
|
341
341
|
o_color = finalColor;
|
|
342
|
-
}`,Fh=[0,255,255,255],X1=[0,-1,-1,-1];function Od(t=Fh,e=[]){let r=new Float32Array(4);for(let n=0;n<4;n+=1){let i=t[n]??255;if(i===255){r[n]=0;continue}let a=e[i];r[n]=a!==void 0?a:1}return r}function K1(t){return[-(t*.25%1),0]}function Ud(t=Ga,e=0){let r=(t&pf)!==0,n=(t&Wa)!==0,i=(t&Ds)!==0,a=(t&zs)!==0,o=(t&Os)!==0,s=a?.33:o?.66:1,c=a||o||n,l=!c&&!i,d=r?K1(e):[0,0];return{alpha:s,blend:c,depthWrite:l,warp:n,flowOffset:d,sky:i}}var fa=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Dd,fragment:zd},{a_position:0,a_texCoord:1,a_lightmapCoord:2,a_lightmapStep:3}),this.uniformMvp=this.program.getUniformLocation("u_modelViewProjection"),this.uniformTexScroll=this.program.getUniformLocation("u_texScroll"),this.uniformLmScroll=this.program.getUniformLocation("u_lightmapScroll"),this.uniformLightStyles=this.program.getUniformLocation("u_lightStyleFactors"),this.uniformStyleLayerMapping=this.program.getUniformLocation("u_styleLayerMapping"),this.uniformAlpha=this.program.getUniformLocation("u_alpha"),this.uniformApplyLightmap=this.program.getUniformLocation("u_applyLightmap"),this.uniformWarp=this.program.getUniformLocation("u_warp"),this.uniformLightmapOnly=this.program.getUniformLocation("u_lightmapOnly"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformLightmap=this.program.getUniformLocation("u_lightmapAtlas"),this.uniformRefraction=this.program.getUniformLocation("u_refractionMap"),this.uniformHasRefraction=this.program.getUniformLocation("u_hasRefraction"),this.uniformTime=this.program.getUniformLocation("u_time"),this.uniformRenderMode=this.program.getUniformLocation("u_renderMode"),this.uniformSolidColor=this.program.getUniformLocation("u_solidColor"),this.uniformNumDlights=this.program.getUniformLocation("u_numDlights");for(let r=0;r<Dn;r++)this.uniformDlights.push({pos:this.program.getUniformLocation(`u_dlights[${r}].position`),color:this.program.getUniformLocation(`u_dlights[${r}].color`),intensity:this.program.getUniformLocation(`u_dlights[${r}].intensity`)});this.uniformBrightness=this.program.getUniformLocation("u_brightness"),this.uniformGamma=this.program.getUniformLocation("u_gamma"),this.uniformFullbright=this.program.getUniformLocation("u_fullbright"),this.uniformAmbient=this.program.getUniformLocation("u_ambient")}get shaderSize(){return this.program.sourceSize}bind(e){let{modelViewProjection:r,styleIndices:n=Fh,styleLayers:i=X1,styleValues:a=[],diffuseSampler:o=0,lightmapSampler:s,refractionSampler:c,surfaceFlags:l=Ga,timeSeconds:d=0,texScroll:f,alpha:u,warp:h,dlights:m=[],renderMode:g,lightmapOnly:p,brightness:y=1,gamma:v=1,fullbright:x=!1,ambient:b=0}=e,_=Ud(l,d),w=Od(n,a),S=f?f[0]:_.flowOffset[0],E=f?f[1]:_.flowOffset[1],L=u!==void 0?u:_.alpha,M=h!==void 0?h:_.warp;this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,r),this.gl.uniform2f(this.uniformTexScroll,S,E),this.gl.uniform2f(this.uniformLmScroll,_.flowOffset[0],_.flowOffset[1]),this.gl.uniform4fv(this.uniformLightStyles,w),this.gl.uniform4fv(this.uniformStyleLayerMapping,i),this.gl.uniform1f(this.uniformAlpha,L);let
|
|
342
|
+
}`,Fh=[0,255,255,255],X1=[0,-1,-1,-1];function Od(t=Fh,e=[]){let r=new Float32Array(4);for(let n=0;n<4;n+=1){let i=t[n]??255;if(i===255){r[n]=0;continue}let a=e[i];r[n]=a!==void 0?a:1}return r}function K1(t){return[-(t*.25%1),0]}function Ud(t=Ga,e=0){let r=(t&pf)!==0,n=(t&Wa)!==0,i=(t&Ds)!==0,a=(t&zs)!==0,o=(t&Os)!==0,s=a?.33:o?.66:1,c=a||o||n,l=!c&&!i,d=r?K1(e):[0,0];return{alpha:s,blend:c,depthWrite:l,warp:n,flowOffset:d,sky:i}}var fa=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Dd,fragment:zd},{a_position:0,a_texCoord:1,a_lightmapCoord:2,a_lightmapStep:3}),this.uniformMvp=this.program.getUniformLocation("u_modelViewProjection"),this.uniformTexScroll=this.program.getUniformLocation("u_texScroll"),this.uniformLmScroll=this.program.getUniformLocation("u_lightmapScroll"),this.uniformLightStyles=this.program.getUniformLocation("u_lightStyleFactors"),this.uniformStyleLayerMapping=this.program.getUniformLocation("u_styleLayerMapping"),this.uniformAlpha=this.program.getUniformLocation("u_alpha"),this.uniformApplyLightmap=this.program.getUniformLocation("u_applyLightmap"),this.uniformWarp=this.program.getUniformLocation("u_warp"),this.uniformLightmapOnly=this.program.getUniformLocation("u_lightmapOnly"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformLightmap=this.program.getUniformLocation("u_lightmapAtlas"),this.uniformRefraction=this.program.getUniformLocation("u_refractionMap"),this.uniformHasRefraction=this.program.getUniformLocation("u_hasRefraction"),this.uniformTime=this.program.getUniformLocation("u_time"),this.uniformRenderMode=this.program.getUniformLocation("u_renderMode"),this.uniformSolidColor=this.program.getUniformLocation("u_solidColor"),this.uniformNumDlights=this.program.getUniformLocation("u_numDlights");for(let r=0;r<Dn;r++)this.uniformDlights.push({pos:this.program.getUniformLocation(`u_dlights[${r}].position`),color:this.program.getUniformLocation(`u_dlights[${r}].color`),intensity:this.program.getUniformLocation(`u_dlights[${r}].intensity`)});this.uniformBrightness=this.program.getUniformLocation("u_brightness"),this.uniformGamma=this.program.getUniformLocation("u_gamma"),this.uniformFullbright=this.program.getUniformLocation("u_fullbright"),this.uniformAmbient=this.program.getUniformLocation("u_ambient")}get shaderSize(){return this.program.sourceSize}bind(e){let{modelViewProjection:r,styleIndices:n=Fh,styleLayers:i=X1,styleValues:a=[],diffuseSampler:o=0,lightmapSampler:s,refractionSampler:c,surfaceFlags:l=Ga,timeSeconds:d=0,texScroll:f,alpha:u,warp:h,dlights:m=[],renderMode:g,lightmapOnly:p,brightness:y=1,gamma:v=1,fullbright:x=!1,ambient:b=0}=e,_=Ud(l,d),w=Od(n,a),S=f?f[0]:_.flowOffset[0],E=f?f[1]:_.flowOffset[1],L=u!==void 0?u:_.alpha,M=h!==void 0?h:_.warp;this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,r),this.gl.uniform2f(this.uniformTexScroll,S,E),this.gl.uniform2f(this.uniformLmScroll,_.flowOffset[0],_.flowOffset[1]),this.gl.uniform4fv(this.uniformLightStyles,w),this.gl.uniform4fv(this.uniformStyleLayerMapping,i),this.gl.uniform1f(this.uniformAlpha,L);let C=!_.sky&&s!==void 0&&!M;this.gl.uniform1i(this.uniformApplyLightmap,C?1:0),this.gl.uniform1i(this.uniformWarp,M?1:0),this.gl.uniform1i(this.uniformLightmapOnly,p?1:0),this.gl.uniform1f(this.uniformTime,d),this.gl.uniform1i(this.uniformDiffuse,o),this.gl.uniform1i(this.uniformLightmap,s??0),c!==void 0&&M?(this.gl.uniform1i(this.uniformRefraction,c),this.gl.uniform1i(this.uniformHasRefraction,1)):this.gl.uniform1i(this.uniformHasRefraction,0);let I=0,B=[1,1,1,1];g&&(g.mode==="solid"||g.mode==="wireframe"?I=1:g.mode==="solid-faceted"&&(I=2),g.color?B=[...g.color]:g.generateRandomColor&&(B=[1,1,1,1])),this.gl.uniform1i(this.uniformRenderMode,I),this.gl.uniform4f(this.uniformSolidColor,B[0],B[1],B[2],B[3]);let F=Math.min(m.length,Dn);this.gl.uniform1i(this.uniformNumDlights,F);for(let U=0;U<F;U++){let ce=m[U];this.gl.uniform3f(this.uniformDlights[U].pos,ce.origin.x,ce.origin.y,ce.origin.z),this.gl.uniform3f(this.uniformDlights[U].color,ce.color.x,ce.color.y,ce.color.z),this.gl.uniform1f(this.uniformDlights[U].intensity,ce.intensity)}return this.gl.uniform1f(this.uniformBrightness,y),this.gl.uniform1f(this.uniformGamma,v),this.gl.uniform1i(this.uniformFullbright,x?1:0),this.gl.uniform1f(this.uniformAmbient,b),_}draw(e,r){if(e.vao.bind(),r&&r.mode==="wireframe"){if(!e.wireframeIndexBuffer){let n=e;n.wireframeIndexBuffer=new Qe(this.gl,this.gl.STATIC_DRAW);let i=ua(e.indexData);n.wireframeIndexBuffer.upload(i),n.wireframeIndexCount=i.length}e.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,e.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else e.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,e.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};function es(t,e){t.depthMask(e.depthWrite),e.blend?(t.enable(t.BLEND),t.blendFunc(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA)):t.disable(t.BLEND)}var kh=new Float32Array([-1,-1,1,1,-1,1,1,1,1,-1,-1,1,1,1,1,-1,1,1,-1,-1,-1,-1,1,-1,1,1,-1,-1,-1,-1,1,1,-1,1,-1,-1,-1,-1,-1,-1,-1,1,-1,1,1,-1,-1,-1,-1,1,1,-1,1,-1,1,-1,-1,1,1,-1,1,1,1,1,-1,-1,1,1,1,1,-1,1,-1,1,-1,-1,1,1,1,1,1,-1,1,-1,1,1,1,1,1,-1,-1,-1,-1,1,-1,-1,1,-1,1,-1,-1,-1,1,-1,1,-1,-1,1]),Nd=`#version 300 es
|
|
343
343
|
precision highp float;
|
|
344
344
|
|
|
345
345
|
layout(location = 0) in vec3 a_position;
|
|
@@ -476,7 +476,7 @@ void main() {
|
|
|
476
476
|
}
|
|
477
477
|
|
|
478
478
|
o_color = finalColor;
|
|
479
|
-
}`;function Y1(t){let e=t.x*t.x+t.y*t.y+t.z*t.z;if(e<=0)return{x:0,y:0,z:1};let r=1/Math.sqrt(e);return{x:t.x*r,y:t.y*r,z:t.z*r}}function Vd(t,e,r){return t+(e-t)*r}function Dh(t,e,r){return{x:Vd(t.x,e.x,r),y:Vd(t.y,e.y,r),z:Vd(t.z,e.z,r)}}function $1(t,e,r){return[t/r.skinWidth,1-e/r.skinHeight]}function Xd(t){if(t.glCommands.length===0){let n=[],i=[];return t.triangles.forEach(a=>{let o=n.length;for(let s=0;s<3;s+=1){let c=a.vertexIndices[s],l=a.texCoordIndices[s],d=t.texCoords[l];n.push({vertexIndex:c,texCoord:$1(d.s,d.t,t.header)})}i.push(o,o+1,o+2)}),{vertices:n,indices:new Uint16Array(i)}}let e=[],r=[];for(let n of t.glCommands){let i=e.length;if(e.push(...n.vertices.map(a=>({vertexIndex:a.vertexIndex,texCoord:[a.s,1-a.t]}))),n.mode==="strip")for(let a=0;a<n.vertices.length-2;a+=1){let o=a%2===0,s=i+a+(o?0:1),c=i+a+(o?1:0),l=i+a+2;r.push(s,c,l)}else for(let a=1;a<n.vertices.length-1;a+=1)r.push(i,i+a,i+a+1)}return{vertices:e,indices:new Uint16Array(r)}}function Kd(t,e,r){let{frame0:n,frame1:i,lerp:a}=r,o=t.frames[n],s=t.frames[i];if(!o||!s)throw new Error("Requested MD2 frames are out of range");let c=new Float32Array(e.vertices.length*8);return e.vertices.forEach((l,d)=>{let f=o.vertices[l.vertexIndex],u=s.vertices[l.vertexIndex];if(!f||!u)throw new Error("MD2 vertex index out of range for frame");let h=Dh(f.position,u.position,a),m=Y1(Dh(f.normal,u.normal,a)),g=d*8;c[g]=h.x,c[g+1]=h.y,c[g+2]=h.z,c[g+3]=m.x,c[g+4]=m.y,c[g+5]=m.z,c[g+6]=l.texCoord[0],c[g+7]=l.texCoord[1]}),c}var ma=class{constructor(e,r,n){this.gl=e,this.geometry=Xd(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Qe(e,e.STATIC_DRAW),this.vertexArray=new Ee(e),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:32,offset:0},{index:1,size:3,type:e.FLOAT,stride:32,offset:12},{index:2,size:2,type:e.FLOAT,stride:32,offset:24}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,e.STATIC_DRAW),this.update(r,n)}update(e,r){let n=Kd(e,this.geometry,r);this.vertexBuffer.upload(n,this.gl.STATIC_DRAW)}bind(){this.vertexArray.bind(),this.indexBuffer.bind()}dispose(){this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose(),this.wireframeIndexBuffer?.dispose()}},pa=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Gd,fragment:Wd},{a_position:0,a_normal:1,a_texCoord:2}),this.uniformMvp=this.program.getUniformLocation("u_modelViewProjection"),this.uniformModelMatrix=this.program.getUniformLocation("u_modelMatrix"),this.uniformLightDir=this.program.getUniformLocation("u_lightDir"),this.uniformAmbient=this.program.getUniformLocation("u_ambient"),this.uniformTint=this.program.getUniformLocation("u_tint"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformRenderMode=this.program.getUniformLocation("u_renderMode"),this.uniformSolidColor=this.program.getUniformLocation("u_solidColor"),this.uniformNumDlights=this.program.getUniformLocation("u_numDlights");for(let r=0;r<Dn;r++)this.uniformDlights.push({pos:this.program.getUniformLocation(`u_dlights[${r}].position`),color:this.program.getUniformLocation(`u_dlights[${r}].color`),intensity:this.program.getUniformLocation(`u_dlights[${r}].intensity`)});this.uniformBrightness=this.program.getUniformLocation("u_brightness"),this.uniformGamma=this.program.getUniformLocation("u_gamma"),this.uniformFullbright=this.program.getUniformLocation("u_fullbright"),this.uniformGlobalAmbient=this.program.getUniformLocation("u_globalAmbient")}get shaderSize(){return this.program.sourceSize}bind(e){let{modelViewProjection:r,modelMatrix:n,lightDirection:i=[0,0,1],ambientLight:a=.2,tint:o=[1,1,1,1],diffuseSampler:s=0,dlights:c=[],renderMode:l,brightness:d=1,gamma:f=1,fullbright:u=!1,ambient:h=0}=e,m=new Float32Array(i),g=new Float32Array(o);this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,r),n?this.gl.uniformMatrix4fv(this.uniformModelMatrix,!1,n):this.gl.uniformMatrix4fv(this.uniformModelMatrix,!1,new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])),this.gl.uniform3fv(this.uniformLightDir,m),this.gl.uniform1f(this.uniformAmbient,a),this.gl.uniform4fv(this.uniformTint,g),this.gl.uniform1i(this.uniformDiffuse,s);let p=0,y=[1,1,1,1];l&&(l.mode==="solid"||l.mode==="wireframe"?p=1:l.mode==="solid-faceted"&&(p=2),l.color?y=[...l.color]:l.generateRandomColor),this.gl.uniform1i(this.uniformRenderMode,p),this.gl.uniform4f(this.uniformSolidColor,y[0],y[1],y[2],y[3]);let v=Math.min(c.length,Dn);this.gl.uniform1i(this.uniformNumDlights,v);for(let x=0;x<v;x++){let b=c[x];this.gl.uniform3f(this.uniformDlights[x].pos,b.origin.x,b.origin.y,b.origin.z),this.gl.uniform3f(this.uniformDlights[x].color,b.color.x,b.color.y,b.color.z),this.gl.uniform1f(this.uniformDlights[x].intensity,b.intensity)}this.gl.uniform1f(this.uniformBrightness,d),this.gl.uniform1f(this.uniformGamma,f),this.gl.uniform1i(this.uniformFullbright,u?1:0),this.gl.uniform1f(this.uniformGlobalAmbient,h)}draw(e,r){if(e.vertexArray.bind(),r&&r.mode==="wireframe"){if(!e.wireframeIndexBuffer){e.wireframeIndexBuffer=new Qe(this.gl,this.gl.STATIC_DRAW);let n=ua(e.geometry.indices);e.wireframeIndexBuffer.upload(n),e.wireframeIndexCount=n.length}e.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,e.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else e.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,e.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var $=1e-6,xe=typeof Float32Array<"u"?Float32Array:Array,er=Math.random,zh="zyx";function tn(t){return t>=0?Math.round(t):t%.5===0?Math.floor(t):Math.round(t)}var OE=Math.PI/180,UE=180/Math.PI;function Oh(){var t=new xe(9);return xe!=Float32Array&&(t[1]=0,t[2]=0,t[3]=0,t[5]=0,t[6]=0,t[7]=0),t[0]=1,t[4]=1,t[8]=1,t}var j={};Na(j,{add:()=>Fy,adjoint:()=>ny,clone:()=>j1,copy:()=>Q1,create:()=>Z1,decompose:()=>vy,determinant:()=>iy,equals:()=>Oy,exactEquals:()=>zy,frob:()=>By,fromQuat:()=>wy,fromQuat2:()=>yy,fromRotation:()=>hy,fromRotationTranslation:()=>Hh,fromRotationTranslationScale:()=>_y,fromRotationTranslationScaleOrigin:()=>Sy,fromScaling:()=>fy,fromTranslation:()=>uy,fromValues:()=>J1,fromXRotation:()=>my,fromYRotation:()=>py,fromZRotation:()=>gy,frustum:()=>My,getRotation:()=>xy,getScaling:()=>Vh,getTranslation:()=>by,identity:()=>Uh,invert:()=>ry,lookAt:()=>Cy,mul:()=>Uy,multiply:()=>Nh,multiplyScalar:()=>ky,multiplyScalarAndAdd:()=>Dy,ortho:()=>Ty,orthoNO:()=>Wh,orthoZO:()=>Ry,perspective:()=>Ay,perspectiveFromFieldOfView:()=>Ly,perspectiveNO:()=>Gh,perspectiveZO:()=>Ey,rotate:()=>sy,rotateX:()=>ly,rotateY:()=>cy,rotateZ:()=>dy,scale:()=>oy,set:()=>ey,str:()=>Iy,sub:()=>Ny,subtract:()=>Xh,targetTo:()=>Py,translate:()=>ay,transpose:()=>ty});function Z1(){var t=new xe(16);return xe!=Float32Array&&(t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[11]=0,t[12]=0,t[13]=0,t[14]=0),t[0]=1,t[5]=1,t[10]=1,t[15]=1,t}function j1(t){var e=new xe(16);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}function Q1(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function J1(t,e,r,n,i,a,o,s,c,l,d,f,u,h,m,g){var p=new xe(16);return p[0]=t,p[1]=e,p[2]=r,p[3]=n,p[4]=i,p[5]=a,p[6]=o,p[7]=s,p[8]=c,p[9]=l,p[10]=d,p[11]=f,p[12]=u,p[13]=h,p[14]=m,p[15]=g,p}function ey(t,e,r,n,i,a,o,s,c,l,d,f,u,h,m,g,p){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t[4]=a,t[5]=o,t[6]=s,t[7]=c,t[8]=l,t[9]=d,t[10]=f,t[11]=u,t[12]=h,t[13]=m,t[14]=g,t[15]=p,t}function Uh(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function ty(t,e){if(t===e){var r=e[1],n=e[2],i=e[3],a=e[6],o=e[7],s=e[11];t[1]=e[4],t[2]=e[8],t[3]=e[12],t[4]=r,t[6]=e[9],t[7]=e[13],t[8]=n,t[9]=a,t[11]=e[14],t[12]=i,t[13]=o,t[14]=s}else t[0]=e[0],t[1]=e[4],t[2]=e[8],t[3]=e[12],t[4]=e[1],t[5]=e[5],t[6]=e[9],t[7]=e[13],t[8]=e[2],t[9]=e[6],t[10]=e[10],t[11]=e[14],t[12]=e[3],t[13]=e[7],t[14]=e[11],t[15]=e[15];return t}function ry(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=e[4],s=e[5],c=e[6],l=e[7],d=e[8],f=e[9],u=e[10],h=e[11],m=e[12],g=e[13],p=e[14],y=e[15],v=r*s-n*o,x=r*c-i*o,b=r*l-a*o,_=n*c-i*s,w=n*l-a*s,S=i*l-a*c,E=d*g-f*m,L=d*p-u*m,M=d*y-h*m,R=f*p-u*g,I=f*y-h*g,B=u*y-h*p,F=v*B-x*I+b*R+_*M-w*L+S*E;return F?(F=1/F,t[0]=(s*B-c*I+l*R)*F,t[1]=(i*I-n*B-a*R)*F,t[2]=(g*S-p*w+y*_)*F,t[3]=(u*w-f*S-h*_)*F,t[4]=(c*M-o*B-l*L)*F,t[5]=(r*B-i*M+a*L)*F,t[6]=(p*b-m*S-y*x)*F,t[7]=(d*S-u*b+h*x)*F,t[8]=(o*I-s*M+l*E)*F,t[9]=(n*M-r*I-a*E)*F,t[10]=(m*w-g*b+y*v)*F,t[11]=(f*b-d*w-h*v)*F,t[12]=(s*L-o*R-c*E)*F,t[13]=(r*R-n*L+i*E)*F,t[14]=(g*x-m*_-p*v)*F,t[15]=(d*_-f*x+u*v)*F,t):null}function ny(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=e[4],s=e[5],c=e[6],l=e[7],d=e[8],f=e[9],u=e[10],h=e[11],m=e[12],g=e[13],p=e[14],y=e[15],v=r*s-n*o,x=r*c-i*o,b=r*l-a*o,_=n*c-i*s,w=n*l-a*s,S=i*l-a*c,E=d*g-f*m,L=d*p-u*m,M=d*y-h*m,R=f*p-u*g,I=f*y-h*g,B=u*y-h*p;return t[0]=s*B-c*I+l*R,t[1]=i*I-n*B-a*R,t[2]=g*S-p*w+y*_,t[3]=u*w-f*S-h*_,t[4]=c*M-o*B-l*L,t[5]=r*B-i*M+a*L,t[6]=p*b-m*S-y*x,t[7]=d*S-u*b+h*x,t[8]=o*I-s*M+l*E,t[9]=n*M-r*I-a*E,t[10]=m*w-g*b+y*v,t[11]=f*b-d*w-h*v,t[12]=s*L-o*R-c*E,t[13]=r*R-n*L+i*E,t[14]=g*x-m*_-p*v,t[15]=d*_-f*x+u*v,t}function iy(t){var e=t[0],r=t[1],n=t[2],i=t[3],a=t[4],o=t[5],s=t[6],c=t[7],l=t[8],d=t[9],f=t[10],u=t[11],h=t[12],m=t[13],g=t[14],p=t[15],y=e*o-r*a,v=e*s-n*a,x=r*s-n*o,b=l*m-d*h,_=l*g-f*h,w=d*g-f*m,S=e*w-r*_+n*b,E=a*w-o*_+s*b,L=l*x-d*v+f*y,M=h*x-m*v+g*y;return c*S-i*E+p*L-u*M}function Nh(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=e[4],c=e[5],l=e[6],d=e[7],f=e[8],u=e[9],h=e[10],m=e[11],g=e[12],p=e[13],y=e[14],v=e[15],x=r[0],b=r[1],_=r[2],w=r[3];return t[0]=x*n+b*s+_*f+w*g,t[1]=x*i+b*c+_*u+w*p,t[2]=x*a+b*l+_*h+w*y,t[3]=x*o+b*d+_*m+w*v,x=r[4],b=r[5],_=r[6],w=r[7],t[4]=x*n+b*s+_*f+w*g,t[5]=x*i+b*c+_*u+w*p,t[6]=x*a+b*l+_*h+w*y,t[7]=x*o+b*d+_*m+w*v,x=r[8],b=r[9],_=r[10],w=r[11],t[8]=x*n+b*s+_*f+w*g,t[9]=x*i+b*c+_*u+w*p,t[10]=x*a+b*l+_*h+w*y,t[11]=x*o+b*d+_*m+w*v,x=r[12],b=r[13],_=r[14],w=r[15],t[12]=x*n+b*s+_*f+w*g,t[13]=x*i+b*c+_*u+w*p,t[14]=x*a+b*l+_*h+w*y,t[15]=x*o+b*d+_*m+w*v,t}function ay(t,e,r){var n=r[0],i=r[1],a=r[2],o,s,c,l,d,f,u,h,m,g,p,y;return e===t?(t[12]=e[0]*n+e[4]*i+e[8]*a+e[12],t[13]=e[1]*n+e[5]*i+e[9]*a+e[13],t[14]=e[2]*n+e[6]*i+e[10]*a+e[14],t[15]=e[3]*n+e[7]*i+e[11]*a+e[15]):(o=e[0],s=e[1],c=e[2],l=e[3],d=e[4],f=e[5],u=e[6],h=e[7],m=e[8],g=e[9],p=e[10],y=e[11],t[0]=o,t[1]=s,t[2]=c,t[3]=l,t[4]=d,t[5]=f,t[6]=u,t[7]=h,t[8]=m,t[9]=g,t[10]=p,t[11]=y,t[12]=o*n+d*i+m*a+e[12],t[13]=s*n+f*i+g*a+e[13],t[14]=c*n+u*i+p*a+e[14],t[15]=l*n+h*i+y*a+e[15]),t}function oy(t,e,r){var n=r[0],i=r[1],a=r[2];return t[0]=e[0]*n,t[1]=e[1]*n,t[2]=e[2]*n,t[3]=e[3]*n,t[4]=e[4]*i,t[5]=e[5]*i,t[6]=e[6]*i,t[7]=e[7]*i,t[8]=e[8]*a,t[9]=e[9]*a,t[10]=e[10]*a,t[11]=e[11]*a,t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function sy(t,e,r,n){var i=n[0],a=n[1],o=n[2],s=Math.sqrt(i*i+a*a+o*o),c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,L,M,R,I,B,F,U;return s<$?null:(s=1/s,i*=s,a*=s,o*=s,c=Math.sin(r),l=Math.cos(r),d=1-l,f=e[0],u=e[1],h=e[2],m=e[3],g=e[4],p=e[5],y=e[6],v=e[7],x=e[8],b=e[9],_=e[10],w=e[11],S=i*i*d+l,E=a*i*d+o*c,L=o*i*d-a*c,M=i*a*d-o*c,R=a*a*d+l,I=o*a*d+i*c,B=i*o*d+a*c,F=a*o*d-i*c,U=o*o*d+l,t[0]=f*S+g*E+x*L,t[1]=u*S+p*E+b*L,t[2]=h*S+y*E+_*L,t[3]=m*S+v*E+w*L,t[4]=f*M+g*R+x*I,t[5]=u*M+p*R+b*I,t[6]=h*M+y*R+_*I,t[7]=m*M+v*R+w*I,t[8]=f*B+g*F+x*U,t[9]=u*B+p*F+b*U,t[10]=h*B+y*F+_*U,t[11]=m*B+v*F+w*U,e!==t&&(t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t)}function ly(t,e,r){var n=Math.sin(r),i=Math.cos(r),a=e[4],o=e[5],s=e[6],c=e[7],l=e[8],d=e[9],f=e[10],u=e[11];return e!==t&&(t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[4]=a*i+l*n,t[5]=o*i+d*n,t[6]=s*i+f*n,t[7]=c*i+u*n,t[8]=l*i-a*n,t[9]=d*i-o*n,t[10]=f*i-s*n,t[11]=u*i-c*n,t}function cy(t,e,r){var n=Math.sin(r),i=Math.cos(r),a=e[0],o=e[1],s=e[2],c=e[3],l=e[8],d=e[9],f=e[10],u=e[11];return e!==t&&(t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[0]=a*i-l*n,t[1]=o*i-d*n,t[2]=s*i-f*n,t[3]=c*i-u*n,t[8]=a*n+l*i,t[9]=o*n+d*i,t[10]=s*n+f*i,t[11]=c*n+u*i,t}function dy(t,e,r){var n=Math.sin(r),i=Math.cos(r),a=e[0],o=e[1],s=e[2],c=e[3],l=e[4],d=e[5],f=e[6],u=e[7];return e!==t&&(t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[0]=a*i+l*n,t[1]=o*i+d*n,t[2]=s*i+f*n,t[3]=c*i+u*n,t[4]=l*i-a*n,t[5]=d*i-o*n,t[6]=f*i-s*n,t[7]=u*i-c*n,t}function uy(t,e){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=e[0],t[13]=e[1],t[14]=e[2],t[15]=1,t}function fy(t,e){return t[0]=e[0],t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=e[1],t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=e[2],t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function hy(t,e,r){var n=r[0],i=r[1],a=r[2],o=Math.sqrt(n*n+i*i+a*a),s,c,l;return o<$?null:(o=1/o,n*=o,i*=o,a*=o,s=Math.sin(e),c=Math.cos(e),l=1-c,t[0]=n*n*l+c,t[1]=i*n*l+a*s,t[2]=a*n*l-i*s,t[3]=0,t[4]=n*i*l-a*s,t[5]=i*i*l+c,t[6]=a*i*l+n*s,t[7]=0,t[8]=n*a*l+i*s,t[9]=i*a*l-n*s,t[10]=a*a*l+c,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t)}function my(t,e){var r=Math.sin(e),n=Math.cos(e);return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=n,t[6]=r,t[7]=0,t[8]=0,t[9]=-r,t[10]=n,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function py(t,e){var r=Math.sin(e),n=Math.cos(e);return t[0]=n,t[1]=0,t[2]=-r,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=r,t[9]=0,t[10]=n,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function gy(t,e){var r=Math.sin(e),n=Math.cos(e);return t[0]=n,t[1]=r,t[2]=0,t[3]=0,t[4]=-r,t[5]=n,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function Hh(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=n+n,c=i+i,l=a+a,d=n*s,f=n*c,u=n*l,h=i*c,m=i*l,g=a*l,p=o*s,y=o*c,v=o*l;return t[0]=1-(h+g),t[1]=f+v,t[2]=u-y,t[3]=0,t[4]=f-v,t[5]=1-(d+g),t[6]=m+p,t[7]=0,t[8]=u+y,t[9]=m-p,t[10]=1-(d+h),t[11]=0,t[12]=r[0],t[13]=r[1],t[14]=r[2],t[15]=1,t}function yy(t,e){var r=new xe(3),n=-e[0],i=-e[1],a=-e[2],o=e[3],s=e[4],c=e[5],l=e[6],d=e[7],f=n*n+i*i+a*a+o*o;return f>0?(r[0]=(s*o+d*n+c*a-l*i)*2/f,r[1]=(c*o+d*i+l*n-s*a)*2/f,r[2]=(l*o+d*a+s*i-c*n)*2/f):(r[0]=(s*o+d*n+c*a-l*i)*2,r[1]=(c*o+d*i+l*n-s*a)*2,r[2]=(l*o+d*a+s*i-c*n)*2),Hh(t,e,r),t}function by(t,e){return t[0]=e[12],t[1]=e[13],t[2]=e[14],t}function Vh(t,e){var r=e[0],n=e[1],i=e[2],a=e[4],o=e[5],s=e[6],c=e[8],l=e[9],d=e[10];return t[0]=Math.sqrt(r*r+n*n+i*i),t[1]=Math.sqrt(a*a+o*o+s*s),t[2]=Math.sqrt(c*c+l*l+d*d),t}function xy(t,e){var r=new xe(3);Vh(r,e);var n=1/r[0],i=1/r[1],a=1/r[2],o=e[0]*n,s=e[1]*i,c=e[2]*a,l=e[4]*n,d=e[5]*i,f=e[6]*a,u=e[8]*n,h=e[9]*i,m=e[10]*a,g=o+d+m,p=0;return g>0?(p=Math.sqrt(g+1)*2,t[3]=.25*p,t[0]=(f-h)/p,t[1]=(u-c)/p,t[2]=(s-l)/p):o>d&&o>m?(p=Math.sqrt(1+o-d-m)*2,t[3]=(f-h)/p,t[0]=.25*p,t[1]=(s+l)/p,t[2]=(u+c)/p):d>m?(p=Math.sqrt(1+d-o-m)*2,t[3]=(u-c)/p,t[0]=(s+l)/p,t[1]=.25*p,t[2]=(f+h)/p):(p=Math.sqrt(1+m-o-d)*2,t[3]=(s-l)/p,t[0]=(u+c)/p,t[1]=(f+h)/p,t[2]=.25*p),t}function vy(t,e,r,n){e[0]=n[12],e[1]=n[13],e[2]=n[14];var i=n[0],a=n[1],o=n[2],s=n[4],c=n[5],l=n[6],d=n[8],f=n[9],u=n[10];r[0]=Math.sqrt(i*i+a*a+o*o),r[1]=Math.sqrt(s*s+c*c+l*l),r[2]=Math.sqrt(d*d+f*f+u*u);var h=1/r[0],m=1/r[1],g=1/r[2],p=i*h,y=a*m,v=o*g,x=s*h,b=c*m,_=l*g,w=d*h,S=f*m,E=u*g,L=p+b+E,M=0;return L>0?(M=Math.sqrt(L+1)*2,t[3]=.25*M,t[0]=(_-S)/M,t[1]=(w-v)/M,t[2]=(y-x)/M):p>b&&p>E?(M=Math.sqrt(1+p-b-E)*2,t[3]=(_-S)/M,t[0]=.25*M,t[1]=(y+x)/M,t[2]=(w+v)/M):b>E?(M=Math.sqrt(1+b-p-E)*2,t[3]=(w-v)/M,t[0]=(y+x)/M,t[1]=.25*M,t[2]=(_+S)/M):(M=Math.sqrt(1+E-p-b)*2,t[3]=(y-x)/M,t[0]=(w+v)/M,t[1]=(_+S)/M,t[2]=.25*M),t}function _y(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3],c=i+i,l=a+a,d=o+o,f=i*c,u=i*l,h=i*d,m=a*l,g=a*d,p=o*d,y=s*c,v=s*l,x=s*d,b=n[0],_=n[1],w=n[2];return t[0]=(1-(m+p))*b,t[1]=(u+x)*b,t[2]=(h-v)*b,t[3]=0,t[4]=(u-x)*_,t[5]=(1-(f+p))*_,t[6]=(g+y)*_,t[7]=0,t[8]=(h+v)*w,t[9]=(g-y)*w,t[10]=(1-(f+m))*w,t[11]=0,t[12]=r[0],t[13]=r[1],t[14]=r[2],t[15]=1,t}function Sy(t,e,r,n,i){var a=e[0],o=e[1],s=e[2],c=e[3],l=a+a,d=o+o,f=s+s,u=a*l,h=a*d,m=a*f,g=o*d,p=o*f,y=s*f,v=c*l,x=c*d,b=c*f,_=n[0],w=n[1],S=n[2],E=i[0],L=i[1],M=i[2],R=(1-(g+y))*_,I=(h+b)*_,B=(m-x)*_,F=(h-b)*w,U=(1-(u+y))*w,ce=(p+v)*w,Nt=(m+x)*S,Ct=(p-v)*S,zr=(1-(u+g))*S;return t[0]=R,t[1]=I,t[2]=B,t[3]=0,t[4]=F,t[5]=U,t[6]=ce,t[7]=0,t[8]=Nt,t[9]=Ct,t[10]=zr,t[11]=0,t[12]=r[0]+E-(R*E+F*L+Nt*M),t[13]=r[1]+L-(I*E+U*L+Ct*M),t[14]=r[2]+M-(B*E+ce*L+zr*M),t[15]=1,t}function wy(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r+r,s=n+n,c=i+i,l=r*o,d=n*o,f=n*s,u=i*o,h=i*s,m=i*c,g=a*o,p=a*s,y=a*c;return t[0]=1-f-m,t[1]=d+y,t[2]=u-p,t[3]=0,t[4]=d-y,t[5]=1-l-m,t[6]=h+g,t[7]=0,t[8]=u+p,t[9]=h-g,t[10]=1-l-f,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function My(t,e,r,n,i,a,o){var s=1/(r-e),c=1/(i-n),l=1/(a-o);return t[0]=a*2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=a*2*c,t[6]=0,t[7]=0,t[8]=(r+e)*s,t[9]=(i+n)*c,t[10]=(o+a)*l,t[11]=-1,t[12]=0,t[13]=0,t[14]=o*a*2*l,t[15]=0,t}function Gh(t,e,r,n,i){var a=1/Math.tan(e/2);if(t[0]=a/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=a,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[11]=-1,t[12]=0,t[13]=0,t[15]=0,i!=null&&i!==1/0){var o=1/(n-i);t[10]=(i+n)*o,t[14]=2*i*n*o}else t[10]=-1,t[14]=-2*n;return t}var Ay=Gh;function Ey(t,e,r,n,i){var a=1/Math.tan(e/2);if(t[0]=a/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=a,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[11]=-1,t[12]=0,t[13]=0,t[15]=0,i!=null&&i!==1/0){var o=1/(n-i);t[10]=i*o,t[14]=i*n*o}else t[10]=-1,t[14]=-n;return t}function Ly(t,e,r,n){var i=Math.tan(e.upDegrees*Math.PI/180),a=Math.tan(e.downDegrees*Math.PI/180),o=Math.tan(e.leftDegrees*Math.PI/180),s=Math.tan(e.rightDegrees*Math.PI/180),c=2/(o+s),l=2/(i+a);return t[0]=c,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=l,t[6]=0,t[7]=0,t[8]=-((o-s)*c*.5),t[9]=(i-a)*l*.5,t[10]=n/(r-n),t[11]=-1,t[12]=0,t[13]=0,t[14]=n*r/(r-n),t[15]=0,t}function Wh(t,e,r,n,i,a,o){var s=1/(e-r),c=1/(n-i),l=1/(a-o);return t[0]=-2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=-2*c,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=2*l,t[11]=0,t[12]=(e+r)*s,t[13]=(i+n)*c,t[14]=(o+a)*l,t[15]=1,t}var Ty=Wh;function Ry(t,e,r,n,i,a,o){var s=1/(e-r),c=1/(n-i),l=1/(a-o);return t[0]=-2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=-2*c,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=l,t[11]=0,t[12]=(e+r)*s,t[13]=(i+n)*c,t[14]=a*l,t[15]=1,t}function Cy(t,e,r,n){var i,a,o,s,c,l,d,f,u,h,m=e[0],g=e[1],p=e[2],y=n[0],v=n[1],x=n[2],b=r[0],_=r[1],w=r[2];return Math.abs(m-b)<$&&Math.abs(g-_)<$&&Math.abs(p-w)<$?Uh(t):(d=m-b,f=g-_,u=p-w,h=1/Math.sqrt(d*d+f*f+u*u),d*=h,f*=h,u*=h,i=v*u-x*f,a=x*d-y*u,o=y*f-v*d,h=Math.sqrt(i*i+a*a+o*o),h?(h=1/h,i*=h,a*=h,o*=h):(i=0,a=0,o=0),s=f*o-u*a,c=u*i-d*o,l=d*a-f*i,h=Math.sqrt(s*s+c*c+l*l),h?(h=1/h,s*=h,c*=h,l*=h):(s=0,c=0,l=0),t[0]=i,t[1]=s,t[2]=d,t[3]=0,t[4]=a,t[5]=c,t[6]=f,t[7]=0,t[8]=o,t[9]=l,t[10]=u,t[11]=0,t[12]=-(i*m+a*g+o*p),t[13]=-(s*m+c*g+l*p),t[14]=-(d*m+f*g+u*p),t[15]=1,t)}function Py(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=n[0],c=n[1],l=n[2],d=i-r[0],f=a-r[1],u=o-r[2],h=d*d+f*f+u*u;h>0&&(h=1/Math.sqrt(h),d*=h,f*=h,u*=h);var m=c*u-l*f,g=l*d-s*u,p=s*f-c*d;return h=m*m+g*g+p*p,h>0&&(h=1/Math.sqrt(h),m*=h,g*=h,p*=h),t[0]=m,t[1]=g,t[2]=p,t[3]=0,t[4]=f*p-u*g,t[5]=u*m-d*p,t[6]=d*g-f*m,t[7]=0,t[8]=d,t[9]=f,t[10]=u,t[11]=0,t[12]=i,t[13]=a,t[14]=o,t[15]=1,t}function Iy(t){return"mat4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+", "+t[4]+", "+t[5]+", "+t[6]+", "+t[7]+", "+t[8]+", "+t[9]+", "+t[10]+", "+t[11]+", "+t[12]+", "+t[13]+", "+t[14]+", "+t[15]+")"}function By(t){return Math.sqrt(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]+t[3]*t[3]+t[4]*t[4]+t[5]*t[5]+t[6]*t[6]+t[7]*t[7]+t[8]*t[8]+t[9]*t[9]+t[10]*t[10]+t[11]*t[11]+t[12]*t[12]+t[13]*t[13]+t[14]*t[14]+t[15]*t[15])}function Fy(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t[3]=e[3]+r[3],t[4]=e[4]+r[4],t[5]=e[5]+r[5],t[6]=e[6]+r[6],t[7]=e[7]+r[7],t[8]=e[8]+r[8],t[9]=e[9]+r[9],t[10]=e[10]+r[10],t[11]=e[11]+r[11],t[12]=e[12]+r[12],t[13]=e[13]+r[13],t[14]=e[14]+r[14],t[15]=e[15]+r[15],t}function Xh(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t[3]=e[3]-r[3],t[4]=e[4]-r[4],t[5]=e[5]-r[5],t[6]=e[6]-r[6],t[7]=e[7]-r[7],t[8]=e[8]-r[8],t[9]=e[9]-r[9],t[10]=e[10]-r[10],t[11]=e[11]-r[11],t[12]=e[12]-r[12],t[13]=e[13]-r[13],t[14]=e[14]-r[14],t[15]=e[15]-r[15],t}function ky(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t[4]=e[4]*r,t[5]=e[5]*r,t[6]=e[6]*r,t[7]=e[7]*r,t[8]=e[8]*r,t[9]=e[9]*r,t[10]=e[10]*r,t[11]=e[11]*r,t[12]=e[12]*r,t[13]=e[13]*r,t[14]=e[14]*r,t[15]=e[15]*r,t}function Dy(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t[3]=e[3]+r[3]*n,t[4]=e[4]+r[4]*n,t[5]=e[5]+r[5]*n,t[6]=e[6]+r[6]*n,t[7]=e[7]+r[7]*n,t[8]=e[8]+r[8]*n,t[9]=e[9]+r[9]*n,t[10]=e[10]+r[10]*n,t[11]=e[11]+r[11]*n,t[12]=e[12]+r[12]*n,t[13]=e[13]+r[13]*n,t[14]=e[14]+r[14]*n,t[15]=e[15]+r[15]*n,t}function zy(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[7]===e[7]&&t[8]===e[8]&&t[9]===e[9]&&t[10]===e[10]&&t[11]===e[11]&&t[12]===e[12]&&t[13]===e[13]&&t[14]===e[14]&&t[15]===e[15]}function Oy(t,e){var r=t[0],n=t[1],i=t[2],a=t[3],o=t[4],s=t[5],c=t[6],l=t[7],d=t[8],f=t[9],u=t[10],h=t[11],m=t[12],g=t[13],p=t[14],y=t[15],v=e[0],x=e[1],b=e[2],_=e[3],w=e[4],S=e[5],E=e[6],L=e[7],M=e[8],R=e[9],I=e[10],B=e[11],F=e[12],U=e[13],ce=e[14],Nt=e[15];return Math.abs(r-v)<=$*Math.max(1,Math.abs(r),Math.abs(v))&&Math.abs(n-x)<=$*Math.max(1,Math.abs(n),Math.abs(x))&&Math.abs(i-b)<=$*Math.max(1,Math.abs(i),Math.abs(b))&&Math.abs(a-_)<=$*Math.max(1,Math.abs(a),Math.abs(_))&&Math.abs(o-w)<=$*Math.max(1,Math.abs(o),Math.abs(w))&&Math.abs(s-S)<=$*Math.max(1,Math.abs(s),Math.abs(S))&&Math.abs(c-E)<=$*Math.max(1,Math.abs(c),Math.abs(E))&&Math.abs(l-L)<=$*Math.max(1,Math.abs(l),Math.abs(L))&&Math.abs(d-M)<=$*Math.max(1,Math.abs(d),Math.abs(M))&&Math.abs(f-R)<=$*Math.max(1,Math.abs(f),Math.abs(R))&&Math.abs(u-I)<=$*Math.max(1,Math.abs(u),Math.abs(I))&&Math.abs(h-B)<=$*Math.max(1,Math.abs(h),Math.abs(B))&&Math.abs(m-F)<=$*Math.max(1,Math.abs(m),Math.abs(F))&&Math.abs(g-U)<=$*Math.max(1,Math.abs(g),Math.abs(U))&&Math.abs(p-ce)<=$*Math.max(1,Math.abs(p),Math.abs(ce))&&Math.abs(y-Nt)<=$*Math.max(1,Math.abs(y),Math.abs(Nt))}var Uy=Nh,Ny=Xh;var Jl={};Na(Jl,{add:()=>cx,calculateW:()=>Qb,clone:()=>ax,conjugate:()=>rx,copy:()=>sx,create:()=>iu,dot:()=>um,equals:()=>px,exactEquals:()=>mx,exp:()=>sm,fromEuler:()=>nx,fromMat3:()=>cm,fromValues:()=>ox,getAngle:()=>$b,getAxisAngle:()=>Yb,identity:()=>Kb,invert:()=>tx,len:()=>fx,length:()=>fm,lerp:()=>ux,ln:()=>lm,mul:()=>dx,multiply:()=>om,normalize:()=>au,pow:()=>Jb,random:()=>ex,rotateX:()=>qb,rotateY:()=>Zb,rotateZ:()=>jb,rotationTo:()=>gx,scale:()=>dm,set:()=>lx,setAxes:()=>bx,setAxisAngle:()=>am,slerp:()=>Ql,sqlerp:()=>yx,sqrLen:()=>hx,squaredLength:()=>hm,str:()=>ix});var C={};Na(C,{add:()=>Wy,angle:()=>ub,bezier:()=>nb,ceil:()=>Xy,clone:()=>Hy,copy:()=>Vy,create:()=>Yl,cross:()=>ns,dist:()=>xb,distance:()=>Zh,div:()=>bb,divide:()=>qh,dot:()=>rs,equals:()=>pb,exactEquals:()=>mb,floor:()=>Ky,forEach:()=>Sb,fromValues:()=>$l,hermite:()=>rb,inverse:()=>Jy,len:()=>$d,length:()=>Kh,lerp:()=>eb,max:()=>$y,min:()=>Yy,mul:()=>yb,multiply:()=>$h,negate:()=>Qy,normalize:()=>Yd,random:()=>ib,rotateX:()=>lb,rotateY:()=>cb,rotateZ:()=>db,round:()=>qy,scale:()=>Zy,scaleAndAdd:()=>jy,set:()=>Gy,slerp:()=>tb,sqrDist:()=>vb,sqrLen:()=>_b,squaredDistance:()=>jh,squaredLength:()=>Qh,str:()=>hb,sub:()=>gb,subtract:()=>Yh,transformMat3:()=>ob,transformMat4:()=>ab,transformQuat:()=>sb,zero:()=>fb});function Yl(){var t=new xe(3);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t}function Hy(t){var e=new xe(3);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function Kh(t){var e=t[0],r=t[1],n=t[2];return Math.sqrt(e*e+r*r+n*n)}function $l(t,e,r){var n=new xe(3);return n[0]=t,n[1]=e,n[2]=r,n}function Vy(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function Gy(t,e,r,n){return t[0]=e,t[1]=r,t[2]=n,t}function Wy(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t}function Yh(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t}function $h(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t[2]=e[2]*r[2],t}function qh(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t[2]=e[2]/r[2],t}function Xy(t,e){return t[0]=Math.ceil(e[0]),t[1]=Math.ceil(e[1]),t[2]=Math.ceil(e[2]),t}function Ky(t,e){return t[0]=Math.floor(e[0]),t[1]=Math.floor(e[1]),t[2]=Math.floor(e[2]),t}function Yy(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t[2]=Math.min(e[2],r[2]),t}function $y(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t[2]=Math.max(e[2],r[2]),t}function qy(t,e){return t[0]=tn(e[0]),t[1]=tn(e[1]),t[2]=tn(e[2]),t}function Zy(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t}function jy(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t}function Zh(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2];return Math.sqrt(r*r+n*n+i*i)}function jh(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2];return r*r+n*n+i*i}function Qh(t){var e=t[0],r=t[1],n=t[2];return e*e+r*r+n*n}function Qy(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t}function Jy(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t}function Yd(t,e){var r=e[0],n=e[1],i=e[2],a=r*r+n*n+i*i;return a>0&&(a=1/Math.sqrt(a)),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a,t}function rs(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}function ns(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],c=r[2];return t[0]=i*c-a*s,t[1]=a*o-n*c,t[2]=n*s-i*o,t}function eb(t,e,r,n){var i=e[0],a=e[1],o=e[2];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t}function tb(t,e,r,n){var i=Math.acos(Math.min(Math.max(rs(e,r),-1),1)),a=Math.sin(i),o=Math.sin((1-n)*i)/a,s=Math.sin(n*i)/a;return t[0]=o*e[0]+s*r[0],t[1]=o*e[1]+s*r[1],t[2]=o*e[2]+s*r[2],t}function rb(t,e,r,n,i,a){var o=a*a,s=o*(2*a-3)+1,c=o*(a-2)+a,l=o*(a-1),d=o*(3-2*a);return t[0]=e[0]*s+r[0]*c+n[0]*l+i[0]*d,t[1]=e[1]*s+r[1]*c+n[1]*l+i[1]*d,t[2]=e[2]*s+r[2]*c+n[2]*l+i[2]*d,t}function nb(t,e,r,n,i,a){var o=1-a,s=o*o,c=a*a,l=s*o,d=3*a*s,f=3*c*o,u=c*a;return t[0]=e[0]*l+r[0]*d+n[0]*f+i[0]*u,t[1]=e[1]*l+r[1]*d+n[1]*f+i[1]*u,t[2]=e[2]*l+r[2]*d+n[2]*f+i[2]*u,t}function ib(t,e){e=e===void 0?1:e;var r=er()*2*Math.PI,n=er()*2-1,i=Math.sqrt(1-n*n)*e;return t[0]=Math.cos(r)*i,t[1]=Math.sin(r)*i,t[2]=n*e,t}function ab(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[3]*n+r[7]*i+r[11]*a+r[15];return o=o||1,t[0]=(r[0]*n+r[4]*i+r[8]*a+r[12])/o,t[1]=(r[1]*n+r[5]*i+r[9]*a+r[13])/o,t[2]=(r[2]*n+r[6]*i+r[10]*a+r[14])/o,t}function ob(t,e,r){var n=e[0],i=e[1],a=e[2];return t[0]=n*r[0]+i*r[3]+a*r[6],t[1]=n*r[1]+i*r[4]+a*r[7],t[2]=n*r[2]+i*r[5]+a*r[8],t}function sb(t,e,r){var n=r[0],i=r[1],a=r[2],o=r[3],s=e[0],c=e[1],l=e[2],d=i*l-a*c,f=a*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+o*d+i*u-a*f,t[1]=c+o*f+a*d-n*u,t[2]=l+o*u+n*f-i*d,t}function lb(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0],a[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),a[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t}function cb(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),a[1]=i[1],a[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t}function db(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),a[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),a[2]=i[2],t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t}function ub(t,e){var r=t[0],n=t[1],i=t[2],a=e[0],o=e[1],s=e[2],c=Math.sqrt((r*r+n*n+i*i)*(a*a+o*o+s*s)),l=c&&rs(t,e)/c;return Math.acos(Math.min(Math.max(l,-1),1))}function fb(t){return t[0]=0,t[1]=0,t[2]=0,t}function hb(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"}function mb(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]}function pb(t,e){var r=t[0],n=t[1],i=t[2],a=e[0],o=e[1],s=e[2];return Math.abs(r-a)<=$*Math.max(1,Math.abs(r),Math.abs(a))&&Math.abs(n-o)<=$*Math.max(1,Math.abs(n),Math.abs(o))&&Math.abs(i-s)<=$*Math.max(1,Math.abs(i),Math.abs(s))}var gb=Yh,yb=$h,bb=qh,xb=Zh,vb=jh,$d=Kh,_b=Qh,Sb=(function(){var t=Yl();return function(e,r,n,i,a,o){var s,c;for(r||(r=3),n||(n=0),i?c=Math.min(i*r+n,e.length):c=e.length,s=n;s<c;s+=r)t[0]=e[s],t[1]=e[s+1],t[2]=e[s+2],a(t,t,o),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2];return e}})();var ga={};Na(ga,{add:()=>Jd,ceil:()=>wb,clone:()=>qd,copy:()=>jd,create:()=>Jh,cross:()=>Pb,dist:()=>Hb,distance:()=>nm,div:()=>Nb,divide:()=>rm,dot:()=>jl,equals:()=>zb,exactEquals:()=>nu,floor:()=>Mb,forEach:()=>Xb,fromValues:()=>Zd,inverse:()=>Cb,len:()=>Gb,length:()=>ql,lerp:()=>ru,max:()=>Eb,min:()=>Ab,mul:()=>Ub,multiply:()=>tm,negate:()=>Rb,normalize:()=>tu,random:()=>Ib,round:()=>Lb,scale:()=>eu,scaleAndAdd:()=>Tb,set:()=>Qd,sqrDist:()=>Vb,sqrLen:()=>Wb,squaredDistance:()=>im,squaredLength:()=>Zl,str:()=>Db,sub:()=>Ob,subtract:()=>em,transformMat4:()=>Bb,transformQuat:()=>Fb,zero:()=>kb});function Jh(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0,t[3]=0),t}function qd(t){var e=new xe(4);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e}function Zd(t,e,r,n){var i=new xe(4);return i[0]=t,i[1]=e,i[2]=r,i[3]=n,i}function jd(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function Qd(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t}function Jd(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t[3]=e[3]+r[3],t}function em(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t[3]=e[3]-r[3],t}function tm(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t[2]=e[2]*r[2],t[3]=e[3]*r[3],t}function rm(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t[2]=e[2]/r[2],t[3]=e[3]/r[3],t}function wb(t,e){return t[0]=Math.ceil(e[0]),t[1]=Math.ceil(e[1]),t[2]=Math.ceil(e[2]),t[3]=Math.ceil(e[3]),t}function Mb(t,e){return t[0]=Math.floor(e[0]),t[1]=Math.floor(e[1]),t[2]=Math.floor(e[2]),t[3]=Math.floor(e[3]),t}function Ab(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t[2]=Math.min(e[2],r[2]),t[3]=Math.min(e[3],r[3]),t}function Eb(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t[2]=Math.max(e[2],r[2]),t[3]=Math.max(e[3],r[3]),t}function Lb(t,e){return t[0]=tn(e[0]),t[1]=tn(e[1]),t[2]=tn(e[2]),t[3]=tn(e[3]),t}function eu(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t}function Tb(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t[3]=e[3]+r[3]*n,t}function nm(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return Math.sqrt(r*r+n*n+i*i+a*a)}function im(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return r*r+n*n+i*i+a*a}function ql(t){var e=t[0],r=t[1],n=t[2],i=t[3];return Math.sqrt(e*e+r*r+n*n+i*i)}function Zl(t){var e=t[0],r=t[1],n=t[2],i=t[3];return e*e+r*r+n*n+i*i}function Rb(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t}function Cb(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t[3]=1/e[3],t}function tu(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a;return o>0&&(o=1/Math.sqrt(o)),t[0]=r*o,t[1]=n*o,t[2]=i*o,t[3]=a*o,t}function jl(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]}function Pb(t,e,r,n){var i=r[0]*n[1]-r[1]*n[0],a=r[0]*n[2]-r[2]*n[0],o=r[0]*n[3]-r[3]*n[0],s=r[1]*n[2]-r[2]*n[1],c=r[1]*n[3]-r[3]*n[1],l=r[2]*n[3]-r[3]*n[2],d=e[0],f=e[1],u=e[2],h=e[3];return t[0]=f*l-u*c+h*s,t[1]=-(d*l)+u*o-h*a,t[2]=d*c-f*o+h*i,t[3]=-(d*s)+f*a-u*i,t}function ru(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t[3]=s+n*(r[3]-s),t}function Ib(t,e){e=e===void 0?1:e;var r,n,i,a,o,s,c;c=er(),r=c*2-1,n=(4*er()-2)*Math.sqrt(c*-c+c),o=r*r+n*n,c=er(),i=c*2-1,a=(4*er()-2)*Math.sqrt(c*-c+c),s=i*i+a*a;var l=Math.sqrt((1-o)/s);return t[0]=e*r,t[1]=e*n,t[2]=e*i*l,t[3]=e*a*l,t}function Bb(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3];return t[0]=r[0]*n+r[4]*i+r[8]*a+r[12]*o,t[1]=r[1]*n+r[5]*i+r[9]*a+r[13]*o,t[2]=r[2]*n+r[6]*i+r[10]*a+r[14]*o,t[3]=r[3]*n+r[7]*i+r[11]*a+r[15]*o,t}function Fb(t,e,r){var n=r[0],i=r[1],a=r[2],o=r[3],s=e[0],c=e[1],l=e[2],d=i*l-a*c,f=a*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+o*d+i*u-a*f,t[1]=c+o*f+a*d-n*u,t[2]=l+o*u+n*f-i*d,t[3]=e[3],t}function kb(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t}function Db(t){return"vec4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}function nu(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]}function zb(t,e){var r=t[0],n=t[1],i=t[2],a=t[3],o=e[0],s=e[1],c=e[2],l=e[3];return Math.abs(r-o)<=$*Math.max(1,Math.abs(r),Math.abs(o))&&Math.abs(n-s)<=$*Math.max(1,Math.abs(n),Math.abs(s))&&Math.abs(i-c)<=$*Math.max(1,Math.abs(i),Math.abs(c))&&Math.abs(a-l)<=$*Math.max(1,Math.abs(a),Math.abs(l))}var Ob=em,Ub=tm,Nb=rm,Hb=nm,Vb=im,Gb=ql,Wb=Zl,Xb=(function(){var t=Jh();return function(e,r,n,i,a,o){var s,c;for(r||(r=4),n||(n=0),i?c=Math.min(i*r+n,e.length):c=e.length,s=n;s<c;s+=r)t[0]=e[s],t[1]=e[s+1],t[2]=e[s+2],t[3]=e[s+3],a(t,t,o),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2],e[s+3]=t[3];return e}})();function iu(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t[3]=1,t}function Kb(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t}function am(t,e,r){r=r*.5;var n=Math.sin(r);return t[0]=n*e[0],t[1]=n*e[1],t[2]=n*e[2],t[3]=Math.cos(r),t}function Yb(t,e){var r=Math.acos(e[3])*2,n=Math.sin(r/2);return n>$?(t[0]=e[0]/n,t[1]=e[1]/n,t[2]=e[2]/n):(t[0]=1,t[1]=0,t[2]=0),r}function $b(t,e){var r=um(t,e);return Math.acos(2*r*r-1)}function om(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=r[0],c=r[1],l=r[2],d=r[3];return t[0]=n*d+o*s+i*l-a*c,t[1]=i*d+o*c+a*s-n*l,t[2]=a*d+o*l+n*c-i*s,t[3]=o*d-n*s-i*c-a*l,t}function qb(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),c=Math.cos(r);return t[0]=n*c+o*s,t[1]=i*c+a*s,t[2]=a*c-i*s,t[3]=o*c-n*s,t}function Zb(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),c=Math.cos(r);return t[0]=n*c-a*s,t[1]=i*c+o*s,t[2]=a*c+n*s,t[3]=o*c-i*s,t}function jb(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),c=Math.cos(r);return t[0]=n*c+i*s,t[1]=i*c-n*s,t[2]=a*c+o*s,t[3]=o*c-a*s,t}function Qb(t,e){var r=e[0],n=e[1],i=e[2];return t[0]=r,t[1]=n,t[2]=i,t[3]=Math.sqrt(Math.abs(1-r*r-n*n-i*i)),t}function sm(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=Math.sqrt(r*r+n*n+i*i),s=Math.exp(a),c=o>0?s*Math.sin(o)/o:0;return t[0]=r*c,t[1]=n*c,t[2]=i*c,t[3]=s*Math.cos(o),t}function lm(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=Math.sqrt(r*r+n*n+i*i),s=o>0?Math.atan2(o,a)/o:0;return t[0]=r*s,t[1]=n*s,t[2]=i*s,t[3]=.5*Math.log(r*r+n*n+i*i+a*a),t}function Jb(t,e,r){return lm(t,e),dm(t,t,r),sm(t,t),t}function Ql(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3],c=r[0],l=r[1],d=r[2],f=r[3],u,h,m,g,p;return h=i*c+a*l+o*d+s*f,h<0&&(h=-h,c=-c,l=-l,d=-d,f=-f),1-h>$?(u=Math.acos(h),m=Math.sin(u),g=Math.sin((1-n)*u)/m,p=Math.sin(n*u)/m):(g=1-n,p=n),t[0]=g*i+p*c,t[1]=g*a+p*l,t[2]=g*o+p*d,t[3]=g*s+p*f,t}function ex(t){var e=er(),r=er(),n=er(),i=Math.sqrt(1-e),a=Math.sqrt(e);return t[0]=i*Math.sin(2*Math.PI*r),t[1]=i*Math.cos(2*Math.PI*r),t[2]=a*Math.sin(2*Math.PI*n),t[3]=a*Math.cos(2*Math.PI*n),t}function tx(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a,s=o?1/o:0;return t[0]=-r*s,t[1]=-n*s,t[2]=-i*s,t[3]=a*s,t}function rx(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t}function cm(t,e){var r=e[0]+e[4]+e[8],n;if(r>0)n=Math.sqrt(r+1),t[3]=.5*n,n=.5/n,t[0]=(e[5]-e[7])*n,t[1]=(e[6]-e[2])*n,t[2]=(e[1]-e[3])*n;else{var i=0;e[4]>e[0]&&(i=1),e[8]>e[i*3+i]&&(i=2);var a=(i+1)%3,o=(i+2)%3;n=Math.sqrt(e[i*3+i]-e[a*3+a]-e[o*3+o]+1),t[i]=.5*n,n=.5/n,t[3]=(e[a*3+o]-e[o*3+a])*n,t[a]=(e[a*3+i]+e[i*3+a])*n,t[o]=(e[o*3+i]+e[i*3+o])*n}return t}function nx(t,e,r,n){var i=arguments.length>4&&arguments[4]!==void 0?arguments[4]:zh,a=Math.PI/360;e*=a,n*=a,r*=a;var o=Math.sin(e),s=Math.cos(e),c=Math.sin(r),l=Math.cos(r),d=Math.sin(n),f=Math.cos(n);switch(i){case"xyz":t[0]=o*l*f+s*c*d,t[1]=s*c*f-o*l*d,t[2]=s*l*d+o*c*f,t[3]=s*l*f-o*c*d;break;case"xzy":t[0]=o*l*f-s*c*d,t[1]=s*c*f-o*l*d,t[2]=s*l*d+o*c*f,t[3]=s*l*f+o*c*d;break;case"yxz":t[0]=o*l*f+s*c*d,t[1]=s*c*f-o*l*d,t[2]=s*l*d-o*c*f,t[3]=s*l*f+o*c*d;break;case"yzx":t[0]=o*l*f+s*c*d,t[1]=s*c*f+o*l*d,t[2]=s*l*d-o*c*f,t[3]=s*l*f-o*c*d;break;case"zxy":t[0]=o*l*f-s*c*d,t[1]=s*c*f+o*l*d,t[2]=s*l*d+o*c*f,t[3]=s*l*f-o*c*d;break;case"zyx":t[0]=o*l*f-s*c*d,t[1]=s*c*f+o*l*d,t[2]=s*l*d-o*c*f,t[3]=s*l*f+o*c*d;break;default:throw new Error("Unknown angle order "+i)}return t}function ix(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}var ax=qd,ox=Zd,sx=jd,lx=Qd,cx=Jd,dx=om,dm=eu,um=jl,ux=ru,fm=ql,fx=fm,hm=Zl,hx=hm,au=tu,mx=nu;function px(t,e){return Math.abs(jl(t,e))>=1-$}var gx=(function(){var t=Yl(),e=$l(1,0,0),r=$l(0,1,0);return function(n,i,a){var o=rs(i,a);return o<-.999999?(ns(t,e,i),$d(t)<1e-6&&ns(t,r,i),Yd(t,t),am(n,t,Math.PI),n):o>.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(ns(t,i,a),n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=1+o,au(n,n))}})(),yx=(function(){var t=iu(),e=iu();return function(r,n,i,a,o,s){return Ql(t,n,o,s),Ql(e,i,a,s),Ql(r,t,e,2*s*(1-s)),r}})(),bx=(function(){var t=Oh();return function(e,r,n,i){return t[0]=n[0],t[3]=n[1],t[6]=n[2],t[1]=i[0],t[4]=i[1],t[7]=i[2],t[2]=-r[0],t[5]=-r[1],t[8]=-r[2],au(e,cm(e,t))}})();var ec=class{constructor(e,r){this._position=C.create();this._angles=C.create();this._bobAngles=C.create();this._bobOffset=C.create();this._kickAngles=C.create();this._rollAngle=0;this._fov=90;this._aspect=1;this._near=.1;this._far=1e3;this._viewMatrix=j.create();this._projectionMatrix=j.create();this._viewProjectionMatrix=j.create();this._dirty=!0;e!==void 0&&r!==void 0&&r>0&&(this._aspect=e/r)}get position(){return this._position}set position(e){C.equals(this._position,e)||(C.copy(this._position,e),this._dirty=!0,this.triggerMoveEvent())}get angles(){return this._angles}set angles(e){C.equals(this._angles,e)||(C.copy(this._angles,e),this._dirty=!0,this.triggerMoveEvent())}get bobAngles(){return this._bobAngles}set bobAngles(e){C.copy(this._bobAngles,e),this._dirty=!0}get kickAngles(){return this._kickAngles}set kickAngles(e){C.copy(this._kickAngles,e),this._dirty=!0}get bobOffset(){return this._bobOffset}set bobOffset(e){C.copy(this._bobOffset,e),this._dirty=!0}get rollAngle(){return this._rollAngle}set rollAngle(e){this._rollAngle=e,this._dirty=!0}get fov(){return this._fov}set fov(e){this._fov=e,this._dirty=!0}get aspect(){return this._aspect}set aspect(e){this._aspect=e,this._dirty=!0}setPosition(e,r,n){let i=C.fromValues(e,r,n);C.equals(this._position,i)||(C.copy(this._position,i),this._dirty=!0,this.triggerMoveEvent())}setRotation(e,r,n){let i=C.fromValues(e,r,n);C.equals(this._angles,i)||(C.copy(this._angles,i),this._dirty=!0,this.triggerMoveEvent())}setFov(e){this.fov=e}setAspectRatio(e){this.aspect=e}lookAt(e){let r=C.create();if(C.subtract(r,e,this._position),C.length(r)<.001)return;let i=Math.atan2(r[1],r[0])*zc,a=Math.hypot(r[0],r[1]),o=-Math.atan2(r[2],a)*zc;this.setRotation(o,i,0)}triggerMoveEvent(){this.onCameraMove&&this.onCameraMove({position:C.clone(this._position),angles:C.clone(this._angles)})}get viewMatrix(){return this.updateMatrices(),this._viewMatrix}get projectionMatrix(){return this.updateMatrices(),this._projectionMatrix}get viewProjectionMatrix(){return this.updateMatrices(),this._viewProjectionMatrix}getViewmodelProjectionMatrix(e){let r=j.create();return j.perspective(r,e*Pi,this._aspect,this._near,this._far),r}screenToWorldRay(e,r){let n=e*2-1,i=1-r*2,a=C.fromValues(n,i,-1),o=C.fromValues(n,i,1),s=j.create();j.invert(s,this.viewProjectionMatrix);let c=C.create(),l=C.create();C.transformMat4(c,a,s),C.transformMat4(l,o,s);let d=C.create();return C.subtract(d,l,c),C.normalize(d,d),{origin:C.clone(this._position),direction:d}}updateMatrices(){if(!this._dirty)return;j.perspective(this._projectionMatrix,this._fov*Pi,this._aspect,this._near,this._far);let e=j.fromValues(0,0,-1,0,-1,0,0,0,0,1,0,0,0,0,0,1),r=this._angles[0]+this._bobAngles[0]+this._kickAngles[0],n=this._angles[1]+this._bobAngles[1]+this._kickAngles[1],i=this._angles[2]+this._bobAngles[2]+this._kickAngles[2]+this._rollAngle,a=r*Pi,o=n*Pi,s=i*Pi,c=j.create();j.identity(c),j.rotateZ(c,c,-o),j.rotateY(c,c,-a),j.rotateX(c,c,-s);let l=j.create();j.multiply(l,e,c);let d=C.add(C.create(),this._position,this._bobOffset),f=C.negate(C.create(),d),u=C.create();C.transformMat4(u,f,c);let h=C.fromValues(u[1]?-u[1]:0,u[2]||0,u[0]?-u[0]:0);j.copy(this._viewMatrix,l),this._viewMatrix[12]=h[0],this._viewMatrix[13]=h[1],this._viewMatrix[14]=h[2],j.multiply(this._viewProjectionMatrix,this._projectionMatrix,this._viewMatrix),this._dirty=!1}};var xx=[.2,.2,.2],vx={x:0,y:0,z:1},_x=[.8,.8,.8];function ou(t,e,r){return t+(e-t)*r}function ba(t,e,r){return{x:ou(t.x,e.x,r),y:ou(t.y,e.y,r),z:ou(t.z,e.z,r)}}function ya(t){return t<0?0:t>1?1:t}function su(t){let e=[],r=[];for(let n of t.triangles){let i=e.length,[a,o,s]=n.indices,c=t.texCoords[a],l=t.texCoords[o],d=t.texCoords[s];if(!c||!l||!d)throw new Error(`Missing texCoord for triangle in surface ${t.name}`);e.push({vertexIndex:a,texCoord:[c.s,1-c.t]},{vertexIndex:o,texCoord:[l.s,1-l.t]},{vertexIndex:s,texCoord:[d.s,1-d.t]}),r.push(i,i+1,i+2)}return{vertices:e,indices:new Uint16Array(r)}}function Sx(t,e,r){let n=r?.ambient??xx,i=r?.directional??{direction:vx,color:_x},a=Hr(t),o=Hr(i.direction),s=ya(a.x*o.x+a.y*o.y+a.z*o.z),c=n[0]+i.color[0]*s,l=n[1]+i.color[1]*s,d=n[2]+i.color[2]*s;if(r?.dynamicLights){let f=r.modelMatrix?ff(r.modelMatrix,e):e;for(let u of r.dynamicLights){let h=f.x-u.origin.x,m=f.y-u.origin.y,g=f.z-u.origin.z,p=h*h+m*m+g*g,y=u.radius*u.radius;if(p<y&&y>0){let v=1-Math.sqrt(p)/u.radius,x=Math.sqrt(p),b=x>0?ya(-(h*a.x+m*a.y+g*a.z)/x):0,_=ya(v*b);c+=u.color[0]*_,l+=u.color[1]*_,d+=u.color[2]*_}}}return[ya(c),ya(l),ya(d)]}function lu(t,e,r,n){let i=t.vertices[r.frame0],a=t.vertices[r.frame1];if(!i||!a)throw new Error("Requested MD3 frames are out of range");let o=new Float32Array(e.vertices.length*12);return e.vertices.forEach((s,c)=>{let l=i[s.vertexIndex],d=a[s.vertexIndex];if(!l||!d)throw new Error(`Vertex index ${s.vertexIndex} missing for frame`);let f=ba(l.position,d.position,r.lerp),u=Hr(ba(l.normal,d.normal,r.lerp)),h=Sx(u,f,n),m=c*12;o[m]=f.x,o[m+1]=f.y,o[m+2]=f.z,o[m+3]=u.x,o[m+4]=u.y,o[m+5]=u.z,o[m+6]=s.texCoord[0],o[m+7]=s.texCoord[1],o[m+8]=h[0],o[m+9]=h[1],o[m+10]=h[2],o[m+11]=1}),o}function mm(t,e,r){let n=t.tags[0];if(!n)return null;let i=n.findIndex(g=>g.name===r);if(i===-1)return null;let a=t.tags[e.frame0]?.[i],o=t.tags[e.frame1]?.[i];if(!a||!o)throw new Error(`Tag ${r} is missing for one of the interpolated frames`);let s=ba(a.origin,o.origin,e.lerp),c=Hr(ba(a.axis[0],o.axis[0],e.lerp)),l=Hr(ba(a.axis[1],o.axis[1],e.lerp)),d=Hr(ba(a.axis[2],o.axis[2],e.lerp)),f=c,u=Hr({x:l.x-f.x*(f.x*l.x+f.y*l.y+f.z*l.z),y:l.y-f.y*(f.x*l.x+f.y*l.y+f.z*l.z),z:l.z-f.z*(f.x*l.x+f.y*l.y+f.z*l.z)}),h=Hr({x:f.y*u.z-f.z*u.y,y:f.z*u.x-f.x*u.z,z:f.x*u.y-f.y*u.x}),m=[f,u,h];return{origin:s,axis:m,matrix:hf(s,m)}}var cu=`#version 300 es
|
|
479
|
+
}`;function Y1(t){let e=t.x*t.x+t.y*t.y+t.z*t.z;if(e<=0)return{x:0,y:0,z:1};let r=1/Math.sqrt(e);return{x:t.x*r,y:t.y*r,z:t.z*r}}function Vd(t,e,r){return t+(e-t)*r}function Dh(t,e,r){return{x:Vd(t.x,e.x,r),y:Vd(t.y,e.y,r),z:Vd(t.z,e.z,r)}}function $1(t,e,r){return[t/r.skinWidth,1-e/r.skinHeight]}function Xd(t){if(t.glCommands.length===0){let n=[],i=[];return t.triangles.forEach(a=>{let o=n.length;for(let s=0;s<3;s+=1){let c=a.vertexIndices[s],l=a.texCoordIndices[s],d=t.texCoords[l];n.push({vertexIndex:c,texCoord:$1(d.s,d.t,t.header)})}i.push(o,o+1,o+2)}),{vertices:n,indices:new Uint16Array(i)}}let e=[],r=[];for(let n of t.glCommands){let i=e.length;if(e.push(...n.vertices.map(a=>({vertexIndex:a.vertexIndex,texCoord:[a.s,1-a.t]}))),n.mode==="strip")for(let a=0;a<n.vertices.length-2;a+=1){let o=a%2===0,s=i+a+(o?0:1),c=i+a+(o?1:0),l=i+a+2;r.push(s,c,l)}else for(let a=1;a<n.vertices.length-1;a+=1)r.push(i,i+a,i+a+1)}return{vertices:e,indices:new Uint16Array(r)}}function Kd(t,e,r){let{frame0:n,frame1:i,lerp:a}=r,o=t.frames[n],s=t.frames[i];if(!o||!s)throw new Error("Requested MD2 frames are out of range");let c=new Float32Array(e.vertices.length*8);return e.vertices.forEach((l,d)=>{let f=o.vertices[l.vertexIndex],u=s.vertices[l.vertexIndex];if(!f||!u)throw new Error("MD2 vertex index out of range for frame");let h=Dh(f.position,u.position,a),m=Y1(Dh(f.normal,u.normal,a)),g=d*8;c[g]=h.x,c[g+1]=h.y,c[g+2]=h.z,c[g+3]=m.x,c[g+4]=m.y,c[g+5]=m.z,c[g+6]=l.texCoord[0],c[g+7]=l.texCoord[1]}),c}var ma=class{constructor(e,r,n){this.gl=e,this.geometry=Xd(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Qe(e,e.STATIC_DRAW),this.vertexArray=new Ee(e),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:32,offset:0},{index:1,size:3,type:e.FLOAT,stride:32,offset:12},{index:2,size:2,type:e.FLOAT,stride:32,offset:24}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,e.STATIC_DRAW),this.update(r,n)}update(e,r){let n=Kd(e,this.geometry,r);this.vertexBuffer.upload(n,this.gl.STATIC_DRAW)}bind(){this.vertexArray.bind(),this.indexBuffer.bind()}dispose(){this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose(),this.wireframeIndexBuffer?.dispose()}},pa=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Gd,fragment:Wd},{a_position:0,a_normal:1,a_texCoord:2}),this.uniformMvp=this.program.getUniformLocation("u_modelViewProjection"),this.uniformModelMatrix=this.program.getUniformLocation("u_modelMatrix"),this.uniformLightDir=this.program.getUniformLocation("u_lightDir"),this.uniformAmbient=this.program.getUniformLocation("u_ambient"),this.uniformTint=this.program.getUniformLocation("u_tint"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformRenderMode=this.program.getUniformLocation("u_renderMode"),this.uniformSolidColor=this.program.getUniformLocation("u_solidColor"),this.uniformNumDlights=this.program.getUniformLocation("u_numDlights");for(let r=0;r<Dn;r++)this.uniformDlights.push({pos:this.program.getUniformLocation(`u_dlights[${r}].position`),color:this.program.getUniformLocation(`u_dlights[${r}].color`),intensity:this.program.getUniformLocation(`u_dlights[${r}].intensity`)});this.uniformBrightness=this.program.getUniformLocation("u_brightness"),this.uniformGamma=this.program.getUniformLocation("u_gamma"),this.uniformFullbright=this.program.getUniformLocation("u_fullbright"),this.uniformGlobalAmbient=this.program.getUniformLocation("u_globalAmbient")}get shaderSize(){return this.program.sourceSize}bind(e){let{modelViewProjection:r,modelMatrix:n,lightDirection:i=[0,0,1],ambientLight:a=.2,tint:o=[1,1,1,1],diffuseSampler:s=0,dlights:c=[],renderMode:l,brightness:d=1,gamma:f=1,fullbright:u=!1,ambient:h=0}=e,m=new Float32Array(i),g=new Float32Array(o);this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,r),n?this.gl.uniformMatrix4fv(this.uniformModelMatrix,!1,n):this.gl.uniformMatrix4fv(this.uniformModelMatrix,!1,new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])),this.gl.uniform3fv(this.uniformLightDir,m),this.gl.uniform1f(this.uniformAmbient,a),this.gl.uniform4fv(this.uniformTint,g),this.gl.uniform1i(this.uniformDiffuse,s);let p=0,y=[1,1,1,1];l&&(l.mode==="solid"||l.mode==="wireframe"?p=1:l.mode==="solid-faceted"&&(p=2),l.color?y=[...l.color]:l.generateRandomColor),this.gl.uniform1i(this.uniformRenderMode,p),this.gl.uniform4f(this.uniformSolidColor,y[0],y[1],y[2],y[3]);let v=Math.min(c.length,Dn);this.gl.uniform1i(this.uniformNumDlights,v);for(let x=0;x<v;x++){let b=c[x];this.gl.uniform3f(this.uniformDlights[x].pos,b.origin.x,b.origin.y,b.origin.z),this.gl.uniform3f(this.uniformDlights[x].color,b.color.x,b.color.y,b.color.z),this.gl.uniform1f(this.uniformDlights[x].intensity,b.intensity)}this.gl.uniform1f(this.uniformBrightness,d),this.gl.uniform1f(this.uniformGamma,f),this.gl.uniform1i(this.uniformFullbright,u?1:0),this.gl.uniform1f(this.uniformGlobalAmbient,h)}draw(e,r){if(e.vertexArray.bind(),r&&r.mode==="wireframe"){if(!e.wireframeIndexBuffer){e.wireframeIndexBuffer=new Qe(this.gl,this.gl.STATIC_DRAW);let n=ua(e.geometry.indices);e.wireframeIndexBuffer.upload(n),e.wireframeIndexCount=n.length}e.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,e.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else e.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,e.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var $=1e-6,xe=typeof Float32Array<"u"?Float32Array:Array,er=Math.random,zh="zyx";function tn(t){return t>=0?Math.round(t):t%.5===0?Math.floor(t):Math.round(t)}var OE=Math.PI/180,UE=180/Math.PI;function Oh(){var t=new xe(9);return xe!=Float32Array&&(t[1]=0,t[2]=0,t[3]=0,t[5]=0,t[6]=0,t[7]=0),t[0]=1,t[4]=1,t[8]=1,t}var j={};Na(j,{add:()=>Fy,adjoint:()=>ny,clone:()=>j1,copy:()=>Q1,create:()=>Z1,decompose:()=>vy,determinant:()=>iy,equals:()=>Oy,exactEquals:()=>zy,frob:()=>By,fromQuat:()=>wy,fromQuat2:()=>yy,fromRotation:()=>hy,fromRotationTranslation:()=>Hh,fromRotationTranslationScale:()=>_y,fromRotationTranslationScaleOrigin:()=>Sy,fromScaling:()=>fy,fromTranslation:()=>uy,fromValues:()=>J1,fromXRotation:()=>my,fromYRotation:()=>py,fromZRotation:()=>gy,frustum:()=>My,getRotation:()=>xy,getScaling:()=>Vh,getTranslation:()=>by,identity:()=>Uh,invert:()=>ry,lookAt:()=>Cy,mul:()=>Uy,multiply:()=>Nh,multiplyScalar:()=>ky,multiplyScalarAndAdd:()=>Dy,ortho:()=>Ty,orthoNO:()=>Wh,orthoZO:()=>Ry,perspective:()=>Ay,perspectiveFromFieldOfView:()=>Ly,perspectiveNO:()=>Gh,perspectiveZO:()=>Ey,rotate:()=>sy,rotateX:()=>ly,rotateY:()=>cy,rotateZ:()=>dy,scale:()=>oy,set:()=>ey,str:()=>Iy,sub:()=>Ny,subtract:()=>Xh,targetTo:()=>Py,translate:()=>ay,transpose:()=>ty});function Z1(){var t=new xe(16);return xe!=Float32Array&&(t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[11]=0,t[12]=0,t[13]=0,t[14]=0),t[0]=1,t[5]=1,t[10]=1,t[15]=1,t}function j1(t){var e=new xe(16);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}function Q1(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function J1(t,e,r,n,i,a,o,s,c,l,d,f,u,h,m,g){var p=new xe(16);return p[0]=t,p[1]=e,p[2]=r,p[3]=n,p[4]=i,p[5]=a,p[6]=o,p[7]=s,p[8]=c,p[9]=l,p[10]=d,p[11]=f,p[12]=u,p[13]=h,p[14]=m,p[15]=g,p}function ey(t,e,r,n,i,a,o,s,c,l,d,f,u,h,m,g,p){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t[4]=a,t[5]=o,t[6]=s,t[7]=c,t[8]=l,t[9]=d,t[10]=f,t[11]=u,t[12]=h,t[13]=m,t[14]=g,t[15]=p,t}function Uh(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function ty(t,e){if(t===e){var r=e[1],n=e[2],i=e[3],a=e[6],o=e[7],s=e[11];t[1]=e[4],t[2]=e[8],t[3]=e[12],t[4]=r,t[6]=e[9],t[7]=e[13],t[8]=n,t[9]=a,t[11]=e[14],t[12]=i,t[13]=o,t[14]=s}else t[0]=e[0],t[1]=e[4],t[2]=e[8],t[3]=e[12],t[4]=e[1],t[5]=e[5],t[6]=e[9],t[7]=e[13],t[8]=e[2],t[9]=e[6],t[10]=e[10],t[11]=e[14],t[12]=e[3],t[13]=e[7],t[14]=e[11],t[15]=e[15];return t}function ry(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=e[4],s=e[5],c=e[6],l=e[7],d=e[8],f=e[9],u=e[10],h=e[11],m=e[12],g=e[13],p=e[14],y=e[15],v=r*s-n*o,x=r*c-i*o,b=r*l-a*o,_=n*c-i*s,w=n*l-a*s,S=i*l-a*c,E=d*g-f*m,L=d*p-u*m,M=d*y-h*m,C=f*p-u*g,I=f*y-h*g,B=u*y-h*p,F=v*B-x*I+b*C+_*M-w*L+S*E;return F?(F=1/F,t[0]=(s*B-c*I+l*C)*F,t[1]=(i*I-n*B-a*C)*F,t[2]=(g*S-p*w+y*_)*F,t[3]=(u*w-f*S-h*_)*F,t[4]=(c*M-o*B-l*L)*F,t[5]=(r*B-i*M+a*L)*F,t[6]=(p*b-m*S-y*x)*F,t[7]=(d*S-u*b+h*x)*F,t[8]=(o*I-s*M+l*E)*F,t[9]=(n*M-r*I-a*E)*F,t[10]=(m*w-g*b+y*v)*F,t[11]=(f*b-d*w-h*v)*F,t[12]=(s*L-o*C-c*E)*F,t[13]=(r*C-n*L+i*E)*F,t[14]=(g*x-m*_-p*v)*F,t[15]=(d*_-f*x+u*v)*F,t):null}function ny(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=e[4],s=e[5],c=e[6],l=e[7],d=e[8],f=e[9],u=e[10],h=e[11],m=e[12],g=e[13],p=e[14],y=e[15],v=r*s-n*o,x=r*c-i*o,b=r*l-a*o,_=n*c-i*s,w=n*l-a*s,S=i*l-a*c,E=d*g-f*m,L=d*p-u*m,M=d*y-h*m,C=f*p-u*g,I=f*y-h*g,B=u*y-h*p;return t[0]=s*B-c*I+l*C,t[1]=i*I-n*B-a*C,t[2]=g*S-p*w+y*_,t[3]=u*w-f*S-h*_,t[4]=c*M-o*B-l*L,t[5]=r*B-i*M+a*L,t[6]=p*b-m*S-y*x,t[7]=d*S-u*b+h*x,t[8]=o*I-s*M+l*E,t[9]=n*M-r*I-a*E,t[10]=m*w-g*b+y*v,t[11]=f*b-d*w-h*v,t[12]=s*L-o*C-c*E,t[13]=r*C-n*L+i*E,t[14]=g*x-m*_-p*v,t[15]=d*_-f*x+u*v,t}function iy(t){var e=t[0],r=t[1],n=t[2],i=t[3],a=t[4],o=t[5],s=t[6],c=t[7],l=t[8],d=t[9],f=t[10],u=t[11],h=t[12],m=t[13],g=t[14],p=t[15],y=e*o-r*a,v=e*s-n*a,x=r*s-n*o,b=l*m-d*h,_=l*g-f*h,w=d*g-f*m,S=e*w-r*_+n*b,E=a*w-o*_+s*b,L=l*x-d*v+f*y,M=h*x-m*v+g*y;return c*S-i*E+p*L-u*M}function Nh(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=e[4],c=e[5],l=e[6],d=e[7],f=e[8],u=e[9],h=e[10],m=e[11],g=e[12],p=e[13],y=e[14],v=e[15],x=r[0],b=r[1],_=r[2],w=r[3];return t[0]=x*n+b*s+_*f+w*g,t[1]=x*i+b*c+_*u+w*p,t[2]=x*a+b*l+_*h+w*y,t[3]=x*o+b*d+_*m+w*v,x=r[4],b=r[5],_=r[6],w=r[7],t[4]=x*n+b*s+_*f+w*g,t[5]=x*i+b*c+_*u+w*p,t[6]=x*a+b*l+_*h+w*y,t[7]=x*o+b*d+_*m+w*v,x=r[8],b=r[9],_=r[10],w=r[11],t[8]=x*n+b*s+_*f+w*g,t[9]=x*i+b*c+_*u+w*p,t[10]=x*a+b*l+_*h+w*y,t[11]=x*o+b*d+_*m+w*v,x=r[12],b=r[13],_=r[14],w=r[15],t[12]=x*n+b*s+_*f+w*g,t[13]=x*i+b*c+_*u+w*p,t[14]=x*a+b*l+_*h+w*y,t[15]=x*o+b*d+_*m+w*v,t}function ay(t,e,r){var n=r[0],i=r[1],a=r[2],o,s,c,l,d,f,u,h,m,g,p,y;return e===t?(t[12]=e[0]*n+e[4]*i+e[8]*a+e[12],t[13]=e[1]*n+e[5]*i+e[9]*a+e[13],t[14]=e[2]*n+e[6]*i+e[10]*a+e[14],t[15]=e[3]*n+e[7]*i+e[11]*a+e[15]):(o=e[0],s=e[1],c=e[2],l=e[3],d=e[4],f=e[5],u=e[6],h=e[7],m=e[8],g=e[9],p=e[10],y=e[11],t[0]=o,t[1]=s,t[2]=c,t[3]=l,t[4]=d,t[5]=f,t[6]=u,t[7]=h,t[8]=m,t[9]=g,t[10]=p,t[11]=y,t[12]=o*n+d*i+m*a+e[12],t[13]=s*n+f*i+g*a+e[13],t[14]=c*n+u*i+p*a+e[14],t[15]=l*n+h*i+y*a+e[15]),t}function oy(t,e,r){var n=r[0],i=r[1],a=r[2];return t[0]=e[0]*n,t[1]=e[1]*n,t[2]=e[2]*n,t[3]=e[3]*n,t[4]=e[4]*i,t[5]=e[5]*i,t[6]=e[6]*i,t[7]=e[7]*i,t[8]=e[8]*a,t[9]=e[9]*a,t[10]=e[10]*a,t[11]=e[11]*a,t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function sy(t,e,r,n){var i=n[0],a=n[1],o=n[2],s=Math.sqrt(i*i+a*a+o*o),c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,L,M,C,I,B,F,U;return s<$?null:(s=1/s,i*=s,a*=s,o*=s,c=Math.sin(r),l=Math.cos(r),d=1-l,f=e[0],u=e[1],h=e[2],m=e[3],g=e[4],p=e[5],y=e[6],v=e[7],x=e[8],b=e[9],_=e[10],w=e[11],S=i*i*d+l,E=a*i*d+o*c,L=o*i*d-a*c,M=i*a*d-o*c,C=a*a*d+l,I=o*a*d+i*c,B=i*o*d+a*c,F=a*o*d-i*c,U=o*o*d+l,t[0]=f*S+g*E+x*L,t[1]=u*S+p*E+b*L,t[2]=h*S+y*E+_*L,t[3]=m*S+v*E+w*L,t[4]=f*M+g*C+x*I,t[5]=u*M+p*C+b*I,t[6]=h*M+y*C+_*I,t[7]=m*M+v*C+w*I,t[8]=f*B+g*F+x*U,t[9]=u*B+p*F+b*U,t[10]=h*B+y*F+_*U,t[11]=m*B+v*F+w*U,e!==t&&(t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t)}function ly(t,e,r){var n=Math.sin(r),i=Math.cos(r),a=e[4],o=e[5],s=e[6],c=e[7],l=e[8],d=e[9],f=e[10],u=e[11];return e!==t&&(t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[4]=a*i+l*n,t[5]=o*i+d*n,t[6]=s*i+f*n,t[7]=c*i+u*n,t[8]=l*i-a*n,t[9]=d*i-o*n,t[10]=f*i-s*n,t[11]=u*i-c*n,t}function cy(t,e,r){var n=Math.sin(r),i=Math.cos(r),a=e[0],o=e[1],s=e[2],c=e[3],l=e[8],d=e[9],f=e[10],u=e[11];return e!==t&&(t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[0]=a*i-l*n,t[1]=o*i-d*n,t[2]=s*i-f*n,t[3]=c*i-u*n,t[8]=a*n+l*i,t[9]=o*n+d*i,t[10]=s*n+f*i,t[11]=c*n+u*i,t}function dy(t,e,r){var n=Math.sin(r),i=Math.cos(r),a=e[0],o=e[1],s=e[2],c=e[3],l=e[4],d=e[5],f=e[6],u=e[7];return e!==t&&(t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[0]=a*i+l*n,t[1]=o*i+d*n,t[2]=s*i+f*n,t[3]=c*i+u*n,t[4]=l*i-a*n,t[5]=d*i-o*n,t[6]=f*i-s*n,t[7]=u*i-c*n,t}function uy(t,e){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=e[0],t[13]=e[1],t[14]=e[2],t[15]=1,t}function fy(t,e){return t[0]=e[0],t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=e[1],t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=e[2],t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function hy(t,e,r){var n=r[0],i=r[1],a=r[2],o=Math.sqrt(n*n+i*i+a*a),s,c,l;return o<$?null:(o=1/o,n*=o,i*=o,a*=o,s=Math.sin(e),c=Math.cos(e),l=1-c,t[0]=n*n*l+c,t[1]=i*n*l+a*s,t[2]=a*n*l-i*s,t[3]=0,t[4]=n*i*l-a*s,t[5]=i*i*l+c,t[6]=a*i*l+n*s,t[7]=0,t[8]=n*a*l+i*s,t[9]=i*a*l-n*s,t[10]=a*a*l+c,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t)}function my(t,e){var r=Math.sin(e),n=Math.cos(e);return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=n,t[6]=r,t[7]=0,t[8]=0,t[9]=-r,t[10]=n,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function py(t,e){var r=Math.sin(e),n=Math.cos(e);return t[0]=n,t[1]=0,t[2]=-r,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=r,t[9]=0,t[10]=n,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function gy(t,e){var r=Math.sin(e),n=Math.cos(e);return t[0]=n,t[1]=r,t[2]=0,t[3]=0,t[4]=-r,t[5]=n,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function Hh(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=n+n,c=i+i,l=a+a,d=n*s,f=n*c,u=n*l,h=i*c,m=i*l,g=a*l,p=o*s,y=o*c,v=o*l;return t[0]=1-(h+g),t[1]=f+v,t[2]=u-y,t[3]=0,t[4]=f-v,t[5]=1-(d+g),t[6]=m+p,t[7]=0,t[8]=u+y,t[9]=m-p,t[10]=1-(d+h),t[11]=0,t[12]=r[0],t[13]=r[1],t[14]=r[2],t[15]=1,t}function yy(t,e){var r=new xe(3),n=-e[0],i=-e[1],a=-e[2],o=e[3],s=e[4],c=e[5],l=e[6],d=e[7],f=n*n+i*i+a*a+o*o;return f>0?(r[0]=(s*o+d*n+c*a-l*i)*2/f,r[1]=(c*o+d*i+l*n-s*a)*2/f,r[2]=(l*o+d*a+s*i-c*n)*2/f):(r[0]=(s*o+d*n+c*a-l*i)*2,r[1]=(c*o+d*i+l*n-s*a)*2,r[2]=(l*o+d*a+s*i-c*n)*2),Hh(t,e,r),t}function by(t,e){return t[0]=e[12],t[1]=e[13],t[2]=e[14],t}function Vh(t,e){var r=e[0],n=e[1],i=e[2],a=e[4],o=e[5],s=e[6],c=e[8],l=e[9],d=e[10];return t[0]=Math.sqrt(r*r+n*n+i*i),t[1]=Math.sqrt(a*a+o*o+s*s),t[2]=Math.sqrt(c*c+l*l+d*d),t}function xy(t,e){var r=new xe(3);Vh(r,e);var n=1/r[0],i=1/r[1],a=1/r[2],o=e[0]*n,s=e[1]*i,c=e[2]*a,l=e[4]*n,d=e[5]*i,f=e[6]*a,u=e[8]*n,h=e[9]*i,m=e[10]*a,g=o+d+m,p=0;return g>0?(p=Math.sqrt(g+1)*2,t[3]=.25*p,t[0]=(f-h)/p,t[1]=(u-c)/p,t[2]=(s-l)/p):o>d&&o>m?(p=Math.sqrt(1+o-d-m)*2,t[3]=(f-h)/p,t[0]=.25*p,t[1]=(s+l)/p,t[2]=(u+c)/p):d>m?(p=Math.sqrt(1+d-o-m)*2,t[3]=(u-c)/p,t[0]=(s+l)/p,t[1]=.25*p,t[2]=(f+h)/p):(p=Math.sqrt(1+m-o-d)*2,t[3]=(s-l)/p,t[0]=(u+c)/p,t[1]=(f+h)/p,t[2]=.25*p),t}function vy(t,e,r,n){e[0]=n[12],e[1]=n[13],e[2]=n[14];var i=n[0],a=n[1],o=n[2],s=n[4],c=n[5],l=n[6],d=n[8],f=n[9],u=n[10];r[0]=Math.sqrt(i*i+a*a+o*o),r[1]=Math.sqrt(s*s+c*c+l*l),r[2]=Math.sqrt(d*d+f*f+u*u);var h=1/r[0],m=1/r[1],g=1/r[2],p=i*h,y=a*m,v=o*g,x=s*h,b=c*m,_=l*g,w=d*h,S=f*m,E=u*g,L=p+b+E,M=0;return L>0?(M=Math.sqrt(L+1)*2,t[3]=.25*M,t[0]=(_-S)/M,t[1]=(w-v)/M,t[2]=(y-x)/M):p>b&&p>E?(M=Math.sqrt(1+p-b-E)*2,t[3]=(_-S)/M,t[0]=.25*M,t[1]=(y+x)/M,t[2]=(w+v)/M):b>E?(M=Math.sqrt(1+b-p-E)*2,t[3]=(w-v)/M,t[0]=(y+x)/M,t[1]=.25*M,t[2]=(_+S)/M):(M=Math.sqrt(1+E-p-b)*2,t[3]=(y-x)/M,t[0]=(w+v)/M,t[1]=(_+S)/M,t[2]=.25*M),t}function _y(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3],c=i+i,l=a+a,d=o+o,f=i*c,u=i*l,h=i*d,m=a*l,g=a*d,p=o*d,y=s*c,v=s*l,x=s*d,b=n[0],_=n[1],w=n[2];return t[0]=(1-(m+p))*b,t[1]=(u+x)*b,t[2]=(h-v)*b,t[3]=0,t[4]=(u-x)*_,t[5]=(1-(f+p))*_,t[6]=(g+y)*_,t[7]=0,t[8]=(h+v)*w,t[9]=(g-y)*w,t[10]=(1-(f+m))*w,t[11]=0,t[12]=r[0],t[13]=r[1],t[14]=r[2],t[15]=1,t}function Sy(t,e,r,n,i){var a=e[0],o=e[1],s=e[2],c=e[3],l=a+a,d=o+o,f=s+s,u=a*l,h=a*d,m=a*f,g=o*d,p=o*f,y=s*f,v=c*l,x=c*d,b=c*f,_=n[0],w=n[1],S=n[2],E=i[0],L=i[1],M=i[2],C=(1-(g+y))*_,I=(h+b)*_,B=(m-x)*_,F=(h-b)*w,U=(1-(u+y))*w,ce=(p+v)*w,Nt=(m+x)*S,Ct=(p-v)*S,zr=(1-(u+g))*S;return t[0]=C,t[1]=I,t[2]=B,t[3]=0,t[4]=F,t[5]=U,t[6]=ce,t[7]=0,t[8]=Nt,t[9]=Ct,t[10]=zr,t[11]=0,t[12]=r[0]+E-(C*E+F*L+Nt*M),t[13]=r[1]+L-(I*E+U*L+Ct*M),t[14]=r[2]+M-(B*E+ce*L+zr*M),t[15]=1,t}function wy(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r+r,s=n+n,c=i+i,l=r*o,d=n*o,f=n*s,u=i*o,h=i*s,m=i*c,g=a*o,p=a*s,y=a*c;return t[0]=1-f-m,t[1]=d+y,t[2]=u-p,t[3]=0,t[4]=d-y,t[5]=1-l-m,t[6]=h+g,t[7]=0,t[8]=u+p,t[9]=h-g,t[10]=1-l-f,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t}function My(t,e,r,n,i,a,o){var s=1/(r-e),c=1/(i-n),l=1/(a-o);return t[0]=a*2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=a*2*c,t[6]=0,t[7]=0,t[8]=(r+e)*s,t[9]=(i+n)*c,t[10]=(o+a)*l,t[11]=-1,t[12]=0,t[13]=0,t[14]=o*a*2*l,t[15]=0,t}function Gh(t,e,r,n,i){var a=1/Math.tan(e/2);if(t[0]=a/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=a,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[11]=-1,t[12]=0,t[13]=0,t[15]=0,i!=null&&i!==1/0){var o=1/(n-i);t[10]=(i+n)*o,t[14]=2*i*n*o}else t[10]=-1,t[14]=-2*n;return t}var Ay=Gh;function Ey(t,e,r,n,i){var a=1/Math.tan(e/2);if(t[0]=a/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=a,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[11]=-1,t[12]=0,t[13]=0,t[15]=0,i!=null&&i!==1/0){var o=1/(n-i);t[10]=i*o,t[14]=i*n*o}else t[10]=-1,t[14]=-n;return t}function Ly(t,e,r,n){var i=Math.tan(e.upDegrees*Math.PI/180),a=Math.tan(e.downDegrees*Math.PI/180),o=Math.tan(e.leftDegrees*Math.PI/180),s=Math.tan(e.rightDegrees*Math.PI/180),c=2/(o+s),l=2/(i+a);return t[0]=c,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=l,t[6]=0,t[7]=0,t[8]=-((o-s)*c*.5),t[9]=(i-a)*l*.5,t[10]=n/(r-n),t[11]=-1,t[12]=0,t[13]=0,t[14]=n*r/(r-n),t[15]=0,t}function Wh(t,e,r,n,i,a,o){var s=1/(e-r),c=1/(n-i),l=1/(a-o);return t[0]=-2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=-2*c,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=2*l,t[11]=0,t[12]=(e+r)*s,t[13]=(i+n)*c,t[14]=(o+a)*l,t[15]=1,t}var Ty=Wh;function Ry(t,e,r,n,i,a,o){var s=1/(e-r),c=1/(n-i),l=1/(a-o);return t[0]=-2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=-2*c,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=l,t[11]=0,t[12]=(e+r)*s,t[13]=(i+n)*c,t[14]=a*l,t[15]=1,t}function Cy(t,e,r,n){var i,a,o,s,c,l,d,f,u,h,m=e[0],g=e[1],p=e[2],y=n[0],v=n[1],x=n[2],b=r[0],_=r[1],w=r[2];return Math.abs(m-b)<$&&Math.abs(g-_)<$&&Math.abs(p-w)<$?Uh(t):(d=m-b,f=g-_,u=p-w,h=1/Math.sqrt(d*d+f*f+u*u),d*=h,f*=h,u*=h,i=v*u-x*f,a=x*d-y*u,o=y*f-v*d,h=Math.sqrt(i*i+a*a+o*o),h?(h=1/h,i*=h,a*=h,o*=h):(i=0,a=0,o=0),s=f*o-u*a,c=u*i-d*o,l=d*a-f*i,h=Math.sqrt(s*s+c*c+l*l),h?(h=1/h,s*=h,c*=h,l*=h):(s=0,c=0,l=0),t[0]=i,t[1]=s,t[2]=d,t[3]=0,t[4]=a,t[5]=c,t[6]=f,t[7]=0,t[8]=o,t[9]=l,t[10]=u,t[11]=0,t[12]=-(i*m+a*g+o*p),t[13]=-(s*m+c*g+l*p),t[14]=-(d*m+f*g+u*p),t[15]=1,t)}function Py(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=n[0],c=n[1],l=n[2],d=i-r[0],f=a-r[1],u=o-r[2],h=d*d+f*f+u*u;h>0&&(h=1/Math.sqrt(h),d*=h,f*=h,u*=h);var m=c*u-l*f,g=l*d-s*u,p=s*f-c*d;return h=m*m+g*g+p*p,h>0&&(h=1/Math.sqrt(h),m*=h,g*=h,p*=h),t[0]=m,t[1]=g,t[2]=p,t[3]=0,t[4]=f*p-u*g,t[5]=u*m-d*p,t[6]=d*g-f*m,t[7]=0,t[8]=d,t[9]=f,t[10]=u,t[11]=0,t[12]=i,t[13]=a,t[14]=o,t[15]=1,t}function Iy(t){return"mat4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+", "+t[4]+", "+t[5]+", "+t[6]+", "+t[7]+", "+t[8]+", "+t[9]+", "+t[10]+", "+t[11]+", "+t[12]+", "+t[13]+", "+t[14]+", "+t[15]+")"}function By(t){return Math.sqrt(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]+t[3]*t[3]+t[4]*t[4]+t[5]*t[5]+t[6]*t[6]+t[7]*t[7]+t[8]*t[8]+t[9]*t[9]+t[10]*t[10]+t[11]*t[11]+t[12]*t[12]+t[13]*t[13]+t[14]*t[14]+t[15]*t[15])}function Fy(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t[3]=e[3]+r[3],t[4]=e[4]+r[4],t[5]=e[5]+r[5],t[6]=e[6]+r[6],t[7]=e[7]+r[7],t[8]=e[8]+r[8],t[9]=e[9]+r[9],t[10]=e[10]+r[10],t[11]=e[11]+r[11],t[12]=e[12]+r[12],t[13]=e[13]+r[13],t[14]=e[14]+r[14],t[15]=e[15]+r[15],t}function Xh(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t[3]=e[3]-r[3],t[4]=e[4]-r[4],t[5]=e[5]-r[5],t[6]=e[6]-r[6],t[7]=e[7]-r[7],t[8]=e[8]-r[8],t[9]=e[9]-r[9],t[10]=e[10]-r[10],t[11]=e[11]-r[11],t[12]=e[12]-r[12],t[13]=e[13]-r[13],t[14]=e[14]-r[14],t[15]=e[15]-r[15],t}function ky(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t[4]=e[4]*r,t[5]=e[5]*r,t[6]=e[6]*r,t[7]=e[7]*r,t[8]=e[8]*r,t[9]=e[9]*r,t[10]=e[10]*r,t[11]=e[11]*r,t[12]=e[12]*r,t[13]=e[13]*r,t[14]=e[14]*r,t[15]=e[15]*r,t}function Dy(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t[3]=e[3]+r[3]*n,t[4]=e[4]+r[4]*n,t[5]=e[5]+r[5]*n,t[6]=e[6]+r[6]*n,t[7]=e[7]+r[7]*n,t[8]=e[8]+r[8]*n,t[9]=e[9]+r[9]*n,t[10]=e[10]+r[10]*n,t[11]=e[11]+r[11]*n,t[12]=e[12]+r[12]*n,t[13]=e[13]+r[13]*n,t[14]=e[14]+r[14]*n,t[15]=e[15]+r[15]*n,t}function zy(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]&&t[4]===e[4]&&t[5]===e[5]&&t[6]===e[6]&&t[7]===e[7]&&t[8]===e[8]&&t[9]===e[9]&&t[10]===e[10]&&t[11]===e[11]&&t[12]===e[12]&&t[13]===e[13]&&t[14]===e[14]&&t[15]===e[15]}function Oy(t,e){var r=t[0],n=t[1],i=t[2],a=t[3],o=t[4],s=t[5],c=t[6],l=t[7],d=t[8],f=t[9],u=t[10],h=t[11],m=t[12],g=t[13],p=t[14],y=t[15],v=e[0],x=e[1],b=e[2],_=e[3],w=e[4],S=e[5],E=e[6],L=e[7],M=e[8],C=e[9],I=e[10],B=e[11],F=e[12],U=e[13],ce=e[14],Nt=e[15];return Math.abs(r-v)<=$*Math.max(1,Math.abs(r),Math.abs(v))&&Math.abs(n-x)<=$*Math.max(1,Math.abs(n),Math.abs(x))&&Math.abs(i-b)<=$*Math.max(1,Math.abs(i),Math.abs(b))&&Math.abs(a-_)<=$*Math.max(1,Math.abs(a),Math.abs(_))&&Math.abs(o-w)<=$*Math.max(1,Math.abs(o),Math.abs(w))&&Math.abs(s-S)<=$*Math.max(1,Math.abs(s),Math.abs(S))&&Math.abs(c-E)<=$*Math.max(1,Math.abs(c),Math.abs(E))&&Math.abs(l-L)<=$*Math.max(1,Math.abs(l),Math.abs(L))&&Math.abs(d-M)<=$*Math.max(1,Math.abs(d),Math.abs(M))&&Math.abs(f-C)<=$*Math.max(1,Math.abs(f),Math.abs(C))&&Math.abs(u-I)<=$*Math.max(1,Math.abs(u),Math.abs(I))&&Math.abs(h-B)<=$*Math.max(1,Math.abs(h),Math.abs(B))&&Math.abs(m-F)<=$*Math.max(1,Math.abs(m),Math.abs(F))&&Math.abs(g-U)<=$*Math.max(1,Math.abs(g),Math.abs(U))&&Math.abs(p-ce)<=$*Math.max(1,Math.abs(p),Math.abs(ce))&&Math.abs(y-Nt)<=$*Math.max(1,Math.abs(y),Math.abs(Nt))}var Uy=Nh,Ny=Xh;var Jl={};Na(Jl,{add:()=>cx,calculateW:()=>Qb,clone:()=>ax,conjugate:()=>rx,copy:()=>sx,create:()=>iu,dot:()=>um,equals:()=>px,exactEquals:()=>mx,exp:()=>sm,fromEuler:()=>nx,fromMat3:()=>cm,fromValues:()=>ox,getAngle:()=>$b,getAxisAngle:()=>Yb,identity:()=>Kb,invert:()=>tx,len:()=>fx,length:()=>fm,lerp:()=>ux,ln:()=>lm,mul:()=>dx,multiply:()=>om,normalize:()=>au,pow:()=>Jb,random:()=>ex,rotateX:()=>qb,rotateY:()=>Zb,rotateZ:()=>jb,rotationTo:()=>gx,scale:()=>dm,set:()=>lx,setAxes:()=>bx,setAxisAngle:()=>am,slerp:()=>Ql,sqlerp:()=>yx,sqrLen:()=>hx,squaredLength:()=>hm,str:()=>ix});var R={};Na(R,{add:()=>Wy,angle:()=>ub,bezier:()=>nb,ceil:()=>Xy,clone:()=>Hy,copy:()=>Vy,create:()=>Yl,cross:()=>ns,dist:()=>xb,distance:()=>Zh,div:()=>bb,divide:()=>qh,dot:()=>rs,equals:()=>pb,exactEquals:()=>mb,floor:()=>Ky,forEach:()=>Sb,fromValues:()=>$l,hermite:()=>rb,inverse:()=>Jy,len:()=>$d,length:()=>Kh,lerp:()=>eb,max:()=>$y,min:()=>Yy,mul:()=>yb,multiply:()=>$h,negate:()=>Qy,normalize:()=>Yd,random:()=>ib,rotateX:()=>lb,rotateY:()=>cb,rotateZ:()=>db,round:()=>qy,scale:()=>Zy,scaleAndAdd:()=>jy,set:()=>Gy,slerp:()=>tb,sqrDist:()=>vb,sqrLen:()=>_b,squaredDistance:()=>jh,squaredLength:()=>Qh,str:()=>hb,sub:()=>gb,subtract:()=>Yh,transformMat3:()=>ob,transformMat4:()=>ab,transformQuat:()=>sb,zero:()=>fb});function Yl(){var t=new xe(3);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t}function Hy(t){var e=new xe(3);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function Kh(t){var e=t[0],r=t[1],n=t[2];return Math.sqrt(e*e+r*r+n*n)}function $l(t,e,r){var n=new xe(3);return n[0]=t,n[1]=e,n[2]=r,n}function Vy(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function Gy(t,e,r,n){return t[0]=e,t[1]=r,t[2]=n,t}function Wy(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t}function Yh(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t}function $h(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t[2]=e[2]*r[2],t}function qh(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t[2]=e[2]/r[2],t}function Xy(t,e){return t[0]=Math.ceil(e[0]),t[1]=Math.ceil(e[1]),t[2]=Math.ceil(e[2]),t}function Ky(t,e){return t[0]=Math.floor(e[0]),t[1]=Math.floor(e[1]),t[2]=Math.floor(e[2]),t}function Yy(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t[2]=Math.min(e[2],r[2]),t}function $y(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t[2]=Math.max(e[2],r[2]),t}function qy(t,e){return t[0]=tn(e[0]),t[1]=tn(e[1]),t[2]=tn(e[2]),t}function Zy(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t}function jy(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t}function Zh(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2];return Math.sqrt(r*r+n*n+i*i)}function jh(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2];return r*r+n*n+i*i}function Qh(t){var e=t[0],r=t[1],n=t[2];return e*e+r*r+n*n}function Qy(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t}function Jy(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t}function Yd(t,e){var r=e[0],n=e[1],i=e[2],a=r*r+n*n+i*i;return a>0&&(a=1/Math.sqrt(a)),t[0]=e[0]*a,t[1]=e[1]*a,t[2]=e[2]*a,t}function rs(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}function ns(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[0],s=r[1],c=r[2];return t[0]=i*c-a*s,t[1]=a*o-n*c,t[2]=n*s-i*o,t}function eb(t,e,r,n){var i=e[0],a=e[1],o=e[2];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t}function tb(t,e,r,n){var i=Math.acos(Math.min(Math.max(rs(e,r),-1),1)),a=Math.sin(i),o=Math.sin((1-n)*i)/a,s=Math.sin(n*i)/a;return t[0]=o*e[0]+s*r[0],t[1]=o*e[1]+s*r[1],t[2]=o*e[2]+s*r[2],t}function rb(t,e,r,n,i,a){var o=a*a,s=o*(2*a-3)+1,c=o*(a-2)+a,l=o*(a-1),d=o*(3-2*a);return t[0]=e[0]*s+r[0]*c+n[0]*l+i[0]*d,t[1]=e[1]*s+r[1]*c+n[1]*l+i[1]*d,t[2]=e[2]*s+r[2]*c+n[2]*l+i[2]*d,t}function nb(t,e,r,n,i,a){var o=1-a,s=o*o,c=a*a,l=s*o,d=3*a*s,f=3*c*o,u=c*a;return t[0]=e[0]*l+r[0]*d+n[0]*f+i[0]*u,t[1]=e[1]*l+r[1]*d+n[1]*f+i[1]*u,t[2]=e[2]*l+r[2]*d+n[2]*f+i[2]*u,t}function ib(t,e){e=e===void 0?1:e;var r=er()*2*Math.PI,n=er()*2-1,i=Math.sqrt(1-n*n)*e;return t[0]=Math.cos(r)*i,t[1]=Math.sin(r)*i,t[2]=n*e,t}function ab(t,e,r){var n=e[0],i=e[1],a=e[2],o=r[3]*n+r[7]*i+r[11]*a+r[15];return o=o||1,t[0]=(r[0]*n+r[4]*i+r[8]*a+r[12])/o,t[1]=(r[1]*n+r[5]*i+r[9]*a+r[13])/o,t[2]=(r[2]*n+r[6]*i+r[10]*a+r[14])/o,t}function ob(t,e,r){var n=e[0],i=e[1],a=e[2];return t[0]=n*r[0]+i*r[3]+a*r[6],t[1]=n*r[1]+i*r[4]+a*r[7],t[2]=n*r[2]+i*r[5]+a*r[8],t}function sb(t,e,r){var n=r[0],i=r[1],a=r[2],o=r[3],s=e[0],c=e[1],l=e[2],d=i*l-a*c,f=a*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+o*d+i*u-a*f,t[1]=c+o*f+a*d-n*u,t[2]=l+o*u+n*f-i*d,t}function lb(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0],a[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),a[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t}function cb(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),a[1]=i[1],a[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t}function db(t,e,r,n){var i=[],a=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],a[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),a[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),a[2]=i[2],t[0]=a[0]+r[0],t[1]=a[1]+r[1],t[2]=a[2]+r[2],t}function ub(t,e){var r=t[0],n=t[1],i=t[2],a=e[0],o=e[1],s=e[2],c=Math.sqrt((r*r+n*n+i*i)*(a*a+o*o+s*s)),l=c&&rs(t,e)/c;return Math.acos(Math.min(Math.max(l,-1),1))}function fb(t){return t[0]=0,t[1]=0,t[2]=0,t}function hb(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"}function mb(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]}function pb(t,e){var r=t[0],n=t[1],i=t[2],a=e[0],o=e[1],s=e[2];return Math.abs(r-a)<=$*Math.max(1,Math.abs(r),Math.abs(a))&&Math.abs(n-o)<=$*Math.max(1,Math.abs(n),Math.abs(o))&&Math.abs(i-s)<=$*Math.max(1,Math.abs(i),Math.abs(s))}var gb=Yh,yb=$h,bb=qh,xb=Zh,vb=jh,$d=Kh,_b=Qh,Sb=(function(){var t=Yl();return function(e,r,n,i,a,o){var s,c;for(r||(r=3),n||(n=0),i?c=Math.min(i*r+n,e.length):c=e.length,s=n;s<c;s+=r)t[0]=e[s],t[1]=e[s+1],t[2]=e[s+2],a(t,t,o),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2];return e}})();var ga={};Na(ga,{add:()=>Jd,ceil:()=>wb,clone:()=>qd,copy:()=>jd,create:()=>Jh,cross:()=>Pb,dist:()=>Hb,distance:()=>nm,div:()=>Nb,divide:()=>rm,dot:()=>jl,equals:()=>zb,exactEquals:()=>nu,floor:()=>Mb,forEach:()=>Xb,fromValues:()=>Zd,inverse:()=>Cb,len:()=>Gb,length:()=>ql,lerp:()=>ru,max:()=>Eb,min:()=>Ab,mul:()=>Ub,multiply:()=>tm,negate:()=>Rb,normalize:()=>tu,random:()=>Ib,round:()=>Lb,scale:()=>eu,scaleAndAdd:()=>Tb,set:()=>Qd,sqrDist:()=>Vb,sqrLen:()=>Wb,squaredDistance:()=>im,squaredLength:()=>Zl,str:()=>Db,sub:()=>Ob,subtract:()=>em,transformMat4:()=>Bb,transformQuat:()=>Fb,zero:()=>kb});function Jh(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0,t[3]=0),t}function qd(t){var e=new xe(4);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e}function Zd(t,e,r,n){var i=new xe(4);return i[0]=t,i[1]=e,i[2]=r,i[3]=n,i}function jd(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function Qd(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t}function Jd(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t[3]=e[3]+r[3],t}function em(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],t[3]=e[3]-r[3],t}function tm(t,e,r){return t[0]=e[0]*r[0],t[1]=e[1]*r[1],t[2]=e[2]*r[2],t[3]=e[3]*r[3],t}function rm(t,e,r){return t[0]=e[0]/r[0],t[1]=e[1]/r[1],t[2]=e[2]/r[2],t[3]=e[3]/r[3],t}function wb(t,e){return t[0]=Math.ceil(e[0]),t[1]=Math.ceil(e[1]),t[2]=Math.ceil(e[2]),t[3]=Math.ceil(e[3]),t}function Mb(t,e){return t[0]=Math.floor(e[0]),t[1]=Math.floor(e[1]),t[2]=Math.floor(e[2]),t[3]=Math.floor(e[3]),t}function Ab(t,e,r){return t[0]=Math.min(e[0],r[0]),t[1]=Math.min(e[1],r[1]),t[2]=Math.min(e[2],r[2]),t[3]=Math.min(e[3],r[3]),t}function Eb(t,e,r){return t[0]=Math.max(e[0],r[0]),t[1]=Math.max(e[1],r[1]),t[2]=Math.max(e[2],r[2]),t[3]=Math.max(e[3],r[3]),t}function Lb(t,e){return t[0]=tn(e[0]),t[1]=tn(e[1]),t[2]=tn(e[2]),t[3]=tn(e[3]),t}function eu(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t[3]=e[3]*r,t}function Tb(t,e,r,n){return t[0]=e[0]+r[0]*n,t[1]=e[1]+r[1]*n,t[2]=e[2]+r[2]*n,t[3]=e[3]+r[3]*n,t}function nm(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return Math.sqrt(r*r+n*n+i*i+a*a)}function im(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],a=e[3]-t[3];return r*r+n*n+i*i+a*a}function ql(t){var e=t[0],r=t[1],n=t[2],i=t[3];return Math.sqrt(e*e+r*r+n*n+i*i)}function Zl(t){var e=t[0],r=t[1],n=t[2],i=t[3];return e*e+r*r+n*n+i*i}function Rb(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t}function Cb(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t[3]=1/e[3],t}function tu(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a;return o>0&&(o=1/Math.sqrt(o)),t[0]=r*o,t[1]=n*o,t[2]=i*o,t[3]=a*o,t}function jl(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]}function Pb(t,e,r,n){var i=r[0]*n[1]-r[1]*n[0],a=r[0]*n[2]-r[2]*n[0],o=r[0]*n[3]-r[3]*n[0],s=r[1]*n[2]-r[2]*n[1],c=r[1]*n[3]-r[3]*n[1],l=r[2]*n[3]-r[3]*n[2],d=e[0],f=e[1],u=e[2],h=e[3];return t[0]=f*l-u*c+h*s,t[1]=-(d*l)+u*o-h*a,t[2]=d*c-f*o+h*i,t[3]=-(d*s)+f*a-u*i,t}function ru(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3];return t[0]=i+n*(r[0]-i),t[1]=a+n*(r[1]-a),t[2]=o+n*(r[2]-o),t[3]=s+n*(r[3]-s),t}function Ib(t,e){e=e===void 0?1:e;var r,n,i,a,o,s,c;c=er(),r=c*2-1,n=(4*er()-2)*Math.sqrt(c*-c+c),o=r*r+n*n,c=er(),i=c*2-1,a=(4*er()-2)*Math.sqrt(c*-c+c),s=i*i+a*a;var l=Math.sqrt((1-o)/s);return t[0]=e*r,t[1]=e*n,t[2]=e*i*l,t[3]=e*a*l,t}function Bb(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3];return t[0]=r[0]*n+r[4]*i+r[8]*a+r[12]*o,t[1]=r[1]*n+r[5]*i+r[9]*a+r[13]*o,t[2]=r[2]*n+r[6]*i+r[10]*a+r[14]*o,t[3]=r[3]*n+r[7]*i+r[11]*a+r[15]*o,t}function Fb(t,e,r){var n=r[0],i=r[1],a=r[2],o=r[3],s=e[0],c=e[1],l=e[2],d=i*l-a*c,f=a*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+o*d+i*u-a*f,t[1]=c+o*f+a*d-n*u,t[2]=l+o*u+n*f-i*d,t[3]=e[3],t}function kb(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t}function Db(t){return"vec4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}function nu(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]}function zb(t,e){var r=t[0],n=t[1],i=t[2],a=t[3],o=e[0],s=e[1],c=e[2],l=e[3];return Math.abs(r-o)<=$*Math.max(1,Math.abs(r),Math.abs(o))&&Math.abs(n-s)<=$*Math.max(1,Math.abs(n),Math.abs(s))&&Math.abs(i-c)<=$*Math.max(1,Math.abs(i),Math.abs(c))&&Math.abs(a-l)<=$*Math.max(1,Math.abs(a),Math.abs(l))}var Ob=em,Ub=tm,Nb=rm,Hb=nm,Vb=im,Gb=ql,Wb=Zl,Xb=(function(){var t=Jh();return function(e,r,n,i,a,o){var s,c;for(r||(r=4),n||(n=0),i?c=Math.min(i*r+n,e.length):c=e.length,s=n;s<c;s+=r)t[0]=e[s],t[1]=e[s+1],t[2]=e[s+2],t[3]=e[s+3],a(t,t,o),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2],e[s+3]=t[3];return e}})();function iu(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t[3]=1,t}function Kb(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t}function am(t,e,r){r=r*.5;var n=Math.sin(r);return t[0]=n*e[0],t[1]=n*e[1],t[2]=n*e[2],t[3]=Math.cos(r),t}function Yb(t,e){var r=Math.acos(e[3])*2,n=Math.sin(r/2);return n>$?(t[0]=e[0]/n,t[1]=e[1]/n,t[2]=e[2]/n):(t[0]=1,t[1]=0,t[2]=0),r}function $b(t,e){var r=um(t,e);return Math.acos(2*r*r-1)}function om(t,e,r){var n=e[0],i=e[1],a=e[2],o=e[3],s=r[0],c=r[1],l=r[2],d=r[3];return t[0]=n*d+o*s+i*l-a*c,t[1]=i*d+o*c+a*s-n*l,t[2]=a*d+o*l+n*c-i*s,t[3]=o*d-n*s-i*c-a*l,t}function qb(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),c=Math.cos(r);return t[0]=n*c+o*s,t[1]=i*c+a*s,t[2]=a*c-i*s,t[3]=o*c-n*s,t}function Zb(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),c=Math.cos(r);return t[0]=n*c-a*s,t[1]=i*c+o*s,t[2]=a*c+n*s,t[3]=o*c-i*s,t}function jb(t,e,r){r*=.5;var n=e[0],i=e[1],a=e[2],o=e[3],s=Math.sin(r),c=Math.cos(r);return t[0]=n*c+i*s,t[1]=i*c-n*s,t[2]=a*c+o*s,t[3]=o*c-a*s,t}function Qb(t,e){var r=e[0],n=e[1],i=e[2];return t[0]=r,t[1]=n,t[2]=i,t[3]=Math.sqrt(Math.abs(1-r*r-n*n-i*i)),t}function sm(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=Math.sqrt(r*r+n*n+i*i),s=Math.exp(a),c=o>0?s*Math.sin(o)/o:0;return t[0]=r*c,t[1]=n*c,t[2]=i*c,t[3]=s*Math.cos(o),t}function lm(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=Math.sqrt(r*r+n*n+i*i),s=o>0?Math.atan2(o,a)/o:0;return t[0]=r*s,t[1]=n*s,t[2]=i*s,t[3]=.5*Math.log(r*r+n*n+i*i+a*a),t}function Jb(t,e,r){return lm(t,e),dm(t,t,r),sm(t,t),t}function Ql(t,e,r,n){var i=e[0],a=e[1],o=e[2],s=e[3],c=r[0],l=r[1],d=r[2],f=r[3],u,h,m,g,p;return h=i*c+a*l+o*d+s*f,h<0&&(h=-h,c=-c,l=-l,d=-d,f=-f),1-h>$?(u=Math.acos(h),m=Math.sin(u),g=Math.sin((1-n)*u)/m,p=Math.sin(n*u)/m):(g=1-n,p=n),t[0]=g*i+p*c,t[1]=g*a+p*l,t[2]=g*o+p*d,t[3]=g*s+p*f,t}function ex(t){var e=er(),r=er(),n=er(),i=Math.sqrt(1-e),a=Math.sqrt(e);return t[0]=i*Math.sin(2*Math.PI*r),t[1]=i*Math.cos(2*Math.PI*r),t[2]=a*Math.sin(2*Math.PI*n),t[3]=a*Math.cos(2*Math.PI*n),t}function tx(t,e){var r=e[0],n=e[1],i=e[2],a=e[3],o=r*r+n*n+i*i+a*a,s=o?1/o:0;return t[0]=-r*s,t[1]=-n*s,t[2]=-i*s,t[3]=a*s,t}function rx(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t}function cm(t,e){var r=e[0]+e[4]+e[8],n;if(r>0)n=Math.sqrt(r+1),t[3]=.5*n,n=.5/n,t[0]=(e[5]-e[7])*n,t[1]=(e[6]-e[2])*n,t[2]=(e[1]-e[3])*n;else{var i=0;e[4]>e[0]&&(i=1),e[8]>e[i*3+i]&&(i=2);var a=(i+1)%3,o=(i+2)%3;n=Math.sqrt(e[i*3+i]-e[a*3+a]-e[o*3+o]+1),t[i]=.5*n,n=.5/n,t[3]=(e[a*3+o]-e[o*3+a])*n,t[a]=(e[a*3+i]+e[i*3+a])*n,t[o]=(e[o*3+i]+e[i*3+o])*n}return t}function nx(t,e,r,n){var i=arguments.length>4&&arguments[4]!==void 0?arguments[4]:zh,a=Math.PI/360;e*=a,n*=a,r*=a;var o=Math.sin(e),s=Math.cos(e),c=Math.sin(r),l=Math.cos(r),d=Math.sin(n),f=Math.cos(n);switch(i){case"xyz":t[0]=o*l*f+s*c*d,t[1]=s*c*f-o*l*d,t[2]=s*l*d+o*c*f,t[3]=s*l*f-o*c*d;break;case"xzy":t[0]=o*l*f-s*c*d,t[1]=s*c*f-o*l*d,t[2]=s*l*d+o*c*f,t[3]=s*l*f+o*c*d;break;case"yxz":t[0]=o*l*f+s*c*d,t[1]=s*c*f-o*l*d,t[2]=s*l*d-o*c*f,t[3]=s*l*f+o*c*d;break;case"yzx":t[0]=o*l*f+s*c*d,t[1]=s*c*f+o*l*d,t[2]=s*l*d-o*c*f,t[3]=s*l*f-o*c*d;break;case"zxy":t[0]=o*l*f-s*c*d,t[1]=s*c*f+o*l*d,t[2]=s*l*d+o*c*f,t[3]=s*l*f-o*c*d;break;case"zyx":t[0]=o*l*f-s*c*d,t[1]=s*c*f+o*l*d,t[2]=s*l*d-o*c*f,t[3]=s*l*f+o*c*d;break;default:throw new Error("Unknown angle order "+i)}return t}function ix(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}var ax=qd,ox=Zd,sx=jd,lx=Qd,cx=Jd,dx=om,dm=eu,um=jl,ux=ru,fm=ql,fx=fm,hm=Zl,hx=hm,au=tu,mx=nu;function px(t,e){return Math.abs(jl(t,e))>=1-$}var gx=(function(){var t=Yl(),e=$l(1,0,0),r=$l(0,1,0);return function(n,i,a){var o=rs(i,a);return o<-.999999?(ns(t,e,i),$d(t)<1e-6&&ns(t,r,i),Yd(t,t),am(n,t,Math.PI),n):o>.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(ns(t,i,a),n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=1+o,au(n,n))}})(),yx=(function(){var t=iu(),e=iu();return function(r,n,i,a,o,s){return Ql(t,n,o,s),Ql(e,i,a,s),Ql(r,t,e,2*s*(1-s)),r}})(),bx=(function(){var t=Oh();return function(e,r,n,i){return t[0]=n[0],t[3]=n[1],t[6]=n[2],t[1]=i[0],t[4]=i[1],t[7]=i[2],t[2]=-r[0],t[5]=-r[1],t[8]=-r[2],au(e,cm(e,t))}})();var ec=class{constructor(e,r){this._position=R.create();this._angles=R.create();this._bobAngles=R.create();this._bobOffset=R.create();this._kickAngles=R.create();this._rollAngle=0;this._fov=90;this._aspect=1;this._near=.1;this._far=1e3;this._viewMatrix=j.create();this._projectionMatrix=j.create();this._viewProjectionMatrix=j.create();this._dirty=!0;e!==void 0&&r!==void 0&&r>0&&(this._aspect=e/r)}get position(){return this._position}set position(e){R.equals(this._position,e)||(R.copy(this._position,e),this._dirty=!0,this.triggerMoveEvent())}get angles(){return this._angles}set angles(e){R.equals(this._angles,e)||(R.copy(this._angles,e),this._dirty=!0,this.triggerMoveEvent())}get bobAngles(){return this._bobAngles}set bobAngles(e){R.copy(this._bobAngles,e),this._dirty=!0}get kickAngles(){return this._kickAngles}set kickAngles(e){R.copy(this._kickAngles,e),this._dirty=!0}get bobOffset(){return this._bobOffset}set bobOffset(e){R.copy(this._bobOffset,e),this._dirty=!0}get rollAngle(){return this._rollAngle}set rollAngle(e){this._rollAngle=e,this._dirty=!0}get fov(){return this._fov}set fov(e){this._fov=e,this._dirty=!0}get aspect(){return this._aspect}set aspect(e){this._aspect=e,this._dirty=!0}toState(){return{position:R.clone(this._position),angles:R.clone(this._angles),fov:this._fov,aspect:this._aspect,near:this._near,far:this._far}}setPosition(e,r,n){let i=R.fromValues(e,r,n);R.equals(this._position,i)||(R.copy(this._position,i),this._dirty=!0,this.triggerMoveEvent())}setRotation(e,r,n){let i=R.fromValues(e,r,n);R.equals(this._angles,i)||(R.copy(this._angles,i),this._dirty=!0,this.triggerMoveEvent())}setFov(e){this.fov=e}setAspectRatio(e){this.aspect=e}lookAt(e){let r=R.create();if(R.subtract(r,e,this._position),R.length(r)<.001)return;let i=Math.atan2(r[1],r[0])*zc,a=Math.hypot(r[0],r[1]),o=-Math.atan2(r[2],a)*zc;this.setRotation(o,i,0)}triggerMoveEvent(){this.onCameraMove&&this.onCameraMove({position:R.clone(this._position),angles:R.clone(this._angles)})}get viewMatrix(){return this.updateMatrices(),this._viewMatrix}get projectionMatrix(){return this.updateMatrices(),this._projectionMatrix}get viewProjectionMatrix(){return this.updateMatrices(),this._viewProjectionMatrix}getViewmodelProjectionMatrix(e){let r=j.create();return j.perspective(r,e*Pi,this._aspect,this._near,this._far),r}screenToWorldRay(e,r){let n=e*2-1,i=1-r*2,a=R.fromValues(n,i,-1),o=R.fromValues(n,i,1),s=j.create();j.invert(s,this.viewProjectionMatrix);let c=R.create(),l=R.create();R.transformMat4(c,a,s),R.transformMat4(l,o,s);let d=R.create();return R.subtract(d,l,c),R.normalize(d,d),{origin:R.clone(this._position),direction:d}}updateMatrices(){if(!this._dirty)return;j.perspective(this._projectionMatrix,this._fov*Pi,this._aspect,this._near,this._far);let e=j.fromValues(0,0,-1,0,-1,0,0,0,0,1,0,0,0,0,0,1),r=this._angles[0]+this._bobAngles[0]+this._kickAngles[0],n=this._angles[1]+this._bobAngles[1]+this._kickAngles[1],i=this._angles[2]+this._bobAngles[2]+this._kickAngles[2]+this._rollAngle,a=r*Pi,o=n*Pi,s=i*Pi,c=j.create();j.identity(c),j.rotateZ(c,c,-o),j.rotateY(c,c,-a),j.rotateX(c,c,-s);let l=j.create();j.multiply(l,e,c);let d=R.add(R.create(),this._position,this._bobOffset),f=R.negate(R.create(),d),u=R.create();R.transformMat4(u,f,c);let h=R.fromValues(u[1]?-u[1]:0,u[2]||0,u[0]?-u[0]:0);j.copy(this._viewMatrix,l),this._viewMatrix[12]=h[0],this._viewMatrix[13]=h[1],this._viewMatrix[14]=h[2],j.multiply(this._viewProjectionMatrix,this._projectionMatrix,this._viewMatrix),this._dirty=!1}};var xx=[.2,.2,.2],vx={x:0,y:0,z:1},_x=[.8,.8,.8];function ou(t,e,r){return t+(e-t)*r}function ba(t,e,r){return{x:ou(t.x,e.x,r),y:ou(t.y,e.y,r),z:ou(t.z,e.z,r)}}function ya(t){return t<0?0:t>1?1:t}function su(t){let e=[],r=[];for(let n of t.triangles){let i=e.length,[a,o,s]=n.indices,c=t.texCoords[a],l=t.texCoords[o],d=t.texCoords[s];if(!c||!l||!d)throw new Error(`Missing texCoord for triangle in surface ${t.name}`);e.push({vertexIndex:a,texCoord:[c.s,1-c.t]},{vertexIndex:o,texCoord:[l.s,1-l.t]},{vertexIndex:s,texCoord:[d.s,1-d.t]}),r.push(i,i+1,i+2)}return{vertices:e,indices:new Uint16Array(r)}}function Sx(t,e,r){let n=r?.ambient??xx,i=r?.directional??{direction:vx,color:_x},a=Hr(t),o=Hr(i.direction),s=ya(a.x*o.x+a.y*o.y+a.z*o.z),c=n[0]+i.color[0]*s,l=n[1]+i.color[1]*s,d=n[2]+i.color[2]*s;if(r?.dynamicLights){let f=r.modelMatrix?ff(r.modelMatrix,e):e;for(let u of r.dynamicLights){let h=f.x-u.origin.x,m=f.y-u.origin.y,g=f.z-u.origin.z,p=h*h+m*m+g*g,y=u.radius*u.radius;if(p<y&&y>0){let v=1-Math.sqrt(p)/u.radius,x=Math.sqrt(p),b=x>0?ya(-(h*a.x+m*a.y+g*a.z)/x):0,_=ya(v*b);c+=u.color[0]*_,l+=u.color[1]*_,d+=u.color[2]*_}}}return[ya(c),ya(l),ya(d)]}function lu(t,e,r,n){let i=t.vertices[r.frame0],a=t.vertices[r.frame1];if(!i||!a)throw new Error("Requested MD3 frames are out of range");let o=new Float32Array(e.vertices.length*12);return e.vertices.forEach((s,c)=>{let l=i[s.vertexIndex],d=a[s.vertexIndex];if(!l||!d)throw new Error(`Vertex index ${s.vertexIndex} missing for frame`);let f=ba(l.position,d.position,r.lerp),u=Hr(ba(l.normal,d.normal,r.lerp)),h=Sx(u,f,n),m=c*12;o[m]=f.x,o[m+1]=f.y,o[m+2]=f.z,o[m+3]=u.x,o[m+4]=u.y,o[m+5]=u.z,o[m+6]=s.texCoord[0],o[m+7]=s.texCoord[1],o[m+8]=h[0],o[m+9]=h[1],o[m+10]=h[2],o[m+11]=1}),o}function mm(t,e,r){let n=t.tags[0];if(!n)return null;let i=n.findIndex(g=>g.name===r);if(i===-1)return null;let a=t.tags[e.frame0]?.[i],o=t.tags[e.frame1]?.[i];if(!a||!o)throw new Error(`Tag ${r} is missing for one of the interpolated frames`);let s=ba(a.origin,o.origin,e.lerp),c=Hr(ba(a.axis[0],o.axis[0],e.lerp)),l=Hr(ba(a.axis[1],o.axis[1],e.lerp)),d=Hr(ba(a.axis[2],o.axis[2],e.lerp)),f=c,u=Hr({x:l.x-f.x*(f.x*l.x+f.y*l.y+f.z*l.z),y:l.y-f.y*(f.x*l.x+f.y*l.y+f.z*l.z),z:l.z-f.z*(f.x*l.x+f.y*l.y+f.z*l.z)}),h=Hr({x:f.y*u.z-f.z*u.y,y:f.z*u.x-f.x*u.z,z:f.x*u.y-f.y*u.x}),m=[f,u,h];return{origin:s,axis:m,matrix:hf(s,m)}}var cu=`#version 300 es
|
|
480
480
|
precision highp float;
|
|
481
481
|
|
|
482
482
|
layout(location = 0) in vec3 a_position;
|
|
@@ -551,7 +551,7 @@ void main() {
|
|
|
551
551
|
}
|
|
552
552
|
|
|
553
553
|
o_color = finalColor;
|
|
554
|
-
}`,is=class{constructor(e,r,n,i){this.gl=e,this.geometry=su(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Qe(e,e.STATIC_DRAW),this.vertexArray=new Ee(e),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:48,offset:0},{index:1,size:3,type:e.FLOAT,stride:48,offset:12},{index:2,size:2,type:e.FLOAT,stride:48,offset:24},{index:3,size:4,type:e.FLOAT,stride:48,offset:32}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,e.STATIC_DRAW),this.update(r,n,i)}update(e,r,n){let i=lu(e,this.geometry,r,n);this.vertexBuffer.upload(i,this.gl.STATIC_DRAW)}bind(){this.vertexArray.bind(),this.indexBuffer.bind()}dispose(){this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose(),this.wireframeIndexBuffer?.dispose()}},xa=class{constructor(e,r,n,i){this.surfaces=new Map;this.gl=e,this.model=r,this.blend=n,this.lighting=i,r.surfaces.forEach(a=>{this.surfaces.set(a.name,new is(e,a,n,i))})}update(e,r){this.blend=e,this.lighting=r??this.lighting;for(let n of this.model.surfaces)this.surfaces.get(n.name)?.update(n,e,this.lighting)}dispose(){for(let e of this.surfaces.values())e.dispose();this.surfaces.clear()}},va=class{constructor(e){this.gl=e,this.program=le.create(e,{vertex:cu,fragment:du},{a_position:0,a_normal:1,a_texCoord:2,a_color:3}),this.uniformMvp=this.program.getUniformLocation("u_modelViewProjection"),this.uniformTint=this.program.getUniformLocation("u_tint"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformRenderMode=this.program.getUniformLocation("u_renderMode"),this.uniformSolidColor=this.program.getUniformLocation("u_solidColor"),this.uniformBrightness=this.program.getUniformLocation("u_brightness"),this.uniformGamma=this.program.getUniformLocation("u_gamma"),this.uniformFullbright=this.program.getUniformLocation("u_fullbright"),this.uniformGlobalAmbient=this.program.getUniformLocation("u_globalAmbient")}get shaderSize(){return this.program.sourceSize}bind(e,r=[1,1,1,1],n=0){this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,e),this.gl.uniform4fv(this.uniformTint,new Float32Array(r)),this.gl.uniform1i(this.uniformDiffuse,n),this.gl.uniform1i(this.uniformRenderMode,0),this.gl.uniform4f(this.uniformSolidColor,1,1,1,1)}drawSurface(e,r){let n=r?.diffuseSampler??0,i=r?.tint??[1,1,1,1],a=r?.renderMode,o=r?.brightness??1,s=r?.gamma??1,c=r?.fullbright??!1,l=r?.globalAmbient??0;this.gl.uniform4fv(this.uniformTint,new Float32Array(i)),this.gl.uniform1i(this.uniformDiffuse,n);let d=0,f=[1,1,1,1];if(a&&(a.mode==="solid"||a.mode==="wireframe"?d=1:a.mode==="solid-faceted"&&(d=2),a.color&&(f=[...a.color])),this.gl.uniform1i(this.uniformRenderMode,d),this.gl.uniform4f(this.uniformSolidColor,f[0],f[1],f[2],f[3]),this.gl.uniform1f(this.uniformBrightness,o),this.gl.uniform1f(this.uniformGamma,s),this.gl.uniform1i(this.uniformFullbright,c?1:0),this.gl.uniform1f(this.uniformGlobalAmbient,l),e.vertexArray.bind(),a&&a.mode==="wireframe"){if(!e.wireframeIndexBuffer){e.wireframeIndexBuffer=new Qe(this.gl,this.gl.STATIC_DRAW);let u=ua(e.geometry.indices);e.wireframeIndexBuffer.upload(u),e.wireframeIndexCount=u.length}e.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,e.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else e.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,e.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var wx=[1,1,1,1],_a=class{constructor(e,r){this.maxParticles=e,this.rng=r,this.alive=new Uint8Array(e),this.positionX=new Float32Array(e),this.positionY=new Float32Array(e),this.positionZ=new Float32Array(e),this.velocityX=new Float32Array(e),this.velocityY=new Float32Array(e),this.velocityZ=new Float32Array(e),this.colorR=new Float32Array(e),this.colorG=new Float32Array(e),this.colorB=new Float32Array(e),this.colorA=new Float32Array(e),this.size=new Float32Array(e),this.lifetime=new Float32Array(e),this.remaining=new Float32Array(e),this.gravity=new Float32Array(e),this.damping=new Float32Array(e),this.bounce=new Float32Array(e),this.fade=new Uint8Array(e),this.blendMode=new Uint8Array(e),this.textureIndex=new Int16Array(e)}spawn(e){let r=this.findFreeSlot();if(r===-1)return null;let n=e.color??wx,i=e.velocity??{x:0,y:0,z:0};return this.alive[r]=1,this.positionX[r]=e.position.x,this.positionY[r]=e.position.y,this.positionZ[r]=e.position.z,this.velocityX[r]=i.x,this.velocityY[r]=i.y,this.velocityZ[r]=i.z,this.colorR[r]=n[0],this.colorG[r]=n[1],this.colorB[r]=n[2],this.colorA[r]=n[3],this.size[r]=e.size??2.5,this.lifetime[r]=e.lifetime,this.remaining[r]=e.lifetime,this.gravity[r]=e.gravity??800,this.damping[r]=e.damping??0,this.bounce[r]=e.bounce??.25,this.fade[r]=e.fade?1:0,this.blendMode[r]=e.blendMode==="additive"?1:0,this.textureIndex[r]=e.textureIndex??0,r}update(e,r={}){let n=r.floorZ??-1/0;for(let i=0;i<this.maxParticles;i+=1){if(!this.alive[i])continue;if(this.remaining[i]-=e,this.remaining[i]<=0){this.alive[i]=0;continue}let a=Math.max(0,1-this.damping[i]*e);this.velocityX[i]*=a,this.velocityY[i]*=a,this.velocityZ[i]=this.velocityZ[i]*a-this.gravity[i]*e,this.positionX[i]+=this.velocityX[i]*e,this.positionY[i]+=this.velocityY[i]*e,this.positionZ[i]+=this.velocityZ[i]*e,this.positionZ[i]<n&&(this.positionZ[i]=n,this.velocityZ[i]=-this.velocityZ[i]*this.bounce[i],this.velocityX[i]*=.7,this.velocityY[i]*=.7)}}killAll(){this.alive.fill(0)}aliveCount(){let e=0;for(let r=0;r<this.maxParticles;r+=1)this.alive[r]&&(e+=1);return e}getState(e){return{alive:this.alive[e]===1,position:{x:this.positionX[e],y:this.positionY[e],z:this.positionZ[e]},velocity:{x:this.velocityX[e],y:this.velocityY[e],z:this.velocityZ[e]},remaining:this.remaining[e],color:[this.colorR[e],this.colorG[e],this.colorB[e],this.colorA[e]],size:this.size[e],blendMode:this.blendMode[e]===1?"additive":"alpha",textureIndex:this.textureIndex[e]}}buildMesh(e,r){let n=[],i=[],a=[],o=s=>{let c=i.length,l=0;for(let d=0;d<this.maxParticles;d+=1){if(!this.alive[d]||(s==="additive"?1:0)!==this.blendMode[d])continue;l+=1;let f=n.length/9,u=this.size[d]*.5,h=this.fade[d]?Math.max(this.remaining[d]/this.lifetime[d],0):1,m=this.blendMode[d]===1?1.2:1,g=this.colorR[d]*m,p=this.colorG[d]*m,y=this.colorB[d]*m,v=this.colorA[d]*h,x=this.positionX[d],b=this.positionY[d],_=this.positionZ[d],w=e.x*u,S=e.y*u,E=e.z*u,L=r.x*u,M=r.y*u,
|
|
554
|
+
}`,is=class{constructor(e,r,n,i){this.gl=e,this.geometry=su(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Qe(e,e.STATIC_DRAW),this.vertexArray=new Ee(e),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:48,offset:0},{index:1,size:3,type:e.FLOAT,stride:48,offset:12},{index:2,size:2,type:e.FLOAT,stride:48,offset:24},{index:3,size:4,type:e.FLOAT,stride:48,offset:32}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,e.STATIC_DRAW),this.update(r,n,i)}update(e,r,n){let i=lu(e,this.geometry,r,n);this.vertexBuffer.upload(i,this.gl.STATIC_DRAW)}bind(){this.vertexArray.bind(),this.indexBuffer.bind()}dispose(){this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose(),this.wireframeIndexBuffer?.dispose()}},xa=class{constructor(e,r,n,i){this.surfaces=new Map;this.gl=e,this.model=r,this.blend=n,this.lighting=i,r.surfaces.forEach(a=>{this.surfaces.set(a.name,new is(e,a,n,i))})}update(e,r){this.blend=e,this.lighting=r??this.lighting;for(let n of this.model.surfaces)this.surfaces.get(n.name)?.update(n,e,this.lighting)}dispose(){for(let e of this.surfaces.values())e.dispose();this.surfaces.clear()}},va=class{constructor(e){this.gl=e,this.program=le.create(e,{vertex:cu,fragment:du},{a_position:0,a_normal:1,a_texCoord:2,a_color:3}),this.uniformMvp=this.program.getUniformLocation("u_modelViewProjection"),this.uniformTint=this.program.getUniformLocation("u_tint"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformRenderMode=this.program.getUniformLocation("u_renderMode"),this.uniformSolidColor=this.program.getUniformLocation("u_solidColor"),this.uniformBrightness=this.program.getUniformLocation("u_brightness"),this.uniformGamma=this.program.getUniformLocation("u_gamma"),this.uniformFullbright=this.program.getUniformLocation("u_fullbright"),this.uniformGlobalAmbient=this.program.getUniformLocation("u_globalAmbient")}get shaderSize(){return this.program.sourceSize}bind(e,r=[1,1,1,1],n=0){this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,e),this.gl.uniform4fv(this.uniformTint,new Float32Array(r)),this.gl.uniform1i(this.uniformDiffuse,n),this.gl.uniform1i(this.uniformRenderMode,0),this.gl.uniform4f(this.uniformSolidColor,1,1,1,1)}drawSurface(e,r){let n=r?.diffuseSampler??0,i=r?.tint??[1,1,1,1],a=r?.renderMode,o=r?.brightness??1,s=r?.gamma??1,c=r?.fullbright??!1,l=r?.globalAmbient??0;this.gl.uniform4fv(this.uniformTint,new Float32Array(i)),this.gl.uniform1i(this.uniformDiffuse,n);let d=0,f=[1,1,1,1];if(a&&(a.mode==="solid"||a.mode==="wireframe"?d=1:a.mode==="solid-faceted"&&(d=2),a.color&&(f=[...a.color])),this.gl.uniform1i(this.uniformRenderMode,d),this.gl.uniform4f(this.uniformSolidColor,f[0],f[1],f[2],f[3]),this.gl.uniform1f(this.uniformBrightness,o),this.gl.uniform1f(this.uniformGamma,s),this.gl.uniform1i(this.uniformFullbright,c?1:0),this.gl.uniform1f(this.uniformGlobalAmbient,l),e.vertexArray.bind(),a&&a.mode==="wireframe"){if(!e.wireframeIndexBuffer){e.wireframeIndexBuffer=new Qe(this.gl,this.gl.STATIC_DRAW);let u=ua(e.geometry.indices);e.wireframeIndexBuffer.upload(u),e.wireframeIndexCount=u.length}e.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,e.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else e.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,e.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var wx=[1,1,1,1],_a=class{constructor(e,r){this.maxParticles=e,this.rng=r,this.alive=new Uint8Array(e),this.positionX=new Float32Array(e),this.positionY=new Float32Array(e),this.positionZ=new Float32Array(e),this.velocityX=new Float32Array(e),this.velocityY=new Float32Array(e),this.velocityZ=new Float32Array(e),this.colorR=new Float32Array(e),this.colorG=new Float32Array(e),this.colorB=new Float32Array(e),this.colorA=new Float32Array(e),this.size=new Float32Array(e),this.lifetime=new Float32Array(e),this.remaining=new Float32Array(e),this.gravity=new Float32Array(e),this.damping=new Float32Array(e),this.bounce=new Float32Array(e),this.fade=new Uint8Array(e),this.blendMode=new Uint8Array(e),this.textureIndex=new Int16Array(e)}spawn(e){let r=this.findFreeSlot();if(r===-1)return null;let n=e.color??wx,i=e.velocity??{x:0,y:0,z:0};return this.alive[r]=1,this.positionX[r]=e.position.x,this.positionY[r]=e.position.y,this.positionZ[r]=e.position.z,this.velocityX[r]=i.x,this.velocityY[r]=i.y,this.velocityZ[r]=i.z,this.colorR[r]=n[0],this.colorG[r]=n[1],this.colorB[r]=n[2],this.colorA[r]=n[3],this.size[r]=e.size??2.5,this.lifetime[r]=e.lifetime,this.remaining[r]=e.lifetime,this.gravity[r]=e.gravity??800,this.damping[r]=e.damping??0,this.bounce[r]=e.bounce??.25,this.fade[r]=e.fade?1:0,this.blendMode[r]=e.blendMode==="additive"?1:0,this.textureIndex[r]=e.textureIndex??0,r}update(e,r={}){let n=r.floorZ??-1/0;for(let i=0;i<this.maxParticles;i+=1){if(!this.alive[i])continue;if(this.remaining[i]-=e,this.remaining[i]<=0){this.alive[i]=0;continue}let a=Math.max(0,1-this.damping[i]*e);this.velocityX[i]*=a,this.velocityY[i]*=a,this.velocityZ[i]=this.velocityZ[i]*a-this.gravity[i]*e,this.positionX[i]+=this.velocityX[i]*e,this.positionY[i]+=this.velocityY[i]*e,this.positionZ[i]+=this.velocityZ[i]*e,this.positionZ[i]<n&&(this.positionZ[i]=n,this.velocityZ[i]=-this.velocityZ[i]*this.bounce[i],this.velocityX[i]*=.7,this.velocityY[i]*=.7)}}killAll(){this.alive.fill(0)}aliveCount(){let e=0;for(let r=0;r<this.maxParticles;r+=1)this.alive[r]&&(e+=1);return e}getState(e){return{alive:this.alive[e]===1,position:{x:this.positionX[e],y:this.positionY[e],z:this.positionZ[e]},velocity:{x:this.velocityX[e],y:this.velocityY[e],z:this.velocityZ[e]},remaining:this.remaining[e],color:[this.colorR[e],this.colorG[e],this.colorB[e],this.colorA[e]],size:this.size[e],blendMode:this.blendMode[e]===1?"additive":"alpha",textureIndex:this.textureIndex[e]}}buildMesh(e,r){let n=[],i=[],a=[],o=s=>{let c=i.length,l=0;for(let d=0;d<this.maxParticles;d+=1){if(!this.alive[d]||(s==="additive"?1:0)!==this.blendMode[d])continue;l+=1;let f=n.length/9,u=this.size[d]*.5,h=this.fade[d]?Math.max(this.remaining[d]/this.lifetime[d],0):1,m=this.blendMode[d]===1?1.2:1,g=this.colorR[d]*m,p=this.colorG[d]*m,y=this.colorB[d]*m,v=this.colorA[d]*h,x=this.positionX[d],b=this.positionY[d],_=this.positionZ[d],w=e.x*u,S=e.y*u,E=e.z*u,L=r.x*u,M=r.y*u,C=r.z*u,I=[{x:x-w-L,y:b-S-M,z:_-E-C},{x:x+w-L,y:b+S-M,z:_+E-C},{x:x-w+L,y:b-S+M,z:_-E+C},{x:x+w+L,y:b+S+M,z:_+E+C}],B=[[0,1],[1,1],[0,0],[1,0]];I.forEach((F,U)=>{n.push(F.x,F.y,F.z,B[U]?.[0]??0,B[U]?.[1]??0,g,p,y,v)}),i.push(f,f+1,f+2,f+2,f+1,f+3)}l>0&&a.push({blendMode:s,start:c,count:i.length-c})};return o("alpha"),o("additive"),{vertices:new Float32Array(n),indices:new Uint16Array(i),batches:a}}findFreeSlot(){for(let e=0;e<this.maxParticles;e+=1)if(!this.alive[e])return e;return-1}},uu=`#version 300 es
|
|
555
555
|
precision highp float;
|
|
556
556
|
|
|
557
557
|
layout(location = 0) in vec3 a_position;
|
|
@@ -681,7 +681,7 @@ void main() {
|
|
|
681
681
|
vec4 color = texture(u_texture, v_texCoord);
|
|
682
682
|
o_color = vec4(color.rgb * u_intensity, 1.0);
|
|
683
683
|
}
|
|
684
|
-
`,rc=class{constructor(e){this.width=0;this.height=0;this.gl=e,this.extractProgram=le.create(e,{vertex:hu,fragment:Ex},{a_position:0}),this.blurProgram=le.create(e,{vertex:hu,fragment:Lx},{a_position:0}),this.compositeProgram=le.create(e,{vertex:hu,fragment:Tx},{a_position:0}),this.framebuffer1=new gi(e),this.framebuffer2=new gi(e),this.texture1=new Je(e),this.texture2=new Je(e),this.texture1.setParameters({minFilter:e.LINEAR,magFilter:e.LINEAR,wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE}),this.texture2.setParameters({minFilter:e.LINEAR,magFilter:e.LINEAR,wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE}),this.vao=e.createVertexArray(),e.bindVertexArray(this.vao);let r=new Float32Array([-1,-1,1,-1,-1,1,1,1]),n=e.createBuffer();e.bindBuffer(e.ARRAY_BUFFER,n),e.bufferData(e.ARRAY_BUFFER,r,e.STATIC_DRAW),e.enableVertexAttribArray(0),e.vertexAttribPointer(0,2,e.FLOAT,!1,0,0),e.bindVertexArray(null)}resize(e,r){if(this.width!==e||this.height!==r){this.width=e,this.height=r;let n=Math.floor(e/2)||1,i=Math.floor(r/2)||1;this.texture1.upload(n,i,null),this.framebuffer1.attachTexture2D(this.gl.COLOR_ATTACHMENT0,this.texture1),this.texture2.upload(n,i,null),this.framebuffer2.attachTexture2D(this.gl.COLOR_ATTACHMENT0,this.texture2)}}render(e,r=.5){let n=this.gl,i=Math.floor(this.width/2)||1,a=Math.floor(this.height/2)||1;n.bindVertexArray(this.vao),this.framebuffer1.bind(),n.viewport(0,0,i,a),n.clear(n.COLOR_BUFFER_BIT),this.extractProgram.use(),n.activeTexture(n.TEXTURE0),n.bindTexture(n.TEXTURE_2D,e.texture),n.uniform1i(this.extractProgram.getUniformLocation("u_texture"),0),n.uniform1f(this.extractProgram.getUniformLocation("u_threshold"),.7),n.drawArrays(n.TRIANGLE_STRIP,0,4),this.blurProgram.use(),n.uniform1fv(this.blurProgram.getUniformLocation("u_weight"),[.227027,.1945946,.1216216,.054054,.016216]);let o=this.blurProgram.getUniformLocation("u_horizontal"),s=this.blurProgram.getUniformLocation("u_texture"),c=4,l=!0,d=!0;for(let f=0;f<c;f++)this.framebuffer2.bind(),l?(this.framebuffer2.bind(),n.bindTexture(n.TEXTURE_2D,this.texture1.texture)):(this.framebuffer1.bind(),n.bindTexture(n.TEXTURE_2D,this.texture2.texture)),n.uniform1i(o,l?1:0),n.uniform1i(s,0),n.drawArrays(n.TRIANGLE_STRIP,0,4),l=!l;n.bindFramebuffer(n.FRAMEBUFFER,null),n.viewport(0,0,this.width,this.height),n.enable(n.BLEND),n.blendFunc(n.ONE,n.ONE),n.disable(n.DEPTH_TEST),this.compositeProgram.use(),n.activeTexture(n.TEXTURE0),n.bindTexture(n.TEXTURE_2D,this.texture1.texture),n.uniform1i(this.compositeProgram.getUniformLocation("u_texture"),0),n.uniform1f(this.compositeProgram.getUniformLocation("u_intensity"),r),n.drawArrays(n.TRIANGLE_STRIP,0,4),n.blendFunc(n.SRC_ALPHA,n.ONE_MINUS_SRC_ALPHA),n.enable(n.DEPTH_TEST),n.bindVertexArray(null)}dispose(){this.extractProgram.dispose(),this.blurProgram.dispose(),this.compositeProgram.dispose(),this.framebuffer1.dispose(),this.framebuffer2.dispose(),this.texture1.dispose(),this.texture2.dispose(),this.gl.deleteVertexArray(this.vao)}};var Rx={gatherVisibleFaces:xi,extractFrustumPlanes:kn,computeSkyScroll:Kl,removeViewTranslation:Xl};function Cx(t,e,r,n,i){if(!n)return;let a=i.removeViewTranslation(e.viewMatrix),o=j.create();j.multiply(o,e.projectionMatrix,a);let s=i.computeSkyScroll(r,n.scrollSpeeds??[.01,.02]);t.bind({viewProjection:o,scroll:s,textureUnit:n.textureUnit??0}),t.draw(),t.gl.depthMask(!0)}function Px(t){return[...t].sort((e,r)=>r.sortKey-e.sortKey)}function Ix(t){return[...t].sort((e,r)=>e.sortKey-r.sortKey)}function Bx(t,e,r){let n=e?.materials?.getMaterial(t.texture),i;if(n){let s=n.texture;s&&(i=s)}i||(i=e?.textures?.get(t.texture));let a=t.lightmap?.atlasIndex,o=a!==void 0?e?.lightmaps?.[a]?.texture:void 0;return{diffuse:i,lightmap:o,refraction:r}}function Lm(t,e,r,n){let i=n.diffuse;i&&r.diffuse!==i&&(i.bind(0),r.diffuse=i);let a=n.lightmap;a&&r.lightmap!==a&&(a.bind(1),r.lightmap=a),a||(r.lightmap=void 0);let o=n.refraction,s;return o&&t.surfaceFlags&Wa?(r.refraction!==o&&(o.bind(2),r.refraction=o),s=2):r.refraction=void 0,{diffuse:0,lightmap:a?1:void 0,refraction:s}}function Fx(t,e,r,n){if(!r)return!1;let i=r.fov?e.getViewmodelProjectionMatrix(r.fov):e.projectionMatrix,a=n(e.viewMatrix),o=j.create();return j.multiply(o,i,a),r.depthRange&&t.depthRange(r.depthRange[0],r.depthRange[1]),r.draw(new Float32Array(o)),r.depthRange&&t.depthRange(0,1),!0}function kx(t,e){if(!t)return 1;let r=Math.floor(e*10)%t.length;return(t.charCodeAt(r)-97)/12}var Tm=(t,e,r,n=Rx)=>{let i=new tc(t),a=new rc(t),o=0,s,c=0,l=0,d=(u,h)=>((!s||c!==u||l!==h)&&(s=new Je(t),s.upload(u,h,null),s.setParameters({minFilter:t.LINEAR,magFilter:t.LINEAR,wrapS:t.CLAMP_TO_EDGE,wrapT:t.CLAMP_TO_EDGE}),c=u,l=h),s);return{renderFrame:u=>{let h=performance.now(),m=o>0?1e3/(h-o):0;o=h;let g={batches:0,facesDrawn:0,drawCalls:0,skyDrawn:!1,viewModelDrawn:!1,fps:Math.round(m),vertexCount:0},{camera:p,world:y,sky:v,clearColor:x=[0,0,0,1],timeSeconds:b=0,viewModel:_,dlights:w,renderMode:S,disableLightmaps:E,lightmapOnly:L,brightness:M,gamma:
|
|
684
|
+
`,rc=class{constructor(e){this.width=0;this.height=0;this.gl=e,this.extractProgram=le.create(e,{vertex:hu,fragment:Ex},{a_position:0}),this.blurProgram=le.create(e,{vertex:hu,fragment:Lx},{a_position:0}),this.compositeProgram=le.create(e,{vertex:hu,fragment:Tx},{a_position:0}),this.framebuffer1=new gi(e),this.framebuffer2=new gi(e),this.texture1=new Je(e),this.texture2=new Je(e),this.texture1.setParameters({minFilter:e.LINEAR,magFilter:e.LINEAR,wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE}),this.texture2.setParameters({minFilter:e.LINEAR,magFilter:e.LINEAR,wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE}),this.vao=e.createVertexArray(),e.bindVertexArray(this.vao);let r=new Float32Array([-1,-1,1,-1,-1,1,1,1]),n=e.createBuffer();e.bindBuffer(e.ARRAY_BUFFER,n),e.bufferData(e.ARRAY_BUFFER,r,e.STATIC_DRAW),e.enableVertexAttribArray(0),e.vertexAttribPointer(0,2,e.FLOAT,!1,0,0),e.bindVertexArray(null)}resize(e,r){if(this.width!==e||this.height!==r){this.width=e,this.height=r;let n=Math.floor(e/2)||1,i=Math.floor(r/2)||1;this.texture1.upload(n,i,null),this.framebuffer1.attachTexture2D(this.gl.COLOR_ATTACHMENT0,this.texture1),this.texture2.upload(n,i,null),this.framebuffer2.attachTexture2D(this.gl.COLOR_ATTACHMENT0,this.texture2)}}render(e,r=.5){let n=this.gl,i=Math.floor(this.width/2)||1,a=Math.floor(this.height/2)||1;n.bindVertexArray(this.vao),this.framebuffer1.bind(),n.viewport(0,0,i,a),n.clear(n.COLOR_BUFFER_BIT),this.extractProgram.use(),n.activeTexture(n.TEXTURE0),n.bindTexture(n.TEXTURE_2D,e.texture),n.uniform1i(this.extractProgram.getUniformLocation("u_texture"),0),n.uniform1f(this.extractProgram.getUniformLocation("u_threshold"),.7),n.drawArrays(n.TRIANGLE_STRIP,0,4),this.blurProgram.use(),n.uniform1fv(this.blurProgram.getUniformLocation("u_weight"),[.227027,.1945946,.1216216,.054054,.016216]);let o=this.blurProgram.getUniformLocation("u_horizontal"),s=this.blurProgram.getUniformLocation("u_texture"),c=4,l=!0,d=!0;for(let f=0;f<c;f++)this.framebuffer2.bind(),l?(this.framebuffer2.bind(),n.bindTexture(n.TEXTURE_2D,this.texture1.texture)):(this.framebuffer1.bind(),n.bindTexture(n.TEXTURE_2D,this.texture2.texture)),n.uniform1i(o,l?1:0),n.uniform1i(s,0),n.drawArrays(n.TRIANGLE_STRIP,0,4),l=!l;n.bindFramebuffer(n.FRAMEBUFFER,null),n.viewport(0,0,this.width,this.height),n.enable(n.BLEND),n.blendFunc(n.ONE,n.ONE),n.disable(n.DEPTH_TEST),this.compositeProgram.use(),n.activeTexture(n.TEXTURE0),n.bindTexture(n.TEXTURE_2D,this.texture1.texture),n.uniform1i(this.compositeProgram.getUniformLocation("u_texture"),0),n.uniform1f(this.compositeProgram.getUniformLocation("u_intensity"),r),n.drawArrays(n.TRIANGLE_STRIP,0,4),n.blendFunc(n.SRC_ALPHA,n.ONE_MINUS_SRC_ALPHA),n.enable(n.DEPTH_TEST),n.bindVertexArray(null)}dispose(){this.extractProgram.dispose(),this.blurProgram.dispose(),this.compositeProgram.dispose(),this.framebuffer1.dispose(),this.framebuffer2.dispose(),this.texture1.dispose(),this.texture2.dispose(),this.gl.deleteVertexArray(this.vao)}};var Rx={gatherVisibleFaces:xi,extractFrustumPlanes:kn,computeSkyScroll:Kl,removeViewTranslation:Xl};function Cx(t,e,r,n,i){if(!n)return;let a=i.removeViewTranslation(e.viewMatrix),o=j.create();j.multiply(o,e.projectionMatrix,a);let s=i.computeSkyScroll(r,n.scrollSpeeds??[.01,.02]);t.bind({viewProjection:o,scroll:s,textureUnit:n.textureUnit??0}),t.draw(),t.gl.depthMask(!0)}function Px(t){return[...t].sort((e,r)=>r.sortKey-e.sortKey)}function Ix(t){return[...t].sort((e,r)=>e.sortKey-r.sortKey)}function Bx(t,e,r){let n=e?.materials?.getMaterial(t.texture),i;if(n){let s=n.texture;s&&(i=s)}i||(i=e?.textures?.get(t.texture));let a=t.lightmap?.atlasIndex,o=a!==void 0?e?.lightmaps?.[a]?.texture:void 0;return{diffuse:i,lightmap:o,refraction:r}}function Lm(t,e,r,n){let i=n.diffuse;i&&r.diffuse!==i&&(i.bind(0),r.diffuse=i);let a=n.lightmap;a&&r.lightmap!==a&&(a.bind(1),r.lightmap=a),a||(r.lightmap=void 0);let o=n.refraction,s;return o&&t.surfaceFlags&Wa?(r.refraction!==o&&(o.bind(2),r.refraction=o),s=2):r.refraction=void 0,{diffuse:0,lightmap:a?1:void 0,refraction:s}}function Fx(t,e,r,n){if(!r)return!1;let i=r.fov?e.getViewmodelProjectionMatrix(r.fov):e.projectionMatrix,a=n(e.viewMatrix),o=j.create();return j.multiply(o,i,a),r.depthRange&&t.depthRange(r.depthRange[0],r.depthRange[1]),r.draw(new Float32Array(o)),r.depthRange&&t.depthRange(0,1),!0}function kx(t,e){if(!t)return 1;let r=Math.floor(e*10)%t.length;return(t.charCodeAt(r)-97)/12}var Tm=(t,e,r,n=Rx)=>{let i=new tc(t),a=new rc(t),o=0,s,c=0,l=0,d=(u,h)=>((!s||c!==u||l!==h)&&(s=new Je(t),s.upload(u,h,null),s.setParameters({minFilter:t.LINEAR,magFilter:t.LINEAR,wrapS:t.CLAMP_TO_EDGE,wrapT:t.CLAMP_TO_EDGE}),c=u,l=h),s);return{renderFrame:u=>{let h=performance.now(),m=o>0?1e3/(h-o):0;o=h;let g={batches:0,facesDrawn:0,drawCalls:0,skyDrawn:!1,viewModelDrawn:!1,fps:Math.round(m),vertexCount:0},{camera:p,world:y,sky:v,clearColor:x=[0,0,0,1],timeSeconds:b=0,viewModel:_,dlights:w,renderMode:S,disableLightmaps:E,lightmapOnly:L,brightness:M,gamma:C,fullbright:I,ambient:B,lightStyleOverrides:F,waterTint:U,underwaterWarp:ce,bloom:Nt,bloomIntensity:Ct,portalState:zr}=u,on=new Float32Array(p.viewProjectionMatrix);if(t.clearColor(x[0],x[1],x[2],x[3]),t.clear(t.COLOR_BUFFER_BIT|t.DEPTH_BUFFER_BIT),Cx(r,p,b,v,n),g.skyDrawn=!!v,y){y.materials?.update(b);let dt=n.extractFrustumPlanes(Array.from(on)),et={x:p.position[0]??0,y:p.position[1]??0,z:p.position[2]??0},Ht=n.gatherVisibleFaces(y.map,et,dt,zr),Gn=[],sn=[];for(let oe of Ht){let Ce=y.surfaces[oe.faceIndex];if(!Ce)continue;(Ce.surfaceFlags&(zs|Os|Wa))!==0?sn.push(oe):Gn.push(oe)}let Or=Px(Gn),Ur=y.lightStyles||[];if(F&&F.size>0){let oe=[...y.lightStyles||[]];for(let[Ce,Re]of F){for(;oe.length<=Ce;)oe.push(1);oe[Ce]=kx(Re,b)}Ur=oe}let Nr=(oe,Ce)=>{let Re,ir,Vt={},ln=Ce?s:void 0;for(let{faceIndex:Ti}of oe){let Gt=y.surfaces[Ti];if(!Gt||(Gt.surfaceFlags&Ds)!==0)continue;let Rc=y.map.faces[Ti]?.styles,Fa=y.materials?.getMaterial(Gt.texture),Wn=Bx(Gt,y,ln),ka=S;S&&!S.applyToAll&&Wn.diffuse?ka=void 0:S&&!S.applyToAll&&!Wn.diffuse&&(ka=S);let Da=Wn.lightmap;E&&(Da=void 0);let Ri={diffuse:Wn.diffuse,lightmap:Da,surfaceFlags:Gt.surfaceFlags,styleKey:Rc?.join(",")??""};if(Re&&Re.diffuse===Ri.diffuse&&Re.lightmap===Ri.lightmap&&Re.surfaceFlags===Ri.surfaceFlags&&Re.styleKey===Ri.styleKey){let Ls={...Wn,lightmap:Da};Lm(Gt,y,Vt,Ls),ir&&es(t,ir)}else{g.batches+=1,Vt.diffuse=void 0,Vt.lightmap=void 0,Vt.refraction=void 0;let Ls={...Wn,lightmap:Da},Ts=Lm(Gt,y,Vt,Ls),Ju=Fa?Fa.scrollOffset:void 0,ef=Fa?Fa.warp:void 0;ir=e.bind({modelViewProjection:on,styleIndices:Rc,styleValues:Ur,surfaceFlags:Gt.surfaceFlags,timeSeconds:b,diffuseSampler:Ts.diffuse??0,lightmapSampler:Ts.lightmap,refractionSampler:Ts.refraction,texScroll:Ju,warp:ef,dlights:w,renderMode:ka,lightmapOnly:L,brightness:M,gamma:C,fullbright:I,ambient:B}),es(t,ir),Re=Ri}e.draw(Gt,ka),g.facesDrawn+=1,g.drawCalls+=1,g.vertexCount+=Gt.vertexCount}};if(Nr(Or,!1),sn.length>0){let oe=t.canvas.width,Ce=t.canvas.height;d(oe,Ce).bind(2),t.copyTexImage2D(t.TEXTURE_2D,0,t.RGBA,0,0,oe,Ce,0)}let k=Ix(sn);Nr(k,!0)}if(Fx(t,p,_,n.removeViewTranslation)&&(g.viewModelDrawn=!0),ce){let dt=t.canvas.width,et=t.canvas.height,Ht=d(dt,et);Ht.bind(0),t.copyTexImage2D(t.TEXTURE_2D,0,t.RGBA,0,0,dt,et,0),t.disable(t.DEPTH_TEST),t.depthMask(!1),i.render(Ht.texture,b),t.enable(t.DEPTH_TEST),t.depthMask(!0)}if(Nt){let dt=t.canvas.width,et=t.canvas.height;a.resize(dt,et);let Ht=d(dt,et);Ht.bind(0),t.copyTexImage2D(t.TEXTURE_2D,0,t.RGBA,0,0,dt,et,0),a.render(Ht,Ct??.5)}return g}}};var Dx=`#version 300 es
|
|
685
685
|
precision highp float;
|
|
686
686
|
|
|
687
687
|
layout(location = 0) in vec2 a_position;
|
|
@@ -727,7 +727,7 @@ out vec4 o_color;
|
|
|
727
727
|
|
|
728
728
|
void main() {
|
|
729
729
|
o_color = v_color;
|
|
730
|
-
}`,nc=class{constructor(e){this.vertices=[];this.gl=e,this.program=le.create(e,{vertex:Ox,fragment:Ux},{a_position:0,a_color:1}),this.uniformViewProjection=this.program.getUniformLocation("u_viewProjection"),this.vao=new Ee(e),this.vbo=new Ae(e,e.STREAM_DRAW),this.vao.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:28,offset:0},{index:1,size:4,type:e.FLOAT,stride:28,offset:12}],this.vbo)}get shaderSize(){return this.program.sourceSize}addLine(e,r,n={r:1,g:0,b:0,a:1}){this.vertices.push(e.x,e.y,e.z,n.r,n.g,n.b,n.a,r.x,r.y,r.z,n.r,n.g,n.b,n.a)}addBBox(e,r,n={r:0,g:1,b:0,a:1}){let i={x:e.x,y:e.y,z:e.z},a={x:r.x,y:e.y,z:e.z},o={x:r.x,y:r.y,z:e.z},s={x:e.x,y:r.y,z:e.z},c={x:e.x,y:e.y,z:r.z},l={x:r.x,y:e.y,z:r.z},d={x:r.x,y:r.y,z:r.z},f={x:e.x,y:r.y,z:r.z};this.addLine(i,a,n),this.addLine(a,o,n),this.addLine(o,s,n),this.addLine(s,i,n),this.addLine(c,l,n),this.addLine(l,d,n),this.addLine(d,f,n),this.addLine(f,c,n),this.addLine(i,c,n),this.addLine(a,l,n),this.addLine(o,d,n),this.addLine(s,f,n)}clear(){this.vertices=[]}render(e){this.vertices.length!==0&&(this.program.use(),this.gl.uniformMatrix4fv(this.uniformViewProjection,!1,e),this.vbo.upload(new Float32Array(this.vertices),this.gl.STREAM_DRAW),this.vao.bind(),this.gl.drawArrays(this.gl.LINES,0,this.vertices.length/7))}};function Nx(t,e){let r=t.models[0].headNode;for(;r>=0;){let i=t.nodes[r],a=t.planes[i.planeIndex];a.normal[0]*e.x+a.normal[1]*e.y+a.normal[2]*e.z-a.dist>=0?r=i.children[0]:r=i.children[1]}let n=-(r+1);return{leaf:t.leafs[n],index:n}}function Hx(t){if(t.entities.worldspawn?.properties.light){let e=parseInt(t.entities.worldspawn.properties.light,10);if(!isNaN(e))return e/255}if(t.entities.worldspawn?.properties._minlight){let e=parseInt(t.entities.worldspawn.properties._minlight,10);if(!isNaN(e))return e/255}return .2}function Vx(t,e,r,n){let i=t.faces[e];if(!i||i.lightOffset<0||!t.lightMapInfo[e])return 0;let o=t.texInfo[i.texInfo],s=1/0,c=-1/0,l=1/0,d=-1/0,f=i.firstEdge;for(let E=0;E<i.numEdges;E++){let L=t.surfEdges[f+E],M=L>=0?t.edges[L].vertices[0]:t.edges[Math.abs(L)].vertices[1],
|
|
730
|
+
}`,nc=class{constructor(e){this.vertices=[];this.gl=e,this.program=le.create(e,{vertex:Ox,fragment:Ux},{a_position:0,a_color:1}),this.uniformViewProjection=this.program.getUniformLocation("u_viewProjection"),this.vao=new Ee(e),this.vbo=new Ae(e,e.STREAM_DRAW),this.vao.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:28,offset:0},{index:1,size:4,type:e.FLOAT,stride:28,offset:12}],this.vbo)}get shaderSize(){return this.program.sourceSize}addLine(e,r,n={r:1,g:0,b:0,a:1}){this.vertices.push(e.x,e.y,e.z,n.r,n.g,n.b,n.a,r.x,r.y,r.z,n.r,n.g,n.b,n.a)}addBBox(e,r,n={r:0,g:1,b:0,a:1}){let i={x:e.x,y:e.y,z:e.z},a={x:r.x,y:e.y,z:e.z},o={x:r.x,y:r.y,z:e.z},s={x:e.x,y:r.y,z:e.z},c={x:e.x,y:e.y,z:r.z},l={x:r.x,y:e.y,z:r.z},d={x:r.x,y:r.y,z:r.z},f={x:e.x,y:r.y,z:r.z};this.addLine(i,a,n),this.addLine(a,o,n),this.addLine(o,s,n),this.addLine(s,i,n),this.addLine(c,l,n),this.addLine(l,d,n),this.addLine(d,f,n),this.addLine(f,c,n),this.addLine(i,c,n),this.addLine(a,l,n),this.addLine(o,d,n),this.addLine(s,f,n)}clear(){this.vertices=[]}render(e){this.vertices.length!==0&&(this.program.use(),this.gl.uniformMatrix4fv(this.uniformViewProjection,!1,e),this.vbo.upload(new Float32Array(this.vertices),this.gl.STREAM_DRAW),this.vao.bind(),this.gl.drawArrays(this.gl.LINES,0,this.vertices.length/7))}};function Nx(t,e){let r=t.models[0].headNode;for(;r>=0;){let i=t.nodes[r],a=t.planes[i.planeIndex];a.normal[0]*e.x+a.normal[1]*e.y+a.normal[2]*e.z-a.dist>=0?r=i.children[0]:r=i.children[1]}let n=-(r+1);return{leaf:t.leafs[n],index:n}}function Hx(t){if(t.entities.worldspawn?.properties.light){let e=parseInt(t.entities.worldspawn.properties.light,10);if(!isNaN(e))return e/255}if(t.entities.worldspawn?.properties._minlight){let e=parseInt(t.entities.worldspawn.properties._minlight,10);if(!isNaN(e))return e/255}return .2}function Vx(t,e,r,n){let i=t.faces[e];if(!i||i.lightOffset<0||!t.lightMapInfo[e])return 0;let o=t.texInfo[i.texInfo],s=1/0,c=-1/0,l=1/0,d=-1/0,f=i.firstEdge;for(let E=0;E<i.numEdges;E++){let L=t.surfEdges[f+E],M=L>=0?t.edges[L].vertices[0]:t.edges[Math.abs(L)].vertices[1],C=t.vertices[M],I=C[0]*o.s[0]+C[1]*o.s[1]+C[2]*o.s[2]+o.sOffset,B=C[0]*o.t[0]+C[1]*o.t[1]+C[2]*o.t[2]+o.tOffset;I<s&&(s=I),I>c&&(c=I),B<l&&(l=B),B>d&&(d=B)}let u=Math.floor(s/16),h=Math.floor(l/16),m=Math.ceil(c/16)-u+1,g=Math.ceil(d/16)-h+1,p=r/16-u,y=n/16-h,v=Math.max(0,Math.min(m-1,Math.floor(p))),x=Math.max(0,Math.min(g-1,Math.floor(y))),b=i.lightOffset+(x*m+v)*3;if(b+2>=t.lightMaps.length)return 0;let _=t.lightMaps[b],w=t.lightMaps[b+1],S=t.lightMaps[b+2];return Math.max(_,w,S)/255}function Rm(t,e){if(!t)return 1;let r=Hx(t),n={x:e.x,y:e.y,z:e.z-8192},i=1,a=-1,o=0,s=0,{leaf:c,index:l}=Nx(t,e);if(c.contents&1)return r;let d=t.leafLists.leafFaces[l];if(d)for(let f of d){let u=t.faces[f],h=t.planes[u.planeIndex],m=u.side,g=m?-h.normal[0]:h.normal[0],p=m?-h.normal[1]:h.normal[1],y=m?-h.normal[2]:h.normal[2],v=m?-h.dist:h.dist;if(y>.7){let x=g*e.x+p*e.y+y*e.z-v;if(x>=0&&x<64){let b=t.texInfo[u.texInfo],_=e.x*b.s[0]+e.y*b.s[1]+e.z*b.s[2]+b.sOffset,w=e.x*b.t[0]+e.y*b.t[1]+e.z*b.t[2]+b.tOffset,S=Vx(t,f,_,w);if(S>r)return S}}}return Math.max(r,.2)}var ic=class{constructor(e){this.activeQueries=[];this.queryPool=[];this.currentQuery=null;this.lastGpuTimeMs=0;this.frameStartTime=0;this.lastCpuFrameTimeMs=0;this.textureMemoryBytes=0;this.bufferMemoryBytes=0;this.shaderMemoryBytes=0;this.gl=e,this.ext=e.getExtension("EXT_disjoint_timer_query_webgl2")}get available(){return!!this.ext}getPerformanceReport(e){let r=this.textureMemoryBytes/1048576,n=this.bufferMemoryBytes/(1024*1024);return{frameTimeMs:this.lastCpuFrameTimeMs,gpuTimeMs:this.lastGpuTimeMs,cpuFrameTimeMs:this.lastCpuFrameTimeMs,drawCalls:e.drawCalls,triangles:Math.floor(e.vertexCount/3),vertices:e.vertexCount,textureBinds:e.batches,shaderSwitches:e.shaderSwitches,visibleSurfaces:e.visibleSurfaces,culledSurfaces:e.culledSurfaces,visibleEntities:e.visibleEntities,culledEntities:e.culledEntities,memoryUsageMB:{textures:r,geometry:n,total:r+n}}}startFrame(){if(this.frameStartTime=performance.now(),!this.ext||this.currentQuery)return;let e=this.getQuery();e&&(this.gl.beginQuery(this.ext.TIME_ELAPSED_EXT,e),this.currentQuery=e)}endFrame(){this.lastCpuFrameTimeMs=performance.now()-this.frameStartTime,!(!this.ext||!this.currentQuery)&&(this.gl.endQuery(this.ext.TIME_ELAPSED_EXT),this.activeQueries.push(this.currentQuery),this.currentQuery=null,this.pollQueries())}trackTextureMemory(e){this.textureMemoryBytes+=e}trackBufferMemory(e){this.bufferMemoryBytes+=e}trackShaderMemory(e){this.shaderMemoryBytes+=e}getMemoryUsage(){let e=this.textureMemoryBytes,r=this.bufferMemoryBytes,n=this.shaderMemoryBytes,i=this.bufferMemoryBytes,a=e+r+n;return{texturesBytes:e,geometryBytes:r,shadersBytes:n,buffersBytes:i,totalBytes:a}}getQuery(){return this.queryPool.length>0?this.queryPool.pop():this.gl.createQuery()}pollQueries(){if(this.activeQueries.length===0)return;let e=this.activeQueries[0],r=this.gl.getQueryParameter(e,this.gl.QUERY_RESULT_AVAILABLE),n=this.gl.getParameter(this.ext.GPU_DISJOINT_EXT);if(r)if(n)this.activeQueries.forEach(i=>this.queryPool.push(i)),this.activeQueries.length=0;else{let i=this.gl.getQueryParameter(e,this.gl.QUERY_RESULT);this.lastGpuTimeMs=i/1e6,this.activeQueries.shift(),this.queryPool.push(e)}}dispose(){[...this.activeQueries,...this.queryPool].forEach(e=>this.gl.deleteQuery(e)),this.activeQueries.length=0,this.queryPool.length=0}};var Cm={1:[1,0,0,1],2:[0,1,0,1],3:[1,1,0,1],4:[0,0,1,1],5:[0,1,1,1],6:[1,0,1,1],7:[1,1,1,1],0:[0,0,0,1]};function Pm(t){let e=[],r="",n;for(let i=0;i<t.length;i++){if(t[i]==="^"&&i+1<t.length){let a=t[i+1];if(Cm[a]){r.length>0&&(e.push({text:r,color:n}),r=""),n=Cm[a],i++;continue}}r+=t[i]}return r.length>0&&e.push({text:r,color:n}),e}var Gx=`
|
|
731
731
|
attribute vec3 a_position;
|
|
732
732
|
attribute vec3 a_color;
|
|
733
733
|
uniform mat4 u_viewProjection;
|
|
@@ -779,7 +779,7 @@ void main() {
|
|
|
779
779
|
|
|
780
780
|
gl_FragColor = vec4(color, 1.0);
|
|
781
781
|
}
|
|
782
|
-
`;function ac(t){return C.fromValues(t.x,t.y,t.z)}function tr(t){return{x:t[0],y:t[1],z:t[2]}}var oc=class{constructor(e){this.vertices=[];this.solidVertices=[];this.labels=[];this.gl=e,this.shader=le.create(e,{vertex:Gx,fragment:Wx}),this.vao=new Ee(e),this.vbo=new Ae(e,e.DYNAMIC_DRAW),this.vao.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:24,offset:0},{index:1,size:3,type:e.FLOAT,stride:24,offset:12}],this.vbo),this.shaderSolid=le.create(e,{vertex:Xx,fragment:Kx}),this.vaoSolid=new Ee(e),this.vboSolid=new Ae(e,e.DYNAMIC_DRAW),this.vaoSolid.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:36,offset:0},{index:1,size:3,type:e.FLOAT,stride:36,offset:12},{index:2,size:3,type:e.FLOAT,stride:36,offset:24}],this.vboSolid)}get shaderSize(){return this.shader.sourceSize+this.shaderSolid.sourceSize}drawLine(e,r,n){this.vertices.push(e.x,e.y,e.z,n.r,n.g,n.b,r.x,r.y,r.z,n.r,n.g,n.b)}drawBoundingBox(e,r,n){let{x:i,y:a,z:o}=e,{x:s,y:c,z:l}=r;this.drawLine({x:i,y:a,z:o},{x:s,y:a,z:o},n),this.drawLine({x:s,y:a,z:o},{x:s,y:c,z:o},n),this.drawLine({x:s,y:c,z:o},{x:i,y:c,z:o},n),this.drawLine({x:i,y:c,z:o},{x:i,y:a,z:o},n),this.drawLine({x:i,y:a,z:l},{x:s,y:a,z:l},n),this.drawLine({x:s,y:a,z:l},{x:s,y:c,z:l},n),this.drawLine({x:s,y:c,z:l},{x:i,y:c,z:l},n),this.drawLine({x:i,y:c,z:l},{x:i,y:a,z:l},n),this.drawLine({x:i,y:a,z:o},{x:i,y:a,z:l},n),this.drawLine({x:s,y:a,z:o},{x:s,y:a,z:l},n),this.drawLine({x:s,y:c,z:o},{x:s,y:c,z:l},n),this.drawLine({x:i,y:c,z:o},{x:i,y:c,z:l},n)}drawPoint(e,r,n){let i=r/2;this.drawBoundingBox({x:e.x-i,y:e.y-i,z:e.z-i},{x:e.x+i,y:e.y+i,z:e.z+i},n)}drawAxes(e,r){this.drawLine(e,{x:e.x+r,y:e.y,z:e.z},{r:1,g:0,b:0}),this.drawLine(e,{x:e.x,y:e.y+r,z:e.z},{r:0,g:1,b:0}),this.drawLine(e,{x:e.x,y:e.y,z:e.z+r},{r:0,g:0,b:1})}drawText3D(e,r){this.labels.push({text:e,position:r})}addTriangle(e,r,n,i,a){this.solidVertices.push(e.x,e.y,e.z),this.solidVertices.push(a.r,a.g,a.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(r.x,r.y,r.z),this.solidVertices.push(a.r,a.g,a.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(n.x,n.y,n.z),this.solidVertices.push(a.r,a.g,a.b),this.solidVertices.push(i.x,i.y,i.z)}addCone(e,r,n,i){let o=ac(e),s=ac(r),c=C.create();C.subtract(c,o,s),C.normalize(c,c);let l=C.fromValues(0,0,1);Math.abs(C.dot(c,l))>.99&&(l=C.fromValues(0,1,0));let d=C.create();C.cross(d,l,c),C.normalize(d,d);let f=C.create();C.cross(f,c,d);let u=[];for(let p=0;p<16;p++){let y=p/16*Math.PI*2,v=Math.cos(y)*n,x=Math.sin(y)*n,b=C.clone(s);C.scaleAndAdd(b,b,d,v),C.scaleAndAdd(b,b,f,x),u.push(b)}let h=C.clone(c);C.scale(h,h,-1);let m=tr(h),g=r;for(let p=0;p<16;p++){let y=tr(u[p]),v=tr(u[(p+1)%16]);this.addTriangle(g,v,y,m,i)}for(let p=0;p<16;p++){let y=u[p],v=u[(p+1)%16],x=tr(y),b=tr(v),_=C.create();C.subtract(_,v,y);let w=C.create();C.subtract(w,o,y);let S=C.create();C.cross(S,_,w),C.normalize(S,S);let E=tr(S);this.addTriangle(x,b,e,E,i)}}addTorus(e,r,n,i,a={x:0,y:0,z:1}){let c=ac(a);C.normalize(c,c);let l=ac(e),d=C.fromValues(0,0,1),f=j.create();if(Math.abs(C.dot(c,d))>.999)c[2]<0&&j.rotateX(f,f,Math.PI);else{let m=C.create();C.cross(m,d,c),C.normalize(m,m);let g=Math.acos(C.dot(d,c));j.fromRotation(f,g,m)}let u=[],h=[];for(let m=0;m<=16;m++){let g=m/16*Math.PI*2,p=Math.cos(g),y=Math.sin(g),v=[],x=[];for(let b=0;b<=8;b++){let _=b/8*Math.PI*2,w=Math.cos(_),S=Math.sin(_),E=(r+n*w)*p,L=(r+n*w)*y,M=n*S,R=C.fromValues(E,L,M),I=w*p,B=w*y,F=S,U=C.fromValues(I,B,F);C.transformMat4(R,R,f),C.transformMat4(U,U,f),C.add(R,R,l),v.push(R),x.push(U)}u.push(v),h.push(x)}for(let m=0;m<16;m++)for(let g=0;g<8;g++){let p=u[m][g],y=u[m+1][g],v=u[m+1][g+1],x=u[m][g+1],b=tr(p),_=tr(y),w=tr(v),S=tr(x),E=C.create();C.subtract(E,y,p);let L=C.create();C.subtract(L,v,p);let M=C.create();C.cross(M,E,L),C.normalize(M,M),this.addTriangle(b,_,w,tr(M),i);let R=C.create();C.subtract(R,v,p);let I=C.create();C.subtract(I,x,p);let B=C.create();C.cross(B,R,I),C.normalize(B,B),this.addTriangle(b,w,S,tr(B),i)}}render(e,r=!1){if(r&&this.gl.disable(this.gl.DEPTH_TEST),this.vertices.length>0){this.shader.use();let n=this.shader.getUniformLocation("u_viewProjection");n&&this.gl.uniformMatrix4fv(n,!1,e),this.vbo.upload(new Float32Array(this.vertices)),this.vao.bind(),this.gl.drawArrays(this.gl.LINES,0,this.vertices.length/6)}if(this.solidVertices.length>0){this.shaderSolid.use();let n=this.shaderSolid.getUniformLocation("u_viewProjection");n&&this.gl.uniformMatrix4fv(n,!1,e);let i=this.shaderSolid.getUniformLocation("u_lightingEnabled");i&&this.gl.uniform1i(i,1),this.vboSolid.upload(new Float32Array(this.solidVertices)),this.vaoSolid.bind(),this.gl.drawArrays(this.gl.TRIANGLES,0,this.solidVertices.length/9)}r&&this.gl.enable(this.gl.DEPTH_TEST)}getLabels(e,r,n){let i=[];for(let a of this.labels){let o=ga.fromValues(a.position.x,a.position.y,a.position.z,1),s=ga.create(),l=e,d=o[0],f=o[1],u=o[2],h=o[3];if(s[0]=l[0]*d+l[4]*f+l[8]*u+l[12]*h,s[1]=l[1]*d+l[5]*f+l[9]*u+l[13]*h,s[2]=l[2]*d+l[6]*f+l[10]*u+l[14]*h,s[3]=l[3]*d+l[7]*f+l[11]*u+l[15]*h,s[3]>0){let m=s[0]/s[3],g=s[1]/s[3],p=(m+1)*.5*r,y=(1-g)*.5*n;p>=0&&p<=r&&y>=0&&y<=n&&i.push({text:a.text,x:p,y})}}return i}clear(){this.vertices=[],this.solidVertices=[],this.labels=[]}};function Im(t,e,r,n=32){let i=[];for(let s of t){let c=!0;for(let l of e)if(l.normal.x*s.origin.x+l.normal.y*s.origin.y+l.normal.z*s.origin.z+l.distance<-s.intensity){c=!1;break}if(c){let l=0;if(r){let d=s.origin.x-r.x,f=s.origin.y-r.y,u=s.origin.z-r.z;l=d*d+f*f+u*u}i.push({light:s,distSq:l})}}r&&i.sort((s,c)=>s.distSq-c.distSq);let a=[],o=Math.min(i.length,n);for(let s=0;s<o;s++)a.push(i[s].light);return a}function mu(t){let e=(t*1664525+1013904223>>>0)/4294967296,r=(t*25214903917+11>>>0)/4294967296,n=(t*69069+1>>>0)/4294967296;return[e,r,n,1]}var Bm=t=>{let e=new fa(t),r=new ha(t),n=new pa(t),i=new va(t),a=new wa(t),o=new nc(t),s=new oc(t),c=new ic(t),l=new uf({seed:Date.now()}),d=new _a(4096,l),f=new Sa(t,d),u=e.shaderSize+r.shaderSize+n.shaderSize+i.shaderSize+a.shaderSize+o.shaderSize+s.shaderSize+f.shaderSize;c.trackShaderMemory(u);let h=new Map,m=new Map,g=new Map,p=new Map,y=0,v=600,x=300,b=null,_={drawCalls:0,vertexCount:0,batches:0,shaderSwitches:0,visibleSurfaces:0,culledSurfaces:0,visibleEntities:0,culledEntities:0},w=new Map,S=new Map,E=0,L=1,M=1,R=!1,I=0,B=new Map,F=!1,U=!1,ce=.5,Nt=1,Ct=new Array(1024).fill(!0),zr=Tm(t,e,r),on=1e4,dt=[],et=0,Ht=Jl.create(),Gn=C.create(),sn=C.create();for(let A=0;A<on;A++){let K={id:-1,model:void 0,transform:new Float32Array(16),type:"md3",blend:{frame0:0,frame1:0,lerp:0},tint:[1,1,1,1],lighting:{ambient:[.5,.5,.5],dynamicLights:[],modelMatrix:void 0}};K.lighting&&(K.lighting.modelMatrix=K.transform),dt.push(K)}let Or=[],Ur,Nr,k,oe=(A,K)=>{if(A.type==="md2"){let ie=A.model;if(!ie.lods||ie.lods.length===0)return{model:A.model,type:A.type};let de=A.transform[12]-K.x,re=A.transform[13]-K.y,pe=A.transform[14]-K.z,Ke=Math.sqrt(de*de+re*re+pe*pe),Pt=Math.floor(Ke*Nt/500);if(Pt<=0)return{model:A.model,type:A.type};let Pe=ie.lods,Wt=Math.min(Pt-1,Pe.length-1);return{model:Pe[Wt],type:A.type}}return{model:A.model,type:A.type}},Ce=(A,K,ie)=>{c.startFrame(),y++;let de=Or.length>0?[...K,...Or]:K;Or.length=0,et=0,A.deltaTime&&d.update(A.deltaTime),t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0);let pe=A.renderMode,Ke=!1;ie?.wireframe||E===6?pe={mode:"wireframe",applyToAll:!0,color:[1,1,1,1]}:E===5&&(Ke=!0);let Pt=A.sky;ie?.showSkybox===!1&&(Pt=void 0);let Pe=new Float32Array(A.camera.viewProjectionMatrix),Wt=kn(Pe),It=A.dlights?Im(A.dlights,Wt,{x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},32):void 0,za={...A,sky:Pt,renderMode:pe,disableLightmaps:ie?.showLightmaps===!1&&E!==5,dlights:It,lightmapOnly:Ke,brightness:L,gamma:M,fullbright:R,ambient:I,lightStyleOverrides:B,underwaterWarp:F,bloom:U,bloomIntensity:ce,portalState:Ct},Rs=zr.renderFrame(za),tf=Rs.facesDrawn||0,rf=0;A.world&&A.world.map&&A.world.map.faces&&(rf=A.world.map.faces.length);let mp=rf-tf,Cc=-1,Pc=-1,Ic=null;if(A.world&&ie?.cullingEnabled!==!1){let z={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},ke=bi(A.world.map,z);if(ke>=0){let ut=A.world.map.leafs[ke];Cc=ut.cluster,Pc=ut.area,Pc>=0&&A.world.map.areas.length>0&&(Ic=kd(A.world.map,Pc,Ct))}}let Cs,Oa=0,Bc=0,nf=0,Ps=0,pp={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]};if(y%v===0)for(let[z,ke]of p)y-ke.lastFrameSeen>x&&p.delete(z);for(let z of de){if(A.world&&Cc>=0){let Q={x:z.transform[12],y:z.transform[13],z:z.transform[14]},O=-1;if(z.id!==void 0){let Y=p.get(z.id);Y&&Y.position[12]===z.transform[12]&&Y.position[13]===z.transform[13]&&Y.position[14]===z.transform[14]?(O=Y.leafIndex,Y.lastFrameSeen=y):(O=bi(A.world.map,Q),O>=0&&p.set(z.id,{leafIndex:O,position:new Float32Array(z.transform),lastFrameSeen:y}))}else O=bi(A.world.map,Q);if(O>=0){let Y=A.world.map.leafs[O],Xt=Y.cluster,ze=Y.area;if(Ic&&ze>=0&&!Ic.has(ze)){Ps++;continue}if(!Fd(A.world.map.visibility,Cc,Xt)){Ps++;continue}}}let{model:ke,type:ut}=oe(z,pp),De,ve;if(ut==="md2"){let Q=ke,O=Q.frames[z.blend.frame0%Q.frames.length],Y=Q.frames[z.blend.frame1%Q.frames.length];O&&Y&&(De={x:Math.min(O.minBounds.x,Y.minBounds.x),y:Math.min(O.minBounds.y,Y.minBounds.y),z:Math.min(O.minBounds.z,Y.minBounds.z)},ve={x:Math.max(O.maxBounds.x,Y.maxBounds.x),y:Math.max(O.maxBounds.y,Y.maxBounds.y),z:Math.max(O.maxBounds.z,Y.maxBounds.z)})}else if(ut==="md3"){let Q=ke,O=Q.frames[z.blend.frame0%Q.frames.length],Y=Q.frames[z.blend.frame1%Q.frames.length];O&&Y?(De={x:Math.min(O.minBounds.x,Y.minBounds.x),y:Math.min(O.minBounds.y,Y.minBounds.y),z:Math.min(O.minBounds.z,Y.minBounds.z)},ve={x:Math.max(O.maxBounds.x,Y.maxBounds.x),y:Math.max(O.maxBounds.y,Y.maxBounds.y),z:Math.max(O.maxBounds.z,Y.maxBounds.z)}):(De={x:-32,y:-32,z:-32},ve={x:32,y:32,z:32})}if(De&&ve){let Q=Ch(De,ve,z.transform);if(!yi(Q.mins,Q.maxs,Wt)){Ps++;continue}}nf++;let ar={x:z.transform[12],y:z.transform[13],z:z.transform[14]},Ye=Rm(A.world?.map,ar),Le=z.id!==void 0?w.get(z.id):void 0;switch(ut){case"md2":{let Q=ke,O=m.get(Q);if(O)O.update(Q,z.blend);else{O=new ma(t,Q,z.blend),m.set(Q,O);let Oe=O.geometry.vertices.length*8*4,cn=O.geometry.indices.length*2;c.trackBufferMemory(Oe+cn)}let Y=Oc(Pe,z.transform),Xt=z.skin,ze=Xt?A.world?.textures?.get(Xt):void 0;ze&&ze!==Cs&&(ze.bind(0),Cs=ze);let Kt=pe;if(Kt&&!Kt.applyToAll&&ze&&(Kt=void 0),Kt?.generateRandomColor&&z.id!==void 0){let Oe=mu(z.id);Kt={...Kt,color:Oe}}if(n.bind({modelViewProjection:Y,modelMatrix:z.transform,ambientLight:Ye,dlights:A.dlights,renderMode:Kt,tint:z.tint,brightness:L,gamma:M,fullbright:R,ambient:I}),n.draw(O,Kt),Oa++,Bc+=O.geometry.vertices.length,Le){let Oe={mode:"wireframe",applyToAll:!0,color:Le};n.bind({modelViewProjection:Y,modelMatrix:z.transform,ambientLight:1,renderMode:Oe,tint:[1,1,1,1],brightness:1,gamma:1,fullbright:!0,ambient:0}),n.draw(O,Oe),Oa++}}break;case"md3":{let Q=ke,O=h.get(Q),Y=z,Xt=A.dlights?A.dlights.map(Oe=>({origin:Oe.origin,color:[Oe.color.x,Oe.color.y,Oe.color.z],radius:Oe.intensity})):void 0,ze={...Y.lighting,ambient:[Ye,Ye,Ye],dynamicLights:Xt,modelMatrix:z.transform};O?O.update(z.blend,ze):(O=new xa(t,Q,z.blend,ze),h.set(Q,O));let Kt=Oc(Pe,z.transform);i.bind(Kt);for(let Oe of Q.surfaces){let cn=O.surfaces.get(Oe.name);if(cn){let of=Y.skins?.get(Oe.name),Ua=of?A.world?.textures?.get(of):void 0;Ua&&Ua!==Cs&&(Ua.bind(0),Cs=Ua);let Kn=pe;if(Kn&&!Kn.applyToAll&&Ua&&(Kn=void 0),Kn?.generateRandomColor&&z.id!==void 0){let sf=mu(z.id);Kn={...Kn,color:sf}}let gp={renderMode:Kn,brightness:L,gamma:M,fullbright:R,globalAmbient:I};if(i.drawSurface(cn,gp),Oa++,Bc+=cn.geometry.vertices.length,Le){let yp={renderMode:{mode:"wireframe",applyToAll:!0,color:Le},brightness:1,gamma:1,fullbright:!0,globalAmbient:0};i.drawSurface(cn,yp),Oa++}}}}break}}let Xn=A.camera.viewMatrix;if(Xn){let z={x:Xn[0],y:Xn[4],z:Xn[8]},ke={x:Xn[1],y:Xn[5],z:Xn[9]};f.render({viewProjection:Pe,viewRight:z,viewUp:ke})}if(za.waterTint&&(Ur(),k(0,0,t.canvas.width,t.canvas.height,za.waterTint),Nr()),o.render(Pe),o.clear(),A.world&&(S.size>0||E===3)){let z=new Map(S);if(E===3&&A.world){let ke=kn(Pe),ut={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},De=xi(A.world.map,ut,ke,Ct);for(let{faceIndex:ve,leafIndex:ar}of De){let Ye=A.world.map.leafs[ar];Ye&&!z.has(ve)&&z.set(ve,mu(Ye.cluster))}}for(let[ke,ut]of z){let De=A.world.surfaces[ke];if(De&&De.vertexCount>0){let ve=[];for(let Le=0;Le<De.vertexCount;Le++)ve.push({x:De.vertexData[Le*7],y:De.vertexData[Le*7+1],z:De.vertexData[Le*7+2]});let Ye={r:ut[0],g:ut[1],b:ut[2]};for(let Le=0;Le<ve.length;Le++){let Q=ve[Le],O=ve[(Le+1)%ve.length];s.drawLine(Q,O,Ye)}s.drawLine(ve[0],ve[ve.length/2|0],Ye)}}}if((ie?.showNormals||E===2)&&A.world){let z=kn(Pe),ke={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},ut=xi(A.world.map,ke,z,Ct);for(let{faceIndex:De}of ut){let ve=A.world.map.faces[De],ar=A.world.map.planes[ve.planeIndex],Ye=A.world.surfaces[De];if(!Ye)continue;let Le=0,Q=0,O=0,Y=Ye.vertexCount;for(let Xt=0;Xt<Y;Xt++){let ze=Xt*7;Le+=Ye.vertexData[ze],Q+=Ye.vertexData[ze+1],O+=Ye.vertexData[ze+2]}if(Y>0){Le/=Y,Q/=Y,O/=Y;let Xt=ve.side===0?ar.normal[0]:-ar.normal[0],ze=ve.side===0?ar.normal[1]:-ar.normal[1],Kt=ve.side===0?ar.normal[2]:-ar.normal[2],Oe={x:Le,y:Q,z:O},cn={x:Le+Xt*8,y:Q+ze*8,z:O+Kt*8};s.drawLine(Oe,cn,{r:1,g:1,b:0})}}}s.render(Pe);let af=s.getLabels(Pe,t.canvas.width,t.canvas.height);if(af.length>0){Ur();for(let z of af)Ti(z.x,z.y,z.text,[1,1,1,1]);Nr()}s.clear(),_={drawCalls:Rs.drawCalls+Oa,vertexCount:Rs.vertexCount+Bc,batches:Rs.batches,shaderSwitches:0,visibleSurfaces:tf,culledSurfaces:mp,visibleEntities:nf,culledEntities:Ps},c.endFrame()},Re=async(A,K)=>{if(g.has(A))return g.get(A);let ie=new Blob([K]),de=await createImageBitmap(ie),re=new Je(t);return re.upload(de.width,de.height,de),g.set(A,re),c.trackTextureMemory(de.width*de.height*4),A.includes("conchars")&&(b=re),re},ir=(A,K)=>{if(g.has(A))return g.get(A);let ie=new Je(t),de=K.levels[0];return ie.upload(de.width,de.height,de.rgba),g.set(A,ie),c.trackTextureMemory(de.width*de.height*4),A.includes("conchars")&&(b=ie),ie};Ur=()=>{t.enable(t.BLEND),t.blendFunc(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA),t.disable(t.DEPTH_TEST),t.depthMask(!1);let A=j.create();j.ortho(A,0,t.canvas.width,t.canvas.height,0,-1,1),a.begin(A)},Nr=()=>{t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0)};let Vt=(A,K,ie,de)=>{ie.bind(0),a.draw(A,K,ie.width,ie.height,0,0,1,1,de)},ln=(A,K,ie,de)=>{if(!b)return;let re=8,pe=8,Ke=b.width/re,Pt=ie&255,Pe=Pt%Ke*re/b.width,Wt=Math.floor(Pt/Ke)*pe/b.height,It=Pe+re/b.width,za=Wt+pe/b.height;b.bind(0),a.draw(A,K,re,pe,Pe,Wt,It,za,de)},Ti=(A,K,ie,de)=>{let re=Pm(ie),pe=A,Ke=8;for(let Pt of re){let Pe=Pt.color||de;for(let Wt=0;Wt<Pt.text.length;Wt++)ln(pe,K,Pt.text.charCodeAt(Wt),Pe),pe+=Ke}},Gt=(A,K)=>{let re=K.replace(/\^[0-9]/g,"").length*8,pe=(t.canvas.width-re)/2;Ti(pe,A,K)};return k=(A,K,ie,de,re)=>{a.drawRect(A,K,ie,de,re)},{get width(){return t.canvas.width},get height(){return t.canvas.height},get collisionVis(){return o},get debug(){return s},get particleSystem(){return d},getPerformanceReport:()=>c.getPerformanceReport(_),getMemoryUsage:()=>c.getMemoryUsage(),renderFrame:Ce,registerPic:Re,registerTexture:ir,begin2D:Ur,end2D:Nr,drawPic:Vt,drawString:Ti,drawCenterString:Gt,drawfillRect:k,setEntityHighlight:(A,K)=>{w.set(A,K)},clearEntityHighlight:A=>{w.delete(A)},highlightSurface:(A,K)=>{S.set(A,K)},removeSurfaceHighlight:A=>{S.delete(A)},setDebugMode:A=>{E=A},setBrightness:A=>{L=Math.max(0,Math.min(2,A))},setGamma:A=>{M=Math.max(.5,Math.min(3,A))},setFullbright:A=>{R=A},setAmbient:A=>{I=Math.max(0,Math.min(1,A))},setLightStyle:(A,K)=>{K===null?B.delete(A):B.set(A,K)},setUnderwaterWarp:A=>{F=A},setBloom:A=>{U=A},setBloomIntensity:A=>{ce=A},setLodBias:A=>{Nt=Math.max(0,Math.min(2,A))},setAreaPortalState:(A,K)=>{A>=0&&A<Ct.length&&(Ct[A]=K)},renderInstanced:(A,K)=>{let ie="glCommands"in A,de=ie?"md2":"md3";for(let re of K){if(et>=on){console.warn("Max instances reached");break}let pe=dt[et++];pe.model=A,pe.type=de;let Ke=pe.blend;re.frame!==void 0?(Ke.frame0=re.frame,Ke.frame1=re.frame,Ke.lerp=0):(Ke.frame0=re.frame0||0,Ke.frame1=re.frame1||0,Ke.lerp=re.lerp||0),ie&&(pe.skin=re.skin!==void 0?"skin"+re.skin:void 0);let Pt=re.rotation,Pe=re.position,Wt=re.scale||{x:1,y:1,z:1};j.fromRotationTranslationScale(pe.transform,Ht,Gn,sn);let It=pe.lighting;It&&(It.dynamicLights?It.dynamicLights.length=0:It.dynamicLights=[],It.ambient?(It.ambient[0]=.5,It.ambient[1]=.5,It.ambient[2]=.5):It.ambient=[.5,.5,.5]),Or.push(pe)}},dispose:()=>{c.dispose()}}};var fr=class{constructor(e){this.messageOffsets=[];this.currentBlock=null;this.buffer=e,this.view=new DataView(e),this.offset=0,this.scan()}scan(){let e=0;for(this.messageOffsets=[];e+4<=this.buffer.byteLength;){let r=this.view.getInt32(e,!0);if(r===-1)break;if(r<0||r>2097152){console.warn(`DemoReader: Invalid block length ${r} at offset ${e} during scan`);break}if(e+4+r>this.buffer.byteLength){console.warn(`DemoReader: Incomplete block at offset ${e} during scan`);break}this.messageOffsets.push(e),e+=4+r}}hasMore(){return this.offset<this.buffer.byteLength}readNextBlock(){if(this.offset+4>this.buffer.byteLength)return null;let e=this.view.getInt32(this.offset,!0);if(e===-1||e<0||this.offset+4+e>this.buffer.byteLength)return null;this.offset+=4;let r=this.buffer.slice(this.offset,this.offset+e);return this.offset+=e,{length:e,data:new mn(r)}}nextBlock(){let e=this.readNextBlock();return e?(this.currentBlock=e,!0):(this.currentBlock=null,!1)}getBlock(){if(!this.currentBlock)throw new Error("No current block. Call nextBlock() first.");return this.currentBlock}readAllBlocksToBuffer(){let e=0,r=this.offset,n=[],i=this.offset;for(;i+4<=this.buffer.byteLength;){let c=this.view.getInt32(i,!0);if(c===-1||c<0||i+4+c>this.buffer.byteLength)break;n.push({offset:i+4,length:c}),e+=c,i+=4+c}let a=new Uint8Array(e),o=0,s=new Uint8Array(this.buffer);for(let c of n)a.set(s.subarray(c.offset,c.offset+c.length),o),o+=c.length;return this.offset=i,a.buffer}reset(){this.offset=0,this.currentBlock=null}seekToMessage(e){return e<0||e>=this.messageOffsets.length?!1:(this.offset=this.messageOffsets[e],this.currentBlock=null,!0)}getMessageCount(){return this.messageOffsets.length}getOffset(){return this.offset}getProgress(){let e=this.offset,r=this.buffer.byteLength;return{current:e,total:r,percent:r>0?e/r*100:0}}};function Ra(t){let e=t.length;for(;--e>=0;)t[e]=0}var Yx=0,b0=1,$x=2,qx=3,Zx=258,Ou=29,xs=256,us=xs+1+Ou,Ea=30,Uu=19,x0=2*us+1,vi=15,pu=16,jx=7,Nu=256,v0=16,_0=17,S0=18,Ru=new Uint8Array([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0]),fc=new Uint8Array([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13]),Qx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),w0=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),Jx=512,nn=new Array((us+2)*2);Ra(nn);var ls=new Array(Ea*2);Ra(ls);var fs=new Array(Jx);Ra(fs);var hs=new Array(Zx-qx+1);Ra(hs);var Hu=new Array(Ou);Ra(Hu);var hc=new Array(Ea);Ra(hc);function gu(t,e,r,n,i){this.static_tree=t,this.extra_bits=e,this.extra_base=r,this.elems=n,this.max_length=i,this.has_stree=t&&t.length}var M0,A0,E0;function yu(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}var L0=t=>t<256?fs[t]:fs[256+(t>>>7)],ms=(t,e)=>{t.pending_buf[t.pending++]=e&255,t.pending_buf[t.pending++]=e>>>8&255},Rt=(t,e,r)=>{t.bi_valid>pu-r?(t.bi_buf|=e<<t.bi_valid&65535,ms(t,t.bi_buf),t.bi_buf=e>>pu-t.bi_valid,t.bi_valid+=r-pu):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=r)},Ir=(t,e,r)=>{Rt(t,r[e*2],r[e*2+1])},T0=(t,e)=>{let r=0;do r|=t&1,t>>>=1,r<<=1;while(--e>0);return r>>>1},ev=t=>{t.bi_valid===16?(ms(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=t.bi_buf&255,t.bi_buf>>=8,t.bi_valid-=8)},tv=(t,e)=>{let r=e.dyn_tree,n=e.max_code,i=e.stat_desc.static_tree,a=e.stat_desc.has_stree,o=e.stat_desc.extra_bits,s=e.stat_desc.extra_base,c=e.stat_desc.max_length,l,d,f,u,h,m,g=0;for(u=0;u<=vi;u++)t.bl_count[u]=0;for(r[t.heap[t.heap_max]*2+1]=0,l=t.heap_max+1;l<x0;l++)d=t.heap[l],u=r[r[d*2+1]*2+1]+1,u>c&&(u=c,g++),r[d*2+1]=u,!(d>n)&&(t.bl_count[u]++,h=0,d>=s&&(h=o[d-s]),m=r[d*2],t.opt_len+=m*(u+h),a&&(t.static_len+=m*(i[d*2+1]+h)));if(g!==0){do{for(u=c-1;t.bl_count[u]===0;)u--;t.bl_count[u]--,t.bl_count[u+1]+=2,t.bl_count[c]--,g-=2}while(g>0);for(u=c;u!==0;u--)for(d=t.bl_count[u];d!==0;)f=t.heap[--l],!(f>n)&&(r[f*2+1]!==u&&(t.opt_len+=(u-r[f*2+1])*r[f*2],r[f*2+1]=u),d--)}},R0=(t,e,r)=>{let n=new Array(vi+1),i=0,a,o;for(a=1;a<=vi;a++)i=i+r[a-1]<<1,n[a]=i;for(o=0;o<=e;o++){let s=t[o*2+1];s!==0&&(t[o*2]=T0(n[s]++,s))}},rv=()=>{let t,e,r,n,i,a=new Array(vi+1);for(r=0,n=0;n<Ou-1;n++)for(Hu[n]=r,t=0;t<1<<Ru[n];t++)hs[r++]=n;for(hs[r-1]=n,i=0,n=0;n<16;n++)for(hc[n]=i,t=0;t<1<<fc[n];t++)fs[i++]=n;for(i>>=7;n<Ea;n++)for(hc[n]=i<<7,t=0;t<1<<fc[n]-7;t++)fs[256+i++]=n;for(e=0;e<=vi;e++)a[e]=0;for(t=0;t<=143;)nn[t*2+1]=8,t++,a[8]++;for(;t<=255;)nn[t*2+1]=9,t++,a[9]++;for(;t<=279;)nn[t*2+1]=7,t++,a[7]++;for(;t<=287;)nn[t*2+1]=8,t++,a[8]++;for(R0(nn,us+1,a),t=0;t<Ea;t++)ls[t*2+1]=5,ls[t*2]=T0(t,5);M0=new gu(nn,Ru,xs+1,us,vi),A0=new gu(ls,fc,0,Ea,vi),E0=new gu(new Array(0),Qx,0,Uu,jx)},C0=t=>{let e;for(e=0;e<us;e++)t.dyn_ltree[e*2]=0;for(e=0;e<Ea;e++)t.dyn_dtree[e*2]=0;for(e=0;e<Uu;e++)t.bl_tree[e*2]=0;t.dyn_ltree[Nu*2]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},P0=t=>{t.bi_valid>8?ms(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},Fm=(t,e,r,n)=>{let i=e*2,a=r*2;return t[i]<t[a]||t[i]===t[a]&&n[e]<=n[r]},bu=(t,e,r)=>{let n=t.heap[r],i=r<<1;for(;i<=t.heap_len&&(i<t.heap_len&&Fm(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!Fm(e,n,t.heap[i],t.depth));)t.heap[r]=t.heap[i],r=i,i<<=1;t.heap[r]=n},km=(t,e,r)=>{let n,i,a=0,o,s;if(t.sym_next!==0)do n=t.pending_buf[t.sym_buf+a++]&255,n+=(t.pending_buf[t.sym_buf+a++]&255)<<8,i=t.pending_buf[t.sym_buf+a++],n===0?Ir(t,i,e):(o=hs[i],Ir(t,o+xs+1,e),s=Ru[o],s!==0&&(i-=Hu[o],Rt(t,i,s)),n--,o=L0(n),Ir(t,o,r),s=fc[o],s!==0&&(n-=hc[o],Rt(t,n,s)));while(a<t.sym_next);Ir(t,Nu,e)},Cu=(t,e)=>{let r=e.dyn_tree,n=e.stat_desc.static_tree,i=e.stat_desc.has_stree,a=e.stat_desc.elems,o,s,c=-1,l;for(t.heap_len=0,t.heap_max=x0,o=0;o<a;o++)r[o*2]!==0?(t.heap[++t.heap_len]=c=o,t.depth[o]=0):r[o*2+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=c<2?++c:0,r[l*2]=1,t.depth[l]=0,t.opt_len--,i&&(t.static_len-=n[l*2+1]);for(e.max_code=c,o=t.heap_len>>1;o>=1;o--)bu(t,r,o);l=a;do o=t.heap[1],t.heap[1]=t.heap[t.heap_len--],bu(t,r,1),s=t.heap[1],t.heap[--t.heap_max]=o,t.heap[--t.heap_max]=s,r[l*2]=r[o*2]+r[s*2],t.depth[l]=(t.depth[o]>=t.depth[s]?t.depth[o]:t.depth[s])+1,r[o*2+1]=r[s*2+1]=l,t.heap[1]=l++,bu(t,r,1);while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],tv(t,e),R0(r,c,t.bl_count)},Dm=(t,e,r)=>{let n,i=-1,a,o=e[1],s=0,c=7,l=4;for(o===0&&(c=138,l=3),e[(r+1)*2+1]=65535,n=0;n<=r;n++)a=o,o=e[(n+1)*2+1],!(++s<c&&a===o)&&(s<l?t.bl_tree[a*2]+=s:a!==0?(a!==i&&t.bl_tree[a*2]++,t.bl_tree[v0*2]++):s<=10?t.bl_tree[_0*2]++:t.bl_tree[S0*2]++,s=0,i=a,o===0?(c=138,l=3):a===o?(c=6,l=3):(c=7,l=4))},zm=(t,e,r)=>{let n,i=-1,a,o=e[1],s=0,c=7,l=4;for(o===0&&(c=138,l=3),n=0;n<=r;n++)if(a=o,o=e[(n+1)*2+1],!(++s<c&&a===o)){if(s<l)do Ir(t,a,t.bl_tree);while(--s!==0);else a!==0?(a!==i&&(Ir(t,a,t.bl_tree),s--),Ir(t,v0,t.bl_tree),Rt(t,s-3,2)):s<=10?(Ir(t,_0,t.bl_tree),Rt(t,s-3,3)):(Ir(t,S0,t.bl_tree),Rt(t,s-11,7));s=0,i=a,o===0?(c=138,l=3):a===o?(c=6,l=3):(c=7,l=4)}},nv=t=>{let e;for(Dm(t,t.dyn_ltree,t.l_desc.max_code),Dm(t,t.dyn_dtree,t.d_desc.max_code),Cu(t,t.bl_desc),e=Uu-1;e>=3&&t.bl_tree[w0[e]*2+1]===0;e--);return t.opt_len+=3*(e+1)+5+5+4,e},iv=(t,e,r,n)=>{let i;for(Rt(t,e-257,5),Rt(t,r-1,5),Rt(t,n-4,4),i=0;i<n;i++)Rt(t,t.bl_tree[w0[i]*2+1],3);zm(t,t.dyn_ltree,e-1),zm(t,t.dyn_dtree,r-1)},av=t=>{let e=4093624447,r;for(r=0;r<=31;r++,e>>>=1)if(e&1&&t.dyn_ltree[r*2]!==0)return 0;if(t.dyn_ltree[18]!==0||t.dyn_ltree[20]!==0||t.dyn_ltree[26]!==0)return 1;for(r=32;r<xs;r++)if(t.dyn_ltree[r*2]!==0)return 1;return 0},Om=!1,ov=t=>{Om||(rv(),Om=!0),t.l_desc=new yu(t.dyn_ltree,M0),t.d_desc=new yu(t.dyn_dtree,A0),t.bl_desc=new yu(t.bl_tree,E0),t.bi_buf=0,t.bi_valid=0,C0(t)},I0=(t,e,r,n)=>{Rt(t,(Yx<<1)+(n?1:0),3),P0(t),ms(t,r),ms(t,~r),r&&t.pending_buf.set(t.window.subarray(e,e+r),t.pending),t.pending+=r},sv=t=>{Rt(t,b0<<1,3),Ir(t,Nu,nn),ev(t)},lv=(t,e,r,n)=>{let i,a,o=0;t.level>0?(t.strm.data_type===2&&(t.strm.data_type=av(t)),Cu(t,t.l_desc),Cu(t,t.d_desc),o=nv(t),i=t.opt_len+3+7>>>3,a=t.static_len+3+7>>>3,a<=i&&(i=a)):i=a=r+5,r+4<=i&&e!==-1?I0(t,e,r,n):t.strategy===4||a===i?(Rt(t,(b0<<1)+(n?1:0),3),km(t,nn,ls)):(Rt(t,($x<<1)+(n?1:0),3),iv(t,t.l_desc.max_code+1,t.d_desc.max_code+1,o+1),km(t,t.dyn_ltree,t.dyn_dtree)),C0(t),n&&P0(t)},cv=(t,e,r)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=r,e===0?t.dyn_ltree[r*2]++:(t.matches++,e--,t.dyn_ltree[(hs[r]+xs+1)*2]++,t.dyn_dtree[L0(e)*2]++),t.sym_next===t.sym_end),dv=ov,uv=I0,fv=lv,hv=cv,mv=sv,pv={_tr_init:dv,_tr_stored_block:uv,_tr_flush_block:fv,_tr_tally:hv,_tr_align:mv},gv=(t,e,r,n)=>{let i=t&65535|0,a=t>>>16&65535|0,o=0;for(;r!==0;){o=r>2e3?2e3:r,r-=o;do i=i+e[n++]|0,a=a+i|0;while(--o);i%=65521,a%=65521}return i|a<<16|0},ps=gv,yv=()=>{let t,e=[];for(var r=0;r<256;r++){t=r;for(var n=0;n<8;n++)t=t&1?3988292384^t>>>1:t>>>1;e[r]=t}return e},bv=new Uint32Array(yv()),xv=(t,e,r,n)=>{let i=bv,a=n+r;t^=-1;for(let o=n;o<a;o++)t=t>>>8^i[(t^e[o])&255];return t^-1},Fe=xv,wi={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"},Ei={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8},{_tr_init:vv,_tr_stored_block:Pu,_tr_flush_block:_v,_tr_tally:Un,_tr_align:Sv}=pv,{Z_NO_FLUSH:Nn,Z_PARTIAL_FLUSH:wv,Z_FULL_FLUSH:Mv,Z_FINISH:rr,Z_BLOCK:Um,Z_OK:Xe,Z_STREAM_END:Nm,Z_STREAM_ERROR:Br,Z_DATA_ERROR:Av,Z_BUF_ERROR:xu,Z_DEFAULT_COMPRESSION:Ev,Z_FILTERED:Lv,Z_HUFFMAN_ONLY:sc,Z_RLE:Tv,Z_FIXED:Rv,Z_DEFAULT_STRATEGY:Cv,Z_UNKNOWN:Pv,Z_DEFLATED:gc}=Ei,Iv=9,Bv=15,Fv=8,kv=29,Dv=256,Iu=Dv+1+kv,zv=30,Ov=19,Uv=2*Iu+1,Nv=15,Z=3,On=258,Fr=On+Z+1,Hv=32,La=42,Vu=57,Bu=69,Fu=73,ku=91,Du=103,_i=113,os=666,lt=1,Ca=2,Mi=3,Pa=4,Vv=3,Si=(t,e)=>(t.msg=wi[e],e),Hm=t=>t*2-(t>4?9:0),zn=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Gv=t=>{let e,r,n,i=t.w_size;e=t.hash_size,n=e;do r=t.head[--n],t.head[n]=r>=i?r-i:0;while(--e);e=i,n=e;do r=t.prev[--n],t.prev[n]=r>=i?r-i:0;while(--e)},Wv=(t,e,r)=>(e<<t.hash_shift^r)&t.hash_mask,Hn=Wv,Ot=t=>{let e=t.state,r=e.pending;r>t.avail_out&&(r=t.avail_out),r!==0&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+r),t.next_out),t.next_out+=r,e.pending_out+=r,t.total_out+=r,t.avail_out-=r,e.pending-=r,e.pending===0&&(e.pending_out=0))},Ut=(t,e)=>{_v(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Ot(t.strm)},ne=(t,e)=>{t.pending_buf[t.pending++]=e},as=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=e&255},zu=(t,e,r,n)=>{let i=t.avail_in;return i>n&&(i=n),i===0?0:(t.avail_in-=i,e.set(t.input.subarray(t.next_in,t.next_in+i),r),t.state.wrap===1?t.adler=ps(t.adler,e,i,r):t.state.wrap===2&&(t.adler=Fe(t.adler,e,i,r)),t.next_in+=i,t.total_in+=i,i)},B0=(t,e)=>{let r=t.max_chain_length,n=t.strstart,i,a,o=t.prev_length,s=t.nice_match,c=t.strstart>t.w_size-Fr?t.strstart-(t.w_size-Fr):0,l=t.window,d=t.w_mask,f=t.prev,u=t.strstart+On,h=l[n+o-1],m=l[n+o];t.prev_length>=t.good_match&&(r>>=2),s>t.lookahead&&(s=t.lookahead);do if(i=e,!(l[i+o]!==m||l[i+o-1]!==h||l[i]!==l[n]||l[++i]!==l[n+1])){n+=2,i++;do;while(l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&n<u);if(a=On-(u-n),n=u-On,a>o){if(t.match_start=e,o=a,a>=s)break;h=l[n+o-1],m=l[n+o]}}while((e=f[e&d])>c&&--r!==0);return o<=t.lookahead?o:t.lookahead},Ta=t=>{let e=t.w_size,r,n,i;do{if(n=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-Fr)&&(t.window.set(t.window.subarray(e,e+e-n),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),Gv(t),n+=e),t.strm.avail_in===0)break;if(r=zu(t.strm,t.window,t.strstart+t.lookahead,n),t.lookahead+=r,t.lookahead+t.insert>=Z)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Hn(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Hn(t,t.ins_h,t.window[i+Z-1]),t.prev[i&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=i,i++,t.insert--,!(t.lookahead+t.insert<Z)););}while(t.lookahead<Fr&&t.strm.avail_in!==0)},F0=(t,e)=>{let r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n,i,a,o=0,s=t.strm.avail_in;do{if(n=65535,a=t.bi_valid+42>>3,t.strm.avail_out<a||(a=t.strm.avail_out-a,i=t.strstart-t.block_start,n>i+t.strm.avail_in&&(n=i+t.strm.avail_in),n>a&&(n=a),n<r&&(n===0&&e!==rr||e===Nn||n!==i+t.strm.avail_in)))break;o=e===rr&&n===i+t.strm.avail_in?1:0,Pu(t,0,0,o),t.pending_buf[t.pending-4]=n,t.pending_buf[t.pending-3]=n>>8,t.pending_buf[t.pending-2]=~n,t.pending_buf[t.pending-1]=~n>>8,Ot(t.strm),i&&(i>n&&(i=n),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,n-=i),n&&(zu(t.strm,t.strm.output,t.strm.next_out,n),t.strm.next_out+=n,t.strm.avail_out-=n,t.strm.total_out+=n)}while(o===0);return s-=t.strm.avail_in,s&&(s>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=s&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-s,t.strm.next_in),t.strstart),t.strstart+=s,t.insert+=s>t.w_size-t.insert?t.w_size-t.insert:s),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),o?Pa:e!==Nn&&e!==rr&&t.strm.avail_in===0&&t.strstart===t.block_start?Ca:(a=t.window_size-t.strstart,t.strm.avail_in>a&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,a+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),a>t.strm.avail_in&&(a=t.strm.avail_in),a&&(zu(t.strm,t.window,t.strstart,a),t.strstart+=a,t.insert+=a>t.w_size-t.insert?t.w_size-t.insert:a),t.high_water<t.strstart&&(t.high_water=t.strstart),a=t.bi_valid+42>>3,a=t.pending_buf_size-a>65535?65535:t.pending_buf_size-a,r=a>t.w_size?t.w_size:a,i=t.strstart-t.block_start,(i>=r||(i||e===rr)&&e!==Nn&&t.strm.avail_in===0&&i<=a)&&(n=i>a?a:i,o=e===rr&&t.strm.avail_in===0&&n===i?1:0,Pu(t,t.block_start,n,o),t.block_start+=n,Ot(t.strm)),o?Mi:lt)},vu=(t,e)=>{let r,n;for(;;){if(t.lookahead<Fr){if(Ta(t),t.lookahead<Fr&&e===Nn)return lt;if(t.lookahead===0)break}if(r=0,t.lookahead>=Z&&(t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),r!==0&&t.strstart-r<=t.w_size-Fr&&(t.match_length=B0(t,r)),t.match_length>=Z)if(n=Un(t,t.strstart-t.match_start,t.match_length-Z),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=Z){t.match_length--;do t.strstart++,t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart;while(--t.match_length!==0);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+1]);else n=Un(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(n&&(Ut(t,!1),t.strm.avail_out===0))return lt}return t.insert=t.strstart<Z-1?t.strstart:Z-1,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca},Ma=(t,e)=>{let r,n,i;for(;;){if(t.lookahead<Fr){if(Ta(t),t.lookahead<Fr&&e===Nn)return lt;if(t.lookahead===0)break}if(r=0,t.lookahead>=Z&&(t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=Z-1,r!==0&&t.prev_length<t.max_lazy_match&&t.strstart-r<=t.w_size-Fr&&(t.match_length=B0(t,r),t.match_length<=5&&(t.strategy===Lv||t.match_length===Z&&t.strstart-t.match_start>4096)&&(t.match_length=Z-1)),t.prev_length>=Z&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-Z,n=Un(t,t.strstart-1-t.prev_match,t.prev_length-Z),t.lookahead-=t.prev_length-1,t.prev_length-=2;do++t.strstart<=i&&(t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart);while(--t.prev_length!==0);if(t.match_available=0,t.match_length=Z-1,t.strstart++,n&&(Ut(t,!1),t.strm.avail_out===0))return lt}else if(t.match_available){if(n=Un(t,0,t.window[t.strstart-1]),n&&Ut(t,!1),t.strstart++,t.lookahead--,t.strm.avail_out===0)return lt}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(n=Un(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<Z-1?t.strstart:Z-1,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca},Xv=(t,e)=>{let r,n,i,a,o=t.window;for(;;){if(t.lookahead<=On){if(Ta(t),t.lookahead<=On&&e===Nn)return lt;if(t.lookahead===0)break}if(t.match_length=0,t.lookahead>=Z&&t.strstart>0&&(i=t.strstart-1,n=o[i],n===o[++i]&&n===o[++i]&&n===o[++i])){a=t.strstart+On;do;while(n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&i<a);t.match_length=On-(a-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=Z?(r=Un(t,1,t.match_length-Z),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(r=Un(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),r&&(Ut(t,!1),t.strm.avail_out===0))return lt}return t.insert=0,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca},Kv=(t,e)=>{let r;for(;;){if(t.lookahead===0&&(Ta(t),t.lookahead===0)){if(e===Nn)return lt;break}if(t.match_length=0,r=Un(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,r&&(Ut(t,!1),t.strm.avail_out===0))return lt}return t.insert=0,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca};function Pr(t,e,r,n,i){this.good_length=t,this.max_lazy=e,this.nice_length=r,this.max_chain=n,this.func=i}var ss=[new Pr(0,0,0,0,F0),new Pr(4,4,8,4,vu),new Pr(4,5,16,8,vu),new Pr(4,6,32,32,vu),new Pr(4,4,16,16,Ma),new Pr(8,16,32,32,Ma),new Pr(8,16,128,128,Ma),new Pr(8,32,128,256,Ma),new Pr(32,128,258,1024,Ma),new Pr(32,258,258,4096,Ma)],Yv=t=>{t.window_size=2*t.w_size,zn(t.head),t.max_lazy_match=ss[t.level].max_lazy,t.good_match=ss[t.level].good_length,t.nice_match=ss[t.level].nice_length,t.max_chain_length=ss[t.level].max_chain,t.strstart=0,t.block_start=0,t.lookahead=0,t.insert=0,t.match_length=t.prev_length=Z-1,t.match_available=0,t.ins_h=0};function $v(){this.strm=null,this.status=0,this.pending_buf=null,this.pending_buf_size=0,this.pending_out=0,this.pending=0,this.wrap=0,this.gzhead=null,this.gzindex=0,this.method=gc,this.last_flush=-1,this.w_size=0,this.w_bits=0,this.w_mask=0,this.window=null,this.window_size=0,this.prev=null,this.head=null,this.ins_h=0,this.hash_size=0,this.hash_bits=0,this.hash_mask=0,this.hash_shift=0,this.block_start=0,this.match_length=0,this.prev_match=0,this.match_available=0,this.strstart=0,this.match_start=0,this.lookahead=0,this.prev_length=0,this.max_chain_length=0,this.max_lazy_match=0,this.level=0,this.strategy=0,this.good_match=0,this.nice_match=0,this.dyn_ltree=new Uint16Array(Uv*2),this.dyn_dtree=new Uint16Array((2*zv+1)*2),this.bl_tree=new Uint16Array((2*Ov+1)*2),zn(this.dyn_ltree),zn(this.dyn_dtree),zn(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(Nv+1),this.heap=new Uint16Array(2*Iu+1),zn(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(2*Iu+1),zn(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}var vs=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.status!==La&&e.status!==Vu&&e.status!==Bu&&e.status!==Fu&&e.status!==ku&&e.status!==Du&&e.status!==_i&&e.status!==os?1:0},k0=t=>{if(vs(t))return Si(t,Br);t.total_in=t.total_out=0,t.data_type=Pv;let e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=e.wrap===2?Vu:e.wrap?La:_i,t.adler=e.wrap===2?0:1,e.last_flush=-2,vv(e),Xe},D0=t=>{let e=k0(t);return e===Xe&&Yv(t.state),e},qv=(t,e)=>vs(t)||t.state.wrap!==2?Br:(t.state.gzhead=e,Xe),z0=(t,e,r,n,i,a)=>{if(!t)return Br;let o=1;if(e===Ev&&(e=6),n<0?(o=0,n=-n):n>15&&(o=2,n-=16),i<1||i>Iv||r!==gc||n<8||n>15||e<0||e>9||a<0||a>Rv||n===8&&o!==1)return Si(t,Br);n===8&&(n=9);let s=new $v;return t.state=s,s.strm=t,s.status=La,s.wrap=o,s.gzhead=null,s.w_bits=n,s.w_size=1<<s.w_bits,s.w_mask=s.w_size-1,s.hash_bits=i+7,s.hash_size=1<<s.hash_bits,s.hash_mask=s.hash_size-1,s.hash_shift=~~((s.hash_bits+Z-1)/Z),s.window=new Uint8Array(s.w_size*2),s.head=new Uint16Array(s.hash_size),s.prev=new Uint16Array(s.w_size),s.lit_bufsize=1<<i+6,s.pending_buf_size=s.lit_bufsize*4,s.pending_buf=new Uint8Array(s.pending_buf_size),s.sym_buf=s.lit_bufsize,s.sym_end=(s.lit_bufsize-1)*3,s.level=e,s.strategy=a,s.method=r,D0(t)},Zv=(t,e)=>z0(t,e,gc,Bv,Fv,Cv),jv=(t,e)=>{if(vs(t)||e>Um||e<0)return t?Si(t,Br):Br;let r=t.state;if(!t.output||t.avail_in!==0&&!t.input||r.status===os&&e!==rr)return Si(t,t.avail_out===0?xu:Br);let n=r.last_flush;if(r.last_flush=e,r.pending!==0){if(Ot(t),t.avail_out===0)return r.last_flush=-1,Xe}else if(t.avail_in===0&&Hm(e)<=Hm(n)&&e!==rr)return Si(t,xu);if(r.status===os&&t.avail_in!==0)return Si(t,xu);if(r.status===La&&r.wrap===0&&(r.status=_i),r.status===La){let i=gc+(r.w_bits-8<<4)<<8,a=-1;if(r.strategy>=sc||r.level<2?a=0:r.level<6?a=1:r.level===6?a=2:a=3,i|=a<<6,r.strstart!==0&&(i|=Hv),i+=31-i%31,as(r,i),r.strstart!==0&&(as(r,t.adler>>>16),as(r,t.adler&65535)),t.adler=1,r.status=_i,Ot(t),r.pending!==0)return r.last_flush=-1,Xe}if(r.status===Vu){if(t.adler=0,ne(r,31),ne(r,139),ne(r,8),r.gzhead)ne(r,(r.gzhead.text?1:0)+(r.gzhead.hcrc?2:0)+(r.gzhead.extra?4:0)+(r.gzhead.name?8:0)+(r.gzhead.comment?16:0)),ne(r,r.gzhead.time&255),ne(r,r.gzhead.time>>8&255),ne(r,r.gzhead.time>>16&255),ne(r,r.gzhead.time>>24&255),ne(r,r.level===9?2:r.strategy>=sc||r.level<2?4:0),ne(r,r.gzhead.os&255),r.gzhead.extra&&r.gzhead.extra.length&&(ne(r,r.gzhead.extra.length&255),ne(r,r.gzhead.extra.length>>8&255)),r.gzhead.hcrc&&(t.adler=Fe(t.adler,r.pending_buf,r.pending,0)),r.gzindex=0,r.status=Bu;else if(ne(r,0),ne(r,0),ne(r,0),ne(r,0),ne(r,0),ne(r,r.level===9?2:r.strategy>=sc||r.level<2?4:0),ne(r,Vv),r.status=_i,Ot(t),r.pending!==0)return r.last_flush=-1,Xe}if(r.status===Bu){if(r.gzhead.extra){let i=r.pending,a=(r.gzhead.extra.length&65535)-r.gzindex;for(;r.pending+a>r.pending_buf_size;){let s=r.pending_buf_size-r.pending;if(r.pending_buf.set(r.gzhead.extra.subarray(r.gzindex,r.gzindex+s),r.pending),r.pending=r.pending_buf_size,r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex+=s,Ot(t),r.pending!==0)return r.last_flush=-1,Xe;i=0,a-=s}let o=new Uint8Array(r.gzhead.extra);r.pending_buf.set(o.subarray(r.gzindex,r.gzindex+a),r.pending),r.pending+=a,r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Fu}if(r.status===Fu){if(r.gzhead.name){let i=r.pending,a;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),Ot(t),r.pending!==0)return r.last_flush=-1,Xe;i=0}r.gzindex<r.gzhead.name.length?a=r.gzhead.name.charCodeAt(r.gzindex++)&255:a=0,ne(r,a)}while(a!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=ku}if(r.status===ku){if(r.gzhead.comment){let i=r.pending,a;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),Ot(t),r.pending!==0)return r.last_flush=-1,Xe;i=0}r.gzindex<r.gzhead.comment.length?a=r.gzhead.comment.charCodeAt(r.gzindex++)&255:a=0,ne(r,a)}while(a!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i))}r.status=Du}if(r.status===Du){if(r.gzhead.hcrc){if(r.pending+2>r.pending_buf_size&&(Ot(t),r.pending!==0))return r.last_flush=-1,Xe;ne(r,t.adler&255),ne(r,t.adler>>8&255),t.adler=0}if(r.status=_i,Ot(t),r.pending!==0)return r.last_flush=-1,Xe}if(t.avail_in!==0||r.lookahead!==0||e!==Nn&&r.status!==os){let i=r.level===0?F0(r,e):r.strategy===sc?Kv(r,e):r.strategy===Tv?Xv(r,e):ss[r.level].func(r,e);if((i===Mi||i===Pa)&&(r.status=os),i===lt||i===Mi)return t.avail_out===0&&(r.last_flush=-1),Xe;if(i===Ca&&(e===wv?Sv(r):e!==Um&&(Pu(r,0,0,!1),e===Mv&&(zn(r.head),r.lookahead===0&&(r.strstart=0,r.block_start=0,r.insert=0))),Ot(t),t.avail_out===0))return r.last_flush=-1,Xe}return e!==rr?Xe:r.wrap<=0?Nm:(r.wrap===2?(ne(r,t.adler&255),ne(r,t.adler>>8&255),ne(r,t.adler>>16&255),ne(r,t.adler>>24&255),ne(r,t.total_in&255),ne(r,t.total_in>>8&255),ne(r,t.total_in>>16&255),ne(r,t.total_in>>24&255)):(as(r,t.adler>>>16),as(r,t.adler&65535)),Ot(t),r.wrap>0&&(r.wrap=-r.wrap),r.pending!==0?Xe:Nm)},Qv=t=>{if(vs(t))return Br;let e=t.state.status;return t.state=null,e===_i?Si(t,Av):Xe},Jv=(t,e)=>{let r=e.length;if(vs(t))return Br;let n=t.state,i=n.wrap;if(i===2||i===1&&n.status!==La||n.lookahead)return Br;if(i===1&&(t.adler=ps(t.adler,e,r,0)),n.wrap=0,r>=n.w_size){i===0&&(zn(n.head),n.strstart=0,n.block_start=0,n.insert=0);let c=new Uint8Array(n.w_size);c.set(e.subarray(r-n.w_size,r),0),e=c,r=n.w_size}let a=t.avail_in,o=t.next_in,s=t.input;for(t.avail_in=r,t.next_in=0,t.input=e,Ta(n);n.lookahead>=Z;){let c=n.strstart,l=n.lookahead-(Z-1);do n.ins_h=Hn(n,n.ins_h,n.window[c+Z-1]),n.prev[c&n.w_mask]=n.head[n.ins_h],n.head[n.ins_h]=c,c++;while(--l);n.strstart=c,n.lookahead=Z-1,Ta(n)}return n.strstart+=n.lookahead,n.block_start=n.strstart,n.insert=n.lookahead,n.lookahead=0,n.match_length=n.prev_length=Z-1,n.match_available=0,t.next_in=o,t.input=s,t.avail_in=a,n.wrap=i,Xe},e_=Zv,t_=z0,r_=D0,n_=k0,i_=qv,a_=jv,o_=Qv,s_=Jv,l_="pako deflate (from Nodeca project)",cs={deflateInit:e_,deflateInit2:t_,deflateReset:r_,deflateResetKeep:n_,deflateSetHeader:i_,deflate:a_,deflateEnd:o_,deflateSetDictionary:s_,deflateInfo:l_},c_=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),d_=function(t){let e=Array.prototype.slice.call(arguments,1);for(;e.length;){let r=e.shift();if(r){if(typeof r!="object")throw new TypeError(r+"must be non-object");for(let n in r)c_(r,n)&&(t[n]=r[n])}}return t},u_=t=>{let e=0;for(let n=0,i=t.length;n<i;n++)e+=t[n].length;let r=new Uint8Array(e);for(let n=0,i=0,a=t.length;n<a;n++){let o=t[n];r.set(o,i),i+=o.length}return r},yc={assign:d_,flattenChunks:u_},O0=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{O0=!1}var gs=new Uint8Array(256);for(let t=0;t<256;t++)gs[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;gs[254]=gs[254]=1;var f_=t=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(t);let e,r,n,i,a,o=t.length,s=0;for(i=0;i<o;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<o&&(n=t.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),s+=r<128?1:r<2048?2:r<65536?3:4;for(e=new Uint8Array(s),a=0,i=0;a<s;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<o&&(n=t.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),r<128?e[a++]=r:r<2048?(e[a++]=192|r>>>6,e[a++]=128|r&63):r<65536?(e[a++]=224|r>>>12,e[a++]=128|r>>>6&63,e[a++]=128|r&63):(e[a++]=240|r>>>18,e[a++]=128|r>>>12&63,e[a++]=128|r>>>6&63,e[a++]=128|r&63);return e},h_=(t,e)=>{if(e<65534&&t.subarray&&O0)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let r="";for(let n=0;n<e;n++)r+=String.fromCharCode(t[n]);return r},m_=(t,e)=>{let r=e||t.length;if(typeof TextDecoder=="function"&&TextDecoder.prototype.decode)return new TextDecoder().decode(t.subarray(0,e));let n,i,a=new Array(r*2);for(i=0,n=0;n<r;){let o=t[n++];if(o<128){a[i++]=o;continue}let s=gs[o];if(s>4){a[i++]=65533,n+=s-1;continue}for(o&=s===2?31:s===3?15:7;s>1&&n<r;)o=o<<6|t[n++]&63,s--;if(s>1){a[i++]=65533;continue}o<65536?a[i++]=o:(o-=65536,a[i++]=55296|o>>10&1023,a[i++]=56320|o&1023)}return h_(a,i)},p_=(t,e)=>{e=e||t.length,e>t.length&&(e=t.length);let r=e-1;for(;r>=0&&(t[r]&192)===128;)r--;return r<0||r===0?e:r+gs[t[r]]>e?r:e},ys={string2buf:f_,buf2string:m_,utf8border:p_};function g_(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}var U0=g_,N0=Object.prototype.toString,{Z_NO_FLUSH:y_,Z_SYNC_FLUSH:b_,Z_FULL_FLUSH:x_,Z_FINISH:v_,Z_OK:mc,Z_STREAM_END:__,Z_DEFAULT_COMPRESSION:S_,Z_DEFAULT_STRATEGY:w_,Z_DEFLATED:M_}=Ei;function _s(t){this.options=yc.assign({level:S_,method:M_,chunkSize:16384,windowBits:15,memLevel:8,strategy:w_},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new U0,this.strm.avail_out=0;let r=cs.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(r!==mc)throw new Error(wi[r]);if(e.header&&cs.deflateSetHeader(this.strm,e.header),e.dictionary){let n;if(typeof e.dictionary=="string"?n=ys.string2buf(e.dictionary):N0.call(e.dictionary)==="[object ArrayBuffer]"?n=new Uint8Array(e.dictionary):n=e.dictionary,r=cs.deflateSetDictionary(this.strm,n),r!==mc)throw new Error(wi[r]);this._dict_set=!0}}_s.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i,a;if(this.ended)return!1;for(e===~~e?a=e:a=e===!0?v_:y_,typeof t=="string"?r.input=ys.string2buf(t):N0.call(t)==="[object ArrayBuffer]"?r.input=new Uint8Array(t):r.input=t,r.next_in=0,r.avail_in=r.input.length;;){if(r.avail_out===0&&(r.output=new Uint8Array(n),r.next_out=0,r.avail_out=n),(a===b_||a===x_)&&r.avail_out<=6){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(i=cs.deflate(r,a),i===__)return r.next_out>0&&this.onData(r.output.subarray(0,r.next_out)),i=cs.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===mc;if(r.avail_out===0){this.onData(r.output);continue}if(a>0&&r.next_out>0){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(r.avail_in===0)break}return!0};_s.prototype.onData=function(t){this.chunks.push(t)};_s.prototype.onEnd=function(t){t===mc&&(this.result=yc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Gu(t,e){let r=new _s(e);if(r.push(t,!0),r.err)throw r.msg||wi[r.err];return r.result}function A_(t,e){return e=e||{},e.raw=!0,Gu(t,e)}function E_(t,e){return e=e||{},e.gzip=!0,Gu(t,e)}var L_=_s,T_=Gu,R_=A_,C_=E_,P_=Ei,I_={Deflate:L_,deflate:T_,deflateRaw:R_,gzip:C_,constants:P_},lc=16209,B_=16191,F_=function(e,r){let n,i,a,o,s,c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,L,M,R=e.state;n=e.next_in,L=e.input,i=n+(e.avail_in-5),a=e.next_out,M=e.output,o=a-(r-e.avail_out),s=a+(e.avail_out-257),c=R.dmax,l=R.wsize,d=R.whave,f=R.wnext,u=R.window,h=R.hold,m=R.bits,g=R.lencode,p=R.distcode,y=(1<<R.lenbits)-1,v=(1<<R.distbits)-1;e:do{m<15&&(h+=L[n++]<<m,m+=8,h+=L[n++]<<m,m+=8),x=g[h&y];t:for(;;){if(b=x>>>24,h>>>=b,m-=b,b=x>>>16&255,b===0)M[a++]=x&65535;else if(b&16){_=x&65535,b&=15,b&&(m<b&&(h+=L[n++]<<m,m+=8),_+=h&(1<<b)-1,h>>>=b,m-=b),m<15&&(h+=L[n++]<<m,m+=8,h+=L[n++]<<m,m+=8),x=p[h&v];r:for(;;){if(b=x>>>24,h>>>=b,m-=b,b=x>>>16&255,b&16){if(w=x&65535,b&=15,m<b&&(h+=L[n++]<<m,m+=8,m<b&&(h+=L[n++]<<m,m+=8)),w+=h&(1<<b)-1,w>c){e.msg="invalid distance too far back",R.mode=lc;break e}if(h>>>=b,m-=b,b=a-o,w>b){if(b=w-b,b>d&&R.sane){e.msg="invalid distance too far back",R.mode=lc;break e}if(S=0,E=u,f===0){if(S+=l-b,b<_){_-=b;do M[a++]=u[S++];while(--b);S=a-w,E=M}}else if(f<b){if(S+=l+f-b,b-=f,b<_){_-=b;do M[a++]=u[S++];while(--b);if(S=0,f<_){b=f,_-=b;do M[a++]=u[S++];while(--b);S=a-w,E=M}}}else if(S+=f-b,b<_){_-=b;do M[a++]=u[S++];while(--b);S=a-w,E=M}for(;_>2;)M[a++]=E[S++],M[a++]=E[S++],M[a++]=E[S++],_-=3;_&&(M[a++]=E[S++],_>1&&(M[a++]=E[S++]))}else{S=a-w;do M[a++]=M[S++],M[a++]=M[S++],M[a++]=M[S++],_-=3;while(_>2);_&&(M[a++]=M[S++],_>1&&(M[a++]=M[S++]))}}else if((b&64)===0){x=p[(x&65535)+(h&(1<<b)-1)];continue r}else{e.msg="invalid distance code",R.mode=lc;break e}break}}else if((b&64)===0){x=g[(x&65535)+(h&(1<<b)-1)];continue t}else if(b&32){R.mode=B_;break e}else{e.msg="invalid literal/length code",R.mode=lc;break e}break}}while(n<i&&a<s);_=m>>3,n-=_,m-=_<<3,h&=(1<<m)-1,e.next_in=n,e.next_out=a,e.avail_in=n<i?5+(i-n):5-(n-i),e.avail_out=a<s?257+(s-a):257-(a-s),R.hold=h,R.bits=m},Aa=15,Vm=852,Gm=592,Wm=0,_u=1,Xm=2,k_=new Uint16Array([3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0]),D_=new Uint8Array([16,16,16,16,16,16,16,16,17,17,17,17,18,18,18,18,19,19,19,19,20,20,20,20,21,21,21,21,16,72,78]),z_=new Uint16Array([1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0]),O_=new Uint8Array([16,16,16,16,17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,64,64]),U_=(t,e,r,n,i,a,o,s)=>{let c=s.bits,l=0,d=0,f=0,u=0,h=0,m=0,g=0,p=0,y=0,v=0,x,b,_,w,S,E=null,L,M=new Uint16Array(Aa+1),R=new Uint16Array(Aa+1),I=null,B,F,U;for(l=0;l<=Aa;l++)M[l]=0;for(d=0;d<n;d++)M[e[r+d]]++;for(h=c,u=Aa;u>=1&&M[u]===0;u--);if(h>u&&(h=u),u===0)return i[a++]=1<<24|64<<16|0,i[a++]=1<<24|64<<16|0,s.bits=1,0;for(f=1;f<u&&M[f]===0;f++);for(h<f&&(h=f),p=1,l=1;l<=Aa;l++)if(p<<=1,p-=M[l],p<0)return-1;if(p>0&&(t===Wm||u!==1))return-1;for(R[1]=0,l=1;l<Aa;l++)R[l+1]=R[l]+M[l];for(d=0;d<n;d++)e[r+d]!==0&&(o[R[e[r+d]]++]=d);if(t===Wm?(E=I=o,L=20):t===_u?(E=k_,I=D_,L=257):(E=z_,I=O_,L=0),v=0,d=0,l=f,S=a,m=h,g=0,_=-1,y=1<<h,w=y-1,t===_u&&y>Vm||t===Xm&&y>Gm)return 1;for(;;){B=l-g,o[d]+1<L?(F=0,U=o[d]):o[d]>=L?(F=I[o[d]-L],U=E[o[d]-L]):(F=96,U=0),x=1<<l-g,b=1<<m,f=b;do b-=x,i[S+(v>>g)+b]=B<<24|F<<16|U|0;while(b!==0);for(x=1<<l-1;v&x;)x>>=1;if(x!==0?(v&=x-1,v+=x):v=0,d++,--M[l]===0){if(l===u)break;l=e[r+o[d]]}if(l>h&&(v&w)!==_){for(g===0&&(g=h),S+=f,m=l-g,p=1<<m;m+g<u&&(p-=M[m+g],!(p<=0));)m++,p<<=1;if(y+=1<<m,t===_u&&y>Vm||t===Xm&&y>Gm)return 1;_=v&w,i[_]=h<<24|m<<16|S-a|0}}return v!==0&&(i[S+v]=l-g<<24|64<<16|0),s.bits=h,0},ds=U_,N_=0,H0=1,V0=2,{Z_FINISH:Km,Z_BLOCK:H_,Z_TREES:cc,Z_OK:Ai,Z_STREAM_END:V_,Z_NEED_DICT:G_,Z_STREAM_ERROR:nr,Z_DATA_ERROR:G0,Z_MEM_ERROR:W0,Z_BUF_ERROR:W_,Z_DEFLATED:Ym}=Ei,bc=16180,$m=16181,qm=16182,Zm=16183,jm=16184,Qm=16185,Jm=16186,e0=16187,t0=16188,r0=16189,pc=16190,rn=16191,Su=16192,n0=16193,wu=16194,i0=16195,a0=16196,o0=16197,s0=16198,dc=16199,uc=16200,l0=16201,c0=16202,d0=16203,u0=16204,f0=16205,Mu=16206,h0=16207,m0=16208,be=16209,X0=16210,K0=16211,X_=852,K_=592,Y_=15,$_=Y_,p0=t=>(t>>>24&255)+(t>>>8&65280)+((t&65280)<<8)+((t&255)<<24);function q_(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}var Li=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.mode<bc||e.mode>K0?1:0},Y0=t=>{if(Li(t))return nr;let e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=e.wrap&1),e.mode=bc,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(X_),e.distcode=e.distdyn=new Int32Array(K_),e.sane=1,e.back=-1,Ai},$0=t=>{if(Li(t))return nr;let e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,Y0(t)},q0=(t,e)=>{let r;if(Li(t))return nr;let n=t.state;return e<0?(r=0,e=-e):(r=(e>>4)+5,e<48&&(e&=15)),e&&(e<8||e>15)?nr:(n.window!==null&&n.wbits!==e&&(n.window=null),n.wrap=r,n.wbits=e,$0(t))},Z0=(t,e)=>{if(!t)return nr;let r=new q_;t.state=r,r.strm=t,r.window=null,r.mode=bc;let n=q0(t,e);return n!==Ai&&(t.state=null),n},Z_=t=>Z0(t,$_),g0=!0,Au,Eu,j_=t=>{if(g0){Au=new Int32Array(512),Eu=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(ds(H0,t.lens,0,288,Au,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;ds(V0,t.lens,0,32,Eu,0,t.work,{bits:5}),g0=!1}t.lencode=Au,t.lenbits=9,t.distcode=Eu,t.distbits=5},j0=(t,e,r,n)=>{let i,a=t.state;return a.window===null&&(a.wsize=1<<a.wbits,a.wnext=0,a.whave=0,a.window=new Uint8Array(a.wsize)),n>=a.wsize?(a.window.set(e.subarray(r-a.wsize,r),0),a.wnext=0,a.whave=a.wsize):(i=a.wsize-a.wnext,i>n&&(i=n),a.window.set(e.subarray(r-n,r-n+i),a.wnext),n-=i,n?(a.window.set(e.subarray(r-n,r),0),a.wnext=n,a.whave=a.wsize):(a.wnext+=i,a.wnext===a.wsize&&(a.wnext=0),a.whave<a.wsize&&(a.whave+=i))),0},Q_=(t,e)=>{let r,n,i,a,o,s,c,l,d,f,u,h,m,g,p=0,y,v,x,b,_,w,S,E,L=new Uint8Array(4),M,R,I=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Li(t)||!t.output||!t.input&&t.avail_in!==0)return nr;r=t.state,r.mode===rn&&(r.mode=Su),o=t.next_out,i=t.output,c=t.avail_out,a=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,f=s,u=c,E=Ai;e:for(;;)switch(r.mode){case bc:if(r.wrap===0){r.mode=Su;break}for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.wrap&2&&l===35615){r.wbits===0&&(r.wbits=15),r.check=0,L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0),l=0,d=0,r.mode=$m;break}if(r.head&&(r.head.done=!1),!(r.wrap&1)||(((l&255)<<8)+(l>>8))%31){t.msg="incorrect header check",r.mode=be;break}if((l&15)!==Ym){t.msg="unknown compression method",r.mode=be;break}if(l>>>=4,d-=4,S=(l&15)+8,r.wbits===0&&(r.wbits=S),S>15||S>r.wbits){t.msg="invalid window size",r.mode=be;break}r.dmax=1<<r.wbits,r.flags=0,t.adler=r.check=1,r.mode=l&512?r0:rn,l=0,d=0;break;case $m:for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.flags=l,(r.flags&255)!==Ym){t.msg="unknown compression method",r.mode=be;break}if(r.flags&57344){t.msg="unknown header flags set",r.mode=be;break}r.head&&(r.head.text=l>>8&1),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0)),l=0,d=0,r.mode=qm;case qm:for(;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.head&&(r.head.time=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,L[2]=l>>>16&255,L[3]=l>>>24&255,r.check=Fe(r.check,L,4,0)),l=0,d=0,r.mode=Zm;case Zm:for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.head&&(r.head.xflags=l&255,r.head.os=l>>8),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0)),l=0,d=0,r.mode=jm;case jm:if(r.flags&1024){for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.length=l,r.head&&(r.head.extra_len=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0)),l=0,d=0}else r.head&&(r.head.extra=null);r.mode=Qm;case Qm:if(r.flags&1024&&(h=r.length,h>s&&(h=s),h&&(r.head&&(S=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Uint8Array(r.head.extra_len)),r.head.extra.set(n.subarray(a,a+h),S)),r.flags&512&&r.wrap&4&&(r.check=Fe(r.check,n,h,a)),s-=h,a+=h,r.length-=h),r.length))break e;r.length=0,r.mode=Jm;case Jm:if(r.flags&2048){if(s===0)break e;h=0;do S=n[a+h++],r.head&&S&&r.length<65536&&(r.head.name+=String.fromCharCode(S));while(S&&h<s);if(r.flags&512&&r.wrap&4&&(r.check=Fe(r.check,n,h,a)),s-=h,a+=h,S)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=e0;case e0:if(r.flags&4096){if(s===0)break e;h=0;do S=n[a+h++],r.head&&S&&r.length<65536&&(r.head.comment+=String.fromCharCode(S));while(S&&h<s);if(r.flags&512&&r.wrap&4&&(r.check=Fe(r.check,n,h,a)),s-=h,a+=h,S)break e}else r.head&&(r.head.comment=null);r.mode=t0;case t0:if(r.flags&512){for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.wrap&4&&l!==(r.check&65535)){t.msg="header crc mismatch",r.mode=be;break}l=0,d=0}r.head&&(r.head.hcrc=r.flags>>9&1,r.head.done=!0),t.adler=r.check=0,r.mode=rn;break;case r0:for(;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}t.adler=r.check=p0(l),l=0,d=0,r.mode=pc;case pc:if(r.havedict===0)return t.next_out=o,t.avail_out=c,t.next_in=a,t.avail_in=s,r.hold=l,r.bits=d,G_;t.adler=r.check=1,r.mode=rn;case rn:if(e===H_||e===cc)break e;case Su:if(r.last){l>>>=d&7,d-=d&7,r.mode=Mu;break}for(;d<3;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}switch(r.last=l&1,l>>>=1,d-=1,l&3){case 0:r.mode=n0;break;case 1:if(j_(r),r.mode=dc,e===cc){l>>>=2,d-=2;break e}break;case 2:r.mode=a0;break;case 3:t.msg="invalid block type",r.mode=be}l>>>=2,d-=2;break;case n0:for(l>>>=d&7,d-=d&7;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if((l&65535)!==(l>>>16^65535)){t.msg="invalid stored block lengths",r.mode=be;break}if(r.length=l&65535,l=0,d=0,r.mode=wu,e===cc)break e;case wu:r.mode=i0;case i0:if(h=r.length,h){if(h>s&&(h=s),h>c&&(h=c),h===0)break e;i.set(n.subarray(a,a+h),o),s-=h,a+=h,c-=h,o+=h,r.length-=h;break}r.mode=rn;break;case a0:for(;d<14;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.nlen=(l&31)+257,l>>>=5,d-=5,r.ndist=(l&31)+1,l>>>=5,d-=5,r.ncode=(l&15)+4,l>>>=4,d-=4,r.nlen>286||r.ndist>30){t.msg="too many length or distance symbols",r.mode=be;break}r.have=0,r.mode=o0;case o0:for(;r.have<r.ncode;){for(;d<3;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.lens[I[r.have++]]=l&7,l>>>=3,d-=3}for(;r.have<19;)r.lens[I[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,M={bits:r.lenbits},E=ds(N_,r.lens,0,19,r.lencode,0,r.work,M),r.lenbits=M.bits,E){t.msg="invalid code lengths set",r.mode=be;break}r.have=0,r.mode=s0;case s0:for(;r.have<r.nlen+r.ndist;){for(;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,v=p>>>16&255,x=p&65535,!(y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(x<16)l>>>=y,d-=y,r.lens[r.have++]=x;else{if(x===16){for(R=y+2;d<R;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(l>>>=y,d-=y,r.have===0){t.msg="invalid bit length repeat",r.mode=be;break}S=r.lens[r.have-1],h=3+(l&3),l>>>=2,d-=2}else if(x===17){for(R=y+3;d<R;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=y,d-=y,S=0,h=3+(l&7),l>>>=3,d-=3}else{for(R=y+7;d<R;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=y,d-=y,S=0,h=11+(l&127),l>>>=7,d-=7}if(r.have+h>r.nlen+r.ndist){t.msg="invalid bit length repeat",r.mode=be;break}for(;h--;)r.lens[r.have++]=S}}if(r.mode===be)break;if(r.lens[256]===0){t.msg="invalid code -- missing end-of-block",r.mode=be;break}if(r.lenbits=9,M={bits:r.lenbits},E=ds(H0,r.lens,0,r.nlen,r.lencode,0,r.work,M),r.lenbits=M.bits,E){t.msg="invalid literal/lengths set",r.mode=be;break}if(r.distbits=6,r.distcode=r.distdyn,M={bits:r.distbits},E=ds(V0,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,M),r.distbits=M.bits,E){t.msg="invalid distances set",r.mode=be;break}if(r.mode=dc,e===cc)break e;case dc:r.mode=uc;case uc:if(s>=6&&c>=258){t.next_out=o,t.avail_out=c,t.next_in=a,t.avail_in=s,r.hold=l,r.bits=d,F_(t,u),o=t.next_out,i=t.output,c=t.avail_out,a=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,r.mode===rn&&(r.back=-1);break}for(r.back=0;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,v=p>>>16&255,x=p&65535,!(y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(v&&(v&240)===0){for(b=y,_=v,w=x;p=r.lencode[w+((l&(1<<b+_)-1)>>b)],y=p>>>24,v=p>>>16&255,x=p&65535,!(b+y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=b,d-=b,r.back+=b}if(l>>>=y,d-=y,r.back+=y,r.length=x,v===0){r.mode=f0;break}if(v&32){r.back=-1,r.mode=rn;break}if(v&64){t.msg="invalid literal/length code",r.mode=be;break}r.extra=v&15,r.mode=l0;case l0:if(r.extra){for(R=r.extra;d<R;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.length+=l&(1<<r.extra)-1,l>>>=r.extra,d-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=c0;case c0:for(;p=r.distcode[l&(1<<r.distbits)-1],y=p>>>24,v=p>>>16&255,x=p&65535,!(y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if((v&240)===0){for(b=y,_=v,w=x;p=r.distcode[w+((l&(1<<b+_)-1)>>b)],y=p>>>24,v=p>>>16&255,x=p&65535,!(b+y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=b,d-=b,r.back+=b}if(l>>>=y,d-=y,r.back+=y,v&64){t.msg="invalid distance code",r.mode=be;break}r.offset=x,r.extra=v&15,r.mode=d0;case d0:if(r.extra){for(R=r.extra;d<R;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.offset+=l&(1<<r.extra)-1,l>>>=r.extra,d-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){t.msg="invalid distance too far back",r.mode=be;break}r.mode=u0;case u0:if(c===0)break e;if(h=u-c,r.offset>h){if(h=r.offset-h,h>r.whave&&r.sane){t.msg="invalid distance too far back",r.mode=be;break}h>r.wnext?(h-=r.wnext,m=r.wsize-h):m=r.wnext-h,h>r.length&&(h=r.length),g=r.window}else g=i,m=o-r.offset,h=r.length;h>c&&(h=c),c-=h,r.length-=h;do i[o++]=g[m++];while(--h);r.length===0&&(r.mode=uc);break;case f0:if(c===0)break e;i[o++]=r.length,c--,r.mode=uc;break;case Mu:if(r.wrap){for(;d<32;){if(s===0)break e;s--,l|=n[a++]<<d,d+=8}if(u-=c,t.total_out+=u,r.total+=u,r.wrap&4&&u&&(t.adler=r.check=r.flags?Fe(r.check,i,u,o-u):ps(r.check,i,u,o-u)),u=c,r.wrap&4&&(r.flags?l:p0(l))!==r.check){t.msg="incorrect data check",r.mode=be;break}l=0,d=0}r.mode=h0;case h0:if(r.wrap&&r.flags){for(;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.wrap&4&&l!==(r.total&4294967295)){t.msg="incorrect length check",r.mode=be;break}l=0,d=0}r.mode=m0;case m0:E=V_;break e;case be:E=G0;break e;case X0:return W0;case K0:default:return nr}return t.next_out=o,t.avail_out=c,t.next_in=a,t.avail_in=s,r.hold=l,r.bits=d,(r.wsize||u!==t.avail_out&&r.mode<be&&(r.mode<Mu||e!==Km))&&j0(t,t.output,t.next_out,u-t.avail_out),f-=t.avail_in,u-=t.avail_out,t.total_in+=f,t.total_out+=u,r.total+=u,r.wrap&4&&u&&(t.adler=r.check=r.flags?Fe(r.check,i,u,t.next_out-u):ps(r.check,i,u,t.next_out-u)),t.data_type=r.bits+(r.last?64:0)+(r.mode===rn?128:0)+(r.mode===dc||r.mode===wu?256:0),(f===0&&u===0||e===Km)&&E===Ai&&(E=W_),E},J_=t=>{if(Li(t))return nr;let e=t.state;return e.window&&(e.window=null),t.state=null,Ai},eS=(t,e)=>{if(Li(t))return nr;let r=t.state;return(r.wrap&2)===0?nr:(r.head=e,e.done=!1,Ai)},tS=(t,e)=>{let r=e.length,n,i,a;return Li(t)||(n=t.state,n.wrap!==0&&n.mode!==pc)?nr:n.mode===pc&&(i=1,i=ps(i,e,r,0),i!==n.check)?G0:(a=j0(t,e,r,r),a?(n.mode=X0,W0):(n.havedict=1,Ai))},rS=$0,nS=q0,iS=Y0,aS=Z_,oS=Z0,sS=Q_,lS=J_,cS=eS,dS=tS,uS="pako inflate (from Nodeca project)",an={inflateReset:rS,inflateReset2:nS,inflateResetKeep:iS,inflateInit:aS,inflateInit2:oS,inflate:sS,inflateEnd:lS,inflateGetHeader:cS,inflateSetDictionary:dS,inflateInfo:uS};function fS(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}var hS=fS,Q0=Object.prototype.toString,{Z_NO_FLUSH:mS,Z_FINISH:pS,Z_OK:bs,Z_STREAM_END:Lu,Z_NEED_DICT:Tu,Z_STREAM_ERROR:gS,Z_DATA_ERROR:y0,Z_MEM_ERROR:yS}=Ei;function Ss(t){this.options=yc.assign({chunkSize:1024*64,windowBits:15,to:""},t||{});let e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,e.windowBits===0&&(e.windowBits=-15)),e.windowBits>=0&&e.windowBits<16&&!(t&&t.windowBits)&&(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&(e.windowBits&15)===0&&(e.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new U0,this.strm.avail_out=0;let r=an.inflateInit2(this.strm,e.windowBits);if(r!==bs)throw new Error(wi[r]);if(this.header=new hS,an.inflateGetHeader(this.strm,this.header),e.dictionary&&(typeof e.dictionary=="string"?e.dictionary=ys.string2buf(e.dictionary):Q0.call(e.dictionary)==="[object ArrayBuffer]"&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(r=an.inflateSetDictionary(this.strm,e.dictionary),r!==bs)))throw new Error(wi[r])}Ss.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i=this.options.dictionary,a,o,s;if(this.ended)return!1;for(e===~~e?o=e:o=e===!0?pS:mS,Q0.call(t)==="[object ArrayBuffer]"?r.input=new Uint8Array(t):r.input=t,r.next_in=0,r.avail_in=r.input.length;;){for(r.avail_out===0&&(r.output=new Uint8Array(n),r.next_out=0,r.avail_out=n),a=an.inflate(r,o),a===Tu&&i&&(a=an.inflateSetDictionary(r,i),a===bs?a=an.inflate(r,o):a===y0&&(a=Tu));r.avail_in>0&&a===Lu&&r.state.wrap>0&&t[r.next_in]!==0;)an.inflateReset(r),a=an.inflate(r,o);switch(a){case gS:case y0:case Tu:case yS:return this.onEnd(a),this.ended=!0,!1}if(s=r.avail_out,r.next_out&&(r.avail_out===0||a===Lu))if(this.options.to==="string"){let c=ys.utf8border(r.output,r.next_out),l=r.next_out-c,d=ys.buf2string(r.output,c);r.next_out=l,r.avail_out=n-l,l&&r.output.set(r.output.subarray(c,c+l),0),this.onData(d)}else this.onData(r.output.length===r.next_out?r.output:r.output.subarray(0,r.next_out));if(!(a===bs&&s===0)){if(a===Lu)return a=an.inflateEnd(this.strm),this.onEnd(a),this.ended=!0,!0;if(r.avail_in===0)break}}return!0};Ss.prototype.onData=function(t){this.chunks.push(t)};Ss.prototype.onEnd=function(t){t===bs&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=yc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Wu(t,e){let r=new Ss(e);if(r.push(t),r.err)throw r.msg||wi[r.err];return r.result}function bS(t,e){return e=e||{},e.raw=!0,Wu(t,e)}var xS=Ss,vS=Wu,_S=bS,SS=Wu,wS=Ei,MS={Inflate:xS,inflate:vS,inflateRaw:_S,ungzip:SS,constants:wS},{Deflate:AS,deflate:ES,deflateRaw:LS,gzip:TS}=I_,{Inflate:RS,inflate:CS,inflateRaw:PS,ungzip:IS}=MS,BS=AS,FS=ES,kS=LS,DS=TS,zS=RS,OS=CS,US=PS,NS=IS,HS=Ei,Xu={Deflate:BS,deflate:FS,deflateRaw:kS,gzip:DS,Inflate:zS,inflate:OS,inflateRaw:US,ungzip:NS,constants:HS};var Ia=class Ia{constructor(e=Ia.INITIAL_SIZE){this.buffer=new Uint8Array(e),this.readOffset=0,this.writeOffset=0}append(e){let r=e instanceof Uint8Array?e:new Uint8Array(e),n=this.writeOffset+r.length;n>this.buffer.length&&this.grow(n),this.buffer.set(r,this.writeOffset),this.writeOffset+=r.length}hasBytes(e){return this.writeOffset-this.readOffset>=e}available(){return this.writeOffset-this.readOffset}readByte(){if(!this.hasBytes(1))throw new Error("Buffer underflow");return this.buffer[this.readOffset++]}readShort(){if(!this.hasBytes(2))throw new Error("Buffer underflow");let e=this.buffer[this.readOffset]|this.buffer[this.readOffset+1]<<8;return this.readOffset+=2,e>32767?e-65536:e}readLong(){if(!this.hasBytes(4))throw new Error("Buffer underflow");let e=this.buffer[this.readOffset]|this.buffer[this.readOffset+1]<<8|this.buffer[this.readOffset+2]<<16|this.buffer[this.readOffset+3]<<24;return this.readOffset+=4,e}readFloat(){if(!this.hasBytes(4))throw new Error("Buffer underflow");let r=new DataView(this.buffer.buffer,this.buffer.byteOffset+this.readOffset,4).getFloat32(0,!0);return this.readOffset+=4,r}readString(){let e=Math.min(Ia.MAX_STRING_LENGTH,this.writeOffset-this.readOffset),r=0;for(;r<e&&this.buffer[this.readOffset+r]!==0;)r++;if(r>=e)throw this.writeOffset-this.readOffset<=e?new Error("Buffer underflow"):new Error("String exceeds max length");let n=this.buffer.slice(this.readOffset,this.readOffset+r);return this.readOffset+=r+1,new TextDecoder("latin1").decode(n)}peekBytes(e){if(!this.hasBytes(e))throw new Error("Buffer underflow");return this.buffer.slice(this.readOffset,this.readOffset+e)}readBytes(e){if(!this.hasBytes(e))throw new Error("Buffer underflow");let r=this.buffer.slice(this.readOffset,this.readOffset+e);return this.readOffset+=e,r}readData(e){return this.readBytes(e)}getReadPosition(){return this.readOffset}getWritePosition(){return this.writeOffset}setReadPosition(e){if(e<0||e>this.writeOffset)throw new Error("Invalid read position");this.readOffset=e}grow(e){let r=e?Math.max(e,this.buffer.length*2):this.buffer.length*2,n=new Uint8Array(r);n.set(this.buffer),this.buffer=n}compact(){if(this.readOffset===0)return;let e=this.writeOffset-this.readOffset;if(e===0){this.readOffset=0,this.writeOffset=0;return}this.buffer.copyWithin(0,this.readOffset,this.writeOffset),this.readOffset=0,this.writeOffset=e}getCapacity(){return this.buffer.length}reset(){this.readOffset=0,this.writeOffset=0}};Ia.INITIAL_SIZE=64*1024,Ia.MAX_STRING_LENGTH=2048;var Vn=Ia;var kr=()=>({number:0,modelindex:0,modelindex2:0,modelindex3:0,modelindex4:0,frame:0,skinnum:0,effects:0,renderfx:0,origin:{x:0,y:0,z:0},old_origin:{x:0,y:0,z:0},angles:{x:0,y:0,z:0},sound:0,event:0,solid:0,bits:0,bitsHigh:0,alpha:0,scale:0,instanceBits:0,loopVolume:0,loopAttenuation:0,owner:0,oldFrame:0}),hr=()=>({pm_type:0,origin:{x:0,y:0,z:0},velocity:{x:0,y:0,z:0},pm_time:0,pm_flags:0,gravity:0,delta_angles:{x:0,y:0,z:0},viewoffset:{x:0,y:0,z:0},viewangles:{x:0,y:0,z:0},kick_angles:{x:0,y:0,z:0},gun_index:0,gun_frame:0,gun_offset:{x:0,y:0,z:0},gun_angles:{x:0,y:0,z:0},blend:[0,0,0,0],fov:0,rdflags:0,stats:new Array(32).fill(0),gunskin:0,gunrate:0,damage_blend:[0,0,0,0],team_id:0,watertype:0});var J0={0:T.bad,1:T.nop,2:T.disconnect,3:T.reconnect,4:T.download,5:T.frame,6:T.inventory,7:T.layout,8:T.muzzleflash,9:T.temp_entity,10:T.sound,11:T.print,12:T.stufftext,13:T.serverdata,14:T.configstring,15:T.spawnbaseline,16:T.centerprint,17:T.playerinfo,18:T.packetentities,19:T.deltapacketentities,20:T.muzzleflash2},xc=class{constructor(){this.protocolVersion=34}translateCommand(e){return J0[e]!==void 0?J0[e]:T.bad}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),a=e.readString(),o=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:a,playerNum:o,levelName:s}}parseEntityBits(e){let r=e.readByte();r&gr&&(r|=e.readByte()<<8),r&br&&(r|=e.readByte()<<16),r&xr&&(r|=e.readByte()<<24);let n;return r&Zn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,a,o){r.number=e.number,r.modelindex=e.modelindex,r.modelindex2=e.modelindex2,r.modelindex3=e.modelindex3,r.modelindex4=e.modelindex4,r.frame=e.frame,r.skinnum=e.skinnum,r.effects=e.effects,r.renderfx=e.renderfx,r.origin.x=e.origin.x,r.origin.y=e.origin.y,r.origin.z=e.origin.z,r.old_origin.x=e.origin.x,r.old_origin.y=e.origin.y,r.old_origin.z=e.origin.z,r.angles.x=e.angles.x,r.angles.y=e.angles.y,r.angles.z=e.angles.z,r.sound=e.sound,r.event=e.event,r.solid=e.solid,r.number=n,r.bits=i,i&vt&&(r.modelindex=o.readByte()),i&St&&(r.modelindex2=o.readByte()),i&wt&&(r.modelindex3=o.readByte()),i&Mt&&(r.modelindex4=o.readByte()),i>&&(r.frame=o.readByte()),i&_t&&(r.frame=o.readShort()),i&He&&i&We?r.skinnum=o.readLong():i&He?r.skinnum=o.readByte():i&We&&(r.skinnum=o.readShort()),i&Ne&&i&Ge?r.effects=o.readLong():i&Ne?r.effects=o.readByte():i&Ge&&(r.effects=o.readShort()),i&Ue&&i&Ve?r.renderfx=o.readLong():i&Ue?r.renderfx=o.readByte():i&Ve&&(r.renderfx=o.readShort()),i&ft&&(r.origin.x=o.readShort()*.125),i&ht&&(r.origin.y=o.readShort()*.125),i&bt&&(r.origin.z=o.readShort()*.125),i&xt&&(r.angles.x=o.readByte()*(360/256)),i&mt&&(r.angles.y=o.readByte()*(360/256)),i&pt&&(r.angles.z=o.readByte()*(360/256)),i&sr&&(r.old_origin.x=o.readShort()*.125,r.old_origin.y=o.readShort()*.125,r.old_origin.z=o.readShort()*.125),i&At&&(r.sound=o.readByte()),i&yt?r.event=o.readByte():r.event=0,i&Et&&(r.solid=o.readShort())}parsePlayerState(e){let r=hr(),n=e.readShort();n&1&&(r.pm_type=e.readByte()),n&2&&(r.origin.x=e.readShort()*.125,r.origin.y=e.readShort()*.125,r.origin.z=e.readShort()*.125),n&4&&(r.velocity.x=e.readShort()*.125,r.velocity.y=e.readShort()*.125,r.velocity.z=e.readShort()*.125),n&8&&(r.pm_time=e.readByte()),n&16&&(r.pm_flags=e.readByte()),n&32&&(r.gravity=e.readShort()),n&64&&(r.delta_angles.x=e.readShort()*(180/32768),r.delta_angles.y=e.readShort()*(180/32768),r.delta_angles.z=e.readShort()*(180/32768)),n&128&&(r.viewoffset.x=(e.readByte()<<24>>24)*.25,r.viewoffset.y=(e.readByte()<<24>>24)*.25,r.viewoffset.z=(e.readByte()<<24>>24)*.25),n&256&&(r.viewangles.x=e.readShort()*(360/65536),r.viewangles.y=e.readShort()*(360/65536),r.viewangles.z=e.readShort()*(360/65536)),n&512&&(r.kick_angles.x=(e.readByte()<<24>>24)*.25,r.kick_angles.y=(e.readByte()<<24>>24)*.25,r.kick_angles.z=(e.readByte()<<24>>24)*.25),n&4096&&(r.gun_index=e.readByte()),n&8192&&(r.gun_frame=e.readByte(),r.gun_offset.x=(e.readByte()<<24>>24)*.25,r.gun_offset.y=(e.readByte()<<24>>24)*.25,r.gun_offset.z=(e.readByte()<<24>>24)*.25,r.gun_angles.x=(e.readByte()<<24>>24)*.25,r.gun_angles.y=(e.readByte()<<24>>24)*.25,r.gun_angles.z=(e.readByte()<<24>>24)*.25),n&1024&&(r.blend[0]=e.readByte(),r.blend[1]=e.readByte(),r.blend[2]=e.readByte(),r.blend[3]=e.readByte()),n&2048&&(r.fov=e.readByte()),n&16384&&(r.rdflags=e.readByte()),n&32768&&(r.watertype=e.readByte());let i=e.readLong();for(let a=0;a<32;a++)i&1<<a&&(r.stats[a]=e.readShort());return r}};var Dr=2023,vc=class{constructor(){this.protocolVersion=Dr}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),a=e.readByte(),o=e.readString(),s=e.readShort();if(s===-2){let l=e.readShort();for(let d=0;d<l;d++)e.readShort();s=0}else s===-1&&(s=-1);let c=e.readString();return{protocol:r,serverCount:n,spawnCount:n,attractLoop:0,gameDir:o,playerNum:s,levelName:c,tickRate:a,demoType:i}}parseEntityBits(e){let r=e.readByte();r&gr&&(r|=e.readByte()<<8),r&br&&(r|=e.readByte()<<16),r&xr&&(r|=e.readByte()<<24);let n=0;r&Ii&&(n=e.readByte());let i;return r&Zn?i=e.readShort():i=e.readByte(),{number:i,bits:r,bitsHigh:n}}parseDelta(e,r,n,i,a,o){Object.assign(r,e),r.origin={...e.origin},r.old_origin={...e.old_origin},r.angles={...e.angles},r.number=n,r.bits=i,r.bitsHigh=a,i&vt&&(r.modelindex=o.readByte()),i&St&&(r.modelindex2=o.readByte()),i&wt&&(r.modelindex3=o.readByte()),i&Mt&&(r.modelindex4=o.readByte()),i>&&(r.frame=o.readByte()),i&_t&&(r.frame=o.readShort()),i&He&&i&We?r.skinnum=o.readLong():i&He?r.skinnum=o.readByte():i&We&&(r.skinnum=o.readShort()),i&Ne&&i&Ge?r.effects=o.readLong():i&Ne?r.effects=o.readByte():i&Ge&&(r.effects=o.readShort()),i&Ue&&i&Ve?r.renderfx=o.readLong():i&Ue?r.renderfx=o.readByte():i&Ve&&(r.renderfx=o.readShort()),i&ft&&(r.origin.x=o.readShort()*.125),i&ht&&(r.origin.y=o.readShort()*.125),i&bt&&(r.origin.z=o.readShort()*.125),i&xt&&(r.angles.x=o.readByte()*(360/256)),i&mt&&(r.angles.y=o.readByte()*(360/256)),i&pt&&(r.angles.z=o.readByte()*(360/256)),i&sr&&(r.old_origin.x=o.readShort()*.125,r.old_origin.y=o.readShort()*.125,r.old_origin.z=o.readShort()*.125),i&At&&(r.sound=o.readByte()),i&yt?r.event=o.readByte():r.event=0,i&Et&&(r.solid=o.readShort()),i&yr&&(r.alpha=o.readByte()/255),i&vr&&(r.scale=o.readFloat()),i&_r&&(r.instanceBits=o.readLong()),i&Sr&&(r.loopVolume=o.readByte()/255),a&un&&(r.loopAttenuation=o.readByte()/255),a&fn&&(r.owner=o.readShort()),a&hn&&(r.oldFrame=o.readShort())}parsePlayerState(e){let r=hr(),n=e.readShort();n&1&&(r.pm_type=e.readByte()),n&2&&(r.origin.x=e.readShort()*.125,r.origin.y=e.readShort()*.125,r.origin.z=e.readShort()*.125),n&4&&(r.velocity.x=e.readShort()*.125,r.velocity.y=e.readShort()*.125,r.velocity.z=e.readShort()*.125),n&8&&(r.pm_time=e.readByte()),n&16&&(r.pm_flags=e.readByte()),n&32&&(r.gravity=e.readShort()),n&64&&(r.delta_angles.x=e.readShort()*(180/32768),r.delta_angles.y=e.readShort()*(180/32768),r.delta_angles.z=e.readShort()*(180/32768)),n&128&&(r.viewoffset.x=(e.readByte()<<24>>24)*.25,r.viewoffset.y=(e.readByte()<<24>>24)*.25,r.viewoffset.z=(e.readByte()<<24>>24)*.25),n&256&&(r.viewangles.x=e.readShort()*(360/65536),r.viewangles.y=e.readShort()*(360/65536),r.viewangles.z=e.readShort()*(360/65536)),n&512&&(r.kick_angles.x=(e.readByte()<<24>>24)*.25,r.kick_angles.y=(e.readByte()<<24>>24)*.25,r.kick_angles.z=(e.readByte()<<24>>24)*.25),n&4096&&(r.gun_index=e.readByte()),n&8192&&(r.gun_frame=e.readByte(),r.gun_offset.x=(e.readByte()<<24>>24)*.25,r.gun_offset.y=(e.readByte()<<24>>24)*.25,r.gun_offset.z=(e.readByte()<<24>>24)*.25,r.gun_angles.x=(e.readByte()<<24>>24)*.25,r.gun_angles.y=(e.readByte()<<24>>24)*.25,r.gun_angles.z=(e.readByte()<<24>>24)*.25),n&1024&&(r.blend[0]=e.readByte(),r.blend[1]=e.readByte(),r.blend[2]=e.readByte(),r.blend[3]=e.readByte()),n&2048&&(r.fov=e.readByte()),n&16384&&(r.rdflags=e.readByte()),n&32768&&(r.watertype=e.readByte());let i=e.readLong();for(let a=0;a<32;a++)i&1<<a&&(r.stats[a]=e.readShort());return r}};var _c=class{constructor(e=0){this.protocolVersion=e}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),a=e.readString(),o=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:a,playerNum:o,levelName:s}}parseEntityBits(e){let r=e.readByte();r&gr&&(r|=e.readByte()<<8),r&br&&(r|=e.readByte()<<16),r&xr&&(r|=e.readByte()<<24);let n;return r&Zn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,a,o){r.number=e.number,r.modelindex=e.modelindex,r.modelindex2=e.modelindex2,r.modelindex3=e.modelindex3,r.modelindex4=e.modelindex4,r.frame=e.frame,r.skinnum=e.skinnum,r.effects=e.effects,r.renderfx=e.renderfx,r.origin.x=e.origin.x,r.origin.y=e.origin.y,r.origin.z=e.origin.z,r.old_origin.x=e.origin.x,r.old_origin.y=e.origin.y,r.old_origin.z=e.origin.z,r.angles.x=e.angles.x,r.angles.y=e.angles.y,r.angles.z=e.angles.z,r.sound=e.sound,r.event=e.event,r.solid=e.solid,r.number=n,r.bits=i,i&vt&&(r.modelindex=o.readByte()),i&St&&(r.modelindex2=o.readByte()),i&wt&&(r.modelindex3=o.readByte()),i&Mt&&(r.modelindex4=o.readByte()),i>&&(r.frame=o.readByte()),i&_t&&(r.frame=o.readShort()),i&He&&i&We?r.skinnum=o.readLong():i&He?r.skinnum=o.readByte():i&We&&(r.skinnum=o.readShort()),i&Ne&&i&Ge?r.effects=o.readLong():i&Ne?r.effects=o.readByte():i&Ge&&(r.effects=o.readShort()),i&Ue&&i&Ve?r.renderfx=o.readLong():i&Ue?r.renderfx=o.readByte():i&Ve&&(r.renderfx=o.readShort()),i&ft&&(r.origin.x=o.readShort()*.125),i&ht&&(r.origin.y=o.readShort()*.125),i&bt&&(r.origin.z=o.readShort()*.125),i&xt&&(r.angles.x=o.readByte()*(360/256)),i&mt&&(r.angles.y=o.readByte()*(360/256)),i&pt&&(r.angles.z=o.readByte()*(360/256)),i&sr&&(r.old_origin.x=o.readShort()*.125,r.old_origin.y=o.readShort()*.125,r.old_origin.z=o.readShort()*.125),i&At&&(r.sound=o.readByte()),i&yt?r.event=o.readByte():r.event=0,i&Et&&(r.solid=o.readShort())}parsePlayerState(e){let r=hr(),n=e.readShort();n&1&&(r.pm_type=e.readByte()),n&2&&(r.origin.x=e.readShort()*.125,r.origin.y=e.readShort()*.125,r.origin.z=e.readShort()*.125),n&4&&(r.velocity.x=e.readShort()*.125,r.velocity.y=e.readShort()*.125,r.velocity.z=e.readShort()*.125),n&8&&(r.pm_time=e.readByte()),n&16&&(r.pm_flags=e.readByte()),n&32&&(r.gravity=e.readShort()),n&64&&(r.delta_angles.x=e.readShort()*(180/32768),r.delta_angles.y=e.readShort()*(180/32768),r.delta_angles.z=e.readShort()*(180/32768)),n&128&&(r.viewoffset.x=(e.readByte()<<24>>24)*.25,r.viewoffset.y=(e.readByte()<<24>>24)*.25,r.viewoffset.z=(e.readByte()<<24>>24)*.25),n&256&&(r.viewangles.x=e.readShort()*(360/65536),r.viewangles.y=e.readShort()*(360/65536),r.viewangles.z=e.readShort()*(360/65536)),n&512&&(r.kick_angles.x=(e.readByte()<<24>>24)*.25,r.kick_angles.y=(e.readByte()<<24>>24)*.25,r.kick_angles.z=(e.readByte()<<24>>24)*.25),n&4096&&(r.gun_index=e.readByte()),n&8192&&(r.gun_frame=e.readByte(),r.gun_offset.x=(e.readByte()<<24>>24)*.25,r.gun_offset.y=(e.readByte()<<24>>24)*.25,r.gun_offset.z=(e.readByte()<<24>>24)*.25,r.gun_angles.x=(e.readByte()<<24>>24)*.25,r.gun_angles.y=(e.readByte()<<24>>24)*.25,r.gun_angles.z=(e.readByte()<<24>>24)*.25),n&1024&&(r.blend[0]=e.readByte(),r.blend[1]=e.readByte(),r.blend[2]=e.readByte(),r.blend[3]=e.readByte()),n&2048&&(r.fov=e.readByte()),n&16384&&(r.rdflags=e.readByte()),n&32768&&(r.watertype=e.readByte());let i=e.readLong();for(let a=0;a<32;a++)i&1<<a&&(r.stats[a]=e.readShort());return r}};var ws=class{constructor(){this.protocolVersion=0}translateCommand(e){return e===7?T.serverdata:e===12?T.serverdata:e===13?T.serverdata:e===T.stufftext?T.stufftext:T.bad}parseServerData(e){let r=e.readLong();if(r===Dr){let n=e.readLong(),i=e.readByte(),a=e.readByte(),o=e.readString(),s=e.readShort();if(s===-2){let l=e.readShort();for(let d=0;d<l;d++)e.readShort();s=0}else s===-1&&(s=-1);let c=e.readString();return{protocol:r,serverCount:n,spawnCount:n,attractLoop:0,gameDir:o,playerNum:s,levelName:c,tickRate:a,demoType:i}}else{let n=e.readLong(),i=e.readByte(),a=e.readString(),o=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:a,playerNum:o,levelName:s}}}parseEntityBits(e){throw new Error("Bootstrap handler cannot parse entities")}parseDelta(e,r,n,i,a,o){throw new Error("Bootstrap handler cannot parse delta")}parsePlayerState(e){throw new Error("Bootstrap handler cannot parse player state")}};function ep(t){return t===0?new ws:t===Dr?new vc:t===34?new xc:new _c(t)}var tp=1,VS=2,GS=128,Ku=class extends Vn{constructor(r){super(0);this.stream=r}readByte(){return this.stream.readByte()}readShort(){return this.stream.readShort()}readLong(){return this.stream.readLong()}readFloat(){return this.stream.readFloat()}readString(){return this.stream.readString()}readData(r){return this.stream.readData(r)}hasBytes(r){return this.stream.hasMore()}available(){return this.stream.getRemaining()}getReadPosition(){return this.stream.getPosition()}peekBytes(r){throw new Error("peekBytes not implemented for BinaryStreamAdapter")}},ct=class t{constructor(e,r,n=!1){this.strictMode=!1;this.errorCount=0;this.isDemo=tp;e instanceof mn?this.stream=new Ku(e):this.stream=e,this.handler=r,this.strictMode=n,this.protocolHandler=new ws}setProtocolVersion(e){this.protocolHandler.protocolVersion!==e&&(this.protocolHandler=ep(e))}getProtocolVersion(){return this.protocolHandler.protocolVersion}getErrorCount(){return this.errorCount}parseMessage(){for(;this.stream.hasBytes(1);){let e=this.stream.getReadPosition(),r=-1;try{if(r=this.stream.readByte(),r===-1)break;let n=r,i=this.protocolHandler.translateCommand(r);switch(i){case T.bad:if(n===0)return;let a=`Unknown server command: ${n} (translated: ${i}) at offset ${e} (Protocol: ${this.getProtocolVersion()})`;if(this.strictMode)throw new Error(a);console.warn(a),this.errorCount++;return;case T.nop:break;case T.disconnect:this.handler?.onDisconnect&&this.handler.onDisconnect();break;case T.reconnect:this.handler?.onReconnect&&this.handler.onReconnect();break;case T.print:this.parsePrint();break;case T.serverdata:this.parseServerData();break;case T.configstring:this.parseConfigString();break;case T.spawnbaseline:this.parseSpawnBaseline();break;case T.centerprint:this.parseCenterPrint();break;case T.download:this.parseDownload();break;case T.frame:this.parseFrame();break;case T.packetentities:this.parsePacketEntities(!1);break;case T.deltapacketentities:this.parsePacketEntities(!0);break;case T.playerinfo:this.parsePlayerState();break;case T.stufftext:this.parseStuffText();break;case T.layout:this.parseLayout();break;case T.inventory:this.parseInventory();break;case T.sound:this.parseSound();break;case T.muzzleflash:this.parseMuzzleFlash();break;case T.muzzleflash2:this.parseMuzzleFlash2();break;case T.temp_entity:this.parseTempEntity();break;case T.splitclient:this.parseSplitClient();break;case T.configblast:this.parseConfigBlast();break;case T.spawnbaselineblast:this.parseSpawnBaselineBlast();break;case T.level_restart:this.handler?.onLevelRestart&&this.handler.onLevelRestart();break;case T.damage:this.parseDamage();break;case T.locprint:this.parseLocPrint();break;case T.fog:this.parseFog();break;case T.waitingforplayers:this.parseWaitingForPlayers();break;case T.bot_chat:this.parseBotChat();break;case T.poi:this.parsePoi();break;case T.help_path:this.parseHelpPath();break;case T.muzzleflash3:this.parseMuzzleFlash3();break;case T.achievement:this.parseAchievement();break;default:let o=`Unknown server command: ${n} (translated: ${i}) at offset ${e}`;if(this.strictMode)throw new Error(o);console.warn(o),this.errorCount++;return}}catch(n){let i=n.message;if(i==="Buffer underflow"||i.includes("StreamingBuffer")){try{this.stream.setReadPosition(e)}catch(o){console.error("Failed to rollback stream position",o)}return}let a=`offset ${e}, cmd ${r}, protocol ${this.getProtocolVersion()}`;if(console.warn(`Error parsing command ${r} (${a}): ${i}`),this.errorCount++,this.strictMode)throw n;return}}}readAngle16(){return this.stream.readShort()*(360/65536)}readCoord(){return this.stream.readShort()*.125}readAngle(){return this.stream.readByte()*(360/256)}readPos(e){e.x=this.stream.readShort()*.125,e.y=this.stream.readShort()*.125,e.z=this.stream.readShort()*.125}readDir(e){let r=this.stream.readByte();if(r>=or.length)e.x=0,e.y=0,e.z=0;else{let n=or[r];e.x=n[0],e.y=n[1],e.z=n[2]}}parsePrint(){let e=this.stream.readByte(),r=this.stream.readString();this.handler&&this.handler.onPrint(e,r)}parseStuffText(){let e=this.stream.readString();this.handler&&this.handler.onStuffText(e)}parseLayout(){let e=this.stream.readString();this.handler&&this.handler.onLayout(e)}parseCenterPrint(){let e=this.stream.readString();this.handler&&this.handler.onCenterPrint(e)}parseServerData(){let e=this.protocolHandler.parseServerData(this.stream);this.setProtocolVersion(e.protocol),this.handler&&this.handler.onServerData(e.protocol,e.serverCount,e.attractLoop,e.gameDir,e.playerNum,e.levelName,e.tickRate,e.demoType),e.protocol===Dr?this.isDemo=e.demoType??tp:this.isDemo=e.attractLoop}parseConfigString(){let e=this.stream.readShort(),r=this.stream.readString();this.handler&&this.handler.onConfigString(e,r)}parseSplitClient(){let e=this.stream.readByte();this.handler?.onSplitClient&&this.handler.onSplitClient(e)}parseConfigBlast(){let e=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(e);try{let i=Xu.inflate(n),a=new mn(i.buffer);for(;a.hasMore();){let o=a.readUShort(),s=a.readString();this.handler&&this.handler.onConfigString(o,s)}}catch(i){console.error("svc_configblast error",i)}}parseSpawnBaselineBlast(){let e=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(e);try{let i=Xu.inflate(n),a=new mn(i.buffer),o=new t(a,this.handler,this.strictMode);for(o.setProtocolVersion(this.getProtocolVersion());a.hasMore();)o.parseSpawnBaseline()}catch(i){console.error("svc_spawnbaselineblast error",i)}}parseLocPrint(){let e=this.stream.readByte(),r=this.stream.readString(),n=this.stream.readByte(),i=[];for(let a=0;a<n;a++)i.push(this.stream.readString());this.handler?.onLocPrint&&this.handler.onLocPrint(e,r,i)}parseWaitingForPlayers(){let e=this.stream.readByte();this.handler?.onWaitingForPlayers&&this.handler.onWaitingForPlayers(e)}parseBotChat(){let e=this.stream.readString(),r=this.stream.readShort(),n=this.stream.readString();this.handler?.onBotChat&&this.handler.onBotChat(n)}parsePoi(){let e=this.stream.readShort(),r=this.stream.readShort(),n={x:0,y:0,z:0};this.readPos(n);let i=this.stream.readShort(),a=this.stream.readByte(),o=this.stream.readByte();this.handler?.onPoi&&this.handler.onPoi(o,n)}parseHelpPath(){let e=this.stream.readByte(),r={x:0,y:0,z:0};this.readPos(r);let n={x:0,y:0,z:0};this.readDir(n),this.handler?.onHelpPath&&this.handler.onHelpPath(r)}parseAchievement(){let e=this.stream.readString();this.handler?.onAchievement&&this.handler.onAchievement(e)}parseDownload(){let e=this.stream.readShort(),r=this.stream.readByte(),n;e>0&&(n=this.stream.readData(e)),this.handler&&this.handler.onDownload(e,r,n)}parseInventory(){let r=new Array(256);for(let n=0;n<256;n++)r[n]=this.stream.readShort();this.handler&&this.handler.onInventory(r)}parseSound(){let e=this.stream.readByte(),r=this.stream.readByte(),n,i,a,o,s;if(e&1&&(n=this.stream.readByte()),e&2&&(i=this.stream.readByte()),e&16&&(a=this.stream.readByte()),e&8&&(o=this.stream.readShort()),e&4){let c={x:0,y:0,z:0};this.readPos(c),s=c}this.handler&&this.handler.onSound(e,r,n,i,a,o,s)}parseMuzzleFlash(){let e=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash(e,r)}parseMuzzleFlash2(){let e=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash2(e,r)}parseMuzzleFlash3(){let e=this.stream.readShort(),r=this.stream.readShort();this.handler?.onMuzzleFlash3&&this.handler.onMuzzleFlash3(e,r)}parseFog(){let e=this.stream.readByte();if(e&128){let n=this.stream.readByte();e|=n<<8}let r={};e&1&&(r.density=this.stream.readFloat(),r.skyfactor=this.stream.readByte()),e&2&&(r.red=this.stream.readByte()),e&4&&(r.green=this.stream.readByte()),e&8&&(r.blue=this.stream.readByte()),e&16&&(r.time=this.stream.readShort()),e&32&&(r.hf_falloff=this.stream.readFloat()),e&64&&(r.hf_density=this.stream.readFloat()),e&256&&(r.hf_start_r=this.stream.readByte()),e&512&&(r.hf_start_g=this.stream.readByte()),e&1024&&(r.hf_start_b=this.stream.readByte()),e&2048&&(r.hf_start_dist=this.stream.readLong()),e&4096&&(r.hf_end_r=this.stream.readByte()),e&8192&&(r.hf_end_g=this.stream.readByte()),e&16384&&(r.hf_end_b=this.stream.readByte()),e&32768&&(r.hf_end_dist=this.stream.readLong()),this.handler?.onFog&&this.handler.onFog(r)}parseDamage(){let e=this.stream.readByte(),r=[];for(let n=0;n<e;n++){let i=this.stream.readByte(),a={x:0,y:0,z:0};this.readDir(a);let o=i&31,s=(i&32)!==0,c=(i&64)!==0,l=(i&128)!==0;r.push({damage:o,health:s,armor:c,power:l,dir:a})}this.handler?.onDamage&&this.handler.onDamage(r)}parseTempEntity(){let e=this.stream.readByte(),r={x:0,y:0,z:0},n={x:0,y:0,z:0},i={x:0,y:0,z:0},a,o,s,c,l;switch(e){case D.EXPLOSION1:case D.EXPLOSION2:case D.ROCKET_EXPLOSION:case D.GRENADE_EXPLOSION:case D.ROCKET_EXPLOSION_WATER:case D.GRENADE_EXPLOSION_WATER:case D.BFG_EXPLOSION:case D.BFG_BIGEXPLOSION:case D.BOSSTPORT:case D.PLASMA_EXPLOSION:case D.PLAIN_EXPLOSION:case D.CHAINFIST_SMOKE:case D.TRACKER_EXPLOSION:case D.TELEPORT_EFFECT:case D.DBALL_GOAL:case D.NUKEBLAST:case D.WIDOWSPLASH:case D.EXPLOSION1_BIG:case D.EXPLOSION1_NP:this.readPos(r);break;case D.GUNSHOT:case D.BLOOD:case D.BLASTER:case D.SHOTGUN:case D.SPARKS:case D.BULLET_SPARKS:case D.SCREEN_SPARKS:case D.SHIELD_SPARKS:case D.BLASTER2:case D.FLECHETTE:case D.MOREBLOOD:case D.ELECTRIC_SPARKS:case D.HEATBEAM_SPARKS:case D.HEATBEAM_STEAM:this.readPos(r),this.readDir(i);break;case D.SPLASH:case D.LASER_SPARKS:case D.WELDING_SPARKS:case D.TUNNEL_SPARKS:a=this.stream.readByte(),this.readPos(r),this.readDir(i),o=this.stream.readByte();break;case D.BLUEHYPERBLASTER:this.getProtocolVersion()>=32?(this.readPos(r),this.readPos(n)):(this.readPos(r),this.readDir(i));break;case D.GREENBLOOD:this.getProtocolVersion()>=32?(this.readPos(r),this.readDir(i)):(this.readPos(r),this.readPos(n));break;case D.RAILTRAIL:case D.BUBBLETRAIL:case D.BFG_LASER:case D.DEBUGTRAIL:case D.BUBBLETRAIL2:this.readPos(r),this.readPos(n);break;case D.PARASITE_ATTACK:case D.MEDIC_CABLE_ATTACK:this.stream.readShort(),this.readPos(r),this.readPos(n);break;case D.GRAPPLE_CABLE:s=this.stream.readShort(),this.readPos(r),this.readPos(n),this.readPos(i);break;case D.LIGHTNING:c=this.stream.readShort(),l=this.stream.readShort(),this.readPos(r),this.readPos(n);break;case D.FLASHLIGHT:this.readPos(r),s=this.stream.readShort();break;case D.FORCEWALL:this.readPos(r),this.readPos(n),o=this.stream.readByte();break;case D.STEAM:let d=this.stream.readShort();a=this.stream.readByte(),this.readPos(r),this.readDir(i),o=this.stream.readByte(),this.stream.readShort(),d!==-1&&this.stream.readLong();break;case D.WIDOWBEAMOUT:this.stream.readShort();case D.HEATBEAM:case D.MONSTER_HEATBEAM:s=this.stream.readShort(),this.readPos(r),this.readPos(n),this.readDir(i);break}this.handler&&this.handler.onTempEntity(e,r,n,i,a,o,s,c,l)}parseSpawnBaseline(){let e=this.protocolHandler.parseEntityBits(this.stream),r=kr();this.protocolHandler.parseDelta(kr(),r,e.number,e.bits,e.bitsHigh,this.stream),this.handler&&this.handler.onSpawnBaseline(r)}parseFrame(){let e=this.stream.readLong(),r=this.stream.readLong(),n=0;this.getProtocolVersion()!==26&&this.getProtocolVersion()!==25&&(n=this.stream.readByte());let i=this.stream.readByte(),a=this.stream.readData(i),o=this.stream.readByte();if(o=this.protocolHandler.translateCommand(o),o!==T.playerinfo){if(this.strictMode)throw new Error(`Expected svc_playerinfo after svc_frame, got ${o}`);return}let s=this.parsePlayerState(),c=this.stream.readByte();if(c=this.protocolHandler.translateCommand(c),c!==T.packetentities&&c!==T.deltapacketentities){if(this.strictMode)throw new Error(`Expected svc_packetentities after svc_playerinfo, got ${c}`);return}let l=this.collectPacketEntities();if(this.isDemo===GS){let d=this.stream.readByte();for(let f=0;f<d;f++)this.stream.readByte()}this.isDemo===VS&&this.stream.readLong(),this.handler&&this.handler.onFrame({serverFrame:e,deltaFrame:r,surpressCount:n,areaBytes:i,areaBits:a,playerState:s,packetEntities:{delta:!0,entities:l}})}parsePlayerState(){return this.protocolHandler.parsePlayerState(this.stream)}parsePacketEntities(e){let r=this.collectPacketEntities();this.handler&&this.handler.onFrame({serverFrame:0,deltaFrame:0,surpressCount:0,areaBytes:0,areaBits:new Uint8Array,playerState:hr(),packetEntities:{delta:e,entities:r}})}collectPacketEntities(){let e=[];for(;;){let r=this.protocolHandler.parseEntityBits(this.stream);if(r.bits&Xa){if(r.number===0)break;continue}let n=kr();if(r.number===0)break;this.protocolHandler.parseDelta(kr(),n,r.number,r.bits,r.bitsHigh,this.stream),e.push(n)}return e}};var Yu=(d=>(d.WeaponFire="weapon_fire",d.DamageDealt="damage_dealt",d.DamageReceived="damage_received",d.Pickup="pickup",d.Death="death",d.Kill="kill",d.Spawn="spawn",d.PlayerInfo="player_info",d.Chat="chat",d.Objective="objective",d))(Yu||{});var Ba=class{constructor(e){this.events=[];this.summary={totalKills:0,totalDeaths:0,damageDealt:0,damageReceived:0,weaponUsage:new Map};this.header=null;this.configStrings=new Map;this.serverInfo={};this.statistics=null;this.playerStats=new Map;this.weaponStats=new Map;this.activeEntities=new Set;this.buffer=e}analyze(){let e=new fr(this.buffer),r=-1,n=0,i=.1,a=0,o={onServerData:(s,c,l,d,f,u,h,m)=>{a=s,this.header={protocolVersion:s,gameDir:d,levelName:u,playerNum:f,serverCount:c,spawnCount:c,tickRate:h,demoType:m},h&&h>0&&(i=1/h)},onConfigString:(s,c)=>{this.configStrings.set(s,c),s===0&&this.parseServerInfo(c)},onSpawnBaseline:s=>{},onFrame:s=>{let c=new Set;if(s.packetEntities&&s.packetEntities.entities)for(let l of s.packetEntities.entities)c.add(l.number),this.activeEntities.has(l.number)||this.recordEvent({type:"spawn",frame:r,time:n,entityId:l.number,position:{x:l.origin.x,y:l.origin.y,z:l.origin.z},description:`Entity ${l.number} spawned`});this.activeEntities=c,s.playerState&&this.header},onPrint:(s,c)=>{let l=c.replace(/\n/g," ").trim();l.includes("died")||l.includes("killed")||l.includes("suicide")?(this.summary.totalDeaths++,this.recordEvent({type:"death",frame:r,time:n,description:l})):l.startsWith("You got the ")?this.recordEvent({type:"pickup",frame:r,time:n,description:l}):(s===3||s===2)&&this.recordEvent({type:"chat",frame:r,time:n,description:l,data:{level:s}})},onCenterPrint:s=>{this.recordEvent({type:"objective",frame:r,time:n,description:s.trim()})},onStuffText:()=>{},onSound:()=>{},onTempEntity:()=>{},onLayout:()=>{},onInventory:()=>{},onMuzzleFlash:(s,c)=>{this.handleWeaponFire(s,c,r,n)},onMuzzleFlash2:(s,c)=>{this.handleWeaponFire(s,c,r,n)},onMuzzleFlash3:(s,c)=>{this.handleWeaponFire(s,c,r,n)},onDisconnect:()=>{},onReconnect:()=>{},onDownload:()=>{},onDamage:s=>{for(let c of s)if(this.recordEvent({type:"damage_received",frame:r,time:n,value:c.damage,position:c.dir,description:`Took ${c.damage} damage`}),this.summary.damageReceived+=c.damage,this.header){let l=this.getOrCreatePlayerStats(this.header.playerNum);l.damageReceived+=c.damage}}};for(;e.hasMore();){let s=e.readNextBlock();if(!s)break;r++,n=r*i;let c=new ct(s.data,o);c.setProtocolVersion(a),c.parseMessage(),a=c.getProtocolVersion()}return this.statistics={duration:n,frameCount:r+1,averageFps:(r+1)/(n||1),mapName:this.header?.levelName||"unknown",playerCount:1},{events:this.events,summary:this.summary,header:this.header,configStrings:this.configStrings,serverInfo:this.serverInfo,statistics:this.statistics,playerStats:this.playerStats,weaponStats:this.weaponStats}}handleWeaponFire(e,r,n,i){this.recordEvent({type:"weapon_fire",frame:n,time:i,entityId:e,value:r,description:`Weapon ${r} fired by ${e}`});let a=this.summary.weaponUsage.get(r)||0;this.summary.weaponUsage.set(r,a+1);let o=this.getOrCreateWeaponStat(e,r);o.shotsFired++}recordEvent(e){this.events.push(e)}parseServerInfo(e){let r=e.split("\\");for(let n=1;n<r.length;n+=2)n+1<r.length&&(this.serverInfo[r[n]]=r[n+1])}getOrCreatePlayerStats(e){let r=this.playerStats.get(e);return r||(r={kills:0,deaths:0,damageDealt:0,damageReceived:0,suicides:0},this.playerStats.set(e,r)),r}getOrCreateWeaponStat(e,r){let n=this.weaponStats.get(e);n||(n=[],this.weaponStats.set(e,n));let i=n.find(a=>a.weaponId===r);return i||(i={weaponId:r,shotsFired:0,hits:0,kills:0},n.push(i)),i}};var $u=(i=>(i[i.FirstPerson=0]="FirstPerson",i[i.ThirdPerson=1]="ThirdPerson",i[i.Free=2]="Free",i[i.Follow=3]="Follow",i))($u||{});var Sc=(i=>(i[i.Stopped=0]="Stopped",i[i.Playing=1]="Playing",i[i.Paused=2]="Paused",i[i.Finished=3]="Finished",i))(Sc||{}),WS=()=>({onServerData:()=>{},onConfigString:()=>{},onSpawnBaseline:()=>{},onFrame:()=>{},onCenterPrint:()=>{},onStuffText:()=>{},onPrint:()=>{},onSound:()=>{},onTempEntity:()=>{},onLayout:()=>{},onInventory:()=>{},onMuzzleFlash:()=>{},onMuzzleFlash2:()=>{},onDisconnect:()=>{},onReconnect:()=>{},onDownload:()=>{}}),Ms=class{constructor(){this.reader=null;this.buffer=null;this.state=0;this.playbackSpeed=1;this.currentProtocolVersion=0;this.currentFrameIndex=-1;this.lastFrameData=null;this.accumulatedTime=0;this.frameDuration=100;this.snapshotInterval=100;this.snapshots=new Map;this.cachedEvents=null;this.cachedSummary=null;this.cachedHeader=null;this.cachedConfigStrings=null;this.cachedServerInfo=null;this.cachedStatistics=null;this.cachedPlayerStats=null;this.cachedWeaponStats=null;this.tracker=null;this.cameraMode=0;this.thirdPersonDistance=80;this.thirdPersonOffset={x:0,y:0,z:0}}setHandler(e){this.handler=e}setCallbacks(e){this.callbacks=e}loadDemo(e){this.buffer=e,this.reader=new fr(e),this.transitionState(0),this.accumulatedTime=0,this.currentProtocolVersion=0,this.currentFrameIndex=-1,this.snapshots.clear(),this.lastFrameData=null,this.cachedEvents=null,this.cachedSummary=null,this.cachedHeader=null,this.cachedConfigStrings=null,this.cachedServerInfo=null,this.cachedStatistics=null,this.cachedPlayerStats=null,this.cachedWeaponStats=null}play(){this.reader&&this.state!==1&&this.transitionState(1)}pause(){this.state===1&&this.transitionState(2)}stop(){this.transitionState(0),this.reader&&this.reader.reset(),this.accumulatedTime=0,this.currentProtocolVersion=0,this.currentFrameIndex=-1,this.lastFrameData=null}transitionState(e){this.state!==e&&(this.state=e,this.callbacks?.onPlaybackStateChange&&this.callbacks.onPlaybackStateChange(e))}setFrameDuration(e){this.frameDuration=e}setSpeed(e){this.playbackSpeed=Math.max(.1,Math.min(e,16))}getSpeed(){return this.playbackSpeed}getPlaybackSpeed(){return this.playbackSpeed}getInterpolationFactor(){return this.frameDuration<=0?0:Math.max(0,Math.min(1,this.accumulatedTime/this.frameDuration))}update(e){if(!(this.state!==1||!this.reader))for(this.accumulatedTime+=e*1e3*this.playbackSpeed;this.accumulatedTime>=this.frameDuration;){if(!this.processNextFrame())return;this.accumulatedTime-=this.frameDuration,this.callbacks?.onTimeUpdate&&this.callbacks.onTimeUpdate(this.getCurrentTime())}}stepForward(){this.reader&&(this.processNextFrame(),this.callbacks?.onTimeUpdate&&this.callbacks.onTimeUpdate(this.getCurrentTime()))}stepBackward(){this.reader&&this.currentFrameIndex>0&&this.seek(this.currentFrameIndex-1)}seekToTime(e){let r=this.timeToFrame(e);this.seek(r)}seekToFrame(e){this.seek(e)}frameToTime(e){return e*this.frameDuration/1e3}timeToFrame(e){return Math.floor(e*1e3/this.frameDuration)}playFrom(e){if(e.type==="frame")this.seek(e.frame);else if(e.type==="time")this.seekToTime(e.seconds);else throw new Error(`Invalid offset type: ${e.type}`);this.play()}playRange(e,r){let n=e.type==="frame"?e.frame:this.timeToFrame(e.seconds),i=r.type==="frame"?r.frame:this.timeToFrame(r.seconds),a=this.getTotalFrames(),o=Math.max(0,a-1);if(n<0)throw new Error(`Invalid start offset: ${n}`);if(i<n)throw new Error(`End offset (${i}) cannot be before start offset (${n})`);this.playFrom(e);let s=this.callbacks?.onFrameUpdate,c={...this.callbacks,onFrameUpdate:l=>{if(s&&s(l),this.currentFrameIndex>=i){this.pause();let d=this.callbacks?.onPlaybackComplete;this.callbacks===c&&this.setCallbacks({...this.callbacks,onFrameUpdate:s}),d&&d()}}};this.setCallbacks(c)}seek(e){if(!this.reader)return;let r=this.getTotalFrames();if(r>0&&e>=r&&(e=r-1),e<0&&(e=0),e===this.currentFrameIndex+1){this.processNextFrame(),this.callbacks?.onSeekComplete&&this.callbacks.onSeekComplete();return}if(e===this.currentFrameIndex){this.callbacks?.onSeekComplete&&this.callbacks.onSeekComplete();return}let n=-1,i=null;if(e>this.currentFrameIndex&&this.currentFrameIndex!==-1&&(n=this.currentFrameIndex),this.callbacks?.onRestoreSnapshot)for(let[a,o]of this.snapshots)a<=e&&a>n&&(n=a,i=o);for(n===-1&&this.currentFrameIndex>e?(this.reader.reset(),this.currentFrameIndex=-1,this.currentProtocolVersion=0):n===-1&&(this.reader.reset(),this.currentFrameIndex=-1,this.currentProtocolVersion=0),i&&this.callbacks?.onRestoreSnapshot&&(this.callbacks.onRestoreSnapshot(i),this.reader.seekToMessage(n+1)?this.currentFrameIndex=n:(this.reader.reset(),this.currentFrameIndex=-1,this.currentProtocolVersion=0));this.currentFrameIndex<e&&(this.callbacks?.onCaptureSnapshot&&(this.currentFrameIndex+1)%this.snapshotInterval,!!this.processNextFrame()););this.accumulatedTime=0,this.callbacks?.onSeekComplete&&this.callbacks.onSeekComplete(),this.callbacks?.onTimeUpdate&&this.callbacks.onTimeUpdate(this.getCurrentTime())}processNextFrame(){if(!this.reader||!this.reader.hasMore())return this.transitionState(3),this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),!1;let e=this.reader.readNextBlock();if(!e)return this.transitionState(3),this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),!1;this.currentFrameIndex++,this.tracker&&(this.tracker.setCurrentFrame(this.currentFrameIndex),this.tracker.setCurrentTime(this.getCurrentTime()));try{let r={...this.handler||WS(),onFrame:i=>{this.lastFrameData=i,this.handler?.onFrame&&this.handler.onFrame(i),this.callbacks?.onFrameUpdate&&this.callbacks.onFrameUpdate(i)}},n=new ct(e.data,r);if(n.setProtocolVersion(this.currentProtocolVersion),n.parseMessage(),this.currentProtocolVersion=n.getProtocolVersion(),this.callbacks?.onCaptureSnapshot&&this.currentFrameIndex%this.snapshotInterval===0&&this.currentFrameIndex>0){let i=this.callbacks.onCaptureSnapshot(this.currentFrameIndex);i&&this.snapshots.set(this.currentFrameIndex,i)}}catch(r){return console.error("Error processing demo frame",r),this.callbacks?.onPlaybackError&&this.callbacks.onPlaybackError(r instanceof Error?r:new Error(String(r))),!1}return!0}getState(){return this.state}getCurrentTime(){return this.currentFrameIndex<0?this.accumulatedTime/1e3:(this.currentFrameIndex*this.frameDuration+this.accumulatedTime)/1e3}getFrameCount(){return this.reader?this.reader.getMessageCount():0}getTotalFrames(){return this.getFrameCount()}getCurrentFrame(){return this.currentFrameIndex<0?0:this.currentFrameIndex}getDuration(){return this.getFrameCount()*this.frameDuration/1e3}getTotalBytes(){return this.reader?this.reader.getProgress().total:0}getProcessedBytes(){return this.reader?this.reader.getOffset():0}getFrameData(e){if(e===this.currentFrameIndex&&this.lastFrameData)return this.lastFrameData;let r=this.state;return this.pause(),this.seek(e),r===1&&this.play(),this.lastFrameData}getFramePlayerState(e){if(e===this.currentFrameIndex&&this.handler?.getPlayerState){let n=this.handler.getPlayerState();if(n)return n}let r=this.getFrameData(e);return r?r.playerState:null}getFrameEntities(e){if(e===this.currentFrameIndex&&this.handler?.getEntities){let r=this.handler.getEntities();if(r)return Array.from(r.values())}if(this.seek(e),this.handler?.getEntities){let r=this.handler.getEntities();return r?Array.from(r.values()):[]}return[]}compareFrames(e,r){let n=this.getFramePlayerState(e),i=this.getFrameEntities(e),a=new Map;i.forEach(d=>a.set(d.number,d));let o=this.getFramePlayerState(r),s=this.getFrameEntities(r),c=new Map;s.forEach(d=>c.set(d.number,d));let l={frameA:e,frameB:r,playerStateDiff:{origin:null,viewangles:null,health:null,ammo:null},entityDiffs:{added:[],removed:[],moved:[]}};n&&o&&((n.origin.x!==o.origin.x||n.origin.y!==o.origin.y||n.origin.z!==o.origin.z)&&(l.playerStateDiff.origin={x:o.origin.x-n.origin.x,y:o.origin.y-n.origin.y,z:o.origin.z-n.origin.z}),n.stats[1]!==o.stats[1]&&(l.playerStateDiff.health=o.stats[1]-n.stats[1]),n.stats[2]!==o.stats[2]&&(l.playerStateDiff.ammo=o.stats[2]-n.stats[2]));for(let[d,f]of c){let u=a.get(d);u?(u.origin.x!==f.origin.x||u.origin.y!==f.origin.y||u.origin.z!==f.origin.z)&&l.entityDiffs.moved.push({id:d,delta:{x:f.origin.x-u.origin.x,y:f.origin.y-u.origin.y,z:f.origin.z-u.origin.z}}):l.entityDiffs.added.push(d)}for(let[d,f]of a)c.has(d)||l.entityDiffs.removed.push(d);return l}getEntityTrajectory(e,r,n){let i=[],a=this.getCurrentFrame();for(this.seek(r);this.getCurrentFrame()<=n&&this.state!==3;){let o=null;if(e===-1){let s=this.getFramePlayerState(this.getCurrentFrame());s&&(o={...s.origin})}else if(this.handler?.getEntities){let s=this.handler.getEntities().get(e);s&&(o={...s.origin})}if(o&&i.push(o),this.getCurrentFrame()===n)break;this.stepForward()}return this.seek(a),i}getEvents(){return this.ensureAnalysis(),this.cachedEvents||[]}getDemoEvents(){return this.getEvents()}filterEvents(e,r){return this.getDemoEvents().filter(i=>!(i.type!==e||r!==void 0&&i.entityId!==r))}getEventSummary(){return this.ensureAnalysis(),this.cachedSummary||{totalKills:0,totalDeaths:0,damageDealt:0,damageReceived:0,weaponUsage:new Map}}getMetadata(){let e=this.getDemoHeader();if(!e)return null;let r=this.getDemoServerInfo(),n="Unknown";return this.cachedConfigStrings,{mapName:e.levelName,playerName:n,serverName:r.hostname,demoVersion:e.protocolVersion,tickRate:e.tickRate||10}}getDemoHeader(){return this.ensureAnalysis(),this.cachedHeader}getDemoConfigStrings(){return this.ensureAnalysis(),this.cachedConfigStrings||new Map}getDemoServerInfo(){return this.ensureAnalysis(),this.cachedServerInfo||{}}getDemoStatistics(){return this.ensureAnalysis(),this.cachedStatistics}getPlayerStatistics(e){return this.ensureAnalysis(),this.cachedPlayerStats?.get(e)||null}getWeaponStatistics(e){return this.ensureAnalysis(),this.cachedWeaponStats?.get(e)||null}ensureAnalysis(){if(!this.cachedEvents&&this.buffer){let r=new Ba(this.buffer).analyze();this.cachedEvents=r.events,this.cachedSummary=r.summary,this.cachedHeader=r.header,this.cachedConfigStrings=r.configStrings,this.cachedServerInfo=r.serverInfo,this.cachedStatistics=r.statistics,this.cachedPlayerStats=r.playerStats,this.cachedWeaponStats=r.weaponStats}}setCameraMode(e){this.cameraMode=e}getCameraMode(){return this.cameraMode}setThirdPersonDistance(e){this.thirdPersonDistance=e}setThirdPersonOffset(e){this.thirdPersonOffset=e}async playWithTracking(e,r={}){if(this.tracker=e,e.startTracking(),r.fastForward)try{this.state===0&&this.reader,this.transitionState(1);let n=100,i=async()=>{if(this.state!==1)throw new Error("Playback stopped unexpectedly during fast forward");let a=0;for(;a<n;){if(!this.processNextFrame()){this.transitionState(0);let o=e.stopTracking();return this.tracker=null,this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),o}a++}return await new Promise(o=>setTimeout(o,0)),i()};return await i()}catch(n){throw this.transitionState(0),e.stopTracking(),this.tracker=null,n}else return new Promise((n,i)=>{let a=this.callbacks?.onPlaybackComplete,o=this.callbacks?.onPlaybackError,s=()=>{this.setCallbacks({...this.callbacks,onPlaybackComplete:a,onPlaybackError:o}),this.tracker=null};this.setCallbacks({...this.callbacks,onPlaybackComplete:()=>{let c=e.stopTracking();a&&a(),s(),n(c)},onPlaybackError:c=>{e.stopTracking(),o&&o(c),s(),i(c)}}),this.play()})}async playRangeWithTracking(e,r,n,i={}){this.tracker=n,n.startTracking();let a=e.type==="frame"?e.frame:this.timeToFrame(e.seconds),o=r.type==="frame"?r.frame:this.timeToFrame(r.seconds);if(i.fastForward)try{this.playFrom(e),this.transitionState(1);let s=100,c=async()=>{if(this.state!==1)throw new Error("Playback stopped unexpectedly during fast forward");let l=0;for(;l<s;){if(this.currentFrameIndex>=o||!this.processNextFrame()){this.transitionState(0);let d=n.stopTracking();return this.tracker=null,this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),d}l++}return await new Promise(d=>setTimeout(d,0)),c()};return await c()}catch(s){throw this.transitionState(0),n.stopTracking(),this.tracker=null,s}else return new Promise((s,c)=>{let l=this.callbacks?.onPlaybackComplete,d=this.callbacks?.onPlaybackError,f=()=>{this.setCallbacks({...this.callbacks,onPlaybackComplete:l,onPlaybackError:d}),this.tracker=null};this.setCallbacks({...this.callbacks,onPlaybackComplete:()=>{let u=n.stopTracking();l&&l(),f(),s(u)},onPlaybackError:u=>{n.stopTracking(),d&&d(u),f(),c(u)}}),this.playRange(e,r)})}};var As=class{constructor(){this.isRecording=!1;this.startTime=0;this.frameCount=0;this.filename=null;this.lastMessageSize=-1;this.messageBuffer=new jn(1024*1024)}startRecording(e,r=0){this.isRecording||(this.isRecording=!0,this.filename=e,this.startTime=r,this.frameCount=0,this.messageBuffer.reset(),console.log(`DemoRecorder: Started recording to ${e}`))}recordMessage(e){if(this.isRecording){this.messageBuffer.writeLong(e.byteLength);for(let r=0;r<e.length;r++)this.messageBuffer.writeByte(e[r]);this.frameCount++}}stopRecording(){return this.isRecording?(this.isRecording=!1,this.messageBuffer.writeLong(-1),console.log(`DemoRecorder: Stopped recording. Frames: ${this.frameCount}, Size: ${this.messageBuffer.getOffset()} bytes`),this.messageBuffer.getData()):null}getIsRecording(){return this.isRecording}};var wc=class{constructor(e,r=34){this.writer=e||new jn(new Uint8Array(64*1024)),this.protocol=r}getData(){return this.writer.getData()}getOpcode(e){if(this.protocol===34)switch(e){case T.serverdata:return 13;case T.frame:return 5;case T.playerinfo:return 17;case T.packetentities:return 18;case T.deltapacketentities:return 19;case T.print:return 11;case T.centerprint:return 16;case T.stufftext:return 12;case T.sound:return 10;case T.temp_entity:return 9;case T.configstring:return 14;case T.spawnbaseline:return 15;case T.layout:return 7;case T.inventory:return 6;case T.muzzleflash:return 8;case T.muzzleflash2:return 20}return e}writeCommand(e,r){let n=r??this.protocol;n===34||n===0?this.writer.writeByte(this.getOpcode(e)):this.writer.writeByte(e)}writeServerData(e,r,n,i,a,o){this.writeCommand(T.serverdata),this.writer.writeLong(e),this.writer.writeLong(r),this.writer.writeByte(n),this.writer.writeString(i),this.writer.writeShort(a),this.writer.writeString(o)}writeConfigString(e,r){this.writeCommand(T.configstring),this.writer.writeShort(e),this.writer.writeString(r)}writeStuffText(e){this.writeCommand(T.stufftext),this.writer.writeString(e)}writeCenterPrint(e){this.writeCommand(T.centerprint),this.writer.writeString(e)}writePrint(e,r){this.writeCommand(T.print),this.writer.writeByte(e),this.writer.writeString(r)}writeLayout(e){this.writeCommand(T.layout),this.writer.writeString(e)}writeInventory(e){this.writeCommand(T.inventory);for(let r of e)this.writer.writeShort(r);for(let r=e.length;r<256;r++)this.writer.writeShort(0)}writeMuzzleFlash(e,r){this.writeCommand(T.muzzleflash),this.writer.writeShort(e),this.writer.writeByte(r)}writeMuzzleFlash2(e,r){this.writeCommand(T.muzzleflash2),this.writer.writeShort(e),this.writer.writeByte(r)}writeSound(e,r,n,i,a,o,s,c){this.writeCommand(T.sound),this.writer.writeByte(e),this.writer.writeByte(r),e&1&&this.writer.writeByte(n),e&2&&this.writer.writeByte(i),e&16&&this.writer.writeByte(a),e&8&&this.writer.writeShort(o),e&4&&(this.writer.writeCoord(s.x),this.writer.writeCoord(s.y),this.writer.writeCoord(s.z))}writeTempEntity(e,r,n,i,a,o,s,c,l){this.writeCommand(T.temp_entity),this.writer.writeByte(e),r&&this.writer.writePos(r)}writePlayerState(e){this.writeCommand(T.playerinfo);let r=0;e.pm_type!==0&&(r|=1),(e.origin.x!==0||e.origin.y!==0||e.origin.z!==0)&&(r|=2),(e.velocity.x!==0||e.velocity.y!==0||e.velocity.z!==0)&&(r|=4),e.pm_time!==0&&(r|=8),e.pm_flags!==0&&(r|=16),e.gravity!==0&&(r|=32),(e.delta_angles.x!==0||e.delta_angles.y!==0||e.delta_angles.z!==0)&&(r|=64),(e.viewoffset.x!==0||e.viewoffset.y!==0||e.viewoffset.z!==0)&&(r|=128),(e.viewangles.x!==0||e.viewangles.y!==0||e.viewangles.z!==0)&&(r|=256),(e.kick_angles.x!==0||e.kick_angles.y!==0||e.kick_angles.z!==0)&&(r|=512),e.gun_index!==0&&(r|=4096),(e.gun_frame!==0||e.gun_offset.x!==0||e.gun_offset.y!==0||e.gun_offset.z!==0||e.gun_angles.x!==0||e.gun_angles.y!==0||e.gun_angles.z!==0)&&(r|=8192),(e.blend[0]!==0||e.blend[1]!==0||e.blend[2]!==0||e.blend[3]!==0)&&(r|=1024),e.fov!==0&&(r|=2048),e.rdflags!==0&&(r|=16384),e.watertype!==0&&(r|=32768),this.writer.writeShort(r),r&1&&this.writer.writeByte(e.pm_type),r&2&&(this.writer.writeShort(e.origin.x/.125),this.writer.writeShort(e.origin.y/.125),this.writer.writeShort(e.origin.z/.125)),r&4&&(this.writer.writeShort(e.velocity.x/.125),this.writer.writeShort(e.velocity.y/.125),this.writer.writeShort(e.velocity.z/.125)),r&8&&this.writer.writeByte(e.pm_time),r&16&&this.writer.writeByte(e.pm_flags),r&32&&this.writer.writeShort(e.gravity),r&64&&(this.writer.writeShort(e.delta_angles.x/(180/32768)),this.writer.writeShort(e.delta_angles.y/(180/32768)),this.writer.writeShort(e.delta_angles.z/(180/32768))),r&128&&(this.writer.writeByte(e.viewoffset.x/.25),this.writer.writeByte(e.viewoffset.y/.25),this.writer.writeByte(e.viewoffset.z/.25)),r&256&&(this.writer.writeShort(e.viewangles.x/(360/65536)),this.writer.writeShort(e.viewangles.y/(360/65536)),this.writer.writeShort(e.viewangles.z/(360/65536))),r&512&&(this.writer.writeByte(e.kick_angles.x/.25),this.writer.writeByte(e.kick_angles.y/.25),this.writer.writeByte(e.kick_angles.z/.25)),r&4096&&this.writer.writeByte(e.gun_index),r&8192&&(this.writer.writeByte(e.gun_frame),this.writer.writeByte(e.gun_offset.x/.25),this.writer.writeByte(e.gun_offset.y/.25),this.writer.writeByte(e.gun_offset.z/.25),this.writer.writeByte(e.gun_angles.x/.25),this.writer.writeByte(e.gun_angles.y/.25),this.writer.writeByte(e.gun_angles.z/.25)),r&1024&&(this.writer.writeByte(e.blend[0]),this.writer.writeByte(e.blend[1]),this.writer.writeByte(e.blend[2]),this.writer.writeByte(e.blend[3])),r&2048&&this.writer.writeByte(e.fov),r&16384&&this.writer.writeByte(e.rdflags),r&32768&&this.writer.writeByte(e.watertype);let n=0;for(let i=0;i<32;i++)e.stats[i]!==0&&(n|=1<<i);this.writer.writeLong(n);for(let i=0;i<32;i++)n&1<<i&&this.writer.writeShort(e.stats[i])}writePacketEntities(e,r,n){this.writeCommand(r?T.deltapacketentities:T.packetentities);for(let i of e)this.writeDeltaEntity(kr(),i,!0);this.writer.writeShort(0)}writeFrame(e,r){this.writeCommand(T.frame),this.writer.writeLong(e.serverFrame),this.writer.writeLong(e.deltaFrame),r!==26&&r!==25&&this.writer.writeByte(e.surpressCount),this.writer.writeByte(e.areaBytes),this.writer.writeBytes(e.areaBits),this.writePlayerState(e.playerState),this.writePacketEntities(e.packetEntities.entities,e.packetEntities.delta,r)}writeDeltaEntity(e,r,n){let i=0,a=0;(r.modelindex!==e.modelindex||n)&&(i|=vt),(r.modelindex2!==e.modelindex2||n)&&(i|=St),(r.modelindex3!==e.modelindex3||n)&&(i|=wt),(r.modelindex4!==e.modelindex4||n)&&(i|=Mt),(r.frame!==e.frame||n)&&(r.frame>=256?i|=_t:i|=gt),(r.skinnum!==e.skinnum||n)&&(r.skinnum>=256?i|=We:i|=He),(r.effects!==e.effects||n)&&(r.effects>=256?i|=Ge:i|=Ne),(r.renderfx!==e.renderfx||n)&&(r.renderfx>=256?i|=Ve:i|=Ue),(r.origin.x!==e.origin.x||n)&&r.origin.x!==0&&(i|=ft),(r.origin.y!==e.origin.y||n)&&r.origin.y!==0&&(i|=ht),(r.origin.z!==e.origin.z||n)&&r.origin.z!==0&&(i|=bt),(r.angles.x!==e.angles.x||n)&&r.angles.x!==0&&(i|=xt),(r.angles.y!==e.angles.y||n)&&r.angles.y!==0&&(i|=mt),(r.angles.z!==e.angles.z||n)&&r.angles.z!==0&&(i|=pt),(r.sound!==e.sound||n)&&(i|=At),(r.event!==e.event||n)&&(i|=yt),(r.solid!==e.solid||n)&&(i|=Et),this.protocol!==34&&((r.alpha!==e.alpha||n)&&(i|=yr),(r.scale!==e.scale||n)&&(i|=vr),(r.instanceBits!==e.instanceBits||n)&&(i|=_r),(r.loopVolume!==e.loopVolume||n)&&(i|=Sr),(r.loopAttenuation!==e.loopAttenuation||n)&&(a|=un),(r.owner!==e.owner||n)&&(a|=fn),(r.oldFrame!==e.oldFrame||n)&&(a|=hn)),a>0&&(i|=Ii),i&4278190080&&(i|=xr),i&4294901760&&(i|=br),i&4294967040&&(i|=gr),this.writer.writeByte(i&255),i&gr&&this.writer.writeByte(i>>8&255),i&br&&this.writer.writeByte(i>>16&255),i&xr&&this.writer.writeByte(i>>24&255),i&Ii&&this.writer.writeByte(a&255),r.number>=256?this.writer.writeShort(r.number):this.writer.writeByte(r.number),i&vt&&this.writer.writeByte(r.modelindex),i&St&&this.writer.writeByte(r.modelindex2),i&wt&&this.writer.writeByte(r.modelindex3),i&Mt&&this.writer.writeByte(r.modelindex4),i>&&this.writer.writeByte(r.frame),i&_t&&this.writer.writeShort(r.frame),i&He&&this.writer.writeByte(r.skinnum),i&We&&this.writer.writeShort(r.skinnum),i&Ne&&this.writer.writeByte(r.effects),i&Ge&&this.writer.writeShort(r.effects),i&Ue&&this.writer.writeByte(r.renderfx),i&Ve&&this.writer.writeShort(r.renderfx),i&ft&&this.writer.writeCoord(r.origin.x),i&ht&&this.writer.writeCoord(r.origin.y),i&bt&&this.writer.writeCoord(r.origin.z),i&xt&&this.writer.writeAngle(r.angles.x),i&mt&&this.writer.writeAngle(r.angles.y),i&pt&&this.writer.writeAngle(r.angles.z),i&At&&this.writer.writeByte(r.sound??0),i&yt&&this.writer.writeByte(r.event??0),i&Et&&this.writer.writeShort(r.solid),this.protocol!==34&&(i&yr&&this.writer.writeByte(r.alpha*255),i&vr&&this.writer.writeFloat(r.scale),i&_r&&this.writer.writeLong(r.instanceBits),i&Sr&&this.writer.writeByte(r.loopVolume*255),a&un&&this.writer.writeByte(r.loopAttenuation*255),a&fn&&this.writer.writeShort(r.owner),a&hn&&this.writer.writeShort(r.oldFrame))}};var Mc=class{static validate(e,r){if(r&&!r.toLowerCase().endsWith(".dm2"))return{valid:!1,error:"Invalid file extension (expected .dm2)"};if(e.byteLength<5)return{valid:!1,error:"File too small to be a valid demo"};let n=new DataView(e),i=n.getInt32(0,!0);if(i<=0||i>e.byteLength-4)return{valid:!1,error:`Invalid first block length: ${i}`};let a=n.getUint8(4);if(a!==T.serverdata)return{valid:!1,error:`First command is not svc_serverdata (expected ${T.serverdata}, got ${a})`};let o=-1;return i>=5&&(o=n.getInt32(5,!0)),{valid:!0,version:o}}};var Ac=class{constructor(e){this.frames=[];this.configStrings=new Map;this.baselines=new Map;this.currentEntities=new Map;if(e){let r=new Vn(e.byteLength);r.append(new Uint8Array(e)),r.setReadPosition(0),this.parser=new ct(r,this)}else this.parser=new ct(new Vn,this)}extractClip(e,r,n,i){let a=new fr(e.buffer),o=[],s=0,c=r.frame??-1,l=n.frame??Number.MAX_SAFE_INTEGER,d=0,f=0;for(;a.nextBlock();){let p=a.getBlock().data,y=!1,v=-1,x=!1,b={onServerData:S=>{d=S,y=!0,x=!0},onConfigString:()=>{y=!0,x=!0},onSpawnBaseline:()=>{y=!0,x=!0},onFrame:S=>{v=S.serverFrame,x=!0,v>=c&&v<=l&&(y=!0)},onCenterPrint:()=>{x=!0},onStuffText:()=>{x=!0},onPrint:()=>{x=!0},onSound:()=>{x=!0},onTempEntity:()=>{x=!0},onLayout:()=>{x=!0},onInventory:()=>{x=!0},onMuzzleFlash:()=>{x=!0},onMuzzleFlash2:()=>{x=!0},onDisconnect:()=>{x=!0},onReconnect:()=>{x=!0},onDownload:()=>{x=!0}},_=new Vn(p.getLength());_.append(p.readData(p.getLength())),_.setReadPosition(0),p.seek(0);let w=new ct(_,b);d>0&&w.setProtocolVersion(d);try{w.parseMessage()}catch{}if(x||f>=c&&f<=l&&(y=!0),y){let S=new Uint8Array(4);new DataView(S.buffer).setUint32(0,p.getLength(),!0),o.push(S);let L=p.readData(p.getLength());o.push(L),s+=4+L.length}f++}let u=new Uint8Array(4);new DataView(u.buffer).setInt32(0,-1,!0),o.push(u),s+=4;let h=new Uint8Array(s),m=0;for(let g of o)h.set(g,m),m+=g.length;return h}extractDemoRange(e,r,n){return this.extractClip(e,{frame:r},{frame:n})}onServerData(e,r,n,i,a,o){this.serverData={protocol:e,serverCount:r,attractLoop:n,gameDir:i,playerNum:a,levelName:o}}onConfigString(e,r){this.configStrings.set(e,r)}onSpawnBaseline(e){this.baselines.set(e.number,e)}onFrame(e){this.frames.push(e)}onCenterPrint(e){}onStuffText(e){}onPrint(e,r){}onSound(e,r,n,i,a,o,s){}onTempEntity(e,r,n,i,a,o,s,c,l){}onLayout(e){}onInventory(e){}onMuzzleFlash(e,r){}onMuzzleFlash2(e,r){}onDisconnect(){}onReconnect(){}onDownload(e,r,n){}};function rp(t,e){let r=e.bits;t.bits=r,t.number=e.number,r&vt&&(t.modelindex=e.modelindex),r&St&&(t.modelindex2=e.modelindex2),r&wt&&(t.modelindex3=e.modelindex3),r&Mt&&(t.modelindex4=e.modelindex4),r>&&(t.frame=e.frame),r&_t&&(t.frame=e.frame),r&He&&(t.skinnum=e.skinnum),r&We&&(t.skinnum=e.skinnum),r&Ne&&(t.effects=e.effects),r&Ge&&(t.effects=e.effects),r&Ue&&(t.renderfx=e.renderfx),r&Ve&&(t.renderfx=e.renderfx),r&ft&&(t.origin.x=e.origin.x),r&ht&&(t.origin.y=e.origin.y),r&bt&&(t.origin.z=e.origin.z),r&xt&&(t.angles.x=e.angles.x),r&mt&&(t.angles.y=e.angles.y),r&pt&&(t.angles.z=e.angles.z),r&sr&&(t.old_origin.x=e.old_origin.x,t.old_origin.y=e.old_origin.y,t.old_origin.z=e.old_origin.z),r&At&&(t.sound=e.sound),r&yt&&(t.event=e.event),r&Et&&(t.solid=e.solid),r&yr&&(t.alpha=e.alpha),r&vr&&(t.scale=e.scale),r&_r&&(t.instanceBits=e.instanceBits),r&Sr&&(t.loopVolume=e.loopVolume)}var qu=(u=>(u.Unknown="unknown",u.BSP="bsp",u.MD2="md2",u.MD3="md3",u.WAL="wal",u.PCX="pcx",u.TGA="tga",u.WAV="wav",u.OGG="ogg",u.TXT="txt",u.CFG="cfg",u.DEM="dem",u))(qu||{}),np={".bsp":"bsp",".md2":"md2",".md3":"md3",".wal":"wal",".pcx":"pcx",".tga":"tga",".wav":"wav",".ogg":"ogg",".txt":"txt",".cfg":"cfg",".dm2":"dem"};function Es(t,e){if(t.length<e.length)return!1;for(let r=0;r<e.length;r++)if(t[r]!==e[r])return!1;return!0}var XS=[73,66,83,80],KS=[73,68,80,50],YS=[73,68,80,51];var $S=[82,73,70,70];var qS=[79,103,103,83];function Zu(t,e){let r=t.slice(t.lastIndexOf(".")).toLowerCase();if(e){if(Es(e,XS))return"bsp";if(Es(e,KS))return"md2";if(Es(e,YS))return"md3";if(Es(e,qS))return"ogg";if(e.length>128&&e[0]===10&&e[1]<6)return"pcx";if(Es(e,$S)&&e.length>=12&&e[8]===87&&e[9]===65&&e[10]===86&&e[11]===69)return"wav"}return np[r]?np[r]:"unknown"}function ju(t){let e=Zu(t);return e==="txt"||e==="cfg"}function ip(t){return!ju(t)}function ZS(t,e,r,n,i){let a=new Uint8ClampedArray(n*i*4),o=e/n,s=r/i;for(let c=0;c<i;c++)for(let l=0;l<n;l++){let d=l*o,f=c*s,u=Math.floor(d),h=Math.floor(f),m=d-u,g=f-h,p=Math.min(u+1,e-1),y=Math.min(h+1,r-1),v=(h*e+u)*4,x=(h*e+p)*4,b=(y*e+u)*4,_=(y*e+p)*4,w=(c*n+l)*4;for(let S=0;S<4;S++){let E=t[v+S],L=t[x+S],M=t[b+S],R=t[_+S],I=E*(1-m)+L*m,B=M*(1-m)+R*m,F=I*(1-g)+B*g;a[w+S]=F}}return a}function jS(t,e,r,n,i,a,o,s,c,l,d){n=Math.floor(n),i=Math.floor(i),a=Math.floor(a),o=Math.floor(o);let f=Math.abs(a-n),u=Math.abs(o-i),h=n<a?1:-1,m=i<o?1:-1,g=f-u;for(;;){if(n>=0&&n<e&&i>=0&&i<r){let y=(i*e+n)*4,v=1-d/255;t[y]=s*(d/255)+t[y]*v,t[y+1]=c*(d/255)+t[y+1]*v,t[y+2]=l*(d/255)+t[y+2]*v,t[y+3]=255}if(n===a&&i===o)break;let p=2*g;p>-u&&(g-=u,n+=h),p<f&&(g+=f,i+=m)}}function ap(t,e,r,n,i){let s=(t.x-n.x)*.707-(t.y-n.y)*.707,c=(t.x-n.x)*.707+(t.y-n.y)*.707,l=t.z-n.z,d=.866,f=.5,u=c*d-l*f,h=c*f+l*d,m=e/2+s*i,g=r/2-h*i;return{x:m,y:g}}var Ec=class{constructor(e){this.assetManager=e}async generateTextureThumbnail(e,r){try{let n=await this.assetManager.loadTexture(e);if(!n||n.levels.length===0)return null;let i=n.levels[0],a=i.width/i.height,o=r,s=r;a>1?s=Math.floor(r/a):o=Math.floor(r*a),o=Math.max(1,o),s=Math.max(1,s);let c=ZS(i.rgba,i.width,i.height,o,s);return new ImageData(c,o,s)}catch(n){return console.error(`Failed to generate thumbnail for ${e}`,n),null}}async generateModelThumbnail(e,r){try{let n=[],i=[],a=e.split(".").pop()?.toLowerCase();if(a==="md2"){let p=await this.assetManager.loadMd2Model(e);if(!p||p.frames.length===0)return null;n=p.frames[0].vertices.map(v=>v.position);for(let v of p.triangles)i.push(v.vertexIndices[0],v.vertexIndices[1]),i.push(v.vertexIndices[1],v.vertexIndices[2]),i.push(v.vertexIndices[2],v.vertexIndices[0])}else if(a==="md3"){let p=await this.assetManager.loadMd3Model(e);if(!p||p.surfaces.length===0)return null;let y=0;for(let v of p.surfaces){if(v.vertices.length===0)continue;let x=v.vertices[0];n.push(...x.map(b=>({x:b.position.x,y:b.position.y,z:b.position.z})));for(let b of v.triangles)i.push(y+b.indices[0],y+b.indices[1]),i.push(y+b.indices[1],y+b.indices[2]),i.push(y+b.indices[2],y+b.indices[0]);y+=x.length}}else return null;if(n.length===0)return null;let o={x:1/0,y:1/0,z:1/0},s={x:-1/0,y:-1/0,z:-1/0};for(let p of n)o.x=Math.min(o.x,p.x),o.y=Math.min(o.y,p.y),o.z=Math.min(o.z,p.z),s.x=Math.max(s.x,p.x),s.y=Math.max(s.y,p.y),s.z=Math.max(s.z,p.z);let c={x:(o.x+s.x)/2,y:(o.y+s.y)/2,z:(o.z+s.z)/2},l=s.x-o.x,d=s.y-o.y,f=s.z-o.z,u=Math.max(l,d,f),h=Math.max(u,.001),m=r*.8/h,g=new Uint8ClampedArray(r*r*4);for(let p=0;p<i.length;p+=2){let y=i[p],v=i[p+1],x=n[y],b=n[v],_=ap(x,r,r,c,m),w=ap(b,r,r,c,m);jS(g,r,r,_.x,_.y,w.x,w.y,0,255,0,255)}return new ImageData(g,r,r)}catch(n){return console.error(`Failed to generate model thumbnail for ${e}`,n),null}}async getMapBounds(e,r){try{let n=ja(r);if(n.models.length>0){let i=n.models[0];return{mins:{x:i.mins[0],y:i.mins[1],z:i.mins[2]},maxs:{x:i.maxs[0],y:i.maxs[1],z:i.maxs[2]}}}return null}catch(n){return console.error("Failed to get map bounds",n),null}}async extractMapScreenshot(e){return null}};var Lc=class{constructor(e){this.loader=e}async getMapStatistics(e){let r=await this.loader.load(e),n=r.faces.filter(o=>o.lightOffset!==-1).length,i=r.models[0],a=i?{mins:i.mins,maxs:i.maxs}:{mins:[0,0,0],maxs:[0,0,0]};return{entityCount:r.entities.entities.length,surfaceCount:r.faces.length,lightmapCount:n,vertexCount:r.vertices.length,bounds:a}}async getUsedTextures(e){let r=await this.loader.load(e),n=new Set;for(let i of r.texInfo)i.texture&&n.add(i.texture);return Array.from(n).sort()}async getUsedModels(e){let r=await this.loader.load(e),n=new Set;for(let i of r.entities.entities)i.properties.model&&!i.properties.model.startsWith("*")&&n.add(i.properties.model);return Array.from(n).sort()}async getUsedSounds(e){let r=await this.loader.load(e),n=new Set;for(let i of r.entities.entities){i.properties.noise&&n.add(i.properties.noise);for(let[a,o]of Object.entries(i.properties))(a==="noise"||a.endsWith("_sound")||a==="sound")&&typeof o=="string"&&n.add(o)}return Array.from(n).sort()}};function op(t){let e=[],r=0,n=t.length;function i(){for(;r<n&&/\s/.test(t[r]);)r++}function a(){if(i(),r>=n)return null;if(t[r]==='"'){r++;let o=r;for(;r<n&&t[r]!=='"';)t[r],r++;let s=t.substring(o,r);return r++,s}else{if(t[r]==="{"||t[r]==="}")return t[r++];{if(t.startsWith("//",r)){for(;r<n&&t[r]!==`
|
|
782
|
+
`;function ac(t){return R.fromValues(t.x,t.y,t.z)}function tr(t){return{x:t[0],y:t[1],z:t[2]}}var oc=class{constructor(e){this.vertices=[];this.solidVertices=[];this.labels=[];this.gl=e,this.shader=le.create(e,{vertex:Gx,fragment:Wx}),this.vao=new Ee(e),this.vbo=new Ae(e,e.DYNAMIC_DRAW),this.vao.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:24,offset:0},{index:1,size:3,type:e.FLOAT,stride:24,offset:12}],this.vbo),this.shaderSolid=le.create(e,{vertex:Xx,fragment:Kx}),this.vaoSolid=new Ee(e),this.vboSolid=new Ae(e,e.DYNAMIC_DRAW),this.vaoSolid.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:36,offset:0},{index:1,size:3,type:e.FLOAT,stride:36,offset:12},{index:2,size:3,type:e.FLOAT,stride:36,offset:24}],this.vboSolid)}get shaderSize(){return this.shader.sourceSize+this.shaderSolid.sourceSize}drawLine(e,r,n){this.vertices.push(e.x,e.y,e.z,n.r,n.g,n.b,r.x,r.y,r.z,n.r,n.g,n.b)}drawBoundingBox(e,r,n){let{x:i,y:a,z:o}=e,{x:s,y:c,z:l}=r;this.drawLine({x:i,y:a,z:o},{x:s,y:a,z:o},n),this.drawLine({x:s,y:a,z:o},{x:s,y:c,z:o},n),this.drawLine({x:s,y:c,z:o},{x:i,y:c,z:o},n),this.drawLine({x:i,y:c,z:o},{x:i,y:a,z:o},n),this.drawLine({x:i,y:a,z:l},{x:s,y:a,z:l},n),this.drawLine({x:s,y:a,z:l},{x:s,y:c,z:l},n),this.drawLine({x:s,y:c,z:l},{x:i,y:c,z:l},n),this.drawLine({x:i,y:c,z:l},{x:i,y:a,z:l},n),this.drawLine({x:i,y:a,z:o},{x:i,y:a,z:l},n),this.drawLine({x:s,y:a,z:o},{x:s,y:a,z:l},n),this.drawLine({x:s,y:c,z:o},{x:s,y:c,z:l},n),this.drawLine({x:i,y:c,z:o},{x:i,y:c,z:l},n)}drawPoint(e,r,n){let i=r/2;this.drawBoundingBox({x:e.x-i,y:e.y-i,z:e.z-i},{x:e.x+i,y:e.y+i,z:e.z+i},n)}drawAxes(e,r){this.drawLine(e,{x:e.x+r,y:e.y,z:e.z},{r:1,g:0,b:0}),this.drawLine(e,{x:e.x,y:e.y+r,z:e.z},{r:0,g:1,b:0}),this.drawLine(e,{x:e.x,y:e.y,z:e.z+r},{r:0,g:0,b:1})}drawText3D(e,r){this.labels.push({text:e,position:r})}addTriangle(e,r,n,i,a){this.solidVertices.push(e.x,e.y,e.z),this.solidVertices.push(a.r,a.g,a.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(r.x,r.y,r.z),this.solidVertices.push(a.r,a.g,a.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(n.x,n.y,n.z),this.solidVertices.push(a.r,a.g,a.b),this.solidVertices.push(i.x,i.y,i.z)}addCone(e,r,n,i){let o=ac(e),s=ac(r),c=R.create();R.subtract(c,o,s),R.normalize(c,c);let l=R.fromValues(0,0,1);Math.abs(R.dot(c,l))>.99&&(l=R.fromValues(0,1,0));let d=R.create();R.cross(d,l,c),R.normalize(d,d);let f=R.create();R.cross(f,c,d);let u=[];for(let p=0;p<16;p++){let y=p/16*Math.PI*2,v=Math.cos(y)*n,x=Math.sin(y)*n,b=R.clone(s);R.scaleAndAdd(b,b,d,v),R.scaleAndAdd(b,b,f,x),u.push(b)}let h=R.clone(c);R.scale(h,h,-1);let m=tr(h),g=r;for(let p=0;p<16;p++){let y=tr(u[p]),v=tr(u[(p+1)%16]);this.addTriangle(g,v,y,m,i)}for(let p=0;p<16;p++){let y=u[p],v=u[(p+1)%16],x=tr(y),b=tr(v),_=R.create();R.subtract(_,v,y);let w=R.create();R.subtract(w,o,y);let S=R.create();R.cross(S,_,w),R.normalize(S,S);let E=tr(S);this.addTriangle(x,b,e,E,i)}}addTorus(e,r,n,i,a={x:0,y:0,z:1}){let c=ac(a);R.normalize(c,c);let l=ac(e),d=R.fromValues(0,0,1),f=j.create();if(Math.abs(R.dot(c,d))>.999)c[2]<0&&j.rotateX(f,f,Math.PI);else{let m=R.create();R.cross(m,d,c),R.normalize(m,m);let g=Math.acos(R.dot(d,c));j.fromRotation(f,g,m)}let u=[],h=[];for(let m=0;m<=16;m++){let g=m/16*Math.PI*2,p=Math.cos(g),y=Math.sin(g),v=[],x=[];for(let b=0;b<=8;b++){let _=b/8*Math.PI*2,w=Math.cos(_),S=Math.sin(_),E=(r+n*w)*p,L=(r+n*w)*y,M=n*S,C=R.fromValues(E,L,M),I=w*p,B=w*y,F=S,U=R.fromValues(I,B,F);R.transformMat4(C,C,f),R.transformMat4(U,U,f),R.add(C,C,l),v.push(C),x.push(U)}u.push(v),h.push(x)}for(let m=0;m<16;m++)for(let g=0;g<8;g++){let p=u[m][g],y=u[m+1][g],v=u[m+1][g+1],x=u[m][g+1],b=tr(p),_=tr(y),w=tr(v),S=tr(x),E=R.create();R.subtract(E,y,p);let L=R.create();R.subtract(L,v,p);let M=R.create();R.cross(M,E,L),R.normalize(M,M),this.addTriangle(b,_,w,tr(M),i);let C=R.create();R.subtract(C,v,p);let I=R.create();R.subtract(I,x,p);let B=R.create();R.cross(B,C,I),R.normalize(B,B),this.addTriangle(b,w,S,tr(B),i)}}render(e,r=!1){if(r&&this.gl.disable(this.gl.DEPTH_TEST),this.vertices.length>0){this.shader.use();let n=this.shader.getUniformLocation("u_viewProjection");n&&this.gl.uniformMatrix4fv(n,!1,e),this.vbo.upload(new Float32Array(this.vertices)),this.vao.bind(),this.gl.drawArrays(this.gl.LINES,0,this.vertices.length/6)}if(this.solidVertices.length>0){this.shaderSolid.use();let n=this.shaderSolid.getUniformLocation("u_viewProjection");n&&this.gl.uniformMatrix4fv(n,!1,e);let i=this.shaderSolid.getUniformLocation("u_lightingEnabled");i&&this.gl.uniform1i(i,1),this.vboSolid.upload(new Float32Array(this.solidVertices)),this.vaoSolid.bind(),this.gl.drawArrays(this.gl.TRIANGLES,0,this.solidVertices.length/9)}r&&this.gl.enable(this.gl.DEPTH_TEST)}getLabels(e,r,n){let i=[];for(let a of this.labels){let o=ga.fromValues(a.position.x,a.position.y,a.position.z,1),s=ga.create(),l=e,d=o[0],f=o[1],u=o[2],h=o[3];if(s[0]=l[0]*d+l[4]*f+l[8]*u+l[12]*h,s[1]=l[1]*d+l[5]*f+l[9]*u+l[13]*h,s[2]=l[2]*d+l[6]*f+l[10]*u+l[14]*h,s[3]=l[3]*d+l[7]*f+l[11]*u+l[15]*h,s[3]>0){let m=s[0]/s[3],g=s[1]/s[3],p=(m+1)*.5*r,y=(1-g)*.5*n;p>=0&&p<=r&&y>=0&&y<=n&&i.push({text:a.text,x:p,y})}}return i}clear(){this.vertices=[],this.solidVertices=[],this.labels=[]}};function Im(t,e,r,n=32){let i=[];for(let s of t){let c=!0;for(let l of e)if(l.normal.x*s.origin.x+l.normal.y*s.origin.y+l.normal.z*s.origin.z+l.distance<-s.intensity){c=!1;break}if(c){let l=0;if(r){let d=s.origin.x-r.x,f=s.origin.y-r.y,u=s.origin.z-r.z;l=d*d+f*f+u*u}i.push({light:s,distSq:l})}}r&&i.sort((s,c)=>s.distSq-c.distSq);let a=[],o=Math.min(i.length,n);for(let s=0;s<o;s++)a.push(i[s].light);return a}function mu(t){let e=(t*1664525+1013904223>>>0)/4294967296,r=(t*25214903917+11>>>0)/4294967296,n=(t*69069+1>>>0)/4294967296;return[e,r,n,1]}var Bm=t=>{let e=new fa(t),r=new ha(t),n=new pa(t),i=new va(t),a=new wa(t),o=new nc(t),s=new oc(t),c=new ic(t),l=new uf({seed:Date.now()}),d=new _a(4096,l),f=new Sa(t,d),u=e.shaderSize+r.shaderSize+n.shaderSize+i.shaderSize+a.shaderSize+o.shaderSize+s.shaderSize+f.shaderSize;c.trackShaderMemory(u);let h=new Map,m=new Map,g=new Map,p=new Map,y=0,v=600,x=300,b=null,_={drawCalls:0,vertexCount:0,batches:0,shaderSwitches:0,visibleSurfaces:0,culledSurfaces:0,visibleEntities:0,culledEntities:0},w=new Map,S=new Map,E=0,L=1,M=1,C=!1,I=0,B=new Map,F=!1,U=!1,ce=.5,Nt=1,Ct=new Array(1024).fill(!0),zr=Tm(t,e,r),on=1e4,dt=[],et=0,Ht=Jl.create(),Gn=R.create(),sn=R.create();for(let A=0;A<on;A++){let K={id:-1,model:void 0,transform:new Float32Array(16),type:"md3",blend:{frame0:0,frame1:0,lerp:0},tint:[1,1,1,1],lighting:{ambient:[.5,.5,.5],dynamicLights:[],modelMatrix:void 0}};K.lighting&&(K.lighting.modelMatrix=K.transform),dt.push(K)}let Or=[],Ur,Nr,k,oe=(A,K)=>{if(A.type==="md2"){let ie=A.model;if(!ie.lods||ie.lods.length===0)return{model:A.model,type:A.type};let de=A.transform[12]-K.x,re=A.transform[13]-K.y,pe=A.transform[14]-K.z,Ke=Math.sqrt(de*de+re*re+pe*pe),Pt=Math.floor(Ke*Nt/500);if(Pt<=0)return{model:A.model,type:A.type};let Pe=ie.lods,Wt=Math.min(Pt-1,Pe.length-1);return{model:Pe[Wt],type:A.type}}return{model:A.model,type:A.type}},Ce=(A,K,ie)=>{c.startFrame(),y++;let de=Or.length>0?[...K,...Or]:K;Or.length=0,et=0,A.deltaTime&&d.update(A.deltaTime),t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0);let pe=A.renderMode,Ke=!1;ie?.wireframe||E===6?pe={mode:"wireframe",applyToAll:!0,color:[1,1,1,1]}:E===5&&(Ke=!0);let Pt=A.sky;ie?.showSkybox===!1&&(Pt=void 0);let Pe=new Float32Array(A.camera.viewProjectionMatrix),Wt=kn(Pe),It=A.dlights?Im(A.dlights,Wt,{x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},32):void 0,za={...A,sky:Pt,renderMode:pe,disableLightmaps:ie?.showLightmaps===!1&&E!==5,dlights:It,lightmapOnly:Ke,brightness:L,gamma:M,fullbright:C,ambient:I,lightStyleOverrides:B,underwaterWarp:F,bloom:U,bloomIntensity:ce,portalState:Ct},Rs=zr.renderFrame(za),tf=Rs.facesDrawn||0,rf=0;A.world&&A.world.map&&A.world.map.faces&&(rf=A.world.map.faces.length);let mp=rf-tf,Cc=-1,Pc=-1,Ic=null;if(A.world&&ie?.cullingEnabled!==!1){let z={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},ke=bi(A.world.map,z);if(ke>=0){let ut=A.world.map.leafs[ke];Cc=ut.cluster,Pc=ut.area,Pc>=0&&A.world.map.areas.length>0&&(Ic=kd(A.world.map,Pc,Ct))}}let Cs,Oa=0,Bc=0,nf=0,Ps=0,pp={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]};if(y%v===0)for(let[z,ke]of p)y-ke.lastFrameSeen>x&&p.delete(z);for(let z of de){if(A.world&&Cc>=0){let Q={x:z.transform[12],y:z.transform[13],z:z.transform[14]},O=-1;if(z.id!==void 0){let Y=p.get(z.id);Y&&Y.position[12]===z.transform[12]&&Y.position[13]===z.transform[13]&&Y.position[14]===z.transform[14]?(O=Y.leafIndex,Y.lastFrameSeen=y):(O=bi(A.world.map,Q),O>=0&&p.set(z.id,{leafIndex:O,position:new Float32Array(z.transform),lastFrameSeen:y}))}else O=bi(A.world.map,Q);if(O>=0){let Y=A.world.map.leafs[O],Xt=Y.cluster,ze=Y.area;if(Ic&&ze>=0&&!Ic.has(ze)){Ps++;continue}if(!Fd(A.world.map.visibility,Cc,Xt)){Ps++;continue}}}let{model:ke,type:ut}=oe(z,pp),De,ve;if(ut==="md2"){let Q=ke,O=Q.frames[z.blend.frame0%Q.frames.length],Y=Q.frames[z.blend.frame1%Q.frames.length];O&&Y&&(De={x:Math.min(O.minBounds.x,Y.minBounds.x),y:Math.min(O.minBounds.y,Y.minBounds.y),z:Math.min(O.minBounds.z,Y.minBounds.z)},ve={x:Math.max(O.maxBounds.x,Y.maxBounds.x),y:Math.max(O.maxBounds.y,Y.maxBounds.y),z:Math.max(O.maxBounds.z,Y.maxBounds.z)})}else if(ut==="md3"){let Q=ke,O=Q.frames[z.blend.frame0%Q.frames.length],Y=Q.frames[z.blend.frame1%Q.frames.length];O&&Y?(De={x:Math.min(O.minBounds.x,Y.minBounds.x),y:Math.min(O.minBounds.y,Y.minBounds.y),z:Math.min(O.minBounds.z,Y.minBounds.z)},ve={x:Math.max(O.maxBounds.x,Y.maxBounds.x),y:Math.max(O.maxBounds.y,Y.maxBounds.y),z:Math.max(O.maxBounds.z,Y.maxBounds.z)}):(De={x:-32,y:-32,z:-32},ve={x:32,y:32,z:32})}if(De&&ve){let Q=Ch(De,ve,z.transform);if(!yi(Q.mins,Q.maxs,Wt)){Ps++;continue}}nf++;let ar={x:z.transform[12],y:z.transform[13],z:z.transform[14]},Ye=Rm(A.world?.map,ar),Le=z.id!==void 0?w.get(z.id):void 0;switch(ut){case"md2":{let Q=ke,O=m.get(Q);if(O)O.update(Q,z.blend);else{O=new ma(t,Q,z.blend),m.set(Q,O);let Oe=O.geometry.vertices.length*8*4,cn=O.geometry.indices.length*2;c.trackBufferMemory(Oe+cn)}let Y=Oc(Pe,z.transform),Xt=z.skin,ze=Xt?A.world?.textures?.get(Xt):void 0;ze&&ze!==Cs&&(ze.bind(0),Cs=ze);let Kt=pe;if(Kt&&!Kt.applyToAll&&ze&&(Kt=void 0),Kt?.generateRandomColor&&z.id!==void 0){let Oe=mu(z.id);Kt={...Kt,color:Oe}}if(n.bind({modelViewProjection:Y,modelMatrix:z.transform,ambientLight:Ye,dlights:A.dlights,renderMode:Kt,tint:z.tint,brightness:L,gamma:M,fullbright:C,ambient:I}),n.draw(O,Kt),Oa++,Bc+=O.geometry.vertices.length,Le){let Oe={mode:"wireframe",applyToAll:!0,color:Le};n.bind({modelViewProjection:Y,modelMatrix:z.transform,ambientLight:1,renderMode:Oe,tint:[1,1,1,1],brightness:1,gamma:1,fullbright:!0,ambient:0}),n.draw(O,Oe),Oa++}}break;case"md3":{let Q=ke,O=h.get(Q),Y=z,Xt=A.dlights?A.dlights.map(Oe=>({origin:Oe.origin,color:[Oe.color.x,Oe.color.y,Oe.color.z],radius:Oe.intensity})):void 0,ze={...Y.lighting,ambient:[Ye,Ye,Ye],dynamicLights:Xt,modelMatrix:z.transform};O?O.update(z.blend,ze):(O=new xa(t,Q,z.blend,ze),h.set(Q,O));let Kt=Oc(Pe,z.transform);i.bind(Kt);for(let Oe of Q.surfaces){let cn=O.surfaces.get(Oe.name);if(cn){let of=Y.skins?.get(Oe.name),Ua=of?A.world?.textures?.get(of):void 0;Ua&&Ua!==Cs&&(Ua.bind(0),Cs=Ua);let Kn=pe;if(Kn&&!Kn.applyToAll&&Ua&&(Kn=void 0),Kn?.generateRandomColor&&z.id!==void 0){let sf=mu(z.id);Kn={...Kn,color:sf}}let gp={renderMode:Kn,brightness:L,gamma:M,fullbright:C,globalAmbient:I};if(i.drawSurface(cn,gp),Oa++,Bc+=cn.geometry.vertices.length,Le){let yp={renderMode:{mode:"wireframe",applyToAll:!0,color:Le},brightness:1,gamma:1,fullbright:!0,globalAmbient:0};i.drawSurface(cn,yp),Oa++}}}}break}}let Xn=A.camera.viewMatrix;if(Xn){let z={x:Xn[0],y:Xn[4],z:Xn[8]},ke={x:Xn[1],y:Xn[5],z:Xn[9]};f.render({viewProjection:Pe,viewRight:z,viewUp:ke})}if(za.waterTint&&(Ur(),k(0,0,t.canvas.width,t.canvas.height,za.waterTint),Nr()),o.render(Pe),o.clear(),A.world&&(S.size>0||E===3)){let z=new Map(S);if(E===3&&A.world){let ke=kn(Pe),ut={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},De=xi(A.world.map,ut,ke,Ct);for(let{faceIndex:ve,leafIndex:ar}of De){let Ye=A.world.map.leafs[ar];Ye&&!z.has(ve)&&z.set(ve,mu(Ye.cluster))}}for(let[ke,ut]of z){let De=A.world.surfaces[ke];if(De&&De.vertexCount>0){let ve=[];for(let Le=0;Le<De.vertexCount;Le++)ve.push({x:De.vertexData[Le*7],y:De.vertexData[Le*7+1],z:De.vertexData[Le*7+2]});let Ye={r:ut[0],g:ut[1],b:ut[2]};for(let Le=0;Le<ve.length;Le++){let Q=ve[Le],O=ve[(Le+1)%ve.length];s.drawLine(Q,O,Ye)}s.drawLine(ve[0],ve[ve.length/2|0],Ye)}}}if((ie?.showNormals||E===2)&&A.world){let z=kn(Pe),ke={x:A.camera.position[0],y:A.camera.position[1],z:A.camera.position[2]},ut=xi(A.world.map,ke,z,Ct);for(let{faceIndex:De}of ut){let ve=A.world.map.faces[De],ar=A.world.map.planes[ve.planeIndex],Ye=A.world.surfaces[De];if(!Ye)continue;let Le=0,Q=0,O=0,Y=Ye.vertexCount;for(let Xt=0;Xt<Y;Xt++){let ze=Xt*7;Le+=Ye.vertexData[ze],Q+=Ye.vertexData[ze+1],O+=Ye.vertexData[ze+2]}if(Y>0){Le/=Y,Q/=Y,O/=Y;let Xt=ve.side===0?ar.normal[0]:-ar.normal[0],ze=ve.side===0?ar.normal[1]:-ar.normal[1],Kt=ve.side===0?ar.normal[2]:-ar.normal[2],Oe={x:Le,y:Q,z:O},cn={x:Le+Xt*8,y:Q+ze*8,z:O+Kt*8};s.drawLine(Oe,cn,{r:1,g:1,b:0})}}}s.render(Pe);let af=s.getLabels(Pe,t.canvas.width,t.canvas.height);if(af.length>0){Ur();for(let z of af)Ti(z.x,z.y,z.text,[1,1,1,1]);Nr()}s.clear(),_={drawCalls:Rs.drawCalls+Oa,vertexCount:Rs.vertexCount+Bc,batches:Rs.batches,shaderSwitches:0,visibleSurfaces:tf,culledSurfaces:mp,visibleEntities:nf,culledEntities:Ps},c.endFrame()},Re=async(A,K)=>{if(g.has(A))return g.get(A);let ie=new Blob([K]),de=await createImageBitmap(ie),re=new Je(t);return re.upload(de.width,de.height,de),g.set(A,re),c.trackTextureMemory(de.width*de.height*4),A.includes("conchars")&&(b=re),re},ir=(A,K)=>{if(g.has(A))return g.get(A);let ie=new Je(t),de=K.levels[0];return ie.upload(de.width,de.height,de.rgba),g.set(A,ie),c.trackTextureMemory(de.width*de.height*4),A.includes("conchars")&&(b=ie),ie};Ur=()=>{t.enable(t.BLEND),t.blendFunc(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA),t.disable(t.DEPTH_TEST),t.depthMask(!1);let A=j.create();j.ortho(A,0,t.canvas.width,t.canvas.height,0,-1,1),a.begin(A)},Nr=()=>{t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0)};let Vt=(A,K,ie,de)=>{ie.bind(0),a.draw(A,K,ie.width,ie.height,0,0,1,1,de)},ln=(A,K,ie,de)=>{if(!b)return;let re=8,pe=8,Ke=b.width/re,Pt=ie&255,Pe=Pt%Ke*re/b.width,Wt=Math.floor(Pt/Ke)*pe/b.height,It=Pe+re/b.width,za=Wt+pe/b.height;b.bind(0),a.draw(A,K,re,pe,Pe,Wt,It,za,de)},Ti=(A,K,ie,de)=>{let re=Pm(ie),pe=A,Ke=8;for(let Pt of re){let Pe=Pt.color||de;for(let Wt=0;Wt<Pt.text.length;Wt++)ln(pe,K,Pt.text.charCodeAt(Wt),Pe),pe+=Ke}},Gt=(A,K)=>{let re=K.replace(/\^[0-9]/g,"").length*8,pe=(t.canvas.width-re)/2;Ti(pe,A,K)};return k=(A,K,ie,de,re)=>{a.drawRect(A,K,ie,de,re)},{get width(){return t.canvas.width},get height(){return t.canvas.height},get collisionVis(){return o},get debug(){return s},get particleSystem(){return d},getPerformanceReport:()=>c.getPerformanceReport(_),getMemoryUsage:()=>c.getMemoryUsage(),renderFrame:Ce,registerPic:Re,registerTexture:ir,begin2D:Ur,end2D:Nr,drawPic:Vt,drawString:Ti,drawCenterString:Gt,drawfillRect:k,setEntityHighlight:(A,K)=>{w.set(A,K)},clearEntityHighlight:A=>{w.delete(A)},highlightSurface:(A,K)=>{S.set(A,K)},removeSurfaceHighlight:A=>{S.delete(A)},setDebugMode:A=>{E=A},setBrightness:A=>{L=Math.max(0,Math.min(2,A))},setGamma:A=>{M=Math.max(.5,Math.min(3,A))},setFullbright:A=>{C=A},setAmbient:A=>{I=Math.max(0,Math.min(1,A))},setLightStyle:(A,K)=>{K===null?B.delete(A):B.set(A,K)},setUnderwaterWarp:A=>{F=A},setBloom:A=>{U=A},setBloomIntensity:A=>{ce=A},setLodBias:A=>{Nt=Math.max(0,Math.min(2,A))},setAreaPortalState:(A,K)=>{A>=0&&A<Ct.length&&(Ct[A]=K)},renderInstanced:(A,K)=>{let ie="glCommands"in A,de=ie?"md2":"md3";for(let re of K){if(et>=on){console.warn("Max instances reached");break}let pe=dt[et++];pe.model=A,pe.type=de;let Ke=pe.blend;re.frame!==void 0?(Ke.frame0=re.frame,Ke.frame1=re.frame,Ke.lerp=0):(Ke.frame0=re.frame0||0,Ke.frame1=re.frame1||0,Ke.lerp=re.lerp||0),ie&&(pe.skin=re.skin!==void 0?"skin"+re.skin:void 0);let Pt=re.rotation,Pe=re.position,Wt=re.scale||{x:1,y:1,z:1};j.fromRotationTranslationScale(pe.transform,Ht,Gn,sn);let It=pe.lighting;It&&(It.dynamicLights?It.dynamicLights.length=0:It.dynamicLights=[],It.ambient?(It.ambient[0]=.5,It.ambient[1]=.5,It.ambient[2]=.5):It.ambient=[.5,.5,.5]),Or.push(pe)}},dispose:()=>{c.dispose()}}};var fr=class{constructor(e){this.messageOffsets=[];this.currentBlock=null;this.buffer=e,this.view=new DataView(e),this.offset=0,this.scan()}scan(){let e=0;for(this.messageOffsets=[];e+4<=this.buffer.byteLength;){let r=this.view.getInt32(e,!0);if(r===-1)break;if(r<0||r>2097152){console.warn(`DemoReader: Invalid block length ${r} at offset ${e} during scan`);break}if(e+4+r>this.buffer.byteLength){console.warn(`DemoReader: Incomplete block at offset ${e} during scan`);break}this.messageOffsets.push(e),e+=4+r}}hasMore(){return this.offset<this.buffer.byteLength}readNextBlock(){if(this.offset+4>this.buffer.byteLength)return null;let e=this.view.getInt32(this.offset,!0);if(e===-1||e<0||this.offset+4+e>this.buffer.byteLength)return null;this.offset+=4;let r=this.buffer.slice(this.offset,this.offset+e);return this.offset+=e,{length:e,data:new mn(r)}}nextBlock(){let e=this.readNextBlock();return e?(this.currentBlock=e,!0):(this.currentBlock=null,!1)}getBlock(){if(!this.currentBlock)throw new Error("No current block. Call nextBlock() first.");return this.currentBlock}readAllBlocksToBuffer(){let e=0,r=this.offset,n=[],i=this.offset;for(;i+4<=this.buffer.byteLength;){let c=this.view.getInt32(i,!0);if(c===-1||c<0||i+4+c>this.buffer.byteLength)break;n.push({offset:i+4,length:c}),e+=c,i+=4+c}let a=new Uint8Array(e),o=0,s=new Uint8Array(this.buffer);for(let c of n)a.set(s.subarray(c.offset,c.offset+c.length),o),o+=c.length;return this.offset=i,a.buffer}reset(){this.offset=0,this.currentBlock=null}seekToMessage(e){return e<0||e>=this.messageOffsets.length?!1:(this.offset=this.messageOffsets[e],this.currentBlock=null,!0)}getMessageCount(){return this.messageOffsets.length}getOffset(){return this.offset}getProgress(){let e=this.offset,r=this.buffer.byteLength;return{current:e,total:r,percent:r>0?e/r*100:0}}};function Ra(t){let e=t.length;for(;--e>=0;)t[e]=0}var Yx=0,b0=1,$x=2,qx=3,Zx=258,Ou=29,xs=256,us=xs+1+Ou,Ea=30,Uu=19,x0=2*us+1,vi=15,pu=16,jx=7,Nu=256,v0=16,_0=17,S0=18,Ru=new Uint8Array([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0]),fc=new Uint8Array([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13]),Qx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),w0=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),Jx=512,nn=new Array((us+2)*2);Ra(nn);var ls=new Array(Ea*2);Ra(ls);var fs=new Array(Jx);Ra(fs);var hs=new Array(Zx-qx+1);Ra(hs);var Hu=new Array(Ou);Ra(Hu);var hc=new Array(Ea);Ra(hc);function gu(t,e,r,n,i){this.static_tree=t,this.extra_bits=e,this.extra_base=r,this.elems=n,this.max_length=i,this.has_stree=t&&t.length}var M0,A0,E0;function yu(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}var L0=t=>t<256?fs[t]:fs[256+(t>>>7)],ms=(t,e)=>{t.pending_buf[t.pending++]=e&255,t.pending_buf[t.pending++]=e>>>8&255},Rt=(t,e,r)=>{t.bi_valid>pu-r?(t.bi_buf|=e<<t.bi_valid&65535,ms(t,t.bi_buf),t.bi_buf=e>>pu-t.bi_valid,t.bi_valid+=r-pu):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=r)},Ir=(t,e,r)=>{Rt(t,r[e*2],r[e*2+1])},T0=(t,e)=>{let r=0;do r|=t&1,t>>>=1,r<<=1;while(--e>0);return r>>>1},ev=t=>{t.bi_valid===16?(ms(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=t.bi_buf&255,t.bi_buf>>=8,t.bi_valid-=8)},tv=(t,e)=>{let r=e.dyn_tree,n=e.max_code,i=e.stat_desc.static_tree,a=e.stat_desc.has_stree,o=e.stat_desc.extra_bits,s=e.stat_desc.extra_base,c=e.stat_desc.max_length,l,d,f,u,h,m,g=0;for(u=0;u<=vi;u++)t.bl_count[u]=0;for(r[t.heap[t.heap_max]*2+1]=0,l=t.heap_max+1;l<x0;l++)d=t.heap[l],u=r[r[d*2+1]*2+1]+1,u>c&&(u=c,g++),r[d*2+1]=u,!(d>n)&&(t.bl_count[u]++,h=0,d>=s&&(h=o[d-s]),m=r[d*2],t.opt_len+=m*(u+h),a&&(t.static_len+=m*(i[d*2+1]+h)));if(g!==0){do{for(u=c-1;t.bl_count[u]===0;)u--;t.bl_count[u]--,t.bl_count[u+1]+=2,t.bl_count[c]--,g-=2}while(g>0);for(u=c;u!==0;u--)for(d=t.bl_count[u];d!==0;)f=t.heap[--l],!(f>n)&&(r[f*2+1]!==u&&(t.opt_len+=(u-r[f*2+1])*r[f*2],r[f*2+1]=u),d--)}},R0=(t,e,r)=>{let n=new Array(vi+1),i=0,a,o;for(a=1;a<=vi;a++)i=i+r[a-1]<<1,n[a]=i;for(o=0;o<=e;o++){let s=t[o*2+1];s!==0&&(t[o*2]=T0(n[s]++,s))}},rv=()=>{let t,e,r,n,i,a=new Array(vi+1);for(r=0,n=0;n<Ou-1;n++)for(Hu[n]=r,t=0;t<1<<Ru[n];t++)hs[r++]=n;for(hs[r-1]=n,i=0,n=0;n<16;n++)for(hc[n]=i,t=0;t<1<<fc[n];t++)fs[i++]=n;for(i>>=7;n<Ea;n++)for(hc[n]=i<<7,t=0;t<1<<fc[n]-7;t++)fs[256+i++]=n;for(e=0;e<=vi;e++)a[e]=0;for(t=0;t<=143;)nn[t*2+1]=8,t++,a[8]++;for(;t<=255;)nn[t*2+1]=9,t++,a[9]++;for(;t<=279;)nn[t*2+1]=7,t++,a[7]++;for(;t<=287;)nn[t*2+1]=8,t++,a[8]++;for(R0(nn,us+1,a),t=0;t<Ea;t++)ls[t*2+1]=5,ls[t*2]=T0(t,5);M0=new gu(nn,Ru,xs+1,us,vi),A0=new gu(ls,fc,0,Ea,vi),E0=new gu(new Array(0),Qx,0,Uu,jx)},C0=t=>{let e;for(e=0;e<us;e++)t.dyn_ltree[e*2]=0;for(e=0;e<Ea;e++)t.dyn_dtree[e*2]=0;for(e=0;e<Uu;e++)t.bl_tree[e*2]=0;t.dyn_ltree[Nu*2]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},P0=t=>{t.bi_valid>8?ms(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},Fm=(t,e,r,n)=>{let i=e*2,a=r*2;return t[i]<t[a]||t[i]===t[a]&&n[e]<=n[r]},bu=(t,e,r)=>{let n=t.heap[r],i=r<<1;for(;i<=t.heap_len&&(i<t.heap_len&&Fm(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!Fm(e,n,t.heap[i],t.depth));)t.heap[r]=t.heap[i],r=i,i<<=1;t.heap[r]=n},km=(t,e,r)=>{let n,i,a=0,o,s;if(t.sym_next!==0)do n=t.pending_buf[t.sym_buf+a++]&255,n+=(t.pending_buf[t.sym_buf+a++]&255)<<8,i=t.pending_buf[t.sym_buf+a++],n===0?Ir(t,i,e):(o=hs[i],Ir(t,o+xs+1,e),s=Ru[o],s!==0&&(i-=Hu[o],Rt(t,i,s)),n--,o=L0(n),Ir(t,o,r),s=fc[o],s!==0&&(n-=hc[o],Rt(t,n,s)));while(a<t.sym_next);Ir(t,Nu,e)},Cu=(t,e)=>{let r=e.dyn_tree,n=e.stat_desc.static_tree,i=e.stat_desc.has_stree,a=e.stat_desc.elems,o,s,c=-1,l;for(t.heap_len=0,t.heap_max=x0,o=0;o<a;o++)r[o*2]!==0?(t.heap[++t.heap_len]=c=o,t.depth[o]=0):r[o*2+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=c<2?++c:0,r[l*2]=1,t.depth[l]=0,t.opt_len--,i&&(t.static_len-=n[l*2+1]);for(e.max_code=c,o=t.heap_len>>1;o>=1;o--)bu(t,r,o);l=a;do o=t.heap[1],t.heap[1]=t.heap[t.heap_len--],bu(t,r,1),s=t.heap[1],t.heap[--t.heap_max]=o,t.heap[--t.heap_max]=s,r[l*2]=r[o*2]+r[s*2],t.depth[l]=(t.depth[o]>=t.depth[s]?t.depth[o]:t.depth[s])+1,r[o*2+1]=r[s*2+1]=l,t.heap[1]=l++,bu(t,r,1);while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],tv(t,e),R0(r,c,t.bl_count)},Dm=(t,e,r)=>{let n,i=-1,a,o=e[1],s=0,c=7,l=4;for(o===0&&(c=138,l=3),e[(r+1)*2+1]=65535,n=0;n<=r;n++)a=o,o=e[(n+1)*2+1],!(++s<c&&a===o)&&(s<l?t.bl_tree[a*2]+=s:a!==0?(a!==i&&t.bl_tree[a*2]++,t.bl_tree[v0*2]++):s<=10?t.bl_tree[_0*2]++:t.bl_tree[S0*2]++,s=0,i=a,o===0?(c=138,l=3):a===o?(c=6,l=3):(c=7,l=4))},zm=(t,e,r)=>{let n,i=-1,a,o=e[1],s=0,c=7,l=4;for(o===0&&(c=138,l=3),n=0;n<=r;n++)if(a=o,o=e[(n+1)*2+1],!(++s<c&&a===o)){if(s<l)do Ir(t,a,t.bl_tree);while(--s!==0);else a!==0?(a!==i&&(Ir(t,a,t.bl_tree),s--),Ir(t,v0,t.bl_tree),Rt(t,s-3,2)):s<=10?(Ir(t,_0,t.bl_tree),Rt(t,s-3,3)):(Ir(t,S0,t.bl_tree),Rt(t,s-11,7));s=0,i=a,o===0?(c=138,l=3):a===o?(c=6,l=3):(c=7,l=4)}},nv=t=>{let e;for(Dm(t,t.dyn_ltree,t.l_desc.max_code),Dm(t,t.dyn_dtree,t.d_desc.max_code),Cu(t,t.bl_desc),e=Uu-1;e>=3&&t.bl_tree[w0[e]*2+1]===0;e--);return t.opt_len+=3*(e+1)+5+5+4,e},iv=(t,e,r,n)=>{let i;for(Rt(t,e-257,5),Rt(t,r-1,5),Rt(t,n-4,4),i=0;i<n;i++)Rt(t,t.bl_tree[w0[i]*2+1],3);zm(t,t.dyn_ltree,e-1),zm(t,t.dyn_dtree,r-1)},av=t=>{let e=4093624447,r;for(r=0;r<=31;r++,e>>>=1)if(e&1&&t.dyn_ltree[r*2]!==0)return 0;if(t.dyn_ltree[18]!==0||t.dyn_ltree[20]!==0||t.dyn_ltree[26]!==0)return 1;for(r=32;r<xs;r++)if(t.dyn_ltree[r*2]!==0)return 1;return 0},Om=!1,ov=t=>{Om||(rv(),Om=!0),t.l_desc=new yu(t.dyn_ltree,M0),t.d_desc=new yu(t.dyn_dtree,A0),t.bl_desc=new yu(t.bl_tree,E0),t.bi_buf=0,t.bi_valid=0,C0(t)},I0=(t,e,r,n)=>{Rt(t,(Yx<<1)+(n?1:0),3),P0(t),ms(t,r),ms(t,~r),r&&t.pending_buf.set(t.window.subarray(e,e+r),t.pending),t.pending+=r},sv=t=>{Rt(t,b0<<1,3),Ir(t,Nu,nn),ev(t)},lv=(t,e,r,n)=>{let i,a,o=0;t.level>0?(t.strm.data_type===2&&(t.strm.data_type=av(t)),Cu(t,t.l_desc),Cu(t,t.d_desc),o=nv(t),i=t.opt_len+3+7>>>3,a=t.static_len+3+7>>>3,a<=i&&(i=a)):i=a=r+5,r+4<=i&&e!==-1?I0(t,e,r,n):t.strategy===4||a===i?(Rt(t,(b0<<1)+(n?1:0),3),km(t,nn,ls)):(Rt(t,($x<<1)+(n?1:0),3),iv(t,t.l_desc.max_code+1,t.d_desc.max_code+1,o+1),km(t,t.dyn_ltree,t.dyn_dtree)),C0(t),n&&P0(t)},cv=(t,e,r)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=r,e===0?t.dyn_ltree[r*2]++:(t.matches++,e--,t.dyn_ltree[(hs[r]+xs+1)*2]++,t.dyn_dtree[L0(e)*2]++),t.sym_next===t.sym_end),dv=ov,uv=I0,fv=lv,hv=cv,mv=sv,pv={_tr_init:dv,_tr_stored_block:uv,_tr_flush_block:fv,_tr_tally:hv,_tr_align:mv},gv=(t,e,r,n)=>{let i=t&65535|0,a=t>>>16&65535|0,o=0;for(;r!==0;){o=r>2e3?2e3:r,r-=o;do i=i+e[n++]|0,a=a+i|0;while(--o);i%=65521,a%=65521}return i|a<<16|0},ps=gv,yv=()=>{let t,e=[];for(var r=0;r<256;r++){t=r;for(var n=0;n<8;n++)t=t&1?3988292384^t>>>1:t>>>1;e[r]=t}return e},bv=new Uint32Array(yv()),xv=(t,e,r,n)=>{let i=bv,a=n+r;t^=-1;for(let o=n;o<a;o++)t=t>>>8^i[(t^e[o])&255];return t^-1},Fe=xv,wi={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"},Ei={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8},{_tr_init:vv,_tr_stored_block:Pu,_tr_flush_block:_v,_tr_tally:Un,_tr_align:Sv}=pv,{Z_NO_FLUSH:Nn,Z_PARTIAL_FLUSH:wv,Z_FULL_FLUSH:Mv,Z_FINISH:rr,Z_BLOCK:Um,Z_OK:Xe,Z_STREAM_END:Nm,Z_STREAM_ERROR:Br,Z_DATA_ERROR:Av,Z_BUF_ERROR:xu,Z_DEFAULT_COMPRESSION:Ev,Z_FILTERED:Lv,Z_HUFFMAN_ONLY:sc,Z_RLE:Tv,Z_FIXED:Rv,Z_DEFAULT_STRATEGY:Cv,Z_UNKNOWN:Pv,Z_DEFLATED:gc}=Ei,Iv=9,Bv=15,Fv=8,kv=29,Dv=256,Iu=Dv+1+kv,zv=30,Ov=19,Uv=2*Iu+1,Nv=15,Z=3,On=258,Fr=On+Z+1,Hv=32,La=42,Vu=57,Bu=69,Fu=73,ku=91,Du=103,_i=113,os=666,lt=1,Ca=2,Mi=3,Pa=4,Vv=3,Si=(t,e)=>(t.msg=wi[e],e),Hm=t=>t*2-(t>4?9:0),zn=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Gv=t=>{let e,r,n,i=t.w_size;e=t.hash_size,n=e;do r=t.head[--n],t.head[n]=r>=i?r-i:0;while(--e);e=i,n=e;do r=t.prev[--n],t.prev[n]=r>=i?r-i:0;while(--e)},Wv=(t,e,r)=>(e<<t.hash_shift^r)&t.hash_mask,Hn=Wv,Ot=t=>{let e=t.state,r=e.pending;r>t.avail_out&&(r=t.avail_out),r!==0&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+r),t.next_out),t.next_out+=r,e.pending_out+=r,t.total_out+=r,t.avail_out-=r,e.pending-=r,e.pending===0&&(e.pending_out=0))},Ut=(t,e)=>{_v(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Ot(t.strm)},ne=(t,e)=>{t.pending_buf[t.pending++]=e},as=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=e&255},zu=(t,e,r,n)=>{let i=t.avail_in;return i>n&&(i=n),i===0?0:(t.avail_in-=i,e.set(t.input.subarray(t.next_in,t.next_in+i),r),t.state.wrap===1?t.adler=ps(t.adler,e,i,r):t.state.wrap===2&&(t.adler=Fe(t.adler,e,i,r)),t.next_in+=i,t.total_in+=i,i)},B0=(t,e)=>{let r=t.max_chain_length,n=t.strstart,i,a,o=t.prev_length,s=t.nice_match,c=t.strstart>t.w_size-Fr?t.strstart-(t.w_size-Fr):0,l=t.window,d=t.w_mask,f=t.prev,u=t.strstart+On,h=l[n+o-1],m=l[n+o];t.prev_length>=t.good_match&&(r>>=2),s>t.lookahead&&(s=t.lookahead);do if(i=e,!(l[i+o]!==m||l[i+o-1]!==h||l[i]!==l[n]||l[++i]!==l[n+1])){n+=2,i++;do;while(l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&l[++n]===l[++i]&&n<u);if(a=On-(u-n),n=u-On,a>o){if(t.match_start=e,o=a,a>=s)break;h=l[n+o-1],m=l[n+o]}}while((e=f[e&d])>c&&--r!==0);return o<=t.lookahead?o:t.lookahead},Ta=t=>{let e=t.w_size,r,n,i;do{if(n=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-Fr)&&(t.window.set(t.window.subarray(e,e+e-n),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),Gv(t),n+=e),t.strm.avail_in===0)break;if(r=zu(t.strm,t.window,t.strstart+t.lookahead,n),t.lookahead+=r,t.lookahead+t.insert>=Z)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Hn(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Hn(t,t.ins_h,t.window[i+Z-1]),t.prev[i&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=i,i++,t.insert--,!(t.lookahead+t.insert<Z)););}while(t.lookahead<Fr&&t.strm.avail_in!==0)},F0=(t,e)=>{let r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n,i,a,o=0,s=t.strm.avail_in;do{if(n=65535,a=t.bi_valid+42>>3,t.strm.avail_out<a||(a=t.strm.avail_out-a,i=t.strstart-t.block_start,n>i+t.strm.avail_in&&(n=i+t.strm.avail_in),n>a&&(n=a),n<r&&(n===0&&e!==rr||e===Nn||n!==i+t.strm.avail_in)))break;o=e===rr&&n===i+t.strm.avail_in?1:0,Pu(t,0,0,o),t.pending_buf[t.pending-4]=n,t.pending_buf[t.pending-3]=n>>8,t.pending_buf[t.pending-2]=~n,t.pending_buf[t.pending-1]=~n>>8,Ot(t.strm),i&&(i>n&&(i=n),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,n-=i),n&&(zu(t.strm,t.strm.output,t.strm.next_out,n),t.strm.next_out+=n,t.strm.avail_out-=n,t.strm.total_out+=n)}while(o===0);return s-=t.strm.avail_in,s&&(s>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=s&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-s,t.strm.next_in),t.strstart),t.strstart+=s,t.insert+=s>t.w_size-t.insert?t.w_size-t.insert:s),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),o?Pa:e!==Nn&&e!==rr&&t.strm.avail_in===0&&t.strstart===t.block_start?Ca:(a=t.window_size-t.strstart,t.strm.avail_in>a&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,a+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),a>t.strm.avail_in&&(a=t.strm.avail_in),a&&(zu(t.strm,t.window,t.strstart,a),t.strstart+=a,t.insert+=a>t.w_size-t.insert?t.w_size-t.insert:a),t.high_water<t.strstart&&(t.high_water=t.strstart),a=t.bi_valid+42>>3,a=t.pending_buf_size-a>65535?65535:t.pending_buf_size-a,r=a>t.w_size?t.w_size:a,i=t.strstart-t.block_start,(i>=r||(i||e===rr)&&e!==Nn&&t.strm.avail_in===0&&i<=a)&&(n=i>a?a:i,o=e===rr&&t.strm.avail_in===0&&n===i?1:0,Pu(t,t.block_start,n,o),t.block_start+=n,Ot(t.strm)),o?Mi:lt)},vu=(t,e)=>{let r,n;for(;;){if(t.lookahead<Fr){if(Ta(t),t.lookahead<Fr&&e===Nn)return lt;if(t.lookahead===0)break}if(r=0,t.lookahead>=Z&&(t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),r!==0&&t.strstart-r<=t.w_size-Fr&&(t.match_length=B0(t,r)),t.match_length>=Z)if(n=Un(t,t.strstart-t.match_start,t.match_length-Z),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=Z){t.match_length--;do t.strstart++,t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart;while(--t.match_length!==0);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+1]);else n=Un(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(n&&(Ut(t,!1),t.strm.avail_out===0))return lt}return t.insert=t.strstart<Z-1?t.strstart:Z-1,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca},Ma=(t,e)=>{let r,n,i;for(;;){if(t.lookahead<Fr){if(Ta(t),t.lookahead<Fr&&e===Nn)return lt;if(t.lookahead===0)break}if(r=0,t.lookahead>=Z&&(t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=Z-1,r!==0&&t.prev_length<t.max_lazy_match&&t.strstart-r<=t.w_size-Fr&&(t.match_length=B0(t,r),t.match_length<=5&&(t.strategy===Lv||t.match_length===Z&&t.strstart-t.match_start>4096)&&(t.match_length=Z-1)),t.prev_length>=Z&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-Z,n=Un(t,t.strstart-1-t.prev_match,t.prev_length-Z),t.lookahead-=t.prev_length-1,t.prev_length-=2;do++t.strstart<=i&&(t.ins_h=Hn(t,t.ins_h,t.window[t.strstart+Z-1]),r=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart);while(--t.prev_length!==0);if(t.match_available=0,t.match_length=Z-1,t.strstart++,n&&(Ut(t,!1),t.strm.avail_out===0))return lt}else if(t.match_available){if(n=Un(t,0,t.window[t.strstart-1]),n&&Ut(t,!1),t.strstart++,t.lookahead--,t.strm.avail_out===0)return lt}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(n=Un(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<Z-1?t.strstart:Z-1,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca},Xv=(t,e)=>{let r,n,i,a,o=t.window;for(;;){if(t.lookahead<=On){if(Ta(t),t.lookahead<=On&&e===Nn)return lt;if(t.lookahead===0)break}if(t.match_length=0,t.lookahead>=Z&&t.strstart>0&&(i=t.strstart-1,n=o[i],n===o[++i]&&n===o[++i]&&n===o[++i])){a=t.strstart+On;do;while(n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&i<a);t.match_length=On-(a-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=Z?(r=Un(t,1,t.match_length-Z),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(r=Un(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),r&&(Ut(t,!1),t.strm.avail_out===0))return lt}return t.insert=0,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca},Kv=(t,e)=>{let r;for(;;){if(t.lookahead===0&&(Ta(t),t.lookahead===0)){if(e===Nn)return lt;break}if(t.match_length=0,r=Un(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,r&&(Ut(t,!1),t.strm.avail_out===0))return lt}return t.insert=0,e===rr?(Ut(t,!0),t.strm.avail_out===0?Mi:Pa):t.sym_next&&(Ut(t,!1),t.strm.avail_out===0)?lt:Ca};function Pr(t,e,r,n,i){this.good_length=t,this.max_lazy=e,this.nice_length=r,this.max_chain=n,this.func=i}var ss=[new Pr(0,0,0,0,F0),new Pr(4,4,8,4,vu),new Pr(4,5,16,8,vu),new Pr(4,6,32,32,vu),new Pr(4,4,16,16,Ma),new Pr(8,16,32,32,Ma),new Pr(8,16,128,128,Ma),new Pr(8,32,128,256,Ma),new Pr(32,128,258,1024,Ma),new Pr(32,258,258,4096,Ma)],Yv=t=>{t.window_size=2*t.w_size,zn(t.head),t.max_lazy_match=ss[t.level].max_lazy,t.good_match=ss[t.level].good_length,t.nice_match=ss[t.level].nice_length,t.max_chain_length=ss[t.level].max_chain,t.strstart=0,t.block_start=0,t.lookahead=0,t.insert=0,t.match_length=t.prev_length=Z-1,t.match_available=0,t.ins_h=0};function $v(){this.strm=null,this.status=0,this.pending_buf=null,this.pending_buf_size=0,this.pending_out=0,this.pending=0,this.wrap=0,this.gzhead=null,this.gzindex=0,this.method=gc,this.last_flush=-1,this.w_size=0,this.w_bits=0,this.w_mask=0,this.window=null,this.window_size=0,this.prev=null,this.head=null,this.ins_h=0,this.hash_size=0,this.hash_bits=0,this.hash_mask=0,this.hash_shift=0,this.block_start=0,this.match_length=0,this.prev_match=0,this.match_available=0,this.strstart=0,this.match_start=0,this.lookahead=0,this.prev_length=0,this.max_chain_length=0,this.max_lazy_match=0,this.level=0,this.strategy=0,this.good_match=0,this.nice_match=0,this.dyn_ltree=new Uint16Array(Uv*2),this.dyn_dtree=new Uint16Array((2*zv+1)*2),this.bl_tree=new Uint16Array((2*Ov+1)*2),zn(this.dyn_ltree),zn(this.dyn_dtree),zn(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(Nv+1),this.heap=new Uint16Array(2*Iu+1),zn(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(2*Iu+1),zn(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}var vs=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.status!==La&&e.status!==Vu&&e.status!==Bu&&e.status!==Fu&&e.status!==ku&&e.status!==Du&&e.status!==_i&&e.status!==os?1:0},k0=t=>{if(vs(t))return Si(t,Br);t.total_in=t.total_out=0,t.data_type=Pv;let e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=e.wrap===2?Vu:e.wrap?La:_i,t.adler=e.wrap===2?0:1,e.last_flush=-2,vv(e),Xe},D0=t=>{let e=k0(t);return e===Xe&&Yv(t.state),e},qv=(t,e)=>vs(t)||t.state.wrap!==2?Br:(t.state.gzhead=e,Xe),z0=(t,e,r,n,i,a)=>{if(!t)return Br;let o=1;if(e===Ev&&(e=6),n<0?(o=0,n=-n):n>15&&(o=2,n-=16),i<1||i>Iv||r!==gc||n<8||n>15||e<0||e>9||a<0||a>Rv||n===8&&o!==1)return Si(t,Br);n===8&&(n=9);let s=new $v;return t.state=s,s.strm=t,s.status=La,s.wrap=o,s.gzhead=null,s.w_bits=n,s.w_size=1<<s.w_bits,s.w_mask=s.w_size-1,s.hash_bits=i+7,s.hash_size=1<<s.hash_bits,s.hash_mask=s.hash_size-1,s.hash_shift=~~((s.hash_bits+Z-1)/Z),s.window=new Uint8Array(s.w_size*2),s.head=new Uint16Array(s.hash_size),s.prev=new Uint16Array(s.w_size),s.lit_bufsize=1<<i+6,s.pending_buf_size=s.lit_bufsize*4,s.pending_buf=new Uint8Array(s.pending_buf_size),s.sym_buf=s.lit_bufsize,s.sym_end=(s.lit_bufsize-1)*3,s.level=e,s.strategy=a,s.method=r,D0(t)},Zv=(t,e)=>z0(t,e,gc,Bv,Fv,Cv),jv=(t,e)=>{if(vs(t)||e>Um||e<0)return t?Si(t,Br):Br;let r=t.state;if(!t.output||t.avail_in!==0&&!t.input||r.status===os&&e!==rr)return Si(t,t.avail_out===0?xu:Br);let n=r.last_flush;if(r.last_flush=e,r.pending!==0){if(Ot(t),t.avail_out===0)return r.last_flush=-1,Xe}else if(t.avail_in===0&&Hm(e)<=Hm(n)&&e!==rr)return Si(t,xu);if(r.status===os&&t.avail_in!==0)return Si(t,xu);if(r.status===La&&r.wrap===0&&(r.status=_i),r.status===La){let i=gc+(r.w_bits-8<<4)<<8,a=-1;if(r.strategy>=sc||r.level<2?a=0:r.level<6?a=1:r.level===6?a=2:a=3,i|=a<<6,r.strstart!==0&&(i|=Hv),i+=31-i%31,as(r,i),r.strstart!==0&&(as(r,t.adler>>>16),as(r,t.adler&65535)),t.adler=1,r.status=_i,Ot(t),r.pending!==0)return r.last_flush=-1,Xe}if(r.status===Vu){if(t.adler=0,ne(r,31),ne(r,139),ne(r,8),r.gzhead)ne(r,(r.gzhead.text?1:0)+(r.gzhead.hcrc?2:0)+(r.gzhead.extra?4:0)+(r.gzhead.name?8:0)+(r.gzhead.comment?16:0)),ne(r,r.gzhead.time&255),ne(r,r.gzhead.time>>8&255),ne(r,r.gzhead.time>>16&255),ne(r,r.gzhead.time>>24&255),ne(r,r.level===9?2:r.strategy>=sc||r.level<2?4:0),ne(r,r.gzhead.os&255),r.gzhead.extra&&r.gzhead.extra.length&&(ne(r,r.gzhead.extra.length&255),ne(r,r.gzhead.extra.length>>8&255)),r.gzhead.hcrc&&(t.adler=Fe(t.adler,r.pending_buf,r.pending,0)),r.gzindex=0,r.status=Bu;else if(ne(r,0),ne(r,0),ne(r,0),ne(r,0),ne(r,0),ne(r,r.level===9?2:r.strategy>=sc||r.level<2?4:0),ne(r,Vv),r.status=_i,Ot(t),r.pending!==0)return r.last_flush=-1,Xe}if(r.status===Bu){if(r.gzhead.extra){let i=r.pending,a=(r.gzhead.extra.length&65535)-r.gzindex;for(;r.pending+a>r.pending_buf_size;){let s=r.pending_buf_size-r.pending;if(r.pending_buf.set(r.gzhead.extra.subarray(r.gzindex,r.gzindex+s),r.pending),r.pending=r.pending_buf_size,r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex+=s,Ot(t),r.pending!==0)return r.last_flush=-1,Xe;i=0,a-=s}let o=new Uint8Array(r.gzhead.extra);r.pending_buf.set(o.subarray(r.gzindex,r.gzindex+a),r.pending),r.pending+=a,r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Fu}if(r.status===Fu){if(r.gzhead.name){let i=r.pending,a;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),Ot(t),r.pending!==0)return r.last_flush=-1,Xe;i=0}r.gzindex<r.gzhead.name.length?a=r.gzhead.name.charCodeAt(r.gzindex++)&255:a=0,ne(r,a)}while(a!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=ku}if(r.status===ku){if(r.gzhead.comment){let i=r.pending,a;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i)),Ot(t),r.pending!==0)return r.last_flush=-1,Xe;i=0}r.gzindex<r.gzhead.comment.length?a=r.gzhead.comment.charCodeAt(r.gzindex++)&255:a=0,ne(r,a)}while(a!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=Fe(t.adler,r.pending_buf,r.pending-i,i))}r.status=Du}if(r.status===Du){if(r.gzhead.hcrc){if(r.pending+2>r.pending_buf_size&&(Ot(t),r.pending!==0))return r.last_flush=-1,Xe;ne(r,t.adler&255),ne(r,t.adler>>8&255),t.adler=0}if(r.status=_i,Ot(t),r.pending!==0)return r.last_flush=-1,Xe}if(t.avail_in!==0||r.lookahead!==0||e!==Nn&&r.status!==os){let i=r.level===0?F0(r,e):r.strategy===sc?Kv(r,e):r.strategy===Tv?Xv(r,e):ss[r.level].func(r,e);if((i===Mi||i===Pa)&&(r.status=os),i===lt||i===Mi)return t.avail_out===0&&(r.last_flush=-1),Xe;if(i===Ca&&(e===wv?Sv(r):e!==Um&&(Pu(r,0,0,!1),e===Mv&&(zn(r.head),r.lookahead===0&&(r.strstart=0,r.block_start=0,r.insert=0))),Ot(t),t.avail_out===0))return r.last_flush=-1,Xe}return e!==rr?Xe:r.wrap<=0?Nm:(r.wrap===2?(ne(r,t.adler&255),ne(r,t.adler>>8&255),ne(r,t.adler>>16&255),ne(r,t.adler>>24&255),ne(r,t.total_in&255),ne(r,t.total_in>>8&255),ne(r,t.total_in>>16&255),ne(r,t.total_in>>24&255)):(as(r,t.adler>>>16),as(r,t.adler&65535)),Ot(t),r.wrap>0&&(r.wrap=-r.wrap),r.pending!==0?Xe:Nm)},Qv=t=>{if(vs(t))return Br;let e=t.state.status;return t.state=null,e===_i?Si(t,Av):Xe},Jv=(t,e)=>{let r=e.length;if(vs(t))return Br;let n=t.state,i=n.wrap;if(i===2||i===1&&n.status!==La||n.lookahead)return Br;if(i===1&&(t.adler=ps(t.adler,e,r,0)),n.wrap=0,r>=n.w_size){i===0&&(zn(n.head),n.strstart=0,n.block_start=0,n.insert=0);let c=new Uint8Array(n.w_size);c.set(e.subarray(r-n.w_size,r),0),e=c,r=n.w_size}let a=t.avail_in,o=t.next_in,s=t.input;for(t.avail_in=r,t.next_in=0,t.input=e,Ta(n);n.lookahead>=Z;){let c=n.strstart,l=n.lookahead-(Z-1);do n.ins_h=Hn(n,n.ins_h,n.window[c+Z-1]),n.prev[c&n.w_mask]=n.head[n.ins_h],n.head[n.ins_h]=c,c++;while(--l);n.strstart=c,n.lookahead=Z-1,Ta(n)}return n.strstart+=n.lookahead,n.block_start=n.strstart,n.insert=n.lookahead,n.lookahead=0,n.match_length=n.prev_length=Z-1,n.match_available=0,t.next_in=o,t.input=s,t.avail_in=a,n.wrap=i,Xe},e_=Zv,t_=z0,r_=D0,n_=k0,i_=qv,a_=jv,o_=Qv,s_=Jv,l_="pako deflate (from Nodeca project)",cs={deflateInit:e_,deflateInit2:t_,deflateReset:r_,deflateResetKeep:n_,deflateSetHeader:i_,deflate:a_,deflateEnd:o_,deflateSetDictionary:s_,deflateInfo:l_},c_=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),d_=function(t){let e=Array.prototype.slice.call(arguments,1);for(;e.length;){let r=e.shift();if(r){if(typeof r!="object")throw new TypeError(r+"must be non-object");for(let n in r)c_(r,n)&&(t[n]=r[n])}}return t},u_=t=>{let e=0;for(let n=0,i=t.length;n<i;n++)e+=t[n].length;let r=new Uint8Array(e);for(let n=0,i=0,a=t.length;n<a;n++){let o=t[n];r.set(o,i),i+=o.length}return r},yc={assign:d_,flattenChunks:u_},O0=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{O0=!1}var gs=new Uint8Array(256);for(let t=0;t<256;t++)gs[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;gs[254]=gs[254]=1;var f_=t=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(t);let e,r,n,i,a,o=t.length,s=0;for(i=0;i<o;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<o&&(n=t.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),s+=r<128?1:r<2048?2:r<65536?3:4;for(e=new Uint8Array(s),a=0,i=0;a<s;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<o&&(n=t.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),r<128?e[a++]=r:r<2048?(e[a++]=192|r>>>6,e[a++]=128|r&63):r<65536?(e[a++]=224|r>>>12,e[a++]=128|r>>>6&63,e[a++]=128|r&63):(e[a++]=240|r>>>18,e[a++]=128|r>>>12&63,e[a++]=128|r>>>6&63,e[a++]=128|r&63);return e},h_=(t,e)=>{if(e<65534&&t.subarray&&O0)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let r="";for(let n=0;n<e;n++)r+=String.fromCharCode(t[n]);return r},m_=(t,e)=>{let r=e||t.length;if(typeof TextDecoder=="function"&&TextDecoder.prototype.decode)return new TextDecoder().decode(t.subarray(0,e));let n,i,a=new Array(r*2);for(i=0,n=0;n<r;){let o=t[n++];if(o<128){a[i++]=o;continue}let s=gs[o];if(s>4){a[i++]=65533,n+=s-1;continue}for(o&=s===2?31:s===3?15:7;s>1&&n<r;)o=o<<6|t[n++]&63,s--;if(s>1){a[i++]=65533;continue}o<65536?a[i++]=o:(o-=65536,a[i++]=55296|o>>10&1023,a[i++]=56320|o&1023)}return h_(a,i)},p_=(t,e)=>{e=e||t.length,e>t.length&&(e=t.length);let r=e-1;for(;r>=0&&(t[r]&192)===128;)r--;return r<0||r===0?e:r+gs[t[r]]>e?r:e},ys={string2buf:f_,buf2string:m_,utf8border:p_};function g_(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}var U0=g_,N0=Object.prototype.toString,{Z_NO_FLUSH:y_,Z_SYNC_FLUSH:b_,Z_FULL_FLUSH:x_,Z_FINISH:v_,Z_OK:mc,Z_STREAM_END:__,Z_DEFAULT_COMPRESSION:S_,Z_DEFAULT_STRATEGY:w_,Z_DEFLATED:M_}=Ei;function _s(t){this.options=yc.assign({level:S_,method:M_,chunkSize:16384,windowBits:15,memLevel:8,strategy:w_},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new U0,this.strm.avail_out=0;let r=cs.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(r!==mc)throw new Error(wi[r]);if(e.header&&cs.deflateSetHeader(this.strm,e.header),e.dictionary){let n;if(typeof e.dictionary=="string"?n=ys.string2buf(e.dictionary):N0.call(e.dictionary)==="[object ArrayBuffer]"?n=new Uint8Array(e.dictionary):n=e.dictionary,r=cs.deflateSetDictionary(this.strm,n),r!==mc)throw new Error(wi[r]);this._dict_set=!0}}_s.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i,a;if(this.ended)return!1;for(e===~~e?a=e:a=e===!0?v_:y_,typeof t=="string"?r.input=ys.string2buf(t):N0.call(t)==="[object ArrayBuffer]"?r.input=new Uint8Array(t):r.input=t,r.next_in=0,r.avail_in=r.input.length;;){if(r.avail_out===0&&(r.output=new Uint8Array(n),r.next_out=0,r.avail_out=n),(a===b_||a===x_)&&r.avail_out<=6){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(i=cs.deflate(r,a),i===__)return r.next_out>0&&this.onData(r.output.subarray(0,r.next_out)),i=cs.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===mc;if(r.avail_out===0){this.onData(r.output);continue}if(a>0&&r.next_out>0){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(r.avail_in===0)break}return!0};_s.prototype.onData=function(t){this.chunks.push(t)};_s.prototype.onEnd=function(t){t===mc&&(this.result=yc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Gu(t,e){let r=new _s(e);if(r.push(t,!0),r.err)throw r.msg||wi[r.err];return r.result}function A_(t,e){return e=e||{},e.raw=!0,Gu(t,e)}function E_(t,e){return e=e||{},e.gzip=!0,Gu(t,e)}var L_=_s,T_=Gu,R_=A_,C_=E_,P_=Ei,I_={Deflate:L_,deflate:T_,deflateRaw:R_,gzip:C_,constants:P_},lc=16209,B_=16191,F_=function(e,r){let n,i,a,o,s,c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,L,M,C=e.state;n=e.next_in,L=e.input,i=n+(e.avail_in-5),a=e.next_out,M=e.output,o=a-(r-e.avail_out),s=a+(e.avail_out-257),c=C.dmax,l=C.wsize,d=C.whave,f=C.wnext,u=C.window,h=C.hold,m=C.bits,g=C.lencode,p=C.distcode,y=(1<<C.lenbits)-1,v=(1<<C.distbits)-1;e:do{m<15&&(h+=L[n++]<<m,m+=8,h+=L[n++]<<m,m+=8),x=g[h&y];t:for(;;){if(b=x>>>24,h>>>=b,m-=b,b=x>>>16&255,b===0)M[a++]=x&65535;else if(b&16){_=x&65535,b&=15,b&&(m<b&&(h+=L[n++]<<m,m+=8),_+=h&(1<<b)-1,h>>>=b,m-=b),m<15&&(h+=L[n++]<<m,m+=8,h+=L[n++]<<m,m+=8),x=p[h&v];r:for(;;){if(b=x>>>24,h>>>=b,m-=b,b=x>>>16&255,b&16){if(w=x&65535,b&=15,m<b&&(h+=L[n++]<<m,m+=8,m<b&&(h+=L[n++]<<m,m+=8)),w+=h&(1<<b)-1,w>c){e.msg="invalid distance too far back",C.mode=lc;break e}if(h>>>=b,m-=b,b=a-o,w>b){if(b=w-b,b>d&&C.sane){e.msg="invalid distance too far back",C.mode=lc;break e}if(S=0,E=u,f===0){if(S+=l-b,b<_){_-=b;do M[a++]=u[S++];while(--b);S=a-w,E=M}}else if(f<b){if(S+=l+f-b,b-=f,b<_){_-=b;do M[a++]=u[S++];while(--b);if(S=0,f<_){b=f,_-=b;do M[a++]=u[S++];while(--b);S=a-w,E=M}}}else if(S+=f-b,b<_){_-=b;do M[a++]=u[S++];while(--b);S=a-w,E=M}for(;_>2;)M[a++]=E[S++],M[a++]=E[S++],M[a++]=E[S++],_-=3;_&&(M[a++]=E[S++],_>1&&(M[a++]=E[S++]))}else{S=a-w;do M[a++]=M[S++],M[a++]=M[S++],M[a++]=M[S++],_-=3;while(_>2);_&&(M[a++]=M[S++],_>1&&(M[a++]=M[S++]))}}else if((b&64)===0){x=p[(x&65535)+(h&(1<<b)-1)];continue r}else{e.msg="invalid distance code",C.mode=lc;break e}break}}else if((b&64)===0){x=g[(x&65535)+(h&(1<<b)-1)];continue t}else if(b&32){C.mode=B_;break e}else{e.msg="invalid literal/length code",C.mode=lc;break e}break}}while(n<i&&a<s);_=m>>3,n-=_,m-=_<<3,h&=(1<<m)-1,e.next_in=n,e.next_out=a,e.avail_in=n<i?5+(i-n):5-(n-i),e.avail_out=a<s?257+(s-a):257-(a-s),C.hold=h,C.bits=m},Aa=15,Vm=852,Gm=592,Wm=0,_u=1,Xm=2,k_=new Uint16Array([3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0]),D_=new Uint8Array([16,16,16,16,16,16,16,16,17,17,17,17,18,18,18,18,19,19,19,19,20,20,20,20,21,21,21,21,16,72,78]),z_=new Uint16Array([1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0]),O_=new Uint8Array([16,16,16,16,17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,64,64]),U_=(t,e,r,n,i,a,o,s)=>{let c=s.bits,l=0,d=0,f=0,u=0,h=0,m=0,g=0,p=0,y=0,v=0,x,b,_,w,S,E=null,L,M=new Uint16Array(Aa+1),C=new Uint16Array(Aa+1),I=null,B,F,U;for(l=0;l<=Aa;l++)M[l]=0;for(d=0;d<n;d++)M[e[r+d]]++;for(h=c,u=Aa;u>=1&&M[u]===0;u--);if(h>u&&(h=u),u===0)return i[a++]=1<<24|64<<16|0,i[a++]=1<<24|64<<16|0,s.bits=1,0;for(f=1;f<u&&M[f]===0;f++);for(h<f&&(h=f),p=1,l=1;l<=Aa;l++)if(p<<=1,p-=M[l],p<0)return-1;if(p>0&&(t===Wm||u!==1))return-1;for(C[1]=0,l=1;l<Aa;l++)C[l+1]=C[l]+M[l];for(d=0;d<n;d++)e[r+d]!==0&&(o[C[e[r+d]]++]=d);if(t===Wm?(E=I=o,L=20):t===_u?(E=k_,I=D_,L=257):(E=z_,I=O_,L=0),v=0,d=0,l=f,S=a,m=h,g=0,_=-1,y=1<<h,w=y-1,t===_u&&y>Vm||t===Xm&&y>Gm)return 1;for(;;){B=l-g,o[d]+1<L?(F=0,U=o[d]):o[d]>=L?(F=I[o[d]-L],U=E[o[d]-L]):(F=96,U=0),x=1<<l-g,b=1<<m,f=b;do b-=x,i[S+(v>>g)+b]=B<<24|F<<16|U|0;while(b!==0);for(x=1<<l-1;v&x;)x>>=1;if(x!==0?(v&=x-1,v+=x):v=0,d++,--M[l]===0){if(l===u)break;l=e[r+o[d]]}if(l>h&&(v&w)!==_){for(g===0&&(g=h),S+=f,m=l-g,p=1<<m;m+g<u&&(p-=M[m+g],!(p<=0));)m++,p<<=1;if(y+=1<<m,t===_u&&y>Vm||t===Xm&&y>Gm)return 1;_=v&w,i[_]=h<<24|m<<16|S-a|0}}return v!==0&&(i[S+v]=l-g<<24|64<<16|0),s.bits=h,0},ds=U_,N_=0,H0=1,V0=2,{Z_FINISH:Km,Z_BLOCK:H_,Z_TREES:cc,Z_OK:Ai,Z_STREAM_END:V_,Z_NEED_DICT:G_,Z_STREAM_ERROR:nr,Z_DATA_ERROR:G0,Z_MEM_ERROR:W0,Z_BUF_ERROR:W_,Z_DEFLATED:Ym}=Ei,bc=16180,$m=16181,qm=16182,Zm=16183,jm=16184,Qm=16185,Jm=16186,e0=16187,t0=16188,r0=16189,pc=16190,rn=16191,Su=16192,n0=16193,wu=16194,i0=16195,a0=16196,o0=16197,s0=16198,dc=16199,uc=16200,l0=16201,c0=16202,d0=16203,u0=16204,f0=16205,Mu=16206,h0=16207,m0=16208,be=16209,X0=16210,K0=16211,X_=852,K_=592,Y_=15,$_=Y_,p0=t=>(t>>>24&255)+(t>>>8&65280)+((t&65280)<<8)+((t&255)<<24);function q_(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}var Li=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.mode<bc||e.mode>K0?1:0},Y0=t=>{if(Li(t))return nr;let e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=e.wrap&1),e.mode=bc,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(X_),e.distcode=e.distdyn=new Int32Array(K_),e.sane=1,e.back=-1,Ai},$0=t=>{if(Li(t))return nr;let e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,Y0(t)},q0=(t,e)=>{let r;if(Li(t))return nr;let n=t.state;return e<0?(r=0,e=-e):(r=(e>>4)+5,e<48&&(e&=15)),e&&(e<8||e>15)?nr:(n.window!==null&&n.wbits!==e&&(n.window=null),n.wrap=r,n.wbits=e,$0(t))},Z0=(t,e)=>{if(!t)return nr;let r=new q_;t.state=r,r.strm=t,r.window=null,r.mode=bc;let n=q0(t,e);return n!==Ai&&(t.state=null),n},Z_=t=>Z0(t,$_),g0=!0,Au,Eu,j_=t=>{if(g0){Au=new Int32Array(512),Eu=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(ds(H0,t.lens,0,288,Au,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;ds(V0,t.lens,0,32,Eu,0,t.work,{bits:5}),g0=!1}t.lencode=Au,t.lenbits=9,t.distcode=Eu,t.distbits=5},j0=(t,e,r,n)=>{let i,a=t.state;return a.window===null&&(a.wsize=1<<a.wbits,a.wnext=0,a.whave=0,a.window=new Uint8Array(a.wsize)),n>=a.wsize?(a.window.set(e.subarray(r-a.wsize,r),0),a.wnext=0,a.whave=a.wsize):(i=a.wsize-a.wnext,i>n&&(i=n),a.window.set(e.subarray(r-n,r-n+i),a.wnext),n-=i,n?(a.window.set(e.subarray(r-n,r),0),a.wnext=n,a.whave=a.wsize):(a.wnext+=i,a.wnext===a.wsize&&(a.wnext=0),a.whave<a.wsize&&(a.whave+=i))),0},Q_=(t,e)=>{let r,n,i,a,o,s,c,l,d,f,u,h,m,g,p=0,y,v,x,b,_,w,S,E,L=new Uint8Array(4),M,C,I=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Li(t)||!t.output||!t.input&&t.avail_in!==0)return nr;r=t.state,r.mode===rn&&(r.mode=Su),o=t.next_out,i=t.output,c=t.avail_out,a=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,f=s,u=c,E=Ai;e:for(;;)switch(r.mode){case bc:if(r.wrap===0){r.mode=Su;break}for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.wrap&2&&l===35615){r.wbits===0&&(r.wbits=15),r.check=0,L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0),l=0,d=0,r.mode=$m;break}if(r.head&&(r.head.done=!1),!(r.wrap&1)||(((l&255)<<8)+(l>>8))%31){t.msg="incorrect header check",r.mode=be;break}if((l&15)!==Ym){t.msg="unknown compression method",r.mode=be;break}if(l>>>=4,d-=4,S=(l&15)+8,r.wbits===0&&(r.wbits=S),S>15||S>r.wbits){t.msg="invalid window size",r.mode=be;break}r.dmax=1<<r.wbits,r.flags=0,t.adler=r.check=1,r.mode=l&512?r0:rn,l=0,d=0;break;case $m:for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.flags=l,(r.flags&255)!==Ym){t.msg="unknown compression method",r.mode=be;break}if(r.flags&57344){t.msg="unknown header flags set",r.mode=be;break}r.head&&(r.head.text=l>>8&1),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0)),l=0,d=0,r.mode=qm;case qm:for(;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.head&&(r.head.time=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,L[2]=l>>>16&255,L[3]=l>>>24&255,r.check=Fe(r.check,L,4,0)),l=0,d=0,r.mode=Zm;case Zm:for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.head&&(r.head.xflags=l&255,r.head.os=l>>8),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0)),l=0,d=0,r.mode=jm;case jm:if(r.flags&1024){for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.length=l,r.head&&(r.head.extra_len=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=Fe(r.check,L,2,0)),l=0,d=0}else r.head&&(r.head.extra=null);r.mode=Qm;case Qm:if(r.flags&1024&&(h=r.length,h>s&&(h=s),h&&(r.head&&(S=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Uint8Array(r.head.extra_len)),r.head.extra.set(n.subarray(a,a+h),S)),r.flags&512&&r.wrap&4&&(r.check=Fe(r.check,n,h,a)),s-=h,a+=h,r.length-=h),r.length))break e;r.length=0,r.mode=Jm;case Jm:if(r.flags&2048){if(s===0)break e;h=0;do S=n[a+h++],r.head&&S&&r.length<65536&&(r.head.name+=String.fromCharCode(S));while(S&&h<s);if(r.flags&512&&r.wrap&4&&(r.check=Fe(r.check,n,h,a)),s-=h,a+=h,S)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=e0;case e0:if(r.flags&4096){if(s===0)break e;h=0;do S=n[a+h++],r.head&&S&&r.length<65536&&(r.head.comment+=String.fromCharCode(S));while(S&&h<s);if(r.flags&512&&r.wrap&4&&(r.check=Fe(r.check,n,h,a)),s-=h,a+=h,S)break e}else r.head&&(r.head.comment=null);r.mode=t0;case t0:if(r.flags&512){for(;d<16;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.wrap&4&&l!==(r.check&65535)){t.msg="header crc mismatch",r.mode=be;break}l=0,d=0}r.head&&(r.head.hcrc=r.flags>>9&1,r.head.done=!0),t.adler=r.check=0,r.mode=rn;break;case r0:for(;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}t.adler=r.check=p0(l),l=0,d=0,r.mode=pc;case pc:if(r.havedict===0)return t.next_out=o,t.avail_out=c,t.next_in=a,t.avail_in=s,r.hold=l,r.bits=d,G_;t.adler=r.check=1,r.mode=rn;case rn:if(e===H_||e===cc)break e;case Su:if(r.last){l>>>=d&7,d-=d&7,r.mode=Mu;break}for(;d<3;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}switch(r.last=l&1,l>>>=1,d-=1,l&3){case 0:r.mode=n0;break;case 1:if(j_(r),r.mode=dc,e===cc){l>>>=2,d-=2;break e}break;case 2:r.mode=a0;break;case 3:t.msg="invalid block type",r.mode=be}l>>>=2,d-=2;break;case n0:for(l>>>=d&7,d-=d&7;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if((l&65535)!==(l>>>16^65535)){t.msg="invalid stored block lengths",r.mode=be;break}if(r.length=l&65535,l=0,d=0,r.mode=wu,e===cc)break e;case wu:r.mode=i0;case i0:if(h=r.length,h){if(h>s&&(h=s),h>c&&(h=c),h===0)break e;i.set(n.subarray(a,a+h),o),s-=h,a+=h,c-=h,o+=h,r.length-=h;break}r.mode=rn;break;case a0:for(;d<14;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.nlen=(l&31)+257,l>>>=5,d-=5,r.ndist=(l&31)+1,l>>>=5,d-=5,r.ncode=(l&15)+4,l>>>=4,d-=4,r.nlen>286||r.ndist>30){t.msg="too many length or distance symbols",r.mode=be;break}r.have=0,r.mode=o0;case o0:for(;r.have<r.ncode;){for(;d<3;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.lens[I[r.have++]]=l&7,l>>>=3,d-=3}for(;r.have<19;)r.lens[I[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,M={bits:r.lenbits},E=ds(N_,r.lens,0,19,r.lencode,0,r.work,M),r.lenbits=M.bits,E){t.msg="invalid code lengths set",r.mode=be;break}r.have=0,r.mode=s0;case s0:for(;r.have<r.nlen+r.ndist;){for(;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,v=p>>>16&255,x=p&65535,!(y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(x<16)l>>>=y,d-=y,r.lens[r.have++]=x;else{if(x===16){for(C=y+2;d<C;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(l>>>=y,d-=y,r.have===0){t.msg="invalid bit length repeat",r.mode=be;break}S=r.lens[r.have-1],h=3+(l&3),l>>>=2,d-=2}else if(x===17){for(C=y+3;d<C;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=y,d-=y,S=0,h=3+(l&7),l>>>=3,d-=3}else{for(C=y+7;d<C;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=y,d-=y,S=0,h=11+(l&127),l>>>=7,d-=7}if(r.have+h>r.nlen+r.ndist){t.msg="invalid bit length repeat",r.mode=be;break}for(;h--;)r.lens[r.have++]=S}}if(r.mode===be)break;if(r.lens[256]===0){t.msg="invalid code -- missing end-of-block",r.mode=be;break}if(r.lenbits=9,M={bits:r.lenbits},E=ds(H0,r.lens,0,r.nlen,r.lencode,0,r.work,M),r.lenbits=M.bits,E){t.msg="invalid literal/lengths set",r.mode=be;break}if(r.distbits=6,r.distcode=r.distdyn,M={bits:r.distbits},E=ds(V0,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,M),r.distbits=M.bits,E){t.msg="invalid distances set",r.mode=be;break}if(r.mode=dc,e===cc)break e;case dc:r.mode=uc;case uc:if(s>=6&&c>=258){t.next_out=o,t.avail_out=c,t.next_in=a,t.avail_in=s,r.hold=l,r.bits=d,F_(t,u),o=t.next_out,i=t.output,c=t.avail_out,a=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,r.mode===rn&&(r.back=-1);break}for(r.back=0;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,v=p>>>16&255,x=p&65535,!(y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(v&&(v&240)===0){for(b=y,_=v,w=x;p=r.lencode[w+((l&(1<<b+_)-1)>>b)],y=p>>>24,v=p>>>16&255,x=p&65535,!(b+y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=b,d-=b,r.back+=b}if(l>>>=y,d-=y,r.back+=y,r.length=x,v===0){r.mode=f0;break}if(v&32){r.back=-1,r.mode=rn;break}if(v&64){t.msg="invalid literal/length code",r.mode=be;break}r.extra=v&15,r.mode=l0;case l0:if(r.extra){for(C=r.extra;d<C;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.length+=l&(1<<r.extra)-1,l>>>=r.extra,d-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=c0;case c0:for(;p=r.distcode[l&(1<<r.distbits)-1],y=p>>>24,v=p>>>16&255,x=p&65535,!(y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if((v&240)===0){for(b=y,_=v,w=x;p=r.distcode[w+((l&(1<<b+_)-1)>>b)],y=p>>>24,v=p>>>16&255,x=p&65535,!(b+y<=d);){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}l>>>=b,d-=b,r.back+=b}if(l>>>=y,d-=y,r.back+=y,v&64){t.msg="invalid distance code",r.mode=be;break}r.offset=x,r.extra=v&15,r.mode=d0;case d0:if(r.extra){for(C=r.extra;d<C;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}r.offset+=l&(1<<r.extra)-1,l>>>=r.extra,d-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){t.msg="invalid distance too far back",r.mode=be;break}r.mode=u0;case u0:if(c===0)break e;if(h=u-c,r.offset>h){if(h=r.offset-h,h>r.whave&&r.sane){t.msg="invalid distance too far back",r.mode=be;break}h>r.wnext?(h-=r.wnext,m=r.wsize-h):m=r.wnext-h,h>r.length&&(h=r.length),g=r.window}else g=i,m=o-r.offset,h=r.length;h>c&&(h=c),c-=h,r.length-=h;do i[o++]=g[m++];while(--h);r.length===0&&(r.mode=uc);break;case f0:if(c===0)break e;i[o++]=r.length,c--,r.mode=uc;break;case Mu:if(r.wrap){for(;d<32;){if(s===0)break e;s--,l|=n[a++]<<d,d+=8}if(u-=c,t.total_out+=u,r.total+=u,r.wrap&4&&u&&(t.adler=r.check=r.flags?Fe(r.check,i,u,o-u):ps(r.check,i,u,o-u)),u=c,r.wrap&4&&(r.flags?l:p0(l))!==r.check){t.msg="incorrect data check",r.mode=be;break}l=0,d=0}r.mode=h0;case h0:if(r.wrap&&r.flags){for(;d<32;){if(s===0)break e;s--,l+=n[a++]<<d,d+=8}if(r.wrap&4&&l!==(r.total&4294967295)){t.msg="incorrect length check",r.mode=be;break}l=0,d=0}r.mode=m0;case m0:E=V_;break e;case be:E=G0;break e;case X0:return W0;case K0:default:return nr}return t.next_out=o,t.avail_out=c,t.next_in=a,t.avail_in=s,r.hold=l,r.bits=d,(r.wsize||u!==t.avail_out&&r.mode<be&&(r.mode<Mu||e!==Km))&&j0(t,t.output,t.next_out,u-t.avail_out),f-=t.avail_in,u-=t.avail_out,t.total_in+=f,t.total_out+=u,r.total+=u,r.wrap&4&&u&&(t.adler=r.check=r.flags?Fe(r.check,i,u,t.next_out-u):ps(r.check,i,u,t.next_out-u)),t.data_type=r.bits+(r.last?64:0)+(r.mode===rn?128:0)+(r.mode===dc||r.mode===wu?256:0),(f===0&&u===0||e===Km)&&E===Ai&&(E=W_),E},J_=t=>{if(Li(t))return nr;let e=t.state;return e.window&&(e.window=null),t.state=null,Ai},eS=(t,e)=>{if(Li(t))return nr;let r=t.state;return(r.wrap&2)===0?nr:(r.head=e,e.done=!1,Ai)},tS=(t,e)=>{let r=e.length,n,i,a;return Li(t)||(n=t.state,n.wrap!==0&&n.mode!==pc)?nr:n.mode===pc&&(i=1,i=ps(i,e,r,0),i!==n.check)?G0:(a=j0(t,e,r,r),a?(n.mode=X0,W0):(n.havedict=1,Ai))},rS=$0,nS=q0,iS=Y0,aS=Z_,oS=Z0,sS=Q_,lS=J_,cS=eS,dS=tS,uS="pako inflate (from Nodeca project)",an={inflateReset:rS,inflateReset2:nS,inflateResetKeep:iS,inflateInit:aS,inflateInit2:oS,inflate:sS,inflateEnd:lS,inflateGetHeader:cS,inflateSetDictionary:dS,inflateInfo:uS};function fS(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}var hS=fS,Q0=Object.prototype.toString,{Z_NO_FLUSH:mS,Z_FINISH:pS,Z_OK:bs,Z_STREAM_END:Lu,Z_NEED_DICT:Tu,Z_STREAM_ERROR:gS,Z_DATA_ERROR:y0,Z_MEM_ERROR:yS}=Ei;function Ss(t){this.options=yc.assign({chunkSize:1024*64,windowBits:15,to:""},t||{});let e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,e.windowBits===0&&(e.windowBits=-15)),e.windowBits>=0&&e.windowBits<16&&!(t&&t.windowBits)&&(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&(e.windowBits&15)===0&&(e.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new U0,this.strm.avail_out=0;let r=an.inflateInit2(this.strm,e.windowBits);if(r!==bs)throw new Error(wi[r]);if(this.header=new hS,an.inflateGetHeader(this.strm,this.header),e.dictionary&&(typeof e.dictionary=="string"?e.dictionary=ys.string2buf(e.dictionary):Q0.call(e.dictionary)==="[object ArrayBuffer]"&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(r=an.inflateSetDictionary(this.strm,e.dictionary),r!==bs)))throw new Error(wi[r])}Ss.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i=this.options.dictionary,a,o,s;if(this.ended)return!1;for(e===~~e?o=e:o=e===!0?pS:mS,Q0.call(t)==="[object ArrayBuffer]"?r.input=new Uint8Array(t):r.input=t,r.next_in=0,r.avail_in=r.input.length;;){for(r.avail_out===0&&(r.output=new Uint8Array(n),r.next_out=0,r.avail_out=n),a=an.inflate(r,o),a===Tu&&i&&(a=an.inflateSetDictionary(r,i),a===bs?a=an.inflate(r,o):a===y0&&(a=Tu));r.avail_in>0&&a===Lu&&r.state.wrap>0&&t[r.next_in]!==0;)an.inflateReset(r),a=an.inflate(r,o);switch(a){case gS:case y0:case Tu:case yS:return this.onEnd(a),this.ended=!0,!1}if(s=r.avail_out,r.next_out&&(r.avail_out===0||a===Lu))if(this.options.to==="string"){let c=ys.utf8border(r.output,r.next_out),l=r.next_out-c,d=ys.buf2string(r.output,c);r.next_out=l,r.avail_out=n-l,l&&r.output.set(r.output.subarray(c,c+l),0),this.onData(d)}else this.onData(r.output.length===r.next_out?r.output:r.output.subarray(0,r.next_out));if(!(a===bs&&s===0)){if(a===Lu)return a=an.inflateEnd(this.strm),this.onEnd(a),this.ended=!0,!0;if(r.avail_in===0)break}}return!0};Ss.prototype.onData=function(t){this.chunks.push(t)};Ss.prototype.onEnd=function(t){t===bs&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=yc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Wu(t,e){let r=new Ss(e);if(r.push(t),r.err)throw r.msg||wi[r.err];return r.result}function bS(t,e){return e=e||{},e.raw=!0,Wu(t,e)}var xS=Ss,vS=Wu,_S=bS,SS=Wu,wS=Ei,MS={Inflate:xS,inflate:vS,inflateRaw:_S,ungzip:SS,constants:wS},{Deflate:AS,deflate:ES,deflateRaw:LS,gzip:TS}=I_,{Inflate:RS,inflate:CS,inflateRaw:PS,ungzip:IS}=MS,BS=AS,FS=ES,kS=LS,DS=TS,zS=RS,OS=CS,US=PS,NS=IS,HS=Ei,Xu={Deflate:BS,deflate:FS,deflateRaw:kS,gzip:DS,Inflate:zS,inflate:OS,inflateRaw:US,ungzip:NS,constants:HS};var Ia=class Ia{constructor(e=Ia.INITIAL_SIZE){this.buffer=new Uint8Array(e),this.readOffset=0,this.writeOffset=0}append(e){let r=e instanceof Uint8Array?e:new Uint8Array(e),n=this.writeOffset+r.length;n>this.buffer.length&&this.grow(n),this.buffer.set(r,this.writeOffset),this.writeOffset+=r.length}hasBytes(e){return this.writeOffset-this.readOffset>=e}available(){return this.writeOffset-this.readOffset}readByte(){if(!this.hasBytes(1))throw new Error("Buffer underflow");return this.buffer[this.readOffset++]}readShort(){if(!this.hasBytes(2))throw new Error("Buffer underflow");let e=this.buffer[this.readOffset]|this.buffer[this.readOffset+1]<<8;return this.readOffset+=2,e>32767?e-65536:e}readLong(){if(!this.hasBytes(4))throw new Error("Buffer underflow");let e=this.buffer[this.readOffset]|this.buffer[this.readOffset+1]<<8|this.buffer[this.readOffset+2]<<16|this.buffer[this.readOffset+3]<<24;return this.readOffset+=4,e}readFloat(){if(!this.hasBytes(4))throw new Error("Buffer underflow");let r=new DataView(this.buffer.buffer,this.buffer.byteOffset+this.readOffset,4).getFloat32(0,!0);return this.readOffset+=4,r}readString(){let e=Math.min(Ia.MAX_STRING_LENGTH,this.writeOffset-this.readOffset),r=0;for(;r<e&&this.buffer[this.readOffset+r]!==0;)r++;if(r>=e)throw this.writeOffset-this.readOffset<=e?new Error("Buffer underflow"):new Error("String exceeds max length");let n=this.buffer.slice(this.readOffset,this.readOffset+r);return this.readOffset+=r+1,new TextDecoder("latin1").decode(n)}peekBytes(e){if(!this.hasBytes(e))throw new Error("Buffer underflow");return this.buffer.slice(this.readOffset,this.readOffset+e)}readBytes(e){if(!this.hasBytes(e))throw new Error("Buffer underflow");let r=this.buffer.slice(this.readOffset,this.readOffset+e);return this.readOffset+=e,r}readData(e){return this.readBytes(e)}getReadPosition(){return this.readOffset}getWritePosition(){return this.writeOffset}setReadPosition(e){if(e<0||e>this.writeOffset)throw new Error("Invalid read position");this.readOffset=e}grow(e){let r=e?Math.max(e,this.buffer.length*2):this.buffer.length*2,n=new Uint8Array(r);n.set(this.buffer),this.buffer=n}compact(){if(this.readOffset===0)return;let e=this.writeOffset-this.readOffset;if(e===0){this.readOffset=0,this.writeOffset=0;return}this.buffer.copyWithin(0,this.readOffset,this.writeOffset),this.readOffset=0,this.writeOffset=e}getCapacity(){return this.buffer.length}reset(){this.readOffset=0,this.writeOffset=0}};Ia.INITIAL_SIZE=64*1024,Ia.MAX_STRING_LENGTH=2048;var Vn=Ia;var kr=()=>({number:0,modelindex:0,modelindex2:0,modelindex3:0,modelindex4:0,frame:0,skinnum:0,effects:0,renderfx:0,origin:{x:0,y:0,z:0},old_origin:{x:0,y:0,z:0},angles:{x:0,y:0,z:0},sound:0,event:0,solid:0,bits:0,bitsHigh:0,alpha:0,scale:0,instanceBits:0,loopVolume:0,loopAttenuation:0,owner:0,oldFrame:0}),hr=()=>({pm_type:0,origin:{x:0,y:0,z:0},velocity:{x:0,y:0,z:0},pm_time:0,pm_flags:0,gravity:0,delta_angles:{x:0,y:0,z:0},viewoffset:{x:0,y:0,z:0},viewangles:{x:0,y:0,z:0},kick_angles:{x:0,y:0,z:0},gun_index:0,gun_frame:0,gun_offset:{x:0,y:0,z:0},gun_angles:{x:0,y:0,z:0},blend:[0,0,0,0],fov:0,rdflags:0,stats:new Array(32).fill(0),gunskin:0,gunrate:0,damage_blend:[0,0,0,0],team_id:0,watertype:0});var J0={0:T.bad,1:T.nop,2:T.disconnect,3:T.reconnect,4:T.download,5:T.frame,6:T.inventory,7:T.layout,8:T.muzzleflash,9:T.temp_entity,10:T.sound,11:T.print,12:T.stufftext,13:T.serverdata,14:T.configstring,15:T.spawnbaseline,16:T.centerprint,17:T.playerinfo,18:T.packetentities,19:T.deltapacketentities,20:T.muzzleflash2},xc=class{constructor(){this.protocolVersion=34}translateCommand(e){return J0[e]!==void 0?J0[e]:T.bad}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),a=e.readString(),o=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:a,playerNum:o,levelName:s}}parseEntityBits(e){let r=e.readByte();r&gr&&(r|=e.readByte()<<8),r&br&&(r|=e.readByte()<<16),r&xr&&(r|=e.readByte()<<24);let n;return r&Zn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,a,o){r.number=e.number,r.modelindex=e.modelindex,r.modelindex2=e.modelindex2,r.modelindex3=e.modelindex3,r.modelindex4=e.modelindex4,r.frame=e.frame,r.skinnum=e.skinnum,r.effects=e.effects,r.renderfx=e.renderfx,r.origin.x=e.origin.x,r.origin.y=e.origin.y,r.origin.z=e.origin.z,r.old_origin.x=e.origin.x,r.old_origin.y=e.origin.y,r.old_origin.z=e.origin.z,r.angles.x=e.angles.x,r.angles.y=e.angles.y,r.angles.z=e.angles.z,r.sound=e.sound,r.event=e.event,r.solid=e.solid,r.number=n,r.bits=i,i&vt&&(r.modelindex=o.readByte()),i&St&&(r.modelindex2=o.readByte()),i&wt&&(r.modelindex3=o.readByte()),i&Mt&&(r.modelindex4=o.readByte()),i>&&(r.frame=o.readByte()),i&_t&&(r.frame=o.readShort()),i&He&&i&We?r.skinnum=o.readLong():i&He?r.skinnum=o.readByte():i&We&&(r.skinnum=o.readShort()),i&Ne&&i&Ge?r.effects=o.readLong():i&Ne?r.effects=o.readByte():i&Ge&&(r.effects=o.readShort()),i&Ue&&i&Ve?r.renderfx=o.readLong():i&Ue?r.renderfx=o.readByte():i&Ve&&(r.renderfx=o.readShort()),i&ft&&(r.origin.x=o.readShort()*.125),i&ht&&(r.origin.y=o.readShort()*.125),i&bt&&(r.origin.z=o.readShort()*.125),i&xt&&(r.angles.x=o.readByte()*(360/256)),i&mt&&(r.angles.y=o.readByte()*(360/256)),i&pt&&(r.angles.z=o.readByte()*(360/256)),i&sr&&(r.old_origin.x=o.readShort()*.125,r.old_origin.y=o.readShort()*.125,r.old_origin.z=o.readShort()*.125),i&At&&(r.sound=o.readByte()),i&yt?r.event=o.readByte():r.event=0,i&Et&&(r.solid=o.readShort())}parsePlayerState(e){let r=hr(),n=e.readShort();n&1&&(r.pm_type=e.readByte()),n&2&&(r.origin.x=e.readShort()*.125,r.origin.y=e.readShort()*.125,r.origin.z=e.readShort()*.125),n&4&&(r.velocity.x=e.readShort()*.125,r.velocity.y=e.readShort()*.125,r.velocity.z=e.readShort()*.125),n&8&&(r.pm_time=e.readByte()),n&16&&(r.pm_flags=e.readByte()),n&32&&(r.gravity=e.readShort()),n&64&&(r.delta_angles.x=e.readShort()*(180/32768),r.delta_angles.y=e.readShort()*(180/32768),r.delta_angles.z=e.readShort()*(180/32768)),n&128&&(r.viewoffset.x=(e.readByte()<<24>>24)*.25,r.viewoffset.y=(e.readByte()<<24>>24)*.25,r.viewoffset.z=(e.readByte()<<24>>24)*.25),n&256&&(r.viewangles.x=e.readShort()*(360/65536),r.viewangles.y=e.readShort()*(360/65536),r.viewangles.z=e.readShort()*(360/65536)),n&512&&(r.kick_angles.x=(e.readByte()<<24>>24)*.25,r.kick_angles.y=(e.readByte()<<24>>24)*.25,r.kick_angles.z=(e.readByte()<<24>>24)*.25),n&4096&&(r.gun_index=e.readByte()),n&8192&&(r.gun_frame=e.readByte(),r.gun_offset.x=(e.readByte()<<24>>24)*.25,r.gun_offset.y=(e.readByte()<<24>>24)*.25,r.gun_offset.z=(e.readByte()<<24>>24)*.25,r.gun_angles.x=(e.readByte()<<24>>24)*.25,r.gun_angles.y=(e.readByte()<<24>>24)*.25,r.gun_angles.z=(e.readByte()<<24>>24)*.25),n&1024&&(r.blend[0]=e.readByte(),r.blend[1]=e.readByte(),r.blend[2]=e.readByte(),r.blend[3]=e.readByte()),n&2048&&(r.fov=e.readByte()),n&16384&&(r.rdflags=e.readByte()),n&32768&&(r.watertype=e.readByte());let i=e.readLong();for(let a=0;a<32;a++)i&1<<a&&(r.stats[a]=e.readShort());return r}};var Dr=2023,vc=class{constructor(){this.protocolVersion=Dr}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),a=e.readByte(),o=e.readString(),s=e.readShort();if(s===-2){let l=e.readShort();for(let d=0;d<l;d++)e.readShort();s=0}else s===-1&&(s=-1);let c=e.readString();return{protocol:r,serverCount:n,spawnCount:n,attractLoop:0,gameDir:o,playerNum:s,levelName:c,tickRate:a,demoType:i}}parseEntityBits(e){let r=e.readByte();r&gr&&(r|=e.readByte()<<8),r&br&&(r|=e.readByte()<<16),r&xr&&(r|=e.readByte()<<24);let n=0;r&Ii&&(n=e.readByte());let i;return r&Zn?i=e.readShort():i=e.readByte(),{number:i,bits:r,bitsHigh:n}}parseDelta(e,r,n,i,a,o){Object.assign(r,e),r.origin={...e.origin},r.old_origin={...e.old_origin},r.angles={...e.angles},r.number=n,r.bits=i,r.bitsHigh=a,i&vt&&(r.modelindex=o.readByte()),i&St&&(r.modelindex2=o.readByte()),i&wt&&(r.modelindex3=o.readByte()),i&Mt&&(r.modelindex4=o.readByte()),i>&&(r.frame=o.readByte()),i&_t&&(r.frame=o.readShort()),i&He&&i&We?r.skinnum=o.readLong():i&He?r.skinnum=o.readByte():i&We&&(r.skinnum=o.readShort()),i&Ne&&i&Ge?r.effects=o.readLong():i&Ne?r.effects=o.readByte():i&Ge&&(r.effects=o.readShort()),i&Ue&&i&Ve?r.renderfx=o.readLong():i&Ue?r.renderfx=o.readByte():i&Ve&&(r.renderfx=o.readShort()),i&ft&&(r.origin.x=o.readShort()*.125),i&ht&&(r.origin.y=o.readShort()*.125),i&bt&&(r.origin.z=o.readShort()*.125),i&xt&&(r.angles.x=o.readByte()*(360/256)),i&mt&&(r.angles.y=o.readByte()*(360/256)),i&pt&&(r.angles.z=o.readByte()*(360/256)),i&sr&&(r.old_origin.x=o.readShort()*.125,r.old_origin.y=o.readShort()*.125,r.old_origin.z=o.readShort()*.125),i&At&&(r.sound=o.readByte()),i&yt?r.event=o.readByte():r.event=0,i&Et&&(r.solid=o.readShort()),i&yr&&(r.alpha=o.readByte()/255),i&vr&&(r.scale=o.readFloat()),i&_r&&(r.instanceBits=o.readLong()),i&Sr&&(r.loopVolume=o.readByte()/255),a&un&&(r.loopAttenuation=o.readByte()/255),a&fn&&(r.owner=o.readShort()),a&hn&&(r.oldFrame=o.readShort())}parsePlayerState(e){let r=hr(),n=e.readShort();n&1&&(r.pm_type=e.readByte()),n&2&&(r.origin.x=e.readShort()*.125,r.origin.y=e.readShort()*.125,r.origin.z=e.readShort()*.125),n&4&&(r.velocity.x=e.readShort()*.125,r.velocity.y=e.readShort()*.125,r.velocity.z=e.readShort()*.125),n&8&&(r.pm_time=e.readByte()),n&16&&(r.pm_flags=e.readByte()),n&32&&(r.gravity=e.readShort()),n&64&&(r.delta_angles.x=e.readShort()*(180/32768),r.delta_angles.y=e.readShort()*(180/32768),r.delta_angles.z=e.readShort()*(180/32768)),n&128&&(r.viewoffset.x=(e.readByte()<<24>>24)*.25,r.viewoffset.y=(e.readByte()<<24>>24)*.25,r.viewoffset.z=(e.readByte()<<24>>24)*.25),n&256&&(r.viewangles.x=e.readShort()*(360/65536),r.viewangles.y=e.readShort()*(360/65536),r.viewangles.z=e.readShort()*(360/65536)),n&512&&(r.kick_angles.x=(e.readByte()<<24>>24)*.25,r.kick_angles.y=(e.readByte()<<24>>24)*.25,r.kick_angles.z=(e.readByte()<<24>>24)*.25),n&4096&&(r.gun_index=e.readByte()),n&8192&&(r.gun_frame=e.readByte(),r.gun_offset.x=(e.readByte()<<24>>24)*.25,r.gun_offset.y=(e.readByte()<<24>>24)*.25,r.gun_offset.z=(e.readByte()<<24>>24)*.25,r.gun_angles.x=(e.readByte()<<24>>24)*.25,r.gun_angles.y=(e.readByte()<<24>>24)*.25,r.gun_angles.z=(e.readByte()<<24>>24)*.25),n&1024&&(r.blend[0]=e.readByte(),r.blend[1]=e.readByte(),r.blend[2]=e.readByte(),r.blend[3]=e.readByte()),n&2048&&(r.fov=e.readByte()),n&16384&&(r.rdflags=e.readByte()),n&32768&&(r.watertype=e.readByte());let i=e.readLong();for(let a=0;a<32;a++)i&1<<a&&(r.stats[a]=e.readShort());return r}};var _c=class{constructor(e=0){this.protocolVersion=e}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),a=e.readString(),o=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:a,playerNum:o,levelName:s}}parseEntityBits(e){let r=e.readByte();r&gr&&(r|=e.readByte()<<8),r&br&&(r|=e.readByte()<<16),r&xr&&(r|=e.readByte()<<24);let n;return r&Zn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,a,o){r.number=e.number,r.modelindex=e.modelindex,r.modelindex2=e.modelindex2,r.modelindex3=e.modelindex3,r.modelindex4=e.modelindex4,r.frame=e.frame,r.skinnum=e.skinnum,r.effects=e.effects,r.renderfx=e.renderfx,r.origin.x=e.origin.x,r.origin.y=e.origin.y,r.origin.z=e.origin.z,r.old_origin.x=e.origin.x,r.old_origin.y=e.origin.y,r.old_origin.z=e.origin.z,r.angles.x=e.angles.x,r.angles.y=e.angles.y,r.angles.z=e.angles.z,r.sound=e.sound,r.event=e.event,r.solid=e.solid,r.number=n,r.bits=i,i&vt&&(r.modelindex=o.readByte()),i&St&&(r.modelindex2=o.readByte()),i&wt&&(r.modelindex3=o.readByte()),i&Mt&&(r.modelindex4=o.readByte()),i>&&(r.frame=o.readByte()),i&_t&&(r.frame=o.readShort()),i&He&&i&We?r.skinnum=o.readLong():i&He?r.skinnum=o.readByte():i&We&&(r.skinnum=o.readShort()),i&Ne&&i&Ge?r.effects=o.readLong():i&Ne?r.effects=o.readByte():i&Ge&&(r.effects=o.readShort()),i&Ue&&i&Ve?r.renderfx=o.readLong():i&Ue?r.renderfx=o.readByte():i&Ve&&(r.renderfx=o.readShort()),i&ft&&(r.origin.x=o.readShort()*.125),i&ht&&(r.origin.y=o.readShort()*.125),i&bt&&(r.origin.z=o.readShort()*.125),i&xt&&(r.angles.x=o.readByte()*(360/256)),i&mt&&(r.angles.y=o.readByte()*(360/256)),i&pt&&(r.angles.z=o.readByte()*(360/256)),i&sr&&(r.old_origin.x=o.readShort()*.125,r.old_origin.y=o.readShort()*.125,r.old_origin.z=o.readShort()*.125),i&At&&(r.sound=o.readByte()),i&yt?r.event=o.readByte():r.event=0,i&Et&&(r.solid=o.readShort())}parsePlayerState(e){let r=hr(),n=e.readShort();n&1&&(r.pm_type=e.readByte()),n&2&&(r.origin.x=e.readShort()*.125,r.origin.y=e.readShort()*.125,r.origin.z=e.readShort()*.125),n&4&&(r.velocity.x=e.readShort()*.125,r.velocity.y=e.readShort()*.125,r.velocity.z=e.readShort()*.125),n&8&&(r.pm_time=e.readByte()),n&16&&(r.pm_flags=e.readByte()),n&32&&(r.gravity=e.readShort()),n&64&&(r.delta_angles.x=e.readShort()*(180/32768),r.delta_angles.y=e.readShort()*(180/32768),r.delta_angles.z=e.readShort()*(180/32768)),n&128&&(r.viewoffset.x=(e.readByte()<<24>>24)*.25,r.viewoffset.y=(e.readByte()<<24>>24)*.25,r.viewoffset.z=(e.readByte()<<24>>24)*.25),n&256&&(r.viewangles.x=e.readShort()*(360/65536),r.viewangles.y=e.readShort()*(360/65536),r.viewangles.z=e.readShort()*(360/65536)),n&512&&(r.kick_angles.x=(e.readByte()<<24>>24)*.25,r.kick_angles.y=(e.readByte()<<24>>24)*.25,r.kick_angles.z=(e.readByte()<<24>>24)*.25),n&4096&&(r.gun_index=e.readByte()),n&8192&&(r.gun_frame=e.readByte(),r.gun_offset.x=(e.readByte()<<24>>24)*.25,r.gun_offset.y=(e.readByte()<<24>>24)*.25,r.gun_offset.z=(e.readByte()<<24>>24)*.25,r.gun_angles.x=(e.readByte()<<24>>24)*.25,r.gun_angles.y=(e.readByte()<<24>>24)*.25,r.gun_angles.z=(e.readByte()<<24>>24)*.25),n&1024&&(r.blend[0]=e.readByte(),r.blend[1]=e.readByte(),r.blend[2]=e.readByte(),r.blend[3]=e.readByte()),n&2048&&(r.fov=e.readByte()),n&16384&&(r.rdflags=e.readByte()),n&32768&&(r.watertype=e.readByte());let i=e.readLong();for(let a=0;a<32;a++)i&1<<a&&(r.stats[a]=e.readShort());return r}};var ws=class{constructor(){this.protocolVersion=0}translateCommand(e){return e===7?T.serverdata:e===12?T.serverdata:e===13?T.serverdata:e===T.stufftext?T.stufftext:T.bad}parseServerData(e){let r=e.readLong();if(r===Dr){let n=e.readLong(),i=e.readByte(),a=e.readByte(),o=e.readString(),s=e.readShort();if(s===-2){let l=e.readShort();for(let d=0;d<l;d++)e.readShort();s=0}else s===-1&&(s=-1);let c=e.readString();return{protocol:r,serverCount:n,spawnCount:n,attractLoop:0,gameDir:o,playerNum:s,levelName:c,tickRate:a,demoType:i}}else{let n=e.readLong(),i=e.readByte(),a=e.readString(),o=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:a,playerNum:o,levelName:s}}}parseEntityBits(e){throw new Error("Bootstrap handler cannot parse entities")}parseDelta(e,r,n,i,a,o){throw new Error("Bootstrap handler cannot parse delta")}parsePlayerState(e){throw new Error("Bootstrap handler cannot parse player state")}};function ep(t){return t===0?new ws:t===Dr?new vc:t===34?new xc:new _c(t)}var tp=1,VS=2,GS=128,Ku=class extends Vn{constructor(r){super(0);this.stream=r}readByte(){return this.stream.readByte()}readShort(){return this.stream.readShort()}readLong(){return this.stream.readLong()}readFloat(){return this.stream.readFloat()}readString(){return this.stream.readString()}readData(r){return this.stream.readData(r)}hasBytes(r){return this.stream.hasMore()}available(){return this.stream.getRemaining()}getReadPosition(){return this.stream.getPosition()}peekBytes(r){throw new Error("peekBytes not implemented for BinaryStreamAdapter")}},ct=class t{constructor(e,r,n=!1){this.strictMode=!1;this.errorCount=0;this.isDemo=tp;e instanceof mn?this.stream=new Ku(e):this.stream=e,this.handler=r,this.strictMode=n,this.protocolHandler=new ws}setProtocolVersion(e){this.protocolHandler.protocolVersion!==e&&(this.protocolHandler=ep(e))}getProtocolVersion(){return this.protocolHandler.protocolVersion}getErrorCount(){return this.errorCount}parseMessage(){for(;this.stream.hasBytes(1);){let e=this.stream.getReadPosition(),r=-1;try{if(r=this.stream.readByte(),r===-1)break;let n=r,i=this.protocolHandler.translateCommand(r);switch(i){case T.bad:if(n===0)return;let a=`Unknown server command: ${n} (translated: ${i}) at offset ${e} (Protocol: ${this.getProtocolVersion()})`;if(this.strictMode)throw new Error(a);console.warn(a),this.errorCount++;return;case T.nop:break;case T.disconnect:this.handler?.onDisconnect&&this.handler.onDisconnect();break;case T.reconnect:this.handler?.onReconnect&&this.handler.onReconnect();break;case T.print:this.parsePrint();break;case T.serverdata:this.parseServerData();break;case T.configstring:this.parseConfigString();break;case T.spawnbaseline:this.parseSpawnBaseline();break;case T.centerprint:this.parseCenterPrint();break;case T.download:this.parseDownload();break;case T.frame:this.parseFrame();break;case T.packetentities:this.parsePacketEntities(!1);break;case T.deltapacketentities:this.parsePacketEntities(!0);break;case T.playerinfo:this.parsePlayerState();break;case T.stufftext:this.parseStuffText();break;case T.layout:this.parseLayout();break;case T.inventory:this.parseInventory();break;case T.sound:this.parseSound();break;case T.muzzleflash:this.parseMuzzleFlash();break;case T.muzzleflash2:this.parseMuzzleFlash2();break;case T.temp_entity:this.parseTempEntity();break;case T.splitclient:this.parseSplitClient();break;case T.configblast:this.parseConfigBlast();break;case T.spawnbaselineblast:this.parseSpawnBaselineBlast();break;case T.level_restart:this.handler?.onLevelRestart&&this.handler.onLevelRestart();break;case T.damage:this.parseDamage();break;case T.locprint:this.parseLocPrint();break;case T.fog:this.parseFog();break;case T.waitingforplayers:this.parseWaitingForPlayers();break;case T.bot_chat:this.parseBotChat();break;case T.poi:this.parsePoi();break;case T.help_path:this.parseHelpPath();break;case T.muzzleflash3:this.parseMuzzleFlash3();break;case T.achievement:this.parseAchievement();break;default:let o=`Unknown server command: ${n} (translated: ${i}) at offset ${e}`;if(this.strictMode)throw new Error(o);console.warn(o),this.errorCount++;return}}catch(n){let i=n.message;if(i==="Buffer underflow"||i.includes("StreamingBuffer")){try{this.stream.setReadPosition(e)}catch(o){console.error("Failed to rollback stream position",o)}return}let a=`offset ${e}, cmd ${r}, protocol ${this.getProtocolVersion()}`;if(console.warn(`Error parsing command ${r} (${a}): ${i}`),this.errorCount++,this.strictMode)throw n;return}}}readAngle16(){return this.stream.readShort()*(360/65536)}readCoord(){return this.stream.readShort()*.125}readAngle(){return this.stream.readByte()*(360/256)}readPos(e){e.x=this.stream.readShort()*.125,e.y=this.stream.readShort()*.125,e.z=this.stream.readShort()*.125}readDir(e){let r=this.stream.readByte();if(r>=or.length)e.x=0,e.y=0,e.z=0;else{let n=or[r];e.x=n[0],e.y=n[1],e.z=n[2]}}parsePrint(){let e=this.stream.readByte(),r=this.stream.readString();this.handler&&this.handler.onPrint(e,r)}parseStuffText(){let e=this.stream.readString();this.handler&&this.handler.onStuffText(e)}parseLayout(){let e=this.stream.readString();this.handler&&this.handler.onLayout(e)}parseCenterPrint(){let e=this.stream.readString();this.handler&&this.handler.onCenterPrint(e)}parseServerData(){let e=this.protocolHandler.parseServerData(this.stream);this.setProtocolVersion(e.protocol),this.handler&&this.handler.onServerData(e.protocol,e.serverCount,e.attractLoop,e.gameDir,e.playerNum,e.levelName,e.tickRate,e.demoType),e.protocol===Dr?this.isDemo=e.demoType??tp:this.isDemo=e.attractLoop}parseConfigString(){let e=this.stream.readShort(),r=this.stream.readString();this.handler&&this.handler.onConfigString(e,r)}parseSplitClient(){let e=this.stream.readByte();this.handler?.onSplitClient&&this.handler.onSplitClient(e)}parseConfigBlast(){let e=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(e);try{let i=Xu.inflate(n),a=new mn(i.buffer);for(;a.hasMore();){let o=a.readUShort(),s=a.readString();this.handler&&this.handler.onConfigString(o,s)}}catch(i){console.error("svc_configblast error",i)}}parseSpawnBaselineBlast(){let e=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(e);try{let i=Xu.inflate(n),a=new mn(i.buffer),o=new t(a,this.handler,this.strictMode);for(o.setProtocolVersion(this.getProtocolVersion());a.hasMore();)o.parseSpawnBaseline()}catch(i){console.error("svc_spawnbaselineblast error",i)}}parseLocPrint(){let e=this.stream.readByte(),r=this.stream.readString(),n=this.stream.readByte(),i=[];for(let a=0;a<n;a++)i.push(this.stream.readString());this.handler?.onLocPrint&&this.handler.onLocPrint(e,r,i)}parseWaitingForPlayers(){let e=this.stream.readByte();this.handler?.onWaitingForPlayers&&this.handler.onWaitingForPlayers(e)}parseBotChat(){let e=this.stream.readString(),r=this.stream.readShort(),n=this.stream.readString();this.handler?.onBotChat&&this.handler.onBotChat(n)}parsePoi(){let e=this.stream.readShort(),r=this.stream.readShort(),n={x:0,y:0,z:0};this.readPos(n);let i=this.stream.readShort(),a=this.stream.readByte(),o=this.stream.readByte();this.handler?.onPoi&&this.handler.onPoi(o,n)}parseHelpPath(){let e=this.stream.readByte(),r={x:0,y:0,z:0};this.readPos(r);let n={x:0,y:0,z:0};this.readDir(n),this.handler?.onHelpPath&&this.handler.onHelpPath(r)}parseAchievement(){let e=this.stream.readString();this.handler?.onAchievement&&this.handler.onAchievement(e)}parseDownload(){let e=this.stream.readShort(),r=this.stream.readByte(),n;e>0&&(n=this.stream.readData(e)),this.handler&&this.handler.onDownload(e,r,n)}parseInventory(){let r=new Array(256);for(let n=0;n<256;n++)r[n]=this.stream.readShort();this.handler&&this.handler.onInventory(r)}parseSound(){let e=this.stream.readByte(),r=this.stream.readByte(),n,i,a,o,s;if(e&1&&(n=this.stream.readByte()),e&2&&(i=this.stream.readByte()),e&16&&(a=this.stream.readByte()),e&8&&(o=this.stream.readShort()),e&4){let c={x:0,y:0,z:0};this.readPos(c),s=c}this.handler&&this.handler.onSound(e,r,n,i,a,o,s)}parseMuzzleFlash(){let e=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash(e,r)}parseMuzzleFlash2(){let e=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash2(e,r)}parseMuzzleFlash3(){let e=this.stream.readShort(),r=this.stream.readShort();this.handler?.onMuzzleFlash3&&this.handler.onMuzzleFlash3(e,r)}parseFog(){let e=this.stream.readByte();if(e&128){let n=this.stream.readByte();e|=n<<8}let r={};e&1&&(r.density=this.stream.readFloat(),r.skyfactor=this.stream.readByte()),e&2&&(r.red=this.stream.readByte()),e&4&&(r.green=this.stream.readByte()),e&8&&(r.blue=this.stream.readByte()),e&16&&(r.time=this.stream.readShort()),e&32&&(r.hf_falloff=this.stream.readFloat()),e&64&&(r.hf_density=this.stream.readFloat()),e&256&&(r.hf_start_r=this.stream.readByte()),e&512&&(r.hf_start_g=this.stream.readByte()),e&1024&&(r.hf_start_b=this.stream.readByte()),e&2048&&(r.hf_start_dist=this.stream.readLong()),e&4096&&(r.hf_end_r=this.stream.readByte()),e&8192&&(r.hf_end_g=this.stream.readByte()),e&16384&&(r.hf_end_b=this.stream.readByte()),e&32768&&(r.hf_end_dist=this.stream.readLong()),this.handler?.onFog&&this.handler.onFog(r)}parseDamage(){let e=this.stream.readByte(),r=[];for(let n=0;n<e;n++){let i=this.stream.readByte(),a={x:0,y:0,z:0};this.readDir(a);let o=i&31,s=(i&32)!==0,c=(i&64)!==0,l=(i&128)!==0;r.push({damage:o,health:s,armor:c,power:l,dir:a})}this.handler?.onDamage&&this.handler.onDamage(r)}parseTempEntity(){let e=this.stream.readByte(),r={x:0,y:0,z:0},n={x:0,y:0,z:0},i={x:0,y:0,z:0},a,o,s,c,l;switch(e){case D.EXPLOSION1:case D.EXPLOSION2:case D.ROCKET_EXPLOSION:case D.GRENADE_EXPLOSION:case D.ROCKET_EXPLOSION_WATER:case D.GRENADE_EXPLOSION_WATER:case D.BFG_EXPLOSION:case D.BFG_BIGEXPLOSION:case D.BOSSTPORT:case D.PLASMA_EXPLOSION:case D.PLAIN_EXPLOSION:case D.CHAINFIST_SMOKE:case D.TRACKER_EXPLOSION:case D.TELEPORT_EFFECT:case D.DBALL_GOAL:case D.NUKEBLAST:case D.WIDOWSPLASH:case D.EXPLOSION1_BIG:case D.EXPLOSION1_NP:this.readPos(r);break;case D.GUNSHOT:case D.BLOOD:case D.BLASTER:case D.SHOTGUN:case D.SPARKS:case D.BULLET_SPARKS:case D.SCREEN_SPARKS:case D.SHIELD_SPARKS:case D.BLASTER2:case D.FLECHETTE:case D.MOREBLOOD:case D.ELECTRIC_SPARKS:case D.HEATBEAM_SPARKS:case D.HEATBEAM_STEAM:this.readPos(r),this.readDir(i);break;case D.SPLASH:case D.LASER_SPARKS:case D.WELDING_SPARKS:case D.TUNNEL_SPARKS:a=this.stream.readByte(),this.readPos(r),this.readDir(i),o=this.stream.readByte();break;case D.BLUEHYPERBLASTER:this.getProtocolVersion()>=32?(this.readPos(r),this.readPos(n)):(this.readPos(r),this.readDir(i));break;case D.GREENBLOOD:this.getProtocolVersion()>=32?(this.readPos(r),this.readDir(i)):(this.readPos(r),this.readPos(n));break;case D.RAILTRAIL:case D.BUBBLETRAIL:case D.BFG_LASER:case D.DEBUGTRAIL:case D.BUBBLETRAIL2:this.readPos(r),this.readPos(n);break;case D.PARASITE_ATTACK:case D.MEDIC_CABLE_ATTACK:this.stream.readShort(),this.readPos(r),this.readPos(n);break;case D.GRAPPLE_CABLE:s=this.stream.readShort(),this.readPos(r),this.readPos(n),this.readPos(i);break;case D.LIGHTNING:c=this.stream.readShort(),l=this.stream.readShort(),this.readPos(r),this.readPos(n);break;case D.FLASHLIGHT:this.readPos(r),s=this.stream.readShort();break;case D.FORCEWALL:this.readPos(r),this.readPos(n),o=this.stream.readByte();break;case D.STEAM:let d=this.stream.readShort();a=this.stream.readByte(),this.readPos(r),this.readDir(i),o=this.stream.readByte(),this.stream.readShort(),d!==-1&&this.stream.readLong();break;case D.WIDOWBEAMOUT:this.stream.readShort();case D.HEATBEAM:case D.MONSTER_HEATBEAM:s=this.stream.readShort(),this.readPos(r),this.readPos(n),this.readDir(i);break}this.handler&&this.handler.onTempEntity(e,r,n,i,a,o,s,c,l)}parseSpawnBaseline(){let e=this.protocolHandler.parseEntityBits(this.stream),r=kr();this.protocolHandler.parseDelta(kr(),r,e.number,e.bits,e.bitsHigh,this.stream),this.handler&&this.handler.onSpawnBaseline(r)}parseFrame(){let e=this.stream.readLong(),r=this.stream.readLong(),n=0;this.getProtocolVersion()!==26&&this.getProtocolVersion()!==25&&(n=this.stream.readByte());let i=this.stream.readByte(),a=this.stream.readData(i),o=this.stream.readByte();if(o=this.protocolHandler.translateCommand(o),o!==T.playerinfo){if(this.strictMode)throw new Error(`Expected svc_playerinfo after svc_frame, got ${o}`);return}let s=this.parsePlayerState(),c=this.stream.readByte();if(c=this.protocolHandler.translateCommand(c),c!==T.packetentities&&c!==T.deltapacketentities){if(this.strictMode)throw new Error(`Expected svc_packetentities after svc_playerinfo, got ${c}`);return}let l=this.collectPacketEntities();if(this.isDemo===GS){let d=this.stream.readByte();for(let f=0;f<d;f++)this.stream.readByte()}this.isDemo===VS&&this.stream.readLong(),this.handler&&this.handler.onFrame({serverFrame:e,deltaFrame:r,surpressCount:n,areaBytes:i,areaBits:a,playerState:s,packetEntities:{delta:!0,entities:l}})}parsePlayerState(){return this.protocolHandler.parsePlayerState(this.stream)}parsePacketEntities(e){let r=this.collectPacketEntities();this.handler&&this.handler.onFrame({serverFrame:0,deltaFrame:0,surpressCount:0,areaBytes:0,areaBits:new Uint8Array,playerState:hr(),packetEntities:{delta:e,entities:r}})}collectPacketEntities(){let e=[];for(;;){let r=this.protocolHandler.parseEntityBits(this.stream);if(r.bits&Xa){if(r.number===0)break;continue}let n=kr();if(r.number===0)break;this.protocolHandler.parseDelta(kr(),n,r.number,r.bits,r.bitsHigh,this.stream),e.push(n)}return e}};var Yu=(d=>(d.WeaponFire="weapon_fire",d.DamageDealt="damage_dealt",d.DamageReceived="damage_received",d.Pickup="pickup",d.Death="death",d.Kill="kill",d.Spawn="spawn",d.PlayerInfo="player_info",d.Chat="chat",d.Objective="objective",d))(Yu||{});var Ba=class{constructor(e){this.events=[];this.summary={totalKills:0,totalDeaths:0,damageDealt:0,damageReceived:0,weaponUsage:new Map};this.header=null;this.configStrings=new Map;this.serverInfo={};this.statistics=null;this.playerStats=new Map;this.weaponStats=new Map;this.activeEntities=new Set;this.buffer=e}analyze(){let e=new fr(this.buffer),r=-1,n=0,i=.1,a=0,o={onServerData:(s,c,l,d,f,u,h,m)=>{a=s,this.header={protocolVersion:s,gameDir:d,levelName:u,playerNum:f,serverCount:c,spawnCount:c,tickRate:h,demoType:m},h&&h>0&&(i=1/h)},onConfigString:(s,c)=>{this.configStrings.set(s,c),s===0&&this.parseServerInfo(c)},onSpawnBaseline:s=>{},onFrame:s=>{let c=new Set;if(s.packetEntities&&s.packetEntities.entities)for(let l of s.packetEntities.entities)c.add(l.number),this.activeEntities.has(l.number)||this.recordEvent({type:"spawn",frame:r,time:n,entityId:l.number,position:{x:l.origin.x,y:l.origin.y,z:l.origin.z},description:`Entity ${l.number} spawned`});this.activeEntities=c,s.playerState&&this.header},onPrint:(s,c)=>{let l=c.replace(/\n/g," ").trim();l.includes("died")||l.includes("killed")||l.includes("suicide")?(this.summary.totalDeaths++,this.recordEvent({type:"death",frame:r,time:n,description:l})):l.startsWith("You got the ")?this.recordEvent({type:"pickup",frame:r,time:n,description:l}):(s===3||s===2)&&this.recordEvent({type:"chat",frame:r,time:n,description:l,data:{level:s}})},onCenterPrint:s=>{this.recordEvent({type:"objective",frame:r,time:n,description:s.trim()})},onStuffText:()=>{},onSound:()=>{},onTempEntity:()=>{},onLayout:()=>{},onInventory:()=>{},onMuzzleFlash:(s,c)=>{this.handleWeaponFire(s,c,r,n)},onMuzzleFlash2:(s,c)=>{this.handleWeaponFire(s,c,r,n)},onMuzzleFlash3:(s,c)=>{this.handleWeaponFire(s,c,r,n)},onDisconnect:()=>{},onReconnect:()=>{},onDownload:()=>{},onDamage:s=>{for(let c of s)if(this.recordEvent({type:"damage_received",frame:r,time:n,value:c.damage,position:c.dir,description:`Took ${c.damage} damage`}),this.summary.damageReceived+=c.damage,this.header){let l=this.getOrCreatePlayerStats(this.header.playerNum);l.damageReceived+=c.damage}}};for(;e.hasMore();){let s=e.readNextBlock();if(!s)break;r++,n=r*i;let c=new ct(s.data,o);c.setProtocolVersion(a),c.parseMessage(),a=c.getProtocolVersion()}return this.statistics={duration:n,frameCount:r+1,averageFps:(r+1)/(n||1),mapName:this.header?.levelName||"unknown",playerCount:1},{events:this.events,summary:this.summary,header:this.header,configStrings:this.configStrings,serverInfo:this.serverInfo,statistics:this.statistics,playerStats:this.playerStats,weaponStats:this.weaponStats}}handleWeaponFire(e,r,n,i){this.recordEvent({type:"weapon_fire",frame:n,time:i,entityId:e,value:r,description:`Weapon ${r} fired by ${e}`});let a=this.summary.weaponUsage.get(r)||0;this.summary.weaponUsage.set(r,a+1);let o=this.getOrCreateWeaponStat(e,r);o.shotsFired++}recordEvent(e){this.events.push(e)}parseServerInfo(e){let r=e.split("\\");for(let n=1;n<r.length;n+=2)n+1<r.length&&(this.serverInfo[r[n]]=r[n+1])}getOrCreatePlayerStats(e){let r=this.playerStats.get(e);return r||(r={kills:0,deaths:0,damageDealt:0,damageReceived:0,suicides:0},this.playerStats.set(e,r)),r}getOrCreateWeaponStat(e,r){let n=this.weaponStats.get(e);n||(n=[],this.weaponStats.set(e,n));let i=n.find(a=>a.weaponId===r);return i||(i={weaponId:r,shotsFired:0,hits:0,kills:0},n.push(i)),i}};var $u=(i=>(i[i.FirstPerson=0]="FirstPerson",i[i.ThirdPerson=1]="ThirdPerson",i[i.Free=2]="Free",i[i.Follow=3]="Follow",i))($u||{});var Sc=(i=>(i[i.Stopped=0]="Stopped",i[i.Playing=1]="Playing",i[i.Paused=2]="Paused",i[i.Finished=3]="Finished",i))(Sc||{}),WS=()=>({onServerData:()=>{},onConfigString:()=>{},onSpawnBaseline:()=>{},onFrame:()=>{},onCenterPrint:()=>{},onStuffText:()=>{},onPrint:()=>{},onSound:()=>{},onTempEntity:()=>{},onLayout:()=>{},onInventory:()=>{},onMuzzleFlash:()=>{},onMuzzleFlash2:()=>{},onDisconnect:()=>{},onReconnect:()=>{},onDownload:()=>{}}),Ms=class{constructor(){this.reader=null;this.buffer=null;this.state=0;this.playbackSpeed=1;this.currentProtocolVersion=0;this.currentFrameIndex=-1;this.lastFrameData=null;this.accumulatedTime=0;this.frameDuration=100;this.snapshotInterval=100;this.snapshots=new Map;this.cachedEvents=null;this.cachedSummary=null;this.cachedHeader=null;this.cachedConfigStrings=null;this.cachedServerInfo=null;this.cachedStatistics=null;this.cachedPlayerStats=null;this.cachedWeaponStats=null;this.tracker=null;this.cameraMode=0;this.thirdPersonDistance=80;this.thirdPersonOffset={x:0,y:0,z:0}}setHandler(e){this.handler=e}setCallbacks(e){this.callbacks=e}loadDemo(e){this.buffer=e,this.reader=new fr(e),this.transitionState(0),this.accumulatedTime=0,this.currentProtocolVersion=0,this.currentFrameIndex=-1,this.snapshots.clear(),this.lastFrameData=null,this.cachedEvents=null,this.cachedSummary=null,this.cachedHeader=null,this.cachedConfigStrings=null,this.cachedServerInfo=null,this.cachedStatistics=null,this.cachedPlayerStats=null,this.cachedWeaponStats=null}play(){this.reader&&this.state!==1&&this.transitionState(1)}pause(){this.state===1&&this.transitionState(2)}stop(){this.transitionState(0),this.reader&&this.reader.reset(),this.accumulatedTime=0,this.currentProtocolVersion=0,this.currentFrameIndex=-1,this.lastFrameData=null}transitionState(e){this.state!==e&&(this.state=e,this.callbacks?.onPlaybackStateChange&&this.callbacks.onPlaybackStateChange(e))}setFrameDuration(e){this.frameDuration=e}setSpeed(e){this.playbackSpeed=Math.max(.1,Math.min(e,16))}getSpeed(){return this.playbackSpeed}getPlaybackSpeed(){return this.playbackSpeed}getInterpolationFactor(){return this.frameDuration<=0?0:Math.max(0,Math.min(1,this.accumulatedTime/this.frameDuration))}update(e){if(!(this.state!==1||!this.reader))for(this.accumulatedTime+=e*1e3*this.playbackSpeed;this.accumulatedTime>=this.frameDuration;){if(!this.processNextFrame())return;this.accumulatedTime-=this.frameDuration,this.callbacks?.onTimeUpdate&&this.callbacks.onTimeUpdate(this.getCurrentTime())}}stepForward(){this.reader&&(this.processNextFrame(),this.callbacks?.onTimeUpdate&&this.callbacks.onTimeUpdate(this.getCurrentTime()))}stepBackward(){this.reader&&this.currentFrameIndex>0&&this.seek(this.currentFrameIndex-1)}seekToTime(e){let r=this.timeToFrame(e);this.seek(r)}seekToFrame(e){this.seek(e)}frameToTime(e){return e*this.frameDuration/1e3}timeToFrame(e){return Math.floor(e*1e3/this.frameDuration)}playFrom(e){if(e.type==="frame")this.seek(e.frame);else if(e.type==="time")this.seekToTime(e.seconds);else throw new Error(`Invalid offset type: ${e.type}`);this.play()}playRange(e,r){let n=e.type==="frame"?e.frame:this.timeToFrame(e.seconds),i=r.type==="frame"?r.frame:this.timeToFrame(r.seconds),a=this.getTotalFrames(),o=Math.max(0,a-1);if(n<0)throw new Error(`Invalid start offset: ${n}`);if(i<n)throw new Error(`End offset (${i}) cannot be before start offset (${n})`);this.playFrom(e);let s=this.callbacks?.onFrameUpdate,c={...this.callbacks,onFrameUpdate:l=>{if(s&&s(l),this.currentFrameIndex>=i){this.pause();let d=this.callbacks?.onPlaybackComplete;this.callbacks===c&&this.setCallbacks({...this.callbacks,onFrameUpdate:s}),d&&d()}}};this.setCallbacks(c)}seek(e){if(!this.reader)return;let r=this.getTotalFrames();if(r>0&&e>=r&&(e=r-1),e<0&&(e=0),e===this.currentFrameIndex+1){this.processNextFrame(),this.callbacks?.onSeekComplete&&this.callbacks.onSeekComplete();return}if(e===this.currentFrameIndex){this.callbacks?.onSeekComplete&&this.callbacks.onSeekComplete();return}let n=-1,i=null;if(e>this.currentFrameIndex&&this.currentFrameIndex!==-1&&(n=this.currentFrameIndex),this.callbacks?.onRestoreSnapshot)for(let[a,o]of this.snapshots)a<=e&&a>n&&(n=a,i=o);for(n===-1&&this.currentFrameIndex>e?(this.reader.reset(),this.currentFrameIndex=-1,this.currentProtocolVersion=0):n===-1&&(this.reader.reset(),this.currentFrameIndex=-1,this.currentProtocolVersion=0),i&&this.callbacks?.onRestoreSnapshot&&(this.callbacks.onRestoreSnapshot(i),this.reader.seekToMessage(n+1)?this.currentFrameIndex=n:(this.reader.reset(),this.currentFrameIndex=-1,this.currentProtocolVersion=0));this.currentFrameIndex<e&&(this.callbacks?.onCaptureSnapshot&&(this.currentFrameIndex+1)%this.snapshotInterval,!!this.processNextFrame()););this.accumulatedTime=0,this.callbacks?.onSeekComplete&&this.callbacks.onSeekComplete(),this.callbacks?.onTimeUpdate&&this.callbacks.onTimeUpdate(this.getCurrentTime())}processNextFrame(){if(!this.reader||!this.reader.hasMore())return this.transitionState(3),this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),!1;let e=this.reader.readNextBlock();if(!e)return this.transitionState(3),this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),!1;this.currentFrameIndex++,this.tracker&&(this.tracker.setCurrentFrame(this.currentFrameIndex),this.tracker.setCurrentTime(this.getCurrentTime()));try{let r={...this.handler||WS(),onFrame:i=>{this.lastFrameData=i,this.handler?.onFrame&&this.handler.onFrame(i),this.callbacks?.onFrameUpdate&&this.callbacks.onFrameUpdate(i)}},n=new ct(e.data,r);if(n.setProtocolVersion(this.currentProtocolVersion),n.parseMessage(),this.currentProtocolVersion=n.getProtocolVersion(),this.callbacks?.onCaptureSnapshot&&this.currentFrameIndex%this.snapshotInterval===0&&this.currentFrameIndex>0){let i=this.callbacks.onCaptureSnapshot(this.currentFrameIndex);i&&this.snapshots.set(this.currentFrameIndex,i)}}catch(r){return console.error("Error processing demo frame",r),this.callbacks?.onPlaybackError&&this.callbacks.onPlaybackError(r instanceof Error?r:new Error(String(r))),!1}return!0}getState(){return this.state}getCurrentTime(){return this.currentFrameIndex<0?this.accumulatedTime/1e3:(this.currentFrameIndex*this.frameDuration+this.accumulatedTime)/1e3}getFrameCount(){return this.reader?this.reader.getMessageCount():0}getTotalFrames(){return this.getFrameCount()}getCurrentFrame(){return this.currentFrameIndex<0?0:this.currentFrameIndex}getDuration(){return this.getFrameCount()*this.frameDuration/1e3}getTotalBytes(){return this.reader?this.reader.getProgress().total:0}getProcessedBytes(){return this.reader?this.reader.getOffset():0}getFrameData(e){if(e===this.currentFrameIndex&&this.lastFrameData)return this.lastFrameData;let r=this.state;return this.pause(),this.seek(e),r===1&&this.play(),this.lastFrameData}getFramePlayerState(e){if(e===this.currentFrameIndex&&this.handler?.getPlayerState){let n=this.handler.getPlayerState();if(n)return n}let r=this.getFrameData(e);return r?r.playerState:null}getFrameEntities(e){if(e===this.currentFrameIndex&&this.handler?.getEntities){let r=this.handler.getEntities();if(r)return Array.from(r.values())}if(this.seek(e),this.handler?.getEntities){let r=this.handler.getEntities();return r?Array.from(r.values()):[]}return[]}compareFrames(e,r){let n=this.getFramePlayerState(e),i=this.getFrameEntities(e),a=new Map;i.forEach(d=>a.set(d.number,d));let o=this.getFramePlayerState(r),s=this.getFrameEntities(r),c=new Map;s.forEach(d=>c.set(d.number,d));let l={frameA:e,frameB:r,playerStateDiff:{origin:null,viewangles:null,health:null,ammo:null},entityDiffs:{added:[],removed:[],moved:[]}};n&&o&&((n.origin.x!==o.origin.x||n.origin.y!==o.origin.y||n.origin.z!==o.origin.z)&&(l.playerStateDiff.origin={x:o.origin.x-n.origin.x,y:o.origin.y-n.origin.y,z:o.origin.z-n.origin.z}),n.stats[1]!==o.stats[1]&&(l.playerStateDiff.health=o.stats[1]-n.stats[1]),n.stats[2]!==o.stats[2]&&(l.playerStateDiff.ammo=o.stats[2]-n.stats[2]));for(let[d,f]of c){let u=a.get(d);u?(u.origin.x!==f.origin.x||u.origin.y!==f.origin.y||u.origin.z!==f.origin.z)&&l.entityDiffs.moved.push({id:d,delta:{x:f.origin.x-u.origin.x,y:f.origin.y-u.origin.y,z:f.origin.z-u.origin.z}}):l.entityDiffs.added.push(d)}for(let[d,f]of a)c.has(d)||l.entityDiffs.removed.push(d);return l}getEntityTrajectory(e,r,n){let i=[],a=this.getCurrentFrame();for(this.seek(r);this.getCurrentFrame()<=n&&this.state!==3;){let o=null;if(e===-1){let s=this.getFramePlayerState(this.getCurrentFrame());s&&(o={...s.origin})}else if(this.handler?.getEntities){let s=this.handler.getEntities().get(e);s&&(o={...s.origin})}if(o&&i.push(o),this.getCurrentFrame()===n)break;this.stepForward()}return this.seek(a),i}getEvents(){return this.ensureAnalysis(),this.cachedEvents||[]}getDemoEvents(){return this.getEvents()}filterEvents(e,r){return this.getDemoEvents().filter(i=>!(i.type!==e||r!==void 0&&i.entityId!==r))}getEventSummary(){return this.ensureAnalysis(),this.cachedSummary||{totalKills:0,totalDeaths:0,damageDealt:0,damageReceived:0,weaponUsage:new Map}}getMetadata(){let e=this.getDemoHeader();if(!e)return null;let r=this.getDemoServerInfo(),n="Unknown";return this.cachedConfigStrings,{mapName:e.levelName,playerName:n,serverName:r.hostname,demoVersion:e.protocolVersion,tickRate:e.tickRate||10}}getDemoHeader(){return this.ensureAnalysis(),this.cachedHeader}getDemoConfigStrings(){return this.ensureAnalysis(),this.cachedConfigStrings||new Map}getDemoServerInfo(){return this.ensureAnalysis(),this.cachedServerInfo||{}}getDemoStatistics(){return this.ensureAnalysis(),this.cachedStatistics}getPlayerStatistics(e){return this.ensureAnalysis(),this.cachedPlayerStats?.get(e)||null}getWeaponStatistics(e){return this.ensureAnalysis(),this.cachedWeaponStats?.get(e)||null}ensureAnalysis(){if(!this.cachedEvents&&this.buffer){let r=new Ba(this.buffer).analyze();this.cachedEvents=r.events,this.cachedSummary=r.summary,this.cachedHeader=r.header,this.cachedConfigStrings=r.configStrings,this.cachedServerInfo=r.serverInfo,this.cachedStatistics=r.statistics,this.cachedPlayerStats=r.playerStats,this.cachedWeaponStats=r.weaponStats}}setCameraMode(e){this.cameraMode=e}getCameraMode(){return this.cameraMode}setThirdPersonDistance(e){this.thirdPersonDistance=e}setThirdPersonOffset(e){this.thirdPersonOffset=e}async playWithTracking(e,r={}){if(this.tracker=e,e.startTracking(),r.fastForward)try{this.state===0&&this.reader,this.transitionState(1);let n=100,i=async()=>{if(this.state!==1)throw new Error("Playback stopped unexpectedly during fast forward");let a=0;for(;a<n;){if(!this.processNextFrame()){this.transitionState(0);let o=e.stopTracking();return this.tracker=null,this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),o}a++}return await new Promise(o=>setTimeout(o,0)),i()};return await i()}catch(n){throw this.transitionState(0),e.stopTracking(),this.tracker=null,n}else return new Promise((n,i)=>{let a=this.callbacks?.onPlaybackComplete,o=this.callbacks?.onPlaybackError,s=()=>{this.setCallbacks({...this.callbacks,onPlaybackComplete:a,onPlaybackError:o}),this.tracker=null};this.setCallbacks({...this.callbacks,onPlaybackComplete:()=>{let c=e.stopTracking();a&&a(),s(),n(c)},onPlaybackError:c=>{e.stopTracking(),o&&o(c),s(),i(c)}}),this.play()})}async playRangeWithTracking(e,r,n,i={}){this.tracker=n,n.startTracking();let a=e.type==="frame"?e.frame:this.timeToFrame(e.seconds),o=r.type==="frame"?r.frame:this.timeToFrame(r.seconds);if(i.fastForward)try{this.playFrom(e),this.transitionState(1);let s=100,c=async()=>{if(this.state!==1)throw new Error("Playback stopped unexpectedly during fast forward");let l=0;for(;l<s;){if(this.currentFrameIndex>=o||!this.processNextFrame()){this.transitionState(0);let d=n.stopTracking();return this.tracker=null,this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),d}l++}return await new Promise(d=>setTimeout(d,0)),c()};return await c()}catch(s){throw this.transitionState(0),n.stopTracking(),this.tracker=null,s}else return new Promise((s,c)=>{let l=this.callbacks?.onPlaybackComplete,d=this.callbacks?.onPlaybackError,f=()=>{this.setCallbacks({...this.callbacks,onPlaybackComplete:l,onPlaybackError:d}),this.tracker=null};this.setCallbacks({...this.callbacks,onPlaybackComplete:()=>{let u=n.stopTracking();l&&l(),f(),s(u)},onPlaybackError:u=>{n.stopTracking(),d&&d(u),f(),c(u)}}),this.playRange(e,r)})}};var As=class{constructor(){this.isRecording=!1;this.startTime=0;this.frameCount=0;this.filename=null;this.lastMessageSize=-1;this.messageBuffer=new jn(1024*1024)}startRecording(e,r=0){this.isRecording||(this.isRecording=!0,this.filename=e,this.startTime=r,this.frameCount=0,this.messageBuffer.reset(),console.log(`DemoRecorder: Started recording to ${e}`))}recordMessage(e){if(this.isRecording){this.messageBuffer.writeLong(e.byteLength);for(let r=0;r<e.length;r++)this.messageBuffer.writeByte(e[r]);this.frameCount++}}stopRecording(){return this.isRecording?(this.isRecording=!1,this.messageBuffer.writeLong(-1),console.log(`DemoRecorder: Stopped recording. Frames: ${this.frameCount}, Size: ${this.messageBuffer.getOffset()} bytes`),this.messageBuffer.getData()):null}getIsRecording(){return this.isRecording}};var wc=class{constructor(e,r=34){this.writer=e||new jn(new Uint8Array(64*1024)),this.protocol=r}getData(){return this.writer.getData()}getOpcode(e){if(this.protocol===34)switch(e){case T.serverdata:return 13;case T.frame:return 5;case T.playerinfo:return 17;case T.packetentities:return 18;case T.deltapacketentities:return 19;case T.print:return 11;case T.centerprint:return 16;case T.stufftext:return 12;case T.sound:return 10;case T.temp_entity:return 9;case T.configstring:return 14;case T.spawnbaseline:return 15;case T.layout:return 7;case T.inventory:return 6;case T.muzzleflash:return 8;case T.muzzleflash2:return 20}return e}writeCommand(e,r){let n=r??this.protocol;n===34||n===0?this.writer.writeByte(this.getOpcode(e)):this.writer.writeByte(e)}writeServerData(e,r,n,i,a,o){this.writeCommand(T.serverdata),this.writer.writeLong(e),this.writer.writeLong(r),this.writer.writeByte(n),this.writer.writeString(i),this.writer.writeShort(a),this.writer.writeString(o)}writeConfigString(e,r){this.writeCommand(T.configstring),this.writer.writeShort(e),this.writer.writeString(r)}writeStuffText(e){this.writeCommand(T.stufftext),this.writer.writeString(e)}writeCenterPrint(e){this.writeCommand(T.centerprint),this.writer.writeString(e)}writePrint(e,r){this.writeCommand(T.print),this.writer.writeByte(e),this.writer.writeString(r)}writeLayout(e){this.writeCommand(T.layout),this.writer.writeString(e)}writeInventory(e){this.writeCommand(T.inventory);for(let r of e)this.writer.writeShort(r);for(let r=e.length;r<256;r++)this.writer.writeShort(0)}writeMuzzleFlash(e,r){this.writeCommand(T.muzzleflash),this.writer.writeShort(e),this.writer.writeByte(r)}writeMuzzleFlash2(e,r){this.writeCommand(T.muzzleflash2),this.writer.writeShort(e),this.writer.writeByte(r)}writeSound(e,r,n,i,a,o,s,c){this.writeCommand(T.sound),this.writer.writeByte(e),this.writer.writeByte(r),e&1&&this.writer.writeByte(n),e&2&&this.writer.writeByte(i),e&16&&this.writer.writeByte(a),e&8&&this.writer.writeShort(o),e&4&&(this.writer.writeCoord(s.x),this.writer.writeCoord(s.y),this.writer.writeCoord(s.z))}writeTempEntity(e,r,n,i,a,o,s,c,l){this.writeCommand(T.temp_entity),this.writer.writeByte(e),r&&this.writer.writePos(r)}writePlayerState(e){this.writeCommand(T.playerinfo);let r=0;e.pm_type!==0&&(r|=1),(e.origin.x!==0||e.origin.y!==0||e.origin.z!==0)&&(r|=2),(e.velocity.x!==0||e.velocity.y!==0||e.velocity.z!==0)&&(r|=4),e.pm_time!==0&&(r|=8),e.pm_flags!==0&&(r|=16),e.gravity!==0&&(r|=32),(e.delta_angles.x!==0||e.delta_angles.y!==0||e.delta_angles.z!==0)&&(r|=64),(e.viewoffset.x!==0||e.viewoffset.y!==0||e.viewoffset.z!==0)&&(r|=128),(e.viewangles.x!==0||e.viewangles.y!==0||e.viewangles.z!==0)&&(r|=256),(e.kick_angles.x!==0||e.kick_angles.y!==0||e.kick_angles.z!==0)&&(r|=512),e.gun_index!==0&&(r|=4096),(e.gun_frame!==0||e.gun_offset.x!==0||e.gun_offset.y!==0||e.gun_offset.z!==0||e.gun_angles.x!==0||e.gun_angles.y!==0||e.gun_angles.z!==0)&&(r|=8192),(e.blend[0]!==0||e.blend[1]!==0||e.blend[2]!==0||e.blend[3]!==0)&&(r|=1024),e.fov!==0&&(r|=2048),e.rdflags!==0&&(r|=16384),e.watertype!==0&&(r|=32768),this.writer.writeShort(r),r&1&&this.writer.writeByte(e.pm_type),r&2&&(this.writer.writeShort(e.origin.x/.125),this.writer.writeShort(e.origin.y/.125),this.writer.writeShort(e.origin.z/.125)),r&4&&(this.writer.writeShort(e.velocity.x/.125),this.writer.writeShort(e.velocity.y/.125),this.writer.writeShort(e.velocity.z/.125)),r&8&&this.writer.writeByte(e.pm_time),r&16&&this.writer.writeByte(e.pm_flags),r&32&&this.writer.writeShort(e.gravity),r&64&&(this.writer.writeShort(e.delta_angles.x/(180/32768)),this.writer.writeShort(e.delta_angles.y/(180/32768)),this.writer.writeShort(e.delta_angles.z/(180/32768))),r&128&&(this.writer.writeByte(e.viewoffset.x/.25),this.writer.writeByte(e.viewoffset.y/.25),this.writer.writeByte(e.viewoffset.z/.25)),r&256&&(this.writer.writeShort(e.viewangles.x/(360/65536)),this.writer.writeShort(e.viewangles.y/(360/65536)),this.writer.writeShort(e.viewangles.z/(360/65536))),r&512&&(this.writer.writeByte(e.kick_angles.x/.25),this.writer.writeByte(e.kick_angles.y/.25),this.writer.writeByte(e.kick_angles.z/.25)),r&4096&&this.writer.writeByte(e.gun_index),r&8192&&(this.writer.writeByte(e.gun_frame),this.writer.writeByte(e.gun_offset.x/.25),this.writer.writeByte(e.gun_offset.y/.25),this.writer.writeByte(e.gun_offset.z/.25),this.writer.writeByte(e.gun_angles.x/.25),this.writer.writeByte(e.gun_angles.y/.25),this.writer.writeByte(e.gun_angles.z/.25)),r&1024&&(this.writer.writeByte(e.blend[0]),this.writer.writeByte(e.blend[1]),this.writer.writeByte(e.blend[2]),this.writer.writeByte(e.blend[3])),r&2048&&this.writer.writeByte(e.fov),r&16384&&this.writer.writeByte(e.rdflags),r&32768&&this.writer.writeByte(e.watertype);let n=0;for(let i=0;i<32;i++)e.stats[i]!==0&&(n|=1<<i);this.writer.writeLong(n);for(let i=0;i<32;i++)n&1<<i&&this.writer.writeShort(e.stats[i])}writePacketEntities(e,r,n){this.writeCommand(r?T.deltapacketentities:T.packetentities);for(let i of e)this.writeDeltaEntity(kr(),i,!0);this.writer.writeShort(0)}writeFrame(e,r){this.writeCommand(T.frame),this.writer.writeLong(e.serverFrame),this.writer.writeLong(e.deltaFrame),r!==26&&r!==25&&this.writer.writeByte(e.surpressCount),this.writer.writeByte(e.areaBytes),this.writer.writeBytes(e.areaBits),this.writePlayerState(e.playerState),this.writePacketEntities(e.packetEntities.entities,e.packetEntities.delta,r)}writeDeltaEntity(e,r,n){let i=0,a=0;(r.modelindex!==e.modelindex||n)&&(i|=vt),(r.modelindex2!==e.modelindex2||n)&&(i|=St),(r.modelindex3!==e.modelindex3||n)&&(i|=wt),(r.modelindex4!==e.modelindex4||n)&&(i|=Mt),(r.frame!==e.frame||n)&&(r.frame>=256?i|=_t:i|=gt),(r.skinnum!==e.skinnum||n)&&(r.skinnum>=256?i|=We:i|=He),(r.effects!==e.effects||n)&&(r.effects>=256?i|=Ge:i|=Ne),(r.renderfx!==e.renderfx||n)&&(r.renderfx>=256?i|=Ve:i|=Ue),(r.origin.x!==e.origin.x||n)&&r.origin.x!==0&&(i|=ft),(r.origin.y!==e.origin.y||n)&&r.origin.y!==0&&(i|=ht),(r.origin.z!==e.origin.z||n)&&r.origin.z!==0&&(i|=bt),(r.angles.x!==e.angles.x||n)&&r.angles.x!==0&&(i|=xt),(r.angles.y!==e.angles.y||n)&&r.angles.y!==0&&(i|=mt),(r.angles.z!==e.angles.z||n)&&r.angles.z!==0&&(i|=pt),(r.sound!==e.sound||n)&&(i|=At),(r.event!==e.event||n)&&(i|=yt),(r.solid!==e.solid||n)&&(i|=Et),this.protocol!==34&&((r.alpha!==e.alpha||n)&&(i|=yr),(r.scale!==e.scale||n)&&(i|=vr),(r.instanceBits!==e.instanceBits||n)&&(i|=_r),(r.loopVolume!==e.loopVolume||n)&&(i|=Sr),(r.loopAttenuation!==e.loopAttenuation||n)&&(a|=un),(r.owner!==e.owner||n)&&(a|=fn),(r.oldFrame!==e.oldFrame||n)&&(a|=hn)),a>0&&(i|=Ii),i&4278190080&&(i|=xr),i&4294901760&&(i|=br),i&4294967040&&(i|=gr),this.writer.writeByte(i&255),i&gr&&this.writer.writeByte(i>>8&255),i&br&&this.writer.writeByte(i>>16&255),i&xr&&this.writer.writeByte(i>>24&255),i&Ii&&this.writer.writeByte(a&255),r.number>=256?this.writer.writeShort(r.number):this.writer.writeByte(r.number),i&vt&&this.writer.writeByte(r.modelindex),i&St&&this.writer.writeByte(r.modelindex2),i&wt&&this.writer.writeByte(r.modelindex3),i&Mt&&this.writer.writeByte(r.modelindex4),i>&&this.writer.writeByte(r.frame),i&_t&&this.writer.writeShort(r.frame),i&He&&this.writer.writeByte(r.skinnum),i&We&&this.writer.writeShort(r.skinnum),i&Ne&&this.writer.writeByte(r.effects),i&Ge&&this.writer.writeShort(r.effects),i&Ue&&this.writer.writeByte(r.renderfx),i&Ve&&this.writer.writeShort(r.renderfx),i&ft&&this.writer.writeCoord(r.origin.x),i&ht&&this.writer.writeCoord(r.origin.y),i&bt&&this.writer.writeCoord(r.origin.z),i&xt&&this.writer.writeAngle(r.angles.x),i&mt&&this.writer.writeAngle(r.angles.y),i&pt&&this.writer.writeAngle(r.angles.z),i&At&&this.writer.writeByte(r.sound??0),i&yt&&this.writer.writeByte(r.event??0),i&Et&&this.writer.writeShort(r.solid),this.protocol!==34&&(i&yr&&this.writer.writeByte(r.alpha*255),i&vr&&this.writer.writeFloat(r.scale),i&_r&&this.writer.writeLong(r.instanceBits),i&Sr&&this.writer.writeByte(r.loopVolume*255),a&un&&this.writer.writeByte(r.loopAttenuation*255),a&fn&&this.writer.writeShort(r.owner),a&hn&&this.writer.writeShort(r.oldFrame))}};var Mc=class{static validate(e,r){if(r&&!r.toLowerCase().endsWith(".dm2"))return{valid:!1,error:"Invalid file extension (expected .dm2)"};if(e.byteLength<5)return{valid:!1,error:"File too small to be a valid demo"};let n=new DataView(e),i=n.getInt32(0,!0);if(i<=0||i>e.byteLength-4)return{valid:!1,error:`Invalid first block length: ${i}`};let a=n.getUint8(4);if(a!==T.serverdata)return{valid:!1,error:`First command is not svc_serverdata (expected ${T.serverdata}, got ${a})`};let o=-1;return i>=5&&(o=n.getInt32(5,!0)),{valid:!0,version:o}}};var Ac=class{constructor(e){this.frames=[];this.configStrings=new Map;this.baselines=new Map;this.currentEntities=new Map;if(e){let r=new Vn(e.byteLength);r.append(new Uint8Array(e)),r.setReadPosition(0),this.parser=new ct(r,this)}else this.parser=new ct(new Vn,this)}extractClip(e,r,n,i){let a=new fr(e.buffer),o=[],s=0,c=r.frame??-1,l=n.frame??Number.MAX_SAFE_INTEGER,d=0,f=0;for(;a.nextBlock();){let p=a.getBlock().data,y=!1,v=-1,x=!1,b={onServerData:S=>{d=S,y=!0,x=!0},onConfigString:()=>{y=!0,x=!0},onSpawnBaseline:()=>{y=!0,x=!0},onFrame:S=>{v=S.serverFrame,x=!0,v>=c&&v<=l&&(y=!0)},onCenterPrint:()=>{x=!0},onStuffText:()=>{x=!0},onPrint:()=>{x=!0},onSound:()=>{x=!0},onTempEntity:()=>{x=!0},onLayout:()=>{x=!0},onInventory:()=>{x=!0},onMuzzleFlash:()=>{x=!0},onMuzzleFlash2:()=>{x=!0},onDisconnect:()=>{x=!0},onReconnect:()=>{x=!0},onDownload:()=>{x=!0}},_=new Vn(p.getLength());_.append(p.readData(p.getLength())),_.setReadPosition(0),p.seek(0);let w=new ct(_,b);d>0&&w.setProtocolVersion(d);try{w.parseMessage()}catch{}if(x||f>=c&&f<=l&&(y=!0),y){let S=new Uint8Array(4);new DataView(S.buffer).setUint32(0,p.getLength(),!0),o.push(S);let L=p.readData(p.getLength());o.push(L),s+=4+L.length}f++}let u=new Uint8Array(4);new DataView(u.buffer).setInt32(0,-1,!0),o.push(u),s+=4;let h=new Uint8Array(s),m=0;for(let g of o)h.set(g,m),m+=g.length;return h}extractDemoRange(e,r,n){return this.extractClip(e,{frame:r},{frame:n})}onServerData(e,r,n,i,a,o){this.serverData={protocol:e,serverCount:r,attractLoop:n,gameDir:i,playerNum:a,levelName:o}}onConfigString(e,r){this.configStrings.set(e,r)}onSpawnBaseline(e){this.baselines.set(e.number,e)}onFrame(e){this.frames.push(e)}onCenterPrint(e){}onStuffText(e){}onPrint(e,r){}onSound(e,r,n,i,a,o,s){}onTempEntity(e,r,n,i,a,o,s,c,l){}onLayout(e){}onInventory(e){}onMuzzleFlash(e,r){}onMuzzleFlash2(e,r){}onDisconnect(){}onReconnect(){}onDownload(e,r,n){}};function rp(t,e){let r=e.bits;t.bits=r,t.number=e.number,r&vt&&(t.modelindex=e.modelindex),r&St&&(t.modelindex2=e.modelindex2),r&wt&&(t.modelindex3=e.modelindex3),r&Mt&&(t.modelindex4=e.modelindex4),r>&&(t.frame=e.frame),r&_t&&(t.frame=e.frame),r&He&&(t.skinnum=e.skinnum),r&We&&(t.skinnum=e.skinnum),r&Ne&&(t.effects=e.effects),r&Ge&&(t.effects=e.effects),r&Ue&&(t.renderfx=e.renderfx),r&Ve&&(t.renderfx=e.renderfx),r&ft&&(t.origin.x=e.origin.x),r&ht&&(t.origin.y=e.origin.y),r&bt&&(t.origin.z=e.origin.z),r&xt&&(t.angles.x=e.angles.x),r&mt&&(t.angles.y=e.angles.y),r&pt&&(t.angles.z=e.angles.z),r&sr&&(t.old_origin.x=e.old_origin.x,t.old_origin.y=e.old_origin.y,t.old_origin.z=e.old_origin.z),r&At&&(t.sound=e.sound),r&yt&&(t.event=e.event),r&Et&&(t.solid=e.solid),r&yr&&(t.alpha=e.alpha),r&vr&&(t.scale=e.scale),r&_r&&(t.instanceBits=e.instanceBits),r&Sr&&(t.loopVolume=e.loopVolume)}var qu=(u=>(u.Unknown="unknown",u.BSP="bsp",u.MD2="md2",u.MD3="md3",u.WAL="wal",u.PCX="pcx",u.TGA="tga",u.WAV="wav",u.OGG="ogg",u.TXT="txt",u.CFG="cfg",u.DEM="dem",u))(qu||{}),np={".bsp":"bsp",".md2":"md2",".md3":"md3",".wal":"wal",".pcx":"pcx",".tga":"tga",".wav":"wav",".ogg":"ogg",".txt":"txt",".cfg":"cfg",".dm2":"dem"};function Es(t,e){if(t.length<e.length)return!1;for(let r=0;r<e.length;r++)if(t[r]!==e[r])return!1;return!0}var XS=[73,66,83,80],KS=[73,68,80,50],YS=[73,68,80,51];var $S=[82,73,70,70];var qS=[79,103,103,83];function Zu(t,e){let r=t.slice(t.lastIndexOf(".")).toLowerCase();if(e){if(Es(e,XS))return"bsp";if(Es(e,KS))return"md2";if(Es(e,YS))return"md3";if(Es(e,qS))return"ogg";if(e.length>128&&e[0]===10&&e[1]<6)return"pcx";if(Es(e,$S)&&e.length>=12&&e[8]===87&&e[9]===65&&e[10]===86&&e[11]===69)return"wav"}return np[r]?np[r]:"unknown"}function ju(t){let e=Zu(t);return e==="txt"||e==="cfg"}function ip(t){return!ju(t)}function ZS(t,e,r,n,i){let a=new Uint8ClampedArray(n*i*4),o=e/n,s=r/i;for(let c=0;c<i;c++)for(let l=0;l<n;l++){let d=l*o,f=c*s,u=Math.floor(d),h=Math.floor(f),m=d-u,g=f-h,p=Math.min(u+1,e-1),y=Math.min(h+1,r-1),v=(h*e+u)*4,x=(h*e+p)*4,b=(y*e+u)*4,_=(y*e+p)*4,w=(c*n+l)*4;for(let S=0;S<4;S++){let E=t[v+S],L=t[x+S],M=t[b+S],C=t[_+S],I=E*(1-m)+L*m,B=M*(1-m)+C*m,F=I*(1-g)+B*g;a[w+S]=F}}return a}function jS(t,e,r,n,i,a,o,s,c,l,d){n=Math.floor(n),i=Math.floor(i),a=Math.floor(a),o=Math.floor(o);let f=Math.abs(a-n),u=Math.abs(o-i),h=n<a?1:-1,m=i<o?1:-1,g=f-u;for(;;){if(n>=0&&n<e&&i>=0&&i<r){let y=(i*e+n)*4,v=1-d/255;t[y]=s*(d/255)+t[y]*v,t[y+1]=c*(d/255)+t[y+1]*v,t[y+2]=l*(d/255)+t[y+2]*v,t[y+3]=255}if(n===a&&i===o)break;let p=2*g;p>-u&&(g-=u,n+=h),p<f&&(g+=f,i+=m)}}function ap(t,e,r,n,i){let s=(t.x-n.x)*.707-(t.y-n.y)*.707,c=(t.x-n.x)*.707+(t.y-n.y)*.707,l=t.z-n.z,d=.866,f=.5,u=c*d-l*f,h=c*f+l*d,m=e/2+s*i,g=r/2-h*i;return{x:m,y:g}}var Ec=class{constructor(e){this.assetManager=e}async generateTextureThumbnail(e,r){try{let n=await this.assetManager.loadTexture(e);if(!n||n.levels.length===0)return null;let i=n.levels[0],a=i.width/i.height,o=r,s=r;a>1?s=Math.floor(r/a):o=Math.floor(r*a),o=Math.max(1,o),s=Math.max(1,s);let c=ZS(i.rgba,i.width,i.height,o,s);return new ImageData(c,o,s)}catch(n){return console.error(`Failed to generate thumbnail for ${e}`,n),null}}async generateModelThumbnail(e,r){try{let n=[],i=[],a=e.split(".").pop()?.toLowerCase();if(a==="md2"){let p=await this.assetManager.loadMd2Model(e);if(!p||p.frames.length===0)return null;n=p.frames[0].vertices.map(v=>v.position);for(let v of p.triangles)i.push(v.vertexIndices[0],v.vertexIndices[1]),i.push(v.vertexIndices[1],v.vertexIndices[2]),i.push(v.vertexIndices[2],v.vertexIndices[0])}else if(a==="md3"){let p=await this.assetManager.loadMd3Model(e);if(!p||p.surfaces.length===0)return null;let y=0;for(let v of p.surfaces){if(v.vertices.length===0)continue;let x=v.vertices[0];n.push(...x.map(b=>({x:b.position.x,y:b.position.y,z:b.position.z})));for(let b of v.triangles)i.push(y+b.indices[0],y+b.indices[1]),i.push(y+b.indices[1],y+b.indices[2]),i.push(y+b.indices[2],y+b.indices[0]);y+=x.length}}else return null;if(n.length===0)return null;let o={x:1/0,y:1/0,z:1/0},s={x:-1/0,y:-1/0,z:-1/0};for(let p of n)o.x=Math.min(o.x,p.x),o.y=Math.min(o.y,p.y),o.z=Math.min(o.z,p.z),s.x=Math.max(s.x,p.x),s.y=Math.max(s.y,p.y),s.z=Math.max(s.z,p.z);let c={x:(o.x+s.x)/2,y:(o.y+s.y)/2,z:(o.z+s.z)/2},l=s.x-o.x,d=s.y-o.y,f=s.z-o.z,u=Math.max(l,d,f),h=Math.max(u,.001),m=r*.8/h,g=new Uint8ClampedArray(r*r*4);for(let p=0;p<i.length;p+=2){let y=i[p],v=i[p+1],x=n[y],b=n[v],_=ap(x,r,r,c,m),w=ap(b,r,r,c,m);jS(g,r,r,_.x,_.y,w.x,w.y,0,255,0,255)}return new ImageData(g,r,r)}catch(n){return console.error(`Failed to generate model thumbnail for ${e}`,n),null}}async getMapBounds(e,r){try{let n=ja(r);if(n.models.length>0){let i=n.models[0];return{mins:{x:i.mins[0],y:i.mins[1],z:i.mins[2]},maxs:{x:i.maxs[0],y:i.maxs[1],z:i.maxs[2]}}}return null}catch(n){return console.error("Failed to get map bounds",n),null}}async extractMapScreenshot(e){return null}};var Lc=class{constructor(e){this.loader=e}async getMapStatistics(e){let r=await this.loader.load(e),n=r.faces.filter(o=>o.lightOffset!==-1).length,i=r.models[0],a=i?{mins:i.mins,maxs:i.maxs}:{mins:[0,0,0],maxs:[0,0,0]};return{entityCount:r.entities.entities.length,surfaceCount:r.faces.length,lightmapCount:n,vertexCount:r.vertices.length,bounds:a}}async getUsedTextures(e){let r=await this.loader.load(e),n=new Set;for(let i of r.texInfo)i.texture&&n.add(i.texture);return Array.from(n).sort()}async getUsedModels(e){let r=await this.loader.load(e),n=new Set;for(let i of r.entities.entities)i.properties.model&&!i.properties.model.startsWith("*")&&n.add(i.properties.model);return Array.from(n).sort()}async getUsedSounds(e){let r=await this.loader.load(e),n=new Set;for(let i of r.entities.entities){i.properties.noise&&n.add(i.properties.noise);for(let[a,o]of Object.entries(i.properties))(a==="noise"||a.endsWith("_sound")||a==="sound")&&typeof o=="string"&&n.add(o)}return Array.from(n).sort()}};function op(t){let e=[],r=0,n=t.length;function i(){for(;r<n&&/\s/.test(t[r]);)r++}function a(){if(i(),r>=n)return null;if(t[r]==='"'){r++;let o=r;for(;r<n&&t[r]!=='"';)t[r],r++;let s=t.substring(o,r);return r++,s}else{if(t[r]==="{"||t[r]==="}")return t[r++];{if(t.startsWith("//",r)){for(;r<n&&t[r]!==`
|
|
783
783
|
`;)r++;return a()}let o=r;for(;r<n&&!/\s/.test(t[r])&&t[r]!=="}"&&t[r]!=="{";)r++;return t.substring(o,r)}}}for(;r<n;){let o=a();if(o===null)break;if(o==="{"){let s={};for(;;){let c=r,l=a();if(l==="}"||l===null)break;if(l==="{"){r=c;break}let d=a();if(d===null||d==="}"||d==="{"){d==="}"&&r--,d==="{"&&r--;break}s[l]=d}e.push({classname:s.classname,properties:s})}}return e}function sp(t){let e="";for(let r of t){e+=`{
|
|
784
784
|
`;let i=Object.keys(r.properties).sort((a,o)=>a==="classname"?-1:o==="classname"?1:a==="origin"?-1:o==="origin"?1:a.localeCompare(o));for(let a of i){let o=r.properties[a];e+=`"${a}" "${o}"
|
|
785
785
|
`}e+=`}
|