@quake2ts/engine 0.0.824 → 0.0.828
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 +16 -16
- package/dist/browser/index.global.js.map +1 -1
- package/dist/cjs/index.cjs +4 -0
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/types/render/interface.d.ts +1 -0
- package/dist/types/render/interface.d.ts.map +1 -1
- package/dist/types/render/renderer.d.ts.map +1 -1
- package/package.json +5 -5
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
"use strict";var Quake2Engine=(()=>{var Lp=Object.create;var Is=Object.defineProperty;var Tp=Object.getOwnPropertyDescriptor;var Rp=Object.getOwnPropertyNames;var Cp=Object.getPrototypeOf,Pp=Object.prototype.hasOwnProperty;var Ip=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Ho=(t,e)=>{for(var r in e)Is(t,r,{get:e[r],enumerable:!0})},bf=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Rp(e))!Pp.call(t,i)&&i!==r&&Is(t,i,{get:()=>e[i],enumerable:!(n=Tp(e,i))||n.enumerable});return t};var Bp=(t,e,r)=>(r=t!=null?Lp(Cp(t)):{},bf(e||!t||!t.__esModule?Is(r,"default",{value:t,enumerable:!0}):r,t)),Fp=t=>bf(Is({},"__esModule",{value:!0}),t);var ih=Ip((rM,nh)=>{"use strict";nh.exports=Worker});var lw={};Ho(lw,{ATTN_IDLE:()=>rd,ATTN_LOOP_NONE:()=>ed,ATTN_NONE:()=>qo,ATTN_NORM:()=>td,ATTN_STATIC:()=>nd,AssetDependencyError:()=>gi,AssetDependencyTracker:()=>ja,AssetManager:()=>Bl,AssetPreviewGenerator:()=>Tc,AudioApi:()=>zi,AudioContextController:()=>Fl,AudioOcclusion:()=>Ja,AudioRegistry:()=>lo,AudioRegistryError:()=>Ya,AudioSystem:()=>Hl,BSP_SURFACE_FRAGMENT_SOURCE:()=>$d,BSP_SURFACE_VERTEX_SOURCE:()=>Xd,BSP_VERTEX_LAYOUT:()=>Ud,BspLoader:()=>Ni,BspParseError:()=>se,BspSurfacePipeline:()=>ho,Camera:()=>rc,ClientConnection:()=>kc,Command:()=>Vo,CommandRegistry:()=>Pi,ConfigStringRegistry:()=>Oi,ConnectionState:()=>cf,CoordinateSystem:()=>lf,Cvar:()=>Zo,CvarRegistry:()=>ki,DemoAnalyzer:()=>Fo,DemoCameraMode:()=>nf,DemoClipper:()=>Lc,DemoEventType:()=>rf,DemoPlaybackController:()=>Ms,DemoReader:()=>hr,DemoRecorder:()=>As,DemoValidator:()=>Ec,DynamicLightManager:()=>$l,EngineHost:()=>Di,EngineRuntime:()=>jo,FileType:()=>of,FixedTimestepLoop:()=>Yn,Framebuffer:()=>yi,IndexBuffer:()=>Je,LoggingRenderer:()=>Fc,LruCache:()=>yn,MAX_SOUND_CHANNELS:()=>Yo,MD2_FRAGMENT_SHADER:()=>Jd,MD2_VERTEX_SHADER:()=>Qd,MD3_FRAGMENT_SHADER:()=>xu,MD3_VERTEX_SHADER:()=>bu,MapAnalyzer:()=>Rc,Md2Loader:()=>Hi,Md2MeshBuffers:()=>po,Md2ParseError:()=>Ze,Md2Pipeline:()=>go,Md3Loader:()=>Vi,Md3ModelMesh:()=>vo,Md3ParseError:()=>Yt,Md3Pipeline:()=>_o,Md3SurfaceMesh:()=>is,MessageWriter:()=>Ac,MusicSystem:()=>Vl,NetworkMessageParser:()=>dt,NullRenderer:()=>Cc,PARTICLE_FRAGMENT_SHADER:()=>_u,PARTICLE_VERTEX_SHADER:()=>vu,PROTOCOL_VERSION_RERELEASE:()=>zr,PakArchive:()=>Ui,PakIndexStore:()=>Il,PakIngestionError:()=>gn,PakParseError:()=>Be,PakValidationError:()=>ei,PakValidator:()=>$s,PakWriter:()=>Gs,ParticleRenderer:()=>wo,ParticleSystem:()=>So,PlaybackState:()=>Mc,RERELEASE_KNOWN_PAKS:()=>ld,ResourceLoadTracker:()=>Ws,ResourceType:()=>sd,SKYBOX_FRAGMENT_SHADER:()=>Zd,SKYBOX_VERTEX_SHADER:()=>qd,SOUND_FULLVOLUME:()=>Bi,SOUND_LOOP_ATTENUATE:()=>id,ShaderProgram:()=>le,SkyboxPipeline:()=>mo,SoundChannel:()=>Mr,SoundPrecache:()=>zl,SoundRegistry:()=>Dl,SpriteLoader:()=>Gi,SpriteParseError:()=>bn,SpriteRenderer:()=>Mo,StreamingPakArchive:()=>Vs,Texture2D:()=>et,TextureCache:()=>Wi,TextureCubeMap:()=>co,TgaParseError:()=>Gr,U_ALPHA:()=>br,U_ANGLE1:()=>vt,U_ANGLE2:()=>pt,U_ANGLE3:()=>gt,U_EFFECTS16:()=>We,U_EFFECTS8:()=>He,U_EVENT:()=>bt,U_FRAME16:()=>St,U_FRAME8:()=>yt,U_INSTANCE_BITS:()=>Sr,U_LOOP_ATTENUATION_HIGH:()=>fn,U_LOOP_VOLUME:()=>wr,U_MODEL:()=>_t,U_MODEL2:()=>wt,U_MODEL3:()=>Mt,U_MODEL4:()=>At,U_OLDORIGIN:()=>lr,U_OLD_FRAME_HIGH:()=>mn,U_ORIGIN1:()=>ht,U_ORIGIN2:()=>mt,U_ORIGIN3:()=>xt,U_OWNER_HIGH:()=>hn,U_REMOVE:()=>$o,U_RENDERFX16:()=>Ge,U_RENDERFX8:()=>Ne,U_SCALE:()=>_r,U_SKIN16:()=>Xe,U_SKIN8:()=>Ve,U_SOLID:()=>Lt,U_SOUND:()=>Et,VertexArray:()=>Le,VertexBuffer:()=>Ae,VirtualFileSystem:()=>Xs,advanceAnimation:()=>Qf,applyEntityDelta:()=>lp,applySurfaceState:()=>es,attenuationToDistanceMultiplier:()=>Fi,boxIntersectsFrustum:()=>bi,buildBspGeometry:()=>Xl,buildMd2Geometry:()=>eu,buildMd2VertexData:()=>tu,buildMd3SurfaceGeometry:()=>gu,buildMd3VertexData:()=>yu,calculateMaxAudibleDistance:()=>Jn,calculatePakChecksum:()=>Df,captureRenderTarget:()=>bp,computeFrameBlend:()=>Jf,computeSkyScroll:()=>Yl,createAnimationState:()=>eh,createAudioGraph:()=>kl,createBspSurfaces:()=>Wl,createEmptyEntityState:()=>Dr,createEmptyProtocolPlayerState:()=>mr,createEngine:()=>sw,createEngineRuntime:()=>Bf,createFaceLightmap:()=>Ys,createHeadlessRenderTarget:()=>yp,createInitialChannels:()=>Ol,createOcclusionResolver:()=>Fh,createProgramFromSources:()=>zh,createRenderer:()=>Um,createWebGLContext:()=>kh,createWebGPUContext:()=>pp,decodeOgg:()=>Pl,deriveSurfaceRenderState:()=>Yd,detectFileType:()=>af,extractFrustumPlanes:()=>Dn,filesToPakSources:()=>cd,findLeafForPoint:()=>xi,gatherVisibleFaces:()=>vi,groupMd2Animations:()=>Yf,ingestPakFiles:()=>Nf,ingestPaks:()=>Ks,interpolateMd3Tag:()=>vm,interpolateVec3:()=>th,isBinaryFile:()=>dp,isTextFile:()=>sf,parseBsp:()=>Qo,parseEntLump:()=>fp,parseMd2:()=>dd,parseMd3:()=>ud,parsePcx:()=>ra,parseSprite:()=>fd,parseTga:()=>hd,parseWal:()=>Zs,parseWalTexture:()=>Js,parseWav:()=>el,pcxToRgba:()=>js,pickChannel:()=>Ul,preparePcxTexture:()=>Qs,queryCapabilities:()=>gp,removeViewTranslation:()=>Kl,resolveLightStyles:()=>Kd,serializeEntLump:()=>hp,spawnBfgExplosion:()=>Im,spawnBlasterImpact:()=>Pm,spawnBlood:()=>wm,spawnBulletImpact:()=>_m,spawnExplosion:()=>Sm,spawnMuzzleFlash:()=>Am,spawnRailTrail:()=>Rm,spawnSparks:()=>Cm,spawnSplash:()=>Lm,spawnSteam:()=>Tm,spawnTeleportFlash:()=>Mm,spawnTrail:()=>Em,validateEntity:()=>mp,walToRgba:()=>md,wireDropTarget:()=>Hf,wireFileInput:()=>Vf});var kp=()=>typeof performance<"u"?performance.now():Date.now(),Dp=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??kp,schedule:r.schedule??Dp}}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 o=this.options.fixedDeltaMs===0?0:this.accumulatorMs/this.options.fixedDeltaMs;this.callbacks.render?.({alpha:o,nowMs:r,accumulatorMs:this.accumulatorMs,frame:this.frame})}};var Vo=class{constructor(e,r,n){this.name=e,this.callback=r,this.description=n}execute(e){this.callback(e)}},Pi=class{constructor(){this.commands=new Map;this.history=[];this.historyLimit=64;this.autocompleteProviders=[]}register(e,r,n){let i=new Vo(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],o=n.slice(1),a=this.get(i);return a?(a.execute(o),!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 o of i)o.startsWith(e)&&r.add(o)}return Array.from(r).sort()}tokenize(e){let r=[],n="",i=!1;for(let o=0;o<e.length;o++){let a=e[o];a==='"'?i=!i:a===" "&&!i?n.length>0&&(r.push(n),n=""):n+=a}return n.length>0&&r.push(n),r}list(){return[...this.commands.values()].sort((e,r)=>e.name.localeCompare(r.name))}};var zp=Object.defineProperty,Op=(t,e)=>{for(var r in e)zp(t,r,{get:e[r],enumerable:!0})},xf={x:0,y:0,z:0};var bw=Math.PI/180;function vf(t,e){return{x:t.x-e.x,y:t.y-e.y,z:t.z-e.z}}function Up(t,e){return{x:t.x*e,y:t.y*e,z:t.z*e}}function Np(t,e){return t.x*e.x+t.y*e.y+t.z*e.z}function Hp(t){return Np(t,t)}function Gc(t){return Math.sqrt(Hp(t))}function Vr(t){let e=Gc(t);return e===0?t:Up(t,1/e)}var Vp=Math.PI/180,Gp=180/Math.PI,Ee=Vp,Wc=Gp;var sr=[[-.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 pr=624,Wp=397,Xp=2567483615,$p=2147483648,Kp=2147483647,Hc=4294967296,Yp=class{constructor(t=5489){this.state=new Uint32Array(pr),this.index=pr,this.seed(t)}seed(t){this.state[0]=t>>>0;for(let e=1;e<pr;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=pr}nextUint32(){this.index>=pr&&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<pr;t++){let e=this.state[t]&$p|this.state[(t+1)%pr]&Kp,r=this.state[(t+Wp)%pr]^e>>>1;(e&1)!==0&&(r^=Xp),this.state[t]=r>>>0}this.index=0}getState(){return{index:this.index,state:Array.from(this.state)}}setState(t){if(t.state.length!==pr)throw new Error(`Expected ${pr} MT state values, received ${t.state.length}`);this.index=t.index,this.state=Uint32Array.from(t.state,e=>e>>>0)}},_f=class{constructor(t={}){this.mt=new Yp(t.seed)}seed(t){this.mt.seed(t)}frandom(){return this.mt.nextUint32()/Hc}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=Hc-Hc%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 qp(){return new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}function Xc(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 Sf(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 wf(t,e){let r=qp();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 gr=1,un=2;var $c=8,Kc=16,Zp=32;var jp=16384;var Bs=65536,Mf=1<<17,Qp=1<<18,Jp=1<<19,eg=1<<20,tg=1<<21,rg=1<<22,ng=1<<23,xw=1<<24,Fs=1<<25,ig=1<<26,vw=1<<27,_w=1<<28,Sw=1<<29,ks=1<<30,ww=1<<31;var Wo=0;var Ds=4,Xo=8,zs=16,Os=32,Af=64;var Mw=1<<25,Aw=1<<28,Ew=1<<29,Lw=1<<30,Tw=1<<31;var Rw=gr|un,Cw=gr|Bs|un|Fs|ks,Pw=gr|Bs|un,Iw=gr|Mf|un|Fs|ks,Bw=Zp|$c|Kc,Fw=gr|Kc|$c,og=gr|Fs|ks|un|ig,kw=Qp|Jp|eg|tg|rg|ng,Dw=gr|$c|Kc|Fs|ks,zw=gr|Bs|un,Ow=gr|un,Uw=gr|Bs|un|Mf,Nw=og|jp;var Hw=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 Yc=256,qc=8192,Hs=2048,Zc=512,jc=256,Qc=Ns*2,Jc=256,Vc=32,Go=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+qc]="Sounds",t[t.Images=t.Sounds+Hs]="Images",t[t.Lights=t.Images+Zc]="Lights",t[t.ShadowLights=t.Lights+Yc]="ShadowLights",t[t.Items=t.ShadowLights+Jc]="Items",t[t.Players=t.Items+jc]="Players",t[t.PlayerSkins=t.Players]="PlayerSkins",t[t.General=t.Players+Ns]="General",t[t.WheelWeapons=t.General+Qc]="WheelWeapons",t[t.WheelAmmo=t.WheelWeapons+Vc]="WheelAmmo",t[t.WheelPowerups=t.WheelAmmo+Vc]="WheelPowerups",t[t.CdLoopCount=t.WheelPowerups+Vc]="CdLoopCount",t[t.GameStyle=t.CdLoopCount+1]="GameStyle",t[t.MaxConfigStrings=t.GameStyle+1]="MaxConfigStrings",t))(J||{}),Ef=J.MaxConfigStrings;function Lf(t){return t>=5&&t<59?Go*(59-t):t>=J.General&&t<J.WheelWeapons?Go*(J.MaxConfigStrings-t):Go}var Vw=J.Sounds,Gw=J.Images,Ww=J.Lights,Xw=J.Items,$w=J.Players,Kw=J.General,ag={};Op(ag,{addReplayFrame:()=>dg,createReplaySession:()=>cg,deserializeReplay:()=>lg,serializeReplay:()=>sg});function sg(t){return JSON.stringify(t,null,2)}function lg(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 cg(t,e){return{metadata:{map:t,date:new Date().toISOString(),version:"1.0",seed:e},frames:[]}}function dg(t,e,r,n){t.frames.push({serverFrame:r,cmd:e,timestamp:Date.now()-n})}var R=(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))(R||{}),Zn=(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))(Zn||{}),z=(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))(z||{});var Tf=64;var ug=12,fg=9,Yw=Math.ceil(ug*fg/16),hg=23,mg=2,qw=Math.ceil(hg*mg/16);function Rf(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 pg=[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 Cf(t){let e=0;for(let r=0;r<t.length;r++)e=pg[(e^t[r])&255];return e}var ht=1,mt=2,pt=4,gt=8,yt=16,bt=32,$o=64,yr=128,jn=256,xt=512,vt=1024,_t=2048,Ne=4096,br=8192,He=16384,xr=32768,Ve=65536,St=1<<17,Ge=1<<18,We=1<<19,wt=1<<20,Mt=1<<21,At=1<<22,vr=1<<23,lr=1<<24,Xe=1<<25,Et=1<<26,Lt=1<<27,_r=1<<28,Sr=1<<29,wr=1<<30,Ii=-2147483648,fn=1,hn=2,mn=4;var pn=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=sr[e];t.x=r[0],t.y=r[1],t.z=r[2]}},Qn=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<sr.length;n++){let i=sr[n],o=t.x*i[0]+t.y*i[1]+t.z*i[2];o>e&&(e=o,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}},Ko=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,o=Math.sqrt(t*t+e*e+r*r);if(o>0){t/=o,e/=o,r/=o;for(let a=0;a<162;a++){let s=t*sr[a][0]+e*sr[a][1]+r*sr[a][2];s>i&&(i=s,n=a)}}this.writeByte(n)}},qn=class qe{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 Qn(qe.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>qe.FRAGMENT_SIZE?(n=!0,this.fragmentSendOffset>=this.reliableLength&&(this.fragmentSendOffset=0),r=this.reliableLength-this.fragmentSendOffset,r>qe.FRAGMENT_SIZE&&(r=qe.FRAGMENT_SIZE),i=this.fragmentSendOffset,this.fragmentSendOffset+=r):r=this.reliableLength);let o=qe.PACKET_HEADER,a=r>0?2+(n?8:0):0,s=e?e.length:0;o+a+r+s>qe.MAX_MSGLEN&&(s=qe.MAX_MSGLEN-o-a-r,s<0&&(s=0));let c=new ArrayBuffer(o+a+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=o;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<qe.PACKET_HEADER)return null;let i=r.getUint32(4,!0),o=r.getUint16(8,!0);if(this.qport!==o)return null;let a=n&1073741823;if((a-this.incomingSequence|0)<=0)return null;this.incomingSequence=a;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=qe.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>qe.MAX_RELIABLE_BUFFER)return console.warn(`NetChan: received invalid fragment total ${v} > ${qe.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>qe.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeByte(e),this.reliableLength++}writeReliableShort(e){if(this.reliableLength+2>qe.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeShort(e),this.reliableLength+=2}writeReliableLong(e){if(this.reliableLength+4>qe.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>qe.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}};qn.MAX_MSGLEN=1400;qn.FRAGMENT_SIZE=1024;qn.PACKET_HEADER=10;qn.HEADER_OVERHEAD=qn.PACKET_HEADER+2;qn.MAX_RELIABLE_BUFFER=262144;var Pf=qn;var If=(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))(If||{}),Zw=Object.keys(If).length/2;var Yo=32,Mr=(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))(Mr||{}),ed=-1,qo=0,td=1,rd=2,nd=3,Bi=80,id=.003;function Fi(t){return t*.001}function Jn(t){let e=Fi(t);return e<=0?Number.POSITIVE_INFINITY:Bi+1/e}var Zo=class{constructor({name:e,defaultValue:r,description:n,flags:i=Us.None,onChange:o}){this.modifiedCount=0;this.name=e,this.defaultValue=r,this.description=n,this.flags=i,this._value=r,this.onChange=o}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=(a,s)=>{n?.(a,s),this.onCvarChange?.(a.name,a.string)},o=new Zo({...e,onChange:i});return this.cvars.set(e.name,o),o}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 Pi;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(o=>o.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,o,a){this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:o,timeOffsetMs:a}),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,o){let a=this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:o,looping:!0});return this.triggerSubtitle(n),a}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 jo=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 Bf(t,e,r,n,i){let o=new zi({...n,client:r}),a=new Di(e,r,i);return{runtime:new jo(t,a),audio:o}}function gg(t){if(t<0||t>=J.MaxConfigStrings)throw new RangeError(`Configstring index ${t} is out of range (0-${J.MaxConfigStrings-1})`)}function Ff(t,e){let r=Lf(t);if(e.length>r)throw new RangeError(`Configstring ${t} exceeds maximum length (${e.length} > ${r}); limit is ${Go} 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 gg(e),Ff(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(Ef).fill("");for(let[r,n]of this.values.entries())e[r]=n;return e}modelIndex(e){return this.register(e,J.Models,qc,"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,Zc,"imageCursor")}lightIndex(e){return this.register(e,J.Lights,Yc,"lightCursor")}shadowLightIndex(e){return this.register(e,J.ShadowLights,Jc,"shadowLightCursor")}itemIndex(e){return this.register(e,J.Items,jc,"itemCursor")}playerSkinIndex(e){return this.register(e,J.PlayerSkins,Ns,"playerSkinCursor")}generalIndex(e){return this.register(e,J.General,Qc,"generalCursor")}register(e,r,n,i){for(let s=r;s<r+n;s+=1)if(this.values.get(s)===e)return s;let o=this[i],a=r+n;if(o>=a)throw new RangeError(`Out of configstring slots for range starting at ${r}`);return Ff(o,e),this.values.set(o,e),this[i]=o+1,o}};var yg="PACK";function bg(t,e,r){let n=[];for(let i=0;i<r;i+=1){let o=t.getUint8(e+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function _e(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}function xg(){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 vg=xg();function kf(t){let e=4294967295;for(let r=0;r<t.length;r+=1){let n=t[r];e=vg[(e^n)&255]^e>>>8}return(e^4294967295)>>>0}var Be=class extends Error{},Ui=class t{constructor(e,r,n,i){this.name=e;this.buffer=r;this.entries=new Map(n.map(o=>[o.name,o])),this.checksum=i,this.size=r.byteLength}static fromArrayBuffer(e,r){let n=new DataView(r);if(r.byteLength<12)throw new Be("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!==yg)throw new Be(`Invalid PAK header magic: ${i}`);let o=n.getInt32(4,!0),a=n.getInt32(8,!0);if(o<12)throw new Be(`Invalid directory offset: ${o}`);if(a<0||a%64!==0)throw new Be(`Invalid directory length: ${a}`);if(o+a>r.byteLength)throw new Be("Directory exceeds buffer length");let c=a/64,l=[],d=new Map;for(let f=0;f<c;f+=1){let u=o+f*64,h=bg(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 Be(`Invalid entry bounds for ${h||"<unnamed>"} (offset=${g}, length=${p})`);if(!m)throw new Be(`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,kf(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 Be(`File not found in PAK: ${e}`);return new Uint8Array(this.buffer,r.offset,r.length)}validate(){return{checksum:this.checksum,entries:this.listEntries()}}};function Df(t){return kf(new Uint8Array(t))}var _g="PACK",zf=12,od=64;function Of(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,zf),r=new DataView(e),n=String.fromCharCode(r.getUint8(0),r.getUint8(1),r.getUint8(2),r.getUint8(3));if(n!==_g)throw new Be(`Invalid PAK header magic: ${n}`);let i=r.getInt32(4,!0),o=r.getInt32(8,!0);if(i<zf)throw new Be(`Invalid directory offset: ${i}`);if(o<0||o%od!==0)throw new Be(`Invalid directory length: ${o}`);let a=await this.readChunk(i,o),s=new DataView(a),c=o/od,l=new Map;for(let d=0;d<c;d++){let f=d*od,u=this.readCString(s,f,56),h=Of(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 Be(`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 Be(`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(Of(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 o=0;o<n;o+=1){let a=e.getUint8(r+o);if(a===0)break;i.push(a)}return String.fromCharCode(...i)}};var ad=12,Uf=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*Uf,n=ad+e+r,i=new Uint8Array(n),o=new DataView(i.buffer);o.setUint8(0,80),o.setUint8(1,65),o.setUint8(2,67),o.setUint8(3,75);let a=ad+e;o.setInt32(4,a,!0),o.setInt32(8,r,!0);let s=ad,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=a,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?o.setUint8(d+g,m[g]):o.setUint8(d+g,0);o.setInt32(d+56,c.get(u),!0),o.setInt32(d+60,h.byteLength,!0),d+=Uf}return i}static buildFromEntries(e){let r=new t;for(let[n,i]of e)r.addFile(n,i);return r.build()}};var sd=(a=>(a.Texture="texture",a.Sound="sound",a.Model="model",a.Map="map",a.Sprite="sprite",a.ConfigString="configString",a))(sd||{}),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,o)=>o.priority-i.priority);for(let i of e.listEntries()){let o=_e(i.name),a={archive:e,entry:i,priority:r};this.files.has(o)||this.files.set(o,[]);let s=this.files.get(o),c=s.findIndex(l=>l.archive===e);c!==-1&&s.splice(c,1),s.unshift(a),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,o=i.readFile(e),a=0,s=o.length;return new ReadableStream({pull(c){if(a>=s){c.close();return}let l=Math.min(a+r,s),d=o.slice(a,l);a=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,o=r?`${r}/`:"";for(let[a,s]of this.files){let c=s[0];if(r&&!c.entry.name.startsWith(o))continue;let l=r?c.entry.name.slice(o.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((a,s)=>a.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,o]of this.files){let a=o[0];a.entry.name.toLowerCase().endsWith(r)&&n.push({path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name})}return n.sort((i,o)=>i.path.localeCompare(o.path))}listByExtension(e){let r=new Set(e.map(i=>i.startsWith(".")?i.toLowerCase():`.${i.toLowerCase()}`)),n=[];for(let[i,o]of this.files){let a=o[0],s=a.entry.name.toLowerCase();for(let c of r)if(s.endsWith(c)){n.push({path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name});break}}return n.sort((i,o)=>i.path.localeCompare(o.path))}searchFiles(e){let r=[];for(let[n,i]of this.files){let o=i[0];e.test(o.entry.name)&&r.push({path:o.entry.name,size:o.entry.length,sourcePak:o.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 o=i[0];return{path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name}}).sort((i,o)=>i.path.localeCompare(o.path));for(let i of n){let o=i.path.split("/"),a=o.pop(),s="",c=e;for(let l of o){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 ld=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"}]),ei=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"}},$s=class{constructor(e=ld){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,o="size"in e?e.size:void 0,a=this.known.get(n);return a?a.checksum!==i?{name:n,checksum:i,expectedChecksum:a.checksum,status:"mismatch",size:o,description:a.description}:{name:n,checksum:i,expectedChecksum:a.checksum,status:"valid",size:o,description:a.description}:{name:n,checksum:i,status:"unknown",size:o}}assertValid(e,r){let n=this.validateArchive(e,r);if(n.status==="mismatch")throw new ei(n);return n}normalizePakName(e){let r=_e(e),n=r.split("/"),i=n.pop()??r,o=n.pop();return o?`${i}@${o}`:i}};var gn=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 Sg(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=o=>{e?.({file:"blob",loadedBytes:o.loaded,totalBytes:o.total||t.size,state:"reading"})},i.onload=()=>{let o=i.result;o instanceof ArrayBuffer?r(o):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 o=new Uint8Array(i),a=0;for(let s of n)o.set(s,a),a+=s.byteLength;return o.buffer}throw new gn("blob",new Error("Unsupported Blob type"))}async function wg(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 Sg(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 Ks(t,e,r){let n=typeof r=="function"?{onProgress:r}:r??{},i=n.persistIndexes??!!n.pakIndexStore,o=n.enforceValidation??!!n.validator,a=n.allowUnknownPaks??!0,s=n.stopOnError??!1,c=[];for(let l of e)try{let d=await wg(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&&o||m&&!a){let g=new ei(u);if(n.onError?.(l.name,g),s)throw new gn(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 gn(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 gn(l.name,d)}return c}var yn=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 Mg(t){return Array.isArray(t)?t:Array.from(t)}function cd(t){return Mg(t).map(e=>({name:e.name,data:e}))}async function Nf(t,e,r){let n=cd(e);return Ks(t,n,r??{})}function Hf(t,e){let r=i=>{i.preventDefault(),i.dataTransfer?.dropEffect&&(i.dataTransfer.dropEffect="copy")},n=i=>{i.preventDefault();let o=i.dataTransfer?.files;o&&o.length>0&&e(Array.from(o))};return t.addEventListener("dragover",r),t.addEventListener("drop",n),()=>{t.removeEventListener("dragover",r),t.removeEventListener("drop",n)}}function Vf(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 Ag="IBSP",Eg=38,Wf=19,Lg=8+Wf*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 Xf(i)}catch(i){console.warn("BSP worker parsing failed, falling back to main thread",i)}return Qo(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=o=>{let{type:a,data:s,message:c}=o.data;a==="success"?(r(this.rehydrateData(s)),i.terminate()):(n(new Error(c)),i.terminate())},i.onerror=o=>{n(o),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 Qo(t){let e=Tg(t);return Xf(e)}function Xf(t){return{...t,pickEntity(e){let r=null,n=1/0;for(let i of t.entities.entities){let o=i.properties.model;if(!o||!o.startsWith("*"))continue;let a=parseInt(o.substring(1),10);if(isNaN(a)||a<0||a>=t.models.length)continue;let s=t.models[a],c=Rg(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],o=t.planes[i.planeIndex];o.normal[0]*e[0]+o.normal[1]*e[1]+o.normal[2]*e[2]-o.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 Tg(t){if(t.byteLength<Lg)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!==Ag)throw new se(`Invalid BSP magic ${r}`);let n=e.getInt32(4,!0);if(n!==Eg)throw new se(`Unsupported BSP version ${n}`);let i=new Map;for(let E=0;E<Wf;E+=1){let T=e.getInt32(8+E*8,!0),A=e.getInt32(12+E*8,!0);if(T<0||A<0||T+A>t.byteLength)throw new se(`Invalid lump bounds for index ${E}`);i.set(E,{offset:T,length:A})}let o={version:n,lumps:i},a=Cg(t,i.get(0)),s=Ig(t,i.get(1)),c=Bg(t,i.get(2)),l=Fg(t,i.get(4)),d=kg(t,i.get(5)),f=Dg(t,i.get(6)),u=new Uint8Array(t,i.get(7).offset,i.get(7).length),h=Yg(f,i.get(7)),m=zg(t,i.get(8)),g=Og(t,i.get(11)),p=Ug(t,i.get(12)),y=Ng(t,i.get(13)),v=Hg(t,i.get(14)),x=Vg(t,i.get(15)),b=$g(t,i.get(9),i.get(10),m),_=Kg(t,i.get(3)),w=Gg(t,i.get(17)),S=Wg(t,i.get(18));return{header:o,entities:a,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 Rg(t,e,r,n){let i=0,o=1/0;for(let a=0;a<3;a++)if(Math.abs(e[a])<1e-8){if(t[a]<r[a]||t[a]>n[a])return null}else{let s=1/e[a],c=(r[a]-t[a])*s,l=(n[a]-t[a])*s;if(c>l){let d=c;c=l,l=d}if(i=Math.max(i,c),o=Math.min(o,l),i>o)return null}return i}function Cg(t,e){let r=new TextDecoder().decode(new Uint8Array(t,e.offset,e.length)),n=Pg(r),i=n.find(o=>o.classname==="worldspawn");return{raw:r,entities:n,worldspawn:i,getUniqueClassnames(){let o=new Set;for(let a of n)a.classname&&o.add(a.classname);return Array.from(o).sort()}}}function Pg(t){let e=[],r=/\{([^}]*)\}/gms,n;for(;(n=r.exec(t))!==null;){let i=n[1],o={},a=/"([^\"]*)"\s+"([^\"]*)"/g,s;for(;(s=a.exec(i))!==null;)o[s[1]]=s[2];e.push({classname:o.classname,properties:o})}return e}function Ig(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 o=0;o<n;o+=1){let a=[r.getFloat32(o*20,!0),r.getFloat32(o*20+4,!0),r.getFloat32(o*20+8,!0)],s=r.getFloat32(o*20+12,!0),c=r.getInt32(o*20+16,!0);i.push({normal:a,dist:s,type:c})}return i}function Bg(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 o=0;o<n;o+=1)i.push([r.getFloat32(o*12,!0),r.getFloat32(o*12+4,!0),r.getFloat32(o*12+8,!0)]);return i}function Fg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({planeIndex:c,children:l,mins:d,maxs:f,firstFace:u,numFaces:h})}return o}function kg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({s:c,sOffset:l,t:d,tOffset:f,flags:u,value:h,texture:g,nextTexInfo:p})}return o}function Dg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({planeIndex:c,side:l,firstEdge:d,numEdges:f,texInfo:u,styles:h,lightOffset:m})}return o}function zg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({contents:c,cluster:l,area:d,mins:f,maxs:u,firstLeafFace:h,numLeafFaces:m,firstLeafBrush:g,numLeafBrushes:p})}return o}function Og(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 o=[];for(let a=0;a<i;a+=1){let s=a*n;o.push({vertices:[r.getUint16(s,!0),r.getUint16(s+2,!0)]})}return o}function Ug(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 o=0;o<r;o+=1)i[o]=n.getInt32(o*4,!0);return i}function Ng(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,o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({mins:c,maxs:l,origin:d,headNode:f,firstFace:u,numFaces:h})}return o}function Hg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n;o.push({firstSide:r.getInt32(s,!0),numSides:r.getInt32(s+4,!0),contents:r.getInt32(s+8,!0)})}return o}function Vg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n;o.push({planeIndex:r.getUint16(s,!0),texInfo:r.getInt16(s+2,!0)})}return o}function Gg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);o.push({numAreaPortals:c,firstAreaPortal:l})}return o}function Wg(t,e){return Xg(t,e)}function Xg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);o.push({portalNumber:c,otherArea:l})}return o}function $g(t,e,r,n){let i=[],o=[],a=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>a)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),o.push(u)}return{leafFaces:i,leafBrushes:o}}function Kg(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 o=4,a=[];for(let s=0;s<n;s+=1){let c=r.getInt32(o,!0),l=r.getInt32(o+4,!0);o+=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");a.push({pvs:Gf(t,d,n,e),phs:Gf(t,f,n,e)})}return{numClusters:n,clusters:a}}function Gf(t,e,r,n){let i=Math.ceil(r/8),o=new Uint8Array(i),a=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=a[s++];if(d!==0){o[c++]=d;continue}if(s>=l)throw new se("Visibility run exceeds lump bounds");let f=a[s++];for(let u=0;u<f&&c<i;u+=1)o[c++]=0}return o}function Yg(t,e){return t.map(r=>{if(!(r.lightOffset<0))return{offset:r.lightOffset,length:Math.max(0,e.length-r.lightOffset)}})}function Ys(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 qg=844121161,Zg=8,$f=68,Ze=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=dd(n.buffer);return this.cache.set(e,i),i}get(e){return this.cache.get(e)}};function Kf(t,e,r){let n=[];for(let i=0;i<r;i+=1){let o=t.getUint8(e+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function Jo(t,e,r,n){if(r!==0&&(e<$f||e+r>t.byteLength))throw new Ze(`${n} section is out of bounds`)}function jg(t){if(t.byteLength<$f)throw new Ze("MD2 buffer too small to contain header");let e=new DataView(t),r=e.getInt32(0,!0),n=e.getInt32(4,!0);if(r!==qg)throw new Ze(`Invalid MD2 ident: ${r}`);if(n!==Zg)throw new Ze(`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},o=40+i.numVertices*4;if(i.frameSize!==o)throw new Ze(`Unexpected frame size ${i.frameSize}, expected ${o}`);if(i.offsetEnd>t.byteLength)throw new Ze("MD2 offset_end exceeds buffer length");return i}function Qg(t,e){let r=e.numSkins*64;Jo(t,e.offsetSkins,r,"skins");let n=new DataView(t,e.offsetSkins,r),i=[];for(let o=0;o<e.numSkins;o+=1)i.push({name:Kf(n,o*64,64)});return i}function Jg(t,e){let r=e.numTexCoords*4;Jo(t,e.offsetTexCoords,r,"texcoords");let n=new DataView(t,e.offsetTexCoords,r),i=[];for(let o=0;o<e.numTexCoords;o+=1){let a=o*4;i.push({s:n.getInt16(a,!0),t:n.getInt16(a+2,!0)})}return i}function e1(t,e){let r=e.numTriangles*12;Jo(t,e.offsetTriangles,r,"triangles");let n=new DataView(t,e.offsetTriangles,r),i=[];for(let o=0;o<e.numTriangles;o+=1){let a=o*12,s=[n.getUint16(a,!0),n.getUint16(a+2,!0),n.getUint16(a+4,!0)],c=[n.getUint16(a+6,!0),n.getUint16(a+8,!0),n.getUint16(a+10,!0)];if(s.some(l=>l>=e.numVertices)||c.some(l=>l>=e.numTexCoords))throw new Ze("Triangle references out of range vertex or texcoord");i.push({vertexIndices:s,texCoordIndices:c})}return i}function t1(t,e){let r=e.numFrames*e.frameSize;Jo(t,e.offsetFrames,r,"frames");let n=[];for(let i=0;i<e.numFrames;i+=1){let o=e.offsetFrames+i*e.frameSize,a=new DataView(t,o,e.frameSize),s={x:a.getFloat32(0,!0),y:a.getFloat32(4,!0),z:a.getFloat32(8,!0)},c={x:a.getFloat32(12,!0),y:a.getFloat32(16,!0),z:a.getFloat32(20,!0)},l=Kf(a,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=a.getUint8(v)*s.x+c.x,b=a.getUint8(v+1)*s.y+c.y,_=a.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=a.getUint8(v+3),E=sr[S];if(!E)throw new Ze(`Invalid normal index ${S} in frame ${l}`);let T={x:E[0],y:E[1],z:E[2]};d.push({position:w,normalIndex:S,normal:T})}n.push({name:l,vertices:d,minBounds:{x:f,y:u,z:h},maxBounds:{x:m,y:g,z:p}})}return n}function r1(t,e){let r=e.numGlCommands*4;if(Jo(t,e.offsetGlCommands,r,"gl commands"),r===0)return[];let n=new DataView(t,e.offsetGlCommands,r),i=[],o=0;for(;;){if(o+4>r)throw new Ze("GL command list ended unexpectedly");let a=n.getInt32(o,!0);if(o+=4,a===0)break;let s=Math.abs(a),c=[],l=s*12;if(o+l>r)throw new Ze("GL command vertex block exceeds buffer");for(let d=0;d<s;d+=1){let f=n.getFloat32(o,!0),u=n.getFloat32(o+4,!0),h=n.getInt32(o+8,!0);if(o+=12,h<0||h>=e.numVertices)throw new Ze("GL command references invalid vertex index");c.push({s:f,t:u,vertexIndex:h})}i.push({mode:a>0?"strip":"fan",vertices:c})}if(o!==r)throw new Ze("GL command list did not consume expected data");return i}function dd(t){let e=jg(t),r=Qg(t,e),n=Jg(t,e),i=e1(t,e),o=t1(t,e),a=r1(t,e);return{header:e,skins:r,texCoords:n,triangles:i,frames:o,glCommands:a}}function Yf(t){let e=[],r=0;for(;r<t.length;){let n=t[r].name,i=n.replace(/\d+$/,"")||n,o=r;for(;o+1<t.length&&(t[o+1].name.replace(/\d+$/,"")||t[o+1].name)===i;)o+=1;e.push({name:i,firstFrame:r,lastFrame:o}),r=o+1}return e}var qf=860898377,n1=15,Yt=class extends Error{constructor(e){super(e),this.name="Md3ParseError"}};function ea(t,e,r){let n=new Uint8Array(t.buffer,t.byteOffset+e,r);return new TextDecoder("utf-8").decode(n).replace(/\0.*$/,"").trim()}function i1(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 o1(t){let e=t.getInt32(0,!0);if(e!==qf)throw new Yt(`Invalid MD3 ident: ${e}`);let r=t.getInt32(4,!0);if(r!==n1)throw new Yt(`Unsupported MD3 version: ${r}`);let n=ea(t,8,64),i=t.getInt32(72,!0),o=t.getInt32(76,!0),a=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(o<=0||s<0||a<0)throw new Yt("Invalid MD3 counts");return{ident:e,version:r,name:n,flags:i,numFrames:o,numTags:a,numSurfaces:s,numSkins:c,ofsFrames:l,ofsTags:d,ofsSurfaces:f,ofsEnd:u,magic:e}}function a1(t,e){let r=[];qs("Frames",e.ofsFrames,e.numFrames*56,t.byteLength);for(let i=0;i<e.numFrames;i+=1){let o=e.ofsFrames+i*56;r.push({minBounds:{x:t.getFloat32(o,!0),y:t.getFloat32(o+4,!0),z:t.getFloat32(o+8,!0)},maxBounds:{x:t.getFloat32(o+12,!0),y:t.getFloat32(o+16,!0),z:t.getFloat32(o+20,!0)},localOrigin:{x:t.getFloat32(o+24,!0),y:t.getFloat32(o+28,!0),z:t.getFloat32(o+32,!0)},radius:t.getFloat32(o+36,!0),name:ea(t,o+40,16)})}return r}function s1(t,e){let r=[],i=e.numFrames*e.numTags*112;qs("Tags",e.ofsTags,i,t.byteLength);for(let o=0;o<e.numFrames;o+=1){let a=[];for(let s=0;s<e.numTags;s+=1){let c=e.ofsTags+(o*e.numTags+s)*112,l=c+64,d=l+12;a.push({name:ea(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(a)}return r}function l1(t,e){let r=t.getInt32(e,!0);if(r!==qf)throw new Yt(`Invalid surface ident at ${e}: ${r}`);let n=ea(t,e+4,64),i=t.getInt32(e+68,!0),o=t.getInt32(e+72,!0),a=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(o<=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<a;S+=1){let E=v+S*68;y.push({name:ea(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<o;S+=1){let E=[];for(let T=0;T<s;T+=1){let A=w+(S*s+T)*8,C=t.getInt16(A,!0)/64,B=t.getInt16(A+2,!0)/64,F=t.getInt16(A+4,!0)/64,k=t.getUint16(A+6,!0);E.push({position:{x:C,y:B,z:F},latLng:k,normal:i1(k)})}_.push(E)}return{surface:{name:n,flags:i,numFrames:o,shaders:y,triangles:g,texCoords:x,vertices:_},nextOffset:e+h}}function ud(t){if(t.byteLength<108)throw new Yt("MD3 buffer too small for header");let e=new DataView(t),r=o1(e);qs("MD3 end",r.ofsEnd,0,t.byteLength);let n=a1(e,r),i=s1(e,r),o=[],a=r.ofsSurfaces;for(let s=0;s<r.numSurfaces;s+=1){let{surface:c,nextOffset:l}=l1(e,a);o.push(c),a=l}if(a!==r.ofsEnd)throw new Yt("Surface parsing did not reach ofsEnd");return{header:r,frames:n,tags:i,surfaces:o}}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=ud(r.slice().buffer);return this.cache.set(e,n),n}get(e){return this.cache.get(e)}};var c1=844317769,d1=2,Zf=64,jf=12,bn=class extends Error{};function u1(t,e,r){let n=[];for(let i=0;i<r;i+=1){let o=t.getUint8(e+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function fd(t){if(t.byteLength<jf)throw new bn("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!==c1)throw new bn(`Invalid Sprite ident: ${r}`);if(n!==d1)throw new bn(`Unsupported Sprite version: ${n}`);let o=[],a=16+Zf,s=jf;for(let c=0;c<i;c+=1){if(s+a>t.byteLength)throw new bn("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=u1(e,s+16,Zf);o.push({width:l,height:d,originX:f,originY:u,name:h}),s+=a}return{ident:r,version:n,numFrames:i,frames:o}}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),fd(n.buffer)}};function Qf(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 Jf(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 o=n?i%e:Math.min(i,e-1),a=Math.floor(o),s=t.sequence.start+a,c=a+1>=e?n?t.sequence.start:t.sequence.end:s+1,l=!n&&a>=e-1?0:o-a;return{frame0:s,frame1:c,lerp:l}}function eh(t){return{sequence:t,time:0}}function th(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 ta=class extends Error{constructor(e){super(e),this.name="WalParseError"}};function Zs(t){if(t.byteLength<100)throw new ta("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),o=e.getInt32(36,!0),a=[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||o<=0)throw new ta("Invalid WAL dimensions");let u=[],h=i,m=o;for(let g=0;g<a.length;g+=1){let p=a[g],y=Math.max(1,h*m|0);if(p<=0||p+y>t.byteLength)throw new ta(`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:o,mipmaps:u,animName:c,flags:l,contents:d,value:f}}var ti=class extends Error{constructor(e){super(e),this.name="PcxParseError"}};function ra(t){if(t.byteLength<128)throw new ti("PCX buffer too small for header");let e=new DataView(t),r=e.getUint8(0),n=e.getUint8(2),i=e.getUint8(3),o=e.getUint16(4,!0),a=e.getUint16(6,!0),s=e.getUint16(8,!0),c=e.getUint16(10,!0);if(r!==10||n!==1)throw new ti("Unsupported PCX encoding");if(i!==8)throw new ti("Only 8bpp PCX files are supported");let l=s-o+1,d=c-a+1,f=e.getUint16(66,!0),u=t.byteLength-769;if(u<128||new DataView(t,u,1).getUint8(0)!==12)throw new ti("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 ti("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,o=r*4;e[o]=t.palette[i],e[o+1]=t.palette[i+1],e[o+2]=t.palette[i+2],e[o+3]=n===255?0:255}return e}var Gr=class extends Error{constructor(e){super(e),this.name="TgaParseError"}};function hd(t){let e=new DataView(t);if(t.byteLength<18)throw new Gr("Buffer too small for TGA header");let r=e.getUint8(0),n=e.getUint8(1),i=e.getUint8(2),o=e.getUint16(12,!0),a=e.getUint16(14,!0),s=e.getUint8(16),c=e.getUint8(17);if(i!==2&&i!==10&&i!==3&&i!==11)throw new Gr(`Unsupported TGA image type: ${i} (only RGB/Grayscale supported)`);if(s!==24&&s!==32&&s!==8)throw new Gr(`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=o*a,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 Gr("Unexpected end of TGA RLE data");let b=y[u++],_=(b&127)+1,w=(b&128)!==0;if(x+_>h)throw new Gr("TGA RLE packet exceeds image bounds");if(w){let S=d?y[u]:y[u+2],E=d?y[u]:y[u+1],T=y[u],A=d?255:s===32?y[u+3]:255;u+=f;for(let C=0;C<_;C++){let B=(x+C)*4;m[B]=S,m[B+1]=E,m[B+2]=T,m[B+3]=A}}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 Gr("Unexpected end of TGA data");v(x*4)}if(!g){let x=o*4,b=new Uint8Array(x);for(let _=0;_<a/2;_++){let w=_*x,S=(a-1-_)*x;b.set(m.subarray(w,w+x)),m.set(m.subarray(S,S+x),w),m.set(b,S)}}return{width:o,height:a,bitsPerPixel:32,pixels:m}}function f1(t){let e=0;for(let r of t.levels)e+=r.rgba.byteLength;return e}var Wi=class{constructor(e={}){this.cache=new yn(e.capacity??128,e.maxMemory??256*1024*1024,f1)}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 md(t,e){let r=[];for(let n of t.mipmaps){let i=new Uint8Array(n.width*n.height*4);for(let o=0;o<n.data.length;o+=1){let a=n.data[o],s=a*3,c=o*4;i[c]=e[s],i[c+1]=e[s+1],i[c+2]=e[s+2],i[c+3]=a===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 rh(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 md(Zs(t),e)}var ri=class extends Error{constructor(e){super(e),this.name="WavParseError"}};function pd(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 ri("WAV buffer too small");let e=new DataView(t);if(pd(e,0,4)!=="RIFF"||pd(e,8,4)!=="WAVE")throw new ri("Invalid WAV header");let r=12,n=-1,i=-1,o=0,a=0;for(;r+8<=t.byteLength;){let m=pd(e,r,4),g=e.getUint32(r+4,!0),p=r+8;m==="fmt "?(n=p,o=g):m==="data"&&(i=p,a=g),r=p+g}if(n===-1||i===-1)throw new ri("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 ri("Only PCM WAV is supported");let f=d/8,u=a/(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 ri(`Unsupported bitsPerSample: ${d}`)}return{sampleRate:l,channels:c,bitsPerSample:d,samples:h}}var h1=(t,e=4294967295,r=79764919)=>{let n=new Int32Array(256),i,o,a,s=e;for(i=0;i<256;i++){for(a=i<<24,o=8;o>0;--o)a=2147483648&a?a<<1^r:a<<1;n[i]=a}for(i=0;i<t.length;i++)s=s<<8^n[255&(s>>24^t[i])];return s};var gd=(t,e=h1)=>{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 o=new Uint8Array(t.length),a,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(a=t.charCodeAt(p),a!==61||l){if(a===92&&p<t.length-5&&u){let y=t.charCodeAt(p+1);y!==117&&y!==85||(a=parseInt(t.substring(p+2,p+6),16),p+=5)}if(a>255){let y=i.get(a);y&&(a=y+127)}l&&(l=!1,a-=64),o[d++]=a<f&&a>0?a+m:a-f}else l=!0;let g=o.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 Lp=Object.create;var Bs=Object.defineProperty;var Tp=Object.getOwnPropertyDescriptor;var Rp=Object.getOwnPropertyNames;var Cp=Object.getPrototypeOf,Pp=Object.prototype.hasOwnProperty;var Ip=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),No=(t,e)=>{for(var r in e)Bs(t,r,{get:e[r],enumerable:!0})},bf=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Rp(e))!Pp.call(t,i)&&i!==r&&Bs(t,i,{get:()=>e[i],enumerable:!(n=Tp(e,i))||n.enumerable});return t};var Bp=(t,e,r)=>(r=t!=null?Lp(Cp(t)):{},bf(e||!t||!t.__esModule?Bs(r,"default",{value:t,enumerable:!0}):r,t)),Fp=t=>bf(Bs({},"__esModule",{value:!0}),t);var ih=Ip((nM,nh)=>{"use strict";nh.exports=Worker});var lw={};No(lw,{ATTN_IDLE:()=>rd,ATTN_LOOP_NONE:()=>ed,ATTN_NONE:()=>Yo,ATTN_NORM:()=>td,ATTN_STATIC:()=>nd,AssetDependencyError:()=>gi,AssetDependencyTracker:()=>Za,AssetManager:()=>Fl,AssetPreviewGenerator:()=>Rc,AudioApi:()=>Di,AudioContextController:()=>kl,AudioOcclusion:()=>Qa,AudioRegistry:()=>so,AudioRegistryError:()=>Ka,AudioSystem:()=>Vl,BSP_SURFACE_FRAGMENT_SOURCE:()=>$d,BSP_SURFACE_VERTEX_SOURCE:()=>Xd,BSP_VERTEX_LAYOUT:()=>Ud,BspLoader:()=>Ui,BspParseError:()=>se,BspSurfacePipeline:()=>fo,Camera:()=>nc,ClientConnection:()=>Dc,Command:()=>Ho,CommandRegistry:()=>Ci,ConfigStringRegistry:()=>zi,ConnectionState:()=>cf,CoordinateSystem:()=>lf,Cvar:()=>qo,CvarRegistry:()=>Fi,DemoAnalyzer:()=>Bo,DemoCameraMode:()=>nf,DemoClipper:()=>Tc,DemoEventType:()=>rf,DemoPlaybackController:()=>ws,DemoReader:()=>hr,DemoRecorder:()=>Ms,DemoValidator:()=>Lc,DynamicLightManager:()=>Kl,EngineHost:()=>ki,EngineRuntime:()=>Zo,FileType:()=>of,FixedTimestepLoop:()=>Yn,Framebuffer:()=>yi,IndexBuffer:()=>Je,LoggingRenderer:()=>kc,LruCache:()=>yn,MAX_SOUND_CHANNELS:()=>Ko,MD2_FRAGMENT_SHADER:()=>Jd,MD2_VERTEX_SHADER:()=>Qd,MD3_FRAGMENT_SHADER:()=>xu,MD3_VERTEX_SHADER:()=>bu,MapAnalyzer:()=>Cc,Md2Loader:()=>Ni,Md2MeshBuffers:()=>mo,Md2ParseError:()=>Ze,Md2Pipeline:()=>po,Md3Loader:()=>Hi,Md3ModelMesh:()=>xo,Md3ParseError:()=>Yt,Md3Pipeline:()=>vo,Md3SurfaceMesh:()=>ns,MessageWriter:()=>Ec,MusicSystem:()=>Gl,NetworkMessageParser:()=>dt,NullRenderer:()=>Pc,PARTICLE_FRAGMENT_SHADER:()=>_u,PARTICLE_VERTEX_SHADER:()=>vu,PROTOCOL_VERSION_RERELEASE:()=>zr,PakArchive:()=>Oi,PakIndexStore:()=>Bl,PakIngestionError:()=>gn,PakParseError:()=>Be,PakValidationError:()=>ei,PakValidator:()=>Ks,PakWriter:()=>Ws,ParticleRenderer:()=>So,ParticleSystem:()=>_o,PlaybackState:()=>Ac,RERELEASE_KNOWN_PAKS:()=>ld,ResourceLoadTracker:()=>Xs,ResourceType:()=>sd,SKYBOX_FRAGMENT_SHADER:()=>Zd,SKYBOX_VERTEX_SHADER:()=>qd,SOUND_FULLVOLUME:()=>Ii,SOUND_LOOP_ATTENUATE:()=>id,ShaderProgram:()=>le,SkyboxPipeline:()=>ho,SoundChannel:()=>Mr,SoundPrecache:()=>Ol,SoundRegistry:()=>zl,SpriteLoader:()=>Vi,SpriteParseError:()=>bn,SpriteRenderer:()=>wo,StreamingPakArchive:()=>Gs,Texture2D:()=>et,TextureCache:()=>Gi,TextureCubeMap:()=>lo,TgaParseError:()=>Gr,U_ALPHA:()=>br,U_ANGLE1:()=>_t,U_ANGLE2:()=>gt,U_ANGLE3:()=>yt,U_EFFECTS16:()=>We,U_EFFECTS8:()=>He,U_EVENT:()=>xt,U_FRAME16:()=>wt,U_FRAME8:()=>bt,U_INSTANCE_BITS:()=>Sr,U_LOOP_ATTENUATION_HIGH:()=>fn,U_LOOP_VOLUME:()=>wr,U_MODEL:()=>St,U_MODEL2:()=>Mt,U_MODEL3:()=>At,U_MODEL4:()=>Et,U_OLDORIGIN:()=>lr,U_OLD_FRAME_HIGH:()=>mn,U_ORIGIN1:()=>mt,U_ORIGIN2:()=>pt,U_ORIGIN3:()=>vt,U_OWNER_HIGH:()=>hn,U_REMOVE:()=>Xo,U_RENDERFX16:()=>Ge,U_RENDERFX8:()=>Ne,U_SCALE:()=>_r,U_SKIN16:()=>Xe,U_SKIN8:()=>Ve,U_SOLID:()=>Tt,U_SOUND:()=>Lt,VertexArray:()=>Le,VertexBuffer:()=>Ae,VirtualFileSystem:()=>$s,advanceAnimation:()=>Qf,applyEntityDelta:()=>lp,applySurfaceState:()=>Ja,attenuationToDistanceMultiplier:()=>Bi,boxIntersectsFrustum:()=>bi,buildBspGeometry:()=>$l,buildMd2Geometry:()=>eu,buildMd2VertexData:()=>tu,buildMd3SurfaceGeometry:()=>gu,buildMd3VertexData:()=>yu,calculateMaxAudibleDistance:()=>Jn,calculatePakChecksum:()=>Df,captureRenderTarget:()=>bp,computeFrameBlend:()=>Jf,computeSkyScroll:()=>ql,createAnimationState:()=>eh,createAudioGraph:()=>Dl,createBspSurfaces:()=>Xl,createEmptyEntityState:()=>Dr,createEmptyProtocolPlayerState:()=>mr,createEngine:()=>sw,createEngineRuntime:()=>Bf,createFaceLightmap:()=>qs,createHeadlessRenderTarget:()=>yp,createInitialChannels:()=>Ul,createOcclusionResolver:()=>Fh,createProgramFromSources:()=>zh,createRenderer:()=>Um,createWebGLContext:()=>kh,createWebGPUContext:()=>pp,decodeOgg:()=>Il,deriveSurfaceRenderState:()=>Yd,detectFileType:()=>af,extractFrustumPlanes:()=>Dn,filesToPakSources:()=>cd,findLeafForPoint:()=>xi,gatherVisibleFaces:()=>vi,groupMd2Animations:()=>Yf,ingestPakFiles:()=>Nf,ingestPaks:()=>Ys,interpolateMd3Tag:()=>vm,interpolateVec3:()=>th,isBinaryFile:()=>dp,isTextFile:()=>sf,parseBsp:()=>jo,parseEntLump:()=>fp,parseMd2:()=>dd,parseMd3:()=>ud,parsePcx:()=>ta,parseSprite:()=>fd,parseTga:()=>hd,parseWal:()=>js,parseWalTexture:()=>el,parseWav:()=>tl,pcxToRgba:()=>Qs,pickChannel:()=>Nl,preparePcxTexture:()=>Js,queryCapabilities:()=>gp,removeViewTranslation:()=>Yl,resolveLightStyles:()=>Kd,serializeEntLump:()=>hp,spawnBfgExplosion:()=>Im,spawnBlasterImpact:()=>Pm,spawnBlood:()=>wm,spawnBulletImpact:()=>_m,spawnExplosion:()=>Sm,spawnMuzzleFlash:()=>Am,spawnRailTrail:()=>Rm,spawnSparks:()=>Cm,spawnSplash:()=>Lm,spawnSteam:()=>Tm,spawnTeleportFlash:()=>Mm,spawnTrail:()=>Em,validateEntity:()=>mp,walToRgba:()=>md,wireDropTarget:()=>Hf,wireFileInput:()=>Vf});var kp=()=>typeof performance<"u"?performance.now():Date.now(),Dp=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??kp,schedule:r.schedule??Dp}}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 o=this.options.fixedDeltaMs===0?0:this.accumulatorMs/this.options.fixedDeltaMs;this.callbacks.render?.({alpha:o,nowMs:r,accumulatorMs:this.accumulatorMs,frame:this.frame})}};var Ho=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 Ho(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],o=n.slice(1),a=this.get(i);return a?(a.execute(o),!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 o of i)o.startsWith(e)&&r.add(o)}return Array.from(r).sort()}tokenize(e){let r=[],n="",i=!1;for(let o=0;o<e.length;o++){let a=e[o];a==='"'?i=!i:a===" "&&!i?n.length>0&&(r.push(n),n=""):n+=a}return n.length>0&&r.push(n),r}list(){return[...this.commands.values()].sort((e,r)=>e.name.localeCompare(r.name))}};var zp=Object.defineProperty,Op=(t,e)=>{for(var r in e)zp(t,r,{get:e[r],enumerable:!0})},xf={x:0,y:0,z:0};var xw=Math.PI/180;function vf(t,e){return{x:t.x-e.x,y:t.y-e.y,z:t.z-e.z}}function Up(t,e){return{x:t.x*e,y:t.y*e,z:t.z*e}}function Np(t,e){return t.x*e.x+t.y*e.y+t.z*e.z}function Hp(t){return Np(t,t)}function Gc(t){return Math.sqrt(Hp(t))}function Vr(t){let e=Gc(t);return e===0?t:Up(t,1/e)}var Vp=Math.PI/180,Gp=180/Math.PI,Ee=Vp,Wc=Gp;var sr=[[-.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 pr=624,Wp=397,Xp=2567483615,$p=2147483648,Kp=2147483647,Hc=4294967296,Yp=class{constructor(t=5489){this.state=new Uint32Array(pr),this.index=pr,this.seed(t)}seed(t){this.state[0]=t>>>0;for(let e=1;e<pr;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=pr}nextUint32(){this.index>=pr&&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<pr;t++){let e=this.state[t]&$p|this.state[(t+1)%pr]&Kp,r=this.state[(t+Wp)%pr]^e>>>1;(e&1)!==0&&(r^=Xp),this.state[t]=r>>>0}this.index=0}getState(){return{index:this.index,state:Array.from(this.state)}}setState(t){if(t.state.length!==pr)throw new Error(`Expected ${pr} MT state values, received ${t.state.length}`);this.index=t.index,this.state=Uint32Array.from(t.state,e=>e>>>0)}},_f=class{constructor(t={}){this.mt=new Yp(t.seed)}seed(t){this.mt.seed(t)}frandom(){return this.mt.nextUint32()/Hc}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=Hc-Hc%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 qp(){return new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}function Xc(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 Sf(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 wf(t,e){let r=qp();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 gr=1,un=2;var $c=8,Kc=16,Zp=32;var jp=16384;var Fs=65536,Mf=1<<17,Qp=1<<18,Jp=1<<19,eg=1<<20,tg=1<<21,rg=1<<22,ng=1<<23,vw=1<<24,ks=1<<25,ig=1<<26,_w=1<<27,Sw=1<<28,ww=1<<29,Ds=1<<30,Mw=1<<31;var Go=0;var zs=4,Wo=8,Os=16,Us=32,Af=64;var Aw=1<<25,Ew=1<<28,Lw=1<<29,Tw=1<<30,Rw=1<<31;var Cw=gr|un,Pw=gr|Fs|un|ks|Ds,Iw=gr|Fs|un,Bw=gr|Mf|un|ks|Ds,Fw=Zp|$c|Kc,kw=gr|Kc|$c,og=gr|ks|Ds|un|ig,Dw=Qp|Jp|eg|tg|rg|ng,zw=gr|$c|Kc|ks|Ds,Ow=gr|Fs|un,Uw=gr|un,Nw=gr|Fs|un|Mf,Hw=og|jp;var Vw=Number.MAX_SAFE_INTEGER-1;var Ns=(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))(Ns||{});var Hs=256;var Yc=256,qc=8192,Vs=2048,Zc=512,jc=256,Qc=Hs*2,Jc=256,Vc=32,Vo=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+qc]="Sounds",t[t.Images=t.Sounds+Vs]="Images",t[t.Lights=t.Images+Zc]="Lights",t[t.ShadowLights=t.Lights+Yc]="ShadowLights",t[t.Items=t.ShadowLights+Jc]="Items",t[t.Players=t.Items+jc]="Players",t[t.PlayerSkins=t.Players]="PlayerSkins",t[t.General=t.Players+Hs]="General",t[t.WheelWeapons=t.General+Qc]="WheelWeapons",t[t.WheelAmmo=t.WheelWeapons+Vc]="WheelAmmo",t[t.WheelPowerups=t.WheelAmmo+Vc]="WheelPowerups",t[t.CdLoopCount=t.WheelPowerups+Vc]="CdLoopCount",t[t.GameStyle=t.CdLoopCount+1]="GameStyle",t[t.MaxConfigStrings=t.GameStyle+1]="MaxConfigStrings",t))(J||{}),Ef=J.MaxConfigStrings;function Lf(t){return t>=5&&t<59?Vo*(59-t):t>=J.General&&t<J.WheelWeapons?Vo*(J.MaxConfigStrings-t):Vo}var Gw=J.Sounds,Ww=J.Images,Xw=J.Lights,$w=J.Items,Kw=J.Players,Yw=J.General,ag={};Op(ag,{addReplayFrame:()=>dg,createReplaySession:()=>cg,deserializeReplay:()=>lg,serializeReplay:()=>sg});function sg(t){return JSON.stringify(t,null,2)}function lg(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 cg(t,e){return{metadata:{map:t,date:new Date().toISOString(),version:"1.0",seed:e},frames:[]}}function dg(t,e,r,n){t.frames.push({serverFrame:r,cmd:e,timestamp:Date.now()-n})}var R=(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))(R||{}),Zn=(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))(Zn||{}),z=(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))(z||{});var Tf=64;var ug=12,fg=9,qw=Math.ceil(ug*fg/16),hg=23,mg=2,Zw=Math.ceil(hg*mg/16);function Rf(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 pg=[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 Cf(t){let e=0;for(let r=0;r<t.length;r++)e=pg[(e^t[r])&255];return e}var mt=1,pt=2,gt=4,yt=8,bt=16,xt=32,Xo=64,yr=128,jn=256,vt=512,_t=1024,St=2048,Ne=4096,br=8192,He=16384,xr=32768,Ve=65536,wt=1<<17,Ge=1<<18,We=1<<19,Mt=1<<20,At=1<<21,Et=1<<22,vr=1<<23,lr=1<<24,Xe=1<<25,Lt=1<<26,Tt=1<<27,_r=1<<28,Sr=1<<29,wr=1<<30,Pi=-2147483648,fn=1,hn=2,mn=4;var pn=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=sr[e];t.x=r[0],t.y=r[1],t.z=r[2]}},Qn=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<sr.length;n++){let i=sr[n],o=t.x*i[0]+t.y*i[1]+t.z*i[2];o>e&&(e=o,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}},$o=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,o=Math.sqrt(t*t+e*e+r*r);if(o>0){t/=o,e/=o,r/=o;for(let a=0;a<162;a++){let s=t*sr[a][0]+e*sr[a][1]+r*sr[a][2];s>i&&(i=s,n=a)}}this.writeByte(n)}},qn=class qe{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 Qn(qe.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>qe.FRAGMENT_SIZE?(n=!0,this.fragmentSendOffset>=this.reliableLength&&(this.fragmentSendOffset=0),r=this.reliableLength-this.fragmentSendOffset,r>qe.FRAGMENT_SIZE&&(r=qe.FRAGMENT_SIZE),i=this.fragmentSendOffset,this.fragmentSendOffset+=r):r=this.reliableLength);let o=qe.PACKET_HEADER,a=r>0?2+(n?8:0):0,s=e?e.length:0;o+a+r+s>qe.MAX_MSGLEN&&(s=qe.MAX_MSGLEN-o-a-r,s<0&&(s=0));let c=new ArrayBuffer(o+a+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=o;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<qe.PACKET_HEADER)return null;let i=r.getUint32(4,!0),o=r.getUint16(8,!0);if(this.qport!==o)return null;let a=n&1073741823;if((a-this.incomingSequence|0)<=0)return null;this.incomingSequence=a;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=qe.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>qe.MAX_RELIABLE_BUFFER)return console.warn(`NetChan: received invalid fragment total ${v} > ${qe.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>qe.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeByte(e),this.reliableLength++}writeReliableShort(e){if(this.reliableLength+2>qe.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeShort(e),this.reliableLength+=2}writeReliableLong(e){if(this.reliableLength+4>qe.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>qe.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}};qn.MAX_MSGLEN=1400;qn.FRAGMENT_SIZE=1024;qn.PACKET_HEADER=10;qn.HEADER_OVERHEAD=qn.PACKET_HEADER+2;qn.MAX_RELIABLE_BUFFER=262144;var Pf=qn;var If=(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))(If||{}),jw=Object.keys(If).length/2;var Ko=32,Mr=(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))(Mr||{}),ed=-1,Yo=0,td=1,rd=2,nd=3,Ii=80,id=.003;function Bi(t){return t*.001}function Jn(t){let e=Bi(t);return e<=0?Number.POSITIVE_INFINITY:Ii+1/e}var qo=class{constructor({name:e,defaultValue:r,description:n,flags:i=Ns.None,onChange:o}){this.modifiedCount=0;this.name=e,this.defaultValue=r,this.description=n,this.flags=i,this._value=r,this.onChange=o}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&Ns.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)}},Fi=class{constructor(){this.cvars=new Map}register(e){let r=this.cvars.get(e.name);if(r)return r;let n=e.onChange,i=(a,s)=>{n?.(a,s),this.onCvarChange?.(a.name,a.string)},o=new qo({...e,onChange:i});return this.cvars.set(e.name,o),o}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 ki=class{constructor(e,r,n={}){this.game=e;this.client=r;this.started=!1;this.paused_=!1;this.commands=new Ci;this.cvars=new Fi;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(o=>o.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 Di=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,o,a){this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:o,timeOffsetMs:a}),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,o){let a=this.system.play({entity:e,channel:r,soundIndex:n,volume:i,attenuation:o,looping:!0});return this.triggerSubtitle(n),a}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 Zo=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 Bf(t,e,r,n,i){let o=new Di({...n,client:r}),a=new ki(e,r,i);return{runtime:new Zo(t,a),audio:o}}function gg(t){if(t<0||t>=J.MaxConfigStrings)throw new RangeError(`Configstring index ${t} is out of range (0-${J.MaxConfigStrings-1})`)}function Ff(t,e){let r=Lf(t);if(e.length>r)throw new RangeError(`Configstring ${t} exceeds maximum length (${e.length} > ${r}); limit is ${Vo} chars per slot`)}var zi=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 gg(e),Ff(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(Ef).fill("");for(let[r,n]of this.values.entries())e[r]=n;return e}modelIndex(e){return this.register(e,J.Models,qc,"modelCursor")}soundIndex(e){return this.register(e,J.Sounds,Vs,"soundCursor")}findSoundIndex(e){for(let r=J.Sounds;r<J.Sounds+Vs;r+=1)if(this.values.get(r)===e)return r}imageIndex(e){return this.register(e,J.Images,Zc,"imageCursor")}lightIndex(e){return this.register(e,J.Lights,Yc,"lightCursor")}shadowLightIndex(e){return this.register(e,J.ShadowLights,Jc,"shadowLightCursor")}itemIndex(e){return this.register(e,J.Items,jc,"itemCursor")}playerSkinIndex(e){return this.register(e,J.PlayerSkins,Hs,"playerSkinCursor")}generalIndex(e){return this.register(e,J.General,Qc,"generalCursor")}register(e,r,n,i){for(let s=r;s<r+n;s+=1)if(this.values.get(s)===e)return s;let o=this[i],a=r+n;if(o>=a)throw new RangeError(`Out of configstring slots for range starting at ${r}`);return Ff(o,e),this.values.set(o,e),this[i]=o+1,o}};var yg="PACK";function bg(t,e,r){let n=[];for(let i=0;i<r;i+=1){let o=t.getUint8(e+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function _e(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}function xg(){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 vg=xg();function kf(t){let e=4294967295;for(let r=0;r<t.length;r+=1){let n=t[r];e=vg[(e^n)&255]^e>>>8}return(e^4294967295)>>>0}var Be=class extends Error{},Oi=class t{constructor(e,r,n,i){this.name=e;this.buffer=r;this.entries=new Map(n.map(o=>[o.name,o])),this.checksum=i,this.size=r.byteLength}static fromArrayBuffer(e,r){let n=new DataView(r);if(r.byteLength<12)throw new Be("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!==yg)throw new Be(`Invalid PAK header magic: ${i}`);let o=n.getInt32(4,!0),a=n.getInt32(8,!0);if(o<12)throw new Be(`Invalid directory offset: ${o}`);if(a<0||a%64!==0)throw new Be(`Invalid directory length: ${a}`);if(o+a>r.byteLength)throw new Be("Directory exceeds buffer length");let c=a/64,l=[],d=new Map;for(let f=0;f<c;f+=1){let u=o+f*64,h=bg(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 Be(`Invalid entry bounds for ${h||"<unnamed>"} (offset=${g}, length=${p})`);if(!m)throw new Be(`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,kf(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 Be(`File not found in PAK: ${e}`);return new Uint8Array(this.buffer,r.offset,r.length)}validate(){return{checksum:this.checksum,entries:this.listEntries()}}};function Df(t){return kf(new Uint8Array(t))}var _g="PACK",zf=12,od=64;function Of(t){return t.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}var Gs=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,zf),r=new DataView(e),n=String.fromCharCode(r.getUint8(0),r.getUint8(1),r.getUint8(2),r.getUint8(3));if(n!==_g)throw new Be(`Invalid PAK header magic: ${n}`);let i=r.getInt32(4,!0),o=r.getInt32(8,!0);if(i<zf)throw new Be(`Invalid directory offset: ${i}`);if(o<0||o%od!==0)throw new Be(`Invalid directory length: ${o}`);let a=await this.readChunk(i,o),s=new DataView(a),c=o/od,l=new Map;for(let d=0;d<c;d++){let f=d*od,u=this.readCString(s,f,56),h=Of(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 Be(`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 Be(`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(Of(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 o=0;o<n;o+=1){let a=e.getUint8(r+o);if(a===0)break;i.push(a)}return String.fromCharCode(...i)}};var ad=12,Uf=64,Ws=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*Uf,n=ad+e+r,i=new Uint8Array(n),o=new DataView(i.buffer);o.setUint8(0,80),o.setUint8(1,65),o.setUint8(2,67),o.setUint8(3,75);let a=ad+e;o.setInt32(4,a,!0),o.setInt32(8,r,!0);let s=ad,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=a,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?o.setUint8(d+g,m[g]):o.setUint8(d+g,0);o.setInt32(d+56,c.get(u),!0),o.setInt32(d+60,h.byteLength,!0),d+=Uf}return i}static buildFromEntries(e){let r=new t;for(let[n,i]of e)r.addFile(n,i);return r.build()}};var sd=(a=>(a.Texture="texture",a.Sound="sound",a.Model="model",a.Map="map",a.Sprite="sprite",a.ConfigString="configString",a))(sd||{}),Xs=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 $s=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,o)=>o.priority-i.priority);for(let i of e.listEntries()){let o=_e(i.name),a={archive:e,entry:i,priority:r};this.files.has(o)||this.files.set(o,[]);let s=this.files.get(o),c=s.findIndex(l=>l.archive===e);c!==-1&&s.splice(c,1),s.unshift(a),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,o=i.readFile(e),a=0,s=o.length;return new ReadableStream({pull(c){if(a>=s){c.close();return}let l=Math.min(a+r,s),d=o.slice(a,l);a=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,o=r?`${r}/`:"";for(let[a,s]of this.files){let c=s[0];if(r&&!c.entry.name.startsWith(o))continue;let l=r?c.entry.name.slice(o.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((a,s)=>a.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,o]of this.files){let a=o[0];a.entry.name.toLowerCase().endsWith(r)&&n.push({path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name})}return n.sort((i,o)=>i.path.localeCompare(o.path))}listByExtension(e){let r=new Set(e.map(i=>i.startsWith(".")?i.toLowerCase():`.${i.toLowerCase()}`)),n=[];for(let[i,o]of this.files){let a=o[0],s=a.entry.name.toLowerCase();for(let c of r)if(s.endsWith(c)){n.push({path:a.entry.name,size:a.entry.length,sourcePak:a.archive.name});break}}return n.sort((i,o)=>i.path.localeCompare(o.path))}searchFiles(e){let r=[];for(let[n,i]of this.files){let o=i[0];e.test(o.entry.name)&&r.push({path:o.entry.name,size:o.entry.length,sourcePak:o.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 o=i[0];return{path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name}}).sort((i,o)=>i.path.localeCompare(o.path));for(let i of n){let o=i.path.split("/"),a=o.pop(),s="",c=e;for(let l of o){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 ld=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"}]),ei=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=ld){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,o="size"in e?e.size:void 0,a=this.known.get(n);return a?a.checksum!==i?{name:n,checksum:i,expectedChecksum:a.checksum,status:"mismatch",size:o,description:a.description}:{name:n,checksum:i,expectedChecksum:a.checksum,status:"valid",size:o,description:a.description}:{name:n,checksum:i,status:"unknown",size:o}}assertValid(e,r){let n=this.validateArchive(e,r);if(n.status==="mismatch")throw new ei(n);return n}normalizePakName(e){let r=_e(e),n=r.split("/"),i=n.pop()??r,o=n.pop();return o?`${i}@${o}`:i}};var gn=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 Sg(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=o=>{e?.({file:"blob",loadedBytes:o.loaded,totalBytes:o.total||t.size,state:"reading"})},i.onload=()=>{let o=i.result;o instanceof ArrayBuffer?r(o):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 o=new Uint8Array(i),a=0;for(let s of n)o.set(s,a),a+=s.byteLength;return o.buffer}throw new gn("blob",new Error("Unsupported Blob type"))}async function wg(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 Sg(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,o=n.enforceValidation??!!n.validator,a=n.allowUnknownPaks??!0,s=n.stopOnError??!1,c=[];for(let l of e)try{let d=await wg(l,n.onProgress),f=Oi.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&&o||m&&!a){let g=new ei(u);if(n.onError?.(l.name,g),s)throw new gn(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 gn(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 gn(l.name,d)}return c}var yn=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 Mg(t){return Array.isArray(t)?t:Array.from(t)}function cd(t){return Mg(t).map(e=>({name:e.name,data:e}))}async function Nf(t,e,r){let n=cd(e);return Ys(t,n,r??{})}function Hf(t,e){let r=i=>{i.preventDefault(),i.dataTransfer?.dropEffect&&(i.dataTransfer.dropEffect="copy")},n=i=>{i.preventDefault();let o=i.dataTransfer?.files;o&&o.length>0&&e(Array.from(o))};return t.addEventListener("dragover",r),t.addEventListener("drop",n),()=>{t.removeEventListener("dragover",r),t.removeEventListener("drop",n)}}function Vf(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 Ag="IBSP",Eg=38,Wf=19,Lg=8+Wf*8;var se=class extends Error{},Ui=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 Xf(i)}catch(i){console.warn("BSP worker parsing failed, falling back to main thread",i)}return jo(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=o=>{let{type:a,data:s,message:c}=o.data;a==="success"?(r(this.rehydrateData(s)),i.terminate()):(n(new Error(c)),i.terminate())},i.onerror=o=>{n(o),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 jo(t){let e=Tg(t);return Xf(e)}function Xf(t){return{...t,pickEntity(e){let r=null,n=1/0;for(let i of t.entities.entities){let o=i.properties.model;if(!o||!o.startsWith("*"))continue;let a=parseInt(o.substring(1),10);if(isNaN(a)||a<0||a>=t.models.length)continue;let s=t.models[a],c=Rg(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],o=t.planes[i.planeIndex];o.normal[0]*e[0]+o.normal[1]*e[1]+o.normal[2]*e[2]-o.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 Tg(t){if(t.byteLength<Lg)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!==Ag)throw new se(`Invalid BSP magic ${r}`);let n=e.getInt32(4,!0);if(n!==Eg)throw new se(`Unsupported BSP version ${n}`);let i=new Map;for(let E=0;E<Wf;E+=1){let T=e.getInt32(8+E*8,!0),A=e.getInt32(12+E*8,!0);if(T<0||A<0||T+A>t.byteLength)throw new se(`Invalid lump bounds for index ${E}`);i.set(E,{offset:T,length:A})}let o={version:n,lumps:i},a=Cg(t,i.get(0)),s=Ig(t,i.get(1)),c=Bg(t,i.get(2)),l=Fg(t,i.get(4)),d=kg(t,i.get(5)),f=Dg(t,i.get(6)),u=new Uint8Array(t,i.get(7).offset,i.get(7).length),h=Yg(f,i.get(7)),m=zg(t,i.get(8)),g=Og(t,i.get(11)),p=Ug(t,i.get(12)),y=Ng(t,i.get(13)),v=Hg(t,i.get(14)),x=Vg(t,i.get(15)),b=$g(t,i.get(9),i.get(10),m),_=Kg(t,i.get(3)),w=Gg(t,i.get(17)),S=Wg(t,i.get(18));return{header:o,entities:a,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 Rg(t,e,r,n){let i=0,o=1/0;for(let a=0;a<3;a++)if(Math.abs(e[a])<1e-8){if(t[a]<r[a]||t[a]>n[a])return null}else{let s=1/e[a],c=(r[a]-t[a])*s,l=(n[a]-t[a])*s;if(c>l){let d=c;c=l,l=d}if(i=Math.max(i,c),o=Math.min(o,l),i>o)return null}return i}function Cg(t,e){let r=new TextDecoder().decode(new Uint8Array(t,e.offset,e.length)),n=Pg(r),i=n.find(o=>o.classname==="worldspawn");return{raw:r,entities:n,worldspawn:i,getUniqueClassnames(){let o=new Set;for(let a of n)a.classname&&o.add(a.classname);return Array.from(o).sort()}}}function Pg(t){let e=[],r=/\{([^}]*)\}/gms,n;for(;(n=r.exec(t))!==null;){let i=n[1],o={},a=/"([^\"]*)"\s+"([^\"]*)"/g,s;for(;(s=a.exec(i))!==null;)o[s[1]]=s[2];e.push({classname:o.classname,properties:o})}return e}function Ig(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 o=0;o<n;o+=1){let a=[r.getFloat32(o*20,!0),r.getFloat32(o*20+4,!0),r.getFloat32(o*20+8,!0)],s=r.getFloat32(o*20+12,!0),c=r.getInt32(o*20+16,!0);i.push({normal:a,dist:s,type:c})}return i}function Bg(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 o=0;o<n;o+=1)i.push([r.getFloat32(o*12,!0),r.getFloat32(o*12+4,!0),r.getFloat32(o*12+8,!0)]);return i}function Fg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({planeIndex:c,children:l,mins:d,maxs:f,firstFace:u,numFaces:h})}return o}function kg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({s:c,sOffset:l,t:d,tOffset:f,flags:u,value:h,texture:g,nextTexInfo:p})}return o}function Dg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({planeIndex:c,side:l,firstEdge:d,numEdges:f,texInfo:u,styles:h,lightOffset:m})}return o}function zg(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 o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({contents:c,cluster:l,area:d,mins:f,maxs:u,firstLeafFace:h,numLeafFaces:m,firstLeafBrush:g,numLeafBrushes:p})}return o}function Og(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 o=[];for(let a=0;a<i;a+=1){let s=a*n;o.push({vertices:[r.getUint16(s,!0),r.getUint16(s+2,!0)]})}return o}function Ug(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 o=0;o<r;o+=1)i[o]=n.getInt32(o*4,!0);return i}function Ng(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,o=[];for(let a=0;a<i;a+=1){let s=a*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);o.push({mins:c,maxs:l,origin:d,headNode:f,firstFace:u,numFaces:h})}return o}function Hg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n;o.push({firstSide:r.getInt32(s,!0),numSides:r.getInt32(s+4,!0),contents:r.getInt32(s+8,!0)})}return o}function Vg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n;o.push({planeIndex:r.getUint16(s,!0),texInfo:r.getInt16(s+2,!0)})}return o}function Gg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);o.push({numAreaPortals:c,firstAreaPortal:l})}return o}function Wg(t,e){return Xg(t,e)}function Xg(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 o=[];for(let a=0;a<i;a+=1){let s=a*n,c=r.getInt32(s,!0),l=r.getInt32(s+4,!0);o.push({portalNumber:c,otherArea:l})}return o}function $g(t,e,r,n){let i=[],o=[],a=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>a)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),o.push(u)}return{leafFaces:i,leafBrushes:o}}function Kg(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 o=4,a=[];for(let s=0;s<n;s+=1){let c=r.getInt32(o,!0),l=r.getInt32(o+4,!0);o+=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");a.push({pvs:Gf(t,d,n,e),phs:Gf(t,f,n,e)})}return{numClusters:n,clusters:a}}function Gf(t,e,r,n){let i=Math.ceil(r/8),o=new Uint8Array(i),a=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=a[s++];if(d!==0){o[c++]=d;continue}if(s>=l)throw new se("Visibility run exceeds lump bounds");let f=a[s++];for(let u=0;u<f&&c<i;u+=1)o[c++]=0}return o}function Yg(t,e){return t.map(r=>{if(!(r.lightOffset<0))return{offset:r.lightOffset,length:Math.max(0,e.length-r.lightOffset)}})}function qs(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 qg=844121161,Zg=8,$f=68,Ze=class extends Error{},Ni=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=dd(n.buffer);return this.cache.set(e,i),i}get(e){return this.cache.get(e)}};function Kf(t,e,r){let n=[];for(let i=0;i<r;i+=1){let o=t.getUint8(e+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function Qo(t,e,r,n){if(r!==0&&(e<$f||e+r>t.byteLength))throw new Ze(`${n} section is out of bounds`)}function jg(t){if(t.byteLength<$f)throw new Ze("MD2 buffer too small to contain header");let e=new DataView(t),r=e.getInt32(0,!0),n=e.getInt32(4,!0);if(r!==qg)throw new Ze(`Invalid MD2 ident: ${r}`);if(n!==Zg)throw new Ze(`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},o=40+i.numVertices*4;if(i.frameSize!==o)throw new Ze(`Unexpected frame size ${i.frameSize}, expected ${o}`);if(i.offsetEnd>t.byteLength)throw new Ze("MD2 offset_end exceeds buffer length");return i}function Qg(t,e){let r=e.numSkins*64;Qo(t,e.offsetSkins,r,"skins");let n=new DataView(t,e.offsetSkins,r),i=[];for(let o=0;o<e.numSkins;o+=1)i.push({name:Kf(n,o*64,64)});return i}function Jg(t,e){let r=e.numTexCoords*4;Qo(t,e.offsetTexCoords,r,"texcoords");let n=new DataView(t,e.offsetTexCoords,r),i=[];for(let o=0;o<e.numTexCoords;o+=1){let a=o*4;i.push({s:n.getInt16(a,!0),t:n.getInt16(a+2,!0)})}return i}function e1(t,e){let r=e.numTriangles*12;Qo(t,e.offsetTriangles,r,"triangles");let n=new DataView(t,e.offsetTriangles,r),i=[];for(let o=0;o<e.numTriangles;o+=1){let a=o*12,s=[n.getUint16(a,!0),n.getUint16(a+2,!0),n.getUint16(a+4,!0)],c=[n.getUint16(a+6,!0),n.getUint16(a+8,!0),n.getUint16(a+10,!0)];if(s.some(l=>l>=e.numVertices)||c.some(l=>l>=e.numTexCoords))throw new Ze("Triangle references out of range vertex or texcoord");i.push({vertexIndices:s,texCoordIndices:c})}return i}function t1(t,e){let r=e.numFrames*e.frameSize;Qo(t,e.offsetFrames,r,"frames");let n=[];for(let i=0;i<e.numFrames;i+=1){let o=e.offsetFrames+i*e.frameSize,a=new DataView(t,o,e.frameSize),s={x:a.getFloat32(0,!0),y:a.getFloat32(4,!0),z:a.getFloat32(8,!0)},c={x:a.getFloat32(12,!0),y:a.getFloat32(16,!0),z:a.getFloat32(20,!0)},l=Kf(a,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=a.getUint8(v)*s.x+c.x,b=a.getUint8(v+1)*s.y+c.y,_=a.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=a.getUint8(v+3),E=sr[S];if(!E)throw new Ze(`Invalid normal index ${S} in frame ${l}`);let T={x:E[0],y:E[1],z:E[2]};d.push({position:w,normalIndex:S,normal:T})}n.push({name:l,vertices:d,minBounds:{x:f,y:u,z:h},maxBounds:{x:m,y:g,z:p}})}return n}function r1(t,e){let r=e.numGlCommands*4;if(Qo(t,e.offsetGlCommands,r,"gl commands"),r===0)return[];let n=new DataView(t,e.offsetGlCommands,r),i=[],o=0;for(;;){if(o+4>r)throw new Ze("GL command list ended unexpectedly");let a=n.getInt32(o,!0);if(o+=4,a===0)break;let s=Math.abs(a),c=[],l=s*12;if(o+l>r)throw new Ze("GL command vertex block exceeds buffer");for(let d=0;d<s;d+=1){let f=n.getFloat32(o,!0),u=n.getFloat32(o+4,!0),h=n.getInt32(o+8,!0);if(o+=12,h<0||h>=e.numVertices)throw new Ze("GL command references invalid vertex index");c.push({s:f,t:u,vertexIndex:h})}i.push({mode:a>0?"strip":"fan",vertices:c})}if(o!==r)throw new Ze("GL command list did not consume expected data");return i}function dd(t){let e=jg(t),r=Qg(t,e),n=Jg(t,e),i=e1(t,e),o=t1(t,e),a=r1(t,e);return{header:e,skins:r,texCoords:n,triangles:i,frames:o,glCommands:a}}function Yf(t){let e=[],r=0;for(;r<t.length;){let n=t[r].name,i=n.replace(/\d+$/,"")||n,o=r;for(;o+1<t.length&&(t[o+1].name.replace(/\d+$/,"")||t[o+1].name)===i;)o+=1;e.push({name:i,firstFrame:r,lastFrame:o}),r=o+1}return e}var qf=860898377,n1=15,Yt=class extends Error{constructor(e){super(e),this.name="Md3ParseError"}};function Jo(t,e,r){let n=new Uint8Array(t.buffer,t.byteOffset+e,r);return new TextDecoder("utf-8").decode(n).replace(/\0.*$/,"").trim()}function i1(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 Zs(t,e,r,n){if(e<0||e+r>n)throw new Yt(`${t} exceeds buffer bounds`)}function o1(t){let e=t.getInt32(0,!0);if(e!==qf)throw new Yt(`Invalid MD3 ident: ${e}`);let r=t.getInt32(4,!0);if(r!==n1)throw new Yt(`Unsupported MD3 version: ${r}`);let n=Jo(t,8,64),i=t.getInt32(72,!0),o=t.getInt32(76,!0),a=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(o<=0||s<0||a<0)throw new Yt("Invalid MD3 counts");return{ident:e,version:r,name:n,flags:i,numFrames:o,numTags:a,numSurfaces:s,numSkins:c,ofsFrames:l,ofsTags:d,ofsSurfaces:f,ofsEnd:u,magic:e}}function a1(t,e){let r=[];Zs("Frames",e.ofsFrames,e.numFrames*56,t.byteLength);for(let i=0;i<e.numFrames;i+=1){let o=e.ofsFrames+i*56;r.push({minBounds:{x:t.getFloat32(o,!0),y:t.getFloat32(o+4,!0),z:t.getFloat32(o+8,!0)},maxBounds:{x:t.getFloat32(o+12,!0),y:t.getFloat32(o+16,!0),z:t.getFloat32(o+20,!0)},localOrigin:{x:t.getFloat32(o+24,!0),y:t.getFloat32(o+28,!0),z:t.getFloat32(o+32,!0)},radius:t.getFloat32(o+36,!0),name:Jo(t,o+40,16)})}return r}function s1(t,e){let r=[],i=e.numFrames*e.numTags*112;Zs("Tags",e.ofsTags,i,t.byteLength);for(let o=0;o<e.numFrames;o+=1){let a=[];for(let s=0;s<e.numTags;s+=1){let c=e.ofsTags+(o*e.numTags+s)*112,l=c+64,d=l+12;a.push({name:Jo(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(a)}return r}function l1(t,e){let r=t.getInt32(e,!0);if(r!==qf)throw new Yt(`Invalid surface ident at ${e}: ${r}`);let n=Jo(t,e+4,64),i=t.getInt32(e+68,!0),o=t.getInt32(e+72,!0),a=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(o<=0||s<=0||c<=0)throw new Yt(`Invalid surface counts for ${n}`);let m=h;Zs(`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<a;S+=1){let E=v+S*68;y.push({name:Jo(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<o;S+=1){let E=[];for(let T=0;T<s;T+=1){let A=w+(S*s+T)*8,C=t.getInt16(A,!0)/64,B=t.getInt16(A+2,!0)/64,F=t.getInt16(A+4,!0)/64,k=t.getUint16(A+6,!0);E.push({position:{x:C,y:B,z:F},latLng:k,normal:i1(k)})}_.push(E)}return{surface:{name:n,flags:i,numFrames:o,shaders:y,triangles:g,texCoords:x,vertices:_},nextOffset:e+h}}function ud(t){if(t.byteLength<108)throw new Yt("MD3 buffer too small for header");let e=new DataView(t),r=o1(e);Zs("MD3 end",r.ofsEnd,0,t.byteLength);let n=a1(e,r),i=s1(e,r),o=[],a=r.ofsSurfaces;for(let s=0;s<r.numSurfaces;s+=1){let{surface:c,nextOffset:l}=l1(e,a);o.push(c),a=l}if(a!==r.ofsEnd)throw new Yt("Surface parsing did not reach ofsEnd");return{header:r,frames:n,tags:i,surfaces:o}}var 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=ud(r.slice().buffer);return this.cache.set(e,n),n}get(e){return this.cache.get(e)}};var c1=844317769,d1=2,Zf=64,jf=12,bn=class extends Error{};function u1(t,e,r){let n=[];for(let i=0;i<r;i+=1){let o=t.getUint8(e+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function fd(t){if(t.byteLength<jf)throw new bn("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!==c1)throw new bn(`Invalid Sprite ident: ${r}`);if(n!==d1)throw new bn(`Unsupported Sprite version: ${n}`);let o=[],a=16+Zf,s=jf;for(let c=0;c<i;c+=1){if(s+a>t.byteLength)throw new bn("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=u1(e,s+16,Zf);o.push({width:l,height:d,originX:f,originY:u,name:h}),s+=a}return{ident:r,version:n,numFrames:i,frames:o}}var Vi=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),fd(n.buffer)}};function Qf(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 Jf(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 o=n?i%e:Math.min(i,e-1),a=Math.floor(o),s=t.sequence.start+a,c=a+1>=e?n?t.sequence.start:t.sequence.end:s+1,l=!n&&a>=e-1?0:o-a;return{frame0:s,frame1:c,lerp:l}}function eh(t){return{sequence:t,time:0}}function th(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 ea=class extends Error{constructor(e){super(e),this.name="WalParseError"}};function js(t){if(t.byteLength<100)throw new ea("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),o=e.getInt32(36,!0),a=[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||o<=0)throw new ea("Invalid WAL dimensions");let u=[],h=i,m=o;for(let g=0;g<a.length;g+=1){let p=a[g],y=Math.max(1,h*m|0);if(p<=0||p+y>t.byteLength)throw new ea(`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:o,mipmaps:u,animName:c,flags:l,contents:d,value:f}}var ti=class extends Error{constructor(e){super(e),this.name="PcxParseError"}};function ta(t){if(t.byteLength<128)throw new ti("PCX buffer too small for header");let e=new DataView(t),r=e.getUint8(0),n=e.getUint8(2),i=e.getUint8(3),o=e.getUint16(4,!0),a=e.getUint16(6,!0),s=e.getUint16(8,!0),c=e.getUint16(10,!0);if(r!==10||n!==1)throw new ti("Unsupported PCX encoding");if(i!==8)throw new ti("Only 8bpp PCX files are supported");let l=s-o+1,d=c-a+1,f=e.getUint16(66,!0),u=t.byteLength-769;if(u<128||new DataView(t,u,1).getUint8(0)!==12)throw new ti("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 ti("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 Qs(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,o=r*4;e[o]=t.palette[i],e[o+1]=t.palette[i+1],e[o+2]=t.palette[i+2],e[o+3]=n===255?0:255}return e}var Gr=class extends Error{constructor(e){super(e),this.name="TgaParseError"}};function hd(t){let e=new DataView(t);if(t.byteLength<18)throw new Gr("Buffer too small for TGA header");let r=e.getUint8(0),n=e.getUint8(1),i=e.getUint8(2),o=e.getUint16(12,!0),a=e.getUint16(14,!0),s=e.getUint8(16),c=e.getUint8(17);if(i!==2&&i!==10&&i!==3&&i!==11)throw new Gr(`Unsupported TGA image type: ${i} (only RGB/Grayscale supported)`);if(s!==24&&s!==32&&s!==8)throw new Gr(`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=o*a,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 Gr("Unexpected end of TGA RLE data");let b=y[u++],_=(b&127)+1,w=(b&128)!==0;if(x+_>h)throw new Gr("TGA RLE packet exceeds image bounds");if(w){let S=d?y[u]:y[u+2],E=d?y[u]:y[u+1],T=y[u],A=d?255:s===32?y[u+3]:255;u+=f;for(let C=0;C<_;C++){let B=(x+C)*4;m[B]=S,m[B+1]=E,m[B+2]=T,m[B+3]=A}}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 Gr("Unexpected end of TGA data");v(x*4)}if(!g){let x=o*4,b=new Uint8Array(x);for(let _=0;_<a/2;_++){let w=_*x,S=(a-1-_)*x;b.set(m.subarray(w,w+x)),m.set(m.subarray(S,S+x),w),m.set(b,S)}}return{width:o,height:a,bitsPerPixel:32,pixels:m}}function f1(t){let e=0;for(let r of t.levels)e+=r.rgba.byteLength;return e}var Gi=class{constructor(e={}){this.cache=new yn(e.capacity??128,e.maxMemory??256*1024*1024,f1)}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 md(t,e){let r=[];for(let n of t.mipmaps){let i=new Uint8Array(n.width*n.height*4);for(let o=0;o<n.data.length;o+=1){let a=n.data[o],s=a*3,c=o*4;i[c]=e[s],i[c+1]=e[s+1],i[c+2]=e[s+2],i[c+3]=a===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 Js(t){let e=Qs(t),r={level:0,width:t.width,height:t.height,rgba:e};return{width:t.width,height:t.height,levels:[r],source:"pcx"}}function rh(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 el(t,e){return md(js(t),e)}var ri=class extends Error{constructor(e){super(e),this.name="WavParseError"}};function pd(t,e,r){return new TextDecoder("ascii").decode(new Uint8Array(t.buffer,t.byteOffset+e,r))}function tl(t){if(t.byteLength<44)throw new ri("WAV buffer too small");let e=new DataView(t);if(pd(e,0,4)!=="RIFF"||pd(e,8,4)!=="WAVE")throw new ri("Invalid WAV header");let r=12,n=-1,i=-1,o=0,a=0;for(;r+8<=t.byteLength;){let m=pd(e,r,4),g=e.getUint32(r+4,!0),p=r+8;m==="fmt "?(n=p,o=g):m==="data"&&(i=p,a=g),r=p+g}if(n===-1||i===-1)throw new ri("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 ri("Only PCM WAV is supported");let f=d/8,u=a/(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 ri(`Unsupported bitsPerSample: ${d}`)}return{sampleRate:l,channels:c,bitsPerSample:d,samples:h}}var h1=(t,e=4294967295,r=79764919)=>{let n=new Int32Array(256),i,o,a,s=e;for(i=0;i<256;i++){for(a=i<<24,o=8;o>0;--o)a=2147483648&a?a<<1^r:a<<1;n[i]=a}for(i=0;i<t.length;i++)s=s<<8^n[255&(s>>24^t[i])];return s};var gd=(t,e=h1)=>{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 o=new Uint8Array(t.length),a,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(a=t.charCodeAt(p),a!==61||l){if(a===92&&p<t.length-5&&u){let y=t.charCodeAt(p+1);y!==117&&y!==85||(a=parseInt(t.substring(p+2,p+6),16),p+=5)}if(a>255){let y=i.get(a);y&&(a=y+127)}l&&(l=!1,a-=64),o[d++]=a<f&&a>0?a+m:a-f}else l=!0;let g=o.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
|
-
`,"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(gd(n)):(n=r.wasm,i=ge.inflateDynEncodeString(n).then(o=>WebAssembly.compile(o))),ge.modules.set(r,i)),i}},concatFloat32:{value(r,n){let i=new e(n),o=0,a=0;for(;o<r.length;)i.set(r[o],a),a+=r[o++].length;return i}},getDecodedAudio:{value:(r,n,i,o,a)=>({errors:r,channelData:n,samplesDecoded:i,sampleRate:o,bitDepth:a})},getDecodedAudioMultiChannel:{value(r,n,i,o,a,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,o))}return ge.getDecodedAudio(r,c,o,a,s)}},inflateDynEncodeString:{value(r){return r=gd(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(o=>WebAssembly.instantiate(o,{})).then(({exports:o})=>{let a=new Map(Object.entries(o)),s=a.get("puff"),c=a.get("memory").buffer,l=new t(c),d=new DataView(c),f=a.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 o=[],a=0;for(;a<n;)o.push(r.slice(a*i,a++*i+i));return o},this.allocateTypedArray=(r,n,i=!0)=>{let o=this._wasm.malloc(n.BYTES_PER_ELEMENT*r);return i&&this._pointers.add(o),{ptr:o,len:r,buf:new n(this._wasm.HEAP,o,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 o=i[r];o!==0;o=i[++r])n.push(o);return String.fromCharCode.apply(null,n)},this.addError=(r,n,i,o,a,s)=>{r.push({message:n,frameLength:i,frameNumber:o,inputBytes:a,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 oh=Bp(ih(),1);var m1=()=>globalThis.Worker||oh.default,Xi=class extends m1(){constructor(e,r,n,i){ge.modules||new ge;let o=ge.modules.get(n);if(!o){let a="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{}o=s?`data:${a};base64,${Buffer.from(c).toString("base64")}`:URL.createObjectURL(new Blob([c],{type:a})),ge.modules.set(n,o)}super(o,{name:r}),this._id=Number.MIN_SAFE_INTEGER,this._enqueuedOperations=new Map,this.onmessage=({data:a})=>{let{id:s,...c}=a;this._enqueuedOperations.get(s)(c),this._enqueuedOperations.delete(s)},new i(ge).getModule().then(a=>{this.postToDecoder("init",{module:a,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,ah=", ",G=(()=>{let t="front",e="side",r="rear",n="left",i="center",o="right";return["",t+" ",e+" ",r+" "].map(a=>[[n,o],[n,o,i],[n,i,o],[i,n,o],[i]].flatMap(s=>s.map(c=>a+c).join(ah)))})(),Ar="LFE",xn="monophonic (mono)",vn="stereo",na="surround",Se=(t,...e)=>`${[xn,vn,`linear ${na}`,"quadraphonic",`5.0 ${na}`,`5.1 ${na}`,`6.1 ${na}`,`7.1 ${na}`][t-1]} (${e.join(ah)})`,ia=[xn,Se(2,G[0][0]),Se(3,G[0][2]),Se(4,G[1][0],G[3][0]),Se(5,G[1][2],G[3][0]),Se(6,G[1][2],G[3][0],Ar),Se(7,G[1][2],G[2][0],G[3][4],Ar),Se(8,G[1][2],G[2][0],G[3][0],Ar)],sh=192e3,lh=176400,rl=96e3,nl=88200,ch=64e3,_n=48e3,$i=44100,Ki=32e3,Yi=24e3,qi=22050,Zi=16e3,il=12e3,ol=11025,ji=8e3,dh=7350,cr="absoluteGranulePosition",K="bandwidth",rt="bitDepth",nt="bitrate",oa=nt+"Maximum",aa=nt+"Minimum",sa=nt+"Nominal",Er="buffer",la=Er+"Fullness",me="codec",it=me+"Frames",ca="coupledStreamCount",Qi="crc",da=Qi+"16",ua=Qi+"32",he="data",V="description",Lr="duration",Ji="emphasis",fa="hasOpusPadding",Ft="header",Sn="isContinuedPacket",ha="isCopyrighted",wn="isFirstPage",ma="isHome",kt="isLastPage",Wr="isOriginal",Xr="isPrivate",pa="isVbr",Tt="layer",P="length",$="mode",$r=$+"Extension",al="mpeg",Kr=al+"Version",ga="numberAACFrames",ya="outputGain",ni="preSkip",ba="profile",sl=ye(),Yr="protection",yd="rawData",qt="segments",Z="subarray",Mn="version",ii="vorbis",xa=ii+"Comments",eo=ii+"Setup",ll="block",va=ll+"ingStrategy",cl=ye(),qr=ll+"Size",An=ll+"size0",En=ll+"size1",_a=ye(),dl="channel",Zr=dl+"MappingFamily",Sa=dl+"MappingTable",ot=dl+"Mode",wa=ye(),H=dl+"s",uh="copyright",Ma=uh+"Id",Aa=uh+"IdStart",jr="frame",Qr=jr+"Count",Rt=jr+"Length",ul="Number",Jr=jr+ul,Tr=jr+"Padding",W=jr+"Size",fh="Rate",Ea="inputSample"+fh,bd="page",oi=bd+"Checksum",to=ye(),Ln=bd+"SegmentTable",Re=bd+"Sequence"+ul,xd="sample",La=xd+ul,ee=xd+fh,Rr=ye(),te=xd+"s",fl="stream",Ta=fl+"Count",Ra=fl+"Info",Cr=fl+"Serial"+ul,vd=fl+"StructureVersion",_d="total",ai=_d+"BytesOut",si=_d+"Duration",li=_d+"Samples",oe=ye(),Zt=ye(),Ca=ye(),Tn=ye(),dr=ye(),hl=ye(),Sd=ye(),Rn=ye(),ue=ye(),jt=ye(),Qt=ye(),Pr=ye(),Cn=ye(),ml=ye(),ur=ye(),fr=ye(),Jt=ye(),pl=ye(),at=Uint8Array,Pn=DataView,fe="reserved",st="bad",ro="free",Pa="none",gl="16bit CRC";var wd=(t,e,r)=>{for(let n=0;n<t[P];n++){let i=e(n);for(let o=8;o>0;o--)i=r(i);t[n]=i}return t},g1=wd(new at(256),t=>t,t=>t&128?7^t<<1:t<<1),we=[wd(new Uint16Array(256),t=>t<<8,t=>t<<1^(t&32768?32773:0))],Me=[wd(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 mh=t=>{let e=0,r=t[P];for(let n=0;n!==r;n++)e=g1[e^t[n]];return e},ph=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},gh=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},Ba=(...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},Dt=t=>String.fromCharCode(...t),hh=[0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15],Ia=t=>hh[t&15]<<4|hh[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,(Ia(this._data[r-1])<<8)+Ia(this._data[r])>>7-n&255}},yh=(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 Fa=class{constructor(e,r){this._onCodecHeader=e,this._onCodecUpdate=r,this[ur]()}[fr](){this._isEnabled=!0}[ur](){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}[jt](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 Fe=new WeakMap,je=new WeakMap;var lt=class{constructor(e,r){this._codecParser=e,this._headerCache=r}*[Sd](){let e;do{if(e=yield*this.Frame[Qt](this._codecParser,this._headerCache,0),e)return e;this._codecParser[Zt](1)}while(!0)}*[Rn](e){let r=yield*this[Sd](),n=je.get(r)[P];if(e||this._codecParser._flushing||(yield*this.Header[ue](this._codecParser,this._headerCache,n)))return this._headerCache[fr](),this._codecParser[Zt](n),this._codecParser[Tn](r),r;this._codecParser[dr](`Missing ${jr} at ${n} bytes from current position.`,`Dropping current ${jr} and trying again.`),this._headerCache[ur](),this._codecParser[Zt](1)}};var ci=class{constructor(e,r){je.set(this,{[Ft]:e}),this[he]=r}};var zt=class extends ci{static*[Qt](e,r,n,i,o){let a=yield*e[ue](n,i,o);if(a){let s=Fe.get(a)[Rt],c=Fe.get(a)[te],l=(yield*n[oe](s,o))[Z](0,s);return new r(a,l,c)}else return null}constructor(e,r,n){super(e,r),this[Ft]=e,this[te]=n,this[Lr]=n/e[ee]*1e3,this[Jr]=null,this[ai]=null,this[li]=null,this[si]=null,je.get(this)[P]=r[P]}};var Md="unsynchronizationFlag",Ad="extendedHeaderFlag",Ed="experimentalFlag",Ld="footerPresent",ka=class t{static*getID3v2Header(e,r,n){let o={},a=yield*e[oe](3,n);if(a[0]!==73||a[1]!==68||a[2]!==51||(a=yield*e[oe](10,n),o[Mn]=`id3v2.${a[3]}.${a[4]}`,a[5]&15)||(o[Md]=!!(a[5]&128),o[Ad]=!!(a[5]&64),o[Ed]=!!(a[5]&32),o[Ld]=!!(a[5]&16),a[6]&128||a[7]&128||a[8]&128||a[9]&128))return null;let s=a[6]<<21|a[7]<<14|a[8]<<7|a[9];return o[P]=10+s,new t(o)}constructor(e){this[Mn]=e[Mn],this[Md]=e[Md],this[Ad]=e[Ad],this[Ed]=e[Ed],this[Ld]=e[Ld],this[P]=e[P]}};var Ot=class{constructor(e){Fe.set(this,e),this[rt]=e[rt],this[nt]=null,this[H]=e[H],this[ot]=e[ot],this[ee]=e[ee]}};var Sh={0:[ro,ro,ro,ro,ro],16:[32,32,32,32,8],240:[st,st,st,st,st]},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++)Sh[t<<4]=[t*32,bl(t,4,0),bl(t,4,-1),bl(t,8,4),bl(t,8,0)];var y1=0,b1=1,x1=2,v1=3,bh=4,xl="bands ",vl=" to 31",xh={0:xl+4+vl,16:xl+8+vl,32:xl+12+vl,48:xl+16+vl},di="bitrateIndex",Da="v2",Al="v1",_l="Intensity stereo ",Sl=", MS stereo ",wl="on",Ml="off",_1={0:_l+Ml+Sl+Ml,16:_l+wl+Sl+Ml,32:_l+Ml+Sl+wl,48:_l+wl+Sl+wl},Td={0:{[V]:fe},2:{[V]:"Layer III",[Tr]:1,[$r]:_1,[Al]:{[di]:x1,[te]:1152},[Da]:{[di]:bh,[te]:576}},4:{[V]:"Layer II",[Tr]:1,[$r]:xh,[te]:1152,[Al]:{[di]:b1},[Da]:{[di]:bh}},6:{[V]:"Layer I",[Tr]:4,[$r]:xh,[te]:384,[Al]:{[di]:y1},[Da]:{[di]:v1}}},Rd="MPEG Version ",vh="ISO/IEC ",S1={0:{[V]:`${Rd}2.5 (later extension of MPEG 2)`,[Tt]:Da,[ee]:{0:ol,4:il,8:ji,12:fe}},8:{[V]:fe},16:{[V]:`${Rd}2 (${vh}13818-3)`,[Tt]:Da,[ee]:{0:qi,4:Yi,8:Zi,12:fe}},24:{[V]:`${Rd}1 (${vh}11172-3)`,[Tt]:Al,[ee]:{0:$i,4:_n,8:Ki,12:fe}},length:P},w1={0:gl,1:Pa},M1={0:Pa,1:"50/15 ms",2:fe,3:"CCIT J.17"},_h={0:{[H]:2,[V]:vn},64:{[H]:2,[V]:"joint "+vn},128:{[H]:2,[V]:"dual channel"},192:{[H]:1,[V]:xn}},ui=class t extends Ot{static*[ue](e,r,n){let i={},o=yield*ka.getID3v2Header(e,r,n);o&&(yield*e[oe](o[P],n),e[Zt](o[P]));let a=yield*e[oe](4,n),s=Dt(a[Z](0,4)),c=r[ue](s);if(c)return new t(c);if(a[0]!==255||a[1]<224)return null;let l=S1[a[1]&24];if(l[V]===fe)return null;let d=a[1]&6;if(Td[d][V]===fe)return null;let f={...Td[d],...Td[d][l[Tt]]};if(i[Kr]=l[V],i[Tt]=f[V],i[te]=f[te],i[Yr]=w1[a[1]&1],i[P]=4,i[nt]=Sh[a[2]&240][f[di]],i[nt]===st||(i[ee]=l[ee][a[2]&12],i[ee]===fe)||(i[Tr]=a[2]&2&&f[Tr],i[Xr]=!!(a[2]&1),i[Rt]=Math.floor(125*i[nt]*i[te]/i[ee]+i[Tr]),!i[Rt]))return null;let u=a[3]&192;if(i[ot]=_h[u][V],i[H]=_h[u][H],i[$r]=f[$r][a[3]&48],i[ha]=!!(a[3]&8),i[Wr]=!!(a[3]&4),i[Ji]=M1[a[3]&3],i[Ji]===fe)return null;i[rt]=16;{let{length:h,frameLength:m,samples:g,...p}=i;r[jt](s,i,p)}return new t(i)}constructor(e){super(e),this[nt]=e[nt],this[Ji]=e[Ji],this[Tr]=e[Tr],this[ha]=e[ha],this[Wr]=e[Wr],this[Xr]=e[Xr],this[Tt]=e[Tt],this[$r]=e[$r],this[Kr]=e[Kr],this[Yr]=e[Yr]}};var za=class t extends zt{static*[Qt](e,r,n){return yield*super[Qt](ui,t,e,r,n)}constructor(e,r,n){super(e,r,n)}};var Oa=class extends lt{constructor(e,r,n){super(e,r),this.Frame=za,this.Header=ui,n(this[me])}get[me](){return al}*[Pr](){return yield*this[Rn]()}};var A1={0:"MPEG-4",8:"MPEG-2"},E1={0:"valid",2:st,4:st,6:st},L1={0:gl,1:Pa},T1={0:"AAC Main",64:"AAC LC (Low Complexity)",128:"AAC SSR (Scalable Sample Rate)",192:"AAC LTP (Long Term Prediction)"},R1={0:rl,4:nl,8:ch,12:_n,16:$i,20:Ki,24:Yi,28:qi,32:Zi,36:il,40:ol,44:ji,48:dh,52:fe,56:fe,60:"frequency is written explicitly"},wh={0:{[H]:0,[V]:"Defined in AOT Specific Config"},64:{[H]:1,[V]:xn},128:{[H]:2,[V]:Se(2,G[0][0])},192:{[H]:3,[V]:Se(3,G[1][3])},256:{[H]:4,[V]:Se(4,G[1][3],G[3][4])},320:{[H]:5,[V]:Se(5,G[1][3],G[3][0])},384:{[H]:6,[V]:Se(6,G[1][3],G[3][0],Ar)},448:{[H]:8,[V]:Se(8,G[1][3],G[2][0],G[3][0],Ar)}},fi=class t extends Ot{static*[ue](e,r,n){let i={},o=yield*e[oe](7,n),a=Dt([o[0],o[1],o[2],o[3]&252|o[6]&3]),s=r[ue](a);if(s)Object.assign(i,s);else{if(o[0]!==255||o[1]<240||(i[Kr]=A1[o[1]&8],i[Tt]=E1[o[1]&6],i[Tt]===st))return null;let l=o[1]&1;i[Yr]=L1[l],i[P]=l?7:9,i[sl]=o[2]&192,i[Rr]=o[2]&60;let d=o[2]&2;if(i[ba]=T1[i[sl]],i[ee]=R1[i[Rr]],i[ee]===fe)return null;i[Xr]=!!d,i[wa]=(o[2]<<8|o[3])&448,i[ot]=wh[i[wa]][V],i[H]=wh[i[wa]][H],i[Wr]=!!(o[3]&32),i[ma]=!!(o[3]&8),i[Ma]=!!(o[3]&8),i[Aa]=!!(o[3]&4),i[rt]=16,i[te]=1024,i[ga]=o[6]&3;{let{length:f,channelModeBits:u,profileBits:h,sampleRateBits:m,frameLength:g,samples:p,numberAACFrames:y,...v}=i;r[jt](a,i,v)}}if(i[Rt]=(o[3]<<11|o[4]<<3|o[5]>>5)&8191,!i[Rt])return null;let c=(o[5]<<6|o[6]>>2)&2047;return i[la]=c===2047?"VBR":c,new t(i)}constructor(e){super(e),this[Ma]=e[Ma],this[Aa]=e[Aa],this[la]=e[la],this[ma]=e[ma],this[Wr]=e[Wr],this[Xr]=e[Xr],this[Tt]=e[Tt],this[P]=e[P],this[Kr]=e[Kr],this[ga]=e[ga],this[ba]=e[ba],this[Yr]=e[Yr]}get audioSpecificConfig(){let e=Fe.get(this),r=e[sl]+64<<5|e[Rr]<<5|e[wa]>>3,n=new at(2);return new Pn(n[Er]).setUint16(0,r,!1),n}};var Ua=class t extends zt{static*[Qt](e,r,n){return yield*super[Qt](fi,t,e,r,n)}constructor(e,r,n){super(e,r,n)}};var Na=class extends lt{constructor(e,r,n){super(e,r),this.Frame=Ua,this.Header=fi,n(this[me])}get[me](){return"aac"}*[Pr](){return yield*this[Rn]()}};var In=class t extends zt{static _getFrameFooterCrc16(e){return(e[e[P]-2]<<8)+e[e[P]-1]}static[pl](e){let r=t._getFrameFooterCrc16(e),n=ph(e[Z](0,-2));return r===n}constructor(e,r,n){r[Ra]=n,r[da]=t._getFrameFooterCrc16(e),super(r,e,Fe.get(r)[te])}};var Mh="get from STREAMINFO metadata block",C1={0:"Fixed",1:"Variable"},Ah={0:fe,16:192};for(let t=2;t<16;t++)Ah[t<<4]=t<6?576*2**(t-2):2**t;var P1={0:Mh,1:nl,2:lh,3:sh,4:ji,5:Zi,6:qi,7:Yi,8:Ki,9:$i,10:_n,11:rl,15:st},I1={0:{[H]:1,[V]:xn},16:{[H]:2,[V]:Se(2,G[0][0])},32:{[H]:3,[V]:Se(3,G[0][1])},48:{[H]:4,[V]:Se(4,G[1][0],G[3][0])},64:{[H]:5,[V]:Se(5,G[1][1],G[3][0])},80:{[H]:6,[V]:Se(6,G[1][1],Ar,G[3][0])},96:{[H]:7,[V]:Se(7,G[1][1],Ar,G[3][4],G[2][0])},112:{[H]:8,[V]:Se(8,G[1][1],Ar,G[3][0],G[2][0])},128:{[H]:2,[V]:`${vn} (left, diff)`},144:{[H]:2,[V]:`${vn} (diff, right)`},160:{[H]:2,[V]:`${vn} (avg, diff)`},176:fe,192:fe,208:fe,224:fe,240:fe},B1={0:Mh,2:8,4:12,6:fe,8:16,10:20,12:24,14:fe},Bn=class t extends Ot{static _decodeUTF8Int(e){if(e[0]>254)return null;if(e[0]<128)return{value:e[0],length:1};let r=1;for(let a=64;a&e[0];a>>=1)r++;let n=r-1,i=0,o=0;for(;n>0;o+=6,n--){if((e[n]&192)!==128)return null;i|=(e[n]&63)<<o}return i|=(e[n]&127>>r)<<o,{value:i,length:r}}static[Jt](e,r){let n={[oe]:function*(){return e}};return t[ue](n,r,0).next().value}static*[ue](e,r,n){let i=yield*e[oe](6,n);if(i[0]!==255||!(i[1]===248||i[1]===249))return null;let o={},a=Dt(i[Z](0,4)),s=r[ue](a);if(s)Object.assign(o,s);else{if(o[cl]=i[1]&1,o[va]=C1[o[cl]],o[_a]=i[2]&240,o[Rr]=i[2]&15,o[qr]=Ah[o[_a]],o[qr]===fe||(o[ee]=P1[o[Rr]],o[ee]===st)||i[3]&1)return null;let l=I1[i[3]&240];if(l===fe||(o[H]=l[H],o[ot]=l[V],o[rt]=B1[i[3]&14],o[rt]===fe))return null}o[P]=5,i=yield*e[oe](o[P]+8,n);let c=t._decodeUTF8Int(i[Z](4));if(!c||(o[cl]?o[La]=c.value:o[Jr]=c.value,o[P]+=c[P],o[_a]===96?(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[qr]=i[o[P]-1]+1,o[P]+=1):o[_a]===112&&(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[qr]=(i[o[P]-1]<<8)+i[o[P]]+1,o[P]+=2),o[te]=o[qr],o[Rr]===12?(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ee]=i[o[P]-1]*1e3,o[P]+=1):o[Rr]===13?(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ee]=(i[o[P]-1]<<8)+i[o[P]],o[P]+=2):o[Rr]===14&&(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ee]=((i[o[P]-1]<<8)+i[o[P]])*10,o[P]+=2),i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[Qi]=i[o[P]-1],o[Qi]!==mh(i[Z](0,o[P]-1))))return null;if(!s){let{blockingStrategyBits:l,frameNumber:d,sampleNumber:f,samples:u,sampleRateBits:h,blockSizeBits:m,crc:g,length:p,...y}=o;r[jt](a,o,y)}return new t(o)}constructor(e){super(e),this[da]=null,this[va]=e[va],this[qr]=e[qr],this[Jr]=e[Jr],this[La]=e[La],this[Ra]=null}};var F1=2,k1=512*1024,hi=class extends lt{constructor(e,r,n){super(e,r),this.Frame=In,this.Header=Bn,n(this[me])}get[me](){return"flac"}*_getNextFrameSyncOffset(e){let r=yield*this._codecParser[oe](2,0),n=r[P]-2;for(;e<n;){if(r[e]===255){let o=r[e+1];if(o===248||o===249)break;o!==255&&e++}e++}return e}*[Pr](){do{let e=yield*Bn[ue](this._codecParser,this._headerCache,0);if(e){let r=Fe.get(e)[P]+F1;for(;r<=k1;){if(this._codecParser._flushing||(yield*Bn[ue](this._codecParser,this._headerCache,r))){let n=yield*this._codecParser[oe](r);if(this._codecParser._flushing||(n=n[Z](0,r)),In[pl](n)){let i=new In(n,e);return this._headerCache[fr](),this._codecParser[Zt](r),this._codecParser[Tn](i),i}}r=yield*this._getNextFrameSyncOffset(r+1)}this._codecParser[dr](`Unable to sync FLAC frame after searching ${r} bytes.`),this._codecParser[Zt](r)}else this._codecParser[Zt](yield*this._getNextFrameSyncOffset(1))}while(!0)}[Cn](e){return e[Re]===0?(this._headerCache[fr](),this._streamInfo=e[he][Z](13)):e[Re]===1||(e[it]=je.get(e)[qt].map(r=>{let n=Bn[Jt](r,this._headerCache);if(n)return new In(r,n,this._streamInfo);this._codecParser[dr]("Failed to parse Ogg FLAC frame","Skipping invalid FLAC frame")}).filter(r=>!!r)),e}};var mi=class t{static*[ue](e,r,n){let i={},o=yield*e[oe](28,n);if(o[0]!==79||o[1]!==103||o[2]!==103||o[3]!==83||(i[vd]=o[4],o[5]&248))return null;i[kt]=!!(o[5]&4),i[wn]=!!(o[5]&2),i[Sn]=!!(o[5]&1);let s=new Pn(at.from(o[Z](0,28))[Er]);i[cr]=yh(s,6),i[Cr]=s.getInt32(14,!0),i[Re]=s.getInt32(18,!0),i[oi]=s.getInt32(22,!0);let c=o[26];i[P]=c+27,o=yield*e[oe](i[P],n),i[Rt]=0,i[Ln]=[],i[to]=at.from(o[Z](27,i[P]));for(let l=0,d=0;l<c;l++){let f=i[to][l];i[Rt]+=f,d+=f,(f!==255||l===c-1)&&(i[Ln].push(d),d=0)}return new t(i)}constructor(e){Fe.set(this,e),this[cr]=e[cr],this[Sn]=e[Sn],this[wn]=e[wn],this[kt]=e[kt],this[Ln]=e[Ln],this[Re]=e[Re],this[oi]=e[oi],this[Cr]=e[Cr]}};var Ha=class t extends ci{static*[Qt](e,r,n){let i=yield*mi[ue](e,r,n);if(i){let o=Fe.get(i)[Rt],a=Fe.get(i)[P],s=a+o,c=(yield*e[oe](s,0))[Z](0,s),l=c[Z](a,s);return new t(i,l,c)}else return null}constructor(e,r,n){super(e,r),je.get(this)[P]=n[P],this[it]=[],this[yd]=n,this[cr]=e[cr],this[ua]=e[oi],this[Lr]=0,this[Sn]=e[Sn],this[wn]=e[wn],this[kt]=e[kt],this[Re]=e[Re],this[te]=0,this[Cr]=e[Cr]}};var no=class extends zt{constructor(e,r,n){super(r,e,n)}};var Eh={0:ia.slice(0,2),1:ia},er="SILK-only",Qe="CELT-only",El="Hybrid",Fn="narrowband",Ll="medium-band",kn="wideband",io="super-wideband",oo="fullband",D1={0:{[$]:er,[K]:Fn,[W]:10},8:{[$]:er,[K]:Fn,[W]:20},16:{[$]:er,[K]:Fn,[W]:40},24:{[$]:er,[K]:Fn,[W]:60},32:{[$]:er,[K]:Ll,[W]:10},40:{[$]:er,[K]:Ll,[W]:20},48:{[$]:er,[K]:Ll,[W]:40},56:{[$]:er,[K]:Ll,[W]:60},64:{[$]:er,[K]:kn,[W]:10},72:{[$]:er,[K]:kn,[W]:20},80:{[$]:er,[K]:kn,[W]:40},88:{[$]:er,[K]:kn,[W]:60},96:{[$]:El,[K]:io,[W]:10},104:{[$]:El,[K]:io,[W]:20},112:{[$]:El,[K]:oo,[W]:10},120:{[$]:El,[K]:oo,[W]:20},128:{[$]:Qe,[K]:Fn,[W]:2.5},136:{[$]:Qe,[K]:Fn,[W]:5},144:{[$]:Qe,[K]:Fn,[W]:10},152:{[$]:Qe,[K]:Fn,[W]:20},160:{[$]:Qe,[K]:kn,[W]:2.5},168:{[$]:Qe,[K]:kn,[W]:5},176:{[$]:Qe,[K]:kn,[W]:10},184:{[$]:Qe,[K]:kn,[W]:20},192:{[$]:Qe,[K]:io,[W]:2.5},200:{[$]:Qe,[K]:io,[W]:5},208:{[$]:Qe,[K]:io,[W]:10},216:{[$]:Qe,[K]:io,[W]:20},224:{[$]:Qe,[K]:oo,[W]:2.5},232:{[$]:Qe,[K]:oo,[W]:5},240:{[$]:Qe,[K]:oo,[W]:10},248:{[$]:Qe,[K]:oo,[W]:20}},ao=class t extends Ot{static[Jt](e,r,n){let i={};if(i[H]=e[9],i[Zr]=e[18],i[P]=i[Zr]!==0?21+i[H]:19,e[P]<i[P])throw new Error("Out of data while inside an Ogg Page");let o=r[0]&3,a=o===3?2:1,s=Dt(e[Z](0,i[P]))+Dt(r[Z](0,a)),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[Z](0,i[P]));let l=new Pn(i[he][Er]);if(i[rt]=16,i[ni]=l.getUint16(10,!0),i[Ea]=l.getUint32(12,!0),i[ee]=_n,i[ya]=l.getInt16(16,!0),i[Zr]in Eh&&(i[ot]=Eh[i[Zr]][i[H]-1],!i[ot]))return null;i[Zr]!==0&&(i[Ta]=e[19],i[ca]=e[20],i[Sa]=[...e[Z](21,i[H]+21)]);let d=D1[248&r[0]];switch(i[$]=d[$],i[K]=d[K],i[W]=d[W],o){case 0:i[Qr]=1;break;case 1:case 2:i[Qr]=2;break;case 3:i[pa]=!!(128&r[1]),i[fa]=!!(64&r[1]),i[Qr]=63&r[1];break;default:return null}{let{length:f,data:u,channelMappingFamily:h,...m}=i;n[jt](s,i,m)}return new t(i)}constructor(e){super(e),this[he]=e[he],this[K]=e[K],this[Zr]=e[Zr],this[Sa]=e[Sa],this[ca]=e[ca],this[Qr]=e[Qr],this[W]=e[W],this[fa]=e[fa],this[Ea]=e[Ea],this[pa]=e[pa],this[$]=e[$],this[ya]=e[ya],this[ni]=e[ni],this[Ta]=e[Ta]}};var Va=class extends lt{constructor(e,r,n){super(e,r),this.Frame=no,this.Header=ao,n(this[me]),this._identificationHeader=null,this._preSkipRemaining=null}get[me](){return"opus"}[Cn](e){return e[Re]===0?(this._headerCache[fr](),this._identificationHeader=e[he]):e[Re]===1||(e[it]=je.get(e)[qt].map(r=>{let n=ao[Jt](this._identificationHeader,r,this._headerCache);if(n){this._preSkipRemaining===null&&(this._preSkipRemaining=n[ni]);let i=n[W]*n[Qr]/1e3*n[ee];return this._preSkipRemaining>0&&(this._preSkipRemaining-=i,i=this._preSkipRemaining<0?-this._preSkipRemaining:0),new no(r,n,i)}this._codecParser[hl]("Failed to parse Ogg Opus Header","Not a valid Ogg Opus file")})),e}};var so=class extends zt{constructor(e,r,n){super(r,e,n)}};var Cd={};for(let t=0;t<8;t++)Cd[t+6]=2**(6+t);var Ga=class t extends Ot{static[Jt](e,r,n,i){if(e[P]<30)throw new Error("Out of data while inside an Ogg Page");let o=Dt(e[Z](0,30)),a=r[ue](o);if(a)return new t(a);let s={[P]:30};if(o.substr(0,7)!=="vorbis")return null;s[he]=at.from(e[Z](0,30));let c=new Pn(s[he][Er]);if(s[Mn]=c.getUint32(7,!0),s[Mn]!==0||(s[H]=e[11],s[ot]=ia[s[H]-1]||"application defined",s[ee]=c.getUint32(12,!0),s[oa]=c.getInt32(16,!0),s[sa]=c.getInt32(20,!0),s[aa]=c.getInt32(24,!0),s[En]=Cd[(e[28]&240)>>4],s[An]=Cd[e[28]&15],s[An]>s[En])||e[29]!==1)return null;s[rt]=32,s[eo]=i,s[xa]=n;{let{length:l,data:d,version:f,vorbisSetup:u,vorbisComments:h,...m}=s;r[jt](o,s,m)}return new t(s)}constructor(e){super(e),this[oa]=e[oa],this[aa]=e[aa],this[sa]=e[sa],this[An]=e[An],this[En]=e[En],this[he]=e[he],this[xa]=e[xa],this[eo]=e[eo]}};var Wa=class extends lt{constructor(e,r,n){super(e,r),this.Frame=so,n(this[me]),this._identificationHeader=null,this._setupComplete=!1,this._prevBlockSize=null}get[me](){return ii}[Cn](e){e[it]=[];for(let r of je.get(e)[qt])if(r[0]===1)this._headerCache[fr](),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=Ga[Jt](this._identificationHeader,this._headerCache,this._vorbisComments,this._vorbisSetup);n?e[it].push(new so(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[En]:r[An],o=this._prevBlockSize===null?0:(this._prevBlockSize+i)/4;return this._prevBlockSize=i,o}_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;){Ia(r.read(8));let o=0;for(;r.read(8)===0&&o++<3;);if(o===4)i=r.read(7),n.blockFlags.unshift(i&1),r.position+=6,n.count++;else{((Ia(i)&126)>>1)+1!==n.count&&this._codecParser[dr]("vorbis derived mode count did not match actual mode count");break}}return n.mask=(1<<Math.log2(n.count))-1,n}};var Pd=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[ur](),this._parser=new r(this._codecParser,this._headerCache,this._onCodec),this._codec=e)}_checkCodecSupport({data:e}){let r=Dt(e[Z](0,8));switch(r){case"fishead\0":return!1;case"OpusHead":return this._updateCodec("opus",Va),!0;case(/^\x7fFLAC/.test(r)&&r):return this._updateCodec("flac",hi),!0;case(/^\x01vorbis/.test(r)&&r):return this._updateCodec(ii,Wa),!0;default:return!1}}_checkPageSequenceNumber(e){e[Re]!==this._pageSequenceNumber+1&&this._pageSequenceNumber>1&&e[Re]>1&&this._codecParser[dr]("Unexpected gap in Ogg Page Sequence Number.",`Expected: ${this._pageSequenceNumber+1}, Got: ${e[Re]}`),this._pageSequenceNumber=e[Re]}_parsePage(e){this._isSupported===null&&(this._pageSequenceNumber=e[Re],this._isSupported=this._checkCodecSupport(e)),this._checkPageSequenceNumber(e);let r=je.get(e),n=Fe.get(r[Ft]),i=0;if(r[qt]=n[Ln].map(o=>e[he][Z](i,i+=o)),this._continuedPacket[P]&&(r[qt][0]=Ba(this._continuedPacket,r[qt][0]),this._continuedPacket=new at),n[to][n[to][P]-1]===255&&(this._continuedPacket=Ba(this._continuedPacket,r[qt].pop())),this._previousAbsoluteGranulePosition!==null&&(e[te]=Number(e[cr]-this._previousAbsoluteGranulePosition)),this._previousAbsoluteGranulePosition=e[cr],this._isSupported){let o=this._parser[Cn](e);return this._codecParser[Tn](o),o}else return e}},Xa=class extends lt{constructor(e,r,n){super(e,r),this._onCodec=n,this.Frame=Ha,this.Header=mi,this._streams=new Map,this._currentSerialNumber=null}get[me](){let e=this._streams.get(this._currentSerialNumber);return e?e.codec:""}*[Pr](){let e=yield*this[Rn](!0);this._currentSerialNumber=e[Cr];let r=this._streams.get(this._currentSerialNumber);return r||(r=new Pd(this._codecParser,this._headerCache,this._onCodec),this._streams.set(this._currentSerialNumber,r)),e[kt]&&this._streams.delete(this._currentSerialNumber),r._parsePage(e)}};var Id=()=>{},$a=class{constructor(e,{onCodec:r,onCodecHeader:n,onCodecUpdate:i,enableLogging:o=!1,enableFrameCRC32:a=!0}={}){this._inputMimeType=e,this._onCodec=r||Id,this._onCodecHeader=n||Id,this._onCodecUpdate=i,this._enableLogging=o,this._crc32=a?gh:Id,this[ur]()}get[me](){return this._parser?this._parser[me]:""}[ur](){this._headerCache=new Fa(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[ur]()}*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 Na(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/mpeg/))this._parser=new Oa(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/flac/))this._parser=new hi(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/ogg/))this._parser=new Xa(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[Pr]();e&&(yield e)}}*[oe](e=0,r=0){let n;for(;this._rawData[P]<=e+r;){if(n=yield,this._flushing)return this._rawData[Z](r);n&&(this._totalBytesIn+=n[P],this._rawData=Ba(this._rawData,n))}return this._rawData[Z](r)}[Zt](e){this._currentReadPosition+=e,this._rawData=this._rawData[Z](e)}[Ca](e){this._sampleRate=e[Ft][ee],e[Ft][nt]=e[Lr]>0?Math.round(e[he][P]/e[Lr])*8:0,e[Jr]=this._frameNumber++,e[ai]=this._totalBytesOut,e[li]=this._totalSamples,e[si]=this._totalSamples/this._sampleRate*1e3,e[ua]=this._crc32(e[he]),this._headerCache[ml](e[Ft][nt],e[si]),this._totalBytesOut+=e[he][P],this._totalSamples+=e[te]}[Tn](e){if(e[it]){if(e[kt]){let r=e[te];e[it].forEach(n=>{let i=n[te];r<i&&(n[te]=r>0?r:0,n[Lr]=n[te]/n[Ft][ee]*1e3),r-=i,this[Ca](n)})}else e[te]=0,e[it].forEach(r=>{e[te]+=r[te],this[Ca](r)});e[Lr]=e[te]/this._sampleRate*1e3||0,e[li]=this._totalSamples,e[si]=this._totalSamples/this._sampleRate*1e3||0,e[ai]=this._totalBytesOut}else this[Ca](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(o=>o[P]));r.push(`--stats--${"-".repeat(i-9)}`,...n,"-".repeat(i)),e("codec-parser",r.reduce((o,a)=>o+`
|
|
4
|
-
`+a,""))}}[dr](...e){this._log(console.warn,e)}[
|
|
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(gd(n)):(n=r.wasm,i=ge.inflateDynEncodeString(n).then(o=>WebAssembly.compile(o))),ge.modules.set(r,i)),i}},concatFloat32:{value(r,n){let i=new e(n),o=0,a=0;for(;o<r.length;)i.set(r[o],a),a+=r[o++].length;return i}},getDecodedAudio:{value:(r,n,i,o,a)=>({errors:r,channelData:n,samplesDecoded:i,sampleRate:o,bitDepth:a})},getDecodedAudioMultiChannel:{value(r,n,i,o,a,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,o))}return ge.getDecodedAudio(r,c,o,a,s)}},inflateDynEncodeString:{value(r){return r=gd(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(o=>WebAssembly.instantiate(o,{})).then(({exports:o})=>{let a=new Map(Object.entries(o)),s=a.get("puff"),c=a.get("memory").buffer,l=new t(c),d=new DataView(c),f=a.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 o=[],a=0;for(;a<n;)o.push(r.slice(a*i,a++*i+i));return o},this.allocateTypedArray=(r,n,i=!0)=>{let o=this._wasm.malloc(n.BYTES_PER_ELEMENT*r);return i&&this._pointers.add(o),{ptr:o,len:r,buf:new n(this._wasm.HEAP,o,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 o=i[r];o!==0;o=i[++r])n.push(o);return String.fromCharCode.apply(null,n)},this.addError=(r,n,i,o,a,s)=>{r.push({message:n,frameLength:i,frameNumber:o,inputBytes:a,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 oh=Bp(ih(),1);var m1=()=>globalThis.Worker||oh.default,Wi=class extends m1(){constructor(e,r,n,i){ge.modules||new ge;let o=ge.modules.get(n);if(!o){let a="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{}o=s?`data:${a};base64,${Buffer.from(c).toString("base64")}`:URL.createObjectURL(new Blob([c],{type:a})),ge.modules.set(n,o)}super(o,{name:r}),this._id=Number.MIN_SAFE_INTEGER,this._enqueuedOperations=new Map,this.onmessage=({data:a})=>{let{id:s,...c}=a;this._enqueuedOperations.get(s)(c),this._enqueuedOperations.delete(s)},new i(ge).getModule().then(a=>{this.postToDecoder("init",{module:a,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 rl=(t,e)=>{Object.defineProperty(t,"name",{value:e})};var ye=Symbol,ah=", ",G=(()=>{let t="front",e="side",r="rear",n="left",i="center",o="right";return["",t+" ",e+" ",r+" "].map(a=>[[n,o],[n,o,i],[n,i,o],[i,n,o],[i]].flatMap(s=>s.map(c=>a+c).join(ah)))})(),Ar="LFE",xn="monophonic (mono)",vn="stereo",ra="surround",Se=(t,...e)=>`${[xn,vn,`linear ${ra}`,"quadraphonic",`5.0 ${ra}`,`5.1 ${ra}`,`6.1 ${ra}`,`7.1 ${ra}`][t-1]} (${e.join(ah)})`,na=[xn,Se(2,G[0][0]),Se(3,G[0][2]),Se(4,G[1][0],G[3][0]),Se(5,G[1][2],G[3][0]),Se(6,G[1][2],G[3][0],Ar),Se(7,G[1][2],G[2][0],G[3][4],Ar),Se(8,G[1][2],G[2][0],G[3][0],Ar)],sh=192e3,lh=176400,nl=96e3,il=88200,ch=64e3,_n=48e3,Xi=44100,$i=32e3,Ki=24e3,Yi=22050,qi=16e3,ol=12e3,al=11025,Zi=8e3,dh=7350,cr="absoluteGranulePosition",K="bandwidth",rt="bitDepth",nt="bitrate",ia=nt+"Maximum",oa=nt+"Minimum",aa=nt+"Nominal",Er="buffer",sa=Er+"Fullness",me="codec",it=me+"Frames",la="coupledStreamCount",ji="crc",ca=ji+"16",da=ji+"32",he="data",V="description",Lr="duration",Qi="emphasis",ua="hasOpusPadding",kt="header",Sn="isContinuedPacket",fa="isCopyrighted",wn="isFirstPage",ha="isHome",Dt="isLastPage",Wr="isOriginal",Xr="isPrivate",ma="isVbr",Rt="layer",P="length",$="mode",$r=$+"Extension",sl="mpeg",Kr=sl+"Version",pa="numberAACFrames",ga="outputGain",ni="preSkip",ya="profile",ll=ye(),Yr="protection",yd="rawData",qt="segments",Z="subarray",Mn="version",ii="vorbis",ba=ii+"Comments",Ji=ii+"Setup",cl="block",xa=cl+"ingStrategy",dl=ye(),qr=cl+"Size",An=cl+"size0",En=cl+"size1",va=ye(),ul="channel",Zr=ul+"MappingFamily",_a=ul+"MappingTable",ot=ul+"Mode",Sa=ye(),H=ul+"s",uh="copyright",wa=uh+"Id",Ma=uh+"IdStart",jr="frame",Qr=jr+"Count",Ct=jr+"Length",fl="Number",Jr=jr+fl,Tr=jr+"Padding",W=jr+"Size",fh="Rate",Aa="inputSample"+fh,bd="page",oi=bd+"Checksum",eo=ye(),Ln=bd+"SegmentTable",Re=bd+"Sequence"+fl,xd="sample",Ea=xd+fl,ee=xd+fh,Rr=ye(),te=xd+"s",hl="stream",La=hl+"Count",Ta=hl+"Info",Cr=hl+"Serial"+fl,vd=hl+"StructureVersion",_d="total",ai=_d+"BytesOut",si=_d+"Duration",li=_d+"Samples",oe=ye(),Zt=ye(),Ra=ye(),Tn=ye(),dr=ye(),ml=ye(),Sd=ye(),Rn=ye(),ue=ye(),jt=ye(),Qt=ye(),Pr=ye(),Cn=ye(),pl=ye(),ur=ye(),fr=ye(),Jt=ye(),gl=ye(),at=Uint8Array,Pn=DataView,fe="reserved",st="bad",to="free",Ca="none",yl="16bit CRC";var wd=(t,e,r)=>{for(let n=0;n<t[P];n++){let i=e(n);for(let o=8;o>0;o--)i=r(i);t[n]=i}return t},g1=wd(new at(256),t=>t,t=>t&128?7^t<<1:t<<1),we=[wd(new Uint16Array(256),t=>t<<8,t=>t<<1^(t&32768?32773:0))],Me=[wd(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 mh=t=>{let e=0,r=t[P];for(let n=0;n!==r;n++)e=g1[e^t[n]];return e},ph=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},gh=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},Ia=(...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},zt=t=>String.fromCharCode(...t),hh=[0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15],Pa=t=>hh[t&15]<<4|hh[t>>4],bl=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,(Pa(this._data[r-1])<<8)+Pa(this._data[r])>>7-n&255}},yh=(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 Ba=class{constructor(e,r){this._onCodecHeader=e,this._onCodecUpdate=r,this[ur]()}[fr](){this._isEnabled=!0}[ur](){this._headerCache=new Map,this._codecUpdateData=new WeakMap,this._codecHeaderSent=!1,this._codecShouldUpdate=!1,this._bitrate=null,this._isEnabled=!1}[pl](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}[jt](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 Fe=new WeakMap,je=new WeakMap;var lt=class{constructor(e,r){this._codecParser=e,this._headerCache=r}*[Sd](){let e;do{if(e=yield*this.Frame[Qt](this._codecParser,this._headerCache,0),e)return e;this._codecParser[Zt](1)}while(!0)}*[Rn](e){let r=yield*this[Sd](),n=je.get(r)[P];if(e||this._codecParser._flushing||(yield*this.Header[ue](this._codecParser,this._headerCache,n)))return this._headerCache[fr](),this._codecParser[Zt](n),this._codecParser[Tn](r),r;this._codecParser[dr](`Missing ${jr} at ${n} bytes from current position.`,`Dropping current ${jr} and trying again.`),this._headerCache[ur](),this._codecParser[Zt](1)}};var ci=class{constructor(e,r){je.set(this,{[kt]:e}),this[he]=r}};var Ot=class extends ci{static*[Qt](e,r,n,i,o){let a=yield*e[ue](n,i,o);if(a){let s=Fe.get(a)[Ct],c=Fe.get(a)[te],l=(yield*n[oe](s,o))[Z](0,s);return new r(a,l,c)}else return null}constructor(e,r,n){super(e,r),this[kt]=e,this[te]=n,this[Lr]=n/e[ee]*1e3,this[Jr]=null,this[ai]=null,this[li]=null,this[si]=null,je.get(this)[P]=r[P]}};var Md="unsynchronizationFlag",Ad="extendedHeaderFlag",Ed="experimentalFlag",Ld="footerPresent",Fa=class t{static*getID3v2Header(e,r,n){let o={},a=yield*e[oe](3,n);if(a[0]!==73||a[1]!==68||a[2]!==51||(a=yield*e[oe](10,n),o[Mn]=`id3v2.${a[3]}.${a[4]}`,a[5]&15)||(o[Md]=!!(a[5]&128),o[Ad]=!!(a[5]&64),o[Ed]=!!(a[5]&32),o[Ld]=!!(a[5]&16),a[6]&128||a[7]&128||a[8]&128||a[9]&128))return null;let s=a[6]<<21|a[7]<<14|a[8]<<7|a[9];return o[P]=10+s,new t(o)}constructor(e){this[Mn]=e[Mn],this[Md]=e[Md],this[Ad]=e[Ad],this[Ed]=e[Ed],this[Ld]=e[Ld],this[P]=e[P]}};var Ut=class{constructor(e){Fe.set(this,e),this[rt]=e[rt],this[nt]=null,this[H]=e[H],this[ot]=e[ot],this[ee]=e[ee]}};var Sh={0:[to,to,to,to,to],16:[32,32,32,32,8],240:[st,st,st,st,st]},xl=(t,e,r)=>8*((t+r)%e+e)*(1<<(t+r)/e)-8*e*(e/8|0);for(let t=2;t<15;t++)Sh[t<<4]=[t*32,xl(t,4,0),xl(t,4,-1),xl(t,8,4),xl(t,8,0)];var y1=0,b1=1,x1=2,v1=3,bh=4,vl="bands ",_l=" to 31",xh={0:vl+4+_l,16:vl+8+_l,32:vl+12+_l,48:vl+16+_l},di="bitrateIndex",ka="v2",El="v1",Sl="Intensity stereo ",wl=", MS stereo ",Ml="on",Al="off",_1={0:Sl+Al+wl+Al,16:Sl+Ml+wl+Al,32:Sl+Al+wl+Ml,48:Sl+Ml+wl+Ml},Td={0:{[V]:fe},2:{[V]:"Layer III",[Tr]:1,[$r]:_1,[El]:{[di]:x1,[te]:1152},[ka]:{[di]:bh,[te]:576}},4:{[V]:"Layer II",[Tr]:1,[$r]:xh,[te]:1152,[El]:{[di]:b1},[ka]:{[di]:bh}},6:{[V]:"Layer I",[Tr]:4,[$r]:xh,[te]:384,[El]:{[di]:y1},[ka]:{[di]:v1}}},Rd="MPEG Version ",vh="ISO/IEC ",S1={0:{[V]:`${Rd}2.5 (later extension of MPEG 2)`,[Rt]:ka,[ee]:{0:al,4:ol,8:Zi,12:fe}},8:{[V]:fe},16:{[V]:`${Rd}2 (${vh}13818-3)`,[Rt]:ka,[ee]:{0:Yi,4:Ki,8:qi,12:fe}},24:{[V]:`${Rd}1 (${vh}11172-3)`,[Rt]:El,[ee]:{0:Xi,4:_n,8:$i,12:fe}},length:P},w1={0:yl,1:Ca},M1={0:Ca,1:"50/15 ms",2:fe,3:"CCIT J.17"},_h={0:{[H]:2,[V]:vn},64:{[H]:2,[V]:"joint "+vn},128:{[H]:2,[V]:"dual channel"},192:{[H]:1,[V]:xn}},ui=class t extends Ut{static*[ue](e,r,n){let i={},o=yield*Fa.getID3v2Header(e,r,n);o&&(yield*e[oe](o[P],n),e[Zt](o[P]));let a=yield*e[oe](4,n),s=zt(a[Z](0,4)),c=r[ue](s);if(c)return new t(c);if(a[0]!==255||a[1]<224)return null;let l=S1[a[1]&24];if(l[V]===fe)return null;let d=a[1]&6;if(Td[d][V]===fe)return null;let f={...Td[d],...Td[d][l[Rt]]};if(i[Kr]=l[V],i[Rt]=f[V],i[te]=f[te],i[Yr]=w1[a[1]&1],i[P]=4,i[nt]=Sh[a[2]&240][f[di]],i[nt]===st||(i[ee]=l[ee][a[2]&12],i[ee]===fe)||(i[Tr]=a[2]&2&&f[Tr],i[Xr]=!!(a[2]&1),i[Ct]=Math.floor(125*i[nt]*i[te]/i[ee]+i[Tr]),!i[Ct]))return null;let u=a[3]&192;if(i[ot]=_h[u][V],i[H]=_h[u][H],i[$r]=f[$r][a[3]&48],i[fa]=!!(a[3]&8),i[Wr]=!!(a[3]&4),i[Qi]=M1[a[3]&3],i[Qi]===fe)return null;i[rt]=16;{let{length:h,frameLength:m,samples:g,...p}=i;r[jt](s,i,p)}return new t(i)}constructor(e){super(e),this[nt]=e[nt],this[Qi]=e[Qi],this[Tr]=e[Tr],this[fa]=e[fa],this[Wr]=e[Wr],this[Xr]=e[Xr],this[Rt]=e[Rt],this[$r]=e[$r],this[Kr]=e[Kr],this[Yr]=e[Yr]}};var Da=class t extends Ot{static*[Qt](e,r,n){return yield*super[Qt](ui,t,e,r,n)}constructor(e,r,n){super(e,r,n)}};var za=class extends lt{constructor(e,r,n){super(e,r),this.Frame=Da,this.Header=ui,n(this[me])}get[me](){return sl}*[Pr](){return yield*this[Rn]()}};var A1={0:"MPEG-4",8:"MPEG-2"},E1={0:"valid",2:st,4:st,6:st},L1={0:yl,1:Ca},T1={0:"AAC Main",64:"AAC LC (Low Complexity)",128:"AAC SSR (Scalable Sample Rate)",192:"AAC LTP (Long Term Prediction)"},R1={0:nl,4:il,8:ch,12:_n,16:Xi,20:$i,24:Ki,28:Yi,32:qi,36:ol,40:al,44:Zi,48:dh,52:fe,56:fe,60:"frequency is written explicitly"},wh={0:{[H]:0,[V]:"Defined in AOT Specific Config"},64:{[H]:1,[V]:xn},128:{[H]:2,[V]:Se(2,G[0][0])},192:{[H]:3,[V]:Se(3,G[1][3])},256:{[H]:4,[V]:Se(4,G[1][3],G[3][4])},320:{[H]:5,[V]:Se(5,G[1][3],G[3][0])},384:{[H]:6,[V]:Se(6,G[1][3],G[3][0],Ar)},448:{[H]:8,[V]:Se(8,G[1][3],G[2][0],G[3][0],Ar)}},fi=class t extends Ut{static*[ue](e,r,n){let i={},o=yield*e[oe](7,n),a=zt([o[0],o[1],o[2],o[3]&252|o[6]&3]),s=r[ue](a);if(s)Object.assign(i,s);else{if(o[0]!==255||o[1]<240||(i[Kr]=A1[o[1]&8],i[Rt]=E1[o[1]&6],i[Rt]===st))return null;let l=o[1]&1;i[Yr]=L1[l],i[P]=l?7:9,i[ll]=o[2]&192,i[Rr]=o[2]&60;let d=o[2]&2;if(i[ya]=T1[i[ll]],i[ee]=R1[i[Rr]],i[ee]===fe)return null;i[Xr]=!!d,i[Sa]=(o[2]<<8|o[3])&448,i[ot]=wh[i[Sa]][V],i[H]=wh[i[Sa]][H],i[Wr]=!!(o[3]&32),i[ha]=!!(o[3]&8),i[wa]=!!(o[3]&8),i[Ma]=!!(o[3]&4),i[rt]=16,i[te]=1024,i[pa]=o[6]&3;{let{length:f,channelModeBits:u,profileBits:h,sampleRateBits:m,frameLength:g,samples:p,numberAACFrames:y,...v}=i;r[jt](a,i,v)}}if(i[Ct]=(o[3]<<11|o[4]<<3|o[5]>>5)&8191,!i[Ct])return null;let c=(o[5]<<6|o[6]>>2)&2047;return i[sa]=c===2047?"VBR":c,new t(i)}constructor(e){super(e),this[wa]=e[wa],this[Ma]=e[Ma],this[sa]=e[sa],this[ha]=e[ha],this[Wr]=e[Wr],this[Xr]=e[Xr],this[Rt]=e[Rt],this[P]=e[P],this[Kr]=e[Kr],this[pa]=e[pa],this[ya]=e[ya],this[Yr]=e[Yr]}get audioSpecificConfig(){let e=Fe.get(this),r=e[ll]+64<<5|e[Rr]<<5|e[Sa]>>3,n=new at(2);return new Pn(n[Er]).setUint16(0,r,!1),n}};var Oa=class t extends Ot{static*[Qt](e,r,n){return yield*super[Qt](fi,t,e,r,n)}constructor(e,r,n){super(e,r,n)}};var Ua=class extends lt{constructor(e,r,n){super(e,r),this.Frame=Oa,this.Header=fi,n(this[me])}get[me](){return"aac"}*[Pr](){return yield*this[Rn]()}};var In=class t extends Ot{static _getFrameFooterCrc16(e){return(e[e[P]-2]<<8)+e[e[P]-1]}static[gl](e){let r=t._getFrameFooterCrc16(e),n=ph(e[Z](0,-2));return r===n}constructor(e,r,n){r[Ta]=n,r[ca]=t._getFrameFooterCrc16(e),super(r,e,Fe.get(r)[te])}};var Mh="get from STREAMINFO metadata block",C1={0:"Fixed",1:"Variable"},Ah={0:fe,16:192};for(let t=2;t<16;t++)Ah[t<<4]=t<6?576*2**(t-2):2**t;var P1={0:Mh,1:il,2:lh,3:sh,4:Zi,5:qi,6:Yi,7:Ki,8:$i,9:Xi,10:_n,11:nl,15:st},I1={0:{[H]:1,[V]:xn},16:{[H]:2,[V]:Se(2,G[0][0])},32:{[H]:3,[V]:Se(3,G[0][1])},48:{[H]:4,[V]:Se(4,G[1][0],G[3][0])},64:{[H]:5,[V]:Se(5,G[1][1],G[3][0])},80:{[H]:6,[V]:Se(6,G[1][1],Ar,G[3][0])},96:{[H]:7,[V]:Se(7,G[1][1],Ar,G[3][4],G[2][0])},112:{[H]:8,[V]:Se(8,G[1][1],Ar,G[3][0],G[2][0])},128:{[H]:2,[V]:`${vn} (left, diff)`},144:{[H]:2,[V]:`${vn} (diff, right)`},160:{[H]:2,[V]:`${vn} (avg, diff)`},176:fe,192:fe,208:fe,224:fe,240:fe},B1={0:Mh,2:8,4:12,6:fe,8:16,10:20,12:24,14:fe},Bn=class t extends Ut{static _decodeUTF8Int(e){if(e[0]>254)return null;if(e[0]<128)return{value:e[0],length:1};let r=1;for(let a=64;a&e[0];a>>=1)r++;let n=r-1,i=0,o=0;for(;n>0;o+=6,n--){if((e[n]&192)!==128)return null;i|=(e[n]&63)<<o}return i|=(e[n]&127>>r)<<o,{value:i,length:r}}static[Jt](e,r){let n={[oe]:function*(){return e}};return t[ue](n,r,0).next().value}static*[ue](e,r,n){let i=yield*e[oe](6,n);if(i[0]!==255||!(i[1]===248||i[1]===249))return null;let o={},a=zt(i[Z](0,4)),s=r[ue](a);if(s)Object.assign(o,s);else{if(o[dl]=i[1]&1,o[xa]=C1[o[dl]],o[va]=i[2]&240,o[Rr]=i[2]&15,o[qr]=Ah[o[va]],o[qr]===fe||(o[ee]=P1[o[Rr]],o[ee]===st)||i[3]&1)return null;let l=I1[i[3]&240];if(l===fe||(o[H]=l[H],o[ot]=l[V],o[rt]=B1[i[3]&14],o[rt]===fe))return null}o[P]=5,i=yield*e[oe](o[P]+8,n);let c=t._decodeUTF8Int(i[Z](4));if(!c||(o[dl]?o[Ea]=c.value:o[Jr]=c.value,o[P]+=c[P],o[va]===96?(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[qr]=i[o[P]-1]+1,o[P]+=1):o[va]===112&&(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[qr]=(i[o[P]-1]<<8)+i[o[P]]+1,o[P]+=2),o[te]=o[qr],o[Rr]===12?(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ee]=i[o[P]-1]*1e3,o[P]+=1):o[Rr]===13?(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ee]=(i[o[P]-1]<<8)+i[o[P]],o[P]+=2):o[Rr]===14&&(i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ee]=((i[o[P]-1]<<8)+i[o[P]])*10,o[P]+=2),i[P]<o[P]&&(i=yield*e[oe](o[P],n)),o[ji]=i[o[P]-1],o[ji]!==mh(i[Z](0,o[P]-1))))return null;if(!s){let{blockingStrategyBits:l,frameNumber:d,sampleNumber:f,samples:u,sampleRateBits:h,blockSizeBits:m,crc:g,length:p,...y}=o;r[jt](a,o,y)}return new t(o)}constructor(e){super(e),this[ca]=null,this[xa]=e[xa],this[qr]=e[qr],this[Jr]=e[Jr],this[Ea]=e[Ea],this[Ta]=null}};var F1=2,k1=512*1024,hi=class extends lt{constructor(e,r,n){super(e,r),this.Frame=In,this.Header=Bn,n(this[me])}get[me](){return"flac"}*_getNextFrameSyncOffset(e){let r=yield*this._codecParser[oe](2,0),n=r[P]-2;for(;e<n;){if(r[e]===255){let o=r[e+1];if(o===248||o===249)break;o!==255&&e++}e++}return e}*[Pr](){do{let e=yield*Bn[ue](this._codecParser,this._headerCache,0);if(e){let r=Fe.get(e)[P]+F1;for(;r<=k1;){if(this._codecParser._flushing||(yield*Bn[ue](this._codecParser,this._headerCache,r))){let n=yield*this._codecParser[oe](r);if(this._codecParser._flushing||(n=n[Z](0,r)),In[gl](n)){let i=new In(n,e);return this._headerCache[fr](),this._codecParser[Zt](r),this._codecParser[Tn](i),i}}r=yield*this._getNextFrameSyncOffset(r+1)}this._codecParser[dr](`Unable to sync FLAC frame after searching ${r} bytes.`),this._codecParser[Zt](r)}else this._codecParser[Zt](yield*this._getNextFrameSyncOffset(1))}while(!0)}[Cn](e){return e[Re]===0?(this._headerCache[fr](),this._streamInfo=e[he][Z](13)):e[Re]===1||(e[it]=je.get(e)[qt].map(r=>{let n=Bn[Jt](r,this._headerCache);if(n)return new In(r,n,this._streamInfo);this._codecParser[dr]("Failed to parse Ogg FLAC frame","Skipping invalid FLAC frame")}).filter(r=>!!r)),e}};var mi=class t{static*[ue](e,r,n){let i={},o=yield*e[oe](28,n);if(o[0]!==79||o[1]!==103||o[2]!==103||o[3]!==83||(i[vd]=o[4],o[5]&248))return null;i[Dt]=!!(o[5]&4),i[wn]=!!(o[5]&2),i[Sn]=!!(o[5]&1);let s=new Pn(at.from(o[Z](0,28))[Er]);i[cr]=yh(s,6),i[Cr]=s.getInt32(14,!0),i[Re]=s.getInt32(18,!0),i[oi]=s.getInt32(22,!0);let c=o[26];i[P]=c+27,o=yield*e[oe](i[P],n),i[Ct]=0,i[Ln]=[],i[eo]=at.from(o[Z](27,i[P]));for(let l=0,d=0;l<c;l++){let f=i[eo][l];i[Ct]+=f,d+=f,(f!==255||l===c-1)&&(i[Ln].push(d),d=0)}return new t(i)}constructor(e){Fe.set(this,e),this[cr]=e[cr],this[Sn]=e[Sn],this[wn]=e[wn],this[Dt]=e[Dt],this[Ln]=e[Ln],this[Re]=e[Re],this[oi]=e[oi],this[Cr]=e[Cr]}};var Na=class t extends ci{static*[Qt](e,r,n){let i=yield*mi[ue](e,r,n);if(i){let o=Fe.get(i)[Ct],a=Fe.get(i)[P],s=a+o,c=(yield*e[oe](s,0))[Z](0,s),l=c[Z](a,s);return new t(i,l,c)}else return null}constructor(e,r,n){super(e,r),je.get(this)[P]=n[P],this[it]=[],this[yd]=n,this[cr]=e[cr],this[da]=e[oi],this[Lr]=0,this[Sn]=e[Sn],this[wn]=e[wn],this[Dt]=e[Dt],this[Re]=e[Re],this[te]=0,this[Cr]=e[Cr]}};var ro=class extends Ot{constructor(e,r,n){super(r,e,n)}};var Eh={0:na.slice(0,2),1:na},er="SILK-only",Qe="CELT-only",Ll="Hybrid",Fn="narrowband",Tl="medium-band",kn="wideband",no="super-wideband",io="fullband",D1={0:{[$]:er,[K]:Fn,[W]:10},8:{[$]:er,[K]:Fn,[W]:20},16:{[$]:er,[K]:Fn,[W]:40},24:{[$]:er,[K]:Fn,[W]:60},32:{[$]:er,[K]:Tl,[W]:10},40:{[$]:er,[K]:Tl,[W]:20},48:{[$]:er,[K]:Tl,[W]:40},56:{[$]:er,[K]:Tl,[W]:60},64:{[$]:er,[K]:kn,[W]:10},72:{[$]:er,[K]:kn,[W]:20},80:{[$]:er,[K]:kn,[W]:40},88:{[$]:er,[K]:kn,[W]:60},96:{[$]:Ll,[K]:no,[W]:10},104:{[$]:Ll,[K]:no,[W]:20},112:{[$]:Ll,[K]:io,[W]:10},120:{[$]:Ll,[K]:io,[W]:20},128:{[$]:Qe,[K]:Fn,[W]:2.5},136:{[$]:Qe,[K]:Fn,[W]:5},144:{[$]:Qe,[K]:Fn,[W]:10},152:{[$]:Qe,[K]:Fn,[W]:20},160:{[$]:Qe,[K]:kn,[W]:2.5},168:{[$]:Qe,[K]:kn,[W]:5},176:{[$]:Qe,[K]:kn,[W]:10},184:{[$]:Qe,[K]:kn,[W]:20},192:{[$]:Qe,[K]:no,[W]:2.5},200:{[$]:Qe,[K]:no,[W]:5},208:{[$]:Qe,[K]:no,[W]:10},216:{[$]:Qe,[K]:no,[W]:20},224:{[$]:Qe,[K]:io,[W]:2.5},232:{[$]:Qe,[K]:io,[W]:5},240:{[$]:Qe,[K]:io,[W]:10},248:{[$]:Qe,[K]:io,[W]:20}},oo=class t extends Ut{static[Jt](e,r,n){let i={};if(i[H]=e[9],i[Zr]=e[18],i[P]=i[Zr]!==0?21+i[H]:19,e[P]<i[P])throw new Error("Out of data while inside an Ogg Page");let o=r[0]&3,a=o===3?2:1,s=zt(e[Z](0,i[P]))+zt(r[Z](0,a)),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[Z](0,i[P]));let l=new Pn(i[he][Er]);if(i[rt]=16,i[ni]=l.getUint16(10,!0),i[Aa]=l.getUint32(12,!0),i[ee]=_n,i[ga]=l.getInt16(16,!0),i[Zr]in Eh&&(i[ot]=Eh[i[Zr]][i[H]-1],!i[ot]))return null;i[Zr]!==0&&(i[La]=e[19],i[la]=e[20],i[_a]=[...e[Z](21,i[H]+21)]);let d=D1[248&r[0]];switch(i[$]=d[$],i[K]=d[K],i[W]=d[W],o){case 0:i[Qr]=1;break;case 1:case 2:i[Qr]=2;break;case 3:i[ma]=!!(128&r[1]),i[ua]=!!(64&r[1]),i[Qr]=63&r[1];break;default:return null}{let{length:f,data:u,channelMappingFamily:h,...m}=i;n[jt](s,i,m)}return new t(i)}constructor(e){super(e),this[he]=e[he],this[K]=e[K],this[Zr]=e[Zr],this[_a]=e[_a],this[la]=e[la],this[Qr]=e[Qr],this[W]=e[W],this[ua]=e[ua],this[Aa]=e[Aa],this[ma]=e[ma],this[$]=e[$],this[ga]=e[ga],this[ni]=e[ni],this[La]=e[La]}};var Ha=class extends lt{constructor(e,r,n){super(e,r),this.Frame=ro,this.Header=oo,n(this[me]),this._identificationHeader=null,this._preSkipRemaining=null}get[me](){return"opus"}[Cn](e){return e[Re]===0?(this._headerCache[fr](),this._identificationHeader=e[he]):e[Re]===1||(e[it]=je.get(e)[qt].map(r=>{let n=oo[Jt](this._identificationHeader,r,this._headerCache);if(n){this._preSkipRemaining===null&&(this._preSkipRemaining=n[ni]);let i=n[W]*n[Qr]/1e3*n[ee];return this._preSkipRemaining>0&&(this._preSkipRemaining-=i,i=this._preSkipRemaining<0?-this._preSkipRemaining:0),new ro(r,n,i)}this._codecParser[ml]("Failed to parse Ogg Opus Header","Not a valid Ogg Opus file")})),e}};var ao=class extends Ot{constructor(e,r,n){super(r,e,n)}};var Cd={};for(let t=0;t<8;t++)Cd[t+6]=2**(6+t);var Va=class t extends Ut{static[Jt](e,r,n,i){if(e[P]<30)throw new Error("Out of data while inside an Ogg Page");let o=zt(e[Z](0,30)),a=r[ue](o);if(a)return new t(a);let s={[P]:30};if(o.substr(0,7)!=="vorbis")return null;s[he]=at.from(e[Z](0,30));let c=new Pn(s[he][Er]);if(s[Mn]=c.getUint32(7,!0),s[Mn]!==0||(s[H]=e[11],s[ot]=na[s[H]-1]||"application defined",s[ee]=c.getUint32(12,!0),s[ia]=c.getInt32(16,!0),s[aa]=c.getInt32(20,!0),s[oa]=c.getInt32(24,!0),s[En]=Cd[(e[28]&240)>>4],s[An]=Cd[e[28]&15],s[An]>s[En])||e[29]!==1)return null;s[rt]=32,s[Ji]=i,s[ba]=n;{let{length:l,data:d,version:f,vorbisSetup:u,vorbisComments:h,...m}=s;r[jt](o,s,m)}return new t(s)}constructor(e){super(e),this[ia]=e[ia],this[oa]=e[oa],this[aa]=e[aa],this[An]=e[An],this[En]=e[En],this[he]=e[he],this[ba]=e[ba],this[Ji]=e[Ji]}};var Ga=class extends lt{constructor(e,r,n){super(e,r),this.Frame=ao,n(this[me]),this._identificationHeader=null,this._setupComplete=!1,this._prevBlockSize=null}get[me](){return ii}[Cn](e){e[it]=[];for(let r of je.get(e)[qt])if(r[0]===1)this._headerCache[fr](),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=Va[Jt](this._identificationHeader,this._headerCache,this._vorbisComments,this._vorbisSetup);n?e[it].push(new ao(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[En]:r[An],o=this._prevBlockSize===null?0:(this._prevBlockSize+i)/4;return this._prevBlockSize=i,o}_parseSetupHeader(e){let r=new bl(e),n={count:0,blockFlags:[]};for(;(r.read(1)&1)!==1;);let i;for(;n.count<64&&r.position>0;){Pa(r.read(8));let o=0;for(;r.read(8)===0&&o++<3;);if(o===4)i=r.read(7),n.blockFlags.unshift(i&1),r.position+=6,n.count++;else{((Pa(i)&126)>>1)+1!==n.count&&this._codecParser[dr]("vorbis derived mode count did not match actual mode count");break}}return n.mask=(1<<Math.log2(n.count))-1,n}};var Pd=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[ur](),this._parser=new r(this._codecParser,this._headerCache,this._onCodec),this._codec=e)}_checkCodecSupport({data:e}){let r=zt(e[Z](0,8));switch(r){case"fishead\0":return!1;case"OpusHead":return this._updateCodec("opus",Ha),!0;case(/^\x7fFLAC/.test(r)&&r):return this._updateCodec("flac",hi),!0;case(/^\x01vorbis/.test(r)&&r):return this._updateCodec(ii,Ga),!0;default:return!1}}_checkPageSequenceNumber(e){e[Re]!==this._pageSequenceNumber+1&&this._pageSequenceNumber>1&&e[Re]>1&&this._codecParser[dr]("Unexpected gap in Ogg Page Sequence Number.",`Expected: ${this._pageSequenceNumber+1}, Got: ${e[Re]}`),this._pageSequenceNumber=e[Re]}_parsePage(e){this._isSupported===null&&(this._pageSequenceNumber=e[Re],this._isSupported=this._checkCodecSupport(e)),this._checkPageSequenceNumber(e);let r=je.get(e),n=Fe.get(r[kt]),i=0;if(r[qt]=n[Ln].map(o=>e[he][Z](i,i+=o)),this._continuedPacket[P]&&(r[qt][0]=Ia(this._continuedPacket,r[qt][0]),this._continuedPacket=new at),n[eo][n[eo][P]-1]===255&&(this._continuedPacket=Ia(this._continuedPacket,r[qt].pop())),this._previousAbsoluteGranulePosition!==null&&(e[te]=Number(e[cr]-this._previousAbsoluteGranulePosition)),this._previousAbsoluteGranulePosition=e[cr],this._isSupported){let o=this._parser[Cn](e);return this._codecParser[Tn](o),o}else return e}},Wa=class extends lt{constructor(e,r,n){super(e,r),this._onCodec=n,this.Frame=Na,this.Header=mi,this._streams=new Map,this._currentSerialNumber=null}get[me](){let e=this._streams.get(this._currentSerialNumber);return e?e.codec:""}*[Pr](){let e=yield*this[Rn](!0);this._currentSerialNumber=e[Cr];let r=this._streams.get(this._currentSerialNumber);return r||(r=new Pd(this._codecParser,this._headerCache,this._onCodec),this._streams.set(this._currentSerialNumber,r)),e[Dt]&&this._streams.delete(this._currentSerialNumber),r._parsePage(e)}};var Id=()=>{},Xa=class{constructor(e,{onCodec:r,onCodecHeader:n,onCodecUpdate:i,enableLogging:o=!1,enableFrameCRC32:a=!0}={}){this._inputMimeType=e,this._onCodec=r||Id,this._onCodecHeader=n||Id,this._onCodecUpdate=i,this._enableLogging=o,this._crc32=a?gh:Id,this[ur]()}get[me](){return this._parser?this._parser[me]:""}[ur](){this._headerCache=new Ba(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[ur]()}*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 Ua(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/mpeg/))this._parser=new za(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/flac/))this._parser=new hi(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/ogg/))this._parser=new Wa(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[Pr]();e&&(yield e)}}*[oe](e=0,r=0){let n;for(;this._rawData[P]<=e+r;){if(n=yield,this._flushing)return this._rawData[Z](r);n&&(this._totalBytesIn+=n[P],this._rawData=Ia(this._rawData,n))}return this._rawData[Z](r)}[Zt](e){this._currentReadPosition+=e,this._rawData=this._rawData[Z](e)}[Ra](e){this._sampleRate=e[kt][ee],e[kt][nt]=e[Lr]>0?Math.round(e[he][P]/e[Lr])*8:0,e[Jr]=this._frameNumber++,e[ai]=this._totalBytesOut,e[li]=this._totalSamples,e[si]=this._totalSamples/this._sampleRate*1e3,e[da]=this._crc32(e[he]),this._headerCache[pl](e[kt][nt],e[si]),this._totalBytesOut+=e[he][P],this._totalSamples+=e[te]}[Tn](e){if(e[it]){if(e[Dt]){let r=e[te];e[it].forEach(n=>{let i=n[te];r<i&&(n[te]=r>0?r:0,n[Lr]=n[te]/n[kt][ee]*1e3),r-=i,this[Ra](n)})}else e[te]=0,e[it].forEach(r=>{e[te]+=r[te],this[Ra](r)});e[Lr]=e[te]/this._sampleRate*1e3||0,e[li]=this._totalSamples,e[si]=this._totalSamples/this._sampleRate*1e3||0,e[ai]=this._totalBytesOut}else this[Ra](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(o=>o[P]));r.push(`--stats--${"-".repeat(i-9)}`,...n,"-".repeat(i)),e("codec-parser",r.reduce((o,a)=>o+`
|
|
4
|
+
`+a,""))}}[dr](...e){this._log(console.warn,e)}[ml](...e){this._log(console.error,e)}};var Lh=Xa;var Rl=it;var Cl=he;var Th=kt;var Rh=Dt;var Ch=Ji;var Ph=li;function en(t){var e=e;function r(){}e={};function n(D){throw D}var i,o,a,s,c,l,d,f,u,h,m;function g(){var D=m.buffer;i=new Int8Array(D),o=new Int16Array(D),s=new Uint8Array(D),c=new Uint16Array(D),a=new Int32Array(D),l=new Uint32Array(D),d=new Float32Array(D),f=new Float64Array(D),u=new BigInt64Array(D),h=new BigUint64Array(D)}for(var p=D=>{for(var ae,Pe,Ce=0,or=0,Wt=D.length,cn=new Uint8Array((Wt*3>>2)-(D[Wt-2]=="=")-(D[Wt-1]=="="));Ce<Wt;Ce+=4,or+=3)ae=N[D.charCodeAt(Ce+1)],Pe=N[D.charCodeAt(Ce+2)],cn[or]=N[D.charCodeAt(Ce)]<<2|ae>>4,cn[or+1]=ae<<4|Pe>>2,cn[or+2]=Pe<<6|N[D.charCodeAt(Ce+3)];return cn},y=()=>n(""),v=()=>{},x={},b=D=>D(),_=()=>performance.now(),w=(D,ae)=>{if(x[D]&&(clearTimeout(x[D].id),delete x[D]),!ae)return 0;var Pe=setTimeout(()=>{delete x[D],b(()=>Ur(D,_()))},ae);return x[D]={id:Pe,timeout_ms:ae},0},S=Math.atan,E=Math.cos,T=Math.exp,A=Math.log,C=Math.pow,B=Math.sin,F=D=>{var ae=s.length;return D>>>=0,!1},k=D=>{throw`exit(${D})`},N=new Uint8Array(123),ce=25;ce>=0;--ce)N[48+ce]=52+ce,N[65+ce]=ce,N[97+ce]=26+ce;N[43]=62,N[47]=63;var Vt={e:y,d:v,f:w,b:S,a:E,i:T,h:A,g:C,c:B,k:F,j:k};function It(D){Or=D.n,sn=D.o,ut=D.p,tt=D.q,Gt=D.r,Wn=D.s,ln=D.t,Ur=D.v}var Or,sn,ut,tt,Gt,Wn,ln,Ur;function Nr(D){D.m()}en.wasm||Object.defineProperty(en,"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ô^ö·%!É
|
|
@@ -138,7 +138,7 @@ KÙ:KµºKí{K]ûK£[KÚKóKÓ½R׿ÿ'P^j9TîçmóþL¿_o©×hÙtÙ
|
|
|
138
138
|
Ái;ªäÀ%n= =M+W= ÓÖc[aS
|
|
139
139
|
FÁð]NôÝ'= qr(¶ù¤nü«òÿ¿d&ÿÈõT4Þ=}z|ö ¿OW×SMtdH.ÏãRX&§o3ØÜXÍ^ÊMí£W´iâ]NüOå£S£Å·ç÷ݧ½GÑUy¹¦ß§/6P0(Cúýb"þ¥°VÙÄá£ÓÙ@¾YýòD{òÃv?EP©=MBé\ĽYäýRò øfâëEEf¼D+gC×úDZGÅÿ±Ç?TzÙ¡±ÏÁÕ¯¦ðvZmT}3xËz×cºrÑM=Mc-É©Ô7½wæc§Î»cû¾yfÙWòÆÝÔc¥³ôØf«Äñ·9ø%g:y^+{U]¤þ
[&fÓÏYë«Gªõ¹¦Öðþ¬moÛø?/ÛS.[S9ÛùC
/û2²Y£ÎÑ%/sy¢×ÌùJW6Oí\g0^JùêßÏ0í[Ü'ÏÔ>À-¿[ÔW?Y]±ØÙÃî<~ÎëR~Ìf¾Z/×¼_á¾Þê+îoÐñ{Þ\e3K%©¹§íB¹§(c=}ËÈ·SzÔnf§èx}o\9öf|%Ýå¥~©IÇüñY8}Ffú@Rú1éþ3÷ËótQøvû|³Îaá,Óé>BG6Òê}ÃJ|¶=}°öf6õk¶ÌºHgNjÒ{æ¾M;9·é§WèO±Ä3ÒËÒyt ;ù´à©a|Ó^!ÝøûÂÄ
|
|
140
140
|
(VV¸ÇÙcÏ>yoçzÃvòG{3Þ£½c×ôíÅé;°OÛGØ<wÜW> rU]q{û'ùÝír{*øï?t-ígùWÿ
&§]m}×ût¥Ë~ß&>&Õv!b#ÅÌq¢µ|jÍüùÉ^Æ&ôþ~sIµ"]d)uâ´ºvk Å\<Íÿöê½Â
|
|
141
|
-
ïBçϧmÙIólÜoëVb¦¯éWÇû3`});var Hr={a:Ht};this.setModule=D=>{t.setModule(en,D)},this.getModule=()=>t.getModule(en),this.instantiate=()=>(this.getModule().then(D=>WebAssembly.instantiate(D,Hr)).then(D=>{let ae=D.exports;Pt(ae),m=ae.l,g(),Nr(ae),r()}),this.ready=new Promise(D=>{r=D}).then(()=>{this.HEAP=m.buffer,this.malloc=sn,this.free=ln,this.create_decoder=Or,this.send_setup=ut,this.init_dsp=tt,this.decode_packets=Vt,this.destroy_decoder=Wn}),this)}function pi(){return this._init=()=>new this._WASMAudioDecoderCommon().instantiate(this._EmscriptenWASM,this._module).then(t=>{this._common=t,this._input=this._common.allocateTypedArray(this._inputSize,Uint8Array),this._firstPage=!0,this._inputLen=this._common.allocateTypedArray(1,Uint32Array),this._outputBufferPtr=this._common.allocateTypedArray(1,Uint32Array),this._channels=this._common.allocateTypedArray(1,Uint32Array),this._sampleRate=this._common.allocateTypedArray(1,Uint32Array),this._samplesDecoded=this._common.allocateTypedArray(1,Uint32Array);let e=256;this._errors=this._common.allocateTypedArray(e,Uint32Array),this._errorsLength=this._common.allocateTypedArray(1,Int32Array),this._frameNumber=0,this._inputBytes=0,this._outputSamples=0,this._decoder=this._common.wasm.create_decoder(this._input.ptr,this._inputLen.ptr,this._outputBufferPtr.ptr,this._channels.ptr,this._sampleRate.ptr,this._samplesDecoded.ptr,this._errors.ptr,this._errorsLength.ptr,e)}),Object.defineProperty(this,"ready",{enumerable:!0,get:()=>this._ready}),this.reset=()=>(this.free(),this._init()),this.free=()=>{this._common.wasm.destroy_decoder(this._decoder),this._common.free()},this.sendSetupHeader=t=>{this._input.buf.set(t),this._inputLen.buf[0]=t.length,this._common.wasm.send_setup(this._decoder,this._firstPage),this._firstPage=!1},this.initDsp=()=>{this._common.wasm.init_dsp(this._decoder)},this.decodePackets=t=>{let e=[],r=0,n=[];for(let i=0;i<t.length;i++){let o=t[i];this._input.buf.set(o),this._inputLen.buf[0]=o.length,this._common.wasm.decode_packets(this._decoder);let a=this._samplesDecoded.buf[0],s=[],c=new Uint32Array(this._common.wasm.HEAP,this._outputBufferPtr.buf[0],this._channels.buf[0]);for(let l=0;l<this._channels.buf[0];l++){let d=new Float32Array(a);a&&d.set(new Float32Array(this._common.wasm.HEAP,c[l],a)),s.push(d)}e.push(s),r+=a,this._frameNumber++,this._inputBytes+=o.length,this._outputSamples+=a;for(let l=0;l<this._errorsLength.buf;l+=2){let d=this._common.codeToString(this._errors.buf[l]),f=this._common.codeToString(this._errors.buf[l+1]);n.push({message:d+" vorbis_synthesis"+f,frameLength:o.length,frameNumber:this._frameNumber,inputBytes:this._inputBytes,outputSamples:this._outputSamples})}this._errorsLength.buf[0]=0}return this._WASMAudioDecoderCommon.getDecodedAudioMultiChannel(n,e,this._channels.buf[0],r,this._sampleRate.buf[0],16)},this._isWebWorker=pi.isWebWorker,this._WASMAudioDecoderCommon=pi.WASMAudioDecoderCommon||ge,this._EmscriptenWASM=pi.EmscriptenWASM||en,this._module=pi.module,this._inputSize=128*1024,this._ready=this._init(),this}var Cl=Symbol(),tn=class{constructor(){this._onCodec=e=>{if(e!=="vorbis")throw new Error("@wasm-audio-decoders/ogg-vorbis does not support this codec "+e)},new ge,this._init(),this._ready=this[Cl](pi)}_init(){this._vorbisSetupInProgress=!0,this._totalSamplesDecoded=0,this._codecParser=new Lh("audio/ogg",{onCodec:this._onCodec,enableFrameCRC32:!1})}async[Cl](e){if(this._decoder){let r=this._decoder;await r.ready.then(()=>r.free())}return this._decoder=new e,this._decoder.ready}get ready(){return this._ready}async reset(){return this._init(),this._decoder.reset()}free(){this._decoder.free()}async decodeOggPages(e){let r=[];for(let o=0;o<e.length;o++){let a=e[o];if(this._vorbisSetupInProgress&&(a[Rl][0]===1&&this._decoder.sendSetupHeader(a[Rl]),a[Tl].length)){let s=a[Tl][0][Th];this._decoder.sendSetupHeader(s[Ch]),this._decoder.initDsp(),this._vorbisSetupInProgress=!1}r.push(...a[Tl].map(s=>s[Rl]))}let n=await this._decoder.decodePackets(r);this._totalSamplesDecoded+=n.samplesDecoded;let i=e[e.length-1];if(i&&i[Rh]){let o=this._totalSamplesDecoded-i[Ph];if(o>0){for(let a=0;a<n.channelData.length;a++)n.channelData[a]=n.channelData[a].subarray(0,n.samplesDecoded-o);n.samplesDecoded-=o,this._totalSamplesDecoded-=o}}return n}async decode(e){return this.decodeOggPages([...this._codecParser.parseChunk(e)])}async flush(){let e=await this.decodeOggPages([...this._codecParser.flush()]);return await this.reset(),e}async decodeFile(e){let r=await this.decodeOggPages([...this._codecParser.parseAll(e)]);return await this.reset(),r}};var Bd=class extends Xi{constructor(e){super(e,"ogg-vorbis-decoder",pi,en)}async sendSetupHeader(e){return this.postToDecoder("sendSetupHeader",e)}async initDsp(){return this.postToDecoder("initDsp")}async decodePackets(e){return this.postToDecoder("decodePackets",e)}},Ka=class extends tn{constructor(){super(),this._ready=super[Cl](Bd)}async free(){await this._decoder.free()}terminate(){this._decoder.terminate()}};tl(tn,"OggVorbisDecoder");tl(Ka,"OggVorbisDecoderWebWorker");var Fd=class extends Error{constructor(e){super(e),this.name="OggDecodeError"}};async function Pl(t,e=new tn){await e.ready;let r=await e.decode(new Uint8Array(t)),n=r.errors;if(n&&n.length>0)throw new Fd(n.map(i=>i.message).join("; "));return{sampleRate:r.sampleRate,channels:r.channelData.length,bitDepth:r.bitDepth,channelData:r.channelData}}var Ya=class extends Error{constructor(e){super(e),this.name="AudioRegistryError"}},lo=class{constructor(e,r={}){this.vfs=e;this.refCounts=new Map;this.nextRequestId=0;this.cache=new yn(r.cacheSize??64),r.workerPath&&(this.worker=new Worker(r.workerPath,{type:"module"}))}get size(){return this.cache.size}get capacity(){return this.cache.capacity}async load(e){let r=e.toLowerCase(),n=this.cache.get(r);if(n)return this.refCounts.set(r,(this.refCounts.get(r)??0)+1),n;let o=(await this.vfs.readFile(e)).slice().buffer,a=await this.decodeByExtension(e,o);return this.cache.set(r,a),this.refCounts.set(r,1),a}release(e){let r=e.toLowerCase(),n=this.refCounts.get(r)??0;n<=1?(this.cache.delete(r),this.refCounts.delete(r)):this.refCounts.set(r,n-1)}clearAll(){this.cache.clear(),this.refCounts.clear()}set capacity(e){this.cache.capacity=e}async decodeByExtension(e,r){let n=e.toLowerCase();if(n.endsWith(".wav")){if(this.worker)return this.decodeWavInWorker(r);let i=el(r),o=i.channels,a=Array.from({length:o},()=>new Float32Array(i.samples.length/o));for(let s=0;s<i.samples.length;s+=1)a[s%o][Math.floor(s/o)]=i.samples[s];return{sampleRate:i.sampleRate,channels:o,bitDepth:i.bitsPerSample,channelData:a}}if(n.endsWith(".ogg")||n.endsWith(".oga"))return Pl(r);throw new Ya(`Unsupported audio format: ${e}`)}decodeWavInWorker(e){return new Promise((r,n)=>{if(!this.worker){n(new Error("Worker not initialized"));return}let i=this.nextRequestId++,o=a=>{if(a.data.id===i)if(this.worker.removeEventListener("message",o),a.data.type==="success"){let s=a.data.data,c=s.channels,l=Array.from({length:c},()=>new Float32Array(s.samples.length/c));for(let d=0;d<s.samples.length;d+=1)l[d%c][Math.floor(d/c)]=s.samples[d];r({sampleRate:s.sampleRate,channels:c,bitDepth:s.bitsPerSample,channelData:l})}else n(new Error(a.data.message))};this.worker.addEventListener("message",o),this.worker.postMessage({id:i,buffer:e,type:"wav"},[e])})}};var z1="quake2ts-pak-indexes",O1="pak-indexes";function Ih(){if(typeof indexedDB<"u")return indexedDB;if(typeof window<"u"&&"indexedDB"in window)return window.indexedDB;if(typeof globalThis<"u"&&"indexedDB"in globalThis)return globalThis.indexedDB}function qa(t,e){let r=Ih();return r?new Promise((n,i)=>{let o=r.open(t,1);o.onupgradeneeded=()=>{let{result:a}=o;a.objectStoreNames.contains(e)||a.createObjectStore(e,{keyPath:"key"})},o.onerror=()=>i(o.error??new Error("Unknown IndexedDB error")),o.onsuccess=()=>n(o.result)}):Promise.reject(new Error("IndexedDB is not available in this environment"))}function Za(t,e,r,n){return new Promise((i,o)=>{let s=t.transaction(e,r).objectStore(e),c=n(s);c.onsuccess=()=>i(c.result),c.onerror=()=>o(c.error??new Error("IndexedDB transaction error"))})}function kd(t,e){return`${_e(t)}:${e.toString(16)}`}function U1(t){return t.map(e=>({...e}))}var Il=class{constructor(e=z1,r=O1){this.dbName=e;this.storeName=r}get isSupported(){return!!Ih()}async persist(e){if(!this.isSupported)return;let r=e.validate(),n={...r,key:kd(e.name,r.checksum),name:e.name,size:e.size,persistedAt:Date.now(),entries:U1(r.entries)},i=await qa(this.dbName,this.storeName);return await Za(i,this.storeName,"readwrite",o=>o.put(n)),i.close(),n}async find(e,r){if(!this.isSupported)return;let n=await qa(this.dbName,this.storeName),i=r!==void 0?kd(e,r):void 0,o=await Za(n,this.storeName,"readonly",a=>i?a.get(i):a.getAll());if(n.close(),!!o){if(Array.isArray(o)){let a=_e(e),s=o.filter(c=>_e(c.name)===a);return s.length===0?void 0:s.sort((c,l)=>l.persistedAt-c.persistedAt)[0]}return o}}async remove(e,r){if(!this.isSupported)return!1;let n=await qa(this.dbName,this.storeName),i=r!==void 0?kd(e,r):void 0,o=await Za(n,this.storeName,"readwrite",a=>{if(i)return a.delete(i);let s=`${_e(e)}:`;return a.delete(IDBKeyRange.bound(s,`${s}\uFFFF`,!1,!0))});return n.close(),typeof o=="number"?o>0:!0}async clear(){if(!this.isSupported)return;let e=await qa(this.dbName,this.storeName);await Za(e,this.storeName,"readwrite",r=>r.clear()),e.close()}async list(){if(!this.isSupported)return[];let e=await qa(this.dbName,this.storeName),r=await Za(e,this.storeName,"readonly",n=>n.getAll());return e.close(),r.sort((n,i)=>i.persistedAt-n.persistedAt)}};var gi=class extends Error{constructor(r,n){super(n??`Missing dependencies: ${r.join(", ")}`);this.missing=r;this.name="AssetDependencyError"}},ja=class{constructor(){this.nodes=new Map}register(e,r=[]){let n=this.nodes.get(e)??{dependencies:new Set,loaded:!1};r.forEach(i=>n.dependencies.add(i)),this.nodes.set(e,n),r.forEach(i=>{this.nodes.has(i)||this.nodes.set(i,{dependencies:new Set,loaded:!1})})}markLoaded(e){let r=this.nodes.get(e)??{dependencies:new Set,loaded:!1},n=this.getMissingDependencies(e,r);if(n.length>0)throw new gi(n,`Asset ${e} is missing dependencies: ${n.join(", ")}`);r.loaded=!0,this.nodes.set(e,r)}markUnloaded(e){let r=this.nodes.get(e);r&&(r.loaded=!1)}isLoaded(e){return this.nodes.get(e)?.loaded??!1}missingDependencies(e){let r=this.nodes.get(e);return r?this.getMissingDependencies(e,r):[]}reset(){this.nodes.clear()}getMissingDependencies(e,r){let n=[];for(let i of r.dependencies)this.nodes.get(i)?.loaded||n.push(i);return n}},Bl=class{constructor(e,r={}){this.vfs=e;this.maps=new Map;this.loadQueue=[];this.activeLoads=0;this.textures=new Wi({capacity:r.textureCacheCapacity??128,maxMemory:r.textureMemoryLimit}),this.audio=new lo(e,{cacheSize:r.audioCacheSize??64,workerPath:r.audioWorkerPath}),this.dependencyTracker=r.dependencyTracker??new ja,this.resourceTracker=r.resourceTracker,this.md2=new Hi(e),this.md3=new Vi(e),this.sprite=new Gi(e),this.bsp=new Ni(e,{useWorker:!!r.bspWorkerPath,workerPath:r.bspWorkerPath}),this.maxConcurrentLoads=r.maxConcurrentLoads??4,this.palette=new Uint8Array(768);for(let n=0;n<256;n++)this.palette[n*3]=n,this.palette[n*3+1]=n,this.palette[n*3+2]=n}async loadPalette(e="pics/colormap.pcx"){try{let r=await this.vfs.readFile(e),n=ra(r);n.palette&&(this.palette=n.palette)}catch(r){console.warn(`Failed to load palette from ${e}:`,r)}}isAssetLoaded(e,r){return this.dependencyTracker.isLoaded(this.makeKey(e,r))}registerTexture(e,r){this.textures.set(e,r);let n=this.makeKey("texture",e);this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n)}async loadTexture(e){if(this.resourceTracker){let a=this.vfs.stat(e);this.resourceTracker.recordLoad("texture",e,a?.size,a?.sourcePak)}let r=this.textures.get(e);if(r)return r;let n=await this.vfs.readFile(e),i=e.split(".").pop()?.toLowerCase(),o;if(i==="wal")o=Js(n,this.palette);else if(i==="pcx")o=Qs(ra(n));else if(i==="tga")o=rh(hd(n));else throw new Error(`Unsupported texture format for loadTexture: ${i}`);return this.registerTexture(e,o),o}async loadSound(e){if(this.resourceTracker){let i=this.vfs.stat(e);this.resourceTracker.recordLoad("sound",e,i?.size,i?.sourcePak)}let r=await this.audio.load(e),n=this.makeKey("sound",e);return this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n),r}async loadMd2Model(e,r=[]){if(this.resourceTracker){let s=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,s?.size,s?.sourcePak)}let n=this.makeKey("model",e),i=r.map(s=>this.makeKey("texture",s));this.dependencyTracker.register(n,i);let o=this.dependencyTracker.missingDependencies(n);if(o.length>0)throw new gi(o,`Asset ${n} is missing dependencies: ${o.join(", ")}`);let a=await this.md2.load(e);return this.dependencyTracker.markLoaded(n),a}getMd2Model(e){if(this.resourceTracker){let r=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,r?.size,r?.sourcePak)}return this.md2.get(e)}async loadMd3Model(e,r=[]){if(this.resourceTracker){let s=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,s?.size,s?.sourcePak)}let n=this.makeKey("model",e),i=r.map(s=>this.makeKey("texture",s));this.dependencyTracker.register(n,i);let o=this.dependencyTracker.missingDependencies(n);if(o.length>0)throw new gi(o,`Asset ${n} is missing dependencies: ${o.join(", ")}`);let a=await this.md3.load(e);return this.dependencyTracker.markLoaded(n),a}getMd3Model(e){if(this.resourceTracker){let r=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,r?.size,r?.sourcePak)}return this.md3.get(e)}async loadSprite(e){if(this.resourceTracker){let i=this.vfs.stat(e);this.resourceTracker.recordLoad("sprite",e,i?.size,i?.sourcePak)}let r=this.makeKey("sprite",e);this.dependencyTracker.register(r);let n=await this.sprite.load(e);return this.dependencyTracker.markLoaded(r),n}async loadMap(e){if(this.resourceTracker){let i=this.vfs.stat(e);this.resourceTracker.recordLoad("map",e,i?.size,i?.sourcePak)}let r=this.makeKey("map",e);if(this.maps.has(e))return this.maps.get(e);this.dependencyTracker.register(r);let n=await this.bsp.load(e);return this.maps.set(e,n),this.dependencyTracker.markLoaded(r),n}getMap(e){return this.maps.get(e)}listFiles(e){return this.vfs.findByExtension(e)}resetForLevelChange(){this.textures.clear(),this.audio.clearAll(),this.dependencyTracker.reset(),this.maps.clear(),this.loadQueue.length=0}getMemoryUsage(){let e=0,r=0;if(typeof process<"u"&&process.memoryUsage){let n=process.memoryUsage();e=n.heapTotal,r=n.heapUsed}return{textures:this.textures.memoryUsage,audio:this.audio.size,heapTotal:e,heapUsed:r}}enforceMemoryBudget(e){e.textureMemoryLimit!==void 0&&(this.textures.maxMemory=e.textureMemoryLimit),e.textureCacheCapacity!==void 0&&(this.textures.capacity=e.textureCacheCapacity),e.audioCacheSize!==void 0&&(this.audio.capacity=e.audioCacheSize)}clearCache(e){switch(e){case"texture":this.textures.clear();break;case"sound":this.audio.clearAll();break;case"map":this.maps.clear();break}}async preloadAssets(e){let r=e.map(n=>{let i=this.detectAssetType(n);return i?this.queueLoad(n,i,0):Promise.resolve()});await Promise.all(r)}queueLoad(e,r,n=1){return r==="texture"&&this.textures.get(e)?Promise.resolve(this.textures.get(e)):new Promise((i,o)=>{this.loadQueue.push({path:e,type:r,priority:n,resolve:i,reject:o}),this.loadQueue.sort((a,s)=>s.priority-a.priority),this.processQueue()})}async processQueue(){if(this.activeLoads>=this.maxConcurrentLoads||this.loadQueue.length===0)return;let e=this.loadQueue.shift();this.activeLoads++;try{let r;switch(e.type){case"texture":r=await this.loadTexture(e.path);break;case"sound":r=await this.loadSound(e.path);break;case"model":e.path.endsWith(".md2")?r=await this.loadMd2Model(e.path):e.path.endsWith(".md3")&&(r=await this.loadMd3Model(e.path));break;case"sprite":r=await this.loadSprite(e.path);break;case"map":r=await this.loadMap(e.path);break;default:throw new Error(`Unknown asset type ${e.type}`)}e.resolve(r)}catch(r){e.reject(r)}finally{this.activeLoads--,this.processQueue()}}detectAssetType(e){let r=e.split(".").pop()?.toLowerCase();return r?["wal","pcx","tga","png","jpg"].includes(r)?"texture":["wav","ogg"].includes(r)?"sound":["md2","md3"].includes(r)?"model":["sp2"].includes(r)?"sprite":["bsp"].includes(r)?"map":null:null}makeKey(e,r){return`${e}:${_e(r)}`}};var Fl=class{constructor(e){this.factory=e}getContext(){return this.context||(this.context=this.factory()),this.context}async resume(){let e=this.getContext();e.state==="suspended"&&await e.resume()}getState(){return this.context?.state??"suspended"}};function kl(t){let e=t.getContext(),r=e.createGain();r.gain.value=1;let n=e.createDynamicsCompressor(),i=e.createBiquadFilter?.(),o;if(e.createConvolver&&e.createGain){let a=e.createConvolver(),s=e.createGain(),c=e.createGain();s.connect(a),a.connect(c),o={convolver:a,input:s,output:c}}return i?(i.type="lowpass",i.frequency.value=2e4,i.Q.value=.707,r.connect(i),i.connect(n),o&&o.output.connect(i)):(r.connect(n),o&&o.output.connect(n)),n.connect(e.destination),{context:e,master:r,compressor:n,filter:i,reverb:o}}var Dl=class{constructor(e=new Oi){this.configStrings=e;this.buffers=new Map}registerName(e){return this.configStrings.soundIndex(e)}register(e,r){let n=this.registerName(e);return this.buffers.set(n,r),n}find(e){return this.configStrings.findSoundIndex(e)}get(e){return this.buffers.get(e)}has(e){return this.buffers.has(e)}getName(e){return this.configStrings.getName(e)}};var zl=class{constructor(e){this.vfs=e.vfs,this.registry=e.registry,this.contextController=e.context,this.soundRoot=e.soundRoot??"sound/",this.decodeAudio=e.decodeAudio??((r,n)=>{if(!r.decodeAudioData)throw new Error("decodeAudioData is not available on the provided audio context");return r.decodeAudioData(n)})}async precache(e){let r=[...new Set(e.map(o=>this.normalize(o)))],n={loaded:[],skipped:[],missing:[],errors:{}},i=this.contextController.getContext();for(let o of r)try{let a=this.registry.find(o);if(a!==void 0&&this.registry.has(a)){n.skipped.push(o);continue}if(!this.vfs.stat(o)){n.missing.push(o);continue}let l=(await this.vfs.readFile(o)).slice().buffer,d=await this.decodeAudio(i,l);this.registry.register(o,d),n.loaded.push(o)}catch(a){let s=a instanceof Error?a:new Error(String(a));n.errors[o]=s}return n}normalize(e){let r=_e(e.replace(/^\//,""));return r.startsWith(this.soundRoot)?r:_e(`${this.soundRoot}${r}`)}};var N1=7,Qa=t=>t&N1;function Ol(t){return Array.from({length:Yo},()=>({entnum:0,entchannel:Mr.Auto,endTimeMs:0,isPlayer:!1,active:!1})).map(e=>({...e,isPlayer:e.entnum===t}))}function Ul(t,e,r,n){if(r<0)throw new Error("pickChannel: entchannel must be non-negative");let i=Qa(r),o=-1,a=Number.POSITIVE_INFINITY;for(let s=0;s<t.length;s+=1){let c=t[s],l=Qa(c.entchannel);if(i!==Mr.Auto&&c.entnum===e&&l===i){o=s;break}if(c.active&&c.entnum===n.playerEntity&&e!==n.playerEntity)continue;let d=c.endTimeMs-n.nowMs;(o===-1||d<a)&&(a=d,o=s)}return o===-1?void 0:o}var Nl=class{constructor(e){this.activePreset=null;this.enabled=!0;this.node=e,this.node.input.gain.value=.5,this.node.output.gain.value=1}setPreset(e){this.activePreset=e,this.node.convolver.buffer!==(e?.buffer??null)&&(this.node.convolver.buffer=e?.buffer??null),e&&e.gain!==void 0?this.node.output.gain.value=e.gain:this.node.output.gain.value=1}setEnabled(e){this.enabled=e,e?this.node.input.gain.value=.5:this.node.input.gain.value=0}getOutputNode(){return this.node.output}getInputNode(){return this.node.input}};var Hl=class{constructor(e){this.activeSources=new Map;this.playbackRate=1;this.contextController=e.context,this.registry=e.registry,this.playerEntity=e.playerEntity,this.channels=Ol(e.playerEntity),this.listener=e.listener??{origin:xf,right:{x:1,y:0,z:0}},this.sfxVolume=e.sfxVolume??1,this.masterVolume=e.masterVolume??1,this.resolveOcclusion=e.resolveOcclusion,this.graph=kl(this.contextController),this.graph.master.gain.value=this.masterVolume,this.graph.reverb&&(this.reverb=new Nl(this.graph.reverb))}setListener(e){this.listener=e}setMasterVolume(e){this.masterVolume=e,this.graph.master.gain.value=e}setSfxVolume(e){this.sfxVolume=e}setPlaybackRate(e){this.playbackRate=e;for(let r of this.activeSources.values())r.source.playbackRate&&(r.source.playbackRate.value=e),this.updateSourceGain(r)}async ensureRunning(){await this.contextController.resume()}setReverbPreset(e){this.reverb?.setPreset(e)}play(e){let r=this.registry.get(e.soundIndex);if(!r)return;let n=this.graph.context,i=n.currentTime*1e3,o=Ul(this.channels,e.entity,e.channel,{nowMs:i,playerEntity:this.playerEntity});if(o===void 0)return;let a=this.activeSources.get(o);a&&(a.source.onended=null,a.source.stop(),this.activeSources.delete(o));let s=n.createBufferSource();s.buffer=r,s.loop=e.looping??!1,s.playbackRate&&(s.playbackRate.value=this.playbackRate);let c=e.origin??this.listener.origin,l=n.createGain(),d=this.createPanner(n,e.attenuation),f=this.resolveOcclusion?.(this.listener,c,e.attenuation),u=Bh(f?.gainScale??1),h=this.resolveOcclusion?this.createOcclusionFilter(n,f?.lowpassHz??2e4):void 0;this.applyOriginToPanner(d,c);let g=e.volume/255*this.sfxVolume,p=Math.abs(this.playbackRate-1)<.001?1:0;l.gain.value=g*u*p;let y=n.currentTime+(e.timeOffsetMs??0)/1e3,v=(e.looping?Number.POSITIVE_INFINITY:r.duration*1e3)+y*1e3;s.connect(d);let x=d;h?(d.connect(h),h.connect(l),x=l):(d.connect(l),x=l),l.connect(this.graph.master),this.reverb&&l.connect(this.reverb.getInputNode()),s.start(y),s.onended=()=>{this.channels[o].active=!1,this.activeSources.delete(o)};let b={channelIndex:o,entnum:e.entity,entchannel:Qa(e.channel),endTimeMs:v,source:s,panner:d,gain:l,baseGain:g,origin:c,attenuation:e.attenuation,occlusion:h?{scale:u,lowpassHz:f?.lowpassHz,filter:h}:f?{scale:u,lowpassHz:f.lowpassHz}:void 0};return this.channels[o]={entnum:e.entity,entchannel:Qa(e.channel),endTimeMs:v,isPlayer:e.entity===this.playerEntity,active:!0},this.activeSources.set(o,b),b}stop(e){let r=this.activeSources.get(e);r&&(r.source.stop(),this.channels[e].active=!1,this.activeSources.delete(e))}stopEntitySounds(e){for(let[r,n]of[...this.activeSources.entries()])n.entnum===e&&(n.source.stop(),this.channels[r].active=!1,this.activeSources.delete(r))}updateEntityPosition(e,r){for(let n of this.activeSources.values())if(n.entnum===e&&(this.applyOriginToPanner(n.panner,r),n.origin=r,this.resolveOcclusion)){let i=this.resolveOcclusion(this.listener,r,n.attenuation);this.applyOcclusion(n,i)}}positionedSound(e,r,n,i){return this.play({entity:0,channel:Mr.Auto,soundIndex:r,volume:n,attenuation:i,origin:e})}ambientSound(e,r,n){return this.play({entity:0,channel:Mr.Auto,soundIndex:r,volume:n,attenuation:qo,origin:e,looping:!0})}getChannelState(e){return this.channels[e]}getDiagnostics(){return{activeChannels:this.activeSources.size,masterVolume:this.masterVolume,sfxVolume:this.sfxVolume,channels:[...this.channels],activeSounds:[...this.activeSources.values()].map(e=>({entnum:e.entnum,entchannel:e.entchannel,channelIndex:e.channelIndex,origin:e.origin,gain:e.gain.gain.value,baseGain:e.baseGain,attenuation:e.attenuation,maxDistance:e.panner.maxDistance,distanceModel:e.panner.distanceModel,occlusion:e.occlusion?{scale:e.occlusion.scale,lowpassHz:e.occlusion.lowpassHz}:void 0}))}}setUnderwater(e,r=400){let n=this.graph.filter;n&&(n.type="lowpass",n.Q.value=.707,n.frequency.value=e?r:2e4)}createPanner(e,r){let n=e.createPanner?e.createPanner():Object.assign(e.createGain(),{positionX:{value:this.listener.origin.x},positionY:{value:this.listener.origin.y},positionZ:{value:this.listener.origin.z}});return this.configurePanner(n,r)}configurePanner(e,r){let n=Fi(r);return e.refDistance=Bi,e.maxDistance=Jn(r),e.rolloffFactor=n,e.distanceModel="linear",e.positionX.value=this.listener.origin.x,e.positionY.value=this.listener.origin.y,e.positionZ.value=this.listener.origin.z,e}applyOriginToPanner(e,r){e.positionX.value=r.x,e.positionY.value=r.y,e.positionZ.value=r.z}createOcclusionFilter(e,r){if(!e.createBiquadFilter)return;let n=e.createBiquadFilter();return n.type="lowpass",n.Q.value=.707,n.frequency.value=Dd(r,10,2e4),n}updateSourceGain(e){let r=e.occlusion?.scale??1,n=Math.abs(this.playbackRate-1)<.001?1:0;e.gain.gain.value=e.baseGain*r*n}applyOcclusion(e,r){let n=Bh(r?.gainScale??1),i=Math.abs(this.playbackRate-1)<.001?1:0;if(e.gain.gain.value=e.baseGain*n*i,e.occlusion?.filter){let o=r?.lowpassHz??2e4;e.occlusion.filter.frequency.value=Dd(o,10,2e4)}e.occlusion?(e.occlusion.scale=n,e.occlusion.lowpassHz=r?.lowpassHz):r&&(e.occlusion={scale:n,lowpassHz:r.lowpassHz})}},Dd=(t,e,r)=>Math.min(r,Math.max(e,t)),Bh=t=>Dd(t,0,1);var Ja=class{constructor(e){this.trace=e;this.resolve=(e,r,n)=>{let i=Gc(vf(r,e.origin)),o=Jn(n),c=2e4*(1-Math.min(i,o)/Math.max(1,o)*.9),l=this.trace(e.origin,r,void 0,void 0),d=1,f=2e4;l.fraction<1&&(d=.3,f=400);let u=Math.min(c,f);if(d<1||u<2e4)return{gainScale:d,lowpassHz:u}}}};function Fh(t){return new Ja(t).resolve}var Vl=class{constructor(e){this.createElement=e.createElement,this.resolveSource=e.resolveSource??(async r=>r),this.volume=e.volume??1,this.crossfadeDuration=e.crossfadeDuration??1}async playTrack(e){let r=`music/track${e.toString().padStart(2,"0")}.ogg`;return this.play(r)}async play(e,{loop:r=!0,restart:n=!1}={}){if(this.track===e&&this.currentElement){this.currentElement.loop=r,this.cancelFade(),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0),this.currentElement.volume=this.volume,n&&(this.currentElement.currentTime=0),(this.currentElement.paused||n)&&await this.currentElement.play();return}let i=await this.resolveSource(e);this.cancelFade(),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0),this.currentElement&&(this.fadingElement=this.currentElement,this.currentElement=void 0);let o=this.createElement();o.src=i,o.loop=r,o.volume=0,o.currentTime=0,o.load();try{await o.play()}catch(a){console.warn(`MusicSystem: Failed to play ${e}`,a),this.fadingElement}this.currentElement=o,this.track=e,this.startCrossfade()}pause(){this.cancelFade(),this.currentElement&&!this.currentElement.paused&&this.currentElement.pause(),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0)}async resume(){!this.currentElement||!this.currentElement.paused||(await this.currentElement.play(),this.currentElement.volume=this.volume)}stop(){this.cancelFade(),this.currentElement&&(this.currentElement.pause(),this.currentElement.currentTime=0,this.currentElement=void 0),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0),this.track=void 0}setVolume(e){this.volume=e,this.currentElement&&!this.fadeInterval&&(this.currentElement.volume=e)}getState(){let e=!!(this.currentElement&&!this.currentElement.paused&&!this.currentElement.ended),r=!!this.currentElement?.paused;return{track:this.track,paused:r,playing:e,volume:this.volume}}startCrossfade(){let r=this.crossfadeDuration*1e3/50,n=this.volume/r,i=0,o=this.fadingElement?this.fadingElement.volume:0,a=()=>{let s=!1;this.currentElement&&(i=Math.min(this.volume,i+n),this.currentElement.volume=i,i<this.volume&&(s=!0)),this.fadingElement&&(o=Math.max(0,o-n),this.fadingElement.volume=o,o>0?s=!0:(this.fadingElement.pause(),this.fadingElement=void 0)),s||this.cancelFade()};a(),(this.currentElement&&this.currentElement.volume<this.volume||this.fadingElement)&&(this.fadeInterval=setInterval(a,50))}cancelFade(){this.fadeInterval&&(clearInterval(this.fadeInterval),this.fadeInterval=void 0)}};function H1(t){t.enable(t.DEPTH_TEST),t.depthFunc(t.LEQUAL),t.enable(t.CULL_FACE),t.cullFace(t.BACK),t.enable(t.BLEND),t.blendFuncSeparate(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA,t.ONE,t.ONE_MINUS_SRC_ALPHA)}function V1(t,e,r,n){for(let i of e){let o=t.getExtension(i);if(!o)throw new Error(`Missing required WebGL extension: ${i}`);n.set(i,o)}for(let i of r){let o=t.getExtension(i);o&&n.set(i,o)}}function kh(t,e={}){let{contextAttributes:r,requiredExtensions:n=[],optionalExtensions:i=[]}=e,o=t.getContext("webgl2",r??{antialias:!0});if(!o)throw new Error("WebGL2 not supported or failed to initialize");H1(o);let a=new Map;V1(o,n,i,a);let s=!1,c=new Set,l=new Set,d=u=>{s=!0,u.preventDefault();for(let h of c)h()},f=()=>{s=!1;for(let u of l)u()};return t.addEventListener("webglcontextlost",d),t.addEventListener("webglcontextrestored",f),{gl:o,extensions:a,isLost:()=>s,onLost(u){return c.add(u),()=>c.delete(u)},onRestored(u){return l.add(u),()=>l.delete(u)},dispose(){t.removeEventListener("webglcontextlost",d),t.removeEventListener("webglcontextrestored",f),c.clear(),l.clear(),a.clear()}}}function Dh(t,e,r){let n=t.createShader(e);if(!n)throw new Error("Failed to allocate shader");if(t.shaderSource(n,r.trim()),t.compileShader(n),!t.getShaderParameter(n,t.COMPILE_STATUS)){let o=t.getShaderInfoLog(n)??"Unknown shader compile failure";throw t.deleteShader(n),new Error(o)}return n}function G1(t,e,r,n){let i=t.createProgram();if(!i)throw new Error("Failed to allocate shader program");if(t.attachShader(i,e),t.attachShader(i,r),n)for(let[a,s]of Object.entries(n))t.bindAttribLocation(i,s,a);if(t.linkProgram(i),!t.getProgramParameter(i,t.LINK_STATUS)){let a=t.getProgramInfoLog(i)??"Unknown shader link failure";throw t.deleteProgram(i),new Error(a)}return i}var le=class t{constructor(e,r,n){this.uniformLocations=new Map;this.attributeLocations=new Map;this.gl=e,this.program=r,this.sourceSize=n}static create(e,r,n){let i=Dh(e,e.VERTEX_SHADER,r.vertex),o=Dh(e,e.FRAGMENT_SHADER,r.fragment);try{let a=G1(e,i,o,n),s=r.vertex.length+r.fragment.length;return new t(e,a,s)}finally{e.deleteShader(i),e.deleteShader(o)}}use(){this.gl.useProgram(this.program)}getUniformLocation(e){if(!this.uniformLocations.has(e)){let r=this.gl.getUniformLocation(this.program,e);this.uniformLocations.set(e,r)}return this.uniformLocations.get(e)??null}getAttributeLocation(e){if(!this.attributeLocations.has(e)){let r=this.gl.getAttribLocation(this.program,e);this.attributeLocations.set(e,r)}return this.attributeLocations.get(e)??-1}dispose(){this.gl.deleteProgram(this.program),this.uniformLocations.clear(),this.attributeLocations.clear()}};function zh(t,e,r){return le.create(t,e,r)}var Ae=class{constructor(e,r=e.STATIC_DRAW,n){this.gl=e,this.target=n??e.ARRAY_BUFFER;let i=e.createBuffer();if(!i)throw new Error("Failed to allocate buffer");this.buffer=i,e.bindBuffer(this.target,this.buffer),e.bufferData(this.target,0,r)}bind(){this.gl.bindBuffer(this.target,this.buffer)}upload(e,r=this.gl.STATIC_DRAW){this.bind(),this.gl.bufferData(this.target,e,r)}update(e,r=0){this.bind(),this.gl.bufferSubData(this.target,r,e)}dispose(){this.gl.deleteBuffer(this.buffer)}},Je=class extends Ae{constructor(e,r=e.STATIC_DRAW){super(e,r,e.ELEMENT_ARRAY_BUFFER)}},Le=class{constructor(e){this.gl=e;let r=e.createVertexArray();if(!r)throw new Error("Failed to allocate vertex array object");this.vao=r}bind(){this.gl.bindVertexArray(this.vao)}configureAttributes(e,r){this.bind(),r&&r.bind();for(let n of e)this.gl.enableVertexAttribArray(n.index),this.gl.vertexAttribPointer(n.index,n.size,n.type,n.normalized??!1,n.stride??0,n.offset??0),n.divisor!==void 0&&this.gl.vertexAttribDivisor(n.index,n.divisor)}dispose(){this.gl.deleteVertexArray(this.vao)}},et=class{constructor(e,r=e.TEXTURE_2D){this.width=0;this.height=0;this.gl=e,this.target=r;let n=e.createTexture();if(!n)throw new Error("Failed to allocate texture");this.texture=n}bind(e=0){this.gl.activeTexture(this.gl.TEXTURE0+e),this.gl.bindTexture(this.target,this.texture)}setParameters(e){this.bind(),e.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,e.wrapS),e.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,e.wrapT),e.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,e.minFilter),e.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,e.magFilter)}upload(e,r,n){this.width=e,this.height=r,this.uploadImage(0,this.gl.RGBA,e,r,0,this.gl.RGBA,this.gl.UNSIGNED_BYTE,n)}uploadImage(e,r,n,i,o,a,s,c){this.bind(),this.gl.texImage2D(this.target,e,r,n,i,o,a,s,c)}dispose(){this.gl.deleteTexture(this.texture)}},co=class{constructor(e){this.gl=e,this.target=e.TEXTURE_CUBE_MAP;let r=e.createTexture();if(!r)throw new Error("Failed to allocate cubemap texture");this.texture=r}bind(e=0){this.gl.activeTexture(this.gl.TEXTURE0+e),this.gl.bindTexture(this.target,this.texture)}setParameters(e){this.bind(),e.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,e.wrapS),e.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,e.wrapT),e.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,e.minFilter),e.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,e.magFilter)}uploadFace(e,r,n,i,o,a,s,c,l){this.bind(),this.gl.texImage2D(e,r,n,i,o,a,s,c,l)}dispose(){this.gl.deleteTexture(this.texture)}},yi=class{constructor(e){this.gl=e;let r=e.createFramebuffer();if(!r)throw new Error("Failed to allocate framebuffer");this.framebuffer=r}bind(e=this.gl.FRAMEBUFFER){this.gl.bindFramebuffer(e,this.framebuffer)}attachTexture2D(e,r,n=0){this.bind(),this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER,e,r.target,r.texture,n)}dispose(){this.gl.deleteFramebuffer(this.framebuffer)}};var Od=4,zd=7*Od,Ud=[{index:0,size:3,type:5126,stride:zd,offset:0},{index:1,size:2,type:5126,stride:zd,offset:3*Od},{index:2,size:2,type:5126,stride:zd,offset:5*Od}];function W1(t,e){return{width:t,height:t,padding:e,data:new Uint8Array(t*t*4),cursorX:0,cursorY:0,rowHeight:0}}function X1(t){let e=t.width*t.height;if(e===0)throw new Error("Invalid lightmap with zero area");let r=t.samples.byteLength/e;if(!Number.isInteger(r)||r<3||r>4)throw new Error("Unsupported lightmap channel count");return r}function $1(t,e,r){let n=X1(r),i=t.width*4,o=e.x+t.padding,a=e.y+t.padding,s=0;for(let c=0;c<r.height;c++){let l=(a+c)*i+o*4;for(let d=0;d<r.width;d++){let f=l+d*4;t.data[f]=r.samples[s],t.data[f+1]=r.samples[s+1],t.data[f+2]=r.samples[s+2],t.data[f+3]=n===4?r.samples[s+3]:255,s+=n}}}function K1(t,e,r){let n=e.width+r.lightmapPadding*2,i=e.height+r.lightmapPadding*2;if(n>r.atlasSize||i>r.atlasSize)throw new Error("Lightmap too large for atlas");for(let s of t){if(s.cursorX+n>s.width&&(s.cursorX=0,s.cursorY+=s.rowHeight+r.lightmapPadding,s.rowHeight=0),s.cursorY+i>s.height)continue;let c={atlasIndex:t.indexOf(s),x:s.cursorX,y:s.cursorY,width:e.width,height:e.height};return s.cursorX+=n+r.lightmapPadding,s.rowHeight=Math.max(s.rowHeight,i),{placement:c,atlas:s}}let o=W1(r.atlasSize,r.lightmapPadding);t.push(o);let a={atlasIndex:t.length-1,x:0,y:0,width:e.width,height:e.height};return o.cursorX=n+r.lightmapPadding,o.rowHeight=i,{placement:a,atlas:o}}function Gl(t){return t instanceof Float32Array?t:new Float32Array(t)}function Y1(t,e){if(!t){let n=new Uint16Array(e);for(let i=0;i<e;i++)n[i]=i;return n}return t instanceof Uint16Array?t:new Uint16Array(t)}function q1(t,e){let r=new Float32Array(t.length);for(let n=0;n<t.length;n+=2)r[n]=e.offset[0]+t[n]*e.scale[0],r[n+1]=e.offset[1]+t[n+1]*e.scale[1];return r}function Z1(t,e){let r=Gl(t.vertices),n=Gl(t.textureCoords),i=e?q1(Gl(t.lightmapCoords??t.textureCoords),e):Gl(t.lightmapCoords??new Float32Array(n.length)),o=r.length/3;if(n.length/2!==o)throw new Error("Texture coordinates count mismatch");if(i.length/2!==o)throw new Error("Lightmap coordinates count mismatch");let a=new Float32Array(o*7);for(let s=0;s<o;s++){let c=s*3,l=s*2,d=s*7;a[d]=r[c],a[d+1]=r[c+1],a[d+2]=r[c+2],a[d+3]=n[l],a[d+4]=n[l+1],a[d+5]=i[l],a[d+6]=i[l+1]}return a}function Wl(t){let e=[];for(let r=0;r<t.faces.length;r++){let n=t.faces[r];if(n.texInfo<0)continue;let i=t.texInfo[n.texInfo],o=[],a=[],s=[];for(let u=0;u<n.numEdges;u++){let h=t.surfEdges[n.firstEdge+u],m=t.edges[Math.abs(h)],g=h>=0?m.vertices[0]:m.vertices[1],p=t.vertices[g];o.push(p[0],p[1],p[2]);let y=p[0]*i.s[0]+p[1]*i.s[1]+p[2]*i.s[2]+i.sOffset,v=p[0]*i.t[0]+p[1]*i.t[1]+p[2]*i.t[2]+i.tOffset;a.push(y,v),s.push(y,v)}let c=[],l=o.length/3;for(let u=1;u<l-1;u++)c.push(0,u,u+1);let d,f=t.lightMapInfo[r];if(f){let u=1/0,h=-1/0,m=1/0,g=-1/0;for(let _=0;_<a.length;_+=2){let w=a[_],S=a[_+1];w<u&&(u=w),w>h&&(h=w),S<m&&(m=S),S>g&&(g=S)}let p=Math.floor(u/16),y=Math.floor(m/16),v=Math.ceil(h/16)-p+1,x=Math.ceil(g/16)-y+1,b=Ys(n,t.lightMaps,f);if(b&&b.length===v*x*3){d={width:v,height:x,samples:b};for(let _=0;_<s.length;_+=2)s[_]=a[_]/16-p+.5,s[_+1]=a[_+1]/16-y+.5}}e.push({vertices:new Float32Array(o),textureCoords:new Float32Array(a),lightmapCoords:new Float32Array(s),indices:new Uint16Array(c),texture:i.texture,surfaceFlags:i.flags,lightmap:d,faceIndex:r})}return e}function Xl(t,e,r,n={}){let i=e;if(r&&n.hiddenClassnames&&n.hiddenClassnames.size>0){let d=new Set;for(let f of r.entities.entities)if(f.classname&&n.hiddenClassnames.has(f.classname)){let u=f.properties.model;if(u&&u.startsWith("*")){let h=parseInt(u.substring(1),10);if(!isNaN(h)&&h>=0&&h<r.models.length){let m=r.models[h];for(let g=0;g<m.numFaces;g++)d.add(m.firstFace+g)}}}d.size>0&&(i=e.filter(f=>!d.has(f.faceIndex)))}let o={atlasSize:n.atlasSize??1024,lightmapPadding:n.lightmapPadding??1,hiddenClassnames:n.hiddenClassnames??new Set},a=[],s=new Map;i.forEach((d,f)=>{if(!d.lightmap)return;let{placement:u,atlas:h}=K1(a,d.lightmap,o);$1(h,u,d.lightmap),s.set(f,{atlasIndex:u.atlasIndex,offset:[(u.x+o.lightmapPadding)/o.atlasSize,(u.y+o.lightmapPadding)/o.atlasSize],scale:[u.width/o.atlasSize,u.height/o.atlasSize]})});let c=a.map(d=>{let f=new et(t);return f.setParameters({wrapS:t.CLAMP_TO_EDGE,wrapT:t.CLAMP_TO_EDGE,minFilter:t.LINEAR,magFilter:t.LINEAR}),f.uploadImage(0,t.RGBA,d.width,d.height,0,t.RGBA,t.UNSIGNED_BYTE,d.data),{texture:f,width:d.width,height:d.height,pixels:d.data}});return{surfaces:i.map((d,f)=>{let u=s.get(f),h=Z1(d,u),m=Y1(d.indices,h.length/7),g=new Ae(t,t.STATIC_DRAW,t.ARRAY_BUFFER);g.upload(h);let p=new Je(t,t.STATIC_DRAW);p.upload(m);let y=new Le(t);return y.configureAttributes(Ud,g),{vao:y,vertexBuffer:g,indexBuffer:p,indexCount:m.length,vertexCount:h.length/7,texture:d.texture,surfaceFlags:d.surfaceFlags??Wo,lightmap:u,vertexData:h,indexData:m}}),lightmaps:c}}function uo(t){let{normal:e,distance:r}=t,n=Math.sqrt(e.x*e.x+e.y*e.y+e.z*e.z);if(n===0)return t;let i=1/n;return{normal:{x:e.x*i,y:e.y*i,z:e.z*i},distance:r*i}}function Dn(t){if(t.length!==16)throw new Error("View-projection matrix must contain 16 elements");let e=t[0],r=t[4],n=t[8],i=t[12],o=t[1],a=t[5],s=t[9],c=t[13],l=t[2],d=t[6],f=t[10],u=t[14],h=t[3],m=t[7],g=t[11],p=t[15];return[uo({normal:{x:h+e,y:m+r,z:g+n},distance:p+i}),uo({normal:{x:h-e,y:m-r,z:g-n},distance:p-i}),uo({normal:{x:h+o,y:m+a,z:g+s},distance:p+c}),uo({normal:{x:h-o,y:m-a,z:g-s},distance:p-c}),uo({normal:{x:h+l,y:m+d,z:g+f},distance:p+u}),uo({normal:{x:h-l,y:m-d,z:g-f},distance:p-u})]}function j1(t,e){return t.normal.x*e.x+t.normal.y*e.y+t.normal.z*e.z+t.distance}function bi(t,e,r){for(let n of r){let i=n.normal.x>=0?e.x:t.x,o=n.normal.y>=0?e.y:t.y,a=n.normal.z>=0?e.z:t.z;if(j1(n,{x:i,y:o,z:a})<0)return!1}return!0}function Oh(t,e,r){let n=(t.x+e.x)*.5,i=(t.y+e.y)*.5,o=(t.z+e.z)*.5,a=(e.x-t.x)*.5,s=(e.y-t.y)*.5,c=(e.z-t.z)*.5,l=r,d=l[0]*n+l[4]*i+l[8]*o+l[12],f=l[1]*n+l[5]*i+l[9]*o+l[13],u=l[2]*n+l[6]*i+l[10]*o+l[14],h=Math.abs(l[0])*a+Math.abs(l[4])*s+Math.abs(l[8])*c,m=Math.abs(l[1])*a+Math.abs(l[5])*s+Math.abs(l[9])*c,g=Math.abs(l[2])*a+Math.abs(l[6])*s+Math.abs(l[10])*c;return{mins:{x:d-h,y:f-m,z:u-g},maxs:{x:d+h,y:f+m,z:u+g}}}function Nd(t){return t<0}function Hd(t){return-t-1}function Uh(t,e){return t.normal[0]*e.x+t.normal[1]*e.y+t.normal[2]*e.z-t.dist}function Gd(t,e,r){if(!t||e<0||r<0)return!0;let n=Math.ceil(t.numClusters/8),i=t.clusters[e].pvs,o=Math.floor(r/8),a=1<<r%8;return o<0||o>=n?!1:(i[o]&a)!==0}function Q1(t,e){let r={x:t.mins[0],y:t.mins[1],z:t.mins[2]},n={x:t.maxs[0],y:t.maxs[1],z:t.maxs[2]};return bi(r,n,e)}function xi(t,e){if(t.models.length===0)return-1;let r=t.models[0].headNode;for(;r>=0;){let n=t.nodes[r],i=t.planes[n.planeIndex],a=Uh(i,e)>=0?0:1,s=n.children[a];if(Nd(s))return Hd(s);r=s}return Nd(r)?Hd(r):-1}function J1(t,e){let r=t.leafs[e],n=[];for(let i=0;i<r.numLeafFaces;i+=1)n.push(t.leafLists.leafFaces[e][i]);return n}function Vd(t,e,r,n,i,o,a,s){if(Nd(e)){let h=Hd(e),m=t.leafs[h];if(s&&m.area>=0&&!s.has(m.area)||!Gd(t.visibility,i,m.cluster)||!Q1(m,n))return;let g={x:(m.mins[0]+m.maxs[0])*.5,y:(m.mins[1]+m.maxs[1])*.5,z:(m.mins[2]+m.maxs[2])*.5},p=g.x-r.x,y=g.y-r.y,v=g.z-r.z,x=-(p*p+y*y+v*v);for(let b of J1(t,h))a.has(b)||(a.add(b),o.push({faceIndex:b,leafIndex:h,sortKey:x}));return}let c=t.nodes[e],l=t.planes[c.planeIndex],d=Uh(l,r),f=d>=0?c.children[0]:c.children[1],u=d>=0?c.children[1]:c.children[0];bi({x:c.mins[0],y:c.mins[1],z:c.mins[2]},{x:c.maxs[0],y:c.maxs[1],z:c.maxs[2]},n)&&(Vd(t,f,r,n,i,o,a,s),Vd(t,u,r,n,i,o,a,s))}function Wd(t,e,r){let n=new Set;if(e<0||e>=t.areas.length)return n;let i=[e];for(n.add(e);i.length>0;){let o=i.pop(),a=t.areas[o];for(let s=0;s<a.numAreaPortals;s++){let c=a.firstAreaPortal+s,l=t.areaPortals[c],d=l.otherArea;(l.portalNumber<=0||r[l.portalNumber])&&!n.has(d)&&(n.add(d),i.push(d))}}return n}function vi(t,e,r,n){let i=xi(t,e),o=i>=0?t.leafs[i]:null,a=o?o.cluster:-1,s=o?o.area:-1,c=null;n&&s>=0&&t.areas&&t.areas.length>0&&(c=Wd(t,s,n));let l=[],d=new Set;if(t.models.length>0){let f=t.models[0].headNode;Vd(t,f,e,r,a,l,d,c)}return l}var zn=32,$l=class{constructor(){this.lights=[]}addLight(e,r){if(e.key!==void 0){let n=this.lights.findIndex(i=>i.key===e.key);if(n!==-1){this.lights[n]=e;return}}this.lights.push(e)}clear(){this.lights=[]}update(e,r=0){if(this.lights=this.lights.filter(n=>n.die>e),r>0)for(let n of this.lights)n.radiusSpeed!==void 0&&n.radiusSpeed!==0&&(n.intensity+=n.radiusSpeed*r,n.intensity<0&&(n.intensity=0))}getActiveLights(){return this.lights}};function fo(t){let e=[];for(let r=0;r<t.length;r+=3){let n=t[r],i=t[r+1],o=t[r+2];e.push(n,i,i,o,o,n)}return t instanceof Uint32Array||Math.max(...e)>65535?new Uint32Array(e):new Uint16Array(e)}var Xd=`#version 300 es
|
|
141
|
+
ïBçϧmÙIólÜoëVb¦¯éWÇû3`});var Hr={a:Vt};this.setModule=D=>{t.setModule(en,D)},this.getModule=()=>t.getModule(en),this.instantiate=()=>(this.getModule().then(D=>WebAssembly.instantiate(D,Hr)).then(D=>{let ae=D.exports;It(ae),m=ae.l,g(),Nr(ae),r()}),this.ready=new Promise(D=>{r=D}).then(()=>{this.HEAP=m.buffer,this.malloc=sn,this.free=ln,this.create_decoder=Or,this.send_setup=ut,this.init_dsp=tt,this.decode_packets=Gt,this.destroy_decoder=Wn}),this)}function pi(){return this._init=()=>new this._WASMAudioDecoderCommon().instantiate(this._EmscriptenWASM,this._module).then(t=>{this._common=t,this._input=this._common.allocateTypedArray(this._inputSize,Uint8Array),this._firstPage=!0,this._inputLen=this._common.allocateTypedArray(1,Uint32Array),this._outputBufferPtr=this._common.allocateTypedArray(1,Uint32Array),this._channels=this._common.allocateTypedArray(1,Uint32Array),this._sampleRate=this._common.allocateTypedArray(1,Uint32Array),this._samplesDecoded=this._common.allocateTypedArray(1,Uint32Array);let e=256;this._errors=this._common.allocateTypedArray(e,Uint32Array),this._errorsLength=this._common.allocateTypedArray(1,Int32Array),this._frameNumber=0,this._inputBytes=0,this._outputSamples=0,this._decoder=this._common.wasm.create_decoder(this._input.ptr,this._inputLen.ptr,this._outputBufferPtr.ptr,this._channels.ptr,this._sampleRate.ptr,this._samplesDecoded.ptr,this._errors.ptr,this._errorsLength.ptr,e)}),Object.defineProperty(this,"ready",{enumerable:!0,get:()=>this._ready}),this.reset=()=>(this.free(),this._init()),this.free=()=>{this._common.wasm.destroy_decoder(this._decoder),this._common.free()},this.sendSetupHeader=t=>{this._input.buf.set(t),this._inputLen.buf[0]=t.length,this._common.wasm.send_setup(this._decoder,this._firstPage),this._firstPage=!1},this.initDsp=()=>{this._common.wasm.init_dsp(this._decoder)},this.decodePackets=t=>{let e=[],r=0,n=[];for(let i=0;i<t.length;i++){let o=t[i];this._input.buf.set(o),this._inputLen.buf[0]=o.length,this._common.wasm.decode_packets(this._decoder);let a=this._samplesDecoded.buf[0],s=[],c=new Uint32Array(this._common.wasm.HEAP,this._outputBufferPtr.buf[0],this._channels.buf[0]);for(let l=0;l<this._channels.buf[0];l++){let d=new Float32Array(a);a&&d.set(new Float32Array(this._common.wasm.HEAP,c[l],a)),s.push(d)}e.push(s),r+=a,this._frameNumber++,this._inputBytes+=o.length,this._outputSamples+=a;for(let l=0;l<this._errorsLength.buf;l+=2){let d=this._common.codeToString(this._errors.buf[l]),f=this._common.codeToString(this._errors.buf[l+1]);n.push({message:d+" vorbis_synthesis"+f,frameLength:o.length,frameNumber:this._frameNumber,inputBytes:this._inputBytes,outputSamples:this._outputSamples})}this._errorsLength.buf[0]=0}return this._WASMAudioDecoderCommon.getDecodedAudioMultiChannel(n,e,this._channels.buf[0],r,this._sampleRate.buf[0],16)},this._isWebWorker=pi.isWebWorker,this._WASMAudioDecoderCommon=pi.WASMAudioDecoderCommon||ge,this._EmscriptenWASM=pi.EmscriptenWASM||en,this._module=pi.module,this._inputSize=128*1024,this._ready=this._init(),this}var Pl=Symbol(),tn=class{constructor(){this._onCodec=e=>{if(e!=="vorbis")throw new Error("@wasm-audio-decoders/ogg-vorbis does not support this codec "+e)},new ge,this._init(),this._ready=this[Pl](pi)}_init(){this._vorbisSetupInProgress=!0,this._totalSamplesDecoded=0,this._codecParser=new Lh("audio/ogg",{onCodec:this._onCodec,enableFrameCRC32:!1})}async[Pl](e){if(this._decoder){let r=this._decoder;await r.ready.then(()=>r.free())}return this._decoder=new e,this._decoder.ready}get ready(){return this._ready}async reset(){return this._init(),this._decoder.reset()}free(){this._decoder.free()}async decodeOggPages(e){let r=[];for(let o=0;o<e.length;o++){let a=e[o];if(this._vorbisSetupInProgress&&(a[Cl][0]===1&&this._decoder.sendSetupHeader(a[Cl]),a[Rl].length)){let s=a[Rl][0][Th];this._decoder.sendSetupHeader(s[Ch]),this._decoder.initDsp(),this._vorbisSetupInProgress=!1}r.push(...a[Rl].map(s=>s[Cl]))}let n=await this._decoder.decodePackets(r);this._totalSamplesDecoded+=n.samplesDecoded;let i=e[e.length-1];if(i&&i[Rh]){let o=this._totalSamplesDecoded-i[Ph];if(o>0){for(let a=0;a<n.channelData.length;a++)n.channelData[a]=n.channelData[a].subarray(0,n.samplesDecoded-o);n.samplesDecoded-=o,this._totalSamplesDecoded-=o}}return n}async decode(e){return this.decodeOggPages([...this._codecParser.parseChunk(e)])}async flush(){let e=await this.decodeOggPages([...this._codecParser.flush()]);return await this.reset(),e}async decodeFile(e){let r=await this.decodeOggPages([...this._codecParser.parseAll(e)]);return await this.reset(),r}};var Bd=class extends Wi{constructor(e){super(e,"ogg-vorbis-decoder",pi,en)}async sendSetupHeader(e){return this.postToDecoder("sendSetupHeader",e)}async initDsp(){return this.postToDecoder("initDsp")}async decodePackets(e){return this.postToDecoder("decodePackets",e)}},$a=class extends tn{constructor(){super(),this._ready=super[Pl](Bd)}async free(){await this._decoder.free()}terminate(){this._decoder.terminate()}};rl(tn,"OggVorbisDecoder");rl($a,"OggVorbisDecoderWebWorker");var Fd=class extends Error{constructor(e){super(e),this.name="OggDecodeError"}};async function Il(t,e=new tn){await e.ready;let r=await e.decode(new Uint8Array(t)),n=r.errors;if(n&&n.length>0)throw new Fd(n.map(i=>i.message).join("; "));return{sampleRate:r.sampleRate,channels:r.channelData.length,bitDepth:r.bitDepth,channelData:r.channelData}}var Ka=class extends Error{constructor(e){super(e),this.name="AudioRegistryError"}},so=class{constructor(e,r={}){this.vfs=e;this.refCounts=new Map;this.nextRequestId=0;this.cache=new yn(r.cacheSize??64),r.workerPath&&(this.worker=new Worker(r.workerPath,{type:"module"}))}get size(){return this.cache.size}get capacity(){return this.cache.capacity}async load(e){let r=e.toLowerCase(),n=this.cache.get(r);if(n)return this.refCounts.set(r,(this.refCounts.get(r)??0)+1),n;let o=(await this.vfs.readFile(e)).slice().buffer,a=await this.decodeByExtension(e,o);return this.cache.set(r,a),this.refCounts.set(r,1),a}release(e){let r=e.toLowerCase(),n=this.refCounts.get(r)??0;n<=1?(this.cache.delete(r),this.refCounts.delete(r)):this.refCounts.set(r,n-1)}clearAll(){this.cache.clear(),this.refCounts.clear()}set capacity(e){this.cache.capacity=e}async decodeByExtension(e,r){let n=e.toLowerCase();if(n.endsWith(".wav")){if(this.worker)return this.decodeWavInWorker(r);let i=tl(r),o=i.channels,a=Array.from({length:o},()=>new Float32Array(i.samples.length/o));for(let s=0;s<i.samples.length;s+=1)a[s%o][Math.floor(s/o)]=i.samples[s];return{sampleRate:i.sampleRate,channels:o,bitDepth:i.bitsPerSample,channelData:a}}if(n.endsWith(".ogg")||n.endsWith(".oga"))return Il(r);throw new Ka(`Unsupported audio format: ${e}`)}decodeWavInWorker(e){return new Promise((r,n)=>{if(!this.worker){n(new Error("Worker not initialized"));return}let i=this.nextRequestId++,o=a=>{if(a.data.id===i)if(this.worker.removeEventListener("message",o),a.data.type==="success"){let s=a.data.data,c=s.channels,l=Array.from({length:c},()=>new Float32Array(s.samples.length/c));for(let d=0;d<s.samples.length;d+=1)l[d%c][Math.floor(d/c)]=s.samples[d];r({sampleRate:s.sampleRate,channels:c,bitDepth:s.bitsPerSample,channelData:l})}else n(new Error(a.data.message))};this.worker.addEventListener("message",o),this.worker.postMessage({id:i,buffer:e,type:"wav"},[e])})}};var z1="quake2ts-pak-indexes",O1="pak-indexes";function Ih(){if(typeof indexedDB<"u")return indexedDB;if(typeof window<"u"&&"indexedDB"in window)return window.indexedDB;if(typeof globalThis<"u"&&"indexedDB"in globalThis)return globalThis.indexedDB}function Ya(t,e){let r=Ih();return r?new Promise((n,i)=>{let o=r.open(t,1);o.onupgradeneeded=()=>{let{result:a}=o;a.objectStoreNames.contains(e)||a.createObjectStore(e,{keyPath:"key"})},o.onerror=()=>i(o.error??new Error("Unknown IndexedDB error")),o.onsuccess=()=>n(o.result)}):Promise.reject(new Error("IndexedDB is not available in this environment"))}function qa(t,e,r,n){return new Promise((i,o)=>{let s=t.transaction(e,r).objectStore(e),c=n(s);c.onsuccess=()=>i(c.result),c.onerror=()=>o(c.error??new Error("IndexedDB transaction error"))})}function kd(t,e){return`${_e(t)}:${e.toString(16)}`}function U1(t){return t.map(e=>({...e}))}var Bl=class{constructor(e=z1,r=O1){this.dbName=e;this.storeName=r}get isSupported(){return!!Ih()}async persist(e){if(!this.isSupported)return;let r=e.validate(),n={...r,key:kd(e.name,r.checksum),name:e.name,size:e.size,persistedAt:Date.now(),entries:U1(r.entries)},i=await Ya(this.dbName,this.storeName);return await qa(i,this.storeName,"readwrite",o=>o.put(n)),i.close(),n}async find(e,r){if(!this.isSupported)return;let n=await Ya(this.dbName,this.storeName),i=r!==void 0?kd(e,r):void 0,o=await qa(n,this.storeName,"readonly",a=>i?a.get(i):a.getAll());if(n.close(),!!o){if(Array.isArray(o)){let a=_e(e),s=o.filter(c=>_e(c.name)===a);return s.length===0?void 0:s.sort((c,l)=>l.persistedAt-c.persistedAt)[0]}return o}}async remove(e,r){if(!this.isSupported)return!1;let n=await Ya(this.dbName,this.storeName),i=r!==void 0?kd(e,r):void 0,o=await qa(n,this.storeName,"readwrite",a=>{if(i)return a.delete(i);let s=`${_e(e)}:`;return a.delete(IDBKeyRange.bound(s,`${s}\uFFFF`,!1,!0))});return n.close(),typeof o=="number"?o>0:!0}async clear(){if(!this.isSupported)return;let e=await Ya(this.dbName,this.storeName);await qa(e,this.storeName,"readwrite",r=>r.clear()),e.close()}async list(){if(!this.isSupported)return[];let e=await Ya(this.dbName,this.storeName),r=await qa(e,this.storeName,"readonly",n=>n.getAll());return e.close(),r.sort((n,i)=>i.persistedAt-n.persistedAt)}};var gi=class extends Error{constructor(r,n){super(n??`Missing dependencies: ${r.join(", ")}`);this.missing=r;this.name="AssetDependencyError"}},Za=class{constructor(){this.nodes=new Map}register(e,r=[]){let n=this.nodes.get(e)??{dependencies:new Set,loaded:!1};r.forEach(i=>n.dependencies.add(i)),this.nodes.set(e,n),r.forEach(i=>{this.nodes.has(i)||this.nodes.set(i,{dependencies:new Set,loaded:!1})})}markLoaded(e){let r=this.nodes.get(e)??{dependencies:new Set,loaded:!1},n=this.getMissingDependencies(e,r);if(n.length>0)throw new gi(n,`Asset ${e} is missing dependencies: ${n.join(", ")}`);r.loaded=!0,this.nodes.set(e,r)}markUnloaded(e){let r=this.nodes.get(e);r&&(r.loaded=!1)}isLoaded(e){return this.nodes.get(e)?.loaded??!1}missingDependencies(e){let r=this.nodes.get(e);return r?this.getMissingDependencies(e,r):[]}reset(){this.nodes.clear()}getMissingDependencies(e,r){let n=[];for(let i of r.dependencies)this.nodes.get(i)?.loaded||n.push(i);return n}},Fl=class{constructor(e,r={}){this.vfs=e;this.maps=new Map;this.loadQueue=[];this.activeLoads=0;this.textures=new Gi({capacity:r.textureCacheCapacity??128,maxMemory:r.textureMemoryLimit}),this.audio=new so(e,{cacheSize:r.audioCacheSize??64,workerPath:r.audioWorkerPath}),this.dependencyTracker=r.dependencyTracker??new Za,this.resourceTracker=r.resourceTracker,this.md2=new Ni(e),this.md3=new Hi(e),this.sprite=new Vi(e),this.bsp=new Ui(e,{useWorker:!!r.bspWorkerPath,workerPath:r.bspWorkerPath}),this.maxConcurrentLoads=r.maxConcurrentLoads??4,this.palette=new Uint8Array(768);for(let n=0;n<256;n++)this.palette[n*3]=n,this.palette[n*3+1]=n,this.palette[n*3+2]=n}async loadPalette(e="pics/colormap.pcx"){try{let r=await this.vfs.readFile(e),n=ta(r);n.palette&&(this.palette=n.palette)}catch(r){console.warn(`Failed to load palette from ${e}:`,r)}}isAssetLoaded(e,r){return this.dependencyTracker.isLoaded(this.makeKey(e,r))}registerTexture(e,r){this.textures.set(e,r);let n=this.makeKey("texture",e);this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n)}async loadTexture(e){if(this.resourceTracker){let a=this.vfs.stat(e);this.resourceTracker.recordLoad("texture",e,a?.size,a?.sourcePak)}let r=this.textures.get(e);if(r)return r;let n=await this.vfs.readFile(e),i=e.split(".").pop()?.toLowerCase(),o;if(i==="wal")o=el(n,this.palette);else if(i==="pcx")o=Js(ta(n));else if(i==="tga")o=rh(hd(n));else throw new Error(`Unsupported texture format for loadTexture: ${i}`);return this.registerTexture(e,o),o}async loadSound(e){if(this.resourceTracker){let i=this.vfs.stat(e);this.resourceTracker.recordLoad("sound",e,i?.size,i?.sourcePak)}let r=await this.audio.load(e),n=this.makeKey("sound",e);return this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n),r}async loadMd2Model(e,r=[]){if(this.resourceTracker){let s=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,s?.size,s?.sourcePak)}let n=this.makeKey("model",e),i=r.map(s=>this.makeKey("texture",s));this.dependencyTracker.register(n,i);let o=this.dependencyTracker.missingDependencies(n);if(o.length>0)throw new gi(o,`Asset ${n} is missing dependencies: ${o.join(", ")}`);let a=await this.md2.load(e);return this.dependencyTracker.markLoaded(n),a}getMd2Model(e){if(this.resourceTracker){let r=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,r?.size,r?.sourcePak)}return this.md2.get(e)}async loadMd3Model(e,r=[]){if(this.resourceTracker){let s=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,s?.size,s?.sourcePak)}let n=this.makeKey("model",e),i=r.map(s=>this.makeKey("texture",s));this.dependencyTracker.register(n,i);let o=this.dependencyTracker.missingDependencies(n);if(o.length>0)throw new gi(o,`Asset ${n} is missing dependencies: ${o.join(", ")}`);let a=await this.md3.load(e);return this.dependencyTracker.markLoaded(n),a}getMd3Model(e){if(this.resourceTracker){let r=this.vfs.stat(e);this.resourceTracker.recordLoad("model",e,r?.size,r?.sourcePak)}return this.md3.get(e)}async loadSprite(e){if(this.resourceTracker){let i=this.vfs.stat(e);this.resourceTracker.recordLoad("sprite",e,i?.size,i?.sourcePak)}let r=this.makeKey("sprite",e);this.dependencyTracker.register(r);let n=await this.sprite.load(e);return this.dependencyTracker.markLoaded(r),n}async loadMap(e){if(this.resourceTracker){let i=this.vfs.stat(e);this.resourceTracker.recordLoad("map",e,i?.size,i?.sourcePak)}let r=this.makeKey("map",e);if(this.maps.has(e))return this.maps.get(e);this.dependencyTracker.register(r);let n=await this.bsp.load(e);return this.maps.set(e,n),this.dependencyTracker.markLoaded(r),n}getMap(e){return this.maps.get(e)}listFiles(e){return this.vfs.findByExtension(e)}resetForLevelChange(){this.textures.clear(),this.audio.clearAll(),this.dependencyTracker.reset(),this.maps.clear(),this.loadQueue.length=0}getMemoryUsage(){let e=0,r=0;if(typeof process<"u"&&process.memoryUsage){let n=process.memoryUsage();e=n.heapTotal,r=n.heapUsed}return{textures:this.textures.memoryUsage,audio:this.audio.size,heapTotal:e,heapUsed:r}}enforceMemoryBudget(e){e.textureMemoryLimit!==void 0&&(this.textures.maxMemory=e.textureMemoryLimit),e.textureCacheCapacity!==void 0&&(this.textures.capacity=e.textureCacheCapacity),e.audioCacheSize!==void 0&&(this.audio.capacity=e.audioCacheSize)}clearCache(e){switch(e){case"texture":this.textures.clear();break;case"sound":this.audio.clearAll();break;case"map":this.maps.clear();break}}async preloadAssets(e){let r=e.map(n=>{let i=this.detectAssetType(n);return i?this.queueLoad(n,i,0):Promise.resolve()});await Promise.all(r)}queueLoad(e,r,n=1){return r==="texture"&&this.textures.get(e)?Promise.resolve(this.textures.get(e)):new Promise((i,o)=>{this.loadQueue.push({path:e,type:r,priority:n,resolve:i,reject:o}),this.loadQueue.sort((a,s)=>s.priority-a.priority),this.processQueue()})}async processQueue(){if(this.activeLoads>=this.maxConcurrentLoads||this.loadQueue.length===0)return;let e=this.loadQueue.shift();this.activeLoads++;try{let r;switch(e.type){case"texture":r=await this.loadTexture(e.path);break;case"sound":r=await this.loadSound(e.path);break;case"model":e.path.endsWith(".md2")?r=await this.loadMd2Model(e.path):e.path.endsWith(".md3")&&(r=await this.loadMd3Model(e.path));break;case"sprite":r=await this.loadSprite(e.path);break;case"map":r=await this.loadMap(e.path);break;default:throw new Error(`Unknown asset type ${e.type}`)}e.resolve(r)}catch(r){e.reject(r)}finally{this.activeLoads--,this.processQueue()}}detectAssetType(e){let r=e.split(".").pop()?.toLowerCase();return r?["wal","pcx","tga","png","jpg"].includes(r)?"texture":["wav","ogg"].includes(r)?"sound":["md2","md3"].includes(r)?"model":["sp2"].includes(r)?"sprite":["bsp"].includes(r)?"map":null:null}makeKey(e,r){return`${e}:${_e(r)}`}};var kl=class{constructor(e){this.factory=e}getContext(){return this.context||(this.context=this.factory()),this.context}async resume(){let e=this.getContext();e.state==="suspended"&&await e.resume()}getState(){return this.context?.state??"suspended"}};function Dl(t){let e=t.getContext(),r=e.createGain();r.gain.value=1;let n=e.createDynamicsCompressor(),i=e.createBiquadFilter?.(),o;if(e.createConvolver&&e.createGain){let a=e.createConvolver(),s=e.createGain(),c=e.createGain();s.connect(a),a.connect(c),o={convolver:a,input:s,output:c}}return i?(i.type="lowpass",i.frequency.value=2e4,i.Q.value=.707,r.connect(i),i.connect(n),o&&o.output.connect(i)):(r.connect(n),o&&o.output.connect(n)),n.connect(e.destination),{context:e,master:r,compressor:n,filter:i,reverb:o}}var zl=class{constructor(e=new zi){this.configStrings=e;this.buffers=new Map}registerName(e){return this.configStrings.soundIndex(e)}register(e,r){let n=this.registerName(e);return this.buffers.set(n,r),n}find(e){return this.configStrings.findSoundIndex(e)}get(e){return this.buffers.get(e)}has(e){return this.buffers.has(e)}getName(e){return this.configStrings.getName(e)}};var Ol=class{constructor(e){this.vfs=e.vfs,this.registry=e.registry,this.contextController=e.context,this.soundRoot=e.soundRoot??"sound/",this.decodeAudio=e.decodeAudio??((r,n)=>{if(!r.decodeAudioData)throw new Error("decodeAudioData is not available on the provided audio context");return r.decodeAudioData(n)})}async precache(e){let r=[...new Set(e.map(o=>this.normalize(o)))],n={loaded:[],skipped:[],missing:[],errors:{}},i=this.contextController.getContext();for(let o of r)try{let a=this.registry.find(o);if(a!==void 0&&this.registry.has(a)){n.skipped.push(o);continue}if(!this.vfs.stat(o)){n.missing.push(o);continue}let l=(await this.vfs.readFile(o)).slice().buffer,d=await this.decodeAudio(i,l);this.registry.register(o,d),n.loaded.push(o)}catch(a){let s=a instanceof Error?a:new Error(String(a));n.errors[o]=s}return n}normalize(e){let r=_e(e.replace(/^\//,""));return r.startsWith(this.soundRoot)?r:_e(`${this.soundRoot}${r}`)}};var N1=7,ja=t=>t&N1;function Ul(t){return Array.from({length:Ko},()=>({entnum:0,entchannel:Mr.Auto,endTimeMs:0,isPlayer:!1,active:!1})).map(e=>({...e,isPlayer:e.entnum===t}))}function Nl(t,e,r,n){if(r<0)throw new Error("pickChannel: entchannel must be non-negative");let i=ja(r),o=-1,a=Number.POSITIVE_INFINITY;for(let s=0;s<t.length;s+=1){let c=t[s],l=ja(c.entchannel);if(i!==Mr.Auto&&c.entnum===e&&l===i){o=s;break}if(c.active&&c.entnum===n.playerEntity&&e!==n.playerEntity)continue;let d=c.endTimeMs-n.nowMs;(o===-1||d<a)&&(a=d,o=s)}return o===-1?void 0:o}var Hl=class{constructor(e){this.activePreset=null;this.enabled=!0;this.node=e,this.node.input.gain.value=.5,this.node.output.gain.value=1}setPreset(e){this.activePreset=e,this.node.convolver.buffer!==(e?.buffer??null)&&(this.node.convolver.buffer=e?.buffer??null),e&&e.gain!==void 0?this.node.output.gain.value=e.gain:this.node.output.gain.value=1}setEnabled(e){this.enabled=e,e?this.node.input.gain.value=.5:this.node.input.gain.value=0}getOutputNode(){return this.node.output}getInputNode(){return this.node.input}};var Vl=class{constructor(e){this.activeSources=new Map;this.playbackRate=1;this.contextController=e.context,this.registry=e.registry,this.playerEntity=e.playerEntity,this.channels=Ul(e.playerEntity),this.listener=e.listener??{origin:xf,right:{x:1,y:0,z:0}},this.sfxVolume=e.sfxVolume??1,this.masterVolume=e.masterVolume??1,this.resolveOcclusion=e.resolveOcclusion,this.graph=Dl(this.contextController),this.graph.master.gain.value=this.masterVolume,this.graph.reverb&&(this.reverb=new Hl(this.graph.reverb))}setListener(e){this.listener=e}setMasterVolume(e){this.masterVolume=e,this.graph.master.gain.value=e}setSfxVolume(e){this.sfxVolume=e}setPlaybackRate(e){this.playbackRate=e;for(let r of this.activeSources.values())r.source.playbackRate&&(r.source.playbackRate.value=e),this.updateSourceGain(r)}async ensureRunning(){await this.contextController.resume()}setReverbPreset(e){this.reverb?.setPreset(e)}play(e){let r=this.registry.get(e.soundIndex);if(!r)return;let n=this.graph.context,i=n.currentTime*1e3,o=Nl(this.channels,e.entity,e.channel,{nowMs:i,playerEntity:this.playerEntity});if(o===void 0)return;let a=this.activeSources.get(o);a&&(a.source.onended=null,a.source.stop(),this.activeSources.delete(o));let s=n.createBufferSource();s.buffer=r,s.loop=e.looping??!1,s.playbackRate&&(s.playbackRate.value=this.playbackRate);let c=e.origin??this.listener.origin,l=n.createGain(),d=this.createPanner(n,e.attenuation),f=this.resolveOcclusion?.(this.listener,c,e.attenuation),u=Bh(f?.gainScale??1),h=this.resolveOcclusion?this.createOcclusionFilter(n,f?.lowpassHz??2e4):void 0;this.applyOriginToPanner(d,c);let g=e.volume/255*this.sfxVolume,p=Math.abs(this.playbackRate-1)<.001?1:0;l.gain.value=g*u*p;let y=n.currentTime+(e.timeOffsetMs??0)/1e3,v=(e.looping?Number.POSITIVE_INFINITY:r.duration*1e3)+y*1e3;s.connect(d);let x=d;h?(d.connect(h),h.connect(l),x=l):(d.connect(l),x=l),l.connect(this.graph.master),this.reverb&&l.connect(this.reverb.getInputNode()),s.start(y),s.onended=()=>{this.channels[o].active=!1,this.activeSources.delete(o)};let b={channelIndex:o,entnum:e.entity,entchannel:ja(e.channel),endTimeMs:v,source:s,panner:d,gain:l,baseGain:g,origin:c,attenuation:e.attenuation,occlusion:h?{scale:u,lowpassHz:f?.lowpassHz,filter:h}:f?{scale:u,lowpassHz:f.lowpassHz}:void 0};return this.channels[o]={entnum:e.entity,entchannel:ja(e.channel),endTimeMs:v,isPlayer:e.entity===this.playerEntity,active:!0},this.activeSources.set(o,b),b}stop(e){let r=this.activeSources.get(e);r&&(r.source.stop(),this.channels[e].active=!1,this.activeSources.delete(e))}stopEntitySounds(e){for(let[r,n]of[...this.activeSources.entries()])n.entnum===e&&(n.source.stop(),this.channels[r].active=!1,this.activeSources.delete(r))}updateEntityPosition(e,r){for(let n of this.activeSources.values())if(n.entnum===e&&(this.applyOriginToPanner(n.panner,r),n.origin=r,this.resolveOcclusion)){let i=this.resolveOcclusion(this.listener,r,n.attenuation);this.applyOcclusion(n,i)}}positionedSound(e,r,n,i){return this.play({entity:0,channel:Mr.Auto,soundIndex:r,volume:n,attenuation:i,origin:e})}ambientSound(e,r,n){return this.play({entity:0,channel:Mr.Auto,soundIndex:r,volume:n,attenuation:Yo,origin:e,looping:!0})}getChannelState(e){return this.channels[e]}getDiagnostics(){return{activeChannels:this.activeSources.size,masterVolume:this.masterVolume,sfxVolume:this.sfxVolume,channels:[...this.channels],activeSounds:[...this.activeSources.values()].map(e=>({entnum:e.entnum,entchannel:e.entchannel,channelIndex:e.channelIndex,origin:e.origin,gain:e.gain.gain.value,baseGain:e.baseGain,attenuation:e.attenuation,maxDistance:e.panner.maxDistance,distanceModel:e.panner.distanceModel,occlusion:e.occlusion?{scale:e.occlusion.scale,lowpassHz:e.occlusion.lowpassHz}:void 0}))}}setUnderwater(e,r=400){let n=this.graph.filter;n&&(n.type="lowpass",n.Q.value=.707,n.frequency.value=e?r:2e4)}createPanner(e,r){let n=e.createPanner?e.createPanner():Object.assign(e.createGain(),{positionX:{value:this.listener.origin.x},positionY:{value:this.listener.origin.y},positionZ:{value:this.listener.origin.z}});return this.configurePanner(n,r)}configurePanner(e,r){let n=Bi(r);return e.refDistance=Ii,e.maxDistance=Jn(r),e.rolloffFactor=n,e.distanceModel="linear",e.positionX.value=this.listener.origin.x,e.positionY.value=this.listener.origin.y,e.positionZ.value=this.listener.origin.z,e}applyOriginToPanner(e,r){e.positionX.value=r.x,e.positionY.value=r.y,e.positionZ.value=r.z}createOcclusionFilter(e,r){if(!e.createBiquadFilter)return;let n=e.createBiquadFilter();return n.type="lowpass",n.Q.value=.707,n.frequency.value=Dd(r,10,2e4),n}updateSourceGain(e){let r=e.occlusion?.scale??1,n=Math.abs(this.playbackRate-1)<.001?1:0;e.gain.gain.value=e.baseGain*r*n}applyOcclusion(e,r){let n=Bh(r?.gainScale??1),i=Math.abs(this.playbackRate-1)<.001?1:0;if(e.gain.gain.value=e.baseGain*n*i,e.occlusion?.filter){let o=r?.lowpassHz??2e4;e.occlusion.filter.frequency.value=Dd(o,10,2e4)}e.occlusion?(e.occlusion.scale=n,e.occlusion.lowpassHz=r?.lowpassHz):r&&(e.occlusion={scale:n,lowpassHz:r.lowpassHz})}},Dd=(t,e,r)=>Math.min(r,Math.max(e,t)),Bh=t=>Dd(t,0,1);var Qa=class{constructor(e){this.trace=e;this.resolve=(e,r,n)=>{let i=Gc(vf(r,e.origin)),o=Jn(n),c=2e4*(1-Math.min(i,o)/Math.max(1,o)*.9),l=this.trace(e.origin,r,void 0,void 0),d=1,f=2e4;l.fraction<1&&(d=.3,f=400);let u=Math.min(c,f);if(d<1||u<2e4)return{gainScale:d,lowpassHz:u}}}};function Fh(t){return new Qa(t).resolve}var Gl=class{constructor(e){this.createElement=e.createElement,this.resolveSource=e.resolveSource??(async r=>r),this.volume=e.volume??1,this.crossfadeDuration=e.crossfadeDuration??1}async playTrack(e){let r=`music/track${e.toString().padStart(2,"0")}.ogg`;return this.play(r)}async play(e,{loop:r=!0,restart:n=!1}={}){if(this.track===e&&this.currentElement){this.currentElement.loop=r,this.cancelFade(),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0),this.currentElement.volume=this.volume,n&&(this.currentElement.currentTime=0),(this.currentElement.paused||n)&&await this.currentElement.play();return}let i=await this.resolveSource(e);this.cancelFade(),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0),this.currentElement&&(this.fadingElement=this.currentElement,this.currentElement=void 0);let o=this.createElement();o.src=i,o.loop=r,o.volume=0,o.currentTime=0,o.load();try{await o.play()}catch(a){console.warn(`MusicSystem: Failed to play ${e}`,a),this.fadingElement}this.currentElement=o,this.track=e,this.startCrossfade()}pause(){this.cancelFade(),this.currentElement&&!this.currentElement.paused&&this.currentElement.pause(),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0)}async resume(){!this.currentElement||!this.currentElement.paused||(await this.currentElement.play(),this.currentElement.volume=this.volume)}stop(){this.cancelFade(),this.currentElement&&(this.currentElement.pause(),this.currentElement.currentTime=0,this.currentElement=void 0),this.fadingElement&&(this.fadingElement.pause(),this.fadingElement=void 0),this.track=void 0}setVolume(e){this.volume=e,this.currentElement&&!this.fadeInterval&&(this.currentElement.volume=e)}getState(){let e=!!(this.currentElement&&!this.currentElement.paused&&!this.currentElement.ended),r=!!this.currentElement?.paused;return{track:this.track,paused:r,playing:e,volume:this.volume}}startCrossfade(){let r=this.crossfadeDuration*1e3/50,n=this.volume/r,i=0,o=this.fadingElement?this.fadingElement.volume:0,a=()=>{let s=!1;this.currentElement&&(i=Math.min(this.volume,i+n),this.currentElement.volume=i,i<this.volume&&(s=!0)),this.fadingElement&&(o=Math.max(0,o-n),this.fadingElement.volume=o,o>0?s=!0:(this.fadingElement.pause(),this.fadingElement=void 0)),s||this.cancelFade()};a(),(this.currentElement&&this.currentElement.volume<this.volume||this.fadingElement)&&(this.fadeInterval=setInterval(a,50))}cancelFade(){this.fadeInterval&&(clearInterval(this.fadeInterval),this.fadeInterval=void 0)}};function H1(t){t.enable(t.DEPTH_TEST),t.depthFunc(t.LEQUAL),t.enable(t.CULL_FACE),t.cullFace(t.BACK),t.enable(t.BLEND),t.blendFuncSeparate(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA,t.ONE,t.ONE_MINUS_SRC_ALPHA)}function V1(t,e,r,n){for(let i of e){let o=t.getExtension(i);if(!o)throw new Error(`Missing required WebGL extension: ${i}`);n.set(i,o)}for(let i of r){let o=t.getExtension(i);o&&n.set(i,o)}}function kh(t,e={}){let{contextAttributes:r,requiredExtensions:n=[],optionalExtensions:i=[]}=e,o=t.getContext("webgl2",r??{antialias:!0});if(!o)throw new Error("WebGL2 not supported or failed to initialize");H1(o);let a=new Map;V1(o,n,i,a);let s=!1,c=new Set,l=new Set,d=u=>{s=!0,u.preventDefault();for(let h of c)h()},f=()=>{s=!1;for(let u of l)u()};return t.addEventListener("webglcontextlost",d),t.addEventListener("webglcontextrestored",f),{gl:o,extensions:a,isLost:()=>s,onLost(u){return c.add(u),()=>c.delete(u)},onRestored(u){return l.add(u),()=>l.delete(u)},dispose(){t.removeEventListener("webglcontextlost",d),t.removeEventListener("webglcontextrestored",f),c.clear(),l.clear(),a.clear()}}}function Dh(t,e,r){let n=t.createShader(e);if(!n)throw new Error("Failed to allocate shader");if(t.shaderSource(n,r.trim()),t.compileShader(n),!t.getShaderParameter(n,t.COMPILE_STATUS)){let o=t.getShaderInfoLog(n)??"Unknown shader compile failure";throw t.deleteShader(n),new Error(o)}return n}function G1(t,e,r,n){let i=t.createProgram();if(!i)throw new Error("Failed to allocate shader program");if(t.attachShader(i,e),t.attachShader(i,r),n)for(let[a,s]of Object.entries(n))t.bindAttribLocation(i,s,a);if(t.linkProgram(i),!t.getProgramParameter(i,t.LINK_STATUS)){let a=t.getProgramInfoLog(i)??"Unknown shader link failure";throw t.deleteProgram(i),new Error(a)}return i}var le=class t{constructor(e,r,n){this.uniformLocations=new Map;this.attributeLocations=new Map;this.gl=e,this.program=r,this.sourceSize=n}static create(e,r,n){let i=Dh(e,e.VERTEX_SHADER,r.vertex),o=Dh(e,e.FRAGMENT_SHADER,r.fragment);try{let a=G1(e,i,o,n),s=r.vertex.length+r.fragment.length;return new t(e,a,s)}finally{e.deleteShader(i),e.deleteShader(o)}}use(){this.gl.useProgram(this.program)}getUniformLocation(e){if(!this.uniformLocations.has(e)){let r=this.gl.getUniformLocation(this.program,e);this.uniformLocations.set(e,r)}return this.uniformLocations.get(e)??null}getAttributeLocation(e){if(!this.attributeLocations.has(e)){let r=this.gl.getAttribLocation(this.program,e);this.attributeLocations.set(e,r)}return this.attributeLocations.get(e)??-1}dispose(){this.gl.deleteProgram(this.program),this.uniformLocations.clear(),this.attributeLocations.clear()}};function zh(t,e,r){return le.create(t,e,r)}var Ae=class{constructor(e,r=e.STATIC_DRAW,n){this.gl=e,this.target=n??e.ARRAY_BUFFER;let i=e.createBuffer();if(!i)throw new Error("Failed to allocate buffer");this.buffer=i,e.bindBuffer(this.target,this.buffer),e.bufferData(this.target,0,r)}bind(){this.gl.bindBuffer(this.target,this.buffer)}upload(e,r=this.gl.STATIC_DRAW){this.bind(),this.gl.bufferData(this.target,e,r)}update(e,r=0){this.bind(),this.gl.bufferSubData(this.target,r,e)}dispose(){this.gl.deleteBuffer(this.buffer)}},Je=class extends Ae{constructor(e,r=e.STATIC_DRAW){super(e,r,e.ELEMENT_ARRAY_BUFFER)}},Le=class{constructor(e){this.gl=e;let r=e.createVertexArray();if(!r)throw new Error("Failed to allocate vertex array object");this.vao=r}bind(){this.gl.bindVertexArray(this.vao)}configureAttributes(e,r){this.bind(),r&&r.bind();for(let n of e)this.gl.enableVertexAttribArray(n.index),this.gl.vertexAttribPointer(n.index,n.size,n.type,n.normalized??!1,n.stride??0,n.offset??0),n.divisor!==void 0&&this.gl.vertexAttribDivisor(n.index,n.divisor)}dispose(){this.gl.deleteVertexArray(this.vao)}},et=class{constructor(e,r=e.TEXTURE_2D){this.width=0;this.height=0;this.gl=e,this.target=r;let n=e.createTexture();if(!n)throw new Error("Failed to allocate texture");this.texture=n}bind(e=0){this.gl.activeTexture(this.gl.TEXTURE0+e),this.gl.bindTexture(this.target,this.texture)}setParameters(e){this.bind(),e.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,e.wrapS),e.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,e.wrapT),e.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,e.minFilter),e.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,e.magFilter)}upload(e,r,n){this.width=e,this.height=r,this.uploadImage(0,this.gl.RGBA,e,r,0,this.gl.RGBA,this.gl.UNSIGNED_BYTE,n)}uploadImage(e,r,n,i,o,a,s,c){this.bind(),this.gl.texImage2D(this.target,e,r,n,i,o,a,s,c)}dispose(){this.gl.deleteTexture(this.texture)}},lo=class{constructor(e){this.gl=e,this.target=e.TEXTURE_CUBE_MAP;let r=e.createTexture();if(!r)throw new Error("Failed to allocate cubemap texture");this.texture=r}bind(e=0){this.gl.activeTexture(this.gl.TEXTURE0+e),this.gl.bindTexture(this.target,this.texture)}setParameters(e){this.bind(),e.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,e.wrapS),e.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,e.wrapT),e.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,e.minFilter),e.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,e.magFilter)}uploadFace(e,r,n,i,o,a,s,c,l){this.bind(),this.gl.texImage2D(e,r,n,i,o,a,s,c,l)}dispose(){this.gl.deleteTexture(this.texture)}},yi=class{constructor(e){this.gl=e;let r=e.createFramebuffer();if(!r)throw new Error("Failed to allocate framebuffer");this.framebuffer=r}bind(e=this.gl.FRAMEBUFFER){this.gl.bindFramebuffer(e,this.framebuffer)}attachTexture2D(e,r,n=0){this.bind(),this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER,e,r.target,r.texture,n)}dispose(){this.gl.deleteFramebuffer(this.framebuffer)}};var Od=4,zd=7*Od,Ud=[{index:0,size:3,type:5126,stride:zd,offset:0},{index:1,size:2,type:5126,stride:zd,offset:3*Od},{index:2,size:2,type:5126,stride:zd,offset:5*Od}];function W1(t,e){return{width:t,height:t,padding:e,data:new Uint8Array(t*t*4),cursorX:0,cursorY:0,rowHeight:0}}function X1(t){let e=t.width*t.height;if(e===0)throw new Error("Invalid lightmap with zero area");let r=t.samples.byteLength/e;if(!Number.isInteger(r)||r<3||r>4)throw new Error("Unsupported lightmap channel count");return r}function $1(t,e,r){let n=X1(r),i=t.width*4,o=e.x+t.padding,a=e.y+t.padding,s=0;for(let c=0;c<r.height;c++){let l=(a+c)*i+o*4;for(let d=0;d<r.width;d++){let f=l+d*4;t.data[f]=r.samples[s],t.data[f+1]=r.samples[s+1],t.data[f+2]=r.samples[s+2],t.data[f+3]=n===4?r.samples[s+3]:255,s+=n}}}function K1(t,e,r){let n=e.width+r.lightmapPadding*2,i=e.height+r.lightmapPadding*2;if(n>r.atlasSize||i>r.atlasSize)throw new Error("Lightmap too large for atlas");for(let s of t){if(s.cursorX+n>s.width&&(s.cursorX=0,s.cursorY+=s.rowHeight+r.lightmapPadding,s.rowHeight=0),s.cursorY+i>s.height)continue;let c={atlasIndex:t.indexOf(s),x:s.cursorX,y:s.cursorY,width:e.width,height:e.height};return s.cursorX+=n+r.lightmapPadding,s.rowHeight=Math.max(s.rowHeight,i),{placement:c,atlas:s}}let o=W1(r.atlasSize,r.lightmapPadding);t.push(o);let a={atlasIndex:t.length-1,x:0,y:0,width:e.width,height:e.height};return o.cursorX=n+r.lightmapPadding,o.rowHeight=i,{placement:a,atlas:o}}function Wl(t){return t instanceof Float32Array?t:new Float32Array(t)}function Y1(t,e){if(!t){let n=new Uint16Array(e);for(let i=0;i<e;i++)n[i]=i;return n}return t instanceof Uint16Array?t:new Uint16Array(t)}function q1(t,e){let r=new Float32Array(t.length);for(let n=0;n<t.length;n+=2)r[n]=e.offset[0]+t[n]*e.scale[0],r[n+1]=e.offset[1]+t[n+1]*e.scale[1];return r}function Z1(t,e){let r=Wl(t.vertices),n=Wl(t.textureCoords),i=e?q1(Wl(t.lightmapCoords??t.textureCoords),e):Wl(t.lightmapCoords??new Float32Array(n.length)),o=r.length/3;if(n.length/2!==o)throw new Error("Texture coordinates count mismatch");if(i.length/2!==o)throw new Error("Lightmap coordinates count mismatch");let a=new Float32Array(o*7);for(let s=0;s<o;s++){let c=s*3,l=s*2,d=s*7;a[d]=r[c],a[d+1]=r[c+1],a[d+2]=r[c+2],a[d+3]=n[l],a[d+4]=n[l+1],a[d+5]=i[l],a[d+6]=i[l+1]}return a}function Xl(t){let e=[];for(let r=0;r<t.faces.length;r++){let n=t.faces[r];if(n.texInfo<0)continue;let i=t.texInfo[n.texInfo],o=[],a=[],s=[];for(let u=0;u<n.numEdges;u++){let h=t.surfEdges[n.firstEdge+u],m=t.edges[Math.abs(h)],g=h>=0?m.vertices[0]:m.vertices[1],p=t.vertices[g];o.push(p[0],p[1],p[2]);let y=p[0]*i.s[0]+p[1]*i.s[1]+p[2]*i.s[2]+i.sOffset,v=p[0]*i.t[0]+p[1]*i.t[1]+p[2]*i.t[2]+i.tOffset;a.push(y,v),s.push(y,v)}let c=[],l=o.length/3;for(let u=1;u<l-1;u++)c.push(0,u,u+1);let d,f=t.lightMapInfo[r];if(f){let u=1/0,h=-1/0,m=1/0,g=-1/0;for(let _=0;_<a.length;_+=2){let w=a[_],S=a[_+1];w<u&&(u=w),w>h&&(h=w),S<m&&(m=S),S>g&&(g=S)}let p=Math.floor(u/16),y=Math.floor(m/16),v=Math.ceil(h/16)-p+1,x=Math.ceil(g/16)-y+1,b=qs(n,t.lightMaps,f);if(b&&b.length===v*x*3){d={width:v,height:x,samples:b};for(let _=0;_<s.length;_+=2)s[_]=a[_]/16-p+.5,s[_+1]=a[_+1]/16-y+.5}}e.push({vertices:new Float32Array(o),textureCoords:new Float32Array(a),lightmapCoords:new Float32Array(s),indices:new Uint16Array(c),texture:i.texture,surfaceFlags:i.flags,lightmap:d,faceIndex:r})}return e}function $l(t,e,r,n={}){let i=e;if(r&&n.hiddenClassnames&&n.hiddenClassnames.size>0){let d=new Set;for(let f of r.entities.entities)if(f.classname&&n.hiddenClassnames.has(f.classname)){let u=f.properties.model;if(u&&u.startsWith("*")){let h=parseInt(u.substring(1),10);if(!isNaN(h)&&h>=0&&h<r.models.length){let m=r.models[h];for(let g=0;g<m.numFaces;g++)d.add(m.firstFace+g)}}}d.size>0&&(i=e.filter(f=>!d.has(f.faceIndex)))}let o={atlasSize:n.atlasSize??1024,lightmapPadding:n.lightmapPadding??1,hiddenClassnames:n.hiddenClassnames??new Set},a=[],s=new Map;i.forEach((d,f)=>{if(!d.lightmap)return;let{placement:u,atlas:h}=K1(a,d.lightmap,o);$1(h,u,d.lightmap),s.set(f,{atlasIndex:u.atlasIndex,offset:[(u.x+o.lightmapPadding)/o.atlasSize,(u.y+o.lightmapPadding)/o.atlasSize],scale:[u.width/o.atlasSize,u.height/o.atlasSize]})});let c=a.map(d=>{let f=new et(t);return f.setParameters({wrapS:t.CLAMP_TO_EDGE,wrapT:t.CLAMP_TO_EDGE,minFilter:t.LINEAR,magFilter:t.LINEAR}),f.uploadImage(0,t.RGBA,d.width,d.height,0,t.RGBA,t.UNSIGNED_BYTE,d.data),{texture:f,width:d.width,height:d.height,pixels:d.data}});return{surfaces:i.map((d,f)=>{let u=s.get(f),h=Z1(d,u),m=Y1(d.indices,h.length/7),g=new Ae(t,t.STATIC_DRAW,t.ARRAY_BUFFER);g.upload(h);let p=new Je(t,t.STATIC_DRAW);p.upload(m);let y=new Le(t);return y.configureAttributes(Ud,g),{vao:y,vertexBuffer:g,indexBuffer:p,indexCount:m.length,vertexCount:h.length/7,texture:d.texture,surfaceFlags:d.surfaceFlags??Go,lightmap:u,vertexData:h,indexData:m}}),lightmaps:c}}function co(t){let{normal:e,distance:r}=t,n=Math.sqrt(e.x*e.x+e.y*e.y+e.z*e.z);if(n===0)return t;let i=1/n;return{normal:{x:e.x*i,y:e.y*i,z:e.z*i},distance:r*i}}function Dn(t){if(t.length!==16)throw new Error("View-projection matrix must contain 16 elements");let e=t[0],r=t[4],n=t[8],i=t[12],o=t[1],a=t[5],s=t[9],c=t[13],l=t[2],d=t[6],f=t[10],u=t[14],h=t[3],m=t[7],g=t[11],p=t[15];return[co({normal:{x:h+e,y:m+r,z:g+n},distance:p+i}),co({normal:{x:h-e,y:m-r,z:g-n},distance:p-i}),co({normal:{x:h+o,y:m+a,z:g+s},distance:p+c}),co({normal:{x:h-o,y:m-a,z:g-s},distance:p-c}),co({normal:{x:h+l,y:m+d,z:g+f},distance:p+u}),co({normal:{x:h-l,y:m-d,z:g-f},distance:p-u})]}function j1(t,e){return t.normal.x*e.x+t.normal.y*e.y+t.normal.z*e.z+t.distance}function bi(t,e,r){for(let n of r){let i=n.normal.x>=0?e.x:t.x,o=n.normal.y>=0?e.y:t.y,a=n.normal.z>=0?e.z:t.z;if(j1(n,{x:i,y:o,z:a})<0)return!1}return!0}function Oh(t,e,r){let n=(t.x+e.x)*.5,i=(t.y+e.y)*.5,o=(t.z+e.z)*.5,a=(e.x-t.x)*.5,s=(e.y-t.y)*.5,c=(e.z-t.z)*.5,l=r,d=l[0]*n+l[4]*i+l[8]*o+l[12],f=l[1]*n+l[5]*i+l[9]*o+l[13],u=l[2]*n+l[6]*i+l[10]*o+l[14],h=Math.abs(l[0])*a+Math.abs(l[4])*s+Math.abs(l[8])*c,m=Math.abs(l[1])*a+Math.abs(l[5])*s+Math.abs(l[9])*c,g=Math.abs(l[2])*a+Math.abs(l[6])*s+Math.abs(l[10])*c;return{mins:{x:d-h,y:f-m,z:u-g},maxs:{x:d+h,y:f+m,z:u+g}}}function Nd(t){return t<0}function Hd(t){return-t-1}function Uh(t,e){return t.normal[0]*e.x+t.normal[1]*e.y+t.normal[2]*e.z-t.dist}function Gd(t,e,r){if(!t||e<0||r<0)return!0;let n=Math.ceil(t.numClusters/8),i=t.clusters[e].pvs,o=Math.floor(r/8),a=1<<r%8;return o<0||o>=n?!1:(i[o]&a)!==0}function Q1(t,e){let r={x:t.mins[0],y:t.mins[1],z:t.mins[2]},n={x:t.maxs[0],y:t.maxs[1],z:t.maxs[2]};return bi(r,n,e)}function xi(t,e){if(t.models.length===0)return-1;let r=t.models[0].headNode;for(;r>=0;){let n=t.nodes[r],i=t.planes[n.planeIndex],a=Uh(i,e)>=0?0:1,s=n.children[a];if(Nd(s))return Hd(s);r=s}return Nd(r)?Hd(r):-1}function J1(t,e){let r=t.leafs[e],n=[];for(let i=0;i<r.numLeafFaces;i+=1)n.push(t.leafLists.leafFaces[e][i]);return n}function Vd(t,e,r,n,i,o,a,s){if(Nd(e)){let h=Hd(e),m=t.leafs[h];if(s&&m.area>=0&&!s.has(m.area)||!Gd(t.visibility,i,m.cluster)||!Q1(m,n))return;let g={x:(m.mins[0]+m.maxs[0])*.5,y:(m.mins[1]+m.maxs[1])*.5,z:(m.mins[2]+m.maxs[2])*.5},p=g.x-r.x,y=g.y-r.y,v=g.z-r.z,x=-(p*p+y*y+v*v);for(let b of J1(t,h))a.has(b)||(a.add(b),o.push({faceIndex:b,leafIndex:h,sortKey:x}));return}let c=t.nodes[e],l=t.planes[c.planeIndex],d=Uh(l,r),f=d>=0?c.children[0]:c.children[1],u=d>=0?c.children[1]:c.children[0];bi({x:c.mins[0],y:c.mins[1],z:c.mins[2]},{x:c.maxs[0],y:c.maxs[1],z:c.maxs[2]},n)&&(Vd(t,f,r,n,i,o,a,s),Vd(t,u,r,n,i,o,a,s))}function Wd(t,e,r){let n=new Set;if(e<0||e>=t.areas.length)return n;let i=[e];for(n.add(e);i.length>0;){let o=i.pop(),a=t.areas[o];for(let s=0;s<a.numAreaPortals;s++){let c=a.firstAreaPortal+s,l=t.areaPortals[c],d=l.otherArea;(l.portalNumber<=0||r[l.portalNumber])&&!n.has(d)&&(n.add(d),i.push(d))}}return n}function vi(t,e,r,n){let i=xi(t,e),o=i>=0?t.leafs[i]:null,a=o?o.cluster:-1,s=o?o.area:-1,c=null;n&&s>=0&&t.areas&&t.areas.length>0&&(c=Wd(t,s,n));let l=[],d=new Set;if(t.models.length>0){let f=t.models[0].headNode;Vd(t,f,e,r,a,l,d,c)}return l}var zn=32,Kl=class{constructor(){this.lights=[]}addLight(e,r){if(e.key!==void 0){let n=this.lights.findIndex(i=>i.key===e.key);if(n!==-1){this.lights[n]=e;return}}this.lights.push(e)}clear(){this.lights=[]}update(e,r=0){if(this.lights=this.lights.filter(n=>n.die>e),r>0)for(let n of this.lights)n.radiusSpeed!==void 0&&n.radiusSpeed!==0&&(n.intensity+=n.radiusSpeed*r,n.intensity<0&&(n.intensity=0))}getActiveLights(){return this.lights}};function uo(t){let e=[];for(let r=0;r<t.length;r+=3){let n=t[r],i=t[r+1],o=t[r+2];e.push(n,i,i,o,o,n)}return t instanceof Uint32Array||Math.max(...e)>65535?new Uint32Array(e):new Uint16Array(e)}var Xd=`#version 300 es
|
|
142
142
|
precision highp float;
|
|
143
143
|
|
|
144
144
|
layout(location = 0) in vec3 a_position;
|
|
@@ -339,7 +339,7 @@ void main() {
|
|
|
339
339
|
}
|
|
340
340
|
|
|
341
341
|
o_color = finalColor;
|
|
342
|
-
}`,Nh=[0,255,255,255],ey=[0,-1,-1,-1];function Kd(t=Nh,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 o=e[i];r[n]=o!==void 0?o:1}return r}function ty(t){return[-(t*.25%1),0]}function Yd(t=
|
|
342
|
+
}`,Nh=[0,255,255,255],ey=[0,-1,-1,-1];function Kd(t=Nh,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 o=e[i];r[n]=o!==void 0?o:1}return r}function ty(t){return[-(t*.25%1),0]}function Yd(t=Go,e=0){let r=(t&Af)!==0,n=(t&Wo)!==0,i=(t&zs)!==0,o=(t&Os)!==0,a=(t&Us)!==0,s=o?.33:a?.66:1,c=o||a||n,l=!c&&!i,d=r?ty(e):[0,0];return{alpha:s,blend:c,depthWrite:l,warp:n,flowOffset:d,sky:i}}var fo=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Xd,fragment:$d},{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<zn;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=Nh,styleLayers:i=ey,styleValues:o=[],diffuseSampler:a=0,lightmapSampler:s,refractionSampler:c,surfaceFlags:l=Go,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,_=Yd(l,d),w=Kd(n,o),S=f?f[0]:_.flowOffset[0],E=f?f[1]:_.flowOffset[1],T=u!==void 0?u:_.alpha,A=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,T);let C=!_.sky&&s!==void 0&&!A;this.gl.uniform1i(this.uniformApplyLightmap,C?1:0),this.gl.uniform1i(this.uniformWarp,A?1:0),this.gl.uniform1i(this.uniformLightmapOnly,p?1:0),this.gl.uniform1f(this.uniformTime,d),this.gl.uniform1i(this.uniformDiffuse,a),this.gl.uniform1i(this.uniformLightmap,s??0),c!==void 0&&A?(this.gl.uniform1i(this.uniformRefraction,c),this.gl.uniform1i(this.uniformHasRefraction,1)):this.gl.uniform1i(this.uniformHasRefraction,0);let B=0,F=[1,1,1,1];g&&(g.mode==="solid"||g.mode==="wireframe"?B=1:g.mode==="solid-faceted"&&(B=2),g.color?F=[...g.color]:g.generateRandomColor&&(F=[1,1,1,1])),this.gl.uniform1i(this.uniformRenderMode,B),this.gl.uniform4f(this.uniformSolidColor,F[0],F[1],F[2],F[3]);let k=Math.min(m.length,zn);this.gl.uniform1i(this.uniformNumDlights,k);for(let N=0;N<k;N++){let ce=m[N];this.gl.uniform3f(this.uniformDlights[N].pos,ce.origin.x,ce.origin.y,ce.origin.z),this.gl.uniform3f(this.uniformDlights[N].color,ce.color.x,ce.color.y,ce.color.z),this.gl.uniform1f(this.uniformDlights[N].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 Je(this.gl,this.gl.STATIC_DRAW);let i=uo(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 Ja(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 Hh=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]),qd=`#version 300 es
|
|
343
343
|
precision highp float;
|
|
344
344
|
|
|
345
345
|
layout(location = 0) in vec3 a_position;
|
|
@@ -377,7 +377,7 @@ out vec4 o_color;
|
|
|
377
377
|
|
|
378
378
|
void main() {
|
|
379
379
|
o_color = texture(u_skybox, v_direction);
|
|
380
|
-
}`,
|
|
380
|
+
}`,ho=class{constructor(e){this.gl=e,this.program=le.create(e,{vertex:qd,fragment:Zd},{a_position:0}),this.vao=new Le(e),this.vbo=new Ae(e,e.STATIC_DRAW),this.vbo.upload(Hh,e.STATIC_DRAW);let r=[{index:0,size:3,type:e.FLOAT,stride:12,offset:0}];this.vao.configureAttributes(r,this.vbo),this.uniformViewProj=this.program.getUniformLocation("u_viewProjectionNoTranslation"),this.uniformScroll=this.program.getUniformLocation("u_scroll"),this.uniformSampler=this.program.getUniformLocation("u_skybox"),this.cubemap=new lo(e),this.cubemap.setParameters({minFilter:e.LINEAR,magFilter:e.LINEAR,wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE})}get shaderSize(){return this.program.sourceSize}bind(e){let{viewProjection:r,scroll:n,textureUnit:i=0}=e;this.program.use(),this.gl.depthMask(!1),this.gl.uniformMatrix4fv(this.uniformViewProj,!1,r),this.gl.uniform2f(this.uniformScroll,n[0],n[1]),this.gl.uniform1i(this.uniformSampler,i),this.cubemap.bind(i),this.vao.bind()}draw(){this.gl.drawArrays(this.gl.TRIANGLES,0,Hh.length/3)}dispose(){this.vbo.dispose(),this.vao.dispose(),this.cubemap.dispose(),this.program.dispose()}};function Yl(t){let e=new Float32Array(t);return e[12]=0,e[13]=0,e[14]=0,e}function ql(t,e=[.01,.02]){let[r,n]=e;return[r*t,n*t]}var Qd=`#version 300 es
|
|
381
381
|
precision highp float;
|
|
382
382
|
|
|
383
383
|
layout(location = 0) in vec3 a_position;
|
|
@@ -489,7 +489,7 @@ void main() {
|
|
|
489
489
|
}
|
|
490
490
|
|
|
491
491
|
o_color = finalColor;
|
|
492
|
-
}`;function ry(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 jd(t,e,r){return t+(e-t)*r}function Vh(t,e,r){return{x:jd(t.x,e.x,r),y:jd(t.y,e.y,r),z:jd(t.z,e.z,r)}}function ny(t,e,r){return[t/r.skinWidth,1-e/r.skinHeight]}function eu(t){if(t.glCommands.length===0){let n=[],i=[];return t.triangles.forEach(o=>{let a=n.length;for(let s=0;s<3;s+=1){let c=o.vertexIndices[s],l=o.texCoordIndices[s],d=t.texCoords[l];n.push({vertexIndex:c,texCoord:ny(d.s,d.t,t.header)})}i.push(a,a+1,a+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(o=>({vertexIndex:o.vertexIndex,texCoord:[o.s,1-o.t]}))),n.mode==="strip")for(let o=0;o<n.vertices.length-2;o+=1){let a=o%2===0,s=i+o+(a?0:1),c=i+o+(a?1:0),l=i+o+2;r.push(s,c,l)}else for(let o=1;o<n.vertices.length-1;o+=1)r.push(i,i+o,i+o+1)}return{vertices:e,indices:new Uint16Array(r)}}function tu(t,e,r){let{frame0:n,frame1:i,lerp:o}=r,a=t.frames[n],s=t.frames[i];if(!a||!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=a.vertices[l.vertexIndex],u=s.vertices[l.vertexIndex];if(!f||!u)throw new Error("MD2 vertex index out of range for frame");let h=Vh(f.position,u.position,o),m=ry(Vh(f.normal,u.normal,o)),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 po=class{constructor(e,r,n){this.gl=e,this.geometry=eu(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Je(e,e.STATIC_DRAW),this.vertexArray=new Le(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=tu(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()}},go=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Qd,fragment:Jd},{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<zn;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:o=.2,tint:a=[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(a);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,o),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,zn);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 Je(this.gl,this.gl.STATIC_DRAW);let n=fo(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 q=1e-6,xe=typeof Float32Array<"u"?Float32Array:Array,tr=Math.random,Gh="zyx";function rn(t){return t>=0?Math.round(t):t%.5===0?Math.floor(t):Math.round(t)}var YE=Math.PI/180,qE=180/Math.PI;function Wh(){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 I={};Ho(I,{add:()=>Gy,adjoint:()=>fy,clone:()=>ay,copy:()=>sy,create:()=>oy,decompose:()=>Ry,determinant:()=>hy,equals:()=>Ky,exactEquals:()=>$y,frob:()=>Vy,fromQuat:()=>Iy,fromQuat2:()=>Ey,fromRotation:()=>Sy,fromRotationTranslation:()=>Kh,fromRotationTranslationScale:()=>Cy,fromRotationTranslationScaleOrigin:()=>Py,fromScaling:()=>_y,fromTranslation:()=>vy,fromValues:()=>ly,fromXRotation:()=>wy,fromYRotation:()=>My,fromZRotation:()=>Ay,frustum:()=>By,getRotation:()=>Ty,getScaling:()=>Yh,getTranslation:()=>Ly,identity:()=>Xh,invert:()=>uy,lookAt:()=>Uy,mul:()=>Yy,multiply:()=>$h,multiplyScalar:()=>Wy,multiplyScalarAndAdd:()=>Xy,ortho:()=>zy,orthoNO:()=>Zh,orthoZO:()=>Oy,perspective:()=>Fy,perspectiveFromFieldOfView:()=>Dy,perspectiveNO:()=>qh,perspectiveZO:()=>ky,rotate:()=>gy,rotateX:()=>yy,rotateY:()=>by,rotateZ:()=>xy,scale:()=>py,set:()=>cy,str:()=>Hy,sub:()=>qy,subtract:()=>jh,targetTo:()=>Ny,translate:()=>my,transpose:()=>dy});function oy(){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 ay(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 sy(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 ly(t,e,r,n,i,o,a,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]=o,p[6]=a,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 cy(t,e,r,n,i,o,a,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]=o,t[5]=a,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 Xh(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 dy(t,e){if(t===e){var r=e[1],n=e[2],i=e[3],o=e[6],a=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]=o,t[11]=e[14],t[12]=i,t[13]=a,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 uy(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=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*a,x=r*c-i*a,b=r*l-o*a,_=n*c-i*s,w=n*l-o*s,S=i*l-o*c,E=d*g-f*m,T=d*p-u*m,A=d*y-h*m,C=f*p-u*g,B=f*y-h*g,F=u*y-h*p,k=v*F-x*B+b*C+_*A-w*T+S*E;return k?(k=1/k,t[0]=(s*F-c*B+l*C)*k,t[1]=(i*B-n*F-o*C)*k,t[2]=(g*S-p*w+y*_)*k,t[3]=(u*w-f*S-h*_)*k,t[4]=(c*A-a*F-l*T)*k,t[5]=(r*F-i*A+o*T)*k,t[6]=(p*b-m*S-y*x)*k,t[7]=(d*S-u*b+h*x)*k,t[8]=(a*B-s*A+l*E)*k,t[9]=(n*A-r*B-o*E)*k,t[10]=(m*w-g*b+y*v)*k,t[11]=(f*b-d*w-h*v)*k,t[12]=(s*T-a*C-c*E)*k,t[13]=(r*C-n*T+i*E)*k,t[14]=(g*x-m*_-p*v)*k,t[15]=(d*_-f*x+u*v)*k,t):null}function fy(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=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*a,x=r*c-i*a,b=r*l-o*a,_=n*c-i*s,w=n*l-o*s,S=i*l-o*c,E=d*g-f*m,T=d*p-u*m,A=d*y-h*m,C=f*p-u*g,B=f*y-h*g,F=u*y-h*p;return t[0]=s*F-c*B+l*C,t[1]=i*B-n*F-o*C,t[2]=g*S-p*w+y*_,t[3]=u*w-f*S-h*_,t[4]=c*A-a*F-l*T,t[5]=r*F-i*A+o*T,t[6]=p*b-m*S-y*x,t[7]=d*S-u*b+h*x,t[8]=a*B-s*A+l*E,t[9]=n*A-r*B-o*E,t[10]=m*w-g*b+y*v,t[11]=f*b-d*w-h*v,t[12]=s*T-a*C-c*E,t[13]=r*C-n*T+i*E,t[14]=g*x-m*_-p*v,t[15]=d*_-f*x+u*v,t}function hy(t){var e=t[0],r=t[1],n=t[2],i=t[3],o=t[4],a=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*a-r*o,v=e*s-n*o,x=r*s-n*a,b=l*m-d*h,_=l*g-f*h,w=d*g-f*m,S=e*w-r*_+n*b,E=o*w-a*_+s*b,T=l*x-d*v+f*y,A=h*x-m*v+g*y;return c*S-i*E+p*T-u*A}function $h(t,e,r){var n=e[0],i=e[1],o=e[2],a=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*o+b*l+_*h+w*y,t[3]=x*a+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*o+b*l+_*h+w*y,t[7]=x*a+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*o+b*l+_*h+w*y,t[11]=x*a+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*o+b*l+_*h+w*y,t[15]=x*a+b*d+_*m+w*v,t}function my(t,e,r){var n=r[0],i=r[1],o=r[2],a,s,c,l,d,f,u,h,m,g,p,y;return e===t?(t[12]=e[0]*n+e[4]*i+e[8]*o+e[12],t[13]=e[1]*n+e[5]*i+e[9]*o+e[13],t[14]=e[2]*n+e[6]*i+e[10]*o+e[14],t[15]=e[3]*n+e[7]*i+e[11]*o+e[15]):(a=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]=a,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]=a*n+d*i+m*o+e[12],t[13]=s*n+f*i+g*o+e[13],t[14]=c*n+u*i+p*o+e[14],t[15]=l*n+h*i+y*o+e[15]),t}function py(t,e,r){var n=r[0],i=r[1],o=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]*o,t[9]=e[9]*o,t[10]=e[10]*o,t[11]=e[11]*o,t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function gy(t,e,r,n){var i=n[0],o=n[1],a=n[2],s=Math.sqrt(i*i+o*o+a*a),c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,T,A,C,B,F,k,N;return s<q?null:(s=1/s,i*=s,o*=s,a*=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=o*i*d+a*c,T=a*i*d-o*c,A=i*o*d-a*c,C=o*o*d+l,B=a*o*d+i*c,F=i*a*d+o*c,k=o*a*d-i*c,N=a*a*d+l,t[0]=f*S+g*E+x*T,t[1]=u*S+p*E+b*T,t[2]=h*S+y*E+_*T,t[3]=m*S+v*E+w*T,t[4]=f*A+g*C+x*B,t[5]=u*A+p*C+b*B,t[6]=h*A+y*C+_*B,t[7]=m*A+v*C+w*B,t[8]=f*F+g*k+x*N,t[9]=u*F+p*k+b*N,t[10]=h*F+y*k+_*N,t[11]=m*F+v*k+w*N,e!==t&&(t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t)}function yy(t,e,r){var n=Math.sin(r),i=Math.cos(r),o=e[4],a=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]=o*i+l*n,t[5]=a*i+d*n,t[6]=s*i+f*n,t[7]=c*i+u*n,t[8]=l*i-o*n,t[9]=d*i-a*n,t[10]=f*i-s*n,t[11]=u*i-c*n,t}function by(t,e,r){var n=Math.sin(r),i=Math.cos(r),o=e[0],a=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]=o*i-l*n,t[1]=a*i-d*n,t[2]=s*i-f*n,t[3]=c*i-u*n,t[8]=o*n+l*i,t[9]=a*n+d*i,t[10]=s*n+f*i,t[11]=c*n+u*i,t}function xy(t,e,r){var n=Math.sin(r),i=Math.cos(r),o=e[0],a=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]=o*i+l*n,t[1]=a*i+d*n,t[2]=s*i+f*n,t[3]=c*i+u*n,t[4]=l*i-o*n,t[5]=d*i-a*n,t[6]=f*i-s*n,t[7]=u*i-c*n,t}function vy(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 _y(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 Sy(t,e,r){var n=r[0],i=r[1],o=r[2],a=Math.sqrt(n*n+i*i+o*o),s,c,l;return a<q?null:(a=1/a,n*=a,i*=a,o*=a,s=Math.sin(e),c=Math.cos(e),l=1-c,t[0]=n*n*l+c,t[1]=i*n*l+o*s,t[2]=o*n*l-i*s,t[3]=0,t[4]=n*i*l-o*s,t[5]=i*i*l+c,t[6]=o*i*l+n*s,t[7]=0,t[8]=n*o*l+i*s,t[9]=i*o*l-n*s,t[10]=o*o*l+c,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t)}function wy(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 My(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 Ay(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 Kh(t,e,r){var n=e[0],i=e[1],o=e[2],a=e[3],s=n+n,c=i+i,l=o+o,d=n*s,f=n*c,u=n*l,h=i*c,m=i*l,g=o*l,p=a*s,y=a*c,v=a*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 Ey(t,e){var r=new xe(3),n=-e[0],i=-e[1],o=-e[2],a=e[3],s=e[4],c=e[5],l=e[6],d=e[7],f=n*n+i*i+o*o+a*a;return f>0?(r[0]=(s*a+d*n+c*o-l*i)*2/f,r[1]=(c*a+d*i+l*n-s*o)*2/f,r[2]=(l*a+d*o+s*i-c*n)*2/f):(r[0]=(s*a+d*n+c*o-l*i)*2,r[1]=(c*a+d*i+l*n-s*o)*2,r[2]=(l*a+d*o+s*i-c*n)*2),Kh(t,e,r),t}function Ly(t,e){return t[0]=e[12],t[1]=e[13],t[2]=e[14],t}function Yh(t,e){var r=e[0],n=e[1],i=e[2],o=e[4],a=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(o*o+a*a+s*s),t[2]=Math.sqrt(c*c+l*l+d*d),t}function Ty(t,e){var r=new xe(3);Yh(r,e);var n=1/r[0],i=1/r[1],o=1/r[2],a=e[0]*n,s=e[1]*i,c=e[2]*o,l=e[4]*n,d=e[5]*i,f=e[6]*o,u=e[8]*n,h=e[9]*i,m=e[10]*o,g=a+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):a>d&&a>m?(p=Math.sqrt(1+a-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-a-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-a-d)*2,t[3]=(s-l)/p,t[0]=(u+c)/p,t[1]=(f+h)/p,t[2]=.25*p),t}function Ry(t,e,r,n){e[0]=n[12],e[1]=n[13],e[2]=n[14];var i=n[0],o=n[1],a=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+o*o+a*a),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=o*m,v=a*g,x=s*h,b=c*m,_=l*g,w=d*h,S=f*m,E=u*g,T=p+b+E,A=0;return T>0?(A=Math.sqrt(T+1)*2,t[3]=.25*A,t[0]=(_-S)/A,t[1]=(w-v)/A,t[2]=(y-x)/A):p>b&&p>E?(A=Math.sqrt(1+p-b-E)*2,t[3]=(_-S)/A,t[0]=.25*A,t[1]=(y+x)/A,t[2]=(w+v)/A):b>E?(A=Math.sqrt(1+b-p-E)*2,t[3]=(w-v)/A,t[0]=(y+x)/A,t[1]=.25*A,t[2]=(_+S)/A):(A=Math.sqrt(1+E-p-b)*2,t[3]=(y-x)/A,t[0]=(w+v)/A,t[1]=(_+S)/A,t[2]=.25*A),t}function Cy(t,e,r,n){var i=e[0],o=e[1],a=e[2],s=e[3],c=i+i,l=o+o,d=a+a,f=i*c,u=i*l,h=i*d,m=o*l,g=o*d,p=a*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 Py(t,e,r,n,i){var o=e[0],a=e[1],s=e[2],c=e[3],l=o+o,d=a+a,f=s+s,u=o*l,h=o*d,m=o*f,g=a*d,p=a*f,y=s*f,v=c*l,x=c*d,b=c*f,_=n[0],w=n[1],S=n[2],E=i[0],T=i[1],A=i[2],C=(1-(g+y))*_,B=(h+b)*_,F=(m-x)*_,k=(h-b)*w,N=(1-(u+y))*w,ce=(p+v)*w,Ht=(m+x)*S,Pt=(p-v)*S,Or=(1-(u+g))*S;return t[0]=C,t[1]=B,t[2]=F,t[3]=0,t[4]=k,t[5]=N,t[6]=ce,t[7]=0,t[8]=Ht,t[9]=Pt,t[10]=Or,t[11]=0,t[12]=r[0]+E-(C*E+k*T+Ht*A),t[13]=r[1]+T-(B*E+N*T+Pt*A),t[14]=r[2]+A-(F*E+ce*T+Or*A),t[15]=1,t}function Iy(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=r+r,s=n+n,c=i+i,l=r*a,d=n*a,f=n*s,u=i*a,h=i*s,m=i*c,g=o*a,p=o*s,y=o*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 By(t,e,r,n,i,o,a){var s=1/(r-e),c=1/(i-n),l=1/(o-a);return t[0]=o*2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=o*2*c,t[6]=0,t[7]=0,t[8]=(r+e)*s,t[9]=(i+n)*c,t[10]=(a+o)*l,t[11]=-1,t[12]=0,t[13]=0,t[14]=a*o*2*l,t[15]=0,t}function qh(t,e,r,n,i){var o=1/Math.tan(e/2);if(t[0]=o/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=o,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 a=1/(n-i);t[10]=(i+n)*a,t[14]=2*i*n*a}else t[10]=-1,t[14]=-2*n;return t}var Fy=qh;function ky(t,e,r,n,i){var o=1/Math.tan(e/2);if(t[0]=o/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=o,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 a=1/(n-i);t[10]=i*a,t[14]=i*n*a}else t[10]=-1,t[14]=-n;return t}function Dy(t,e,r,n){var i=Math.tan(e.upDegrees*Math.PI/180),o=Math.tan(e.downDegrees*Math.PI/180),a=Math.tan(e.leftDegrees*Math.PI/180),s=Math.tan(e.rightDegrees*Math.PI/180),c=2/(a+s),l=2/(i+o);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]=-((a-s)*c*.5),t[9]=(i-o)*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 Zh(t,e,r,n,i,o,a){var s=1/(e-r),c=1/(n-i),l=1/(o-a);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]=(a+o)*l,t[15]=1,t}var zy=Zh;function Oy(t,e,r,n,i,o,a){var s=1/(e-r),c=1/(n-i),l=1/(o-a);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]=o*l,t[15]=1,t}function Uy(t,e,r,n){var i,o,a,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)<q&&Math.abs(g-_)<q&&Math.abs(p-w)<q?Xh(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,o=x*d-y*u,a=y*f-v*d,h=Math.sqrt(i*i+o*o+a*a),h?(h=1/h,i*=h,o*=h,a*=h):(i=0,o=0,a=0),s=f*a-u*o,c=u*i-d*a,l=d*o-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]=o,t[5]=c,t[6]=f,t[7]=0,t[8]=a,t[9]=l,t[10]=u,t[11]=0,t[12]=-(i*m+o*g+a*p),t[13]=-(s*m+c*g+l*p),t[14]=-(d*m+f*g+u*p),t[15]=1,t)}function Ny(t,e,r,n){var i=e[0],o=e[1],a=e[2],s=n[0],c=n[1],l=n[2],d=i-r[0],f=o-r[1],u=a-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]=o,t[14]=a,t[15]=1,t}function Hy(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 Vy(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 Gy(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 jh(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 Wy(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 Xy(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 $y(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 Ky(t,e){var r=t[0],n=t[1],i=t[2],o=t[3],a=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],T=e[7],A=e[8],C=e[9],B=e[10],F=e[11],k=e[12],N=e[13],ce=e[14],Ht=e[15];return Math.abs(r-v)<=q*Math.max(1,Math.abs(r),Math.abs(v))&&Math.abs(n-x)<=q*Math.max(1,Math.abs(n),Math.abs(x))&&Math.abs(i-b)<=q*Math.max(1,Math.abs(i),Math.abs(b))&&Math.abs(o-_)<=q*Math.max(1,Math.abs(o),Math.abs(_))&&Math.abs(a-w)<=q*Math.max(1,Math.abs(a),Math.abs(w))&&Math.abs(s-S)<=q*Math.max(1,Math.abs(s),Math.abs(S))&&Math.abs(c-E)<=q*Math.max(1,Math.abs(c),Math.abs(E))&&Math.abs(l-T)<=q*Math.max(1,Math.abs(l),Math.abs(T))&&Math.abs(d-A)<=q*Math.max(1,Math.abs(d),Math.abs(A))&&Math.abs(f-C)<=q*Math.max(1,Math.abs(f),Math.abs(C))&&Math.abs(u-B)<=q*Math.max(1,Math.abs(u),Math.abs(B))&&Math.abs(h-F)<=q*Math.max(1,Math.abs(h),Math.abs(F))&&Math.abs(m-k)<=q*Math.max(1,Math.abs(m),Math.abs(k))&&Math.abs(g-N)<=q*Math.max(1,Math.abs(g),Math.abs(N))&&Math.abs(p-ce)<=q*Math.max(1,Math.abs(p),Math.abs(ce))&&Math.abs(y-Ht)<=q*Math.max(1,Math.abs(y),Math.abs(Ht))}var Yy=$h,qy=jh;var tc={};Ho(tc,{add:()=>bx,calculateW:()=>sx,clone:()=>mx,conjugate:()=>ux,copy:()=>gx,create:()=>hu,dot:()=>ym,equals:()=>Mx,exactEquals:()=>wx,exp:()=>hm,fromEuler:()=>fx,fromMat3:()=>pm,fromValues:()=>px,getAngle:()=>nx,getAxisAngle:()=>rx,identity:()=>tx,invert:()=>dx,len:()=>_x,length:()=>bm,lerp:()=>vx,ln:()=>mm,mul:()=>xx,multiply:()=>fm,normalize:()=>mu,pow:()=>lx,random:()=>cx,rotateX:()=>ix,rotateY:()=>ox,rotateZ:()=>ax,rotationTo:()=>Ax,scale:()=>gm,set:()=>yx,setAxes:()=>Lx,setAxisAngle:()=>um,slerp:()=>ec,sqlerp:()=>Ex,sqrLen:()=>Sx,squaredLength:()=>xm,str:()=>hx});var L={};Ho(L,{add:()=>Jy,angle:()=>vb,bezier:()=>fb,ceil:()=>eb,clone:()=>Zy,copy:()=>jy,create:()=>ql,cross:()=>ns,dist:()=>Tb,distance:()=>rm,div:()=>Lb,divide:()=>tm,dot:()=>rs,equals:()=>Mb,exactEquals:()=>wb,floor:()=>tb,forEach:()=>Pb,fromValues:()=>Zl,hermite:()=>ub,inverse:()=>lb,len:()=>nu,length:()=>Qh,lerp:()=>cb,max:()=>nb,min:()=>rb,mul:()=>Eb,multiply:()=>em,negate:()=>sb,normalize:()=>ru,random:()=>hb,rotateX:()=>yb,rotateY:()=>bb,rotateZ:()=>xb,round:()=>ib,scale:()=>ob,scaleAndAdd:()=>ab,set:()=>Qy,slerp:()=>db,sqrDist:()=>Rb,sqrLen:()=>Cb,squaredDistance:()=>nm,squaredLength:()=>im,str:()=>Sb,sub:()=>Ab,subtract:()=>Jh,transformMat3:()=>pb,transformMat4:()=>mb,transformQuat:()=>gb,zero:()=>_b});function ql(){var t=new xe(3);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t}function Zy(t){var e=new xe(3);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function Qh(t){var e=t[0],r=t[1],n=t[2];return Math.sqrt(e*e+r*r+n*n)}function Zl(t,e,r){var n=new xe(3);return n[0]=t,n[1]=e,n[2]=r,n}function jy(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function Qy(t,e,r,n){return t[0]=e,t[1]=r,t[2]=n,t}function Jy(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t}function Jh(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],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}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}function eb(t,e){return t[0]=Math.ceil(e[0]),t[1]=Math.ceil(e[1]),t[2]=Math.ceil(e[2]),t}function tb(t,e){return t[0]=Math.floor(e[0]),t[1]=Math.floor(e[1]),t[2]=Math.floor(e[2]),t}function rb(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 nb(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 ib(t,e){return t[0]=rn(e[0]),t[1]=rn(e[1]),t[2]=rn(e[2]),t}function ob(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t}function ab(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 rm(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 nm(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 im(t){var e=t[0],r=t[1],n=t[2];return e*e+r*r+n*n}function sb(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t}function lb(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t}function ru(t,e){var r=e[0],n=e[1],i=e[2],o=r*r+n*n+i*i;return o>0&&(o=1/Math.sqrt(o)),t[0]=e[0]*o,t[1]=e[1]*o,t[2]=e[2]*o,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],o=e[2],a=r[0],s=r[1],c=r[2];return t[0]=i*c-o*s,t[1]=o*a-n*c,t[2]=n*s-i*a,t}function cb(t,e,r,n){var i=e[0],o=e[1],a=e[2];return t[0]=i+n*(r[0]-i),t[1]=o+n*(r[1]-o),t[2]=a+n*(r[2]-a),t}function db(t,e,r,n){var i=Math.acos(Math.min(Math.max(rs(e,r),-1),1)),o=Math.sin(i),a=Math.sin((1-n)*i)/o,s=Math.sin(n*i)/o;return t[0]=a*e[0]+s*r[0],t[1]=a*e[1]+s*r[1],t[2]=a*e[2]+s*r[2],t}function ub(t,e,r,n,i,o){var a=o*o,s=a*(2*o-3)+1,c=a*(o-2)+o,l=a*(o-1),d=a*(3-2*o);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 fb(t,e,r,n,i,o){var a=1-o,s=a*a,c=o*o,l=s*a,d=3*o*s,f=3*c*a,u=c*o;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 hb(t,e){e=e===void 0?1:e;var r=tr()*2*Math.PI,n=tr()*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 mb(t,e,r){var n=e[0],i=e[1],o=e[2],a=r[3]*n+r[7]*i+r[11]*o+r[15];return a=a||1,t[0]=(r[0]*n+r[4]*i+r[8]*o+r[12])/a,t[1]=(r[1]*n+r[5]*i+r[9]*o+r[13])/a,t[2]=(r[2]*n+r[6]*i+r[10]*o+r[14])/a,t}function pb(t,e,r){var n=e[0],i=e[1],o=e[2];return t[0]=n*r[0]+i*r[3]+o*r[6],t[1]=n*r[1]+i*r[4]+o*r[7],t[2]=n*r[2]+i*r[5]+o*r[8],t}function gb(t,e,r){var n=r[0],i=r[1],o=r[2],a=r[3],s=e[0],c=e[1],l=e[2],d=i*l-o*c,f=o*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+a*d+i*u-o*f,t[1]=c+a*f+o*d-n*u,t[2]=l+a*u+n*f-i*d,t}function yb(t,e,r,n){var i=[],o=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],o[0]=i[0],o[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),o[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),t[0]=o[0]+r[0],t[1]=o[1]+r[1],t[2]=o[2]+r[2],t}function bb(t,e,r,n){var i=[],o=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],o[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),o[1]=i[1],o[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),t[0]=o[0]+r[0],t[1]=o[1]+r[1],t[2]=o[2]+r[2],t}function xb(t,e,r,n){var i=[],o=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],o[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),o[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),o[2]=i[2],t[0]=o[0]+r[0],t[1]=o[1]+r[1],t[2]=o[2]+r[2],t}function vb(t,e){var r=t[0],n=t[1],i=t[2],o=e[0],a=e[1],s=e[2],c=Math.sqrt((r*r+n*n+i*i)*(o*o+a*a+s*s)),l=c&&rs(t,e)/c;return Math.acos(Math.min(Math.max(l,-1),1))}function _b(t){return t[0]=0,t[1]=0,t[2]=0,t}function Sb(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"}function wb(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]}function Mb(t,e){var r=t[0],n=t[1],i=t[2],o=e[0],a=e[1],s=e[2];return Math.abs(r-o)<=q*Math.max(1,Math.abs(r),Math.abs(o))&&Math.abs(n-a)<=q*Math.max(1,Math.abs(n),Math.abs(a))&&Math.abs(i-s)<=q*Math.max(1,Math.abs(i),Math.abs(s))}var Ab=Jh,Eb=em,Lb=tm,Tb=rm,Rb=nm,nu=Qh,Cb=im,Pb=(function(){var t=ql();return function(e,r,n,i,o,a){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],o(t,t,a),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2];return e}})();var yo={};Ho(yo,{add:()=>lu,ceil:()=>Ib,clone:()=>iu,copy:()=>au,create:()=>om,cross:()=>Nb,dist:()=>Zb,distance:()=>cm,div:()=>qb,divide:()=>lm,dot:()=>Jl,equals:()=>$b,exactEquals:()=>fu,floor:()=>Bb,forEach:()=>ex,fromValues:()=>ou,inverse:()=>Ub,len:()=>Qb,length:()=>jl,lerp:()=>uu,max:()=>kb,min:()=>Fb,mul:()=>Yb,multiply:()=>sm,negate:()=>Ob,normalize:()=>du,random:()=>Hb,round:()=>Db,scale:()=>cu,scaleAndAdd:()=>zb,set:()=>su,sqrDist:()=>jb,sqrLen:()=>Jb,squaredDistance:()=>dm,squaredLength:()=>Ql,str:()=>Xb,sub:()=>Kb,subtract:()=>am,transformMat4:()=>Vb,transformQuat:()=>Gb,zero:()=>Wb});function om(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0,t[3]=0),t}function iu(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 ou(t,e,r,n){var i=new xe(4);return i[0]=t,i[1]=e,i[2]=r,i[3]=n,i}function au(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function su(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t}function lu(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 am(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 sm(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 lm(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 Ib(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 Bb(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 Fb(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 kb(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 Db(t,e){return t[0]=rn(e[0]),t[1]=rn(e[1]),t[2]=rn(e[2]),t[3]=rn(e[3]),t}function cu(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 zb(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 cm(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],o=e[3]-t[3];return Math.sqrt(r*r+n*n+i*i+o*o)}function dm(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],o=e[3]-t[3];return r*r+n*n+i*i+o*o}function jl(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 Ql(t){var e=t[0],r=t[1],n=t[2],i=t[3];return e*e+r*r+n*n+i*i}function Ob(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t}function Ub(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 du(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=r*r+n*n+i*i+o*o;return a>0&&(a=1/Math.sqrt(a)),t[0]=r*a,t[1]=n*a,t[2]=i*a,t[3]=o*a,t}function Jl(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]}function Nb(t,e,r,n){var i=r[0]*n[1]-r[1]*n[0],o=r[0]*n[2]-r[2]*n[0],a=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*a-h*o,t[2]=d*c-f*a+h*i,t[3]=-(d*s)+f*o-u*i,t}function uu(t,e,r,n){var i=e[0],o=e[1],a=e[2],s=e[3];return t[0]=i+n*(r[0]-i),t[1]=o+n*(r[1]-o),t[2]=a+n*(r[2]-a),t[3]=s+n*(r[3]-s),t}function Hb(t,e){e=e===void 0?1:e;var r,n,i,o,a,s,c;c=tr(),r=c*2-1,n=(4*tr()-2)*Math.sqrt(c*-c+c),a=r*r+n*n,c=tr(),i=c*2-1,o=(4*tr()-2)*Math.sqrt(c*-c+c),s=i*i+o*o;var l=Math.sqrt((1-a)/s);return t[0]=e*r,t[1]=e*n,t[2]=e*i*l,t[3]=e*o*l,t}function Vb(t,e,r){var n=e[0],i=e[1],o=e[2],a=e[3];return t[0]=r[0]*n+r[4]*i+r[8]*o+r[12]*a,t[1]=r[1]*n+r[5]*i+r[9]*o+r[13]*a,t[2]=r[2]*n+r[6]*i+r[10]*o+r[14]*a,t[3]=r[3]*n+r[7]*i+r[11]*o+r[15]*a,t}function Gb(t,e,r){var n=r[0],i=r[1],o=r[2],a=r[3],s=e[0],c=e[1],l=e[2],d=i*l-o*c,f=o*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+a*d+i*u-o*f,t[1]=c+a*f+o*d-n*u,t[2]=l+a*u+n*f-i*d,t[3]=e[3],t}function Wb(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t}function Xb(t){return"vec4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}function fu(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]}function $b(t,e){var r=t[0],n=t[1],i=t[2],o=t[3],a=e[0],s=e[1],c=e[2],l=e[3];return Math.abs(r-a)<=q*Math.max(1,Math.abs(r),Math.abs(a))&&Math.abs(n-s)<=q*Math.max(1,Math.abs(n),Math.abs(s))&&Math.abs(i-c)<=q*Math.max(1,Math.abs(i),Math.abs(c))&&Math.abs(o-l)<=q*Math.max(1,Math.abs(o),Math.abs(l))}var Kb=am,Yb=sm,qb=lm,Zb=cm,jb=dm,Qb=jl,Jb=Ql,ex=(function(){var t=om();return function(e,r,n,i,o,a){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],o(t,t,a),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2],e[s+3]=t[3];return e}})();function hu(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t[3]=1,t}function tx(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t}function um(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 rx(t,e){var r=Math.acos(e[3])*2,n=Math.sin(r/2);return n>q?(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 nx(t,e){var r=ym(t,e);return Math.acos(2*r*r-1)}function fm(t,e,r){var n=e[0],i=e[1],o=e[2],a=e[3],s=r[0],c=r[1],l=r[2],d=r[3];return t[0]=n*d+a*s+i*l-o*c,t[1]=i*d+a*c+o*s-n*l,t[2]=o*d+a*l+n*c-i*s,t[3]=a*d-n*s-i*c-o*l,t}function ix(t,e,r){r*=.5;var n=e[0],i=e[1],o=e[2],a=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]=o*c-i*s,t[3]=a*c-n*s,t}function ox(t,e,r){r*=.5;var n=e[0],i=e[1],o=e[2],a=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]=o*c+n*s,t[3]=a*c-i*s,t}function ax(t,e,r){r*=.5;var n=e[0],i=e[1],o=e[2],a=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]=o*c+a*s,t[3]=a*c-o*s,t}function sx(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 hm(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=Math.sqrt(r*r+n*n+i*i),s=Math.exp(o),c=a>0?s*Math.sin(a)/a:0;return t[0]=r*c,t[1]=n*c,t[2]=i*c,t[3]=s*Math.cos(a),t}function mm(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=Math.sqrt(r*r+n*n+i*i),s=a>0?Math.atan2(a,o)/a: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+o*o),t}function lx(t,e,r){return mm(t,e),gm(t,t,r),hm(t,t),t}function ec(t,e,r,n){var i=e[0],o=e[1],a=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+o*l+a*d+s*f,h<0&&(h=-h,c=-c,l=-l,d=-d,f=-f),1-h>q?(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*o+p*l,t[2]=g*a+p*d,t[3]=g*s+p*f,t}function cx(t){var e=tr(),r=tr(),n=tr(),i=Math.sqrt(1-e),o=Math.sqrt(e);return t[0]=i*Math.sin(2*Math.PI*r),t[1]=i*Math.cos(2*Math.PI*r),t[2]=o*Math.sin(2*Math.PI*n),t[3]=o*Math.cos(2*Math.PI*n),t}function dx(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=r*r+n*n+i*i+o*o,s=a?1/a:0;return t[0]=-r*s,t[1]=-n*s,t[2]=-i*s,t[3]=o*s,t}function ux(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t}function pm(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 o=(i+1)%3,a=(i+2)%3;n=Math.sqrt(e[i*3+i]-e[o*3+o]-e[a*3+a]+1),t[i]=.5*n,n=.5/n,t[3]=(e[o*3+a]-e[a*3+o])*n,t[o]=(e[o*3+i]+e[i*3+o])*n,t[a]=(e[a*3+i]+e[i*3+a])*n}return t}function fx(t,e,r,n){var i=arguments.length>4&&arguments[4]!==void 0?arguments[4]:Gh,o=Math.PI/360;e*=o,n*=o,r*=o;var a=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]=a*l*f+s*c*d,t[1]=s*c*f-a*l*d,t[2]=s*l*d+a*c*f,t[3]=s*l*f-a*c*d;break;case"xzy":t[0]=a*l*f-s*c*d,t[1]=s*c*f-a*l*d,t[2]=s*l*d+a*c*f,t[3]=s*l*f+a*c*d;break;case"yxz":t[0]=a*l*f+s*c*d,t[1]=s*c*f-a*l*d,t[2]=s*l*d-a*c*f,t[3]=s*l*f+a*c*d;break;case"yzx":t[0]=a*l*f+s*c*d,t[1]=s*c*f+a*l*d,t[2]=s*l*d-a*c*f,t[3]=s*l*f-a*c*d;break;case"zxy":t[0]=a*l*f-s*c*d,t[1]=s*c*f+a*l*d,t[2]=s*l*d+a*c*f,t[3]=s*l*f-a*c*d;break;case"zyx":t[0]=a*l*f-s*c*d,t[1]=s*c*f+a*l*d,t[2]=s*l*d-a*c*f,t[3]=s*l*f+a*c*d;break;default:throw new Error("Unknown angle order "+i)}return t}function hx(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}var mx=iu,px=ou,gx=au,yx=su,bx=lu,xx=fm,gm=cu,ym=Jl,vx=uu,bm=jl,_x=bm,xm=Ql,Sx=xm,mu=du,wx=fu;function Mx(t,e){return Math.abs(Jl(t,e))>=1-q}var Ax=(function(){var t=ql(),e=Zl(1,0,0),r=Zl(0,1,0);return function(n,i,o){var a=rs(i,o);return a<-.999999?(ns(t,e,i),nu(t)<1e-6&&ns(t,r,i),ru(t,t),um(n,t,Math.PI),n):a>.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(ns(t,i,o),n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=1+a,mu(n,n))}})(),Ex=(function(){var t=hu(),e=hu();return function(r,n,i,o,a,s){return ec(t,n,a,s),ec(e,i,o,s),ec(r,t,e,2*s*(1-s)),r}})(),Lx=(function(){var t=Wh();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],mu(e,pm(e,t))}})();var rc=class{constructor(e,r){this._position=L.create();this._angles=L.create();this._bobAngles=L.create();this._bobOffset=L.create();this._kickAngles=L.create();this._rollAngle=0;this._fov=90;this._aspect=1;this._near=.1;this._far=1e3;this._viewMatrix=I.create();this._projectionMatrix=I.create();this._viewProjectionMatrix=I.create();this._dirty=!0;e!==void 0&&r!==void 0&&r>0&&(this._aspect=e/r)}get position(){return this._position}set position(e){L.equals(this._position,e)||(L.copy(this._position,e),this._dirty=!0,this.triggerMoveEvent())}get angles(){return this._angles}set angles(e){L.equals(this._angles,e)||(L.copy(this._angles,e),this._dirty=!0,this.triggerMoveEvent())}get bobAngles(){return this._bobAngles}set bobAngles(e){L.copy(this._bobAngles,e),this._dirty=!0}get kickAngles(){return this._kickAngles}set kickAngles(e){L.copy(this._kickAngles,e),this._dirty=!0}get bobOffset(){return this._bobOffset}set bobOffset(e){L.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:L.clone(this._position),angles:L.clone(this._angles),fov:this._fov,aspect:this._aspect,near:this._near,far:this._far}}setPosition(e,r,n){let i=L.fromValues(e,r,n);L.equals(this._position,i)||(L.copy(this._position,i),this._dirty=!0,this.triggerMoveEvent())}setRotation(e,r,n){let i=L.fromValues(e,r,n);L.equals(this._angles,i)||(L.copy(this._angles,i),this._dirty=!0,this.triggerMoveEvent())}setFov(e){this.fov=e}setAspectRatio(e){this.aspect=e}lookAt(e){let r=L.create();if(L.subtract(r,e,this._position),L.length(r)<.001)return;let i=Math.atan2(r[1],r[0])*Wc,o=Math.hypot(r[0],r[1]),a=-Math.atan2(r[2],o)*Wc;this.setRotation(a,i,0)}triggerMoveEvent(){this.onCameraMove&&this.onCameraMove({position:L.clone(this._position),angles:L.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=I.create();return I.perspective(r,e*Ee,this._aspect,this._near,this._far),r}screenToWorldRay(e,r){let n=e*2-1,i=1-r*2,o=L.fromValues(n,i,-1),a=L.fromValues(n,i,1),s=I.create();I.invert(s,this.viewProjectionMatrix);let c=L.create(),l=L.create();L.transformMat4(c,o,s),L.transformMat4(l,a,s);let d=L.create();return L.subtract(d,l,c),L.normalize(d,d),{origin:L.clone(this._position),direction:d}}updateMatrices(){if(!this._dirty)return;I.perspective(this._projectionMatrix,this._fov*Ee,this._aspect,this._near,this._far);let e=I.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,o=r*Ee,a=n*Ee,s=i*Ee,c=I.create();I.identity(c),I.rotateZ(c,c,-a),I.rotateY(c,c,-o),I.rotateX(c,c,-s);let l=I.create();I.multiply(l,e,c);let d=L.add(L.create(),this._position,this._bobOffset),f=L.negate(L.create(),d),u=L.create();L.transformMat4(u,f,c);let h=L.fromValues(u[1]?-u[1]:0,u[2]||0,u[0]?-u[0]:0);I.copy(this._viewMatrix,l),this._viewMatrix[12]=h[0],this._viewMatrix[13]=h[1],this._viewMatrix[14]=h[2],I.multiply(this._viewProjectionMatrix,this._projectionMatrix,this._viewMatrix),this._dirty=!1}};var Tx=[.2,.2,.2],Rx={x:0,y:0,z:1},Cx=[.8,.8,.8];function pu(t,e,r){return t+(e-t)*r}function xo(t,e,r){return{x:pu(t.x,e.x,r),y:pu(t.y,e.y,r),z:pu(t.z,e.z,r)}}function bo(t){return t<0?0:t>1?1:t}function gu(t){let e=[],r=[];for(let n of t.triangles){let i=e.length,[o,a,s]=n.indices,c=t.texCoords[o],l=t.texCoords[a],d=t.texCoords[s];if(!c||!l||!d)throw new Error(`Missing texCoord for triangle in surface ${t.name}`);e.push({vertexIndex:o,texCoord:[c.s,1-c.t]},{vertexIndex:a,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 Px(t,e,r){let n=r?.ambient??Tx,i=r?.directional??{direction:Rx,color:Cx},o=Vr(t),a=Vr(i.direction),s=bo(o.x*a.x+o.y*a.y+o.z*a.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?Sf(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?bo(-(h*o.x+m*o.y+g*o.z)/x):0,_=bo(v*b);c+=u.color[0]*_,l+=u.color[1]*_,d+=u.color[2]*_}}}return[bo(c),bo(l),bo(d)]}function yu(t,e,r,n){let i=t.vertices[r.frame0],o=t.vertices[r.frame1];if(!i||!o)throw new Error("Requested MD3 frames are out of range");let a=new Float32Array(e.vertices.length*12);return e.vertices.forEach((s,c)=>{let l=i[s.vertexIndex],d=o[s.vertexIndex];if(!l||!d)throw new Error(`Vertex index ${s.vertexIndex} missing for frame`);let f=xo(l.position,d.position,r.lerp),u=Vr(xo(l.normal,d.normal,r.lerp)),h=Px(u,f,n),m=c*12;a[m]=f.x,a[m+1]=f.y,a[m+2]=f.z,a[m+3]=u.x,a[m+4]=u.y,a[m+5]=u.z,a[m+6]=s.texCoord[0],a[m+7]=s.texCoord[1],a[m+8]=h[0],a[m+9]=h[1],a[m+10]=h[2],a[m+11]=1}),a}function vm(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 o=t.tags[e.frame0]?.[i],a=t.tags[e.frame1]?.[i];if(!o||!a)throw new Error(`Tag ${r} is missing for one of the interpolated frames`);let s=xo(o.origin,a.origin,e.lerp),c=Vr(xo(o.axis[0],a.axis[0],e.lerp)),l=Vr(xo(o.axis[1],a.axis[1],e.lerp)),d=Vr(xo(o.axis[2],a.axis[2],e.lerp)),f=c,u=Vr({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=Vr({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:wf(s,m)}}var bu=`#version 300 es
|
|
492
|
+
}`;function ry(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 jd(t,e,r){return t+(e-t)*r}function Vh(t,e,r){return{x:jd(t.x,e.x,r),y:jd(t.y,e.y,r),z:jd(t.z,e.z,r)}}function ny(t,e,r){return[t/r.skinWidth,1-e/r.skinHeight]}function eu(t){if(t.glCommands.length===0){let n=[],i=[];return t.triangles.forEach(o=>{let a=n.length;for(let s=0;s<3;s+=1){let c=o.vertexIndices[s],l=o.texCoordIndices[s],d=t.texCoords[l];n.push({vertexIndex:c,texCoord:ny(d.s,d.t,t.header)})}i.push(a,a+1,a+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(o=>({vertexIndex:o.vertexIndex,texCoord:[o.s,1-o.t]}))),n.mode==="strip")for(let o=0;o<n.vertices.length-2;o+=1){let a=o%2===0,s=i+o+(a?0:1),c=i+o+(a?1:0),l=i+o+2;r.push(s,c,l)}else for(let o=1;o<n.vertices.length-1;o+=1)r.push(i,i+o,i+o+1)}return{vertices:e,indices:new Uint16Array(r)}}function tu(t,e,r){let{frame0:n,frame1:i,lerp:o}=r,a=t.frames[n],s=t.frames[i];if(!a||!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=a.vertices[l.vertexIndex],u=s.vertices[l.vertexIndex];if(!f||!u)throw new Error("MD2 vertex index out of range for frame");let h=Vh(f.position,u.position,o),m=ry(Vh(f.normal,u.normal,o)),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 mo=class{constructor(e,r,n){this.gl=e,this.geometry=eu(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Je(e,e.STATIC_DRAW),this.vertexArray=new Le(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=tu(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()}},po=class{constructor(e){this.uniformDlights=[];this.gl=e,this.program=le.create(e,{vertex:Qd,fragment:Jd},{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<zn;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:o=.2,tint:a=[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(a);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,o),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,zn);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 Je(this.gl,this.gl.STATIC_DRAW);let n=uo(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 q=1e-6,xe=typeof Float32Array<"u"?Float32Array:Array,tr=Math.random,Gh="zyx";function rn(t){return t>=0?Math.round(t):t%.5===0?Math.floor(t):Math.round(t)}var qE=Math.PI/180,ZE=180/Math.PI;function Wh(){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 I={};No(I,{add:()=>Gy,adjoint:()=>fy,clone:()=>ay,copy:()=>sy,create:()=>oy,decompose:()=>Ry,determinant:()=>hy,equals:()=>Ky,exactEquals:()=>$y,frob:()=>Vy,fromQuat:()=>Iy,fromQuat2:()=>Ey,fromRotation:()=>Sy,fromRotationTranslation:()=>Kh,fromRotationTranslationScale:()=>Cy,fromRotationTranslationScaleOrigin:()=>Py,fromScaling:()=>_y,fromTranslation:()=>vy,fromValues:()=>ly,fromXRotation:()=>wy,fromYRotation:()=>My,fromZRotation:()=>Ay,frustum:()=>By,getRotation:()=>Ty,getScaling:()=>Yh,getTranslation:()=>Ly,identity:()=>Xh,invert:()=>uy,lookAt:()=>Uy,mul:()=>Yy,multiply:()=>$h,multiplyScalar:()=>Wy,multiplyScalarAndAdd:()=>Xy,ortho:()=>zy,orthoNO:()=>Zh,orthoZO:()=>Oy,perspective:()=>Fy,perspectiveFromFieldOfView:()=>Dy,perspectiveNO:()=>qh,perspectiveZO:()=>ky,rotate:()=>gy,rotateX:()=>yy,rotateY:()=>by,rotateZ:()=>xy,scale:()=>py,set:()=>cy,str:()=>Hy,sub:()=>qy,subtract:()=>jh,targetTo:()=>Ny,translate:()=>my,transpose:()=>dy});function oy(){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 ay(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 sy(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 ly(t,e,r,n,i,o,a,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]=o,p[6]=a,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 cy(t,e,r,n,i,o,a,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]=o,t[5]=a,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 Xh(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 dy(t,e){if(t===e){var r=e[1],n=e[2],i=e[3],o=e[6],a=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]=o,t[11]=e[14],t[12]=i,t[13]=a,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 uy(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=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*a,x=r*c-i*a,b=r*l-o*a,_=n*c-i*s,w=n*l-o*s,S=i*l-o*c,E=d*g-f*m,T=d*p-u*m,A=d*y-h*m,C=f*p-u*g,B=f*y-h*g,F=u*y-h*p,k=v*F-x*B+b*C+_*A-w*T+S*E;return k?(k=1/k,t[0]=(s*F-c*B+l*C)*k,t[1]=(i*B-n*F-o*C)*k,t[2]=(g*S-p*w+y*_)*k,t[3]=(u*w-f*S-h*_)*k,t[4]=(c*A-a*F-l*T)*k,t[5]=(r*F-i*A+o*T)*k,t[6]=(p*b-m*S-y*x)*k,t[7]=(d*S-u*b+h*x)*k,t[8]=(a*B-s*A+l*E)*k,t[9]=(n*A-r*B-o*E)*k,t[10]=(m*w-g*b+y*v)*k,t[11]=(f*b-d*w-h*v)*k,t[12]=(s*T-a*C-c*E)*k,t[13]=(r*C-n*T+i*E)*k,t[14]=(g*x-m*_-p*v)*k,t[15]=(d*_-f*x+u*v)*k,t):null}function fy(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=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*a,x=r*c-i*a,b=r*l-o*a,_=n*c-i*s,w=n*l-o*s,S=i*l-o*c,E=d*g-f*m,T=d*p-u*m,A=d*y-h*m,C=f*p-u*g,B=f*y-h*g,F=u*y-h*p;return t[0]=s*F-c*B+l*C,t[1]=i*B-n*F-o*C,t[2]=g*S-p*w+y*_,t[3]=u*w-f*S-h*_,t[4]=c*A-a*F-l*T,t[5]=r*F-i*A+o*T,t[6]=p*b-m*S-y*x,t[7]=d*S-u*b+h*x,t[8]=a*B-s*A+l*E,t[9]=n*A-r*B-o*E,t[10]=m*w-g*b+y*v,t[11]=f*b-d*w-h*v,t[12]=s*T-a*C-c*E,t[13]=r*C-n*T+i*E,t[14]=g*x-m*_-p*v,t[15]=d*_-f*x+u*v,t}function hy(t){var e=t[0],r=t[1],n=t[2],i=t[3],o=t[4],a=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*a-r*o,v=e*s-n*o,x=r*s-n*a,b=l*m-d*h,_=l*g-f*h,w=d*g-f*m,S=e*w-r*_+n*b,E=o*w-a*_+s*b,T=l*x-d*v+f*y,A=h*x-m*v+g*y;return c*S-i*E+p*T-u*A}function $h(t,e,r){var n=e[0],i=e[1],o=e[2],a=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*o+b*l+_*h+w*y,t[3]=x*a+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*o+b*l+_*h+w*y,t[7]=x*a+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*o+b*l+_*h+w*y,t[11]=x*a+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*o+b*l+_*h+w*y,t[15]=x*a+b*d+_*m+w*v,t}function my(t,e,r){var n=r[0],i=r[1],o=r[2],a,s,c,l,d,f,u,h,m,g,p,y;return e===t?(t[12]=e[0]*n+e[4]*i+e[8]*o+e[12],t[13]=e[1]*n+e[5]*i+e[9]*o+e[13],t[14]=e[2]*n+e[6]*i+e[10]*o+e[14],t[15]=e[3]*n+e[7]*i+e[11]*o+e[15]):(a=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]=a,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]=a*n+d*i+m*o+e[12],t[13]=s*n+f*i+g*o+e[13],t[14]=c*n+u*i+p*o+e[14],t[15]=l*n+h*i+y*o+e[15]),t}function py(t,e,r){var n=r[0],i=r[1],o=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]*o,t[9]=e[9]*o,t[10]=e[10]*o,t[11]=e[11]*o,t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function gy(t,e,r,n){var i=n[0],o=n[1],a=n[2],s=Math.sqrt(i*i+o*o+a*a),c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,T,A,C,B,F,k,N;return s<q?null:(s=1/s,i*=s,o*=s,a*=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=o*i*d+a*c,T=a*i*d-o*c,A=i*o*d-a*c,C=o*o*d+l,B=a*o*d+i*c,F=i*a*d+o*c,k=o*a*d-i*c,N=a*a*d+l,t[0]=f*S+g*E+x*T,t[1]=u*S+p*E+b*T,t[2]=h*S+y*E+_*T,t[3]=m*S+v*E+w*T,t[4]=f*A+g*C+x*B,t[5]=u*A+p*C+b*B,t[6]=h*A+y*C+_*B,t[7]=m*A+v*C+w*B,t[8]=f*F+g*k+x*N,t[9]=u*F+p*k+b*N,t[10]=h*F+y*k+_*N,t[11]=m*F+v*k+w*N,e!==t&&(t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t)}function yy(t,e,r){var n=Math.sin(r),i=Math.cos(r),o=e[4],a=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]=o*i+l*n,t[5]=a*i+d*n,t[6]=s*i+f*n,t[7]=c*i+u*n,t[8]=l*i-o*n,t[9]=d*i-a*n,t[10]=f*i-s*n,t[11]=u*i-c*n,t}function by(t,e,r){var n=Math.sin(r),i=Math.cos(r),o=e[0],a=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]=o*i-l*n,t[1]=a*i-d*n,t[2]=s*i-f*n,t[3]=c*i-u*n,t[8]=o*n+l*i,t[9]=a*n+d*i,t[10]=s*n+f*i,t[11]=c*n+u*i,t}function xy(t,e,r){var n=Math.sin(r),i=Math.cos(r),o=e[0],a=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]=o*i+l*n,t[1]=a*i+d*n,t[2]=s*i+f*n,t[3]=c*i+u*n,t[4]=l*i-o*n,t[5]=d*i-a*n,t[6]=f*i-s*n,t[7]=u*i-c*n,t}function vy(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 _y(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 Sy(t,e,r){var n=r[0],i=r[1],o=r[2],a=Math.sqrt(n*n+i*i+o*o),s,c,l;return a<q?null:(a=1/a,n*=a,i*=a,o*=a,s=Math.sin(e),c=Math.cos(e),l=1-c,t[0]=n*n*l+c,t[1]=i*n*l+o*s,t[2]=o*n*l-i*s,t[3]=0,t[4]=n*i*l-o*s,t[5]=i*i*l+c,t[6]=o*i*l+n*s,t[7]=0,t[8]=n*o*l+i*s,t[9]=i*o*l-n*s,t[10]=o*o*l+c,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t)}function wy(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 My(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 Ay(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 Kh(t,e,r){var n=e[0],i=e[1],o=e[2],a=e[3],s=n+n,c=i+i,l=o+o,d=n*s,f=n*c,u=n*l,h=i*c,m=i*l,g=o*l,p=a*s,y=a*c,v=a*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 Ey(t,e){var r=new xe(3),n=-e[0],i=-e[1],o=-e[2],a=e[3],s=e[4],c=e[5],l=e[6],d=e[7],f=n*n+i*i+o*o+a*a;return f>0?(r[0]=(s*a+d*n+c*o-l*i)*2/f,r[1]=(c*a+d*i+l*n-s*o)*2/f,r[2]=(l*a+d*o+s*i-c*n)*2/f):(r[0]=(s*a+d*n+c*o-l*i)*2,r[1]=(c*a+d*i+l*n-s*o)*2,r[2]=(l*a+d*o+s*i-c*n)*2),Kh(t,e,r),t}function Ly(t,e){return t[0]=e[12],t[1]=e[13],t[2]=e[14],t}function Yh(t,e){var r=e[0],n=e[1],i=e[2],o=e[4],a=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(o*o+a*a+s*s),t[2]=Math.sqrt(c*c+l*l+d*d),t}function Ty(t,e){var r=new xe(3);Yh(r,e);var n=1/r[0],i=1/r[1],o=1/r[2],a=e[0]*n,s=e[1]*i,c=e[2]*o,l=e[4]*n,d=e[5]*i,f=e[6]*o,u=e[8]*n,h=e[9]*i,m=e[10]*o,g=a+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):a>d&&a>m?(p=Math.sqrt(1+a-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-a-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-a-d)*2,t[3]=(s-l)/p,t[0]=(u+c)/p,t[1]=(f+h)/p,t[2]=.25*p),t}function Ry(t,e,r,n){e[0]=n[12],e[1]=n[13],e[2]=n[14];var i=n[0],o=n[1],a=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+o*o+a*a),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=o*m,v=a*g,x=s*h,b=c*m,_=l*g,w=d*h,S=f*m,E=u*g,T=p+b+E,A=0;return T>0?(A=Math.sqrt(T+1)*2,t[3]=.25*A,t[0]=(_-S)/A,t[1]=(w-v)/A,t[2]=(y-x)/A):p>b&&p>E?(A=Math.sqrt(1+p-b-E)*2,t[3]=(_-S)/A,t[0]=.25*A,t[1]=(y+x)/A,t[2]=(w+v)/A):b>E?(A=Math.sqrt(1+b-p-E)*2,t[3]=(w-v)/A,t[0]=(y+x)/A,t[1]=.25*A,t[2]=(_+S)/A):(A=Math.sqrt(1+E-p-b)*2,t[3]=(y-x)/A,t[0]=(w+v)/A,t[1]=(_+S)/A,t[2]=.25*A),t}function Cy(t,e,r,n){var i=e[0],o=e[1],a=e[2],s=e[3],c=i+i,l=o+o,d=a+a,f=i*c,u=i*l,h=i*d,m=o*l,g=o*d,p=a*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 Py(t,e,r,n,i){var o=e[0],a=e[1],s=e[2],c=e[3],l=o+o,d=a+a,f=s+s,u=o*l,h=o*d,m=o*f,g=a*d,p=a*f,y=s*f,v=c*l,x=c*d,b=c*f,_=n[0],w=n[1],S=n[2],E=i[0],T=i[1],A=i[2],C=(1-(g+y))*_,B=(h+b)*_,F=(m-x)*_,k=(h-b)*w,N=(1-(u+y))*w,ce=(p+v)*w,Vt=(m+x)*S,It=(p-v)*S,Or=(1-(u+g))*S;return t[0]=C,t[1]=B,t[2]=F,t[3]=0,t[4]=k,t[5]=N,t[6]=ce,t[7]=0,t[8]=Vt,t[9]=It,t[10]=Or,t[11]=0,t[12]=r[0]+E-(C*E+k*T+Vt*A),t[13]=r[1]+T-(B*E+N*T+It*A),t[14]=r[2]+A-(F*E+ce*T+Or*A),t[15]=1,t}function Iy(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=r+r,s=n+n,c=i+i,l=r*a,d=n*a,f=n*s,u=i*a,h=i*s,m=i*c,g=o*a,p=o*s,y=o*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 By(t,e,r,n,i,o,a){var s=1/(r-e),c=1/(i-n),l=1/(o-a);return t[0]=o*2*s,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=o*2*c,t[6]=0,t[7]=0,t[8]=(r+e)*s,t[9]=(i+n)*c,t[10]=(a+o)*l,t[11]=-1,t[12]=0,t[13]=0,t[14]=a*o*2*l,t[15]=0,t}function qh(t,e,r,n,i){var o=1/Math.tan(e/2);if(t[0]=o/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=o,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 a=1/(n-i);t[10]=(i+n)*a,t[14]=2*i*n*a}else t[10]=-1,t[14]=-2*n;return t}var Fy=qh;function ky(t,e,r,n,i){var o=1/Math.tan(e/2);if(t[0]=o/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=o,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 a=1/(n-i);t[10]=i*a,t[14]=i*n*a}else t[10]=-1,t[14]=-n;return t}function Dy(t,e,r,n){var i=Math.tan(e.upDegrees*Math.PI/180),o=Math.tan(e.downDegrees*Math.PI/180),a=Math.tan(e.leftDegrees*Math.PI/180),s=Math.tan(e.rightDegrees*Math.PI/180),c=2/(a+s),l=2/(i+o);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]=-((a-s)*c*.5),t[9]=(i-o)*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 Zh(t,e,r,n,i,o,a){var s=1/(e-r),c=1/(n-i),l=1/(o-a);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]=(a+o)*l,t[15]=1,t}var zy=Zh;function Oy(t,e,r,n,i,o,a){var s=1/(e-r),c=1/(n-i),l=1/(o-a);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]=o*l,t[15]=1,t}function Uy(t,e,r,n){var i,o,a,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)<q&&Math.abs(g-_)<q&&Math.abs(p-w)<q?Xh(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,o=x*d-y*u,a=y*f-v*d,h=Math.sqrt(i*i+o*o+a*a),h?(h=1/h,i*=h,o*=h,a*=h):(i=0,o=0,a=0),s=f*a-u*o,c=u*i-d*a,l=d*o-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]=o,t[5]=c,t[6]=f,t[7]=0,t[8]=a,t[9]=l,t[10]=u,t[11]=0,t[12]=-(i*m+o*g+a*p),t[13]=-(s*m+c*g+l*p),t[14]=-(d*m+f*g+u*p),t[15]=1,t)}function Ny(t,e,r,n){var i=e[0],o=e[1],a=e[2],s=n[0],c=n[1],l=n[2],d=i-r[0],f=o-r[1],u=a-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]=o,t[14]=a,t[15]=1,t}function Hy(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 Vy(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 Gy(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 jh(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 Wy(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 Xy(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 $y(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 Ky(t,e){var r=t[0],n=t[1],i=t[2],o=t[3],a=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],T=e[7],A=e[8],C=e[9],B=e[10],F=e[11],k=e[12],N=e[13],ce=e[14],Vt=e[15];return Math.abs(r-v)<=q*Math.max(1,Math.abs(r),Math.abs(v))&&Math.abs(n-x)<=q*Math.max(1,Math.abs(n),Math.abs(x))&&Math.abs(i-b)<=q*Math.max(1,Math.abs(i),Math.abs(b))&&Math.abs(o-_)<=q*Math.max(1,Math.abs(o),Math.abs(_))&&Math.abs(a-w)<=q*Math.max(1,Math.abs(a),Math.abs(w))&&Math.abs(s-S)<=q*Math.max(1,Math.abs(s),Math.abs(S))&&Math.abs(c-E)<=q*Math.max(1,Math.abs(c),Math.abs(E))&&Math.abs(l-T)<=q*Math.max(1,Math.abs(l),Math.abs(T))&&Math.abs(d-A)<=q*Math.max(1,Math.abs(d),Math.abs(A))&&Math.abs(f-C)<=q*Math.max(1,Math.abs(f),Math.abs(C))&&Math.abs(u-B)<=q*Math.max(1,Math.abs(u),Math.abs(B))&&Math.abs(h-F)<=q*Math.max(1,Math.abs(h),Math.abs(F))&&Math.abs(m-k)<=q*Math.max(1,Math.abs(m),Math.abs(k))&&Math.abs(g-N)<=q*Math.max(1,Math.abs(g),Math.abs(N))&&Math.abs(p-ce)<=q*Math.max(1,Math.abs(p),Math.abs(ce))&&Math.abs(y-Vt)<=q*Math.max(1,Math.abs(y),Math.abs(Vt))}var Yy=$h,qy=jh;var rc={};No(rc,{add:()=>bx,calculateW:()=>sx,clone:()=>mx,conjugate:()=>ux,copy:()=>gx,create:()=>hu,dot:()=>ym,equals:()=>Mx,exactEquals:()=>wx,exp:()=>hm,fromEuler:()=>fx,fromMat3:()=>pm,fromValues:()=>px,getAngle:()=>nx,getAxisAngle:()=>rx,identity:()=>tx,invert:()=>dx,len:()=>_x,length:()=>bm,lerp:()=>vx,ln:()=>mm,mul:()=>xx,multiply:()=>fm,normalize:()=>mu,pow:()=>lx,random:()=>cx,rotateX:()=>ix,rotateY:()=>ox,rotateZ:()=>ax,rotationTo:()=>Ax,scale:()=>gm,set:()=>yx,setAxes:()=>Lx,setAxisAngle:()=>um,slerp:()=>tc,sqlerp:()=>Ex,sqrLen:()=>Sx,squaredLength:()=>xm,str:()=>hx});var L={};No(L,{add:()=>Jy,angle:()=>vb,bezier:()=>fb,ceil:()=>eb,clone:()=>Zy,copy:()=>jy,create:()=>Zl,cross:()=>rs,dist:()=>Tb,distance:()=>rm,div:()=>Lb,divide:()=>tm,dot:()=>ts,equals:()=>Mb,exactEquals:()=>wb,floor:()=>tb,forEach:()=>Pb,fromValues:()=>jl,hermite:()=>ub,inverse:()=>lb,len:()=>nu,length:()=>Qh,lerp:()=>cb,max:()=>nb,min:()=>rb,mul:()=>Eb,multiply:()=>em,negate:()=>sb,normalize:()=>ru,random:()=>hb,rotateX:()=>yb,rotateY:()=>bb,rotateZ:()=>xb,round:()=>ib,scale:()=>ob,scaleAndAdd:()=>ab,set:()=>Qy,slerp:()=>db,sqrDist:()=>Rb,sqrLen:()=>Cb,squaredDistance:()=>nm,squaredLength:()=>im,str:()=>Sb,sub:()=>Ab,subtract:()=>Jh,transformMat3:()=>pb,transformMat4:()=>mb,transformQuat:()=>gb,zero:()=>_b});function Zl(){var t=new xe(3);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t}function Zy(t){var e=new xe(3);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function Qh(t){var e=t[0],r=t[1],n=t[2];return Math.sqrt(e*e+r*r+n*n)}function jl(t,e,r){var n=new xe(3);return n[0]=t,n[1]=e,n[2]=r,n}function jy(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function Qy(t,e,r,n){return t[0]=e,t[1]=r,t[2]=n,t}function Jy(t,e,r){return t[0]=e[0]+r[0],t[1]=e[1]+r[1],t[2]=e[2]+r[2],t}function Jh(t,e,r){return t[0]=e[0]-r[0],t[1]=e[1]-r[1],t[2]=e[2]-r[2],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}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}function eb(t,e){return t[0]=Math.ceil(e[0]),t[1]=Math.ceil(e[1]),t[2]=Math.ceil(e[2]),t}function tb(t,e){return t[0]=Math.floor(e[0]),t[1]=Math.floor(e[1]),t[2]=Math.floor(e[2]),t}function rb(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 nb(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 ib(t,e){return t[0]=rn(e[0]),t[1]=rn(e[1]),t[2]=rn(e[2]),t}function ob(t,e,r){return t[0]=e[0]*r,t[1]=e[1]*r,t[2]=e[2]*r,t}function ab(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 rm(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 nm(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 im(t){var e=t[0],r=t[1],n=t[2];return e*e+r*r+n*n}function sb(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t}function lb(t,e){return t[0]=1/e[0],t[1]=1/e[1],t[2]=1/e[2],t}function ru(t,e){var r=e[0],n=e[1],i=e[2],o=r*r+n*n+i*i;return o>0&&(o=1/Math.sqrt(o)),t[0]=e[0]*o,t[1]=e[1]*o,t[2]=e[2]*o,t}function ts(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}function rs(t,e,r){var n=e[0],i=e[1],o=e[2],a=r[0],s=r[1],c=r[2];return t[0]=i*c-o*s,t[1]=o*a-n*c,t[2]=n*s-i*a,t}function cb(t,e,r,n){var i=e[0],o=e[1],a=e[2];return t[0]=i+n*(r[0]-i),t[1]=o+n*(r[1]-o),t[2]=a+n*(r[2]-a),t}function db(t,e,r,n){var i=Math.acos(Math.min(Math.max(ts(e,r),-1),1)),o=Math.sin(i),a=Math.sin((1-n)*i)/o,s=Math.sin(n*i)/o;return t[0]=a*e[0]+s*r[0],t[1]=a*e[1]+s*r[1],t[2]=a*e[2]+s*r[2],t}function ub(t,e,r,n,i,o){var a=o*o,s=a*(2*o-3)+1,c=a*(o-2)+o,l=a*(o-1),d=a*(3-2*o);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 fb(t,e,r,n,i,o){var a=1-o,s=a*a,c=o*o,l=s*a,d=3*o*s,f=3*c*a,u=c*o;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 hb(t,e){e=e===void 0?1:e;var r=tr()*2*Math.PI,n=tr()*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 mb(t,e,r){var n=e[0],i=e[1],o=e[2],a=r[3]*n+r[7]*i+r[11]*o+r[15];return a=a||1,t[0]=(r[0]*n+r[4]*i+r[8]*o+r[12])/a,t[1]=(r[1]*n+r[5]*i+r[9]*o+r[13])/a,t[2]=(r[2]*n+r[6]*i+r[10]*o+r[14])/a,t}function pb(t,e,r){var n=e[0],i=e[1],o=e[2];return t[0]=n*r[0]+i*r[3]+o*r[6],t[1]=n*r[1]+i*r[4]+o*r[7],t[2]=n*r[2]+i*r[5]+o*r[8],t}function gb(t,e,r){var n=r[0],i=r[1],o=r[2],a=r[3],s=e[0],c=e[1],l=e[2],d=i*l-o*c,f=o*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+a*d+i*u-o*f,t[1]=c+a*f+o*d-n*u,t[2]=l+a*u+n*f-i*d,t}function yb(t,e,r,n){var i=[],o=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],o[0]=i[0],o[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),o[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),t[0]=o[0]+r[0],t[1]=o[1]+r[1],t[2]=o[2]+r[2],t}function bb(t,e,r,n){var i=[],o=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],o[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),o[1]=i[1],o[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),t[0]=o[0]+r[0],t[1]=o[1]+r[1],t[2]=o[2]+r[2],t}function xb(t,e,r,n){var i=[],o=[];return i[0]=e[0]-r[0],i[1]=e[1]-r[1],i[2]=e[2]-r[2],o[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),o[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),o[2]=i[2],t[0]=o[0]+r[0],t[1]=o[1]+r[1],t[2]=o[2]+r[2],t}function vb(t,e){var r=t[0],n=t[1],i=t[2],o=e[0],a=e[1],s=e[2],c=Math.sqrt((r*r+n*n+i*i)*(o*o+a*a+s*s)),l=c&&ts(t,e)/c;return Math.acos(Math.min(Math.max(l,-1),1))}function _b(t){return t[0]=0,t[1]=0,t[2]=0,t}function Sb(t){return"vec3("+t[0]+", "+t[1]+", "+t[2]+")"}function wb(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]}function Mb(t,e){var r=t[0],n=t[1],i=t[2],o=e[0],a=e[1],s=e[2];return Math.abs(r-o)<=q*Math.max(1,Math.abs(r),Math.abs(o))&&Math.abs(n-a)<=q*Math.max(1,Math.abs(n),Math.abs(a))&&Math.abs(i-s)<=q*Math.max(1,Math.abs(i),Math.abs(s))}var Ab=Jh,Eb=em,Lb=tm,Tb=rm,Rb=nm,nu=Qh,Cb=im,Pb=(function(){var t=Zl();return function(e,r,n,i,o,a){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],o(t,t,a),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2];return e}})();var go={};No(go,{add:()=>lu,ceil:()=>Ib,clone:()=>iu,copy:()=>au,create:()=>om,cross:()=>Nb,dist:()=>Zb,distance:()=>cm,div:()=>qb,divide:()=>lm,dot:()=>ec,equals:()=>$b,exactEquals:()=>fu,floor:()=>Bb,forEach:()=>ex,fromValues:()=>ou,inverse:()=>Ub,len:()=>Qb,length:()=>Ql,lerp:()=>uu,max:()=>kb,min:()=>Fb,mul:()=>Yb,multiply:()=>sm,negate:()=>Ob,normalize:()=>du,random:()=>Hb,round:()=>Db,scale:()=>cu,scaleAndAdd:()=>zb,set:()=>su,sqrDist:()=>jb,sqrLen:()=>Jb,squaredDistance:()=>dm,squaredLength:()=>Jl,str:()=>Xb,sub:()=>Kb,subtract:()=>am,transformMat4:()=>Vb,transformQuat:()=>Gb,zero:()=>Wb});function om(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0,t[3]=0),t}function iu(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 ou(t,e,r,n){var i=new xe(4);return i[0]=t,i[1]=e,i[2]=r,i[3]=n,i}function au(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function su(t,e,r,n,i){return t[0]=e,t[1]=r,t[2]=n,t[3]=i,t}function lu(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 am(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 sm(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 lm(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 Ib(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 Bb(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 Fb(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 kb(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 Db(t,e){return t[0]=rn(e[0]),t[1]=rn(e[1]),t[2]=rn(e[2]),t[3]=rn(e[3]),t}function cu(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 zb(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 cm(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],o=e[3]-t[3];return Math.sqrt(r*r+n*n+i*i+o*o)}function dm(t,e){var r=e[0]-t[0],n=e[1]-t[1],i=e[2]-t[2],o=e[3]-t[3];return r*r+n*n+i*i+o*o}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 Jl(t){var e=t[0],r=t[1],n=t[2],i=t[3];return e*e+r*r+n*n+i*i}function Ob(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=-e[3],t}function Ub(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 du(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=r*r+n*n+i*i+o*o;return a>0&&(a=1/Math.sqrt(a)),t[0]=r*a,t[1]=n*a,t[2]=i*a,t[3]=o*a,t}function ec(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]+t[3]*e[3]}function Nb(t,e,r,n){var i=r[0]*n[1]-r[1]*n[0],o=r[0]*n[2]-r[2]*n[0],a=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*a-h*o,t[2]=d*c-f*a+h*i,t[3]=-(d*s)+f*o-u*i,t}function uu(t,e,r,n){var i=e[0],o=e[1],a=e[2],s=e[3];return t[0]=i+n*(r[0]-i),t[1]=o+n*(r[1]-o),t[2]=a+n*(r[2]-a),t[3]=s+n*(r[3]-s),t}function Hb(t,e){e=e===void 0?1:e;var r,n,i,o,a,s,c;c=tr(),r=c*2-1,n=(4*tr()-2)*Math.sqrt(c*-c+c),a=r*r+n*n,c=tr(),i=c*2-1,o=(4*tr()-2)*Math.sqrt(c*-c+c),s=i*i+o*o;var l=Math.sqrt((1-a)/s);return t[0]=e*r,t[1]=e*n,t[2]=e*i*l,t[3]=e*o*l,t}function Vb(t,e,r){var n=e[0],i=e[1],o=e[2],a=e[3];return t[0]=r[0]*n+r[4]*i+r[8]*o+r[12]*a,t[1]=r[1]*n+r[5]*i+r[9]*o+r[13]*a,t[2]=r[2]*n+r[6]*i+r[10]*o+r[14]*a,t[3]=r[3]*n+r[7]*i+r[11]*o+r[15]*a,t}function Gb(t,e,r){var n=r[0],i=r[1],o=r[2],a=r[3],s=e[0],c=e[1],l=e[2],d=i*l-o*c,f=o*s-n*l,u=n*c-i*s;return d=d+d,f=f+f,u=u+u,t[0]=s+a*d+i*u-o*f,t[1]=c+a*f+o*d-n*u,t[2]=l+a*u+n*f-i*d,t[3]=e[3],t}function Wb(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=0,t}function Xb(t){return"vec4("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}function fu(t,e){return t[0]===e[0]&&t[1]===e[1]&&t[2]===e[2]&&t[3]===e[3]}function $b(t,e){var r=t[0],n=t[1],i=t[2],o=t[3],a=e[0],s=e[1],c=e[2],l=e[3];return Math.abs(r-a)<=q*Math.max(1,Math.abs(r),Math.abs(a))&&Math.abs(n-s)<=q*Math.max(1,Math.abs(n),Math.abs(s))&&Math.abs(i-c)<=q*Math.max(1,Math.abs(i),Math.abs(c))&&Math.abs(o-l)<=q*Math.max(1,Math.abs(o),Math.abs(l))}var Kb=am,Yb=sm,qb=lm,Zb=cm,jb=dm,Qb=Ql,Jb=Jl,ex=(function(){var t=om();return function(e,r,n,i,o,a){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],o(t,t,a),e[s]=t[0],e[s+1]=t[1],e[s+2]=t[2],e[s+3]=t[3];return e}})();function hu(){var t=new xe(4);return xe!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t[3]=1,t}function tx(t){return t[0]=0,t[1]=0,t[2]=0,t[3]=1,t}function um(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 rx(t,e){var r=Math.acos(e[3])*2,n=Math.sin(r/2);return n>q?(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 nx(t,e){var r=ym(t,e);return Math.acos(2*r*r-1)}function fm(t,e,r){var n=e[0],i=e[1],o=e[2],a=e[3],s=r[0],c=r[1],l=r[2],d=r[3];return t[0]=n*d+a*s+i*l-o*c,t[1]=i*d+a*c+o*s-n*l,t[2]=o*d+a*l+n*c-i*s,t[3]=a*d-n*s-i*c-o*l,t}function ix(t,e,r){r*=.5;var n=e[0],i=e[1],o=e[2],a=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]=o*c-i*s,t[3]=a*c-n*s,t}function ox(t,e,r){r*=.5;var n=e[0],i=e[1],o=e[2],a=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]=o*c+n*s,t[3]=a*c-i*s,t}function ax(t,e,r){r*=.5;var n=e[0],i=e[1],o=e[2],a=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]=o*c+a*s,t[3]=a*c-o*s,t}function sx(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 hm(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=Math.sqrt(r*r+n*n+i*i),s=Math.exp(o),c=a>0?s*Math.sin(a)/a:0;return t[0]=r*c,t[1]=n*c,t[2]=i*c,t[3]=s*Math.cos(a),t}function mm(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=Math.sqrt(r*r+n*n+i*i),s=a>0?Math.atan2(a,o)/a: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+o*o),t}function lx(t,e,r){return mm(t,e),gm(t,t,r),hm(t,t),t}function tc(t,e,r,n){var i=e[0],o=e[1],a=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+o*l+a*d+s*f,h<0&&(h=-h,c=-c,l=-l,d=-d,f=-f),1-h>q?(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*o+p*l,t[2]=g*a+p*d,t[3]=g*s+p*f,t}function cx(t){var e=tr(),r=tr(),n=tr(),i=Math.sqrt(1-e),o=Math.sqrt(e);return t[0]=i*Math.sin(2*Math.PI*r),t[1]=i*Math.cos(2*Math.PI*r),t[2]=o*Math.sin(2*Math.PI*n),t[3]=o*Math.cos(2*Math.PI*n),t}function dx(t,e){var r=e[0],n=e[1],i=e[2],o=e[3],a=r*r+n*n+i*i+o*o,s=a?1/a:0;return t[0]=-r*s,t[1]=-n*s,t[2]=-i*s,t[3]=o*s,t}function ux(t,e){return t[0]=-e[0],t[1]=-e[1],t[2]=-e[2],t[3]=e[3],t}function pm(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 o=(i+1)%3,a=(i+2)%3;n=Math.sqrt(e[i*3+i]-e[o*3+o]-e[a*3+a]+1),t[i]=.5*n,n=.5/n,t[3]=(e[o*3+a]-e[a*3+o])*n,t[o]=(e[o*3+i]+e[i*3+o])*n,t[a]=(e[a*3+i]+e[i*3+a])*n}return t}function fx(t,e,r,n){var i=arguments.length>4&&arguments[4]!==void 0?arguments[4]:Gh,o=Math.PI/360;e*=o,n*=o,r*=o;var a=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]=a*l*f+s*c*d,t[1]=s*c*f-a*l*d,t[2]=s*l*d+a*c*f,t[3]=s*l*f-a*c*d;break;case"xzy":t[0]=a*l*f-s*c*d,t[1]=s*c*f-a*l*d,t[2]=s*l*d+a*c*f,t[3]=s*l*f+a*c*d;break;case"yxz":t[0]=a*l*f+s*c*d,t[1]=s*c*f-a*l*d,t[2]=s*l*d-a*c*f,t[3]=s*l*f+a*c*d;break;case"yzx":t[0]=a*l*f+s*c*d,t[1]=s*c*f+a*l*d,t[2]=s*l*d-a*c*f,t[3]=s*l*f-a*c*d;break;case"zxy":t[0]=a*l*f-s*c*d,t[1]=s*c*f+a*l*d,t[2]=s*l*d+a*c*f,t[3]=s*l*f-a*c*d;break;case"zyx":t[0]=a*l*f-s*c*d,t[1]=s*c*f+a*l*d,t[2]=s*l*d-a*c*f,t[3]=s*l*f+a*c*d;break;default:throw new Error("Unknown angle order "+i)}return t}function hx(t){return"quat("+t[0]+", "+t[1]+", "+t[2]+", "+t[3]+")"}var mx=iu,px=ou,gx=au,yx=su,bx=lu,xx=fm,gm=cu,ym=ec,vx=uu,bm=Ql,_x=bm,xm=Jl,Sx=xm,mu=du,wx=fu;function Mx(t,e){return Math.abs(ec(t,e))>=1-q}var Ax=(function(){var t=Zl(),e=jl(1,0,0),r=jl(0,1,0);return function(n,i,o){var a=ts(i,o);return a<-.999999?(rs(t,e,i),nu(t)<1e-6&&rs(t,r,i),ru(t,t),um(n,t,Math.PI),n):a>.999999?(n[0]=0,n[1]=0,n[2]=0,n[3]=1,n):(rs(t,i,o),n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=1+a,mu(n,n))}})(),Ex=(function(){var t=hu(),e=hu();return function(r,n,i,o,a,s){return tc(t,n,a,s),tc(e,i,o,s),tc(r,t,e,2*s*(1-s)),r}})(),Lx=(function(){var t=Wh();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],mu(e,pm(e,t))}})();var nc=class{constructor(e,r){this._position=L.create();this._angles=L.create();this._bobAngles=L.create();this._bobOffset=L.create();this._kickAngles=L.create();this._rollAngle=0;this._fov=90;this._aspect=1;this._near=.1;this._far=1e3;this._viewMatrix=I.create();this._projectionMatrix=I.create();this._viewProjectionMatrix=I.create();this._dirty=!0;e!==void 0&&r!==void 0&&r>0&&(this._aspect=e/r)}get position(){return this._position}set position(e){L.equals(this._position,e)||(L.copy(this._position,e),this._dirty=!0,this.triggerMoveEvent())}get angles(){return this._angles}set angles(e){L.equals(this._angles,e)||(L.copy(this._angles,e),this._dirty=!0,this.triggerMoveEvent())}get bobAngles(){return this._bobAngles}set bobAngles(e){L.copy(this._bobAngles,e),this._dirty=!0}get kickAngles(){return this._kickAngles}set kickAngles(e){L.copy(this._kickAngles,e),this._dirty=!0}get bobOffset(){return this._bobOffset}set bobOffset(e){L.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:L.clone(this._position),angles:L.clone(this._angles),fov:this._fov,aspect:this._aspect,near:this._near,far:this._far}}setPosition(e,r,n){let i=L.fromValues(e,r,n);L.equals(this._position,i)||(L.copy(this._position,i),this._dirty=!0,this.triggerMoveEvent())}setRotation(e,r,n){let i=L.fromValues(e,r,n);L.equals(this._angles,i)||(L.copy(this._angles,i),this._dirty=!0,this.triggerMoveEvent())}setFov(e){this.fov=e}setAspectRatio(e){this.aspect=e}lookAt(e){let r=L.create();if(L.subtract(r,e,this._position),L.length(r)<.001)return;let i=Math.atan2(r[1],r[0])*Wc,o=Math.hypot(r[0],r[1]),a=-Math.atan2(r[2],o)*Wc;this.setRotation(a,i,0)}triggerMoveEvent(){this.onCameraMove&&this.onCameraMove({position:L.clone(this._position),angles:L.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=I.create();return I.perspective(r,e*Ee,this._aspect,this._near,this._far),r}screenToWorldRay(e,r){let n=e*2-1,i=1-r*2,o=L.fromValues(n,i,-1),a=L.fromValues(n,i,1),s=I.create();I.invert(s,this.viewProjectionMatrix);let c=L.create(),l=L.create();L.transformMat4(c,o,s),L.transformMat4(l,a,s);let d=L.create();return L.subtract(d,l,c),L.normalize(d,d),{origin:L.clone(this._position),direction:d}}updateMatrices(){if(!this._dirty)return;I.perspective(this._projectionMatrix,this._fov*Ee,this._aspect,this._near,this._far);let e=I.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,o=r*Ee,a=n*Ee,s=i*Ee,c=I.create();I.identity(c),I.rotateZ(c,c,-a),I.rotateY(c,c,-o),I.rotateX(c,c,-s);let l=I.create();I.multiply(l,e,c);let d=L.add(L.create(),this._position,this._bobOffset),f=L.negate(L.create(),d),u=L.create();L.transformMat4(u,f,c);let h=L.fromValues(u[1]?-u[1]:0,u[2]||0,u[0]?-u[0]:0);I.copy(this._viewMatrix,l),this._viewMatrix[12]=h[0],this._viewMatrix[13]=h[1],this._viewMatrix[14]=h[2],I.multiply(this._viewProjectionMatrix,this._projectionMatrix,this._viewMatrix),this._dirty=!1}};var Tx=[.2,.2,.2],Rx={x:0,y:0,z:1},Cx=[.8,.8,.8];function pu(t,e,r){return t+(e-t)*r}function bo(t,e,r){return{x:pu(t.x,e.x,r),y:pu(t.y,e.y,r),z:pu(t.z,e.z,r)}}function yo(t){return t<0?0:t>1?1:t}function gu(t){let e=[],r=[];for(let n of t.triangles){let i=e.length,[o,a,s]=n.indices,c=t.texCoords[o],l=t.texCoords[a],d=t.texCoords[s];if(!c||!l||!d)throw new Error(`Missing texCoord for triangle in surface ${t.name}`);e.push({vertexIndex:o,texCoord:[c.s,1-c.t]},{vertexIndex:a,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 Px(t,e,r){let n=r?.ambient??Tx,i=r?.directional??{direction:Rx,color:Cx},o=Vr(t),a=Vr(i.direction),s=yo(o.x*a.x+o.y*a.y+o.z*a.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?Sf(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?yo(-(h*o.x+m*o.y+g*o.z)/x):0,_=yo(v*b);c+=u.color[0]*_,l+=u.color[1]*_,d+=u.color[2]*_}}}return[yo(c),yo(l),yo(d)]}function yu(t,e,r,n){let i=t.vertices[r.frame0],o=t.vertices[r.frame1];if(!i||!o)throw new Error("Requested MD3 frames are out of range");let a=new Float32Array(e.vertices.length*12);return e.vertices.forEach((s,c)=>{let l=i[s.vertexIndex],d=o[s.vertexIndex];if(!l||!d)throw new Error(`Vertex index ${s.vertexIndex} missing for frame`);let f=bo(l.position,d.position,r.lerp),u=Vr(bo(l.normal,d.normal,r.lerp)),h=Px(u,f,n),m=c*12;a[m]=f.x,a[m+1]=f.y,a[m+2]=f.z,a[m+3]=u.x,a[m+4]=u.y,a[m+5]=u.z,a[m+6]=s.texCoord[0],a[m+7]=s.texCoord[1],a[m+8]=h[0],a[m+9]=h[1],a[m+10]=h[2],a[m+11]=1}),a}function vm(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 o=t.tags[e.frame0]?.[i],a=t.tags[e.frame1]?.[i];if(!o||!a)throw new Error(`Tag ${r} is missing for one of the interpolated frames`);let s=bo(o.origin,a.origin,e.lerp),c=Vr(bo(o.axis[0],a.axis[0],e.lerp)),l=Vr(bo(o.axis[1],a.axis[1],e.lerp)),d=Vr(bo(o.axis[2],a.axis[2],e.lerp)),f=c,u=Vr({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=Vr({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:wf(s,m)}}var bu=`#version 300 es
|
|
493
493
|
precision highp float;
|
|
494
494
|
|
|
495
495
|
layout(location = 0) in vec3 a_position;
|
|
@@ -564,7 +564,7 @@ void main() {
|
|
|
564
564
|
}
|
|
565
565
|
|
|
566
566
|
o_color = finalColor;
|
|
567
|
-
}`,
|
|
567
|
+
}`,ns=class{constructor(e,r,n,i){this.gl=e,this.geometry=gu(r),this.vertexBuffer=new Ae(e,e.STATIC_DRAW),this.indexBuffer=new Je(e,e.STATIC_DRAW),this.vertexArray=new Le(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=yu(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()}},xo=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(o=>{this.surfaces.set(o.name,new ns(e,o,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()}},vo=class{constructor(e){this.gl=e,this.program=le.create(e,{vertex:bu,fragment:xu},{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],o=r?.renderMode,a=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(o&&(o.mode==="solid"||o.mode==="wireframe"?d=1:o.mode==="solid-faceted"&&(d=2),o.color&&(f=[...o.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,a),this.gl.uniform1f(this.uniformGamma,s),this.gl.uniform1i(this.uniformFullbright,c?1:0),this.gl.uniform1f(this.uniformGlobalAmbient,l),e.vertexArray.bind(),o&&o.mode==="wireframe"){if(!e.wireframeIndexBuffer){e.wireframeIndexBuffer=new Je(this.gl,this.gl.STATIC_DRAW);let u=uo(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 Ix=[1,1,1,1],_o=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??Ix,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 o=Math.max(0,1-this.damping[i]*e);this.velocityX[i]*=o,this.velocityY[i]*=o,this.velocityZ[i]=this.velocityZ[i]*o-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=[],o=[],a=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,T=r.x*u,A=r.y*u,C=r.z*u,B=[{x:x-w-T,y:b-S-A,z:_-E-C},{x:x+w-T,y:b+S-A,z:_+E-C},{x:x-w+T,y:b-S+A,z:_-E+C},{x:x+w+T,y:b+S+A,z:_+E+C}],F=[[0,1],[1,1],[0,0],[1,0]];B.forEach((k,N)=>{n.push(k.x,k.y,k.z,F[N]?.[0]??0,F[N]?.[1]??0,g,p,y,v)}),i.push(f,f+1,f+2,f+2,f+1,f+3)}l>0&&o.push({blendMode:s,start:c,count:i.length-c})};return a("alpha"),a("additive"),{vertices:new Float32Array(n),indices:new Uint16Array(i),batches:o}}findFreeSlot(){for(let e=0;e<this.maxParticles;e+=1)if(!this.alive[e])return e;return-1}},vu=`#version 300 es
|
|
568
568
|
precision highp float;
|
|
569
569
|
|
|
570
570
|
layout(location = 0) in vec3 a_position;
|
|
@@ -592,7 +592,7 @@ void main() {
|
|
|
592
592
|
float dist = distance(v_uv, vec2(0.5));
|
|
593
593
|
float alpha = v_color.a * (1.0 - smoothstep(0.35, 0.5, dist));
|
|
594
594
|
o_color = vec4(v_color.rgb, alpha);
|
|
595
|
-
}`,
|
|
595
|
+
}`,So=class{constructor(e,r){this.vertexCapacity=0;this.indexCapacity=0;this.gl=e,this.system=r,this.program=le.create(e,{vertex:vu,fragment:_u}),this.vertexBuffer=new Ae(e,e.DYNAMIC_DRAW),this.indexBuffer=new Je(e,e.DYNAMIC_DRAW),this.vertexArray=new Le(e),this.vertexArray.configureAttributes([{index:0,size:3,type:e.FLOAT,stride:36,offset:0},{index:1,size:2,type:e.FLOAT,stride:36,offset:12},{index:2,size:4,type:e.FLOAT,stride:36,offset:20}],this.vertexBuffer)}get shaderSize(){return this.program.sourceSize}render(e){let r=this.system.buildMesh(e.viewRight,e.viewUp);if(r.indices.length===0)return;let n=r.vertices;r.vertices.byteLength>this.vertexCapacity?(this.vertexCapacity=r.vertices.byteLength,this.vertexBuffer.upload(n,this.gl.DYNAMIC_DRAW)):this.vertexBuffer.update(n);let i=r.indices;r.indices.byteLength>this.indexCapacity?(this.indexCapacity=r.indices.byteLength,this.indexBuffer.upload(i,this.gl.DYNAMIC_DRAW)):this.indexBuffer.update(i),this.gl.depthMask(!1),this.program.use();let o=this.program.getUniformLocation("u_viewProjection");this.gl.uniformMatrix4fv(o,!1,e.viewProjection),this.vertexArray.bind();for(let a of r.batches)a.blendMode==="additive"?this.gl.blendFunc(this.gl.SRC_ALPHA,this.gl.ONE):this.gl.blendFuncSeparate(this.gl.SRC_ALPHA,this.gl.ONE_MINUS_SRC_ALPHA,this.gl.ONE,this.gl.ONE_MINUS_SRC_ALPHA),this.gl.drawElements(this.gl.TRIANGLES,a.count,this.gl.UNSIGNED_SHORT,a.start*2);this.gl.depthMask(!0)}dispose(){this.program.dispose(),this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose()}};function _m(t){let{system:e,origin:r,normal:n={x:0,y:0,z:1}}=t;for(let i=0;i<12;i+=1){let o=200+e.rng.frandom()*180,a=e.rng.frandom()*.35;e.spawn({position:r,velocity:{x:n.x*o+(e.rng.frandom()-.5)*80,y:n.y*o+(e.rng.frandom()-.5)*80,z:Math.max(n.z*o,120)+a*80},color:[1,.8,.4,1],size:2.5,lifetime:.45+e.rng.frandom()*.1,gravity:600,damping:2,bounce:.45,blendMode:"additive",fade:!0})}for(let i=0;i<8;i+=1)e.spawn({position:r,velocity:{x:(e.rng.frandom()-.5)*40,y:(e.rng.frandom()-.5)*40,z:80+e.rng.frandom()*40},color:[.45,.45,.45,.75],size:6,lifetime:.6,gravity:200,damping:4,bounce:.15,blendMode:"alpha",fade:!0})}function Sm(t){let{system:e,origin:r}=t;for(let n=0;n<40;n+=1){let i=e.rng.frandom()*Math.PI*2,o=Math.acos(2*e.rng.frandom()-1),a=220+e.rng.frandom()*260,s={x:Math.sin(o)*Math.cos(i),y:Math.sin(o)*Math.sin(i),z:Math.cos(o)};e.spawn({position:r,velocity:{x:s.x*a,y:s.y*a,z:s.z*a},color:[1,.6,.2,1],size:5,lifetime:.9,gravity:700,damping:1,bounce:.35,blendMode:"additive",fade:!0})}for(let n=0;n<16;n+=1)e.spawn({position:r,velocity:{x:(e.rng.frandom()-.5)*30,y:(e.rng.frandom()-.5)*30,z:120+e.rng.frandom()*120},color:[.25,.25,.25,.9],size:12,lifetime:1.2,gravity:300,damping:3,blendMode:"alpha",fade:!0})}function wm(t){let{system:e,origin:r,direction:n={x:0,y:0,z:1}}=t;for(let i=0;i<24;i+=1){let o=120+e.rng.frandom()*180;e.spawn({position:r,velocity:{x:n.x*o+(e.rng.frandom()-.5)*70,y:n.y*o+(e.rng.frandom()-.5)*70,z:n.z*o+e.rng.frandom()*80},color:[.6,0,0,.95],size:3,lifetime:.8,gravity:900,damping:1,bounce:.2,blendMode:"alpha",fade:!0})}}function Mm(t){let{system:e,origin:r}=t;for(let n=0;n<30;n+=1){let i=e.rng.frandom()*Math.PI*2,o=8+e.rng.frandom()*8;e.spawn({position:r,velocity:{x:Math.cos(i)*o,y:Math.sin(i)*o,z:100+e.rng.frandom()*80},color:[.4,.6,1,.9],size:4,lifetime:.5,gravity:300,damping:2,blendMode:"additive",fade:!0})}}function Am(t){let{system:e,origin:r,direction:n={x:1,y:0,z:0}}=t;for(let i=0;i<10;i+=1){let o=350+e.rng.frandom()*100;e.spawn({position:r,velocity:{x:n.x*o+(e.rng.frandom()-.5)*30,y:n.y*o+(e.rng.frandom()-.5)*30,z:n.z*o+(e.rng.frandom()-.5)*30},color:[1,.8,.3,1],size:3,lifetime:.25,gravity:200,damping:1,blendMode:"additive",fade:!0})}}function Em(t){let{system:e,origin:r,direction:n={x:0,y:0,z:0}}=t;for(let i=0;i<6;i+=1)e.spawn({position:{x:r.x+n.x*i*2,y:r.y+n.y*i*2,z:r.z+n.z*i*2},velocity:{x:(e.rng.frandom()-.5)*15,y:(e.rng.frandom()-.5)*15,z:20+e.rng.frandom()*15},color:[.6,.6,.6,.8],size:2.2,lifetime:.6,gravity:200,damping:1.5,blendMode:"alpha",fade:!0})}function Lm(t){let{system:e,origin:r,normal:n={x:0,y:0,z:1}}=t;for(let i=0;i<30;i+=1){let o=100+e.rng.frandom()*150;e.spawn({position:r,velocity:{x:n.x*o+(e.rng.frandom()-.5)*80,y:n.y*o+(e.rng.frandom()-.5)*80,z:100+e.rng.frandom()*120},color:[.5,.6,.8,.5],size:3,lifetime:.5+e.rng.frandom()*.3,gravity:800,damping:1.5,blendMode:"alpha",fade:!0})}}function Tm(t){let{system:e,origin:r}=t;for(let n=0;n<8;n+=1)e.spawn({position:{x:r.x+(e.rng.frandom()-.5)*10,y:r.y+(e.rng.frandom()-.5)*10,z:r.z+(e.rng.frandom()-.5)*10},velocity:{x:(e.rng.frandom()-.5)*20,y:(e.rng.frandom()-.5)*20,z:40+e.rng.frandom()*20},color:[.8,.8,.8,.3],size:5+e.rng.frandom()*4,lifetime:1.5+e.rng.frandom()*.5,gravity:-50,damping:.5,blendMode:"alpha",fade:!0})}function Rm(t){let{system:e,start:r,end:n}=t,i=n.x-r.x,o=n.y-r.y,a=n.z-r.z,s=Math.sqrt(i*i+o*o+a*a);if(s<1)return;let c={x:i/s,y:o/s,z:a/s},l=8;for(let d=0;d<s;d+=l){let f=r.x+c.x*d,u=r.y+c.y*d,h=r.z+c.z*d;e.spawn({position:{x:f,y:u,z:h},velocity:{x:0,y:0,z:0},color:[.4,.4,1,.8],size:2,lifetime:.6,blendMode:"additive",fade:!0});let m=3,g=d*.5;e.spawn({position:{x:f+(e.rng.frandom()-.5)*6,y:u+(e.rng.frandom()-.5)*6,z:h+(e.rng.frandom()-.5)*6},velocity:{x:(e.rng.frandom()-.5)*10,y:(e.rng.frandom()-.5)*10,z:(e.rng.frandom()-.5)*10},color:[.1,.1,.8,.6],size:3,lifetime:.8+e.rng.frandom()*.2,blendMode:"additive",fade:!0})}}function Cm(t){let{system:e,origin:r,normal:n={x:0,y:0,z:1},count:i=12,color:o=[1,.9,.2,1]}=t;for(let a=0;a<i;a++){let s=100+e.rng.frandom()*200,c=.5;e.spawn({position:r,velocity:{x:n.x*s+(e.rng.frandom()-.5)*100*c,y:n.y*s+(e.rng.frandom()-.5)*100*c,z:n.z*s+(e.rng.frandom()-.5)*100*c},color:o,size:1.5,lifetime:.3+e.rng.frandom()*.2,gravity:800,bounce:.5,damping:1,blendMode:"additive",fade:!0})}}function Pm(t){let{system:e,origin:r,normal:n={x:0,y:0,z:1},color:i=[1,.8,0,1]}=t;e.spawn({position:r,velocity:{x:0,y:0,z:0},color:i,size:8,lifetime:.2,blendMode:"additive",fade:!0});for(let o=0;o<8;o++){let a=150+e.rng.frandom()*150;e.spawn({position:r,velocity:{x:n.x*a+(e.rng.frandom()-.5)*120,y:n.y*a+(e.rng.frandom()-.5)*120,z:n.z*a+(e.rng.frandom()-.5)*120},color:i,size:2,lifetime:.4+e.rng.frandom()*.2,gravity:400,blendMode:"additive",fade:!0})}}function Im(t){let{system:e,origin:r}=t;e.spawn({position:r,velocity:{x:0,y:0,z:0},color:[.2,1,.2,1],size:30,lifetime:.5,blendMode:"additive",fade:!0});for(let n=0;n<60;n++){let i=e.rng.frandom()*Math.PI*2,o=Math.acos(2*e.rng.frandom()-1),a=300+e.rng.frandom()*400,s={x:Math.sin(o)*Math.cos(i),y:Math.sin(o)*Math.sin(i),z:Math.cos(o)};e.spawn({position:r,velocity:{x:s.x*a,y:s.y*a,z:s.z*a},color:[.2,1,.2,.8],size:4,lifetime:1,gravity:100,damping:1,blendMode:"additive",fade:!0})}}var Bx=`#version 300 es
|
|
596
596
|
layout(location = 0) in vec2 a_position;
|
|
597
597
|
|
|
598
598
|
out vec2 v_texCoord;
|
|
@@ -627,7 +627,7 @@ void main() {
|
|
|
627
627
|
|
|
628
628
|
o_color = texture(u_texture, uv);
|
|
629
629
|
}
|
|
630
|
-
`,
|
|
630
|
+
`,ic=class{constructor(e){this.gl=e,this.program=le.create(e,{vertex:Bx,fragment:Fx},{a_position:0}),this.uTime=this.program.getUniformLocation("u_time"),this.uStrength=this.program.getUniformLocation("u_strength"),this.uTexture=this.program.getUniformLocation("u_texture"),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)}render(e,r,n=1){this.program.use(),this.gl.activeTexture(this.gl.TEXTURE0),this.gl.bindTexture(this.gl.TEXTURE_2D,e),this.gl.uniform1i(this.uTexture,0),this.gl.uniform1f(this.uTime,r),this.gl.uniform1f(this.uStrength,n),this.gl.bindVertexArray(this.vao),this.gl.drawArrays(this.gl.TRIANGLE_STRIP,0,4),this.gl.bindVertexArray(null)}dispose(){this.program.dispose(),this.gl.deleteVertexArray(this.vao)}};var Su=`#version 300 es
|
|
631
631
|
layout(location = 0) in vec2 a_position;
|
|
632
632
|
|
|
633
633
|
out vec2 v_texCoord;
|
|
@@ -694,7 +694,7 @@ void main() {
|
|
|
694
694
|
vec4 color = texture(u_texture, v_texCoord);
|
|
695
695
|
o_color = vec4(color.rgb * u_intensity, 1.0);
|
|
696
696
|
}
|
|
697
|
-
`,
|
|
697
|
+
`,oc=class{constructor(e){this.width=0;this.height=0;this.gl=e,this.extractProgram=le.create(e,{vertex:Su,fragment:kx},{a_position:0}),this.blurProgram=le.create(e,{vertex:Su,fragment:Dx},{a_position:0}),this.compositeProgram=le.create(e,{vertex:Su,fragment:zx},{a_position:0}),this.framebuffer1=new yi(e),this.framebuffer2=new yi(e),this.texture1=new et(e),this.texture2=new et(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,o=Math.floor(this.height/2)||1;n.bindVertexArray(this.vao),this.framebuffer1.bind(),n.viewport(0,0,i,o),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 a=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(a,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 Ox={gatherVisibleFaces:vi,extractFrustumPlanes:Dn,computeSkyScroll:ql,removeViewTranslation:Yl};function Ux(t,e,r,n,i){if(!n)return;let o=i.removeViewTranslation(e.viewMatrix),a=I.create();I.multiply(a,e.projectionMatrix,o);let s=i.computeSkyScroll(r,n.scrollSpeeds??[.01,.02]);t.bind({viewProjection:a,scroll:s,textureUnit:n.textureUnit??0}),t.draw(),t.gl.depthMask(!0)}function Nx(t){return[...t].sort((e,r)=>r.sortKey-e.sortKey)}function Hx(t){return[...t].sort((e,r)=>e.sortKey-r.sortKey)}function Vx(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 o=t.lightmap?.atlasIndex,a=o!==void 0?e?.lightmaps?.[o]?.texture:void 0;return{diffuse:i,lightmap:a,refraction:r}}function Bm(t,e,r,n){let i=n.diffuse;i&&r.diffuse!==i&&(i.bind(0),r.diffuse=i);let o=n.lightmap;o&&r.lightmap!==o&&(o.bind(1),r.lightmap=o),o||(r.lightmap=void 0);let a=n.refraction,s;return a&&t.surfaceFlags&Wo?(r.refraction!==a&&(a.bind(2),r.refraction=a),s=2):r.refraction=void 0,{diffuse:0,lightmap:o?1:void 0,refraction:s}}function Gx(t,e,r,n){if(!r)return!1;let i=r.fov?e.getViewmodelProjectionMatrix(r.fov):e.projectionMatrix,o=n(e.viewMatrix),a=I.create();return I.multiply(a,i,o),r.depthRange&&t.depthRange(r.depthRange[0],r.depthRange[1]),r.draw(new Float32Array(a)),r.depthRange&&t.depthRange(0,1),!0}function Wx(t,e){if(!t)return 1;let r=Math.floor(e*10)%t.length;return(t.charCodeAt(r)-97)/12}var Fm=(t,e,r,n=Ox)=>{let i=new ic(t),o=new oc(t),a=0,s,c=0,l=0,d=(u,h)=>((!s||c!==u||l!==h)&&(s=new et(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=a>0?1e3/(h-a):0;a=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:T,brightness:A,gamma:C,fullbright:B,ambient:F,lightStyleOverrides:k,waterTint:N,underwaterWarp:ce,bloom:Vt,bloomIntensity:It,portalState:Or}=u,sn=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),Ux(r,p,b,v,n),g.skyDrawn=!!v,y){y.materials?.update(b);let ut=n.extractFrustumPlanes(Array.from(sn)),tt={x:p.position[0]??0,y:p.position[1]??0,z:p.position[2]??0},Gt=n.gatherVisibleFaces(y.map,tt,ut,Or),Wn=[],ln=[];for(let ae of Gt){let Pe=y.surfaces[ae.faceIndex];if(!Pe)continue;(Pe.surfaceFlags&(Os|Us|Wo))!==0?ln.push(ae):Wn.push(ae)}let Ur=Nx(Wn),Nr=y.lightStyles||[];if(k&&k.size>0){let ae=[...y.lightStyles||[]];for(let[Pe,Ce]of k){for(;ae.length<=Pe;)ae.push(1);ae[Pe]=Wx(Ce,b)}Nr=ae}let Hr=(ae,Pe)=>{let Ce,or,Wt={},cn=Pe?s:void 0;for(let{faceIndex:Es}of ae){let ft=y.surfaces[Es];if(!ft||(ft.surfaceFlags&zs)!==0)continue;let Ls=y.map.faces[Es]?.styles,Fo=y.materials?.getMaterial(ft.texture),Xn=Vx(ft,y,cn),ko=S;S&&!S.applyToAll&&Xn.diffuse?ko=void 0:S&&!S.applyToAll&&!Xn.diffuse&&(ko=S);let Do=Xn.lightmap;E&&(Do=void 0);let Ri={diffuse:Xn.diffuse,lightmap:Do,surfaceFlags:ft.surfaceFlags,styleKey:Ls?.join(",")??""};if(Ce&&Ce.diffuse===Ri.diffuse&&Ce.lightmap===Ri.lightmap&&Ce.surfaceFlags===Ri.surfaceFlags&&Ce.styleKey===Ri.styleKey){let Ts={...Xn,lightmap:Do};Bm(ft,y,Wt,Ts),or&&Ja(t,or)}else{g.batches+=1,Wt.diffuse=void 0,Wt.lightmap=void 0,Wt.refraction=void 0;let Ts={...Xn,lightmap:Do},Rs=Bm(ft,y,Wt,Ts),df=Fo?Fo.scrollOffset:void 0,uf=Fo?Fo.warp:void 0;or=e.bind({modelViewProjection:sn,styleIndices:Ls,styleValues:Nr,surfaceFlags:ft.surfaceFlags,timeSeconds:b,diffuseSampler:Rs.diffuse??0,lightmapSampler:Rs.lightmap,refractionSampler:Rs.refraction,texScroll:df,warp:uf,dlights:w,renderMode:ko,lightmapOnly:T,brightness:A,gamma:C,fullbright:B,ambient:F}),Ja(t,or),Ce=Ri}e.draw(ft,ko),g.facesDrawn+=1,g.drawCalls+=1,g.vertexCount+=ft.vertexCount}};if(Hr(Ur,!1),ln.length>0){let ae=t.canvas.width,Pe=t.canvas.height;d(ae,Pe).bind(2),t.copyTexImage2D(t.TEXTURE_2D,0,t.RGBA,0,0,ae,Pe,0)}let D=Hx(ln);Hr(D,!0)}if(Gx(t,p,_,n.removeViewTranslation)&&(g.viewModelDrawn=!0),ce){let ut=t.canvas.width,tt=t.canvas.height,Gt=d(ut,tt);Gt.bind(0),t.copyTexImage2D(t.TEXTURE_2D,0,t.RGBA,0,0,ut,tt,0),t.disable(t.DEPTH_TEST),t.depthMask(!1),i.render(Gt.texture,b),t.enable(t.DEPTH_TEST),t.depthMask(!0)}if(Vt){let ut=t.canvas.width,tt=t.canvas.height;o.resize(ut,tt);let Gt=d(ut,tt);Gt.bind(0),t.copyTexImage2D(t.TEXTURE_2D,0,t.RGBA,0,0,ut,tt,0),o.render(Gt,It??.5)}return g}}};var Xx=`#version 300 es
|
|
698
698
|
precision highp float;
|
|
699
699
|
|
|
700
700
|
layout(location = 0) in vec2 a_position;
|
|
@@ -719,7 +719,7 @@ out vec4 o_color;
|
|
|
719
719
|
|
|
720
720
|
void main() {
|
|
721
721
|
o_color = texture(u_diffuseMap, v_texCoord) * u_tint;
|
|
722
|
-
}`,
|
|
722
|
+
}`,wo=class{constructor(e){this.gl=e,this.program=le.create(e,{vertex:Xx,fragment:$x},{a_position:0,a_texCoord:1}),this.uniformProjection=this.program.getUniformLocation("u_projection"),this.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformTint=this.program.getUniformLocation("u_tint"),this.vao=new Le(e),this.vbo=new Ae(e,e.STREAM_DRAW),this.vao.configureAttributes([{index:0,size:2,type:e.FLOAT,stride:16,offset:0},{index:1,size:2,type:e.FLOAT,stride:16,offset:8}],this.vbo),this.whiteTexture=new et(e),this.whiteTexture.upload(1,1,new Uint8Array([255,255,255,255]))}get shaderSize(){return this.program.sourceSize}begin(e){this.program.use(),this.gl.uniformMatrix4fv(this.uniformProjection,!1,e)}draw(e,r,n,i,o=0,a=0,s=1,c=1,l=[1,1,1,1]){let d=e,f=r,u=e+n,h=r+i,m=new Float32Array([d,f,o,a,u,f,s,a,d,h,o,c,u,h,s,c]);this.vbo.upload(m,this.gl.STREAM_DRAW),this.gl.uniform4fv(this.uniformTint,new Float32Array(l)),this.vao.bind(),this.gl.drawArrays(this.gl.TRIANGLE_STRIP,0,4)}drawRect(e,r,n,i,o){this.whiteTexture.bind(0),this.draw(e,r,n,i,0,0,1,1,o)}};var Kx=`#version 300 es
|
|
723
723
|
precision highp float;
|
|
724
724
|
|
|
725
725
|
layout(location = 0) in vec3 a_position;
|
|
@@ -740,7 +740,7 @@ out vec4 o_color;
|
|
|
740
740
|
|
|
741
741
|
void main() {
|
|
742
742
|
o_color = v_color;
|
|
743
|
-
}`,
|
|
743
|
+
}`,ac=class{constructor(e){this.vertices=[];this.gl=e,this.program=le.create(e,{vertex:Kx,fragment:Yx},{a_position:0,a_color:1}),this.uniformViewProjection=this.program.getUniformLocation("u_viewProjection"),this.vao=new Le(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},o={x:r.x,y:e.y,z:e.z},a={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,o,n),this.addLine(o,a,n),this.addLine(a,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(o,l,n),this.addLine(a,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 qx(t,e){let r=t.models[0].headNode;for(;r>=0;){let i=t.nodes[r],o=t.planes[i.planeIndex];o.normal[0]*e.x+o.normal[1]*e.y+o.normal[2]*e.z-o.dist>=0?r=i.children[0]:r=i.children[1]}let n=-(r+1);return{leaf:t.leafs[n],index:n}}function Zx(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 jx(t,e,r,n){let i=t.faces[e];if(!i||i.lightOffset<0||!t.lightMapInfo[e])return 0;let a=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 T=t.surfEdges[f+E],A=T>=0?t.edges[T].vertices[0]:t.edges[Math.abs(T)].vertices[1],C=t.vertices[A],B=C[0]*a.s[0]+C[1]*a.s[1]+C[2]*a.s[2]+a.sOffset,F=C[0]*a.t[0]+C[1]*a.t[1]+C[2]*a.t[2]+a.tOffset;B<s&&(s=B),B>c&&(c=B),F<l&&(l=F),F>d&&(d=F)}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 km(t,e){if(!t)return 1;let r=Zx(t),n={x:e.x,y:e.y,z:e.z-8192},i=1,o=-1,a=0,s=0,{leaf:c,index:l}=qx(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=jx(t,f,_,w);if(S>r)return S}}}return Math.max(r,.2)}var sc=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,o=e+r+n;return{texturesBytes:e,geometryBytes:r,shadersBytes:n,buffersBytes:i,totalBytes:o}}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 Dm={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 zm(t){let e=[],r="",n;for(let i=0;i<t.length;i++){if(t[i]==="^"&&i+1<t.length){let o=t[i+1];if(Dm[o]){r.length>0&&(e.push({text:r,color:n}),r=""),n=Dm[o],i++;continue}}r+=t[i]}return r.length>0&&e.push({text:r,color:n}),e}var Qx=`
|
|
744
744
|
attribute vec3 a_position;
|
|
745
745
|
attribute vec3 a_color;
|
|
746
746
|
uniform mat4 u_viewProjection;
|
|
@@ -792,14 +792,14 @@ void main() {
|
|
|
792
792
|
|
|
793
793
|
gl_FragColor = vec4(color, 1.0);
|
|
794
794
|
}
|
|
795
|
-
`;function sc(t){return L.fromValues(t.x,t.y,t.z)}function rr(t){return{x:t[0],y:t[1],z:t[2]}}var lc=class{constructor(e){this.vertices=[];this.solidVertices=[];this.labels=[];this.gl=e,this.shader=le.create(e,{vertex:Qx,fragment:Jx}),this.vao=new Le(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:ev,fragment:tv}),this.vaoSolid=new Le(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:o,z:a}=e,{x:s,y:c,z:l}=r;this.drawLine({x:i,y:o,z:a},{x:s,y:o,z:a},n),this.drawLine({x:s,y:o,z:a},{x:s,y:c,z:a},n),this.drawLine({x:s,y:c,z:a},{x:i,y:c,z:a},n),this.drawLine({x:i,y:c,z:a},{x:i,y:o,z:a},n),this.drawLine({x:i,y:o,z:l},{x:s,y:o,z:l},n),this.drawLine({x:s,y:o,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:o,z:l},n),this.drawLine({x:i,y:o,z:a},{x:i,y:o,z:l},n),this.drawLine({x:s,y:o,z:a},{x:s,y:o,z:l},n),this.drawLine({x:s,y:c,z:a},{x:s,y:c,z:l},n),this.drawLine({x:i,y:c,z:a},{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,o){this.solidVertices.push(e.x,e.y,e.z),this.solidVertices.push(o.r,o.g,o.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(r.x,r.y,r.z),this.solidVertices.push(o.r,o.g,o.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(n.x,n.y,n.z),this.solidVertices.push(o.r,o.g,o.b),this.solidVertices.push(i.x,i.y,i.z)}addCone(e,r,n,i){let a=sc(e),s=sc(r),c=L.create();L.subtract(c,a,s),L.normalize(c,c);let l=L.fromValues(0,0,1);Math.abs(L.dot(c,l))>.99&&(l=L.fromValues(0,1,0));let d=L.create();L.cross(d,l,c),L.normalize(d,d);let f=L.create();L.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=L.clone(s);L.scaleAndAdd(b,b,d,v),L.scaleAndAdd(b,b,f,x),u.push(b)}let h=L.clone(c);L.scale(h,h,-1);let m=rr(h),g=r;for(let p=0;p<16;p++){let y=rr(u[p]),v=rr(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=rr(y),b=rr(v),_=L.create();L.subtract(_,v,y);let w=L.create();L.subtract(w,a,y);let S=L.create();L.cross(S,_,w),L.normalize(S,S);let E=rr(S);this.addTriangle(x,b,e,E,i)}}addTorus(e,r,n,i,o={x:0,y:0,z:1}){let c=sc(o);L.normalize(c,c);let l=sc(e),d=L.fromValues(0,0,1),f=I.create();if(Math.abs(L.dot(c,d))>.999)c[2]<0&&I.rotateX(f,f,Math.PI);else{let m=L.create();L.cross(m,d,c),L.normalize(m,m);let g=Math.acos(L.dot(d,c));I.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,T=(r+n*w)*y,A=n*S,C=L.fromValues(E,T,A),B=w*p,F=w*y,k=S,N=L.fromValues(B,F,k);L.transformMat4(C,C,f),L.transformMat4(N,N,f),L.add(C,C,l),v.push(C),x.push(N)}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=rr(p),_=rr(y),w=rr(v),S=rr(x),E=L.create();L.subtract(E,y,p);let T=L.create();L.subtract(T,v,p);let A=L.create();L.cross(A,E,T),L.normalize(A,A),this.addTriangle(b,_,w,rr(A),i);let C=L.create();L.subtract(C,v,p);let B=L.create();L.subtract(B,x,p);let F=L.create();L.cross(F,C,B),L.normalize(F,F),this.addTriangle(b,w,S,rr(F),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 o of this.labels){let a=yo.fromValues(o.position.x,o.position.y,o.position.z,1),s=yo.create(),l=e,d=a[0],f=a[1],u=a[2],h=a[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:o.text,x:p,y})}}return i}clear(){this.vertices=[],this.solidVertices=[],this.labels=[]}};function Om(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 o=[],a=Math.min(i.length,n);for(let s=0;s<a;s++)o.push(i[s].light);return o}function wu(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 Um=t=>{let e=new ho(t),r=new mo(t),n=new go(t),i=new _o(t),o=new Mo(t),a=new oc(t),s=new lc(t),c=new ac(t),l=new _f({seed:Date.now()}),d=new So(4096,l),f=new wo(t,d),u=e.shaderSize+r.shaderSize+n.shaderSize+i.shaderSize+o.shaderSize+a.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,T=1,A=1,C=!1,B=0,F=new Map,k=!1,N=!1,ce=.5,Ht=1,Pt=new Array(1024).fill(!0),Or=Fm(t,e,r),sn=1e4,ut=[],tt=0,Vt=tc.create(),Wn=L.create(),ln=L.create();for(let M=0;M<sn;M++){let X={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}};X.lighting&&(X.lighting.modelMatrix=X.transform),ut.push(X)}let Ur=[],Nr,Hr,D,ae=(M,X)=>{if(M.type==="md2"){let ie=M.model;if(!ie.lods||ie.lods.length===0)return{model:M.model,type:M.type};let de=M.transform[12]-X.x,re=M.transform[13]-X.y,pe=M.transform[14]-X.z,Ke=Math.sqrt(de*de+re*re+pe*pe),It=Math.floor(Ke*Ht/500);if(It<=0)return{model:M.model,type:M.type};let Ie=ie.lods,Xt=Math.min(It-1,Ie.length-1);return{model:Ie[Xt],type:M.type}}return{model:M.model,type:M.type}},Pe=(M,X,ie)=>{c.startFrame(),y++;let de=Ur.length>0?[...X,...Ur]:X;Ur.length=0,tt=0,M.deltaTime&&d.update(M.deltaTime),t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0);let pe=M.renderMode,Ke=!1;ie?.wireframe||E===6?pe={mode:"wireframe",applyToAll:!0,color:[1,1,1,1]}:E===5&&(Ke=!0);let It=M.sky;ie?.showSkybox===!1&&(It=void 0);let Ie=new Float32Array(M.camera.viewProjectionMatrix),Xt=Dn(Ie),Bt=M.dlights?Om(M.dlights,Xt,{x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},32):void 0,Oo={...M,sky:It,renderMode:pe,disableLightmaps:ie?.showLightmaps===!1&&E!==5,dlights:Bt,lightmapOnly:Ke,brightness:T,gamma:A,fullbright:C,ambient:B,lightStyleOverrides:F,underwaterWarp:k,bloom:N,bloomIntensity:ce,portalState:Pt},Rs=Or.renderFrame(Oo),ff=Rs.facesDrawn||0,hf=0;M.world&&M.world.map&&M.world.map.faces&&(hf=M.world.map.faces.length);let wp=hf-ff,zc=-1,Oc=-1,Uc=null;if(M.world&&ie?.cullingEnabled!==!1){let O={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},De=xi(M.world.map,O);if(De>=0){let ft=M.world.map.leafs[De];zc=ft.cluster,Oc=ft.area,Oc>=0&&M.world.map.areas.length>0&&(Uc=Wd(M.world.map,Oc,Pt))}}let Cs,Uo=0,Nc=0,mf=0,Ps=0,Mp={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]};if(y%v===0)for(let[O,De]of p)y-De.lastFrameSeen>x&&p.delete(O);for(let O of de){if(M.world&&zc>=0){let Q={x:O.transform[12],y:O.transform[13],z:O.transform[14]},U=-1;if(O.id!==void 0){let Y=p.get(O.id);Y&&Y.position[12]===O.transform[12]&&Y.position[13]===O.transform[13]&&Y.position[14]===O.transform[14]?(U=Y.leafIndex,Y.lastFrameSeen=y):(U=xi(M.world.map,Q),U>=0&&p.set(O.id,{leafIndex:U,position:new Float32Array(O.transform),lastFrameSeen:y}))}else U=xi(M.world.map,Q);if(U>=0){let Y=M.world.map.leafs[U],$t=Y.cluster,Oe=Y.area;if(Uc&&Oe>=0&&!Uc.has(Oe)){Ps++;continue}if(!Gd(M.world.map.visibility,zc,$t)){Ps++;continue}}}let{model:De,type:ft}=ae(O,Mp),ze,ve;if(ft==="md2"){let Q=De,U=Q.frames[O.blend.frame0%Q.frames.length],Y=Q.frames[O.blend.frame1%Q.frames.length];U&&Y&&(ze={x:Math.min(U.minBounds.x,Y.minBounds.x),y:Math.min(U.minBounds.y,Y.minBounds.y),z:Math.min(U.minBounds.z,Y.minBounds.z)},ve={x:Math.max(U.maxBounds.x,Y.maxBounds.x),y:Math.max(U.maxBounds.y,Y.maxBounds.y),z:Math.max(U.maxBounds.z,Y.maxBounds.z)})}else if(ft==="md3"){let Q=De,U=Q.frames[O.blend.frame0%Q.frames.length],Y=Q.frames[O.blend.frame1%Q.frames.length];U&&Y?(ze={x:Math.min(U.minBounds.x,Y.minBounds.x),y:Math.min(U.minBounds.y,Y.minBounds.y),z:Math.min(U.minBounds.z,Y.minBounds.z)},ve={x:Math.max(U.maxBounds.x,Y.maxBounds.x),y:Math.max(U.maxBounds.y,Y.maxBounds.y),z:Math.max(U.maxBounds.z,Y.maxBounds.z)}):(ze={x:-32,y:-32,z:-32},ve={x:32,y:32,z:32})}if(ze&&ve){let Q=Oh(ze,ve,O.transform);if(!bi(Q.mins,Q.maxs,Xt)){Ps++;continue}}mf++;let ar={x:O.transform[12],y:O.transform[13],z:O.transform[14]},Ye=km(M.world?.map,ar),Te=O.id!==void 0?w.get(O.id):void 0;switch(ft){case"md2":{let Q=De,U=m.get(Q);if(U)U.update(Q,O.blend);else{U=new po(t,Q,O.blend),m.set(Q,U);let Ue=U.geometry.vertices.length*8*4,dn=U.geometry.indices.length*2;c.trackBufferMemory(Ue+dn)}let Y=Xc(Ie,O.transform),$t=O.skin,Oe=$t?M.world?.textures?.get($t):void 0;Oe&&Oe!==Cs&&(Oe.bind(0),Cs=Oe);let Kt=pe;if(Kt&&!Kt.applyToAll&&Oe&&(Kt=void 0),Kt?.generateRandomColor&&O.id!==void 0){let Ue=wu(O.id);Kt={...Kt,color:Ue}}if(n.bind({modelViewProjection:Y,modelMatrix:O.transform,ambientLight:Ye,dlights:M.dlights,renderMode:Kt,tint:O.tint,brightness:T,gamma:A,fullbright:C,ambient:B}),n.draw(U,Kt),Uo++,Nc+=U.geometry.vertices.length,Te){let Ue={mode:"wireframe",applyToAll:!0,color:Te};n.bind({modelViewProjection:Y,modelMatrix:O.transform,ambientLight:1,renderMode:Ue,tint:[1,1,1,1],brightness:1,gamma:1,fullbright:!0,ambient:0}),n.draw(U,Ue),Uo++}}break;case"md3":{let Q=De,U=h.get(Q),Y=O,$t=M.dlights?M.dlights.map(Ue=>({origin:Ue.origin,color:[Ue.color.x,Ue.color.y,Ue.color.z],radius:Ue.intensity})):void 0,Oe={...Y.lighting,ambient:[Ye,Ye,Ye],dynamicLights:$t,modelMatrix:O.transform};U?U.update(O.blend,Oe):(U=new vo(t,Q,O.blend,Oe),h.set(Q,U));let Kt=Xc(Ie,O.transform);i.bind(Kt);for(let Ue of Q.surfaces){let dn=U.surfaces.get(Ue.name);if(dn){let gf=Y.skins?.get(Ue.name),No=gf?M.world?.textures?.get(gf):void 0;No&&No!==Cs&&(No.bind(0),Cs=No);let Kn=pe;if(Kn&&!Kn.applyToAll&&No&&(Kn=void 0),Kn?.generateRandomColor&&O.id!==void 0){let yf=wu(O.id);Kn={...Kn,color:yf}}let Ap={renderMode:Kn,brightness:T,gamma:A,fullbright:C,globalAmbient:B};if(i.drawSurface(dn,Ap),Uo++,Nc+=dn.geometry.vertices.length,Te){let Ep={renderMode:{mode:"wireframe",applyToAll:!0,color:Te},brightness:1,gamma:1,fullbright:!0,globalAmbient:0};i.drawSurface(dn,Ep),Uo++}}}}break}}let $n=M.camera.viewMatrix;if($n){let O={x:$n[0],y:$n[4],z:$n[8]},De={x:$n[1],y:$n[5],z:$n[9]};f.render({viewProjection:Ie,viewRight:O,viewUp:De})}if(Oo.waterTint&&(Nr(),D(0,0,t.canvas.width,t.canvas.height,Oo.waterTint),Hr()),a.render(Ie),a.clear(),M.world&&(S.size>0||E===3)){let O=new Map(S);if(E===3&&M.world){let De=Dn(Ie),ft={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},ze=vi(M.world.map,ft,De,Pt);for(let{faceIndex:ve,leafIndex:ar}of ze){let Ye=M.world.map.leafs[ar];Ye&&!O.has(ve)&&O.set(ve,wu(Ye.cluster))}}for(let[De,ft]of O){let ze=M.world.surfaces[De];if(ze&&ze.vertexCount>0){let ve=[];for(let Te=0;Te<ze.vertexCount;Te++)ve.push({x:ze.vertexData[Te*7],y:ze.vertexData[Te*7+1],z:ze.vertexData[Te*7+2]});let Ye={r:ft[0],g:ft[1],b:ft[2]};for(let Te=0;Te<ve.length;Te++){let Q=ve[Te],U=ve[(Te+1)%ve.length];s.drawLine(Q,U,Ye)}s.drawLine(ve[0],ve[ve.length/2|0],Ye)}}}if((ie?.showNormals||E===2)&&M.world){let O=Dn(Ie),De={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},ft=vi(M.world.map,De,O,Pt);for(let{faceIndex:ze}of ft){let ve=M.world.map.faces[ze],ar=M.world.map.planes[ve.planeIndex],Ye=M.world.surfaces[ze];if(!Ye)continue;let Te=0,Q=0,U=0,Y=Ye.vertexCount;for(let $t=0;$t<Y;$t++){let Oe=$t*7;Te+=Ye.vertexData[Oe],Q+=Ye.vertexData[Oe+1],U+=Ye.vertexData[Oe+2]}if(Y>0){Te/=Y,Q/=Y,U/=Y;let $t=ve.side===0?ar.normal[0]:-ar.normal[0],Oe=ve.side===0?ar.normal[1]:-ar.normal[1],Kt=ve.side===0?ar.normal[2]:-ar.normal[2],Ue={x:Te,y:Q,z:U},dn={x:Te+$t*8,y:Q+Oe*8,z:U+Kt*8};s.drawLine(Ue,dn,{r:1,g:1,b:0})}}}s.render(Ie);let pf=s.getLabels(Ie,t.canvas.width,t.canvas.height);if(pf.length>0){Nr();for(let O of pf)Ri(O.x,O.y,O.text,[1,1,1,1]);Hr()}s.clear(),_={drawCalls:Rs.drawCalls+Uo,vertexCount:Rs.vertexCount+Nc,batches:Rs.batches,shaderSwitches:0,visibleSurfaces:ff,culledSurfaces:wp,visibleEntities:mf,culledEntities:Ps},c.endFrame()},Ce=async(M,X)=>{if(g.has(M))return g.get(M);let ie=new Blob([X]),de=await createImageBitmap(ie),re=new et(t);return re.upload(de.width,de.height,de),g.set(M,re),c.trackTextureMemory(de.width*de.height*4),M.includes("conchars")&&(b=re),re},or=(M,X)=>{if(g.has(M))return g.get(M);let ie=new et(t),de=X.levels[0];return ie.upload(de.width,de.height,de.rgba),g.set(M,ie),c.trackTextureMemory(de.width*de.height*4),M.includes("conchars")&&(b=ie),ie};Nr=()=>{t.enable(t.BLEND),t.blendFunc(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA),t.disable(t.DEPTH_TEST),t.depthMask(!1);let M=I.create();I.ortho(M,0,t.canvas.width,t.canvas.height,0,-1,1),o.begin(M)},Hr=()=>{t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0)};let Gt=(M,X,ie,de)=>{ie.bind(0),o.draw(M,X,ie.width,ie.height,0,0,1,1,de)},cn=(M,X,ie,de)=>{if(!b)return;let re=8,pe=8,Ke=b.width/re,It=ie&255,Ie=It%Ke*re/b.width,Xt=Math.floor(It/Ke)*pe/b.height,Bt=Ie+re/b.width,Oo=Xt+pe/b.height;b.bind(0),o.draw(M,X,re,pe,Ie,Xt,Bt,Oo,de)},Ri=(M,X,ie,de)=>{let re=zm(ie),pe=M,Ke=8;for(let It of re){let Ie=It.color||de;for(let Xt=0;Xt<It.text.length;Xt++)cn(pe,X,It.text.charCodeAt(Xt),Ie),pe+=Ke}},Wt=(M,X)=>{let re=X.replace(/\^[0-9]/g,"").length*8,pe=(t.canvas.width-re)/2;Ri(pe,M,X)};return D=(M,X,ie,de,re)=>{o.drawRect(M,X,ie,de,re)},{get width(){return t.canvas.width},get height(){return t.canvas.height},get collisionVis(){return a},get debug(){return s},get particleSystem(){return d},getPerformanceReport:()=>c.getPerformanceReport(_),getMemoryUsage:()=>c.getMemoryUsage(),renderFrame:Pe,registerPic:Ce,registerTexture:or,begin2D:Nr,end2D:Hr,drawPic:Gt,drawString:Ri,drawCenterString:Wt,drawfillRect:D,setEntityHighlight:(M,X)=>{w.set(M,X)},clearEntityHighlight:M=>{w.delete(M)},highlightSurface:(M,X)=>{S.set(M,X)},removeSurfaceHighlight:M=>{S.delete(M)},setDebugMode:M=>{E=M},setBrightness:M=>{T=Math.max(0,Math.min(2,M))},setGamma:M=>{A=Math.max(.5,Math.min(3,M))},setFullbright:M=>{C=M},setAmbient:M=>{B=Math.max(0,Math.min(1,M))},setLightStyle:(M,X)=>{X===null?F.delete(M):F.set(M,X)},setUnderwaterWarp:M=>{k=M},setBloom:M=>{N=M},setBloomIntensity:M=>{ce=M},setLodBias:M=>{Ht=Math.max(0,Math.min(2,M))},setAreaPortalState:(M,X)=>{M>=0&&M<Pt.length&&(Pt[M]=X)},renderInstanced:(M,X)=>{let ie="glCommands"in M,de=ie?"md2":"md3";for(let re of X){if(tt>=sn){console.warn("Max instances reached");break}let pe=ut[tt++];pe.model=M,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 It=re.rotation,Ie=re.position,Xt=re.scale||{x:1,y:1,z:1};I.fromRotationTranslationScale(pe.transform,Vt,Wn,ln);let Bt=pe.lighting;Bt&&(Bt.dynamicLights?Bt.dynamicLights.length=0:Bt.dynamicLights=[],Bt.ambient?(Bt.ambient[0]=.5,Bt.ambient[1]=.5,Bt.ambient[2]=.5):Bt.ambient=[.5,.5,.5]),Ur.push(pe)}},uploadBspGeometry:M=>{let X=Wl(M);return Xl(t,X,M)},dispose:()=>{c.dispose()}}};var hr=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 pn(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 o=new Uint8Array(e),a=0,s=new Uint8Array(this.buffer);for(let c of n)o.set(s.subarray(c.offset,c.offset+c.length),a),a+=c.length;return this.offset=i,o.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 Co(t){let e=t.length;for(;--e>=0;)t[e]=0}var rv=0,M0=1,nv=2,iv=3,ov=258,Ku=29,xs=256,us=xs+1+Ku,Lo=30,Yu=19,A0=2*us+1,_i=15,Mu=16,av=7,qu=256,E0=16,L0=17,T0=18,Ou=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]),mc=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]),sv=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),R0=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),lv=512,on=new Array((us+2)*2);Co(on);var ls=new Array(Lo*2);Co(ls);var fs=new Array(lv);Co(fs);var hs=new Array(ov-iv+1);Co(hs);var Zu=new Array(Ku);Co(Zu);var pc=new Array(Lo);Co(pc);function Au(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 C0,P0,I0;function Eu(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}var B0=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},Ct=(t,e,r)=>{t.bi_valid>Mu-r?(t.bi_buf|=e<<t.bi_valid&65535,ms(t,t.bi_buf),t.bi_buf=e>>Mu-t.bi_valid,t.bi_valid+=r-Mu):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=r)},Br=(t,e,r)=>{Ct(t,r[e*2],r[e*2+1])},F0=(t,e)=>{let r=0;do r|=t&1,t>>>=1,r<<=1;while(--e>0);return r>>>1},cv=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)},dv=(t,e)=>{let r=e.dyn_tree,n=e.max_code,i=e.stat_desc.static_tree,o=e.stat_desc.has_stree,a=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<=_i;u++)t.bl_count[u]=0;for(r[t.heap[t.heap_max]*2+1]=0,l=t.heap_max+1;l<A0;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=a[d-s]),m=r[d*2],t.opt_len+=m*(u+h),o&&(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--)}},k0=(t,e,r)=>{let n=new Array(_i+1),i=0,o,a;for(o=1;o<=_i;o++)i=i+r[o-1]<<1,n[o]=i;for(a=0;a<=e;a++){let s=t[a*2+1];s!==0&&(t[a*2]=F0(n[s]++,s))}},uv=()=>{let t,e,r,n,i,o=new Array(_i+1);for(r=0,n=0;n<Ku-1;n++)for(Zu[n]=r,t=0;t<1<<Ou[n];t++)hs[r++]=n;for(hs[r-1]=n,i=0,n=0;n<16;n++)for(pc[n]=i,t=0;t<1<<mc[n];t++)fs[i++]=n;for(i>>=7;n<Lo;n++)for(pc[n]=i<<7,t=0;t<1<<mc[n]-7;t++)fs[256+i++]=n;for(e=0;e<=_i;e++)o[e]=0;for(t=0;t<=143;)on[t*2+1]=8,t++,o[8]++;for(;t<=255;)on[t*2+1]=9,t++,o[9]++;for(;t<=279;)on[t*2+1]=7,t++,o[7]++;for(;t<=287;)on[t*2+1]=8,t++,o[8]++;for(k0(on,us+1,o),t=0;t<Lo;t++)ls[t*2+1]=5,ls[t*2]=F0(t,5);C0=new Au(on,Ou,xs+1,us,_i),P0=new Au(ls,mc,0,Lo,_i),I0=new Au(new Array(0),sv,0,Yu,av)},D0=t=>{let e;for(e=0;e<us;e++)t.dyn_ltree[e*2]=0;for(e=0;e<Lo;e++)t.dyn_dtree[e*2]=0;for(e=0;e<Yu;e++)t.bl_tree[e*2]=0;t.dyn_ltree[qu*2]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},z0=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},Nm=(t,e,r,n)=>{let i=e*2,o=r*2;return t[i]<t[o]||t[i]===t[o]&&n[e]<=n[r]},Lu=(t,e,r)=>{let n=t.heap[r],i=r<<1;for(;i<=t.heap_len&&(i<t.heap_len&&Nm(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!Nm(e,n,t.heap[i],t.depth));)t.heap[r]=t.heap[i],r=i,i<<=1;t.heap[r]=n},Hm=(t,e,r)=>{let n,i,o=0,a,s;if(t.sym_next!==0)do n=t.pending_buf[t.sym_buf+o++]&255,n+=(t.pending_buf[t.sym_buf+o++]&255)<<8,i=t.pending_buf[t.sym_buf+o++],n===0?Br(t,i,e):(a=hs[i],Br(t,a+xs+1,e),s=Ou[a],s!==0&&(i-=Zu[a],Ct(t,i,s)),n--,a=B0(n),Br(t,a,r),s=mc[a],s!==0&&(n-=pc[a],Ct(t,n,s)));while(o<t.sym_next);Br(t,qu,e)},Uu=(t,e)=>{let r=e.dyn_tree,n=e.stat_desc.static_tree,i=e.stat_desc.has_stree,o=e.stat_desc.elems,a,s,c=-1,l;for(t.heap_len=0,t.heap_max=A0,a=0;a<o;a++)r[a*2]!==0?(t.heap[++t.heap_len]=c=a,t.depth[a]=0):r[a*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,a=t.heap_len>>1;a>=1;a--)Lu(t,r,a);l=o;do a=t.heap[1],t.heap[1]=t.heap[t.heap_len--],Lu(t,r,1),s=t.heap[1],t.heap[--t.heap_max]=a,t.heap[--t.heap_max]=s,r[l*2]=r[a*2]+r[s*2],t.depth[l]=(t.depth[a]>=t.depth[s]?t.depth[a]:t.depth[s])+1,r[a*2+1]=r[s*2+1]=l,t.heap[1]=l++,Lu(t,r,1);while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],dv(t,e),k0(r,c,t.bl_count)},Vm=(t,e,r)=>{let n,i=-1,o,a=e[1],s=0,c=7,l=4;for(a===0&&(c=138,l=3),e[(r+1)*2+1]=65535,n=0;n<=r;n++)o=a,a=e[(n+1)*2+1],!(++s<c&&o===a)&&(s<l?t.bl_tree[o*2]+=s:o!==0?(o!==i&&t.bl_tree[o*2]++,t.bl_tree[E0*2]++):s<=10?t.bl_tree[L0*2]++:t.bl_tree[T0*2]++,s=0,i=o,a===0?(c=138,l=3):o===a?(c=6,l=3):(c=7,l=4))},Gm=(t,e,r)=>{let n,i=-1,o,a=e[1],s=0,c=7,l=4;for(a===0&&(c=138,l=3),n=0;n<=r;n++)if(o=a,a=e[(n+1)*2+1],!(++s<c&&o===a)){if(s<l)do Br(t,o,t.bl_tree);while(--s!==0);else o!==0?(o!==i&&(Br(t,o,t.bl_tree),s--),Br(t,E0,t.bl_tree),Ct(t,s-3,2)):s<=10?(Br(t,L0,t.bl_tree),Ct(t,s-3,3)):(Br(t,T0,t.bl_tree),Ct(t,s-11,7));s=0,i=o,a===0?(c=138,l=3):o===a?(c=6,l=3):(c=7,l=4)}},fv=t=>{let e;for(Vm(t,t.dyn_ltree,t.l_desc.max_code),Vm(t,t.dyn_dtree,t.d_desc.max_code),Uu(t,t.bl_desc),e=Yu-1;e>=3&&t.bl_tree[R0[e]*2+1]===0;e--);return t.opt_len+=3*(e+1)+5+5+4,e},hv=(t,e,r,n)=>{let i;for(Ct(t,e-257,5),Ct(t,r-1,5),Ct(t,n-4,4),i=0;i<n;i++)Ct(t,t.bl_tree[R0[i]*2+1],3);Gm(t,t.dyn_ltree,e-1),Gm(t,t.dyn_dtree,r-1)},mv=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},Wm=!1,pv=t=>{Wm||(uv(),Wm=!0),t.l_desc=new Eu(t.dyn_ltree,C0),t.d_desc=new Eu(t.dyn_dtree,P0),t.bl_desc=new Eu(t.bl_tree,I0),t.bi_buf=0,t.bi_valid=0,D0(t)},O0=(t,e,r,n)=>{Ct(t,(rv<<1)+(n?1:0),3),z0(t),ms(t,r),ms(t,~r),r&&t.pending_buf.set(t.window.subarray(e,e+r),t.pending),t.pending+=r},gv=t=>{Ct(t,M0<<1,3),Br(t,qu,on),cv(t)},yv=(t,e,r,n)=>{let i,o,a=0;t.level>0?(t.strm.data_type===2&&(t.strm.data_type=mv(t)),Uu(t,t.l_desc),Uu(t,t.d_desc),a=fv(t),i=t.opt_len+3+7>>>3,o=t.static_len+3+7>>>3,o<=i&&(i=o)):i=o=r+5,r+4<=i&&e!==-1?O0(t,e,r,n):t.strategy===4||o===i?(Ct(t,(M0<<1)+(n?1:0),3),Hm(t,on,ls)):(Ct(t,(nv<<1)+(n?1:0),3),hv(t,t.l_desc.max_code+1,t.d_desc.max_code+1,a+1),Hm(t,t.dyn_ltree,t.dyn_dtree)),D0(t),n&&z0(t)},bv=(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[B0(e)*2]++),t.sym_next===t.sym_end),xv=pv,vv=O0,_v=yv,Sv=bv,wv=gv,Mv={_tr_init:xv,_tr_stored_block:vv,_tr_flush_block:_v,_tr_tally:Sv,_tr_align:wv},Av=(t,e,r,n)=>{let i=t&65535|0,o=t>>>16&65535|0,a=0;for(;r!==0;){a=r>2e3?2e3:r,r-=a;do i=i+e[n++]|0,o=o+i|0;while(--a);i%=65521,o%=65521}return i|o<<16|0},ps=Av,Ev=()=>{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},Lv=new Uint32Array(Ev()),Tv=(t,e,r,n)=>{let i=Lv,o=n+r;t^=-1;for(let a=n;a<o;a++)t=t>>>8^i[(t^e[a])&255];return t^-1},ke=Tv,Mi={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"},Li={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:Rv,_tr_stored_block:Nu,_tr_flush_block:Cv,_tr_tally:Nn,_tr_align:Pv}=Mv,{Z_NO_FLUSH:Hn,Z_PARTIAL_FLUSH:Iv,Z_FULL_FLUSH:Bv,Z_FINISH:nr,Z_BLOCK:Xm,Z_OK:$e,Z_STREAM_END:$m,Z_STREAM_ERROR:Fr,Z_DATA_ERROR:Fv,Z_BUF_ERROR:Tu,Z_DEFAULT_COMPRESSION:kv,Z_FILTERED:Dv,Z_HUFFMAN_ONLY:cc,Z_RLE:zv,Z_FIXED:Ov,Z_DEFAULT_STRATEGY:Uv,Z_UNKNOWN:Nv,Z_DEFLATED:bc}=Li,Hv=9,Vv=15,Gv=8,Wv=29,Xv=256,Hu=Xv+1+Wv,$v=30,Kv=19,Yv=2*Hu+1,qv=15,j=3,Un=258,kr=Un+j+1,Zv=32,To=42,ju=57,Vu=69,Gu=73,Wu=91,Xu=103,Si=113,as=666,ct=1,Po=2,Ai=3,Io=4,jv=3,wi=(t,e)=>(t.msg=Mi[e],e),Km=t=>t*2-(t>4?9:0),On=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Qv=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)},Jv=(t,e,r)=>(e<<t.hash_shift^r)&t.hash_mask,Vn=Jv,Ut=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))},Nt=(t,e)=>{Cv(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Ut(t.strm)},ne=(t,e)=>{t.pending_buf[t.pending++]=e},os=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=e&255},$u=(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=ke(t.adler,e,i,r)),t.next_in+=i,t.total_in+=i,i)},U0=(t,e)=>{let r=t.max_chain_length,n=t.strstart,i,o,a=t.prev_length,s=t.nice_match,c=t.strstart>t.w_size-kr?t.strstart-(t.w_size-kr):0,l=t.window,d=t.w_mask,f=t.prev,u=t.strstart+Un,h=l[n+a-1],m=l[n+a];t.prev_length>=t.good_match&&(r>>=2),s>t.lookahead&&(s=t.lookahead);do if(i=e,!(l[i+a]!==m||l[i+a-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(o=Un-(u-n),n=u-Un,o>a){if(t.match_start=e,a=o,o>=s)break;h=l[n+a-1],m=l[n+a]}}while((e=f[e&d])>c&&--r!==0);return a<=t.lookahead?a:t.lookahead},Ro=t=>{let e=t.w_size,r,n,i;do{if(n=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-kr)&&(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),Qv(t),n+=e),t.strm.avail_in===0)break;if(r=$u(t.strm,t.window,t.strstart+t.lookahead,n),t.lookahead+=r,t.lookahead+t.insert>=j)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Vn(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Vn(t,t.ins_h,t.window[i+j-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<j)););}while(t.lookahead<kr&&t.strm.avail_in!==0)},N0=(t,e)=>{let r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n,i,o,a=0,s=t.strm.avail_in;do{if(n=65535,o=t.bi_valid+42>>3,t.strm.avail_out<o||(o=t.strm.avail_out-o,i=t.strstart-t.block_start,n>i+t.strm.avail_in&&(n=i+t.strm.avail_in),n>o&&(n=o),n<r&&(n===0&&e!==nr||e===Hn||n!==i+t.strm.avail_in)))break;a=e===nr&&n===i+t.strm.avail_in?1:0,Nu(t,0,0,a),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,Ut(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&&($u(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(a===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),a?Io:e!==Hn&&e!==nr&&t.strm.avail_in===0&&t.strstart===t.block_start?Po:(o=t.window_size-t.strstart,t.strm.avail_in>o&&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++,o+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),o>t.strm.avail_in&&(o=t.strm.avail_in),o&&($u(t.strm,t.window,t.strstart,o),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.high_water<t.strstart&&(t.high_water=t.strstart),o=t.bi_valid+42>>3,o=t.pending_buf_size-o>65535?65535:t.pending_buf_size-o,r=o>t.w_size?t.w_size:o,i=t.strstart-t.block_start,(i>=r||(i||e===nr)&&e!==Hn&&t.strm.avail_in===0&&i<=o)&&(n=i>o?o:i,a=e===nr&&t.strm.avail_in===0&&n===i?1:0,Nu(t,t.block_start,n,a),t.block_start+=n,Ut(t.strm)),a?Ai:ct)},Ru=(t,e)=>{let r,n;for(;;){if(t.lookahead<kr){if(Ro(t),t.lookahead<kr&&e===Hn)return ct;if(t.lookahead===0)break}if(r=0,t.lookahead>=j&&(t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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-kr&&(t.match_length=U0(t,r)),t.match_length>=j)if(n=Nn(t,t.strstart-t.match_start,t.match_length-j),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=j){t.match_length--;do t.strstart++,t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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=Vn(t,t.ins_h,t.window[t.strstart+1]);else n=Nn(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(n&&(Nt(t,!1),t.strm.avail_out===0))return ct}return t.insert=t.strstart<j-1?t.strstart:j-1,e===nr?(Nt(t,!0),t.strm.avail_out===0?Ai:Io):t.sym_next&&(Nt(t,!1),t.strm.avail_out===0)?ct:Po},Ao=(t,e)=>{let r,n,i;for(;;){if(t.lookahead<kr){if(Ro(t),t.lookahead<kr&&e===Hn)return ct;if(t.lookahead===0)break}if(r=0,t.lookahead>=j&&(t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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=j-1,r!==0&&t.prev_length<t.max_lazy_match&&t.strstart-r<=t.w_size-kr&&(t.match_length=U0(t,r),t.match_length<=5&&(t.strategy===Dv||t.match_length===j&&t.strstart-t.match_start>4096)&&(t.match_length=j-1)),t.prev_length>=j&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-j,n=Nn(t,t.strstart-1-t.prev_match,t.prev_length-j),t.lookahead-=t.prev_length-1,t.prev_length-=2;do++t.strstart<=i&&(t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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=j-1,t.strstart++,n&&(Nt(t,!1),t.strm.avail_out===0))return ct}else if(t.match_available){if(n=Nn(t,0,t.window[t.strstart-1]),n&&Nt(t,!1),t.strstart++,t.lookahead--,t.strm.avail_out===0)return ct}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(n=Nn(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<j-1?t.strstart:j-1,e===nr?(Nt(t,!0),t.strm.avail_out===0?Ai:Io):t.sym_next&&(Nt(t,!1),t.strm.avail_out===0)?ct:Po},e_=(t,e)=>{let r,n,i,o,a=t.window;for(;;){if(t.lookahead<=Un){if(Ro(t),t.lookahead<=Un&&e===Hn)return ct;if(t.lookahead===0)break}if(t.match_length=0,t.lookahead>=j&&t.strstart>0&&(i=t.strstart-1,n=a[i],n===a[++i]&&n===a[++i]&&n===a[++i])){o=t.strstart+Un;do;while(n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&i<o);t.match_length=Un-(o-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=j?(r=Nn(t,1,t.match_length-j),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(r=Nn(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),r&&(Nt(t,!1),t.strm.avail_out===0))return ct}return t.insert=0,e===nr?(Nt(t,!0),t.strm.avail_out===0?Ai:Io):t.sym_next&&(Nt(t,!1),t.strm.avail_out===0)?ct:Po},t_=(t,e)=>{let r;for(;;){if(t.lookahead===0&&(Ro(t),t.lookahead===0)){if(e===Hn)return ct;break}if(t.match_length=0,r=Nn(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,r&&(Nt(t,!1),t.strm.avail_out===0))return ct}return t.insert=0,e===nr?(Nt(t,!0),t.strm.avail_out===0?Ai:Io):t.sym_next&&(Nt(t,!1),t.strm.avail_out===0)?ct:Po};function Ir(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 Ir(0,0,0,0,N0),new Ir(4,4,8,4,Ru),new Ir(4,5,16,8,Ru),new Ir(4,6,32,32,Ru),new Ir(4,4,16,16,Ao),new Ir(8,16,32,32,Ao),new Ir(8,16,128,128,Ao),new Ir(8,32,128,256,Ao),new Ir(32,128,258,1024,Ao),new Ir(32,258,258,4096,Ao)],r_=t=>{t.window_size=2*t.w_size,On(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=j-1,t.match_available=0,t.ins_h=0};function n_(){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=bc,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(Yv*2),this.dyn_dtree=new Uint16Array((2*$v+1)*2),this.bl_tree=new Uint16Array((2*Kv+1)*2),On(this.dyn_ltree),On(this.dyn_dtree),On(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(qv+1),this.heap=new Uint16Array(2*Hu+1),On(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(2*Hu+1),On(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!==To&&e.status!==ju&&e.status!==Vu&&e.status!==Gu&&e.status!==Wu&&e.status!==Xu&&e.status!==Si&&e.status!==as?1:0},H0=t=>{if(vs(t))return wi(t,Fr);t.total_in=t.total_out=0,t.data_type=Nv;let e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=e.wrap===2?ju:e.wrap?To:Si,t.adler=e.wrap===2?0:1,e.last_flush=-2,Rv(e),$e},V0=t=>{let e=H0(t);return e===$e&&r_(t.state),e},i_=(t,e)=>vs(t)||t.state.wrap!==2?Fr:(t.state.gzhead=e,$e),G0=(t,e,r,n,i,o)=>{if(!t)return Fr;let a=1;if(e===kv&&(e=6),n<0?(a=0,n=-n):n>15&&(a=2,n-=16),i<1||i>Hv||r!==bc||n<8||n>15||e<0||e>9||o<0||o>Ov||n===8&&a!==1)return wi(t,Fr);n===8&&(n=9);let s=new n_;return t.state=s,s.strm=t,s.status=To,s.wrap=a,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+j-1)/j),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=o,s.method=r,V0(t)},o_=(t,e)=>G0(t,e,bc,Vv,Gv,Uv),a_=(t,e)=>{if(vs(t)||e>Xm||e<0)return t?wi(t,Fr):Fr;let r=t.state;if(!t.output||t.avail_in!==0&&!t.input||r.status===as&&e!==nr)return wi(t,t.avail_out===0?Tu:Fr);let n=r.last_flush;if(r.last_flush=e,r.pending!==0){if(Ut(t),t.avail_out===0)return r.last_flush=-1,$e}else if(t.avail_in===0&&Km(e)<=Km(n)&&e!==nr)return wi(t,Tu);if(r.status===as&&t.avail_in!==0)return wi(t,Tu);if(r.status===To&&r.wrap===0&&(r.status=Si),r.status===To){let i=bc+(r.w_bits-8<<4)<<8,o=-1;if(r.strategy>=cc||r.level<2?o=0:r.level<6?o=1:r.level===6?o=2:o=3,i|=o<<6,r.strstart!==0&&(i|=Zv),i+=31-i%31,os(r,i),r.strstart!==0&&(os(r,t.adler>>>16),os(r,t.adler&65535)),t.adler=1,r.status=Si,Ut(t),r.pending!==0)return r.last_flush=-1,$e}if(r.status===ju){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>=cc||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=ke(t.adler,r.pending_buf,r.pending,0)),r.gzindex=0,r.status=Vu;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>=cc||r.level<2?4:0),ne(r,jv),r.status=Si,Ut(t),r.pending!==0)return r.last_flush=-1,$e}if(r.status===Vu){if(r.gzhead.extra){let i=r.pending,o=(r.gzhead.extra.length&65535)-r.gzindex;for(;r.pending+o>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=ke(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex+=s,Ut(t),r.pending!==0)return r.last_flush=-1,$e;i=0,o-=s}let a=new Uint8Array(r.gzhead.extra);r.pending_buf.set(a.subarray(r.gzindex,r.gzindex+o),r.pending),r.pending+=o,r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Gu}if(r.status===Gu){if(r.gzhead.name){let i=r.pending,o;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),Ut(t),r.pending!==0)return r.last_flush=-1,$e;i=0}r.gzindex<r.gzhead.name.length?o=r.gzhead.name.charCodeAt(r.gzindex++)&255:o=0,ne(r,o)}while(o!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Wu}if(r.status===Wu){if(r.gzhead.comment){let i=r.pending,o;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),Ut(t),r.pending!==0)return r.last_flush=-1,$e;i=0}r.gzindex<r.gzhead.comment.length?o=r.gzhead.comment.charCodeAt(r.gzindex++)&255:o=0,ne(r,o)}while(o!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i))}r.status=Xu}if(r.status===Xu){if(r.gzhead.hcrc){if(r.pending+2>r.pending_buf_size&&(Ut(t),r.pending!==0))return r.last_flush=-1,$e;ne(r,t.adler&255),ne(r,t.adler>>8&255),t.adler=0}if(r.status=Si,Ut(t),r.pending!==0)return r.last_flush=-1,$e}if(t.avail_in!==0||r.lookahead!==0||e!==Hn&&r.status!==as){let i=r.level===0?N0(r,e):r.strategy===cc?t_(r,e):r.strategy===zv?e_(r,e):ss[r.level].func(r,e);if((i===Ai||i===Io)&&(r.status=as),i===ct||i===Ai)return t.avail_out===0&&(r.last_flush=-1),$e;if(i===Po&&(e===Iv?Pv(r):e!==Xm&&(Nu(r,0,0,!1),e===Bv&&(On(r.head),r.lookahead===0&&(r.strstart=0,r.block_start=0,r.insert=0))),Ut(t),t.avail_out===0))return r.last_flush=-1,$e}return e!==nr?$e:r.wrap<=0?$m:(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)):(os(r,t.adler>>>16),os(r,t.adler&65535)),Ut(t),r.wrap>0&&(r.wrap=-r.wrap),r.pending!==0?$e:$m)},s_=t=>{if(vs(t))return Fr;let e=t.state.status;return t.state=null,e===Si?wi(t,Fv):$e},l_=(t,e)=>{let r=e.length;if(vs(t))return Fr;let n=t.state,i=n.wrap;if(i===2||i===1&&n.status!==To||n.lookahead)return Fr;if(i===1&&(t.adler=ps(t.adler,e,r,0)),n.wrap=0,r>=n.w_size){i===0&&(On(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 o=t.avail_in,a=t.next_in,s=t.input;for(t.avail_in=r,t.next_in=0,t.input=e,Ro(n);n.lookahead>=j;){let c=n.strstart,l=n.lookahead-(j-1);do n.ins_h=Vn(n,n.ins_h,n.window[c+j-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=j-1,Ro(n)}return n.strstart+=n.lookahead,n.block_start=n.strstart,n.insert=n.lookahead,n.lookahead=0,n.match_length=n.prev_length=j-1,n.match_available=0,t.next_in=a,t.input=s,t.avail_in=o,n.wrap=i,$e},c_=o_,d_=G0,u_=V0,f_=H0,h_=i_,m_=a_,p_=s_,g_=l_,y_="pako deflate (from Nodeca project)",cs={deflateInit:c_,deflateInit2:d_,deflateReset:u_,deflateResetKeep:f_,deflateSetHeader:h_,deflate:m_,deflateEnd:p_,deflateSetDictionary:g_,deflateInfo:y_},b_=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),x_=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)b_(r,n)&&(t[n]=r[n])}}return t},v_=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,o=t.length;n<o;n++){let a=t[n];r.set(a,i),i+=a.length}return r},xc={assign:x_,flattenChunks:v_},W0=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{W0=!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 __=t=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(t);let e,r,n,i,o,a=t.length,s=0;for(i=0;i<a;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<a&&(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),o=0,i=0;o<s;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<a&&(n=t.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),r<128?e[o++]=r:r<2048?(e[o++]=192|r>>>6,e[o++]=128|r&63):r<65536?(e[o++]=224|r>>>12,e[o++]=128|r>>>6&63,e[o++]=128|r&63):(e[o++]=240|r>>>18,e[o++]=128|r>>>12&63,e[o++]=128|r>>>6&63,e[o++]=128|r&63);return e},S_=(t,e)=>{if(e<65534&&t.subarray&&W0)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},w_=(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,o=new Array(r*2);for(i=0,n=0;n<r;){let a=t[n++];if(a<128){o[i++]=a;continue}let s=gs[a];if(s>4){o[i++]=65533,n+=s-1;continue}for(a&=s===2?31:s===3?15:7;s>1&&n<r;)a=a<<6|t[n++]&63,s--;if(s>1){o[i++]=65533;continue}a<65536?o[i++]=a:(a-=65536,o[i++]=55296|a>>10&1023,o[i++]=56320|a&1023)}return S_(o,i)},M_=(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:__,buf2string:w_,utf8border:M_};function A_(){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 X0=A_,$0=Object.prototype.toString,{Z_NO_FLUSH:E_,Z_SYNC_FLUSH:L_,Z_FULL_FLUSH:T_,Z_FINISH:R_,Z_OK:gc,Z_STREAM_END:C_,Z_DEFAULT_COMPRESSION:P_,Z_DEFAULT_STRATEGY:I_,Z_DEFLATED:B_}=Li;function _s(t){this.options=xc.assign({level:P_,method:B_,chunkSize:16384,windowBits:15,memLevel:8,strategy:I_},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 X0,this.strm.avail_out=0;let r=cs.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(r!==gc)throw new Error(Mi[r]);if(e.header&&cs.deflateSetHeader(this.strm,e.header),e.dictionary){let n;if(typeof e.dictionary=="string"?n=ys.string2buf(e.dictionary):$0.call(e.dictionary)==="[object ArrayBuffer]"?n=new Uint8Array(e.dictionary):n=e.dictionary,r=cs.deflateSetDictionary(this.strm,n),r!==gc)throw new Error(Mi[r]);this._dict_set=!0}}_s.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i,o;if(this.ended)return!1;for(e===~~e?o=e:o=e===!0?R_:E_,typeof t=="string"?r.input=ys.string2buf(t):$0.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),(o===L_||o===T_)&&r.avail_out<=6){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(i=cs.deflate(r,o),i===C_)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===gc;if(r.avail_out===0){this.onData(r.output);continue}if(o>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===gc&&(this.result=xc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Qu(t,e){let r=new _s(e);if(r.push(t,!0),r.err)throw r.msg||Mi[r.err];return r.result}function F_(t,e){return e=e||{},e.raw=!0,Qu(t,e)}function k_(t,e){return e=e||{},e.gzip=!0,Qu(t,e)}var D_=_s,z_=Qu,O_=F_,U_=k_,N_=Li,H_={Deflate:D_,deflate:z_,deflateRaw:O_,gzip:U_,constants:N_},dc=16209,V_=16191,G_=function(e,r){let n,i,o,a,s,c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,T,A,C=e.state;n=e.next_in,T=e.input,i=n+(e.avail_in-5),o=e.next_out,A=e.output,a=o-(r-e.avail_out),s=o+(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+=T[n++]<<m,m+=8,h+=T[n++]<<m,m+=8),x=g[h&y];t:for(;;){if(b=x>>>24,h>>>=b,m-=b,b=x>>>16&255,b===0)A[o++]=x&65535;else if(b&16){_=x&65535,b&=15,b&&(m<b&&(h+=T[n++]<<m,m+=8),_+=h&(1<<b)-1,h>>>=b,m-=b),m<15&&(h+=T[n++]<<m,m+=8,h+=T[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+=T[n++]<<m,m+=8,m<b&&(h+=T[n++]<<m,m+=8)),w+=h&(1<<b)-1,w>c){e.msg="invalid distance too far back",C.mode=dc;break e}if(h>>>=b,m-=b,b=o-a,w>b){if(b=w-b,b>d&&C.sane){e.msg="invalid distance too far back",C.mode=dc;break e}if(S=0,E=u,f===0){if(S+=l-b,b<_){_-=b;do A[o++]=u[S++];while(--b);S=o-w,E=A}}else if(f<b){if(S+=l+f-b,b-=f,b<_){_-=b;do A[o++]=u[S++];while(--b);if(S=0,f<_){b=f,_-=b;do A[o++]=u[S++];while(--b);S=o-w,E=A}}}else if(S+=f-b,b<_){_-=b;do A[o++]=u[S++];while(--b);S=o-w,E=A}for(;_>2;)A[o++]=E[S++],A[o++]=E[S++],A[o++]=E[S++],_-=3;_&&(A[o++]=E[S++],_>1&&(A[o++]=E[S++]))}else{S=o-w;do A[o++]=A[S++],A[o++]=A[S++],A[o++]=A[S++],_-=3;while(_>2);_&&(A[o++]=A[S++],_>1&&(A[o++]=A[S++]))}}else if((b&64)===0){x=p[(x&65535)+(h&(1<<b)-1)];continue r}else{e.msg="invalid distance code",C.mode=dc;break e}break}}else if((b&64)===0){x=g[(x&65535)+(h&(1<<b)-1)];continue t}else if(b&32){C.mode=V_;break e}else{e.msg="invalid literal/length code",C.mode=dc;break e}break}}while(n<i&&o<s);_=m>>3,n-=_,m-=_<<3,h&=(1<<m)-1,e.next_in=n,e.next_out=o,e.avail_in=n<i?5+(i-n):5-(n-i),e.avail_out=o<s?257+(s-o):257-(o-s),C.hold=h,C.bits=m},Eo=15,Ym=852,qm=592,Zm=0,Cu=1,jm=2,W_=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]),X_=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]),$_=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]),K_=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]),Y_=(t,e,r,n,i,o,a,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,T,A=new Uint16Array(Eo+1),C=new Uint16Array(Eo+1),B=null,F,k,N;for(l=0;l<=Eo;l++)A[l]=0;for(d=0;d<n;d++)A[e[r+d]]++;for(h=c,u=Eo;u>=1&&A[u]===0;u--);if(h>u&&(h=u),u===0)return i[o++]=1<<24|64<<16|0,i[o++]=1<<24|64<<16|0,s.bits=1,0;for(f=1;f<u&&A[f]===0;f++);for(h<f&&(h=f),p=1,l=1;l<=Eo;l++)if(p<<=1,p-=A[l],p<0)return-1;if(p>0&&(t===Zm||u!==1))return-1;for(C[1]=0,l=1;l<Eo;l++)C[l+1]=C[l]+A[l];for(d=0;d<n;d++)e[r+d]!==0&&(a[C[e[r+d]]++]=d);if(t===Zm?(E=B=a,T=20):t===Cu?(E=W_,B=X_,T=257):(E=$_,B=K_,T=0),v=0,d=0,l=f,S=o,m=h,g=0,_=-1,y=1<<h,w=y-1,t===Cu&&y>Ym||t===jm&&y>qm)return 1;for(;;){F=l-g,a[d]+1<T?(k=0,N=a[d]):a[d]>=T?(k=B[a[d]-T],N=E[a[d]-T]):(k=96,N=0),x=1<<l-g,b=1<<m,f=b;do b-=x,i[S+(v>>g)+b]=F<<24|k<<16|N|0;while(b!==0);for(x=1<<l-1;v&x;)x>>=1;if(x!==0?(v&=x-1,v+=x):v=0,d++,--A[l]===0){if(l===u)break;l=e[r+a[d]]}if(l>h&&(v&w)!==_){for(g===0&&(g=h),S+=f,m=l-g,p=1<<m;m+g<u&&(p-=A[m+g],!(p<=0));)m++,p<<=1;if(y+=1<<m,t===Cu&&y>Ym||t===jm&&y>qm)return 1;_=v&w,i[_]=h<<24|m<<16|S-o|0}}return v!==0&&(i[S+v]=l-g<<24|64<<16|0),s.bits=h,0},ds=Y_,q_=0,K0=1,Y0=2,{Z_FINISH:Qm,Z_BLOCK:Z_,Z_TREES:uc,Z_OK:Ei,Z_STREAM_END:j_,Z_NEED_DICT:Q_,Z_STREAM_ERROR:ir,Z_DATA_ERROR:q0,Z_MEM_ERROR:Z0,Z_BUF_ERROR:J_,Z_DEFLATED:Jm}=Li,vc=16180,e0=16181,t0=16182,r0=16183,n0=16184,i0=16185,o0=16186,a0=16187,s0=16188,l0=16189,yc=16190,nn=16191,Pu=16192,c0=16193,Iu=16194,d0=16195,u0=16196,f0=16197,h0=16198,fc=16199,hc=16200,m0=16201,p0=16202,g0=16203,y0=16204,b0=16205,Bu=16206,x0=16207,v0=16208,be=16209,j0=16210,Q0=16211,eS=852,tS=592,rS=15,nS=rS,_0=t=>(t>>>24&255)+(t>>>8&65280)+((t&65280)<<8)+((t&255)<<24);function iS(){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 Ti=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.mode<vc||e.mode>Q0?1:0},J0=t=>{if(Ti(t))return ir;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=vc,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(eS),e.distcode=e.distdyn=new Int32Array(tS),e.sane=1,e.back=-1,Ei},ep=t=>{if(Ti(t))return ir;let e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,J0(t)},tp=(t,e)=>{let r;if(Ti(t))return ir;let n=t.state;return e<0?(r=0,e=-e):(r=(e>>4)+5,e<48&&(e&=15)),e&&(e<8||e>15)?ir:(n.window!==null&&n.wbits!==e&&(n.window=null),n.wrap=r,n.wbits=e,ep(t))},rp=(t,e)=>{if(!t)return ir;let r=new iS;t.state=r,r.strm=t,r.window=null,r.mode=vc;let n=tp(t,e);return n!==Ei&&(t.state=null),n},oS=t=>rp(t,nS),S0=!0,Fu,ku,aS=t=>{if(S0){Fu=new Int32Array(512),ku=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(K0,t.lens,0,288,Fu,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;ds(Y0,t.lens,0,32,ku,0,t.work,{bits:5}),S0=!1}t.lencode=Fu,t.lenbits=9,t.distcode=ku,t.distbits=5},np=(t,e,r,n)=>{let i,o=t.state;return o.window===null&&(o.wsize=1<<o.wbits,o.wnext=0,o.whave=0,o.window=new Uint8Array(o.wsize)),n>=o.wsize?(o.window.set(e.subarray(r-o.wsize,r),0),o.wnext=0,o.whave=o.wsize):(i=o.wsize-o.wnext,i>n&&(i=n),o.window.set(e.subarray(r-n,r-n+i),o.wnext),n-=i,n?(o.window.set(e.subarray(r-n,r),0),o.wnext=n,o.whave=o.wsize):(o.wnext+=i,o.wnext===o.wsize&&(o.wnext=0),o.whave<o.wsize&&(o.whave+=i))),0},sS=(t,e)=>{let r,n,i,o,a,s,c,l,d,f,u,h,m,g,p=0,y,v,x,b,_,w,S,E,T=new Uint8Array(4),A,C,B=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Ti(t)||!t.output||!t.input&&t.avail_in!==0)return ir;r=t.state,r.mode===nn&&(r.mode=Pu),a=t.next_out,i=t.output,c=t.avail_out,o=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,f=s,u=c,E=Ei;e:for(;;)switch(r.mode){case vc:if(r.wrap===0){r.mode=Pu;break}for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}if(r.wrap&2&&l===35615){r.wbits===0&&(r.wbits=15),r.check=0,T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0),l=0,d=0,r.mode=e0;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)!==Jm){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?l0:nn,l=0,d=0;break;case e0:for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}if(r.flags=l,(r.flags&255)!==Jm){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&&(T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0)),l=0,d=0,r.mode=t0;case t0:for(;d<32;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.head&&(r.head.time=l),r.flags&512&&r.wrap&4&&(T[0]=l&255,T[1]=l>>>8&255,T[2]=l>>>16&255,T[3]=l>>>24&255,r.check=ke(r.check,T,4,0)),l=0,d=0,r.mode=r0;case r0:for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.head&&(r.head.xflags=l&255,r.head.os=l>>8),r.flags&512&&r.wrap&4&&(T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0)),l=0,d=0,r.mode=n0;case n0:if(r.flags&1024){for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.length=l,r.head&&(r.head.extra_len=l),r.flags&512&&r.wrap&4&&(T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0)),l=0,d=0}else r.head&&(r.head.extra=null);r.mode=i0;case i0: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(o,o+h),S)),r.flags&512&&r.wrap&4&&(r.check=ke(r.check,n,h,o)),s-=h,o+=h,r.length-=h),r.length))break e;r.length=0,r.mode=o0;case o0:if(r.flags&2048){if(s===0)break e;h=0;do S=n[o+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=ke(r.check,n,h,o)),s-=h,o+=h,S)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=a0;case a0:if(r.flags&4096){if(s===0)break e;h=0;do S=n[o+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=ke(r.check,n,h,o)),s-=h,o+=h,S)break e}else r.head&&(r.head.comment=null);r.mode=s0;case s0:if(r.flags&512){for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<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=nn;break;case l0:for(;d<32;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}t.adler=r.check=_0(l),l=0,d=0,r.mode=yc;case yc:if(r.havedict===0)return t.next_out=a,t.avail_out=c,t.next_in=o,t.avail_in=s,r.hold=l,r.bits=d,Q_;t.adler=r.check=1,r.mode=nn;case nn:if(e===Z_||e===uc)break e;case Pu:if(r.last){l>>>=d&7,d-=d&7,r.mode=Bu;break}for(;d<3;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}switch(r.last=l&1,l>>>=1,d-=1,l&3){case 0:r.mode=c0;break;case 1:if(aS(r),r.mode=fc,e===uc){l>>>=2,d-=2;break e}break;case 2:r.mode=u0;break;case 3:t.msg="invalid block type",r.mode=be}l>>>=2,d-=2;break;case c0:for(l>>>=d&7,d-=d&7;d<32;){if(s===0)break e;s--,l+=n[o++]<<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=Iu,e===uc)break e;case Iu:r.mode=d0;case d0:if(h=r.length,h){if(h>s&&(h=s),h>c&&(h=c),h===0)break e;i.set(n.subarray(o,o+h),a),s-=h,o+=h,c-=h,a+=h,r.length-=h;break}r.mode=nn;break;case u0:for(;d<14;){if(s===0)break e;s--,l+=n[o++]<<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=f0;case f0:for(;r.have<r.ncode;){for(;d<3;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.lens[B[r.have++]]=l&7,l>>>=3,d-=3}for(;r.have<19;)r.lens[B[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,A={bits:r.lenbits},E=ds(q_,r.lens,0,19,r.lencode,0,r.work,A),r.lenbits=A.bits,E){t.msg="invalid code lengths set",r.mode=be;break}r.have=0,r.mode=h0;case h0: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[o++]<<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[o++]<<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[o++]<<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[o++]<<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,A={bits:r.lenbits},E=ds(K0,r.lens,0,r.nlen,r.lencode,0,r.work,A),r.lenbits=A.bits,E){t.msg="invalid literal/lengths set",r.mode=be;break}if(r.distbits=6,r.distcode=r.distdyn,A={bits:r.distbits},E=ds(Y0,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,A),r.distbits=A.bits,E){t.msg="invalid distances set",r.mode=be;break}if(r.mode=fc,e===uc)break e;case fc:r.mode=hc;case hc:if(s>=6&&c>=258){t.next_out=a,t.avail_out=c,t.next_in=o,t.avail_in=s,r.hold=l,r.bits=d,G_(t,u),a=t.next_out,i=t.output,c=t.avail_out,o=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,r.mode===nn&&(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[o++]<<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[o++]<<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=b0;break}if(v&32){r.back=-1,r.mode=nn;break}if(v&64){t.msg="invalid literal/length code",r.mode=be;break}r.extra=v&15,r.mode=m0;case m0:if(r.extra){for(C=r.extra;d<C;){if(s===0)break e;s--,l+=n[o++]<<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=p0;case p0: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[o++]<<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[o++]<<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=g0;case g0:if(r.extra){for(C=r.extra;d<C;){if(s===0)break e;s--,l+=n[o++]<<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=y0;case y0: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=a-r.offset,h=r.length;h>c&&(h=c),c-=h,r.length-=h;do i[a++]=g[m++];while(--h);r.length===0&&(r.mode=hc);break;case b0:if(c===0)break e;i[a++]=r.length,c--,r.mode=hc;break;case Bu:if(r.wrap){for(;d<32;){if(s===0)break e;s--,l|=n[o++]<<d,d+=8}if(u-=c,t.total_out+=u,r.total+=u,r.wrap&4&&u&&(t.adler=r.check=r.flags?ke(r.check,i,u,a-u):ps(r.check,i,u,a-u)),u=c,r.wrap&4&&(r.flags?l:_0(l))!==r.check){t.msg="incorrect data check",r.mode=be;break}l=0,d=0}r.mode=x0;case x0:if(r.wrap&&r.flags){for(;d<32;){if(s===0)break e;s--,l+=n[o++]<<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=v0;case v0:E=j_;break e;case be:E=q0;break e;case j0:return Z0;case Q0:default:return ir}return t.next_out=a,t.avail_out=c,t.next_in=o,t.avail_in=s,r.hold=l,r.bits=d,(r.wsize||u!==t.avail_out&&r.mode<be&&(r.mode<Bu||e!==Qm))&&np(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?ke(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===nn?128:0)+(r.mode===fc||r.mode===Iu?256:0),(f===0&&u===0||e===Qm)&&E===Ei&&(E=J_),E},lS=t=>{if(Ti(t))return ir;let e=t.state;return e.window&&(e.window=null),t.state=null,Ei},cS=(t,e)=>{if(Ti(t))return ir;let r=t.state;return(r.wrap&2)===0?ir:(r.head=e,e.done=!1,Ei)},dS=(t,e)=>{let r=e.length,n,i,o;return Ti(t)||(n=t.state,n.wrap!==0&&n.mode!==yc)?ir:n.mode===yc&&(i=1,i=ps(i,e,r,0),i!==n.check)?q0:(o=np(t,e,r,r),o?(n.mode=j0,Z0):(n.havedict=1,Ei))},uS=ep,fS=tp,hS=J0,mS=oS,pS=rp,gS=sS,yS=lS,bS=cS,xS=dS,vS="pako inflate (from Nodeca project)",an={inflateReset:uS,inflateReset2:fS,inflateResetKeep:hS,inflateInit:mS,inflateInit2:pS,inflate:gS,inflateEnd:yS,inflateGetHeader:bS,inflateSetDictionary:xS,inflateInfo:vS};function _S(){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 SS=_S,ip=Object.prototype.toString,{Z_NO_FLUSH:wS,Z_FINISH:MS,Z_OK:bs,Z_STREAM_END:Du,Z_NEED_DICT:zu,Z_STREAM_ERROR:AS,Z_DATA_ERROR:w0,Z_MEM_ERROR:ES}=Li;function Ss(t){this.options=xc.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 X0,this.strm.avail_out=0;let r=an.inflateInit2(this.strm,e.windowBits);if(r!==bs)throw new Error(Mi[r]);if(this.header=new SS,an.inflateGetHeader(this.strm,this.header),e.dictionary&&(typeof e.dictionary=="string"?e.dictionary=ys.string2buf(e.dictionary):ip.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(Mi[r])}Ss.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i=this.options.dictionary,o,a,s;if(this.ended)return!1;for(e===~~e?a=e:a=e===!0?MS:wS,ip.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),o=an.inflate(r,a),o===zu&&i&&(o=an.inflateSetDictionary(r,i),o===bs?o=an.inflate(r,a):o===w0&&(o=zu));r.avail_in>0&&o===Du&&r.state.wrap>0&&t[r.next_in]!==0;)an.inflateReset(r),o=an.inflate(r,a);switch(o){case AS:case w0:case zu:case ES:return this.onEnd(o),this.ended=!0,!1}if(s=r.avail_out,r.next_out&&(r.avail_out===0||o===Du))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(!(o===bs&&s===0)){if(o===Du)return o=an.inflateEnd(this.strm),this.onEnd(o),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=xc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Ju(t,e){let r=new Ss(e);if(r.push(t),r.err)throw r.msg||Mi[r.err];return r.result}function LS(t,e){return e=e||{},e.raw=!0,Ju(t,e)}var TS=Ss,RS=Ju,CS=LS,PS=Ju,IS=Li,BS={Inflate:TS,inflate:RS,inflateRaw:CS,ungzip:PS,constants:IS},{Deflate:FS,deflate:kS,deflateRaw:DS,gzip:zS}=H_,{Inflate:OS,inflate:US,inflateRaw:NS,ungzip:HS}=BS,VS=FS,GS=kS,WS=DS,XS=zS,$S=OS,KS=US,YS=NS,qS=HS,ZS=Li,ef={Deflate:VS,deflate:GS,deflateRaw:WS,gzip:XS,Inflate:$S,inflate:KS,inflateRaw:YS,ungzip:qS,constants:ZS};var Bo=class Bo{constructor(e=Bo.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(Bo.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}};Bo.INITIAL_SIZE=64*1024,Bo.MAX_STRING_LENGTH=2048;var Gn=Bo;var Dr=()=>({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}),mr=()=>({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 op={0:R.bad,1:R.nop,2:R.disconnect,3:R.reconnect,4:R.download,5:R.frame,6:R.inventory,7:R.layout,8:R.muzzleflash,9:R.temp_entity,10:R.sound,11:R.print,12:R.stufftext,13:R.serverdata,14:R.configstring,15:R.spawnbaseline,16:R.centerprint,17:R.playerinfo,18:R.packetentities,19:R.deltapacketentities,20:R.muzzleflash2},_c=class{constructor(){this.protocolVersion=34}translateCommand(e){return op[e]!==void 0?op[e]:R.bad}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),o=e.readString(),a=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:o,playerNum:a,levelName:s}}parseEntityBits(e){let r=e.readByte();r&yr&&(r|=e.readByte()<<8),r&xr&&(r|=e.readByte()<<16),r&vr&&(r|=e.readByte()<<24);let n;return r&jn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,o,a){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&_t&&(r.modelindex=a.readByte()),i&wt&&(r.modelindex2=a.readByte()),i&Mt&&(r.modelindex3=a.readByte()),i&At&&(r.modelindex4=a.readByte()),i&yt&&(r.frame=a.readByte()),i&St&&(r.frame=a.readShort()),i&Ve&&i&Xe?r.skinnum=a.readLong():i&Ve?r.skinnum=a.readByte():i&Xe&&(r.skinnum=a.readShort()),i&He&&i&We?r.effects=a.readLong():i&He?r.effects=a.readByte():i&We&&(r.effects=a.readShort()),i&Ne&&i&Ge?r.renderfx=a.readLong():i&Ne?r.renderfx=a.readByte():i&Ge&&(r.renderfx=a.readShort()),i&ht&&(r.origin.x=a.readShort()*.125),i&mt&&(r.origin.y=a.readShort()*.125),i&xt&&(r.origin.z=a.readShort()*.125),i&vt&&(r.angles.x=a.readByte()*(360/256)),i&pt&&(r.angles.y=a.readByte()*(360/256)),i>&&(r.angles.z=a.readByte()*(360/256)),i&lr&&(r.old_origin.x=a.readShort()*.125,r.old_origin.y=a.readShort()*.125,r.old_origin.z=a.readShort()*.125),i&Et&&(r.sound=a.readByte()),i&bt?r.event=a.readByte():r.event=0,i&Lt&&(r.solid=a.readShort())}parsePlayerState(e){let r=mr(),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 o=0;o<32;o++)i&1<<o&&(r.stats[o]=e.readShort());return r}};var zr=2023,Sc=class{constructor(){this.protocolVersion=zr}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),o=e.readByte(),a=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:a,playerNum:s,levelName:c,tickRate:o,demoType:i}}parseEntityBits(e){let r=e.readByte();r&yr&&(r|=e.readByte()<<8),r&xr&&(r|=e.readByte()<<16),r&vr&&(r|=e.readByte()<<24);let n=0;r&Ii&&(n=e.readByte());let i;return r&jn?i=e.readShort():i=e.readByte(),{number:i,bits:r,bitsHigh:n}}parseDelta(e,r,n,i,o,a){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=o,i&_t&&(r.modelindex=a.readByte()),i&wt&&(r.modelindex2=a.readByte()),i&Mt&&(r.modelindex3=a.readByte()),i&At&&(r.modelindex4=a.readByte()),i&yt&&(r.frame=a.readByte()),i&St&&(r.frame=a.readShort()),i&Ve&&i&Xe?r.skinnum=a.readLong():i&Ve?r.skinnum=a.readByte():i&Xe&&(r.skinnum=a.readShort()),i&He&&i&We?r.effects=a.readLong():i&He?r.effects=a.readByte():i&We&&(r.effects=a.readShort()),i&Ne&&i&Ge?r.renderfx=a.readLong():i&Ne?r.renderfx=a.readByte():i&Ge&&(r.renderfx=a.readShort()),i&ht&&(r.origin.x=a.readShort()*.125),i&mt&&(r.origin.y=a.readShort()*.125),i&xt&&(r.origin.z=a.readShort()*.125),i&vt&&(r.angles.x=a.readByte()*(360/256)),i&pt&&(r.angles.y=a.readByte()*(360/256)),i>&&(r.angles.z=a.readByte()*(360/256)),i&lr&&(r.old_origin.x=a.readShort()*.125,r.old_origin.y=a.readShort()*.125,r.old_origin.z=a.readShort()*.125),i&Et&&(r.sound=a.readByte()),i&bt?r.event=a.readByte():r.event=0,i&Lt&&(r.solid=a.readShort()),i&br&&(r.alpha=a.readByte()/255),i&_r&&(r.scale=a.readFloat()),i&Sr&&(r.instanceBits=a.readLong()),i&wr&&(r.loopVolume=a.readByte()/255),o&fn&&(r.loopAttenuation=a.readByte()/255),o&hn&&(r.owner=a.readShort()),o&mn&&(r.oldFrame=a.readShort())}parsePlayerState(e){let r=mr(),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 o=0;o<32;o++)i&1<<o&&(r.stats[o]=e.readShort());return r}};var wc=class{constructor(e=0){this.protocolVersion=e}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),o=e.readString(),a=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:o,playerNum:a,levelName:s}}parseEntityBits(e){let r=e.readByte();r&yr&&(r|=e.readByte()<<8),r&xr&&(r|=e.readByte()<<16),r&vr&&(r|=e.readByte()<<24);let n;return r&jn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,o,a){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&_t&&(r.modelindex=a.readByte()),i&wt&&(r.modelindex2=a.readByte()),i&Mt&&(r.modelindex3=a.readByte()),i&At&&(r.modelindex4=a.readByte()),i&yt&&(r.frame=a.readByte()),i&St&&(r.frame=a.readShort()),i&Ve&&i&Xe?r.skinnum=a.readLong():i&Ve?r.skinnum=a.readByte():i&Xe&&(r.skinnum=a.readShort()),i&He&&i&We?r.effects=a.readLong():i&He?r.effects=a.readByte():i&We&&(r.effects=a.readShort()),i&Ne&&i&Ge?r.renderfx=a.readLong():i&Ne?r.renderfx=a.readByte():i&Ge&&(r.renderfx=a.readShort()),i&ht&&(r.origin.x=a.readShort()*.125),i&mt&&(r.origin.y=a.readShort()*.125),i&xt&&(r.origin.z=a.readShort()*.125),i&vt&&(r.angles.x=a.readByte()*(360/256)),i&pt&&(r.angles.y=a.readByte()*(360/256)),i>&&(r.angles.z=a.readByte()*(360/256)),i&lr&&(r.old_origin.x=a.readShort()*.125,r.old_origin.y=a.readShort()*.125,r.old_origin.z=a.readShort()*.125),i&Et&&(r.sound=a.readByte()),i&bt?r.event=a.readByte():r.event=0,i&Lt&&(r.solid=a.readShort())}parsePlayerState(e){let r=mr(),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 o=0;o<32;o++)i&1<<o&&(r.stats[o]=e.readShort());return r}};var ws=class{constructor(){this.protocolVersion=0}translateCommand(e){return e===7?R.serverdata:e===12?R.serverdata:e===13?R.serverdata:e===R.stufftext?R.stufftext:R.bad}parseServerData(e){let r=e.readLong();if(r===zr){let n=e.readLong(),i=e.readByte(),o=e.readByte(),a=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:a,playerNum:s,levelName:c,tickRate:o,demoType:i}}else{let n=e.readLong(),i=e.readByte(),o=e.readString(),a=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:o,playerNum:a,levelName:s}}}parseEntityBits(e){throw new Error("Bootstrap handler cannot parse entities")}parseDelta(e,r,n,i,o,a){throw new Error("Bootstrap handler cannot parse delta")}parsePlayerState(e){throw new Error("Bootstrap handler cannot parse player state")}};function ap(t){return t===0?new ws:t===zr?new Sc:t===34?new _c:new wc(t)}var sp=1,jS=2,QS=128,tf=class extends Gn{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")}},dt=class t{constructor(e,r,n=!1){this.strictMode=!1;this.errorCount=0;this.isDemo=sp;e instanceof pn?this.stream=new tf(e):this.stream=e,this.handler=r,this.strictMode=n,this.protocolHandler=new ws}setProtocolVersion(e){this.protocolHandler.protocolVersion!==e&&(this.protocolHandler=ap(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 R.bad:if(n===0)return;let o=`Unknown server command: ${n} (translated: ${i}) at offset ${e} (Protocol: ${this.getProtocolVersion()})`;if(this.strictMode)throw new Error(o);console.warn(o),this.errorCount++;return;case R.nop:break;case R.disconnect:this.handler?.onDisconnect&&this.handler.onDisconnect();break;case R.reconnect:this.handler?.onReconnect&&this.handler.onReconnect();break;case R.print:this.parsePrint();break;case R.serverdata:this.parseServerData();break;case R.configstring:this.parseConfigString();break;case R.spawnbaseline:this.parseSpawnBaseline();break;case R.centerprint:this.parseCenterPrint();break;case R.download:this.parseDownload();break;case R.frame:this.parseFrame();break;case R.packetentities:this.parsePacketEntities(!1);break;case R.deltapacketentities:this.parsePacketEntities(!0);break;case R.playerinfo:this.parsePlayerState();break;case R.stufftext:this.parseStuffText();break;case R.layout:this.parseLayout();break;case R.inventory:this.parseInventory();break;case R.sound:this.parseSound();break;case R.muzzleflash:this.parseMuzzleFlash();break;case R.muzzleflash2:this.parseMuzzleFlash2();break;case R.temp_entity:this.parseTempEntity();break;case R.splitclient:this.parseSplitClient();break;case R.configblast:this.parseConfigBlast();break;case R.spawnbaselineblast:this.parseSpawnBaselineBlast();break;case R.level_restart:this.handler?.onLevelRestart&&this.handler.onLevelRestart();break;case R.damage:this.parseDamage();break;case R.locprint:this.parseLocPrint();break;case R.fog:this.parseFog();break;case R.waitingforplayers:this.parseWaitingForPlayers();break;case R.bot_chat:this.parseBotChat();break;case R.poi:this.parsePoi();break;case R.help_path:this.parseHelpPath();break;case R.muzzleflash3:this.parseMuzzleFlash3();break;case R.achievement:this.parseAchievement();break;default:let a=`Unknown server command: ${n} (translated: ${i}) at offset ${e}`;if(this.strictMode)throw new Error(a);console.warn(a),this.errorCount++;return}}catch(n){let i=n.message;if(i==="Buffer underflow"||i.includes("StreamingBuffer")){try{this.stream.setReadPosition(e)}catch(a){console.error("Failed to rollback stream position",a)}return}let o=`offset ${e}, cmd ${r}, protocol ${this.getProtocolVersion()}`;if(console.warn(`Error parsing command ${r} (${o}): ${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>=sr.length)e.x=0,e.y=0,e.z=0;else{let n=sr[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===zr?this.isDemo=e.demoType??sp: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=ef.inflate(n),o=new pn(i.buffer);for(;o.hasMore();){let a=o.readUShort(),s=o.readString();this.handler&&this.handler.onConfigString(a,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=ef.inflate(n),o=new pn(i.buffer),a=new t(o,this.handler,this.strictMode);for(a.setProtocolVersion(this.getProtocolVersion());o.hasMore();)a.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 o=0;o<n;o++)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(),o=this.stream.readByte(),a=this.stream.readByte();this.handler?.onPoi&&this.handler.onPoi(a,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,o,a,s;if(e&1&&(n=this.stream.readByte()),e&2&&(i=this.stream.readByte()),e&16&&(o=this.stream.readByte()),e&8&&(a=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,o,a,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(),o={x:0,y:0,z:0};this.readDir(o);let a=i&31,s=(i&32)!==0,c=(i&64)!==0,l=(i&128)!==0;r.push({damage:a,health:s,armor:c,power:l,dir:o})}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},o,a,s,c,l;switch(e){case z.EXPLOSION1:case z.EXPLOSION2:case z.ROCKET_EXPLOSION:case z.GRENADE_EXPLOSION:case z.ROCKET_EXPLOSION_WATER:case z.GRENADE_EXPLOSION_WATER:case z.BFG_EXPLOSION:case z.BFG_BIGEXPLOSION:case z.BOSSTPORT:case z.PLASMA_EXPLOSION:case z.PLAIN_EXPLOSION:case z.CHAINFIST_SMOKE:case z.TRACKER_EXPLOSION:case z.TELEPORT_EFFECT:case z.DBALL_GOAL:case z.NUKEBLAST:case z.WIDOWSPLASH:case z.EXPLOSION1_BIG:case z.EXPLOSION1_NP:this.readPos(r);break;case z.GUNSHOT:case z.BLOOD:case z.BLASTER:case z.SHOTGUN:case z.SPARKS:case z.BULLET_SPARKS:case z.SCREEN_SPARKS:case z.SHIELD_SPARKS:case z.BLASTER2:case z.FLECHETTE:case z.MOREBLOOD:case z.ELECTRIC_SPARKS:case z.HEATBEAM_SPARKS:case z.HEATBEAM_STEAM:this.readPos(r),this.readDir(i);break;case z.SPLASH:case z.LASER_SPARKS:case z.WELDING_SPARKS:case z.TUNNEL_SPARKS:o=this.stream.readByte(),this.readPos(r),this.readDir(i),a=this.stream.readByte();break;case z.BLUEHYPERBLASTER:this.getProtocolVersion()>=32?(this.readPos(r),this.readPos(n)):(this.readPos(r),this.readDir(i));break;case z.GREENBLOOD:this.getProtocolVersion()>=32?(this.readPos(r),this.readDir(i)):(this.readPos(r),this.readPos(n));break;case z.RAILTRAIL:case z.BUBBLETRAIL:case z.BFG_LASER:case z.DEBUGTRAIL:case z.BUBBLETRAIL2:this.readPos(r),this.readPos(n);break;case z.PARASITE_ATTACK:case z.MEDIC_CABLE_ATTACK:this.stream.readShort(),this.readPos(r),this.readPos(n);break;case z.GRAPPLE_CABLE:s=this.stream.readShort(),this.readPos(r),this.readPos(n),this.readPos(i);break;case z.LIGHTNING:c=this.stream.readShort(),l=this.stream.readShort(),this.readPos(r),this.readPos(n);break;case z.FLASHLIGHT:this.readPos(r),s=this.stream.readShort();break;case z.FORCEWALL:this.readPos(r),this.readPos(n),a=this.stream.readByte();break;case z.STEAM:let d=this.stream.readShort();o=this.stream.readByte(),this.readPos(r),this.readDir(i),a=this.stream.readByte(),this.stream.readShort(),d!==-1&&this.stream.readLong();break;case z.WIDOWBEAMOUT:this.stream.readShort();case z.HEATBEAM:case z.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,o,a,s,c,l)}parseSpawnBaseline(){let e=this.protocolHandler.parseEntityBits(this.stream),r=Dr();this.protocolHandler.parseDelta(Dr(),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(),o=this.stream.readData(i),a=this.stream.readByte();if(a=this.protocolHandler.translateCommand(a),a!==R.playerinfo){if(this.strictMode)throw new Error(`Expected svc_playerinfo after svc_frame, got ${a}`);return}let s=this.parsePlayerState(),c=this.stream.readByte();if(c=this.protocolHandler.translateCommand(c),c!==R.packetentities&&c!==R.deltapacketentities){if(this.strictMode)throw new Error(`Expected svc_packetentities after svc_playerinfo, got ${c}`);return}let l=this.collectPacketEntities();if(this.isDemo===QS){let d=this.stream.readByte();for(let f=0;f<d;f++)this.stream.readByte()}this.isDemo===jS&&this.stream.readLong(),this.handler&&this.handler.onFrame({serverFrame:e,deltaFrame:r,surpressCount:n,areaBytes:i,areaBits:o,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:mr(),packetEntities:{delta:e,entities:r}})}collectPacketEntities(){let e=[];for(;;){let r=this.protocolHandler.parseEntityBits(this.stream);if(r.bits&$o){if(r.number===0)break;continue}let n=Dr();if(r.number===0)break;this.protocolHandler.parseDelta(Dr(),n,r.number,r.bits,r.bitsHigh,this.stream),e.push(n)}return e}};var rf=(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))(rf||{});var Fo=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 hr(this.buffer),r=-1,n=0,i=.1,o=0,a={onServerData:(s,c,l,d,f,u,h,m)=>{o=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 dt(s.data,a);c.setProtocolVersion(o),c.parseMessage(),o=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 o=this.summary.weaponUsage.get(r)||0;this.summary.weaponUsage.set(r,o+1);let a=this.getOrCreateWeaponStat(e,r);a.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(o=>o.weaponId===r);return i||(i={weaponId:r,shotsFired:0,hits:0,kills:0},n.push(i)),i}};var nf=(i=>(i[i.FirstPerson=0]="FirstPerson",i[i.ThirdPerson=1]="ThirdPerson",i[i.Free=2]="Free",i[i.Follow=3]="Follow",i))(nf||{});var Mc=(i=>(i[i.Stopped=0]="Stopped",i[i.Playing=1]="Playing",i[i.Paused=2]="Paused",i[i.Finished=3]="Finished",i))(Mc||{}),JS=()=>({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 hr(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),o=this.getTotalFrames(),a=Math.max(0,o-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[o,a]of this.snapshots)o<=e&&o>n&&(n=o,i=a);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||JS(),onFrame:i=>{this.lastFrameData=i,this.handler?.onFrame&&this.handler.onFrame(i),this.callbacks?.onFrameUpdate&&this.callbacks.onFrameUpdate(i)}},n=new dt(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),o=new Map;i.forEach(d=>o.set(d.number,d));let a=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&&a&&((n.origin.x!==a.origin.x||n.origin.y!==a.origin.y||n.origin.z!==a.origin.z)&&(l.playerStateDiff.origin={x:a.origin.x-n.origin.x,y:a.origin.y-n.origin.y,z:a.origin.z-n.origin.z}),n.stats[1]!==a.stats[1]&&(l.playerStateDiff.health=a.stats[1]-n.stats[1]),n.stats[2]!==a.stats[2]&&(l.playerStateDiff.ammo=a.stats[2]-n.stats[2]));for(let[d,f]of c){let u=o.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 o)c.has(d)||l.entityDiffs.removed.push(d);return l}getEntityTrajectory(e,r,n){let i=[],o=this.getCurrentFrame();for(this.seek(r);this.getCurrentFrame()<=n&&this.state!==3;){let a=null;if(e===-1){let s=this.getFramePlayerState(this.getCurrentFrame());s&&(a={...s.origin})}else if(this.handler?.getEntities){let s=this.handler.getEntities().get(e);s&&(a={...s.origin})}if(a&&i.push(a),this.getCurrentFrame()===n)break;this.stepForward()}return this.seek(o),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 Fo(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 o=0;for(;o<n;){if(!this.processNextFrame()){this.transitionState(0);let a=e.stopTracking();return this.tracker=null,this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),a}o++}return await new Promise(a=>setTimeout(a,0)),i()};return await i()}catch(n){throw this.transitionState(0),e.stopTracking(),this.tracker=null,n}else return new Promise((n,i)=>{let o=this.callbacks?.onPlaybackComplete,a=this.callbacks?.onPlaybackError,s=()=>{this.setCallbacks({...this.callbacks,onPlaybackComplete:o,onPlaybackError:a}),this.tracker=null};this.setCallbacks({...this.callbacks,onPlaybackComplete:()=>{let c=e.stopTracking();o&&o(),s(),n(c)},onPlaybackError:c=>{e.stopTracking(),a&&a(c),s(),i(c)}}),this.play()})}async playRangeWithTracking(e,r,n,i={}){this.tracker=n,n.startTracking();let o=e.type==="frame"?e.frame:this.timeToFrame(e.seconds),a=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>=a||!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 Qn(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 Ac=class{constructor(e,r=34){this.writer=e||new Qn(new Uint8Array(64*1024)),this.protocol=r}getData(){return this.writer.getData()}getOpcode(e){if(this.protocol===34)switch(e){case R.serverdata:return 13;case R.frame:return 5;case R.playerinfo:return 17;case R.packetentities:return 18;case R.deltapacketentities:return 19;case R.print:return 11;case R.centerprint:return 16;case R.stufftext:return 12;case R.sound:return 10;case R.temp_entity:return 9;case R.configstring:return 14;case R.spawnbaseline:return 15;case R.layout:return 7;case R.inventory:return 6;case R.muzzleflash:return 8;case R.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,o,a){this.writeCommand(R.serverdata),this.writer.writeLong(e),this.writer.writeLong(r),this.writer.writeByte(n),this.writer.writeString(i),this.writer.writeShort(o),this.writer.writeString(a)}writeConfigString(e,r){this.writeCommand(R.configstring),this.writer.writeShort(e),this.writer.writeString(r)}writeStuffText(e){this.writeCommand(R.stufftext),this.writer.writeString(e)}writeCenterPrint(e){this.writeCommand(R.centerprint),this.writer.writeString(e)}writePrint(e,r){this.writeCommand(R.print),this.writer.writeByte(e),this.writer.writeString(r)}writeLayout(e){this.writeCommand(R.layout),this.writer.writeString(e)}writeInventory(e){this.writeCommand(R.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(R.muzzleflash),this.writer.writeShort(e),this.writer.writeByte(r)}writeMuzzleFlash2(e,r){this.writeCommand(R.muzzleflash2),this.writer.writeShort(e),this.writer.writeByte(r)}writeSound(e,r,n,i,o,a,s,c){this.writeCommand(R.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(o),e&8&&this.writer.writeShort(a),e&4&&(this.writer.writeCoord(s.x),this.writer.writeCoord(s.y),this.writer.writeCoord(s.z))}writeTempEntity(e,r,n,i,o,a,s,c,l){this.writeCommand(R.temp_entity),this.writer.writeByte(e),r&&this.writer.writePos(r)}writePlayerState(e){this.writeCommand(R.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?R.deltapacketentities:R.packetentities);for(let i of e)this.writeDeltaEntity(Dr(),i,!0);this.writer.writeShort(0)}writeFrame(e,r){this.writeCommand(R.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,o=0;(r.modelindex!==e.modelindex||n)&&(i|=_t),(r.modelindex2!==e.modelindex2||n)&&(i|=wt),(r.modelindex3!==e.modelindex3||n)&&(i|=Mt),(r.modelindex4!==e.modelindex4||n)&&(i|=At),(r.frame!==e.frame||n)&&(r.frame>=256?i|=St:i|=yt),(r.skinnum!==e.skinnum||n)&&(r.skinnum>=256?i|=Xe:i|=Ve),(r.effects!==e.effects||n)&&(r.effects>=256?i|=We:i|=He),(r.renderfx!==e.renderfx||n)&&(r.renderfx>=256?i|=Ge:i|=Ne),(r.origin.x!==e.origin.x||n)&&r.origin.x!==0&&(i|=ht),(r.origin.y!==e.origin.y||n)&&r.origin.y!==0&&(i|=mt),(r.origin.z!==e.origin.z||n)&&r.origin.z!==0&&(i|=xt),(r.angles.x!==e.angles.x||n)&&r.angles.x!==0&&(i|=vt),(r.angles.y!==e.angles.y||n)&&r.angles.y!==0&&(i|=pt),(r.angles.z!==e.angles.z||n)&&r.angles.z!==0&&(i|=gt),(r.sound!==e.sound||n)&&(i|=Et),(r.event!==e.event||n)&&(i|=bt),(r.solid!==e.solid||n)&&(i|=Lt),this.protocol!==34&&((r.alpha!==e.alpha||n)&&(i|=br),(r.scale!==e.scale||n)&&(i|=_r),(r.instanceBits!==e.instanceBits||n)&&(i|=Sr),(r.loopVolume!==e.loopVolume||n)&&(i|=wr),(r.loopAttenuation!==e.loopAttenuation||n)&&(o|=fn),(r.owner!==e.owner||n)&&(o|=hn),(r.oldFrame!==e.oldFrame||n)&&(o|=mn)),o>0&&(i|=Ii),i&4278190080&&(i|=vr),i&4294901760&&(i|=xr),i&4294967040&&(i|=yr),this.writer.writeByte(i&255),i&yr&&this.writer.writeByte(i>>8&255),i&xr&&this.writer.writeByte(i>>16&255),i&vr&&this.writer.writeByte(i>>24&255),i&Ii&&this.writer.writeByte(o&255),r.number>=256?this.writer.writeShort(r.number):this.writer.writeByte(r.number),i&_t&&this.writer.writeByte(r.modelindex),i&wt&&this.writer.writeByte(r.modelindex2),i&Mt&&this.writer.writeByte(r.modelindex3),i&At&&this.writer.writeByte(r.modelindex4),i&yt&&this.writer.writeByte(r.frame),i&St&&this.writer.writeShort(r.frame),i&Ve&&this.writer.writeByte(r.skinnum),i&Xe&&this.writer.writeShort(r.skinnum),i&He&&this.writer.writeByte(r.effects),i&We&&this.writer.writeShort(r.effects),i&Ne&&this.writer.writeByte(r.renderfx),i&Ge&&this.writer.writeShort(r.renderfx),i&ht&&this.writer.writeCoord(r.origin.x),i&mt&&this.writer.writeCoord(r.origin.y),i&xt&&this.writer.writeCoord(r.origin.z),i&vt&&this.writer.writeAngle(r.angles.x),i&pt&&this.writer.writeAngle(r.angles.y),i>&&this.writer.writeAngle(r.angles.z),i&Et&&this.writer.writeByte(r.sound??0),i&bt&&this.writer.writeByte(r.event??0),i&Lt&&this.writer.writeShort(r.solid),this.protocol!==34&&(i&br&&this.writer.writeByte(r.alpha*255),i&_r&&this.writer.writeFloat(r.scale),i&Sr&&this.writer.writeLong(r.instanceBits),i&wr&&this.writer.writeByte(r.loopVolume*255),o&fn&&this.writer.writeByte(r.loopAttenuation*255),o&hn&&this.writer.writeShort(r.owner),o&mn&&this.writer.writeShort(r.oldFrame))}};var Ec=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 o=n.getUint8(4);if(o!==R.serverdata)return{valid:!1,error:`First command is not svc_serverdata (expected ${R.serverdata}, got ${o})`};let a=-1;return i>=5&&(a=n.getInt32(5,!0)),{valid:!0,version:a}}};var Lc=class{constructor(e){this.frames=[];this.configStrings=new Map;this.baselines=new Map;this.currentEntities=new Map;if(e){let r=new Gn(e.byteLength);r.append(new Uint8Array(e)),r.setReadPosition(0),this.parser=new dt(r,this)}else this.parser=new dt(new Gn,this)}extractClip(e,r,n,i){let o=new hr(e.buffer),a=[],s=0,c=r.frame??-1,l=n.frame??Number.MAX_SAFE_INTEGER,d=0,f=0;for(;o.nextBlock();){let p=o.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 Gn(p.getLength());_.append(p.readData(p.getLength())),_.setReadPosition(0),p.seek(0);let w=new dt(_,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),a.push(S);let T=p.readData(p.getLength());a.push(T),s+=4+T.length}f++}let u=new Uint8Array(4);new DataView(u.buffer).setInt32(0,-1,!0),a.push(u),s+=4;let h=new Uint8Array(s),m=0;for(let g of a)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,o,a){this.serverData={protocol:e,serverCount:r,attractLoop:n,gameDir:i,playerNum:o,levelName:a}}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,o,a,s){}onTempEntity(e,r,n,i,o,a,s,c,l){}onLayout(e){}onInventory(e){}onMuzzleFlash(e,r){}onMuzzleFlash2(e,r){}onDisconnect(){}onReconnect(){}onDownload(e,r,n){}};function lp(t,e){let r=e.bits;t.bits=r,t.number=e.number,r&_t&&(t.modelindex=e.modelindex),r&wt&&(t.modelindex2=e.modelindex2),r&Mt&&(t.modelindex3=e.modelindex3),r&At&&(t.modelindex4=e.modelindex4),r&yt&&(t.frame=e.frame),r&St&&(t.frame=e.frame),r&Ve&&(t.skinnum=e.skinnum),r&Xe&&(t.skinnum=e.skinnum),r&He&&(t.effects=e.effects),r&We&&(t.effects=e.effects),r&Ne&&(t.renderfx=e.renderfx),r&Ge&&(t.renderfx=e.renderfx),r&ht&&(t.origin.x=e.origin.x),r&mt&&(t.origin.y=e.origin.y),r&xt&&(t.origin.z=e.origin.z),r&vt&&(t.angles.x=e.angles.x),r&pt&&(t.angles.y=e.angles.y),r>&&(t.angles.z=e.angles.z),r&lr&&(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&Et&&(t.sound=e.sound),r&bt&&(t.event=e.event),r&Lt&&(t.solid=e.solid),r&br&&(t.alpha=e.alpha),r&_r&&(t.scale=e.scale),r&Sr&&(t.instanceBits=e.instanceBits),r&wr&&(t.loopVolume=e.loopVolume)}var of=(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))(of||{}),cp={".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 ew=[73,66,83,80],tw=[73,68,80,50],rw=[73,68,80,51];var nw=[82,73,70,70];var iw=[79,103,103,83];function af(t,e){let r=t.slice(t.lastIndexOf(".")).toLowerCase();if(e){if(Es(e,ew))return"bsp";if(Es(e,tw))return"md2";if(Es(e,rw))return"md3";if(Es(e,iw))return"ogg";if(e.length>128&&e[0]===10&&e[1]<6)return"pcx";if(Es(e,nw)&&e.length>=12&&e[8]===87&&e[9]===65&&e[10]===86&&e[11]===69)return"wav"}return cp[r]?cp[r]:"unknown"}function sf(t){let e=af(t);return e==="txt"||e==="cfg"}function dp(t){return!sf(t)}function ow(t,e,r,n,i){let o=new Uint8ClampedArray(n*i*4),a=e/n,s=r/i;for(let c=0;c<i;c++)for(let l=0;l<n;l++){let d=l*a,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],T=t[x+S],A=t[b+S],C=t[_+S],B=E*(1-m)+T*m,F=A*(1-m)+C*m,k=B*(1-g)+F*g;o[w+S]=k}}return o}function aw(t,e,r,n,i,o,a,s,c,l,d){n=Math.floor(n),i=Math.floor(i),o=Math.floor(o),a=Math.floor(a);let f=Math.abs(o-n),u=Math.abs(a-i),h=n<o?1:-1,m=i<a?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===o&&i===a)break;let p=2*g;p>-u&&(g-=u,n+=h),p<f&&(g+=f,i+=m)}}function up(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 Tc=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],o=i.width/i.height,a=r,s=r;o>1?s=Math.floor(r/o):a=Math.floor(r*o),a=Math.max(1,a),s=Math.max(1,s);let c=ow(i.rgba,i.width,i.height,a,s);return new ImageData(c,a,s)}catch(n){return console.error(`Failed to generate thumbnail for ${e}`,n),null}}async generateModelThumbnail(e,r){try{let n=[],i=[],o=e.split(".").pop()?.toLowerCase();if(o==="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(o==="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 a={x:1/0,y:1/0,z:1/0},s={x:-1/0,y:-1/0,z:-1/0};for(let p of n)a.x=Math.min(a.x,p.x),a.y=Math.min(a.y,p.y),a.z=Math.min(a.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:(a.x+s.x)/2,y:(a.y+s.y)/2,z:(a.z+s.z)/2},l=s.x-a.x,d=s.y-a.y,f=s.z-a.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],_=up(x,r,r,c,m),w=up(b,r,r,c,m);aw(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=Qo(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 Rc=class{constructor(e){this.loader=e}async getMapStatistics(e){let r=await this.loader.load(e),n=r.faces.filter(a=>a.lightOffset!==-1).length,i=r.models[0],o=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:o}}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[o,a]of Object.entries(i.properties))(o==="noise"||o.endsWith("_sound")||o==="sound")&&typeof a=="string"&&n.add(a)}return Array.from(n).sort()}};function fp(t){let e=[],r=0,n=t.length;function i(){for(;r<n&&/\s/.test(t[r]);)r++}function o(){if(i(),r>=n)return null;if(t[r]==='"'){r++;let a=r;for(;r<n&&t[r]!=='"';)t[r],r++;let s=t.substring(a,r);return r++,s}else{if(t[r]==="{"||t[r]==="}")return t[r++];{if(t.startsWith("//",r)){for(;r<n&&t[r]!==`
|
|
795
|
+
`;function lc(t){return L.fromValues(t.x,t.y,t.z)}function rr(t){return{x:t[0],y:t[1],z:t[2]}}var cc=class{constructor(e){this.vertices=[];this.solidVertices=[];this.labels=[];this.gl=e,this.shader=le.create(e,{vertex:Qx,fragment:Jx}),this.vao=new Le(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:ev,fragment:tv}),this.vaoSolid=new Le(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:o,z:a}=e,{x:s,y:c,z:l}=r;this.drawLine({x:i,y:o,z:a},{x:s,y:o,z:a},n),this.drawLine({x:s,y:o,z:a},{x:s,y:c,z:a},n),this.drawLine({x:s,y:c,z:a},{x:i,y:c,z:a},n),this.drawLine({x:i,y:c,z:a},{x:i,y:o,z:a},n),this.drawLine({x:i,y:o,z:l},{x:s,y:o,z:l},n),this.drawLine({x:s,y:o,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:o,z:l},n),this.drawLine({x:i,y:o,z:a},{x:i,y:o,z:l},n),this.drawLine({x:s,y:o,z:a},{x:s,y:o,z:l},n),this.drawLine({x:s,y:c,z:a},{x:s,y:c,z:l},n),this.drawLine({x:i,y:c,z:a},{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,o){this.solidVertices.push(e.x,e.y,e.z),this.solidVertices.push(o.r,o.g,o.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(r.x,r.y,r.z),this.solidVertices.push(o.r,o.g,o.b),this.solidVertices.push(i.x,i.y,i.z),this.solidVertices.push(n.x,n.y,n.z),this.solidVertices.push(o.r,o.g,o.b),this.solidVertices.push(i.x,i.y,i.z)}addCone(e,r,n,i){let a=lc(e),s=lc(r),c=L.create();L.subtract(c,a,s),L.normalize(c,c);let l=L.fromValues(0,0,1);Math.abs(L.dot(c,l))>.99&&(l=L.fromValues(0,1,0));let d=L.create();L.cross(d,l,c),L.normalize(d,d);let f=L.create();L.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=L.clone(s);L.scaleAndAdd(b,b,d,v),L.scaleAndAdd(b,b,f,x),u.push(b)}let h=L.clone(c);L.scale(h,h,-1);let m=rr(h),g=r;for(let p=0;p<16;p++){let y=rr(u[p]),v=rr(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=rr(y),b=rr(v),_=L.create();L.subtract(_,v,y);let w=L.create();L.subtract(w,a,y);let S=L.create();L.cross(S,_,w),L.normalize(S,S);let E=rr(S);this.addTriangle(x,b,e,E,i)}}addTorus(e,r,n,i,o={x:0,y:0,z:1}){let c=lc(o);L.normalize(c,c);let l=lc(e),d=L.fromValues(0,0,1),f=I.create();if(Math.abs(L.dot(c,d))>.999)c[2]<0&&I.rotateX(f,f,Math.PI);else{let m=L.create();L.cross(m,d,c),L.normalize(m,m);let g=Math.acos(L.dot(d,c));I.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,T=(r+n*w)*y,A=n*S,C=L.fromValues(E,T,A),B=w*p,F=w*y,k=S,N=L.fromValues(B,F,k);L.transformMat4(C,C,f),L.transformMat4(N,N,f),L.add(C,C,l),v.push(C),x.push(N)}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=rr(p),_=rr(y),w=rr(v),S=rr(x),E=L.create();L.subtract(E,y,p);let T=L.create();L.subtract(T,v,p);let A=L.create();L.cross(A,E,T),L.normalize(A,A),this.addTriangle(b,_,w,rr(A),i);let C=L.create();L.subtract(C,v,p);let B=L.create();L.subtract(B,x,p);let F=L.create();L.cross(F,C,B),L.normalize(F,F),this.addTriangle(b,w,S,rr(F),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 o of this.labels){let a=go.fromValues(o.position.x,o.position.y,o.position.z,1),s=go.create(),l=e,d=a[0],f=a[1],u=a[2],h=a[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:o.text,x:p,y})}}return i}clear(){this.vertices=[],this.solidVertices=[],this.labels=[]}};function Om(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 o=[],a=Math.min(i.length,n);for(let s=0;s<a;s++)o.push(i[s].light);return o}function wu(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 Um=t=>{let e=new fo(t),r=new ho(t),n=new po(t),i=new vo(t),o=new wo(t),a=new ac(t),s=new cc(t),c=new sc(t),l=new _f({seed:Date.now()}),d=new _o(4096,l),f=new So(t,d),u=e.shaderSize+r.shaderSize+n.shaderSize+i.shaderSize+o.shaderSize+a.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,T=1,A=1,C=!1,B=0,F=new Map,k=!1,N=!1,ce=.5,Vt=1,It=new Array(1024).fill(!0),Or=Fm(t,e,r),sn=1e4,ut=[],tt=0,Gt=rc.create(),Wn=L.create(),ln=L.create();for(let M=0;M<sn;M++){let X={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}};X.lighting&&(X.lighting.modelMatrix=X.transform),ut.push(X)}let Ur=[],Nr,Hr,D,ae=(M,X)=>{if(M.type==="md2"){let ie=M.model;if(!ie.lods||ie.lods.length===0)return{model:M.model,type:M.type};let de=M.transform[12]-X.x,re=M.transform[13]-X.y,pe=M.transform[14]-X.z,Ke=Math.sqrt(de*de+re*re+pe*pe),Bt=Math.floor(Ke*Vt/500);if(Bt<=0)return{model:M.model,type:M.type};let Ie=ie.lods,Xt=Math.min(Bt-1,Ie.length-1);return{model:Ie[Xt],type:M.type}}return{model:M.model,type:M.type}},Pe=(M,X,ie)=>{c.startFrame(),y++;let de=Ur.length>0?[...X,...Ur]:X;Ur.length=0,tt=0,M.deltaTime&&d.update(M.deltaTime),t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0);let pe=M.renderMode,Ke=!1;ie?.wireframe||E===6?pe={mode:"wireframe",applyToAll:!0,color:[1,1,1,1]}:E===5&&(Ke=!0);let Bt=M.sky;ie?.showSkybox===!1&&(Bt=void 0);let Ie=new Float32Array(M.camera.viewProjectionMatrix),Xt=Dn(Ie),Ft=M.dlights?Om(M.dlights,Xt,{x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},32):void 0,zo={...M,sky:Bt,renderMode:pe,disableLightmaps:ie?.showLightmaps===!1&&E!==5,dlights:Ft,lightmapOnly:Ke,brightness:T,gamma:A,fullbright:C,ambient:B,lightStyleOverrides:F,underwaterWarp:k,bloom:N,bloomIntensity:ce,portalState:It},Cs=Or.renderFrame(zo),ff=Cs.facesDrawn||0,hf=0;M.world&&M.world.map&&M.world.map.faces&&(hf=M.world.map.faces.length);let wp=hf-ff,zc=-1,Oc=-1,Uc=null;if(M.world&&ie?.cullingEnabled!==!1){let O={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},De=xi(M.world.map,O);if(De>=0){let ht=M.world.map.leafs[De];zc=ht.cluster,Oc=ht.area,Oc>=0&&M.world.map.areas.length>0&&(Uc=Wd(M.world.map,Oc,It))}}let Ps,Oo=0,Nc=0,mf=0,Is=0,Mp={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]};if(y%v===0)for(let[O,De]of p)y-De.lastFrameSeen>x&&p.delete(O);for(let O of de){if(M.world&&zc>=0){let Q={x:O.transform[12],y:O.transform[13],z:O.transform[14]},U=-1;if(O.id!==void 0){let Y=p.get(O.id);Y&&Y.position[12]===O.transform[12]&&Y.position[13]===O.transform[13]&&Y.position[14]===O.transform[14]?(U=Y.leafIndex,Y.lastFrameSeen=y):(U=xi(M.world.map,Q),U>=0&&p.set(O.id,{leafIndex:U,position:new Float32Array(O.transform),lastFrameSeen:y}))}else U=xi(M.world.map,Q);if(U>=0){let Y=M.world.map.leafs[U],$t=Y.cluster,Oe=Y.area;if(Uc&&Oe>=0&&!Uc.has(Oe)){Is++;continue}if(!Gd(M.world.map.visibility,zc,$t)){Is++;continue}}}let{model:De,type:ht}=ae(O,Mp),ze,ve;if(ht==="md2"){let Q=De,U=Q.frames[O.blend.frame0%Q.frames.length],Y=Q.frames[O.blend.frame1%Q.frames.length];U&&Y&&(ze={x:Math.min(U.minBounds.x,Y.minBounds.x),y:Math.min(U.minBounds.y,Y.minBounds.y),z:Math.min(U.minBounds.z,Y.minBounds.z)},ve={x:Math.max(U.maxBounds.x,Y.maxBounds.x),y:Math.max(U.maxBounds.y,Y.maxBounds.y),z:Math.max(U.maxBounds.z,Y.maxBounds.z)})}else if(ht==="md3"){let Q=De,U=Q.frames[O.blend.frame0%Q.frames.length],Y=Q.frames[O.blend.frame1%Q.frames.length];U&&Y?(ze={x:Math.min(U.minBounds.x,Y.minBounds.x),y:Math.min(U.minBounds.y,Y.minBounds.y),z:Math.min(U.minBounds.z,Y.minBounds.z)},ve={x:Math.max(U.maxBounds.x,Y.maxBounds.x),y:Math.max(U.maxBounds.y,Y.maxBounds.y),z:Math.max(U.maxBounds.z,Y.maxBounds.z)}):(ze={x:-32,y:-32,z:-32},ve={x:32,y:32,z:32})}if(ze&&ve){let Q=Oh(ze,ve,O.transform);if(!bi(Q.mins,Q.maxs,Xt)){Is++;continue}}mf++;let ar={x:O.transform[12],y:O.transform[13],z:O.transform[14]},Ye=km(M.world?.map,ar),Te=O.id!==void 0?w.get(O.id):void 0;switch(ht){case"md2":{let Q=De,U=m.get(Q);if(U)U.update(Q,O.blend);else{U=new mo(t,Q,O.blend),m.set(Q,U);let Ue=U.geometry.vertices.length*8*4,dn=U.geometry.indices.length*2;c.trackBufferMemory(Ue+dn)}let Y=Xc(Ie,O.transform),$t=O.skin,Oe=$t?M.world?.textures?.get($t):void 0;Oe&&Oe!==Ps&&(Oe.bind(0),Ps=Oe);let Kt=pe;if(Kt&&!Kt.applyToAll&&Oe&&(Kt=void 0),Kt?.generateRandomColor&&O.id!==void 0){let Ue=wu(O.id);Kt={...Kt,color:Ue}}if(n.bind({modelViewProjection:Y,modelMatrix:O.transform,ambientLight:Ye,dlights:M.dlights,renderMode:Kt,tint:O.tint,brightness:T,gamma:A,fullbright:C,ambient:B}),n.draw(U,Kt),Oo++,Nc+=U.geometry.vertices.length,Te){let Ue={mode:"wireframe",applyToAll:!0,color:Te};n.bind({modelViewProjection:Y,modelMatrix:O.transform,ambientLight:1,renderMode:Ue,tint:[1,1,1,1],brightness:1,gamma:1,fullbright:!0,ambient:0}),n.draw(U,Ue),Oo++}}break;case"md3":{let Q=De,U=h.get(Q),Y=O,$t=M.dlights?M.dlights.map(Ue=>({origin:Ue.origin,color:[Ue.color.x,Ue.color.y,Ue.color.z],radius:Ue.intensity})):void 0,Oe={...Y.lighting,ambient:[Ye,Ye,Ye],dynamicLights:$t,modelMatrix:O.transform};U?U.update(O.blend,Oe):(U=new xo(t,Q,O.blend,Oe),h.set(Q,U));let Kt=Xc(Ie,O.transform);i.bind(Kt);for(let Ue of Q.surfaces){let dn=U.surfaces.get(Ue.name);if(dn){let gf=Y.skins?.get(Ue.name),Uo=gf?M.world?.textures?.get(gf):void 0;Uo&&Uo!==Ps&&(Uo.bind(0),Ps=Uo);let Kn=pe;if(Kn&&!Kn.applyToAll&&Uo&&(Kn=void 0),Kn?.generateRandomColor&&O.id!==void 0){let yf=wu(O.id);Kn={...Kn,color:yf}}let Ap={renderMode:Kn,brightness:T,gamma:A,fullbright:C,globalAmbient:B};if(i.drawSurface(dn,Ap),Oo++,Nc+=dn.geometry.vertices.length,Te){let Ep={renderMode:{mode:"wireframe",applyToAll:!0,color:Te},brightness:1,gamma:1,fullbright:!0,globalAmbient:0};i.drawSurface(dn,Ep),Oo++}}}}break}}let $n=M.camera.viewMatrix;if($n){let O={x:$n[0],y:$n[4],z:$n[8]},De={x:$n[1],y:$n[5],z:$n[9]};f.render({viewProjection:Ie,viewRight:O,viewUp:De})}if(zo.waterTint&&(Nr(),D(0,0,t.canvas.width,t.canvas.height,zo.waterTint),Hr()),a.render(Ie),a.clear(),M.world&&(S.size>0||E===3)){let O=new Map(S);if(E===3&&M.world){let De=Dn(Ie),ht={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},ze=vi(M.world.map,ht,De,It);for(let{faceIndex:ve,leafIndex:ar}of ze){let Ye=M.world.map.leafs[ar];Ye&&!O.has(ve)&&O.set(ve,wu(Ye.cluster))}}for(let[De,ht]of O){let ze=M.world.surfaces[De];if(ze&&ze.vertexCount>0){let ve=[];for(let Te=0;Te<ze.vertexCount;Te++)ve.push({x:ze.vertexData[Te*7],y:ze.vertexData[Te*7+1],z:ze.vertexData[Te*7+2]});let Ye={r:ht[0],g:ht[1],b:ht[2]};for(let Te=0;Te<ve.length;Te++){let Q=ve[Te],U=ve[(Te+1)%ve.length];s.drawLine(Q,U,Ye)}s.drawLine(ve[0],ve[ve.length/2|0],Ye)}}}if((ie?.showNormals||E===2)&&M.world){let O=Dn(Ie),De={x:M.camera.position[0],y:M.camera.position[1],z:M.camera.position[2]},ht=vi(M.world.map,De,O,It);for(let{faceIndex:ze}of ht){let ve=M.world.map.faces[ze],ar=M.world.map.planes[ve.planeIndex],Ye=M.world.surfaces[ze];if(!Ye)continue;let Te=0,Q=0,U=0,Y=Ye.vertexCount;for(let $t=0;$t<Y;$t++){let Oe=$t*7;Te+=Ye.vertexData[Oe],Q+=Ye.vertexData[Oe+1],U+=Ye.vertexData[Oe+2]}if(Y>0){Te/=Y,Q/=Y,U/=Y;let $t=ve.side===0?ar.normal[0]:-ar.normal[0],Oe=ve.side===0?ar.normal[1]:-ar.normal[1],Kt=ve.side===0?ar.normal[2]:-ar.normal[2],Ue={x:Te,y:Q,z:U},dn={x:Te+$t*8,y:Q+Oe*8,z:U+Kt*8};s.drawLine(Ue,dn,{r:1,g:1,b:0})}}}s.render(Ie);let pf=s.getLabels(Ie,t.canvas.width,t.canvas.height);if(pf.length>0){Nr();for(let O of pf)ft(O.x,O.y,O.text,[1,1,1,1]);Hr()}s.clear(),_={drawCalls:Cs.drawCalls+Oo,vertexCount:Cs.vertexCount+Nc,batches:Cs.batches,shaderSwitches:0,visibleSurfaces:ff,culledSurfaces:wp,visibleEntities:mf,culledEntities:Is},c.endFrame()},Ce=async(M,X)=>{if(g.has(M))return g.get(M);let ie=new Blob([X]),de=await createImageBitmap(ie),re=new et(t);return re.upload(de.width,de.height,de),g.set(M,re),c.trackTextureMemory(de.width*de.height*4),M.includes("conchars")&&(b=re),re},or=(M,X)=>{if(g.has(M))return g.get(M);let ie=new et(t),de=X.levels[0];return ie.upload(de.width,de.height,de.rgba),g.set(M,ie),c.trackTextureMemory(de.width*de.height*4),M.includes("conchars")&&(b=ie),ie},Wt=M=>g.get(M);Nr=()=>{t.enable(t.BLEND),t.blendFunc(t.SRC_ALPHA,t.ONE_MINUS_SRC_ALPHA),t.disable(t.DEPTH_TEST),t.depthMask(!1);let M=I.create();I.ortho(M,0,t.canvas.width,t.canvas.height,0,-1,1),o.begin(M)},Hr=()=>{t.disable(t.BLEND),t.enable(t.DEPTH_TEST),t.depthMask(!0)};let cn=(M,X,ie,de)=>{ie.bind(0),o.draw(M,X,ie.width,ie.height,0,0,1,1,de)},Es=(M,X,ie,de)=>{if(!b)return;let re=8,pe=8,Ke=b.width/re,Bt=ie&255,Ie=Bt%Ke*re/b.width,Xt=Math.floor(Bt/Ke)*pe/b.height,Ft=Ie+re/b.width,zo=Xt+pe/b.height;b.bind(0),o.draw(M,X,re,pe,Ie,Xt,Ft,zo,de)},ft=(M,X,ie,de)=>{let re=zm(ie),pe=M,Ke=8;for(let Bt of re){let Ie=Bt.color||de;for(let Xt=0;Xt<Bt.text.length;Xt++)Es(pe,X,Bt.text.charCodeAt(Xt),Ie),pe+=Ke}},Ls=(M,X)=>{let re=X.replace(/\^[0-9]/g,"").length*8,pe=(t.canvas.width-re)/2;ft(pe,M,X)};return D=(M,X,ie,de,re)=>{o.drawRect(M,X,ie,de,re)},{get width(){return t.canvas.width},get height(){return t.canvas.height},get collisionVis(){return a},get debug(){return s},get particleSystem(){return d},getPerformanceReport:()=>c.getPerformanceReport(_),getMemoryUsage:()=>c.getMemoryUsage(),renderFrame:Pe,registerPic:Ce,registerTexture:or,getTexture:Wt,begin2D:Nr,end2D:Hr,drawPic:cn,drawString:ft,drawCenterString:Ls,drawfillRect:D,setEntityHighlight:(M,X)=>{w.set(M,X)},clearEntityHighlight:M=>{w.delete(M)},highlightSurface:(M,X)=>{S.set(M,X)},removeSurfaceHighlight:M=>{S.delete(M)},setDebugMode:M=>{E=M},setBrightness:M=>{T=Math.max(0,Math.min(2,M))},setGamma:M=>{A=Math.max(.5,Math.min(3,M))},setFullbright:M=>{C=M},setAmbient:M=>{B=Math.max(0,Math.min(1,M))},setLightStyle:(M,X)=>{X===null?F.delete(M):F.set(M,X)},setUnderwaterWarp:M=>{k=M},setBloom:M=>{N=M},setBloomIntensity:M=>{ce=M},setLodBias:M=>{Vt=Math.max(0,Math.min(2,M))},setAreaPortalState:(M,X)=>{M>=0&&M<It.length&&(It[M]=X)},renderInstanced:(M,X)=>{let ie="glCommands"in M,de=ie?"md2":"md3";for(let re of X){if(tt>=sn){console.warn("Max instances reached");break}let pe=ut[tt++];pe.model=M,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 Bt=re.rotation,Ie=re.position,Xt=re.scale||{x:1,y:1,z:1};I.fromRotationTranslationScale(pe.transform,Gt,Wn,ln);let Ft=pe.lighting;Ft&&(Ft.dynamicLights?Ft.dynamicLights.length=0:Ft.dynamicLights=[],Ft.ambient?(Ft.ambient[0]=.5,Ft.ambient[1]=.5,Ft.ambient[2]=.5):Ft.ambient=[.5,.5,.5]),Ur.push(pe)}},uploadBspGeometry:M=>{let X=Xl(M);return $l(t,X,M)},dispose:()=>{c.dispose()}}};var hr=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 pn(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 o=new Uint8Array(e),a=0,s=new Uint8Array(this.buffer);for(let c of n)o.set(s.subarray(c.offset,c.offset+c.length),a),a+=c.length;return this.offset=i,o.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 Ro(t){let e=t.length;for(;--e>=0;)t[e]=0}var rv=0,M0=1,nv=2,iv=3,ov=258,Ku=29,bs=256,ds=bs+1+Ku,Eo=30,Yu=19,A0=2*ds+1,_i=15,Mu=16,av=7,qu=256,E0=16,L0=17,T0=18,Ou=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]),pc=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]),sv=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),R0=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),lv=512,on=new Array((ds+2)*2);Ro(on);var ss=new Array(Eo*2);Ro(ss);var us=new Array(lv);Ro(us);var fs=new Array(ov-iv+1);Ro(fs);var Zu=new Array(Ku);Ro(Zu);var gc=new Array(Eo);Ro(gc);function Au(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 C0,P0,I0;function Eu(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}var B0=t=>t<256?us[t]:us[256+(t>>>7)],hs=(t,e)=>{t.pending_buf[t.pending++]=e&255,t.pending_buf[t.pending++]=e>>>8&255},Pt=(t,e,r)=>{t.bi_valid>Mu-r?(t.bi_buf|=e<<t.bi_valid&65535,hs(t,t.bi_buf),t.bi_buf=e>>Mu-t.bi_valid,t.bi_valid+=r-Mu):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=r)},Br=(t,e,r)=>{Pt(t,r[e*2],r[e*2+1])},F0=(t,e)=>{let r=0;do r|=t&1,t>>>=1,r<<=1;while(--e>0);return r>>>1},cv=t=>{t.bi_valid===16?(hs(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)},dv=(t,e)=>{let r=e.dyn_tree,n=e.max_code,i=e.stat_desc.static_tree,o=e.stat_desc.has_stree,a=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<=_i;u++)t.bl_count[u]=0;for(r[t.heap[t.heap_max]*2+1]=0,l=t.heap_max+1;l<A0;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=a[d-s]),m=r[d*2],t.opt_len+=m*(u+h),o&&(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--)}},k0=(t,e,r)=>{let n=new Array(_i+1),i=0,o,a;for(o=1;o<=_i;o++)i=i+r[o-1]<<1,n[o]=i;for(a=0;a<=e;a++){let s=t[a*2+1];s!==0&&(t[a*2]=F0(n[s]++,s))}},uv=()=>{let t,e,r,n,i,o=new Array(_i+1);for(r=0,n=0;n<Ku-1;n++)for(Zu[n]=r,t=0;t<1<<Ou[n];t++)fs[r++]=n;for(fs[r-1]=n,i=0,n=0;n<16;n++)for(gc[n]=i,t=0;t<1<<pc[n];t++)us[i++]=n;for(i>>=7;n<Eo;n++)for(gc[n]=i<<7,t=0;t<1<<pc[n]-7;t++)us[256+i++]=n;for(e=0;e<=_i;e++)o[e]=0;for(t=0;t<=143;)on[t*2+1]=8,t++,o[8]++;for(;t<=255;)on[t*2+1]=9,t++,o[9]++;for(;t<=279;)on[t*2+1]=7,t++,o[7]++;for(;t<=287;)on[t*2+1]=8,t++,o[8]++;for(k0(on,ds+1,o),t=0;t<Eo;t++)ss[t*2+1]=5,ss[t*2]=F0(t,5);C0=new Au(on,Ou,bs+1,ds,_i),P0=new Au(ss,pc,0,Eo,_i),I0=new Au(new Array(0),sv,0,Yu,av)},D0=t=>{let e;for(e=0;e<ds;e++)t.dyn_ltree[e*2]=0;for(e=0;e<Eo;e++)t.dyn_dtree[e*2]=0;for(e=0;e<Yu;e++)t.bl_tree[e*2]=0;t.dyn_ltree[qu*2]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},z0=t=>{t.bi_valid>8?hs(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},Nm=(t,e,r,n)=>{let i=e*2,o=r*2;return t[i]<t[o]||t[i]===t[o]&&n[e]<=n[r]},Lu=(t,e,r)=>{let n=t.heap[r],i=r<<1;for(;i<=t.heap_len&&(i<t.heap_len&&Nm(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!Nm(e,n,t.heap[i],t.depth));)t.heap[r]=t.heap[i],r=i,i<<=1;t.heap[r]=n},Hm=(t,e,r)=>{let n,i,o=0,a,s;if(t.sym_next!==0)do n=t.pending_buf[t.sym_buf+o++]&255,n+=(t.pending_buf[t.sym_buf+o++]&255)<<8,i=t.pending_buf[t.sym_buf+o++],n===0?Br(t,i,e):(a=fs[i],Br(t,a+bs+1,e),s=Ou[a],s!==0&&(i-=Zu[a],Pt(t,i,s)),n--,a=B0(n),Br(t,a,r),s=pc[a],s!==0&&(n-=gc[a],Pt(t,n,s)));while(o<t.sym_next);Br(t,qu,e)},Uu=(t,e)=>{let r=e.dyn_tree,n=e.stat_desc.static_tree,i=e.stat_desc.has_stree,o=e.stat_desc.elems,a,s,c=-1,l;for(t.heap_len=0,t.heap_max=A0,a=0;a<o;a++)r[a*2]!==0?(t.heap[++t.heap_len]=c=a,t.depth[a]=0):r[a*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,a=t.heap_len>>1;a>=1;a--)Lu(t,r,a);l=o;do a=t.heap[1],t.heap[1]=t.heap[t.heap_len--],Lu(t,r,1),s=t.heap[1],t.heap[--t.heap_max]=a,t.heap[--t.heap_max]=s,r[l*2]=r[a*2]+r[s*2],t.depth[l]=(t.depth[a]>=t.depth[s]?t.depth[a]:t.depth[s])+1,r[a*2+1]=r[s*2+1]=l,t.heap[1]=l++,Lu(t,r,1);while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],dv(t,e),k0(r,c,t.bl_count)},Vm=(t,e,r)=>{let n,i=-1,o,a=e[1],s=0,c=7,l=4;for(a===0&&(c=138,l=3),e[(r+1)*2+1]=65535,n=0;n<=r;n++)o=a,a=e[(n+1)*2+1],!(++s<c&&o===a)&&(s<l?t.bl_tree[o*2]+=s:o!==0?(o!==i&&t.bl_tree[o*2]++,t.bl_tree[E0*2]++):s<=10?t.bl_tree[L0*2]++:t.bl_tree[T0*2]++,s=0,i=o,a===0?(c=138,l=3):o===a?(c=6,l=3):(c=7,l=4))},Gm=(t,e,r)=>{let n,i=-1,o,a=e[1],s=0,c=7,l=4;for(a===0&&(c=138,l=3),n=0;n<=r;n++)if(o=a,a=e[(n+1)*2+1],!(++s<c&&o===a)){if(s<l)do Br(t,o,t.bl_tree);while(--s!==0);else o!==0?(o!==i&&(Br(t,o,t.bl_tree),s--),Br(t,E0,t.bl_tree),Pt(t,s-3,2)):s<=10?(Br(t,L0,t.bl_tree),Pt(t,s-3,3)):(Br(t,T0,t.bl_tree),Pt(t,s-11,7));s=0,i=o,a===0?(c=138,l=3):o===a?(c=6,l=3):(c=7,l=4)}},fv=t=>{let e;for(Vm(t,t.dyn_ltree,t.l_desc.max_code),Vm(t,t.dyn_dtree,t.d_desc.max_code),Uu(t,t.bl_desc),e=Yu-1;e>=3&&t.bl_tree[R0[e]*2+1]===0;e--);return t.opt_len+=3*(e+1)+5+5+4,e},hv=(t,e,r,n)=>{let i;for(Pt(t,e-257,5),Pt(t,r-1,5),Pt(t,n-4,4),i=0;i<n;i++)Pt(t,t.bl_tree[R0[i]*2+1],3);Gm(t,t.dyn_ltree,e-1),Gm(t,t.dyn_dtree,r-1)},mv=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<bs;r++)if(t.dyn_ltree[r*2]!==0)return 1;return 0},Wm=!1,pv=t=>{Wm||(uv(),Wm=!0),t.l_desc=new Eu(t.dyn_ltree,C0),t.d_desc=new Eu(t.dyn_dtree,P0),t.bl_desc=new Eu(t.bl_tree,I0),t.bi_buf=0,t.bi_valid=0,D0(t)},O0=(t,e,r,n)=>{Pt(t,(rv<<1)+(n?1:0),3),z0(t),hs(t,r),hs(t,~r),r&&t.pending_buf.set(t.window.subarray(e,e+r),t.pending),t.pending+=r},gv=t=>{Pt(t,M0<<1,3),Br(t,qu,on),cv(t)},yv=(t,e,r,n)=>{let i,o,a=0;t.level>0?(t.strm.data_type===2&&(t.strm.data_type=mv(t)),Uu(t,t.l_desc),Uu(t,t.d_desc),a=fv(t),i=t.opt_len+3+7>>>3,o=t.static_len+3+7>>>3,o<=i&&(i=o)):i=o=r+5,r+4<=i&&e!==-1?O0(t,e,r,n):t.strategy===4||o===i?(Pt(t,(M0<<1)+(n?1:0),3),Hm(t,on,ss)):(Pt(t,(nv<<1)+(n?1:0),3),hv(t,t.l_desc.max_code+1,t.d_desc.max_code+1,a+1),Hm(t,t.dyn_ltree,t.dyn_dtree)),D0(t),n&&z0(t)},bv=(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[(fs[r]+bs+1)*2]++,t.dyn_dtree[B0(e)*2]++),t.sym_next===t.sym_end),xv=pv,vv=O0,_v=yv,Sv=bv,wv=gv,Mv={_tr_init:xv,_tr_stored_block:vv,_tr_flush_block:_v,_tr_tally:Sv,_tr_align:wv},Av=(t,e,r,n)=>{let i=t&65535|0,o=t>>>16&65535|0,a=0;for(;r!==0;){a=r>2e3?2e3:r,r-=a;do i=i+e[n++]|0,o=o+i|0;while(--a);i%=65521,o%=65521}return i|o<<16|0},ms=Av,Ev=()=>{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},Lv=new Uint32Array(Ev()),Tv=(t,e,r,n)=>{let i=Lv,o=n+r;t^=-1;for(let a=n;a<o;a++)t=t>>>8^i[(t^e[a])&255];return t^-1},ke=Tv,Mi={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"},Li={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:Rv,_tr_stored_block:Nu,_tr_flush_block:Cv,_tr_tally:Nn,_tr_align:Pv}=Mv,{Z_NO_FLUSH:Hn,Z_PARTIAL_FLUSH:Iv,Z_FULL_FLUSH:Bv,Z_FINISH:nr,Z_BLOCK:Xm,Z_OK:$e,Z_STREAM_END:$m,Z_STREAM_ERROR:Fr,Z_DATA_ERROR:Fv,Z_BUF_ERROR:Tu,Z_DEFAULT_COMPRESSION:kv,Z_FILTERED:Dv,Z_HUFFMAN_ONLY:dc,Z_RLE:zv,Z_FIXED:Ov,Z_DEFAULT_STRATEGY:Uv,Z_UNKNOWN:Nv,Z_DEFLATED:xc}=Li,Hv=9,Vv=15,Gv=8,Wv=29,Xv=256,Hu=Xv+1+Wv,$v=30,Kv=19,Yv=2*Hu+1,qv=15,j=3,Un=258,kr=Un+j+1,Zv=32,Lo=42,ju=57,Vu=69,Gu=73,Wu=91,Xu=103,Si=113,os=666,ct=1,Co=2,Ai=3,Po=4,jv=3,wi=(t,e)=>(t.msg=Mi[e],e),Km=t=>t*2-(t>4?9:0),On=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Qv=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)},Jv=(t,e,r)=>(e<<t.hash_shift^r)&t.hash_mask,Vn=Jv,Nt=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))},Ht=(t,e)=>{Cv(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Nt(t.strm)},ne=(t,e)=>{t.pending_buf[t.pending++]=e},is=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=e&255},$u=(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=ms(t.adler,e,i,r):t.state.wrap===2&&(t.adler=ke(t.adler,e,i,r)),t.next_in+=i,t.total_in+=i,i)},U0=(t,e)=>{let r=t.max_chain_length,n=t.strstart,i,o,a=t.prev_length,s=t.nice_match,c=t.strstart>t.w_size-kr?t.strstart-(t.w_size-kr):0,l=t.window,d=t.w_mask,f=t.prev,u=t.strstart+Un,h=l[n+a-1],m=l[n+a];t.prev_length>=t.good_match&&(r>>=2),s>t.lookahead&&(s=t.lookahead);do if(i=e,!(l[i+a]!==m||l[i+a-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(o=Un-(u-n),n=u-Un,o>a){if(t.match_start=e,a=o,o>=s)break;h=l[n+a-1],m=l[n+a]}}while((e=f[e&d])>c&&--r!==0);return a<=t.lookahead?a:t.lookahead},To=t=>{let e=t.w_size,r,n,i;do{if(n=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-kr)&&(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),Qv(t),n+=e),t.strm.avail_in===0)break;if(r=$u(t.strm,t.window,t.strstart+t.lookahead,n),t.lookahead+=r,t.lookahead+t.insert>=j)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Vn(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Vn(t,t.ins_h,t.window[i+j-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<j)););}while(t.lookahead<kr&&t.strm.avail_in!==0)},N0=(t,e)=>{let r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n,i,o,a=0,s=t.strm.avail_in;do{if(n=65535,o=t.bi_valid+42>>3,t.strm.avail_out<o||(o=t.strm.avail_out-o,i=t.strstart-t.block_start,n>i+t.strm.avail_in&&(n=i+t.strm.avail_in),n>o&&(n=o),n<r&&(n===0&&e!==nr||e===Hn||n!==i+t.strm.avail_in)))break;a=e===nr&&n===i+t.strm.avail_in?1:0,Nu(t,0,0,a),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,Nt(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&&($u(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(a===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),a?Po:e!==Hn&&e!==nr&&t.strm.avail_in===0&&t.strstart===t.block_start?Co:(o=t.window_size-t.strstart,t.strm.avail_in>o&&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++,o+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),o>t.strm.avail_in&&(o=t.strm.avail_in),o&&($u(t.strm,t.window,t.strstart,o),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.high_water<t.strstart&&(t.high_water=t.strstart),o=t.bi_valid+42>>3,o=t.pending_buf_size-o>65535?65535:t.pending_buf_size-o,r=o>t.w_size?t.w_size:o,i=t.strstart-t.block_start,(i>=r||(i||e===nr)&&e!==Hn&&t.strm.avail_in===0&&i<=o)&&(n=i>o?o:i,a=e===nr&&t.strm.avail_in===0&&n===i?1:0,Nu(t,t.block_start,n,a),t.block_start+=n,Nt(t.strm)),a?Ai:ct)},Ru=(t,e)=>{let r,n;for(;;){if(t.lookahead<kr){if(To(t),t.lookahead<kr&&e===Hn)return ct;if(t.lookahead===0)break}if(r=0,t.lookahead>=j&&(t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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-kr&&(t.match_length=U0(t,r)),t.match_length>=j)if(n=Nn(t,t.strstart-t.match_start,t.match_length-j),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=j){t.match_length--;do t.strstart++,t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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=Vn(t,t.ins_h,t.window[t.strstart+1]);else n=Nn(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(n&&(Ht(t,!1),t.strm.avail_out===0))return ct}return t.insert=t.strstart<j-1?t.strstart:j-1,e===nr?(Ht(t,!0),t.strm.avail_out===0?Ai:Po):t.sym_next&&(Ht(t,!1),t.strm.avail_out===0)?ct:Co},Mo=(t,e)=>{let r,n,i;for(;;){if(t.lookahead<kr){if(To(t),t.lookahead<kr&&e===Hn)return ct;if(t.lookahead===0)break}if(r=0,t.lookahead>=j&&(t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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=j-1,r!==0&&t.prev_length<t.max_lazy_match&&t.strstart-r<=t.w_size-kr&&(t.match_length=U0(t,r),t.match_length<=5&&(t.strategy===Dv||t.match_length===j&&t.strstart-t.match_start>4096)&&(t.match_length=j-1)),t.prev_length>=j&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-j,n=Nn(t,t.strstart-1-t.prev_match,t.prev_length-j),t.lookahead-=t.prev_length-1,t.prev_length-=2;do++t.strstart<=i&&(t.ins_h=Vn(t,t.ins_h,t.window[t.strstart+j-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=j-1,t.strstart++,n&&(Ht(t,!1),t.strm.avail_out===0))return ct}else if(t.match_available){if(n=Nn(t,0,t.window[t.strstart-1]),n&&Ht(t,!1),t.strstart++,t.lookahead--,t.strm.avail_out===0)return ct}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(n=Nn(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<j-1?t.strstart:j-1,e===nr?(Ht(t,!0),t.strm.avail_out===0?Ai:Po):t.sym_next&&(Ht(t,!1),t.strm.avail_out===0)?ct:Co},e_=(t,e)=>{let r,n,i,o,a=t.window;for(;;){if(t.lookahead<=Un){if(To(t),t.lookahead<=Un&&e===Hn)return ct;if(t.lookahead===0)break}if(t.match_length=0,t.lookahead>=j&&t.strstart>0&&(i=t.strstart-1,n=a[i],n===a[++i]&&n===a[++i]&&n===a[++i])){o=t.strstart+Un;do;while(n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&n===a[++i]&&i<o);t.match_length=Un-(o-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=j?(r=Nn(t,1,t.match_length-j),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(r=Nn(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),r&&(Ht(t,!1),t.strm.avail_out===0))return ct}return t.insert=0,e===nr?(Ht(t,!0),t.strm.avail_out===0?Ai:Po):t.sym_next&&(Ht(t,!1),t.strm.avail_out===0)?ct:Co},t_=(t,e)=>{let r;for(;;){if(t.lookahead===0&&(To(t),t.lookahead===0)){if(e===Hn)return ct;break}if(t.match_length=0,r=Nn(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,r&&(Ht(t,!1),t.strm.avail_out===0))return ct}return t.insert=0,e===nr?(Ht(t,!0),t.strm.avail_out===0?Ai:Po):t.sym_next&&(Ht(t,!1),t.strm.avail_out===0)?ct:Co};function Ir(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 as=[new Ir(0,0,0,0,N0),new Ir(4,4,8,4,Ru),new Ir(4,5,16,8,Ru),new Ir(4,6,32,32,Ru),new Ir(4,4,16,16,Mo),new Ir(8,16,32,32,Mo),new Ir(8,16,128,128,Mo),new Ir(8,32,128,256,Mo),new Ir(32,128,258,1024,Mo),new Ir(32,258,258,4096,Mo)],r_=t=>{t.window_size=2*t.w_size,On(t.head),t.max_lazy_match=as[t.level].max_lazy,t.good_match=as[t.level].good_length,t.nice_match=as[t.level].nice_length,t.max_chain_length=as[t.level].max_chain,t.strstart=0,t.block_start=0,t.lookahead=0,t.insert=0,t.match_length=t.prev_length=j-1,t.match_available=0,t.ins_h=0};function n_(){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=xc,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(Yv*2),this.dyn_dtree=new Uint16Array((2*$v+1)*2),this.bl_tree=new Uint16Array((2*Kv+1)*2),On(this.dyn_ltree),On(this.dyn_dtree),On(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(qv+1),this.heap=new Uint16Array(2*Hu+1),On(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(2*Hu+1),On(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 xs=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.status!==Lo&&e.status!==ju&&e.status!==Vu&&e.status!==Gu&&e.status!==Wu&&e.status!==Xu&&e.status!==Si&&e.status!==os?1:0},H0=t=>{if(xs(t))return wi(t,Fr);t.total_in=t.total_out=0,t.data_type=Nv;let e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=e.wrap===2?ju:e.wrap?Lo:Si,t.adler=e.wrap===2?0:1,e.last_flush=-2,Rv(e),$e},V0=t=>{let e=H0(t);return e===$e&&r_(t.state),e},i_=(t,e)=>xs(t)||t.state.wrap!==2?Fr:(t.state.gzhead=e,$e),G0=(t,e,r,n,i,o)=>{if(!t)return Fr;let a=1;if(e===kv&&(e=6),n<0?(a=0,n=-n):n>15&&(a=2,n-=16),i<1||i>Hv||r!==xc||n<8||n>15||e<0||e>9||o<0||o>Ov||n===8&&a!==1)return wi(t,Fr);n===8&&(n=9);let s=new n_;return t.state=s,s.strm=t,s.status=Lo,s.wrap=a,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+j-1)/j),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=o,s.method=r,V0(t)},o_=(t,e)=>G0(t,e,xc,Vv,Gv,Uv),a_=(t,e)=>{if(xs(t)||e>Xm||e<0)return t?wi(t,Fr):Fr;let r=t.state;if(!t.output||t.avail_in!==0&&!t.input||r.status===os&&e!==nr)return wi(t,t.avail_out===0?Tu:Fr);let n=r.last_flush;if(r.last_flush=e,r.pending!==0){if(Nt(t),t.avail_out===0)return r.last_flush=-1,$e}else if(t.avail_in===0&&Km(e)<=Km(n)&&e!==nr)return wi(t,Tu);if(r.status===os&&t.avail_in!==0)return wi(t,Tu);if(r.status===Lo&&r.wrap===0&&(r.status=Si),r.status===Lo){let i=xc+(r.w_bits-8<<4)<<8,o=-1;if(r.strategy>=dc||r.level<2?o=0:r.level<6?o=1:r.level===6?o=2:o=3,i|=o<<6,r.strstart!==0&&(i|=Zv),i+=31-i%31,is(r,i),r.strstart!==0&&(is(r,t.adler>>>16),is(r,t.adler&65535)),t.adler=1,r.status=Si,Nt(t),r.pending!==0)return r.last_flush=-1,$e}if(r.status===ju){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>=dc||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=ke(t.adler,r.pending_buf,r.pending,0)),r.gzindex=0,r.status=Vu;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>=dc||r.level<2?4:0),ne(r,jv),r.status=Si,Nt(t),r.pending!==0)return r.last_flush=-1,$e}if(r.status===Vu){if(r.gzhead.extra){let i=r.pending,o=(r.gzhead.extra.length&65535)-r.gzindex;for(;r.pending+o>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=ke(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex+=s,Nt(t),r.pending!==0)return r.last_flush=-1,$e;i=0,o-=s}let a=new Uint8Array(r.gzhead.extra);r.pending_buf.set(a.subarray(r.gzindex,r.gzindex+o),r.pending),r.pending+=o,r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Gu}if(r.status===Gu){if(r.gzhead.name){let i=r.pending,o;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),Nt(t),r.pending!==0)return r.last_flush=-1,$e;i=0}r.gzindex<r.gzhead.name.length?o=r.gzhead.name.charCodeAt(r.gzindex++)&255:o=0,ne(r,o)}while(o!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Wu}if(r.status===Wu){if(r.gzhead.comment){let i=r.pending,o;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i)),Nt(t),r.pending!==0)return r.last_flush=-1,$e;i=0}r.gzindex<r.gzhead.comment.length?o=r.gzhead.comment.charCodeAt(r.gzindex++)&255:o=0,ne(r,o)}while(o!==0);r.gzhead.hcrc&&r.pending>i&&(t.adler=ke(t.adler,r.pending_buf,r.pending-i,i))}r.status=Xu}if(r.status===Xu){if(r.gzhead.hcrc){if(r.pending+2>r.pending_buf_size&&(Nt(t),r.pending!==0))return r.last_flush=-1,$e;ne(r,t.adler&255),ne(r,t.adler>>8&255),t.adler=0}if(r.status=Si,Nt(t),r.pending!==0)return r.last_flush=-1,$e}if(t.avail_in!==0||r.lookahead!==0||e!==Hn&&r.status!==os){let i=r.level===0?N0(r,e):r.strategy===dc?t_(r,e):r.strategy===zv?e_(r,e):as[r.level].func(r,e);if((i===Ai||i===Po)&&(r.status=os),i===ct||i===Ai)return t.avail_out===0&&(r.last_flush=-1),$e;if(i===Co&&(e===Iv?Pv(r):e!==Xm&&(Nu(r,0,0,!1),e===Bv&&(On(r.head),r.lookahead===0&&(r.strstart=0,r.block_start=0,r.insert=0))),Nt(t),t.avail_out===0))return r.last_flush=-1,$e}return e!==nr?$e:r.wrap<=0?$m:(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)):(is(r,t.adler>>>16),is(r,t.adler&65535)),Nt(t),r.wrap>0&&(r.wrap=-r.wrap),r.pending!==0?$e:$m)},s_=t=>{if(xs(t))return Fr;let e=t.state.status;return t.state=null,e===Si?wi(t,Fv):$e},l_=(t,e)=>{let r=e.length;if(xs(t))return Fr;let n=t.state,i=n.wrap;if(i===2||i===1&&n.status!==Lo||n.lookahead)return Fr;if(i===1&&(t.adler=ms(t.adler,e,r,0)),n.wrap=0,r>=n.w_size){i===0&&(On(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 o=t.avail_in,a=t.next_in,s=t.input;for(t.avail_in=r,t.next_in=0,t.input=e,To(n);n.lookahead>=j;){let c=n.strstart,l=n.lookahead-(j-1);do n.ins_h=Vn(n,n.ins_h,n.window[c+j-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=j-1,To(n)}return n.strstart+=n.lookahead,n.block_start=n.strstart,n.insert=n.lookahead,n.lookahead=0,n.match_length=n.prev_length=j-1,n.match_available=0,t.next_in=a,t.input=s,t.avail_in=o,n.wrap=i,$e},c_=o_,d_=G0,u_=V0,f_=H0,h_=i_,m_=a_,p_=s_,g_=l_,y_="pako deflate (from Nodeca project)",ls={deflateInit:c_,deflateInit2:d_,deflateReset:u_,deflateResetKeep:f_,deflateSetHeader:h_,deflate:m_,deflateEnd:p_,deflateSetDictionary:g_,deflateInfo:y_},b_=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),x_=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)b_(r,n)&&(t[n]=r[n])}}return t},v_=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,o=t.length;n<o;n++){let a=t[n];r.set(a,i),i+=a.length}return r},vc={assign:x_,flattenChunks:v_},W0=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{W0=!1}var ps=new Uint8Array(256);for(let t=0;t<256;t++)ps[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;ps[254]=ps[254]=1;var __=t=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(t);let e,r,n,i,o,a=t.length,s=0;for(i=0;i<a;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<a&&(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),o=0,i=0;o<s;i++)r=t.charCodeAt(i),(r&64512)===55296&&i+1<a&&(n=t.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),r<128?e[o++]=r:r<2048?(e[o++]=192|r>>>6,e[o++]=128|r&63):r<65536?(e[o++]=224|r>>>12,e[o++]=128|r>>>6&63,e[o++]=128|r&63):(e[o++]=240|r>>>18,e[o++]=128|r>>>12&63,e[o++]=128|r>>>6&63,e[o++]=128|r&63);return e},S_=(t,e)=>{if(e<65534&&t.subarray&&W0)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},w_=(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,o=new Array(r*2);for(i=0,n=0;n<r;){let a=t[n++];if(a<128){o[i++]=a;continue}let s=ps[a];if(s>4){o[i++]=65533,n+=s-1;continue}for(a&=s===2?31:s===3?15:7;s>1&&n<r;)a=a<<6|t[n++]&63,s--;if(s>1){o[i++]=65533;continue}a<65536?o[i++]=a:(a-=65536,o[i++]=55296|a>>10&1023,o[i++]=56320|a&1023)}return S_(o,i)},M_=(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+ps[t[r]]>e?r:e},gs={string2buf:__,buf2string:w_,utf8border:M_};function A_(){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 X0=A_,$0=Object.prototype.toString,{Z_NO_FLUSH:E_,Z_SYNC_FLUSH:L_,Z_FULL_FLUSH:T_,Z_FINISH:R_,Z_OK:yc,Z_STREAM_END:C_,Z_DEFAULT_COMPRESSION:P_,Z_DEFAULT_STRATEGY:I_,Z_DEFLATED:B_}=Li;function vs(t){this.options=vc.assign({level:P_,method:B_,chunkSize:16384,windowBits:15,memLevel:8,strategy:I_},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 X0,this.strm.avail_out=0;let r=ls.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(r!==yc)throw new Error(Mi[r]);if(e.header&&ls.deflateSetHeader(this.strm,e.header),e.dictionary){let n;if(typeof e.dictionary=="string"?n=gs.string2buf(e.dictionary):$0.call(e.dictionary)==="[object ArrayBuffer]"?n=new Uint8Array(e.dictionary):n=e.dictionary,r=ls.deflateSetDictionary(this.strm,n),r!==yc)throw new Error(Mi[r]);this._dict_set=!0}}vs.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i,o;if(this.ended)return!1;for(e===~~e?o=e:o=e===!0?R_:E_,typeof t=="string"?r.input=gs.string2buf(t):$0.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),(o===L_||o===T_)&&r.avail_out<=6){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(i=ls.deflate(r,o),i===C_)return r.next_out>0&&this.onData(r.output.subarray(0,r.next_out)),i=ls.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===yc;if(r.avail_out===0){this.onData(r.output);continue}if(o>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};vs.prototype.onData=function(t){this.chunks.push(t)};vs.prototype.onEnd=function(t){t===yc&&(this.result=vc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Qu(t,e){let r=new vs(e);if(r.push(t,!0),r.err)throw r.msg||Mi[r.err];return r.result}function F_(t,e){return e=e||{},e.raw=!0,Qu(t,e)}function k_(t,e){return e=e||{},e.gzip=!0,Qu(t,e)}var D_=vs,z_=Qu,O_=F_,U_=k_,N_=Li,H_={Deflate:D_,deflate:z_,deflateRaw:O_,gzip:U_,constants:N_},uc=16209,V_=16191,G_=function(e,r){let n,i,o,a,s,c,l,d,f,u,h,m,g,p,y,v,x,b,_,w,S,E,T,A,C=e.state;n=e.next_in,T=e.input,i=n+(e.avail_in-5),o=e.next_out,A=e.output,a=o-(r-e.avail_out),s=o+(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+=T[n++]<<m,m+=8,h+=T[n++]<<m,m+=8),x=g[h&y];t:for(;;){if(b=x>>>24,h>>>=b,m-=b,b=x>>>16&255,b===0)A[o++]=x&65535;else if(b&16){_=x&65535,b&=15,b&&(m<b&&(h+=T[n++]<<m,m+=8),_+=h&(1<<b)-1,h>>>=b,m-=b),m<15&&(h+=T[n++]<<m,m+=8,h+=T[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+=T[n++]<<m,m+=8,m<b&&(h+=T[n++]<<m,m+=8)),w+=h&(1<<b)-1,w>c){e.msg="invalid distance too far back",C.mode=uc;break e}if(h>>>=b,m-=b,b=o-a,w>b){if(b=w-b,b>d&&C.sane){e.msg="invalid distance too far back",C.mode=uc;break e}if(S=0,E=u,f===0){if(S+=l-b,b<_){_-=b;do A[o++]=u[S++];while(--b);S=o-w,E=A}}else if(f<b){if(S+=l+f-b,b-=f,b<_){_-=b;do A[o++]=u[S++];while(--b);if(S=0,f<_){b=f,_-=b;do A[o++]=u[S++];while(--b);S=o-w,E=A}}}else if(S+=f-b,b<_){_-=b;do A[o++]=u[S++];while(--b);S=o-w,E=A}for(;_>2;)A[o++]=E[S++],A[o++]=E[S++],A[o++]=E[S++],_-=3;_&&(A[o++]=E[S++],_>1&&(A[o++]=E[S++]))}else{S=o-w;do A[o++]=A[S++],A[o++]=A[S++],A[o++]=A[S++],_-=3;while(_>2);_&&(A[o++]=A[S++],_>1&&(A[o++]=A[S++]))}}else if((b&64)===0){x=p[(x&65535)+(h&(1<<b)-1)];continue r}else{e.msg="invalid distance code",C.mode=uc;break e}break}}else if((b&64)===0){x=g[(x&65535)+(h&(1<<b)-1)];continue t}else if(b&32){C.mode=V_;break e}else{e.msg="invalid literal/length code",C.mode=uc;break e}break}}while(n<i&&o<s);_=m>>3,n-=_,m-=_<<3,h&=(1<<m)-1,e.next_in=n,e.next_out=o,e.avail_in=n<i?5+(i-n):5-(n-i),e.avail_out=o<s?257+(s-o):257-(o-s),C.hold=h,C.bits=m},Ao=15,Ym=852,qm=592,Zm=0,Cu=1,jm=2,W_=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]),X_=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]),$_=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]),K_=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]),Y_=(t,e,r,n,i,o,a,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,T,A=new Uint16Array(Ao+1),C=new Uint16Array(Ao+1),B=null,F,k,N;for(l=0;l<=Ao;l++)A[l]=0;for(d=0;d<n;d++)A[e[r+d]]++;for(h=c,u=Ao;u>=1&&A[u]===0;u--);if(h>u&&(h=u),u===0)return i[o++]=1<<24|64<<16|0,i[o++]=1<<24|64<<16|0,s.bits=1,0;for(f=1;f<u&&A[f]===0;f++);for(h<f&&(h=f),p=1,l=1;l<=Ao;l++)if(p<<=1,p-=A[l],p<0)return-1;if(p>0&&(t===Zm||u!==1))return-1;for(C[1]=0,l=1;l<Ao;l++)C[l+1]=C[l]+A[l];for(d=0;d<n;d++)e[r+d]!==0&&(a[C[e[r+d]]++]=d);if(t===Zm?(E=B=a,T=20):t===Cu?(E=W_,B=X_,T=257):(E=$_,B=K_,T=0),v=0,d=0,l=f,S=o,m=h,g=0,_=-1,y=1<<h,w=y-1,t===Cu&&y>Ym||t===jm&&y>qm)return 1;for(;;){F=l-g,a[d]+1<T?(k=0,N=a[d]):a[d]>=T?(k=B[a[d]-T],N=E[a[d]-T]):(k=96,N=0),x=1<<l-g,b=1<<m,f=b;do b-=x,i[S+(v>>g)+b]=F<<24|k<<16|N|0;while(b!==0);for(x=1<<l-1;v&x;)x>>=1;if(x!==0?(v&=x-1,v+=x):v=0,d++,--A[l]===0){if(l===u)break;l=e[r+a[d]]}if(l>h&&(v&w)!==_){for(g===0&&(g=h),S+=f,m=l-g,p=1<<m;m+g<u&&(p-=A[m+g],!(p<=0));)m++,p<<=1;if(y+=1<<m,t===Cu&&y>Ym||t===jm&&y>qm)return 1;_=v&w,i[_]=h<<24|m<<16|S-o|0}}return v!==0&&(i[S+v]=l-g<<24|64<<16|0),s.bits=h,0},cs=Y_,q_=0,K0=1,Y0=2,{Z_FINISH:Qm,Z_BLOCK:Z_,Z_TREES:fc,Z_OK:Ei,Z_STREAM_END:j_,Z_NEED_DICT:Q_,Z_STREAM_ERROR:ir,Z_DATA_ERROR:q0,Z_MEM_ERROR:Z0,Z_BUF_ERROR:J_,Z_DEFLATED:Jm}=Li,_c=16180,e0=16181,t0=16182,r0=16183,n0=16184,i0=16185,o0=16186,a0=16187,s0=16188,l0=16189,bc=16190,nn=16191,Pu=16192,c0=16193,Iu=16194,d0=16195,u0=16196,f0=16197,h0=16198,hc=16199,mc=16200,m0=16201,p0=16202,g0=16203,y0=16204,b0=16205,Bu=16206,x0=16207,v0=16208,be=16209,j0=16210,Q0=16211,eS=852,tS=592,rS=15,nS=rS,_0=t=>(t>>>24&255)+(t>>>8&65280)+((t&65280)<<8)+((t&255)<<24);function iS(){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 Ti=t=>{if(!t)return 1;let e=t.state;return!e||e.strm!==t||e.mode<_c||e.mode>Q0?1:0},J0=t=>{if(Ti(t))return ir;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=_c,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(eS),e.distcode=e.distdyn=new Int32Array(tS),e.sane=1,e.back=-1,Ei},ep=t=>{if(Ti(t))return ir;let e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,J0(t)},tp=(t,e)=>{let r;if(Ti(t))return ir;let n=t.state;return e<0?(r=0,e=-e):(r=(e>>4)+5,e<48&&(e&=15)),e&&(e<8||e>15)?ir:(n.window!==null&&n.wbits!==e&&(n.window=null),n.wrap=r,n.wbits=e,ep(t))},rp=(t,e)=>{if(!t)return ir;let r=new iS;t.state=r,r.strm=t,r.window=null,r.mode=_c;let n=tp(t,e);return n!==Ei&&(t.state=null),n},oS=t=>rp(t,nS),S0=!0,Fu,ku,aS=t=>{if(S0){Fu=new Int32Array(512),ku=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(cs(K0,t.lens,0,288,Fu,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;cs(Y0,t.lens,0,32,ku,0,t.work,{bits:5}),S0=!1}t.lencode=Fu,t.lenbits=9,t.distcode=ku,t.distbits=5},np=(t,e,r,n)=>{let i,o=t.state;return o.window===null&&(o.wsize=1<<o.wbits,o.wnext=0,o.whave=0,o.window=new Uint8Array(o.wsize)),n>=o.wsize?(o.window.set(e.subarray(r-o.wsize,r),0),o.wnext=0,o.whave=o.wsize):(i=o.wsize-o.wnext,i>n&&(i=n),o.window.set(e.subarray(r-n,r-n+i),o.wnext),n-=i,n?(o.window.set(e.subarray(r-n,r),0),o.wnext=n,o.whave=o.wsize):(o.wnext+=i,o.wnext===o.wsize&&(o.wnext=0),o.whave<o.wsize&&(o.whave+=i))),0},sS=(t,e)=>{let r,n,i,o,a,s,c,l,d,f,u,h,m,g,p=0,y,v,x,b,_,w,S,E,T=new Uint8Array(4),A,C,B=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Ti(t)||!t.output||!t.input&&t.avail_in!==0)return ir;r=t.state,r.mode===nn&&(r.mode=Pu),a=t.next_out,i=t.output,c=t.avail_out,o=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,f=s,u=c,E=Ei;e:for(;;)switch(r.mode){case _c:if(r.wrap===0){r.mode=Pu;break}for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}if(r.wrap&2&&l===35615){r.wbits===0&&(r.wbits=15),r.check=0,T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0),l=0,d=0,r.mode=e0;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)!==Jm){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?l0:nn,l=0,d=0;break;case e0:for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}if(r.flags=l,(r.flags&255)!==Jm){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&&(T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0)),l=0,d=0,r.mode=t0;case t0:for(;d<32;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.head&&(r.head.time=l),r.flags&512&&r.wrap&4&&(T[0]=l&255,T[1]=l>>>8&255,T[2]=l>>>16&255,T[3]=l>>>24&255,r.check=ke(r.check,T,4,0)),l=0,d=0,r.mode=r0;case r0:for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.head&&(r.head.xflags=l&255,r.head.os=l>>8),r.flags&512&&r.wrap&4&&(T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0)),l=0,d=0,r.mode=n0;case n0:if(r.flags&1024){for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.length=l,r.head&&(r.head.extra_len=l),r.flags&512&&r.wrap&4&&(T[0]=l&255,T[1]=l>>>8&255,r.check=ke(r.check,T,2,0)),l=0,d=0}else r.head&&(r.head.extra=null);r.mode=i0;case i0: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(o,o+h),S)),r.flags&512&&r.wrap&4&&(r.check=ke(r.check,n,h,o)),s-=h,o+=h,r.length-=h),r.length))break e;r.length=0,r.mode=o0;case o0:if(r.flags&2048){if(s===0)break e;h=0;do S=n[o+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=ke(r.check,n,h,o)),s-=h,o+=h,S)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=a0;case a0:if(r.flags&4096){if(s===0)break e;h=0;do S=n[o+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=ke(r.check,n,h,o)),s-=h,o+=h,S)break e}else r.head&&(r.head.comment=null);r.mode=s0;case s0:if(r.flags&512){for(;d<16;){if(s===0)break e;s--,l+=n[o++]<<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=nn;break;case l0:for(;d<32;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}t.adler=r.check=_0(l),l=0,d=0,r.mode=bc;case bc:if(r.havedict===0)return t.next_out=a,t.avail_out=c,t.next_in=o,t.avail_in=s,r.hold=l,r.bits=d,Q_;t.adler=r.check=1,r.mode=nn;case nn:if(e===Z_||e===fc)break e;case Pu:if(r.last){l>>>=d&7,d-=d&7,r.mode=Bu;break}for(;d<3;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}switch(r.last=l&1,l>>>=1,d-=1,l&3){case 0:r.mode=c0;break;case 1:if(aS(r),r.mode=hc,e===fc){l>>>=2,d-=2;break e}break;case 2:r.mode=u0;break;case 3:t.msg="invalid block type",r.mode=be}l>>>=2,d-=2;break;case c0:for(l>>>=d&7,d-=d&7;d<32;){if(s===0)break e;s--,l+=n[o++]<<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=Iu,e===fc)break e;case Iu:r.mode=d0;case d0:if(h=r.length,h){if(h>s&&(h=s),h>c&&(h=c),h===0)break e;i.set(n.subarray(o,o+h),a),s-=h,o+=h,c-=h,a+=h,r.length-=h;break}r.mode=nn;break;case u0:for(;d<14;){if(s===0)break e;s--,l+=n[o++]<<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=f0;case f0:for(;r.have<r.ncode;){for(;d<3;){if(s===0)break e;s--,l+=n[o++]<<d,d+=8}r.lens[B[r.have++]]=l&7,l>>>=3,d-=3}for(;r.have<19;)r.lens[B[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,A={bits:r.lenbits},E=cs(q_,r.lens,0,19,r.lencode,0,r.work,A),r.lenbits=A.bits,E){t.msg="invalid code lengths set",r.mode=be;break}r.have=0,r.mode=h0;case h0: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[o++]<<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[o++]<<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[o++]<<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[o++]<<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,A={bits:r.lenbits},E=cs(K0,r.lens,0,r.nlen,r.lencode,0,r.work,A),r.lenbits=A.bits,E){t.msg="invalid literal/lengths set",r.mode=be;break}if(r.distbits=6,r.distcode=r.distdyn,A={bits:r.distbits},E=cs(Y0,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,A),r.distbits=A.bits,E){t.msg="invalid distances set",r.mode=be;break}if(r.mode=hc,e===fc)break e;case hc:r.mode=mc;case mc:if(s>=6&&c>=258){t.next_out=a,t.avail_out=c,t.next_in=o,t.avail_in=s,r.hold=l,r.bits=d,G_(t,u),a=t.next_out,i=t.output,c=t.avail_out,o=t.next_in,n=t.input,s=t.avail_in,l=r.hold,d=r.bits,r.mode===nn&&(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[o++]<<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[o++]<<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=b0;break}if(v&32){r.back=-1,r.mode=nn;break}if(v&64){t.msg="invalid literal/length code",r.mode=be;break}r.extra=v&15,r.mode=m0;case m0:if(r.extra){for(C=r.extra;d<C;){if(s===0)break e;s--,l+=n[o++]<<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=p0;case p0: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[o++]<<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[o++]<<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=g0;case g0:if(r.extra){for(C=r.extra;d<C;){if(s===0)break e;s--,l+=n[o++]<<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=y0;case y0: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=a-r.offset,h=r.length;h>c&&(h=c),c-=h,r.length-=h;do i[a++]=g[m++];while(--h);r.length===0&&(r.mode=mc);break;case b0:if(c===0)break e;i[a++]=r.length,c--,r.mode=mc;break;case Bu:if(r.wrap){for(;d<32;){if(s===0)break e;s--,l|=n[o++]<<d,d+=8}if(u-=c,t.total_out+=u,r.total+=u,r.wrap&4&&u&&(t.adler=r.check=r.flags?ke(r.check,i,u,a-u):ms(r.check,i,u,a-u)),u=c,r.wrap&4&&(r.flags?l:_0(l))!==r.check){t.msg="incorrect data check",r.mode=be;break}l=0,d=0}r.mode=x0;case x0:if(r.wrap&&r.flags){for(;d<32;){if(s===0)break e;s--,l+=n[o++]<<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=v0;case v0:E=j_;break e;case be:E=q0;break e;case j0:return Z0;case Q0:default:return ir}return t.next_out=a,t.avail_out=c,t.next_in=o,t.avail_in=s,r.hold=l,r.bits=d,(r.wsize||u!==t.avail_out&&r.mode<be&&(r.mode<Bu||e!==Qm))&&np(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?ke(r.check,i,u,t.next_out-u):ms(r.check,i,u,t.next_out-u)),t.data_type=r.bits+(r.last?64:0)+(r.mode===nn?128:0)+(r.mode===hc||r.mode===Iu?256:0),(f===0&&u===0||e===Qm)&&E===Ei&&(E=J_),E},lS=t=>{if(Ti(t))return ir;let e=t.state;return e.window&&(e.window=null),t.state=null,Ei},cS=(t,e)=>{if(Ti(t))return ir;let r=t.state;return(r.wrap&2)===0?ir:(r.head=e,e.done=!1,Ei)},dS=(t,e)=>{let r=e.length,n,i,o;return Ti(t)||(n=t.state,n.wrap!==0&&n.mode!==bc)?ir:n.mode===bc&&(i=1,i=ms(i,e,r,0),i!==n.check)?q0:(o=np(t,e,r,r),o?(n.mode=j0,Z0):(n.havedict=1,Ei))},uS=ep,fS=tp,hS=J0,mS=oS,pS=rp,gS=sS,yS=lS,bS=cS,xS=dS,vS="pako inflate (from Nodeca project)",an={inflateReset:uS,inflateReset2:fS,inflateResetKeep:hS,inflateInit:mS,inflateInit2:pS,inflate:gS,inflateEnd:yS,inflateGetHeader:bS,inflateSetDictionary:xS,inflateInfo:vS};function _S(){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 SS=_S,ip=Object.prototype.toString,{Z_NO_FLUSH:wS,Z_FINISH:MS,Z_OK:ys,Z_STREAM_END:Du,Z_NEED_DICT:zu,Z_STREAM_ERROR:AS,Z_DATA_ERROR:w0,Z_MEM_ERROR:ES}=Li;function _s(t){this.options=vc.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 X0,this.strm.avail_out=0;let r=an.inflateInit2(this.strm,e.windowBits);if(r!==ys)throw new Error(Mi[r]);if(this.header=new SS,an.inflateGetHeader(this.strm,this.header),e.dictionary&&(typeof e.dictionary=="string"?e.dictionary=gs.string2buf(e.dictionary):ip.call(e.dictionary)==="[object ArrayBuffer]"&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(r=an.inflateSetDictionary(this.strm,e.dictionary),r!==ys)))throw new Error(Mi[r])}_s.prototype.push=function(t,e){let r=this.strm,n=this.options.chunkSize,i=this.options.dictionary,o,a,s;if(this.ended)return!1;for(e===~~e?a=e:a=e===!0?MS:wS,ip.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),o=an.inflate(r,a),o===zu&&i&&(o=an.inflateSetDictionary(r,i),o===ys?o=an.inflate(r,a):o===w0&&(o=zu));r.avail_in>0&&o===Du&&r.state.wrap>0&&t[r.next_in]!==0;)an.inflateReset(r),o=an.inflate(r,a);switch(o){case AS:case w0:case zu:case ES:return this.onEnd(o),this.ended=!0,!1}if(s=r.avail_out,r.next_out&&(r.avail_out===0||o===Du))if(this.options.to==="string"){let c=gs.utf8border(r.output,r.next_out),l=r.next_out-c,d=gs.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(!(o===ys&&s===0)){if(o===Du)return o=an.inflateEnd(this.strm),this.onEnd(o),this.ended=!0,!0;if(r.avail_in===0)break}}return!0};_s.prototype.onData=function(t){this.chunks.push(t)};_s.prototype.onEnd=function(t){t===ys&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=vc.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};function Ju(t,e){let r=new _s(e);if(r.push(t),r.err)throw r.msg||Mi[r.err];return r.result}function LS(t,e){return e=e||{},e.raw=!0,Ju(t,e)}var TS=_s,RS=Ju,CS=LS,PS=Ju,IS=Li,BS={Inflate:TS,inflate:RS,inflateRaw:CS,ungzip:PS,constants:IS},{Deflate:FS,deflate:kS,deflateRaw:DS,gzip:zS}=H_,{Inflate:OS,inflate:US,inflateRaw:NS,ungzip:HS}=BS,VS=FS,GS=kS,WS=DS,XS=zS,$S=OS,KS=US,YS=NS,qS=HS,ZS=Li,ef={Deflate:VS,deflate:GS,deflateRaw:WS,gzip:XS,Inflate:$S,inflate:KS,inflateRaw:YS,ungzip:qS,constants:ZS};var Io=class Io{constructor(e=Io.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(Io.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}};Io.INITIAL_SIZE=64*1024,Io.MAX_STRING_LENGTH=2048;var Gn=Io;var Dr=()=>({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}),mr=()=>({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 op={0:R.bad,1:R.nop,2:R.disconnect,3:R.reconnect,4:R.download,5:R.frame,6:R.inventory,7:R.layout,8:R.muzzleflash,9:R.temp_entity,10:R.sound,11:R.print,12:R.stufftext,13:R.serverdata,14:R.configstring,15:R.spawnbaseline,16:R.centerprint,17:R.playerinfo,18:R.packetentities,19:R.deltapacketentities,20:R.muzzleflash2},Sc=class{constructor(){this.protocolVersion=34}translateCommand(e){return op[e]!==void 0?op[e]:R.bad}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),o=e.readString(),a=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:o,playerNum:a,levelName:s}}parseEntityBits(e){let r=e.readByte();r&yr&&(r|=e.readByte()<<8),r&xr&&(r|=e.readByte()<<16),r&vr&&(r|=e.readByte()<<24);let n;return r&jn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,o,a){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&St&&(r.modelindex=a.readByte()),i&Mt&&(r.modelindex2=a.readByte()),i&At&&(r.modelindex3=a.readByte()),i&Et&&(r.modelindex4=a.readByte()),i&bt&&(r.frame=a.readByte()),i&wt&&(r.frame=a.readShort()),i&Ve&&i&Xe?r.skinnum=a.readLong():i&Ve?r.skinnum=a.readByte():i&Xe&&(r.skinnum=a.readShort()),i&He&&i&We?r.effects=a.readLong():i&He?r.effects=a.readByte():i&We&&(r.effects=a.readShort()),i&Ne&&i&Ge?r.renderfx=a.readLong():i&Ne?r.renderfx=a.readByte():i&Ge&&(r.renderfx=a.readShort()),i&mt&&(r.origin.x=a.readShort()*.125),i&pt&&(r.origin.y=a.readShort()*.125),i&vt&&(r.origin.z=a.readShort()*.125),i&_t&&(r.angles.x=a.readByte()*(360/256)),i>&&(r.angles.y=a.readByte()*(360/256)),i&yt&&(r.angles.z=a.readByte()*(360/256)),i&lr&&(r.old_origin.x=a.readShort()*.125,r.old_origin.y=a.readShort()*.125,r.old_origin.z=a.readShort()*.125),i&Lt&&(r.sound=a.readByte()),i&xt?r.event=a.readByte():r.event=0,i&Tt&&(r.solid=a.readShort())}parsePlayerState(e){let r=mr(),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 o=0;o<32;o++)i&1<<o&&(r.stats[o]=e.readShort());return r}};var zr=2023,wc=class{constructor(){this.protocolVersion=zr}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),o=e.readByte(),a=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:a,playerNum:s,levelName:c,tickRate:o,demoType:i}}parseEntityBits(e){let r=e.readByte();r&yr&&(r|=e.readByte()<<8),r&xr&&(r|=e.readByte()<<16),r&vr&&(r|=e.readByte()<<24);let n=0;r&Pi&&(n=e.readByte());let i;return r&jn?i=e.readShort():i=e.readByte(),{number:i,bits:r,bitsHigh:n}}parseDelta(e,r,n,i,o,a){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=o,i&St&&(r.modelindex=a.readByte()),i&Mt&&(r.modelindex2=a.readByte()),i&At&&(r.modelindex3=a.readByte()),i&Et&&(r.modelindex4=a.readByte()),i&bt&&(r.frame=a.readByte()),i&wt&&(r.frame=a.readShort()),i&Ve&&i&Xe?r.skinnum=a.readLong():i&Ve?r.skinnum=a.readByte():i&Xe&&(r.skinnum=a.readShort()),i&He&&i&We?r.effects=a.readLong():i&He?r.effects=a.readByte():i&We&&(r.effects=a.readShort()),i&Ne&&i&Ge?r.renderfx=a.readLong():i&Ne?r.renderfx=a.readByte():i&Ge&&(r.renderfx=a.readShort()),i&mt&&(r.origin.x=a.readShort()*.125),i&pt&&(r.origin.y=a.readShort()*.125),i&vt&&(r.origin.z=a.readShort()*.125),i&_t&&(r.angles.x=a.readByte()*(360/256)),i>&&(r.angles.y=a.readByte()*(360/256)),i&yt&&(r.angles.z=a.readByte()*(360/256)),i&lr&&(r.old_origin.x=a.readShort()*.125,r.old_origin.y=a.readShort()*.125,r.old_origin.z=a.readShort()*.125),i&Lt&&(r.sound=a.readByte()),i&xt?r.event=a.readByte():r.event=0,i&Tt&&(r.solid=a.readShort()),i&br&&(r.alpha=a.readByte()/255),i&_r&&(r.scale=a.readFloat()),i&Sr&&(r.instanceBits=a.readLong()),i&wr&&(r.loopVolume=a.readByte()/255),o&fn&&(r.loopAttenuation=a.readByte()/255),o&hn&&(r.owner=a.readShort()),o&mn&&(r.oldFrame=a.readShort())}parsePlayerState(e){let r=mr(),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 o=0;o<32;o++)i&1<<o&&(r.stats[o]=e.readShort());return r}};var Mc=class{constructor(e=0){this.protocolVersion=e}translateCommand(e){return e}parseServerData(e){let r=e.readLong(),n=e.readLong(),i=e.readByte(),o=e.readString(),a=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:o,playerNum:a,levelName:s}}parseEntityBits(e){let r=e.readByte();r&yr&&(r|=e.readByte()<<8),r&xr&&(r|=e.readByte()<<16),r&vr&&(r|=e.readByte()<<24);let n;return r&jn?n=e.readShort():n=e.readByte(),{number:n,bits:r,bitsHigh:0}}parseDelta(e,r,n,i,o,a){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&St&&(r.modelindex=a.readByte()),i&Mt&&(r.modelindex2=a.readByte()),i&At&&(r.modelindex3=a.readByte()),i&Et&&(r.modelindex4=a.readByte()),i&bt&&(r.frame=a.readByte()),i&wt&&(r.frame=a.readShort()),i&Ve&&i&Xe?r.skinnum=a.readLong():i&Ve?r.skinnum=a.readByte():i&Xe&&(r.skinnum=a.readShort()),i&He&&i&We?r.effects=a.readLong():i&He?r.effects=a.readByte():i&We&&(r.effects=a.readShort()),i&Ne&&i&Ge?r.renderfx=a.readLong():i&Ne?r.renderfx=a.readByte():i&Ge&&(r.renderfx=a.readShort()),i&mt&&(r.origin.x=a.readShort()*.125),i&pt&&(r.origin.y=a.readShort()*.125),i&vt&&(r.origin.z=a.readShort()*.125),i&_t&&(r.angles.x=a.readByte()*(360/256)),i>&&(r.angles.y=a.readByte()*(360/256)),i&yt&&(r.angles.z=a.readByte()*(360/256)),i&lr&&(r.old_origin.x=a.readShort()*.125,r.old_origin.y=a.readShort()*.125,r.old_origin.z=a.readShort()*.125),i&Lt&&(r.sound=a.readByte()),i&xt?r.event=a.readByte():r.event=0,i&Tt&&(r.solid=a.readShort())}parsePlayerState(e){let r=mr(),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 o=0;o<32;o++)i&1<<o&&(r.stats[o]=e.readShort());return r}};var Ss=class{constructor(){this.protocolVersion=0}translateCommand(e){return e===7?R.serverdata:e===12?R.serverdata:e===13?R.serverdata:e===R.stufftext?R.stufftext:R.bad}parseServerData(e){let r=e.readLong();if(r===zr){let n=e.readLong(),i=e.readByte(),o=e.readByte(),a=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:a,playerNum:s,levelName:c,tickRate:o,demoType:i}}else{let n=e.readLong(),i=e.readByte(),o=e.readString(),a=e.readShort(),s=e.readString();return{protocol:r,serverCount:n,attractLoop:i,gameDir:o,playerNum:a,levelName:s}}}parseEntityBits(e){throw new Error("Bootstrap handler cannot parse entities")}parseDelta(e,r,n,i,o,a){throw new Error("Bootstrap handler cannot parse delta")}parsePlayerState(e){throw new Error("Bootstrap handler cannot parse player state")}};function ap(t){return t===0?new Ss:t===zr?new wc:t===34?new Sc:new Mc(t)}var sp=1,jS=2,QS=128,tf=class extends Gn{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")}},dt=class t{constructor(e,r,n=!1){this.strictMode=!1;this.errorCount=0;this.isDemo=sp;e instanceof pn?this.stream=new tf(e):this.stream=e,this.handler=r,this.strictMode=n,this.protocolHandler=new Ss}setProtocolVersion(e){this.protocolHandler.protocolVersion!==e&&(this.protocolHandler=ap(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 R.bad:if(n===0)return;let o=`Unknown server command: ${n} (translated: ${i}) at offset ${e} (Protocol: ${this.getProtocolVersion()})`;if(this.strictMode)throw new Error(o);console.warn(o),this.errorCount++;return;case R.nop:break;case R.disconnect:this.handler?.onDisconnect&&this.handler.onDisconnect();break;case R.reconnect:this.handler?.onReconnect&&this.handler.onReconnect();break;case R.print:this.parsePrint();break;case R.serverdata:this.parseServerData();break;case R.configstring:this.parseConfigString();break;case R.spawnbaseline:this.parseSpawnBaseline();break;case R.centerprint:this.parseCenterPrint();break;case R.download:this.parseDownload();break;case R.frame:this.parseFrame();break;case R.packetentities:this.parsePacketEntities(!1);break;case R.deltapacketentities:this.parsePacketEntities(!0);break;case R.playerinfo:this.parsePlayerState();break;case R.stufftext:this.parseStuffText();break;case R.layout:this.parseLayout();break;case R.inventory:this.parseInventory();break;case R.sound:this.parseSound();break;case R.muzzleflash:this.parseMuzzleFlash();break;case R.muzzleflash2:this.parseMuzzleFlash2();break;case R.temp_entity:this.parseTempEntity();break;case R.splitclient:this.parseSplitClient();break;case R.configblast:this.parseConfigBlast();break;case R.spawnbaselineblast:this.parseSpawnBaselineBlast();break;case R.level_restart:this.handler?.onLevelRestart&&this.handler.onLevelRestart();break;case R.damage:this.parseDamage();break;case R.locprint:this.parseLocPrint();break;case R.fog:this.parseFog();break;case R.waitingforplayers:this.parseWaitingForPlayers();break;case R.bot_chat:this.parseBotChat();break;case R.poi:this.parsePoi();break;case R.help_path:this.parseHelpPath();break;case R.muzzleflash3:this.parseMuzzleFlash3();break;case R.achievement:this.parseAchievement();break;default:let a=`Unknown server command: ${n} (translated: ${i}) at offset ${e}`;if(this.strictMode)throw new Error(a);console.warn(a),this.errorCount++;return}}catch(n){let i=n.message;if(i==="Buffer underflow"||i.includes("StreamingBuffer")){try{this.stream.setReadPosition(e)}catch(a){console.error("Failed to rollback stream position",a)}return}let o=`offset ${e}, cmd ${r}, protocol ${this.getProtocolVersion()}`;if(console.warn(`Error parsing command ${r} (${o}): ${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>=sr.length)e.x=0,e.y=0,e.z=0;else{let n=sr[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===zr?this.isDemo=e.demoType??sp: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=ef.inflate(n),o=new pn(i.buffer);for(;o.hasMore();){let a=o.readUShort(),s=o.readString();this.handler&&this.handler.onConfigString(a,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=ef.inflate(n),o=new pn(i.buffer),a=new t(o,this.handler,this.strictMode);for(a.setProtocolVersion(this.getProtocolVersion());o.hasMore();)a.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 o=0;o<n;o++)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(),o=this.stream.readByte(),a=this.stream.readByte();this.handler?.onPoi&&this.handler.onPoi(a,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,o,a,s;if(e&1&&(n=this.stream.readByte()),e&2&&(i=this.stream.readByte()),e&16&&(o=this.stream.readByte()),e&8&&(a=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,o,a,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(),o={x:0,y:0,z:0};this.readDir(o);let a=i&31,s=(i&32)!==0,c=(i&64)!==0,l=(i&128)!==0;r.push({damage:a,health:s,armor:c,power:l,dir:o})}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},o,a,s,c,l;switch(e){case z.EXPLOSION1:case z.EXPLOSION2:case z.ROCKET_EXPLOSION:case z.GRENADE_EXPLOSION:case z.ROCKET_EXPLOSION_WATER:case z.GRENADE_EXPLOSION_WATER:case z.BFG_EXPLOSION:case z.BFG_BIGEXPLOSION:case z.BOSSTPORT:case z.PLASMA_EXPLOSION:case z.PLAIN_EXPLOSION:case z.CHAINFIST_SMOKE:case z.TRACKER_EXPLOSION:case z.TELEPORT_EFFECT:case z.DBALL_GOAL:case z.NUKEBLAST:case z.WIDOWSPLASH:case z.EXPLOSION1_BIG:case z.EXPLOSION1_NP:this.readPos(r);break;case z.GUNSHOT:case z.BLOOD:case z.BLASTER:case z.SHOTGUN:case z.SPARKS:case z.BULLET_SPARKS:case z.SCREEN_SPARKS:case z.SHIELD_SPARKS:case z.BLASTER2:case z.FLECHETTE:case z.MOREBLOOD:case z.ELECTRIC_SPARKS:case z.HEATBEAM_SPARKS:case z.HEATBEAM_STEAM:this.readPos(r),this.readDir(i);break;case z.SPLASH:case z.LASER_SPARKS:case z.WELDING_SPARKS:case z.TUNNEL_SPARKS:o=this.stream.readByte(),this.readPos(r),this.readDir(i),a=this.stream.readByte();break;case z.BLUEHYPERBLASTER:this.getProtocolVersion()>=32?(this.readPos(r),this.readPos(n)):(this.readPos(r),this.readDir(i));break;case z.GREENBLOOD:this.getProtocolVersion()>=32?(this.readPos(r),this.readDir(i)):(this.readPos(r),this.readPos(n));break;case z.RAILTRAIL:case z.BUBBLETRAIL:case z.BFG_LASER:case z.DEBUGTRAIL:case z.BUBBLETRAIL2:this.readPos(r),this.readPos(n);break;case z.PARASITE_ATTACK:case z.MEDIC_CABLE_ATTACK:this.stream.readShort(),this.readPos(r),this.readPos(n);break;case z.GRAPPLE_CABLE:s=this.stream.readShort(),this.readPos(r),this.readPos(n),this.readPos(i);break;case z.LIGHTNING:c=this.stream.readShort(),l=this.stream.readShort(),this.readPos(r),this.readPos(n);break;case z.FLASHLIGHT:this.readPos(r),s=this.stream.readShort();break;case z.FORCEWALL:this.readPos(r),this.readPos(n),a=this.stream.readByte();break;case z.STEAM:let d=this.stream.readShort();o=this.stream.readByte(),this.readPos(r),this.readDir(i),a=this.stream.readByte(),this.stream.readShort(),d!==-1&&this.stream.readLong();break;case z.WIDOWBEAMOUT:this.stream.readShort();case z.HEATBEAM:case z.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,o,a,s,c,l)}parseSpawnBaseline(){let e=this.protocolHandler.parseEntityBits(this.stream),r=Dr();this.protocolHandler.parseDelta(Dr(),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(),o=this.stream.readData(i),a=this.stream.readByte();if(a=this.protocolHandler.translateCommand(a),a!==R.playerinfo){if(this.strictMode)throw new Error(`Expected svc_playerinfo after svc_frame, got ${a}`);return}let s=this.parsePlayerState(),c=this.stream.readByte();if(c=this.protocolHandler.translateCommand(c),c!==R.packetentities&&c!==R.deltapacketentities){if(this.strictMode)throw new Error(`Expected svc_packetentities after svc_playerinfo, got ${c}`);return}let l=this.collectPacketEntities();if(this.isDemo===QS){let d=this.stream.readByte();for(let f=0;f<d;f++)this.stream.readByte()}this.isDemo===jS&&this.stream.readLong(),this.handler&&this.handler.onFrame({serverFrame:e,deltaFrame:r,surpressCount:n,areaBytes:i,areaBits:o,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:mr(),packetEntities:{delta:e,entities:r}})}collectPacketEntities(){let e=[];for(;;){let r=this.protocolHandler.parseEntityBits(this.stream);if(r.bits&Xo){if(r.number===0)break;continue}let n=Dr();if(r.number===0)break;this.protocolHandler.parseDelta(Dr(),n,r.number,r.bits,r.bitsHigh,this.stream),e.push(n)}return e}};var rf=(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))(rf||{});var Bo=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 hr(this.buffer),r=-1,n=0,i=.1,o=0,a={onServerData:(s,c,l,d,f,u,h,m)=>{o=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 dt(s.data,a);c.setProtocolVersion(o),c.parseMessage(),o=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 o=this.summary.weaponUsage.get(r)||0;this.summary.weaponUsage.set(r,o+1);let a=this.getOrCreateWeaponStat(e,r);a.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(o=>o.weaponId===r);return i||(i={weaponId:r,shotsFired:0,hits:0,kills:0},n.push(i)),i}};var nf=(i=>(i[i.FirstPerson=0]="FirstPerson",i[i.ThirdPerson=1]="ThirdPerson",i[i.Free=2]="Free",i[i.Follow=3]="Follow",i))(nf||{});var Ac=(i=>(i[i.Stopped=0]="Stopped",i[i.Playing=1]="Playing",i[i.Paused=2]="Paused",i[i.Finished=3]="Finished",i))(Ac||{}),JS=()=>({onServerData:()=>{},onConfigString:()=>{},onSpawnBaseline:()=>{},onFrame:()=>{},onCenterPrint:()=>{},onStuffText:()=>{},onPrint:()=>{},onSound:()=>{},onTempEntity:()=>{},onLayout:()=>{},onInventory:()=>{},onMuzzleFlash:()=>{},onMuzzleFlash2:()=>{},onDisconnect:()=>{},onReconnect:()=>{},onDownload:()=>{}}),ws=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 hr(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),o=this.getTotalFrames(),a=Math.max(0,o-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[o,a]of this.snapshots)o<=e&&o>n&&(n=o,i=a);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||JS(),onFrame:i=>{this.lastFrameData=i,this.handler?.onFrame&&this.handler.onFrame(i),this.callbacks?.onFrameUpdate&&this.callbacks.onFrameUpdate(i)}},n=new dt(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),o=new Map;i.forEach(d=>o.set(d.number,d));let a=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&&a&&((n.origin.x!==a.origin.x||n.origin.y!==a.origin.y||n.origin.z!==a.origin.z)&&(l.playerStateDiff.origin={x:a.origin.x-n.origin.x,y:a.origin.y-n.origin.y,z:a.origin.z-n.origin.z}),n.stats[1]!==a.stats[1]&&(l.playerStateDiff.health=a.stats[1]-n.stats[1]),n.stats[2]!==a.stats[2]&&(l.playerStateDiff.ammo=a.stats[2]-n.stats[2]));for(let[d,f]of c){let u=o.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 o)c.has(d)||l.entityDiffs.removed.push(d);return l}getEntityTrajectory(e,r,n){let i=[],o=this.getCurrentFrame();for(this.seek(r);this.getCurrentFrame()<=n&&this.state!==3;){let a=null;if(e===-1){let s=this.getFramePlayerState(this.getCurrentFrame());s&&(a={...s.origin})}else if(this.handler?.getEntities){let s=this.handler.getEntities().get(e);s&&(a={...s.origin})}if(a&&i.push(a),this.getCurrentFrame()===n)break;this.stepForward()}return this.seek(o),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 Bo(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 o=0;for(;o<n;){if(!this.processNextFrame()){this.transitionState(0);let a=e.stopTracking();return this.tracker=null,this.callbacks?.onPlaybackComplete&&this.callbacks.onPlaybackComplete(),a}o++}return await new Promise(a=>setTimeout(a,0)),i()};return await i()}catch(n){throw this.transitionState(0),e.stopTracking(),this.tracker=null,n}else return new Promise((n,i)=>{let o=this.callbacks?.onPlaybackComplete,a=this.callbacks?.onPlaybackError,s=()=>{this.setCallbacks({...this.callbacks,onPlaybackComplete:o,onPlaybackError:a}),this.tracker=null};this.setCallbacks({...this.callbacks,onPlaybackComplete:()=>{let c=e.stopTracking();o&&o(),s(),n(c)},onPlaybackError:c=>{e.stopTracking(),a&&a(c),s(),i(c)}}),this.play()})}async playRangeWithTracking(e,r,n,i={}){this.tracker=n,n.startTracking();let o=e.type==="frame"?e.frame:this.timeToFrame(e.seconds),a=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>=a||!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 Ms=class{constructor(){this.isRecording=!1;this.startTime=0;this.frameCount=0;this.filename=null;this.lastMessageSize=-1;this.messageBuffer=new Qn(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 Ec=class{constructor(e,r=34){this.writer=e||new Qn(new Uint8Array(64*1024)),this.protocol=r}getData(){return this.writer.getData()}getOpcode(e){if(this.protocol===34)switch(e){case R.serverdata:return 13;case R.frame:return 5;case R.playerinfo:return 17;case R.packetentities:return 18;case R.deltapacketentities:return 19;case R.print:return 11;case R.centerprint:return 16;case R.stufftext:return 12;case R.sound:return 10;case R.temp_entity:return 9;case R.configstring:return 14;case R.spawnbaseline:return 15;case R.layout:return 7;case R.inventory:return 6;case R.muzzleflash:return 8;case R.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,o,a){this.writeCommand(R.serverdata),this.writer.writeLong(e),this.writer.writeLong(r),this.writer.writeByte(n),this.writer.writeString(i),this.writer.writeShort(o),this.writer.writeString(a)}writeConfigString(e,r){this.writeCommand(R.configstring),this.writer.writeShort(e),this.writer.writeString(r)}writeStuffText(e){this.writeCommand(R.stufftext),this.writer.writeString(e)}writeCenterPrint(e){this.writeCommand(R.centerprint),this.writer.writeString(e)}writePrint(e,r){this.writeCommand(R.print),this.writer.writeByte(e),this.writer.writeString(r)}writeLayout(e){this.writeCommand(R.layout),this.writer.writeString(e)}writeInventory(e){this.writeCommand(R.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(R.muzzleflash),this.writer.writeShort(e),this.writer.writeByte(r)}writeMuzzleFlash2(e,r){this.writeCommand(R.muzzleflash2),this.writer.writeShort(e),this.writer.writeByte(r)}writeSound(e,r,n,i,o,a,s,c){this.writeCommand(R.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(o),e&8&&this.writer.writeShort(a),e&4&&(this.writer.writeCoord(s.x),this.writer.writeCoord(s.y),this.writer.writeCoord(s.z))}writeTempEntity(e,r,n,i,o,a,s,c,l){this.writeCommand(R.temp_entity),this.writer.writeByte(e),r&&this.writer.writePos(r)}writePlayerState(e){this.writeCommand(R.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?R.deltapacketentities:R.packetentities);for(let i of e)this.writeDeltaEntity(Dr(),i,!0);this.writer.writeShort(0)}writeFrame(e,r){this.writeCommand(R.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,o=0;(r.modelindex!==e.modelindex||n)&&(i|=St),(r.modelindex2!==e.modelindex2||n)&&(i|=Mt),(r.modelindex3!==e.modelindex3||n)&&(i|=At),(r.modelindex4!==e.modelindex4||n)&&(i|=Et),(r.frame!==e.frame||n)&&(r.frame>=256?i|=wt:i|=bt),(r.skinnum!==e.skinnum||n)&&(r.skinnum>=256?i|=Xe:i|=Ve),(r.effects!==e.effects||n)&&(r.effects>=256?i|=We:i|=He),(r.renderfx!==e.renderfx||n)&&(r.renderfx>=256?i|=Ge:i|=Ne),(r.origin.x!==e.origin.x||n)&&r.origin.x!==0&&(i|=mt),(r.origin.y!==e.origin.y||n)&&r.origin.y!==0&&(i|=pt),(r.origin.z!==e.origin.z||n)&&r.origin.z!==0&&(i|=vt),(r.angles.x!==e.angles.x||n)&&r.angles.x!==0&&(i|=_t),(r.angles.y!==e.angles.y||n)&&r.angles.y!==0&&(i|=gt),(r.angles.z!==e.angles.z||n)&&r.angles.z!==0&&(i|=yt),(r.sound!==e.sound||n)&&(i|=Lt),(r.event!==e.event||n)&&(i|=xt),(r.solid!==e.solid||n)&&(i|=Tt),this.protocol!==34&&((r.alpha!==e.alpha||n)&&(i|=br),(r.scale!==e.scale||n)&&(i|=_r),(r.instanceBits!==e.instanceBits||n)&&(i|=Sr),(r.loopVolume!==e.loopVolume||n)&&(i|=wr),(r.loopAttenuation!==e.loopAttenuation||n)&&(o|=fn),(r.owner!==e.owner||n)&&(o|=hn),(r.oldFrame!==e.oldFrame||n)&&(o|=mn)),o>0&&(i|=Pi),i&4278190080&&(i|=vr),i&4294901760&&(i|=xr),i&4294967040&&(i|=yr),this.writer.writeByte(i&255),i&yr&&this.writer.writeByte(i>>8&255),i&xr&&this.writer.writeByte(i>>16&255),i&vr&&this.writer.writeByte(i>>24&255),i&Pi&&this.writer.writeByte(o&255),r.number>=256?this.writer.writeShort(r.number):this.writer.writeByte(r.number),i&St&&this.writer.writeByte(r.modelindex),i&Mt&&this.writer.writeByte(r.modelindex2),i&At&&this.writer.writeByte(r.modelindex3),i&Et&&this.writer.writeByte(r.modelindex4),i&bt&&this.writer.writeByte(r.frame),i&wt&&this.writer.writeShort(r.frame),i&Ve&&this.writer.writeByte(r.skinnum),i&Xe&&this.writer.writeShort(r.skinnum),i&He&&this.writer.writeByte(r.effects),i&We&&this.writer.writeShort(r.effects),i&Ne&&this.writer.writeByte(r.renderfx),i&Ge&&this.writer.writeShort(r.renderfx),i&mt&&this.writer.writeCoord(r.origin.x),i&pt&&this.writer.writeCoord(r.origin.y),i&vt&&this.writer.writeCoord(r.origin.z),i&_t&&this.writer.writeAngle(r.angles.x),i>&&this.writer.writeAngle(r.angles.y),i&yt&&this.writer.writeAngle(r.angles.z),i&Lt&&this.writer.writeByte(r.sound??0),i&xt&&this.writer.writeByte(r.event??0),i&Tt&&this.writer.writeShort(r.solid),this.protocol!==34&&(i&br&&this.writer.writeByte(r.alpha*255),i&_r&&this.writer.writeFloat(r.scale),i&Sr&&this.writer.writeLong(r.instanceBits),i&wr&&this.writer.writeByte(r.loopVolume*255),o&fn&&this.writer.writeByte(r.loopAttenuation*255),o&hn&&this.writer.writeShort(r.owner),o&mn&&this.writer.writeShort(r.oldFrame))}};var Lc=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 o=n.getUint8(4);if(o!==R.serverdata)return{valid:!1,error:`First command is not svc_serverdata (expected ${R.serverdata}, got ${o})`};let a=-1;return i>=5&&(a=n.getInt32(5,!0)),{valid:!0,version:a}}};var Tc=class{constructor(e){this.frames=[];this.configStrings=new Map;this.baselines=new Map;this.currentEntities=new Map;if(e){let r=new Gn(e.byteLength);r.append(new Uint8Array(e)),r.setReadPosition(0),this.parser=new dt(r,this)}else this.parser=new dt(new Gn,this)}extractClip(e,r,n,i){let o=new hr(e.buffer),a=[],s=0,c=r.frame??-1,l=n.frame??Number.MAX_SAFE_INTEGER,d=0,f=0;for(;o.nextBlock();){let p=o.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 Gn(p.getLength());_.append(p.readData(p.getLength())),_.setReadPosition(0),p.seek(0);let w=new dt(_,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),a.push(S);let T=p.readData(p.getLength());a.push(T),s+=4+T.length}f++}let u=new Uint8Array(4);new DataView(u.buffer).setInt32(0,-1,!0),a.push(u),s+=4;let h=new Uint8Array(s),m=0;for(let g of a)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,o,a){this.serverData={protocol:e,serverCount:r,attractLoop:n,gameDir:i,playerNum:o,levelName:a}}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,o,a,s){}onTempEntity(e,r,n,i,o,a,s,c,l){}onLayout(e){}onInventory(e){}onMuzzleFlash(e,r){}onMuzzleFlash2(e,r){}onDisconnect(){}onReconnect(){}onDownload(e,r,n){}};function lp(t,e){let r=e.bits;t.bits=r,t.number=e.number,r&St&&(t.modelindex=e.modelindex),r&Mt&&(t.modelindex2=e.modelindex2),r&At&&(t.modelindex3=e.modelindex3),r&Et&&(t.modelindex4=e.modelindex4),r&bt&&(t.frame=e.frame),r&wt&&(t.frame=e.frame),r&Ve&&(t.skinnum=e.skinnum),r&Xe&&(t.skinnum=e.skinnum),r&He&&(t.effects=e.effects),r&We&&(t.effects=e.effects),r&Ne&&(t.renderfx=e.renderfx),r&Ge&&(t.renderfx=e.renderfx),r&mt&&(t.origin.x=e.origin.x),r&pt&&(t.origin.y=e.origin.y),r&vt&&(t.origin.z=e.origin.z),r&_t&&(t.angles.x=e.angles.x),r>&&(t.angles.y=e.angles.y),r&yt&&(t.angles.z=e.angles.z),r&lr&&(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&Lt&&(t.sound=e.sound),r&xt&&(t.event=e.event),r&Tt&&(t.solid=e.solid),r&br&&(t.alpha=e.alpha),r&_r&&(t.scale=e.scale),r&Sr&&(t.instanceBits=e.instanceBits),r&wr&&(t.loopVolume=e.loopVolume)}var of=(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))(of||{}),cp={".bsp":"bsp",".md2":"md2",".md3":"md3",".wal":"wal",".pcx":"pcx",".tga":"tga",".wav":"wav",".ogg":"ogg",".txt":"txt",".cfg":"cfg",".dm2":"dem"};function As(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 ew=[73,66,83,80],tw=[73,68,80,50],rw=[73,68,80,51];var nw=[82,73,70,70];var iw=[79,103,103,83];function af(t,e){let r=t.slice(t.lastIndexOf(".")).toLowerCase();if(e){if(As(e,ew))return"bsp";if(As(e,tw))return"md2";if(As(e,rw))return"md3";if(As(e,iw))return"ogg";if(e.length>128&&e[0]===10&&e[1]<6)return"pcx";if(As(e,nw)&&e.length>=12&&e[8]===87&&e[9]===65&&e[10]===86&&e[11]===69)return"wav"}return cp[r]?cp[r]:"unknown"}function sf(t){let e=af(t);return e==="txt"||e==="cfg"}function dp(t){return!sf(t)}function ow(t,e,r,n,i){let o=new Uint8ClampedArray(n*i*4),a=e/n,s=r/i;for(let c=0;c<i;c++)for(let l=0;l<n;l++){let d=l*a,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],T=t[x+S],A=t[b+S],C=t[_+S],B=E*(1-m)+T*m,F=A*(1-m)+C*m,k=B*(1-g)+F*g;o[w+S]=k}}return o}function aw(t,e,r,n,i,o,a,s,c,l,d){n=Math.floor(n),i=Math.floor(i),o=Math.floor(o),a=Math.floor(a);let f=Math.abs(o-n),u=Math.abs(a-i),h=n<o?1:-1,m=i<a?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===o&&i===a)break;let p=2*g;p>-u&&(g-=u,n+=h),p<f&&(g+=f,i+=m)}}function up(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 Rc=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],o=i.width/i.height,a=r,s=r;o>1?s=Math.floor(r/o):a=Math.floor(r*o),a=Math.max(1,a),s=Math.max(1,s);let c=ow(i.rgba,i.width,i.height,a,s);return new ImageData(c,a,s)}catch(n){return console.error(`Failed to generate thumbnail for ${e}`,n),null}}async generateModelThumbnail(e,r){try{let n=[],i=[],o=e.split(".").pop()?.toLowerCase();if(o==="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(o==="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 a={x:1/0,y:1/0,z:1/0},s={x:-1/0,y:-1/0,z:-1/0};for(let p of n)a.x=Math.min(a.x,p.x),a.y=Math.min(a.y,p.y),a.z=Math.min(a.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:(a.x+s.x)/2,y:(a.y+s.y)/2,z:(a.z+s.z)/2},l=s.x-a.x,d=s.y-a.y,f=s.z-a.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],_=up(x,r,r,c,m),w=up(b,r,r,c,m);aw(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=jo(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 Cc=class{constructor(e){this.loader=e}async getMapStatistics(e){let r=await this.loader.load(e),n=r.faces.filter(a=>a.lightOffset!==-1).length,i=r.models[0],o=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:o}}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[o,a]of Object.entries(i.properties))(o==="noise"||o.endsWith("_sound")||o==="sound")&&typeof a=="string"&&n.add(a)}return Array.from(n).sort()}};function fp(t){let e=[],r=0,n=t.length;function i(){for(;r<n&&/\s/.test(t[r]);)r++}function o(){if(i(),r>=n)return null;if(t[r]==='"'){r++;let a=r;for(;r<n&&t[r]!=='"';)t[r],r++;let s=t.substring(a,r);return r++,s}else{if(t[r]==="{"||t[r]==="}")return t[r++];{if(t.startsWith("//",r)){for(;r<n&&t[r]!==`
|
|
796
796
|
`;)r++;return o()}let a=r;for(;r<n&&!/\s/.test(t[r])&&t[r]!=="}"&&t[r]!=="{";)r++;return t.substring(a,r)}}}for(;r<n;){let a=o();if(a===null)break;if(a==="{"){let s={};for(;;){let c=r,l=o();if(l==="}"||l===null)break;if(l==="{"){r=c;break}let d=o();if(d===null||d==="}"||d==="{"){d==="}"&&r--,d==="{"&&r--;break}s[l]=d}e.push({classname:s.classname,properties:s})}}return e}function hp(t){let e="";for(let r of t){e+=`{
|
|
797
797
|
`;let i=Object.keys(r.properties).sort((o,a)=>o==="classname"?-1:a==="classname"?1:o==="origin"?-1:a==="origin"?1:o.localeCompare(a));for(let o of i){let a=r.properties[o];e+=`"${o}" "${a}"
|
|
798
798
|
`}e+=`}
|
|
799
|
-
`}return e}function mp(t){let e=[],r=[];if(t.properties.classname||e.push('Missing "classname" property'),t.properties.origin){let n=t.properties.origin.split(" ");(n.length!==3||n.some(i=>isNaN(parseFloat(i))))&&e.push(`Invalid origin format: "${t.properties.origin}"`)}return t.properties.angle&&isNaN(parseFloat(t.properties.angle))&&e.push(`Invalid angle format: "${t.properties.angle}"`),{valid:e.length===0,errors:e,warnings:r}}async function pp(t,e){if(!navigator.gpu)throw new Error("WebGPU is not supported in this environment");let r=await navigator.gpu.requestAdapter({powerPreference:e?.powerPreference||"high-performance"});if(!r)throw new Error("No appropriate GPUAdapter found");if(e?.requiredFeatures){for(let u of e.requiredFeatures)if(!r.features.has(u))throw new Error(`Required feature not available: ${u}`)}let n={requiredFeatures:e?.requiredFeatures,requiredLimits:e?.requiredLimits},i=await r.requestDevice(n),o,a="rgba8unorm",s="depth24plus",c=!0,l=e?.width||800,d=e?.height||600;if(t){if(o=t.getContext("webgpu"),!o)throw new Error("Failed to get WebGPU context from canvas");c=!1,a=navigator.gpu.getPreferredCanvasFormat(),l=t.width,d=t.height,o.configure({device:i,format:a,alphaMode:"opaque"})}let f=new Set;for(let u of r.features)f.add(u);return{adapter:r,device:i,context:o,format:a,depthFormat:s,features:f,limits:i.limits,isHeadless:c,width:l,height:d}}function gp(t){let{features:e,limits:r}=t;return{hasTimestampQuery:e.has("timestamp-query"),hasDepthClipControl:e.has("depth-clip-control"),hasTextureCompressionBC:e.has("texture-compression-bc"),hasTextureCompressionETC2:e.has("texture-compression-etc2"),hasTextureCompressionASTC:e.has("texture-compression-astc"),maxTextureDimension2D:r.maxTextureDimension2D,maxBindGroups:r.maxBindGroups,maxUniformBufferBindingSize:r.maxUniformBufferBindingSize,maxStorageBufferBindingSize:r.maxStorageBufferBindingSize}}function yp(t,e,r,n="rgba8unorm"){let i=typeof GPUTextureUsage<"u"?GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.COPY_SRC:17,o=t.createTexture({size:{width:e,height:r,depthOrArrayLayers:1},format:n,usage:i}),a=o.createView();return{texture:o,view:a,width:e,height:r}}async function bp(t,e){let r=e.width,n=e.height,i=4,o=r*i,a=256,s=Math.max(i*r,Math.ceil(r*i/a)*a),c=s*n,l=typeof GPUBufferUsage<"u"?GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ:9,d=t.createBuffer({size:c,usage:l}),f=t.createCommandEncoder();f.copyTextureToBuffer({texture:e},{buffer:d,bytesPerRow:s},{width:r,height:n,depthOrArrayLayers:1}),t.queue.submit([f.finish()]);let u=typeof GPUMapMode<"u"?GPUMapMode.READ:1;await d.mapAsync(u);let h=d.getMappedRange(),m=new Uint8Array(h),g=new Uint8ClampedArray(r*n*4);if(s===o)g.set(m);else for(let p=0;p<n;p++){let y=p*s,v=p*o;g.set(m.subarray(y,y+o),v)}return d.unmap(),g}var
|
|
799
|
+
`}return e}function mp(t){let e=[],r=[];if(t.properties.classname||e.push('Missing "classname" property'),t.properties.origin){let n=t.properties.origin.split(" ");(n.length!==3||n.some(i=>isNaN(parseFloat(i))))&&e.push(`Invalid origin format: "${t.properties.origin}"`)}return t.properties.angle&&isNaN(parseFloat(t.properties.angle))&&e.push(`Invalid angle format: "${t.properties.angle}"`),{valid:e.length===0,errors:e,warnings:r}}async function pp(t,e){if(!navigator.gpu)throw new Error("WebGPU is not supported in this environment");let r=await navigator.gpu.requestAdapter({powerPreference:e?.powerPreference||"high-performance"});if(!r)throw new Error("No appropriate GPUAdapter found");if(e?.requiredFeatures){for(let u of e.requiredFeatures)if(!r.features.has(u))throw new Error(`Required feature not available: ${u}`)}let n={requiredFeatures:e?.requiredFeatures,requiredLimits:e?.requiredLimits},i=await r.requestDevice(n),o,a="rgba8unorm",s="depth24plus",c=!0,l=e?.width||800,d=e?.height||600;if(t){if(o=t.getContext("webgpu"),!o)throw new Error("Failed to get WebGPU context from canvas");c=!1,a=navigator.gpu.getPreferredCanvasFormat(),l=t.width,d=t.height,o.configure({device:i,format:a,alphaMode:"opaque"})}let f=new Set;for(let u of r.features)f.add(u);return{adapter:r,device:i,context:o,format:a,depthFormat:s,features:f,limits:i.limits,isHeadless:c,width:l,height:d}}function gp(t){let{features:e,limits:r}=t;return{hasTimestampQuery:e.has("timestamp-query"),hasDepthClipControl:e.has("depth-clip-control"),hasTextureCompressionBC:e.has("texture-compression-bc"),hasTextureCompressionETC2:e.has("texture-compression-etc2"),hasTextureCompressionASTC:e.has("texture-compression-astc"),maxTextureDimension2D:r.maxTextureDimension2D,maxBindGroups:r.maxBindGroups,maxUniformBufferBindingSize:r.maxUniformBufferBindingSize,maxStorageBufferBindingSize:r.maxStorageBufferBindingSize}}function yp(t,e,r,n="rgba8unorm"){let i=typeof GPUTextureUsage<"u"?GPUTextureUsage.RENDER_ATTACHMENT|GPUTextureUsage.COPY_SRC:17,o=t.createTexture({size:{width:e,height:r,depthOrArrayLayers:1},format:n,usage:i}),a=o.createView();return{texture:o,view:a,width:e,height:r}}async function bp(t,e){let r=e.width,n=e.height,i=4,o=r*i,a=256,s=Math.max(i*r,Math.ceil(r*i/a)*a),c=s*n,l=typeof GPUBufferUsage<"u"?GPUBufferUsage.COPY_DST|GPUBufferUsage.MAP_READ:9,d=t.createBuffer({size:c,usage:l}),f=t.createCommandEncoder();f.copyTextureToBuffer({texture:e},{buffer:d,bytesPerRow:s},{width:r,height:n,depthOrArrayLayers:1}),t.queue.submit([f.finish()]);let u=typeof GPUMapMode<"u"?GPUMapMode.READ:1;await d.mapAsync(u);let h=d.getMappedRange(),m=new Uint8Array(h),g=new Uint8ClampedArray(r*n*4);if(s===o)g.set(m);else for(let p=0;p<n;p++){let y=p*s,v=p*o;g.set(m.subarray(y,y+o),v)}return d.unmap(),g}var Pc=class{constructor(e=800,r=600){this.width=0;this.height=0;this.collisionVis=null;this.debug=null;this.particleSystem=null;this.frameCount=0;this.callLog=[];this.width=e,this.height=r}renderFrame(e,r=[]){this.frameCount++,this.callLog.push(`renderFrame(frame=${this.frameCount}, entities=${r.length})`);let n=e.cameraState??e.camera.toState();this.callLog.push(` camera: pos=${n.position}, angles=${n.angles}`)}async registerPic(e,r){return this.callLog.push(`registerPic(${e})`),{width:256,height:256}}registerTexture(e,r){return this.callLog.push(`registerTexture(${e})`),{width:r.width,height:r.height}}begin2D(){this.callLog.push("begin2D()")}end2D(){this.callLog.push("end2D()")}drawPic(e,r,n,i){this.callLog.push(`drawPic(${e}, ${r})`)}drawString(e,r,n,i){this.callLog.push(`drawString(${e}, ${r}, "${n}")`)}drawCenterString(e,r){this.callLog.push(`drawCenterString(${e}, "${r}")`)}drawfillRect(e,r,n,i,o){this.callLog.push(`drawfillRect(${e}, ${r}, ${n}, ${i})`)}uploadBspGeometry(e){return this.callLog.push(`uploadBspGeometry(${e.faces.length})`),{surfaces:[],lightmaps:[]}}setEntityHighlight(e,r){}clearEntityHighlight(e){}highlightSurface(e,r){}removeSurfaceHighlight(e){}setDebugMode(e){}setBrightness(e){}setGamma(e){}setFullbright(e){}setAmbient(e){}setLightStyle(e,r){}setUnderwaterWarp(e){}setBloom(e){}setBloomIntensity(e){}setLodBias(e){}renderInstanced(e,r){}getPerformanceReport(){return{frameTimeMs:0,gpuTimeMs:0,cpuFrameTimeMs:0,drawCalls:0,triangles:0,vertices:0,textureBinds:0,shaderSwitches:0,visibleSurfaces:0,culledSurfaces:0,visibleEntities:0,culledEntities:0,memoryUsageMB:{textures:0,geometry:0,total:0}}}getMemoryUsage(){return{texturesBytes:0,geometryBytes:0,shadersBytes:0,buffersBytes:0,totalBytes:0}}dispose(){this.callLog.push("dispose()")}getCallLog(){return this.callLog}resetCallLog(){this.callLog=[]}getFrameCount(){return this.frameCount}};var lf=(n=>(n.QUAKE="quake",n.OPENGL="opengl",n.WEBGPU="webgpu",n))(lf||{});var Ic=class{constructor(){this.coordinateSystem="opengl"}buildProjectionMatrix(e){let r=I.create();return I.perspective(r,e.fov*Ee,e.aspect,e.near,e.far),r}buildViewMatrix(e){let r=I.fromValues(0,0,-1,0,-1,0,0,0,0,1,0,0,0,0,0,1),[n,i,o]=e.angles,a=n*Ee,s=i*Ee,c=o*Ee,l=I.create();I.identity(l),I.rotateZ(l,l,-s),I.rotateY(l,l,-a),I.rotateX(l,l,-c);let d=I.create();I.multiply(d,r,l);let f=L.negate(L.create(),e.position),u=L.create();L.transformMat4(u,f,l);let h=L.fromValues(u[1]?-u[1]:0,u[2]||0,u[0]?-u[0]:0),m=I.clone(d);return m[12]=h[0],m[13]=h[1],m[14]=h[2],m}};var Bc=class{constructor(){this.coordinateSystem="webgpu"}buildProjectionMatrix(e){let r=I.create(),n=1/Math.tan(e.fov*Ee/2),i=1/(e.near-e.far);return r[0]=n/e.aspect,r[5]=n,r[10]=e.far*i,r[11]=-1,r[14]=e.near*e.far*i,r}buildViewMatrix(e){let[r,n,i]=e.angles,o=r*Ee,a=n*Ee,s=i*Ee,c=I.create();I.identity(c),I.rotateZ(c,c,-a),I.rotateY(c,c,-o),I.rotateX(c,c,-s);let l=I.fromValues(0,0,-1,0,-1,0,0,0,0,1,0,0,0,0,0,1),d=I.fromValues(0,0,-1,0,-1,0,0,0,0,1,0,0,0,0,0,1),f=I.create();I.multiply(f,d,c);let u=L.fromValues(e.position[0],e.position[1],e.position[2]),h=L.transformMat4(L.create(),u,f);L.negate(h,h);let m=I.clone(f);return m[12]=h[0],m[13]=h[1],m[14]=h[2],m}};var Fc=class{constructor(){this.coordinateSystem="quake"}buildProjectionMatrix(e){let r=I.create();return I.perspective(r,e.fov*Ee,e.aspect,e.near,e.far),r}buildViewMatrix(e){let[r,n,i]=e.angles,o=r*Ee,a=n*Ee,s=i*Ee,c=I.create();I.identity(c),I.rotateZ(c,c,a),I.rotateX(c,c,o),I.rotateY(c,c,s);let l=I.create();I.fromTranslation(l,[-e.position[0],-e.position[1],-e.position[2]]);let d=I.create();return I.multiply(d,c,l),d}};function xp(t,e){let r=t.buildViewMatrix(e),n=t.buildProjectionMatrix(e),i=I.create();return I.multiply(i,n,r),{view:r,projection:n,viewProjection:i}}function vp(t){return L.fromValues(-t[1],t[2],-t[0])}function _p(t){return L.fromValues(-t[1],t[2],-t[0])}var kc=class{constructor(e={}){this.width=0;this.height=0;this.collisionVis=null;this.debug=null;this.particleSystem=null;this.logs=[];switch(this.options={targetSystem:e.targetSystem??"quake",verbose:e.verbose??!0,validateTransforms:e.validateTransforms??!0},this.options.targetSystem){case"opengl":this.builder=new Ic;break;case"webgpu":this.builder=new Bc;break;default:this.builder=new Fc}this.log(`LoggingRenderer initialized (target=${this.options.targetSystem})`)}renderFrame(e,r=[]){this.log(`
|
|
800
800
|
=== FRAME START ===`);let n=e.cameraState??e.camera.toState();this.log("Camera State:"),this.log(` Position: ${this.formatVec3(n.position)} (Quake space)`),this.log(` Angles: ${this.formatVec3(n.angles)} (degrees)`),this.log(` FOV: ${n.fov}\xB0, Aspect: ${n.aspect.toFixed(2)}`);let i=xp(this.builder,n);this.log(`Matrices (${this.options.targetSystem}):`),this.options.verbose&&(this.log(" View Matrix:"),this.logMatrix(i.view),this.log(" Projection Matrix:"),this.logMatrix(i.projection)),this.options.validateTransforms&&this.validateCoordinateTransforms(n,i.view),this.log(`Entities: ${r.length}`),this.options.verbose&&r.length>0&&(r.slice(0,5).forEach((o,a)=>{this.log(` [${a}] type=${o.type}, model=${o.model??"none"}`)}),r.length>5&&this.log(` ... and ${r.length-5} more`)),this.log(`=== FRAME END ===
|
|
801
801
|
`)}validateCoordinateTransforms(e,r){let n=e.position,i=vp(n),o=_p(n),a=[r[12],r[13],r[14]];switch(this.log("Transform Validation:"),this.log(` Quake position: ${this.formatVec3(n)}`),this.options.targetSystem){case"opengl":this.log(` Expected GL transform: ${this.formatVec3(i)}`);break;case"webgpu":this.log(` Expected WebGPU transform: ${this.formatVec3(o)}`);break}this.log(` Matrix translation: [${a.map(l=>l.toFixed(2)).join(", ")}]`);let s=Math.abs(n[0])+Math.abs(n[1])+Math.abs(n[2]),c=Math.abs(a[0])+Math.abs(a[1])+Math.abs(a[2]);s>0&&c/s>2&&this.log(" \u26A0\uFE0F WARNING: Matrix translation seems large relative to input - possible double-transform!")}formatVec3(e){return`[${e[0].toFixed(2)}, ${e[1].toFixed(2)}, ${e[2].toFixed(2)}]`}logMatrix(e){for(let r=0;r<4;r++){let n=[e[r],e[r+4],e[r+8],e[r+12]];this.log(` [${n.map(i=>i.toFixed(4).padStart(8)).join(" ")}]`)}}log(e){this.logs.push(e),this.options.verbose&&console.log(`[LogRenderer] ${e}`)}async registerPic(e,r){return this.log(`registerPic("${e}", ${r.byteLength} bytes)`),{width:256,height:256}}registerTexture(e,r){return this.log(`registerTexture("${e}", ${r.width}x${r.height})`),{width:r.width,height:r.height}}begin2D(){this.log("begin2D()")}end2D(){this.log("end2D()")}drawPic(e,r,n,i){this.log(`drawPic(${e}, ${r})`)}drawString(e,r,n,i){this.log(`drawString(${e}, ${r}, "${n}")`)}drawCenterString(e,r){this.log(`drawCenterString(${e}, "${r}")`)}drawfillRect(e,r,n,i,o){this.log(`drawfillRect(${e}, ${r}, ${n}x${i})`)}uploadBspGeometry(e){return this.log(`uploadBspGeometry(map with ${e.faces.length} faces)`),{surfaces:[],lightmaps:[]}}setEntityHighlight(e,r){}clearEntityHighlight(e){}highlightSurface(e,r){}removeSurfaceHighlight(e){}setDebugMode(e){}setBrightness(e){}setGamma(e){}setFullbright(e){}setAmbient(e){}setLightStyle(e,r){}setUnderwaterWarp(e){}setBloom(e){}setBloomIntensity(e){}setLodBias(e){}renderInstanced(e,r){}getPerformanceReport(){return{frameTimeMs:0,gpuTimeMs:0,cpuFrameTimeMs:0,drawCalls:0,triangles:0,vertices:0,textureBinds:0,shaderSwitches:0,visibleSurfaces:0,culledSurfaces:0,visibleEntities:0,culledEntities:0,memoryUsageMB:{textures:0,geometry:0,total:0}}}getMemoryUsage(){return{texturesBytes:0,geometryBytes:0,shadersBytes:0,buffersBytes:0,totalBytes:0}}dispose(){this.log("dispose()")}getLogs(){return this.logs}resetLogs(){this.logs=[]}printLogs(){console.log(this.logs.join(`
|
|
802
|
-
`))}};var cf=(a=>(a[a.Disconnected=0]="Disconnected",a[a.Connecting=1]="Connecting",a[a.Challenge=2]="Challenge",a[a.Connected=3]="Connected",a[a.Loading=4]="Loading",a[a.Active=5]="Active",a))(cf||{}),
|
|
802
|
+
`))}};var cf=(a=>(a[a.Disconnected=0]="Disconnected",a[a.Connecting=1]="Connecting",a[a.Challenge=2]="Challenge",a[a.Connected=3]="Connected",a[a.Loading=4]="Loading",a[a.Active=5]="Active",a))(cf||{}),Dc=class{constructor(e){this.state=0;this.parser=null;this.listeners={};this.serverProtocol=0;this.serverCount=0;this.gameDir="";this.playerNum=0;this.levelName="";this.configStrings=new Map;this.baselines=new Map;this.entities=new Map;this.latestServerFrame=0;this.frameCRCs=new Map;this.currentPacketCRC=0;this.commandHistory=[];this.options=e,this.netchan=e.netchan??new Pf}on(e,r){this.listeners[e]||(this.listeners[e]=[]),this.listeners[e].push(r)}off(e,r){this.listeners[e]&&(this.listeners[e]=this.listeners[e].filter(n=>n!==r))}emit(e,...r){this.listeners[e]&&this.listeners[e].forEach(n=>n(...r))}connect(){this.netchan.reset(),this.cleanup(),this.setState(1)}startProtocol(){this.state!==1&&this.connect(),this.setState(2),this.sendChallenge()}disconnect(){this.state!==0&&(this.setState(0),this.emit("disconnect"),this.cleanup())}cleanup(){this.configStrings.clear(),this.baselines.clear(),this.entities.clear(),this.commandHistory=[],this.latestServerFrame=0,this.parser=null,this.frameCRCs.clear()}getState(){return this.state}setState(e){this.state!==e&&(this.state=e,this.emit("state",e))}handleMessage(e){let r=this.netchan.process(new Uint8Array(e));if(!r||r.byteLength===0)return;this.currentPacketCRC=Cf(r);let n=new pn(r.buffer);this.parser=new dt(n,this),this.serverProtocol&&this.parser.setProtocolVersion(this.serverProtocol),this.parser.parseMessage()}sendUserCommand(e){if(this.state!==5)return;let r={...e,serverFrame:e.serverFrame??this.latestServerFrame};this.commandHistory.push(r),this.commandHistory.length>Tf&&this.commandHistory.shift();let n=new Qn;n.writeByte(Zn.move);let i=this.frameCRCs.get(this.latestServerFrame)||0;n.writeByte(i),n.writeLong(this.latestServerFrame),Rf(n,r),this.transmit(n.getData())}transmit(e){let r=this.netchan.transmit(e);this.emit("send",r)}sendChallenge(){let e=new $o;e.writeByte(Zn.stringcmd),e.writeString("getchallenge"),this.transmit(e.getData())}sendConnect(e){let r=new $o;r.writeByte(Zn.stringcmd);let n=`\\name\\${this.options.username}\\model\\${this.options.model}\\skin\\${this.options.skin}\\hand\\${this.options.hand??0}\\fov\\${this.options.fov??90}`;r.writeString(`connect ${zr} ${e} ${n}`),this.transmit(r.getData())}sendNew(){let e=new $o;e.writeByte(Zn.stringcmd),e.writeString("new"),this.transmit(e.getData())}sendBegin(){let e=new $o;e.writeByte(Zn.stringcmd),e.writeString("begin"),this.transmit(e.getData())}onServerData(e,r,n,i,o,a){this.serverProtocol=e,this.serverCount=r,this.gameDir=i,this.playerNum=o,this.levelName=a,this.setState(3),this.emit("serverdata",{protocol:e,serverCount:r,gameDir:i,levelName:a}),this.sendNew(),this.setState(4)}onConfigString(e,r){this.configStrings.set(e,r)}onSpawnBaseline(e){this.baselines.set(e.number,e)}onStuffText(e){if(this.emit("stufftext",e),e.startsWith("precache")&&(this.sendBegin(),this.setState(5)),e.startsWith("challenge ")){let r=e.split(" ");if(r.length>1){let n=parseInt(r[1],10);this.sendConnect(n)}}}onFrame(e){e.serverFrame>this.latestServerFrame&&(this.latestServerFrame=e.serverFrame),this.frameCRCs.set(e.serverFrame,this.currentPacketCRC);let r=e.packetEntities;r.delta||this.entities.clear();for(let n of r.entities)this.entities.set(n.number,n);this.emit("frame",e)}onDisconnect(){this.disconnect()}onPrint(e,r){this.emit("print",r,e)}onCenterPrint(e){this.emit("centerprint",e)}onSound(e,r,n,i,o,a,s){this.emit("sound",{flags:e,soundNum:r,volume:n,attenuation:i,offset:o,ent:a,pos:s})}onTempEntity(e,r,n,i,o,a,s,c,l){this.emit("temp_entity",{type:e,pos:r,pos2:n,dir:i,cnt:o,color:a,ent:s})}onInventory(e){this.emit("inventory",e)}onMuzzleFlash(e,r){this.emit("muzzleflash",e,r)}onMuzzleFlash2(e,r){}onMuzzleFlash3(e,r){this.emit("muzzleflash",e,r)}onDownload(e,r,n){this.emit("download",e,r,n)}onReconnect(){}onLayout(e){}onSplitClient(e){}onConfigBlast(e,r){}onSpawnBaselineBlast(e){}onLevelRestart(){}onDamage(e){}onLocPrint(e,r,n){}onFog(e){}onWaitingForPlayers(e){}onBotChat(e){}onPoi(e,r){}onHelpPath(e){}onAchievement(e){}};function sw(t){return{init(){t.trace({x:0,y:0,z:0},{x:0,y:0,z:0})},shutdown(){},createMainLoop(e,r){return new Yn(e,r)},setAreaPortalState(e,r){t.renderer&&t.renderer.setAreaPortalState&&t.renderer.setAreaPortalState(e,r)}}}return Fp(lw);})();
|
|
803
803
|
/*! Bundled license information:
|
|
804
804
|
|
|
805
805
|
pako/dist/pako.esm.mjs:
|