quake2ts 0.0.307 → 0.0.309
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/package.json +1 -1
- package/packages/client/dist/browser/index.global.js +6 -6
- package/packages/client/dist/browser/index.global.js.map +1 -1
- package/packages/client/dist/cjs/index.cjs +70 -7
- package/packages/client/dist/cjs/index.cjs.map +1 -1
- package/packages/client/dist/esm/index.js +70 -7
- package/packages/client/dist/esm/index.js.map +1 -1
- package/packages/client/dist/tsconfig.tsbuildinfo +1 -1
- package/packages/engine/dist/browser/index.global.js +9 -9
- package/packages/engine/dist/browser/index.global.js.map +1 -1
- package/packages/engine/dist/cjs/index.cjs +70 -7
- package/packages/engine/dist/cjs/index.cjs.map +1 -1
- package/packages/engine/dist/esm/index.js +70 -7
- package/packages/engine/dist/esm/index.js.map +1 -1
- package/packages/engine/dist/tsconfig.tsbuildinfo +1 -1
- package/packages/engine/dist/types/demo/demoReader.d.ts +14 -0
- package/packages/engine/dist/types/demo/demoReader.d.ts.map +1 -1
- package/packages/engine/dist/types/demo/playback.d.ts +11 -0
- package/packages/engine/dist/types/demo/playback.d.ts.map +1 -1
- package/packages/game/dist/tsconfig.tsbuildinfo +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
"use strict";var Quake2Engine=(()=>{var Gu=Object.create;var bo=Object.defineProperty;var Wu=Object.getOwnPropertyDescriptor;var Xu=Object.getOwnPropertyNames;var Ku=Object.getPrototypeOf,$u=Object.prototype.hasOwnProperty;var Zu=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),pa=(e,t)=>{for(var r in t)bo(e,r,{get:t[r],enumerable:!0})},Mc=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of Xu(t))!$u.call(e,i)&&i!==r&&bo(e,i,{get:()=>t[i],enumerable:!(n=Wu(t,i))||n.enumerable});return e};var Yu=(e,t,r)=>(r=e!=null?Gu(Ku(e)):{},Mc(t||!e||!e.__esModule?bo(r,"default",{value:e,enumerable:!0}):r,e)),qu=e=>Mc(bo({},"__esModule",{value:!0}),e);var ad=Zu((G_,sd)=>{"use strict";sd.exports=Worker});var gx={};pa(gx,{ATTN_IDLE:()=>Ra,ATTN_LOOP_NONE:()=>Ta,ATTN_NONE:()=>On,ATTN_NORM:()=>Ia,ATTN_STATIC:()=>Lo,AssetDependencyError:()=>Er,AssetDependencyTracker:()=>Ui,AssetManager:()=>gs,AudioApi:()=>Xr,AudioContextController:()=>ys,AudioRegistry:()=>gn,AudioRegistryError:()=>Pi,AudioSystem:()=>As,BSP_SURFACE_FRAGMENT_SOURCE:()=>ml,BSP_SURFACE_VERTEX_SOURCE:()=>hl,BSP_VERTEX_LAYOUT:()=>dl,BspLoader:()=>$r,BspParseError:()=>j,BspSurfacePipeline:()=>Ts,Camera:()=>Fs,Command:()=>Fn,CommandRegistry:()=>Nr,ConfigStringRegistry:()=>Wr,Cvar:()=>Un,CvarRegistry:()=>Vr,DemoPlaybackController:()=>po,DemoReader:()=>Lr,EngineHost:()=>Gr,EngineRuntime:()=>Hn,FixedTimestepLoop:()=>cr,Framebuffer:()=>Es,IndexBuffer:()=>xe,LruCache:()=>Pt,MAX_SOUND_CHANNELS:()=>Pn,MD2_FRAGMENT_SHADER:()=>vl,MD2_VERTEX_SHADER:()=>bl,MD3_FRAGMENT_SHADER:()=>Rl,MD3_VERTEX_SHADER:()=>Il,Md2Loader:()=>Zr,Md2MeshBuffers:()=>Rs,Md2ParseError:()=>pe,Md2Pipeline:()=>Cs,Md3Loader:()=>Yr,Md3ModelMesh:()=>ks,Md3ParseError:()=>Ge,Md3Pipeline:()=>Bs,Md3SurfaceMesh:()=>Gi,MusicSystem:()=>Ms,NetworkMessageParser:()=>Pr,PARTICLE_FRAGMENT_SHADER:()=>zl,PARTICLE_VERTEX_SHADER:()=>Cl,PROTOCOL_VERSION_RERELEASE:()=>qs,PakArchive:()=>Kr,PakIndexStore:()=>ps,PakIngestionError:()=>Dt,PakParseError:()=>Ve,PakValidationError:()=>dr,PakValidator:()=>Io,ParticleRenderer:()=>Ps,ParticleSystem:()=>Ds,PlaybackState:()=>ma,RERELEASE_KNOWN_PAKS:()=>za,SKYBOX_FRAGMENT_SHADER:()=>xl,SKYBOX_VERTEX_SHADER:()=>yl,SOUND_FULLVOLUME:()=>kt,SOUND_LOOP_ATTENUATE:()=>Ca,ShaderProgram:()=>Ee,SkyboxPipeline:()=>Is,SoundChannel:()=>ot,SoundPrecache:()=>bs,SoundRegistry:()=>_s,SpriteLoader:()=>qr,SpriteParseError:()=>Ot,Texture2D:()=>yn,TextureCache:()=>jr,TextureCubeMap:()=>xn,TgaParseError:()=>yt,U_ALPHA:()=>uc,U_ANGLE1:()=>oa,U_ANGLE2:()=>ea,U_ANGLE3:()=>ta,U_EFFECTS16:()=>ho,U_EFFECTS8:()=>co,U_EVENT:()=>na,U_FRAME16:()=>aa,U_FRAME8:()=>ra,U_INSTANCE_BITS:()=>hc,U_LOOP_ATTENUATION_HIGH:()=>pc,U_LOOP_VOLUME:()=>mc,U_MODEL:()=>sa,U_MODEL2:()=>la,U_MODEL3:()=>ca,U_MODEL4:()=>da,U_OLDORIGIN:()=>ua,U_OLD_FRAME_HIGH:()=>yc,U_ORIGIN1:()=>Qs,U_ORIGIN2:()=>Js,U_ORIGIN3:()=>ia,U_OWNER_HIGH:()=>gc,U_REMOVE:()=>dc,U_RENDERFX16:()=>fo,U_RENDERFX8:()=>lo,U_SCALE:()=>fc,U_SKIN16:()=>mo,U_SKIN8:()=>uo,U_SOLID:()=>ha,U_SOUND:()=>fa,VertexArray:()=>ze,VertexBuffer:()=>Le,VirtualFileSystem:()=>To,advanceAnimation:()=>td,applySurfaceState:()=>Zd,attenuationToDistanceMultiplier:()=>Bt,boxIntersectsFrustum:()=>Vi,buildBspGeometry:()=>Hd,buildMd2Geometry:()=>Sl,buildMd2VertexData:()=>wl,buildMd3SurfaceGeometry:()=>Ll,buildMd3VertexData:()=>Tl,calculateMaxAudibleDistance:()=>Nn,calculatePakChecksum:()=>Gc,computeFrameBlend:()=>rd,computeSkyScroll:()=>jd,createAnimationState:()=>nd,createAudioGraph:()=>xs,createBspSurfaces:()=>Ud,createEmptyEntityState:()=>Dr,createEmptyProtocolPlayerState:()=>js,createEngine:()=>px,createEngineRuntime:()=>Hc,createFaceLightmap:()=>Co,createInitialChannels:()=>vs,createProgramFromSources:()=>Nd,createWebGLContext:()=>Pd,decodeOgg:()=>ms,deriveSurfaceRenderState:()=>gl,extractFrustumPlanes:()=>Vd,filesToPakSources:()=>Fa,findLeafForPoint:()=>fl,gatherVisibleFaces:()=>Kd,groupMd2Animations:()=>jc,ingestPakFiles:()=>Wc,ingestPaks:()=>Ro,interpolateMd3Tag:()=>p0,interpolateVec3:()=>id,parseBsp:()=>ka,parseMd2:()=>Ba,parseMd3:()=>Da,parsePcx:()=>Xn,parseSprite:()=>Pa,parseTga:()=>Oa,parseWal:()=>Fo,parseWalTexture:()=>Do,parseWav:()=>Po,pcxToRgba:()=>ko,pickChannel:()=>Ss,preparePcxTexture:()=>Bo,removeViewTranslation:()=>qd,resolveLightStyles:()=>pl,spatializeOrigin:()=>ws,spawnBlood:()=>x0,spawnBulletImpact:()=>g0,spawnExplosion:()=>y0,spawnMuzzleFlash:()=>b0,spawnTeleportFlash:()=>_0,spawnTrail:()=>v0,walToRgba:()=>Na,wireDropTarget:()=>Xc,wireFileInput:()=>Kc});var ju=()=>typeof performance<"u"?performance.now():Date.now(),Qu=e=>{typeof requestAnimationFrame=="function"?requestAnimationFrame(()=>e()):setTimeout(e,25)},cr=class{constructor(t,r={}){this.callbacks=t;this.accumulatorMs=0;this.frame=0;this.running=!1;this.tick=()=>{if(!this.running)return;let t=this.options.now(),r=this.lastTimeMs===void 0?0:t-this.lastTimeMs;this.lastTimeMs=t,this.advance(r,t),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??ju,schedule:r.schedule??Qu}}start(){this.running||(this.running=!0,this.lastTimeMs=this.options.startTimeMs??this.options.now(),this.options.schedule(this.tick))}stop(){this.running=!1}pump(t){let r=(this.lastTimeMs??0)+t;this.lastTimeMs=r,this.advance(t,r)}isRunning(){return this.running}get frameNumber(){return this.frame}advance(t,r){let n=Math.min(Math.max(t,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 Fn=class{constructor(t,r,n){this.name=t,this.callback=r,this.description=n}execute(t){this.callback(t)}},Nr=class{constructor(){this.commands=new Map}register(t,r,n){let i=new Fn(t,r,n);return this.commands.set(t,i),i}get(t){return this.commands.get(t)}execute(t){let r=this.tokenize(t);if(r.length===0)return!1;let n=r[0],i=r.slice(1),o=this.get(n);return o?(o.execute(i),!0):!1}tokenize(t){return t.trim().split(/\s+/)}list(){return[...this.commands.values()].sort((t,r)=>t.name.localeCompare(r.name))}};var Ju=Object.defineProperty,Ec=(e,t)=>{for(var r in t)Ju(e,r,{get:t[r],enumerable:!0})},Lc={x:0,y:0,z:0};var bx=Math.PI/180;function Tc(e,t){return{x:e.x-t.x,y:e.y-t.y,z:e.z-t.z}}function ef(e,t){return{x:e.x*t,y:e.y*t,z:e.z*t}}function xa(e,t){return e.x*t.x+e.y*t.y+e.z*t.z}function tf(e){return xa(e,e)}function _a(e){return Math.sqrt(tf(e))}function Je(e){let t=_a(e);return t===0?e:ef(e,1/t)}var rf=Math.PI/180,vx=180/Math.PI,Hr=rf;var ya=[[-.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]];function nf(){return new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}function Ic(e,t){let r=t.x,n=t.y,i=t.z;return{x:e[0]*r+e[4]*n+e[8]*i+e[12],y:e[1]*r+e[5]*n+e[9]*i+e[13],z:e[2]*r+e[6]*n+e[10]*i+e[14]}}function Rc(e,t){let r=nf();return r[0]=t[0].x,r[1]=t[0].y,r[2]=t[0].z,r[4]=t[1].x,r[5]=t[1].y,r[6]=t[1].z,r[8]=t[2].x,r[9]=t[2].y,r[10]=t[2].z,r[12]=e.x,r[13]=e.y,r[14]=e.z,r}var it=1,Ft=2;var ba=8,va=16,of=32;var sf=16384;var vo=65536,Cc=1<<17,af=1<<18,lf=1<<19,cf=1<<20,df=1<<21,uf=1<<22,ff=1<<23,Sx=1<<24,So=1<<25,hf=1<<26,wx=1<<27,Ax=1<<28,Mx=1<<29,wo=1<<30,Ex=1<<31;var Bn=0;var zc=4,Fc=8,kc=16,Bc=32,Dc=64;var Lx=1<<25,Tx=1<<28,Ix=1<<29,Rx=1<<30,Cx=1<<31;var zx=it|Ft,Fx=it|vo|Ft|So|wo,kx=it|vo|Ft,Bx=it|Cc|Ft|So|wo,Dx=of|ba|va,Px=it|va|ba,mf=it|So|wo|Ft|hf,Ox=af|lf|cf|df|uf|ff,Nx=it|ba|va|So|wo,Ux=it|vo|Ft,Hx=it|Ft,Vx=it|vo|Ft|Cc,Gx=mf|sf;var Wx=Number.MAX_SAFE_INTEGER-1;var Ao=(e=>(e[e.None=0]="None",e[e.Archive=1]="Archive",e[e.UserInfo=2]="UserInfo",e[e.ServerInfo=4]="ServerInfo",e[e.Latch=8]="Latch",e[e.Cheat=16]="Cheat",e))(Ao||{});var Mo=256;var Sa=256,wa=8192,Eo=2048,Aa=512,Ma=256,Ea=Mo*2,La=256,ga=32,kn=96;var q=(e=>(e[e.Name=0]="Name",e[e.CdTrack=1]="CdTrack",e[e.Sky=2]="Sky",e[e.SkyAxis=3]="SkyAxis",e[e.SkyRotate=4]="SkyRotate",e[e.StatusBar=5]="StatusBar",e[e.HealthBarName=55]="HealthBarName",e[e.CONFIG_N64_PHYSICS=56]="CONFIG_N64_PHYSICS",e[e.CONFIG_CTF_TEAMS=57]="CONFIG_CTF_TEAMS",e[e.CONFIG_COOP_RESPAWN_STRING=58]="CONFIG_COOP_RESPAWN_STRING",e[e.AirAccel=59]="AirAccel",e[e.MaxClients=60]="MaxClients",e[e.MapChecksum=61]="MapChecksum",e[e.Models=62]="Models",e[e.Sounds=62+wa]="Sounds",e[e.Images=e.Sounds+Eo]="Images",e[e.Lights=e.Images+Aa]="Lights",e[e.ShadowLights=e.Lights+Sa]="ShadowLights",e[e.Items=e.ShadowLights+La]="Items",e[e.PlayerSkins=e.Items+Ma]="PlayerSkins",e[e.General=e.PlayerSkins+Mo]="General",e[e.WheelWeapons=e.General+Ea]="WheelWeapons",e[e.WheelAmmo=e.WheelWeapons+ga]="WheelAmmo",e[e.WheelPowerups=e.WheelAmmo+ga]="WheelPowerups",e[e.CdLoopCount=e.WheelPowerups+ga]="CdLoopCount",e[e.GameStyle=e.CdLoopCount+1]="GameStyle",e[e.MaxConfigStrings=e.GameStyle+1]="MaxConfigStrings",e))(q||{}),Pc=q.MaxConfigStrings;function Oc(e){return e>=5&&e<59?kn*(59-e):e>=q.General&&e<q.WheelWeapons?kn*(q.MaxConfigStrings-e):kn}var pf={};Ec(pf,{addReplayFrame:()=>_f,createReplaySession:()=>xf,deserializeReplay:()=>yf,serializeReplay:()=>gf});function gf(e){return JSON.stringify(e,null,2)}function yf(e){let t=JSON.parse(e);if(!t.metadata||!Array.isArray(t.frames))throw new Error("Invalid replay format: missing metadata or frames");return t}function xf(e,t){return{metadata:{map:e,date:new Date().toISOString(),version:"1.0",seed:t},frames:[]}}function _f(e,t,r,n){e.frames.push({serverFrame:r,cmd:t,timestamp:Date.now()-n})}var F=(e=>(e[e.bad=0]="bad",e[e.muzzleflash=1]="muzzleflash",e[e.muzzleflash2=2]="muzzleflash2",e[e.temp_entity=3]="temp_entity",e[e.layout=4]="layout",e[e.inventory=5]="inventory",e[e.nop=6]="nop",e[e.disconnect=7]="disconnect",e[e.reconnect=8]="reconnect",e[e.sound=9]="sound",e[e.print=10]="print",e[e.stufftext=11]="stufftext",e[e.serverdata=12]="serverdata",e[e.configstring=13]="configstring",e[e.spawnbaseline=14]="spawnbaseline",e[e.centerprint=15]="centerprint",e[e.download=16]="download",e[e.playerinfo=17]="playerinfo",e[e.packetentities=18]="packetentities",e[e.deltapacketentities=19]="deltapacketentities",e[e.frame=20]="frame",e[e.splitclient=21]="splitclient",e[e.configblast=22]="configblast",e[e.spawnbaselineblast=23]="spawnbaselineblast",e[e.level_restart=24]="level_restart",e[e.damage=25]="damage",e[e.locprint=26]="locprint",e[e.fog=27]="fog",e[e.waitingforplayers=28]="waitingforplayers",e[e.bot_chat=29]="bot_chat",e[e.poi=30]="poi",e[e.help_path=31]="help_path",e[e.muzzleflash3=32]="muzzleflash3",e[e.achievement=33]="achievement",e))(F||{});var I=(e=>(e[e.GUNSHOT=0]="GUNSHOT",e[e.BLOOD=1]="BLOOD",e[e.BLASTER=2]="BLASTER",e[e.RAILTRAIL=3]="RAILTRAIL",e[e.SHOTGUN=4]="SHOTGUN",e[e.EXPLOSION1=5]="EXPLOSION1",e[e.EXPLOSION2=6]="EXPLOSION2",e[e.ROCKET_EXPLOSION=7]="ROCKET_EXPLOSION",e[e.GRENADE_EXPLOSION=8]="GRENADE_EXPLOSION",e[e.SPARKS=9]="SPARKS",e[e.SPLASH=10]="SPLASH",e[e.BUBBLETRAIL=11]="BUBBLETRAIL",e[e.SCREEN_SPARKS=12]="SCREEN_SPARKS",e[e.SHIELD_SPARKS=13]="SHIELD_SPARKS",e[e.BULLET_SPARKS=14]="BULLET_SPARKS",e[e.LASER_SPARKS=15]="LASER_SPARKS",e[e.PARASITE_ATTACK=16]="PARASITE_ATTACK",e[e.ROCKET_EXPLOSION_WATER=17]="ROCKET_EXPLOSION_WATER",e[e.GRENADE_EXPLOSION_WATER=18]="GRENADE_EXPLOSION_WATER",e[e.MEDIC_CABLE_ATTACK=19]="MEDIC_CABLE_ATTACK",e[e.BFG_EXPLOSION=20]="BFG_EXPLOSION",e[e.BFG_BIGEXPLOSION=21]="BFG_BIGEXPLOSION",e[e.BOSSTPORT=22]="BOSSTPORT",e[e.BFG_LASER=23]="BFG_LASER",e[e.GRAPPLE_CABLE=24]="GRAPPLE_CABLE",e[e.WELDING_SPARKS=25]="WELDING_SPARKS",e[e.GREENBLOOD=26]="GREENBLOOD",e[e.BLUEHYPERBLASTER=27]="BLUEHYPERBLASTER",e[e.PLASMA_EXPLOSION=28]="PLASMA_EXPLOSION",e[e.TUNNEL_SPARKS=29]="TUNNEL_SPARKS",e[e.BLASTER2=30]="BLASTER2",e[e.RAILTRAIL2=31]="RAILTRAIL2",e[e.FLAME=32]="FLAME",e[e.LIGHTNING=33]="LIGHTNING",e[e.DEBUGTRAIL=34]="DEBUGTRAIL",e[e.PLAIN_EXPLOSION=35]="PLAIN_EXPLOSION",e[e.FLASHLIGHT=36]="FLASHLIGHT",e[e.FORCEWALL=37]="FORCEWALL",e[e.HEATBEAM=38]="HEATBEAM",e[e.MONSTER_HEATBEAM=39]="MONSTER_HEATBEAM",e[e.STEAM=40]="STEAM",e[e.BUBBLETRAIL2=41]="BUBBLETRAIL2",e[e.MOREBLOOD=42]="MOREBLOOD",e[e.HEATBEAM_SPARKS=43]="HEATBEAM_SPARKS",e[e.HEATBEAM_STEAM=44]="HEATBEAM_STEAM",e[e.CHAINFIST_SMOKE=45]="CHAINFIST_SMOKE",e[e.ELECTRIC_SPARKS=46]="ELECTRIC_SPARKS",e[e.TRACKER_EXPLOSION=47]="TRACKER_EXPLOSION",e[e.TELEPORT_EFFECT=48]="TELEPORT_EFFECT",e[e.DBALL_GOAL=49]="DBALL_GOAL",e[e.WIDOWBEAMOUT=50]="WIDOWBEAMOUT",e[e.NUKEBLAST=51]="NUKEBLAST",e[e.WIDOWSPLASH=52]="WIDOWSPLASH",e[e.EXPLOSION1_BIG=53]="EXPLOSION1_BIG",e[e.EXPLOSION1_NP=54]="EXPLOSION1_NP",e[e.FLECHETTE=55]="FLECHETTE",e[e.BLUEHYPERBLASTER_KEX=56]="BLUEHYPERBLASTER_KEX",e[e.BFG_ZAP=57]="BFG_ZAP",e[e.BERSERK_SLAM=58]="BERSERK_SLAM",e[e.GRAPPLE_CABLE_2=59]="GRAPPLE_CABLE_2",e[e.POWER_SPLASH=60]="POWER_SPLASH",e[e.LIGHTNING_BEAM=61]="LIGHTNING_BEAM",e[e.EXPLOSION1_NL=62]="EXPLOSION1_NL",e[e.EXPLOSION2_NL=63]="EXPLOSION2_NL",e))(I||{});var bf=12,vf=9,Xx=Math.ceil(bf*vf/16),Sf=23,wf=2,Kx=Math.ceil(Sf*wf/16);var Af={};Ec(Af,{U_ANGLE1:()=>Cf,U_ANGLE2:()=>zf,U_ANGLE3:()=>Ff,U_EFFECTS:()=>Df,U_EVENT:()=>Nf,U_FRAME:()=>kf,U_MODEL:()=>Ef,U_MODEL2:()=>Hf,U_MODEL3:()=>Vf,U_MODEL4:()=>Gf,U_MOREBITS:()=>Uf,U_NUMBER:()=>Mf,U_ORIGIN1:()=>Tf,U_ORIGIN2:()=>If,U_ORIGIN3:()=>Rf,U_REMOVE:()=>Wf,U_RENDERFX:()=>Pf,U_SKIN:()=>Bf,U_SOLID:()=>Of,U_SOUND:()=>Lf});var Mf=1,Ef=2,Lf=4,Tf=8,If=16,Rf=32,Cf=64,zf=128,Ff=256,kf=512,Bf=1024,Df=2048,Pf=4096,Of=8192,Nf=16384,Uf=32768,Hf=1,Vf=2,Gf=4,Wf=32768;var Dn=class{constructor(e){e instanceof Uint8Array?this.view=new DataView(e.buffer,e.byteOffset,e.byteLength):this.view=new DataView(e),this.offset=0,this.length=this.view.byteLength}getPosition(){return this.offset}seek(e){if(e<0||e>this.length)throw new Error(`Seek out of bounds: ${e} (length: ${this.length})`);this.offset=e}hasMore(){return this.offset<this.length}readChar(){let e=this.view.getInt8(this.offset);return this.offset+=1,e}readByte(){let e=this.view.getUint8(this.offset);return this.offset+=1,e}readShort(){let e=this.view.getInt16(this.offset,!0);return this.offset+=2,e}readUShort(){let e=this.view.getUint16(this.offset,!0);return this.offset+=2,e}readLong(){let e=this.view.getInt32(this.offset,!0);return this.offset+=4,e}readULong(){let e=this.view.getUint32(this.offset,!0);return this.offset+=4,e}readFloat(){let e=this.view.getFloat32(this.offset,!0);return this.offset+=4,e}readString(){let e="";for(;this.offset<this.length;){let t=this.readChar();if(t===-1||t===0)break;e+=String.fromCharCode(t)}return e}readStringLine(){let e="";for(;this.offset<this.length;){let t=this.readChar();if(t===-1||t===0||t===10)break;e+=String.fromCharCode(t)}return e}readCoord(){return this.readShort()*(1/8)}readAngle(){return this.readChar()*(360/256)}readAngle16(){return this.readShort()*360/65536}readData(e){if(this.offset+e>this.length)throw new Error(`Read out of bounds: ${this.offset+e} (length: ${this.length})`);let t=new Uint8Array(this.view.buffer,this.view.byteOffset+this.offset,e);return this.offset+=e,new Uint8Array(t)}readPos(e){e.x=this.readCoord(),e.y=this.readCoord(),e.z=this.readCoord()}readDir(e){let t=this.readByte();if(t>=162){e.x=0,e.y=0,e.z=0;return}let r=ya[t];e.x=r[0],e.y=r[1],e.z=r[2]}},Xf=class{constructor(e=1400){typeof e=="number"?(this.buffer=new Uint8Array(e),this.fixed=!1):(this.buffer=e,this.fixed=!0),this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength),this.offset=0}ensureSpace(e){if(this.offset+e>this.buffer.byteLength){if(this.fixed)throw new Error(`Buffer overflow: capacity ${this.buffer.byteLength}, needed ${this.offset+e}`);let t=Math.max(this.buffer.byteLength*2,this.offset+e),r=new Uint8Array(t);r.set(this.buffer),this.buffer=r,this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength)}}writeByte(e){this.ensureSpace(1),this.view.setUint8(this.offset,e),this.offset+=1}writeChar(e){this.ensureSpace(1),this.view.setInt8(this.offset,e),this.offset+=1}writeShort(e){this.ensureSpace(2),this.view.setInt16(this.offset,e,!0),this.offset+=2}writeLong(e){this.ensureSpace(4),this.view.setInt32(this.offset,e,!0),this.offset+=4}writeFloat(e){this.ensureSpace(4),this.view.setFloat32(this.offset,e,!0),this.offset+=4}writeString(e){let t=e.length;this.ensureSpace(t+1);for(let r=0;r<t;r++)this.view.setUint8(this.offset+r,e.charCodeAt(r));this.view.setUint8(this.offset+t,0),this.offset+=t+1}writeCoord(e){this.writeShort(Math.trunc(e*8))}writeAngle(e){this.writeByte(Math.trunc(e*256/360)&255)}writeAngle16(e){this.writeShort(Math.trunc(e*65536/360)&65535)}writePos(e){this.writeCoord(e.x),this.writeCoord(e.y),this.writeCoord(e.z)}writeDir(e){let t=-1,r=0;if(e.x===0&&e.y===0&&e.z===0){this.writeByte(0);return}for(let n=0;n<ya.length;n++){let i=ya[n],o=e.x*i[0]+e.y*i[1]+e.z*i[2];o>t&&(t=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}};var Ur=class me{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 Xf(me.MAX_RELIABLE_BUFFER);let t=Date.now();this.lastReceived=t,this.lastSent=t,this.qport=Math.floor(Math.random()*65536)}setup(t,r=null){this.qport=t,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(t){this.outgoingSequence++,this.lastSent=Date.now();let r=0,n=!1,i=0;this.reliableLength>0&&(this.reliableLength>me.FRAGMENT_SIZE?(n=!0,this.fragmentSendOffset>=this.reliableLength&&(this.fragmentSendOffset=0),r=this.reliableLength-this.fragmentSendOffset,r>me.FRAGMENT_SIZE&&(r=me.FRAGMENT_SIZE),i=this.fragmentSendOffset,this.fragmentSendOffset+=r):r=this.reliableLength);let o=me.PACKET_HEADER,s=r>0?2+(n?8:0):0,a=t?t.length:0;o+s+r+a>me.MAX_MSGLEN&&(a=me.MAX_MSGLEN-o-s-r,a<0&&(a=0));let d=new ArrayBuffer(o+s+r+a),l=new DataView(d),c=new Uint8Array(d),h=this.outgoingSequence;r>0&&(h|=2147483648,(this.outgoingReliableSequence&1)!==0&&(h|=1073741824)),l.setUint32(0,h,!0);let u=this.incomingSequence;(this.incomingReliableSequence&1)!==0&&(u|=2147483648),l.setUint32(4,u,!0),l.setUint16(8,this.qport,!0);let f=o;if(r>0){let m=r;n&&(m|=32768),l.setUint16(f,m,!0),f+=2,n&&(l.setUint32(f,i,!0),f+=4,l.setUint32(f,this.reliableLength,!0),f+=4);let p=this.reliableMessage.getBuffer().subarray(i,i+r);c.set(p,f),f+=r}if(t&&a>0){let m=t.slice(0,a);c.set(m,f)}return c}process(t){if(t.length<me.PACKET_HEADER)return null;this.lastReceived=Date.now();let r=new DataView(t.buffer,t.byteOffset,t.byteLength),n=r.getUint32(0,!0),i=r.getUint32(4,!0),o=r.getUint16(8,!0);if(this.qport!==o)return null;let s=n&1073741823;if((s-this.incomingSequence|0)<=0)return null;this.incomingSequence=s;let a=i&2147483647,d=(i&2147483648)!==0;if(a>this.incomingAcknowledged&&(this.incomingAcknowledged=a),this.reliableLength>0){let m=d?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,c=(n&1073741824)!==0?1:0,h=me.PACKET_HEADER,u=null;if(l){if(h+2>t.byteLength)return null;let m=r.getUint16(h,!0);h+=2;let g=(m&32768)!==0;m&=32767;let p=this.incomingReliableSequence&1;if(c===p)if(g){if(h+8>t.byteLength)return null;let y=r.getUint32(h,!0);h+=4;let S=r.getUint32(h,!0);if(h+=4,S>me.MAX_RELIABLE_BUFFER)return console.warn(`NetChan: received invalid fragment total ${S} > ${me.MAX_RELIABLE_BUFFER}`),null;if((!this.fragmentBuffer||this.fragmentBuffer.length!==S)&&(this.fragmentBuffer=new Uint8Array(S),this.fragmentLength=S,this.fragmentReceived=0),h+m>t.byteLength)return null;let _=t.subarray(h,h+m);y===this.fragmentReceived&&y+m<=S&&(this.fragmentBuffer.set(_,y),this.fragmentReceived+=m,this.fragmentReceived>=S&&(u=this.fragmentBuffer,this.incomingReliableSequence++,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0))}else{if(this.incomingReliableSequence++,h+m>t.byteLength)return null;u=t.slice(h,h+m)}h+=m}let f=t.slice(h);if(u&&u.length>0){let m=u.length+f.length,g=new Uint8Array(m);return g.set(u,0),g.set(f,u.length),g}return f||new Uint8Array(0)}canSendReliable(){return this.reliableLength===0}writeReliableByte(t){if(this.reliableLength+1>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeByte(t),this.reliableLength++}writeReliableShort(t){if(this.reliableLength+2>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeShort(t),this.reliableLength+=2}writeReliableLong(t){if(this.reliableLength+4>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeLong(t),this.reliableLength+=4}writeReliableString(t){let r=t.length+1;if(this.reliableLength+r>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeString(t),this.reliableLength+=r}getReliableData(){return this.reliableLength===0?new Uint8Array(0):this.reliableMessage.getBuffer().subarray(0,this.reliableLength)}needsKeepalive(t){return t-this.lastSent>1e3}isTimedOut(t,r=3e4){return t-this.lastReceived>r}};Ur.MAX_MSGLEN=1400;Ur.FRAGMENT_SIZE=1024;Ur.PACKET_HEADER=10;Ur.HEADER_OVERHEAD=Ur.PACKET_HEADER+2;Ur.MAX_RELIABLE_BUFFER=262144;var Nc=(e=>(e[e.Bullets=0]="Bullets",e[e.Shells=1]="Shells",e[e.Rockets=2]="Rockets",e[e.Grenades=3]="Grenades",e[e.Cells=4]="Cells",e[e.Slugs=5]="Slugs",e[e.MagSlugs=6]="MagSlugs",e[e.Trap=7]="Trap",e[e.Flechettes=8]="Flechettes",e[e.Tesla=9]="Tesla",e[e.Disruptor=10]="Disruptor",e[e.Prox=11]="Prox",e[e.Nuke=12]="Nuke",e[e.Rounds=13]="Rounds",e))(Nc||{}),$x=Object.keys(Nc).length/2;var Pn=32,ot=(e=>(e[e.Auto=0]="Auto",e[e.Weapon=1]="Weapon",e[e.Voice=2]="Voice",e[e.Item=3]="Item",e[e.Body=4]="Body",e[e.Aux=5]="Aux",e[e.Footstep=6]="Footstep",e[e.Aux3=7]="Aux3",e[e.NoPhsAdd=8]="NoPhsAdd",e[e.Reliable=16]="Reliable",e[e.ForcePos=32]="ForcePos",e))(ot||{}),Ta=-1,On=0,Ia=1,Ra=2,Lo=3,kt=80,Ca=.003;function Bt(e){return e===Lo?e*.001:e*5e-4}function Nn(e){let t=Bt(e);return t<=0?Number.POSITIVE_INFINITY:kt+1/t}var Un=class{constructor({name:t,defaultValue:r,description:n,flags:i=Ao.None,onChange:o}){this.modifiedCount=0;this.name=t,this.defaultValue=r,this.description=n,this.flags=i,this._value=r,this.onChange=o}get string(){return this._value}get number(){return Number(this._value)}get integer(){return Math.trunc(this.number)}get boolean(){return!!this.integer}set(t){if(this.flags&Ao.Latch){if(t===this._value){this.latched=void 0;return}if(this.latched===t)return;this.latched!==t&&(this.latched=t);return}this.apply(t)}reset(){this.latched=void 0,this.apply(this.defaultValue)}applyLatched(){if(this.latched===void 0)return!1;let t=this.latched;return this.latched=void 0,t===this._value?!1:(this.apply(t),!0)}apply(t){if(this._value===t)return;let r=this._value;this._value=t,this.modifiedCount+=1,this.onChange?.(this,r)}},Vr=class{constructor(){this.cvars=new Map}register(t){let r=this.cvars.get(t.name);if(r)return r;let n=new Un(t);return this.cvars.set(t.name,n),n}get(t){return this.cvars.get(t)}setValue(t,r){let n=this.get(t);if(!n)throw new Error(`Unknown cvar: ${t}`);return n.set(r),n}resetAll(){for(let t of this.cvars.values())t.reset()}applyLatched(){let t=!1;for(let r of this.cvars.values())t=r.applyLatched()||t;return t}list(){return[...this.cvars.values()].sort((t,r)=>t.name.localeCompare(r.name))}};var Gr=class{constructor(t,r,n={}){this.game=t;this.client=r;this.started=!1;this.commands=new Nr;this.cvars=new Vr;this.stepSimulation=t=>{this.previousFrame=this.latestFrame,this.latestFrame=this.game.frame(t,this.latestCommand)};this.renderClient=t=>{this.client&&(this.latestCommand=this.client.render({...t,previous:this.previousFrame,latest:this.latestFrame}))};let i=n.loop?.now?.()??Date.now();this.startTimeMs=n.startTimeMs??n.loop?.startTimeMs??i,this.loop=new cr({simulate:this.stepSimulation,render:this.renderClient},{...n.loop,startTimeMs:this.startTimeMs})}start(){if(!this.started){try{this.latestFrame=this.game.init(this.startTimeMs)??this.latestFrame,this.client?.init(this.latestFrame)}catch(t){throw this.game.shutdown(),this.client?.shutdown(),t}this.started=!0,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)}pump(t){this.loop.pump(t)}getLatestFrame(){return this.latestFrame}isRunning(){return this.loop.isRunning()}};function Kf(e){if(e<0||e>=q.MaxConfigStrings)throw new RangeError(`Configstring index ${e} is out of range (0-${q.MaxConfigStrings-1})`)}function Uc(e,t){let r=Oc(e);if(t.length>r)throw new RangeError(`Configstring ${e} exceeds maximum length (${t.length} > ${r}); limit is ${kn} chars per slot`)}var Wr=class{constructor(){this.values=new Map;this.modelCursor=q.Models;this.soundCursor=q.Sounds;this.imageCursor=q.Images;this.lightCursor=q.Lights;this.shadowLightCursor=q.ShadowLights;this.itemCursor=q.Items;this.playerSkinCursor=q.PlayerSkins;this.generalCursor=q.General}set(t,r){return Kf(t),Uc(t,r),this.values.set(t,r),t}get(t){return this.values.get(t)}getName(t){return this.get(t)}getAll(){let t=new Array(Pc).fill("");for(let[r,n]of this.values.entries())t[r]=n;return t}modelIndex(t){return this.register(t,q.Models,wa,"modelCursor")}soundIndex(t){return this.register(t,q.Sounds,Eo,"soundCursor")}findSoundIndex(t){for(let r=q.Sounds;r<q.Sounds+Eo;r+=1)if(this.values.get(r)===t)return r}imageIndex(t){return this.register(t,q.Images,Aa,"imageCursor")}lightIndex(t){return this.register(t,q.Lights,Sa,"lightCursor")}shadowLightIndex(t){return this.register(t,q.ShadowLights,La,"shadowLightCursor")}itemIndex(t){return this.register(t,q.Items,Ma,"itemCursor")}playerSkinIndex(t){return this.register(t,q.PlayerSkins,Mo,"playerSkinCursor")}generalIndex(t){return this.register(t,q.General,Ea,"generalCursor")}register(t,r,n,i){for(let a=r;a<r+n;a+=1)if(this.values.get(a)===t)return a;let o=this[i],s=r+n;if(o>=s)throw new RangeError(`Out of configstring slots for range starting at ${r}`);return Uc(o,t),this.values.set(o,t),this[i]=o+1,o}};var Xr=class{constructor(t){this.registry=t.registry,this.system=t.system,this.music=t.music,this.client=t.client}soundindex(t){return this.registry.registerName(t)}sound(t,r,n,i,o,s){this.system.play({entity:t,channel:r,soundIndex:n,volume:i,attenuation:o,timeOffsetMs:s}),this.triggerSubtitle(n)}positioned_sound(t,r,n,i){this.system.positionedSound(t,r,n,i),this.triggerSubtitle(r)}loop_sound(t,r,n,i,o){this.system.play({entity:t,channel:r,soundIndex:n,volume:i,attenuation:o,looping:!0}),this.triggerSubtitle(n)}stop_entity_sounds(t){this.system.stopEntitySounds(t)}set_listener(t){this.system.setListener(t)}play_music(t,r=!0){return this.music?this.music.play(t,{loop:r}):Promise.resolve()}pause_music(){this.music?.pause()}resume_music(){return this.music?.resume()??Promise.resolve()}stop_music(){this.music?.stop()}set_music_volume(t){this.music?.setVolume(t)}play_ambient(t,r,n){this.system.ambientSound(t,r,n),this.triggerSubtitle(r)}play_channel(t){this.system.play({...t}),this.triggerSubtitle(t.soundIndex)}triggerSubtitle(t){if(!this.client)return;let r=this.registry.getName(t);if(!r)return;let n=r.match(/\[(.*?)\]/);n&&this.client.showSubtitle(n[1],r)}};var Hn=class{constructor(t,r){this.engine=t;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(t){this.host.pump(t)}getLatestFrame(){return this.host.getLatestFrame()}isRunning(){return this.started&&this.host.isRunning()}};function Hc(e,t,r,n,i){let o=new Xr({...n,client:r}),s=new Gr(t,r,i);return{runtime:new Hn(e,s),audio:o}}var $f="PACK";function Zf(e,t,r){let n=[];for(let i=0;i<r;i+=1){let o=e.getUint8(t+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function ae(e){return e.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}function Yf(){let e=new Uint32Array(256);for(let t=0;t<256;t+=1){let r=t;for(let n=0;n<8;n+=1)r=(r&1)!==0?3988292384^r>>>1:r>>>1;e[t]=r>>>0}return e}var qf=Yf();function Vc(e){let t=4294967295;for(let r=0;r<e.length;r+=1){let n=e[r];t=qf[(t^n)&255]^t>>>8}return(t^4294967295)>>>0}var Ve=class extends Error{},Kr=class e{constructor(t,r,n,i){this.name=t;this.buffer=r;this.entries=new Map(n.map(o=>[o.name,o])),this.checksum=i,this.size=r.byteLength}static fromArrayBuffer(t,r){let n=new DataView(r);if(r.byteLength<12)throw new Ve("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!==$f)throw new Ve(`Invalid PAK header magic: ${i}`);let o=n.getInt32(4,!0),s=n.getInt32(8,!0);if(o<12)throw new Ve(`Invalid directory offset: ${o}`);if(s<=0||s%64!==0)throw new Ve(`Invalid directory length: ${s}`);if(o+s>r.byteLength)throw new Ve("Directory exceeds buffer length");let d=s/64,l=[],c=new Map;for(let h=0;h<d;h+=1){let u=o+h*64,f=Zf(n,u,56),m=ae(f),g=n.getInt32(u+56,!0),p=n.getInt32(u+60,!0);if(g<0||p<0||g+p>r.byteLength)throw new Ve(`Invalid entry bounds for ${f||"<unnamed>"} (offset=${g}, length=${p})`);if(!m)throw new Ve(`Entry ${h} has an empty name`);let y={name:m,offset:g,length:p};c.set(m,y)}return l.push(...c.values()),new e(t,r,l,Vc(new Uint8Array(r)))}getEntry(t){return this.entries.get(ae(t))}listEntries(){return Array.from(this.entries.values())}readFile(t){let r=this.getEntry(t);if(!r)throw new Ve(`File not found in PAK: ${t}`);return new Uint8Array(this.buffer,r.offset,r.length)}validate(){return{checksum:this.checksum,entries:this.listEntries()}}};function Gc(e){return Vc(new Uint8Array(e))}var To=class{constructor(t=[]){this.mounts=[];this.files=new Map;t.forEach(r=>this.mountPak(r))}mountPak(t){this.mounts.push(t);for(let r of t.listEntries()){let n=ae(r.name);this.files.set(n,{archive:t,entry:r})}}get mountedPaks(){return[...this.mounts]}hasFile(t){return this.files.has(ae(t))}stat(t){let r=this.files.get(ae(t));if(r)return{path:r.entry.name,size:r.entry.length,sourcePak:r.archive.name}}async readFile(t){let r=this.files.get(ae(t));if(!r)throw new Error(`File not found in VFS: ${t}`);return r.archive.readFile(t)}list(t=""){let r=ae(t).replace(/\/+$|^\//g,""),n=[],i=new Set,o=r?`${r}/`:"";for(let s of this.files.values()){if(r&&!s.entry.name.startsWith(o))continue;let a=r?s.entry.name.slice(o.length):s.entry.name,d=a.indexOf("/");d===-1?n.push({path:s.entry.name,size:s.entry.length,sourcePak:s.archive.name}):i.add(a.slice(0,d))}return n.sort((s,a)=>s.path.localeCompare(a.path)),{files:n,directories:[...i].sort()}}findByExtension(t){let r=t.startsWith(".")?t.toLowerCase():`.${t.toLowerCase()}`,n=[];for(let i of this.files.values())i.entry.name.toLowerCase().endsWith(r)&&n.push({path:i.entry.name,size:i.entry.length,sourcePak:i.archive.name});return n.sort((i,o)=>i.path.localeCompare(o.path))}};var za=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"}]),dr=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"}},Io=class{constructor(t=za){this.known=new Map;t.forEach(r=>this.known.set(this.normalizePakName(r.name),r))}validateArchive(t,r){let n=this.normalizePakName(r??("name"in t?t.name:"unknown")),i=t.checksum,o="size"in t?t.size:void 0,s=this.known.get(n);return s?s.checksum!==i?{name:n,checksum:i,expectedChecksum:s.checksum,status:"mismatch",size:o,description:s.description}:{name:n,checksum:i,expectedChecksum:s.checksum,status:"valid",size:o,description:s.description}:{name:n,checksum:i,status:"unknown",size:o}}assertValid(t,r){let n=this.validateArchive(t,r);if(n.status==="mismatch")throw new dr(n);return n}normalizePakName(t){let r=ae(t),n=r.split("/"),i=n.pop()??r,o=n.pop();return o?`${i}@${o}`:i}};var Dt=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 jf(e,t){if(typeof e.arrayBuffer=="function"){let r=await e.arrayBuffer();return t?.({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=>{t?.({file:"blob",loadedBytes:o.loaded,totalBytes:o.total||e.size,state:"reading"})},i.onload=()=>{let o=i.result;o instanceof ArrayBuffer?r(o):n(new Error("Unexpected FileReader result"))},i.readAsArrayBuffer(e)});if(typeof Response<"u"){let r=await new Response(e).arrayBuffer();return t?.({file:"blob",loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}if(typeof e.stream=="function"){let r=e.stream().getReader(),n=[],i=0;for(;;){let{done:a,value:d}=await r.read();if(a)break;if(!d)continue;let l=d;n.push(l),i+=l.byteLength,t?.({file:"blob",loadedBytes:i,totalBytes:e.size,state:"reading"})}let o=new Uint8Array(i),s=0;for(let a of n)o.set(a,s),s+=a.byteLength;return o.buffer}throw new Dt("blob",new Error("Unsupported Blob type"))}async function Qf(e,t){if(e.data instanceof ArrayBuffer)return t?.({file:e.name,loadedBytes:e.data.byteLength,totalBytes:e.data.byteLength,state:"reading"}),e.data;if(e.data instanceof Blob){let n=e.data.size;return jf(e.data,i=>t?.({...i,file:e.name,totalBytes:n}))}let r=e.data.buffer.slice(e.data.byteOffset,e.data.byteOffset+e.data.byteLength);return t?.({file:e.name,loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}async function Ro(e,t,r){let n=typeof r=="function"?{onProgress:r}:r??{},i=n.persistIndexes??!!n.pakIndexStore,o=n.enforceValidation??!!n.validator,s=n.allowUnknownPaks??!0,a=n.stopOnError??!1,d=[];for(let l of t)try{let c=await Qf(l,n.onProgress),h=Kr.fromArrayBuffer(l.name,c),u=n.validator?.validateArchive(h);if(u){n.onValidationResult?.(u);let f=u.status==="mismatch",m=u.status==="unknown";if(f&&o||m&&!s){let g=new dr(u);if(n.onError?.(l.name,g),a)throw new Dt(l.name,g);d.push({archive:h,mounted:!1,validation:u});continue}}if(e.mountPak(h),i&&n.pakIndexStore)try{await n.pakIndexStore.persist(h)}catch(f){if(n.onError?.(l.name,f),a)throw new Dt(l.name,f)}n.onProgress?.({file:l.name,loadedBytes:c.byteLength,totalBytes:c.byteLength,state:"parsed"}),d.push({archive:h,mounted:!0,validation:u})}catch(c){if(n.onProgress?.({file:l.name,loadedBytes:0,totalBytes:0,state:"error"}),n.onError?.(l.name,c),a)throw new Dt(l.name,c)}return d}var Pt=class{constructor(t){this.capacity=t;this.map=new Map;if(t<=0)throw new RangeError("LRU cache capacity must be greater than zero")}get size(){return this.map.size}has(t){return this.map.has(t)}get(t){let r=this.map.get(t);if(r!==void 0)return this.map.delete(t),this.map.set(t,r),r}set(t,r){if(this.map.has(t)&&this.map.delete(t),this.map.set(t,r),this.map.size>this.capacity){let n=this.map.keys().next();n.done||this.map.delete(n.value)}}delete(t){return this.map.delete(t)}clear(){this.map.clear()}entries(){return Array.from(this.map.entries()).reverse().map(([t,r])=>({key:t,value:r}))}};function Jf(e){return Array.isArray(e)?e:Array.from(e)}function Fa(e){return Jf(e).map(t=>({name:t.name,data:t}))}async function Wc(e,t,r){let n=Fa(t);return Ro(e,n,r??{})}function Xc(e,t){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&&t(Array.from(o))};return e.addEventListener("dragover",r),e.addEventListener("drop",n),()=>{e.removeEventListener("dragover",r),e.removeEventListener("drop",n)}}function Kc(e,t){let r=n=>{let i=n.target;!i||!i.files||i.files.length===0||(t(i.files),i.value="")};return e.addEventListener("change",r),()=>e.removeEventListener("change",r)}var eh="IBSP",th=38,Zc=19,rh=8+Zc*8;var j=class extends Error{},$r=class{constructor(t){this.vfs=t}async load(t){let r=await this.vfs.readFile(t),n=new Uint8Array(r.byteLength);return n.set(r),ka(n.buffer)}};function ka(e){if(e.byteLength<rh)throw new j("BSP too small to contain header");let t=new DataView(e),r=String.fromCharCode(t.getUint8(0),t.getUint8(1),t.getUint8(2),t.getUint8(3));if(r!==eh)throw new j(`Invalid BSP magic ${r}`);let n=t.getInt32(4,!0);if(n!==th)throw new j(`Unsupported BSP version ${n}`);let i=new Map;for(let v=0;v<Zc;v+=1){let E=t.getInt32(8+v*8,!0),L=t.getInt32(12+v*8,!0);if(E<0||L<0||E+L>e.byteLength)throw new j(`Invalid lump bounds for index ${v}`);i.set(v,{offset:E,length:L})}let o={version:n,lumps:i},s=ih(e,i.get(0)),a=sh(e,i.get(1)),d=ah(e,i.get(2)),l=lh(e,i.get(4)),c=ch(e,i.get(5)),h=dh(e,i.get(6)),u=new Uint8Array(e,i.get(7).offset,i.get(7).length),f=_h(h,i.get(7)),m=uh(e,i.get(8)),g=fh(e,i.get(11)),p=hh(e,i.get(12)),y=mh(e,i.get(13)),S=ph(e,i.get(14)),_=gh(e,i.get(15)),x=yh(e,i.get(9),i.get(10),m),b=xh(e,i.get(3));return{header:o,entities:s,planes:a,vertices:d,nodes:l,texInfo:c,faces:h,lightMaps:u,lightMapInfo:f,leafs:m,leafLists:x,edges:g,surfEdges:p,models:y,brushes:S,brushSides:_,visibility:b,pickEntity(v){let E=null,L=1/0;for(let w of s.entities){let T=w.properties.model;if(!T||!T.startsWith("*"))continue;let z=parseInt(T.substring(1),10);if(isNaN(z)||z<0||z>=y.length)continue;let U=y[z],C=nh(v.origin,v.direction,U.mins,U.maxs);C!==null&&C<L&&(L=C,E={entity:w,model:U,distance:C})}return E}}}function nh(e,t,r,n){let i=0,o=1/0;for(let s=0;s<3;s++)if(Math.abs(t[s])<1e-8){if(e[s]<r[s]||e[s]>n[s])return null}else{let a=1/t[s],d=(r[s]-e[s])*a,l=(n[s]-e[s])*a;if(d>l){let c=d;d=l,l=c}if(i=Math.max(i,d),o=Math.min(o,l),i>o)return null}return i}function ih(e,t){let r=new TextDecoder().decode(new Uint8Array(e,t.offset,t.length)),n=oh(r),i=n.find(o=>o.classname==="worldspawn");return{raw:r,entities:n,worldspawn:i,getUniqueClassnames(){let o=new Set;for(let s of n)s.classname&&o.add(s.classname);return Array.from(o).sort()}}}function oh(e){let t=[],r=/\{([^}]*)\}/gms,n;for(;(n=r.exec(e))!==null;){let i=n[1],o={},s=/"([^\"]*)"\s+"([^\"]*)"/g,a;for(;(a=s.exec(i))!==null;)o[a[1]]=a[2];t.push({classname:o.classname,properties:o})}return t}function sh(e,t){let r=new DataView(e,t.offset,t.length),n=t.length/20;if(n%1!==0)throw new j("Plane lump has invalid length");let i=[];for(let o=0;o<n;o+=1){let s=[r.getFloat32(o*20,!0),r.getFloat32(o*20+4,!0),r.getFloat32(o*20+8,!0)],a=r.getFloat32(o*20+12,!0),d=r.getInt32(o*20+16,!0);i.push({normal:s,dist:a,type:d})}return i}function ah(e,t){let r=new DataView(e,t.offset,t.length),n=t.length/12;if(n%1!==0)throw new j("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 lh(e,t){let r=new DataView(e,t.offset,t.length),n=28,i=t.length/n;if(i%1!==0)throw new j("Node lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n,d=r.getInt32(a,!0),l=[r.getInt32(a+4,!0),r.getInt32(a+8,!0)],c=[r.getInt16(a+12,!0),r.getInt16(a+14,!0),r.getInt16(a+16,!0)],h=[r.getInt16(a+18,!0),r.getInt16(a+20,!0),r.getInt16(a+22,!0)],u=r.getUint16(a+24,!0),f=r.getUint16(a+26,!0);o.push({planeIndex:d,children:l,mins:c,maxs:h,firstFace:u,numFaces:f})}return o}function ch(e,t){let r=new DataView(e,t.offset,t.length),n=76,i=t.length/n;if(i%1!==0)throw new j("TexInfo lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n,d=[r.getFloat32(a,!0),r.getFloat32(a+4,!0),r.getFloat32(a+8,!0)],l=r.getFloat32(a+12,!0),c=[r.getFloat32(a+16,!0),r.getFloat32(a+20,!0),r.getFloat32(a+24,!0)],h=r.getFloat32(a+28,!0),u=r.getInt32(a+32,!0),f=r.getInt32(a+36,!0),m=new Uint8Array(e,t.offset+a+40,32),g=new TextDecoder("utf-8").decode(m).replace(/\0.*$/,""),p=r.getInt32(a+72,!0);o.push({s:d,sOffset:l,t:c,tOffset:h,flags:u,value:f,texture:g,nextTexInfo:p})}return o}function dh(e,t){let r=new DataView(e,t.offset,t.length),n=20,i=t.length/n;if(i%1!==0)throw new j("Face lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n,d=r.getUint16(a,!0),l=r.getInt16(a+2,!0),c=r.getInt32(a+4,!0),h=r.getInt16(a+8,!0),u=r.getInt16(a+10,!0),f=[r.getUint8(a+12),r.getUint8(a+13),r.getUint8(a+14),r.getUint8(a+15)],m=r.getInt32(a+16,!0);o.push({planeIndex:d,side:l,firstEdge:c,numEdges:h,texInfo:u,styles:f,lightOffset:m})}return o}function uh(e,t){let r=new DataView(e,t.offset,t.length),n=28,i=t.length/n;if(i%1!==0)throw new j("Leaf lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n,d=r.getInt32(a,!0),l=r.getInt16(a+4,!0),c=r.getInt16(a+6,!0),h=[r.getInt16(a+8,!0),r.getInt16(a+10,!0),r.getInt16(a+12,!0)],u=[r.getInt16(a+14,!0),r.getInt16(a+16,!0),r.getInt16(a+18,!0)],f=r.getUint16(a+20,!0),m=r.getUint16(a+22,!0),g=r.getUint16(a+24,!0),p=r.getUint16(a+26,!0);o.push({contents:d,cluster:l,area:c,mins:h,maxs:u,firstLeafFace:f,numLeafFaces:m,firstLeafBrush:g,numLeafBrushes:p})}return o}function fh(e,t){let r=new DataView(e,t.offset,t.length),n=4,i=t.length/n;if(i%1!==0)throw new j("Edge lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n;o.push({vertices:[r.getUint16(a,!0),r.getUint16(a+2,!0)]})}return o}function hh(e,t){let r=t.length/4;if(r%1!==0)throw new j("SurfEdge lump has invalid length");let n=new DataView(e,t.offset,t.length),i=new Int32Array(r);for(let o=0;o<r;o+=1)i[o]=n.getInt32(o*4,!0);return i}function mh(e,t){let r=new DataView(e,t.offset,t.length),n=48;if(t.length%n!==0)throw new j("Model lump has invalid length");let i=t.length/n,o=[];for(let s=0;s<i;s+=1){let a=s*n,d=[r.getFloat32(a,!0),r.getFloat32(a+4,!0),r.getFloat32(a+8,!0)],l=[r.getFloat32(a+12,!0),r.getFloat32(a+16,!0),r.getFloat32(a+20,!0)],c=[r.getFloat32(a+24,!0),r.getFloat32(a+28,!0),r.getFloat32(a+32,!0)],h=r.getInt32(a+36,!0),u=r.getInt32(a+40,!0),f=r.getInt32(a+44,!0);o.push({mins:d,maxs:l,origin:c,headNode:h,firstFace:u,numFaces:f})}return o}function ph(e,t){let r=new DataView(e,t.offset,t.length),n=12,i=t.length/n;if(i%1!==0)throw new j("Brush lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n;o.push({firstSide:r.getInt32(a,!0),numSides:r.getInt32(a+4,!0),contents:r.getInt32(a+8,!0)})}return o}function gh(e,t){let r=new DataView(e,t.offset,t.length),n=4,i=t.length/n;if(i%1!==0)throw new j("Brush side lump has invalid length");let o=[];for(let s=0;s<i;s+=1){let a=s*n;o.push({planeIndex:r.getUint16(a,!0),texInfo:r.getInt16(a+2,!0)})}return o}function yh(e,t,r,n){let i=[],o=[],s=t.length/2,a=r.length/2,d=new DataView(e,t.offset,t.length),l=new DataView(e,r.offset,r.length);for(let c of n){if(c.firstLeafFace+c.numLeafFaces>s)throw new j("Leaf faces reference data past lump bounds");if(c.firstLeafBrush+c.numLeafBrushes>a)throw new j("Leaf brushes reference data past lump bounds");let h=[];for(let f=0;f<c.numLeafFaces;f+=1)h.push(d.getUint16((c.firstLeafFace+f)*2,!0));let u=[];for(let f=0;f<c.numLeafBrushes;f+=1)u.push(l.getUint16((c.firstLeafBrush+f)*2,!0));i.push(h),o.push(u)}return{leafFaces:i,leafBrushes:o}}function xh(e,t){if(t.length===0)return;if(t.length<4)throw new j("Visibility lump too small");let r=new DataView(e,t.offset,t.length),n=r.getInt32(0,!0),i=4+n*8;if(n<0||i>t.length)throw new j("Visibility lump truncated");let o=4,s=[];for(let a=0;a<n;a+=1){let d=r.getInt32(o,!0),l=r.getInt32(o+4,!0);o+=8;let c=t.offset+d,h=t.offset+l,u=t.offset+t.length;if(d<0||l<0||c>=u||h>=u)throw new j("Visibility offsets out of range");s.push({pvs:$c(e,c,n,t),phs:$c(e,h,n,t)})}return{numClusters:n,clusters:s}}function $c(e,t,r,n){let i=Math.ceil(r/8),o=new Uint8Array(i),s=new Uint8Array(e),a=t,d=0,l=n.offset+n.length;for(;d<i;){if(a>=l)throw new j("Visibility data truncated");let c=s[a++];if(c!==0){o[d++]=c;continue}if(a>=l)throw new j("Visibility run exceeds lump bounds");let h=s[a++];for(let u=0;u<h&&d<i;u+=1)o[d++]=0}return o}function _h(e,t){return e.map(r=>{if(!(r.lightOffset<0))return{offset:r.lightOffset,length:Math.max(0,t.length-r.lightOffset)}})}function Co(e,t,r){if(e.lightOffset<0||e.lightOffset>=t.byteLength)return;let n=t.byteLength-e.lightOffset,i=Math.min(r?.length??n,n);if(!(i<=0))return t.subarray(e.lightOffset,e.lightOffset+i)}var bh=844121161,vh=8,Yc=68,Sh=[{x:-.525731,y:0,z:.850651},{x:-.442863,y:.238856,z:.864188},{x:-.295242,y:0,z:.955423},{x:-.309017,y:.5,z:.809017},{x:-.16246,y:.262866,z:.951056},{x:0,y:0,z:1},{x:0,y:.850651,z:.525731},{x:-.147621,y:.716567,z:.681718},{x:.147621,y:.716567,z:.681718},{x:0,y:.525731,z:.850651},{x:.309017,y:.5,z:.809017},{x:.525731,y:0,z:.850651},{x:.295242,y:0,z:.955423},{x:.442863,y:.238856,z:.864188},{x:.16246,y:.262866,z:.951056},{x:-.681718,y:.147621,z:.716567},{x:-.809017,y:.309017,z:.5},{x:-.587785,y:.425325,z:.688191},{x:-.850651,y:.525731,z:0},{x:-.864188,y:.442863,z:.238856},{x:-.716567,y:.681718,z:.147621},{x:-.688191,y:.587785,z:.425325},{x:-.5,y:.809017,z:.309017},{x:-.238856,y:.864188,z:.442863},{x:-.425325,y:.688191,z:.587785},{x:-.716567,y:.681718,z:-.147621},{x:-.5,y:.809017,z:-.309017},{x:-.525731,y:.850651,z:0},{x:0,y:.850651,z:-.525731},{x:-.238856,y:.864188,z:-.442863},{x:0,y:.955423,z:-.295242},{x:-.262866,y:.951056,z:-.16246},{x:0,y:1,z:0},{x:0,y:.955423,z:.295242},{x:-.262866,y:.951056,z:.16246},{x:.238856,y:.864188,z:.442863},{x:.262866,y:.951056,z:.16246},{x:.5,y:.809017,z:.309017},{x:.238856,y:.864188,z:-.442863},{x:.262866,y:.951056,z:-.16246},{x:.5,y:.809017,z:-.309017},{x:.850651,y:.525731,z:0},{x:.716567,y:.681718,z:.147621},{x:.716567,y:.681718,z:-.147621},{x:.525731,y:.850651,z:0},{x:.425325,y:.688191,z:.587785},{x:.864188,y:.442863,z:.238856},{x:.688191,y:.587785,z:.425325},{x:.809017,y:.309017,z:.5},{x:.681718,y:.147621,z:.716567},{x:.587785,y:.425325,z:.688191},{x:.955423,y:.295242,z:0},{x:1,y:0,z:0},{x:.951056,y:.16246,z:.262866},{x:.850651,y:-.525731,z:0},{x:.955423,y:-.295242,z:0},{x:.864188,y:-.442863,z:.238856},{x:.951056,y:-.16246,z:.262866},{x:.809017,y:-.309017,z:.5},{x:.681718,y:-.147621,z:.716567},{x:.850651,y:0,z:.525731},{x:.864188,y:.442863,z:-.238856},{x:.809017,y:.309017,z:-.5},{x:.951056,y:.16246,z:-.262866},{x:.525731,y:0,z:-.850651},{x:.681718,y:.147621,z:-.716567},{x:.681718,y:-.147621,z:-.716567},{x:.850651,y:0,z:-.525731},{x:.809017,y:-.309017,z:-.5},{x:.864188,y:-.442863,z:-.238856},{x:.951056,y:-.16246,z:-.262866},{x:.147621,y:.716567,z:-.681718},{x:.309017,y:.5,z:-.809017},{x:.425325,y:.688191,z:-.587785},{x:.442863,y:.238856,z:-.864188},{x:.587785,y:.425325,z:-.688191},{x:.688191,y:.587785,z:-.425325},{x:-.147621,y:.716567,z:-.681718},{x:-.309017,y:.5,z:-.809017},{x:0,y:.525731,z:-.850651},{x:-.525731,y:0,z:-.850651},{x:-.442863,y:.238856,z:-.864188},{x:-.295242,y:0,z:-.955423},{x:-.16246,y:.262866,z:-.951056},{x:0,y:0,z:-1},{x:.295242,y:0,z:-.955423},{x:.16246,y:.262866,z:-.951056},{x:-.442863,y:-.238856,z:-.864188},{x:-.309017,y:-.5,z:-.809017},{x:-.16246,y:-.262866,z:-.951056},{x:0,y:-.850651,z:-.525731},{x:-.147621,y:-.716567,z:-.681718},{x:.147621,y:-.716567,z:-.681718},{x:0,y:-.525731,z:-.850651},{x:.309017,y:-.5,z:-.809017},{x:.442863,y:-.238856,z:-.864188},{x:.16246,y:-.262866,z:-.951056},{x:.238856,y:-.864188,z:-.442863},{x:.5,y:-.809017,z:-.309017},{x:.425325,y:-.688191,z:-.587785},{x:.716567,y:-.681718,z:-.147621},{x:.688191,y:-.587785,z:-.425325},{x:.587785,y:-.425325,z:-.688191},{x:0,y:-.955423,z:-.295242},{x:0,y:-1,z:0},{x:.262866,y:-.951056,z:-.16246},{x:0,y:-.850651,z:.525731},{x:0,y:-.955423,z:.295242},{x:.238856,y:-.864188,z:.442863},{x:.262866,y:-.951056,z:.16246},{x:.5,y:-.809017,z:.309017},{x:.716567,y:-.681718,z:.147621},{x:.525731,y:-.850651,z:0},{x:-.238856,y:-.864188,z:-.442863},{x:-.5,y:-.809017,z:-.309017},{x:-.262866,y:-.951056,z:-.16246},{x:-.850651,y:-.525731,z:0},{x:-.716567,y:-.681718,z:-.147621},{x:-.716567,y:-.681718,z:.147621},{x:-.525731,y:-.850651,z:0},{x:-.5,y:-.809017,z:.309017},{x:-.238856,y:-.864188,z:.442863},{x:-.262866,y:-.951056,z:.16246},{x:-.864188,y:-.442863,z:.238856},{x:-.809017,y:-.309017,z:.5},{x:-.688191,y:-.587785,z:.425325},{x:-.681718,y:-.147621,z:.716567},{x:-.442863,y:-.238856,z:.864188},{x:-.587785,y:-.425325,z:.688191},{x:-.309017,y:-.5,z:.809017},{x:-.147621,y:-.716567,z:.681718},{x:-.425325,y:-.688191,z:.587785},{x:-.16246,y:-.262866,z:.951056},{x:.442863,y:-.238856,z:.864188},{x:.16246,y:-.262866,z:.951056},{x:.309017,y:-.5,z:.809017},{x:.147621,y:-.716567,z:.681718},{x:0,y:-.525731,z:.850651},{x:.425325,y:-.688191,z:.587785},{x:.587785,y:-.425325,z:.688191},{x:.688191,y:-.587785,z:.425325},{x:-.955423,y:.295242,z:0},{x:-.951056,y:.16246,z:.262866},{x:-1,y:0,z:0},{x:-.850651,y:0,z:.525731},{x:-.955423,y:-.295242,z:0},{x:-.951056,y:-.16246,z:.262866},{x:-.864188,y:.442863,z:-.238856},{x:-.951056,y:.16246,z:-.262866},{x:-.809017,y:.309017,z:-.5},{x:-.864188,y:-.442863,z:-.238856},{x:-.951056,y:-.16246,z:-.262866},{x:-.809017,y:-.309017,z:-.5},{x:-.681718,y:.147621,z:-.716567},{x:-.681718,y:-.147621,z:-.716567},{x:-.850651,y:0,z:-.525731},{x:-.688191,y:.587785,z:-.425325},{x:-.587785,y:.425325,z:-.688191},{x:-.425325,y:.688191,z:-.587785},{x:-.425325,y:-.688191,z:-.587785},{x:-.587785,y:-.425325,z:-.688191},{x:-.688191,y:-.587785,z:-.425325}],pe=class extends Error{},Zr=class{constructor(t){this.vfs=t;this.cache=new Map}async load(t){if(this.cache.has(t))return this.cache.get(t);let r=await this.vfs.readFile(t),n=new Uint8Array(r.byteLength);n.set(r);let i=Ba(n.buffer);return this.cache.set(t,i),i}get(t){return this.cache.get(t)}};function qc(e,t,r){let n=[];for(let i=0;i<r;i+=1){let o=e.getUint8(t+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function Vn(e,t,r,n){if(r!==0&&(t<Yc||t+r>e.byteLength))throw new pe(`${n} section is out of bounds`)}function wh(e){if(e.byteLength<Yc)throw new pe("MD2 buffer too small to contain header");let t=new DataView(e),r=t.getInt32(0,!0),n=t.getInt32(4,!0);if(r!==bh)throw new pe(`Invalid MD2 ident: ${r}`);if(n!==vh)throw new pe(`Unsupported MD2 version: ${n}`);let i={ident:r,version:n,skinWidth:t.getInt32(8,!0),skinHeight:t.getInt32(12,!0),frameSize:t.getInt32(16,!0),numSkins:t.getInt32(20,!0),numVertices:t.getInt32(24,!0),numTexCoords:t.getInt32(28,!0),numTriangles:t.getInt32(32,!0),numGlCommands:t.getInt32(36,!0),numFrames:t.getInt32(40,!0),offsetSkins:t.getInt32(44,!0),offsetTexCoords:t.getInt32(48,!0),offsetTriangles:t.getInt32(52,!0),offsetFrames:t.getInt32(56,!0),offsetGlCommands:t.getInt32(60,!0),offsetEnd:t.getInt32(64,!0),magic:r},o=40+i.numVertices*4;if(i.frameSize!==o)throw new pe(`Unexpected frame size ${i.frameSize}, expected ${o}`);if(i.offsetEnd>e.byteLength)throw new pe("MD2 offset_end exceeds buffer length");return i}function Ah(e,t){let r=t.numSkins*64;Vn(e,t.offsetSkins,r,"skins");let n=new DataView(e,t.offsetSkins,r),i=[];for(let o=0;o<t.numSkins;o+=1)i.push({name:qc(n,o*64,64)});return i}function Mh(e,t){let r=t.numTexCoords*4;Vn(e,t.offsetTexCoords,r,"texcoords");let n=new DataView(e,t.offsetTexCoords,r),i=[];for(let o=0;o<t.numTexCoords;o+=1){let s=o*4;i.push({s:n.getInt16(s,!0),t:n.getInt16(s+2,!0)})}return i}function Eh(e,t){let r=t.numTriangles*12;Vn(e,t.offsetTriangles,r,"triangles");let n=new DataView(e,t.offsetTriangles,r),i=[];for(let o=0;o<t.numTriangles;o+=1){let s=o*12,a=[n.getUint16(s,!0),n.getUint16(s+2,!0),n.getUint16(s+4,!0)],d=[n.getUint16(s+6,!0),n.getUint16(s+8,!0),n.getUint16(s+10,!0)];if(a.some(l=>l>=t.numVertices)||d.some(l=>l>=t.numTexCoords))throw new pe("Triangle references out of range vertex or texcoord");i.push({vertexIndices:a,texCoordIndices:d})}return i}function Lh(e,t){let r=t.numFrames*t.frameSize;Vn(e,t.offsetFrames,r,"frames");let n=[];for(let i=0;i<t.numFrames;i+=1){let o=t.offsetFrames+i*t.frameSize,s=new DataView(e,o,t.frameSize),a={x:s.getFloat32(0,!0),y:s.getFloat32(4,!0),z:s.getFloat32(8,!0)},d={x:s.getFloat32(12,!0),y:s.getFloat32(16,!0),z:s.getFloat32(20,!0)},l=qc(s,24,16),c=[],h=1/0,u=1/0,f=1/0,m=-1/0,g=-1/0,p=-1/0;for(let y=0;y<t.numVertices;y+=1){let S=40+y*4,_=s.getUint8(S)*a.x+d.x,x=s.getUint8(S+1)*a.y+d.y,b=s.getUint8(S+2)*a.z+d.z;_<h&&(h=_),x<u&&(u=x),b<f&&(f=b),_>m&&(m=_),x>g&&(g=x),b>p&&(p=b);let A={x:_,y:x,z:b},v=s.getUint8(S+3),E=Sh[v];if(!E)throw new pe(`Invalid normal index ${v} in frame ${l}`);c.push({position:A,normalIndex:v,normal:E})}n.push({name:l,vertices:c,minBounds:{x:h,y:u,z:f},maxBounds:{x:m,y:g,z:p}})}return n}function Th(e,t){let r=t.numGlCommands*4;if(Vn(e,t.offsetGlCommands,r,"gl commands"),r===0)return[];let n=new DataView(e,t.offsetGlCommands,r),i=[],o=0;for(;;){if(o+4>r)throw new pe("GL command list ended unexpectedly");let s=n.getInt32(o,!0);if(o+=4,s===0)break;let a=Math.abs(s),d=[],l=a*12;if(o+l>r)throw new pe("GL command vertex block exceeds buffer");for(let c=0;c<a;c+=1){let h=n.getFloat32(o,!0),u=n.getFloat32(o+4,!0),f=n.getInt32(o+8,!0);if(o+=12,f<0||f>=t.numVertices)throw new pe("GL command references invalid vertex index");d.push({s:h,t:u,vertexIndex:f})}i.push({mode:s>0?"strip":"fan",vertices:d})}if(o!==r)throw new pe("GL command list did not consume expected data");return i}function Ba(e){let t=wh(e),r=Ah(e,t),n=Mh(e,t),i=Eh(e,t),o=Lh(e,t),s=Th(e,t);return{header:t,skins:r,texCoords:n,triangles:i,frames:o,glCommands:s}}function jc(e){let t=[],r=0;for(;r<e.length;){let n=e[r].name,i=n.replace(/\d+$/,"")||n,o=r;for(;o+1<e.length&&(e[o+1].name.replace(/\d+$/,"")||e[o+1].name)===i;)o+=1;t.push({name:i,firstFrame:r,lastFrame:o}),r=o+1}return t}var Qc=860898377,Ih=15,Ge=class extends Error{constructor(t){super(t),this.name="Md3ParseError"}};function Gn(e,t,r){let n=new Uint8Array(e.buffer,e.byteOffset+t,r);return new TextDecoder("utf-8").decode(n).replace(/\0.*$/,"").trim()}function Rh(e){let t=(e>>8&255)*(2*Math.PI/255),r=(e&255)*(2*Math.PI/255),n=Math.sin(r);return{x:Math.cos(t)*n,y:Math.sin(t)*n,z:Math.cos(r)}}function zo(e,t,r,n){if(t<0||t+r>n)throw new Ge(`${e} exceeds buffer bounds`)}function Ch(e){let t=e.getInt32(0,!0);if(t!==Qc)throw new Ge(`Invalid MD3 ident: ${t}`);let r=e.getInt32(4,!0);if(r!==Ih)throw new Ge(`Unsupported MD3 version: ${r}`);let n=Gn(e,8,64),i=e.getInt32(72,!0),o=e.getInt32(76,!0),s=e.getInt32(80,!0),a=e.getInt32(84,!0),d=e.getInt32(88,!0),l=e.getInt32(92,!0),c=e.getInt32(96,!0),h=e.getInt32(100,!0),u=e.getInt32(104,!0);if(o<=0||a<0||s<0)throw new Ge("Invalid MD3 counts");return{ident:t,version:r,name:n,flags:i,numFrames:o,numTags:s,numSurfaces:a,numSkins:d,ofsFrames:l,ofsTags:c,ofsSurfaces:h,ofsEnd:u,magic:t}}function zh(e,t){let r=[];zo("Frames",t.ofsFrames,t.numFrames*56,e.byteLength);for(let i=0;i<t.numFrames;i+=1){let o=t.ofsFrames+i*56;r.push({minBounds:{x:e.getFloat32(o,!0),y:e.getFloat32(o+4,!0),z:e.getFloat32(o+8,!0)},maxBounds:{x:e.getFloat32(o+12,!0),y:e.getFloat32(o+16,!0),z:e.getFloat32(o+20,!0)},localOrigin:{x:e.getFloat32(o+24,!0),y:e.getFloat32(o+28,!0),z:e.getFloat32(o+32,!0)},radius:e.getFloat32(o+36,!0),name:Gn(e,o+40,16)})}return r}function Fh(e,t){let r=[],i=t.numFrames*t.numTags*112;zo("Tags",t.ofsTags,i,e.byteLength);for(let o=0;o<t.numFrames;o+=1){let s=[];for(let a=0;a<t.numTags;a+=1){let d=t.ofsTags+(o*t.numTags+a)*112,l=d+64,c=l+12;s.push({name:Gn(e,d,64),origin:{x:e.getFloat32(l,!0),y:e.getFloat32(l+4,!0),z:e.getFloat32(l+8,!0)},axis:[{x:e.getFloat32(c,!0),y:e.getFloat32(c+4,!0),z:e.getFloat32(c+8,!0)},{x:e.getFloat32(c+12,!0),y:e.getFloat32(c+16,!0),z:e.getFloat32(c+20,!0)},{x:e.getFloat32(c+24,!0),y:e.getFloat32(c+28,!0),z:e.getFloat32(c+32,!0)}]})}r.push(s)}return r}function kh(e,t){let r=e.getInt32(t,!0);if(r!==Qc)throw new Ge(`Invalid surface ident at ${t}: ${r}`);let n=Gn(e,t+4,64),i=e.getInt32(t+68,!0),o=e.getInt32(t+72,!0),s=e.getInt32(t+76,!0),a=e.getInt32(t+80,!0),d=e.getInt32(t+84,!0),l=e.getInt32(t+88,!0),c=e.getInt32(t+92,!0),h=e.getInt32(t+96,!0),u=e.getInt32(t+100,!0),f=e.getInt32(t+104,!0);if(o<=0||a<=0||d<=0)throw new Ge(`Invalid surface counts for ${n}`);let m=f;zo(`Surface ${n}`,t,m,e.byteLength);let g=[],p=t+l;for(let v=0;v<d;v+=1){let E=p+v*12;g.push({indices:[e.getInt32(E,!0),e.getInt32(E+4,!0),e.getInt32(E+8,!0)]})}let y=[],S=t+c;for(let v=0;v<s;v+=1){let E=S+v*68;y.push({name:Gn(e,E,64),shaderIndex:e.getInt32(E+64,!0)})}let _=[],x=t+h;for(let v=0;v<a;v+=1){let E=x+v*8;_.push({s:e.getFloat32(E,!0),t:e.getFloat32(E+4,!0)})}let b=[],A=t+u;for(let v=0;v<o;v+=1){let E=[];for(let L=0;L<a;L+=1){let w=A+(v*a+L)*8,T=e.getInt16(w,!0)/64,z=e.getInt16(w+2,!0)/64,U=e.getInt16(w+4,!0)/64,C=e.getUint16(w+6,!0);E.push({position:{x:T,y:z,z:U},latLng:C,normal:Rh(C)})}b.push(E)}return{surface:{name:n,flags:i,numFrames:o,shaders:y,triangles:g,texCoords:_,vertices:b},nextOffset:t+f}}function Da(e){if(e.byteLength<108)throw new Ge("MD3 buffer too small for header");let t=new DataView(e),r=Ch(t);zo("MD3 end",r.ofsEnd,0,e.byteLength);let n=zh(t,r),i=Fh(t,r),o=[],s=r.ofsSurfaces;for(let a=0;a<r.numSurfaces;a+=1){let{surface:d,nextOffset:l}=kh(t,s);o.push(d),s=l}if(s!==r.ofsEnd)throw new Ge("Surface parsing did not reach ofsEnd");return{header:r,frames:n,tags:i,surfaces:o}}var Yr=class{constructor(t){this.vfs=t;this.cache=new Map}async load(t){if(this.cache.has(t))return this.cache.get(t);let r=await this.vfs.readFile(t),n=Da(r.slice().buffer);return this.cache.set(t,n),n}get(t){return this.cache.get(t)}};var Bh=844317769,Dh=2,Jc=64,ed=12,Ot=class extends Error{};function Ph(e,t,r){let n=[];for(let i=0;i<r;i+=1){let o=e.getUint8(t+i);if(o===0)break;n.push(o)}return String.fromCharCode(...n)}function Pa(e){if(e.byteLength<ed)throw new Ot("Sprite buffer too small to contain header");let t=new DataView(e),r=t.getInt32(0,!0),n=t.getInt32(4,!0),i=t.getInt32(8,!0);if(r!==Bh)throw new Ot(`Invalid Sprite ident: ${r}`);if(n!==Dh)throw new Ot(`Unsupported Sprite version: ${n}`);let o=[],s=16+Jc,a=ed;for(let d=0;d<i;d+=1){if(a+s>e.byteLength)throw new Ot("Sprite frame data exceeds buffer length");let l=t.getInt32(a,!0),c=t.getInt32(a+4,!0),h=t.getInt32(a+8,!0),u=t.getInt32(a+12,!0),f=Ph(t,a+16,Jc);o.push({width:l,height:c,originX:h,originY:u,name:f}),a+=s}return{ident:r,version:n,numFrames:i,frames:o}}var qr=class{constructor(t){this.vfs=t}async load(t){let r=await this.vfs.readFile(t),n=new Uint8Array(r.byteLength);return n.set(r),Pa(n.buffer)}};function td(e,t){let r=(e.sequence.end-e.sequence.start+1)/e.sequence.fps,n=e.sequence.loop!==!1,i=e.time+t;return n?i=(i%r+r)%r:i>r&&(i=r),{...e,time:Math.max(0,Math.min(i,r))}}function rd(e){let t=e.sequence.end-e.sequence.start+1,r=1/e.sequence.fps,n=e.sequence.loop!==!1,i=e.time/r;if(!n&&i>=t)return{frame0:e.sequence.end,frame1:e.sequence.end,lerp:0};let o=n?i%t:Math.min(i,t-1),s=Math.floor(o),a=e.sequence.start+s,d=s+1>=t?n?e.sequence.start:e.sequence.end:a+1,l=!n&&s>=t-1?0:o-s;return{frame0:a,frame1:d,lerp:l}}function nd(e){return{sequence:e,time:0}}function id(e,t,r){return{x:e.x+(t.x-e.x)*r,y:e.y+(t.y-e.y)*r,z:e.z+(t.z-e.z)*r}}var Wn=class extends Error{constructor(t){super(t),this.name="WalParseError"}};function Fo(e){if(e.byteLength<100)throw new Wn("WAL buffer too small");let t=new DataView(e),r=new Uint8Array(e,0,32),n=new TextDecoder("utf-8").decode(r).replace(/\0.*$/,"").trim(),i=t.getInt32(32,!0),o=t.getInt32(36,!0),s=[t.getInt32(40,!0),t.getInt32(44,!0),t.getInt32(48,!0),t.getInt32(52,!0)],a=new Uint8Array(e,56,32),d=new TextDecoder("utf-8").decode(a).replace(/\0.*$/,"").trim(),l=t.getInt32(88,!0),c=t.getInt32(92,!0),h=t.getInt32(96,!0);if(i<=0||o<=0)throw new Wn("Invalid WAL dimensions");let u=[],f=i,m=o;for(let g=0;g<s.length;g+=1){let p=s[g],y=Math.max(1,f*m|0);if(p<=0||p+y>e.byteLength)throw new Wn(`Invalid WAL mip offset for level ${g}`);let S=new Uint8Array(e,p,y);u.push({level:g,width:f,height:m,data:S}),f=Math.max(1,f>>1),m=Math.max(1,m>>1)}return{name:n,width:i,height:o,mipmaps:u,animName:d,flags:l,contents:c,value:h}}var ur=class extends Error{constructor(t){super(t),this.name="PcxParseError"}};function Xn(e){if(e.byteLength<128)throw new ur("PCX buffer too small for header");let t=new DataView(e),r=t.getUint8(0),n=t.getUint8(2),i=t.getUint8(3),o=t.getUint16(4,!0),s=t.getUint16(6,!0),a=t.getUint16(8,!0),d=t.getUint16(10,!0);if(r!==10||n!==1)throw new ur("Unsupported PCX encoding");if(i!==8)throw new ur("Only 8bpp PCX files are supported");let l=a-o+1,c=d-s+1,h=t.getUint16(66,!0),u=e.byteLength-769;if(u<128||new DataView(e,u,1).getUint8(0)!==12)throw new ur("Missing PCX palette");let f=new Uint8Array(e,u+1,768),m=new Uint8Array(e,128,u-128),g=new Uint8Array(l*c),p=0,y=0;for(let S=0;S<c;S+=1){let _=0;for(;_<h&&p<m.length;){let x=1,b=m[p++];if((b&192)===192){if(x=b&63,p>=m.length)throw new ur("Unexpected end of PCX RLE data");b=m[p++]}for(let A=0;A<x&&_<h;A+=1)_<l&&(g[y++]=b),_+=1}}return{width:l,height:c,bitsPerPixel:i,pixels:g,palette:f}}function ko(e){let t=new Uint8Array(e.width*e.height*4);for(let r=0;r<e.pixels.length;r+=1){let n=e.pixels[r],i=n*3,o=r*4;t[o]=e.palette[i],t[o+1]=e.palette[i+1],t[o+2]=e.palette[i+2],t[o+3]=n===255?0:255}return t}var yt=class extends Error{constructor(t){super(t),this.name="TgaParseError"}};function Oa(e){let t=new DataView(e);if(e.byteLength<18)throw new yt("Buffer too small for TGA header");let r=t.getUint8(0),n=t.getUint8(1),i=t.getUint8(2),o=t.getUint16(12,!0),s=t.getUint16(14,!0),a=t.getUint8(16),d=t.getUint8(17);if(i!==2&&i!==10&&i!==3&&i!==11)throw new yt(`Unsupported TGA image type: ${i} (only RGB/Grayscale supported)`);if(a!==24&&a!==32&&a!==8)throw new yt(`Unsupported pixel depth: ${a} (only 8, 24, 32 bpp supported)`);let l=i>=9,c=i===3||i===11,h=a/8,u=18+r;if(n===1){let _=t.getUint16(5,!0),x=t.getUint8(7);u+=_*(x/8)}let f=o*s,m=new Uint8Array(f*4),g=(d&32)!==0,p=0,y=new Uint8Array(e),S=_=>{if(c){let x=y[u++];m[_]=x,m[_+1]=x,m[_+2]=x,m[_+3]=255}else{let x=y[u++],b=y[u++],A=y[u++],v=a===32?y[u++]:255;m[_]=A,m[_+1]=b,m[_+2]=x,m[_+3]=v}};if(l){let _=0;for(;_<f;){if(u>=e.byteLength)throw new yt("Unexpected end of TGA RLE data");let x=y[u++],b=(x&127)+1,A=(x&128)!==0;if(_+b>f)throw new yt("TGA RLE packet exceeds image bounds");if(A){let v=c?y[u]:y[u+2],E=c?y[u]:y[u+1],L=y[u],w=c?255:a===32?y[u+3]:255;u+=h;for(let T=0;T<b;T++){let z=(_+T)*4;m[z]=v,m[z+1]=E,m[z+2]=L,m[z+3]=w}}else for(let v=0;v<b;v++)S((_+v)*4);_+=b}}else for(let _=0;_<f;_++){if(u>=e.byteLength)throw new yt("Unexpected end of TGA data");S(_*4)}if(!g){let _=o*4,x=new Uint8Array(_);for(let b=0;b<s/2;b++){let A=b*_,v=(s-1-b)*_;x.set(m.subarray(A,A+_)),m.set(m.subarray(v,v+_),A),m.set(x,v)}}return{width:o,height:s,bitsPerPixel:32,pixels:m}}var jr=class{constructor(t={}){this.cache=new Pt(t.capacity??128)}get size(){return this.cache.size}get(t){return this.cache.get(t.toLowerCase())}set(t,r){this.cache.set(t.toLowerCase(),r)}clear(){this.cache.clear()}};function Na(e,t){let r=[];for(let n of e.mipmaps){let i=new Uint8Array(n.width*n.height*4);for(let o=0;o<n.data.length;o+=1){let s=n.data[o],a=s*3,d=o*4;i[d]=t[a],i[d+1]=t[a+1],i[d+2]=t[a+2],i[d+3]=s===255?0:255}r.push({level:n.level,width:n.width,height:n.height,rgba:i})}return{width:e.width,height:e.height,levels:r,source:"wal"}}function Bo(e){let t=ko(e),r={level:0,width:e.width,height:e.height,rgba:t};return{width:e.width,height:e.height,levels:[r],source:"pcx"}}function od(e){let t={level:0,width:e.width,height:e.height,rgba:e.pixels};return{width:e.width,height:e.height,levels:[t],source:"tga"}}function Do(e,t){return Na(Fo(e),t)}var fr=class extends Error{constructor(t){super(t),this.name="WavParseError"}};function Ua(e,t,r){return new TextDecoder("ascii").decode(new Uint8Array(e.buffer,e.byteOffset+t,r))}function Po(e){if(e.byteLength<44)throw new fr("WAV buffer too small");let t=new DataView(e);if(Ua(t,0,4)!=="RIFF"||Ua(t,8,4)!=="WAVE")throw new fr("Invalid WAV header");let r=12,n=-1,i=-1,o=0,s=0;for(;r+8<=e.byteLength;){let m=Ua(t,r,4),g=t.getUint32(r+4,!0),p=r+8;m==="fmt "?(n=p,o=g):m==="data"&&(i=p,s=g),r=p+g}if(n===-1||i===-1)throw new fr("Missing fmt or data chunk");let a=t.getUint16(n,!0),d=t.getUint16(n+2,!0),l=t.getUint32(n+4,!0),c=t.getUint16(n+14,!0);if(a!==1)throw new fr("Only PCM WAV is supported");let h=c/8,u=s/(h*d),f=new Float32Array(u*d);for(let m=0;m<u;m+=1)for(let g=0;g<d;g+=1){let p=m*d+g,y=i+p*h,S=0;if(c===8)S=t.getUint8(y),f[p]=(S-128)/128;else if(c===16)S=t.getInt16(y,!0),f[p]=S/32768;else if(c===24){let _=t.getUint8(y),x=t.getUint8(y+1),b=t.getInt8(y+2);S=_|x<<8|b<<16,f[p]=S/8388608}else throw new fr(`Unsupported bitsPerSample: ${c}`)}return{sampleRate:l,channels:d,bitsPerSample:c,samples:f}}var Oh=(e,t=4294967295,r=79764919)=>{let n=new Int32Array(256),i,o,s,a=t;for(i=0;i<256;i++){for(s=i<<24,o=8;o>0;--o)s=2147483648&s?s<<1^r:s<<1;n[i]=s}for(i=0;i<e.length;i++)a=a<<8^n[255&(a>>24^e[i])];return a};var Ha=(e,t=Oh)=>{let r=p=>new Uint8Array(p.length/2).map(((y,S)=>parseInt(p.substring(2*S,2*(S+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(e.length),s,a,d,l=!1,c=0,h=42,u=e.length>13&&e.substring(0,9)==="dynEncode",f=0;u&&(f=11,a=n(e.substring(9,f)),a<=1&&(f+=2,h=n(e.substring(11,f))),a===1&&(f+=8,d=(p=>new DataView(r(p).buffer).getInt32(0,!0))(e.substring(13,f))));let m=256-h;for(let p=f;p<e.length;p++)if(s=e.charCodeAt(p),s!==61||l){if(s===92&&p<e.length-5&&u){let y=e.charCodeAt(p+1);y!==117&&y!==85||(s=parseInt(e.substring(p+2,p+6),16),p+=5)}if(s>255){let y=i.get(s);y&&(s=y+127)}l&&(l=!1,s-=64),o[c++]=s<h&&s>0?s+m:s-h}else l=!0;let g=o.subarray(0,c);if(u&&a===1){let p=t(g);if(p!==d){let y="Decode failed crc32 validation";throw console.error("`simple-yenc`\n",y+`
|
|
1
|
+
"use strict";var Quake2Engine=(()=>{var Gu=Object.create;var _s=Object.defineProperty;var Wu=Object.getOwnPropertyDescriptor;var Xu=Object.getOwnPropertyNames;var Ku=Object.getPrototypeOf,$u=Object.prototype.hasOwnProperty;var Zu=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),pa=(e,t)=>{for(var r in t)_s(e,r,{get:t[r],enumerable:!0})},Mc=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of Xu(t))!$u.call(e,i)&&i!==r&&_s(e,i,{get:()=>t[i],enumerable:!(n=Wu(t,i))||n.enumerable});return e};var Yu=(e,t,r)=>(r=e!=null?Gu(Ku(e)):{},Mc(t||!e||!e.__esModule?_s(r,"default",{value:e,enumerable:!0}):r,e)),qu=e=>Mc(_s({},"__esModule",{value:!0}),e);var ad=Zu((G_,od)=>{"use strict";od.exports=Worker});var gx={};pa(gx,{ATTN_IDLE:()=>Ra,ATTN_LOOP_NONE:()=>Ta,ATTN_NONE:()=>Pn,ATTN_NORM:()=>Ia,ATTN_STATIC:()=>Es,AssetDependencyError:()=>Er,AssetDependencyTracker:()=>Ui,AssetManager:()=>go,AudioApi:()=>Xr,AudioContextController:()=>yo,AudioRegistry:()=>gn,AudioRegistryError:()=>Oi,AudioSystem:()=>Ao,BSP_SURFACE_FRAGMENT_SOURCE:()=>ml,BSP_SURFACE_VERTEX_SOURCE:()=>hl,BSP_VERTEX_LAYOUT:()=>dl,BspLoader:()=>$r,BspParseError:()=>j,BspSurfacePipeline:()=>To,Camera:()=>Fo,Command:()=>Fn,CommandRegistry:()=>Nr,ConfigStringRegistry:()=>Wr,Cvar:()=>Un,CvarRegistry:()=>Vr,DemoPlaybackController:()=>ms,DemoReader:()=>Lr,EngineHost:()=>Gr,EngineRuntime:()=>Hn,FixedTimestepLoop:()=>cr,Framebuffer:()=>Eo,IndexBuffer:()=>xe,LruCache:()=>Ot,MAX_SOUND_CHANNELS:()=>On,MD2_FRAGMENT_SHADER:()=>vl,MD2_VERTEX_SHADER:()=>bl,MD3_FRAGMENT_SHADER:()=>Rl,MD3_VERTEX_SHADER:()=>Il,Md2Loader:()=>Zr,Md2MeshBuffers:()=>Ro,Md2ParseError:()=>pe,Md2Pipeline:()=>Co,Md3Loader:()=>Yr,Md3ModelMesh:()=>ko,Md3ParseError:()=>Ge,Md3Pipeline:()=>Bo,Md3SurfaceMesh:()=>Gi,MusicSystem:()=>Mo,NetworkMessageParser:()=>Or,PARTICLE_FRAGMENT_SHADER:()=>zl,PARTICLE_VERTEX_SHADER:()=>Cl,PROTOCOL_VERSION_RERELEASE:()=>qo,PakArchive:()=>Kr,PakIndexStore:()=>po,PakIngestionError:()=>Dt,PakParseError:()=>Ve,PakValidationError:()=>dr,PakValidator:()=>Ts,ParticleRenderer:()=>Oo,ParticleSystem:()=>Do,PlaybackState:()=>ma,RERELEASE_KNOWN_PAKS:()=>za,SKYBOX_FRAGMENT_SHADER:()=>xl,SKYBOX_VERTEX_SHADER:()=>yl,SOUND_FULLVOLUME:()=>kt,SOUND_LOOP_ATTENUATE:()=>Ca,ShaderProgram:()=>Ee,SkyboxPipeline:()=>Io,SoundChannel:()=>st,SoundPrecache:()=>bo,SoundRegistry:()=>_o,SpriteLoader:()=>qr,SpriteParseError:()=>Pt,Texture2D:()=>yn,TextureCache:()=>jr,TextureCubeMap:()=>xn,TgaParseError:()=>yt,U_ALPHA:()=>uc,U_ANGLE1:()=>sa,U_ANGLE2:()=>ea,U_ANGLE3:()=>ta,U_EFFECTS16:()=>fs,U_EFFECTS8:()=>cs,U_EVENT:()=>na,U_FRAME16:()=>aa,U_FRAME8:()=>ra,U_INSTANCE_BITS:()=>hc,U_LOOP_ATTENUATION_HIGH:()=>pc,U_LOOP_VOLUME:()=>mc,U_MODEL:()=>oa,U_MODEL2:()=>la,U_MODEL3:()=>ca,U_MODEL4:()=>da,U_OLDORIGIN:()=>ua,U_OLD_FRAME_HIGH:()=>yc,U_ORIGIN1:()=>Qo,U_ORIGIN2:()=>Jo,U_ORIGIN3:()=>ia,U_OWNER_HIGH:()=>gc,U_REMOVE:()=>dc,U_RENDERFX16:()=>us,U_RENDERFX8:()=>ls,U_SCALE:()=>fc,U_SKIN16:()=>hs,U_SKIN8:()=>ds,U_SOLID:()=>ha,U_SOUND:()=>fa,VertexArray:()=>ze,VertexBuffer:()=>Le,VirtualFileSystem:()=>Ls,advanceAnimation:()=>td,applySurfaceState:()=>Zd,attenuationToDistanceMultiplier:()=>Bt,boxIntersectsFrustum:()=>Vi,buildBspGeometry:()=>Hd,buildMd2Geometry:()=>Sl,buildMd2VertexData:()=>wl,buildMd3SurfaceGeometry:()=>Ll,buildMd3VertexData:()=>Tl,calculateMaxAudibleDistance:()=>Nn,calculatePakChecksum:()=>Gc,computeFrameBlend:()=>rd,computeSkyScroll:()=>jd,createAnimationState:()=>nd,createAudioGraph:()=>xo,createBspSurfaces:()=>Ud,createEmptyEntityState:()=>Dr,createEmptyProtocolPlayerState:()=>jo,createEngine:()=>px,createEngineRuntime:()=>Hc,createFaceLightmap:()=>Rs,createInitialChannels:()=>vo,createProgramFromSources:()=>Nd,createWebGLContext:()=>Od,decodeOgg:()=>mo,deriveSurfaceRenderState:()=>gl,extractFrustumPlanes:()=>Vd,filesToPakSources:()=>Fa,findLeafForPoint:()=>fl,gatherVisibleFaces:()=>Kd,groupMd2Animations:()=>jc,ingestPakFiles:()=>Wc,ingestPaks:()=>Is,interpolateMd3Tag:()=>p0,interpolateVec3:()=>id,parseBsp:()=>ka,parseMd2:()=>Ba,parseMd3:()=>Da,parsePcx:()=>Xn,parseSprite:()=>Oa,parseTga:()=>Pa,parseWal:()=>zs,parseWalTexture:()=>Bs,parseWav:()=>Ds,pcxToRgba:()=>Fs,pickChannel:()=>So,preparePcxTexture:()=>ks,removeViewTranslation:()=>qd,resolveLightStyles:()=>pl,spatializeOrigin:()=>wo,spawnBlood:()=>x0,spawnBulletImpact:()=>g0,spawnExplosion:()=>y0,spawnMuzzleFlash:()=>b0,spawnTeleportFlash:()=>_0,spawnTrail:()=>v0,walToRgba:()=>Na,wireDropTarget:()=>Xc,wireFileInput:()=>Kc});var ju=()=>typeof performance<"u"?performance.now():Date.now(),Qu=e=>{typeof requestAnimationFrame=="function"?requestAnimationFrame(()=>e()):setTimeout(e,25)},cr=class{constructor(t,r={}){this.callbacks=t;this.accumulatorMs=0;this.frame=0;this.running=!1;this.tick=()=>{if(!this.running)return;let t=this.options.now(),r=this.lastTimeMs===void 0?0:t-this.lastTimeMs;this.lastTimeMs=t,this.advance(r,t),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??ju,schedule:r.schedule??Qu}}start(){this.running||(this.running=!0,this.lastTimeMs=this.options.startTimeMs??this.options.now(),this.options.schedule(this.tick))}stop(){this.running=!1}pump(t){let r=(this.lastTimeMs??0)+t;this.lastTimeMs=r,this.advance(t,r)}isRunning(){return this.running}get frameNumber(){return this.frame}advance(t,r){let n=Math.min(Math.max(t,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 s=this.options.fixedDeltaMs===0?0:this.accumulatorMs/this.options.fixedDeltaMs;this.callbacks.render?.({alpha:s,nowMs:r,accumulatorMs:this.accumulatorMs,frame:this.frame})}};var Fn=class{constructor(t,r,n){this.name=t,this.callback=r,this.description=n}execute(t){this.callback(t)}},Nr=class{constructor(){this.commands=new Map}register(t,r,n){let i=new Fn(t,r,n);return this.commands.set(t,i),i}get(t){return this.commands.get(t)}execute(t){let r=this.tokenize(t);if(r.length===0)return!1;let n=r[0],i=r.slice(1),s=this.get(n);return s?(s.execute(i),!0):!1}tokenize(t){return t.trim().split(/\s+/)}list(){return[...this.commands.values()].sort((t,r)=>t.name.localeCompare(r.name))}};var Ju=Object.defineProperty,Ec=(e,t)=>{for(var r in t)Ju(e,r,{get:t[r],enumerable:!0})},Lc={x:0,y:0,z:0};var bx=Math.PI/180;function Tc(e,t){return{x:e.x-t.x,y:e.y-t.y,z:e.z-t.z}}function ef(e,t){return{x:e.x*t,y:e.y*t,z:e.z*t}}function xa(e,t){return e.x*t.x+e.y*t.y+e.z*t.z}function tf(e){return xa(e,e)}function _a(e){return Math.sqrt(tf(e))}function Je(e){let t=_a(e);return t===0?e:ef(e,1/t)}var rf=Math.PI/180,vx=180/Math.PI,Hr=rf;var ya=[[-.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]];function nf(){return new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])}function Ic(e,t){let r=t.x,n=t.y,i=t.z;return{x:e[0]*r+e[4]*n+e[8]*i+e[12],y:e[1]*r+e[5]*n+e[9]*i+e[13],z:e[2]*r+e[6]*n+e[10]*i+e[14]}}function Rc(e,t){let r=nf();return r[0]=t[0].x,r[1]=t[0].y,r[2]=t[0].z,r[4]=t[1].x,r[5]=t[1].y,r[6]=t[1].z,r[8]=t[2].x,r[9]=t[2].y,r[10]=t[2].z,r[12]=e.x,r[13]=e.y,r[14]=e.z,r}var it=1,Ft=2;var ba=8,va=16,sf=32;var of=16384;var bs=65536,Cc=1<<17,af=1<<18,lf=1<<19,cf=1<<20,df=1<<21,uf=1<<22,ff=1<<23,Sx=1<<24,vs=1<<25,hf=1<<26,wx=1<<27,Ax=1<<28,Mx=1<<29,Ss=1<<30,Ex=1<<31;var Bn=0;var zc=4,Fc=8,kc=16,Bc=32,Dc=64;var Lx=1<<25,Tx=1<<28,Ix=1<<29,Rx=1<<30,Cx=1<<31;var zx=it|Ft,Fx=it|bs|Ft|vs|Ss,kx=it|bs|Ft,Bx=it|Cc|Ft|vs|Ss,Dx=sf|ba|va,Ox=it|va|ba,mf=it|vs|Ss|Ft|hf,Px=af|lf|cf|df|uf|ff,Nx=it|ba|va|vs|Ss,Ux=it|bs|Ft,Hx=it|Ft,Vx=it|bs|Ft|Cc,Gx=mf|of;var Wx=Number.MAX_SAFE_INTEGER-1;var ws=(e=>(e[e.None=0]="None",e[e.Archive=1]="Archive",e[e.UserInfo=2]="UserInfo",e[e.ServerInfo=4]="ServerInfo",e[e.Latch=8]="Latch",e[e.Cheat=16]="Cheat",e))(ws||{});var As=256;var Sa=256,wa=8192,Ms=2048,Aa=512,Ma=256,Ea=As*2,La=256,ga=32,kn=96;var q=(e=>(e[e.Name=0]="Name",e[e.CdTrack=1]="CdTrack",e[e.Sky=2]="Sky",e[e.SkyAxis=3]="SkyAxis",e[e.SkyRotate=4]="SkyRotate",e[e.StatusBar=5]="StatusBar",e[e.HealthBarName=55]="HealthBarName",e[e.CONFIG_N64_PHYSICS=56]="CONFIG_N64_PHYSICS",e[e.CONFIG_CTF_TEAMS=57]="CONFIG_CTF_TEAMS",e[e.CONFIG_COOP_RESPAWN_STRING=58]="CONFIG_COOP_RESPAWN_STRING",e[e.AirAccel=59]="AirAccel",e[e.MaxClients=60]="MaxClients",e[e.MapChecksum=61]="MapChecksum",e[e.Models=62]="Models",e[e.Sounds=62+wa]="Sounds",e[e.Images=e.Sounds+Ms]="Images",e[e.Lights=e.Images+Aa]="Lights",e[e.ShadowLights=e.Lights+Sa]="ShadowLights",e[e.Items=e.ShadowLights+La]="Items",e[e.PlayerSkins=e.Items+Ma]="PlayerSkins",e[e.General=e.PlayerSkins+As]="General",e[e.WheelWeapons=e.General+Ea]="WheelWeapons",e[e.WheelAmmo=e.WheelWeapons+ga]="WheelAmmo",e[e.WheelPowerups=e.WheelAmmo+ga]="WheelPowerups",e[e.CdLoopCount=e.WheelPowerups+ga]="CdLoopCount",e[e.GameStyle=e.CdLoopCount+1]="GameStyle",e[e.MaxConfigStrings=e.GameStyle+1]="MaxConfigStrings",e))(q||{}),Oc=q.MaxConfigStrings;function Pc(e){return e>=5&&e<59?kn*(59-e):e>=q.General&&e<q.WheelWeapons?kn*(q.MaxConfigStrings-e):kn}var pf={};Ec(pf,{addReplayFrame:()=>_f,createReplaySession:()=>xf,deserializeReplay:()=>yf,serializeReplay:()=>gf});function gf(e){return JSON.stringify(e,null,2)}function yf(e){let t=JSON.parse(e);if(!t.metadata||!Array.isArray(t.frames))throw new Error("Invalid replay format: missing metadata or frames");return t}function xf(e,t){return{metadata:{map:e,date:new Date().toISOString(),version:"1.0",seed:t},frames:[]}}function _f(e,t,r,n){e.frames.push({serverFrame:r,cmd:t,timestamp:Date.now()-n})}var F=(e=>(e[e.bad=0]="bad",e[e.muzzleflash=1]="muzzleflash",e[e.muzzleflash2=2]="muzzleflash2",e[e.temp_entity=3]="temp_entity",e[e.layout=4]="layout",e[e.inventory=5]="inventory",e[e.nop=6]="nop",e[e.disconnect=7]="disconnect",e[e.reconnect=8]="reconnect",e[e.sound=9]="sound",e[e.print=10]="print",e[e.stufftext=11]="stufftext",e[e.serverdata=12]="serverdata",e[e.configstring=13]="configstring",e[e.spawnbaseline=14]="spawnbaseline",e[e.centerprint=15]="centerprint",e[e.download=16]="download",e[e.playerinfo=17]="playerinfo",e[e.packetentities=18]="packetentities",e[e.deltapacketentities=19]="deltapacketentities",e[e.frame=20]="frame",e[e.splitclient=21]="splitclient",e[e.configblast=22]="configblast",e[e.spawnbaselineblast=23]="spawnbaselineblast",e[e.level_restart=24]="level_restart",e[e.damage=25]="damage",e[e.locprint=26]="locprint",e[e.fog=27]="fog",e[e.waitingforplayers=28]="waitingforplayers",e[e.bot_chat=29]="bot_chat",e[e.poi=30]="poi",e[e.help_path=31]="help_path",e[e.muzzleflash3=32]="muzzleflash3",e[e.achievement=33]="achievement",e))(F||{});var I=(e=>(e[e.GUNSHOT=0]="GUNSHOT",e[e.BLOOD=1]="BLOOD",e[e.BLASTER=2]="BLASTER",e[e.RAILTRAIL=3]="RAILTRAIL",e[e.SHOTGUN=4]="SHOTGUN",e[e.EXPLOSION1=5]="EXPLOSION1",e[e.EXPLOSION2=6]="EXPLOSION2",e[e.ROCKET_EXPLOSION=7]="ROCKET_EXPLOSION",e[e.GRENADE_EXPLOSION=8]="GRENADE_EXPLOSION",e[e.SPARKS=9]="SPARKS",e[e.SPLASH=10]="SPLASH",e[e.BUBBLETRAIL=11]="BUBBLETRAIL",e[e.SCREEN_SPARKS=12]="SCREEN_SPARKS",e[e.SHIELD_SPARKS=13]="SHIELD_SPARKS",e[e.BULLET_SPARKS=14]="BULLET_SPARKS",e[e.LASER_SPARKS=15]="LASER_SPARKS",e[e.PARASITE_ATTACK=16]="PARASITE_ATTACK",e[e.ROCKET_EXPLOSION_WATER=17]="ROCKET_EXPLOSION_WATER",e[e.GRENADE_EXPLOSION_WATER=18]="GRENADE_EXPLOSION_WATER",e[e.MEDIC_CABLE_ATTACK=19]="MEDIC_CABLE_ATTACK",e[e.BFG_EXPLOSION=20]="BFG_EXPLOSION",e[e.BFG_BIGEXPLOSION=21]="BFG_BIGEXPLOSION",e[e.BOSSTPORT=22]="BOSSTPORT",e[e.BFG_LASER=23]="BFG_LASER",e[e.GRAPPLE_CABLE=24]="GRAPPLE_CABLE",e[e.WELDING_SPARKS=25]="WELDING_SPARKS",e[e.GREENBLOOD=26]="GREENBLOOD",e[e.BLUEHYPERBLASTER=27]="BLUEHYPERBLASTER",e[e.PLASMA_EXPLOSION=28]="PLASMA_EXPLOSION",e[e.TUNNEL_SPARKS=29]="TUNNEL_SPARKS",e[e.BLASTER2=30]="BLASTER2",e[e.RAILTRAIL2=31]="RAILTRAIL2",e[e.FLAME=32]="FLAME",e[e.LIGHTNING=33]="LIGHTNING",e[e.DEBUGTRAIL=34]="DEBUGTRAIL",e[e.PLAIN_EXPLOSION=35]="PLAIN_EXPLOSION",e[e.FLASHLIGHT=36]="FLASHLIGHT",e[e.FORCEWALL=37]="FORCEWALL",e[e.HEATBEAM=38]="HEATBEAM",e[e.MONSTER_HEATBEAM=39]="MONSTER_HEATBEAM",e[e.STEAM=40]="STEAM",e[e.BUBBLETRAIL2=41]="BUBBLETRAIL2",e[e.MOREBLOOD=42]="MOREBLOOD",e[e.HEATBEAM_SPARKS=43]="HEATBEAM_SPARKS",e[e.HEATBEAM_STEAM=44]="HEATBEAM_STEAM",e[e.CHAINFIST_SMOKE=45]="CHAINFIST_SMOKE",e[e.ELECTRIC_SPARKS=46]="ELECTRIC_SPARKS",e[e.TRACKER_EXPLOSION=47]="TRACKER_EXPLOSION",e[e.TELEPORT_EFFECT=48]="TELEPORT_EFFECT",e[e.DBALL_GOAL=49]="DBALL_GOAL",e[e.WIDOWBEAMOUT=50]="WIDOWBEAMOUT",e[e.NUKEBLAST=51]="NUKEBLAST",e[e.WIDOWSPLASH=52]="WIDOWSPLASH",e[e.EXPLOSION1_BIG=53]="EXPLOSION1_BIG",e[e.EXPLOSION1_NP=54]="EXPLOSION1_NP",e[e.FLECHETTE=55]="FLECHETTE",e[e.BLUEHYPERBLASTER_KEX=56]="BLUEHYPERBLASTER_KEX",e[e.BFG_ZAP=57]="BFG_ZAP",e[e.BERSERK_SLAM=58]="BERSERK_SLAM",e[e.GRAPPLE_CABLE_2=59]="GRAPPLE_CABLE_2",e[e.POWER_SPLASH=60]="POWER_SPLASH",e[e.LIGHTNING_BEAM=61]="LIGHTNING_BEAM",e[e.EXPLOSION1_NL=62]="EXPLOSION1_NL",e[e.EXPLOSION2_NL=63]="EXPLOSION2_NL",e))(I||{});var bf=12,vf=9,Xx=Math.ceil(bf*vf/16),Sf=23,wf=2,Kx=Math.ceil(Sf*wf/16);var Af={};Ec(Af,{U_ANGLE1:()=>Cf,U_ANGLE2:()=>zf,U_ANGLE3:()=>Ff,U_EFFECTS:()=>Df,U_EVENT:()=>Nf,U_FRAME:()=>kf,U_MODEL:()=>Ef,U_MODEL2:()=>Hf,U_MODEL3:()=>Vf,U_MODEL4:()=>Gf,U_MOREBITS:()=>Uf,U_NUMBER:()=>Mf,U_ORIGIN1:()=>Tf,U_ORIGIN2:()=>If,U_ORIGIN3:()=>Rf,U_REMOVE:()=>Wf,U_RENDERFX:()=>Of,U_SKIN:()=>Bf,U_SOLID:()=>Pf,U_SOUND:()=>Lf});var Mf=1,Ef=2,Lf=4,Tf=8,If=16,Rf=32,Cf=64,zf=128,Ff=256,kf=512,Bf=1024,Df=2048,Of=4096,Pf=8192,Nf=16384,Uf=32768,Hf=1,Vf=2,Gf=4,Wf=32768;var Dn=class{constructor(e){e instanceof Uint8Array?this.view=new DataView(e.buffer,e.byteOffset,e.byteLength):this.view=new DataView(e),this.offset=0,this.length=this.view.byteLength}getPosition(){return this.offset}seek(e){if(e<0||e>this.length)throw new Error(`Seek out of bounds: ${e} (length: ${this.length})`);this.offset=e}hasMore(){return this.offset<this.length}readChar(){let e=this.view.getInt8(this.offset);return this.offset+=1,e}readByte(){let e=this.view.getUint8(this.offset);return this.offset+=1,e}readShort(){let e=this.view.getInt16(this.offset,!0);return this.offset+=2,e}readUShort(){let e=this.view.getUint16(this.offset,!0);return this.offset+=2,e}readLong(){let e=this.view.getInt32(this.offset,!0);return this.offset+=4,e}readULong(){let e=this.view.getUint32(this.offset,!0);return this.offset+=4,e}readFloat(){let e=this.view.getFloat32(this.offset,!0);return this.offset+=4,e}readString(){let e="";for(;this.offset<this.length;){let t=this.readChar();if(t===-1||t===0)break;e+=String.fromCharCode(t)}return e}readStringLine(){let e="";for(;this.offset<this.length;){let t=this.readChar();if(t===-1||t===0||t===10)break;e+=String.fromCharCode(t)}return e}readCoord(){return this.readShort()*(1/8)}readAngle(){return this.readChar()*(360/256)}readAngle16(){return this.readShort()*360/65536}readData(e){if(this.offset+e>this.length)throw new Error(`Read out of bounds: ${this.offset+e} (length: ${this.length})`);let t=new Uint8Array(this.view.buffer,this.view.byteOffset+this.offset,e);return this.offset+=e,new Uint8Array(t)}readPos(e){e.x=this.readCoord(),e.y=this.readCoord(),e.z=this.readCoord()}readDir(e){let t=this.readByte();if(t>=162){e.x=0,e.y=0,e.z=0;return}let r=ya[t];e.x=r[0],e.y=r[1],e.z=r[2]}},Xf=class{constructor(e=1400){typeof e=="number"?(this.buffer=new Uint8Array(e),this.fixed=!1):(this.buffer=e,this.fixed=!0),this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength),this.offset=0}ensureSpace(e){if(this.offset+e>this.buffer.byteLength){if(this.fixed)throw new Error(`Buffer overflow: capacity ${this.buffer.byteLength}, needed ${this.offset+e}`);let t=Math.max(this.buffer.byteLength*2,this.offset+e),r=new Uint8Array(t);r.set(this.buffer),this.buffer=r,this.view=new DataView(this.buffer.buffer,this.buffer.byteOffset,this.buffer.byteLength)}}writeByte(e){this.ensureSpace(1),this.view.setUint8(this.offset,e),this.offset+=1}writeChar(e){this.ensureSpace(1),this.view.setInt8(this.offset,e),this.offset+=1}writeShort(e){this.ensureSpace(2),this.view.setInt16(this.offset,e,!0),this.offset+=2}writeLong(e){this.ensureSpace(4),this.view.setInt32(this.offset,e,!0),this.offset+=4}writeFloat(e){this.ensureSpace(4),this.view.setFloat32(this.offset,e,!0),this.offset+=4}writeString(e){let t=e.length;this.ensureSpace(t+1);for(let r=0;r<t;r++)this.view.setUint8(this.offset+r,e.charCodeAt(r));this.view.setUint8(this.offset+t,0),this.offset+=t+1}writeCoord(e){this.writeShort(Math.trunc(e*8))}writeAngle(e){this.writeByte(Math.trunc(e*256/360)&255)}writeAngle16(e){this.writeShort(Math.trunc(e*65536/360)&65535)}writePos(e){this.writeCoord(e.x),this.writeCoord(e.y),this.writeCoord(e.z)}writeDir(e){let t=-1,r=0;if(e.x===0&&e.y===0&&e.z===0){this.writeByte(0);return}for(let n=0;n<ya.length;n++){let i=ya[n],s=e.x*i[0]+e.y*i[1]+e.z*i[2];s>t&&(t=s,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}};var Ur=class me{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 Xf(me.MAX_RELIABLE_BUFFER);let t=Date.now();this.lastReceived=t,this.lastSent=t,this.qport=Math.floor(Math.random()*65536)}setup(t,r=null){this.qport=t,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(t){this.outgoingSequence++,this.lastSent=Date.now();let r=0,n=!1,i=0;this.reliableLength>0&&(this.reliableLength>me.FRAGMENT_SIZE?(n=!0,this.fragmentSendOffset>=this.reliableLength&&(this.fragmentSendOffset=0),r=this.reliableLength-this.fragmentSendOffset,r>me.FRAGMENT_SIZE&&(r=me.FRAGMENT_SIZE),i=this.fragmentSendOffset,this.fragmentSendOffset+=r):r=this.reliableLength);let s=me.PACKET_HEADER,o=r>0?2+(n?8:0):0,a=t?t.length:0;s+o+r+a>me.MAX_MSGLEN&&(a=me.MAX_MSGLEN-s-o-r,a<0&&(a=0));let d=new ArrayBuffer(s+o+r+a),l=new DataView(d),c=new Uint8Array(d),h=this.outgoingSequence;r>0&&(h|=2147483648,(this.outgoingReliableSequence&1)!==0&&(h|=1073741824)),l.setUint32(0,h,!0);let u=this.incomingSequence;(this.incomingReliableSequence&1)!==0&&(u|=2147483648),l.setUint32(4,u,!0),l.setUint16(8,this.qport,!0);let f=s;if(r>0){let m=r;n&&(m|=32768),l.setUint16(f,m,!0),f+=2,n&&(l.setUint32(f,i,!0),f+=4,l.setUint32(f,this.reliableLength,!0),f+=4);let p=this.reliableMessage.getBuffer().subarray(i,i+r);c.set(p,f),f+=r}if(t&&a>0){let m=t.slice(0,a);c.set(m,f)}return c}process(t){if(t.length<me.PACKET_HEADER)return null;this.lastReceived=Date.now();let r=new DataView(t.buffer,t.byteOffset,t.byteLength),n=r.getUint32(0,!0),i=r.getUint32(4,!0),s=r.getUint16(8,!0);if(this.qport!==s)return null;let o=n&1073741823;if((o-this.incomingSequence|0)<=0)return null;this.incomingSequence=o;let a=i&2147483647,d=(i&2147483648)!==0;if(a>this.incomingAcknowledged&&(this.incomingAcknowledged=a),this.reliableLength>0){let m=d?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,c=(n&1073741824)!==0?1:0,h=me.PACKET_HEADER,u=null;if(l){if(h+2>t.byteLength)return null;let m=r.getUint16(h,!0);h+=2;let g=(m&32768)!==0;m&=32767;let p=this.incomingReliableSequence&1;if(c===p)if(g){if(h+8>t.byteLength)return null;let y=r.getUint32(h,!0);h+=4;let S=r.getUint32(h,!0);if(h+=4,S>me.MAX_RELIABLE_BUFFER)return console.warn(`NetChan: received invalid fragment total ${S} > ${me.MAX_RELIABLE_BUFFER}`),null;if((!this.fragmentBuffer||this.fragmentBuffer.length!==S)&&(this.fragmentBuffer=new Uint8Array(S),this.fragmentLength=S,this.fragmentReceived=0),h+m>t.byteLength)return null;let _=t.subarray(h,h+m);y===this.fragmentReceived&&y+m<=S&&(this.fragmentBuffer.set(_,y),this.fragmentReceived+=m,this.fragmentReceived>=S&&(u=this.fragmentBuffer,this.incomingReliableSequence++,this.fragmentBuffer=null,this.fragmentLength=0,this.fragmentReceived=0))}else{if(this.incomingReliableSequence++,h+m>t.byteLength)return null;u=t.slice(h,h+m)}h+=m}let f=t.slice(h);if(u&&u.length>0){let m=u.length+f.length,g=new Uint8Array(m);return g.set(u,0),g.set(f,u.length),g}return f||new Uint8Array(0)}canSendReliable(){return this.reliableLength===0}writeReliableByte(t){if(this.reliableLength+1>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeByte(t),this.reliableLength++}writeReliableShort(t){if(this.reliableLength+2>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeShort(t),this.reliableLength+=2}writeReliableLong(t){if(this.reliableLength+4>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeLong(t),this.reliableLength+=4}writeReliableString(t){let r=t.length+1;if(this.reliableLength+r>me.MAX_RELIABLE_BUFFER)throw new Error("NetChan reliable buffer overflow");this.reliableMessage.writeString(t),this.reliableLength+=r}getReliableData(){return this.reliableLength===0?new Uint8Array(0):this.reliableMessage.getBuffer().subarray(0,this.reliableLength)}needsKeepalive(t){return t-this.lastSent>1e3}isTimedOut(t,r=3e4){return t-this.lastReceived>r}};Ur.MAX_MSGLEN=1400;Ur.FRAGMENT_SIZE=1024;Ur.PACKET_HEADER=10;Ur.HEADER_OVERHEAD=Ur.PACKET_HEADER+2;Ur.MAX_RELIABLE_BUFFER=262144;var Nc=(e=>(e[e.Bullets=0]="Bullets",e[e.Shells=1]="Shells",e[e.Rockets=2]="Rockets",e[e.Grenades=3]="Grenades",e[e.Cells=4]="Cells",e[e.Slugs=5]="Slugs",e[e.MagSlugs=6]="MagSlugs",e[e.Trap=7]="Trap",e[e.Flechettes=8]="Flechettes",e[e.Tesla=9]="Tesla",e[e.Disruptor=10]="Disruptor",e[e.Prox=11]="Prox",e[e.Nuke=12]="Nuke",e[e.Rounds=13]="Rounds",e))(Nc||{}),$x=Object.keys(Nc).length/2;var On=32,st=(e=>(e[e.Auto=0]="Auto",e[e.Weapon=1]="Weapon",e[e.Voice=2]="Voice",e[e.Item=3]="Item",e[e.Body=4]="Body",e[e.Aux=5]="Aux",e[e.Footstep=6]="Footstep",e[e.Aux3=7]="Aux3",e[e.NoPhsAdd=8]="NoPhsAdd",e[e.Reliable=16]="Reliable",e[e.ForcePos=32]="ForcePos",e))(st||{}),Ta=-1,Pn=0,Ia=1,Ra=2,Es=3,kt=80,Ca=.003;function Bt(e){return e===Es?e*.001:e*5e-4}function Nn(e){let t=Bt(e);return t<=0?Number.POSITIVE_INFINITY:kt+1/t}var Un=class{constructor({name:t,defaultValue:r,description:n,flags:i=ws.None,onChange:s}){this.modifiedCount=0;this.name=t,this.defaultValue=r,this.description=n,this.flags=i,this._value=r,this.onChange=s}get string(){return this._value}get number(){return Number(this._value)}get integer(){return Math.trunc(this.number)}get boolean(){return!!this.integer}set(t){if(this.flags&ws.Latch){if(t===this._value){this.latched=void 0;return}if(this.latched===t)return;this.latched!==t&&(this.latched=t);return}this.apply(t)}reset(){this.latched=void 0,this.apply(this.defaultValue)}applyLatched(){if(this.latched===void 0)return!1;let t=this.latched;return this.latched=void 0,t===this._value?!1:(this.apply(t),!0)}apply(t){if(this._value===t)return;let r=this._value;this._value=t,this.modifiedCount+=1,this.onChange?.(this,r)}},Vr=class{constructor(){this.cvars=new Map}register(t){let r=this.cvars.get(t.name);if(r)return r;let n=new Un(t);return this.cvars.set(t.name,n),n}get(t){return this.cvars.get(t)}setValue(t,r){let n=this.get(t);if(!n)throw new Error(`Unknown cvar: ${t}`);return n.set(r),n}resetAll(){for(let t of this.cvars.values())t.reset()}applyLatched(){let t=!1;for(let r of this.cvars.values())t=r.applyLatched()||t;return t}list(){return[...this.cvars.values()].sort((t,r)=>t.name.localeCompare(r.name))}};var Gr=class{constructor(t,r,n={}){this.game=t;this.client=r;this.started=!1;this.commands=new Nr;this.cvars=new Vr;this.stepSimulation=t=>{this.previousFrame=this.latestFrame,this.latestFrame=this.game.frame(t,this.latestCommand)};this.renderClient=t=>{this.client&&(this.latestCommand=this.client.render({...t,previous:this.previousFrame,latest:this.latestFrame}))};let i=n.loop?.now?.()??Date.now();this.startTimeMs=n.startTimeMs??n.loop?.startTimeMs??i,this.loop=new cr({simulate:this.stepSimulation,render:this.renderClient},{...n.loop,startTimeMs:this.startTimeMs})}start(){if(!this.started){try{this.latestFrame=this.game.init(this.startTimeMs)??this.latestFrame,this.client?.init(this.latestFrame)}catch(t){throw this.game.shutdown(),this.client?.shutdown(),t}this.started=!0,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)}pump(t){this.loop.pump(t)}getLatestFrame(){return this.latestFrame}isRunning(){return this.loop.isRunning()}};function Kf(e){if(e<0||e>=q.MaxConfigStrings)throw new RangeError(`Configstring index ${e} is out of range (0-${q.MaxConfigStrings-1})`)}function Uc(e,t){let r=Pc(e);if(t.length>r)throw new RangeError(`Configstring ${e} exceeds maximum length (${t.length} > ${r}); limit is ${kn} chars per slot`)}var Wr=class{constructor(){this.values=new Map;this.modelCursor=q.Models;this.soundCursor=q.Sounds;this.imageCursor=q.Images;this.lightCursor=q.Lights;this.shadowLightCursor=q.ShadowLights;this.itemCursor=q.Items;this.playerSkinCursor=q.PlayerSkins;this.generalCursor=q.General}set(t,r){return Kf(t),Uc(t,r),this.values.set(t,r),t}get(t){return this.values.get(t)}getName(t){return this.get(t)}getAll(){let t=new Array(Oc).fill("");for(let[r,n]of this.values.entries())t[r]=n;return t}modelIndex(t){return this.register(t,q.Models,wa,"modelCursor")}soundIndex(t){return this.register(t,q.Sounds,Ms,"soundCursor")}findSoundIndex(t){for(let r=q.Sounds;r<q.Sounds+Ms;r+=1)if(this.values.get(r)===t)return r}imageIndex(t){return this.register(t,q.Images,Aa,"imageCursor")}lightIndex(t){return this.register(t,q.Lights,Sa,"lightCursor")}shadowLightIndex(t){return this.register(t,q.ShadowLights,La,"shadowLightCursor")}itemIndex(t){return this.register(t,q.Items,Ma,"itemCursor")}playerSkinIndex(t){return this.register(t,q.PlayerSkins,As,"playerSkinCursor")}generalIndex(t){return this.register(t,q.General,Ea,"generalCursor")}register(t,r,n,i){for(let a=r;a<r+n;a+=1)if(this.values.get(a)===t)return a;let s=this[i],o=r+n;if(s>=o)throw new RangeError(`Out of configstring slots for range starting at ${r}`);return Uc(s,t),this.values.set(s,t),this[i]=s+1,s}};var Xr=class{constructor(t){this.registry=t.registry,this.system=t.system,this.music=t.music,this.client=t.client}soundindex(t){return this.registry.registerName(t)}sound(t,r,n,i,s,o){this.system.play({entity:t,channel:r,soundIndex:n,volume:i,attenuation:s,timeOffsetMs:o}),this.triggerSubtitle(n)}positioned_sound(t,r,n,i){this.system.positionedSound(t,r,n,i),this.triggerSubtitle(r)}loop_sound(t,r,n,i,s){this.system.play({entity:t,channel:r,soundIndex:n,volume:i,attenuation:s,looping:!0}),this.triggerSubtitle(n)}stop_entity_sounds(t){this.system.stopEntitySounds(t)}set_listener(t){this.system.setListener(t)}play_music(t,r=!0){return this.music?this.music.play(t,{loop:r}):Promise.resolve()}pause_music(){this.music?.pause()}resume_music(){return this.music?.resume()??Promise.resolve()}stop_music(){this.music?.stop()}set_music_volume(t){this.music?.setVolume(t)}play_ambient(t,r,n){this.system.ambientSound(t,r,n),this.triggerSubtitle(r)}play_channel(t){this.system.play({...t}),this.triggerSubtitle(t.soundIndex)}triggerSubtitle(t){if(!this.client)return;let r=this.registry.getName(t);if(!r)return;let n=r.match(/\[(.*?)\]/);n&&this.client.showSubtitle(n[1],r)}};var Hn=class{constructor(t,r){this.engine=t;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(t){this.host.pump(t)}getLatestFrame(){return this.host.getLatestFrame()}isRunning(){return this.started&&this.host.isRunning()}};function Hc(e,t,r,n,i){let s=new Xr({...n,client:r}),o=new Gr(t,r,i);return{runtime:new Hn(e,o),audio:s}}var $f="PACK";function Zf(e,t,r){let n=[];for(let i=0;i<r;i+=1){let s=e.getUint8(t+i);if(s===0)break;n.push(s)}return String.fromCharCode(...n)}function ae(e){return e.replace(/\\/g,"/").replace(/^\/+/,"").toLowerCase()}function Yf(){let e=new Uint32Array(256);for(let t=0;t<256;t+=1){let r=t;for(let n=0;n<8;n+=1)r=(r&1)!==0?3988292384^r>>>1:r>>>1;e[t]=r>>>0}return e}var qf=Yf();function Vc(e){let t=4294967295;for(let r=0;r<e.length;r+=1){let n=e[r];t=qf[(t^n)&255]^t>>>8}return(t^4294967295)>>>0}var Ve=class extends Error{},Kr=class e{constructor(t,r,n,i){this.name=t;this.buffer=r;this.entries=new Map(n.map(s=>[s.name,s])),this.checksum=i,this.size=r.byteLength}static fromArrayBuffer(t,r){let n=new DataView(r);if(r.byteLength<12)throw new Ve("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!==$f)throw new Ve(`Invalid PAK header magic: ${i}`);let s=n.getInt32(4,!0),o=n.getInt32(8,!0);if(s<12)throw new Ve(`Invalid directory offset: ${s}`);if(o<=0||o%64!==0)throw new Ve(`Invalid directory length: ${o}`);if(s+o>r.byteLength)throw new Ve("Directory exceeds buffer length");let d=o/64,l=[],c=new Map;for(let h=0;h<d;h+=1){let u=s+h*64,f=Zf(n,u,56),m=ae(f),g=n.getInt32(u+56,!0),p=n.getInt32(u+60,!0);if(g<0||p<0||g+p>r.byteLength)throw new Ve(`Invalid entry bounds for ${f||"<unnamed>"} (offset=${g}, length=${p})`);if(!m)throw new Ve(`Entry ${h} has an empty name`);let y={name:m,offset:g,length:p};c.set(m,y)}return l.push(...c.values()),new e(t,r,l,Vc(new Uint8Array(r)))}getEntry(t){return this.entries.get(ae(t))}listEntries(){return Array.from(this.entries.values())}readFile(t){let r=this.getEntry(t);if(!r)throw new Ve(`File not found in PAK: ${t}`);return new Uint8Array(this.buffer,r.offset,r.length)}validate(){return{checksum:this.checksum,entries:this.listEntries()}}};function Gc(e){return Vc(new Uint8Array(e))}var Ls=class{constructor(t=[]){this.mounts=[];this.files=new Map;t.forEach(r=>this.mountPak(r))}mountPak(t){this.mounts.push(t);for(let r of t.listEntries()){let n=ae(r.name);this.files.set(n,{archive:t,entry:r})}}get mountedPaks(){return[...this.mounts]}hasFile(t){return this.files.has(ae(t))}stat(t){let r=this.files.get(ae(t));if(r)return{path:r.entry.name,size:r.entry.length,sourcePak:r.archive.name}}async readFile(t){let r=this.files.get(ae(t));if(!r)throw new Error(`File not found in VFS: ${t}`);return r.archive.readFile(t)}list(t=""){let r=ae(t).replace(/\/+$|^\//g,""),n=[],i=new Set,s=r?`${r}/`:"";for(let o of this.files.values()){if(r&&!o.entry.name.startsWith(s))continue;let a=r?o.entry.name.slice(s.length):o.entry.name,d=a.indexOf("/");d===-1?n.push({path:o.entry.name,size:o.entry.length,sourcePak:o.archive.name}):i.add(a.slice(0,d))}return n.sort((o,a)=>o.path.localeCompare(a.path)),{files:n,directories:[...i].sort()}}findByExtension(t){let r=t.startsWith(".")?t.toLowerCase():`.${t.toLowerCase()}`,n=[];for(let i of this.files.values())i.entry.name.toLowerCase().endsWith(r)&&n.push({path:i.entry.name,size:i.entry.length,sourcePak:i.archive.name});return n.sort((i,s)=>i.path.localeCompare(s.path))}};var za=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"}]),dr=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"}},Ts=class{constructor(t=za){this.known=new Map;t.forEach(r=>this.known.set(this.normalizePakName(r.name),r))}validateArchive(t,r){let n=this.normalizePakName(r??("name"in t?t.name:"unknown")),i=t.checksum,s="size"in t?t.size:void 0,o=this.known.get(n);return o?o.checksum!==i?{name:n,checksum:i,expectedChecksum:o.checksum,status:"mismatch",size:s,description:o.description}:{name:n,checksum:i,expectedChecksum:o.checksum,status:"valid",size:s,description:o.description}:{name:n,checksum:i,status:"unknown",size:s}}assertValid(t,r){let n=this.validateArchive(t,r);if(n.status==="mismatch")throw new dr(n);return n}normalizePakName(t){let r=ae(t),n=r.split("/"),i=n.pop()??r,s=n.pop();return s?`${i}@${s}`:i}};var Dt=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 jf(e,t){if(typeof e.arrayBuffer=="function"){let r=await e.arrayBuffer();return t?.({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=s=>{t?.({file:"blob",loadedBytes:s.loaded,totalBytes:s.total||e.size,state:"reading"})},i.onload=()=>{let s=i.result;s instanceof ArrayBuffer?r(s):n(new Error("Unexpected FileReader result"))},i.readAsArrayBuffer(e)});if(typeof Response<"u"){let r=await new Response(e).arrayBuffer();return t?.({file:"blob",loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}if(typeof e.stream=="function"){let r=e.stream().getReader(),n=[],i=0;for(;;){let{done:a,value:d}=await r.read();if(a)break;if(!d)continue;let l=d;n.push(l),i+=l.byteLength,t?.({file:"blob",loadedBytes:i,totalBytes:e.size,state:"reading"})}let s=new Uint8Array(i),o=0;for(let a of n)s.set(a,o),o+=a.byteLength;return s.buffer}throw new Dt("blob",new Error("Unsupported Blob type"))}async function Qf(e,t){if(e.data instanceof ArrayBuffer)return t?.({file:e.name,loadedBytes:e.data.byteLength,totalBytes:e.data.byteLength,state:"reading"}),e.data;if(e.data instanceof Blob){let n=e.data.size;return jf(e.data,i=>t?.({...i,file:e.name,totalBytes:n}))}let r=e.data.buffer.slice(e.data.byteOffset,e.data.byteOffset+e.data.byteLength);return t?.({file:e.name,loadedBytes:r.byteLength,totalBytes:r.byteLength,state:"reading"}),r}async function Is(e,t,r){let n=typeof r=="function"?{onProgress:r}:r??{},i=n.persistIndexes??!!n.pakIndexStore,s=n.enforceValidation??!!n.validator,o=n.allowUnknownPaks??!0,a=n.stopOnError??!1,d=[];for(let l of t)try{let c=await Qf(l,n.onProgress),h=Kr.fromArrayBuffer(l.name,c),u=n.validator?.validateArchive(h);if(u){n.onValidationResult?.(u);let f=u.status==="mismatch",m=u.status==="unknown";if(f&&s||m&&!o){let g=new dr(u);if(n.onError?.(l.name,g),a)throw new Dt(l.name,g);d.push({archive:h,mounted:!1,validation:u});continue}}if(e.mountPak(h),i&&n.pakIndexStore)try{await n.pakIndexStore.persist(h)}catch(f){if(n.onError?.(l.name,f),a)throw new Dt(l.name,f)}n.onProgress?.({file:l.name,loadedBytes:c.byteLength,totalBytes:c.byteLength,state:"parsed"}),d.push({archive:h,mounted:!0,validation:u})}catch(c){if(n.onProgress?.({file:l.name,loadedBytes:0,totalBytes:0,state:"error"}),n.onError?.(l.name,c),a)throw new Dt(l.name,c)}return d}var Ot=class{constructor(t){this.capacity=t;this.map=new Map;if(t<=0)throw new RangeError("LRU cache capacity must be greater than zero")}get size(){return this.map.size}has(t){return this.map.has(t)}get(t){let r=this.map.get(t);if(r!==void 0)return this.map.delete(t),this.map.set(t,r),r}set(t,r){if(this.map.has(t)&&this.map.delete(t),this.map.set(t,r),this.map.size>this.capacity){let n=this.map.keys().next();n.done||this.map.delete(n.value)}}delete(t){return this.map.delete(t)}clear(){this.map.clear()}entries(){return Array.from(this.map.entries()).reverse().map(([t,r])=>({key:t,value:r}))}};function Jf(e){return Array.isArray(e)?e:Array.from(e)}function Fa(e){return Jf(e).map(t=>({name:t.name,data:t}))}async function Wc(e,t,r){let n=Fa(t);return Is(e,n,r??{})}function Xc(e,t){let r=i=>{i.preventDefault(),i.dataTransfer?.dropEffect&&(i.dataTransfer.dropEffect="copy")},n=i=>{i.preventDefault();let s=i.dataTransfer?.files;s&&s.length>0&&t(Array.from(s))};return e.addEventListener("dragover",r),e.addEventListener("drop",n),()=>{e.removeEventListener("dragover",r),e.removeEventListener("drop",n)}}function Kc(e,t){let r=n=>{let i=n.target;!i||!i.files||i.files.length===0||(t(i.files),i.value="")};return e.addEventListener("change",r),()=>e.removeEventListener("change",r)}var eh="IBSP",th=38,Zc=19,rh=8+Zc*8;var j=class extends Error{},$r=class{constructor(t){this.vfs=t}async load(t){let r=await this.vfs.readFile(t),n=new Uint8Array(r.byteLength);return n.set(r),ka(n.buffer)}};function ka(e){if(e.byteLength<rh)throw new j("BSP too small to contain header");let t=new DataView(e),r=String.fromCharCode(t.getUint8(0),t.getUint8(1),t.getUint8(2),t.getUint8(3));if(r!==eh)throw new j(`Invalid BSP magic ${r}`);let n=t.getInt32(4,!0);if(n!==th)throw new j(`Unsupported BSP version ${n}`);let i=new Map;for(let v=0;v<Zc;v+=1){let E=t.getInt32(8+v*8,!0),L=t.getInt32(12+v*8,!0);if(E<0||L<0||E+L>e.byteLength)throw new j(`Invalid lump bounds for index ${v}`);i.set(v,{offset:E,length:L})}let s={version:n,lumps:i},o=ih(e,i.get(0)),a=oh(e,i.get(1)),d=ah(e,i.get(2)),l=lh(e,i.get(4)),c=ch(e,i.get(5)),h=dh(e,i.get(6)),u=new Uint8Array(e,i.get(7).offset,i.get(7).length),f=_h(h,i.get(7)),m=uh(e,i.get(8)),g=fh(e,i.get(11)),p=hh(e,i.get(12)),y=mh(e,i.get(13)),S=ph(e,i.get(14)),_=gh(e,i.get(15)),x=yh(e,i.get(9),i.get(10),m),b=xh(e,i.get(3));return{header:s,entities:o,planes:a,vertices:d,nodes:l,texInfo:c,faces:h,lightMaps:u,lightMapInfo:f,leafs:m,leafLists:x,edges:g,surfEdges:p,models:y,brushes:S,brushSides:_,visibility:b,pickEntity(v){let E=null,L=1/0;for(let w of o.entities){let T=w.properties.model;if(!T||!T.startsWith("*"))continue;let z=parseInt(T.substring(1),10);if(isNaN(z)||z<0||z>=y.length)continue;let U=y[z],C=nh(v.origin,v.direction,U.mins,U.maxs);C!==null&&C<L&&(L=C,E={entity:w,model:U,distance:C})}return E}}}function nh(e,t,r,n){let i=0,s=1/0;for(let o=0;o<3;o++)if(Math.abs(t[o])<1e-8){if(e[o]<r[o]||e[o]>n[o])return null}else{let a=1/t[o],d=(r[o]-e[o])*a,l=(n[o]-e[o])*a;if(d>l){let c=d;d=l,l=c}if(i=Math.max(i,d),s=Math.min(s,l),i>s)return null}return i}function ih(e,t){let r=new TextDecoder().decode(new Uint8Array(e,t.offset,t.length)),n=sh(r),i=n.find(s=>s.classname==="worldspawn");return{raw:r,entities:n,worldspawn:i,getUniqueClassnames(){let s=new Set;for(let o of n)o.classname&&s.add(o.classname);return Array.from(s).sort()}}}function sh(e){let t=[],r=/\{([^}]*)\}/gms,n;for(;(n=r.exec(e))!==null;){let i=n[1],s={},o=/"([^\"]*)"\s+"([^\"]*)"/g,a;for(;(a=o.exec(i))!==null;)s[a[1]]=a[2];t.push({classname:s.classname,properties:s})}return t}function oh(e,t){let r=new DataView(e,t.offset,t.length),n=t.length/20;if(n%1!==0)throw new j("Plane lump has invalid length");let i=[];for(let s=0;s<n;s+=1){let o=[r.getFloat32(s*20,!0),r.getFloat32(s*20+4,!0),r.getFloat32(s*20+8,!0)],a=r.getFloat32(s*20+12,!0),d=r.getInt32(s*20+16,!0);i.push({normal:o,dist:a,type:d})}return i}function ah(e,t){let r=new DataView(e,t.offset,t.length),n=t.length/12;if(n%1!==0)throw new j("Vertex lump has invalid length");let i=[];for(let s=0;s<n;s+=1)i.push([r.getFloat32(s*12,!0),r.getFloat32(s*12+4,!0),r.getFloat32(s*12+8,!0)]);return i}function lh(e,t){let r=new DataView(e,t.offset,t.length),n=28,i=t.length/n;if(i%1!==0)throw new j("Node lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n,d=r.getInt32(a,!0),l=[r.getInt32(a+4,!0),r.getInt32(a+8,!0)],c=[r.getInt16(a+12,!0),r.getInt16(a+14,!0),r.getInt16(a+16,!0)],h=[r.getInt16(a+18,!0),r.getInt16(a+20,!0),r.getInt16(a+22,!0)],u=r.getUint16(a+24,!0),f=r.getUint16(a+26,!0);s.push({planeIndex:d,children:l,mins:c,maxs:h,firstFace:u,numFaces:f})}return s}function ch(e,t){let r=new DataView(e,t.offset,t.length),n=76,i=t.length/n;if(i%1!==0)throw new j("TexInfo lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n,d=[r.getFloat32(a,!0),r.getFloat32(a+4,!0),r.getFloat32(a+8,!0)],l=r.getFloat32(a+12,!0),c=[r.getFloat32(a+16,!0),r.getFloat32(a+20,!0),r.getFloat32(a+24,!0)],h=r.getFloat32(a+28,!0),u=r.getInt32(a+32,!0),f=r.getInt32(a+36,!0),m=new Uint8Array(e,t.offset+a+40,32),g=new TextDecoder("utf-8").decode(m).replace(/\0.*$/,""),p=r.getInt32(a+72,!0);s.push({s:d,sOffset:l,t:c,tOffset:h,flags:u,value:f,texture:g,nextTexInfo:p})}return s}function dh(e,t){let r=new DataView(e,t.offset,t.length),n=20,i=t.length/n;if(i%1!==0)throw new j("Face lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n,d=r.getUint16(a,!0),l=r.getInt16(a+2,!0),c=r.getInt32(a+4,!0),h=r.getInt16(a+8,!0),u=r.getInt16(a+10,!0),f=[r.getUint8(a+12),r.getUint8(a+13),r.getUint8(a+14),r.getUint8(a+15)],m=r.getInt32(a+16,!0);s.push({planeIndex:d,side:l,firstEdge:c,numEdges:h,texInfo:u,styles:f,lightOffset:m})}return s}function uh(e,t){let r=new DataView(e,t.offset,t.length),n=28,i=t.length/n;if(i%1!==0)throw new j("Leaf lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n,d=r.getInt32(a,!0),l=r.getInt16(a+4,!0),c=r.getInt16(a+6,!0),h=[r.getInt16(a+8,!0),r.getInt16(a+10,!0),r.getInt16(a+12,!0)],u=[r.getInt16(a+14,!0),r.getInt16(a+16,!0),r.getInt16(a+18,!0)],f=r.getUint16(a+20,!0),m=r.getUint16(a+22,!0),g=r.getUint16(a+24,!0),p=r.getUint16(a+26,!0);s.push({contents:d,cluster:l,area:c,mins:h,maxs:u,firstLeafFace:f,numLeafFaces:m,firstLeafBrush:g,numLeafBrushes:p})}return s}function fh(e,t){let r=new DataView(e,t.offset,t.length),n=4,i=t.length/n;if(i%1!==0)throw new j("Edge lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n;s.push({vertices:[r.getUint16(a,!0),r.getUint16(a+2,!0)]})}return s}function hh(e,t){let r=t.length/4;if(r%1!==0)throw new j("SurfEdge lump has invalid length");let n=new DataView(e,t.offset,t.length),i=new Int32Array(r);for(let s=0;s<r;s+=1)i[s]=n.getInt32(s*4,!0);return i}function mh(e,t){let r=new DataView(e,t.offset,t.length),n=48;if(t.length%n!==0)throw new j("Model lump has invalid length");let i=t.length/n,s=[];for(let o=0;o<i;o+=1){let a=o*n,d=[r.getFloat32(a,!0),r.getFloat32(a+4,!0),r.getFloat32(a+8,!0)],l=[r.getFloat32(a+12,!0),r.getFloat32(a+16,!0),r.getFloat32(a+20,!0)],c=[r.getFloat32(a+24,!0),r.getFloat32(a+28,!0),r.getFloat32(a+32,!0)],h=r.getInt32(a+36,!0),u=r.getInt32(a+40,!0),f=r.getInt32(a+44,!0);s.push({mins:d,maxs:l,origin:c,headNode:h,firstFace:u,numFaces:f})}return s}function ph(e,t){let r=new DataView(e,t.offset,t.length),n=12,i=t.length/n;if(i%1!==0)throw new j("Brush lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n;s.push({firstSide:r.getInt32(a,!0),numSides:r.getInt32(a+4,!0),contents:r.getInt32(a+8,!0)})}return s}function gh(e,t){let r=new DataView(e,t.offset,t.length),n=4,i=t.length/n;if(i%1!==0)throw new j("Brush side lump has invalid length");let s=[];for(let o=0;o<i;o+=1){let a=o*n;s.push({planeIndex:r.getUint16(a,!0),texInfo:r.getInt16(a+2,!0)})}return s}function yh(e,t,r,n){let i=[],s=[],o=t.length/2,a=r.length/2,d=new DataView(e,t.offset,t.length),l=new DataView(e,r.offset,r.length);for(let c of n){if(c.firstLeafFace+c.numLeafFaces>o)throw new j("Leaf faces reference data past lump bounds");if(c.firstLeafBrush+c.numLeafBrushes>a)throw new j("Leaf brushes reference data past lump bounds");let h=[];for(let f=0;f<c.numLeafFaces;f+=1)h.push(d.getUint16((c.firstLeafFace+f)*2,!0));let u=[];for(let f=0;f<c.numLeafBrushes;f+=1)u.push(l.getUint16((c.firstLeafBrush+f)*2,!0));i.push(h),s.push(u)}return{leafFaces:i,leafBrushes:s}}function xh(e,t){if(t.length===0)return;if(t.length<4)throw new j("Visibility lump too small");let r=new DataView(e,t.offset,t.length),n=r.getInt32(0,!0),i=4+n*8;if(n<0||i>t.length)throw new j("Visibility lump truncated");let s=4,o=[];for(let a=0;a<n;a+=1){let d=r.getInt32(s,!0),l=r.getInt32(s+4,!0);s+=8;let c=t.offset+d,h=t.offset+l,u=t.offset+t.length;if(d<0||l<0||c>=u||h>=u)throw new j("Visibility offsets out of range");o.push({pvs:$c(e,c,n,t),phs:$c(e,h,n,t)})}return{numClusters:n,clusters:o}}function $c(e,t,r,n){let i=Math.ceil(r/8),s=new Uint8Array(i),o=new Uint8Array(e),a=t,d=0,l=n.offset+n.length;for(;d<i;){if(a>=l)throw new j("Visibility data truncated");let c=o[a++];if(c!==0){s[d++]=c;continue}if(a>=l)throw new j("Visibility run exceeds lump bounds");let h=o[a++];for(let u=0;u<h&&d<i;u+=1)s[d++]=0}return s}function _h(e,t){return e.map(r=>{if(!(r.lightOffset<0))return{offset:r.lightOffset,length:Math.max(0,t.length-r.lightOffset)}})}function Rs(e,t,r){if(e.lightOffset<0||e.lightOffset>=t.byteLength)return;let n=t.byteLength-e.lightOffset,i=Math.min(r?.length??n,n);if(!(i<=0))return t.subarray(e.lightOffset,e.lightOffset+i)}var bh=844121161,vh=8,Yc=68,Sh=[{x:-.525731,y:0,z:.850651},{x:-.442863,y:.238856,z:.864188},{x:-.295242,y:0,z:.955423},{x:-.309017,y:.5,z:.809017},{x:-.16246,y:.262866,z:.951056},{x:0,y:0,z:1},{x:0,y:.850651,z:.525731},{x:-.147621,y:.716567,z:.681718},{x:.147621,y:.716567,z:.681718},{x:0,y:.525731,z:.850651},{x:.309017,y:.5,z:.809017},{x:.525731,y:0,z:.850651},{x:.295242,y:0,z:.955423},{x:.442863,y:.238856,z:.864188},{x:.16246,y:.262866,z:.951056},{x:-.681718,y:.147621,z:.716567},{x:-.809017,y:.309017,z:.5},{x:-.587785,y:.425325,z:.688191},{x:-.850651,y:.525731,z:0},{x:-.864188,y:.442863,z:.238856},{x:-.716567,y:.681718,z:.147621},{x:-.688191,y:.587785,z:.425325},{x:-.5,y:.809017,z:.309017},{x:-.238856,y:.864188,z:.442863},{x:-.425325,y:.688191,z:.587785},{x:-.716567,y:.681718,z:-.147621},{x:-.5,y:.809017,z:-.309017},{x:-.525731,y:.850651,z:0},{x:0,y:.850651,z:-.525731},{x:-.238856,y:.864188,z:-.442863},{x:0,y:.955423,z:-.295242},{x:-.262866,y:.951056,z:-.16246},{x:0,y:1,z:0},{x:0,y:.955423,z:.295242},{x:-.262866,y:.951056,z:.16246},{x:.238856,y:.864188,z:.442863},{x:.262866,y:.951056,z:.16246},{x:.5,y:.809017,z:.309017},{x:.238856,y:.864188,z:-.442863},{x:.262866,y:.951056,z:-.16246},{x:.5,y:.809017,z:-.309017},{x:.850651,y:.525731,z:0},{x:.716567,y:.681718,z:.147621},{x:.716567,y:.681718,z:-.147621},{x:.525731,y:.850651,z:0},{x:.425325,y:.688191,z:.587785},{x:.864188,y:.442863,z:.238856},{x:.688191,y:.587785,z:.425325},{x:.809017,y:.309017,z:.5},{x:.681718,y:.147621,z:.716567},{x:.587785,y:.425325,z:.688191},{x:.955423,y:.295242,z:0},{x:1,y:0,z:0},{x:.951056,y:.16246,z:.262866},{x:.850651,y:-.525731,z:0},{x:.955423,y:-.295242,z:0},{x:.864188,y:-.442863,z:.238856},{x:.951056,y:-.16246,z:.262866},{x:.809017,y:-.309017,z:.5},{x:.681718,y:-.147621,z:.716567},{x:.850651,y:0,z:.525731},{x:.864188,y:.442863,z:-.238856},{x:.809017,y:.309017,z:-.5},{x:.951056,y:.16246,z:-.262866},{x:.525731,y:0,z:-.850651},{x:.681718,y:.147621,z:-.716567},{x:.681718,y:-.147621,z:-.716567},{x:.850651,y:0,z:-.525731},{x:.809017,y:-.309017,z:-.5},{x:.864188,y:-.442863,z:-.238856},{x:.951056,y:-.16246,z:-.262866},{x:.147621,y:.716567,z:-.681718},{x:.309017,y:.5,z:-.809017},{x:.425325,y:.688191,z:-.587785},{x:.442863,y:.238856,z:-.864188},{x:.587785,y:.425325,z:-.688191},{x:.688191,y:.587785,z:-.425325},{x:-.147621,y:.716567,z:-.681718},{x:-.309017,y:.5,z:-.809017},{x:0,y:.525731,z:-.850651},{x:-.525731,y:0,z:-.850651},{x:-.442863,y:.238856,z:-.864188},{x:-.295242,y:0,z:-.955423},{x:-.16246,y:.262866,z:-.951056},{x:0,y:0,z:-1},{x:.295242,y:0,z:-.955423},{x:.16246,y:.262866,z:-.951056},{x:-.442863,y:-.238856,z:-.864188},{x:-.309017,y:-.5,z:-.809017},{x:-.16246,y:-.262866,z:-.951056},{x:0,y:-.850651,z:-.525731},{x:-.147621,y:-.716567,z:-.681718},{x:.147621,y:-.716567,z:-.681718},{x:0,y:-.525731,z:-.850651},{x:.309017,y:-.5,z:-.809017},{x:.442863,y:-.238856,z:-.864188},{x:.16246,y:-.262866,z:-.951056},{x:.238856,y:-.864188,z:-.442863},{x:.5,y:-.809017,z:-.309017},{x:.425325,y:-.688191,z:-.587785},{x:.716567,y:-.681718,z:-.147621},{x:.688191,y:-.587785,z:-.425325},{x:.587785,y:-.425325,z:-.688191},{x:0,y:-.955423,z:-.295242},{x:0,y:-1,z:0},{x:.262866,y:-.951056,z:-.16246},{x:0,y:-.850651,z:.525731},{x:0,y:-.955423,z:.295242},{x:.238856,y:-.864188,z:.442863},{x:.262866,y:-.951056,z:.16246},{x:.5,y:-.809017,z:.309017},{x:.716567,y:-.681718,z:.147621},{x:.525731,y:-.850651,z:0},{x:-.238856,y:-.864188,z:-.442863},{x:-.5,y:-.809017,z:-.309017},{x:-.262866,y:-.951056,z:-.16246},{x:-.850651,y:-.525731,z:0},{x:-.716567,y:-.681718,z:-.147621},{x:-.716567,y:-.681718,z:.147621},{x:-.525731,y:-.850651,z:0},{x:-.5,y:-.809017,z:.309017},{x:-.238856,y:-.864188,z:.442863},{x:-.262866,y:-.951056,z:.16246},{x:-.864188,y:-.442863,z:.238856},{x:-.809017,y:-.309017,z:.5},{x:-.688191,y:-.587785,z:.425325},{x:-.681718,y:-.147621,z:.716567},{x:-.442863,y:-.238856,z:.864188},{x:-.587785,y:-.425325,z:.688191},{x:-.309017,y:-.5,z:.809017},{x:-.147621,y:-.716567,z:.681718},{x:-.425325,y:-.688191,z:.587785},{x:-.16246,y:-.262866,z:.951056},{x:.442863,y:-.238856,z:.864188},{x:.16246,y:-.262866,z:.951056},{x:.309017,y:-.5,z:.809017},{x:.147621,y:-.716567,z:.681718},{x:0,y:-.525731,z:.850651},{x:.425325,y:-.688191,z:.587785},{x:.587785,y:-.425325,z:.688191},{x:.688191,y:-.587785,z:.425325},{x:-.955423,y:.295242,z:0},{x:-.951056,y:.16246,z:.262866},{x:-1,y:0,z:0},{x:-.850651,y:0,z:.525731},{x:-.955423,y:-.295242,z:0},{x:-.951056,y:-.16246,z:.262866},{x:-.864188,y:.442863,z:-.238856},{x:-.951056,y:.16246,z:-.262866},{x:-.809017,y:.309017,z:-.5},{x:-.864188,y:-.442863,z:-.238856},{x:-.951056,y:-.16246,z:-.262866},{x:-.809017,y:-.309017,z:-.5},{x:-.681718,y:.147621,z:-.716567},{x:-.681718,y:-.147621,z:-.716567},{x:-.850651,y:0,z:-.525731},{x:-.688191,y:.587785,z:-.425325},{x:-.587785,y:.425325,z:-.688191},{x:-.425325,y:.688191,z:-.587785},{x:-.425325,y:-.688191,z:-.587785},{x:-.587785,y:-.425325,z:-.688191},{x:-.688191,y:-.587785,z:-.425325}],pe=class extends Error{},Zr=class{constructor(t){this.vfs=t;this.cache=new Map}async load(t){if(this.cache.has(t))return this.cache.get(t);let r=await this.vfs.readFile(t),n=new Uint8Array(r.byteLength);n.set(r);let i=Ba(n.buffer);return this.cache.set(t,i),i}get(t){return this.cache.get(t)}};function qc(e,t,r){let n=[];for(let i=0;i<r;i+=1){let s=e.getUint8(t+i);if(s===0)break;n.push(s)}return String.fromCharCode(...n)}function Vn(e,t,r,n){if(r!==0&&(t<Yc||t+r>e.byteLength))throw new pe(`${n} section is out of bounds`)}function wh(e){if(e.byteLength<Yc)throw new pe("MD2 buffer too small to contain header");let t=new DataView(e),r=t.getInt32(0,!0),n=t.getInt32(4,!0);if(r!==bh)throw new pe(`Invalid MD2 ident: ${r}`);if(n!==vh)throw new pe(`Unsupported MD2 version: ${n}`);let i={ident:r,version:n,skinWidth:t.getInt32(8,!0),skinHeight:t.getInt32(12,!0),frameSize:t.getInt32(16,!0),numSkins:t.getInt32(20,!0),numVertices:t.getInt32(24,!0),numTexCoords:t.getInt32(28,!0),numTriangles:t.getInt32(32,!0),numGlCommands:t.getInt32(36,!0),numFrames:t.getInt32(40,!0),offsetSkins:t.getInt32(44,!0),offsetTexCoords:t.getInt32(48,!0),offsetTriangles:t.getInt32(52,!0),offsetFrames:t.getInt32(56,!0),offsetGlCommands:t.getInt32(60,!0),offsetEnd:t.getInt32(64,!0),magic:r},s=40+i.numVertices*4;if(i.frameSize!==s)throw new pe(`Unexpected frame size ${i.frameSize}, expected ${s}`);if(i.offsetEnd>e.byteLength)throw new pe("MD2 offset_end exceeds buffer length");return i}function Ah(e,t){let r=t.numSkins*64;Vn(e,t.offsetSkins,r,"skins");let n=new DataView(e,t.offsetSkins,r),i=[];for(let s=0;s<t.numSkins;s+=1)i.push({name:qc(n,s*64,64)});return i}function Mh(e,t){let r=t.numTexCoords*4;Vn(e,t.offsetTexCoords,r,"texcoords");let n=new DataView(e,t.offsetTexCoords,r),i=[];for(let s=0;s<t.numTexCoords;s+=1){let o=s*4;i.push({s:n.getInt16(o,!0),t:n.getInt16(o+2,!0)})}return i}function Eh(e,t){let r=t.numTriangles*12;Vn(e,t.offsetTriangles,r,"triangles");let n=new DataView(e,t.offsetTriangles,r),i=[];for(let s=0;s<t.numTriangles;s+=1){let o=s*12,a=[n.getUint16(o,!0),n.getUint16(o+2,!0),n.getUint16(o+4,!0)],d=[n.getUint16(o+6,!0),n.getUint16(o+8,!0),n.getUint16(o+10,!0)];if(a.some(l=>l>=t.numVertices)||d.some(l=>l>=t.numTexCoords))throw new pe("Triangle references out of range vertex or texcoord");i.push({vertexIndices:a,texCoordIndices:d})}return i}function Lh(e,t){let r=t.numFrames*t.frameSize;Vn(e,t.offsetFrames,r,"frames");let n=[];for(let i=0;i<t.numFrames;i+=1){let s=t.offsetFrames+i*t.frameSize,o=new DataView(e,s,t.frameSize),a={x:o.getFloat32(0,!0),y:o.getFloat32(4,!0),z:o.getFloat32(8,!0)},d={x:o.getFloat32(12,!0),y:o.getFloat32(16,!0),z:o.getFloat32(20,!0)},l=qc(o,24,16),c=[],h=1/0,u=1/0,f=1/0,m=-1/0,g=-1/0,p=-1/0;for(let y=0;y<t.numVertices;y+=1){let S=40+y*4,_=o.getUint8(S)*a.x+d.x,x=o.getUint8(S+1)*a.y+d.y,b=o.getUint8(S+2)*a.z+d.z;_<h&&(h=_),x<u&&(u=x),b<f&&(f=b),_>m&&(m=_),x>g&&(g=x),b>p&&(p=b);let A={x:_,y:x,z:b},v=o.getUint8(S+3),E=Sh[v];if(!E)throw new pe(`Invalid normal index ${v} in frame ${l}`);c.push({position:A,normalIndex:v,normal:E})}n.push({name:l,vertices:c,minBounds:{x:h,y:u,z:f},maxBounds:{x:m,y:g,z:p}})}return n}function Th(e,t){let r=t.numGlCommands*4;if(Vn(e,t.offsetGlCommands,r,"gl commands"),r===0)return[];let n=new DataView(e,t.offsetGlCommands,r),i=[],s=0;for(;;){if(s+4>r)throw new pe("GL command list ended unexpectedly");let o=n.getInt32(s,!0);if(s+=4,o===0)break;let a=Math.abs(o),d=[],l=a*12;if(s+l>r)throw new pe("GL command vertex block exceeds buffer");for(let c=0;c<a;c+=1){let h=n.getFloat32(s,!0),u=n.getFloat32(s+4,!0),f=n.getInt32(s+8,!0);if(s+=12,f<0||f>=t.numVertices)throw new pe("GL command references invalid vertex index");d.push({s:h,t:u,vertexIndex:f})}i.push({mode:o>0?"strip":"fan",vertices:d})}if(s!==r)throw new pe("GL command list did not consume expected data");return i}function Ba(e){let t=wh(e),r=Ah(e,t),n=Mh(e,t),i=Eh(e,t),s=Lh(e,t),o=Th(e,t);return{header:t,skins:r,texCoords:n,triangles:i,frames:s,glCommands:o}}function jc(e){let t=[],r=0;for(;r<e.length;){let n=e[r].name,i=n.replace(/\d+$/,"")||n,s=r;for(;s+1<e.length&&(e[s+1].name.replace(/\d+$/,"")||e[s+1].name)===i;)s+=1;t.push({name:i,firstFrame:r,lastFrame:s}),r=s+1}return t}var Qc=860898377,Ih=15,Ge=class extends Error{constructor(t){super(t),this.name="Md3ParseError"}};function Gn(e,t,r){let n=new Uint8Array(e.buffer,e.byteOffset+t,r);return new TextDecoder("utf-8").decode(n).replace(/\0.*$/,"").trim()}function Rh(e){let t=(e>>8&255)*(2*Math.PI/255),r=(e&255)*(2*Math.PI/255),n=Math.sin(r);return{x:Math.cos(t)*n,y:Math.sin(t)*n,z:Math.cos(r)}}function Cs(e,t,r,n){if(t<0||t+r>n)throw new Ge(`${e} exceeds buffer bounds`)}function Ch(e){let t=e.getInt32(0,!0);if(t!==Qc)throw new Ge(`Invalid MD3 ident: ${t}`);let r=e.getInt32(4,!0);if(r!==Ih)throw new Ge(`Unsupported MD3 version: ${r}`);let n=Gn(e,8,64),i=e.getInt32(72,!0),s=e.getInt32(76,!0),o=e.getInt32(80,!0),a=e.getInt32(84,!0),d=e.getInt32(88,!0),l=e.getInt32(92,!0),c=e.getInt32(96,!0),h=e.getInt32(100,!0),u=e.getInt32(104,!0);if(s<=0||a<0||o<0)throw new Ge("Invalid MD3 counts");return{ident:t,version:r,name:n,flags:i,numFrames:s,numTags:o,numSurfaces:a,numSkins:d,ofsFrames:l,ofsTags:c,ofsSurfaces:h,ofsEnd:u,magic:t}}function zh(e,t){let r=[];Cs("Frames",t.ofsFrames,t.numFrames*56,e.byteLength);for(let i=0;i<t.numFrames;i+=1){let s=t.ofsFrames+i*56;r.push({minBounds:{x:e.getFloat32(s,!0),y:e.getFloat32(s+4,!0),z:e.getFloat32(s+8,!0)},maxBounds:{x:e.getFloat32(s+12,!0),y:e.getFloat32(s+16,!0),z:e.getFloat32(s+20,!0)},localOrigin:{x:e.getFloat32(s+24,!0),y:e.getFloat32(s+28,!0),z:e.getFloat32(s+32,!0)},radius:e.getFloat32(s+36,!0),name:Gn(e,s+40,16)})}return r}function Fh(e,t){let r=[],i=t.numFrames*t.numTags*112;Cs("Tags",t.ofsTags,i,e.byteLength);for(let s=0;s<t.numFrames;s+=1){let o=[];for(let a=0;a<t.numTags;a+=1){let d=t.ofsTags+(s*t.numTags+a)*112,l=d+64,c=l+12;o.push({name:Gn(e,d,64),origin:{x:e.getFloat32(l,!0),y:e.getFloat32(l+4,!0),z:e.getFloat32(l+8,!0)},axis:[{x:e.getFloat32(c,!0),y:e.getFloat32(c+4,!0),z:e.getFloat32(c+8,!0)},{x:e.getFloat32(c+12,!0),y:e.getFloat32(c+16,!0),z:e.getFloat32(c+20,!0)},{x:e.getFloat32(c+24,!0),y:e.getFloat32(c+28,!0),z:e.getFloat32(c+32,!0)}]})}r.push(o)}return r}function kh(e,t){let r=e.getInt32(t,!0);if(r!==Qc)throw new Ge(`Invalid surface ident at ${t}: ${r}`);let n=Gn(e,t+4,64),i=e.getInt32(t+68,!0),s=e.getInt32(t+72,!0),o=e.getInt32(t+76,!0),a=e.getInt32(t+80,!0),d=e.getInt32(t+84,!0),l=e.getInt32(t+88,!0),c=e.getInt32(t+92,!0),h=e.getInt32(t+96,!0),u=e.getInt32(t+100,!0),f=e.getInt32(t+104,!0);if(s<=0||a<=0||d<=0)throw new Ge(`Invalid surface counts for ${n}`);let m=f;Cs(`Surface ${n}`,t,m,e.byteLength);let g=[],p=t+l;for(let v=0;v<d;v+=1){let E=p+v*12;g.push({indices:[e.getInt32(E,!0),e.getInt32(E+4,!0),e.getInt32(E+8,!0)]})}let y=[],S=t+c;for(let v=0;v<o;v+=1){let E=S+v*68;y.push({name:Gn(e,E,64),shaderIndex:e.getInt32(E+64,!0)})}let _=[],x=t+h;for(let v=0;v<a;v+=1){let E=x+v*8;_.push({s:e.getFloat32(E,!0),t:e.getFloat32(E+4,!0)})}let b=[],A=t+u;for(let v=0;v<s;v+=1){let E=[];for(let L=0;L<a;L+=1){let w=A+(v*a+L)*8,T=e.getInt16(w,!0)/64,z=e.getInt16(w+2,!0)/64,U=e.getInt16(w+4,!0)/64,C=e.getUint16(w+6,!0);E.push({position:{x:T,y:z,z:U},latLng:C,normal:Rh(C)})}b.push(E)}return{surface:{name:n,flags:i,numFrames:s,shaders:y,triangles:g,texCoords:_,vertices:b},nextOffset:t+f}}function Da(e){if(e.byteLength<108)throw new Ge("MD3 buffer too small for header");let t=new DataView(e),r=Ch(t);Cs("MD3 end",r.ofsEnd,0,e.byteLength);let n=zh(t,r),i=Fh(t,r),s=[],o=r.ofsSurfaces;for(let a=0;a<r.numSurfaces;a+=1){let{surface:d,nextOffset:l}=kh(t,o);s.push(d),o=l}if(o!==r.ofsEnd)throw new Ge("Surface parsing did not reach ofsEnd");return{header:r,frames:n,tags:i,surfaces:s}}var Yr=class{constructor(t){this.vfs=t;this.cache=new Map}async load(t){if(this.cache.has(t))return this.cache.get(t);let r=await this.vfs.readFile(t),n=Da(r.slice().buffer);return this.cache.set(t,n),n}get(t){return this.cache.get(t)}};var Bh=844317769,Dh=2,Jc=64,ed=12,Pt=class extends Error{};function Oh(e,t,r){let n=[];for(let i=0;i<r;i+=1){let s=e.getUint8(t+i);if(s===0)break;n.push(s)}return String.fromCharCode(...n)}function Oa(e){if(e.byteLength<ed)throw new Pt("Sprite buffer too small to contain header");let t=new DataView(e),r=t.getInt32(0,!0),n=t.getInt32(4,!0),i=t.getInt32(8,!0);if(r!==Bh)throw new Pt(`Invalid Sprite ident: ${r}`);if(n!==Dh)throw new Pt(`Unsupported Sprite version: ${n}`);let s=[],o=16+Jc,a=ed;for(let d=0;d<i;d+=1){if(a+o>e.byteLength)throw new Pt("Sprite frame data exceeds buffer length");let l=t.getInt32(a,!0),c=t.getInt32(a+4,!0),h=t.getInt32(a+8,!0),u=t.getInt32(a+12,!0),f=Oh(t,a+16,Jc);s.push({width:l,height:c,originX:h,originY:u,name:f}),a+=o}return{ident:r,version:n,numFrames:i,frames:s}}var qr=class{constructor(t){this.vfs=t}async load(t){let r=await this.vfs.readFile(t),n=new Uint8Array(r.byteLength);return n.set(r),Oa(n.buffer)}};function td(e,t){let r=(e.sequence.end-e.sequence.start+1)/e.sequence.fps,n=e.sequence.loop!==!1,i=e.time+t;return n?i=(i%r+r)%r:i>r&&(i=r),{...e,time:Math.max(0,Math.min(i,r))}}function rd(e){let t=e.sequence.end-e.sequence.start+1,r=1/e.sequence.fps,n=e.sequence.loop!==!1,i=e.time/r;if(!n&&i>=t)return{frame0:e.sequence.end,frame1:e.sequence.end,lerp:0};let s=n?i%t:Math.min(i,t-1),o=Math.floor(s),a=e.sequence.start+o,d=o+1>=t?n?e.sequence.start:e.sequence.end:a+1,l=!n&&o>=t-1?0:s-o;return{frame0:a,frame1:d,lerp:l}}function nd(e){return{sequence:e,time:0}}function id(e,t,r){return{x:e.x+(t.x-e.x)*r,y:e.y+(t.y-e.y)*r,z:e.z+(t.z-e.z)*r}}var Wn=class extends Error{constructor(t){super(t),this.name="WalParseError"}};function zs(e){if(e.byteLength<100)throw new Wn("WAL buffer too small");let t=new DataView(e),r=new Uint8Array(e,0,32),n=new TextDecoder("utf-8").decode(r).replace(/\0.*$/,"").trim(),i=t.getInt32(32,!0),s=t.getInt32(36,!0),o=[t.getInt32(40,!0),t.getInt32(44,!0),t.getInt32(48,!0),t.getInt32(52,!0)],a=new Uint8Array(e,56,32),d=new TextDecoder("utf-8").decode(a).replace(/\0.*$/,"").trim(),l=t.getInt32(88,!0),c=t.getInt32(92,!0),h=t.getInt32(96,!0);if(i<=0||s<=0)throw new Wn("Invalid WAL dimensions");let u=[],f=i,m=s;for(let g=0;g<o.length;g+=1){let p=o[g],y=Math.max(1,f*m|0);if(p<=0||p+y>e.byteLength)throw new Wn(`Invalid WAL mip offset for level ${g}`);let S=new Uint8Array(e,p,y);u.push({level:g,width:f,height:m,data:S}),f=Math.max(1,f>>1),m=Math.max(1,m>>1)}return{name:n,width:i,height:s,mipmaps:u,animName:d,flags:l,contents:c,value:h}}var ur=class extends Error{constructor(t){super(t),this.name="PcxParseError"}};function Xn(e){if(e.byteLength<128)throw new ur("PCX buffer too small for header");let t=new DataView(e),r=t.getUint8(0),n=t.getUint8(2),i=t.getUint8(3),s=t.getUint16(4,!0),o=t.getUint16(6,!0),a=t.getUint16(8,!0),d=t.getUint16(10,!0);if(r!==10||n!==1)throw new ur("Unsupported PCX encoding");if(i!==8)throw new ur("Only 8bpp PCX files are supported");let l=a-s+1,c=d-o+1,h=t.getUint16(66,!0),u=e.byteLength-769;if(u<128||new DataView(e,u,1).getUint8(0)!==12)throw new ur("Missing PCX palette");let f=new Uint8Array(e,u+1,768),m=new Uint8Array(e,128,u-128),g=new Uint8Array(l*c),p=0,y=0;for(let S=0;S<c;S+=1){let _=0;for(;_<h&&p<m.length;){let x=1,b=m[p++];if((b&192)===192){if(x=b&63,p>=m.length)throw new ur("Unexpected end of PCX RLE data");b=m[p++]}for(let A=0;A<x&&_<h;A+=1)_<l&&(g[y++]=b),_+=1}}return{width:l,height:c,bitsPerPixel:i,pixels:g,palette:f}}function Fs(e){let t=new Uint8Array(e.width*e.height*4);for(let r=0;r<e.pixels.length;r+=1){let n=e.pixels[r],i=n*3,s=r*4;t[s]=e.palette[i],t[s+1]=e.palette[i+1],t[s+2]=e.palette[i+2],t[s+3]=n===255?0:255}return t}var yt=class extends Error{constructor(t){super(t),this.name="TgaParseError"}};function Pa(e){let t=new DataView(e);if(e.byteLength<18)throw new yt("Buffer too small for TGA header");let r=t.getUint8(0),n=t.getUint8(1),i=t.getUint8(2),s=t.getUint16(12,!0),o=t.getUint16(14,!0),a=t.getUint8(16),d=t.getUint8(17);if(i!==2&&i!==10&&i!==3&&i!==11)throw new yt(`Unsupported TGA image type: ${i} (only RGB/Grayscale supported)`);if(a!==24&&a!==32&&a!==8)throw new yt(`Unsupported pixel depth: ${a} (only 8, 24, 32 bpp supported)`);let l=i>=9,c=i===3||i===11,h=a/8,u=18+r;if(n===1){let _=t.getUint16(5,!0),x=t.getUint8(7);u+=_*(x/8)}let f=s*o,m=new Uint8Array(f*4),g=(d&32)!==0,p=0,y=new Uint8Array(e),S=_=>{if(c){let x=y[u++];m[_]=x,m[_+1]=x,m[_+2]=x,m[_+3]=255}else{let x=y[u++],b=y[u++],A=y[u++],v=a===32?y[u++]:255;m[_]=A,m[_+1]=b,m[_+2]=x,m[_+3]=v}};if(l){let _=0;for(;_<f;){if(u>=e.byteLength)throw new yt("Unexpected end of TGA RLE data");let x=y[u++],b=(x&127)+1,A=(x&128)!==0;if(_+b>f)throw new yt("TGA RLE packet exceeds image bounds");if(A){let v=c?y[u]:y[u+2],E=c?y[u]:y[u+1],L=y[u],w=c?255:a===32?y[u+3]:255;u+=h;for(let T=0;T<b;T++){let z=(_+T)*4;m[z]=v,m[z+1]=E,m[z+2]=L,m[z+3]=w}}else for(let v=0;v<b;v++)S((_+v)*4);_+=b}}else for(let _=0;_<f;_++){if(u>=e.byteLength)throw new yt("Unexpected end of TGA data");S(_*4)}if(!g){let _=s*4,x=new Uint8Array(_);for(let b=0;b<o/2;b++){let A=b*_,v=(o-1-b)*_;x.set(m.subarray(A,A+_)),m.set(m.subarray(v,v+_),A),m.set(x,v)}}return{width:s,height:o,bitsPerPixel:32,pixels:m}}var jr=class{constructor(t={}){this.cache=new Ot(t.capacity??128)}get size(){return this.cache.size}get(t){return this.cache.get(t.toLowerCase())}set(t,r){this.cache.set(t.toLowerCase(),r)}clear(){this.cache.clear()}};function Na(e,t){let r=[];for(let n of e.mipmaps){let i=new Uint8Array(n.width*n.height*4);for(let s=0;s<n.data.length;s+=1){let o=n.data[s],a=o*3,d=s*4;i[d]=t[a],i[d+1]=t[a+1],i[d+2]=t[a+2],i[d+3]=o===255?0:255}r.push({level:n.level,width:n.width,height:n.height,rgba:i})}return{width:e.width,height:e.height,levels:r,source:"wal"}}function ks(e){let t=Fs(e),r={level:0,width:e.width,height:e.height,rgba:t};return{width:e.width,height:e.height,levels:[r],source:"pcx"}}function sd(e){let t={level:0,width:e.width,height:e.height,rgba:e.pixels};return{width:e.width,height:e.height,levels:[t],source:"tga"}}function Bs(e,t){return Na(zs(e),t)}var fr=class extends Error{constructor(t){super(t),this.name="WavParseError"}};function Ua(e,t,r){return new TextDecoder("ascii").decode(new Uint8Array(e.buffer,e.byteOffset+t,r))}function Ds(e){if(e.byteLength<44)throw new fr("WAV buffer too small");let t=new DataView(e);if(Ua(t,0,4)!=="RIFF"||Ua(t,8,4)!=="WAVE")throw new fr("Invalid WAV header");let r=12,n=-1,i=-1,s=0,o=0;for(;r+8<=e.byteLength;){let m=Ua(t,r,4),g=t.getUint32(r+4,!0),p=r+8;m==="fmt "?(n=p,s=g):m==="data"&&(i=p,o=g),r=p+g}if(n===-1||i===-1)throw new fr("Missing fmt or data chunk");let a=t.getUint16(n,!0),d=t.getUint16(n+2,!0),l=t.getUint32(n+4,!0),c=t.getUint16(n+14,!0);if(a!==1)throw new fr("Only PCM WAV is supported");let h=c/8,u=o/(h*d),f=new Float32Array(u*d);for(let m=0;m<u;m+=1)for(let g=0;g<d;g+=1){let p=m*d+g,y=i+p*h,S=0;if(c===8)S=t.getUint8(y),f[p]=(S-128)/128;else if(c===16)S=t.getInt16(y,!0),f[p]=S/32768;else if(c===24){let _=t.getUint8(y),x=t.getUint8(y+1),b=t.getInt8(y+2);S=_|x<<8|b<<16,f[p]=S/8388608}else throw new fr(`Unsupported bitsPerSample: ${c}`)}return{sampleRate:l,channels:d,bitsPerSample:c,samples:f}}var Ph=(e,t=4294967295,r=79764919)=>{let n=new Int32Array(256),i,s,o,a=t;for(i=0;i<256;i++){for(o=i<<24,s=8;s>0;--s)o=2147483648&o?o<<1^r:o<<1;n[i]=o}for(i=0;i<e.length;i++)a=a<<8^n[255&(a>>24^e[i])];return a};var Ha=(e,t=Ph)=>{let r=p=>new Uint8Array(p.length/2).map(((y,S)=>parseInt(p.substring(2*S,2*(S+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 s=new Uint8Array(e.length),o,a,d,l=!1,c=0,h=42,u=e.length>13&&e.substring(0,9)==="dynEncode",f=0;u&&(f=11,a=n(e.substring(9,f)),a<=1&&(f+=2,h=n(e.substring(11,f))),a===1&&(f+=8,d=(p=>new DataView(r(p).buffer).getInt32(0,!0))(e.substring(13,f))));let m=256-h;for(let p=f;p<e.length;p++)if(o=e.charCodeAt(p),o!==61||l){if(o===92&&p<e.length-5&&u){let y=e.charCodeAt(p+1);y!==117&&y!==85||(o=parseInt(e.substring(p+2,p+6),16),p+=5)}if(o>255){let y=i.get(o);y&&(o=y+127)}l&&(l=!1,o-=64),s[c++]=o<h&&o>0?o+m:o-h}else l=!0;let g=s.subarray(0,c);if(u&&a===1){let p=t(g);if(p!==d){let y="Decode failed crc32 validation";throw console.error("`simple-yenc`\n",y+`
|
|
2
2
|
`,"Expected: "+d+"; Got: "+p+`
|
|
3
|
-
`,"Visit https://github.com/eshaz/simple-yenc for more information"),Error(y)}}return g};function te(){let e=Uint8Array,t=Float32Array;te.modules||Object.defineProperties(te,{modules:{value:new WeakMap},setModule:{value(r,n){te.modules.set(r,Promise.resolve(n))}},getModule:{value(r,n){let i=te.modules.get(r);return i||(n?i=WebAssembly.compile(Ha(n)):(n=r.wasm,i=te.inflateDynEncodeString(n).then(o=>WebAssembly.compile(o))),te.modules.set(r,i)),i}},concatFloat32:{value(r,n){let i=new t(n),o=0,s=0;for(;o<r.length;)i.set(r[o],s),s+=r[o++].length;return i}},getDecodedAudio:{value:(r,n,i,o,s)=>({errors:r,channelData:n,samplesDecoded:i,sampleRate:o,bitDepth:s})},getDecodedAudioMultiChannel:{value(r,n,i,o,s,a){let d=[],l,c;for(l=0;l<i;l++){let h=[];for(c=0;c<n.length;)h.push(n[c++][l]||[]);d.push(te.concatFloat32(h,o))}return te.getDecodedAudio(r,d,o,s,a)}},inflateDynEncodeString:{value(r){return r=Ha(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 `;te.getModule(te,i).then(o=>WebAssembly.instantiate(o,{})).then(({exports:o})=>{let s=new Map(Object.entries(o)),a=s.get("puff"),d=s.get("memory").buffer,l=new e(d),c=new DataView(d),h=s.get("__heap_base"),u=r.length,f=h;h+=4,c.setInt32(f,u,!0);let m=h;h+=u,l.set(r,m);let g=h;h+=4,c.setInt32(g,l.byteLength-h,!0),a(h,g,m,f),n(l.slice(h,h+c.getInt32(g,!0)))})})}}}),Object.defineProperty(this,"wasm",{enumerable:!0,get:()=>this._wasm}),this.getOutputChannels=(r,n,i)=>{let o=[],s=0;for(;s<n;)o.push(r.slice(s*i,s++*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,s,a)=>{r.push({message:n,frameLength:i,frameNumber:o,inputBytes:s,outputSamples:a})},this.instantiate=(r,n)=>(n&&te.setModule(r,n),this._wasm=new r(te).instantiate(),this._pointers=new Set,this._wasm.ready.then(()=>this))}var ld=Yu(ad(),1);var Nh=()=>globalThis.Worker||ld.default,Qr=class extends Nh(){constructor(t,r,n,i){te.modules||new te;let o=te.modules.get(n);if(!o){let s="text/javascript",a,d=`'use strict';(${((l,c,h)=>{let u,f,m=new Promise(g=>{f=g});self.onmessage=({data:{id:g,command:p,data:y}})=>{let S=m,_={id:g},x;p==="init"?(Object.defineProperties(l,{WASMAudioDecoderCommon:{value:c},EmscriptenWASM:{value:h},module:{value:y.module},isWebWorker:{value:!0}}),u=new l(y.options),f()):p==="free"?u.free():p==="ready"?S=S.then(()=>u.ready):p==="reset"?S=S.then(()=>u.reset()):(Object.assign(_,u[p](Array.isArray(y)?y.map(b=>new Uint8Array(b)):new Uint8Array(y))),x=_.channelData?_.channelData.map(b=>b.buffer):[]),S.then(()=>self.postMessage(_,x))}}).toString()})(${n}, ${te}, ${i})`;try{a=typeof process.versions.node<"u"}catch{}o=a?`data:${s};base64,${Buffer.from(d).toString("base64")}`:URL.createObjectURL(new Blob([d],{type:s})),te.modules.set(n,o)}super(o,{name:r}),this._id=Number.MIN_SAFE_INTEGER,this._enqueuedOperations=new Map,this.onmessage=({data:s})=>{let{id:a,...d}=s;this._enqueuedOperations.get(a)(d),this._enqueuedOperations.delete(a)},new i(te).getModule().then(s=>{this.postToDecoder("init",{module:s,options:t})})}async postToDecoder(t,r){return new Promise(n=>{this.postMessage({command:t,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 Oo=(e,t)=>{Object.defineProperty(e,"name",{value:t})};var re=Symbol,cd=", ",D=(()=>{let e="front",t="side",r="rear",n="left",i="center",o="right";return["",e+" ",t+" ",r+" "].map(s=>[[n,o],[n,o,i],[n,i,o],[i,n,o],[i]].flatMap(a=>a.map(d=>s+d).join(cd)))})(),st="LFE",Nt="monophonic (mono)",Ut="stereo",Kn="surround",ie=(e,...t)=>`${[Nt,Ut,`linear ${Kn}`,"quadraphonic",`5.0 ${Kn}`,`5.1 ${Kn}`,`6.1 ${Kn}`,`7.1 ${Kn}`][e-1]} (${t.join(cd)})`,$n=[Nt,ie(2,D[0][0]),ie(3,D[0][2]),ie(4,D[1][0],D[3][0]),ie(5,D[1][2],D[3][0]),ie(6,D[1][2],D[3][0],st),ie(7,D[1][2],D[2][0],D[3][4],st),ie(8,D[1][2],D[2][0],D[3][0],st)],dd=192e3,ud=176400,No=96e3,Uo=88200,fd=64e3,Ht=48e3,Jr=44100,en=32e3,tn=24e3,rn=22050,nn=16e3,Ho=12e3,Vo=11025,on=8e3,hd=7350,et="absoluteGranulePosition",N="bandwidth",_e="bitDepth",be="bitrate",Zn=be+"Maximum",Yn=be+"Minimum",qn=be+"Nominal",at="buffer",jn=at+"Fullness",ee="codec",ve=ee+"Frames",Qn="coupledStreamCount",sn="crc",Jn=sn+"16",ei=sn+"32",Q="data",B="description",lt="duration",an="emphasis",ti="hasOpusPadding",ke="header",Vt="isContinuedPacket",ri="isCopyrighted",Gt="isFirstPage",ni="isHome",Be="isLastPage",xt="isOriginal",_t="isPrivate",ii="isVbr",Re="layer",M="length",O="mode",bt=O+"Extension",Go="mpeg",vt=Go+"Version",oi="numberAACFrames",si="outputGain",hr="preSkip",ai="profile",Wo=re(),St="protection",Va="rawData",We="segments",H="subarray",Wt="version",mr="vorbis",li=mr+"Comments",ln=mr+"Setup",Xo="block",ci=Xo+"ingStrategy",Ko=re(),wt=Xo+"Size",Xt=Xo+"size0",Kt=Xo+"size1",di=re(),$o="channel",At=$o+"MappingFamily",ui=$o+"MappingTable",Se=$o+"Mode",fi=re(),k=$o+"s",md="copyright",hi=md+"Id",mi=md+"IdStart",Mt="frame",Et=Mt+"Count",Ce=Mt+"Length",Zo="Number",Lt=Mt+Zo,ct=Mt+"Padding",P=Mt+"Size",pd="Rate",pi="inputSample"+pd,Ga="page",pr=Ga+"Checksum",cn=re(),$t=Ga+"SegmentTable",le=Ga+"Sequence"+Zo,Wa="sample",gi=Wa+Zo,G=Wa+pd,dt=re(),W=Wa+"s",Yo="stream",yi=Yo+"Count",xi=Yo+"Info",ut=Yo+"Serial"+Zo,Xa=Yo+"StructureVersion",Ka="total",gr=Ka+"BytesOut",yr=Ka+"Duration",xr=Ka+"Samples",K=re(),Xe=re(),_i=re(),Zt=re(),tt=re(),qo=re(),$a=re(),Yt=re(),Z=re(),Ke=re(),$e=re(),ft=re(),qt=re(),jo=re(),rt=re(),nt=re(),Ze=re(),Qo=re(),we=Uint8Array,jt=DataView,Y="reserved",Ae="bad",dn="free",bi="none",Jo="16bit CRC";var Za=(e,t,r)=>{for(let n=0;n<e[M];n++){let i=t(n);for(let o=8;o>0;o--)i=r(i);e[n]=i}return e},Hh=Za(new we(256),e=>e,e=>e&128?7^e<<1:e<<1),oe=[Za(new Uint16Array(256),e=>e<<8,e=>e<<1^(e&32768?32773:0))],se=[Za(new Uint32Array(256),e=>e,e=>e>>>1^(e&1)*3988292384)];for(let e=0;e<15;e++){oe.push(new Uint16Array(256)),se.push(new Uint32Array(256));for(let t=0;t<=255;t++)oe[e+1][t]=oe[0][oe[e][t]>>>8]^oe[e][t]<<8,se[e+1][t]=se[e][t]>>>8^se[0][se[e][t]&255]}var yd=e=>{let t=0,r=e[M];for(let n=0;n!==r;n++)t=Hh[t^e[n]];return t},xd=e=>{let t=e[M],r=t-16,n=0,i=0;for(;i<=r;)n^=e[i++]<<8|e[i++],n=oe[15][n>>8]^oe[14][n&255]^oe[13][e[i++]]^oe[12][e[i++]]^oe[11][e[i++]]^oe[10][e[i++]]^oe[9][e[i++]]^oe[8][e[i++]]^oe[7][e[i++]]^oe[6][e[i++]]^oe[5][e[i++]]^oe[4][e[i++]]^oe[3][e[i++]]^oe[2][e[i++]]^oe[1][e[i++]]^oe[0][e[i++]];for(;i!==t;)n=(n&255)<<8^oe[0][n>>8^e[i++]];return n},_d=e=>{let t=e[M],r=t-16,n=0,i=0;for(;i<=r;)n=se[15][(e[i++]^n)&255]^se[14][(e[i++]^n>>>8)&255]^se[13][(e[i++]^n>>>16)&255]^se[12][e[i++]^n>>>24]^se[11][e[i++]]^se[10][e[i++]]^se[9][e[i++]]^se[8][e[i++]]^se[7][e[i++]]^se[6][e[i++]]^se[5][e[i++]]^se[4][e[i++]]^se[3][e[i++]]^se[2][e[i++]]^se[1][e[i++]]^se[0][e[i++]];for(;i!==t;)n=se[0][(n^e[i++])&255]^n>>>8;return n^-1},Si=(...e)=>{let t=new we(e.reduce((r,n)=>r+n[M],0));return e.reduce((r,n)=>(t.set(n,r),r+n[M]),0),t},De=e=>String.fromCharCode(...e),gd=[0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15],vi=e=>gd[e&15]<<4|gd[e>>4],es=class{constructor(t){this._data=t,this._pos=t[M]*8}set position(t){this._pos=t}get position(){return this._pos}read(t){let r=Math.floor(this._pos/8),n=this._pos%8;return this._pos-=t,(vi(this._data[r-1])<<8)+vi(this._data[r])>>7-n&255}},bd=(e,t)=>{try{return e.getBigInt64(t,!0)}catch{let r=e.getUint8(t+7)&128?-1:1,n=e.getUint32(t,!0),i=e.getUint32(t+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 wi=class{constructor(t,r){this._onCodecHeader=t,this._onCodecUpdate=r,this[rt]()}[nt](){this._isEnabled=!0}[rt](){this._headerCache=new Map,this._codecUpdateData=new WeakMap,this._codecHeaderSent=!1,this._codecShouldUpdate=!1,this._bitrate=null,this._isEnabled=!1}[jo](t,r){if(this._onCodecUpdate){this._bitrate!==t&&(this._bitrate=t,this._codecShouldUpdate=!0);let n=this._codecUpdateData.get(this._headerCache.get(this._currentHeader));this._codecShouldUpdate&&n&&this._onCodecUpdate({bitrate:t,...n},r),this._codecShouldUpdate=!1}}[Z](t){let r=this._headerCache.get(t);return r&&this._updateCurrentHeader(t),r}[Ke](t,r,n){this._isEnabled&&(this._codecHeaderSent||(this._onCodecHeader({...r}),this._codecHeaderSent=!0),this._updateCurrentHeader(t),this._headerCache.set(t,r),this._codecUpdateData.set(r,n))}_updateCurrentHeader(t){this._onCodecUpdate&&t!==this._currentHeader&&(this._codecShouldUpdate=!0,this._currentHeader=t)}};var ue=new WeakMap,ge=new WeakMap;var Me=class{constructor(t,r){this._codecParser=t,this._headerCache=r}*[$a](){let t;do{if(t=yield*this.Frame[$e](this._codecParser,this._headerCache,0),t)return t;this._codecParser[Xe](1)}while(!0)}*[Yt](t){let r=yield*this[$a](),n=ge.get(r)[M];if(t||this._codecParser._flushing||(yield*this.Header[Z](this._codecParser,this._headerCache,n)))return this._headerCache[nt](),this._codecParser[Xe](n),this._codecParser[Zt](r),r;this._codecParser[tt](`Missing ${Mt} at ${n} bytes from current position.`,`Dropping current ${Mt} and trying again.`),this._headerCache[rt](),this._codecParser[Xe](1)}};var _r=class{constructor(t,r){ge.set(this,{[ke]:t}),this[Q]=r}};var Pe=class extends _r{static*[$e](t,r,n,i,o){let s=yield*t[Z](n,i,o);if(s){let a=ue.get(s)[Ce],d=ue.get(s)[W],l=(yield*n[K](a,o))[H](0,a);return new r(s,l,d)}else return null}constructor(t,r,n){super(t,r),this[ke]=t,this[W]=n,this[lt]=n/t[G]*1e3,this[Lt]=null,this[gr]=null,this[xr]=null,this[yr]=null,ge.get(this)[M]=r[M]}};var Ya="unsynchronizationFlag",qa="extendedHeaderFlag",ja="experimentalFlag",Qa="footerPresent",Ai=class e{static*getID3v2Header(t,r,n){let o={},s=yield*t[K](3,n);if(s[0]!==73||s[1]!==68||s[2]!==51||(s=yield*t[K](10,n),o[Wt]=`id3v2.${s[3]}.${s[4]}`,s[5]&15)||(o[Ya]=!!(s[5]&128),o[qa]=!!(s[5]&64),o[ja]=!!(s[5]&32),o[Qa]=!!(s[5]&16),s[6]&128||s[7]&128||s[8]&128||s[9]&128))return null;let a=s[6]<<21|s[7]<<14|s[8]<<7|s[9];return o[M]=10+a,new e(o)}constructor(t){this[Wt]=t[Wt],this[Ya]=t[Ya],this[qa]=t[qa],this[ja]=t[ja],this[Qa]=t[Qa],this[M]=t[M]}};var Oe=class{constructor(t){ue.set(this,t),this[_e]=t[_e],this[be]=null,this[k]=t[k],this[Se]=t[Se],this[G]=t[G]}};var Md={0:[dn,dn,dn,dn,dn],16:[32,32,32,32,8],240:[Ae,Ae,Ae,Ae,Ae]},ts=(e,t,r)=>8*((e+r)%t+t)*(1<<(e+r)/t)-8*t*(t/8|0);for(let e=2;e<15;e++)Md[e<<4]=[e*32,ts(e,4,0),ts(e,4,-1),ts(e,8,4),ts(e,8,0)];var Vh=0,Gh=1,Wh=2,Xh=3,vd=4,rs="bands ",ns=" to 31",Sd={0:rs+4+ns,16:rs+8+ns,32:rs+12+ns,48:rs+16+ns},br="bitrateIndex",Mi="v2",ls="v1",is="Intensity stereo ",os=", MS stereo ",ss="on",as="off",Kh={0:is+as+os+as,16:is+ss+os+as,32:is+as+os+ss,48:is+ss+os+ss},Ja={0:{[B]:Y},2:{[B]:"Layer III",[ct]:1,[bt]:Kh,[ls]:{[br]:Wh,[W]:1152},[Mi]:{[br]:vd,[W]:576}},4:{[B]:"Layer II",[ct]:1,[bt]:Sd,[W]:1152,[ls]:{[br]:Gh},[Mi]:{[br]:vd}},6:{[B]:"Layer I",[ct]:4,[bt]:Sd,[W]:384,[ls]:{[br]:Vh},[Mi]:{[br]:Xh}}},el="MPEG Version ",wd="ISO/IEC ",$h={0:{[B]:`${el}2.5 (later extension of MPEG 2)`,[Re]:Mi,[G]:{0:Vo,4:Ho,8:on,12:Y}},8:{[B]:Y},16:{[B]:`${el}2 (${wd}13818-3)`,[Re]:Mi,[G]:{0:rn,4:tn,8:nn,12:Y}},24:{[B]:`${el}1 (${wd}11172-3)`,[Re]:ls,[G]:{0:Jr,4:Ht,8:en,12:Y}},length:M},Zh={0:Jo,1:bi},Yh={0:bi,1:"50/15 ms",2:Y,3:"CCIT J.17"},Ad={0:{[k]:2,[B]:Ut},64:{[k]:2,[B]:"joint "+Ut},128:{[k]:2,[B]:"dual channel"},192:{[k]:1,[B]:Nt}},vr=class e extends Oe{static*[Z](t,r,n){let i={},o=yield*Ai.getID3v2Header(t,r,n);o&&(yield*t[K](o[M],n),t[Xe](o[M]));let s=yield*t[K](4,n),a=De(s[H](0,4)),d=r[Z](a);if(d)return new e(d);if(s[0]!==255||s[1]<224)return null;let l=$h[s[1]&24];if(l[B]===Y)return null;let c=s[1]&6;if(Ja[c][B]===Y)return null;let h={...Ja[c],...Ja[c][l[Re]]};if(i[vt]=l[B],i[Re]=h[B],i[W]=h[W],i[St]=Zh[s[1]&1],i[M]=4,i[be]=Md[s[2]&240][h[br]],i[be]===Ae||(i[G]=l[G][s[2]&12],i[G]===Y)||(i[ct]=s[2]&2&&h[ct],i[_t]=!!(s[2]&1),i[Ce]=Math.floor(125*i[be]*i[W]/i[G]+i[ct]),!i[Ce]))return null;let u=s[3]&192;if(i[Se]=Ad[u][B],i[k]=Ad[u][k],i[bt]=h[bt][s[3]&48],i[ri]=!!(s[3]&8),i[xt]=!!(s[3]&4),i[an]=Yh[s[3]&3],i[an]===Y)return null;i[_e]=16;{let{length:f,frameLength:m,samples:g,...p}=i;r[Ke](a,i,p)}return new e(i)}constructor(t){super(t),this[be]=t[be],this[an]=t[an],this[ct]=t[ct],this[ri]=t[ri],this[xt]=t[xt],this[_t]=t[_t],this[Re]=t[Re],this[bt]=t[bt],this[vt]=t[vt],this[St]=t[St]}};var Ei=class e extends Pe{static*[$e](t,r,n){return yield*super[$e](vr,e,t,r,n)}constructor(t,r,n){super(t,r,n)}};var Li=class extends Me{constructor(t,r,n){super(t,r),this.Frame=Ei,this.Header=vr,n(this[ee])}get[ee](){return Go}*[ft](){return yield*this[Yt]()}};var qh={0:"MPEG-4",8:"MPEG-2"},jh={0:"valid",2:Ae,4:Ae,6:Ae},Qh={0:Jo,1:bi},Jh={0:"AAC Main",64:"AAC LC (Low Complexity)",128:"AAC SSR (Scalable Sample Rate)",192:"AAC LTP (Long Term Prediction)"},em={0:No,4:Uo,8:fd,12:Ht,16:Jr,20:en,24:tn,28:rn,32:nn,36:Ho,40:Vo,44:on,48:hd,52:Y,56:Y,60:"frequency is written explicitly"},Ed={0:{[k]:0,[B]:"Defined in AOT Specific Config"},64:{[k]:1,[B]:Nt},128:{[k]:2,[B]:ie(2,D[0][0])},192:{[k]:3,[B]:ie(3,D[1][3])},256:{[k]:4,[B]:ie(4,D[1][3],D[3][4])},320:{[k]:5,[B]:ie(5,D[1][3],D[3][0])},384:{[k]:6,[B]:ie(6,D[1][3],D[3][0],st)},448:{[k]:8,[B]:ie(8,D[1][3],D[2][0],D[3][0],st)}},Sr=class e extends Oe{static*[Z](t,r,n){let i={},o=yield*t[K](7,n),s=De([o[0],o[1],o[2],o[3]&252|o[6]&3]),a=r[Z](s);if(a)Object.assign(i,a);else{if(o[0]!==255||o[1]<240||(i[vt]=qh[o[1]&8],i[Re]=jh[o[1]&6],i[Re]===Ae))return null;let l=o[1]&1;i[St]=Qh[l],i[M]=l?7:9,i[Wo]=o[2]&192,i[dt]=o[2]&60;let c=o[2]&2;if(i[ai]=Jh[i[Wo]],i[G]=em[i[dt]],i[G]===Y)return null;i[_t]=!!c,i[fi]=(o[2]<<8|o[3])&448,i[Se]=Ed[i[fi]][B],i[k]=Ed[i[fi]][k],i[xt]=!!(o[3]&32),i[ni]=!!(o[3]&8),i[hi]=!!(o[3]&8),i[mi]=!!(o[3]&4),i[_e]=16,i[W]=1024,i[oi]=o[6]&3;{let{length:h,channelModeBits:u,profileBits:f,sampleRateBits:m,frameLength:g,samples:p,numberAACFrames:y,...S}=i;r[Ke](s,i,S)}}if(i[Ce]=(o[3]<<11|o[4]<<3|o[5]>>5)&8191,!i[Ce])return null;let d=(o[5]<<6|o[6]>>2)&2047;return i[jn]=d===2047?"VBR":d,new e(i)}constructor(t){super(t),this[hi]=t[hi],this[mi]=t[mi],this[jn]=t[jn],this[ni]=t[ni],this[xt]=t[xt],this[_t]=t[_t],this[Re]=t[Re],this[M]=t[M],this[vt]=t[vt],this[oi]=t[oi],this[ai]=t[ai],this[St]=t[St]}get audioSpecificConfig(){let t=ue.get(this),r=t[Wo]+64<<5|t[dt]<<5|t[fi]>>3,n=new we(2);return new jt(n[at]).setUint16(0,r,!1),n}};var Ti=class e extends Pe{static*[$e](t,r,n){return yield*super[$e](Sr,e,t,r,n)}constructor(t,r,n){super(t,r,n)}};var Ii=class extends Me{constructor(t,r,n){super(t,r),this.Frame=Ti,this.Header=Sr,n(this[ee])}get[ee](){return"aac"}*[ft](){return yield*this[Yt]()}};var Qt=class e extends Pe{static _getFrameFooterCrc16(t){return(t[t[M]-2]<<8)+t[t[M]-1]}static[Qo](t){let r=e._getFrameFooterCrc16(t),n=xd(t[H](0,-2));return r===n}constructor(t,r,n){r[xi]=n,r[Jn]=e._getFrameFooterCrc16(t),super(r,t,ue.get(r)[W])}};var Ld="get from STREAMINFO metadata block",tm={0:"Fixed",1:"Variable"},Td={0:Y,16:192};for(let e=2;e<16;e++)Td[e<<4]=e<6?576*2**(e-2):2**e;var rm={0:Ld,1:Uo,2:ud,3:dd,4:on,5:nn,6:rn,7:tn,8:en,9:Jr,10:Ht,11:No,15:Ae},nm={0:{[k]:1,[B]:Nt},16:{[k]:2,[B]:ie(2,D[0][0])},32:{[k]:3,[B]:ie(3,D[0][1])},48:{[k]:4,[B]:ie(4,D[1][0],D[3][0])},64:{[k]:5,[B]:ie(5,D[1][1],D[3][0])},80:{[k]:6,[B]:ie(6,D[1][1],st,D[3][0])},96:{[k]:7,[B]:ie(7,D[1][1],st,D[3][4],D[2][0])},112:{[k]:8,[B]:ie(8,D[1][1],st,D[3][0],D[2][0])},128:{[k]:2,[B]:`${Ut} (left, diff)`},144:{[k]:2,[B]:`${Ut} (diff, right)`},160:{[k]:2,[B]:`${Ut} (avg, diff)`},176:Y,192:Y,208:Y,224:Y,240:Y},im={0:Ld,2:8,4:12,6:Y,8:16,10:20,12:24,14:Y},Jt=class e extends Oe{static _decodeUTF8Int(t){if(t[0]>254)return null;if(t[0]<128)return{value:t[0],length:1};let r=1;for(let s=64;s&t[0];s>>=1)r++;let n=r-1,i=0,o=0;for(;n>0;o+=6,n--){if((t[n]&192)!==128)return null;i|=(t[n]&63)<<o}return i|=(t[n]&127>>r)<<o,{value:i,length:r}}static[Ze](t,r){let n={[K]:function*(){return t}};return e[Z](n,r,0).next().value}static*[Z](t,r,n){let i=yield*t[K](6,n);if(i[0]!==255||!(i[1]===248||i[1]===249))return null;let o={},s=De(i[H](0,4)),a=r[Z](s);if(a)Object.assign(o,a);else{if(o[Ko]=i[1]&1,o[ci]=tm[o[Ko]],o[di]=i[2]&240,o[dt]=i[2]&15,o[wt]=Td[o[di]],o[wt]===Y||(o[G]=rm[o[dt]],o[G]===Ae)||i[3]&1)return null;let l=nm[i[3]&240];if(l===Y||(o[k]=l[k],o[Se]=l[B],o[_e]=im[i[3]&14],o[_e]===Y))return null}o[M]=5,i=yield*t[K](o[M]+8,n);let d=e._decodeUTF8Int(i[H](4));if(!d||(o[Ko]?o[gi]=d.value:o[Lt]=d.value,o[M]+=d[M],o[di]===96?(i[M]<o[M]&&(i=yield*t[K](o[M],n)),o[wt]=i[o[M]-1]+1,o[M]+=1):o[di]===112&&(i[M]<o[M]&&(i=yield*t[K](o[M],n)),o[wt]=(i[o[M]-1]<<8)+i[o[M]]+1,o[M]+=2),o[W]=o[wt],o[dt]===12?(i[M]<o[M]&&(i=yield*t[K](o[M],n)),o[G]=i[o[M]-1]*1e3,o[M]+=1):o[dt]===13?(i[M]<o[M]&&(i=yield*t[K](o[M],n)),o[G]=(i[o[M]-1]<<8)+i[o[M]],o[M]+=2):o[dt]===14&&(i[M]<o[M]&&(i=yield*t[K](o[M],n)),o[G]=((i[o[M]-1]<<8)+i[o[M]])*10,o[M]+=2),i[M]<o[M]&&(i=yield*t[K](o[M],n)),o[sn]=i[o[M]-1],o[sn]!==yd(i[H](0,o[M]-1))))return null;if(!a){let{blockingStrategyBits:l,frameNumber:c,sampleNumber:h,samples:u,sampleRateBits:f,blockSizeBits:m,crc:g,length:p,...y}=o;r[Ke](s,o,y)}return new e(o)}constructor(t){super(t),this[Jn]=null,this[ci]=t[ci],this[wt]=t[wt],this[Lt]=t[Lt],this[gi]=t[gi],this[xi]=null}};var om=2,sm=512*1024,wr=class extends Me{constructor(t,r,n){super(t,r),this.Frame=Qt,this.Header=Jt,n(this[ee])}get[ee](){return"flac"}*_getNextFrameSyncOffset(t){let r=yield*this._codecParser[K](2,0),n=r[M]-2;for(;t<n;){if(r[t]===255){let o=r[t+1];if(o===248||o===249)break;o!==255&&t++}t++}return t}*[ft](){do{let t=yield*Jt[Z](this._codecParser,this._headerCache,0);if(t){let r=ue.get(t)[M]+om;for(;r<=sm;){if(this._codecParser._flushing||(yield*Jt[Z](this._codecParser,this._headerCache,r))){let n=yield*this._codecParser[K](r);if(this._codecParser._flushing||(n=n[H](0,r)),Qt[Qo](n)){let i=new Qt(n,t);return this._headerCache[nt](),this._codecParser[Xe](r),this._codecParser[Zt](i),i}}r=yield*this._getNextFrameSyncOffset(r+1)}this._codecParser[tt](`Unable to sync FLAC frame after searching ${r} bytes.`),this._codecParser[Xe](r)}else this._codecParser[Xe](yield*this._getNextFrameSyncOffset(1))}while(!0)}[qt](t){return t[le]===0?(this._headerCache[nt](),this._streamInfo=t[Q][H](13)):t[le]===1||(t[ve]=ge.get(t)[We].map(r=>{let n=Jt[Ze](r,this._headerCache);if(n)return new Qt(r,n,this._streamInfo);this._codecParser[tt]("Failed to parse Ogg FLAC frame","Skipping invalid FLAC frame")}).filter(r=>!!r)),t}};var Ar=class e{static*[Z](t,r,n){let i={},o=yield*t[K](28,n);if(o[0]!==79||o[1]!==103||o[2]!==103||o[3]!==83||(i[Xa]=o[4],o[5]&248))return null;i[Be]=!!(o[5]&4),i[Gt]=!!(o[5]&2),i[Vt]=!!(o[5]&1);let a=new jt(we.from(o[H](0,28))[at]);i[et]=bd(a,6),i[ut]=a.getInt32(14,!0),i[le]=a.getInt32(18,!0),i[pr]=a.getInt32(22,!0);let d=o[26];i[M]=d+27,o=yield*t[K](i[M],n),i[Ce]=0,i[$t]=[],i[cn]=we.from(o[H](27,i[M]));for(let l=0,c=0;l<d;l++){let h=i[cn][l];i[Ce]+=h,c+=h,(h!==255||l===d-1)&&(i[$t].push(c),c=0)}return new e(i)}constructor(t){ue.set(this,t),this[et]=t[et],this[Vt]=t[Vt],this[Gt]=t[Gt],this[Be]=t[Be],this[$t]=t[$t],this[le]=t[le],this[pr]=t[pr],this[ut]=t[ut]}};var Ri=class e extends _r{static*[$e](t,r,n){let i=yield*Ar[Z](t,r,n);if(i){let o=ue.get(i)[Ce],s=ue.get(i)[M],a=s+o,d=(yield*t[K](a,0))[H](0,a),l=d[H](s,a);return new e(i,l,d)}else return null}constructor(t,r,n){super(t,r),ge.get(this)[M]=n[M],this[ve]=[],this[Va]=n,this[et]=t[et],this[ei]=t[pr],this[lt]=0,this[Vt]=t[Vt],this[Gt]=t[Gt],this[Be]=t[Be],this[le]=t[le],this[W]=0,this[ut]=t[ut]}};var un=class extends Pe{constructor(t,r,n){super(r,t,n)}};var Id={0:$n.slice(0,2),1:$n},Ye="SILK-only",ye="CELT-only",cs="Hybrid",er="narrowband",ds="medium-band",tr="wideband",fn="super-wideband",hn="fullband",am={0:{[O]:Ye,[N]:er,[P]:10},8:{[O]:Ye,[N]:er,[P]:20},16:{[O]:Ye,[N]:er,[P]:40},24:{[O]:Ye,[N]:er,[P]:60},32:{[O]:Ye,[N]:ds,[P]:10},40:{[O]:Ye,[N]:ds,[P]:20},48:{[O]:Ye,[N]:ds,[P]:40},56:{[O]:Ye,[N]:ds,[P]:60},64:{[O]:Ye,[N]:tr,[P]:10},72:{[O]:Ye,[N]:tr,[P]:20},80:{[O]:Ye,[N]:tr,[P]:40},88:{[O]:Ye,[N]:tr,[P]:60},96:{[O]:cs,[N]:fn,[P]:10},104:{[O]:cs,[N]:fn,[P]:20},112:{[O]:cs,[N]:hn,[P]:10},120:{[O]:cs,[N]:hn,[P]:20},128:{[O]:ye,[N]:er,[P]:2.5},136:{[O]:ye,[N]:er,[P]:5},144:{[O]:ye,[N]:er,[P]:10},152:{[O]:ye,[N]:er,[P]:20},160:{[O]:ye,[N]:tr,[P]:2.5},168:{[O]:ye,[N]:tr,[P]:5},176:{[O]:ye,[N]:tr,[P]:10},184:{[O]:ye,[N]:tr,[P]:20},192:{[O]:ye,[N]:fn,[P]:2.5},200:{[O]:ye,[N]:fn,[P]:5},208:{[O]:ye,[N]:fn,[P]:10},216:{[O]:ye,[N]:fn,[P]:20},224:{[O]:ye,[N]:hn,[P]:2.5},232:{[O]:ye,[N]:hn,[P]:5},240:{[O]:ye,[N]:hn,[P]:10},248:{[O]:ye,[N]:hn,[P]:20}},mn=class e extends Oe{static[Ze](t,r,n){let i={};if(i[k]=t[9],i[At]=t[18],i[M]=i[At]!==0?21+i[k]:19,t[M]<i[M])throw new Error("Out of data while inside an Ogg Page");let o=r[0]&3,s=o===3?2:1,a=De(t[H](0,i[M]))+De(r[H](0,s)),d=n[Z](a);if(d)return new e(d);if(a.substr(0,8)!=="OpusHead"||t[8]!==1)return null;i[Q]=we.from(t[H](0,i[M]));let l=new jt(i[Q][at]);if(i[_e]=16,i[hr]=l.getUint16(10,!0),i[pi]=l.getUint32(12,!0),i[G]=Ht,i[si]=l.getInt16(16,!0),i[At]in Id&&(i[Se]=Id[i[At]][i[k]-1],!i[Se]))return null;i[At]!==0&&(i[yi]=t[19],i[Qn]=t[20],i[ui]=[...t[H](21,i[k]+21)]);let c=am[248&r[0]];switch(i[O]=c[O],i[N]=c[N],i[P]=c[P],o){case 0:i[Et]=1;break;case 1:case 2:i[Et]=2;break;case 3:i[ii]=!!(128&r[1]),i[ti]=!!(64&r[1]),i[Et]=63&r[1];break;default:return null}{let{length:h,data:u,channelMappingFamily:f,...m}=i;n[Ke](a,i,m)}return new e(i)}constructor(t){super(t),this[Q]=t[Q],this[N]=t[N],this[At]=t[At],this[ui]=t[ui],this[Qn]=t[Qn],this[Et]=t[Et],this[P]=t[P],this[ti]=t[ti],this[pi]=t[pi],this[ii]=t[ii],this[O]=t[O],this[si]=t[si],this[hr]=t[hr],this[yi]=t[yi]}};var Ci=class extends Me{constructor(t,r,n){super(t,r),this.Frame=un,this.Header=mn,n(this[ee]),this._identificationHeader=null,this._preSkipRemaining=null}get[ee](){return"opus"}[qt](t){return t[le]===0?(this._headerCache[nt](),this._identificationHeader=t[Q]):t[le]===1||(t[ve]=ge.get(t)[We].map(r=>{let n=mn[Ze](this._identificationHeader,r,this._headerCache);if(n){this._preSkipRemaining===null&&(this._preSkipRemaining=n[hr]);let i=n[P]*n[Et]/1e3*n[G];return this._preSkipRemaining>0&&(this._preSkipRemaining-=i,i=this._preSkipRemaining<0?-this._preSkipRemaining:0),new un(r,n,i)}this._codecParser[qo]("Failed to parse Ogg Opus Header","Not a valid Ogg Opus file")})),t}};var pn=class extends Pe{constructor(t,r,n){super(r,t,n)}};var tl={};for(let e=0;e<8;e++)tl[e+6]=2**(6+e);var zi=class e extends Oe{static[Ze](t,r,n,i){if(t[M]<30)throw new Error("Out of data while inside an Ogg Page");let o=De(t[H](0,30)),s=r[Z](o);if(s)return new e(s);let a={[M]:30};if(o.substr(0,7)!=="vorbis")return null;a[Q]=we.from(t[H](0,30));let d=new jt(a[Q][at]);if(a[Wt]=d.getUint32(7,!0),a[Wt]!==0||(a[k]=t[11],a[Se]=$n[a[k]-1]||"application defined",a[G]=d.getUint32(12,!0),a[Zn]=d.getInt32(16,!0),a[qn]=d.getInt32(20,!0),a[Yn]=d.getInt32(24,!0),a[Kt]=tl[(t[28]&240)>>4],a[Xt]=tl[t[28]&15],a[Xt]>a[Kt])||t[29]!==1)return null;a[_e]=32,a[ln]=i,a[li]=n;{let{length:l,data:c,version:h,vorbisSetup:u,vorbisComments:f,...m}=a;r[Ke](o,a,m)}return new e(a)}constructor(t){super(t),this[Zn]=t[Zn],this[Yn]=t[Yn],this[qn]=t[qn],this[Xt]=t[Xt],this[Kt]=t[Kt],this[Q]=t[Q],this[li]=t[li],this[ln]=t[ln]}};var Fi=class extends Me{constructor(t,r,n){super(t,r),this.Frame=pn,n(this[ee]),this._identificationHeader=null,this._setupComplete=!1,this._prevBlockSize=null}get[ee](){return mr}[qt](t){t[ve]=[];for(let r of ge.get(t)[We])if(r[0]===1)this._headerCache[nt](),this._identificationHeader=t[Q],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=zi[Ze](this._identificationHeader,this._headerCache,this._vorbisComments,this._vorbisSetup);n?t[ve].push(new pn(r,n,this._getSamples(r,n))):this._codecParser[logError]("Failed to parse Ogg Vorbis Header","Not a valid Ogg Vorbis file")}return t}_getSamples(t,r){let i=this._mode.blockFlags[t[0]>>1&this._mode.mask]?r[Kt]:r[Xt],o=this._prevBlockSize===null?0:(this._prevBlockSize+i)/4;return this._prevBlockSize=i,o}_parseSetupHeader(t){let r=new es(t),n={count:0,blockFlags:[]};for(;(r.read(1)&1)!==1;);let i;for(;n.count<64&&r.position>0;){vi(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{((vi(i)&126)>>1)+1!==n.count&&this._codecParser[tt]("vorbis derived mode count did not match actual mode count");break}}return n.mask=(1<<Math.log2(n.count))-1,n}};var rl=class{constructor(t,r,n){this._codecParser=t,this._headerCache=r,this._onCodec=n,this._continuedPacket=new we,this._codec=null,this._isSupported=null,this._previousAbsoluteGranulePosition=null}get[ee](){return this._codec||""}_updateCodec(t,r){this._codec!==t&&(this._headerCache[rt](),this._parser=new r(this._codecParser,this._headerCache,this._onCodec),this._codec=t)}_checkCodecSupport({data:t}){let r=De(t[H](0,8));switch(r){case"fishead\0":return!1;case"OpusHead":return this._updateCodec("opus",Ci),!0;case(/^\x7fFLAC/.test(r)&&r):return this._updateCodec("flac",wr),!0;case(/^\x01vorbis/.test(r)&&r):return this._updateCodec(mr,Fi),!0;default:return!1}}_checkPageSequenceNumber(t){t[le]!==this._pageSequenceNumber+1&&this._pageSequenceNumber>1&&t[le]>1&&this._codecParser[tt]("Unexpected gap in Ogg Page Sequence Number.",`Expected: ${this._pageSequenceNumber+1}, Got: ${t[le]}`),this._pageSequenceNumber=t[le]}_parsePage(t){this._isSupported===null&&(this._pageSequenceNumber=t[le],this._isSupported=this._checkCodecSupport(t)),this._checkPageSequenceNumber(t);let r=ge.get(t),n=ue.get(r[ke]),i=0;if(r[We]=n[$t].map(o=>t[Q][H](i,i+=o)),this._continuedPacket[M]&&(r[We][0]=Si(this._continuedPacket,r[We][0]),this._continuedPacket=new we),n[cn][n[cn][M]-1]===255&&(this._continuedPacket=Si(this._continuedPacket,r[We].pop())),this._previousAbsoluteGranulePosition!==null&&(t[W]=Number(t[et]-this._previousAbsoluteGranulePosition)),this._previousAbsoluteGranulePosition=t[et],this._isSupported){let o=this._parser[qt](t);return this._codecParser[Zt](o),o}else return t}},ki=class extends Me{constructor(t,r,n){super(t,r),this._onCodec=n,this.Frame=Ri,this.Header=Ar,this._streams=new Map,this._currentSerialNumber=null}get[ee](){let t=this._streams.get(this._currentSerialNumber);return t?t.codec:""}*[ft](){let t=yield*this[Yt](!0);this._currentSerialNumber=t[ut];let r=this._streams.get(this._currentSerialNumber);return r||(r=new rl(this._codecParser,this._headerCache,this._onCodec),this._streams.set(this._currentSerialNumber,r)),t[Be]&&this._streams.delete(this._currentSerialNumber),r._parsePage(t)}};var nl=()=>{},Bi=class{constructor(t,{onCodec:r,onCodecHeader:n,onCodecUpdate:i,enableLogging:o=!1,enableFrameCRC32:s=!0}={}){this._inputMimeType=t,this._onCodec=r||nl,this._onCodecHeader=n||nl,this._onCodecUpdate=i,this._enableLogging=o,this._crc32=s?_d:nl,this[rt]()}get[ee](){return this._parser?this._parser[ee]:""}[rt](){this._headerCache=new wi(this._onCodecHeader,this._onCodecUpdate),this._generator=this._getGenerator(),this._generator.next()}*flush(){this._flushing=!0;for(let t=this._generator.next();t.value;t=this._generator.next())yield t.value;this._flushing=!1,this[rt]()}*parseChunk(t){for(let r=this._generator.next(t);r.value;r=this._generator.next())yield r.value}parseAll(t){return[...this.parseChunk(t),...this.flush()]}*_getGenerator(){if(this._inputMimeType.match(/aac/))this._parser=new Ii(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/mpeg/))this._parser=new Li(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/flac/))this._parser=new wr(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/ogg/))this._parser=new ki(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 t=yield*this._parser[ft]();t&&(yield t)}}*[K](t=0,r=0){let n;for(;this._rawData[M]<=t+r;){if(n=yield,this._flushing)return this._rawData[H](r);n&&(this._totalBytesIn+=n[M],this._rawData=Si(this._rawData,n))}return this._rawData[H](r)}[Xe](t){this._currentReadPosition+=t,this._rawData=this._rawData[H](t)}[_i](t){this._sampleRate=t[ke][G],t[ke][be]=t[lt]>0?Math.round(t[Q][M]/t[lt])*8:0,t[Lt]=this._frameNumber++,t[gr]=this._totalBytesOut,t[xr]=this._totalSamples,t[yr]=this._totalSamples/this._sampleRate*1e3,t[ei]=this._crc32(t[Q]),this._headerCache[jo](t[ke][be],t[yr]),this._totalBytesOut+=t[Q][M],this._totalSamples+=t[W]}[Zt](t){if(t[ve]){if(t[Be]){let r=t[W];t[ve].forEach(n=>{let i=n[W];r<i&&(n[W]=r>0?r:0,n[lt]=n[W]/n[ke][G]*1e3),r-=i,this[_i](n)})}else t[W]=0,t[ve].forEach(r=>{t[W]+=r[W],this[_i](r)});t[lt]=t[W]/this._sampleRate*1e3||0,t[xr]=this._totalSamples,t[yr]=this._totalSamples/this._sampleRate*1e3||0,t[gr]=this._totalBytesOut}else this[_i](t)}_log(t,r){if(this._enableLogging){let n=[`${ee}: ${this[ee]}`,`inputMimeType: ${this._inputMimeType}`,`readPosition: ${this._currentReadPosition}`,`totalBytesIn: ${this._totalBytesIn}`,`${gr}: ${this._totalBytesOut}`],i=Math.max(...n.map(o=>o[M]));r.push(`--stats--${"-".repeat(i-9)}`,...n,"-".repeat(i)),t("codec-parser",r.reduce((o,s)=>o+`
|
|
4
|
-
`+
|
|
3
|
+
`,"Visit https://github.com/eshaz/simple-yenc for more information"),Error(y)}}return g};function te(){let e=Uint8Array,t=Float32Array;te.modules||Object.defineProperties(te,{modules:{value:new WeakMap},setModule:{value(r,n){te.modules.set(r,Promise.resolve(n))}},getModule:{value(r,n){let i=te.modules.get(r);return i||(n?i=WebAssembly.compile(Ha(n)):(n=r.wasm,i=te.inflateDynEncodeString(n).then(s=>WebAssembly.compile(s))),te.modules.set(r,i)),i}},concatFloat32:{value(r,n){let i=new t(n),s=0,o=0;for(;s<r.length;)i.set(r[s],o),o+=r[s++].length;return i}},getDecodedAudio:{value:(r,n,i,s,o)=>({errors:r,channelData:n,samplesDecoded:i,sampleRate:s,bitDepth:o})},getDecodedAudioMultiChannel:{value(r,n,i,s,o,a){let d=[],l,c;for(l=0;l<i;l++){let h=[];for(c=0;c<n.length;)h.push(n[c++][l]||[]);d.push(te.concatFloat32(h,s))}return te.getDecodedAudio(r,d,s,o,a)}},inflateDynEncodeString:{value(r){return r=Ha(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 `;te.getModule(te,i).then(s=>WebAssembly.instantiate(s,{})).then(({exports:s})=>{let o=new Map(Object.entries(s)),a=o.get("puff"),d=o.get("memory").buffer,l=new e(d),c=new DataView(d),h=o.get("__heap_base"),u=r.length,f=h;h+=4,c.setInt32(f,u,!0);let m=h;h+=u,l.set(r,m);let g=h;h+=4,c.setInt32(g,l.byteLength-h,!0),a(h,g,m,f),n(l.slice(h,h+c.getInt32(g,!0)))})})}}}),Object.defineProperty(this,"wasm",{enumerable:!0,get:()=>this._wasm}),this.getOutputChannels=(r,n,i)=>{let s=[],o=0;for(;o<n;)s.push(r.slice(o*i,o++*i+i));return s},this.allocateTypedArray=(r,n,i=!0)=>{let s=this._wasm.malloc(n.BYTES_PER_ELEMENT*r);return i&&this._pointers.add(s),{ptr:s,len:r,buf:new n(this._wasm.HEAP,s,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 s=i[r];s!==0;s=i[++r])n.push(s);return String.fromCharCode.apply(null,n)},this.addError=(r,n,i,s,o,a)=>{r.push({message:n,frameLength:i,frameNumber:s,inputBytes:o,outputSamples:a})},this.instantiate=(r,n)=>(n&&te.setModule(r,n),this._wasm=new r(te).instantiate(),this._pointers=new Set,this._wasm.ready.then(()=>this))}var ld=Yu(ad(),1);var Nh=()=>globalThis.Worker||ld.default,Qr=class extends Nh(){constructor(t,r,n,i){te.modules||new te;let s=te.modules.get(n);if(!s){let o="text/javascript",a,d=`'use strict';(${((l,c,h)=>{let u,f,m=new Promise(g=>{f=g});self.onmessage=({data:{id:g,command:p,data:y}})=>{let S=m,_={id:g},x;p==="init"?(Object.defineProperties(l,{WASMAudioDecoderCommon:{value:c},EmscriptenWASM:{value:h},module:{value:y.module},isWebWorker:{value:!0}}),u=new l(y.options),f()):p==="free"?u.free():p==="ready"?S=S.then(()=>u.ready):p==="reset"?S=S.then(()=>u.reset()):(Object.assign(_,u[p](Array.isArray(y)?y.map(b=>new Uint8Array(b)):new Uint8Array(y))),x=_.channelData?_.channelData.map(b=>b.buffer):[]),S.then(()=>self.postMessage(_,x))}}).toString()})(${n}, ${te}, ${i})`;try{a=typeof process.versions.node<"u"}catch{}s=a?`data:${o};base64,${Buffer.from(d).toString("base64")}`:URL.createObjectURL(new Blob([d],{type:o})),te.modules.set(n,s)}super(s,{name:r}),this._id=Number.MIN_SAFE_INTEGER,this._enqueuedOperations=new Map,this.onmessage=({data:o})=>{let{id:a,...d}=o;this._enqueuedOperations.get(a)(d),this._enqueuedOperations.delete(a)},new i(te).getModule().then(o=>{this.postToDecoder("init",{module:o,options:t})})}async postToDecoder(t,r){return new Promise(n=>{this.postMessage({command:t,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 Os=(e,t)=>{Object.defineProperty(e,"name",{value:t})};var re=Symbol,cd=", ",D=(()=>{let e="front",t="side",r="rear",n="left",i="center",s="right";return["",e+" ",t+" ",r+" "].map(o=>[[n,s],[n,s,i],[n,i,s],[i,n,s],[i]].flatMap(a=>a.map(d=>o+d).join(cd)))})(),ot="LFE",Nt="monophonic (mono)",Ut="stereo",Kn="surround",ie=(e,...t)=>`${[Nt,Ut,`linear ${Kn}`,"quadraphonic",`5.0 ${Kn}`,`5.1 ${Kn}`,`6.1 ${Kn}`,`7.1 ${Kn}`][e-1]} (${t.join(cd)})`,$n=[Nt,ie(2,D[0][0]),ie(3,D[0][2]),ie(4,D[1][0],D[3][0]),ie(5,D[1][2],D[3][0]),ie(6,D[1][2],D[3][0],ot),ie(7,D[1][2],D[2][0],D[3][4],ot),ie(8,D[1][2],D[2][0],D[3][0],ot)],dd=192e3,ud=176400,Ps=96e3,Ns=88200,fd=64e3,Ht=48e3,Jr=44100,en=32e3,tn=24e3,rn=22050,nn=16e3,Us=12e3,Hs=11025,sn=8e3,hd=7350,et="absoluteGranulePosition",N="bandwidth",_e="bitDepth",be="bitrate",Zn=be+"Maximum",Yn=be+"Minimum",qn=be+"Nominal",at="buffer",jn=at+"Fullness",ee="codec",ve=ee+"Frames",Qn="coupledStreamCount",on="crc",Jn=on+"16",ei=on+"32",Q="data",B="description",lt="duration",an="emphasis",ti="hasOpusPadding",ke="header",Vt="isContinuedPacket",ri="isCopyrighted",Gt="isFirstPage",ni="isHome",Be="isLastPage",xt="isOriginal",_t="isPrivate",ii="isVbr",Re="layer",M="length",P="mode",bt=P+"Extension",Vs="mpeg",vt=Vs+"Version",si="numberAACFrames",oi="outputGain",hr="preSkip",ai="profile",Gs=re(),St="protection",Va="rawData",We="segments",H="subarray",Wt="version",mr="vorbis",li=mr+"Comments",ln=mr+"Setup",Ws="block",ci=Ws+"ingStrategy",Xs=re(),wt=Ws+"Size",Xt=Ws+"size0",Kt=Ws+"size1",di=re(),Ks="channel",At=Ks+"MappingFamily",ui=Ks+"MappingTable",Se=Ks+"Mode",fi=re(),k=Ks+"s",md="copyright",hi=md+"Id",mi=md+"IdStart",Mt="frame",Et=Mt+"Count",Ce=Mt+"Length",$s="Number",Lt=Mt+$s,ct=Mt+"Padding",O=Mt+"Size",pd="Rate",pi="inputSample"+pd,Ga="page",pr=Ga+"Checksum",cn=re(),$t=Ga+"SegmentTable",le=Ga+"Sequence"+$s,Wa="sample",gi=Wa+$s,G=Wa+pd,dt=re(),W=Wa+"s",Zs="stream",yi=Zs+"Count",xi=Zs+"Info",ut=Zs+"Serial"+$s,Xa=Zs+"StructureVersion",Ka="total",gr=Ka+"BytesOut",yr=Ka+"Duration",xr=Ka+"Samples",K=re(),Xe=re(),_i=re(),Zt=re(),tt=re(),Ys=re(),$a=re(),Yt=re(),Z=re(),Ke=re(),$e=re(),ft=re(),qt=re(),qs=re(),rt=re(),nt=re(),Ze=re(),js=re(),we=Uint8Array,jt=DataView,Y="reserved",Ae="bad",dn="free",bi="none",Qs="16bit CRC";var Za=(e,t,r)=>{for(let n=0;n<e[M];n++){let i=t(n);for(let s=8;s>0;s--)i=r(i);e[n]=i}return e},Hh=Za(new we(256),e=>e,e=>e&128?7^e<<1:e<<1),se=[Za(new Uint16Array(256),e=>e<<8,e=>e<<1^(e&32768?32773:0))],oe=[Za(new Uint32Array(256),e=>e,e=>e>>>1^(e&1)*3988292384)];for(let e=0;e<15;e++){se.push(new Uint16Array(256)),oe.push(new Uint32Array(256));for(let t=0;t<=255;t++)se[e+1][t]=se[0][se[e][t]>>>8]^se[e][t]<<8,oe[e+1][t]=oe[e][t]>>>8^oe[0][oe[e][t]&255]}var yd=e=>{let t=0,r=e[M];for(let n=0;n!==r;n++)t=Hh[t^e[n]];return t},xd=e=>{let t=e[M],r=t-16,n=0,i=0;for(;i<=r;)n^=e[i++]<<8|e[i++],n=se[15][n>>8]^se[14][n&255]^se[13][e[i++]]^se[12][e[i++]]^se[11][e[i++]]^se[10][e[i++]]^se[9][e[i++]]^se[8][e[i++]]^se[7][e[i++]]^se[6][e[i++]]^se[5][e[i++]]^se[4][e[i++]]^se[3][e[i++]]^se[2][e[i++]]^se[1][e[i++]]^se[0][e[i++]];for(;i!==t;)n=(n&255)<<8^se[0][n>>8^e[i++]];return n},_d=e=>{let t=e[M],r=t-16,n=0,i=0;for(;i<=r;)n=oe[15][(e[i++]^n)&255]^oe[14][(e[i++]^n>>>8)&255]^oe[13][(e[i++]^n>>>16)&255]^oe[12][e[i++]^n>>>24]^oe[11][e[i++]]^oe[10][e[i++]]^oe[9][e[i++]]^oe[8][e[i++]]^oe[7][e[i++]]^oe[6][e[i++]]^oe[5][e[i++]]^oe[4][e[i++]]^oe[3][e[i++]]^oe[2][e[i++]]^oe[1][e[i++]]^oe[0][e[i++]];for(;i!==t;)n=oe[0][(n^e[i++])&255]^n>>>8;return n^-1},Si=(...e)=>{let t=new we(e.reduce((r,n)=>r+n[M],0));return e.reduce((r,n)=>(t.set(n,r),r+n[M]),0),t},De=e=>String.fromCharCode(...e),gd=[0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15],vi=e=>gd[e&15]<<4|gd[e>>4],Js=class{constructor(t){this._data=t,this._pos=t[M]*8}set position(t){this._pos=t}get position(){return this._pos}read(t){let r=Math.floor(this._pos/8),n=this._pos%8;return this._pos-=t,(vi(this._data[r-1])<<8)+vi(this._data[r])>>7-n&255}},bd=(e,t)=>{try{return e.getBigInt64(t,!0)}catch{let r=e.getUint8(t+7)&128?-1:1,n=e.getUint32(t,!0),i=e.getUint32(t+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 wi=class{constructor(t,r){this._onCodecHeader=t,this._onCodecUpdate=r,this[rt]()}[nt](){this._isEnabled=!0}[rt](){this._headerCache=new Map,this._codecUpdateData=new WeakMap,this._codecHeaderSent=!1,this._codecShouldUpdate=!1,this._bitrate=null,this._isEnabled=!1}[qs](t,r){if(this._onCodecUpdate){this._bitrate!==t&&(this._bitrate=t,this._codecShouldUpdate=!0);let n=this._codecUpdateData.get(this._headerCache.get(this._currentHeader));this._codecShouldUpdate&&n&&this._onCodecUpdate({bitrate:t,...n},r),this._codecShouldUpdate=!1}}[Z](t){let r=this._headerCache.get(t);return r&&this._updateCurrentHeader(t),r}[Ke](t,r,n){this._isEnabled&&(this._codecHeaderSent||(this._onCodecHeader({...r}),this._codecHeaderSent=!0),this._updateCurrentHeader(t),this._headerCache.set(t,r),this._codecUpdateData.set(r,n))}_updateCurrentHeader(t){this._onCodecUpdate&&t!==this._currentHeader&&(this._codecShouldUpdate=!0,this._currentHeader=t)}};var ue=new WeakMap,ge=new WeakMap;var Me=class{constructor(t,r){this._codecParser=t,this._headerCache=r}*[$a](){let t;do{if(t=yield*this.Frame[$e](this._codecParser,this._headerCache,0),t)return t;this._codecParser[Xe](1)}while(!0)}*[Yt](t){let r=yield*this[$a](),n=ge.get(r)[M];if(t||this._codecParser._flushing||(yield*this.Header[Z](this._codecParser,this._headerCache,n)))return this._headerCache[nt](),this._codecParser[Xe](n),this._codecParser[Zt](r),r;this._codecParser[tt](`Missing ${Mt} at ${n} bytes from current position.`,`Dropping current ${Mt} and trying again.`),this._headerCache[rt](),this._codecParser[Xe](1)}};var _r=class{constructor(t,r){ge.set(this,{[ke]:t}),this[Q]=r}};var Oe=class extends _r{static*[$e](t,r,n,i,s){let o=yield*t[Z](n,i,s);if(o){let a=ue.get(o)[Ce],d=ue.get(o)[W],l=(yield*n[K](a,s))[H](0,a);return new r(o,l,d)}else return null}constructor(t,r,n){super(t,r),this[ke]=t,this[W]=n,this[lt]=n/t[G]*1e3,this[Lt]=null,this[gr]=null,this[xr]=null,this[yr]=null,ge.get(this)[M]=r[M]}};var Ya="unsynchronizationFlag",qa="extendedHeaderFlag",ja="experimentalFlag",Qa="footerPresent",Ai=class e{static*getID3v2Header(t,r,n){let s={},o=yield*t[K](3,n);if(o[0]!==73||o[1]!==68||o[2]!==51||(o=yield*t[K](10,n),s[Wt]=`id3v2.${o[3]}.${o[4]}`,o[5]&15)||(s[Ya]=!!(o[5]&128),s[qa]=!!(o[5]&64),s[ja]=!!(o[5]&32),s[Qa]=!!(o[5]&16),o[6]&128||o[7]&128||o[8]&128||o[9]&128))return null;let a=o[6]<<21|o[7]<<14|o[8]<<7|o[9];return s[M]=10+a,new e(s)}constructor(t){this[Wt]=t[Wt],this[Ya]=t[Ya],this[qa]=t[qa],this[ja]=t[ja],this[Qa]=t[Qa],this[M]=t[M]}};var Pe=class{constructor(t){ue.set(this,t),this[_e]=t[_e],this[be]=null,this[k]=t[k],this[Se]=t[Se],this[G]=t[G]}};var Md={0:[dn,dn,dn,dn,dn],16:[32,32,32,32,8],240:[Ae,Ae,Ae,Ae,Ae]},eo=(e,t,r)=>8*((e+r)%t+t)*(1<<(e+r)/t)-8*t*(t/8|0);for(let e=2;e<15;e++)Md[e<<4]=[e*32,eo(e,4,0),eo(e,4,-1),eo(e,8,4),eo(e,8,0)];var Vh=0,Gh=1,Wh=2,Xh=3,vd=4,to="bands ",ro=" to 31",Sd={0:to+4+ro,16:to+8+ro,32:to+12+ro,48:to+16+ro},br="bitrateIndex",Mi="v2",ao="v1",no="Intensity stereo ",io=", MS stereo ",so="on",oo="off",Kh={0:no+oo+io+oo,16:no+so+io+oo,32:no+oo+io+so,48:no+so+io+so},Ja={0:{[B]:Y},2:{[B]:"Layer III",[ct]:1,[bt]:Kh,[ao]:{[br]:Wh,[W]:1152},[Mi]:{[br]:vd,[W]:576}},4:{[B]:"Layer II",[ct]:1,[bt]:Sd,[W]:1152,[ao]:{[br]:Gh},[Mi]:{[br]:vd}},6:{[B]:"Layer I",[ct]:4,[bt]:Sd,[W]:384,[ao]:{[br]:Vh},[Mi]:{[br]:Xh}}},el="MPEG Version ",wd="ISO/IEC ",$h={0:{[B]:`${el}2.5 (later extension of MPEG 2)`,[Re]:Mi,[G]:{0:Hs,4:Us,8:sn,12:Y}},8:{[B]:Y},16:{[B]:`${el}2 (${wd}13818-3)`,[Re]:Mi,[G]:{0:rn,4:tn,8:nn,12:Y}},24:{[B]:`${el}1 (${wd}11172-3)`,[Re]:ao,[G]:{0:Jr,4:Ht,8:en,12:Y}},length:M},Zh={0:Qs,1:bi},Yh={0:bi,1:"50/15 ms",2:Y,3:"CCIT J.17"},Ad={0:{[k]:2,[B]:Ut},64:{[k]:2,[B]:"joint "+Ut},128:{[k]:2,[B]:"dual channel"},192:{[k]:1,[B]:Nt}},vr=class e extends Pe{static*[Z](t,r,n){let i={},s=yield*Ai.getID3v2Header(t,r,n);s&&(yield*t[K](s[M],n),t[Xe](s[M]));let o=yield*t[K](4,n),a=De(o[H](0,4)),d=r[Z](a);if(d)return new e(d);if(o[0]!==255||o[1]<224)return null;let l=$h[o[1]&24];if(l[B]===Y)return null;let c=o[1]&6;if(Ja[c][B]===Y)return null;let h={...Ja[c],...Ja[c][l[Re]]};if(i[vt]=l[B],i[Re]=h[B],i[W]=h[W],i[St]=Zh[o[1]&1],i[M]=4,i[be]=Md[o[2]&240][h[br]],i[be]===Ae||(i[G]=l[G][o[2]&12],i[G]===Y)||(i[ct]=o[2]&2&&h[ct],i[_t]=!!(o[2]&1),i[Ce]=Math.floor(125*i[be]*i[W]/i[G]+i[ct]),!i[Ce]))return null;let u=o[3]&192;if(i[Se]=Ad[u][B],i[k]=Ad[u][k],i[bt]=h[bt][o[3]&48],i[ri]=!!(o[3]&8),i[xt]=!!(o[3]&4),i[an]=Yh[o[3]&3],i[an]===Y)return null;i[_e]=16;{let{length:f,frameLength:m,samples:g,...p}=i;r[Ke](a,i,p)}return new e(i)}constructor(t){super(t),this[be]=t[be],this[an]=t[an],this[ct]=t[ct],this[ri]=t[ri],this[xt]=t[xt],this[_t]=t[_t],this[Re]=t[Re],this[bt]=t[bt],this[vt]=t[vt],this[St]=t[St]}};var Ei=class e extends Oe{static*[$e](t,r,n){return yield*super[$e](vr,e,t,r,n)}constructor(t,r,n){super(t,r,n)}};var Li=class extends Me{constructor(t,r,n){super(t,r),this.Frame=Ei,this.Header=vr,n(this[ee])}get[ee](){return Vs}*[ft](){return yield*this[Yt]()}};var qh={0:"MPEG-4",8:"MPEG-2"},jh={0:"valid",2:Ae,4:Ae,6:Ae},Qh={0:Qs,1:bi},Jh={0:"AAC Main",64:"AAC LC (Low Complexity)",128:"AAC SSR (Scalable Sample Rate)",192:"AAC LTP (Long Term Prediction)"},em={0:Ps,4:Ns,8:fd,12:Ht,16:Jr,20:en,24:tn,28:rn,32:nn,36:Us,40:Hs,44:sn,48:hd,52:Y,56:Y,60:"frequency is written explicitly"},Ed={0:{[k]:0,[B]:"Defined in AOT Specific Config"},64:{[k]:1,[B]:Nt},128:{[k]:2,[B]:ie(2,D[0][0])},192:{[k]:3,[B]:ie(3,D[1][3])},256:{[k]:4,[B]:ie(4,D[1][3],D[3][4])},320:{[k]:5,[B]:ie(5,D[1][3],D[3][0])},384:{[k]:6,[B]:ie(6,D[1][3],D[3][0],ot)},448:{[k]:8,[B]:ie(8,D[1][3],D[2][0],D[3][0],ot)}},Sr=class e extends Pe{static*[Z](t,r,n){let i={},s=yield*t[K](7,n),o=De([s[0],s[1],s[2],s[3]&252|s[6]&3]),a=r[Z](o);if(a)Object.assign(i,a);else{if(s[0]!==255||s[1]<240||(i[vt]=qh[s[1]&8],i[Re]=jh[s[1]&6],i[Re]===Ae))return null;let l=s[1]&1;i[St]=Qh[l],i[M]=l?7:9,i[Gs]=s[2]&192,i[dt]=s[2]&60;let c=s[2]&2;if(i[ai]=Jh[i[Gs]],i[G]=em[i[dt]],i[G]===Y)return null;i[_t]=!!c,i[fi]=(s[2]<<8|s[3])&448,i[Se]=Ed[i[fi]][B],i[k]=Ed[i[fi]][k],i[xt]=!!(s[3]&32),i[ni]=!!(s[3]&8),i[hi]=!!(s[3]&8),i[mi]=!!(s[3]&4),i[_e]=16,i[W]=1024,i[si]=s[6]&3;{let{length:h,channelModeBits:u,profileBits:f,sampleRateBits:m,frameLength:g,samples:p,numberAACFrames:y,...S}=i;r[Ke](o,i,S)}}if(i[Ce]=(s[3]<<11|s[4]<<3|s[5]>>5)&8191,!i[Ce])return null;let d=(s[5]<<6|s[6]>>2)&2047;return i[jn]=d===2047?"VBR":d,new e(i)}constructor(t){super(t),this[hi]=t[hi],this[mi]=t[mi],this[jn]=t[jn],this[ni]=t[ni],this[xt]=t[xt],this[_t]=t[_t],this[Re]=t[Re],this[M]=t[M],this[vt]=t[vt],this[si]=t[si],this[ai]=t[ai],this[St]=t[St]}get audioSpecificConfig(){let t=ue.get(this),r=t[Gs]+64<<5|t[dt]<<5|t[fi]>>3,n=new we(2);return new jt(n[at]).setUint16(0,r,!1),n}};var Ti=class e extends Oe{static*[$e](t,r,n){return yield*super[$e](Sr,e,t,r,n)}constructor(t,r,n){super(t,r,n)}};var Ii=class extends Me{constructor(t,r,n){super(t,r),this.Frame=Ti,this.Header=Sr,n(this[ee])}get[ee](){return"aac"}*[ft](){return yield*this[Yt]()}};var Qt=class e extends Oe{static _getFrameFooterCrc16(t){return(t[t[M]-2]<<8)+t[t[M]-1]}static[js](t){let r=e._getFrameFooterCrc16(t),n=xd(t[H](0,-2));return r===n}constructor(t,r,n){r[xi]=n,r[Jn]=e._getFrameFooterCrc16(t),super(r,t,ue.get(r)[W])}};var Ld="get from STREAMINFO metadata block",tm={0:"Fixed",1:"Variable"},Td={0:Y,16:192};for(let e=2;e<16;e++)Td[e<<4]=e<6?576*2**(e-2):2**e;var rm={0:Ld,1:Ns,2:ud,3:dd,4:sn,5:nn,6:rn,7:tn,8:en,9:Jr,10:Ht,11:Ps,15:Ae},nm={0:{[k]:1,[B]:Nt},16:{[k]:2,[B]:ie(2,D[0][0])},32:{[k]:3,[B]:ie(3,D[0][1])},48:{[k]:4,[B]:ie(4,D[1][0],D[3][0])},64:{[k]:5,[B]:ie(5,D[1][1],D[3][0])},80:{[k]:6,[B]:ie(6,D[1][1],ot,D[3][0])},96:{[k]:7,[B]:ie(7,D[1][1],ot,D[3][4],D[2][0])},112:{[k]:8,[B]:ie(8,D[1][1],ot,D[3][0],D[2][0])},128:{[k]:2,[B]:`${Ut} (left, diff)`},144:{[k]:2,[B]:`${Ut} (diff, right)`},160:{[k]:2,[B]:`${Ut} (avg, diff)`},176:Y,192:Y,208:Y,224:Y,240:Y},im={0:Ld,2:8,4:12,6:Y,8:16,10:20,12:24,14:Y},Jt=class e extends Pe{static _decodeUTF8Int(t){if(t[0]>254)return null;if(t[0]<128)return{value:t[0],length:1};let r=1;for(let o=64;o&t[0];o>>=1)r++;let n=r-1,i=0,s=0;for(;n>0;s+=6,n--){if((t[n]&192)!==128)return null;i|=(t[n]&63)<<s}return i|=(t[n]&127>>r)<<s,{value:i,length:r}}static[Ze](t,r){let n={[K]:function*(){return t}};return e[Z](n,r,0).next().value}static*[Z](t,r,n){let i=yield*t[K](6,n);if(i[0]!==255||!(i[1]===248||i[1]===249))return null;let s={},o=De(i[H](0,4)),a=r[Z](o);if(a)Object.assign(s,a);else{if(s[Xs]=i[1]&1,s[ci]=tm[s[Xs]],s[di]=i[2]&240,s[dt]=i[2]&15,s[wt]=Td[s[di]],s[wt]===Y||(s[G]=rm[s[dt]],s[G]===Ae)||i[3]&1)return null;let l=nm[i[3]&240];if(l===Y||(s[k]=l[k],s[Se]=l[B],s[_e]=im[i[3]&14],s[_e]===Y))return null}s[M]=5,i=yield*t[K](s[M]+8,n);let d=e._decodeUTF8Int(i[H](4));if(!d||(s[Xs]?s[gi]=d.value:s[Lt]=d.value,s[M]+=d[M],s[di]===96?(i[M]<s[M]&&(i=yield*t[K](s[M],n)),s[wt]=i[s[M]-1]+1,s[M]+=1):s[di]===112&&(i[M]<s[M]&&(i=yield*t[K](s[M],n)),s[wt]=(i[s[M]-1]<<8)+i[s[M]]+1,s[M]+=2),s[W]=s[wt],s[dt]===12?(i[M]<s[M]&&(i=yield*t[K](s[M],n)),s[G]=i[s[M]-1]*1e3,s[M]+=1):s[dt]===13?(i[M]<s[M]&&(i=yield*t[K](s[M],n)),s[G]=(i[s[M]-1]<<8)+i[s[M]],s[M]+=2):s[dt]===14&&(i[M]<s[M]&&(i=yield*t[K](s[M],n)),s[G]=((i[s[M]-1]<<8)+i[s[M]])*10,s[M]+=2),i[M]<s[M]&&(i=yield*t[K](s[M],n)),s[on]=i[s[M]-1],s[on]!==yd(i[H](0,s[M]-1))))return null;if(!a){let{blockingStrategyBits:l,frameNumber:c,sampleNumber:h,samples:u,sampleRateBits:f,blockSizeBits:m,crc:g,length:p,...y}=s;r[Ke](o,s,y)}return new e(s)}constructor(t){super(t),this[Jn]=null,this[ci]=t[ci],this[wt]=t[wt],this[Lt]=t[Lt],this[gi]=t[gi],this[xi]=null}};var sm=2,om=512*1024,wr=class extends Me{constructor(t,r,n){super(t,r),this.Frame=Qt,this.Header=Jt,n(this[ee])}get[ee](){return"flac"}*_getNextFrameSyncOffset(t){let r=yield*this._codecParser[K](2,0),n=r[M]-2;for(;t<n;){if(r[t]===255){let s=r[t+1];if(s===248||s===249)break;s!==255&&t++}t++}return t}*[ft](){do{let t=yield*Jt[Z](this._codecParser,this._headerCache,0);if(t){let r=ue.get(t)[M]+sm;for(;r<=om;){if(this._codecParser._flushing||(yield*Jt[Z](this._codecParser,this._headerCache,r))){let n=yield*this._codecParser[K](r);if(this._codecParser._flushing||(n=n[H](0,r)),Qt[js](n)){let i=new Qt(n,t);return this._headerCache[nt](),this._codecParser[Xe](r),this._codecParser[Zt](i),i}}r=yield*this._getNextFrameSyncOffset(r+1)}this._codecParser[tt](`Unable to sync FLAC frame after searching ${r} bytes.`),this._codecParser[Xe](r)}else this._codecParser[Xe](yield*this._getNextFrameSyncOffset(1))}while(!0)}[qt](t){return t[le]===0?(this._headerCache[nt](),this._streamInfo=t[Q][H](13)):t[le]===1||(t[ve]=ge.get(t)[We].map(r=>{let n=Jt[Ze](r,this._headerCache);if(n)return new Qt(r,n,this._streamInfo);this._codecParser[tt]("Failed to parse Ogg FLAC frame","Skipping invalid FLAC frame")}).filter(r=>!!r)),t}};var Ar=class e{static*[Z](t,r,n){let i={},s=yield*t[K](28,n);if(s[0]!==79||s[1]!==103||s[2]!==103||s[3]!==83||(i[Xa]=s[4],s[5]&248))return null;i[Be]=!!(s[5]&4),i[Gt]=!!(s[5]&2),i[Vt]=!!(s[5]&1);let a=new jt(we.from(s[H](0,28))[at]);i[et]=bd(a,6),i[ut]=a.getInt32(14,!0),i[le]=a.getInt32(18,!0),i[pr]=a.getInt32(22,!0);let d=s[26];i[M]=d+27,s=yield*t[K](i[M],n),i[Ce]=0,i[$t]=[],i[cn]=we.from(s[H](27,i[M]));for(let l=0,c=0;l<d;l++){let h=i[cn][l];i[Ce]+=h,c+=h,(h!==255||l===d-1)&&(i[$t].push(c),c=0)}return new e(i)}constructor(t){ue.set(this,t),this[et]=t[et],this[Vt]=t[Vt],this[Gt]=t[Gt],this[Be]=t[Be],this[$t]=t[$t],this[le]=t[le],this[pr]=t[pr],this[ut]=t[ut]}};var Ri=class e extends _r{static*[$e](t,r,n){let i=yield*Ar[Z](t,r,n);if(i){let s=ue.get(i)[Ce],o=ue.get(i)[M],a=o+s,d=(yield*t[K](a,0))[H](0,a),l=d[H](o,a);return new e(i,l,d)}else return null}constructor(t,r,n){super(t,r),ge.get(this)[M]=n[M],this[ve]=[],this[Va]=n,this[et]=t[et],this[ei]=t[pr],this[lt]=0,this[Vt]=t[Vt],this[Gt]=t[Gt],this[Be]=t[Be],this[le]=t[le],this[W]=0,this[ut]=t[ut]}};var un=class extends Oe{constructor(t,r,n){super(r,t,n)}};var Id={0:$n.slice(0,2),1:$n},Ye="SILK-only",ye="CELT-only",lo="Hybrid",er="narrowband",co="medium-band",tr="wideband",fn="super-wideband",hn="fullband",am={0:{[P]:Ye,[N]:er,[O]:10},8:{[P]:Ye,[N]:er,[O]:20},16:{[P]:Ye,[N]:er,[O]:40},24:{[P]:Ye,[N]:er,[O]:60},32:{[P]:Ye,[N]:co,[O]:10},40:{[P]:Ye,[N]:co,[O]:20},48:{[P]:Ye,[N]:co,[O]:40},56:{[P]:Ye,[N]:co,[O]:60},64:{[P]:Ye,[N]:tr,[O]:10},72:{[P]:Ye,[N]:tr,[O]:20},80:{[P]:Ye,[N]:tr,[O]:40},88:{[P]:Ye,[N]:tr,[O]:60},96:{[P]:lo,[N]:fn,[O]:10},104:{[P]:lo,[N]:fn,[O]:20},112:{[P]:lo,[N]:hn,[O]:10},120:{[P]:lo,[N]:hn,[O]:20},128:{[P]:ye,[N]:er,[O]:2.5},136:{[P]:ye,[N]:er,[O]:5},144:{[P]:ye,[N]:er,[O]:10},152:{[P]:ye,[N]:er,[O]:20},160:{[P]:ye,[N]:tr,[O]:2.5},168:{[P]:ye,[N]:tr,[O]:5},176:{[P]:ye,[N]:tr,[O]:10},184:{[P]:ye,[N]:tr,[O]:20},192:{[P]:ye,[N]:fn,[O]:2.5},200:{[P]:ye,[N]:fn,[O]:5},208:{[P]:ye,[N]:fn,[O]:10},216:{[P]:ye,[N]:fn,[O]:20},224:{[P]:ye,[N]:hn,[O]:2.5},232:{[P]:ye,[N]:hn,[O]:5},240:{[P]:ye,[N]:hn,[O]:10},248:{[P]:ye,[N]:hn,[O]:20}},mn=class e extends Pe{static[Ze](t,r,n){let i={};if(i[k]=t[9],i[At]=t[18],i[M]=i[At]!==0?21+i[k]:19,t[M]<i[M])throw new Error("Out of data while inside an Ogg Page");let s=r[0]&3,o=s===3?2:1,a=De(t[H](0,i[M]))+De(r[H](0,o)),d=n[Z](a);if(d)return new e(d);if(a.substr(0,8)!=="OpusHead"||t[8]!==1)return null;i[Q]=we.from(t[H](0,i[M]));let l=new jt(i[Q][at]);if(i[_e]=16,i[hr]=l.getUint16(10,!0),i[pi]=l.getUint32(12,!0),i[G]=Ht,i[oi]=l.getInt16(16,!0),i[At]in Id&&(i[Se]=Id[i[At]][i[k]-1],!i[Se]))return null;i[At]!==0&&(i[yi]=t[19],i[Qn]=t[20],i[ui]=[...t[H](21,i[k]+21)]);let c=am[248&r[0]];switch(i[P]=c[P],i[N]=c[N],i[O]=c[O],s){case 0:i[Et]=1;break;case 1:case 2:i[Et]=2;break;case 3:i[ii]=!!(128&r[1]),i[ti]=!!(64&r[1]),i[Et]=63&r[1];break;default:return null}{let{length:h,data:u,channelMappingFamily:f,...m}=i;n[Ke](a,i,m)}return new e(i)}constructor(t){super(t),this[Q]=t[Q],this[N]=t[N],this[At]=t[At],this[ui]=t[ui],this[Qn]=t[Qn],this[Et]=t[Et],this[O]=t[O],this[ti]=t[ti],this[pi]=t[pi],this[ii]=t[ii],this[P]=t[P],this[oi]=t[oi],this[hr]=t[hr],this[yi]=t[yi]}};var Ci=class extends Me{constructor(t,r,n){super(t,r),this.Frame=un,this.Header=mn,n(this[ee]),this._identificationHeader=null,this._preSkipRemaining=null}get[ee](){return"opus"}[qt](t){return t[le]===0?(this._headerCache[nt](),this._identificationHeader=t[Q]):t[le]===1||(t[ve]=ge.get(t)[We].map(r=>{let n=mn[Ze](this._identificationHeader,r,this._headerCache);if(n){this._preSkipRemaining===null&&(this._preSkipRemaining=n[hr]);let i=n[O]*n[Et]/1e3*n[G];return this._preSkipRemaining>0&&(this._preSkipRemaining-=i,i=this._preSkipRemaining<0?-this._preSkipRemaining:0),new un(r,n,i)}this._codecParser[Ys]("Failed to parse Ogg Opus Header","Not a valid Ogg Opus file")})),t}};var pn=class extends Oe{constructor(t,r,n){super(r,t,n)}};var tl={};for(let e=0;e<8;e++)tl[e+6]=2**(6+e);var zi=class e extends Pe{static[Ze](t,r,n,i){if(t[M]<30)throw new Error("Out of data while inside an Ogg Page");let s=De(t[H](0,30)),o=r[Z](s);if(o)return new e(o);let a={[M]:30};if(s.substr(0,7)!=="vorbis")return null;a[Q]=we.from(t[H](0,30));let d=new jt(a[Q][at]);if(a[Wt]=d.getUint32(7,!0),a[Wt]!==0||(a[k]=t[11],a[Se]=$n[a[k]-1]||"application defined",a[G]=d.getUint32(12,!0),a[Zn]=d.getInt32(16,!0),a[qn]=d.getInt32(20,!0),a[Yn]=d.getInt32(24,!0),a[Kt]=tl[(t[28]&240)>>4],a[Xt]=tl[t[28]&15],a[Xt]>a[Kt])||t[29]!==1)return null;a[_e]=32,a[ln]=i,a[li]=n;{let{length:l,data:c,version:h,vorbisSetup:u,vorbisComments:f,...m}=a;r[Ke](s,a,m)}return new e(a)}constructor(t){super(t),this[Zn]=t[Zn],this[Yn]=t[Yn],this[qn]=t[qn],this[Xt]=t[Xt],this[Kt]=t[Kt],this[Q]=t[Q],this[li]=t[li],this[ln]=t[ln]}};var Fi=class extends Me{constructor(t,r,n){super(t,r),this.Frame=pn,n(this[ee]),this._identificationHeader=null,this._setupComplete=!1,this._prevBlockSize=null}get[ee](){return mr}[qt](t){t[ve]=[];for(let r of ge.get(t)[We])if(r[0]===1)this._headerCache[nt](),this._identificationHeader=t[Q],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=zi[Ze](this._identificationHeader,this._headerCache,this._vorbisComments,this._vorbisSetup);n?t[ve].push(new pn(r,n,this._getSamples(r,n))):this._codecParser[logError]("Failed to parse Ogg Vorbis Header","Not a valid Ogg Vorbis file")}return t}_getSamples(t,r){let i=this._mode.blockFlags[t[0]>>1&this._mode.mask]?r[Kt]:r[Xt],s=this._prevBlockSize===null?0:(this._prevBlockSize+i)/4;return this._prevBlockSize=i,s}_parseSetupHeader(t){let r=new Js(t),n={count:0,blockFlags:[]};for(;(r.read(1)&1)!==1;);let i;for(;n.count<64&&r.position>0;){vi(r.read(8));let s=0;for(;r.read(8)===0&&s++<3;);if(s===4)i=r.read(7),n.blockFlags.unshift(i&1),r.position+=6,n.count++;else{((vi(i)&126)>>1)+1!==n.count&&this._codecParser[tt]("vorbis derived mode count did not match actual mode count");break}}return n.mask=(1<<Math.log2(n.count))-1,n}};var rl=class{constructor(t,r,n){this._codecParser=t,this._headerCache=r,this._onCodec=n,this._continuedPacket=new we,this._codec=null,this._isSupported=null,this._previousAbsoluteGranulePosition=null}get[ee](){return this._codec||""}_updateCodec(t,r){this._codec!==t&&(this._headerCache[rt](),this._parser=new r(this._codecParser,this._headerCache,this._onCodec),this._codec=t)}_checkCodecSupport({data:t}){let r=De(t[H](0,8));switch(r){case"fishead\0":return!1;case"OpusHead":return this._updateCodec("opus",Ci),!0;case(/^\x7fFLAC/.test(r)&&r):return this._updateCodec("flac",wr),!0;case(/^\x01vorbis/.test(r)&&r):return this._updateCodec(mr,Fi),!0;default:return!1}}_checkPageSequenceNumber(t){t[le]!==this._pageSequenceNumber+1&&this._pageSequenceNumber>1&&t[le]>1&&this._codecParser[tt]("Unexpected gap in Ogg Page Sequence Number.",`Expected: ${this._pageSequenceNumber+1}, Got: ${t[le]}`),this._pageSequenceNumber=t[le]}_parsePage(t){this._isSupported===null&&(this._pageSequenceNumber=t[le],this._isSupported=this._checkCodecSupport(t)),this._checkPageSequenceNumber(t);let r=ge.get(t),n=ue.get(r[ke]),i=0;if(r[We]=n[$t].map(s=>t[Q][H](i,i+=s)),this._continuedPacket[M]&&(r[We][0]=Si(this._continuedPacket,r[We][0]),this._continuedPacket=new we),n[cn][n[cn][M]-1]===255&&(this._continuedPacket=Si(this._continuedPacket,r[We].pop())),this._previousAbsoluteGranulePosition!==null&&(t[W]=Number(t[et]-this._previousAbsoluteGranulePosition)),this._previousAbsoluteGranulePosition=t[et],this._isSupported){let s=this._parser[qt](t);return this._codecParser[Zt](s),s}else return t}},ki=class extends Me{constructor(t,r,n){super(t,r),this._onCodec=n,this.Frame=Ri,this.Header=Ar,this._streams=new Map,this._currentSerialNumber=null}get[ee](){let t=this._streams.get(this._currentSerialNumber);return t?t.codec:""}*[ft](){let t=yield*this[Yt](!0);this._currentSerialNumber=t[ut];let r=this._streams.get(this._currentSerialNumber);return r||(r=new rl(this._codecParser,this._headerCache,this._onCodec),this._streams.set(this._currentSerialNumber,r)),t[Be]&&this._streams.delete(this._currentSerialNumber),r._parsePage(t)}};var nl=()=>{},Bi=class{constructor(t,{onCodec:r,onCodecHeader:n,onCodecUpdate:i,enableLogging:s=!1,enableFrameCRC32:o=!0}={}){this._inputMimeType=t,this._onCodec=r||nl,this._onCodecHeader=n||nl,this._onCodecUpdate=i,this._enableLogging=s,this._crc32=o?_d:nl,this[rt]()}get[ee](){return this._parser?this._parser[ee]:""}[rt](){this._headerCache=new wi(this._onCodecHeader,this._onCodecUpdate),this._generator=this._getGenerator(),this._generator.next()}*flush(){this._flushing=!0;for(let t=this._generator.next();t.value;t=this._generator.next())yield t.value;this._flushing=!1,this[rt]()}*parseChunk(t){for(let r=this._generator.next(t);r.value;r=this._generator.next())yield r.value}parseAll(t){return[...this.parseChunk(t),...this.flush()]}*_getGenerator(){if(this._inputMimeType.match(/aac/))this._parser=new Ii(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/mpeg/))this._parser=new Li(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/flac/))this._parser=new wr(this,this._headerCache,this._onCodec);else if(this._inputMimeType.match(/ogg/))this._parser=new ki(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 t=yield*this._parser[ft]();t&&(yield t)}}*[K](t=0,r=0){let n;for(;this._rawData[M]<=t+r;){if(n=yield,this._flushing)return this._rawData[H](r);n&&(this._totalBytesIn+=n[M],this._rawData=Si(this._rawData,n))}return this._rawData[H](r)}[Xe](t){this._currentReadPosition+=t,this._rawData=this._rawData[H](t)}[_i](t){this._sampleRate=t[ke][G],t[ke][be]=t[lt]>0?Math.round(t[Q][M]/t[lt])*8:0,t[Lt]=this._frameNumber++,t[gr]=this._totalBytesOut,t[xr]=this._totalSamples,t[yr]=this._totalSamples/this._sampleRate*1e3,t[ei]=this._crc32(t[Q]),this._headerCache[qs](t[ke][be],t[yr]),this._totalBytesOut+=t[Q][M],this._totalSamples+=t[W]}[Zt](t){if(t[ve]){if(t[Be]){let r=t[W];t[ve].forEach(n=>{let i=n[W];r<i&&(n[W]=r>0?r:0,n[lt]=n[W]/n[ke][G]*1e3),r-=i,this[_i](n)})}else t[W]=0,t[ve].forEach(r=>{t[W]+=r[W],this[_i](r)});t[lt]=t[W]/this._sampleRate*1e3||0,t[xr]=this._totalSamples,t[yr]=this._totalSamples/this._sampleRate*1e3||0,t[gr]=this._totalBytesOut}else this[_i](t)}_log(t,r){if(this._enableLogging){let n=[`${ee}: ${this[ee]}`,`inputMimeType: ${this._inputMimeType}`,`readPosition: ${this._currentReadPosition}`,`totalBytesIn: ${this._totalBytesIn}`,`${gr}: ${this._totalBytesOut}`],i=Math.max(...n.map(s=>s[M]));r.push(`--stats--${"-".repeat(i-9)}`,...n,"-".repeat(i)),t("codec-parser",r.reduce((s,o)=>s+`
|
|
4
|
+
`+o,""))}}[tt](...t){this._log(console.warn,t)}[Ys](...t){this._log(console.error,t)}};var Rd=Bi;var uo=ve;var fo=Q;var Cd=ke;var zd=Be;var Fd=ln;var kd=xr;function Tt(e){var t=t;function r(){}t={};function n(R){throw R}var i,s,o,a,d,l,c,h,u,f,m;function g(){var R=m.buffer;i=new Int8Array(R),s=new Int16Array(R),a=new Uint8Array(R),d=new Uint16Array(R),o=new Int32Array(R),l=new Uint32Array(R),c=new Float32Array(R),h=new Float64Array(R),u=new BigInt64Array(R),f=new BigUint64Array(R)}for(var p=R=>{for(var He,zn,Pr=0,gs=0,ys=R.length,xs=new Uint8Array((ys*3>>2)-(R[ys-2]=="=")-(R[ys-1]=="="));Pr<ys;Pr+=4,gs+=3)He=$[R.charCodeAt(Pr+1)],zn=$[R.charCodeAt(Pr+2)],xs[gs]=$[R.charCodeAt(Pr)]<<2|He>>4,xs[gs+1]=He<<4|zn>>2,xs[gs+2]=zn<<6|$[R.charCodeAt(Pr+3)];return xs},y=()=>n(""),S=()=>{},_={},x=R=>R(),b=()=>performance.now(),A=(R,He)=>{if(_[R]&&(clearTimeout(_[R].id),delete _[R]),!He)return 0;var zn=setTimeout(()=>{delete _[R],x(()=>Ac(R,b()))},He);return _[R]={id:zn,timeout_ms:He},0},v=Math.atan,E=Math.cos,L=Math.exp,w=Math.log,T=Math.pow,z=Math.sin,U=R=>{var He=a.length;return R>>>=0,!1},C=R=>{throw`exit(${R})`},$=new Uint8Array(123),Ie=25;Ie>=0;--Ie)$[48+Ie]=52+Ie,$[65+Ie]=Ie,$[97+Ie]=26+Ie;$[43]=62,$[47]=63;var lr={e:y,d:S,f:A,b:v,a:E,i:L,h:w,g:T,c:z,k:U,j:C};function ps(R){Cn=R.n,xc=R.o,_c=R.p,bc=R.q,vc=R.r,Sc=R.s,wc=R.t,Ac=R.v}var Cn,xc,_c,bc,vc,Sc,wc,Ac;function Hu(R){R.m()}Tt.wasm||Object.defineProperty(Tt,"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 Vu={a:lr};this.setModule=R=>{e.setModule(Tt,R)},this.getModule=()=>e.getModule(Tt),this.instantiate=()=>(this.getModule().then(R=>WebAssembly.instantiate(R,Vu)).then(R=>{let He=R.exports;go(He),m=He.l,g(),Hu(He),r()}),this.ready=new Promise(R=>{r=R}).then(()=>{this.HEAP=m.buffer,this.malloc=xc,this.free=wc,this.create_decoder=Cn,this.send_setup=_c,this.init_dsp=bc,this.decode_packets=vc,this.destroy_decoder=Sc}),this)}function Mr(){return this._init=()=>new this._WASMAudioDecoderCommon().instantiate(this._EmscriptenWASM,this._module).then(e=>{this._common=e,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 t=256;this._errors=this._common.allocateTypedArray(t,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,t)}),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=e=>{this._input.buf.set(e),this._inputLen.buf[0]=e.length,this._common.wasm.send_setup(this._decoder,this._firstPage),this._firstPage=!1},this.initDsp=()=>{this._common.wasm.init_dsp(this._decoder)},this.decodePackets=e=>{let t=[],r=0,n=[];for(let i=0;i<e.length;i++){let o=e[i];this._input.buf.set(o),this._inputLen.buf[0]=o.length,this._common.wasm.decode_packets(this._decoder);let s=this._samplesDecoded.buf[0],a=[],d=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 c=new Float32Array(s);s&&c.set(new Float32Array(this._common.wasm.HEAP,d[l],s)),a.push(c)}t.push(a),r+=s,this._frameNumber++,this._inputBytes+=o.length,this._outputSamples+=s;for(let l=0;l<this._errorsLength.buf;l+=2){let c=this._common.codeToString(this._errors.buf[l]),h=this._common.codeToString(this._errors.buf[l+1]);n.push({message:c+" vorbis_synthesis"+h,frameLength:o.length,frameNumber:this._frameNumber,inputBytes:this._inputBytes,outputSamples:this._outputSamples})}this._errorsLength.buf[0]=0}return this._WASMAudioDecoderCommon.getDecodedAudioMultiChannel(n,t,this._channels.buf[0],r,this._sampleRate.buf[0],16)},this._isWebWorker=Mr.isWebWorker,this._WASMAudioDecoderCommon=Mr.WASMAudioDecoderCommon||te,this._EmscriptenWASM=Mr.EmscriptenWASM||Tt,this._module=Mr.module,this._inputSize=128*1024,this._ready=this._init(),this}var hs=Symbol(),It=class{constructor(){this._onCodec=t=>{if(t!=="vorbis")throw new Error("@wasm-audio-decoders/ogg-vorbis does not support this codec "+t)},new te,this._init(),this._ready=this[hs](Mr)}_init(){this._vorbisSetupInProgress=!0,this._totalSamplesDecoded=0,this._codecParser=new Rd("audio/ogg",{onCodec:this._onCodec,enableFrameCRC32:!1})}async[hs](t){if(this._decoder){let r=this._decoder;await r.ready.then(()=>r.free())}return this._decoder=new t,this._decoder.ready}get ready(){return this._ready}async reset(){return this._init(),this._decoder.reset()}free(){this._decoder.free()}async decodeOggPages(t){let r=[];for(let o=0;o<t.length;o++){let s=t[o];if(this._vorbisSetupInProgress&&(s[fs][0]===1&&this._decoder.sendSetupHeader(s[fs]),s[us].length)){let a=s[us][0][Cd];this._decoder.sendSetupHeader(a[Fd]),this._decoder.initDsp(),this._vorbisSetupInProgress=!1}r.push(...s[us].map(a=>a[fs]))}let n=await this._decoder.decodePackets(r);this._totalSamplesDecoded+=n.samplesDecoded;let i=t[t.length-1];if(i&&i[zd]){let o=this._totalSamplesDecoded-i[kd];if(o>0){for(let s=0;s<n.channelData.length;s++)n.channelData[s]=n.channelData[s].subarray(0,n.samplesDecoded-o);n.samplesDecoded-=o,this._totalSamplesDecoded-=o}}return n}async decode(t){return this.decodeOggPages([...this._codecParser.parseChunk(t)])}async flush(){let t=await this.decodeOggPages([...this._codecParser.flush()]);return await this.reset(),t}async decodeFile(t){let r=await this.decodeOggPages([...this._codecParser.parseAll(t)]);return await this.reset(),r}};var il=class extends Qr{constructor(t){super(t,"ogg-vorbis-decoder",Mr,Tt)}async sendSetupHeader(t){return this.postToDecoder("sendSetupHeader",t)}async initDsp(){return this.postToDecoder("initDsp")}async decodePackets(t){return this.postToDecoder("decodePackets",t)}},Di=class extends It{constructor(){super(),this._ready=super[hs](il)}async free(){await this._decoder.free()}terminate(){this._decoder.terminate()}};Oo(It,"OggVorbisDecoder");Oo(Di,"OggVorbisDecoderWebWorker");var ol=class extends Error{constructor(t){super(t),this.name="OggDecodeError"}};async function ms(e,t=new It){await t.ready;let r=await t.decode(new Uint8Array(e)),n=r.errors;if(n&&n.length>0)throw new ol(n.map(i=>i.message).join("; "));return{sampleRate:r.sampleRate,channels:r.channelData.length,bitDepth:r.bitDepth,channelData:r.channelData}}var Pi=class extends Error{constructor(t){super(t),this.name="AudioRegistryError"}},gn=class{constructor(t,r={}){this.vfs=t;this.refCounts=new Map;this.cache=new Pt(r.cacheSize??64)}get size(){return this.cache.size}async load(t){let r=t.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(t)).slice().buffer,s=await this.decodeByExtension(t,o);return this.cache.set(r,s),this.refCounts.set(r,1),s}release(t){let r=t.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()}async decodeByExtension(t,r){let n=t.toLowerCase();if(n.endsWith(".wav")){let i=Po(r),o=i.channels,s=Array.from({length:o},()=>new Float32Array(i.samples.length/o));for(let a=0;a<i.samples.length;a+=1)s[a%o][Math.floor(a/o)]=i.samples[a];return{sampleRate:i.sampleRate,channels:o,bitDepth:i.bitsPerSample,channelData:s}}if(n.endsWith(".ogg")||n.endsWith(".oga"))return ms(r);throw new Pi(`Unsupported audio format: ${t}`)}};var lm="quake2ts-pak-indexes",cm="pak-indexes";function Bd(){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 Oi(e,t){let r=Bd();return r?new Promise((n,i)=>{let o=r.open(e,1);o.onupgradeneeded=()=>{let{result:s}=o;s.objectStoreNames.contains(t)||s.createObjectStore(t,{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 Ni(e,t,r,n){return new Promise((i,o)=>{let a=e.transaction(t,r).objectStore(t),d=n(a);d.onsuccess=()=>i(d.result),d.onerror=()=>o(d.error??new Error("IndexedDB transaction error"))})}function sl(e,t){return`${ae(e)}:${t.toString(16)}`}function dm(e){return e.map(t=>({...t}))}var ps=class{constructor(t=lm,r=cm){this.dbName=t;this.storeName=r}get isSupported(){return!!Bd()}async persist(t){if(!this.isSupported)return;let r=t.validate(),n={...r,key:sl(t.name,r.checksum),name:t.name,size:t.size,persistedAt:Date.now(),entries:dm(r.entries)},i=await Oi(this.dbName,this.storeName);return await Ni(i,this.storeName,"readwrite",o=>o.put(n)),i.close(),n}async find(t,r){if(!this.isSupported)return;let n=await Oi(this.dbName,this.storeName),i=r!==void 0?sl(t,r):void 0,o=await Ni(n,this.storeName,"readonly",s=>i?s.get(i):s.getAll());if(n.close(),!!o){if(Array.isArray(o)){let s=ae(t),a=o.filter(d=>ae(d.name)===s);return a.length===0?void 0:a.sort((d,l)=>l.persistedAt-d.persistedAt)[0]}return o}}async remove(t,r){if(!this.isSupported)return!1;let n=await Oi(this.dbName,this.storeName),i=r!==void 0?sl(t,r):void 0,o=await Ni(n,this.storeName,"readwrite",s=>{if(i)return s.delete(i);let a=`${ae(t)}:`;return s.delete(IDBKeyRange.bound(a,`${a}\uFFFF`,!1,!0))});return n.close(),typeof o=="number"?o>0:!0}async clear(){if(!this.isSupported)return;let t=await Oi(this.dbName,this.storeName);await Ni(t,this.storeName,"readwrite",r=>r.clear()),t.close()}async list(){if(!this.isSupported)return[];let t=await Oi(this.dbName,this.storeName),r=await Ni(t,this.storeName,"readonly",n=>n.getAll());return t.close(),r.sort((n,i)=>i.persistedAt-n.persistedAt)}};var Er=class extends Error{constructor(r,n){super(n??`Missing dependencies: ${r.join(", ")}`);this.missing=r;this.name="AssetDependencyError"}},Ui=class{constructor(){this.nodes=new Map}register(t,r=[]){let n=this.nodes.get(t)??{dependencies:new Set,loaded:!1};r.forEach(i=>n.dependencies.add(i)),this.nodes.set(t,n),r.forEach(i=>{this.nodes.has(i)||this.nodes.set(i,{dependencies:new Set,loaded:!1})})}markLoaded(t){let r=this.nodes.get(t)??{dependencies:new Set,loaded:!1},n=this.getMissingDependencies(t,r);if(n.length>0)throw new Er(n,`Asset ${t} is missing dependencies: ${n.join(", ")}`);r.loaded=!0,this.nodes.set(t,r)}markUnloaded(t){let r=this.nodes.get(t);r&&(r.loaded=!1)}isLoaded(t){return this.nodes.get(t)?.loaded??!1}missingDependencies(t){let r=this.nodes.get(t);return r?this.getMissingDependencies(t,r):[]}reset(){this.nodes.clear()}getMissingDependencies(t,r){let n=[];for(let i of r.dependencies)this.nodes.get(i)?.loaded||n.push(i);return n}},gs=class{constructor(t,r={}){this.vfs=t;this.maps=new Map;this.textures=new jr({capacity:r.textureCacheCapacity??128}),this.audio=new gn(t,{cacheSize:r.audioCacheSize??64}),this.dependencyTracker=r.dependencyTracker??new Ui,this.md2=new Zr(t),this.md3=new Yr(t),this.sprite=new qr(t),this.bsp=new $r(t),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(t="pics/colormap.pcx"){try{let r=await this.vfs.readFile(t),n=Xn(r);n.palette&&(this.palette=n.palette)}catch(r){console.warn(`Failed to load palette from ${t}:`,r)}}isAssetLoaded(t,r){return this.dependencyTracker.isLoaded(this.makeKey(t,r))}registerTexture(t,r){this.textures.set(t,r);let n=this.makeKey("texture",t);this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n)}async loadTexture(t){let r=this.textures.get(t);if(r)return r;let n=await this.vfs.readFile(t),i=t.split(".").pop()?.toLowerCase(),o;if(i==="wal")o=Do(n,this.palette);else if(i==="pcx")o=Bo(Xn(n));else if(i==="tga")o=od(Oa(n));else throw new Error(`Unsupported texture format for loadTexture: ${i}`);return this.registerTexture(t,o),o}async loadSound(t){let r=await this.audio.load(t),n=this.makeKey("sound",t);return this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n),r}async loadMd2Model(t,r=[]){let n=this.makeKey("model",t),i=r.map(a=>this.makeKey("texture",a));this.dependencyTracker.register(n,i);let o=this.dependencyTracker.missingDependencies(n);if(o.length>0)throw new Er(o,`Asset ${n} is missing dependencies: ${o.join(", ")}`);let s=await this.md2.load(t);return this.dependencyTracker.markLoaded(n),s}getMd2Model(t){return this.md2.get(t)}async loadMd3Model(t,r=[]){let n=this.makeKey("model",t),i=r.map(a=>this.makeKey("texture",a));this.dependencyTracker.register(n,i);let o=this.dependencyTracker.missingDependencies(n);if(o.length>0)throw new Er(o,`Asset ${n} is missing dependencies: ${o.join(", ")}`);let s=await this.md3.load(t);return this.dependencyTracker.markLoaded(n),s}getMd3Model(t){return this.md3.get(t)}async loadSprite(t){let r=this.makeKey("sprite",t);this.dependencyTracker.register(r);let n=await this.sprite.load(t);return this.dependencyTracker.markLoaded(r),n}async loadMap(t){let r=this.makeKey("map",t);if(this.maps.has(t))return this.maps.get(t);this.dependencyTracker.register(r);let n=await this.bsp.load(t);return this.maps.set(t,n),this.dependencyTracker.markLoaded(r),n}getMap(t){return this.maps.get(t)}listFiles(t){return this.vfs.findByExtension(t)}resetForLevelChange(){this.textures.clear(),this.audio.clearAll(),this.dependencyTracker.reset(),this.maps.clear()}makeKey(t,r){return`${t}:${ae(r)}`}};var ys=class{constructor(t){this.factory=t}getContext(){return this.context||(this.context=this.factory()),this.context}async resume(){let t=this.getContext();t.state==="suspended"&&await t.resume()}getState(){return this.context?.state??"suspended"}};function xs(e){let t=e.getContext(),r=t.createGain();r.gain.value=1;let n=t.createDynamicsCompressor(),i=t.createBiquadFilter?.();return i?(i.type="lowpass",i.frequency.value=2e4,i.Q.value=.707,r.connect(i),i.connect(n)):r.connect(n),n.connect(t.destination),{context:t,master:r,compressor:n,filter:i}}var _s=class{constructor(t=new Wr){this.configStrings=t;this.buffers=new Map}registerName(t){return this.configStrings.soundIndex(t)}register(t,r){let n=this.registerName(t);return this.buffers.set(n,r),n}find(t){return this.configStrings.findSoundIndex(t)}get(t){return this.buffers.get(t)}has(t){return this.buffers.has(t)}getName(t){return this.configStrings.getName(t)}};var bs=class{constructor(t){this.vfs=t.vfs,this.registry=t.registry,this.contextController=t.context,this.soundRoot=t.soundRoot??"sound/",this.decodeAudio=t.decodeAudio??((r,n)=>{if(!r.decodeAudioData)throw new Error("decodeAudioData is not available on the provided audio context");return r.decodeAudioData(n)})}async precache(t){let r=[...new Set(t.map(o=>this.normalize(o)))],n={loaded:[],skipped:[],missing:[],errors:{}},i=this.contextController.getContext();for(let o of r)try{let s=this.registry.find(o);if(s!==void 0&&this.registry.has(s)){n.skipped.push(o);continue}if(!this.vfs.stat(o)){n.missing.push(o);continue}let l=(await this.vfs.readFile(o)).slice().buffer,c=await this.decodeAudio(i,l);this.registry.register(o,c),n.loaded.push(o)}catch(s){let a=s instanceof Error?s:new Error(String(s));n.errors[o]=a}return n}normalize(t){let r=ae(t.replace(/^\//,""));return r.startsWith(this.soundRoot)?r:ae(`${this.soundRoot}${r}`)}};var um=7,Hi=e=>e&um;function vs(e){return Array.from({length:Pn},()=>({entnum:0,entchannel:ot.Auto,endTimeMs:0,isPlayer:!1,active:!1})).map(t=>({...t,isPlayer:t.entnum===e}))}function Ss(e,t,r,n){if(r<0)throw new Error("pickChannel: entchannel must be non-negative");let i=Hi(r),o=-1,s=Number.POSITIVE_INFINITY;for(let a=0;a<e.length;a+=1){let d=e[a],l=Hi(d.entchannel);if(i!==ot.Auto&&d.entnum===t&&l===i){o=a;break}if(d.active&&d.entnum===n.playerEntity&&t!==n.playerEntity)continue;let c=d.endTimeMs-n.nowMs;(o===-1||c<s)&&(s=c,o=a)}return o===-1?void 0:o}function ws(e,t,r,n,i){if(i)return{left:r,right:r,distanceComponent:0};let o=Tc(e,t.origin),s=_a(o),a=Je(o),d=s-kt;d<0&&(d=0),d*=Bt(n);let l=xa(t.right,a),c=t.mono??!1,h=c||n===0?1:.5*(1+l),u=c||n===0?1:.5*(1-l),f=Math.max(0,Math.floor(r*(1-d)*h));return{left:Math.max(0,Math.floor(r*(1-d)*u)),right:f,distanceComponent:d}}var As=class{constructor(t){this.activeSources=new Map;this.contextController=t.context,this.registry=t.registry,this.playerEntity=t.playerEntity,this.channels=vs(t.playerEntity),this.listener=t.listener??{origin:Lc,right:{x:1,y:0,z:0}},this.sfxVolume=t.sfxVolume??1,this.masterVolume=t.masterVolume??1,this.resolveOcclusion=t.resolveOcclusion,this.graph=xs(this.contextController),this.graph.master.gain.value=this.masterVolume}setListener(t){this.listener=t}setMasterVolume(t){this.masterVolume=t,this.graph.master.gain.value=t}setSfxVolume(t){this.sfxVolume=t}async ensureRunning(){await this.contextController.resume()}play(t){let r=this.registry.get(t.soundIndex);if(!r)return;let n=this.graph.context,i=n.currentTime*1e3,o=Ss(this.channels,t.entity,t.channel,{nowMs:i,playerEntity:this.playerEntity});if(o===void 0)return;let s=this.activeSources.get(o);s&&(s.source.onended=null,s.source.stop(),this.activeSources.delete(o));let a=n.createBufferSource();a.buffer=r,a.loop=t.looping??!1;let d=t.origin??this.listener.origin,l=n.createGain(),c=this.createPanner(n,t.attenuation),h=this.resolveOcclusion?.(this.listener,d,t.attenuation),u=Dd(h?.gainScale??1),f=this.resolveOcclusion?this.createOcclusionFilter(n,h?.lowpassHz??2e4):void 0;this.applyOriginToPanner(c,d);let m=t.entity===this.playerEntity,g=ws(d,this.listener,t.volume,t.attenuation,m),y=(t.volume===0?0:Math.max(g.left,g.right)/Math.max(1,t.volume))*(t.volume/255)*this.masterVolume*this.sfxVolume;l.gain.value=y*u;let S=n.currentTime+(t.timeOffsetMs??0)/1e3,_=(t.looping?Number.POSITIVE_INFINITY:r.duration*1e3)+S*1e3;a.connect(c),f?(c.connect(f),f.connect(l)):c.connect(l),l.connect(this.graph.master),a.start(S),a.onended=()=>{this.channels[o].active=!1,this.activeSources.delete(o)};let x={channelIndex:o,entnum:t.entity,entchannel:Hi(t.channel),endTimeMs:_,source:a,panner:c,gain:l,baseGain:y,origin:d,attenuation:t.attenuation,occlusion:f?{scale:u,lowpassHz:h?.lowpassHz,filter:f}:h?{scale:u,lowpassHz:h.lowpassHz}:void 0};return this.channels[o]={entnum:t.entity,entchannel:Hi(t.channel),endTimeMs:_,isPlayer:t.entity===this.playerEntity,active:!0},this.activeSources.set(o,x),x}stop(t){let r=this.activeSources.get(t);r&&(r.source.stop(),this.channels[t].active=!1,this.activeSources.delete(t))}stopEntitySounds(t){for(let[r,n]of[...this.activeSources.entries()])n.entnum===t&&(n.source.stop(),this.channels[r].active=!1,this.activeSources.delete(r))}updateEntityPosition(t,r){for(let n of this.activeSources.values())if(n.entnum===t&&(this.applyOriginToPanner(n.panner,r),n.origin=r,this.resolveOcclusion)){let i=this.resolveOcclusion(this.listener,r,n.attenuation);this.applyOcclusion(n,i)}}positionedSound(t,r,n,i){return this.play({entity:0,channel:ot.Auto,soundIndex:r,volume:n,attenuation:i,origin:t})}ambientSound(t,r,n){return this.play({entity:0,channel:ot.Auto,soundIndex:r,volume:n,attenuation:On,origin:t,looping:!0})}getChannelState(t){return this.channels[t]}getDiagnostics(){return{activeChannels:this.activeSources.size,masterVolume:this.masterVolume,sfxVolume:this.sfxVolume,channels:[...this.channels],activeSounds:[...this.activeSources.values()].map(t=>({entnum:t.entnum,entchannel:t.entchannel,channelIndex:t.channelIndex,origin:t.origin,gain:t.gain.gain.value,baseGain:t.baseGain,attenuation:t.attenuation,maxDistance:t.panner.maxDistance,distanceModel:t.panner.distanceModel,occlusion:t.occlusion?{scale:t.occlusion.scale,lowpassHz:t.occlusion.lowpassHz}:void 0}))}}setUnderwater(t,r=400){let n=this.graph.filter;n&&(n.type="lowpass",n.Q.value=.707,n.frequency.value=t?r:2e4)}createPanner(t,r){let n=t.createPanner?t.createPanner():Object.assign(t.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(t,r){let n=Bt(r);return t.refDistance=kt,t.maxDistance=Nn(r),t.rolloffFactor=n,t.distanceModel=r===0?"linear":"inverse",t.positionX.value=this.listener.origin.x,t.positionY.value=this.listener.origin.y,t.positionZ.value=this.listener.origin.z,t}applyOriginToPanner(t,r){t.positionX.value=r.x,t.positionY.value=r.y,t.positionZ.value=r.z}createOcclusionFilter(t,r){if(!t.createBiquadFilter)return;let n=t.createBiquadFilter();return n.type="lowpass",n.Q.value=.707,n.frequency.value=al(r,10,2e4),n}applyOcclusion(t,r){let n=Dd(r?.gainScale??1);if(t.gain.gain.value=t.baseGain*n,t.occlusion?.filter){let i=r?.lowpassHz??2e4;t.occlusion.filter.frequency.value=al(i,10,2e4)}t.occlusion?(t.occlusion.scale=n,t.occlusion.lowpassHz=r?.lowpassHz):r&&(t.occlusion={scale:n,lowpassHz:r.lowpassHz})}},al=(e,t,r)=>Math.min(r,Math.max(t,e)),Dd=e=>al(e,0,1);var Ms=class{constructor(t){this.createElement=t.createElement,this.resolveSource=t.resolveSource??(async r=>r),this.volume=t.volume??1}async play(t,{loop:r=!0,restart:n=!1}={}){if(this.track===t&&this.element){this.element.loop=r,this.element.volume=this.volume,n&&(this.element.currentTime=0),(this.element.paused||n)&&await this.element.play();return}let i=await this.resolveSource(t),o=this.createElement();o.src=i,o.loop=r,o.volume=this.volume,o.currentTime=0,o.load(),await o.play(),this.element=o,this.track=t}pause(){!this.element||this.element.paused||this.element.pause()}async resume(){!this.element||!this.element.paused||await this.element.play()}stop(){this.element&&(this.element.pause(),this.element.currentTime=0,this.element=void 0,this.track=void 0)}setVolume(t){this.volume=t,this.element&&(this.element.volume=t)}getState(){let t=!!(this.element&&!this.element.paused&&!this.element.ended),r=!!this.element?.paused;return{track:this.track,paused:r,playing:t,volume:this.volume}}};function fm(e){e.enable(e.DEPTH_TEST),e.depthFunc(e.LEQUAL),e.enable(e.CULL_FACE),e.cullFace(e.BACK),e.enable(e.BLEND),e.blendFuncSeparate(e.SRC_ALPHA,e.ONE_MINUS_SRC_ALPHA,e.ONE,e.ONE_MINUS_SRC_ALPHA)}function hm(e,t,r,n){for(let i of t){let o=e.getExtension(i);if(!o)throw new Error(`Missing required WebGL extension: ${i}`);n.set(i,o)}for(let i of r){let o=e.getExtension(i);o&&n.set(i,o)}}function Pd(e,t={}){let{contextAttributes:r,requiredExtensions:n=[],optionalExtensions:i=[]}=t,o=e.getContext("webgl2",r??{antialias:!0});if(!o)throw new Error("WebGL2 not supported or failed to initialize");fm(o);let s=new Map;hm(o,n,i,s);let a=!1,d=new Set,l=new Set,c=u=>{a=!0,u.preventDefault();for(let f of d)f()},h=()=>{a=!1;for(let u of l)u()};return e.addEventListener("webglcontextlost",c),e.addEventListener("webglcontextrestored",h),{gl:o,extensions:s,isLost:()=>a,onLost(u){return d.add(u),()=>d.delete(u)},onRestored(u){return l.add(u),()=>l.delete(u)},dispose(){e.removeEventListener("webglcontextlost",c),e.removeEventListener("webglcontextrestored",h),d.clear(),l.clear(),s.clear()}}}function Od(e,t,r){let n=e.createShader(t);if(!n)throw new Error("Failed to allocate shader");if(e.shaderSource(n,r),e.compileShader(n),!e.getShaderParameter(n,e.COMPILE_STATUS)){let o=e.getShaderInfoLog(n)??"Unknown shader compile failure";throw e.deleteShader(n),new Error(o)}return n}function mm(e,t,r,n){let i=e.createProgram();if(!i)throw new Error("Failed to allocate shader program");if(e.attachShader(i,t),e.attachShader(i,r),n)for(let[s,a]of Object.entries(n))e.bindAttribLocation(i,a,s);if(e.linkProgram(i),!e.getProgramParameter(i,e.LINK_STATUS)){let s=e.getProgramInfoLog(i)??"Unknown shader link failure";throw e.deleteProgram(i),new Error(s)}return i}var Ee=class e{constructor(t,r){this.uniformLocations=new Map;this.attributeLocations=new Map;this.gl=t,this.program=r}static create(t,r,n){let i=Od(t,t.VERTEX_SHADER,r.vertex),o=Od(t,t.FRAGMENT_SHADER,r.fragment);try{let s=mm(t,i,o,n);return new e(t,s)}finally{t.deleteShader(i),t.deleteShader(o)}}use(){this.gl.useProgram(this.program)}getUniformLocation(t){if(!this.uniformLocations.has(t)){let r=this.gl.getUniformLocation(this.program,t);this.uniformLocations.set(t,r)}return this.uniformLocations.get(t)??null}getAttributeLocation(t){if(!this.attributeLocations.has(t)){let r=this.gl.getAttribLocation(this.program,t);this.attributeLocations.set(t,r)}return this.attributeLocations.get(t)??-1}dispose(){this.gl.deleteProgram(this.program),this.uniformLocations.clear(),this.attributeLocations.clear()}};function Nd(e,t,r){return Ee.create(e,t,r)}var Le=class{constructor(t,r=t.STATIC_DRAW,n){this.gl=t,this.target=n??t.ARRAY_BUFFER;let i=t.createBuffer();if(!i)throw new Error("Failed to allocate buffer");this.buffer=i,t.bindBuffer(this.target,this.buffer),t.bufferData(this.target,0,r)}bind(){this.gl.bindBuffer(this.target,this.buffer)}upload(t,r=this.gl.STATIC_DRAW){this.bind(),this.gl.bufferData(this.target,t,r)}update(t,r=0){this.bind(),this.gl.bufferSubData(this.target,r,t)}dispose(){this.gl.deleteBuffer(this.buffer)}},xe=class extends Le{constructor(t,r=t.STATIC_DRAW){super(t,r,t.ELEMENT_ARRAY_BUFFER)}},ze=class{constructor(t){this.gl=t;let r=t.createVertexArray();if(!r)throw new Error("Failed to allocate vertex array object");this.vao=r}bind(){this.gl.bindVertexArray(this.vao)}configureAttributes(t,r){this.bind(),r&&r.bind();for(let n of t)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)}},yn=class{constructor(t,r=t.TEXTURE_2D){this.width=0;this.height=0;this.gl=t,this.target=r;let n=t.createTexture();if(!n)throw new Error("Failed to allocate texture");this.texture=n}bind(t=0){this.gl.activeTexture(this.gl.TEXTURE0+t),this.gl.bindTexture(this.target,this.texture)}setParameters(t){this.bind(),t.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,t.wrapS),t.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,t.wrapT),t.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,t.minFilter),t.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,t.magFilter)}upload(t,r,n){this.width=t,this.height=r,this.uploadImage(0,this.gl.RGBA,t,r,0,this.gl.RGBA,this.gl.UNSIGNED_BYTE,n)}uploadImage(t,r,n,i,o,s,a,d){this.bind(),this.gl.texImage2D(this.target,t,r,n,i,o,s,a,d)}dispose(){this.gl.deleteTexture(this.texture)}},xn=class{constructor(t){this.gl=t,this.target=t.TEXTURE_CUBE_MAP;let r=t.createTexture();if(!r)throw new Error("Failed to allocate cubemap texture");this.texture=r}bind(t=0){this.gl.activeTexture(this.gl.TEXTURE0+t),this.gl.bindTexture(this.target,this.texture)}setParameters(t){this.bind(),t.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,t.wrapS),t.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,t.wrapT),t.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,t.minFilter),t.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,t.magFilter)}uploadFace(t,r,n,i,o,s,a,d,l){this.bind(),this.gl.texImage2D(t,r,n,i,o,s,a,d,l)}dispose(){this.gl.deleteTexture(this.texture)}},Es=class{constructor(t){this.gl=t;let r=t.createFramebuffer();if(!r)throw new Error("Failed to allocate framebuffer");this.framebuffer=r}bind(t=this.gl.FRAMEBUFFER){this.gl.bindFramebuffer(t,this.framebuffer)}attachTexture2D(t,r,n=0){this.bind(),this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER,t,r.target,r.texture,n)}dispose(){this.gl.deleteFramebuffer(this.framebuffer)}};var cl=4,ll=7*cl,dl=[{index:0,size:3,type:5126,stride:ll,offset:0},{index:1,size:2,type:5126,stride:ll,offset:3*cl},{index:2,size:2,type:5126,stride:ll,offset:5*cl}];function pm(e,t){return{width:e,height:e,padding:t,data:new Uint8Array(e*e*4),cursorX:0,cursorY:0,rowHeight:0}}function gm(e){let t=e.width*e.height;if(t===0)throw new Error("Invalid lightmap with zero area");let r=e.samples.byteLength/t;if(!Number.isInteger(r)||r<3||r>4)throw new Error("Unsupported lightmap channel count");return r}function ym(e,t,r){let n=gm(r),i=e.width*4,o=t.x+e.padding,s=t.y+e.padding,a=0;for(let d=0;d<r.height;d++){let l=(s+d)*i+o*4;for(let c=0;c<r.width;c++){let h=l+c*4;e.data[h]=r.samples[a],e.data[h+1]=r.samples[a+1],e.data[h+2]=r.samples[a+2],e.data[h+3]=n===4?r.samples[a+3]:255,a+=n}}}function xm(e,t,r){let n=t.width+r.lightmapPadding*2,i=t.height+r.lightmapPadding*2;if(n>r.atlasSize||i>r.atlasSize)throw new Error("Lightmap too large for atlas");for(let a of e){if(a.cursorX+n>a.width&&(a.cursorX=0,a.cursorY+=a.rowHeight+r.lightmapPadding,a.rowHeight=0),a.cursorY+i>a.height)continue;let d={atlasIndex:e.indexOf(a),x:a.cursorX,y:a.cursorY,width:t.width,height:t.height};return a.cursorX+=n+r.lightmapPadding,a.rowHeight=Math.max(a.rowHeight,i),{placement:d,atlas:a}}let o=pm(r.atlasSize,r.lightmapPadding);e.push(o);let s={atlasIndex:e.length-1,x:0,y:0,width:t.width,height:t.height};return o.cursorX=n+r.lightmapPadding,o.rowHeight=i,{placement:s,atlas:o}}function Ls(e){return e instanceof Float32Array?e:new Float32Array(e)}function _m(e,t){if(!e){let n=new Uint16Array(t);for(let i=0;i<t;i++)n[i]=i;return n}return e instanceof Uint16Array?e:new Uint16Array(e)}function bm(e,t){let r=new Float32Array(e.length);for(let n=0;n<e.length;n+=2)r[n]=t.offset[0]+e[n]*t.scale[0],r[n+1]=t.offset[1]+e[n+1]*t.scale[1];return r}function vm(e,t){let r=Ls(e.vertices),n=Ls(e.textureCoords),i=t?bm(Ls(e.lightmapCoords??e.textureCoords),t):Ls(e.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 s=new Float32Array(o*7);for(let a=0;a<o;a++){let d=a*3,l=a*2,c=a*7;s[c]=r[d],s[c+1]=r[d+1],s[c+2]=r[d+2],s[c+3]=n[l],s[c+4]=n[l+1],s[c+5]=i[l],s[c+6]=i[l+1]}return s}function Ud(e){let t=[];for(let r=0;r<e.faces.length;r++){let n=e.faces[r];if(n.texInfo<0)continue;let i=e.texInfo[n.texInfo],o=[],s=[],a=[];for(let u=0;u<n.numEdges;u++){let f=e.surfEdges[n.firstEdge+u],m=e.edges[Math.abs(f)],g=f>=0?m.vertices[0]:m.vertices[1],p=e.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,S=p[0]*i.t[0]+p[1]*i.t[1]+p[2]*i.t[2]+i.tOffset;s.push(y,S),a.push(y,S)}let d=[],l=o.length/3;for(let u=1;u<l-1;u++)d.push(0,u,u+1);let c,h=e.lightMapInfo[r];if(h){let u=1/0,f=-1/0,m=1/0,g=-1/0;for(let b=0;b<s.length;b+=2){let A=s[b],v=s[b+1];A<u&&(u=A),A>f&&(f=A),v<m&&(m=v),v>g&&(g=v)}let p=Math.floor(u/16),y=Math.floor(m/16),S=Math.ceil(f/16)-p+1,_=Math.ceil(g/16)-y+1,x=Co(n,e.lightMaps,h);if(x&&x.length===S*_*3){c={width:S,height:_,samples:x};for(let b=0;b<a.length;b+=2)a[b]=s[b]/16-p+.5,a[b+1]=s[b+1]/16-y+.5}}t.push({vertices:new Float32Array(o),textureCoords:new Float32Array(s),lightmapCoords:new Float32Array(a),indices:new Uint16Array(d),texture:i.texture,surfaceFlags:i.flags,lightmap:c,faceIndex:r})}return t}function Hd(e,t,r,n={}){let i=t;if(r&&n.hiddenClassnames&&n.hiddenClassnames.size>0){let c=new Set;for(let h of r.entities.entities)if(h.classname&&n.hiddenClassnames.has(h.classname)){let u=h.properties.model;if(u&&u.startsWith("*")){let f=parseInt(u.substring(1),10);if(!isNaN(f)&&f>=0&&f<r.models.length){let m=r.models[f];for(let g=0;g<m.numFaces;g++)c.add(m.firstFace+g)}}}c.size>0&&(i=t.filter(h=>!c.has(h.faceIndex)))}let o={atlasSize:n.atlasSize??1024,lightmapPadding:n.lightmapPadding??1,hiddenClassnames:n.hiddenClassnames??new Set},s=[],a=new Map;i.forEach((c,h)=>{if(!c.lightmap)return;let{placement:u,atlas:f}=xm(s,c.lightmap,o);ym(f,u,c.lightmap),a.set(h,{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 d=s.map(c=>{let h=new yn(e);return h.setParameters({wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE,minFilter:e.LINEAR,magFilter:e.LINEAR}),h.uploadImage(0,e.RGBA,c.width,c.height,0,e.RGBA,e.UNSIGNED_BYTE,c.data),{texture:h,width:c.width,height:c.height,pixels:c.data}});return{surfaces:i.map((c,h)=>{let u=a.get(h),f=vm(c,u),m=_m(c.indices,f.length/7),g=new Le(e,e.STATIC_DRAW,e.ARRAY_BUFFER);g.upload(f);let p=new xe(e,e.STATIC_DRAW);p.upload(m);let y=new ze(e);return y.configureAttributes(dl,g),{vao:y,vertexBuffer:g,indexBuffer:p,indexCount:m.length,vertexCount:f.length/7,texture:c.texture,surfaceFlags:c.surfaceFlags??Bn,lightmap:u,vertexData:f,indexData:m}}),lightmaps:d}}function _n(e){let{normal:t,distance:r}=e,n=Math.sqrt(t.x*t.x+t.y*t.y+t.z*t.z);if(n===0)return e;let i=1/n;return{normal:{x:t.x*i,y:t.y*i,z:t.z*i},distance:r*i}}function Vd(e){if(e.length!==16)throw new Error("View-projection matrix must contain 16 elements");let t=e[0],r=e[4],n=e[8],i=e[12],o=e[1],s=e[5],a=e[9],d=e[13],l=e[2],c=e[6],h=e[10],u=e[14],f=e[3],m=e[7],g=e[11],p=e[15];return[_n({normal:{x:f+t,y:m+r,z:g+n},distance:p+i}),_n({normal:{x:f-t,y:m-r,z:g-n},distance:p-i}),_n({normal:{x:f+o,y:m+s,z:g+a},distance:p+d}),_n({normal:{x:f-o,y:m-s,z:g-a},distance:p-d}),_n({normal:{x:f+l,y:m+c,z:g+h},distance:p+u}),_n({normal:{x:f-l,y:m-c,z:g-h},distance:p-u})]}function Sm(e,t){return e.normal.x*t.x+e.normal.y*t.y+e.normal.z*t.z+e.distance}function Vi(e,t,r){for(let n of r){let i=n.normal.x>=0?t.x:e.x,o=n.normal.y>=0?t.y:e.y,s=n.normal.z>=0?t.z:e.z;if(Sm(n,{x:i,y:o,z:s})<0)return!1}return!0}function Gd(e){return e<0}function Wd(e){return-e-1}function Xd(e,t){return e.normal[0]*t.x+e.normal[1]*t.y+e.normal[2]*t.z-e.dist}function wm(e,t,r){if(!e||t<0||r<0)return!0;let n=Math.ceil(e.numClusters/8),i=e.clusters[t].pvs,o=Math.floor(r/8),s=1<<r%8;return o<0||o>=n?!1:(i[o]&s)!==0}function Am(e,t){let r={x:e.mins[0],y:e.mins[1],z:e.mins[2]},n={x:e.maxs[0],y:e.maxs[1],z:e.maxs[2]};return Vi(r,n,t)}function fl(e,t){let r=0;for(;r>=0;){let n=e.nodes[r],i=e.planes[n.planeIndex],s=Xd(i,t)>=0?0:1,a=n.children[s];if(Gd(a))return Wd(a);r=a}return-1}function Mm(e,t){let r=e.leafs[t],n=[];for(let i=0;i<r.numLeafFaces;i+=1)n.push(e.leafLists.leafFaces[t][i]);return n}function ul(e,t,r,n,i,o,s){if(Gd(t)){let u=Wd(t),f=e.leafs[u];if(!wm(e.visibility,i,f.cluster)||!Am(f,n))return;let m={x:(f.mins[0]+f.maxs[0])*.5,y:(f.mins[1]+f.maxs[1])*.5,z:(f.mins[2]+f.maxs[2])*.5},g=m.x-r.x,p=m.y-r.y,y=m.z-r.z,S=-(g*g+p*p+y*y);for(let _ of Mm(e,u))s.has(_)||(s.add(_),o.push({faceIndex:_,leafIndex:u,sortKey:S}));return}let a=e.nodes[t],d=e.planes[a.planeIndex],l=Xd(d,r),c=l>=0?a.children[0]:a.children[1],h=l>=0?a.children[1]:a.children[0];Vi({x:a.mins[0],y:a.mins[1],z:a.mins[2]},{x:a.maxs[0],y:a.maxs[1],z:a.maxs[2]},n)&&(ul(e,c,r,n,i,o,s),ul(e,h,r,n,i,o,s))}function Kd(e,t,r){let n=fl(e,t),i=n>=0?e.leafs[n].cluster:-1,o=[];return ul(e,0,t,r,i,o,new Set),o}var rr=32;function bn(e){let t=[];for(let r=0;r<e.length;r+=3){let n=e[r],i=e[r+1],o=e[r+2];t.push(n,i,i,o,o,n)}return e instanceof Uint32Array||Math.max(...t)>65535?new Uint32Array(t):new Uint16Array(t)}var hl=`#version 300 es
|
|
141
|
+
ïBçϧmÙIólÜoëVb¦¯éWÇû3`});var Vu={a:lr};this.setModule=R=>{e.setModule(Tt,R)},this.getModule=()=>e.getModule(Tt),this.instantiate=()=>(this.getModule().then(R=>WebAssembly.instantiate(R,Vu)).then(R=>{let He=R.exports;ps(He),m=He.l,g(),Hu(He),r()}),this.ready=new Promise(R=>{r=R}).then(()=>{this.HEAP=m.buffer,this.malloc=xc,this.free=wc,this.create_decoder=Cn,this.send_setup=_c,this.init_dsp=bc,this.decode_packets=vc,this.destroy_decoder=Sc}),this)}function Mr(){return this._init=()=>new this._WASMAudioDecoderCommon().instantiate(this._EmscriptenWASM,this._module).then(e=>{this._common=e,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 t=256;this._errors=this._common.allocateTypedArray(t,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,t)}),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=e=>{this._input.buf.set(e),this._inputLen.buf[0]=e.length,this._common.wasm.send_setup(this._decoder,this._firstPage),this._firstPage=!1},this.initDsp=()=>{this._common.wasm.init_dsp(this._decoder)},this.decodePackets=e=>{let t=[],r=0,n=[];for(let i=0;i<e.length;i++){let s=e[i];this._input.buf.set(s),this._inputLen.buf[0]=s.length,this._common.wasm.decode_packets(this._decoder);let o=this._samplesDecoded.buf[0],a=[],d=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 c=new Float32Array(o);o&&c.set(new Float32Array(this._common.wasm.HEAP,d[l],o)),a.push(c)}t.push(a),r+=o,this._frameNumber++,this._inputBytes+=s.length,this._outputSamples+=o;for(let l=0;l<this._errorsLength.buf;l+=2){let c=this._common.codeToString(this._errors.buf[l]),h=this._common.codeToString(this._errors.buf[l+1]);n.push({message:c+" vorbis_synthesis"+h,frameLength:s.length,frameNumber:this._frameNumber,inputBytes:this._inputBytes,outputSamples:this._outputSamples})}this._errorsLength.buf[0]=0}return this._WASMAudioDecoderCommon.getDecodedAudioMultiChannel(n,t,this._channels.buf[0],r,this._sampleRate.buf[0],16)},this._isWebWorker=Mr.isWebWorker,this._WASMAudioDecoderCommon=Mr.WASMAudioDecoderCommon||te,this._EmscriptenWASM=Mr.EmscriptenWASM||Tt,this._module=Mr.module,this._inputSize=128*1024,this._ready=this._init(),this}var ho=Symbol(),It=class{constructor(){this._onCodec=t=>{if(t!=="vorbis")throw new Error("@wasm-audio-decoders/ogg-vorbis does not support this codec "+t)},new te,this._init(),this._ready=this[ho](Mr)}_init(){this._vorbisSetupInProgress=!0,this._totalSamplesDecoded=0,this._codecParser=new Rd("audio/ogg",{onCodec:this._onCodec,enableFrameCRC32:!1})}async[ho](t){if(this._decoder){let r=this._decoder;await r.ready.then(()=>r.free())}return this._decoder=new t,this._decoder.ready}get ready(){return this._ready}async reset(){return this._init(),this._decoder.reset()}free(){this._decoder.free()}async decodeOggPages(t){let r=[];for(let s=0;s<t.length;s++){let o=t[s];if(this._vorbisSetupInProgress&&(o[fo][0]===1&&this._decoder.sendSetupHeader(o[fo]),o[uo].length)){let a=o[uo][0][Cd];this._decoder.sendSetupHeader(a[Fd]),this._decoder.initDsp(),this._vorbisSetupInProgress=!1}r.push(...o[uo].map(a=>a[fo]))}let n=await this._decoder.decodePackets(r);this._totalSamplesDecoded+=n.samplesDecoded;let i=t[t.length-1];if(i&&i[zd]){let s=this._totalSamplesDecoded-i[kd];if(s>0){for(let o=0;o<n.channelData.length;o++)n.channelData[o]=n.channelData[o].subarray(0,n.samplesDecoded-s);n.samplesDecoded-=s,this._totalSamplesDecoded-=s}}return n}async decode(t){return this.decodeOggPages([...this._codecParser.parseChunk(t)])}async flush(){let t=await this.decodeOggPages([...this._codecParser.flush()]);return await this.reset(),t}async decodeFile(t){let r=await this.decodeOggPages([...this._codecParser.parseAll(t)]);return await this.reset(),r}};var il=class extends Qr{constructor(t){super(t,"ogg-vorbis-decoder",Mr,Tt)}async sendSetupHeader(t){return this.postToDecoder("sendSetupHeader",t)}async initDsp(){return this.postToDecoder("initDsp")}async decodePackets(t){return this.postToDecoder("decodePackets",t)}},Di=class extends It{constructor(){super(),this._ready=super[ho](il)}async free(){await this._decoder.free()}terminate(){this._decoder.terminate()}};Os(It,"OggVorbisDecoder");Os(Di,"OggVorbisDecoderWebWorker");var sl=class extends Error{constructor(t){super(t),this.name="OggDecodeError"}};async function mo(e,t=new It){await t.ready;let r=await t.decode(new Uint8Array(e)),n=r.errors;if(n&&n.length>0)throw new sl(n.map(i=>i.message).join("; "));return{sampleRate:r.sampleRate,channels:r.channelData.length,bitDepth:r.bitDepth,channelData:r.channelData}}var Oi=class extends Error{constructor(t){super(t),this.name="AudioRegistryError"}},gn=class{constructor(t,r={}){this.vfs=t;this.refCounts=new Map;this.cache=new Ot(r.cacheSize??64)}get size(){return this.cache.size}async load(t){let r=t.toLowerCase(),n=this.cache.get(r);if(n)return this.refCounts.set(r,(this.refCounts.get(r)??0)+1),n;let s=(await this.vfs.readFile(t)).slice().buffer,o=await this.decodeByExtension(t,s);return this.cache.set(r,o),this.refCounts.set(r,1),o}release(t){let r=t.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()}async decodeByExtension(t,r){let n=t.toLowerCase();if(n.endsWith(".wav")){let i=Ds(r),s=i.channels,o=Array.from({length:s},()=>new Float32Array(i.samples.length/s));for(let a=0;a<i.samples.length;a+=1)o[a%s][Math.floor(a/s)]=i.samples[a];return{sampleRate:i.sampleRate,channels:s,bitDepth:i.bitsPerSample,channelData:o}}if(n.endsWith(".ogg")||n.endsWith(".oga"))return mo(r);throw new Oi(`Unsupported audio format: ${t}`)}};var lm="quake2ts-pak-indexes",cm="pak-indexes";function Bd(){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 Pi(e,t){let r=Bd();return r?new Promise((n,i)=>{let s=r.open(e,1);s.onupgradeneeded=()=>{let{result:o}=s;o.objectStoreNames.contains(t)||o.createObjectStore(t,{keyPath:"key"})},s.onerror=()=>i(s.error??new Error("Unknown IndexedDB error")),s.onsuccess=()=>n(s.result)}):Promise.reject(new Error("IndexedDB is not available in this environment"))}function Ni(e,t,r,n){return new Promise((i,s)=>{let a=e.transaction(t,r).objectStore(t),d=n(a);d.onsuccess=()=>i(d.result),d.onerror=()=>s(d.error??new Error("IndexedDB transaction error"))})}function ol(e,t){return`${ae(e)}:${t.toString(16)}`}function dm(e){return e.map(t=>({...t}))}var po=class{constructor(t=lm,r=cm){this.dbName=t;this.storeName=r}get isSupported(){return!!Bd()}async persist(t){if(!this.isSupported)return;let r=t.validate(),n={...r,key:ol(t.name,r.checksum),name:t.name,size:t.size,persistedAt:Date.now(),entries:dm(r.entries)},i=await Pi(this.dbName,this.storeName);return await Ni(i,this.storeName,"readwrite",s=>s.put(n)),i.close(),n}async find(t,r){if(!this.isSupported)return;let n=await Pi(this.dbName,this.storeName),i=r!==void 0?ol(t,r):void 0,s=await Ni(n,this.storeName,"readonly",o=>i?o.get(i):o.getAll());if(n.close(),!!s){if(Array.isArray(s)){let o=ae(t),a=s.filter(d=>ae(d.name)===o);return a.length===0?void 0:a.sort((d,l)=>l.persistedAt-d.persistedAt)[0]}return s}}async remove(t,r){if(!this.isSupported)return!1;let n=await Pi(this.dbName,this.storeName),i=r!==void 0?ol(t,r):void 0,s=await Ni(n,this.storeName,"readwrite",o=>{if(i)return o.delete(i);let a=`${ae(t)}:`;return o.delete(IDBKeyRange.bound(a,`${a}\uFFFF`,!1,!0))});return n.close(),typeof s=="number"?s>0:!0}async clear(){if(!this.isSupported)return;let t=await Pi(this.dbName,this.storeName);await Ni(t,this.storeName,"readwrite",r=>r.clear()),t.close()}async list(){if(!this.isSupported)return[];let t=await Pi(this.dbName,this.storeName),r=await Ni(t,this.storeName,"readonly",n=>n.getAll());return t.close(),r.sort((n,i)=>i.persistedAt-n.persistedAt)}};var Er=class extends Error{constructor(r,n){super(n??`Missing dependencies: ${r.join(", ")}`);this.missing=r;this.name="AssetDependencyError"}},Ui=class{constructor(){this.nodes=new Map}register(t,r=[]){let n=this.nodes.get(t)??{dependencies:new Set,loaded:!1};r.forEach(i=>n.dependencies.add(i)),this.nodes.set(t,n),r.forEach(i=>{this.nodes.has(i)||this.nodes.set(i,{dependencies:new Set,loaded:!1})})}markLoaded(t){let r=this.nodes.get(t)??{dependencies:new Set,loaded:!1},n=this.getMissingDependencies(t,r);if(n.length>0)throw new Er(n,`Asset ${t} is missing dependencies: ${n.join(", ")}`);r.loaded=!0,this.nodes.set(t,r)}markUnloaded(t){let r=this.nodes.get(t);r&&(r.loaded=!1)}isLoaded(t){return this.nodes.get(t)?.loaded??!1}missingDependencies(t){let r=this.nodes.get(t);return r?this.getMissingDependencies(t,r):[]}reset(){this.nodes.clear()}getMissingDependencies(t,r){let n=[];for(let i of r.dependencies)this.nodes.get(i)?.loaded||n.push(i);return n}},go=class{constructor(t,r={}){this.vfs=t;this.maps=new Map;this.textures=new jr({capacity:r.textureCacheCapacity??128}),this.audio=new gn(t,{cacheSize:r.audioCacheSize??64}),this.dependencyTracker=r.dependencyTracker??new Ui,this.md2=new Zr(t),this.md3=new Yr(t),this.sprite=new qr(t),this.bsp=new $r(t),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(t="pics/colormap.pcx"){try{let r=await this.vfs.readFile(t),n=Xn(r);n.palette&&(this.palette=n.palette)}catch(r){console.warn(`Failed to load palette from ${t}:`,r)}}isAssetLoaded(t,r){return this.dependencyTracker.isLoaded(this.makeKey(t,r))}registerTexture(t,r){this.textures.set(t,r);let n=this.makeKey("texture",t);this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n)}async loadTexture(t){let r=this.textures.get(t);if(r)return r;let n=await this.vfs.readFile(t),i=t.split(".").pop()?.toLowerCase(),s;if(i==="wal")s=Bs(n,this.palette);else if(i==="pcx")s=ks(Xn(n));else if(i==="tga")s=sd(Pa(n));else throw new Error(`Unsupported texture format for loadTexture: ${i}`);return this.registerTexture(t,s),s}async loadSound(t){let r=await this.audio.load(t),n=this.makeKey("sound",t);return this.dependencyTracker.register(n),this.dependencyTracker.markLoaded(n),r}async loadMd2Model(t,r=[]){let n=this.makeKey("model",t),i=r.map(a=>this.makeKey("texture",a));this.dependencyTracker.register(n,i);let s=this.dependencyTracker.missingDependencies(n);if(s.length>0)throw new Er(s,`Asset ${n} is missing dependencies: ${s.join(", ")}`);let o=await this.md2.load(t);return this.dependencyTracker.markLoaded(n),o}getMd2Model(t){return this.md2.get(t)}async loadMd3Model(t,r=[]){let n=this.makeKey("model",t),i=r.map(a=>this.makeKey("texture",a));this.dependencyTracker.register(n,i);let s=this.dependencyTracker.missingDependencies(n);if(s.length>0)throw new Er(s,`Asset ${n} is missing dependencies: ${s.join(", ")}`);let o=await this.md3.load(t);return this.dependencyTracker.markLoaded(n),o}getMd3Model(t){return this.md3.get(t)}async loadSprite(t){let r=this.makeKey("sprite",t);this.dependencyTracker.register(r);let n=await this.sprite.load(t);return this.dependencyTracker.markLoaded(r),n}async loadMap(t){let r=this.makeKey("map",t);if(this.maps.has(t))return this.maps.get(t);this.dependencyTracker.register(r);let n=await this.bsp.load(t);return this.maps.set(t,n),this.dependencyTracker.markLoaded(r),n}getMap(t){return this.maps.get(t)}listFiles(t){return this.vfs.findByExtension(t)}resetForLevelChange(){this.textures.clear(),this.audio.clearAll(),this.dependencyTracker.reset(),this.maps.clear()}makeKey(t,r){return`${t}:${ae(r)}`}};var yo=class{constructor(t){this.factory=t}getContext(){return this.context||(this.context=this.factory()),this.context}async resume(){let t=this.getContext();t.state==="suspended"&&await t.resume()}getState(){return this.context?.state??"suspended"}};function xo(e){let t=e.getContext(),r=t.createGain();r.gain.value=1;let n=t.createDynamicsCompressor(),i=t.createBiquadFilter?.();return i?(i.type="lowpass",i.frequency.value=2e4,i.Q.value=.707,r.connect(i),i.connect(n)):r.connect(n),n.connect(t.destination),{context:t,master:r,compressor:n,filter:i}}var _o=class{constructor(t=new Wr){this.configStrings=t;this.buffers=new Map}registerName(t){return this.configStrings.soundIndex(t)}register(t,r){let n=this.registerName(t);return this.buffers.set(n,r),n}find(t){return this.configStrings.findSoundIndex(t)}get(t){return this.buffers.get(t)}has(t){return this.buffers.has(t)}getName(t){return this.configStrings.getName(t)}};var bo=class{constructor(t){this.vfs=t.vfs,this.registry=t.registry,this.contextController=t.context,this.soundRoot=t.soundRoot??"sound/",this.decodeAudio=t.decodeAudio??((r,n)=>{if(!r.decodeAudioData)throw new Error("decodeAudioData is not available on the provided audio context");return r.decodeAudioData(n)})}async precache(t){let r=[...new Set(t.map(s=>this.normalize(s)))],n={loaded:[],skipped:[],missing:[],errors:{}},i=this.contextController.getContext();for(let s of r)try{let o=this.registry.find(s);if(o!==void 0&&this.registry.has(o)){n.skipped.push(s);continue}if(!this.vfs.stat(s)){n.missing.push(s);continue}let l=(await this.vfs.readFile(s)).slice().buffer,c=await this.decodeAudio(i,l);this.registry.register(s,c),n.loaded.push(s)}catch(o){let a=o instanceof Error?o:new Error(String(o));n.errors[s]=a}return n}normalize(t){let r=ae(t.replace(/^\//,""));return r.startsWith(this.soundRoot)?r:ae(`${this.soundRoot}${r}`)}};var um=7,Hi=e=>e&um;function vo(e){return Array.from({length:On},()=>({entnum:0,entchannel:st.Auto,endTimeMs:0,isPlayer:!1,active:!1})).map(t=>({...t,isPlayer:t.entnum===e}))}function So(e,t,r,n){if(r<0)throw new Error("pickChannel: entchannel must be non-negative");let i=Hi(r),s=-1,o=Number.POSITIVE_INFINITY;for(let a=0;a<e.length;a+=1){let d=e[a],l=Hi(d.entchannel);if(i!==st.Auto&&d.entnum===t&&l===i){s=a;break}if(d.active&&d.entnum===n.playerEntity&&t!==n.playerEntity)continue;let c=d.endTimeMs-n.nowMs;(s===-1||c<o)&&(o=c,s=a)}return s===-1?void 0:s}function wo(e,t,r,n,i){if(i)return{left:r,right:r,distanceComponent:0};let s=Tc(e,t.origin),o=_a(s),a=Je(s),d=o-kt;d<0&&(d=0),d*=Bt(n);let l=xa(t.right,a),c=t.mono??!1,h=c||n===0?1:.5*(1+l),u=c||n===0?1:.5*(1-l),f=Math.max(0,Math.floor(r*(1-d)*h));return{left:Math.max(0,Math.floor(r*(1-d)*u)),right:f,distanceComponent:d}}var Ao=class{constructor(t){this.activeSources=new Map;this.contextController=t.context,this.registry=t.registry,this.playerEntity=t.playerEntity,this.channels=vo(t.playerEntity),this.listener=t.listener??{origin:Lc,right:{x:1,y:0,z:0}},this.sfxVolume=t.sfxVolume??1,this.masterVolume=t.masterVolume??1,this.resolveOcclusion=t.resolveOcclusion,this.graph=xo(this.contextController),this.graph.master.gain.value=this.masterVolume}setListener(t){this.listener=t}setMasterVolume(t){this.masterVolume=t,this.graph.master.gain.value=t}setSfxVolume(t){this.sfxVolume=t}async ensureRunning(){await this.contextController.resume()}play(t){let r=this.registry.get(t.soundIndex);if(!r)return;let n=this.graph.context,i=n.currentTime*1e3,s=So(this.channels,t.entity,t.channel,{nowMs:i,playerEntity:this.playerEntity});if(s===void 0)return;let o=this.activeSources.get(s);o&&(o.source.onended=null,o.source.stop(),this.activeSources.delete(s));let a=n.createBufferSource();a.buffer=r,a.loop=t.looping??!1;let d=t.origin??this.listener.origin,l=n.createGain(),c=this.createPanner(n,t.attenuation),h=this.resolveOcclusion?.(this.listener,d,t.attenuation),u=Dd(h?.gainScale??1),f=this.resolveOcclusion?this.createOcclusionFilter(n,h?.lowpassHz??2e4):void 0;this.applyOriginToPanner(c,d);let m=t.entity===this.playerEntity,g=wo(d,this.listener,t.volume,t.attenuation,m),y=(t.volume===0?0:Math.max(g.left,g.right)/Math.max(1,t.volume))*(t.volume/255)*this.masterVolume*this.sfxVolume;l.gain.value=y*u;let S=n.currentTime+(t.timeOffsetMs??0)/1e3,_=(t.looping?Number.POSITIVE_INFINITY:r.duration*1e3)+S*1e3;a.connect(c),f?(c.connect(f),f.connect(l)):c.connect(l),l.connect(this.graph.master),a.start(S),a.onended=()=>{this.channels[s].active=!1,this.activeSources.delete(s)};let x={channelIndex:s,entnum:t.entity,entchannel:Hi(t.channel),endTimeMs:_,source:a,panner:c,gain:l,baseGain:y,origin:d,attenuation:t.attenuation,occlusion:f?{scale:u,lowpassHz:h?.lowpassHz,filter:f}:h?{scale:u,lowpassHz:h.lowpassHz}:void 0};return this.channels[s]={entnum:t.entity,entchannel:Hi(t.channel),endTimeMs:_,isPlayer:t.entity===this.playerEntity,active:!0},this.activeSources.set(s,x),x}stop(t){let r=this.activeSources.get(t);r&&(r.source.stop(),this.channels[t].active=!1,this.activeSources.delete(t))}stopEntitySounds(t){for(let[r,n]of[...this.activeSources.entries()])n.entnum===t&&(n.source.stop(),this.channels[r].active=!1,this.activeSources.delete(r))}updateEntityPosition(t,r){for(let n of this.activeSources.values())if(n.entnum===t&&(this.applyOriginToPanner(n.panner,r),n.origin=r,this.resolveOcclusion)){let i=this.resolveOcclusion(this.listener,r,n.attenuation);this.applyOcclusion(n,i)}}positionedSound(t,r,n,i){return this.play({entity:0,channel:st.Auto,soundIndex:r,volume:n,attenuation:i,origin:t})}ambientSound(t,r,n){return this.play({entity:0,channel:st.Auto,soundIndex:r,volume:n,attenuation:Pn,origin:t,looping:!0})}getChannelState(t){return this.channels[t]}getDiagnostics(){return{activeChannels:this.activeSources.size,masterVolume:this.masterVolume,sfxVolume:this.sfxVolume,channels:[...this.channels],activeSounds:[...this.activeSources.values()].map(t=>({entnum:t.entnum,entchannel:t.entchannel,channelIndex:t.channelIndex,origin:t.origin,gain:t.gain.gain.value,baseGain:t.baseGain,attenuation:t.attenuation,maxDistance:t.panner.maxDistance,distanceModel:t.panner.distanceModel,occlusion:t.occlusion?{scale:t.occlusion.scale,lowpassHz:t.occlusion.lowpassHz}:void 0}))}}setUnderwater(t,r=400){let n=this.graph.filter;n&&(n.type="lowpass",n.Q.value=.707,n.frequency.value=t?r:2e4)}createPanner(t,r){let n=t.createPanner?t.createPanner():Object.assign(t.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(t,r){let n=Bt(r);return t.refDistance=kt,t.maxDistance=Nn(r),t.rolloffFactor=n,t.distanceModel=r===0?"linear":"inverse",t.positionX.value=this.listener.origin.x,t.positionY.value=this.listener.origin.y,t.positionZ.value=this.listener.origin.z,t}applyOriginToPanner(t,r){t.positionX.value=r.x,t.positionY.value=r.y,t.positionZ.value=r.z}createOcclusionFilter(t,r){if(!t.createBiquadFilter)return;let n=t.createBiquadFilter();return n.type="lowpass",n.Q.value=.707,n.frequency.value=al(r,10,2e4),n}applyOcclusion(t,r){let n=Dd(r?.gainScale??1);if(t.gain.gain.value=t.baseGain*n,t.occlusion?.filter){let i=r?.lowpassHz??2e4;t.occlusion.filter.frequency.value=al(i,10,2e4)}t.occlusion?(t.occlusion.scale=n,t.occlusion.lowpassHz=r?.lowpassHz):r&&(t.occlusion={scale:n,lowpassHz:r.lowpassHz})}},al=(e,t,r)=>Math.min(r,Math.max(t,e)),Dd=e=>al(e,0,1);var Mo=class{constructor(t){this.createElement=t.createElement,this.resolveSource=t.resolveSource??(async r=>r),this.volume=t.volume??1}async play(t,{loop:r=!0,restart:n=!1}={}){if(this.track===t&&this.element){this.element.loop=r,this.element.volume=this.volume,n&&(this.element.currentTime=0),(this.element.paused||n)&&await this.element.play();return}let i=await this.resolveSource(t),s=this.createElement();s.src=i,s.loop=r,s.volume=this.volume,s.currentTime=0,s.load(),await s.play(),this.element=s,this.track=t}pause(){!this.element||this.element.paused||this.element.pause()}async resume(){!this.element||!this.element.paused||await this.element.play()}stop(){this.element&&(this.element.pause(),this.element.currentTime=0,this.element=void 0,this.track=void 0)}setVolume(t){this.volume=t,this.element&&(this.element.volume=t)}getState(){let t=!!(this.element&&!this.element.paused&&!this.element.ended),r=!!this.element?.paused;return{track:this.track,paused:r,playing:t,volume:this.volume}}};function fm(e){e.enable(e.DEPTH_TEST),e.depthFunc(e.LEQUAL),e.enable(e.CULL_FACE),e.cullFace(e.BACK),e.enable(e.BLEND),e.blendFuncSeparate(e.SRC_ALPHA,e.ONE_MINUS_SRC_ALPHA,e.ONE,e.ONE_MINUS_SRC_ALPHA)}function hm(e,t,r,n){for(let i of t){let s=e.getExtension(i);if(!s)throw new Error(`Missing required WebGL extension: ${i}`);n.set(i,s)}for(let i of r){let s=e.getExtension(i);s&&n.set(i,s)}}function Od(e,t={}){let{contextAttributes:r,requiredExtensions:n=[],optionalExtensions:i=[]}=t,s=e.getContext("webgl2",r??{antialias:!0});if(!s)throw new Error("WebGL2 not supported or failed to initialize");fm(s);let o=new Map;hm(s,n,i,o);let a=!1,d=new Set,l=new Set,c=u=>{a=!0,u.preventDefault();for(let f of d)f()},h=()=>{a=!1;for(let u of l)u()};return e.addEventListener("webglcontextlost",c),e.addEventListener("webglcontextrestored",h),{gl:s,extensions:o,isLost:()=>a,onLost(u){return d.add(u),()=>d.delete(u)},onRestored(u){return l.add(u),()=>l.delete(u)},dispose(){e.removeEventListener("webglcontextlost",c),e.removeEventListener("webglcontextrestored",h),d.clear(),l.clear(),o.clear()}}}function Pd(e,t,r){let n=e.createShader(t);if(!n)throw new Error("Failed to allocate shader");if(e.shaderSource(n,r),e.compileShader(n),!e.getShaderParameter(n,e.COMPILE_STATUS)){let s=e.getShaderInfoLog(n)??"Unknown shader compile failure";throw e.deleteShader(n),new Error(s)}return n}function mm(e,t,r,n){let i=e.createProgram();if(!i)throw new Error("Failed to allocate shader program");if(e.attachShader(i,t),e.attachShader(i,r),n)for(let[o,a]of Object.entries(n))e.bindAttribLocation(i,a,o);if(e.linkProgram(i),!e.getProgramParameter(i,e.LINK_STATUS)){let o=e.getProgramInfoLog(i)??"Unknown shader link failure";throw e.deleteProgram(i),new Error(o)}return i}var Ee=class e{constructor(t,r){this.uniformLocations=new Map;this.attributeLocations=new Map;this.gl=t,this.program=r}static create(t,r,n){let i=Pd(t,t.VERTEX_SHADER,r.vertex),s=Pd(t,t.FRAGMENT_SHADER,r.fragment);try{let o=mm(t,i,s,n);return new e(t,o)}finally{t.deleteShader(i),t.deleteShader(s)}}use(){this.gl.useProgram(this.program)}getUniformLocation(t){if(!this.uniformLocations.has(t)){let r=this.gl.getUniformLocation(this.program,t);this.uniformLocations.set(t,r)}return this.uniformLocations.get(t)??null}getAttributeLocation(t){if(!this.attributeLocations.has(t)){let r=this.gl.getAttribLocation(this.program,t);this.attributeLocations.set(t,r)}return this.attributeLocations.get(t)??-1}dispose(){this.gl.deleteProgram(this.program),this.uniformLocations.clear(),this.attributeLocations.clear()}};function Nd(e,t,r){return Ee.create(e,t,r)}var Le=class{constructor(t,r=t.STATIC_DRAW,n){this.gl=t,this.target=n??t.ARRAY_BUFFER;let i=t.createBuffer();if(!i)throw new Error("Failed to allocate buffer");this.buffer=i,t.bindBuffer(this.target,this.buffer),t.bufferData(this.target,0,r)}bind(){this.gl.bindBuffer(this.target,this.buffer)}upload(t,r=this.gl.STATIC_DRAW){this.bind(),this.gl.bufferData(this.target,t,r)}update(t,r=0){this.bind(),this.gl.bufferSubData(this.target,r,t)}dispose(){this.gl.deleteBuffer(this.buffer)}},xe=class extends Le{constructor(t,r=t.STATIC_DRAW){super(t,r,t.ELEMENT_ARRAY_BUFFER)}},ze=class{constructor(t){this.gl=t;let r=t.createVertexArray();if(!r)throw new Error("Failed to allocate vertex array object");this.vao=r}bind(){this.gl.bindVertexArray(this.vao)}configureAttributes(t,r){this.bind(),r&&r.bind();for(let n of t)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)}},yn=class{constructor(t,r=t.TEXTURE_2D){this.width=0;this.height=0;this.gl=t,this.target=r;let n=t.createTexture();if(!n)throw new Error("Failed to allocate texture");this.texture=n}bind(t=0){this.gl.activeTexture(this.gl.TEXTURE0+t),this.gl.bindTexture(this.target,this.texture)}setParameters(t){this.bind(),t.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,t.wrapS),t.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,t.wrapT),t.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,t.minFilter),t.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,t.magFilter)}upload(t,r,n){this.width=t,this.height=r,this.uploadImage(0,this.gl.RGBA,t,r,0,this.gl.RGBA,this.gl.UNSIGNED_BYTE,n)}uploadImage(t,r,n,i,s,o,a,d){this.bind(),this.gl.texImage2D(this.target,t,r,n,i,s,o,a,d)}dispose(){this.gl.deleteTexture(this.texture)}},xn=class{constructor(t){this.gl=t,this.target=t.TEXTURE_CUBE_MAP;let r=t.createTexture();if(!r)throw new Error("Failed to allocate cubemap texture");this.texture=r}bind(t=0){this.gl.activeTexture(this.gl.TEXTURE0+t),this.gl.bindTexture(this.target,this.texture)}setParameters(t){this.bind(),t.wrapS!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_S,t.wrapS),t.wrapT!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_WRAP_T,t.wrapT),t.minFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MIN_FILTER,t.minFilter),t.magFilter!==void 0&&this.gl.texParameteri(this.target,this.gl.TEXTURE_MAG_FILTER,t.magFilter)}uploadFace(t,r,n,i,s,o,a,d,l){this.bind(),this.gl.texImage2D(t,r,n,i,s,o,a,d,l)}dispose(){this.gl.deleteTexture(this.texture)}},Eo=class{constructor(t){this.gl=t;let r=t.createFramebuffer();if(!r)throw new Error("Failed to allocate framebuffer");this.framebuffer=r}bind(t=this.gl.FRAMEBUFFER){this.gl.bindFramebuffer(t,this.framebuffer)}attachTexture2D(t,r,n=0){this.bind(),this.gl.framebufferTexture2D(this.gl.FRAMEBUFFER,t,r.target,r.texture,n)}dispose(){this.gl.deleteFramebuffer(this.framebuffer)}};var cl=4,ll=7*cl,dl=[{index:0,size:3,type:5126,stride:ll,offset:0},{index:1,size:2,type:5126,stride:ll,offset:3*cl},{index:2,size:2,type:5126,stride:ll,offset:5*cl}];function pm(e,t){return{width:e,height:e,padding:t,data:new Uint8Array(e*e*4),cursorX:0,cursorY:0,rowHeight:0}}function gm(e){let t=e.width*e.height;if(t===0)throw new Error("Invalid lightmap with zero area");let r=e.samples.byteLength/t;if(!Number.isInteger(r)||r<3||r>4)throw new Error("Unsupported lightmap channel count");return r}function ym(e,t,r){let n=gm(r),i=e.width*4,s=t.x+e.padding,o=t.y+e.padding,a=0;for(let d=0;d<r.height;d++){let l=(o+d)*i+s*4;for(let c=0;c<r.width;c++){let h=l+c*4;e.data[h]=r.samples[a],e.data[h+1]=r.samples[a+1],e.data[h+2]=r.samples[a+2],e.data[h+3]=n===4?r.samples[a+3]:255,a+=n}}}function xm(e,t,r){let n=t.width+r.lightmapPadding*2,i=t.height+r.lightmapPadding*2;if(n>r.atlasSize||i>r.atlasSize)throw new Error("Lightmap too large for atlas");for(let a of e){if(a.cursorX+n>a.width&&(a.cursorX=0,a.cursorY+=a.rowHeight+r.lightmapPadding,a.rowHeight=0),a.cursorY+i>a.height)continue;let d={atlasIndex:e.indexOf(a),x:a.cursorX,y:a.cursorY,width:t.width,height:t.height};return a.cursorX+=n+r.lightmapPadding,a.rowHeight=Math.max(a.rowHeight,i),{placement:d,atlas:a}}let s=pm(r.atlasSize,r.lightmapPadding);e.push(s);let o={atlasIndex:e.length-1,x:0,y:0,width:t.width,height:t.height};return s.cursorX=n+r.lightmapPadding,s.rowHeight=i,{placement:o,atlas:s}}function Lo(e){return e instanceof Float32Array?e:new Float32Array(e)}function _m(e,t){if(!e){let n=new Uint16Array(t);for(let i=0;i<t;i++)n[i]=i;return n}return e instanceof Uint16Array?e:new Uint16Array(e)}function bm(e,t){let r=new Float32Array(e.length);for(let n=0;n<e.length;n+=2)r[n]=t.offset[0]+e[n]*t.scale[0],r[n+1]=t.offset[1]+e[n+1]*t.scale[1];return r}function vm(e,t){let r=Lo(e.vertices),n=Lo(e.textureCoords),i=t?bm(Lo(e.lightmapCoords??e.textureCoords),t):Lo(e.lightmapCoords??new Float32Array(n.length)),s=r.length/3;if(n.length/2!==s)throw new Error("Texture coordinates count mismatch");if(i.length/2!==s)throw new Error("Lightmap coordinates count mismatch");let o=new Float32Array(s*7);for(let a=0;a<s;a++){let d=a*3,l=a*2,c=a*7;o[c]=r[d],o[c+1]=r[d+1],o[c+2]=r[d+2],o[c+3]=n[l],o[c+4]=n[l+1],o[c+5]=i[l],o[c+6]=i[l+1]}return o}function Ud(e){let t=[];for(let r=0;r<e.faces.length;r++){let n=e.faces[r];if(n.texInfo<0)continue;let i=e.texInfo[n.texInfo],s=[],o=[],a=[];for(let u=0;u<n.numEdges;u++){let f=e.surfEdges[n.firstEdge+u],m=e.edges[Math.abs(f)],g=f>=0?m.vertices[0]:m.vertices[1],p=e.vertices[g];s.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,S=p[0]*i.t[0]+p[1]*i.t[1]+p[2]*i.t[2]+i.tOffset;o.push(y,S),a.push(y,S)}let d=[],l=s.length/3;for(let u=1;u<l-1;u++)d.push(0,u,u+1);let c,h=e.lightMapInfo[r];if(h){let u=1/0,f=-1/0,m=1/0,g=-1/0;for(let b=0;b<o.length;b+=2){let A=o[b],v=o[b+1];A<u&&(u=A),A>f&&(f=A),v<m&&(m=v),v>g&&(g=v)}let p=Math.floor(u/16),y=Math.floor(m/16),S=Math.ceil(f/16)-p+1,_=Math.ceil(g/16)-y+1,x=Rs(n,e.lightMaps,h);if(x&&x.length===S*_*3){c={width:S,height:_,samples:x};for(let b=0;b<a.length;b+=2)a[b]=o[b]/16-p+.5,a[b+1]=o[b+1]/16-y+.5}}t.push({vertices:new Float32Array(s),textureCoords:new Float32Array(o),lightmapCoords:new Float32Array(a),indices:new Uint16Array(d),texture:i.texture,surfaceFlags:i.flags,lightmap:c,faceIndex:r})}return t}function Hd(e,t,r,n={}){let i=t;if(r&&n.hiddenClassnames&&n.hiddenClassnames.size>0){let c=new Set;for(let h of r.entities.entities)if(h.classname&&n.hiddenClassnames.has(h.classname)){let u=h.properties.model;if(u&&u.startsWith("*")){let f=parseInt(u.substring(1),10);if(!isNaN(f)&&f>=0&&f<r.models.length){let m=r.models[f];for(let g=0;g<m.numFaces;g++)c.add(m.firstFace+g)}}}c.size>0&&(i=t.filter(h=>!c.has(h.faceIndex)))}let s={atlasSize:n.atlasSize??1024,lightmapPadding:n.lightmapPadding??1,hiddenClassnames:n.hiddenClassnames??new Set},o=[],a=new Map;i.forEach((c,h)=>{if(!c.lightmap)return;let{placement:u,atlas:f}=xm(o,c.lightmap,s);ym(f,u,c.lightmap),a.set(h,{atlasIndex:u.atlasIndex,offset:[(u.x+s.lightmapPadding)/s.atlasSize,(u.y+s.lightmapPadding)/s.atlasSize],scale:[u.width/s.atlasSize,u.height/s.atlasSize]})});let d=o.map(c=>{let h=new yn(e);return h.setParameters({wrapS:e.CLAMP_TO_EDGE,wrapT:e.CLAMP_TO_EDGE,minFilter:e.LINEAR,magFilter:e.LINEAR}),h.uploadImage(0,e.RGBA,c.width,c.height,0,e.RGBA,e.UNSIGNED_BYTE,c.data),{texture:h,width:c.width,height:c.height,pixels:c.data}});return{surfaces:i.map((c,h)=>{let u=a.get(h),f=vm(c,u),m=_m(c.indices,f.length/7),g=new Le(e,e.STATIC_DRAW,e.ARRAY_BUFFER);g.upload(f);let p=new xe(e,e.STATIC_DRAW);p.upload(m);let y=new ze(e);return y.configureAttributes(dl,g),{vao:y,vertexBuffer:g,indexBuffer:p,indexCount:m.length,vertexCount:f.length/7,texture:c.texture,surfaceFlags:c.surfaceFlags??Bn,lightmap:u,vertexData:f,indexData:m}}),lightmaps:d}}function _n(e){let{normal:t,distance:r}=e,n=Math.sqrt(t.x*t.x+t.y*t.y+t.z*t.z);if(n===0)return e;let i=1/n;return{normal:{x:t.x*i,y:t.y*i,z:t.z*i},distance:r*i}}function Vd(e){if(e.length!==16)throw new Error("View-projection matrix must contain 16 elements");let t=e[0],r=e[4],n=e[8],i=e[12],s=e[1],o=e[5],a=e[9],d=e[13],l=e[2],c=e[6],h=e[10],u=e[14],f=e[3],m=e[7],g=e[11],p=e[15];return[_n({normal:{x:f+t,y:m+r,z:g+n},distance:p+i}),_n({normal:{x:f-t,y:m-r,z:g-n},distance:p-i}),_n({normal:{x:f+s,y:m+o,z:g+a},distance:p+d}),_n({normal:{x:f-s,y:m-o,z:g-a},distance:p-d}),_n({normal:{x:f+l,y:m+c,z:g+h},distance:p+u}),_n({normal:{x:f-l,y:m-c,z:g-h},distance:p-u})]}function Sm(e,t){return e.normal.x*t.x+e.normal.y*t.y+e.normal.z*t.z+e.distance}function Vi(e,t,r){for(let n of r){let i=n.normal.x>=0?t.x:e.x,s=n.normal.y>=0?t.y:e.y,o=n.normal.z>=0?t.z:e.z;if(Sm(n,{x:i,y:s,z:o})<0)return!1}return!0}function Gd(e){return e<0}function Wd(e){return-e-1}function Xd(e,t){return e.normal[0]*t.x+e.normal[1]*t.y+e.normal[2]*t.z-e.dist}function wm(e,t,r){if(!e||t<0||r<0)return!0;let n=Math.ceil(e.numClusters/8),i=e.clusters[t].pvs,s=Math.floor(r/8),o=1<<r%8;return s<0||s>=n?!1:(i[s]&o)!==0}function Am(e,t){let r={x:e.mins[0],y:e.mins[1],z:e.mins[2]},n={x:e.maxs[0],y:e.maxs[1],z:e.maxs[2]};return Vi(r,n,t)}function fl(e,t){let r=0;for(;r>=0;){let n=e.nodes[r],i=e.planes[n.planeIndex],o=Xd(i,t)>=0?0:1,a=n.children[o];if(Gd(a))return Wd(a);r=a}return-1}function Mm(e,t){let r=e.leafs[t],n=[];for(let i=0;i<r.numLeafFaces;i+=1)n.push(e.leafLists.leafFaces[t][i]);return n}function ul(e,t,r,n,i,s,o){if(Gd(t)){let u=Wd(t),f=e.leafs[u];if(!wm(e.visibility,i,f.cluster)||!Am(f,n))return;let m={x:(f.mins[0]+f.maxs[0])*.5,y:(f.mins[1]+f.maxs[1])*.5,z:(f.mins[2]+f.maxs[2])*.5},g=m.x-r.x,p=m.y-r.y,y=m.z-r.z,S=-(g*g+p*p+y*y);for(let _ of Mm(e,u))o.has(_)||(o.add(_),s.push({faceIndex:_,leafIndex:u,sortKey:S}));return}let a=e.nodes[t],d=e.planes[a.planeIndex],l=Xd(d,r),c=l>=0?a.children[0]:a.children[1],h=l>=0?a.children[1]:a.children[0];Vi({x:a.mins[0],y:a.mins[1],z:a.mins[2]},{x:a.maxs[0],y:a.maxs[1],z:a.maxs[2]},n)&&(ul(e,c,r,n,i,s,o),ul(e,h,r,n,i,s,o))}function Kd(e,t,r){let n=fl(e,t),i=n>=0?e.leafs[n].cluster:-1,s=[];return ul(e,0,t,r,i,s,new Set),s}var rr=32;function bn(e){let t=[];for(let r=0;r<e.length;r+=3){let n=e[r],i=e[r+1],s=e[r+2];t.push(n,i,i,s,s,n)}return e instanceof Uint32Array||Math.max(...t)>65535?new Uint32Array(t):new Uint16Array(t)}var hl=`#version 300 es
|
|
142
142
|
precision highp float;
|
|
143
143
|
|
|
144
144
|
layout(location = 0) in vec3 a_position;
|
|
@@ -281,7 +281,7 @@ void main() {
|
|
|
281
281
|
}
|
|
282
282
|
|
|
283
283
|
o_color = finalColor;
|
|
284
|
-
}`,$d=[0,255,255,255],Em=[0,-1,-1,-1];function pl(e=$d,t=[]){let r=new Float32Array(4);for(let n=0;n<4;n+=1){let i=e[n]??255;if(i===255){r[n]=0;continue}let
|
|
284
|
+
}`,$d=[0,255,255,255],Em=[0,-1,-1,-1];function pl(e=$d,t=[]){let r=new Float32Array(4);for(let n=0;n<4;n+=1){let i=e[n]??255;if(i===255){r[n]=0;continue}let s=t[i];r[n]=s!==void 0?s:1}return r}function Lm(e){return[-(e*.25%1),0]}function gl(e=Bn,t=0){let r=(e&Dc)!==0,n=(e&Fc)!==0,i=(e&zc)!==0,s=(e&kc)!==0,o=(e&Bc)!==0,a=s?.33:o?.66:1,d=s||o,l=!d&&!i,c=r?Lm(t):[0,0];return{alpha:a,blend:d,depthWrite:l,warp:n,flowOffset:c,sky:i}}var To=class{constructor(t){this.uniformDlights=[];this.gl=t,this.program=Ee.create(t,{vertex:hl,fragment:ml},{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.uniformDiffuse=this.program.getUniformLocation("u_diffuseMap"),this.uniformLightmap=this.program.getUniformLocation("u_lightmapAtlas"),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<rr;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`)})}bind(t){let{modelViewProjection:r,styleIndices:n=$d,styleLayers:i=Em,styleValues:s=[],diffuseSampler:o=0,lightmapSampler:a,surfaceFlags:d=Bn,timeSeconds:l=0,texScroll:c,alpha:h,warp:u,dlights:f=[],renderMode:m}=t,g=gl(d,l),p=pl(n,s),y=c?c[0]:g.flowOffset[0],S=c?c[1]:g.flowOffset[1],_=h!==void 0?h:g.alpha,x=u!==void 0?u:g.warp;this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,r),this.gl.uniform2f(this.uniformTexScroll,y,S),this.gl.uniform2f(this.uniformLmScroll,g.flowOffset[0],g.flowOffset[1]),this.gl.uniform4fv(this.uniformLightStyles,p),this.gl.uniform4fv(this.uniformStyleLayerMapping,i),this.gl.uniform1f(this.uniformAlpha,_);let b=!g.sky&&a!==void 0;this.gl.uniform1i(this.uniformApplyLightmap,b?1:0),this.gl.uniform1i(this.uniformWarp,x?1:0),this.gl.uniform1f(this.uniformTime,l),this.gl.uniform1i(this.uniformDiffuse,o),this.gl.uniform1i(this.uniformLightmap,a??0);let A=0,v=[1,1,1,1];m&&(m.mode==="solid"||m.mode==="wireframe"?A=1:m.mode==="solid-faceted"&&(A=2),m.color?v=[...m.color]:m.generateRandomColor&&(v=[1,1,1,1])),this.gl.uniform1i(this.uniformRenderMode,A),this.gl.uniform4f(this.uniformSolidColor,v[0],v[1],v[2],v[3]);let E=Math.min(f.length,rr);this.gl.uniform1i(this.uniformNumDlights,E);for(let L=0;L<E;L++){let w=f[L];this.gl.uniform3f(this.uniformDlights[L].pos,w.origin.x,w.origin.y,w.origin.z),this.gl.uniform3f(this.uniformDlights[L].color,w.color.x,w.color.y,w.color.z),this.gl.uniform1f(this.uniformDlights[L].intensity,w.intensity)}return g}draw(t,r){if(t.vao.bind(),r&&r.mode==="wireframe"){if(!t.wireframeIndexBuffer){let n=t;n.wireframeIndexBuffer=new xe(this.gl,this.gl.STATIC_DRAW);let i=bn(t.indexData);n.wireframeIndexBuffer.upload(i),n.wireframeIndexCount=i.length}t.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,t.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else t.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,t.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};function Zd(e,t){e.depthMask(t.depthWrite),t.blend?(e.enable(e.BLEND),e.blendFunc(e.SRC_ALPHA,e.ONE_MINUS_SRC_ALPHA)):e.disable(e.BLEND)}var Yd=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]),yl=`#version 300 es
|
|
285
285
|
precision highp float;
|
|
286
286
|
|
|
287
287
|
layout(location = 0) in vec3 a_position;
|
|
@@ -306,7 +306,7 @@ out vec4 o_color;
|
|
|
306
306
|
|
|
307
307
|
void main() {
|
|
308
308
|
o_color = texture(u_skybox, v_direction);
|
|
309
|
-
}`,
|
|
309
|
+
}`,Io=class{constructor(t){this.gl=t,this.program=Ee.create(t,{vertex:yl,fragment:xl},{a_position:0}),this.vao=new ze(t),this.vbo=new Le(t,t.STATIC_DRAW),this.vbo.upload(Yd,t.STATIC_DRAW);let r=[{index:0,size:3,type:t.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 xn(t),this.cubemap.setParameters({minFilter:t.LINEAR,magFilter:t.LINEAR,wrapS:t.CLAMP_TO_EDGE,wrapT:t.CLAMP_TO_EDGE})}bind(t){let{viewProjection:r,scroll:n,textureUnit:i=0}=t;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,Yd.length/3)}dispose(){this.vbo.dispose(),this.vao.dispose(),this.cubemap.dispose(),this.program.dispose()}};function qd(e){let t=new Float32Array(e);return t[12]=0,t[13]=0,t[14]=0,t}function jd(e,t=[.01,.02]){let[r,n]=t;return[r*e,n*e]}var bl=`#version 300 es
|
|
310
310
|
precision highp float;
|
|
311
311
|
|
|
312
312
|
layout(location = 0) in vec3 a_position;
|
|
@@ -394,7 +394,7 @@ void main() {
|
|
|
394
394
|
}
|
|
395
395
|
|
|
396
396
|
o_color = finalColor;
|
|
397
|
-
}`;function Tm(e){let t=e.x*e.x+e.y*e.y+e.z*e.z;if(t<=0)return{x:0,y:0,z:1};let r=1/Math.sqrt(t);return{x:e.x*r,y:e.y*r,z:e.z*r}}function _l(e,t,r){return e+(t-e)*r}function Qd(e,t,r){return{x:_l(e.x,t.x,r),y:_l(e.y,t.y,r),z:_l(e.z,t.z,r)}}function Im(e,t,r){return[e/r.skinWidth,1-t/r.skinHeight]}function Sl(e){if(e.glCommands.length===0){let n=[],i=[];return e.triangles.forEach(o=>{let s=n.length;for(let a=0;a<3;a+=1){let d=o.vertexIndices[a],l=o.texCoordIndices[a],c=e.texCoords[l];n.push({vertexIndex:d,texCoord:Im(c.s,c.t,e.header)})}i.push(s,s+1,s+2)}),{vertices:n,indices:new Uint16Array(i)}}let t=[],r=[];for(let n of e.glCommands){let i=t.length;if(t.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 s=o%2===0,a=i+o+(s?0:1),d=i+o+(s?1:0),l=i+o+2;r.push(a,d,l)}else for(let o=1;o<n.vertices.length-1;o+=1)r.push(i,i+o,i+o+1)}return{vertices:t,indices:new Uint16Array(r)}}function wl(e,t,r){let{frame0:n,frame1:i,lerp:o}=r,s=e.frames[n],a=e.frames[i];if(!s||!a)throw new Error("Requested MD2 frames are out of range");let d=new Float32Array(t.vertices.length*8);return t.vertices.forEach((l,c)=>{let h=s.vertices[l.vertexIndex],u=a.vertices[l.vertexIndex];if(!h||!u)throw new Error("MD2 vertex index out of range for frame");let f=Qd(h.position,u.position,o),m=Tm(Qd(h.normal,u.normal,o)),g=c*8;d[g]=f.x,d[g+1]=f.y,d[g+2]=f.z,d[g+3]=m.x,d[g+4]=m.y,d[g+5]=m.z,d[g+6]=l.texCoord[0],d[g+7]=l.texCoord[1]}),d}var Rs=class{constructor(t,r,n){this.gl=t,this.geometry=Sl(r),this.vertexBuffer=new Le(t,t.STATIC_DRAW),this.indexBuffer=new xe(t,t.STATIC_DRAW),this.vertexArray=new ze(t),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:t.FLOAT,stride:32,offset:0},{index:1,size:3,type:t.FLOAT,stride:32,offset:12},{index:2,size:2,type:t.FLOAT,stride:32,offset:24}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,t.STATIC_DRAW),this.update(r,n)}update(t,r){let n=wl(t,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()}},Cs=class{constructor(t){this.uniformDlights=[];this.gl=t,this.program=Ee.create(t,{vertex:bl,fragment:vl},{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<rr;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`)})}bind(t){let{modelViewProjection:r,modelMatrix:n,lightDirection:i=[0,0,1],ambientLight:o=.2,tint:s=[1,1,1,1],diffuseSampler:a=0,dlights:d=[],renderMode:l}=t,c=new Float32Array(i),h=new Float32Array(s);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,c),this.gl.uniform1f(this.uniformAmbient,o),this.gl.uniform4fv(this.uniformTint,h),this.gl.uniform1i(this.uniformDiffuse,a);let u=0,f=[1,1,1,1];l&&(l.mode==="solid"||l.mode==="wireframe"?u=1:l.mode==="solid-faceted"&&(u=2),l.color?f=[...l.color]:l.generateRandomColor),this.gl.uniform1i(this.uniformRenderMode,u),this.gl.uniform4f(this.uniformSolidColor,f[0],f[1],f[2],f[3]);let m=Math.min(d.length,rr);this.gl.uniform1i(this.uniformNumDlights,m);for(let g=0;g<m;g++){let p=d[g];this.gl.uniform3f(this.uniformDlights[g].pos,p.origin.x,p.origin.y,p.origin.z),this.gl.uniform3f(this.uniformDlights[g].color,p.color.x,p.color.y,p.color.z),this.gl.uniform1f(this.uniformDlights[g].intensity,p.intensity)}}draw(t,r){if(t.vertexArray.bind(),r&&r.mode==="wireframe"){if(!t.wireframeIndexBuffer){t.wireframeIndexBuffer=new xe(this.gl,this.gl.STATIC_DRAW);let n=bn(t.geometry.indices);t.wireframeIndexBuffer.upload(n),t.wireframeIndexCount=n.length}t.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,t.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else t.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,t.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var J=1e-6,qe=typeof Float32Array<"u"?Float32Array:Array,Al=Math.random;function zs(e){return e>=0?Math.round(e):e%.5===0?Math.floor(e):Math.round(e)}var BS=Math.PI/180,DS=180/Math.PI;var de={};pa(de,{add:()=>mp,adjoint:()=>Pm,clone:()=>Cm,copy:()=>zm,create:()=>Rm,decompose:()=>ep,determinant:()=>Om,equals:()=>xp,exactEquals:()=>yp,frob:()=>hp,fromQuat:()=>np,fromQuat2:()=>jm,fromRotation:()=>$m,fromRotationTranslation:()=>r0,fromRotationTranslationScale:()=>tp,fromRotationTranslationScaleOrigin:()=>rp,fromScaling:()=>Km,fromTranslation:()=>Xm,fromValues:()=>Fm,fromXRotation:()=>Zm,fromYRotation:()=>Ym,fromZRotation:()=>qm,frustum:()=>ip,getRotation:()=>Jm,getScaling:()=>n0,getTranslation:()=>Qm,identity:()=>e0,invert:()=>Dm,lookAt:()=>dp,mul:()=>_p,multiply:()=>t0,multiplyScalar:()=>pp,multiplyScalarAndAdd:()=>gp,ortho:()=>lp,orthoNO:()=>o0,orthoZO:()=>cp,perspective:()=>op,perspectiveFromFieldOfView:()=>ap,perspectiveNO:()=>i0,perspectiveZO:()=>sp,rotate:()=>Hm,rotateX:()=>Vm,rotateY:()=>Gm,rotateZ:()=>Wm,scale:()=>Um,set:()=>km,str:()=>fp,sub:()=>bp,subtract:()=>s0,targetTo:()=>up,translate:()=>Nm,transpose:()=>Bm});function Rm(){var e=new qe(16);return qe!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function Cm(e){var t=new qe(16);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 zm(e,t){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 Fm(e,t,r,n,i,o,s,a,d,l,c,h,u,f,m,g){var p=new qe(16);return p[0]=e,p[1]=t,p[2]=r,p[3]=n,p[4]=i,p[5]=o,p[6]=s,p[7]=a,p[8]=d,p[9]=l,p[10]=c,p[11]=h,p[12]=u,p[13]=f,p[14]=m,p[15]=g,p}function km(e,t,r,n,i,o,s,a,d,l,c,h,u,f,m,g,p){return e[0]=t,e[1]=r,e[2]=n,e[3]=i,e[4]=o,e[5]=s,e[6]=a,e[7]=d,e[8]=l,e[9]=c,e[10]=h,e[11]=u,e[12]=f,e[13]=m,e[14]=g,e[15]=p,e}function e0(e){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function Bm(e,t){if(e===t){var r=t[1],n=t[2],i=t[3],o=t[6],s=t[7],a=t[11];e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=r,e[6]=t[9],e[7]=t[13],e[8]=n,e[9]=o,e[11]=t[14],e[12]=i,e[13]=s,e[14]=a}else e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=t[1],e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=t[2],e[9]=t[6],e[10]=t[10],e[11]=t[14],e[12]=t[3],e[13]=t[7],e[14]=t[11],e[15]=t[15];return e}function Dm(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],s=t[4],a=t[5],d=t[6],l=t[7],c=t[8],h=t[9],u=t[10],f=t[11],m=t[12],g=t[13],p=t[14],y=t[15],S=r*a-n*s,_=r*d-i*s,x=r*l-o*s,b=n*d-i*a,A=n*l-o*a,v=i*l-o*d,E=c*g-h*m,L=c*p-u*m,w=c*y-f*m,T=h*p-u*g,z=h*y-f*g,U=u*y-f*p,C=S*U-_*z+x*T+b*w-A*L+v*E;return C?(C=1/C,e[0]=(a*U-d*z+l*T)*C,e[1]=(i*z-n*U-o*T)*C,e[2]=(g*v-p*A+y*b)*C,e[3]=(u*A-h*v-f*b)*C,e[4]=(d*w-s*U-l*L)*C,e[5]=(r*U-i*w+o*L)*C,e[6]=(p*x-m*v-y*_)*C,e[7]=(c*v-u*x+f*_)*C,e[8]=(s*z-a*w+l*E)*C,e[9]=(n*w-r*z-o*E)*C,e[10]=(m*A-g*x+y*S)*C,e[11]=(h*x-c*A-f*S)*C,e[12]=(a*L-s*T-d*E)*C,e[13]=(r*T-n*L+i*E)*C,e[14]=(g*_-m*b-p*S)*C,e[15]=(c*b-h*_+u*S)*C,e):null}function Pm(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],s=t[4],a=t[5],d=t[6],l=t[7],c=t[8],h=t[9],u=t[10],f=t[11],m=t[12],g=t[13],p=t[14],y=t[15],S=r*a-n*s,_=r*d-i*s,x=r*l-o*s,b=n*d-i*a,A=n*l-o*a,v=i*l-o*d,E=c*g-h*m,L=c*p-u*m,w=c*y-f*m,T=h*p-u*g,z=h*y-f*g,U=u*y-f*p;return e[0]=a*U-d*z+l*T,e[1]=i*z-n*U-o*T,e[2]=g*v-p*A+y*b,e[3]=u*A-h*v-f*b,e[4]=d*w-s*U-l*L,e[5]=r*U-i*w+o*L,e[6]=p*x-m*v-y*_,e[7]=c*v-u*x+f*_,e[8]=s*z-a*w+l*E,e[9]=n*w-r*z-o*E,e[10]=m*A-g*x+y*S,e[11]=h*x-c*A-f*S,e[12]=a*L-s*T-d*E,e[13]=r*T-n*L+i*E,e[14]=g*_-m*b-p*S,e[15]=c*b-h*_+u*S,e}function Om(e){var t=e[0],r=e[1],n=e[2],i=e[3],o=e[4],s=e[5],a=e[6],d=e[7],l=e[8],c=e[9],h=e[10],u=e[11],f=e[12],m=e[13],g=e[14],p=e[15],y=t*s-r*o,S=t*a-n*o,_=r*a-n*s,x=l*m-c*f,b=l*g-h*f,A=c*g-h*m,v=t*A-r*b+n*x,E=o*A-s*b+a*x,L=l*_-c*S+h*y,w=f*_-m*S+g*y;return d*v-i*E+p*L-u*w}function t0(e,t,r){var n=t[0],i=t[1],o=t[2],s=t[3],a=t[4],d=t[5],l=t[6],c=t[7],h=t[8],u=t[9],f=t[10],m=t[11],g=t[12],p=t[13],y=t[14],S=t[15],_=r[0],x=r[1],b=r[2],A=r[3];return e[0]=_*n+x*a+b*h+A*g,e[1]=_*i+x*d+b*u+A*p,e[2]=_*o+x*l+b*f+A*y,e[3]=_*s+x*c+b*m+A*S,_=r[4],x=r[5],b=r[6],A=r[7],e[4]=_*n+x*a+b*h+A*g,e[5]=_*i+x*d+b*u+A*p,e[6]=_*o+x*l+b*f+A*y,e[7]=_*s+x*c+b*m+A*S,_=r[8],x=r[9],b=r[10],A=r[11],e[8]=_*n+x*a+b*h+A*g,e[9]=_*i+x*d+b*u+A*p,e[10]=_*o+x*l+b*f+A*y,e[11]=_*s+x*c+b*m+A*S,_=r[12],x=r[13],b=r[14],A=r[15],e[12]=_*n+x*a+b*h+A*g,e[13]=_*i+x*d+b*u+A*p,e[14]=_*o+x*l+b*f+A*y,e[15]=_*s+x*c+b*m+A*S,e}function Nm(e,t,r){var n=r[0],i=r[1],o=r[2],s,a,d,l,c,h,u,f,m,g,p,y;return t===e?(e[12]=t[0]*n+t[4]*i+t[8]*o+t[12],e[13]=t[1]*n+t[5]*i+t[9]*o+t[13],e[14]=t[2]*n+t[6]*i+t[10]*o+t[14],e[15]=t[3]*n+t[7]*i+t[11]*o+t[15]):(s=t[0],a=t[1],d=t[2],l=t[3],c=t[4],h=t[5],u=t[6],f=t[7],m=t[8],g=t[9],p=t[10],y=t[11],e[0]=s,e[1]=a,e[2]=d,e[3]=l,e[4]=c,e[5]=h,e[6]=u,e[7]=f,e[8]=m,e[9]=g,e[10]=p,e[11]=y,e[12]=s*n+c*i+m*o+t[12],e[13]=a*n+h*i+g*o+t[13],e[14]=d*n+u*i+p*o+t[14],e[15]=l*n+f*i+y*o+t[15]),e}function Um(e,t,r){var n=r[0],i=r[1],o=r[2];return e[0]=t[0]*n,e[1]=t[1]*n,e[2]=t[2]*n,e[3]=t[3]*n,e[4]=t[4]*i,e[5]=t[5]*i,e[6]=t[6]*i,e[7]=t[7]*i,e[8]=t[8]*o,e[9]=t[9]*o,e[10]=t[10]*o,e[11]=t[11]*o,e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}function Hm(e,t,r,n){var i=n[0],o=n[1],s=n[2],a=Math.sqrt(i*i+o*o+s*s),d,l,c,h,u,f,m,g,p,y,S,_,x,b,A,v,E,L,w,T,z,U,C,$;return a<J?null:(a=1/a,i*=a,o*=a,s*=a,d=Math.sin(r),l=Math.cos(r),c=1-l,h=t[0],u=t[1],f=t[2],m=t[3],g=t[4],p=t[5],y=t[6],S=t[7],_=t[8],x=t[9],b=t[10],A=t[11],v=i*i*c+l,E=o*i*c+s*d,L=s*i*c-o*d,w=i*o*c-s*d,T=o*o*c+l,z=s*o*c+i*d,U=i*s*c+o*d,C=o*s*c-i*d,$=s*s*c+l,e[0]=h*v+g*E+_*L,e[1]=u*v+p*E+x*L,e[2]=f*v+y*E+b*L,e[3]=m*v+S*E+A*L,e[4]=h*w+g*T+_*z,e[5]=u*w+p*T+x*z,e[6]=f*w+y*T+b*z,e[7]=m*w+S*T+A*z,e[8]=h*U+g*C+_*$,e[9]=u*U+p*C+x*$,e[10]=f*U+y*C+b*$,e[11]=m*U+S*C+A*$,t!==e&&(e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e)}function Vm(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[4],s=t[5],a=t[6],d=t[7],l=t[8],c=t[9],h=t[10],u=t[11];return t!==e&&(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[4]=o*i+l*n,e[5]=s*i+c*n,e[6]=a*i+h*n,e[7]=d*i+u*n,e[8]=l*i-o*n,e[9]=c*i-s*n,e[10]=h*i-a*n,e[11]=u*i-d*n,e}function Gm(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[0],s=t[1],a=t[2],d=t[3],l=t[8],c=t[9],h=t[10],u=t[11];return t!==e&&(e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[0]=o*i-l*n,e[1]=s*i-c*n,e[2]=a*i-h*n,e[3]=d*i-u*n,e[8]=o*n+l*i,e[9]=s*n+c*i,e[10]=a*n+h*i,e[11]=d*n+u*i,e}function Wm(e,t,r){var n=Math.sin(r),i=Math.cos(r),o=t[0],s=t[1],a=t[2],d=t[3],l=t[4],c=t[5],h=t[6],u=t[7];return t!==e&&(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[0]=o*i+l*n,e[1]=s*i+c*n,e[2]=a*i+h*n,e[3]=d*i+u*n,e[4]=l*i-o*n,e[5]=c*i-s*n,e[6]=h*i-a*n,e[7]=u*i-d*n,e}function Xm(e,t){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=t[0],e[13]=t[1],e[14]=t[2],e[15]=1,e}function Km(e,t){return e[0]=t[0],e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t[1],e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t[2],e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function $m(e,t,r){var n=r[0],i=r[1],o=r[2],s=Math.sqrt(n*n+i*i+o*o),a,d,l;return s<J?null:(s=1/s,n*=s,i*=s,o*=s,a=Math.sin(t),d=Math.cos(t),l=1-d,e[0]=n*n*l+d,e[1]=i*n*l+o*a,e[2]=o*n*l-i*a,e[3]=0,e[4]=n*i*l-o*a,e[5]=i*i*l+d,e[6]=o*i*l+n*a,e[7]=0,e[8]=n*o*l+i*a,e[9]=i*o*l-n*a,e[10]=o*o*l+d,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e)}function Zm(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=n,e[6]=r,e[7]=0,e[8]=0,e[9]=-r,e[10]=n,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function Ym(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=0,e[2]=-r,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=r,e[9]=0,e[10]=n,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function qm(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=r,e[2]=0,e[3]=0,e[4]=-r,e[5]=n,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function r0(e,t,r){var n=t[0],i=t[1],o=t[2],s=t[3],a=n+n,d=i+i,l=o+o,c=n*a,h=n*d,u=n*l,f=i*d,m=i*l,g=o*l,p=s*a,y=s*d,S=s*l;return e[0]=1-(f+g),e[1]=h+S,e[2]=u-y,e[3]=0,e[4]=h-S,e[5]=1-(c+g),e[6]=m+p,e[7]=0,e[8]=u+y,e[9]=m-p,e[10]=1-(c+f),e[11]=0,e[12]=r[0],e[13]=r[1],e[14]=r[2],e[15]=1,e}function jm(e,t){var r=new qe(3),n=-t[0],i=-t[1],o=-t[2],s=t[3],a=t[4],d=t[5],l=t[6],c=t[7],h=n*n+i*i+o*o+s*s;return h>0?(r[0]=(a*s+c*n+d*o-l*i)*2/h,r[1]=(d*s+c*i+l*n-a*o)*2/h,r[2]=(l*s+c*o+a*i-d*n)*2/h):(r[0]=(a*s+c*n+d*o-l*i)*2,r[1]=(d*s+c*i+l*n-a*o)*2,r[2]=(l*s+c*o+a*i-d*n)*2),r0(e,t,r),e}function Qm(e,t){return e[0]=t[12],e[1]=t[13],e[2]=t[14],e}function n0(e,t){var r=t[0],n=t[1],i=t[2],o=t[4],s=t[5],a=t[6],d=t[8],l=t[9],c=t[10];return e[0]=Math.sqrt(r*r+n*n+i*i),e[1]=Math.sqrt(o*o+s*s+a*a),e[2]=Math.sqrt(d*d+l*l+c*c),e}function Jm(e,t){var r=new qe(3);n0(r,t);var n=1/r[0],i=1/r[1],o=1/r[2],s=t[0]*n,a=t[1]*i,d=t[2]*o,l=t[4]*n,c=t[5]*i,h=t[6]*o,u=t[8]*n,f=t[9]*i,m=t[10]*o,g=s+c+m,p=0;return g>0?(p=Math.sqrt(g+1)*2,e[3]=.25*p,e[0]=(h-f)/p,e[1]=(u-d)/p,e[2]=(a-l)/p):s>c&&s>m?(p=Math.sqrt(1+s-c-m)*2,e[3]=(h-f)/p,e[0]=.25*p,e[1]=(a+l)/p,e[2]=(u+d)/p):c>m?(p=Math.sqrt(1+c-s-m)*2,e[3]=(u-d)/p,e[0]=(a+l)/p,e[1]=.25*p,e[2]=(h+f)/p):(p=Math.sqrt(1+m-s-c)*2,e[3]=(a-l)/p,e[0]=(u+d)/p,e[1]=(h+f)/p,e[2]=.25*p),e}function ep(e,t,r,n){t[0]=n[12],t[1]=n[13],t[2]=n[14];var i=n[0],o=n[1],s=n[2],a=n[4],d=n[5],l=n[6],c=n[8],h=n[9],u=n[10];r[0]=Math.sqrt(i*i+o*o+s*s),r[1]=Math.sqrt(a*a+d*d+l*l),r[2]=Math.sqrt(c*c+h*h+u*u);var f=1/r[0],m=1/r[1],g=1/r[2],p=i*f,y=o*m,S=s*g,_=a*f,x=d*m,b=l*g,A=c*f,v=h*m,E=u*g,L=p+x+E,w=0;return L>0?(w=Math.sqrt(L+1)*2,e[3]=.25*w,e[0]=(b-v)/w,e[1]=(A-S)/w,e[2]=(y-_)/w):p>x&&p>E?(w=Math.sqrt(1+p-x-E)*2,e[3]=(b-v)/w,e[0]=.25*w,e[1]=(y+_)/w,e[2]=(A+S)/w):x>E?(w=Math.sqrt(1+x-p-E)*2,e[3]=(A-S)/w,e[0]=(y+_)/w,e[1]=.25*w,e[2]=(b+v)/w):(w=Math.sqrt(1+E-p-x)*2,e[3]=(y-_)/w,e[0]=(A+S)/w,e[1]=(b+v)/w,e[2]=.25*w),e}function tp(e,t,r,n){var i=t[0],o=t[1],s=t[2],a=t[3],d=i+i,l=o+o,c=s+s,h=i*d,u=i*l,f=i*c,m=o*l,g=o*c,p=s*c,y=a*d,S=a*l,_=a*c,x=n[0],b=n[1],A=n[2];return e[0]=(1-(m+p))*x,e[1]=(u+_)*x,e[2]=(f-S)*x,e[3]=0,e[4]=(u-_)*b,e[5]=(1-(h+p))*b,e[6]=(g+y)*b,e[7]=0,e[8]=(f+S)*A,e[9]=(g-y)*A,e[10]=(1-(h+m))*A,e[11]=0,e[12]=r[0],e[13]=r[1],e[14]=r[2],e[15]=1,e}function rp(e,t,r,n,i){var o=t[0],s=t[1],a=t[2],d=t[3],l=o+o,c=s+s,h=a+a,u=o*l,f=o*c,m=o*h,g=s*c,p=s*h,y=a*h,S=d*l,_=d*c,x=d*h,b=n[0],A=n[1],v=n[2],E=i[0],L=i[1],w=i[2],T=(1-(g+y))*b,z=(f+x)*b,U=(m-_)*b,C=(f-x)*A,$=(1-(u+y))*A,Ie=(p+S)*A,lr=(m+_)*v,go=(p-S)*v,Cn=(1-(u+g))*v;return e[0]=T,e[1]=z,e[2]=U,e[3]=0,e[4]=C,e[5]=$,e[6]=Ie,e[7]=0,e[8]=lr,e[9]=go,e[10]=Cn,e[11]=0,e[12]=r[0]+E-(T*E+C*L+lr*w),e[13]=r[1]+L-(z*E+$*L+go*w),e[14]=r[2]+w-(U*E+Ie*L+Cn*w),e[15]=1,e}function np(e,t){var r=t[0],n=t[1],i=t[2],o=t[3],s=r+r,a=n+n,d=i+i,l=r*s,c=n*s,h=n*a,u=i*s,f=i*a,m=i*d,g=o*s,p=o*a,y=o*d;return e[0]=1-h-m,e[1]=c+y,e[2]=u-p,e[3]=0,e[4]=c-y,e[5]=1-l-m,e[6]=f+g,e[7]=0,e[8]=u+p,e[9]=f-g,e[10]=1-l-h,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function ip(e,t,r,n,i,o,s){var a=1/(r-t),d=1/(i-n),l=1/(o-s);return e[0]=o*2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=o*2*d,e[6]=0,e[7]=0,e[8]=(r+t)*a,e[9]=(i+n)*d,e[10]=(s+o)*l,e[11]=-1,e[12]=0,e[13]=0,e[14]=s*o*2*l,e[15]=0,e}function i0(e,t,r,n,i){var o=1/Math.tan(t/2);if(e[0]=o/r,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=o,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=-1,e[12]=0,e[13]=0,e[15]=0,i!=null&&i!==1/0){var s=1/(n-i);e[10]=(i+n)*s,e[14]=2*i*n*s}else e[10]=-1,e[14]=-2*n;return e}var op=i0;function sp(e,t,r,n,i){var o=1/Math.tan(t/2);if(e[0]=o/r,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=o,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=-1,e[12]=0,e[13]=0,e[15]=0,i!=null&&i!==1/0){var s=1/(n-i);e[10]=i*s,e[14]=i*n*s}else e[10]=-1,e[14]=-n;return e}function ap(e,t,r,n){var i=Math.tan(t.upDegrees*Math.PI/180),o=Math.tan(t.downDegrees*Math.PI/180),s=Math.tan(t.leftDegrees*Math.PI/180),a=Math.tan(t.rightDegrees*Math.PI/180),d=2/(s+a),l=2/(i+o);return e[0]=d,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=l,e[6]=0,e[7]=0,e[8]=-((s-a)*d*.5),e[9]=(i-o)*l*.5,e[10]=n/(r-n),e[11]=-1,e[12]=0,e[13]=0,e[14]=n*r/(r-n),e[15]=0,e}function o0(e,t,r,n,i,o,s){var a=1/(t-r),d=1/(n-i),l=1/(o-s);return e[0]=-2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*d,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=2*l,e[11]=0,e[12]=(t+r)*a,e[13]=(i+n)*d,e[14]=(s+o)*l,e[15]=1,e}var lp=o0;function cp(e,t,r,n,i,o,s){var a=1/(t-r),d=1/(n-i),l=1/(o-s);return e[0]=-2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*d,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=l,e[11]=0,e[12]=(t+r)*a,e[13]=(i+n)*d,e[14]=o*l,e[15]=1,e}function dp(e,t,r,n){var i,o,s,a,d,l,c,h,u,f,m=t[0],g=t[1],p=t[2],y=n[0],S=n[1],_=n[2],x=r[0],b=r[1],A=r[2];return Math.abs(m-x)<J&&Math.abs(g-b)<J&&Math.abs(p-A)<J?e0(e):(c=m-x,h=g-b,u=p-A,f=1/Math.sqrt(c*c+h*h+u*u),c*=f,h*=f,u*=f,i=S*u-_*h,o=_*c-y*u,s=y*h-S*c,f=Math.sqrt(i*i+o*o+s*s),f?(f=1/f,i*=f,o*=f,s*=f):(i=0,o=0,s=0),a=h*s-u*o,d=u*i-c*s,l=c*o-h*i,f=Math.sqrt(a*a+d*d+l*l),f?(f=1/f,a*=f,d*=f,l*=f):(a=0,d=0,l=0),e[0]=i,e[1]=a,e[2]=c,e[3]=0,e[4]=o,e[5]=d,e[6]=h,e[7]=0,e[8]=s,e[9]=l,e[10]=u,e[11]=0,e[12]=-(i*m+o*g+s*p),e[13]=-(a*m+d*g+l*p),e[14]=-(c*m+h*g+u*p),e[15]=1,e)}function up(e,t,r,n){var i=t[0],o=t[1],s=t[2],a=n[0],d=n[1],l=n[2],c=i-r[0],h=o-r[1],u=s-r[2],f=c*c+h*h+u*u;f>0&&(f=1/Math.sqrt(f),c*=f,h*=f,u*=f);var m=d*u-l*h,g=l*c-a*u,p=a*h-d*c;return f=m*m+g*g+p*p,f>0&&(f=1/Math.sqrt(f),m*=f,g*=f,p*=f),e[0]=m,e[1]=g,e[2]=p,e[3]=0,e[4]=h*p-u*g,e[5]=u*m-c*p,e[6]=c*g-h*m,e[7]=0,e[8]=c,e[9]=h,e[10]=u,e[11]=0,e[12]=i,e[13]=o,e[14]=s,e[15]=1,e}function fp(e){return"mat4("+e[0]+", "+e[1]+", "+e[2]+", "+e[3]+", "+e[4]+", "+e[5]+", "+e[6]+", "+e[7]+", "+e[8]+", "+e[9]+", "+e[10]+", "+e[11]+", "+e[12]+", "+e[13]+", "+e[14]+", "+e[15]+")"}function hp(e){return Math.sqrt(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]+e[3]*e[3]+e[4]*e[4]+e[5]*e[5]+e[6]*e[6]+e[7]*e[7]+e[8]*e[8]+e[9]*e[9]+e[10]*e[10]+e[11]*e[11]+e[12]*e[12]+e[13]*e[13]+e[14]*e[14]+e[15]*e[15])}function mp(e,t,r){return e[0]=t[0]+r[0],e[1]=t[1]+r[1],e[2]=t[2]+r[2],e[3]=t[3]+r[3],e[4]=t[4]+r[4],e[5]=t[5]+r[5],e[6]=t[6]+r[6],e[7]=t[7]+r[7],e[8]=t[8]+r[8],e[9]=t[9]+r[9],e[10]=t[10]+r[10],e[11]=t[11]+r[11],e[12]=t[12]+r[12],e[13]=t[13]+r[13],e[14]=t[14]+r[14],e[15]=t[15]+r[15],e}function s0(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e[3]=t[3]-r[3],e[4]=t[4]-r[4],e[5]=t[5]-r[5],e[6]=t[6]-r[6],e[7]=t[7]-r[7],e[8]=t[8]-r[8],e[9]=t[9]-r[9],e[10]=t[10]-r[10],e[11]=t[11]-r[11],e[12]=t[12]-r[12],e[13]=t[13]-r[13],e[14]=t[14]-r[14],e[15]=t[15]-r[15],e}function pp(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e[3]=t[3]*r,e[4]=t[4]*r,e[5]=t[5]*r,e[6]=t[6]*r,e[7]=t[7]*r,e[8]=t[8]*r,e[9]=t[9]*r,e[10]=t[10]*r,e[11]=t[11]*r,e[12]=t[12]*r,e[13]=t[13]*r,e[14]=t[14]*r,e[15]=t[15]*r,e}function gp(e,t,r,n){return e[0]=t[0]+r[0]*n,e[1]=t[1]+r[1]*n,e[2]=t[2]+r[2]*n,e[3]=t[3]+r[3]*n,e[4]=t[4]+r[4]*n,e[5]=t[5]+r[5]*n,e[6]=t[6]+r[6]*n,e[7]=t[7]+r[7]*n,e[8]=t[8]+r[8]*n,e[9]=t[9]+r[9]*n,e[10]=t[10]+r[10]*n,e[11]=t[11]+r[11]*n,e[12]=t[12]+r[12]*n,e[13]=t[13]+r[13]*n,e[14]=t[14]+r[14]*n,e[15]=t[15]+r[15]*n,e}function yp(e,t){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]}function xp(e,t){var r=e[0],n=e[1],i=e[2],o=e[3],s=e[4],a=e[5],d=e[6],l=e[7],c=e[8],h=e[9],u=e[10],f=e[11],m=e[12],g=e[13],p=e[14],y=e[15],S=t[0],_=t[1],x=t[2],b=t[3],A=t[4],v=t[5],E=t[6],L=t[7],w=t[8],T=t[9],z=t[10],U=t[11],C=t[12],$=t[13],Ie=t[14],lr=t[15];return Math.abs(r-S)<=J*Math.max(1,Math.abs(r),Math.abs(S))&&Math.abs(n-_)<=J*Math.max(1,Math.abs(n),Math.abs(_))&&Math.abs(i-x)<=J*Math.max(1,Math.abs(i),Math.abs(x))&&Math.abs(o-b)<=J*Math.max(1,Math.abs(o),Math.abs(b))&&Math.abs(s-A)<=J*Math.max(1,Math.abs(s),Math.abs(A))&&Math.abs(a-v)<=J*Math.max(1,Math.abs(a),Math.abs(v))&&Math.abs(d-E)<=J*Math.max(1,Math.abs(d),Math.abs(E))&&Math.abs(l-L)<=J*Math.max(1,Math.abs(l),Math.abs(L))&&Math.abs(c-w)<=J*Math.max(1,Math.abs(c),Math.abs(w))&&Math.abs(h-T)<=J*Math.max(1,Math.abs(h),Math.abs(T))&&Math.abs(u-z)<=J*Math.max(1,Math.abs(u),Math.abs(z))&&Math.abs(f-U)<=J*Math.max(1,Math.abs(f),Math.abs(U))&&Math.abs(m-C)<=J*Math.max(1,Math.abs(m),Math.abs(C))&&Math.abs(g-$)<=J*Math.max(1,Math.abs(g),Math.abs($))&&Math.abs(p-Ie)<=J*Math.max(1,Math.abs(p),Math.abs(Ie))&&Math.abs(y-lr)<=J*Math.max(1,Math.abs(y),Math.abs(lr))}var _p=t0,bp=s0;var ce={};pa(ce,{add:()=>Mp,angle:()=>Zp,bezier:()=>Up,ceil:()=>Ep,clone:()=>vp,copy:()=>wp,create:()=>a0,cross:()=>Dp,dist:()=>r1,distance:()=>f0,div:()=>t1,divide:()=>u0,dot:()=>Ml,equals:()=>Qp,exactEquals:()=>jp,floor:()=>Lp,forEach:()=>s1,fromValues:()=>Sp,hermite:()=>Np,inverse:()=>kp,len:()=>i1,length:()=>l0,lerp:()=>Pp,max:()=>Ip,min:()=>Tp,mul:()=>e1,multiply:()=>d0,negate:()=>Fp,normalize:()=>Bp,random:()=>Hp,rotateX:()=>Xp,rotateY:()=>Kp,rotateZ:()=>$p,round:()=>Rp,scale:()=>Cp,scaleAndAdd:()=>zp,set:()=>Ap,slerp:()=>Op,sqrDist:()=>n1,sqrLen:()=>o1,squaredDistance:()=>h0,squaredLength:()=>m0,str:()=>qp,sub:()=>Jp,subtract:()=>c0,transformMat3:()=>Gp,transformMat4:()=>Vp,transformQuat:()=>Wp,zero:()=>Yp});function a0(){var e=new qe(3);return qe!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function vp(e){var t=new qe(3);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function l0(e){var t=e[0],r=e[1],n=e[2];return Math.sqrt(t*t+r*r+n*n)}function Sp(e,t,r){var n=new qe(3);return n[0]=e,n[1]=t,n[2]=r,n}function wp(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function Ap(e,t,r,n){return e[0]=t,e[1]=r,e[2]=n,e}function Mp(e,t,r){return e[0]=t[0]+r[0],e[1]=t[1]+r[1],e[2]=t[2]+r[2],e}function c0(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e}function d0(e,t,r){return e[0]=t[0]*r[0],e[1]=t[1]*r[1],e[2]=t[2]*r[2],e}function u0(e,t,r){return e[0]=t[0]/r[0],e[1]=t[1]/r[1],e[2]=t[2]/r[2],e}function Ep(e,t){return e[0]=Math.ceil(t[0]),e[1]=Math.ceil(t[1]),e[2]=Math.ceil(t[2]),e}function Lp(e,t){return e[0]=Math.floor(t[0]),e[1]=Math.floor(t[1]),e[2]=Math.floor(t[2]),e}function Tp(e,t,r){return e[0]=Math.min(t[0],r[0]),e[1]=Math.min(t[1],r[1]),e[2]=Math.min(t[2],r[2]),e}function Ip(e,t,r){return e[0]=Math.max(t[0],r[0]),e[1]=Math.max(t[1],r[1]),e[2]=Math.max(t[2],r[2]),e}function Rp(e,t){return e[0]=zs(t[0]),e[1]=zs(t[1]),e[2]=zs(t[2]),e}function Cp(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e}function zp(e,t,r,n){return e[0]=t[0]+r[0]*n,e[1]=t[1]+r[1]*n,e[2]=t[2]+r[2]*n,e}function f0(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2];return Math.sqrt(r*r+n*n+i*i)}function h0(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2];return r*r+n*n+i*i}function m0(e){var t=e[0],r=e[1],n=e[2];return t*t+r*r+n*n}function Fp(e,t){return e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e}function kp(e,t){return e[0]=1/t[0],e[1]=1/t[1],e[2]=1/t[2],e}function Bp(e,t){var r=t[0],n=t[1],i=t[2],o=r*r+n*n+i*i;return o>0&&(o=1/Math.sqrt(o)),e[0]=t[0]*o,e[1]=t[1]*o,e[2]=t[2]*o,e}function Ml(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function Dp(e,t,r){var n=t[0],i=t[1],o=t[2],s=r[0],a=r[1],d=r[2];return e[0]=i*d-o*a,e[1]=o*s-n*d,e[2]=n*a-i*s,e}function Pp(e,t,r,n){var i=t[0],o=t[1],s=t[2];return e[0]=i+n*(r[0]-i),e[1]=o+n*(r[1]-o),e[2]=s+n*(r[2]-s),e}function Op(e,t,r,n){var i=Math.acos(Math.min(Math.max(Ml(t,r),-1),1)),o=Math.sin(i),s=Math.sin((1-n)*i)/o,a=Math.sin(n*i)/o;return e[0]=s*t[0]+a*r[0],e[1]=s*t[1]+a*r[1],e[2]=s*t[2]+a*r[2],e}function Np(e,t,r,n,i,o){var s=o*o,a=s*(2*o-3)+1,d=s*(o-2)+o,l=s*(o-1),c=s*(3-2*o);return e[0]=t[0]*a+r[0]*d+n[0]*l+i[0]*c,e[1]=t[1]*a+r[1]*d+n[1]*l+i[1]*c,e[2]=t[2]*a+r[2]*d+n[2]*l+i[2]*c,e}function Up(e,t,r,n,i,o){var s=1-o,a=s*s,d=o*o,l=a*s,c=3*o*a,h=3*d*s,u=d*o;return e[0]=t[0]*l+r[0]*c+n[0]*h+i[0]*u,e[1]=t[1]*l+r[1]*c+n[1]*h+i[1]*u,e[2]=t[2]*l+r[2]*c+n[2]*h+i[2]*u,e}function Hp(e,t){t=t===void 0?1:t;var r=Al()*2*Math.PI,n=Al()*2-1,i=Math.sqrt(1-n*n)*t;return e[0]=Math.cos(r)*i,e[1]=Math.sin(r)*i,e[2]=n*t,e}function Vp(e,t,r){var n=t[0],i=t[1],o=t[2],s=r[3]*n+r[7]*i+r[11]*o+r[15];return s=s||1,e[0]=(r[0]*n+r[4]*i+r[8]*o+r[12])/s,e[1]=(r[1]*n+r[5]*i+r[9]*o+r[13])/s,e[2]=(r[2]*n+r[6]*i+r[10]*o+r[14])/s,e}function Gp(e,t,r){var n=t[0],i=t[1],o=t[2];return e[0]=n*r[0]+i*r[3]+o*r[6],e[1]=n*r[1]+i*r[4]+o*r[7],e[2]=n*r[2]+i*r[5]+o*r[8],e}function Wp(e,t,r){var n=r[0],i=r[1],o=r[2],s=r[3],a=t[0],d=t[1],l=t[2],c=i*l-o*d,h=o*a-n*l,u=n*d-i*a;return c=c+c,h=h+h,u=u+u,e[0]=a+s*c+i*u-o*h,e[1]=d+s*h+o*c-n*u,e[2]=l+s*u+n*h-i*c,e}function Xp(e,t,r,n){var i=[],o=[];return i[0]=t[0]-r[0],i[1]=t[1]-r[1],i[2]=t[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),e[0]=o[0]+r[0],e[1]=o[1]+r[1],e[2]=o[2]+r[2],e}function Kp(e,t,r,n){var i=[],o=[];return i[0]=t[0]-r[0],i[1]=t[1]-r[1],i[2]=t[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),e[0]=o[0]+r[0],e[1]=o[1]+r[1],e[2]=o[2]+r[2],e}function $p(e,t,r,n){var i=[],o=[];return i[0]=t[0]-r[0],i[1]=t[1]-r[1],i[2]=t[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],e[0]=o[0]+r[0],e[1]=o[1]+r[1],e[2]=o[2]+r[2],e}function Zp(e,t){var r=e[0],n=e[1],i=e[2],o=t[0],s=t[1],a=t[2],d=Math.sqrt((r*r+n*n+i*i)*(o*o+s*s+a*a)),l=d&&Ml(e,t)/d;return Math.acos(Math.min(Math.max(l,-1),1))}function Yp(e){return e[0]=0,e[1]=0,e[2]=0,e}function qp(e){return"vec3("+e[0]+", "+e[1]+", "+e[2]+")"}function jp(e,t){return e[0]===t[0]&&e[1]===t[1]&&e[2]===t[2]}function Qp(e,t){var r=e[0],n=e[1],i=e[2],o=t[0],s=t[1],a=t[2];return Math.abs(r-o)<=J*Math.max(1,Math.abs(r),Math.abs(o))&&Math.abs(n-s)<=J*Math.max(1,Math.abs(n),Math.abs(s))&&Math.abs(i-a)<=J*Math.max(1,Math.abs(i),Math.abs(a))}var Jp=c0,e1=d0,t1=u0,r1=f0,n1=h0,i1=l0,o1=m0,s1=(function(){var e=a0();return function(t,r,n,i,o,s){var a,d;for(r||(r=3),n||(n=0),i?d=Math.min(i*r+n,t.length):d=t.length,a=n;a<d;a+=r)e[0]=t[a],e[1]=t[a+1],e[2]=t[a+2],o(e,e,s),t[a]=e[0],t[a+1]=e[1],t[a+2]=e[2];return t}})();var Fs=class{constructor(){this._position=ce.create();this._angles=ce.create();this._bobAngles=ce.create();this._bobOffset=ce.create();this._kickAngles=ce.create();this._rollAngle=0;this._fov=90;this._aspect=1;this._near=.1;this._far=1e3;this._viewMatrix=de.create();this._projectionMatrix=de.create();this._viewProjectionMatrix=de.create();this._dirty=!0}get position(){return this._position}set position(t){ce.copy(this._position,t),this._dirty=!0}get angles(){return this._angles}set angles(t){ce.copy(this._angles,t),this._dirty=!0}get bobAngles(){return this._bobAngles}set bobAngles(t){ce.copy(this._bobAngles,t),this._dirty=!0}get kickAngles(){return this._kickAngles}set kickAngles(t){ce.copy(this._kickAngles,t),this._dirty=!0}get bobOffset(){return this._bobOffset}set bobOffset(t){ce.copy(this._bobOffset,t),this._dirty=!0}get rollAngle(){return this._rollAngle}set rollAngle(t){this._rollAngle=t,this._dirty=!0}get fov(){return this._fov}set fov(t){this._fov=t,this._dirty=!0}get aspect(){return this._aspect}set aspect(t){this._aspect=t,this._dirty=!0}get viewMatrix(){return this.updateMatrices(),this._viewMatrix}get projectionMatrix(){return this.updateMatrices(),this._projectionMatrix}get viewProjectionMatrix(){return this.updateMatrices(),this._viewProjectionMatrix}getViewmodelProjectionMatrix(t){let r=de.create();return de.perspective(r,t*Hr,this._aspect,this._near,this._far),r}updateMatrices(){if(!this._dirty)return;de.perspective(this._projectionMatrix,this._fov*Hr,this._aspect,this._near,this._far);let t=de.fromValues(0,-1,0,0,0,0,1,0,-1,0,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*Hr,s=n*Hr,a=i*Hr,d=de.create();de.identity(d),de.rotateZ(d,d,-s),de.rotateY(d,d,-o),de.rotateX(d,d,-a);let l=de.create();de.multiply(l,t,d);let c=ce.add(ce.create(),this._position,this._bobOffset),h=ce.negate(ce.create(),c),u=ce.create();ce.transformMat4(u,h,d);let f=ce.fromValues(u[1]||0,u[2]||0,u[0]||0);de.copy(this._viewMatrix,l),this._viewMatrix[12]=f[0],this._viewMatrix[13]=f[1],this._viewMatrix[14]=f[2],de.multiply(this._viewProjectionMatrix,this._projectionMatrix,this._viewMatrix),this._dirty=!1}};var a1=[.2,.2,.2],l1={x:0,y:0,z:1},c1=[.8,.8,.8];function El(e,t,r){return e+(t-e)*r}function Sn(e,t,r){return{x:El(e.x,t.x,r),y:El(e.y,t.y,r),z:El(e.z,t.z,r)}}function vn(e){return e<0?0:e>1?1:e}function Ll(e){let t=[],r=[];for(let n of e.triangles){let i=t.length,[o,s,a]=n.indices,d=e.texCoords[o],l=e.texCoords[s],c=e.texCoords[a];if(!d||!l||!c)throw new Error(`Missing texCoord for triangle in surface ${e.name}`);t.push({vertexIndex:o,texCoord:[d.s,1-d.t]},{vertexIndex:s,texCoord:[l.s,1-l.t]},{vertexIndex:a,texCoord:[c.s,1-c.t]}),r.push(i,i+1,i+2)}return{vertices:t,indices:new Uint16Array(r)}}function d1(e,t,r){let n=r?.ambient??a1,i=r?.directional??{direction:l1,color:c1},o=Je(e),s=Je(i.direction),a=vn(o.x*s.x+o.y*s.y+o.z*s.z),d=n[0]+i.color[0]*a,l=n[1]+i.color[1]*a,c=n[2]+i.color[2]*a;if(r?.dynamicLights){let h=r.modelMatrix?Ic(r.modelMatrix,t):t;for(let u of r.dynamicLights){let f=h.x-u.origin.x,m=h.y-u.origin.y,g=h.z-u.origin.z,p=f*f+m*m+g*g,y=u.radius*u.radius;if(p<y&&y>0){let S=1-Math.sqrt(p)/u.radius,_=Math.sqrt(p),x=_>0?vn(-(f*o.x+m*o.y+g*o.z)/_):0,b=vn(S*x);d+=u.color[0]*b,l+=u.color[1]*b,c+=u.color[2]*b}}}return[vn(d),vn(l),vn(c)]}function Tl(e,t,r,n){let i=e.vertices[r.frame0],o=e.vertices[r.frame1];if(!i||!o)throw new Error("Requested MD3 frames are out of range");let s=new Float32Array(t.vertices.length*12);return t.vertices.forEach((a,d)=>{let l=i[a.vertexIndex],c=o[a.vertexIndex];if(!l||!c)throw new Error(`Vertex index ${a.vertexIndex} missing for frame`);let h=Sn(l.position,c.position,r.lerp),u=Je(Sn(l.normal,c.normal,r.lerp)),f=d1(u,h,n),m=d*12;s[m]=h.x,s[m+1]=h.y,s[m+2]=h.z,s[m+3]=u.x,s[m+4]=u.y,s[m+5]=u.z,s[m+6]=a.texCoord[0],s[m+7]=a.texCoord[1],s[m+8]=f[0],s[m+9]=f[1],s[m+10]=f[2],s[m+11]=1}),s}function p0(e,t,r){let n=e.tags[0];if(!n)return null;let i=n.findIndex(g=>g.name===r);if(i===-1)return null;let o=e.tags[t.frame0]?.[i],s=e.tags[t.frame1]?.[i];if(!o||!s)throw new Error(`Tag ${r} is missing for one of the interpolated frames`);let a=Sn(o.origin,s.origin,t.lerp),d=Je(Sn(o.axis[0],s.axis[0],t.lerp)),l=Je(Sn(o.axis[1],s.axis[1],t.lerp)),c=Je(Sn(o.axis[2],s.axis[2],t.lerp)),h=d,u=Je({x:l.x-h.x*(h.x*l.x+h.y*l.y+h.z*l.z),y:l.y-h.y*(h.x*l.x+h.y*l.y+h.z*l.z),z:l.z-h.z*(h.x*l.x+h.y*l.y+h.z*l.z)}),f=Je({x:h.y*u.z-h.z*u.y,y:h.z*u.x-h.x*u.z,z:h.x*u.y-h.y*u.x}),m=[h,u,f];return{origin:a,axis:m,matrix:Rc(a,m)}}var Il=`#version 300 es
|
|
397
|
+
}`;function Tm(e){let t=e.x*e.x+e.y*e.y+e.z*e.z;if(t<=0)return{x:0,y:0,z:1};let r=1/Math.sqrt(t);return{x:e.x*r,y:e.y*r,z:e.z*r}}function _l(e,t,r){return e+(t-e)*r}function Qd(e,t,r){return{x:_l(e.x,t.x,r),y:_l(e.y,t.y,r),z:_l(e.z,t.z,r)}}function Im(e,t,r){return[e/r.skinWidth,1-t/r.skinHeight]}function Sl(e){if(e.glCommands.length===0){let n=[],i=[];return e.triangles.forEach(s=>{let o=n.length;for(let a=0;a<3;a+=1){let d=s.vertexIndices[a],l=s.texCoordIndices[a],c=e.texCoords[l];n.push({vertexIndex:d,texCoord:Im(c.s,c.t,e.header)})}i.push(o,o+1,o+2)}),{vertices:n,indices:new Uint16Array(i)}}let t=[],r=[];for(let n of e.glCommands){let i=t.length;if(t.push(...n.vertices.map(s=>({vertexIndex:s.vertexIndex,texCoord:[s.s,1-s.t]}))),n.mode==="strip")for(let s=0;s<n.vertices.length-2;s+=1){let o=s%2===0,a=i+s+(o?0:1),d=i+s+(o?1:0),l=i+s+2;r.push(a,d,l)}else for(let s=1;s<n.vertices.length-1;s+=1)r.push(i,i+s,i+s+1)}return{vertices:t,indices:new Uint16Array(r)}}function wl(e,t,r){let{frame0:n,frame1:i,lerp:s}=r,o=e.frames[n],a=e.frames[i];if(!o||!a)throw new Error("Requested MD2 frames are out of range");let d=new Float32Array(t.vertices.length*8);return t.vertices.forEach((l,c)=>{let h=o.vertices[l.vertexIndex],u=a.vertices[l.vertexIndex];if(!h||!u)throw new Error("MD2 vertex index out of range for frame");let f=Qd(h.position,u.position,s),m=Tm(Qd(h.normal,u.normal,s)),g=c*8;d[g]=f.x,d[g+1]=f.y,d[g+2]=f.z,d[g+3]=m.x,d[g+4]=m.y,d[g+5]=m.z,d[g+6]=l.texCoord[0],d[g+7]=l.texCoord[1]}),d}var Ro=class{constructor(t,r,n){this.gl=t,this.geometry=Sl(r),this.vertexBuffer=new Le(t,t.STATIC_DRAW),this.indexBuffer=new xe(t,t.STATIC_DRAW),this.vertexArray=new ze(t),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:t.FLOAT,stride:32,offset:0},{index:1,size:3,type:t.FLOAT,stride:32,offset:12},{index:2,size:2,type:t.FLOAT,stride:32,offset:24}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,t.STATIC_DRAW),this.update(r,n)}update(t,r){let n=wl(t,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()}},Co=class{constructor(t){this.uniformDlights=[];this.gl=t,this.program=Ee.create(t,{vertex:bl,fragment:vl},{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<rr;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`)})}bind(t){let{modelViewProjection:r,modelMatrix:n,lightDirection:i=[0,0,1],ambientLight:s=.2,tint:o=[1,1,1,1],diffuseSampler:a=0,dlights:d=[],renderMode:l}=t,c=new Float32Array(i),h=new Float32Array(o);this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,r),n?this.gl.uniformMatrix4fv(this.uniformModelMatrix,!1,n):this.gl.uniformMatrix4fv(this.uniformModelMatrix,!1,new Float32Array([1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1])),this.gl.uniform3fv(this.uniformLightDir,c),this.gl.uniform1f(this.uniformAmbient,s),this.gl.uniform4fv(this.uniformTint,h),this.gl.uniform1i(this.uniformDiffuse,a);let u=0,f=[1,1,1,1];l&&(l.mode==="solid"||l.mode==="wireframe"?u=1:l.mode==="solid-faceted"&&(u=2),l.color?f=[...l.color]:l.generateRandomColor),this.gl.uniform1i(this.uniformRenderMode,u),this.gl.uniform4f(this.uniformSolidColor,f[0],f[1],f[2],f[3]);let m=Math.min(d.length,rr);this.gl.uniform1i(this.uniformNumDlights,m);for(let g=0;g<m;g++){let p=d[g];this.gl.uniform3f(this.uniformDlights[g].pos,p.origin.x,p.origin.y,p.origin.z),this.gl.uniform3f(this.uniformDlights[g].color,p.color.x,p.color.y,p.color.z),this.gl.uniform1f(this.uniformDlights[g].intensity,p.intensity)}}draw(t,r){if(t.vertexArray.bind(),r&&r.mode==="wireframe"){if(!t.wireframeIndexBuffer){t.wireframeIndexBuffer=new xe(this.gl,this.gl.STATIC_DRAW);let n=bn(t.geometry.indices);t.wireframeIndexBuffer.upload(n),t.wireframeIndexCount=n.length}t.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,t.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else t.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,t.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var J=1e-6,qe=typeof Float32Array<"u"?Float32Array:Array,Al=Math.random;function zo(e){return e>=0?Math.round(e):e%.5===0?Math.floor(e):Math.round(e)}var BS=Math.PI/180,DS=180/Math.PI;var de={};pa(de,{add:()=>mp,adjoint:()=>Om,clone:()=>Cm,copy:()=>zm,create:()=>Rm,decompose:()=>ep,determinant:()=>Pm,equals:()=>xp,exactEquals:()=>yp,frob:()=>hp,fromQuat:()=>np,fromQuat2:()=>jm,fromRotation:()=>$m,fromRotationTranslation:()=>r0,fromRotationTranslationScale:()=>tp,fromRotationTranslationScaleOrigin:()=>rp,fromScaling:()=>Km,fromTranslation:()=>Xm,fromValues:()=>Fm,fromXRotation:()=>Zm,fromYRotation:()=>Ym,fromZRotation:()=>qm,frustum:()=>ip,getRotation:()=>Jm,getScaling:()=>n0,getTranslation:()=>Qm,identity:()=>e0,invert:()=>Dm,lookAt:()=>dp,mul:()=>_p,multiply:()=>t0,multiplyScalar:()=>pp,multiplyScalarAndAdd:()=>gp,ortho:()=>lp,orthoNO:()=>s0,orthoZO:()=>cp,perspective:()=>sp,perspectiveFromFieldOfView:()=>ap,perspectiveNO:()=>i0,perspectiveZO:()=>op,rotate:()=>Hm,rotateX:()=>Vm,rotateY:()=>Gm,rotateZ:()=>Wm,scale:()=>Um,set:()=>km,str:()=>fp,sub:()=>bp,subtract:()=>o0,targetTo:()=>up,translate:()=>Nm,transpose:()=>Bm});function Rm(){var e=new qe(16);return qe!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function Cm(e){var t=new qe(16);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 zm(e,t){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 Fm(e,t,r,n,i,s,o,a,d,l,c,h,u,f,m,g){var p=new qe(16);return p[0]=e,p[1]=t,p[2]=r,p[3]=n,p[4]=i,p[5]=s,p[6]=o,p[7]=a,p[8]=d,p[9]=l,p[10]=c,p[11]=h,p[12]=u,p[13]=f,p[14]=m,p[15]=g,p}function km(e,t,r,n,i,s,o,a,d,l,c,h,u,f,m,g,p){return e[0]=t,e[1]=r,e[2]=n,e[3]=i,e[4]=s,e[5]=o,e[6]=a,e[7]=d,e[8]=l,e[9]=c,e[10]=h,e[11]=u,e[12]=f,e[13]=m,e[14]=g,e[15]=p,e}function e0(e){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function Bm(e,t){if(e===t){var r=t[1],n=t[2],i=t[3],s=t[6],o=t[7],a=t[11];e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=r,e[6]=t[9],e[7]=t[13],e[8]=n,e[9]=s,e[11]=t[14],e[12]=i,e[13]=o,e[14]=a}else e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=t[1],e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=t[2],e[9]=t[6],e[10]=t[10],e[11]=t[14],e[12]=t[3],e[13]=t[7],e[14]=t[11],e[15]=t[15];return e}function Dm(e,t){var r=t[0],n=t[1],i=t[2],s=t[3],o=t[4],a=t[5],d=t[6],l=t[7],c=t[8],h=t[9],u=t[10],f=t[11],m=t[12],g=t[13],p=t[14],y=t[15],S=r*a-n*o,_=r*d-i*o,x=r*l-s*o,b=n*d-i*a,A=n*l-s*a,v=i*l-s*d,E=c*g-h*m,L=c*p-u*m,w=c*y-f*m,T=h*p-u*g,z=h*y-f*g,U=u*y-f*p,C=S*U-_*z+x*T+b*w-A*L+v*E;return C?(C=1/C,e[0]=(a*U-d*z+l*T)*C,e[1]=(i*z-n*U-s*T)*C,e[2]=(g*v-p*A+y*b)*C,e[3]=(u*A-h*v-f*b)*C,e[4]=(d*w-o*U-l*L)*C,e[5]=(r*U-i*w+s*L)*C,e[6]=(p*x-m*v-y*_)*C,e[7]=(c*v-u*x+f*_)*C,e[8]=(o*z-a*w+l*E)*C,e[9]=(n*w-r*z-s*E)*C,e[10]=(m*A-g*x+y*S)*C,e[11]=(h*x-c*A-f*S)*C,e[12]=(a*L-o*T-d*E)*C,e[13]=(r*T-n*L+i*E)*C,e[14]=(g*_-m*b-p*S)*C,e[15]=(c*b-h*_+u*S)*C,e):null}function Om(e,t){var r=t[0],n=t[1],i=t[2],s=t[3],o=t[4],a=t[5],d=t[6],l=t[7],c=t[8],h=t[9],u=t[10],f=t[11],m=t[12],g=t[13],p=t[14],y=t[15],S=r*a-n*o,_=r*d-i*o,x=r*l-s*o,b=n*d-i*a,A=n*l-s*a,v=i*l-s*d,E=c*g-h*m,L=c*p-u*m,w=c*y-f*m,T=h*p-u*g,z=h*y-f*g,U=u*y-f*p;return e[0]=a*U-d*z+l*T,e[1]=i*z-n*U-s*T,e[2]=g*v-p*A+y*b,e[3]=u*A-h*v-f*b,e[4]=d*w-o*U-l*L,e[5]=r*U-i*w+s*L,e[6]=p*x-m*v-y*_,e[7]=c*v-u*x+f*_,e[8]=o*z-a*w+l*E,e[9]=n*w-r*z-s*E,e[10]=m*A-g*x+y*S,e[11]=h*x-c*A-f*S,e[12]=a*L-o*T-d*E,e[13]=r*T-n*L+i*E,e[14]=g*_-m*b-p*S,e[15]=c*b-h*_+u*S,e}function Pm(e){var t=e[0],r=e[1],n=e[2],i=e[3],s=e[4],o=e[5],a=e[6],d=e[7],l=e[8],c=e[9],h=e[10],u=e[11],f=e[12],m=e[13],g=e[14],p=e[15],y=t*o-r*s,S=t*a-n*s,_=r*a-n*o,x=l*m-c*f,b=l*g-h*f,A=c*g-h*m,v=t*A-r*b+n*x,E=s*A-o*b+a*x,L=l*_-c*S+h*y,w=f*_-m*S+g*y;return d*v-i*E+p*L-u*w}function t0(e,t,r){var n=t[0],i=t[1],s=t[2],o=t[3],a=t[4],d=t[5],l=t[6],c=t[7],h=t[8],u=t[9],f=t[10],m=t[11],g=t[12],p=t[13],y=t[14],S=t[15],_=r[0],x=r[1],b=r[2],A=r[3];return e[0]=_*n+x*a+b*h+A*g,e[1]=_*i+x*d+b*u+A*p,e[2]=_*s+x*l+b*f+A*y,e[3]=_*o+x*c+b*m+A*S,_=r[4],x=r[5],b=r[6],A=r[7],e[4]=_*n+x*a+b*h+A*g,e[5]=_*i+x*d+b*u+A*p,e[6]=_*s+x*l+b*f+A*y,e[7]=_*o+x*c+b*m+A*S,_=r[8],x=r[9],b=r[10],A=r[11],e[8]=_*n+x*a+b*h+A*g,e[9]=_*i+x*d+b*u+A*p,e[10]=_*s+x*l+b*f+A*y,e[11]=_*o+x*c+b*m+A*S,_=r[12],x=r[13],b=r[14],A=r[15],e[12]=_*n+x*a+b*h+A*g,e[13]=_*i+x*d+b*u+A*p,e[14]=_*s+x*l+b*f+A*y,e[15]=_*o+x*c+b*m+A*S,e}function Nm(e,t,r){var n=r[0],i=r[1],s=r[2],o,a,d,l,c,h,u,f,m,g,p,y;return t===e?(e[12]=t[0]*n+t[4]*i+t[8]*s+t[12],e[13]=t[1]*n+t[5]*i+t[9]*s+t[13],e[14]=t[2]*n+t[6]*i+t[10]*s+t[14],e[15]=t[3]*n+t[7]*i+t[11]*s+t[15]):(o=t[0],a=t[1],d=t[2],l=t[3],c=t[4],h=t[5],u=t[6],f=t[7],m=t[8],g=t[9],p=t[10],y=t[11],e[0]=o,e[1]=a,e[2]=d,e[3]=l,e[4]=c,e[5]=h,e[6]=u,e[7]=f,e[8]=m,e[9]=g,e[10]=p,e[11]=y,e[12]=o*n+c*i+m*s+t[12],e[13]=a*n+h*i+g*s+t[13],e[14]=d*n+u*i+p*s+t[14],e[15]=l*n+f*i+y*s+t[15]),e}function Um(e,t,r){var n=r[0],i=r[1],s=r[2];return e[0]=t[0]*n,e[1]=t[1]*n,e[2]=t[2]*n,e[3]=t[3]*n,e[4]=t[4]*i,e[5]=t[5]*i,e[6]=t[6]*i,e[7]=t[7]*i,e[8]=t[8]*s,e[9]=t[9]*s,e[10]=t[10]*s,e[11]=t[11]*s,e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}function Hm(e,t,r,n){var i=n[0],s=n[1],o=n[2],a=Math.sqrt(i*i+s*s+o*o),d,l,c,h,u,f,m,g,p,y,S,_,x,b,A,v,E,L,w,T,z,U,C,$;return a<J?null:(a=1/a,i*=a,s*=a,o*=a,d=Math.sin(r),l=Math.cos(r),c=1-l,h=t[0],u=t[1],f=t[2],m=t[3],g=t[4],p=t[5],y=t[6],S=t[7],_=t[8],x=t[9],b=t[10],A=t[11],v=i*i*c+l,E=s*i*c+o*d,L=o*i*c-s*d,w=i*s*c-o*d,T=s*s*c+l,z=o*s*c+i*d,U=i*o*c+s*d,C=s*o*c-i*d,$=o*o*c+l,e[0]=h*v+g*E+_*L,e[1]=u*v+p*E+x*L,e[2]=f*v+y*E+b*L,e[3]=m*v+S*E+A*L,e[4]=h*w+g*T+_*z,e[5]=u*w+p*T+x*z,e[6]=f*w+y*T+b*z,e[7]=m*w+S*T+A*z,e[8]=h*U+g*C+_*$,e[9]=u*U+p*C+x*$,e[10]=f*U+y*C+b*$,e[11]=m*U+S*C+A*$,t!==e&&(e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e)}function Vm(e,t,r){var n=Math.sin(r),i=Math.cos(r),s=t[4],o=t[5],a=t[6],d=t[7],l=t[8],c=t[9],h=t[10],u=t[11];return t!==e&&(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[4]=s*i+l*n,e[5]=o*i+c*n,e[6]=a*i+h*n,e[7]=d*i+u*n,e[8]=l*i-s*n,e[9]=c*i-o*n,e[10]=h*i-a*n,e[11]=u*i-d*n,e}function Gm(e,t,r){var n=Math.sin(r),i=Math.cos(r),s=t[0],o=t[1],a=t[2],d=t[3],l=t[8],c=t[9],h=t[10],u=t[11];return t!==e&&(e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[0]=s*i-l*n,e[1]=o*i-c*n,e[2]=a*i-h*n,e[3]=d*i-u*n,e[8]=s*n+l*i,e[9]=o*n+c*i,e[10]=a*n+h*i,e[11]=d*n+u*i,e}function Wm(e,t,r){var n=Math.sin(r),i=Math.cos(r),s=t[0],o=t[1],a=t[2],d=t[3],l=t[4],c=t[5],h=t[6],u=t[7];return t!==e&&(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[0]=s*i+l*n,e[1]=o*i+c*n,e[2]=a*i+h*n,e[3]=d*i+u*n,e[4]=l*i-s*n,e[5]=c*i-o*n,e[6]=h*i-a*n,e[7]=u*i-d*n,e}function Xm(e,t){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=t[0],e[13]=t[1],e[14]=t[2],e[15]=1,e}function Km(e,t){return e[0]=t[0],e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t[1],e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t[2],e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function $m(e,t,r){var n=r[0],i=r[1],s=r[2],o=Math.sqrt(n*n+i*i+s*s),a,d,l;return o<J?null:(o=1/o,n*=o,i*=o,s*=o,a=Math.sin(t),d=Math.cos(t),l=1-d,e[0]=n*n*l+d,e[1]=i*n*l+s*a,e[2]=s*n*l-i*a,e[3]=0,e[4]=n*i*l-s*a,e[5]=i*i*l+d,e[6]=s*i*l+n*a,e[7]=0,e[8]=n*s*l+i*a,e[9]=i*s*l-n*a,e[10]=s*s*l+d,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e)}function Zm(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=n,e[6]=r,e[7]=0,e[8]=0,e[9]=-r,e[10]=n,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function Ym(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=0,e[2]=-r,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=r,e[9]=0,e[10]=n,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function qm(e,t){var r=Math.sin(t),n=Math.cos(t);return e[0]=n,e[1]=r,e[2]=0,e[3]=0,e[4]=-r,e[5]=n,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function r0(e,t,r){var n=t[0],i=t[1],s=t[2],o=t[3],a=n+n,d=i+i,l=s+s,c=n*a,h=n*d,u=n*l,f=i*d,m=i*l,g=s*l,p=o*a,y=o*d,S=o*l;return e[0]=1-(f+g),e[1]=h+S,e[2]=u-y,e[3]=0,e[4]=h-S,e[5]=1-(c+g),e[6]=m+p,e[7]=0,e[8]=u+y,e[9]=m-p,e[10]=1-(c+f),e[11]=0,e[12]=r[0],e[13]=r[1],e[14]=r[2],e[15]=1,e}function jm(e,t){var r=new qe(3),n=-t[0],i=-t[1],s=-t[2],o=t[3],a=t[4],d=t[5],l=t[6],c=t[7],h=n*n+i*i+s*s+o*o;return h>0?(r[0]=(a*o+c*n+d*s-l*i)*2/h,r[1]=(d*o+c*i+l*n-a*s)*2/h,r[2]=(l*o+c*s+a*i-d*n)*2/h):(r[0]=(a*o+c*n+d*s-l*i)*2,r[1]=(d*o+c*i+l*n-a*s)*2,r[2]=(l*o+c*s+a*i-d*n)*2),r0(e,t,r),e}function Qm(e,t){return e[0]=t[12],e[1]=t[13],e[2]=t[14],e}function n0(e,t){var r=t[0],n=t[1],i=t[2],s=t[4],o=t[5],a=t[6],d=t[8],l=t[9],c=t[10];return e[0]=Math.sqrt(r*r+n*n+i*i),e[1]=Math.sqrt(s*s+o*o+a*a),e[2]=Math.sqrt(d*d+l*l+c*c),e}function Jm(e,t){var r=new qe(3);n0(r,t);var n=1/r[0],i=1/r[1],s=1/r[2],o=t[0]*n,a=t[1]*i,d=t[2]*s,l=t[4]*n,c=t[5]*i,h=t[6]*s,u=t[8]*n,f=t[9]*i,m=t[10]*s,g=o+c+m,p=0;return g>0?(p=Math.sqrt(g+1)*2,e[3]=.25*p,e[0]=(h-f)/p,e[1]=(u-d)/p,e[2]=(a-l)/p):o>c&&o>m?(p=Math.sqrt(1+o-c-m)*2,e[3]=(h-f)/p,e[0]=.25*p,e[1]=(a+l)/p,e[2]=(u+d)/p):c>m?(p=Math.sqrt(1+c-o-m)*2,e[3]=(u-d)/p,e[0]=(a+l)/p,e[1]=.25*p,e[2]=(h+f)/p):(p=Math.sqrt(1+m-o-c)*2,e[3]=(a-l)/p,e[0]=(u+d)/p,e[1]=(h+f)/p,e[2]=.25*p),e}function ep(e,t,r,n){t[0]=n[12],t[1]=n[13],t[2]=n[14];var i=n[0],s=n[1],o=n[2],a=n[4],d=n[5],l=n[6],c=n[8],h=n[9],u=n[10];r[0]=Math.sqrt(i*i+s*s+o*o),r[1]=Math.sqrt(a*a+d*d+l*l),r[2]=Math.sqrt(c*c+h*h+u*u);var f=1/r[0],m=1/r[1],g=1/r[2],p=i*f,y=s*m,S=o*g,_=a*f,x=d*m,b=l*g,A=c*f,v=h*m,E=u*g,L=p+x+E,w=0;return L>0?(w=Math.sqrt(L+1)*2,e[3]=.25*w,e[0]=(b-v)/w,e[1]=(A-S)/w,e[2]=(y-_)/w):p>x&&p>E?(w=Math.sqrt(1+p-x-E)*2,e[3]=(b-v)/w,e[0]=.25*w,e[1]=(y+_)/w,e[2]=(A+S)/w):x>E?(w=Math.sqrt(1+x-p-E)*2,e[3]=(A-S)/w,e[0]=(y+_)/w,e[1]=.25*w,e[2]=(b+v)/w):(w=Math.sqrt(1+E-p-x)*2,e[3]=(y-_)/w,e[0]=(A+S)/w,e[1]=(b+v)/w,e[2]=.25*w),e}function tp(e,t,r,n){var i=t[0],s=t[1],o=t[2],a=t[3],d=i+i,l=s+s,c=o+o,h=i*d,u=i*l,f=i*c,m=s*l,g=s*c,p=o*c,y=a*d,S=a*l,_=a*c,x=n[0],b=n[1],A=n[2];return e[0]=(1-(m+p))*x,e[1]=(u+_)*x,e[2]=(f-S)*x,e[3]=0,e[4]=(u-_)*b,e[5]=(1-(h+p))*b,e[6]=(g+y)*b,e[7]=0,e[8]=(f+S)*A,e[9]=(g-y)*A,e[10]=(1-(h+m))*A,e[11]=0,e[12]=r[0],e[13]=r[1],e[14]=r[2],e[15]=1,e}function rp(e,t,r,n,i){var s=t[0],o=t[1],a=t[2],d=t[3],l=s+s,c=o+o,h=a+a,u=s*l,f=s*c,m=s*h,g=o*c,p=o*h,y=a*h,S=d*l,_=d*c,x=d*h,b=n[0],A=n[1],v=n[2],E=i[0],L=i[1],w=i[2],T=(1-(g+y))*b,z=(f+x)*b,U=(m-_)*b,C=(f-x)*A,$=(1-(u+y))*A,Ie=(p+S)*A,lr=(m+_)*v,ps=(p-S)*v,Cn=(1-(u+g))*v;return e[0]=T,e[1]=z,e[2]=U,e[3]=0,e[4]=C,e[5]=$,e[6]=Ie,e[7]=0,e[8]=lr,e[9]=ps,e[10]=Cn,e[11]=0,e[12]=r[0]+E-(T*E+C*L+lr*w),e[13]=r[1]+L-(z*E+$*L+ps*w),e[14]=r[2]+w-(U*E+Ie*L+Cn*w),e[15]=1,e}function np(e,t){var r=t[0],n=t[1],i=t[2],s=t[3],o=r+r,a=n+n,d=i+i,l=r*o,c=n*o,h=n*a,u=i*o,f=i*a,m=i*d,g=s*o,p=s*a,y=s*d;return e[0]=1-h-m,e[1]=c+y,e[2]=u-p,e[3]=0,e[4]=c-y,e[5]=1-l-m,e[6]=f+g,e[7]=0,e[8]=u+p,e[9]=f-g,e[10]=1-l-h,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function ip(e,t,r,n,i,s,o){var a=1/(r-t),d=1/(i-n),l=1/(s-o);return e[0]=s*2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=s*2*d,e[6]=0,e[7]=0,e[8]=(r+t)*a,e[9]=(i+n)*d,e[10]=(o+s)*l,e[11]=-1,e[12]=0,e[13]=0,e[14]=o*s*2*l,e[15]=0,e}function i0(e,t,r,n,i){var s=1/Math.tan(t/2);if(e[0]=s/r,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=s,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=-1,e[12]=0,e[13]=0,e[15]=0,i!=null&&i!==1/0){var o=1/(n-i);e[10]=(i+n)*o,e[14]=2*i*n*o}else e[10]=-1,e[14]=-2*n;return e}var sp=i0;function op(e,t,r,n,i){var s=1/Math.tan(t/2);if(e[0]=s/r,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=s,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=-1,e[12]=0,e[13]=0,e[15]=0,i!=null&&i!==1/0){var o=1/(n-i);e[10]=i*o,e[14]=i*n*o}else e[10]=-1,e[14]=-n;return e}function ap(e,t,r,n){var i=Math.tan(t.upDegrees*Math.PI/180),s=Math.tan(t.downDegrees*Math.PI/180),o=Math.tan(t.leftDegrees*Math.PI/180),a=Math.tan(t.rightDegrees*Math.PI/180),d=2/(o+a),l=2/(i+s);return e[0]=d,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=l,e[6]=0,e[7]=0,e[8]=-((o-a)*d*.5),e[9]=(i-s)*l*.5,e[10]=n/(r-n),e[11]=-1,e[12]=0,e[13]=0,e[14]=n*r/(r-n),e[15]=0,e}function s0(e,t,r,n,i,s,o){var a=1/(t-r),d=1/(n-i),l=1/(s-o);return e[0]=-2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*d,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=2*l,e[11]=0,e[12]=(t+r)*a,e[13]=(i+n)*d,e[14]=(o+s)*l,e[15]=1,e}var lp=s0;function cp(e,t,r,n,i,s,o){var a=1/(t-r),d=1/(n-i),l=1/(s-o);return e[0]=-2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*d,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=l,e[11]=0,e[12]=(t+r)*a,e[13]=(i+n)*d,e[14]=s*l,e[15]=1,e}function dp(e,t,r,n){var i,s,o,a,d,l,c,h,u,f,m=t[0],g=t[1],p=t[2],y=n[0],S=n[1],_=n[2],x=r[0],b=r[1],A=r[2];return Math.abs(m-x)<J&&Math.abs(g-b)<J&&Math.abs(p-A)<J?e0(e):(c=m-x,h=g-b,u=p-A,f=1/Math.sqrt(c*c+h*h+u*u),c*=f,h*=f,u*=f,i=S*u-_*h,s=_*c-y*u,o=y*h-S*c,f=Math.sqrt(i*i+s*s+o*o),f?(f=1/f,i*=f,s*=f,o*=f):(i=0,s=0,o=0),a=h*o-u*s,d=u*i-c*o,l=c*s-h*i,f=Math.sqrt(a*a+d*d+l*l),f?(f=1/f,a*=f,d*=f,l*=f):(a=0,d=0,l=0),e[0]=i,e[1]=a,e[2]=c,e[3]=0,e[4]=s,e[5]=d,e[6]=h,e[7]=0,e[8]=o,e[9]=l,e[10]=u,e[11]=0,e[12]=-(i*m+s*g+o*p),e[13]=-(a*m+d*g+l*p),e[14]=-(c*m+h*g+u*p),e[15]=1,e)}function up(e,t,r,n){var i=t[0],s=t[1],o=t[2],a=n[0],d=n[1],l=n[2],c=i-r[0],h=s-r[1],u=o-r[2],f=c*c+h*h+u*u;f>0&&(f=1/Math.sqrt(f),c*=f,h*=f,u*=f);var m=d*u-l*h,g=l*c-a*u,p=a*h-d*c;return f=m*m+g*g+p*p,f>0&&(f=1/Math.sqrt(f),m*=f,g*=f,p*=f),e[0]=m,e[1]=g,e[2]=p,e[3]=0,e[4]=h*p-u*g,e[5]=u*m-c*p,e[6]=c*g-h*m,e[7]=0,e[8]=c,e[9]=h,e[10]=u,e[11]=0,e[12]=i,e[13]=s,e[14]=o,e[15]=1,e}function fp(e){return"mat4("+e[0]+", "+e[1]+", "+e[2]+", "+e[3]+", "+e[4]+", "+e[5]+", "+e[6]+", "+e[7]+", "+e[8]+", "+e[9]+", "+e[10]+", "+e[11]+", "+e[12]+", "+e[13]+", "+e[14]+", "+e[15]+")"}function hp(e){return Math.sqrt(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]+e[3]*e[3]+e[4]*e[4]+e[5]*e[5]+e[6]*e[6]+e[7]*e[7]+e[8]*e[8]+e[9]*e[9]+e[10]*e[10]+e[11]*e[11]+e[12]*e[12]+e[13]*e[13]+e[14]*e[14]+e[15]*e[15])}function mp(e,t,r){return e[0]=t[0]+r[0],e[1]=t[1]+r[1],e[2]=t[2]+r[2],e[3]=t[3]+r[3],e[4]=t[4]+r[4],e[5]=t[5]+r[5],e[6]=t[6]+r[6],e[7]=t[7]+r[7],e[8]=t[8]+r[8],e[9]=t[9]+r[9],e[10]=t[10]+r[10],e[11]=t[11]+r[11],e[12]=t[12]+r[12],e[13]=t[13]+r[13],e[14]=t[14]+r[14],e[15]=t[15]+r[15],e}function o0(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e[3]=t[3]-r[3],e[4]=t[4]-r[4],e[5]=t[5]-r[5],e[6]=t[6]-r[6],e[7]=t[7]-r[7],e[8]=t[8]-r[8],e[9]=t[9]-r[9],e[10]=t[10]-r[10],e[11]=t[11]-r[11],e[12]=t[12]-r[12],e[13]=t[13]-r[13],e[14]=t[14]-r[14],e[15]=t[15]-r[15],e}function pp(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e[3]=t[3]*r,e[4]=t[4]*r,e[5]=t[5]*r,e[6]=t[6]*r,e[7]=t[7]*r,e[8]=t[8]*r,e[9]=t[9]*r,e[10]=t[10]*r,e[11]=t[11]*r,e[12]=t[12]*r,e[13]=t[13]*r,e[14]=t[14]*r,e[15]=t[15]*r,e}function gp(e,t,r,n){return e[0]=t[0]+r[0]*n,e[1]=t[1]+r[1]*n,e[2]=t[2]+r[2]*n,e[3]=t[3]+r[3]*n,e[4]=t[4]+r[4]*n,e[5]=t[5]+r[5]*n,e[6]=t[6]+r[6]*n,e[7]=t[7]+r[7]*n,e[8]=t[8]+r[8]*n,e[9]=t[9]+r[9]*n,e[10]=t[10]+r[10]*n,e[11]=t[11]+r[11]*n,e[12]=t[12]+r[12]*n,e[13]=t[13]+r[13]*n,e[14]=t[14]+r[14]*n,e[15]=t[15]+r[15]*n,e}function yp(e,t){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]}function xp(e,t){var r=e[0],n=e[1],i=e[2],s=e[3],o=e[4],a=e[5],d=e[6],l=e[7],c=e[8],h=e[9],u=e[10],f=e[11],m=e[12],g=e[13],p=e[14],y=e[15],S=t[0],_=t[1],x=t[2],b=t[3],A=t[4],v=t[5],E=t[6],L=t[7],w=t[8],T=t[9],z=t[10],U=t[11],C=t[12],$=t[13],Ie=t[14],lr=t[15];return Math.abs(r-S)<=J*Math.max(1,Math.abs(r),Math.abs(S))&&Math.abs(n-_)<=J*Math.max(1,Math.abs(n),Math.abs(_))&&Math.abs(i-x)<=J*Math.max(1,Math.abs(i),Math.abs(x))&&Math.abs(s-b)<=J*Math.max(1,Math.abs(s),Math.abs(b))&&Math.abs(o-A)<=J*Math.max(1,Math.abs(o),Math.abs(A))&&Math.abs(a-v)<=J*Math.max(1,Math.abs(a),Math.abs(v))&&Math.abs(d-E)<=J*Math.max(1,Math.abs(d),Math.abs(E))&&Math.abs(l-L)<=J*Math.max(1,Math.abs(l),Math.abs(L))&&Math.abs(c-w)<=J*Math.max(1,Math.abs(c),Math.abs(w))&&Math.abs(h-T)<=J*Math.max(1,Math.abs(h),Math.abs(T))&&Math.abs(u-z)<=J*Math.max(1,Math.abs(u),Math.abs(z))&&Math.abs(f-U)<=J*Math.max(1,Math.abs(f),Math.abs(U))&&Math.abs(m-C)<=J*Math.max(1,Math.abs(m),Math.abs(C))&&Math.abs(g-$)<=J*Math.max(1,Math.abs(g),Math.abs($))&&Math.abs(p-Ie)<=J*Math.max(1,Math.abs(p),Math.abs(Ie))&&Math.abs(y-lr)<=J*Math.max(1,Math.abs(y),Math.abs(lr))}var _p=t0,bp=o0;var ce={};pa(ce,{add:()=>Mp,angle:()=>Zp,bezier:()=>Up,ceil:()=>Ep,clone:()=>vp,copy:()=>wp,create:()=>a0,cross:()=>Dp,dist:()=>r1,distance:()=>f0,div:()=>t1,divide:()=>u0,dot:()=>Ml,equals:()=>Qp,exactEquals:()=>jp,floor:()=>Lp,forEach:()=>o1,fromValues:()=>Sp,hermite:()=>Np,inverse:()=>kp,len:()=>i1,length:()=>l0,lerp:()=>Op,max:()=>Ip,min:()=>Tp,mul:()=>e1,multiply:()=>d0,negate:()=>Fp,normalize:()=>Bp,random:()=>Hp,rotateX:()=>Xp,rotateY:()=>Kp,rotateZ:()=>$p,round:()=>Rp,scale:()=>Cp,scaleAndAdd:()=>zp,set:()=>Ap,slerp:()=>Pp,sqrDist:()=>n1,sqrLen:()=>s1,squaredDistance:()=>h0,squaredLength:()=>m0,str:()=>qp,sub:()=>Jp,subtract:()=>c0,transformMat3:()=>Gp,transformMat4:()=>Vp,transformQuat:()=>Wp,zero:()=>Yp});function a0(){var e=new qe(3);return qe!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function vp(e){var t=new qe(3);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function l0(e){var t=e[0],r=e[1],n=e[2];return Math.sqrt(t*t+r*r+n*n)}function Sp(e,t,r){var n=new qe(3);return n[0]=e,n[1]=t,n[2]=r,n}function wp(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e}function Ap(e,t,r,n){return e[0]=t,e[1]=r,e[2]=n,e}function Mp(e,t,r){return e[0]=t[0]+r[0],e[1]=t[1]+r[1],e[2]=t[2]+r[2],e}function c0(e,t,r){return e[0]=t[0]-r[0],e[1]=t[1]-r[1],e[2]=t[2]-r[2],e}function d0(e,t,r){return e[0]=t[0]*r[0],e[1]=t[1]*r[1],e[2]=t[2]*r[2],e}function u0(e,t,r){return e[0]=t[0]/r[0],e[1]=t[1]/r[1],e[2]=t[2]/r[2],e}function Ep(e,t){return e[0]=Math.ceil(t[0]),e[1]=Math.ceil(t[1]),e[2]=Math.ceil(t[2]),e}function Lp(e,t){return e[0]=Math.floor(t[0]),e[1]=Math.floor(t[1]),e[2]=Math.floor(t[2]),e}function Tp(e,t,r){return e[0]=Math.min(t[0],r[0]),e[1]=Math.min(t[1],r[1]),e[2]=Math.min(t[2],r[2]),e}function Ip(e,t,r){return e[0]=Math.max(t[0],r[0]),e[1]=Math.max(t[1],r[1]),e[2]=Math.max(t[2],r[2]),e}function Rp(e,t){return e[0]=zo(t[0]),e[1]=zo(t[1]),e[2]=zo(t[2]),e}function Cp(e,t,r){return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e}function zp(e,t,r,n){return e[0]=t[0]+r[0]*n,e[1]=t[1]+r[1]*n,e[2]=t[2]+r[2]*n,e}function f0(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2];return Math.sqrt(r*r+n*n+i*i)}function h0(e,t){var r=t[0]-e[0],n=t[1]-e[1],i=t[2]-e[2];return r*r+n*n+i*i}function m0(e){var t=e[0],r=e[1],n=e[2];return t*t+r*r+n*n}function Fp(e,t){return e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e}function kp(e,t){return e[0]=1/t[0],e[1]=1/t[1],e[2]=1/t[2],e}function Bp(e,t){var r=t[0],n=t[1],i=t[2],s=r*r+n*n+i*i;return s>0&&(s=1/Math.sqrt(s)),e[0]=t[0]*s,e[1]=t[1]*s,e[2]=t[2]*s,e}function Ml(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function Dp(e,t,r){var n=t[0],i=t[1],s=t[2],o=r[0],a=r[1],d=r[2];return e[0]=i*d-s*a,e[1]=s*o-n*d,e[2]=n*a-i*o,e}function Op(e,t,r,n){var i=t[0],s=t[1],o=t[2];return e[0]=i+n*(r[0]-i),e[1]=s+n*(r[1]-s),e[2]=o+n*(r[2]-o),e}function Pp(e,t,r,n){var i=Math.acos(Math.min(Math.max(Ml(t,r),-1),1)),s=Math.sin(i),o=Math.sin((1-n)*i)/s,a=Math.sin(n*i)/s;return e[0]=o*t[0]+a*r[0],e[1]=o*t[1]+a*r[1],e[2]=o*t[2]+a*r[2],e}function Np(e,t,r,n,i,s){var o=s*s,a=o*(2*s-3)+1,d=o*(s-2)+s,l=o*(s-1),c=o*(3-2*s);return e[0]=t[0]*a+r[0]*d+n[0]*l+i[0]*c,e[1]=t[1]*a+r[1]*d+n[1]*l+i[1]*c,e[2]=t[2]*a+r[2]*d+n[2]*l+i[2]*c,e}function Up(e,t,r,n,i,s){var o=1-s,a=o*o,d=s*s,l=a*o,c=3*s*a,h=3*d*o,u=d*s;return e[0]=t[0]*l+r[0]*c+n[0]*h+i[0]*u,e[1]=t[1]*l+r[1]*c+n[1]*h+i[1]*u,e[2]=t[2]*l+r[2]*c+n[2]*h+i[2]*u,e}function Hp(e,t){t=t===void 0?1:t;var r=Al()*2*Math.PI,n=Al()*2-1,i=Math.sqrt(1-n*n)*t;return e[0]=Math.cos(r)*i,e[1]=Math.sin(r)*i,e[2]=n*t,e}function Vp(e,t,r){var n=t[0],i=t[1],s=t[2],o=r[3]*n+r[7]*i+r[11]*s+r[15];return o=o||1,e[0]=(r[0]*n+r[4]*i+r[8]*s+r[12])/o,e[1]=(r[1]*n+r[5]*i+r[9]*s+r[13])/o,e[2]=(r[2]*n+r[6]*i+r[10]*s+r[14])/o,e}function Gp(e,t,r){var n=t[0],i=t[1],s=t[2];return e[0]=n*r[0]+i*r[3]+s*r[6],e[1]=n*r[1]+i*r[4]+s*r[7],e[2]=n*r[2]+i*r[5]+s*r[8],e}function Wp(e,t,r){var n=r[0],i=r[1],s=r[2],o=r[3],a=t[0],d=t[1],l=t[2],c=i*l-s*d,h=s*a-n*l,u=n*d-i*a;return c=c+c,h=h+h,u=u+u,e[0]=a+o*c+i*u-s*h,e[1]=d+o*h+s*c-n*u,e[2]=l+o*u+n*h-i*c,e}function Xp(e,t,r,n){var i=[],s=[];return i[0]=t[0]-r[0],i[1]=t[1]-r[1],i[2]=t[2]-r[2],s[0]=i[0],s[1]=i[1]*Math.cos(n)-i[2]*Math.sin(n),s[2]=i[1]*Math.sin(n)+i[2]*Math.cos(n),e[0]=s[0]+r[0],e[1]=s[1]+r[1],e[2]=s[2]+r[2],e}function Kp(e,t,r,n){var i=[],s=[];return i[0]=t[0]-r[0],i[1]=t[1]-r[1],i[2]=t[2]-r[2],s[0]=i[2]*Math.sin(n)+i[0]*Math.cos(n),s[1]=i[1],s[2]=i[2]*Math.cos(n)-i[0]*Math.sin(n),e[0]=s[0]+r[0],e[1]=s[1]+r[1],e[2]=s[2]+r[2],e}function $p(e,t,r,n){var i=[],s=[];return i[0]=t[0]-r[0],i[1]=t[1]-r[1],i[2]=t[2]-r[2],s[0]=i[0]*Math.cos(n)-i[1]*Math.sin(n),s[1]=i[0]*Math.sin(n)+i[1]*Math.cos(n),s[2]=i[2],e[0]=s[0]+r[0],e[1]=s[1]+r[1],e[2]=s[2]+r[2],e}function Zp(e,t){var r=e[0],n=e[1],i=e[2],s=t[0],o=t[1],a=t[2],d=Math.sqrt((r*r+n*n+i*i)*(s*s+o*o+a*a)),l=d&&Ml(e,t)/d;return Math.acos(Math.min(Math.max(l,-1),1))}function Yp(e){return e[0]=0,e[1]=0,e[2]=0,e}function qp(e){return"vec3("+e[0]+", "+e[1]+", "+e[2]+")"}function jp(e,t){return e[0]===t[0]&&e[1]===t[1]&&e[2]===t[2]}function Qp(e,t){var r=e[0],n=e[1],i=e[2],s=t[0],o=t[1],a=t[2];return Math.abs(r-s)<=J*Math.max(1,Math.abs(r),Math.abs(s))&&Math.abs(n-o)<=J*Math.max(1,Math.abs(n),Math.abs(o))&&Math.abs(i-a)<=J*Math.max(1,Math.abs(i),Math.abs(a))}var Jp=c0,e1=d0,t1=u0,r1=f0,n1=h0,i1=l0,s1=m0,o1=(function(){var e=a0();return function(t,r,n,i,s,o){var a,d;for(r||(r=3),n||(n=0),i?d=Math.min(i*r+n,t.length):d=t.length,a=n;a<d;a+=r)e[0]=t[a],e[1]=t[a+1],e[2]=t[a+2],s(e,e,o),t[a]=e[0],t[a+1]=e[1],t[a+2]=e[2];return t}})();var Fo=class{constructor(){this._position=ce.create();this._angles=ce.create();this._bobAngles=ce.create();this._bobOffset=ce.create();this._kickAngles=ce.create();this._rollAngle=0;this._fov=90;this._aspect=1;this._near=.1;this._far=1e3;this._viewMatrix=de.create();this._projectionMatrix=de.create();this._viewProjectionMatrix=de.create();this._dirty=!0}get position(){return this._position}set position(t){ce.copy(this._position,t),this._dirty=!0}get angles(){return this._angles}set angles(t){ce.copy(this._angles,t),this._dirty=!0}get bobAngles(){return this._bobAngles}set bobAngles(t){ce.copy(this._bobAngles,t),this._dirty=!0}get kickAngles(){return this._kickAngles}set kickAngles(t){ce.copy(this._kickAngles,t),this._dirty=!0}get bobOffset(){return this._bobOffset}set bobOffset(t){ce.copy(this._bobOffset,t),this._dirty=!0}get rollAngle(){return this._rollAngle}set rollAngle(t){this._rollAngle=t,this._dirty=!0}get fov(){return this._fov}set fov(t){this._fov=t,this._dirty=!0}get aspect(){return this._aspect}set aspect(t){this._aspect=t,this._dirty=!0}get viewMatrix(){return this.updateMatrices(),this._viewMatrix}get projectionMatrix(){return this.updateMatrices(),this._projectionMatrix}get viewProjectionMatrix(){return this.updateMatrices(),this._viewProjectionMatrix}getViewmodelProjectionMatrix(t){let r=de.create();return de.perspective(r,t*Hr,this._aspect,this._near,this._far),r}updateMatrices(){if(!this._dirty)return;de.perspective(this._projectionMatrix,this._fov*Hr,this._aspect,this._near,this._far);let t=de.fromValues(0,-1,0,0,0,0,1,0,-1,0,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,s=r*Hr,o=n*Hr,a=i*Hr,d=de.create();de.identity(d),de.rotateZ(d,d,-o),de.rotateY(d,d,-s),de.rotateX(d,d,-a);let l=de.create();de.multiply(l,t,d);let c=ce.add(ce.create(),this._position,this._bobOffset),h=ce.negate(ce.create(),c),u=ce.create();ce.transformMat4(u,h,d);let f=ce.fromValues(u[1]||0,u[2]||0,u[0]||0);de.copy(this._viewMatrix,l),this._viewMatrix[12]=f[0],this._viewMatrix[13]=f[1],this._viewMatrix[14]=f[2],de.multiply(this._viewProjectionMatrix,this._projectionMatrix,this._viewMatrix),this._dirty=!1}};var a1=[.2,.2,.2],l1={x:0,y:0,z:1},c1=[.8,.8,.8];function El(e,t,r){return e+(t-e)*r}function Sn(e,t,r){return{x:El(e.x,t.x,r),y:El(e.y,t.y,r),z:El(e.z,t.z,r)}}function vn(e){return e<0?0:e>1?1:e}function Ll(e){let t=[],r=[];for(let n of e.triangles){let i=t.length,[s,o,a]=n.indices,d=e.texCoords[s],l=e.texCoords[o],c=e.texCoords[a];if(!d||!l||!c)throw new Error(`Missing texCoord for triangle in surface ${e.name}`);t.push({vertexIndex:s,texCoord:[d.s,1-d.t]},{vertexIndex:o,texCoord:[l.s,1-l.t]},{vertexIndex:a,texCoord:[c.s,1-c.t]}),r.push(i,i+1,i+2)}return{vertices:t,indices:new Uint16Array(r)}}function d1(e,t,r){let n=r?.ambient??a1,i=r?.directional??{direction:l1,color:c1},s=Je(e),o=Je(i.direction),a=vn(s.x*o.x+s.y*o.y+s.z*o.z),d=n[0]+i.color[0]*a,l=n[1]+i.color[1]*a,c=n[2]+i.color[2]*a;if(r?.dynamicLights){let h=r.modelMatrix?Ic(r.modelMatrix,t):t;for(let u of r.dynamicLights){let f=h.x-u.origin.x,m=h.y-u.origin.y,g=h.z-u.origin.z,p=f*f+m*m+g*g,y=u.radius*u.radius;if(p<y&&y>0){let S=1-Math.sqrt(p)/u.radius,_=Math.sqrt(p),x=_>0?vn(-(f*s.x+m*s.y+g*s.z)/_):0,b=vn(S*x);d+=u.color[0]*b,l+=u.color[1]*b,c+=u.color[2]*b}}}return[vn(d),vn(l),vn(c)]}function Tl(e,t,r,n){let i=e.vertices[r.frame0],s=e.vertices[r.frame1];if(!i||!s)throw new Error("Requested MD3 frames are out of range");let o=new Float32Array(t.vertices.length*12);return t.vertices.forEach((a,d)=>{let l=i[a.vertexIndex],c=s[a.vertexIndex];if(!l||!c)throw new Error(`Vertex index ${a.vertexIndex} missing for frame`);let h=Sn(l.position,c.position,r.lerp),u=Je(Sn(l.normal,c.normal,r.lerp)),f=d1(u,h,n),m=d*12;o[m]=h.x,o[m+1]=h.y,o[m+2]=h.z,o[m+3]=u.x,o[m+4]=u.y,o[m+5]=u.z,o[m+6]=a.texCoord[0],o[m+7]=a.texCoord[1],o[m+8]=f[0],o[m+9]=f[1],o[m+10]=f[2],o[m+11]=1}),o}function p0(e,t,r){let n=e.tags[0];if(!n)return null;let i=n.findIndex(g=>g.name===r);if(i===-1)return null;let s=e.tags[t.frame0]?.[i],o=e.tags[t.frame1]?.[i];if(!s||!o)throw new Error(`Tag ${r} is missing for one of the interpolated frames`);let a=Sn(s.origin,o.origin,t.lerp),d=Je(Sn(s.axis[0],o.axis[0],t.lerp)),l=Je(Sn(s.axis[1],o.axis[1],t.lerp)),c=Je(Sn(s.axis[2],o.axis[2],t.lerp)),h=d,u=Je({x:l.x-h.x*(h.x*l.x+h.y*l.y+h.z*l.z),y:l.y-h.y*(h.x*l.x+h.y*l.y+h.z*l.z),z:l.z-h.z*(h.x*l.x+h.y*l.y+h.z*l.z)}),f=Je({x:h.y*u.z-h.z*u.y,y:h.z*u.x-h.x*u.z,z:h.x*u.y-h.y*u.x}),m=[h,u,f];return{origin:a,axis:m,matrix:Rc(a,m)}}var Il=`#version 300 es
|
|
398
398
|
precision highp float;
|
|
399
399
|
|
|
400
400
|
layout(location = 0) in vec3 a_position;
|
|
@@ -449,7 +449,7 @@ void main() {
|
|
|
449
449
|
}
|
|
450
450
|
|
|
451
451
|
o_color = finalColor;
|
|
452
|
-
}`,Gi=class{constructor(t,r,n,i){this.gl=t,this.geometry=Ll(r),this.vertexBuffer=new Le(t,t.STATIC_DRAW),this.indexBuffer=new xe(t,t.STATIC_DRAW),this.vertexArray=new ze(t),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:t.FLOAT,stride:48,offset:0},{index:1,size:3,type:t.FLOAT,stride:48,offset:12},{index:2,size:2,type:t.FLOAT,stride:48,offset:24},{index:3,size:4,type:t.FLOAT,stride:48,offset:32}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,t.STATIC_DRAW),this.update(r,n,i)}update(t,r,n){let i=Tl(t,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()}},
|
|
452
|
+
}`,Gi=class{constructor(t,r,n,i){this.gl=t,this.geometry=Ll(r),this.vertexBuffer=new Le(t,t.STATIC_DRAW),this.indexBuffer=new xe(t,t.STATIC_DRAW),this.vertexArray=new ze(t),this.indexCount=this.geometry.indices.length,this.vertexArray.configureAttributes([{index:0,size:3,type:t.FLOAT,stride:48,offset:0},{index:1,size:3,type:t.FLOAT,stride:48,offset:12},{index:2,size:2,type:t.FLOAT,stride:48,offset:24},{index:3,size:4,type:t.FLOAT,stride:48,offset:32}],this.vertexBuffer),this.vertexArray.bind(),this.indexBuffer.bind(),this.indexBuffer.upload(this.geometry.indices,t.STATIC_DRAW),this.update(r,n,i)}update(t,r,n){let i=Tl(t,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()}},ko=class{constructor(t,r,n,i){this.surfaces=new Map;this.gl=t,this.model=r,this.blend=n,this.lighting=i,r.surfaces.forEach(s=>{this.surfaces.set(s.name,new Gi(t,s,n,i))})}update(t,r){this.blend=t,this.lighting=r??this.lighting;for(let n of this.model.surfaces)this.surfaces.get(n.name)?.update(n,t,this.lighting)}dispose(){for(let t of this.surfaces.values())t.dispose();this.surfaces.clear()}},Bo=class{constructor(t){this.gl=t,this.program=Ee.create(t,{vertex:Il,fragment:Rl},{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")}bind(t,r=[1,1,1,1],n=0){this.program.use(),this.gl.uniformMatrix4fv(this.uniformMvp,!1,t),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(t,r){let n=r?.diffuseSampler??0,i=r?.tint??[1,1,1,1],s=r?.renderMode;this.gl.uniform4fv(this.uniformTint,new Float32Array(i)),this.gl.uniform1i(this.uniformDiffuse,n);let o=0,a=[1,1,1,1];if(s&&(s.mode==="solid"||s.mode==="wireframe"?o=1:s.mode==="solid-faceted"&&(o=2),s.color&&(a=[...s.color])),this.gl.uniform1i(this.uniformRenderMode,o),this.gl.uniform4f(this.uniformSolidColor,a[0],a[1],a[2],a[3]),t.vertexArray.bind(),s&&s.mode==="wireframe"){if(!t.wireframeIndexBuffer){t.wireframeIndexBuffer=new xe(this.gl,this.gl.STATIC_DRAW);let d=bn(t.geometry.indices);t.wireframeIndexBuffer.upload(d),t.wireframeIndexCount=d.length}t.wireframeIndexBuffer.bind(),this.gl.drawElements(this.gl.LINES,t.wireframeIndexCount,this.gl.UNSIGNED_SHORT,0)}else t.indexBuffer.bind(),this.gl.drawElements(this.gl.TRIANGLES,t.indexCount,this.gl.UNSIGNED_SHORT,0)}dispose(){this.program.dispose()}};var u1=[1,1,1,1],Do=class{constructor(t,r=Math.random){this.maxParticles=t,this.random=r,this.alive=new Uint8Array(t),this.positionX=new Float32Array(t),this.positionY=new Float32Array(t),this.positionZ=new Float32Array(t),this.velocityX=new Float32Array(t),this.velocityY=new Float32Array(t),this.velocityZ=new Float32Array(t),this.colorR=new Float32Array(t),this.colorG=new Float32Array(t),this.colorB=new Float32Array(t),this.colorA=new Float32Array(t),this.size=new Float32Array(t),this.lifetime=new Float32Array(t),this.remaining=new Float32Array(t),this.gravity=new Float32Array(t),this.damping=new Float32Array(t),this.bounce=new Float32Array(t),this.fade=new Uint8Array(t),this.blendMode=new Uint8Array(t)}spawn(t){let r=this.findFreeSlot();if(r===-1)return null;let n=t.color??u1,i=t.velocity??{x:0,y:0,z:0};return this.alive[r]=1,this.positionX[r]=t.position.x,this.positionY[r]=t.position.y,this.positionZ[r]=t.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]=t.size??2.5,this.lifetime[r]=t.lifetime,this.remaining[r]=t.lifetime,this.gravity[r]=t.gravity??800,this.damping[r]=t.damping??0,this.bounce[r]=t.bounce??.25,this.fade[r]=t.fade?1:0,this.blendMode[r]=t.blendMode==="additive"?1:0,r}update(t,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]-=t,this.remaining[i]<=0){this.alive[i]=0;continue}let s=Math.max(0,1-this.damping[i]*t);this.velocityX[i]*=s,this.velocityY[i]*=s,this.velocityZ[i]=this.velocityZ[i]*s-this.gravity[i]*t,this.positionX[i]+=this.velocityX[i]*t,this.positionY[i]+=this.velocityY[i]*t,this.positionZ[i]+=this.velocityZ[i]*t,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 t=0;for(let r=0;r<this.maxParticles;r+=1)this.alive[r]&&(t+=1);return t}getState(t){return{alive:this.alive[t]===1,position:{x:this.positionX[t],y:this.positionY[t],z:this.positionZ[t]},velocity:{x:this.velocityX[t],y:this.velocityY[t],z:this.velocityZ[t]},remaining:this.remaining[t],color:[this.colorR[t],this.colorG[t],this.colorB[t],this.colorA[t]],size:this.size[t],blendMode:this.blendMode[t]===1?"additive":"alpha"}}buildMesh(t,r){let n=[],i=[],s=[],o=a=>{let d=i.length,l=0;for(let c=0;c<this.maxParticles;c+=1){if(!this.alive[c]||(a==="additive"?1:0)!==this.blendMode[c])continue;l+=1;let h=n.length/9,u=this.size[c]*.5,f=this.fade[c]?Math.max(this.remaining[c]/this.lifetime[c],0):1,m=this.blendMode[c]===1?1.2:1,g=this.colorR[c]*m,p=this.colorG[c]*m,y=this.colorB[c]*m,S=this.colorA[c]*f,_=this.positionX[c],x=this.positionY[c],b=this.positionZ[c],A=t.x*u,v=t.y*u,E=t.z*u,L=r.x*u,w=r.y*u,T=r.z*u,z=[{x:_-A-L,y:x-v-w,z:b-E-T},{x:_+A-L,y:x+v-w,z:b+E-T},{x:_-A+L,y:x-v+w,z:b-E+T},{x:_+A+L,y:x+v+w,z:b+E+T}],U=[[0,1],[1,1],[0,0],[1,0]];z.forEach((C,$)=>{n.push(C.x,C.y,C.z,U[$]?.[0]??0,U[$]?.[1]??0,g,p,y,S)}),i.push(h,h+1,h+2,h+2,h+1,h+3)}l>0&&s.push({blendMode:a,start:d,count:i.length-d})};return o("alpha"),o("additive"),{vertices:new Float32Array(n),indices:new Uint16Array(i),batches:s}}findFreeSlot(){for(let t=0;t<this.maxParticles;t+=1)if(!this.alive[t])return t;return-1}},Cl=`#version 300 es
|
|
453
453
|
precision highp float;
|
|
454
454
|
|
|
455
455
|
layout(location = 0) in vec3 a_position;
|
|
@@ -477,7 +477,7 @@ void main() {
|
|
|
477
477
|
float dist = distance(v_uv, vec2(0.5));
|
|
478
478
|
float alpha = v_color.a * (1.0 - smoothstep(0.35, 0.5, dist));
|
|
479
479
|
o_color = vec4(v_color.rgb, alpha);
|
|
480
|
-
}`,Ps=class{constructor(t,r){this.vertexCapacity=0;this.indexCapacity=0;this.gl=t,this.system=r,this.program=Ee.create(t,{vertex:Cl,fragment:zl}),this.vertexBuffer=new Le(t,t.DYNAMIC_DRAW),this.indexBuffer=new xe(t,t.DYNAMIC_DRAW),this.vertexArray=new ze(t),this.vertexArray.configureAttributes([{index:0,size:3,type:t.FLOAT,stride:36,offset:0},{index:1,size:2,type:t.FLOAT,stride:36,offset:12},{index:2,size:4,type:t.FLOAT,stride:36,offset:20}],this.vertexBuffer)}render(t){let r=this.system.buildMesh(t.viewRight,t.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,t.viewProjection),this.vertexArray.bind();for(let s of r.batches)s.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,s.count,this.gl.UNSIGNED_SHORT,s.start*2);this.gl.depthMask(!0)}dispose(){this.program.dispose(),this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose()}};function g0(e){let{system:t,origin:r,normal:n={x:0,y:0,z:1}}=e;for(let i=0;i<12;i+=1){let o=200+t.random()*180,s=t.random()*.35;t.spawn({position:r,velocity:{x:n.x*o+(t.random()-.5)*80,y:n.y*o+(t.random()-.5)*80,z:Math.max(n.z*o,120)+s*80},color:[1,.8,.4,1],size:2.5,lifetime:.45+t.random()*.1,gravity:600,damping:2,bounce:.45,blendMode:"additive",fade:!0})}for(let i=0;i<8;i+=1)t.spawn({position:r,velocity:{x:(t.random()-.5)*40,y:(t.random()-.5)*40,z:80+t.random()*40},color:[.45,.45,.45,.75],size:6,lifetime:.6,gravity:200,damping:4,bounce:.15,blendMode:"alpha",fade:!0})}function y0(e){let{system:t,origin:r}=e;for(let n=0;n<40;n+=1){let i=t.random()*Math.PI*2,o=Math.acos(2*t.random()-1),s=220+t.random()*260,a={x:Math.sin(o)*Math.cos(i),y:Math.sin(o)*Math.sin(i),z:Math.cos(o)};t.spawn({position:r,velocity:{x:a.x*s,y:a.y*s,z:a.z*s},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)t.spawn({position:r,velocity:{x:(t.random()-.5)*30,y:(t.random()-.5)*30,z:120+t.random()*120},color:[.25,.25,.25,.9],size:12,lifetime:1.2,gravity:300,damping:3,blendMode:"alpha",fade:!0})}function x0(e){let{system:t,origin:r,direction:n={x:0,y:0,z:1}}=e;for(let i=0;i<24;i+=1){let o=120+t.random()*180;t.spawn({position:r,velocity:{x:n.x*o+(t.random()-.5)*70,y:n.y*o+(t.random()-.5)*70,z:n.z*o+t.random()*80},color:[.6,0,0,.95],size:3,lifetime:.8,gravity:900,damping:1,bounce:.2,blendMode:"alpha",fade:!0})}}function _0(e){let{system:t,origin:r}=e;for(let n=0;n<30;n+=1){let i=t.random()*Math.PI*2,o=8+t.random()*8;t.spawn({position:r,velocity:{x:Math.cos(i)*o,y:Math.sin(i)*o,z:100+t.random()*80},color:[.4,.6,1,.9],size:4,lifetime:.5,gravity:300,damping:2,blendMode:"additive",fade:!0})}}function b0(e){let{system:t,origin:r,direction:n={x:1,y:0,z:0}}=e;for(let i=0;i<10;i+=1){let o=350+t.random()*100;t.spawn({position:r,velocity:{x:n.x*o+(t.random()-.5)*30,y:n.y*o+(t.random()-.5)*30,z:n.z*o+(t.random()-.5)*30},color:[1,.8,.3,1],size:3,lifetime:.25,gravity:200,damping:1,blendMode:"additive",fade:!0})}}function v0(e){let{system:t,origin:r,direction:n={x:0,y:0,z:0}}=e;for(let i=0;i<6;i+=1)t.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:(t.random()-.5)*15,y:(t.random()-.5)*15,z:20+t.random()*15},color:[.6,.6,.6,.8],size:2.2,lifetime:.6,gravity:200,damping:1.5,blendMode:"alpha",fade:!0})}var Lr=class{constructor(t){this.buffer=t,this.view=new DataView(t),this.offset=0}hasMore(){return this.offset<this.buffer.byteLength}readNextBlock(){if(this.offset+4>this.buffer.byteLength)return null;let t=this.view.getInt32(this.offset,!0);if(this.offset+=4,t<0||t>2097152)return console.warn(`DemoReader: Invalid block length ${t} at offset ${this.offset-4}`),null;if(this.offset+t>this.buffer.byteLength)return console.warn(`DemoReader: Incomplete block. Expected ${t} bytes, but only ${this.buffer.byteLength-this.offset} remain.`),null;let r=this.buffer.slice(this.offset,this.offset+t);return this.offset+=t,{length:t,data:new Dn(r)}}reset(){this.offset=0}getOffset(){return this.offset}};function Tn(e){let t=e.length;for(;--t>=0;)e[t]=0}var f1=0,su=1,h1=2,m1=3,p1=258,rc=29,io=256,qi=io+1+rc,Mn=30,nc=19,au=2*qi+1,Tr=15,Fl=16,g1=7,ic=256,lu=16,cu=17,du=18,$l=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]),Gs=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]),y1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),uu=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),x1=512,Ct=new Array((qi+2)*2);Tn(Ct);var $i=new Array(Mn*2);Tn($i);var ji=new Array(x1);Tn(ji);var Qi=new Array(p1-m1+1);Tn(Qi);var oc=new Array(rc);Tn(oc);var Ws=new Array(Mn);Tn(Ws);function kl(e,t,r,n,i){this.static_tree=e,this.extra_bits=t,this.extra_base=r,this.elems=n,this.max_length=i,this.has_stree=e&&e.length}var fu,hu,mu;function Bl(e,t){this.dyn_tree=e,this.max_code=0,this.stat_desc=t}var pu=e=>e<256?ji[e]:ji[256+(e>>>7)],Ji=(e,t)=>{e.pending_buf[e.pending++]=t&255,e.pending_buf[e.pending++]=t>>>8&255},Fe=(e,t,r)=>{e.bi_valid>Fl-r?(e.bi_buf|=t<<e.bi_valid&65535,Ji(e,e.bi_buf),e.bi_buf=t>>Fl-e.bi_valid,e.bi_valid+=r-Fl):(e.bi_buf|=t<<e.bi_valid&65535,e.bi_valid+=r)},mt=(e,t,r)=>{Fe(e,r[t*2],r[t*2+1])},gu=(e,t)=>{let r=0;do r|=e&1,e>>>=1,r<<=1;while(--t>0);return r>>>1},_1=e=>{e.bi_valid===16?(Ji(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):e.bi_valid>=8&&(e.pending_buf[e.pending++]=e.bi_buf&255,e.bi_buf>>=8,e.bi_valid-=8)},b1=(e,t)=>{let r=t.dyn_tree,n=t.max_code,i=t.stat_desc.static_tree,o=t.stat_desc.has_stree,s=t.stat_desc.extra_bits,a=t.stat_desc.extra_base,d=t.stat_desc.max_length,l,c,h,u,f,m,g=0;for(u=0;u<=Tr;u++)e.bl_count[u]=0;for(r[e.heap[e.heap_max]*2+1]=0,l=e.heap_max+1;l<au;l++)c=e.heap[l],u=r[r[c*2+1]*2+1]+1,u>d&&(u=d,g++),r[c*2+1]=u,!(c>n)&&(e.bl_count[u]++,f=0,c>=a&&(f=s[c-a]),m=r[c*2],e.opt_len+=m*(u+f),o&&(e.static_len+=m*(i[c*2+1]+f)));if(g!==0){do{for(u=d-1;e.bl_count[u]===0;)u--;e.bl_count[u]--,e.bl_count[u+1]+=2,e.bl_count[d]--,g-=2}while(g>0);for(u=d;u!==0;u--)for(c=e.bl_count[u];c!==0;)h=e.heap[--l],!(h>n)&&(r[h*2+1]!==u&&(e.opt_len+=(u-r[h*2+1])*r[h*2],r[h*2+1]=u),c--)}},yu=(e,t,r)=>{let n=new Array(Tr+1),i=0,o,s;for(o=1;o<=Tr;o++)i=i+r[o-1]<<1,n[o]=i;for(s=0;s<=t;s++){let a=e[s*2+1];a!==0&&(e[s*2]=gu(n[a]++,a))}},v1=()=>{let e,t,r,n,i,o=new Array(Tr+1);for(r=0,n=0;n<rc-1;n++)for(oc[n]=r,e=0;e<1<<$l[n];e++)Qi[r++]=n;for(Qi[r-1]=n,i=0,n=0;n<16;n++)for(Ws[n]=i,e=0;e<1<<Gs[n];e++)ji[i++]=n;for(i>>=7;n<Mn;n++)for(Ws[n]=i<<7,e=0;e<1<<Gs[n]-7;e++)ji[256+i++]=n;for(t=0;t<=Tr;t++)o[t]=0;for(e=0;e<=143;)Ct[e*2+1]=8,e++,o[8]++;for(;e<=255;)Ct[e*2+1]=9,e++,o[9]++;for(;e<=279;)Ct[e*2+1]=7,e++,o[7]++;for(;e<=287;)Ct[e*2+1]=8,e++,o[8]++;for(yu(Ct,qi+1,o),e=0;e<Mn;e++)$i[e*2+1]=5,$i[e*2]=gu(e,5);fu=new kl(Ct,$l,io+1,qi,Tr),hu=new kl($i,Gs,0,Mn,Tr),mu=new kl(new Array(0),y1,0,nc,g1)},xu=e=>{let t;for(t=0;t<qi;t++)e.dyn_ltree[t*2]=0;for(t=0;t<Mn;t++)e.dyn_dtree[t*2]=0;for(t=0;t<nc;t++)e.bl_tree[t*2]=0;e.dyn_ltree[ic*2]=1,e.opt_len=e.static_len=0,e.sym_next=e.matches=0},_u=e=>{e.bi_valid>8?Ji(e,e.bi_buf):e.bi_valid>0&&(e.pending_buf[e.pending++]=e.bi_buf),e.bi_buf=0,e.bi_valid=0},S0=(e,t,r,n)=>{let i=t*2,o=r*2;return e[i]<e[o]||e[i]===e[o]&&n[t]<=n[r]},Dl=(e,t,r)=>{let n=e.heap[r],i=r<<1;for(;i<=e.heap_len&&(i<e.heap_len&&S0(t,e.heap[i+1],e.heap[i],e.depth)&&i++,!S0(t,n,e.heap[i],e.depth));)e.heap[r]=e.heap[i],r=i,i<<=1;e.heap[r]=n},w0=(e,t,r)=>{let n,i,o=0,s,a;if(e.sym_next!==0)do n=e.pending_buf[e.sym_buf+o++]&255,n+=(e.pending_buf[e.sym_buf+o++]&255)<<8,i=e.pending_buf[e.sym_buf+o++],n===0?mt(e,i,t):(s=Qi[i],mt(e,s+io+1,t),a=$l[s],a!==0&&(i-=oc[s],Fe(e,i,a)),n--,s=pu(n),mt(e,s,r),a=Gs[s],a!==0&&(n-=Ws[s],Fe(e,n,a)));while(o<e.sym_next);mt(e,ic,t)},Zl=(e,t)=>{let r=t.dyn_tree,n=t.stat_desc.static_tree,i=t.stat_desc.has_stree,o=t.stat_desc.elems,s,a,d=-1,l;for(e.heap_len=0,e.heap_max=au,s=0;s<o;s++)r[s*2]!==0?(e.heap[++e.heap_len]=d=s,e.depth[s]=0):r[s*2+1]=0;for(;e.heap_len<2;)l=e.heap[++e.heap_len]=d<2?++d:0,r[l*2]=1,e.depth[l]=0,e.opt_len--,i&&(e.static_len-=n[l*2+1]);for(t.max_code=d,s=e.heap_len>>1;s>=1;s--)Dl(e,r,s);l=o;do s=e.heap[1],e.heap[1]=e.heap[e.heap_len--],Dl(e,r,1),a=e.heap[1],e.heap[--e.heap_max]=s,e.heap[--e.heap_max]=a,r[l*2]=r[s*2]+r[a*2],e.depth[l]=(e.depth[s]>=e.depth[a]?e.depth[s]:e.depth[a])+1,r[s*2+1]=r[a*2+1]=l,e.heap[1]=l++,Dl(e,r,1);while(e.heap_len>=2);e.heap[--e.heap_max]=e.heap[1],b1(e,t),yu(r,d,e.bl_count)},A0=(e,t,r)=>{let n,i=-1,o,s=t[1],a=0,d=7,l=4;for(s===0&&(d=138,l=3),t[(r+1)*2+1]=65535,n=0;n<=r;n++)o=s,s=t[(n+1)*2+1],!(++a<d&&o===s)&&(a<l?e.bl_tree[o*2]+=a:o!==0?(o!==i&&e.bl_tree[o*2]++,e.bl_tree[lu*2]++):a<=10?e.bl_tree[cu*2]++:e.bl_tree[du*2]++,a=0,i=o,s===0?(d=138,l=3):o===s?(d=6,l=3):(d=7,l=4))},M0=(e,t,r)=>{let n,i=-1,o,s=t[1],a=0,d=7,l=4;for(s===0&&(d=138,l=3),n=0;n<=r;n++)if(o=s,s=t[(n+1)*2+1],!(++a<d&&o===s)){if(a<l)do mt(e,o,e.bl_tree);while(--a!==0);else o!==0?(o!==i&&(mt(e,o,e.bl_tree),a--),mt(e,lu,e.bl_tree),Fe(e,a-3,2)):a<=10?(mt(e,cu,e.bl_tree),Fe(e,a-3,3)):(mt(e,du,e.bl_tree),Fe(e,a-11,7));a=0,i=o,s===0?(d=138,l=3):o===s?(d=6,l=3):(d=7,l=4)}},S1=e=>{let t;for(A0(e,e.dyn_ltree,e.l_desc.max_code),A0(e,e.dyn_dtree,e.d_desc.max_code),Zl(e,e.bl_desc),t=nc-1;t>=3&&e.bl_tree[uu[t]*2+1]===0;t--);return e.opt_len+=3*(t+1)+5+5+4,t},w1=(e,t,r,n)=>{let i;for(Fe(e,t-257,5),Fe(e,r-1,5),Fe(e,n-4,4),i=0;i<n;i++)Fe(e,e.bl_tree[uu[i]*2+1],3);M0(e,e.dyn_ltree,t-1),M0(e,e.dyn_dtree,r-1)},A1=e=>{let t=4093624447,r;for(r=0;r<=31;r++,t>>>=1)if(t&1&&e.dyn_ltree[r*2]!==0)return 0;if(e.dyn_ltree[18]!==0||e.dyn_ltree[20]!==0||e.dyn_ltree[26]!==0)return 1;for(r=32;r<io;r++)if(e.dyn_ltree[r*2]!==0)return 1;return 0},E0=!1,M1=e=>{E0||(v1(),E0=!0),e.l_desc=new Bl(e.dyn_ltree,fu),e.d_desc=new Bl(e.dyn_dtree,hu),e.bl_desc=new Bl(e.bl_tree,mu),e.bi_buf=0,e.bi_valid=0,xu(e)},bu=(e,t,r,n)=>{Fe(e,(f1<<1)+(n?1:0),3),_u(e),Ji(e,r),Ji(e,~r),r&&e.pending_buf.set(e.window.subarray(t,t+r),e.pending),e.pending+=r},E1=e=>{Fe(e,su<<1,3),mt(e,ic,Ct),_1(e)},L1=(e,t,r,n)=>{let i,o,s=0;e.level>0?(e.strm.data_type===2&&(e.strm.data_type=A1(e)),Zl(e,e.l_desc),Zl(e,e.d_desc),s=S1(e),i=e.opt_len+3+7>>>3,o=e.static_len+3+7>>>3,o<=i&&(i=o)):i=o=r+5,r+4<=i&&t!==-1?bu(e,t,r,n):e.strategy===4||o===i?(Fe(e,(su<<1)+(n?1:0),3),w0(e,Ct,$i)):(Fe(e,(h1<<1)+(n?1:0),3),w1(e,e.l_desc.max_code+1,e.d_desc.max_code+1,s+1),w0(e,e.dyn_ltree,e.dyn_dtree)),xu(e),n&&_u(e)},T1=(e,t,r)=>(e.pending_buf[e.sym_buf+e.sym_next++]=t,e.pending_buf[e.sym_buf+e.sym_next++]=t>>8,e.pending_buf[e.sym_buf+e.sym_next++]=r,t===0?e.dyn_ltree[r*2]++:(e.matches++,t--,e.dyn_ltree[(Qi[r]+io+1)*2]++,e.dyn_dtree[pu(t)*2]++),e.sym_next===e.sym_end),I1=M1,R1=bu,C1=L1,z1=T1,F1=E1,k1={_tr_init:I1,_tr_stored_block:R1,_tr_flush_block:C1,_tr_tally:z1,_tr_align:F1},B1=(e,t,r,n)=>{let i=e&65535|0,o=e>>>16&65535|0,s=0;for(;r!==0;){s=r>2e3?2e3:r,r-=s;do i=i+t[n++]|0,o=o+i|0;while(--s);i%=65521,o%=65521}return i|o<<16|0},eo=B1,D1=()=>{let e,t=[];for(var r=0;r<256;r++){e=r;for(var n=0;n<8;n++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e}return t},P1=new Uint32Array(D1()),O1=(e,t,r,n)=>{let i=P1,o=n+r;e^=-1;for(let s=n;s<o;s++)e=e>>>8^i[(e^t[s])&255];return e^-1},fe=O1,Cr={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"},kr={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:N1,_tr_stored_block:Yl,_tr_flush_block:U1,_tr_tally:or,_tr_align:H1}=k1,{Z_NO_FLUSH:sr,Z_PARTIAL_FLUSH:V1,Z_FULL_FLUSH:G1,Z_FINISH:je,Z_BLOCK:L0,Z_OK:he,Z_STREAM_END:T0,Z_STREAM_ERROR:pt,Z_DATA_ERROR:W1,Z_BUF_ERROR:Pl,Z_DEFAULT_COMPRESSION:X1,Z_FILTERED:K1,Z_HUFFMAN_ONLY:Os,Z_RLE:$1,Z_FIXED:Z1,Z_DEFAULT_STRATEGY:Y1,Z_UNKNOWN:q1,Z_DEFLATED:$s}=kr,j1=9,Q1=15,J1=8,eg=29,tg=256,ql=tg+1+eg,rg=30,ng=19,ig=2*ql+1,og=15,V=3,ir=258,gt=ir+V+1,sg=32,En=42,sc=57,jl=69,Ql=73,Jl=91,ec=103,Ir=113,Xi=666,Te=1,In=2,zr=3,Rn=4,ag=3,Rr=(e,t)=>(e.msg=Cr[t],t),I0=e=>e*2-(e>4?9:0),nr=e=>{let t=e.length;for(;--t>=0;)e[t]=0},lg=e=>{let t,r,n,i=e.w_size;t=e.hash_size,n=t;do r=e.head[--n],e.head[n]=r>=i?r-i:0;while(--t);t=i,n=t;do r=e.prev[--n],e.prev[n]=r>=i?r-i:0;while(--t)},cg=(e,t,r)=>(t<<e.hash_shift^r)&e.hash_mask,ar=cg,Ne=e=>{let t=e.state,r=t.pending;r>e.avail_out&&(r=e.avail_out),r!==0&&(e.output.set(t.pending_buf.subarray(t.pending_out,t.pending_out+r),e.next_out),e.next_out+=r,t.pending_out+=r,e.total_out+=r,e.avail_out-=r,t.pending-=r,t.pending===0&&(t.pending_out=0))},Ue=(e,t)=>{U1(e,e.block_start>=0?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,Ne(e.strm)},X=(e,t)=>{e.pending_buf[e.pending++]=t},Wi=(e,t)=>{e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=t&255},tc=(e,t,r,n)=>{let i=e.avail_in;return i>n&&(i=n),i===0?0:(e.avail_in-=i,t.set(e.input.subarray(e.next_in,e.next_in+i),r),e.state.wrap===1?e.adler=eo(e.adler,t,i,r):e.state.wrap===2&&(e.adler=fe(e.adler,t,i,r)),e.next_in+=i,e.total_in+=i,i)},vu=(e,t)=>{let r=e.max_chain_length,n=e.strstart,i,o,s=e.prev_length,a=e.nice_match,d=e.strstart>e.w_size-gt?e.strstart-(e.w_size-gt):0,l=e.window,c=e.w_mask,h=e.prev,u=e.strstart+ir,f=l[n+s-1],m=l[n+s];e.prev_length>=e.good_match&&(r>>=2),a>e.lookahead&&(a=e.lookahead);do if(i=t,!(l[i+s]!==m||l[i+s-1]!==f||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=ir-(u-n),n=u-ir,o>s){if(e.match_start=t,s=o,o>=a)break;f=l[n+s-1],m=l[n+s]}}while((t=h[t&c])>d&&--r!==0);return s<=e.lookahead?s:e.lookahead},Ln=e=>{let t=e.w_size,r,n,i;do{if(n=e.window_size-e.lookahead-e.strstart,e.strstart>=t+(t-gt)&&(e.window.set(e.window.subarray(t,t+t-n),0),e.match_start-=t,e.strstart-=t,e.block_start-=t,e.insert>e.strstart&&(e.insert=e.strstart),lg(e),n+=t),e.strm.avail_in===0)break;if(r=tc(e.strm,e.window,e.strstart+e.lookahead,n),e.lookahead+=r,e.lookahead+e.insert>=V)for(i=e.strstart-e.insert,e.ins_h=e.window[i],e.ins_h=ar(e,e.ins_h,e.window[i+1]);e.insert&&(e.ins_h=ar(e,e.ins_h,e.window[i+V-1]),e.prev[i&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=i,i++,e.insert--,!(e.lookahead+e.insert<V)););}while(e.lookahead<gt&&e.strm.avail_in!==0)},Su=(e,t)=>{let r=e.pending_buf_size-5>e.w_size?e.w_size:e.pending_buf_size-5,n,i,o,s=0,a=e.strm.avail_in;do{if(n=65535,o=e.bi_valid+42>>3,e.strm.avail_out<o||(o=e.strm.avail_out-o,i=e.strstart-e.block_start,n>i+e.strm.avail_in&&(n=i+e.strm.avail_in),n>o&&(n=o),n<r&&(n===0&&t!==je||t===sr||n!==i+e.strm.avail_in)))break;s=t===je&&n===i+e.strm.avail_in?1:0,Yl(e,0,0,s),e.pending_buf[e.pending-4]=n,e.pending_buf[e.pending-3]=n>>8,e.pending_buf[e.pending-2]=~n,e.pending_buf[e.pending-1]=~n>>8,Ne(e.strm),i&&(i>n&&(i=n),e.strm.output.set(e.window.subarray(e.block_start,e.block_start+i),e.strm.next_out),e.strm.next_out+=i,e.strm.avail_out-=i,e.strm.total_out+=i,e.block_start+=i,n-=i),n&&(tc(e.strm,e.strm.output,e.strm.next_out,n),e.strm.next_out+=n,e.strm.avail_out-=n,e.strm.total_out+=n)}while(s===0);return a-=e.strm.avail_in,a&&(a>=e.w_size?(e.matches=2,e.window.set(e.strm.input.subarray(e.strm.next_in-e.w_size,e.strm.next_in),0),e.strstart=e.w_size,e.insert=e.strstart):(e.window_size-e.strstart<=a&&(e.strstart-=e.w_size,e.window.set(e.window.subarray(e.w_size,e.w_size+e.strstart),0),e.matches<2&&e.matches++,e.insert>e.strstart&&(e.insert=e.strstart)),e.window.set(e.strm.input.subarray(e.strm.next_in-a,e.strm.next_in),e.strstart),e.strstart+=a,e.insert+=a>e.w_size-e.insert?e.w_size-e.insert:a),e.block_start=e.strstart),e.high_water<e.strstart&&(e.high_water=e.strstart),s?Rn:t!==sr&&t!==je&&e.strm.avail_in===0&&e.strstart===e.block_start?In:(o=e.window_size-e.strstart,e.strm.avail_in>o&&e.block_start>=e.w_size&&(e.block_start-=e.w_size,e.strstart-=e.w_size,e.window.set(e.window.subarray(e.w_size,e.w_size+e.strstart),0),e.matches<2&&e.matches++,o+=e.w_size,e.insert>e.strstart&&(e.insert=e.strstart)),o>e.strm.avail_in&&(o=e.strm.avail_in),o&&(tc(e.strm,e.window,e.strstart,o),e.strstart+=o,e.insert+=o>e.w_size-e.insert?e.w_size-e.insert:o),e.high_water<e.strstart&&(e.high_water=e.strstart),o=e.bi_valid+42>>3,o=e.pending_buf_size-o>65535?65535:e.pending_buf_size-o,r=o>e.w_size?e.w_size:o,i=e.strstart-e.block_start,(i>=r||(i||t===je)&&t!==sr&&e.strm.avail_in===0&&i<=o)&&(n=i>o?o:i,s=t===je&&e.strm.avail_in===0&&n===i?1:0,Yl(e,e.block_start,n,s),e.block_start+=n,Ne(e.strm)),s?zr:Te)},Ol=(e,t)=>{let r,n;for(;;){if(e.lookahead<gt){if(Ln(e),e.lookahead<gt&&t===sr)return Te;if(e.lookahead===0)break}if(r=0,e.lookahead>=V&&(e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart),r!==0&&e.strstart-r<=e.w_size-gt&&(e.match_length=vu(e,r)),e.match_length>=V)if(n=or(e,e.strstart-e.match_start,e.match_length-V),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=V){e.match_length--;do e.strstart++,e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart;while(--e.match_length!==0);e.strstart++}else e.strstart+=e.match_length,e.match_length=0,e.ins_h=e.window[e.strstart],e.ins_h=ar(e,e.ins_h,e.window[e.strstart+1]);else n=or(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++;if(n&&(Ue(e,!1),e.strm.avail_out===0))return Te}return e.insert=e.strstart<V-1?e.strstart:V-1,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In},wn=(e,t)=>{let r,n,i;for(;;){if(e.lookahead<gt){if(Ln(e),e.lookahead<gt&&t===sr)return Te;if(e.lookahead===0)break}if(r=0,e.lookahead>=V&&(e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart),e.prev_length=e.match_length,e.prev_match=e.match_start,e.match_length=V-1,r!==0&&e.prev_length<e.max_lazy_match&&e.strstart-r<=e.w_size-gt&&(e.match_length=vu(e,r),e.match_length<=5&&(e.strategy===K1||e.match_length===V&&e.strstart-e.match_start>4096)&&(e.match_length=V-1)),e.prev_length>=V&&e.match_length<=e.prev_length){i=e.strstart+e.lookahead-V,n=or(e,e.strstart-1-e.prev_match,e.prev_length-V),e.lookahead-=e.prev_length-1,e.prev_length-=2;do++e.strstart<=i&&(e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart);while(--e.prev_length!==0);if(e.match_available=0,e.match_length=V-1,e.strstart++,n&&(Ue(e,!1),e.strm.avail_out===0))return Te}else if(e.match_available){if(n=or(e,0,e.window[e.strstart-1]),n&&Ue(e,!1),e.strstart++,e.lookahead--,e.strm.avail_out===0)return Te}else e.match_available=1,e.strstart++,e.lookahead--}return e.match_available&&(n=or(e,0,e.window[e.strstart-1]),e.match_available=0),e.insert=e.strstart<V-1?e.strstart:V-1,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In},dg=(e,t)=>{let r,n,i,o,s=e.window;for(;;){if(e.lookahead<=ir){if(Ln(e),e.lookahead<=ir&&t===sr)return Te;if(e.lookahead===0)break}if(e.match_length=0,e.lookahead>=V&&e.strstart>0&&(i=e.strstart-1,n=s[i],n===s[++i]&&n===s[++i]&&n===s[++i])){o=e.strstart+ir;do;while(n===s[++i]&&n===s[++i]&&n===s[++i]&&n===s[++i]&&n===s[++i]&&n===s[++i]&&n===s[++i]&&n===s[++i]&&i<o);e.match_length=ir-(o-i),e.match_length>e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=V?(r=or(e,1,e.match_length-V),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(r=or(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),r&&(Ue(e,!1),e.strm.avail_out===0))return Te}return e.insert=0,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In},ug=(e,t)=>{let r;for(;;){if(e.lookahead===0&&(Ln(e),e.lookahead===0)){if(t===sr)return Te;break}if(e.match_length=0,r=or(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,r&&(Ue(e,!1),e.strm.avail_out===0))return Te}return e.insert=0,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In};function ht(e,t,r,n,i){this.good_length=e,this.max_lazy=t,this.nice_length=r,this.max_chain=n,this.func=i}var Ki=[new ht(0,0,0,0,Su),new ht(4,4,8,4,Ol),new ht(4,5,16,8,Ol),new ht(4,6,32,32,Ol),new ht(4,4,16,16,wn),new ht(8,16,32,32,wn),new ht(8,16,128,128,wn),new ht(8,32,128,256,wn),new ht(32,128,258,1024,wn),new ht(32,258,258,4096,wn)],fg=e=>{e.window_size=2*e.w_size,nr(e.head),e.max_lazy_match=Ki[e.level].max_lazy,e.good_match=Ki[e.level].good_length,e.nice_match=Ki[e.level].nice_length,e.max_chain_length=Ki[e.level].max_chain,e.strstart=0,e.block_start=0,e.lookahead=0,e.insert=0,e.match_length=e.prev_length=V-1,e.match_available=0,e.ins_h=0};function hg(){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=$s,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(ig*2),this.dyn_dtree=new Uint16Array((2*rg+1)*2),this.bl_tree=new Uint16Array((2*ng+1)*2),nr(this.dyn_ltree),nr(this.dyn_dtree),nr(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(og+1),this.heap=new Uint16Array(2*ql+1),nr(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(2*ql+1),nr(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 oo=e=>{if(!e)return 1;let t=e.state;return!t||t.strm!==e||t.status!==En&&t.status!==sc&&t.status!==jl&&t.status!==Ql&&t.status!==Jl&&t.status!==ec&&t.status!==Ir&&t.status!==Xi?1:0},wu=e=>{if(oo(e))return Rr(e,pt);e.total_in=e.total_out=0,e.data_type=q1;let t=e.state;return t.pending=0,t.pending_out=0,t.wrap<0&&(t.wrap=-t.wrap),t.status=t.wrap===2?sc:t.wrap?En:Ir,e.adler=t.wrap===2?0:1,t.last_flush=-2,N1(t),he},Au=e=>{let t=wu(e);return t===he&&fg(e.state),t},mg=(e,t)=>oo(e)||e.state.wrap!==2?pt:(e.state.gzhead=t,he),Mu=(e,t,r,n,i,o)=>{if(!e)return pt;let s=1;if(t===X1&&(t=6),n<0?(s=0,n=-n):n>15&&(s=2,n-=16),i<1||i>j1||r!==$s||n<8||n>15||t<0||t>9||o<0||o>Z1||n===8&&s!==1)return Rr(e,pt);n===8&&(n=9);let a=new hg;return e.state=a,a.strm=e,a.status=En,a.wrap=s,a.gzhead=null,a.w_bits=n,a.w_size=1<<a.w_bits,a.w_mask=a.w_size-1,a.hash_bits=i+7,a.hash_size=1<<a.hash_bits,a.hash_mask=a.hash_size-1,a.hash_shift=~~((a.hash_bits+V-1)/V),a.window=new Uint8Array(a.w_size*2),a.head=new Uint16Array(a.hash_size),a.prev=new Uint16Array(a.w_size),a.lit_bufsize=1<<i+6,a.pending_buf_size=a.lit_bufsize*4,a.pending_buf=new Uint8Array(a.pending_buf_size),a.sym_buf=a.lit_bufsize,a.sym_end=(a.lit_bufsize-1)*3,a.level=t,a.strategy=o,a.method=r,Au(e)},pg=(e,t)=>Mu(e,t,$s,Q1,J1,Y1),gg=(e,t)=>{if(oo(e)||t>L0||t<0)return e?Rr(e,pt):pt;let r=e.state;if(!e.output||e.avail_in!==0&&!e.input||r.status===Xi&&t!==je)return Rr(e,e.avail_out===0?Pl:pt);let n=r.last_flush;if(r.last_flush=t,r.pending!==0){if(Ne(e),e.avail_out===0)return r.last_flush=-1,he}else if(e.avail_in===0&&I0(t)<=I0(n)&&t!==je)return Rr(e,Pl);if(r.status===Xi&&e.avail_in!==0)return Rr(e,Pl);if(r.status===En&&r.wrap===0&&(r.status=Ir),r.status===En){let i=$s+(r.w_bits-8<<4)<<8,o=-1;if(r.strategy>=Os||r.level<2?o=0:r.level<6?o=1:r.level===6?o=2:o=3,i|=o<<6,r.strstart!==0&&(i|=sg),i+=31-i%31,Wi(r,i),r.strstart!==0&&(Wi(r,e.adler>>>16),Wi(r,e.adler&65535)),e.adler=1,r.status=Ir,Ne(e),r.pending!==0)return r.last_flush=-1,he}if(r.status===sc){if(e.adler=0,X(r,31),X(r,139),X(r,8),r.gzhead)X(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)),X(r,r.gzhead.time&255),X(r,r.gzhead.time>>8&255),X(r,r.gzhead.time>>16&255),X(r,r.gzhead.time>>24&255),X(r,r.level===9?2:r.strategy>=Os||r.level<2?4:0),X(r,r.gzhead.os&255),r.gzhead.extra&&r.gzhead.extra.length&&(X(r,r.gzhead.extra.length&255),X(r,r.gzhead.extra.length>>8&255)),r.gzhead.hcrc&&(e.adler=fe(e.adler,r.pending_buf,r.pending,0)),r.gzindex=0,r.status=jl;else if(X(r,0),X(r,0),X(r,0),X(r,0),X(r,0),X(r,r.level===9?2:r.strategy>=Os||r.level<2?4:0),X(r,ag),r.status=Ir,Ne(e),r.pending!==0)return r.last_flush=-1,he}if(r.status===jl){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 a=r.pending_buf_size-r.pending;if(r.pending_buf.set(r.gzhead.extra.subarray(r.gzindex,r.gzindex+a),r.pending),r.pending=r.pending_buf_size,r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),r.gzindex+=a,Ne(e),r.pending!==0)return r.last_flush=-1,he;i=0,o-=a}let s=new Uint8Array(r.gzhead.extra);r.pending_buf.set(s.subarray(r.gzindex,r.gzindex+o),r.pending),r.pending+=o,r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Ql}if(r.status===Ql){if(r.gzhead.name){let i=r.pending,o;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),Ne(e),r.pending!==0)return r.last_flush=-1,he;i=0}r.gzindex<r.gzhead.name.length?o=r.gzhead.name.charCodeAt(r.gzindex++)&255:o=0,X(r,o)}while(o!==0);r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Jl}if(r.status===Jl){if(r.gzhead.comment){let i=r.pending,o;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),Ne(e),r.pending!==0)return r.last_flush=-1,he;i=0}r.gzindex<r.gzhead.comment.length?o=r.gzhead.comment.charCodeAt(r.gzindex++)&255:o=0,X(r,o)}while(o!==0);r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i))}r.status=ec}if(r.status===ec){if(r.gzhead.hcrc){if(r.pending+2>r.pending_buf_size&&(Ne(e),r.pending!==0))return r.last_flush=-1,he;X(r,e.adler&255),X(r,e.adler>>8&255),e.adler=0}if(r.status=Ir,Ne(e),r.pending!==0)return r.last_flush=-1,he}if(e.avail_in!==0||r.lookahead!==0||t!==sr&&r.status!==Xi){let i=r.level===0?Su(r,t):r.strategy===Os?ug(r,t):r.strategy===$1?dg(r,t):Ki[r.level].func(r,t);if((i===zr||i===Rn)&&(r.status=Xi),i===Te||i===zr)return e.avail_out===0&&(r.last_flush=-1),he;if(i===In&&(t===V1?H1(r):t!==L0&&(Yl(r,0,0,!1),t===G1&&(nr(r.head),r.lookahead===0&&(r.strstart=0,r.block_start=0,r.insert=0))),Ne(e),e.avail_out===0))return r.last_flush=-1,he}return t!==je?he:r.wrap<=0?T0:(r.wrap===2?(X(r,e.adler&255),X(r,e.adler>>8&255),X(r,e.adler>>16&255),X(r,e.adler>>24&255),X(r,e.total_in&255),X(r,e.total_in>>8&255),X(r,e.total_in>>16&255),X(r,e.total_in>>24&255)):(Wi(r,e.adler>>>16),Wi(r,e.adler&65535)),Ne(e),r.wrap>0&&(r.wrap=-r.wrap),r.pending!==0?he:T0)},yg=e=>{if(oo(e))return pt;let t=e.state.status;return e.state=null,t===Ir?Rr(e,W1):he},xg=(e,t)=>{let r=t.length;if(oo(e))return pt;let n=e.state,i=n.wrap;if(i===2||i===1&&n.status!==En||n.lookahead)return pt;if(i===1&&(e.adler=eo(e.adler,t,r,0)),n.wrap=0,r>=n.w_size){i===0&&(nr(n.head),n.strstart=0,n.block_start=0,n.insert=0);let d=new Uint8Array(n.w_size);d.set(t.subarray(r-n.w_size,r),0),t=d,r=n.w_size}let o=e.avail_in,s=e.next_in,a=e.input;for(e.avail_in=r,e.next_in=0,e.input=t,Ln(n);n.lookahead>=V;){let d=n.strstart,l=n.lookahead-(V-1);do n.ins_h=ar(n,n.ins_h,n.window[d+V-1]),n.prev[d&n.w_mask]=n.head[n.ins_h],n.head[n.ins_h]=d,d++;while(--l);n.strstart=d,n.lookahead=V-1,Ln(n)}return n.strstart+=n.lookahead,n.block_start=n.strstart,n.insert=n.lookahead,n.lookahead=0,n.match_length=n.prev_length=V-1,n.match_available=0,e.next_in=s,e.input=a,e.avail_in=o,n.wrap=i,he},_g=pg,bg=Mu,vg=Au,Sg=wu,wg=mg,Ag=gg,Mg=yg,Eg=xg,Lg="pako deflate (from Nodeca project)",Zi={deflateInit:_g,deflateInit2:bg,deflateReset:vg,deflateResetKeep:Sg,deflateSetHeader:wg,deflate:Ag,deflateEnd:Mg,deflateSetDictionary:Eg,deflateInfo:Lg},Tg=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Ig=function(e){let t=Array.prototype.slice.call(arguments,1);for(;t.length;){let r=t.shift();if(r){if(typeof r!="object")throw new TypeError(r+"must be non-object");for(let n in r)Tg(r,n)&&(e[n]=r[n])}}return e},Rg=e=>{let t=0;for(let n=0,i=e.length;n<i;n++)t+=e[n].length;let r=new Uint8Array(t);for(let n=0,i=0,o=e.length;n<o;n++){let s=e[n];r.set(s,i),i+=s.length}return r},Zs={assign:Ig,flattenChunks:Rg},Eu=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{Eu=!1}var to=new Uint8Array(256);for(let e=0;e<256;e++)to[e]=e>=252?6:e>=248?5:e>=240?4:e>=224?3:e>=192?2:1;to[254]=to[254]=1;var Cg=e=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(e);let t,r,n,i,o,s=e.length,a=0;for(i=0;i<s;i++)r=e.charCodeAt(i),(r&64512)===55296&&i+1<s&&(n=e.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),a+=r<128?1:r<2048?2:r<65536?3:4;for(t=new Uint8Array(a),o=0,i=0;o<a;i++)r=e.charCodeAt(i),(r&64512)===55296&&i+1<s&&(n=e.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),r<128?t[o++]=r:r<2048?(t[o++]=192|r>>>6,t[o++]=128|r&63):r<65536?(t[o++]=224|r>>>12,t[o++]=128|r>>>6&63,t[o++]=128|r&63):(t[o++]=240|r>>>18,t[o++]=128|r>>>12&63,t[o++]=128|r>>>6&63,t[o++]=128|r&63);return t},zg=(e,t)=>{if(t<65534&&e.subarray&&Eu)return String.fromCharCode.apply(null,e.length===t?e:e.subarray(0,t));let r="";for(let n=0;n<t;n++)r+=String.fromCharCode(e[n]);return r},Fg=(e,t)=>{let r=t||e.length;if(typeof TextDecoder=="function"&&TextDecoder.prototype.decode)return new TextDecoder().decode(e.subarray(0,t));let n,i,o=new Array(r*2);for(i=0,n=0;n<r;){let s=e[n++];if(s<128){o[i++]=s;continue}let a=to[s];if(a>4){o[i++]=65533,n+=a-1;continue}for(s&=a===2?31:a===3?15:7;a>1&&n<r;)s=s<<6|e[n++]&63,a--;if(a>1){o[i++]=65533;continue}s<65536?o[i++]=s:(s-=65536,o[i++]=55296|s>>10&1023,o[i++]=56320|s&1023)}return zg(o,i)},kg=(e,t)=>{t=t||e.length,t>e.length&&(t=e.length);let r=t-1;for(;r>=0&&(e[r]&192)===128;)r--;return r<0||r===0?t:r+to[e[r]]>t?r:t},ro={string2buf:Cg,buf2string:Fg,utf8border:kg};function Bg(){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 Lu=Bg,Tu=Object.prototype.toString,{Z_NO_FLUSH:Dg,Z_SYNC_FLUSH:Pg,Z_FULL_FLUSH:Og,Z_FINISH:Ng,Z_OK:Xs,Z_STREAM_END:Ug,Z_DEFAULT_COMPRESSION:Hg,Z_DEFAULT_STRATEGY:Vg,Z_DEFLATED:Gg}=kr;function so(e){this.options=Zs.assign({level:Hg,method:Gg,chunkSize:16384,windowBits:15,memLevel:8,strategy:Vg},e||{});let t=this.options;t.raw&&t.windowBits>0?t.windowBits=-t.windowBits:t.gzip&&t.windowBits>0&&t.windowBits<16&&(t.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new Lu,this.strm.avail_out=0;let r=Zi.deflateInit2(this.strm,t.level,t.method,t.windowBits,t.memLevel,t.strategy);if(r!==Xs)throw new Error(Cr[r]);if(t.header&&Zi.deflateSetHeader(this.strm,t.header),t.dictionary){let n;if(typeof t.dictionary=="string"?n=ro.string2buf(t.dictionary):Tu.call(t.dictionary)==="[object ArrayBuffer]"?n=new Uint8Array(t.dictionary):n=t.dictionary,r=Zi.deflateSetDictionary(this.strm,n),r!==Xs)throw new Error(Cr[r]);this._dict_set=!0}}so.prototype.push=function(e,t){let r=this.strm,n=this.options.chunkSize,i,o;if(this.ended)return!1;for(t===~~t?o=t:o=t===!0?Ng:Dg,typeof e=="string"?r.input=ro.string2buf(e):Tu.call(e)==="[object ArrayBuffer]"?r.input=new Uint8Array(e):r.input=e,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===Pg||o===Og)&&r.avail_out<=6){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(i=Zi.deflate(r,o),i===Ug)return r.next_out>0&&this.onData(r.output.subarray(0,r.next_out)),i=Zi.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===Xs;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};so.prototype.onData=function(e){this.chunks.push(e)};so.prototype.onEnd=function(e){e===Xs&&(this.result=Zs.flattenChunks(this.chunks)),this.chunks=[],this.err=e,this.msg=this.strm.msg};function ac(e,t){let r=new so(t);if(r.push(e,!0),r.err)throw r.msg||Cr[r.err];return r.result}function Wg(e,t){return t=t||{},t.raw=!0,ac(e,t)}function Xg(e,t){return t=t||{},t.gzip=!0,ac(e,t)}var Kg=so,$g=ac,Zg=Wg,Yg=Xg,qg=kr,jg={Deflate:Kg,deflate:$g,deflateRaw:Zg,gzip:Yg,constants:qg},Ns=16209,Qg=16191,Jg=function(t,r){let n,i,o,s,a,d,l,c,h,u,f,m,g,p,y,S,_,x,b,A,v,E,L,w,T=t.state;n=t.next_in,L=t.input,i=n+(t.avail_in-5),o=t.next_out,w=t.output,s=o-(r-t.avail_out),a=o+(t.avail_out-257),d=T.dmax,l=T.wsize,c=T.whave,h=T.wnext,u=T.window,f=T.hold,m=T.bits,g=T.lencode,p=T.distcode,y=(1<<T.lenbits)-1,S=(1<<T.distbits)-1;e:do{m<15&&(f+=L[n++]<<m,m+=8,f+=L[n++]<<m,m+=8),_=g[f&y];t:for(;;){if(x=_>>>24,f>>>=x,m-=x,x=_>>>16&255,x===0)w[o++]=_&65535;else if(x&16){b=_&65535,x&=15,x&&(m<x&&(f+=L[n++]<<m,m+=8),b+=f&(1<<x)-1,f>>>=x,m-=x),m<15&&(f+=L[n++]<<m,m+=8,f+=L[n++]<<m,m+=8),_=p[f&S];r:for(;;){if(x=_>>>24,f>>>=x,m-=x,x=_>>>16&255,x&16){if(A=_&65535,x&=15,m<x&&(f+=L[n++]<<m,m+=8,m<x&&(f+=L[n++]<<m,m+=8)),A+=f&(1<<x)-1,A>d){t.msg="invalid distance too far back",T.mode=Ns;break e}if(f>>>=x,m-=x,x=o-s,A>x){if(x=A-x,x>c&&T.sane){t.msg="invalid distance too far back",T.mode=Ns;break e}if(v=0,E=u,h===0){if(v+=l-x,x<b){b-=x;do w[o++]=u[v++];while(--x);v=o-A,E=w}}else if(h<x){if(v+=l+h-x,x-=h,x<b){b-=x;do w[o++]=u[v++];while(--x);if(v=0,h<b){x=h,b-=x;do w[o++]=u[v++];while(--x);v=o-A,E=w}}}else if(v+=h-x,x<b){b-=x;do w[o++]=u[v++];while(--x);v=o-A,E=w}for(;b>2;)w[o++]=E[v++],w[o++]=E[v++],w[o++]=E[v++],b-=3;b&&(w[o++]=E[v++],b>1&&(w[o++]=E[v++]))}else{v=o-A;do w[o++]=w[v++],w[o++]=w[v++],w[o++]=w[v++],b-=3;while(b>2);b&&(w[o++]=w[v++],b>1&&(w[o++]=w[v++]))}}else if((x&64)===0){_=p[(_&65535)+(f&(1<<x)-1)];continue r}else{t.msg="invalid distance code",T.mode=Ns;break e}break}}else if((x&64)===0){_=g[(_&65535)+(f&(1<<x)-1)];continue t}else if(x&32){T.mode=Qg;break e}else{t.msg="invalid literal/length code",T.mode=Ns;break e}break}}while(n<i&&o<a);b=m>>3,n-=b,m-=b<<3,f&=(1<<m)-1,t.next_in=n,t.next_out=o,t.avail_in=n<i?5+(i-n):5-(n-i),t.avail_out=o<a?257+(a-o):257-(o-a),T.hold=f,T.bits=m},An=15,R0=852,C0=592,z0=0,Nl=1,F0=2,ey=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]),ty=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]),ry=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]),ny=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]),iy=(e,t,r,n,i,o,s,a)=>{let d=a.bits,l=0,c=0,h=0,u=0,f=0,m=0,g=0,p=0,y=0,S=0,_,x,b,A,v,E=null,L,w=new Uint16Array(An+1),T=new Uint16Array(An+1),z=null,U,C,$;for(l=0;l<=An;l++)w[l]=0;for(c=0;c<n;c++)w[t[r+c]]++;for(f=d,u=An;u>=1&&w[u]===0;u--);if(f>u&&(f=u),u===0)return i[o++]=1<<24|64<<16|0,i[o++]=1<<24|64<<16|0,a.bits=1,0;for(h=1;h<u&&w[h]===0;h++);for(f<h&&(f=h),p=1,l=1;l<=An;l++)if(p<<=1,p-=w[l],p<0)return-1;if(p>0&&(e===z0||u!==1))return-1;for(T[1]=0,l=1;l<An;l++)T[l+1]=T[l]+w[l];for(c=0;c<n;c++)t[r+c]!==0&&(s[T[t[r+c]]++]=c);if(e===z0?(E=z=s,L=20):e===Nl?(E=ey,z=ty,L=257):(E=ry,z=ny,L=0),S=0,c=0,l=h,v=o,m=f,g=0,b=-1,y=1<<f,A=y-1,e===Nl&&y>R0||e===F0&&y>C0)return 1;for(;;){U=l-g,s[c]+1<L?(C=0,$=s[c]):s[c]>=L?(C=z[s[c]-L],$=E[s[c]-L]):(C=96,$=0),_=1<<l-g,x=1<<m,h=x;do x-=_,i[v+(S>>g)+x]=U<<24|C<<16|$|0;while(x!==0);for(_=1<<l-1;S&_;)_>>=1;if(_!==0?(S&=_-1,S+=_):S=0,c++,--w[l]===0){if(l===u)break;l=t[r+s[c]]}if(l>f&&(S&A)!==b){for(g===0&&(g=f),v+=h,m=l-g,p=1<<m;m+g<u&&(p-=w[m+g],!(p<=0));)m++,p<<=1;if(y+=1<<m,e===Nl&&y>R0||e===F0&&y>C0)return 1;b=S&A,i[b]=f<<24|m<<16|v-o|0}}return S!==0&&(i[v+S]=l-g<<24|64<<16|0),a.bits=f,0},Yi=iy,oy=0,Iu=1,Ru=2,{Z_FINISH:k0,Z_BLOCK:sy,Z_TREES:Us,Z_OK:Fr,Z_STREAM_END:ay,Z_NEED_DICT:ly,Z_STREAM_ERROR:Qe,Z_DATA_ERROR:Cu,Z_MEM_ERROR:zu,Z_BUF_ERROR:cy,Z_DEFLATED:B0}=kr,Ys=16180,D0=16181,P0=16182,O0=16183,N0=16184,U0=16185,H0=16186,V0=16187,G0=16188,W0=16189,Ks=16190,Rt=16191,Ul=16192,X0=16193,Hl=16194,K0=16195,$0=16196,Z0=16197,Y0=16198,Hs=16199,Vs=16200,q0=16201,j0=16202,Q0=16203,J0=16204,eu=16205,Vl=16206,tu=16207,ru=16208,ne=16209,Fu=16210,ku=16211,dy=852,uy=592,fy=15,hy=fy,nu=e=>(e>>>24&255)+(e>>>8&65280)+((e&65280)<<8)+((e&255)<<24);function my(){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 Br=e=>{if(!e)return 1;let t=e.state;return!t||t.strm!==e||t.mode<Ys||t.mode>ku?1:0},Bu=e=>{if(Br(e))return Qe;let t=e.state;return e.total_in=e.total_out=t.total=0,e.msg="",t.wrap&&(e.adler=t.wrap&1),t.mode=Ys,t.last=0,t.havedict=0,t.flags=-1,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new Int32Array(dy),t.distcode=t.distdyn=new Int32Array(uy),t.sane=1,t.back=-1,Fr},Du=e=>{if(Br(e))return Qe;let t=e.state;return t.wsize=0,t.whave=0,t.wnext=0,Bu(e)},Pu=(e,t)=>{let r;if(Br(e))return Qe;let n=e.state;return t<0?(r=0,t=-t):(r=(t>>4)+5,t<48&&(t&=15)),t&&(t<8||t>15)?Qe:(n.window!==null&&n.wbits!==t&&(n.window=null),n.wrap=r,n.wbits=t,Du(e))},Ou=(e,t)=>{if(!e)return Qe;let r=new my;e.state=r,r.strm=e,r.window=null,r.mode=Ys;let n=Pu(e,t);return n!==Fr&&(e.state=null),n},py=e=>Ou(e,hy),iu=!0,Gl,Wl,gy=e=>{if(iu){Gl=new Int32Array(512),Wl=new Int32Array(32);let t=0;for(;t<144;)e.lens[t++]=8;for(;t<256;)e.lens[t++]=9;for(;t<280;)e.lens[t++]=7;for(;t<288;)e.lens[t++]=8;for(Yi(Iu,e.lens,0,288,Gl,0,e.work,{bits:9}),t=0;t<32;)e.lens[t++]=5;Yi(Ru,e.lens,0,32,Wl,0,e.work,{bits:5}),iu=!1}e.lencode=Gl,e.lenbits=9,e.distcode=Wl,e.distbits=5},Nu=(e,t,r,n)=>{let i,o=e.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(t.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(t.subarray(r-n,r-n+i),o.wnext),n-=i,n?(o.window.set(t.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},yy=(e,t)=>{let r,n,i,o,s,a,d,l,c,h,u,f,m,g,p=0,y,S,_,x,b,A,v,E,L=new Uint8Array(4),w,T,z=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Br(e)||!e.output||!e.input&&e.avail_in!==0)return Qe;r=e.state,r.mode===Rt&&(r.mode=Ul),s=e.next_out,i=e.output,d=e.avail_out,o=e.next_in,n=e.input,a=e.avail_in,l=r.hold,c=r.bits,h=a,u=d,E=Fr;e:for(;;)switch(r.mode){case Ys:if(r.wrap===0){r.mode=Ul;break}for(;c<16;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(r.wrap&2&&l===35615){r.wbits===0&&(r.wbits=15),r.check=0,L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0),l=0,c=0,r.mode=D0;break}if(r.head&&(r.head.done=!1),!(r.wrap&1)||(((l&255)<<8)+(l>>8))%31){e.msg="incorrect header check",r.mode=ne;break}if((l&15)!==B0){e.msg="unknown compression method",r.mode=ne;break}if(l>>>=4,c-=4,v=(l&15)+8,r.wbits===0&&(r.wbits=v),v>15||v>r.wbits){e.msg="invalid window size",r.mode=ne;break}r.dmax=1<<r.wbits,r.flags=0,e.adler=r.check=1,r.mode=l&512?W0:Rt,l=0,c=0;break;case D0:for(;c<16;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(r.flags=l,(r.flags&255)!==B0){e.msg="unknown compression method",r.mode=ne;break}if(r.flags&57344){e.msg="unknown header flags set",r.mode=ne;break}r.head&&(r.head.text=l>>8&1),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0)),l=0,c=0,r.mode=P0;case P0:for(;c<32;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}r.head&&(r.head.time=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,L[2]=l>>>16&255,L[3]=l>>>24&255,r.check=fe(r.check,L,4,0)),l=0,c=0,r.mode=O0;case O0:for(;c<16;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}r.head&&(r.head.xflags=l&255,r.head.os=l>>8),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0)),l=0,c=0,r.mode=N0;case N0:if(r.flags&1024){for(;c<16;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}r.length=l,r.head&&(r.head.extra_len=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0)),l=0,c=0}else r.head&&(r.head.extra=null);r.mode=U0;case U0:if(r.flags&1024&&(f=r.length,f>a&&(f=a),f&&(r.head&&(v=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+f),v)),r.flags&512&&r.wrap&4&&(r.check=fe(r.check,n,f,o)),a-=f,o+=f,r.length-=f),r.length))break e;r.length=0,r.mode=H0;case H0:if(r.flags&2048){if(a===0)break e;f=0;do v=n[o+f++],r.head&&v&&r.length<65536&&(r.head.name+=String.fromCharCode(v));while(v&&f<a);if(r.flags&512&&r.wrap&4&&(r.check=fe(r.check,n,f,o)),a-=f,o+=f,v)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=V0;case V0:if(r.flags&4096){if(a===0)break e;f=0;do v=n[o+f++],r.head&&v&&r.length<65536&&(r.head.comment+=String.fromCharCode(v));while(v&&f<a);if(r.flags&512&&r.wrap&4&&(r.check=fe(r.check,n,f,o)),a-=f,o+=f,v)break e}else r.head&&(r.head.comment=null);r.mode=G0;case G0:if(r.flags&512){for(;c<16;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(r.wrap&4&&l!==(r.check&65535)){e.msg="header crc mismatch",r.mode=ne;break}l=0,c=0}r.head&&(r.head.hcrc=r.flags>>9&1,r.head.done=!0),e.adler=r.check=0,r.mode=Rt;break;case W0:for(;c<32;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}e.adler=r.check=nu(l),l=0,c=0,r.mode=Ks;case Ks:if(r.havedict===0)return e.next_out=s,e.avail_out=d,e.next_in=o,e.avail_in=a,r.hold=l,r.bits=c,ly;e.adler=r.check=1,r.mode=Rt;case Rt:if(t===sy||t===Us)break e;case Ul:if(r.last){l>>>=c&7,c-=c&7,r.mode=Vl;break}for(;c<3;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}switch(r.last=l&1,l>>>=1,c-=1,l&3){case 0:r.mode=X0;break;case 1:if(gy(r),r.mode=Hs,t===Us){l>>>=2,c-=2;break e}break;case 2:r.mode=$0;break;case 3:e.msg="invalid block type",r.mode=ne}l>>>=2,c-=2;break;case X0:for(l>>>=c&7,c-=c&7;c<32;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if((l&65535)!==(l>>>16^65535)){e.msg="invalid stored block lengths",r.mode=ne;break}if(r.length=l&65535,l=0,c=0,r.mode=Hl,t===Us)break e;case Hl:r.mode=K0;case K0:if(f=r.length,f){if(f>a&&(f=a),f>d&&(f=d),f===0)break e;i.set(n.subarray(o,o+f),s),a-=f,o+=f,d-=f,s+=f,r.length-=f;break}r.mode=Rt;break;case $0:for(;c<14;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(r.nlen=(l&31)+257,l>>>=5,c-=5,r.ndist=(l&31)+1,l>>>=5,c-=5,r.ncode=(l&15)+4,l>>>=4,c-=4,r.nlen>286||r.ndist>30){e.msg="too many length or distance symbols",r.mode=ne;break}r.have=0,r.mode=Z0;case Z0:for(;r.have<r.ncode;){for(;c<3;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}r.lens[z[r.have++]]=l&7,l>>>=3,c-=3}for(;r.have<19;)r.lens[z[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,w={bits:r.lenbits},E=Yi(oy,r.lens,0,19,r.lencode,0,r.work,w),r.lenbits=w.bits,E){e.msg="invalid code lengths set",r.mode=ne;break}r.have=0,r.mode=Y0;case Y0:for(;r.have<r.nlen+r.ndist;){for(;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,S=p>>>16&255,_=p&65535,!(y<=c);){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(_<16)l>>>=y,c-=y,r.lens[r.have++]=_;else{if(_===16){for(T=y+2;c<T;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(l>>>=y,c-=y,r.have===0){e.msg="invalid bit length repeat",r.mode=ne;break}v=r.lens[r.have-1],f=3+(l&3),l>>>=2,c-=2}else if(_===17){for(T=y+3;c<T;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}l>>>=y,c-=y,v=0,f=3+(l&7),l>>>=3,c-=3}else{for(T=y+7;c<T;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}l>>>=y,c-=y,v=0,f=11+(l&127),l>>>=7,c-=7}if(r.have+f>r.nlen+r.ndist){e.msg="invalid bit length repeat",r.mode=ne;break}for(;f--;)r.lens[r.have++]=v}}if(r.mode===ne)break;if(r.lens[256]===0){e.msg="invalid code -- missing end-of-block",r.mode=ne;break}if(r.lenbits=9,w={bits:r.lenbits},E=Yi(Iu,r.lens,0,r.nlen,r.lencode,0,r.work,w),r.lenbits=w.bits,E){e.msg="invalid literal/lengths set",r.mode=ne;break}if(r.distbits=6,r.distcode=r.distdyn,w={bits:r.distbits},E=Yi(Ru,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,w),r.distbits=w.bits,E){e.msg="invalid distances set",r.mode=ne;break}if(r.mode=Hs,t===Us)break e;case Hs:r.mode=Vs;case Vs:if(a>=6&&d>=258){e.next_out=s,e.avail_out=d,e.next_in=o,e.avail_in=a,r.hold=l,r.bits=c,Jg(e,u),s=e.next_out,i=e.output,d=e.avail_out,o=e.next_in,n=e.input,a=e.avail_in,l=r.hold,c=r.bits,r.mode===Rt&&(r.back=-1);break}for(r.back=0;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,S=p>>>16&255,_=p&65535,!(y<=c);){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(S&&(S&240)===0){for(x=y,b=S,A=_;p=r.lencode[A+((l&(1<<x+b)-1)>>x)],y=p>>>24,S=p>>>16&255,_=p&65535,!(x+y<=c);){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}l>>>=x,c-=x,r.back+=x}if(l>>>=y,c-=y,r.back+=y,r.length=_,S===0){r.mode=eu;break}if(S&32){r.back=-1,r.mode=Rt;break}if(S&64){e.msg="invalid literal/length code",r.mode=ne;break}r.extra=S&15,r.mode=q0;case q0:if(r.extra){for(T=r.extra;c<T;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}r.length+=l&(1<<r.extra)-1,l>>>=r.extra,c-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=j0;case j0:for(;p=r.distcode[l&(1<<r.distbits)-1],y=p>>>24,S=p>>>16&255,_=p&65535,!(y<=c);){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if((S&240)===0){for(x=y,b=S,A=_;p=r.distcode[A+((l&(1<<x+b)-1)>>x)],y=p>>>24,S=p>>>16&255,_=p&65535,!(x+y<=c);){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}l>>>=x,c-=x,r.back+=x}if(l>>>=y,c-=y,r.back+=y,S&64){e.msg="invalid distance code",r.mode=ne;break}r.offset=_,r.extra=S&15,r.mode=Q0;case Q0:if(r.extra){for(T=r.extra;c<T;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}r.offset+=l&(1<<r.extra)-1,l>>>=r.extra,c-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){e.msg="invalid distance too far back",r.mode=ne;break}r.mode=J0;case J0:if(d===0)break e;if(f=u-d,r.offset>f){if(f=r.offset-f,f>r.whave&&r.sane){e.msg="invalid distance too far back",r.mode=ne;break}f>r.wnext?(f-=r.wnext,m=r.wsize-f):m=r.wnext-f,f>r.length&&(f=r.length),g=r.window}else g=i,m=s-r.offset,f=r.length;f>d&&(f=d),d-=f,r.length-=f;do i[s++]=g[m++];while(--f);r.length===0&&(r.mode=Vs);break;case eu:if(d===0)break e;i[s++]=r.length,d--,r.mode=Vs;break;case Vl:if(r.wrap){for(;c<32;){if(a===0)break e;a--,l|=n[o++]<<c,c+=8}if(u-=d,e.total_out+=u,r.total+=u,r.wrap&4&&u&&(e.adler=r.check=r.flags?fe(r.check,i,u,s-u):eo(r.check,i,u,s-u)),u=d,r.wrap&4&&(r.flags?l:nu(l))!==r.check){e.msg="incorrect data check",r.mode=ne;break}l=0,c=0}r.mode=tu;case tu:if(r.wrap&&r.flags){for(;c<32;){if(a===0)break e;a--,l+=n[o++]<<c,c+=8}if(r.wrap&4&&l!==(r.total&4294967295)){e.msg="incorrect length check",r.mode=ne;break}l=0,c=0}r.mode=ru;case ru:E=ay;break e;case ne:E=Cu;break e;case Fu:return zu;case ku:default:return Qe}return e.next_out=s,e.avail_out=d,e.next_in=o,e.avail_in=a,r.hold=l,r.bits=c,(r.wsize||u!==e.avail_out&&r.mode<ne&&(r.mode<Vl||t!==k0))&&Nu(e,e.output,e.next_out,u-e.avail_out),h-=e.avail_in,u-=e.avail_out,e.total_in+=h,e.total_out+=u,r.total+=u,r.wrap&4&&u&&(e.adler=r.check=r.flags?fe(r.check,i,u,e.next_out-u):eo(r.check,i,u,e.next_out-u)),e.data_type=r.bits+(r.last?64:0)+(r.mode===Rt?128:0)+(r.mode===Hs||r.mode===Hl?256:0),(h===0&&u===0||t===k0)&&E===Fr&&(E=cy),E},xy=e=>{if(Br(e))return Qe;let t=e.state;return t.window&&(t.window=null),e.state=null,Fr},_y=(e,t)=>{if(Br(e))return Qe;let r=e.state;return(r.wrap&2)===0?Qe:(r.head=t,t.done=!1,Fr)},by=(e,t)=>{let r=t.length,n,i,o;return Br(e)||(n=e.state,n.wrap!==0&&n.mode!==Ks)?Qe:n.mode===Ks&&(i=1,i=eo(i,t,r,0),i!==n.check)?Cu:(o=Nu(e,t,r,r),o?(n.mode=Fu,zu):(n.havedict=1,Fr))},vy=Du,Sy=Pu,wy=Bu,Ay=py,My=Ou,Ey=yy,Ly=xy,Ty=_y,Iy=by,Ry="pako inflate (from Nodeca project)",zt={inflateReset:vy,inflateReset2:Sy,inflateResetKeep:wy,inflateInit:Ay,inflateInit2:My,inflate:Ey,inflateEnd:Ly,inflateGetHeader:Ty,inflateSetDictionary:Iy,inflateInfo:Ry};function Cy(){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 zy=Cy,Uu=Object.prototype.toString,{Z_NO_FLUSH:Fy,Z_FINISH:ky,Z_OK:no,Z_STREAM_END:Xl,Z_NEED_DICT:Kl,Z_STREAM_ERROR:By,Z_DATA_ERROR:ou,Z_MEM_ERROR:Dy}=kr;function ao(e){this.options=Zs.assign({chunkSize:1024*64,windowBits:15,to:""},e||{});let t=this.options;t.raw&&t.windowBits>=0&&t.windowBits<16&&(t.windowBits=-t.windowBits,t.windowBits===0&&(t.windowBits=-15)),t.windowBits>=0&&t.windowBits<16&&!(e&&e.windowBits)&&(t.windowBits+=32),t.windowBits>15&&t.windowBits<48&&(t.windowBits&15)===0&&(t.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new Lu,this.strm.avail_out=0;let r=zt.inflateInit2(this.strm,t.windowBits);if(r!==no)throw new Error(Cr[r]);if(this.header=new zy,zt.inflateGetHeader(this.strm,this.header),t.dictionary&&(typeof t.dictionary=="string"?t.dictionary=ro.string2buf(t.dictionary):Uu.call(t.dictionary)==="[object ArrayBuffer]"&&(t.dictionary=new Uint8Array(t.dictionary)),t.raw&&(r=zt.inflateSetDictionary(this.strm,t.dictionary),r!==no)))throw new Error(Cr[r])}ao.prototype.push=function(e,t){let r=this.strm,n=this.options.chunkSize,i=this.options.dictionary,o,s,a;if(this.ended)return!1;for(t===~~t?s=t:s=t===!0?ky:Fy,Uu.call(e)==="[object ArrayBuffer]"?r.input=new Uint8Array(e):r.input=e,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=zt.inflate(r,s),o===Kl&&i&&(o=zt.inflateSetDictionary(r,i),o===no?o=zt.inflate(r,s):o===ou&&(o=Kl));r.avail_in>0&&o===Xl&&r.state.wrap>0&&e[r.next_in]!==0;)zt.inflateReset(r),o=zt.inflate(r,s);switch(o){case By:case ou:case Kl:case Dy:return this.onEnd(o),this.ended=!0,!1}if(a=r.avail_out,r.next_out&&(r.avail_out===0||o===Xl))if(this.options.to==="string"){let d=ro.utf8border(r.output,r.next_out),l=r.next_out-d,c=ro.buf2string(r.output,d);r.next_out=l,r.avail_out=n-l,l&&r.output.set(r.output.subarray(d,d+l),0),this.onData(c)}else this.onData(r.output.length===r.next_out?r.output:r.output.subarray(0,r.next_out));if(!(o===no&&a===0)){if(o===Xl)return o=zt.inflateEnd(this.strm),this.onEnd(o),this.ended=!0,!0;if(r.avail_in===0)break}}return!0};ao.prototype.onData=function(e){this.chunks.push(e)};ao.prototype.onEnd=function(e){e===no&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=Zs.flattenChunks(this.chunks)),this.chunks=[],this.err=e,this.msg=this.strm.msg};function lc(e,t){let r=new ao(t);if(r.push(e),r.err)throw r.msg||Cr[r.err];return r.result}function Py(e,t){return t=t||{},t.raw=!0,lc(e,t)}var Oy=ao,Ny=lc,Uy=Py,Hy=lc,Vy=kr,Gy={Inflate:Oy,inflate:Ny,inflateRaw:Uy,ungzip:Hy,constants:Vy},{Deflate:Wy,deflate:Xy,deflateRaw:Ky,gzip:$y}=jg,{Inflate:Zy,inflate:Yy,inflateRaw:qy,ungzip:jy}=Gy,Qy=Wy,Jy=Xy,ex=Ky,tx=$y,rx=Zy,nx=Yy,ix=qy,ox=jy,sx=kr,cc={Deflate:Qy,deflate:Jy,deflateRaw:ex,gzip:tx,Inflate:rx,inflate:nx,inflateRaw:ix,ungzip:ox,constants:sx};var qs=2023,Qs=1,Js=2,ea=4,ta=8,ra=16,na=32,dc=64,ax=128,lx=256,ia=512,oa=1024,sa=2048,lo=4096,uc=8192,co=16384,cx=32768,uo=65536,aa=1<<17,fo=1<<18,ho=1<<19,la=1<<20,ca=1<<21,da=1<<22,dx=1<<23,ua=1<<24,mo=1<<25,fa=1<<26,ha=1<<27,fc=1<<28,hc=1<<29,mc=1<<30,ux=-2147483648,pc=1,gc=2,yc=4;var fx=1,hx=2,mx=128,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}),js=()=>({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}),Pr=class e{constructor(t,r){this.protocolVersion=0;this.isDemo=fx;this.stream=t,this.handler=r}setProtocolVersion(t){this.protocolVersion=t}getProtocolVersion(){return this.protocolVersion}translateCommand(t){if(this.protocolVersion===0){if(t===7)return F.serverdata;if(t===12)return F.serverdata}return this.protocolVersion===qs?t:this.protocolVersion===34||this.protocolVersion===25?t<=F.frame?t:t===22?F.playerinfo:t===23?F.packetentities:F.bad:(this.protocolVersion===0,t)}parseMessage(){for(;this.stream.hasMore();){let t=this.stream.readByte();if(t===-1)break;let r=t;t=this.translateCommand(t);try{switch(t){case F.bad:return;case F.nop:break;case F.disconnect:this.handler&&this.handler.onDisconnect&&this.handler.onDisconnect();break;case F.reconnect:this.handler&&this.handler.onReconnect&&this.handler.onReconnect();break;case F.print:this.parsePrint();break;case F.serverdata:this.parseServerData();break;case F.configstring:this.parseConfigString();break;case F.spawnbaseline:this.parseSpawnBaseline();break;case F.centerprint:this.parseCenterPrint();break;case F.download:this.parseDownload();break;case F.frame:this.parseFrame();break;case F.packetentities:this.parsePacketEntities(!1);break;case F.deltapacketentities:this.parsePacketEntities(!0);break;case F.playerinfo:this.parsePlayerState();break;case F.stufftext:this.parseStuffText();break;case F.layout:this.parseLayout();break;case F.inventory:this.parseInventory();break;case F.sound:this.parseSound();break;case F.muzzleflash:this.parseMuzzleFlash();break;case F.muzzleflash2:this.parseMuzzleFlash2();break;case F.temp_entity:this.parseTempEntity();break;case F.splitclient:this.parseSplitClient();break;case F.configblast:this.parseConfigBlast();break;case F.spawnbaselineblast:this.parseSpawnBaselineBlast();break;case F.level_restart:this.handler&&this.handler.onLevelRestart&&this.handler.onLevelRestart();break;case F.damage:this.parseDamage();break;case F.locprint:this.parseLocPrint();break;case F.fog:this.parseFog();break;case F.waitingforplayers:this.parseWaitingForPlayers();break;case F.bot_chat:this.parseBotChat();break;case F.poi:this.parsePoi();break;case F.help_path:this.parseHelpPath();break;case F.muzzleflash3:this.parseMuzzleFlash3();break;case F.achievement:this.parseAchievement();break;default:console.warn(`Unknown server command: ${r} (translated: ${t}) at offset ${this.stream.getPosition()-1}`);return}}catch(n){console.warn(`Error parsing command ${t}: ${n.message}`);return}}}parsePrint(){let t=this.stream.readByte(),r=this.stream.readString();this.handler&&this.handler.onPrint(t,r)}parseStuffText(){let t=this.stream.readString();this.handler&&this.handler.onStuffText(t)}parseLayout(){let t=this.stream.readString();this.handler&&this.handler.onLayout(t)}parseCenterPrint(){let t=this.stream.readString();this.handler&&this.handler.onCenterPrint(t)}parseServerData(){if(this.protocolVersion=this.stream.readLong(),this.protocolVersion===qs){let t=this.stream.readLong(),r=this.stream.readByte();this.isDemo=r;let n=this.stream.readByte(),i=this.stream.readString(),o=this.stream.readShort();if(o===-2){let a=this.stream.readShort();for(let d=0;d<a;d++)this.stream.readShort();o=0}else o===-1&&(o=-1);let s=this.stream.readString();this.handler?this.handler.onServerData(this.protocolVersion,t,0,i,o,s,n,r):console.log(`Server Data (Rerelease): Protocol ${this.protocolVersion}, Level ${s}, Tick ${n}`)}else{let t=this.stream.readLong();this.isDemo=this.stream.readByte();let r=0,n=this.stream.readString(),i=this.stream.readShort(),o=this.stream.readString();this.handler?this.handler.onServerData(this.protocolVersion,t,r,n,i,o):console.log(`Server Data: Protocol ${this.protocolVersion}, Level ${o}, GameDir ${n}`)}}parseConfigString(){let t=this.stream.readShort(),r=this.stream.readString();this.handler&&this.handler.onConfigString(t,r)}parseSplitClient(){let t=this.stream.readByte();this.handler&&this.handler.onSplitClient&&this.handler.onSplitClient(t)}parseConfigBlast(){let t=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(t);try{let i=cc.inflate(n);i.byteLength!==r&&console.warn(`svc_configblast: Decompressed size mismatch. Expected ${r}, got ${i.byteLength}`);let o=new Dn(i.buffer);for(;o.hasMore();){let s=o.readUShort(),a=o.readString();this.handler&&this.handler.onConfigString(s,a)}}catch(i){console.error("svc_configblast: Failed to decompress data",i)}}parseSpawnBaselineBlast(){let t=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(t);try{let i=cc.inflate(n);i.byteLength!==r&&console.warn(`svc_spawnbaselineblast: Decompressed size mismatch. Expected ${r}, got ${i.byteLength}`);let o=new Dn(i.buffer),s=new e(o,this.handler);for(;o.hasMore();)s.parseSpawnBaseline()}catch(i){console.error("svc_spawnbaselineblast: Failed to decompress data",i)}}parseLocPrint(){let t=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&&this.handler.onLocPrint&&this.handler.onLocPrint(t,r,i)}parseWaitingForPlayers(){let t=this.stream.readByte();this.handler&&this.handler.onWaitingForPlayers&&this.handler.onWaitingForPlayers(t)}parseBotChat(){let t=this.stream.readString(),r=this.stream.readShort(),n=this.stream.readString();this.handler&&this.handler.onBotChat&&this.handler.onBotChat(n)}parsePoi(){let t=this.stream.readUShort(),r=this.stream.readUShort(),n={x:0,y:0,z:0};this.stream.readPos(n);let i=this.stream.readUShort(),o=this.stream.readByte(),s=this.stream.readByte();this.handler&&this.handler.onPoi&&this.handler.onPoi(s,n)}parseHelpPath(){let t=this.stream.readByte(),r={x:0,y:0,z:0};this.stream.readPos(r);let n={x:0,y:0,z:0};this.stream.readDir(n),this.handler&&this.handler.onHelpPath&&this.handler.onHelpPath(r)}parseAchievement(){let t=this.stream.readString();this.handler&&this.handler.onAchievement&&this.handler.onAchievement(t)}parseDownload(){let t=this.stream.readShort(),r=this.stream.readByte(),n;t>0&&(n=this.stream.readData(t)),this.handler&&this.handler.onDownload(t,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 t=this.stream.readByte(),r=this.stream.readByte(),n,i,o,s,a;if(t&1&&(n=this.stream.readByte()),t&2&&(i=this.stream.readByte()),t&16&&(o=this.stream.readByte()),t&8&&(s=this.stream.readShort()),t&4){let d={x:0,y:0,z:0};this.stream.readPos(d),a=d}this.handler&&this.handler.onSound(t,r,n,i,o,s,a)}parseMuzzleFlash(){let t=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash(t,r)}parseMuzzleFlash2(){let t=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash2(t,r)}parseMuzzleFlash3(){let t=this.stream.readShort(),r=this.stream.readShort();this.handler&&this.handler.onMuzzleFlash3&&this.handler.onMuzzleFlash3(t,r)}parseFog(){let t=this.stream.readByte();if(t&128){let n=this.stream.readByte();t|=n<<8}let r={};t&1&&(r.density=this.stream.readFloat(),r.skyfactor=this.stream.readByte()),t&2&&(r.red=this.stream.readByte()),t&4&&(r.green=this.stream.readByte()),t&8&&(r.blue=this.stream.readByte()),t&16&&(r.time=this.stream.readShort()),t&32&&(r.hf_falloff=this.stream.readFloat()),t&64&&(r.hf_density=this.stream.readFloat()),t&256&&(r.hf_start_r=this.stream.readByte()),t&512&&(r.hf_start_g=this.stream.readByte()),t&1024&&(r.hf_start_b=this.stream.readByte()),t&2048&&(r.hf_start_dist=this.stream.readLong()),t&4096&&(r.hf_end_r=this.stream.readByte()),t&8192&&(r.hf_end_g=this.stream.readByte()),t&16384&&(r.hf_end_b=this.stream.readByte()),t&32768&&(r.hf_end_dist=this.stream.readLong()),this.handler&&this.handler.onFog&&this.handler.onFog(r)}parseDamage(){let t=this.stream.readByte(),r=[];for(let n=0;n<t;n++){let i=this.stream.readByte(),o={x:0,y:0,z:0};this.stream.readDir(o);let s=i&31,a=(i&32)!==0,d=(i&64)!==0,l=(i&128)!==0;r.push({damage:s,health:a,armor:d,power:l,dir:o})}this.handler&&this.handler.onDamage&&this.handler.onDamage(r)}parseTempEntity(){let t=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,s,a,d,l;switch(t){case I.EXPLOSION1:case I.EXPLOSION2:case I.ROCKET_EXPLOSION:case I.GRENADE_EXPLOSION:case I.ROCKET_EXPLOSION_WATER:case I.GRENADE_EXPLOSION_WATER:case I.BFG_EXPLOSION:case I.BFG_BIGEXPLOSION:case I.BOSSTPORT:case I.PLASMA_EXPLOSION:case I.PLAIN_EXPLOSION:case I.CHAINFIST_SMOKE:case I.TRACKER_EXPLOSION:case I.TELEPORT_EFFECT:case I.DBALL_GOAL:case I.NUKEBLAST:case I.WIDOWSPLASH:case I.EXPLOSION1_BIG:case I.EXPLOSION1_NP:this.stream.readPos(r);break;case I.GUNSHOT:case I.BLOOD:case I.BLASTER:case I.SHOTGUN:case I.SPARKS:case I.BULLET_SPARKS:case I.SCREEN_SPARKS:case I.SHIELD_SPARKS:case I.BLASTER2:case I.FLECHETTE:case I.MOREBLOOD:case I.ELECTRIC_SPARKS:case I.HEATBEAM_SPARKS:case I.HEATBEAM_STEAM:this.stream.readPos(r),this.stream.readDir(i);break;case I.SPLASH:case I.LASER_SPARKS:case I.WELDING_SPARKS:case I.TUNNEL_SPARKS:o=this.stream.readByte(),this.stream.readPos(r),this.stream.readDir(i),s=this.stream.readByte();break;case I.BLUEHYPERBLASTER:this.protocolVersion>=32?(this.stream.readPos(r),this.stream.readPos(n)):(this.stream.readPos(r),this.stream.readDir(i));break;case I.GREENBLOOD:this.protocolVersion>=32?(this.stream.readPos(r),this.stream.readDir(i)):(this.stream.readPos(r),this.stream.readPos(n));break;case I.RAILTRAIL:case I.BUBBLETRAIL:case I.BFG_LASER:case I.DEBUGTRAIL:case I.BUBBLETRAIL2:this.stream.readPos(r),this.stream.readPos(n);break;case I.PARASITE_ATTACK:case I.MEDIC_CABLE_ATTACK:this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n);break;case I.GRAPPLE_CABLE:a=this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n),this.stream.readPos(i);break;case I.LIGHTNING:d=this.stream.readShort(),l=this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n);break;case I.FLASHLIGHT:this.stream.readPos(r),a=this.stream.readShort();break;case I.FORCEWALL:this.stream.readPos(r),this.stream.readPos(n),s=this.stream.readByte();break;case I.STEAM:let c=this.stream.readShort();o=this.stream.readByte(),this.stream.readPos(r),this.stream.readDir(i),s=this.stream.readByte(),this.stream.readShort(),c!==-1&&this.stream.readLong();break;case I.WIDOWBEAMOUT:this.stream.readShort();case I.HEATBEAM:case I.MONSTER_HEATBEAM:a=this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n),this.stream.readPos(i);break;default:break}this.handler&&this.handler.onTempEntity(t,r,n,i,o,s,a,d,l)}parseSpawnBaseline(){let t=this.parseEntityBits(),r=Dr();this.parseDelta(Dr(),r,t.number,t.bits,t.bitsHigh),this.handler&&this.handler.onSpawnBaseline(r)}parseFrame(){let t=this.stream.readLong(),r=this.stream.readLong(),n=this.stream.readByte(),i=this.stream.readByte(),o=this.stream.readData(i),s=this.stream.readByte();if(s=this.translateCommand(s),s!==F.playerinfo)throw new Error(`Expected svc_playerinfo after svc_frame, got ${s} (translated)`);let a=this.parsePlayerState(),d=this.stream.readByte();if(d=this.translateCommand(d),d!==F.packetentities)throw new Error(`Expected svc_packetentities after svc_playerinfo, got ${d} (translated)`);let l=this.collectPacketEntities();if(this.isDemo===mx){let c=this.stream.readByte();for(let h=0;h<c;h++)this.stream.readByte()}this.isDemo===hx&&this.stream.readLong(),this.handler&&this.handler.onFrame({serverFrame:t,deltaFrame:r,surpressCount:n,areaBytes:i,areaBits:o,playerState:a,packetEntities:{delta:!0,entities:l}})}parsePlayerState(){let t=js(),r=this.stream.readShort();r&1&&(t.pm_type=this.stream.readByte()),r&2&&(t.origin.x=this.stream.readShort()*.125,t.origin.y=this.stream.readShort()*.125,t.origin.z=this.stream.readShort()*.125),r&4&&(t.velocity.x=this.stream.readShort()*.125,t.velocity.y=this.stream.readShort()*.125,t.velocity.z=this.stream.readShort()*.125),r&8&&(t.pm_time=this.stream.readByte()),r&16&&(t.pm_flags=this.stream.readByte()),r&32&&(t.gravity=this.stream.readShort()),r&64&&(t.delta_angles.x=this.stream.readShort()*(180/32768),t.delta_angles.y=this.stream.readShort()*(180/32768),t.delta_angles.z=this.stream.readShort()*(180/32768)),r&128&&(t.viewoffset.x=this.stream.readChar()*.25,t.viewoffset.y=this.stream.readChar()*.25,t.viewoffset.z=this.stream.readChar()*.25),r&256&&(t.viewangles.x=this.stream.readAngle16(),t.viewangles.y=this.stream.readAngle16(),t.viewangles.z=this.stream.readAngle16()),r&512&&(t.kick_angles.x=this.stream.readChar()*.25,t.kick_angles.y=this.stream.readChar()*.25,t.kick_angles.z=this.stream.readChar()*.25),r&4096&&(t.gun_index=this.stream.readByte()),r&8192&&(t.gun_frame=this.stream.readByte(),t.gun_offset.x=this.stream.readChar()*.25,t.gun_offset.y=this.stream.readChar()*.25,t.gun_offset.z=this.stream.readChar()*.25,t.gun_angles.x=this.stream.readChar()*.25,t.gun_angles.y=this.stream.readChar()*.25,t.gun_angles.z=this.stream.readChar()*.25),r&1024&&(t.blend[0]=this.stream.readByte(),t.blend[1]=this.stream.readByte(),t.blend[2]=this.stream.readByte(),t.blend[3]=this.stream.readByte()),r&2048&&(t.fov=this.stream.readByte()),r&16384&&(t.rdflags=this.stream.readByte());let n=this.stream.readLong();for(let i=0;i<32;i++)n&1<<i&&(t.stats[i]=this.stream.readShort());return t}parsePacketEntities(t){let r=this.collectPacketEntities();this.handler&&this.handler.onFrame({serverFrame:0,deltaFrame:0,surpressCount:0,areaBytes:0,areaBits:new Uint8Array,playerState:js(),packetEntities:{delta:t,entities:r}})}collectPacketEntities(){let t=[];for(;;){let r=this.parseEntityBits();if(r.number===0)break;let n=Dr();this.parseDelta(Dr(),n,r.number,r.bits,r.bitsHigh),t.push(n)}return t}parseEntityBits(){let t=this.stream.readByte();t&ax&&(t|=this.stream.readByte()<<8),t&cx&&(t|=this.stream.readByte()<<16),t&dx&&(t|=this.stream.readByte()<<24);let r=0;t&ux&&(r=this.stream.readByte());let n;return t&lx?n=this.stream.readShort():n=this.stream.readByte(),{number:n,bits:t,bitsHigh:r}}parseDelta(t,r,n,i,o=0){r.number=t.number,r.modelindex=t.modelindex,r.modelindex2=t.modelindex2,r.modelindex3=t.modelindex3,r.modelindex4=t.modelindex4,r.frame=t.frame,r.skinnum=t.skinnum,r.effects=t.effects,r.renderfx=t.renderfx,r.origin.x=t.origin.x,r.origin.y=t.origin.y,r.origin.z=t.origin.z,r.old_origin.x=t.origin.x,r.old_origin.y=t.origin.y,r.old_origin.z=t.origin.z,r.angles.x=t.angles.x,r.angles.y=t.angles.y,r.angles.z=t.angles.z,r.sound=t.sound,r.event=t.event,r.solid=t.solid,r.alpha=t.alpha,r.scale=t.scale,r.instanceBits=t.instanceBits,r.loopVolume=t.loopVolume,r.loopAttenuation=t.loopAttenuation,r.owner=t.owner,r.oldFrame=t.oldFrame,r.number=n,r.bits=i,r.bitsHigh=o,i&sa&&(r.modelindex=this.stream.readByte()),i&la&&(r.modelindex2=this.stream.readByte()),i&ca&&(r.modelindex3=this.stream.readByte()),i&da&&(r.modelindex4=this.stream.readByte()),i&ra&&(r.frame=this.stream.readByte()),i&aa&&(r.frame=this.stream.readShort()),i&uo&&i&mo?r.skinnum=this.stream.readLong():i&uo?r.skinnum=this.stream.readByte():i&mo&&(r.skinnum=this.stream.readShort()),i&co&&i&ho?r.effects=this.stream.readLong():i&co?r.effects=this.stream.readByte():i&ho&&(r.effects=this.stream.readShort()),i&lo&&i&fo?r.renderfx=this.stream.readLong():i&lo?r.renderfx=this.stream.readByte():i&fo&&(r.renderfx=this.stream.readShort()),i&Qs&&(r.origin.x=this.stream.readCoord()),i&Js&&(r.origin.y=this.stream.readCoord()),i&ia&&(r.origin.z=this.stream.readCoord()),i&oa&&(r.angles.x=this.stream.readAngle()),i&ea&&(r.angles.y=this.stream.readAngle()),i&ta&&(r.angles.z=this.stream.readAngle()),i&ua&&this.stream.readPos(r.old_origin),i&fa&&(r.sound=this.stream.readByte()),i&na?r.event=this.stream.readByte():r.event=0,i&ha&&(r.solid=this.stream.readShort()),i&uc&&(r.alpha=this.stream.readByte()/255),i&fc&&(r.scale=this.stream.readFloat()),i&hc&&(r.instanceBits=this.stream.readLong()),i&mc&&(r.loopVolume=this.stream.readByte()/255),o&pc&&(r.loopAttenuation=this.stream.readByte()/255),o&gc&&(r.owner=this.stream.readShort()),o&yc&&(r.oldFrame=this.stream.readShort())}};var ma=(i=>(i[i.Stopped=0]="Stopped",i[i.Playing=1]="Playing",i[i.Paused=2]="Paused",i[i.Finished=3]="Finished",i))(ma||{}),po=class{constructor(){this.reader=null;this.state=0;this.playbackSpeed=1;this.currentProtocolVersion=0;this.accumulatedTime=0;this.frameDuration=100}setHandler(t){this.handler=t}loadDemo(t){this.reader=new Lr(t),this.state=0,this.accumulatedTime=0,this.currentProtocolVersion=0}play(){this.reader&&(this.state=1)}pause(){this.state===1&&(this.state=2)}stop(){this.state=0,this.reader&&this.reader.reset(),this.accumulatedTime=0,this.currentProtocolVersion=0}setFrameDuration(t){this.frameDuration=t}setSpeed(t){this.playbackSpeed=Math.max(.1,Math.min(t,16))}getSpeed(){return this.playbackSpeed}update(t){if(!(this.state!==1||!this.reader))for(this.accumulatedTime+=t*1e3*this.playbackSpeed;this.accumulatedTime>=this.frameDuration;){if(!this.processNextFrame())return;this.accumulatedTime-=this.frameDuration}}stepForward(){this.reader&&this.processNextFrame()}stepBackward(){console.warn("stepBackward not implemented")}processNextFrame(){if(!this.reader||!this.reader.hasMore())return this.state=3,!1;let t=this.reader.readNextBlock();if(!t)return this.state=3,!1;let r=new Pr(t.data,this.handler);return r.setProtocolVersion(this.currentProtocolVersion),r.parseMessage(),this.currentProtocolVersion=r.getProtocolVersion(),!0}getState(){return this.state}getCurrentTime(){return this.accumulatedTime}};function px(e){return{init(){e.trace({x:0,y:0,z:0},{x:0,y:0,z:0})},shutdown(){},createMainLoop(t,r){return new cr(t,r)}}}return qu(gx);})();
|
|
480
|
+
}`,Oo=class{constructor(t,r){this.vertexCapacity=0;this.indexCapacity=0;this.gl=t,this.system=r,this.program=Ee.create(t,{vertex:Cl,fragment:zl}),this.vertexBuffer=new Le(t,t.DYNAMIC_DRAW),this.indexBuffer=new xe(t,t.DYNAMIC_DRAW),this.vertexArray=new ze(t),this.vertexArray.configureAttributes([{index:0,size:3,type:t.FLOAT,stride:36,offset:0},{index:1,size:2,type:t.FLOAT,stride:36,offset:12},{index:2,size:4,type:t.FLOAT,stride:36,offset:20}],this.vertexBuffer)}render(t){let r=this.system.buildMesh(t.viewRight,t.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 s=this.program.getUniformLocation("u_viewProjection");this.gl.uniformMatrix4fv(s,!1,t.viewProjection),this.vertexArray.bind();for(let o of r.batches)o.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,o.count,this.gl.UNSIGNED_SHORT,o.start*2);this.gl.depthMask(!0)}dispose(){this.program.dispose(),this.vertexBuffer.dispose(),this.indexBuffer.dispose(),this.vertexArray.dispose()}};function g0(e){let{system:t,origin:r,normal:n={x:0,y:0,z:1}}=e;for(let i=0;i<12;i+=1){let s=200+t.random()*180,o=t.random()*.35;t.spawn({position:r,velocity:{x:n.x*s+(t.random()-.5)*80,y:n.y*s+(t.random()-.5)*80,z:Math.max(n.z*s,120)+o*80},color:[1,.8,.4,1],size:2.5,lifetime:.45+t.random()*.1,gravity:600,damping:2,bounce:.45,blendMode:"additive",fade:!0})}for(let i=0;i<8;i+=1)t.spawn({position:r,velocity:{x:(t.random()-.5)*40,y:(t.random()-.5)*40,z:80+t.random()*40},color:[.45,.45,.45,.75],size:6,lifetime:.6,gravity:200,damping:4,bounce:.15,blendMode:"alpha",fade:!0})}function y0(e){let{system:t,origin:r}=e;for(let n=0;n<40;n+=1){let i=t.random()*Math.PI*2,s=Math.acos(2*t.random()-1),o=220+t.random()*260,a={x:Math.sin(s)*Math.cos(i),y:Math.sin(s)*Math.sin(i),z:Math.cos(s)};t.spawn({position:r,velocity:{x:a.x*o,y:a.y*o,z:a.z*o},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)t.spawn({position:r,velocity:{x:(t.random()-.5)*30,y:(t.random()-.5)*30,z:120+t.random()*120},color:[.25,.25,.25,.9],size:12,lifetime:1.2,gravity:300,damping:3,blendMode:"alpha",fade:!0})}function x0(e){let{system:t,origin:r,direction:n={x:0,y:0,z:1}}=e;for(let i=0;i<24;i+=1){let s=120+t.random()*180;t.spawn({position:r,velocity:{x:n.x*s+(t.random()-.5)*70,y:n.y*s+(t.random()-.5)*70,z:n.z*s+t.random()*80},color:[.6,0,0,.95],size:3,lifetime:.8,gravity:900,damping:1,bounce:.2,blendMode:"alpha",fade:!0})}}function _0(e){let{system:t,origin:r}=e;for(let n=0;n<30;n+=1){let i=t.random()*Math.PI*2,s=8+t.random()*8;t.spawn({position:r,velocity:{x:Math.cos(i)*s,y:Math.sin(i)*s,z:100+t.random()*80},color:[.4,.6,1,.9],size:4,lifetime:.5,gravity:300,damping:2,blendMode:"additive",fade:!0})}}function b0(e){let{system:t,origin:r,direction:n={x:1,y:0,z:0}}=e;for(let i=0;i<10;i+=1){let s=350+t.random()*100;t.spawn({position:r,velocity:{x:n.x*s+(t.random()-.5)*30,y:n.y*s+(t.random()-.5)*30,z:n.z*s+(t.random()-.5)*30},color:[1,.8,.3,1],size:3,lifetime:.25,gravity:200,damping:1,blendMode:"additive",fade:!0})}}function v0(e){let{system:t,origin:r,direction:n={x:0,y:0,z:0}}=e;for(let i=0;i<6;i+=1)t.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:(t.random()-.5)*15,y:(t.random()-.5)*15,z:20+t.random()*15},color:[.6,.6,.6,.8],size:2.2,lifetime:.6,gravity:200,damping:1.5,blendMode:"alpha",fade:!0})}var Lr=class{constructor(t){this.messageOffsets=[];this.buffer=t,this.view=new DataView(t),this.offset=0,this.scan()}scan(){let t=0;for(this.messageOffsets=[];t+4<=this.buffer.byteLength;){let r=this.view.getInt32(t,!0);if(r<0||r>2097152){console.warn(`DemoReader: Invalid block length ${r} at offset ${t} during scan`);break}if(t+4+r>this.buffer.byteLength){console.warn(`DemoReader: Incomplete block at offset ${t} during scan`);break}this.messageOffsets.push(t),t+=4+r}}hasMore(){return this.offset<this.buffer.byteLength}readNextBlock(){if(this.offset+4>this.buffer.byteLength)return null;let t=this.view.getInt32(this.offset,!0);if(t<0||this.offset+4+t>this.buffer.byteLength)return null;this.offset+=4;let r=this.buffer.slice(this.offset,this.offset+t);return this.offset+=t,{length:t,data:new Dn(r)}}reset(){this.offset=0}seekToMessage(t){return t<0||t>=this.messageOffsets.length?!1:(this.offset=this.messageOffsets[t],!0)}getMessageCount(){return this.messageOffsets.length}getOffset(){return this.offset}};function Tn(e){let t=e.length;for(;--t>=0;)e[t]=0}var f1=0,ou=1,h1=2,m1=3,p1=258,rc=29,is=256,qi=is+1+rc,Mn=30,nc=19,au=2*qi+1,Tr=15,Fl=16,g1=7,ic=256,lu=16,cu=17,du=18,$l=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]),Go=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]),y1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),uu=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),x1=512,Ct=new Array((qi+2)*2);Tn(Ct);var $i=new Array(Mn*2);Tn($i);var ji=new Array(x1);Tn(ji);var Qi=new Array(p1-m1+1);Tn(Qi);var sc=new Array(rc);Tn(sc);var Wo=new Array(Mn);Tn(Wo);function kl(e,t,r,n,i){this.static_tree=e,this.extra_bits=t,this.extra_base=r,this.elems=n,this.max_length=i,this.has_stree=e&&e.length}var fu,hu,mu;function Bl(e,t){this.dyn_tree=e,this.max_code=0,this.stat_desc=t}var pu=e=>e<256?ji[e]:ji[256+(e>>>7)],Ji=(e,t)=>{e.pending_buf[e.pending++]=t&255,e.pending_buf[e.pending++]=t>>>8&255},Fe=(e,t,r)=>{e.bi_valid>Fl-r?(e.bi_buf|=t<<e.bi_valid&65535,Ji(e,e.bi_buf),e.bi_buf=t>>Fl-e.bi_valid,e.bi_valid+=r-Fl):(e.bi_buf|=t<<e.bi_valid&65535,e.bi_valid+=r)},mt=(e,t,r)=>{Fe(e,r[t*2],r[t*2+1])},gu=(e,t)=>{let r=0;do r|=e&1,e>>>=1,r<<=1;while(--t>0);return r>>>1},_1=e=>{e.bi_valid===16?(Ji(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):e.bi_valid>=8&&(e.pending_buf[e.pending++]=e.bi_buf&255,e.bi_buf>>=8,e.bi_valid-=8)},b1=(e,t)=>{let r=t.dyn_tree,n=t.max_code,i=t.stat_desc.static_tree,s=t.stat_desc.has_stree,o=t.stat_desc.extra_bits,a=t.stat_desc.extra_base,d=t.stat_desc.max_length,l,c,h,u,f,m,g=0;for(u=0;u<=Tr;u++)e.bl_count[u]=0;for(r[e.heap[e.heap_max]*2+1]=0,l=e.heap_max+1;l<au;l++)c=e.heap[l],u=r[r[c*2+1]*2+1]+1,u>d&&(u=d,g++),r[c*2+1]=u,!(c>n)&&(e.bl_count[u]++,f=0,c>=a&&(f=o[c-a]),m=r[c*2],e.opt_len+=m*(u+f),s&&(e.static_len+=m*(i[c*2+1]+f)));if(g!==0){do{for(u=d-1;e.bl_count[u]===0;)u--;e.bl_count[u]--,e.bl_count[u+1]+=2,e.bl_count[d]--,g-=2}while(g>0);for(u=d;u!==0;u--)for(c=e.bl_count[u];c!==0;)h=e.heap[--l],!(h>n)&&(r[h*2+1]!==u&&(e.opt_len+=(u-r[h*2+1])*r[h*2],r[h*2+1]=u),c--)}},yu=(e,t,r)=>{let n=new Array(Tr+1),i=0,s,o;for(s=1;s<=Tr;s++)i=i+r[s-1]<<1,n[s]=i;for(o=0;o<=t;o++){let a=e[o*2+1];a!==0&&(e[o*2]=gu(n[a]++,a))}},v1=()=>{let e,t,r,n,i,s=new Array(Tr+1);for(r=0,n=0;n<rc-1;n++)for(sc[n]=r,e=0;e<1<<$l[n];e++)Qi[r++]=n;for(Qi[r-1]=n,i=0,n=0;n<16;n++)for(Wo[n]=i,e=0;e<1<<Go[n];e++)ji[i++]=n;for(i>>=7;n<Mn;n++)for(Wo[n]=i<<7,e=0;e<1<<Go[n]-7;e++)ji[256+i++]=n;for(t=0;t<=Tr;t++)s[t]=0;for(e=0;e<=143;)Ct[e*2+1]=8,e++,s[8]++;for(;e<=255;)Ct[e*2+1]=9,e++,s[9]++;for(;e<=279;)Ct[e*2+1]=7,e++,s[7]++;for(;e<=287;)Ct[e*2+1]=8,e++,s[8]++;for(yu(Ct,qi+1,s),e=0;e<Mn;e++)$i[e*2+1]=5,$i[e*2]=gu(e,5);fu=new kl(Ct,$l,is+1,qi,Tr),hu=new kl($i,Go,0,Mn,Tr),mu=new kl(new Array(0),y1,0,nc,g1)},xu=e=>{let t;for(t=0;t<qi;t++)e.dyn_ltree[t*2]=0;for(t=0;t<Mn;t++)e.dyn_dtree[t*2]=0;for(t=0;t<nc;t++)e.bl_tree[t*2]=0;e.dyn_ltree[ic*2]=1,e.opt_len=e.static_len=0,e.sym_next=e.matches=0},_u=e=>{e.bi_valid>8?Ji(e,e.bi_buf):e.bi_valid>0&&(e.pending_buf[e.pending++]=e.bi_buf),e.bi_buf=0,e.bi_valid=0},S0=(e,t,r,n)=>{let i=t*2,s=r*2;return e[i]<e[s]||e[i]===e[s]&&n[t]<=n[r]},Dl=(e,t,r)=>{let n=e.heap[r],i=r<<1;for(;i<=e.heap_len&&(i<e.heap_len&&S0(t,e.heap[i+1],e.heap[i],e.depth)&&i++,!S0(t,n,e.heap[i],e.depth));)e.heap[r]=e.heap[i],r=i,i<<=1;e.heap[r]=n},w0=(e,t,r)=>{let n,i,s=0,o,a;if(e.sym_next!==0)do n=e.pending_buf[e.sym_buf+s++]&255,n+=(e.pending_buf[e.sym_buf+s++]&255)<<8,i=e.pending_buf[e.sym_buf+s++],n===0?mt(e,i,t):(o=Qi[i],mt(e,o+is+1,t),a=$l[o],a!==0&&(i-=sc[o],Fe(e,i,a)),n--,o=pu(n),mt(e,o,r),a=Go[o],a!==0&&(n-=Wo[o],Fe(e,n,a)));while(s<e.sym_next);mt(e,ic,t)},Zl=(e,t)=>{let r=t.dyn_tree,n=t.stat_desc.static_tree,i=t.stat_desc.has_stree,s=t.stat_desc.elems,o,a,d=-1,l;for(e.heap_len=0,e.heap_max=au,o=0;o<s;o++)r[o*2]!==0?(e.heap[++e.heap_len]=d=o,e.depth[o]=0):r[o*2+1]=0;for(;e.heap_len<2;)l=e.heap[++e.heap_len]=d<2?++d:0,r[l*2]=1,e.depth[l]=0,e.opt_len--,i&&(e.static_len-=n[l*2+1]);for(t.max_code=d,o=e.heap_len>>1;o>=1;o--)Dl(e,r,o);l=s;do o=e.heap[1],e.heap[1]=e.heap[e.heap_len--],Dl(e,r,1),a=e.heap[1],e.heap[--e.heap_max]=o,e.heap[--e.heap_max]=a,r[l*2]=r[o*2]+r[a*2],e.depth[l]=(e.depth[o]>=e.depth[a]?e.depth[o]:e.depth[a])+1,r[o*2+1]=r[a*2+1]=l,e.heap[1]=l++,Dl(e,r,1);while(e.heap_len>=2);e.heap[--e.heap_max]=e.heap[1],b1(e,t),yu(r,d,e.bl_count)},A0=(e,t,r)=>{let n,i=-1,s,o=t[1],a=0,d=7,l=4;for(o===0&&(d=138,l=3),t[(r+1)*2+1]=65535,n=0;n<=r;n++)s=o,o=t[(n+1)*2+1],!(++a<d&&s===o)&&(a<l?e.bl_tree[s*2]+=a:s!==0?(s!==i&&e.bl_tree[s*2]++,e.bl_tree[lu*2]++):a<=10?e.bl_tree[cu*2]++:e.bl_tree[du*2]++,a=0,i=s,o===0?(d=138,l=3):s===o?(d=6,l=3):(d=7,l=4))},M0=(e,t,r)=>{let n,i=-1,s,o=t[1],a=0,d=7,l=4;for(o===0&&(d=138,l=3),n=0;n<=r;n++)if(s=o,o=t[(n+1)*2+1],!(++a<d&&s===o)){if(a<l)do mt(e,s,e.bl_tree);while(--a!==0);else s!==0?(s!==i&&(mt(e,s,e.bl_tree),a--),mt(e,lu,e.bl_tree),Fe(e,a-3,2)):a<=10?(mt(e,cu,e.bl_tree),Fe(e,a-3,3)):(mt(e,du,e.bl_tree),Fe(e,a-11,7));a=0,i=s,o===0?(d=138,l=3):s===o?(d=6,l=3):(d=7,l=4)}},S1=e=>{let t;for(A0(e,e.dyn_ltree,e.l_desc.max_code),A0(e,e.dyn_dtree,e.d_desc.max_code),Zl(e,e.bl_desc),t=nc-1;t>=3&&e.bl_tree[uu[t]*2+1]===0;t--);return e.opt_len+=3*(t+1)+5+5+4,t},w1=(e,t,r,n)=>{let i;for(Fe(e,t-257,5),Fe(e,r-1,5),Fe(e,n-4,4),i=0;i<n;i++)Fe(e,e.bl_tree[uu[i]*2+1],3);M0(e,e.dyn_ltree,t-1),M0(e,e.dyn_dtree,r-1)},A1=e=>{let t=4093624447,r;for(r=0;r<=31;r++,t>>>=1)if(t&1&&e.dyn_ltree[r*2]!==0)return 0;if(e.dyn_ltree[18]!==0||e.dyn_ltree[20]!==0||e.dyn_ltree[26]!==0)return 1;for(r=32;r<is;r++)if(e.dyn_ltree[r*2]!==0)return 1;return 0},E0=!1,M1=e=>{E0||(v1(),E0=!0),e.l_desc=new Bl(e.dyn_ltree,fu),e.d_desc=new Bl(e.dyn_dtree,hu),e.bl_desc=new Bl(e.bl_tree,mu),e.bi_buf=0,e.bi_valid=0,xu(e)},bu=(e,t,r,n)=>{Fe(e,(f1<<1)+(n?1:0),3),_u(e),Ji(e,r),Ji(e,~r),r&&e.pending_buf.set(e.window.subarray(t,t+r),e.pending),e.pending+=r},E1=e=>{Fe(e,ou<<1,3),mt(e,ic,Ct),_1(e)},L1=(e,t,r,n)=>{let i,s,o=0;e.level>0?(e.strm.data_type===2&&(e.strm.data_type=A1(e)),Zl(e,e.l_desc),Zl(e,e.d_desc),o=S1(e),i=e.opt_len+3+7>>>3,s=e.static_len+3+7>>>3,s<=i&&(i=s)):i=s=r+5,r+4<=i&&t!==-1?bu(e,t,r,n):e.strategy===4||s===i?(Fe(e,(ou<<1)+(n?1:0),3),w0(e,Ct,$i)):(Fe(e,(h1<<1)+(n?1:0),3),w1(e,e.l_desc.max_code+1,e.d_desc.max_code+1,o+1),w0(e,e.dyn_ltree,e.dyn_dtree)),xu(e),n&&_u(e)},T1=(e,t,r)=>(e.pending_buf[e.sym_buf+e.sym_next++]=t,e.pending_buf[e.sym_buf+e.sym_next++]=t>>8,e.pending_buf[e.sym_buf+e.sym_next++]=r,t===0?e.dyn_ltree[r*2]++:(e.matches++,t--,e.dyn_ltree[(Qi[r]+is+1)*2]++,e.dyn_dtree[pu(t)*2]++),e.sym_next===e.sym_end),I1=M1,R1=bu,C1=L1,z1=T1,F1=E1,k1={_tr_init:I1,_tr_stored_block:R1,_tr_flush_block:C1,_tr_tally:z1,_tr_align:F1},B1=(e,t,r,n)=>{let i=e&65535|0,s=e>>>16&65535|0,o=0;for(;r!==0;){o=r>2e3?2e3:r,r-=o;do i=i+t[n++]|0,s=s+i|0;while(--o);i%=65521,s%=65521}return i|s<<16|0},es=B1,D1=()=>{let e,t=[];for(var r=0;r<256;r++){e=r;for(var n=0;n<8;n++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e}return t},O1=new Uint32Array(D1()),P1=(e,t,r,n)=>{let i=O1,s=n+r;e^=-1;for(let o=n;o<s;o++)e=e>>>8^i[(e^t[o])&255];return e^-1},fe=P1,Cr={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"},kr={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:N1,_tr_stored_block:Yl,_tr_flush_block:U1,_tr_tally:sr,_tr_align:H1}=k1,{Z_NO_FLUSH:or,Z_PARTIAL_FLUSH:V1,Z_FULL_FLUSH:G1,Z_FINISH:je,Z_BLOCK:L0,Z_OK:he,Z_STREAM_END:T0,Z_STREAM_ERROR:pt,Z_DATA_ERROR:W1,Z_BUF_ERROR:Ol,Z_DEFAULT_COMPRESSION:X1,Z_FILTERED:K1,Z_HUFFMAN_ONLY:Po,Z_RLE:$1,Z_FIXED:Z1,Z_DEFAULT_STRATEGY:Y1,Z_UNKNOWN:q1,Z_DEFLATED:$o}=kr,j1=9,Q1=15,J1=8,eg=29,tg=256,ql=tg+1+eg,rg=30,ng=19,ig=2*ql+1,sg=15,V=3,ir=258,gt=ir+V+1,og=32,En=42,oc=57,jl=69,Ql=73,Jl=91,ec=103,Ir=113,Xi=666,Te=1,In=2,zr=3,Rn=4,ag=3,Rr=(e,t)=>(e.msg=Cr[t],t),I0=e=>e*2-(e>4?9:0),nr=e=>{let t=e.length;for(;--t>=0;)e[t]=0},lg=e=>{let t,r,n,i=e.w_size;t=e.hash_size,n=t;do r=e.head[--n],e.head[n]=r>=i?r-i:0;while(--t);t=i,n=t;do r=e.prev[--n],e.prev[n]=r>=i?r-i:0;while(--t)},cg=(e,t,r)=>(t<<e.hash_shift^r)&e.hash_mask,ar=cg,Ne=e=>{let t=e.state,r=t.pending;r>e.avail_out&&(r=e.avail_out),r!==0&&(e.output.set(t.pending_buf.subarray(t.pending_out,t.pending_out+r),e.next_out),e.next_out+=r,t.pending_out+=r,e.total_out+=r,e.avail_out-=r,t.pending-=r,t.pending===0&&(t.pending_out=0))},Ue=(e,t)=>{U1(e,e.block_start>=0?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,Ne(e.strm)},X=(e,t)=>{e.pending_buf[e.pending++]=t},Wi=(e,t)=>{e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=t&255},tc=(e,t,r,n)=>{let i=e.avail_in;return i>n&&(i=n),i===0?0:(e.avail_in-=i,t.set(e.input.subarray(e.next_in,e.next_in+i),r),e.state.wrap===1?e.adler=es(e.adler,t,i,r):e.state.wrap===2&&(e.adler=fe(e.adler,t,i,r)),e.next_in+=i,e.total_in+=i,i)},vu=(e,t)=>{let r=e.max_chain_length,n=e.strstart,i,s,o=e.prev_length,a=e.nice_match,d=e.strstart>e.w_size-gt?e.strstart-(e.w_size-gt):0,l=e.window,c=e.w_mask,h=e.prev,u=e.strstart+ir,f=l[n+o-1],m=l[n+o];e.prev_length>=e.good_match&&(r>>=2),a>e.lookahead&&(a=e.lookahead);do if(i=t,!(l[i+o]!==m||l[i+o-1]!==f||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(s=ir-(u-n),n=u-ir,s>o){if(e.match_start=t,o=s,s>=a)break;f=l[n+o-1],m=l[n+o]}}while((t=h[t&c])>d&&--r!==0);return o<=e.lookahead?o:e.lookahead},Ln=e=>{let t=e.w_size,r,n,i;do{if(n=e.window_size-e.lookahead-e.strstart,e.strstart>=t+(t-gt)&&(e.window.set(e.window.subarray(t,t+t-n),0),e.match_start-=t,e.strstart-=t,e.block_start-=t,e.insert>e.strstart&&(e.insert=e.strstart),lg(e),n+=t),e.strm.avail_in===0)break;if(r=tc(e.strm,e.window,e.strstart+e.lookahead,n),e.lookahead+=r,e.lookahead+e.insert>=V)for(i=e.strstart-e.insert,e.ins_h=e.window[i],e.ins_h=ar(e,e.ins_h,e.window[i+1]);e.insert&&(e.ins_h=ar(e,e.ins_h,e.window[i+V-1]),e.prev[i&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=i,i++,e.insert--,!(e.lookahead+e.insert<V)););}while(e.lookahead<gt&&e.strm.avail_in!==0)},Su=(e,t)=>{let r=e.pending_buf_size-5>e.w_size?e.w_size:e.pending_buf_size-5,n,i,s,o=0,a=e.strm.avail_in;do{if(n=65535,s=e.bi_valid+42>>3,e.strm.avail_out<s||(s=e.strm.avail_out-s,i=e.strstart-e.block_start,n>i+e.strm.avail_in&&(n=i+e.strm.avail_in),n>s&&(n=s),n<r&&(n===0&&t!==je||t===or||n!==i+e.strm.avail_in)))break;o=t===je&&n===i+e.strm.avail_in?1:0,Yl(e,0,0,o),e.pending_buf[e.pending-4]=n,e.pending_buf[e.pending-3]=n>>8,e.pending_buf[e.pending-2]=~n,e.pending_buf[e.pending-1]=~n>>8,Ne(e.strm),i&&(i>n&&(i=n),e.strm.output.set(e.window.subarray(e.block_start,e.block_start+i),e.strm.next_out),e.strm.next_out+=i,e.strm.avail_out-=i,e.strm.total_out+=i,e.block_start+=i,n-=i),n&&(tc(e.strm,e.strm.output,e.strm.next_out,n),e.strm.next_out+=n,e.strm.avail_out-=n,e.strm.total_out+=n)}while(o===0);return a-=e.strm.avail_in,a&&(a>=e.w_size?(e.matches=2,e.window.set(e.strm.input.subarray(e.strm.next_in-e.w_size,e.strm.next_in),0),e.strstart=e.w_size,e.insert=e.strstart):(e.window_size-e.strstart<=a&&(e.strstart-=e.w_size,e.window.set(e.window.subarray(e.w_size,e.w_size+e.strstart),0),e.matches<2&&e.matches++,e.insert>e.strstart&&(e.insert=e.strstart)),e.window.set(e.strm.input.subarray(e.strm.next_in-a,e.strm.next_in),e.strstart),e.strstart+=a,e.insert+=a>e.w_size-e.insert?e.w_size-e.insert:a),e.block_start=e.strstart),e.high_water<e.strstart&&(e.high_water=e.strstart),o?Rn:t!==or&&t!==je&&e.strm.avail_in===0&&e.strstart===e.block_start?In:(s=e.window_size-e.strstart,e.strm.avail_in>s&&e.block_start>=e.w_size&&(e.block_start-=e.w_size,e.strstart-=e.w_size,e.window.set(e.window.subarray(e.w_size,e.w_size+e.strstart),0),e.matches<2&&e.matches++,s+=e.w_size,e.insert>e.strstart&&(e.insert=e.strstart)),s>e.strm.avail_in&&(s=e.strm.avail_in),s&&(tc(e.strm,e.window,e.strstart,s),e.strstart+=s,e.insert+=s>e.w_size-e.insert?e.w_size-e.insert:s),e.high_water<e.strstart&&(e.high_water=e.strstart),s=e.bi_valid+42>>3,s=e.pending_buf_size-s>65535?65535:e.pending_buf_size-s,r=s>e.w_size?e.w_size:s,i=e.strstart-e.block_start,(i>=r||(i||t===je)&&t!==or&&e.strm.avail_in===0&&i<=s)&&(n=i>s?s:i,o=t===je&&e.strm.avail_in===0&&n===i?1:0,Yl(e,e.block_start,n,o),e.block_start+=n,Ne(e.strm)),o?zr:Te)},Pl=(e,t)=>{let r,n;for(;;){if(e.lookahead<gt){if(Ln(e),e.lookahead<gt&&t===or)return Te;if(e.lookahead===0)break}if(r=0,e.lookahead>=V&&(e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart),r!==0&&e.strstart-r<=e.w_size-gt&&(e.match_length=vu(e,r)),e.match_length>=V)if(n=sr(e,e.strstart-e.match_start,e.match_length-V),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=V){e.match_length--;do e.strstart++,e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart;while(--e.match_length!==0);e.strstart++}else e.strstart+=e.match_length,e.match_length=0,e.ins_h=e.window[e.strstart],e.ins_h=ar(e,e.ins_h,e.window[e.strstart+1]);else n=sr(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++;if(n&&(Ue(e,!1),e.strm.avail_out===0))return Te}return e.insert=e.strstart<V-1?e.strstart:V-1,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In},wn=(e,t)=>{let r,n,i;for(;;){if(e.lookahead<gt){if(Ln(e),e.lookahead<gt&&t===or)return Te;if(e.lookahead===0)break}if(r=0,e.lookahead>=V&&(e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart),e.prev_length=e.match_length,e.prev_match=e.match_start,e.match_length=V-1,r!==0&&e.prev_length<e.max_lazy_match&&e.strstart-r<=e.w_size-gt&&(e.match_length=vu(e,r),e.match_length<=5&&(e.strategy===K1||e.match_length===V&&e.strstart-e.match_start>4096)&&(e.match_length=V-1)),e.prev_length>=V&&e.match_length<=e.prev_length){i=e.strstart+e.lookahead-V,n=sr(e,e.strstart-1-e.prev_match,e.prev_length-V),e.lookahead-=e.prev_length-1,e.prev_length-=2;do++e.strstart<=i&&(e.ins_h=ar(e,e.ins_h,e.window[e.strstart+V-1]),r=e.prev[e.strstart&e.w_mask]=e.head[e.ins_h],e.head[e.ins_h]=e.strstart);while(--e.prev_length!==0);if(e.match_available=0,e.match_length=V-1,e.strstart++,n&&(Ue(e,!1),e.strm.avail_out===0))return Te}else if(e.match_available){if(n=sr(e,0,e.window[e.strstart-1]),n&&Ue(e,!1),e.strstart++,e.lookahead--,e.strm.avail_out===0)return Te}else e.match_available=1,e.strstart++,e.lookahead--}return e.match_available&&(n=sr(e,0,e.window[e.strstart-1]),e.match_available=0),e.insert=e.strstart<V-1?e.strstart:V-1,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In},dg=(e,t)=>{let r,n,i,s,o=e.window;for(;;){if(e.lookahead<=ir){if(Ln(e),e.lookahead<=ir&&t===or)return Te;if(e.lookahead===0)break}if(e.match_length=0,e.lookahead>=V&&e.strstart>0&&(i=e.strstart-1,n=o[i],n===o[++i]&&n===o[++i]&&n===o[++i])){s=e.strstart+ir;do;while(n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&n===o[++i]&&i<s);e.match_length=ir-(s-i),e.match_length>e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=V?(r=sr(e,1,e.match_length-V),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(r=sr(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),r&&(Ue(e,!1),e.strm.avail_out===0))return Te}return e.insert=0,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In},ug=(e,t)=>{let r;for(;;){if(e.lookahead===0&&(Ln(e),e.lookahead===0)){if(t===or)return Te;break}if(e.match_length=0,r=sr(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,r&&(Ue(e,!1),e.strm.avail_out===0))return Te}return e.insert=0,t===je?(Ue(e,!0),e.strm.avail_out===0?zr:Rn):e.sym_next&&(Ue(e,!1),e.strm.avail_out===0)?Te:In};function ht(e,t,r,n,i){this.good_length=e,this.max_lazy=t,this.nice_length=r,this.max_chain=n,this.func=i}var Ki=[new ht(0,0,0,0,Su),new ht(4,4,8,4,Pl),new ht(4,5,16,8,Pl),new ht(4,6,32,32,Pl),new ht(4,4,16,16,wn),new ht(8,16,32,32,wn),new ht(8,16,128,128,wn),new ht(8,32,128,256,wn),new ht(32,128,258,1024,wn),new ht(32,258,258,4096,wn)],fg=e=>{e.window_size=2*e.w_size,nr(e.head),e.max_lazy_match=Ki[e.level].max_lazy,e.good_match=Ki[e.level].good_length,e.nice_match=Ki[e.level].nice_length,e.max_chain_length=Ki[e.level].max_chain,e.strstart=0,e.block_start=0,e.lookahead=0,e.insert=0,e.match_length=e.prev_length=V-1,e.match_available=0,e.ins_h=0};function hg(){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=$o,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(ig*2),this.dyn_dtree=new Uint16Array((2*rg+1)*2),this.bl_tree=new Uint16Array((2*ng+1)*2),nr(this.dyn_ltree),nr(this.dyn_dtree),nr(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(sg+1),this.heap=new Uint16Array(2*ql+1),nr(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(2*ql+1),nr(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 ss=e=>{if(!e)return 1;let t=e.state;return!t||t.strm!==e||t.status!==En&&t.status!==oc&&t.status!==jl&&t.status!==Ql&&t.status!==Jl&&t.status!==ec&&t.status!==Ir&&t.status!==Xi?1:0},wu=e=>{if(ss(e))return Rr(e,pt);e.total_in=e.total_out=0,e.data_type=q1;let t=e.state;return t.pending=0,t.pending_out=0,t.wrap<0&&(t.wrap=-t.wrap),t.status=t.wrap===2?oc:t.wrap?En:Ir,e.adler=t.wrap===2?0:1,t.last_flush=-2,N1(t),he},Au=e=>{let t=wu(e);return t===he&&fg(e.state),t},mg=(e,t)=>ss(e)||e.state.wrap!==2?pt:(e.state.gzhead=t,he),Mu=(e,t,r,n,i,s)=>{if(!e)return pt;let o=1;if(t===X1&&(t=6),n<0?(o=0,n=-n):n>15&&(o=2,n-=16),i<1||i>j1||r!==$o||n<8||n>15||t<0||t>9||s<0||s>Z1||n===8&&o!==1)return Rr(e,pt);n===8&&(n=9);let a=new hg;return e.state=a,a.strm=e,a.status=En,a.wrap=o,a.gzhead=null,a.w_bits=n,a.w_size=1<<a.w_bits,a.w_mask=a.w_size-1,a.hash_bits=i+7,a.hash_size=1<<a.hash_bits,a.hash_mask=a.hash_size-1,a.hash_shift=~~((a.hash_bits+V-1)/V),a.window=new Uint8Array(a.w_size*2),a.head=new Uint16Array(a.hash_size),a.prev=new Uint16Array(a.w_size),a.lit_bufsize=1<<i+6,a.pending_buf_size=a.lit_bufsize*4,a.pending_buf=new Uint8Array(a.pending_buf_size),a.sym_buf=a.lit_bufsize,a.sym_end=(a.lit_bufsize-1)*3,a.level=t,a.strategy=s,a.method=r,Au(e)},pg=(e,t)=>Mu(e,t,$o,Q1,J1,Y1),gg=(e,t)=>{if(ss(e)||t>L0||t<0)return e?Rr(e,pt):pt;let r=e.state;if(!e.output||e.avail_in!==0&&!e.input||r.status===Xi&&t!==je)return Rr(e,e.avail_out===0?Ol:pt);let n=r.last_flush;if(r.last_flush=t,r.pending!==0){if(Ne(e),e.avail_out===0)return r.last_flush=-1,he}else if(e.avail_in===0&&I0(t)<=I0(n)&&t!==je)return Rr(e,Ol);if(r.status===Xi&&e.avail_in!==0)return Rr(e,Ol);if(r.status===En&&r.wrap===0&&(r.status=Ir),r.status===En){let i=$o+(r.w_bits-8<<4)<<8,s=-1;if(r.strategy>=Po||r.level<2?s=0:r.level<6?s=1:r.level===6?s=2:s=3,i|=s<<6,r.strstart!==0&&(i|=og),i+=31-i%31,Wi(r,i),r.strstart!==0&&(Wi(r,e.adler>>>16),Wi(r,e.adler&65535)),e.adler=1,r.status=Ir,Ne(e),r.pending!==0)return r.last_flush=-1,he}if(r.status===oc){if(e.adler=0,X(r,31),X(r,139),X(r,8),r.gzhead)X(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)),X(r,r.gzhead.time&255),X(r,r.gzhead.time>>8&255),X(r,r.gzhead.time>>16&255),X(r,r.gzhead.time>>24&255),X(r,r.level===9?2:r.strategy>=Po||r.level<2?4:0),X(r,r.gzhead.os&255),r.gzhead.extra&&r.gzhead.extra.length&&(X(r,r.gzhead.extra.length&255),X(r,r.gzhead.extra.length>>8&255)),r.gzhead.hcrc&&(e.adler=fe(e.adler,r.pending_buf,r.pending,0)),r.gzindex=0,r.status=jl;else if(X(r,0),X(r,0),X(r,0),X(r,0),X(r,0),X(r,r.level===9?2:r.strategy>=Po||r.level<2?4:0),X(r,ag),r.status=Ir,Ne(e),r.pending!==0)return r.last_flush=-1,he}if(r.status===jl){if(r.gzhead.extra){let i=r.pending,s=(r.gzhead.extra.length&65535)-r.gzindex;for(;r.pending+s>r.pending_buf_size;){let a=r.pending_buf_size-r.pending;if(r.pending_buf.set(r.gzhead.extra.subarray(r.gzindex,r.gzindex+a),r.pending),r.pending=r.pending_buf_size,r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),r.gzindex+=a,Ne(e),r.pending!==0)return r.last_flush=-1,he;i=0,s-=a}let o=new Uint8Array(r.gzhead.extra);r.pending_buf.set(o.subarray(r.gzindex,r.gzindex+s),r.pending),r.pending+=s,r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Ql}if(r.status===Ql){if(r.gzhead.name){let i=r.pending,s;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),Ne(e),r.pending!==0)return r.last_flush=-1,he;i=0}r.gzindex<r.gzhead.name.length?s=r.gzhead.name.charCodeAt(r.gzindex++)&255:s=0,X(r,s)}while(s!==0);r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),r.gzindex=0}r.status=Jl}if(r.status===Jl){if(r.gzhead.comment){let i=r.pending,s;do{if(r.pending===r.pending_buf_size){if(r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i)),Ne(e),r.pending!==0)return r.last_flush=-1,he;i=0}r.gzindex<r.gzhead.comment.length?s=r.gzhead.comment.charCodeAt(r.gzindex++)&255:s=0,X(r,s)}while(s!==0);r.gzhead.hcrc&&r.pending>i&&(e.adler=fe(e.adler,r.pending_buf,r.pending-i,i))}r.status=ec}if(r.status===ec){if(r.gzhead.hcrc){if(r.pending+2>r.pending_buf_size&&(Ne(e),r.pending!==0))return r.last_flush=-1,he;X(r,e.adler&255),X(r,e.adler>>8&255),e.adler=0}if(r.status=Ir,Ne(e),r.pending!==0)return r.last_flush=-1,he}if(e.avail_in!==0||r.lookahead!==0||t!==or&&r.status!==Xi){let i=r.level===0?Su(r,t):r.strategy===Po?ug(r,t):r.strategy===$1?dg(r,t):Ki[r.level].func(r,t);if((i===zr||i===Rn)&&(r.status=Xi),i===Te||i===zr)return e.avail_out===0&&(r.last_flush=-1),he;if(i===In&&(t===V1?H1(r):t!==L0&&(Yl(r,0,0,!1),t===G1&&(nr(r.head),r.lookahead===0&&(r.strstart=0,r.block_start=0,r.insert=0))),Ne(e),e.avail_out===0))return r.last_flush=-1,he}return t!==je?he:r.wrap<=0?T0:(r.wrap===2?(X(r,e.adler&255),X(r,e.adler>>8&255),X(r,e.adler>>16&255),X(r,e.adler>>24&255),X(r,e.total_in&255),X(r,e.total_in>>8&255),X(r,e.total_in>>16&255),X(r,e.total_in>>24&255)):(Wi(r,e.adler>>>16),Wi(r,e.adler&65535)),Ne(e),r.wrap>0&&(r.wrap=-r.wrap),r.pending!==0?he:T0)},yg=e=>{if(ss(e))return pt;let t=e.state.status;return e.state=null,t===Ir?Rr(e,W1):he},xg=(e,t)=>{let r=t.length;if(ss(e))return pt;let n=e.state,i=n.wrap;if(i===2||i===1&&n.status!==En||n.lookahead)return pt;if(i===1&&(e.adler=es(e.adler,t,r,0)),n.wrap=0,r>=n.w_size){i===0&&(nr(n.head),n.strstart=0,n.block_start=0,n.insert=0);let d=new Uint8Array(n.w_size);d.set(t.subarray(r-n.w_size,r),0),t=d,r=n.w_size}let s=e.avail_in,o=e.next_in,a=e.input;for(e.avail_in=r,e.next_in=0,e.input=t,Ln(n);n.lookahead>=V;){let d=n.strstart,l=n.lookahead-(V-1);do n.ins_h=ar(n,n.ins_h,n.window[d+V-1]),n.prev[d&n.w_mask]=n.head[n.ins_h],n.head[n.ins_h]=d,d++;while(--l);n.strstart=d,n.lookahead=V-1,Ln(n)}return n.strstart+=n.lookahead,n.block_start=n.strstart,n.insert=n.lookahead,n.lookahead=0,n.match_length=n.prev_length=V-1,n.match_available=0,e.next_in=o,e.input=a,e.avail_in=s,n.wrap=i,he},_g=pg,bg=Mu,vg=Au,Sg=wu,wg=mg,Ag=gg,Mg=yg,Eg=xg,Lg="pako deflate (from Nodeca project)",Zi={deflateInit:_g,deflateInit2:bg,deflateReset:vg,deflateResetKeep:Sg,deflateSetHeader:wg,deflate:Ag,deflateEnd:Mg,deflateSetDictionary:Eg,deflateInfo:Lg},Tg=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Ig=function(e){let t=Array.prototype.slice.call(arguments,1);for(;t.length;){let r=t.shift();if(r){if(typeof r!="object")throw new TypeError(r+"must be non-object");for(let n in r)Tg(r,n)&&(e[n]=r[n])}}return e},Rg=e=>{let t=0;for(let n=0,i=e.length;n<i;n++)t+=e[n].length;let r=new Uint8Array(t);for(let n=0,i=0,s=e.length;n<s;n++){let o=e[n];r.set(o,i),i+=o.length}return r},Zo={assign:Ig,flattenChunks:Rg},Eu=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch{Eu=!1}var ts=new Uint8Array(256);for(let e=0;e<256;e++)ts[e]=e>=252?6:e>=248?5:e>=240?4:e>=224?3:e>=192?2:1;ts[254]=ts[254]=1;var Cg=e=>{if(typeof TextEncoder=="function"&&TextEncoder.prototype.encode)return new TextEncoder().encode(e);let t,r,n,i,s,o=e.length,a=0;for(i=0;i<o;i++)r=e.charCodeAt(i),(r&64512)===55296&&i+1<o&&(n=e.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),a+=r<128?1:r<2048?2:r<65536?3:4;for(t=new Uint8Array(a),s=0,i=0;s<a;i++)r=e.charCodeAt(i),(r&64512)===55296&&i+1<o&&(n=e.charCodeAt(i+1),(n&64512)===56320&&(r=65536+(r-55296<<10)+(n-56320),i++)),r<128?t[s++]=r:r<2048?(t[s++]=192|r>>>6,t[s++]=128|r&63):r<65536?(t[s++]=224|r>>>12,t[s++]=128|r>>>6&63,t[s++]=128|r&63):(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63,t[s++]=128|r>>>6&63,t[s++]=128|r&63);return t},zg=(e,t)=>{if(t<65534&&e.subarray&&Eu)return String.fromCharCode.apply(null,e.length===t?e:e.subarray(0,t));let r="";for(let n=0;n<t;n++)r+=String.fromCharCode(e[n]);return r},Fg=(e,t)=>{let r=t||e.length;if(typeof TextDecoder=="function"&&TextDecoder.prototype.decode)return new TextDecoder().decode(e.subarray(0,t));let n,i,s=new Array(r*2);for(i=0,n=0;n<r;){let o=e[n++];if(o<128){s[i++]=o;continue}let a=ts[o];if(a>4){s[i++]=65533,n+=a-1;continue}for(o&=a===2?31:a===3?15:7;a>1&&n<r;)o=o<<6|e[n++]&63,a--;if(a>1){s[i++]=65533;continue}o<65536?s[i++]=o:(o-=65536,s[i++]=55296|o>>10&1023,s[i++]=56320|o&1023)}return zg(s,i)},kg=(e,t)=>{t=t||e.length,t>e.length&&(t=e.length);let r=t-1;for(;r>=0&&(e[r]&192)===128;)r--;return r<0||r===0?t:r+ts[e[r]]>t?r:t},rs={string2buf:Cg,buf2string:Fg,utf8border:kg};function Bg(){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 Lu=Bg,Tu=Object.prototype.toString,{Z_NO_FLUSH:Dg,Z_SYNC_FLUSH:Og,Z_FULL_FLUSH:Pg,Z_FINISH:Ng,Z_OK:Xo,Z_STREAM_END:Ug,Z_DEFAULT_COMPRESSION:Hg,Z_DEFAULT_STRATEGY:Vg,Z_DEFLATED:Gg}=kr;function os(e){this.options=Zo.assign({level:Hg,method:Gg,chunkSize:16384,windowBits:15,memLevel:8,strategy:Vg},e||{});let t=this.options;t.raw&&t.windowBits>0?t.windowBits=-t.windowBits:t.gzip&&t.windowBits>0&&t.windowBits<16&&(t.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new Lu,this.strm.avail_out=0;let r=Zi.deflateInit2(this.strm,t.level,t.method,t.windowBits,t.memLevel,t.strategy);if(r!==Xo)throw new Error(Cr[r]);if(t.header&&Zi.deflateSetHeader(this.strm,t.header),t.dictionary){let n;if(typeof t.dictionary=="string"?n=rs.string2buf(t.dictionary):Tu.call(t.dictionary)==="[object ArrayBuffer]"?n=new Uint8Array(t.dictionary):n=t.dictionary,r=Zi.deflateSetDictionary(this.strm,n),r!==Xo)throw new Error(Cr[r]);this._dict_set=!0}}os.prototype.push=function(e,t){let r=this.strm,n=this.options.chunkSize,i,s;if(this.ended)return!1;for(t===~~t?s=t:s=t===!0?Ng:Dg,typeof e=="string"?r.input=rs.string2buf(e):Tu.call(e)==="[object ArrayBuffer]"?r.input=new Uint8Array(e):r.input=e,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),(s===Og||s===Pg)&&r.avail_out<=6){this.onData(r.output.subarray(0,r.next_out)),r.avail_out=0;continue}if(i=Zi.deflate(r,s),i===Ug)return r.next_out>0&&this.onData(r.output.subarray(0,r.next_out)),i=Zi.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===Xo;if(r.avail_out===0){this.onData(r.output);continue}if(s>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};os.prototype.onData=function(e){this.chunks.push(e)};os.prototype.onEnd=function(e){e===Xo&&(this.result=Zo.flattenChunks(this.chunks)),this.chunks=[],this.err=e,this.msg=this.strm.msg};function ac(e,t){let r=new os(t);if(r.push(e,!0),r.err)throw r.msg||Cr[r.err];return r.result}function Wg(e,t){return t=t||{},t.raw=!0,ac(e,t)}function Xg(e,t){return t=t||{},t.gzip=!0,ac(e,t)}var Kg=os,$g=ac,Zg=Wg,Yg=Xg,qg=kr,jg={Deflate:Kg,deflate:$g,deflateRaw:Zg,gzip:Yg,constants:qg},No=16209,Qg=16191,Jg=function(t,r){let n,i,s,o,a,d,l,c,h,u,f,m,g,p,y,S,_,x,b,A,v,E,L,w,T=t.state;n=t.next_in,L=t.input,i=n+(t.avail_in-5),s=t.next_out,w=t.output,o=s-(r-t.avail_out),a=s+(t.avail_out-257),d=T.dmax,l=T.wsize,c=T.whave,h=T.wnext,u=T.window,f=T.hold,m=T.bits,g=T.lencode,p=T.distcode,y=(1<<T.lenbits)-1,S=(1<<T.distbits)-1;e:do{m<15&&(f+=L[n++]<<m,m+=8,f+=L[n++]<<m,m+=8),_=g[f&y];t:for(;;){if(x=_>>>24,f>>>=x,m-=x,x=_>>>16&255,x===0)w[s++]=_&65535;else if(x&16){b=_&65535,x&=15,x&&(m<x&&(f+=L[n++]<<m,m+=8),b+=f&(1<<x)-1,f>>>=x,m-=x),m<15&&(f+=L[n++]<<m,m+=8,f+=L[n++]<<m,m+=8),_=p[f&S];r:for(;;){if(x=_>>>24,f>>>=x,m-=x,x=_>>>16&255,x&16){if(A=_&65535,x&=15,m<x&&(f+=L[n++]<<m,m+=8,m<x&&(f+=L[n++]<<m,m+=8)),A+=f&(1<<x)-1,A>d){t.msg="invalid distance too far back",T.mode=No;break e}if(f>>>=x,m-=x,x=s-o,A>x){if(x=A-x,x>c&&T.sane){t.msg="invalid distance too far back",T.mode=No;break e}if(v=0,E=u,h===0){if(v+=l-x,x<b){b-=x;do w[s++]=u[v++];while(--x);v=s-A,E=w}}else if(h<x){if(v+=l+h-x,x-=h,x<b){b-=x;do w[s++]=u[v++];while(--x);if(v=0,h<b){x=h,b-=x;do w[s++]=u[v++];while(--x);v=s-A,E=w}}}else if(v+=h-x,x<b){b-=x;do w[s++]=u[v++];while(--x);v=s-A,E=w}for(;b>2;)w[s++]=E[v++],w[s++]=E[v++],w[s++]=E[v++],b-=3;b&&(w[s++]=E[v++],b>1&&(w[s++]=E[v++]))}else{v=s-A;do w[s++]=w[v++],w[s++]=w[v++],w[s++]=w[v++],b-=3;while(b>2);b&&(w[s++]=w[v++],b>1&&(w[s++]=w[v++]))}}else if((x&64)===0){_=p[(_&65535)+(f&(1<<x)-1)];continue r}else{t.msg="invalid distance code",T.mode=No;break e}break}}else if((x&64)===0){_=g[(_&65535)+(f&(1<<x)-1)];continue t}else if(x&32){T.mode=Qg;break e}else{t.msg="invalid literal/length code",T.mode=No;break e}break}}while(n<i&&s<a);b=m>>3,n-=b,m-=b<<3,f&=(1<<m)-1,t.next_in=n,t.next_out=s,t.avail_in=n<i?5+(i-n):5-(n-i),t.avail_out=s<a?257+(a-s):257-(s-a),T.hold=f,T.bits=m},An=15,R0=852,C0=592,z0=0,Nl=1,F0=2,ey=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]),ty=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]),ry=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]),ny=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]),iy=(e,t,r,n,i,s,o,a)=>{let d=a.bits,l=0,c=0,h=0,u=0,f=0,m=0,g=0,p=0,y=0,S=0,_,x,b,A,v,E=null,L,w=new Uint16Array(An+1),T=new Uint16Array(An+1),z=null,U,C,$;for(l=0;l<=An;l++)w[l]=0;for(c=0;c<n;c++)w[t[r+c]]++;for(f=d,u=An;u>=1&&w[u]===0;u--);if(f>u&&(f=u),u===0)return i[s++]=1<<24|64<<16|0,i[s++]=1<<24|64<<16|0,a.bits=1,0;for(h=1;h<u&&w[h]===0;h++);for(f<h&&(f=h),p=1,l=1;l<=An;l++)if(p<<=1,p-=w[l],p<0)return-1;if(p>0&&(e===z0||u!==1))return-1;for(T[1]=0,l=1;l<An;l++)T[l+1]=T[l]+w[l];for(c=0;c<n;c++)t[r+c]!==0&&(o[T[t[r+c]]++]=c);if(e===z0?(E=z=o,L=20):e===Nl?(E=ey,z=ty,L=257):(E=ry,z=ny,L=0),S=0,c=0,l=h,v=s,m=f,g=0,b=-1,y=1<<f,A=y-1,e===Nl&&y>R0||e===F0&&y>C0)return 1;for(;;){U=l-g,o[c]+1<L?(C=0,$=o[c]):o[c]>=L?(C=z[o[c]-L],$=E[o[c]-L]):(C=96,$=0),_=1<<l-g,x=1<<m,h=x;do x-=_,i[v+(S>>g)+x]=U<<24|C<<16|$|0;while(x!==0);for(_=1<<l-1;S&_;)_>>=1;if(_!==0?(S&=_-1,S+=_):S=0,c++,--w[l]===0){if(l===u)break;l=t[r+o[c]]}if(l>f&&(S&A)!==b){for(g===0&&(g=f),v+=h,m=l-g,p=1<<m;m+g<u&&(p-=w[m+g],!(p<=0));)m++,p<<=1;if(y+=1<<m,e===Nl&&y>R0||e===F0&&y>C0)return 1;b=S&A,i[b]=f<<24|m<<16|v-s|0}}return S!==0&&(i[v+S]=l-g<<24|64<<16|0),a.bits=f,0},Yi=iy,sy=0,Iu=1,Ru=2,{Z_FINISH:k0,Z_BLOCK:oy,Z_TREES:Uo,Z_OK:Fr,Z_STREAM_END:ay,Z_NEED_DICT:ly,Z_STREAM_ERROR:Qe,Z_DATA_ERROR:Cu,Z_MEM_ERROR:zu,Z_BUF_ERROR:cy,Z_DEFLATED:B0}=kr,Yo=16180,D0=16181,O0=16182,P0=16183,N0=16184,U0=16185,H0=16186,V0=16187,G0=16188,W0=16189,Ko=16190,Rt=16191,Ul=16192,X0=16193,Hl=16194,K0=16195,$0=16196,Z0=16197,Y0=16198,Ho=16199,Vo=16200,q0=16201,j0=16202,Q0=16203,J0=16204,eu=16205,Vl=16206,tu=16207,ru=16208,ne=16209,Fu=16210,ku=16211,dy=852,uy=592,fy=15,hy=fy,nu=e=>(e>>>24&255)+(e>>>8&65280)+((e&65280)<<8)+((e&255)<<24);function my(){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 Br=e=>{if(!e)return 1;let t=e.state;return!t||t.strm!==e||t.mode<Yo||t.mode>ku?1:0},Bu=e=>{if(Br(e))return Qe;let t=e.state;return e.total_in=e.total_out=t.total=0,e.msg="",t.wrap&&(e.adler=t.wrap&1),t.mode=Yo,t.last=0,t.havedict=0,t.flags=-1,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new Int32Array(dy),t.distcode=t.distdyn=new Int32Array(uy),t.sane=1,t.back=-1,Fr},Du=e=>{if(Br(e))return Qe;let t=e.state;return t.wsize=0,t.whave=0,t.wnext=0,Bu(e)},Ou=(e,t)=>{let r;if(Br(e))return Qe;let n=e.state;return t<0?(r=0,t=-t):(r=(t>>4)+5,t<48&&(t&=15)),t&&(t<8||t>15)?Qe:(n.window!==null&&n.wbits!==t&&(n.window=null),n.wrap=r,n.wbits=t,Du(e))},Pu=(e,t)=>{if(!e)return Qe;let r=new my;e.state=r,r.strm=e,r.window=null,r.mode=Yo;let n=Ou(e,t);return n!==Fr&&(e.state=null),n},py=e=>Pu(e,hy),iu=!0,Gl,Wl,gy=e=>{if(iu){Gl=new Int32Array(512),Wl=new Int32Array(32);let t=0;for(;t<144;)e.lens[t++]=8;for(;t<256;)e.lens[t++]=9;for(;t<280;)e.lens[t++]=7;for(;t<288;)e.lens[t++]=8;for(Yi(Iu,e.lens,0,288,Gl,0,e.work,{bits:9}),t=0;t<32;)e.lens[t++]=5;Yi(Ru,e.lens,0,32,Wl,0,e.work,{bits:5}),iu=!1}e.lencode=Gl,e.lenbits=9,e.distcode=Wl,e.distbits=5},Nu=(e,t,r,n)=>{let i,s=e.state;return s.window===null&&(s.wsize=1<<s.wbits,s.wnext=0,s.whave=0,s.window=new Uint8Array(s.wsize)),n>=s.wsize?(s.window.set(t.subarray(r-s.wsize,r),0),s.wnext=0,s.whave=s.wsize):(i=s.wsize-s.wnext,i>n&&(i=n),s.window.set(t.subarray(r-n,r-n+i),s.wnext),n-=i,n?(s.window.set(t.subarray(r-n,r),0),s.wnext=n,s.whave=s.wsize):(s.wnext+=i,s.wnext===s.wsize&&(s.wnext=0),s.whave<s.wsize&&(s.whave+=i))),0},yy=(e,t)=>{let r,n,i,s,o,a,d,l,c,h,u,f,m,g,p=0,y,S,_,x,b,A,v,E,L=new Uint8Array(4),w,T,z=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(Br(e)||!e.output||!e.input&&e.avail_in!==0)return Qe;r=e.state,r.mode===Rt&&(r.mode=Ul),o=e.next_out,i=e.output,d=e.avail_out,s=e.next_in,n=e.input,a=e.avail_in,l=r.hold,c=r.bits,h=a,u=d,E=Fr;e:for(;;)switch(r.mode){case Yo:if(r.wrap===0){r.mode=Ul;break}for(;c<16;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(r.wrap&2&&l===35615){r.wbits===0&&(r.wbits=15),r.check=0,L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0),l=0,c=0,r.mode=D0;break}if(r.head&&(r.head.done=!1),!(r.wrap&1)||(((l&255)<<8)+(l>>8))%31){e.msg="incorrect header check",r.mode=ne;break}if((l&15)!==B0){e.msg="unknown compression method",r.mode=ne;break}if(l>>>=4,c-=4,v=(l&15)+8,r.wbits===0&&(r.wbits=v),v>15||v>r.wbits){e.msg="invalid window size",r.mode=ne;break}r.dmax=1<<r.wbits,r.flags=0,e.adler=r.check=1,r.mode=l&512?W0:Rt,l=0,c=0;break;case D0:for(;c<16;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(r.flags=l,(r.flags&255)!==B0){e.msg="unknown compression method",r.mode=ne;break}if(r.flags&57344){e.msg="unknown header flags set",r.mode=ne;break}r.head&&(r.head.text=l>>8&1),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0)),l=0,c=0,r.mode=O0;case O0:for(;c<32;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}r.head&&(r.head.time=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,L[2]=l>>>16&255,L[3]=l>>>24&255,r.check=fe(r.check,L,4,0)),l=0,c=0,r.mode=P0;case P0:for(;c<16;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}r.head&&(r.head.xflags=l&255,r.head.os=l>>8),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0)),l=0,c=0,r.mode=N0;case N0:if(r.flags&1024){for(;c<16;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}r.length=l,r.head&&(r.head.extra_len=l),r.flags&512&&r.wrap&4&&(L[0]=l&255,L[1]=l>>>8&255,r.check=fe(r.check,L,2,0)),l=0,c=0}else r.head&&(r.head.extra=null);r.mode=U0;case U0:if(r.flags&1024&&(f=r.length,f>a&&(f=a),f&&(r.head&&(v=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Uint8Array(r.head.extra_len)),r.head.extra.set(n.subarray(s,s+f),v)),r.flags&512&&r.wrap&4&&(r.check=fe(r.check,n,f,s)),a-=f,s+=f,r.length-=f),r.length))break e;r.length=0,r.mode=H0;case H0:if(r.flags&2048){if(a===0)break e;f=0;do v=n[s+f++],r.head&&v&&r.length<65536&&(r.head.name+=String.fromCharCode(v));while(v&&f<a);if(r.flags&512&&r.wrap&4&&(r.check=fe(r.check,n,f,s)),a-=f,s+=f,v)break e}else r.head&&(r.head.name=null);r.length=0,r.mode=V0;case V0:if(r.flags&4096){if(a===0)break e;f=0;do v=n[s+f++],r.head&&v&&r.length<65536&&(r.head.comment+=String.fromCharCode(v));while(v&&f<a);if(r.flags&512&&r.wrap&4&&(r.check=fe(r.check,n,f,s)),a-=f,s+=f,v)break e}else r.head&&(r.head.comment=null);r.mode=G0;case G0:if(r.flags&512){for(;c<16;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(r.wrap&4&&l!==(r.check&65535)){e.msg="header crc mismatch",r.mode=ne;break}l=0,c=0}r.head&&(r.head.hcrc=r.flags>>9&1,r.head.done=!0),e.adler=r.check=0,r.mode=Rt;break;case W0:for(;c<32;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}e.adler=r.check=nu(l),l=0,c=0,r.mode=Ko;case Ko:if(r.havedict===0)return e.next_out=o,e.avail_out=d,e.next_in=s,e.avail_in=a,r.hold=l,r.bits=c,ly;e.adler=r.check=1,r.mode=Rt;case Rt:if(t===oy||t===Uo)break e;case Ul:if(r.last){l>>>=c&7,c-=c&7,r.mode=Vl;break}for(;c<3;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}switch(r.last=l&1,l>>>=1,c-=1,l&3){case 0:r.mode=X0;break;case 1:if(gy(r),r.mode=Ho,t===Uo){l>>>=2,c-=2;break e}break;case 2:r.mode=$0;break;case 3:e.msg="invalid block type",r.mode=ne}l>>>=2,c-=2;break;case X0:for(l>>>=c&7,c-=c&7;c<32;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if((l&65535)!==(l>>>16^65535)){e.msg="invalid stored block lengths",r.mode=ne;break}if(r.length=l&65535,l=0,c=0,r.mode=Hl,t===Uo)break e;case Hl:r.mode=K0;case K0:if(f=r.length,f){if(f>a&&(f=a),f>d&&(f=d),f===0)break e;i.set(n.subarray(s,s+f),o),a-=f,s+=f,d-=f,o+=f,r.length-=f;break}r.mode=Rt;break;case $0:for(;c<14;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(r.nlen=(l&31)+257,l>>>=5,c-=5,r.ndist=(l&31)+1,l>>>=5,c-=5,r.ncode=(l&15)+4,l>>>=4,c-=4,r.nlen>286||r.ndist>30){e.msg="too many length or distance symbols",r.mode=ne;break}r.have=0,r.mode=Z0;case Z0:for(;r.have<r.ncode;){for(;c<3;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}r.lens[z[r.have++]]=l&7,l>>>=3,c-=3}for(;r.have<19;)r.lens[z[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,w={bits:r.lenbits},E=Yi(sy,r.lens,0,19,r.lencode,0,r.work,w),r.lenbits=w.bits,E){e.msg="invalid code lengths set",r.mode=ne;break}r.have=0,r.mode=Y0;case Y0:for(;r.have<r.nlen+r.ndist;){for(;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,S=p>>>16&255,_=p&65535,!(y<=c);){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(_<16)l>>>=y,c-=y,r.lens[r.have++]=_;else{if(_===16){for(T=y+2;c<T;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(l>>>=y,c-=y,r.have===0){e.msg="invalid bit length repeat",r.mode=ne;break}v=r.lens[r.have-1],f=3+(l&3),l>>>=2,c-=2}else if(_===17){for(T=y+3;c<T;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}l>>>=y,c-=y,v=0,f=3+(l&7),l>>>=3,c-=3}else{for(T=y+7;c<T;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}l>>>=y,c-=y,v=0,f=11+(l&127),l>>>=7,c-=7}if(r.have+f>r.nlen+r.ndist){e.msg="invalid bit length repeat",r.mode=ne;break}for(;f--;)r.lens[r.have++]=v}}if(r.mode===ne)break;if(r.lens[256]===0){e.msg="invalid code -- missing end-of-block",r.mode=ne;break}if(r.lenbits=9,w={bits:r.lenbits},E=Yi(Iu,r.lens,0,r.nlen,r.lencode,0,r.work,w),r.lenbits=w.bits,E){e.msg="invalid literal/lengths set",r.mode=ne;break}if(r.distbits=6,r.distcode=r.distdyn,w={bits:r.distbits},E=Yi(Ru,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,w),r.distbits=w.bits,E){e.msg="invalid distances set",r.mode=ne;break}if(r.mode=Ho,t===Uo)break e;case Ho:r.mode=Vo;case Vo:if(a>=6&&d>=258){e.next_out=o,e.avail_out=d,e.next_in=s,e.avail_in=a,r.hold=l,r.bits=c,Jg(e,u),o=e.next_out,i=e.output,d=e.avail_out,s=e.next_in,n=e.input,a=e.avail_in,l=r.hold,c=r.bits,r.mode===Rt&&(r.back=-1);break}for(r.back=0;p=r.lencode[l&(1<<r.lenbits)-1],y=p>>>24,S=p>>>16&255,_=p&65535,!(y<=c);){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(S&&(S&240)===0){for(x=y,b=S,A=_;p=r.lencode[A+((l&(1<<x+b)-1)>>x)],y=p>>>24,S=p>>>16&255,_=p&65535,!(x+y<=c);){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}l>>>=x,c-=x,r.back+=x}if(l>>>=y,c-=y,r.back+=y,r.length=_,S===0){r.mode=eu;break}if(S&32){r.back=-1,r.mode=Rt;break}if(S&64){e.msg="invalid literal/length code",r.mode=ne;break}r.extra=S&15,r.mode=q0;case q0:if(r.extra){for(T=r.extra;c<T;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}r.length+=l&(1<<r.extra)-1,l>>>=r.extra,c-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=j0;case j0:for(;p=r.distcode[l&(1<<r.distbits)-1],y=p>>>24,S=p>>>16&255,_=p&65535,!(y<=c);){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if((S&240)===0){for(x=y,b=S,A=_;p=r.distcode[A+((l&(1<<x+b)-1)>>x)],y=p>>>24,S=p>>>16&255,_=p&65535,!(x+y<=c);){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}l>>>=x,c-=x,r.back+=x}if(l>>>=y,c-=y,r.back+=y,S&64){e.msg="invalid distance code",r.mode=ne;break}r.offset=_,r.extra=S&15,r.mode=Q0;case Q0:if(r.extra){for(T=r.extra;c<T;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}r.offset+=l&(1<<r.extra)-1,l>>>=r.extra,c-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){e.msg="invalid distance too far back",r.mode=ne;break}r.mode=J0;case J0:if(d===0)break e;if(f=u-d,r.offset>f){if(f=r.offset-f,f>r.whave&&r.sane){e.msg="invalid distance too far back",r.mode=ne;break}f>r.wnext?(f-=r.wnext,m=r.wsize-f):m=r.wnext-f,f>r.length&&(f=r.length),g=r.window}else g=i,m=o-r.offset,f=r.length;f>d&&(f=d),d-=f,r.length-=f;do i[o++]=g[m++];while(--f);r.length===0&&(r.mode=Vo);break;case eu:if(d===0)break e;i[o++]=r.length,d--,r.mode=Vo;break;case Vl:if(r.wrap){for(;c<32;){if(a===0)break e;a--,l|=n[s++]<<c,c+=8}if(u-=d,e.total_out+=u,r.total+=u,r.wrap&4&&u&&(e.adler=r.check=r.flags?fe(r.check,i,u,o-u):es(r.check,i,u,o-u)),u=d,r.wrap&4&&(r.flags?l:nu(l))!==r.check){e.msg="incorrect data check",r.mode=ne;break}l=0,c=0}r.mode=tu;case tu:if(r.wrap&&r.flags){for(;c<32;){if(a===0)break e;a--,l+=n[s++]<<c,c+=8}if(r.wrap&4&&l!==(r.total&4294967295)){e.msg="incorrect length check",r.mode=ne;break}l=0,c=0}r.mode=ru;case ru:E=ay;break e;case ne:E=Cu;break e;case Fu:return zu;case ku:default:return Qe}return e.next_out=o,e.avail_out=d,e.next_in=s,e.avail_in=a,r.hold=l,r.bits=c,(r.wsize||u!==e.avail_out&&r.mode<ne&&(r.mode<Vl||t!==k0))&&Nu(e,e.output,e.next_out,u-e.avail_out),h-=e.avail_in,u-=e.avail_out,e.total_in+=h,e.total_out+=u,r.total+=u,r.wrap&4&&u&&(e.adler=r.check=r.flags?fe(r.check,i,u,e.next_out-u):es(r.check,i,u,e.next_out-u)),e.data_type=r.bits+(r.last?64:0)+(r.mode===Rt?128:0)+(r.mode===Ho||r.mode===Hl?256:0),(h===0&&u===0||t===k0)&&E===Fr&&(E=cy),E},xy=e=>{if(Br(e))return Qe;let t=e.state;return t.window&&(t.window=null),e.state=null,Fr},_y=(e,t)=>{if(Br(e))return Qe;let r=e.state;return(r.wrap&2)===0?Qe:(r.head=t,t.done=!1,Fr)},by=(e,t)=>{let r=t.length,n,i,s;return Br(e)||(n=e.state,n.wrap!==0&&n.mode!==Ko)?Qe:n.mode===Ko&&(i=1,i=es(i,t,r,0),i!==n.check)?Cu:(s=Nu(e,t,r,r),s?(n.mode=Fu,zu):(n.havedict=1,Fr))},vy=Du,Sy=Ou,wy=Bu,Ay=py,My=Pu,Ey=yy,Ly=xy,Ty=_y,Iy=by,Ry="pako inflate (from Nodeca project)",zt={inflateReset:vy,inflateReset2:Sy,inflateResetKeep:wy,inflateInit:Ay,inflateInit2:My,inflate:Ey,inflateEnd:Ly,inflateGetHeader:Ty,inflateSetDictionary:Iy,inflateInfo:Ry};function Cy(){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 zy=Cy,Uu=Object.prototype.toString,{Z_NO_FLUSH:Fy,Z_FINISH:ky,Z_OK:ns,Z_STREAM_END:Xl,Z_NEED_DICT:Kl,Z_STREAM_ERROR:By,Z_DATA_ERROR:su,Z_MEM_ERROR:Dy}=kr;function as(e){this.options=Zo.assign({chunkSize:1024*64,windowBits:15,to:""},e||{});let t=this.options;t.raw&&t.windowBits>=0&&t.windowBits<16&&(t.windowBits=-t.windowBits,t.windowBits===0&&(t.windowBits=-15)),t.windowBits>=0&&t.windowBits<16&&!(e&&e.windowBits)&&(t.windowBits+=32),t.windowBits>15&&t.windowBits<48&&(t.windowBits&15)===0&&(t.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new Lu,this.strm.avail_out=0;let r=zt.inflateInit2(this.strm,t.windowBits);if(r!==ns)throw new Error(Cr[r]);if(this.header=new zy,zt.inflateGetHeader(this.strm,this.header),t.dictionary&&(typeof t.dictionary=="string"?t.dictionary=rs.string2buf(t.dictionary):Uu.call(t.dictionary)==="[object ArrayBuffer]"&&(t.dictionary=new Uint8Array(t.dictionary)),t.raw&&(r=zt.inflateSetDictionary(this.strm,t.dictionary),r!==ns)))throw new Error(Cr[r])}as.prototype.push=function(e,t){let r=this.strm,n=this.options.chunkSize,i=this.options.dictionary,s,o,a;if(this.ended)return!1;for(t===~~t?o=t:o=t===!0?ky:Fy,Uu.call(e)==="[object ArrayBuffer]"?r.input=new Uint8Array(e):r.input=e,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),s=zt.inflate(r,o),s===Kl&&i&&(s=zt.inflateSetDictionary(r,i),s===ns?s=zt.inflate(r,o):s===su&&(s=Kl));r.avail_in>0&&s===Xl&&r.state.wrap>0&&e[r.next_in]!==0;)zt.inflateReset(r),s=zt.inflate(r,o);switch(s){case By:case su:case Kl:case Dy:return this.onEnd(s),this.ended=!0,!1}if(a=r.avail_out,r.next_out&&(r.avail_out===0||s===Xl))if(this.options.to==="string"){let d=rs.utf8border(r.output,r.next_out),l=r.next_out-d,c=rs.buf2string(r.output,d);r.next_out=l,r.avail_out=n-l,l&&r.output.set(r.output.subarray(d,d+l),0),this.onData(c)}else this.onData(r.output.length===r.next_out?r.output:r.output.subarray(0,r.next_out));if(!(s===ns&&a===0)){if(s===Xl)return s=zt.inflateEnd(this.strm),this.onEnd(s),this.ended=!0,!0;if(r.avail_in===0)break}}return!0};as.prototype.onData=function(e){this.chunks.push(e)};as.prototype.onEnd=function(e){e===ns&&(this.options.to==="string"?this.result=this.chunks.join(""):this.result=Zo.flattenChunks(this.chunks)),this.chunks=[],this.err=e,this.msg=this.strm.msg};function lc(e,t){let r=new as(t);if(r.push(e),r.err)throw r.msg||Cr[r.err];return r.result}function Oy(e,t){return t=t||{},t.raw=!0,lc(e,t)}var Py=as,Ny=lc,Uy=Oy,Hy=lc,Vy=kr,Gy={Inflate:Py,inflate:Ny,inflateRaw:Uy,ungzip:Hy,constants:Vy},{Deflate:Wy,deflate:Xy,deflateRaw:Ky,gzip:$y}=jg,{Inflate:Zy,inflate:Yy,inflateRaw:qy,ungzip:jy}=Gy,Qy=Wy,Jy=Xy,ex=Ky,tx=$y,rx=Zy,nx=Yy,ix=qy,sx=jy,ox=kr,cc={Deflate:Qy,deflate:Jy,deflateRaw:ex,gzip:tx,Inflate:rx,inflate:nx,inflateRaw:ix,ungzip:sx,constants:ox};var qo=2023,Qo=1,Jo=2,ea=4,ta=8,ra=16,na=32,dc=64,ax=128,lx=256,ia=512,sa=1024,oa=2048,ls=4096,uc=8192,cs=16384,cx=32768,ds=65536,aa=1<<17,us=1<<18,fs=1<<19,la=1<<20,ca=1<<21,da=1<<22,dx=1<<23,ua=1<<24,hs=1<<25,fa=1<<26,ha=1<<27,fc=1<<28,hc=1<<29,mc=1<<30,ux=-2147483648,pc=1,gc=2,yc=4;var fx=1,hx=2,mx=128,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}),jo=()=>({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}),Or=class e{constructor(t,r){this.protocolVersion=0;this.isDemo=fx;this.stream=t,this.handler=r}setProtocolVersion(t){this.protocolVersion=t}getProtocolVersion(){return this.protocolVersion}translateCommand(t){if(this.protocolVersion===0){if(t===7)return F.serverdata;if(t===12)return F.serverdata}return this.protocolVersion===qo?t:this.protocolVersion===34||this.protocolVersion===25?t<=F.frame?t:t===22?F.playerinfo:t===23?F.packetentities:F.bad:(this.protocolVersion===0,t)}parseMessage(){for(;this.stream.hasMore();){let t=this.stream.readByte();if(t===-1)break;let r=t;t=this.translateCommand(t);try{switch(t){case F.bad:return;case F.nop:break;case F.disconnect:this.handler&&this.handler.onDisconnect&&this.handler.onDisconnect();break;case F.reconnect:this.handler&&this.handler.onReconnect&&this.handler.onReconnect();break;case F.print:this.parsePrint();break;case F.serverdata:this.parseServerData();break;case F.configstring:this.parseConfigString();break;case F.spawnbaseline:this.parseSpawnBaseline();break;case F.centerprint:this.parseCenterPrint();break;case F.download:this.parseDownload();break;case F.frame:this.parseFrame();break;case F.packetentities:this.parsePacketEntities(!1);break;case F.deltapacketentities:this.parsePacketEntities(!0);break;case F.playerinfo:this.parsePlayerState();break;case F.stufftext:this.parseStuffText();break;case F.layout:this.parseLayout();break;case F.inventory:this.parseInventory();break;case F.sound:this.parseSound();break;case F.muzzleflash:this.parseMuzzleFlash();break;case F.muzzleflash2:this.parseMuzzleFlash2();break;case F.temp_entity:this.parseTempEntity();break;case F.splitclient:this.parseSplitClient();break;case F.configblast:this.parseConfigBlast();break;case F.spawnbaselineblast:this.parseSpawnBaselineBlast();break;case F.level_restart:this.handler&&this.handler.onLevelRestart&&this.handler.onLevelRestart();break;case F.damage:this.parseDamage();break;case F.locprint:this.parseLocPrint();break;case F.fog:this.parseFog();break;case F.waitingforplayers:this.parseWaitingForPlayers();break;case F.bot_chat:this.parseBotChat();break;case F.poi:this.parsePoi();break;case F.help_path:this.parseHelpPath();break;case F.muzzleflash3:this.parseMuzzleFlash3();break;case F.achievement:this.parseAchievement();break;default:console.warn(`Unknown server command: ${r} (translated: ${t}) at offset ${this.stream.getPosition()-1}`);return}}catch(n){console.warn(`Error parsing command ${t}: ${n.message}`);return}}}parsePrint(){let t=this.stream.readByte(),r=this.stream.readString();this.handler&&this.handler.onPrint(t,r)}parseStuffText(){let t=this.stream.readString();this.handler&&this.handler.onStuffText(t)}parseLayout(){let t=this.stream.readString();this.handler&&this.handler.onLayout(t)}parseCenterPrint(){let t=this.stream.readString();this.handler&&this.handler.onCenterPrint(t)}parseServerData(){if(this.protocolVersion=this.stream.readLong(),this.protocolVersion===qo){let t=this.stream.readLong(),r=this.stream.readByte();this.isDemo=r;let n=this.stream.readByte(),i=this.stream.readString(),s=this.stream.readShort();if(s===-2){let a=this.stream.readShort();for(let d=0;d<a;d++)this.stream.readShort();s=0}else s===-1&&(s=-1);let o=this.stream.readString();this.handler?this.handler.onServerData(this.protocolVersion,t,0,i,s,o,n,r):console.log(`Server Data (Rerelease): Protocol ${this.protocolVersion}, Level ${o}, Tick ${n}`)}else{let t=this.stream.readLong();this.isDemo=this.stream.readByte();let r=0,n=this.stream.readString(),i=this.stream.readShort(),s=this.stream.readString();this.handler?this.handler.onServerData(this.protocolVersion,t,r,n,i,s):console.log(`Server Data: Protocol ${this.protocolVersion}, Level ${s}, GameDir ${n}`)}}parseConfigString(){let t=this.stream.readShort(),r=this.stream.readString();this.handler&&this.handler.onConfigString(t,r)}parseSplitClient(){let t=this.stream.readByte();this.handler&&this.handler.onSplitClient&&this.handler.onSplitClient(t)}parseConfigBlast(){let t=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(t);try{let i=cc.inflate(n);i.byteLength!==r&&console.warn(`svc_configblast: Decompressed size mismatch. Expected ${r}, got ${i.byteLength}`);let s=new Dn(i.buffer);for(;s.hasMore();){let o=s.readUShort(),a=s.readString();this.handler&&this.handler.onConfigString(o,a)}}catch(i){console.error("svc_configblast: Failed to decompress data",i)}}parseSpawnBaselineBlast(){let t=this.stream.readShort(),r=this.stream.readShort(),n=this.stream.readData(t);try{let i=cc.inflate(n);i.byteLength!==r&&console.warn(`svc_spawnbaselineblast: Decompressed size mismatch. Expected ${r}, got ${i.byteLength}`);let s=new Dn(i.buffer),o=new e(s,this.handler);for(;s.hasMore();)o.parseSpawnBaseline()}catch(i){console.error("svc_spawnbaselineblast: Failed to decompress data",i)}}parseLocPrint(){let t=this.stream.readByte(),r=this.stream.readString(),n=this.stream.readByte(),i=[];for(let s=0;s<n;s++)i.push(this.stream.readString());this.handler&&this.handler.onLocPrint&&this.handler.onLocPrint(t,r,i)}parseWaitingForPlayers(){let t=this.stream.readByte();this.handler&&this.handler.onWaitingForPlayers&&this.handler.onWaitingForPlayers(t)}parseBotChat(){let t=this.stream.readString(),r=this.stream.readShort(),n=this.stream.readString();this.handler&&this.handler.onBotChat&&this.handler.onBotChat(n)}parsePoi(){let t=this.stream.readUShort(),r=this.stream.readUShort(),n={x:0,y:0,z:0};this.stream.readPos(n);let i=this.stream.readUShort(),s=this.stream.readByte(),o=this.stream.readByte();this.handler&&this.handler.onPoi&&this.handler.onPoi(o,n)}parseHelpPath(){let t=this.stream.readByte(),r={x:0,y:0,z:0};this.stream.readPos(r);let n={x:0,y:0,z:0};this.stream.readDir(n),this.handler&&this.handler.onHelpPath&&this.handler.onHelpPath(r)}parseAchievement(){let t=this.stream.readString();this.handler&&this.handler.onAchievement&&this.handler.onAchievement(t)}parseDownload(){let t=this.stream.readShort(),r=this.stream.readByte(),n;t>0&&(n=this.stream.readData(t)),this.handler&&this.handler.onDownload(t,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 t=this.stream.readByte(),r=this.stream.readByte(),n,i,s,o,a;if(t&1&&(n=this.stream.readByte()),t&2&&(i=this.stream.readByte()),t&16&&(s=this.stream.readByte()),t&8&&(o=this.stream.readShort()),t&4){let d={x:0,y:0,z:0};this.stream.readPos(d),a=d}this.handler&&this.handler.onSound(t,r,n,i,s,o,a)}parseMuzzleFlash(){let t=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash(t,r)}parseMuzzleFlash2(){let t=this.stream.readShort(),r=this.stream.readByte();this.handler&&this.handler.onMuzzleFlash2(t,r)}parseMuzzleFlash3(){let t=this.stream.readShort(),r=this.stream.readShort();this.handler&&this.handler.onMuzzleFlash3&&this.handler.onMuzzleFlash3(t,r)}parseFog(){let t=this.stream.readByte();if(t&128){let n=this.stream.readByte();t|=n<<8}let r={};t&1&&(r.density=this.stream.readFloat(),r.skyfactor=this.stream.readByte()),t&2&&(r.red=this.stream.readByte()),t&4&&(r.green=this.stream.readByte()),t&8&&(r.blue=this.stream.readByte()),t&16&&(r.time=this.stream.readShort()),t&32&&(r.hf_falloff=this.stream.readFloat()),t&64&&(r.hf_density=this.stream.readFloat()),t&256&&(r.hf_start_r=this.stream.readByte()),t&512&&(r.hf_start_g=this.stream.readByte()),t&1024&&(r.hf_start_b=this.stream.readByte()),t&2048&&(r.hf_start_dist=this.stream.readLong()),t&4096&&(r.hf_end_r=this.stream.readByte()),t&8192&&(r.hf_end_g=this.stream.readByte()),t&16384&&(r.hf_end_b=this.stream.readByte()),t&32768&&(r.hf_end_dist=this.stream.readLong()),this.handler&&this.handler.onFog&&this.handler.onFog(r)}parseDamage(){let t=this.stream.readByte(),r=[];for(let n=0;n<t;n++){let i=this.stream.readByte(),s={x:0,y:0,z:0};this.stream.readDir(s);let o=i&31,a=(i&32)!==0,d=(i&64)!==0,l=(i&128)!==0;r.push({damage:o,health:a,armor:d,power:l,dir:s})}this.handler&&this.handler.onDamage&&this.handler.onDamage(r)}parseTempEntity(){let t=this.stream.readByte(),r={x:0,y:0,z:0},n={x:0,y:0,z:0},i={x:0,y:0,z:0},s,o,a,d,l;switch(t){case I.EXPLOSION1:case I.EXPLOSION2:case I.ROCKET_EXPLOSION:case I.GRENADE_EXPLOSION:case I.ROCKET_EXPLOSION_WATER:case I.GRENADE_EXPLOSION_WATER:case I.BFG_EXPLOSION:case I.BFG_BIGEXPLOSION:case I.BOSSTPORT:case I.PLASMA_EXPLOSION:case I.PLAIN_EXPLOSION:case I.CHAINFIST_SMOKE:case I.TRACKER_EXPLOSION:case I.TELEPORT_EFFECT:case I.DBALL_GOAL:case I.NUKEBLAST:case I.WIDOWSPLASH:case I.EXPLOSION1_BIG:case I.EXPLOSION1_NP:this.stream.readPos(r);break;case I.GUNSHOT:case I.BLOOD:case I.BLASTER:case I.SHOTGUN:case I.SPARKS:case I.BULLET_SPARKS:case I.SCREEN_SPARKS:case I.SHIELD_SPARKS:case I.BLASTER2:case I.FLECHETTE:case I.MOREBLOOD:case I.ELECTRIC_SPARKS:case I.HEATBEAM_SPARKS:case I.HEATBEAM_STEAM:this.stream.readPos(r),this.stream.readDir(i);break;case I.SPLASH:case I.LASER_SPARKS:case I.WELDING_SPARKS:case I.TUNNEL_SPARKS:s=this.stream.readByte(),this.stream.readPos(r),this.stream.readDir(i),o=this.stream.readByte();break;case I.BLUEHYPERBLASTER:this.protocolVersion>=32?(this.stream.readPos(r),this.stream.readPos(n)):(this.stream.readPos(r),this.stream.readDir(i));break;case I.GREENBLOOD:this.protocolVersion>=32?(this.stream.readPos(r),this.stream.readDir(i)):(this.stream.readPos(r),this.stream.readPos(n));break;case I.RAILTRAIL:case I.BUBBLETRAIL:case I.BFG_LASER:case I.DEBUGTRAIL:case I.BUBBLETRAIL2:this.stream.readPos(r),this.stream.readPos(n);break;case I.PARASITE_ATTACK:case I.MEDIC_CABLE_ATTACK:this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n);break;case I.GRAPPLE_CABLE:a=this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n),this.stream.readPos(i);break;case I.LIGHTNING:d=this.stream.readShort(),l=this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n);break;case I.FLASHLIGHT:this.stream.readPos(r),a=this.stream.readShort();break;case I.FORCEWALL:this.stream.readPos(r),this.stream.readPos(n),o=this.stream.readByte();break;case I.STEAM:let c=this.stream.readShort();s=this.stream.readByte(),this.stream.readPos(r),this.stream.readDir(i),o=this.stream.readByte(),this.stream.readShort(),c!==-1&&this.stream.readLong();break;case I.WIDOWBEAMOUT:this.stream.readShort();case I.HEATBEAM:case I.MONSTER_HEATBEAM:a=this.stream.readShort(),this.stream.readPos(r),this.stream.readPos(n),this.stream.readPos(i);break;default:break}this.handler&&this.handler.onTempEntity(t,r,n,i,s,o,a,d,l)}parseSpawnBaseline(){let t=this.parseEntityBits(),r=Dr();this.parseDelta(Dr(),r,t.number,t.bits,t.bitsHigh),this.handler&&this.handler.onSpawnBaseline(r)}parseFrame(){let t=this.stream.readLong(),r=this.stream.readLong(),n=this.stream.readByte(),i=this.stream.readByte(),s=this.stream.readData(i),o=this.stream.readByte();if(o=this.translateCommand(o),o!==F.playerinfo)throw new Error(`Expected svc_playerinfo after svc_frame, got ${o} (translated)`);let a=this.parsePlayerState(),d=this.stream.readByte();if(d=this.translateCommand(d),d!==F.packetentities)throw new Error(`Expected svc_packetentities after svc_playerinfo, got ${d} (translated)`);let l=this.collectPacketEntities();if(this.isDemo===mx){let c=this.stream.readByte();for(let h=0;h<c;h++)this.stream.readByte()}this.isDemo===hx&&this.stream.readLong(),this.handler&&this.handler.onFrame({serverFrame:t,deltaFrame:r,surpressCount:n,areaBytes:i,areaBits:s,playerState:a,packetEntities:{delta:!0,entities:l}})}parsePlayerState(){let t=jo(),r=this.stream.readShort();r&1&&(t.pm_type=this.stream.readByte()),r&2&&(t.origin.x=this.stream.readShort()*.125,t.origin.y=this.stream.readShort()*.125,t.origin.z=this.stream.readShort()*.125),r&4&&(t.velocity.x=this.stream.readShort()*.125,t.velocity.y=this.stream.readShort()*.125,t.velocity.z=this.stream.readShort()*.125),r&8&&(t.pm_time=this.stream.readByte()),r&16&&(t.pm_flags=this.stream.readByte()),r&32&&(t.gravity=this.stream.readShort()),r&64&&(t.delta_angles.x=this.stream.readShort()*(180/32768),t.delta_angles.y=this.stream.readShort()*(180/32768),t.delta_angles.z=this.stream.readShort()*(180/32768)),r&128&&(t.viewoffset.x=this.stream.readChar()*.25,t.viewoffset.y=this.stream.readChar()*.25,t.viewoffset.z=this.stream.readChar()*.25),r&256&&(t.viewangles.x=this.stream.readAngle16(),t.viewangles.y=this.stream.readAngle16(),t.viewangles.z=this.stream.readAngle16()),r&512&&(t.kick_angles.x=this.stream.readChar()*.25,t.kick_angles.y=this.stream.readChar()*.25,t.kick_angles.z=this.stream.readChar()*.25),r&4096&&(t.gun_index=this.stream.readByte()),r&8192&&(t.gun_frame=this.stream.readByte(),t.gun_offset.x=this.stream.readChar()*.25,t.gun_offset.y=this.stream.readChar()*.25,t.gun_offset.z=this.stream.readChar()*.25,t.gun_angles.x=this.stream.readChar()*.25,t.gun_angles.y=this.stream.readChar()*.25,t.gun_angles.z=this.stream.readChar()*.25),r&1024&&(t.blend[0]=this.stream.readByte(),t.blend[1]=this.stream.readByte(),t.blend[2]=this.stream.readByte(),t.blend[3]=this.stream.readByte()),r&2048&&(t.fov=this.stream.readByte()),r&16384&&(t.rdflags=this.stream.readByte());let n=this.stream.readLong();for(let i=0;i<32;i++)n&1<<i&&(t.stats[i]=this.stream.readShort());return t}parsePacketEntities(t){let r=this.collectPacketEntities();this.handler&&this.handler.onFrame({serverFrame:0,deltaFrame:0,surpressCount:0,areaBytes:0,areaBits:new Uint8Array,playerState:jo(),packetEntities:{delta:t,entities:r}})}collectPacketEntities(){let t=[];for(;;){let r=this.parseEntityBits();if(r.number===0)break;let n=Dr();this.parseDelta(Dr(),n,r.number,r.bits,r.bitsHigh),t.push(n)}return t}parseEntityBits(){let t=this.stream.readByte();t&ax&&(t|=this.stream.readByte()<<8),t&cx&&(t|=this.stream.readByte()<<16),t&dx&&(t|=this.stream.readByte()<<24);let r=0;t&ux&&(r=this.stream.readByte());let n;return t&lx?n=this.stream.readShort():n=this.stream.readByte(),{number:n,bits:t,bitsHigh:r}}parseDelta(t,r,n,i,s=0){r.number=t.number,r.modelindex=t.modelindex,r.modelindex2=t.modelindex2,r.modelindex3=t.modelindex3,r.modelindex4=t.modelindex4,r.frame=t.frame,r.skinnum=t.skinnum,r.effects=t.effects,r.renderfx=t.renderfx,r.origin.x=t.origin.x,r.origin.y=t.origin.y,r.origin.z=t.origin.z,r.old_origin.x=t.origin.x,r.old_origin.y=t.origin.y,r.old_origin.z=t.origin.z,r.angles.x=t.angles.x,r.angles.y=t.angles.y,r.angles.z=t.angles.z,r.sound=t.sound,r.event=t.event,r.solid=t.solid,r.alpha=t.alpha,r.scale=t.scale,r.instanceBits=t.instanceBits,r.loopVolume=t.loopVolume,r.loopAttenuation=t.loopAttenuation,r.owner=t.owner,r.oldFrame=t.oldFrame,r.number=n,r.bits=i,r.bitsHigh=s,i&oa&&(r.modelindex=this.stream.readByte()),i&la&&(r.modelindex2=this.stream.readByte()),i&ca&&(r.modelindex3=this.stream.readByte()),i&da&&(r.modelindex4=this.stream.readByte()),i&ra&&(r.frame=this.stream.readByte()),i&aa&&(r.frame=this.stream.readShort()),i&ds&&i&hs?r.skinnum=this.stream.readLong():i&ds?r.skinnum=this.stream.readByte():i&hs&&(r.skinnum=this.stream.readShort()),i&cs&&i&fs?r.effects=this.stream.readLong():i&cs?r.effects=this.stream.readByte():i&fs&&(r.effects=this.stream.readShort()),i&ls&&i&us?r.renderfx=this.stream.readLong():i&ls?r.renderfx=this.stream.readByte():i&us&&(r.renderfx=this.stream.readShort()),i&Qo&&(r.origin.x=this.stream.readCoord()),i&Jo&&(r.origin.y=this.stream.readCoord()),i&ia&&(r.origin.z=this.stream.readCoord()),i&sa&&(r.angles.x=this.stream.readAngle()),i&ea&&(r.angles.y=this.stream.readAngle()),i&ta&&(r.angles.z=this.stream.readAngle()),i&ua&&this.stream.readPos(r.old_origin),i&fa&&(r.sound=this.stream.readByte()),i&na?r.event=this.stream.readByte():r.event=0,i&ha&&(r.solid=this.stream.readShort()),i&uc&&(r.alpha=this.stream.readByte()/255),i&fc&&(r.scale=this.stream.readFloat()),i&hc&&(r.instanceBits=this.stream.readLong()),i&mc&&(r.loopVolume=this.stream.readByte()/255),s&pc&&(r.loopAttenuation=this.stream.readByte()/255),s&gc&&(r.owner=this.stream.readShort()),s&yc&&(r.oldFrame=this.stream.readShort())}};var ma=(i=>(i[i.Stopped=0]="Stopped",i[i.Playing=1]="Playing",i[i.Paused=2]="Paused",i[i.Finished=3]="Finished",i))(ma||{}),ms=class{constructor(){this.reader=null;this.state=0;this.playbackSpeed=1;this.currentProtocolVersion=0;this.currentFrameIndex=0;this.accumulatedTime=0;this.frameDuration=100}setHandler(t){this.handler=t}loadDemo(t){this.reader=new Lr(t),this.state=0,this.accumulatedTime=0,this.currentProtocolVersion=0,this.currentFrameIndex=0}play(){this.reader&&(this.state=1)}pause(){this.state===1&&(this.state=2)}stop(){this.state=0,this.reader&&this.reader.reset(),this.accumulatedTime=0,this.currentProtocolVersion=0,this.currentFrameIndex=0}setFrameDuration(t){this.frameDuration=t}setSpeed(t){this.playbackSpeed=Math.max(.1,Math.min(t,16))}getSpeed(){return this.playbackSpeed}update(t){if(!(this.state!==1||!this.reader))for(this.accumulatedTime+=t*1e3*this.playbackSpeed;this.accumulatedTime>=this.frameDuration;){if(!this.processNextFrame())return;this.accumulatedTime-=this.frameDuration}}stepForward(){this.reader&&this.processNextFrame()}stepBackward(){console.warn("stepBackward not implemented")}seek(t){if(!this.reader)return;let r=this.getTotalFrames();t<0&&(t=0),t>=r&&(t=r-1),this.reader.seekToMessage(t)&&(this.currentFrameIndex=t,this.accumulatedTime=0)}processNextFrame(){if(!this.reader||!this.reader.hasMore())return this.state=3,!1;let t=this.reader.readNextBlock();if(!t)return this.state=3,!1;this.currentFrameIndex++;let r=new Or(t.data,this.handler);return r.setProtocolVersion(this.currentProtocolVersion),r.parseMessage(),this.currentProtocolVersion=r.getProtocolVersion(),!0}getState(){return this.state}getCurrentTime(){return this.accumulatedTime}getTotalFrames(){return this.reader?this.reader.getMessageCount():0}getCurrentFrame(){return this.currentFrameIndex}getDuration(){return this.getTotalFrames()*this.frameDuration/1e3}};function px(e){return{init(){e.trace({x:0,y:0,z:0},{x:0,y:0,z:0})},shutdown(){},createMainLoop(t,r){return new cr(t,r)}}}return qu(gx);})();
|
|
481
481
|
/*! Bundled license information:
|
|
482
482
|
|
|
483
483
|
pako/dist/pako.esm.mjs:
|