spessasynth_lib 4.3.0 → 4.3.2
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.
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
function xt(t,e,A=0){let s=0;for(let n=0;n<e;n++)s=s<<8|t[A+n];return s>>>0}function Nt(t,e){let A=xt(t,e,t.currentIndex);return t.currentIndex+=e,A}function sA(t,e){let A=new Array(e).fill(0);for(let s=e-1;s>=0;s--)A[s]=t&255,t>>=8;return A}function V(t,e){let A=cs(t,e,t.currentIndex);return t.currentIndex+=e,A}function cs(t,e,A=0){let s=0;for(let n=0;n<e;n++)s|=t[A+n]<<n*8;return s>>>0}function hs(t,e,A){for(let s=0;s<A;s++)t[t.currentIndex++]=e>>s*8&255}function Ae(t,e){t[t.currentIndex++]=e&255,t[t.currentIndex++]=e>>8}function ge(t,e){hs(t,e,4)}function ls(t,e){let A=e<<8|t;return A>32767?A-65536:A}function Yn(t){return t>127?t-256:t}var ee=class extends Uint8Array{currentIndex=0;slice(t,e){let A=super.slice(t,e);return A.currentIndex=0,A}};function _e(t,e=t.length,A=0){let s="";for(let n=0;n<e;n++){let a=t[A+n];if(a===0)return s;s+=String.fromCharCode(a)}return s}function Ee(t,e){let A=t.currentIndex;return t.currentIndex+=e,_e(t,e,A)}function $e(t,e=!1,A=!1){let s=t.length;e&&s++,A&&s%2!==0&&s++;let n=new ee(s);return Le(n,t),n}function Le(t,e,A=0){A>0&&e.length>A&&(e=e.slice(0,A));for(let s=0;s<e.length;s++)t[t.currentIndex++]=e.charCodeAt(s);if(A>e.length)for(let s=0;s<A-e.length;s++)t[t.currentIndex++]=0;return t}function Qe(t){let e=0;for(;t;){let A=t[t.currentIndex++];if(e=e<<7|A&127,A>>7!==1)break}return e}function UA(t){let e=[t&127];for(t>>=7;t>0;)e.unshift(t&127|128),t>>=7;return e}function _A(t){t=Math.floor(t);let e=Math.floor(t/60),A=Math.round(t-e*60);return{minutes:e,seconds:A,time:`${e.toString().padStart(2,"0")}:${A.toString().padStart(2,"0")}`}}function zs(t){let e="";for(let A=0;A<t.length;A++){let s=t[A].toString(16).padStart(2,"0").toUpperCase();e+=s,A<t.length-1&&(e+=" ")}return e}var d={warn:"color: orange;",unrecognized:"color: red;",info:"color: aqua;",recognized:"color: lime",value:"color: yellow; background-color: black;"},$s;(()=>{var t=Uint8Array,e=Uint16Array,A=Int32Array,s=new t([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,0,0,0]),n=new t([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,0,0]),a=new t([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),r=function(T,F){for(var u=new e(31),x=0;x<31;++x)u[x]=F+=1<<T[x-1];for(var P=new A(u[30]),x=1;x<30;++x)for(var te=u[x];te<u[x+1];++te)P[te]=te-u[x]<<5|x;return{b:u,r:P}},i=r(s,2),o=i.b,g=i.r;o[28]=258,g[258]=28;var l=r(n,0),C=l.b;l.r;var B=new e(32768);for(y=0;y<32768;++y)I=(y&43690)>>1|(y&21845)<<1,I=(I&52428)>>2|(I&13107)<<2,I=(I&61680)>>4|(I&3855)<<4,B[y]=((I&65280)>>8|(I&255)<<8)>>1;var I,y,E=function(T,F,u){for(var x=T.length,P=0,te=new e(F);P<x;++P)T[P]&&++te[T[P]-1];var W=new e(F);for(P=1;P<F;++P)W[P]=W[P-1]+te[P-1]<<1;var _;if(u){_=new e(1<<F);var $=15-F;for(P=0;P<x;++P)if(T[P])for(var ne=P<<4|T[P],ae=F-T[P],J=W[T[P]-1]++<<ae,ie=J|(1<<ae)-1;J<=ie;++J)_[B[J]>>$]=ne}else for(_=new e(x),P=0;P<x;++P)T[P]&&(_[P]=B[W[T[P]-1]++]>>15-T[P]);return _},m=new t(288);for(y=0;y<144;++y)m[y]=8;var y;for(y=144;y<256;++y)m[y]=9;var y;for(y=256;y<280;++y)m[y]=7;var y;for(y=280;y<288;++y)m[y]=8;var y,k=new t(32);for(y=0;y<32;++y)k[y]=5;var y,b=E(m,9,1),R=E(k,5,1),M=function(T){for(var F=T[0],u=1;u<T.length;++u)T[u]>F&&(F=T[u]);return F},S=function(T,F,u){var x=F/8|0;return(T[x]|T[x+1]<<8)>>(F&7)&u},Q=function(T,F){var u=F/8|0;return(T[u]|T[u+1]<<8|T[u+2]<<16)>>(F&7)},p=function(T){return(T+7)/8|0},D=function(T,F,u){return(F==null||F<0)&&(F=0),(u==null||u>T.length)&&(u=T.length),new t(T.subarray(F,u))},q=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],K=function(T,F,u){var x=new Error(F||q[T]);if(x.code=T,Error.captureStackTrace&&Error.captureStackTrace(x,K),!u)throw x;return x},O=function(T,F,u,x){var P=T.length,te=x?x.length:0;if(!P||F.f&&!F.l)return u||new t(0);var W=!u,_=W||F.i!=2,$=F.i;W&&(u=new t(P*3));var ne=function(Ce){var he=u.length;if(Ce>he){var Pe=new t(Math.max(he*2,Ce));Pe.set(u),u=Pe}},ae=F.f||0,J=F.p||0,ie=F.b||0,pe=F.l,ve=F.d,Be=F.m,be=F.n,Ue=P*8;do{if(!pe){ae=S(T,J,1);var ht=S(T,J+1,3);if(J+=3,ht)if(ht==1)pe=b,ve=R,Be=9,be=5;else if(ht==2){var lt=S(T,J,31)+257,jt=S(T,J+10,15)+4,eA=lt+S(T,J+5,31)+1;J+=14;for(var Oe=new t(eA),Et=new t(19),Re=0;Re<jt;++Re)Et[a[Re]]=S(T,J+Re*3,7);J+=jt*3;for(var Ot=M(Et),wt=(1<<Ot)-1,TA=E(Et,Ot,1),Re=0;Re<eA;){var Yt=TA[S(T,J,wt)];J+=Yt&15;var Xe=Yt>>4;if(Xe<16)Oe[Re++]=Xe;else{var it=0,Ct=0;for(Xe==16?(Ct=3+S(T,J,3),J+=2,it=Oe[Re-1]):Xe==17?(Ct=3+S(T,J,7),J+=3):Xe==18&&(Ct=11+S(T,J,127),J+=7);Ct--;)Oe[Re++]=it}}var bt=Oe.subarray(0,lt),Ye=Oe.subarray(lt);Be=M(bt),be=M(Ye),pe=E(bt,Be,1),ve=E(Ye,be,1)}else K(1);else{var Xe=p(J)+4,dt=T[Xe-4]|T[Xe-3]<<8,je=Xe+dt;if(je>P){$&&K(0);break}_&&ne(ie+dt),u.set(T.subarray(Xe,je),ie),F.b=ie+=dt,F.p=J=je*8,F.f=ae;continue}if(J>Ue){$&&K(0);break}}_&&ne(ie+131072);for(var v=(1<<Be)-1,w=(1<<be)-1,L=J;;L=J){var it=pe[Q(T,J)&v],z=it>>4;if(J+=it&15,J>Ue){$&&K(0);break}if(it||K(2),z<256)u[ie++]=z;else if(z==256){L=J,pe=null;break}else{var re=z-254;if(z>264){var Re=z-257,ce=s[Re];re=S(T,J,(1<<ce)-1)+o[Re],J+=ce}var de=ve[Q(T,J)&w],j=de>>4;de||K(3),J+=de&15;var Ye=C[j];if(j>3){var ce=n[j];Ye+=Q(T,J)&(1<<ce)-1,J+=ce}if(J>Ue){$&&K(0);break}_&&ne(ie+131072);var Ne=ie+re;if(ie<Ye){var De=te-Ye,oe=Math.min(Ye,Ne);for(De+ie<0&&K(3);ie<oe;++ie)u[ie]=x[De+ie]}for(;ie<Ne;++ie)u[ie]=u[ie-Ye]}}F.l=pe,F.p=L,F.b=ie,F.f=ae,pe&&(ae=1,F.m=Be,F.d=ve,F.n=be)}while(!ae);return ie!=u.length&&W?D(u,0,ie):u.subarray(0,ie)},Y=new t(0);function H(T,F){return O(T,{i:2},F&&F.out,F&&F.dictionary)}var Z=typeof TextDecoder<"u"&&new TextDecoder;try{Z.decode(Y,{stream:!0})}catch{}$s=H})();var js=$s,U=class en{header;size;data;constructor(e,A,s){this.header=e,this.size=A,this.data=s}static read(e,A=!0,s=!1){let n=Ee(e,4),a=V(e,4);n===""&&(a=0);let r=A?e.slice(e.currentIndex,e.currentIndex+a):new ee(0);return(A||s)&&(e.currentIndex+=a,a%2!==0&&e.currentIndex++),new en(n,a,r)}static write(e,A,s=!1,n=!1){if(e.length!==4)throw new Error(`Invalid header length: ${e}`);let a=8,r=e,i=A.length;s&&i++;let o=i;n&&(a+=4,o+=4,r="LIST");let g=a+i;g%2!==0&&g++;let l=new ee(g);return Le(l,r),ge(l,o),n&&Le(l,e),l.set(A,a),l}static getParts(e,A,s=!1){let n=e,a=A.reduce((o,g)=>g.length+o,0);s&&(a+=4,n="LIST");let r=new ee(4);ge(r,a);let i=[$e(n),r];return s&&i.push($e(e)),i.push(...A),a%2!==0&&i.push(new Uint8Array(1)),i}static writeParts(e,A,s=!1){let n=8,a=e,r=A.reduce((l,C)=>C.length+l,0),i=r;s&&(n+=4,i+=4,a="LIST");let o=n+r;o%2!==0&&o++;let g=new ee(o);Le(g,a),ge(g,i),s&&Le(g,e);for(let l of A)g.set(l,n),n+=l.length;return g}static findListType(e,A){return e.find(s=>s.header!=="LIST"?!1:(s.data.currentIndex=4,_e(s.data,4)===A))}};function bA(t,e){return{...e,...t}}var h=class WA{static infoEnabled=!1;static warnEnabled=!0;static groupEnabled=!1;static setLogLevel(e,A,s){this.infoEnabled=e,this.warnEnabled=A,this.groupEnabled=s}static info(...e){this.infoEnabled&&console.info(...e)}static warn(...e){this.warnEnabled&&console.warn(...e)}static group(...e){this.groupEnabled&&console.group(...e)}static groupCollapsed(...e){this.groupEnabled&&console.groupCollapsed(...e)}static groupEnd(){this.groupEnabled&&console.groupEnd()}static unsupported(e,A,s=""){this.infoEnabled&&this.info(`%cUnsupported %c${e}%c message: %c${zs(A)}%c. ${s}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn)}static gmInfo(e,A,s=""){this.infoEnabled&&this.coolInfo(`General MIDI ${e}`,A,s)}static gmFail(e,A){this.infoEnabled&&this.unsupported(`General MIDI ${e}`,A)}static gsInfo(e,A,s=""){this.infoEnabled&&this.coolInfo(`Roland GS ${e}`,A,s)}static gsFail(e,A,s=""){this.infoEnabled&&this.unsupported(`Roland GS ${e}`,A,s)}static xgInfo(e,A,s=""){this.infoEnabled&&this.coolInfo(`Yamaha XG ${e}`,A,s)}static xgFail(e,A,s=""){this.infoEnabled&&this.unsupported(`Yamaha XG ${e}`,A,s)}static coolInfo(e,A,s=""){this.infoEnabled&&(s?WA.info(`%c${e}%c is now set to %c${A}%c ${s}.`,d.recognized,d.info,d.value,d.info):WA.info(`%c${e}%c is now set to %c${A}%c.`,d.recognized,d.info,d.value,d.info))}},tn={ConsoleColors:d,readBigEndian:xt,readLittleEndian:cs,readLittleEndianIndexed:V,readBinaryString:_e,readBinaryStringIndexed:Ee,readVariableLengthQuantity:Qe,inflateSync:js},G={noteOff:128,noteOn:144,polyPressure:160,controllerChange:176,programChange:192,channelPressure:208,pitchWheel:224,systemExclusive:240,timecode:241,songPosition:242,songSelect:243,tuneRequest:246,clock:248,start:250,continue:251,stop:252,activeSensing:254,reset:255,sequenceNumber:0,text:1,copyright:2,trackName:3,instrumentName:4,lyric:5,marker:6,cuePoint:7,programName:8,midiChannelPrefix:32,midiPort:33,endOfTrack:47,setTempo:81,smpteOffset:84,timeSignature:88,keySignature:89,sequenceSpecific:127},f={bankSelect:0,modulationWheel:1,breathController:2,undefinedCC3:3,footController:4,portamentoTime:5,dataEntryMSB:6,mainVolume:7,balance:8,undefinedCC9:9,pan:10,expression:11,effectControl1:12,effectControl2:13,undefinedCC14:14,undefinedCC15:15,generalPurposeController1:16,generalPurposeController2:17,generalPurposeController3:18,generalPurposeController4:19,undefinedCC20:20,undefinedCC21:21,undefinedCC22:22,undefinedCC23:23,undefinedCC24:24,undefinedCC25:25,undefinedCC26:26,undefinedCC27:27,undefinedCC28:28,undefinedCC29:29,undefinedCC30:30,undefinedCC31:31,bankSelectLSB:32,modulationWheelLSB:33,breathControllerLSB:34,undefinedCC3LSB:35,footControllerLSB:36,portamentoTimeLSB:37,dataEntryLSB:38,mainVolumeLSB:39,balanceLSB:40,undefinedCC9LSB:41,panLSB:42,expressionLSB:43,effectControl1LSB:44,effectControl2LSB:45,undefinedCC14LSB:46,undefinedCC15LSB:47,undefinedCC16LSB:48,undefinedCC17LSB:49,undefinedCC18LSB:50,undefinedCC19LSB:51,undefinedCC20LSB:52,undefinedCC21LSB:53,undefinedCC22LSB:54,undefinedCC23LSB:55,undefinedCC24LSB:56,undefinedCC25LSB:57,undefinedCC26LSB:58,undefinedCC27LSB:59,undefinedCC28LSB:60,undefinedCC29LSB:61,undefinedCC30LSB:62,undefinedCC31LSB:63,sustainPedal:64,portamentoOnOff:65,sostenutoPedal:66,softPedal:67,legatoFootswitch:68,hold2Pedal:69,soundVariation:70,filterResonance:71,releaseTime:72,attackTime:73,brightness:74,decayTime:75,vibratoRate:76,vibratoDepth:77,vibratoDelay:78,soundController10:79,generalPurposeController5:80,generalPurposeController6:81,generalPurposeController7:82,generalPurposeController8:83,portamentoControl:84,undefinedCC85:85,undefinedCC86:86,undefinedCC87:87,undefinedCC88:88,undefinedCC89:89,undefinedCC90:90,reverbDepth:91,tremoloDepth:92,chorusDepth:93,variationDepth:94,phaserDepth:95,dataIncrement:96,dataDecrement:97,nonRegisteredParameterLSB:98,nonRegisteredParameterMSB:99,registeredParameterLSB:100,registeredParameterMSB:101,undefinedCC102LSB:102,undefinedCC103LSB:103,undefinedCC104LSB:104,undefinedCC105LSB:105,undefinedCC106LSB:106,undefinedCC107LSB:107,undefinedCC108LSB:108,undefinedCC109LSB:109,undefinedCC110LSB:110,undefinedCC111LSB:111,undefinedCC112LSB:112,undefinedCC113LSB:113,undefinedCC114LSB:114,undefinedCC115LSB:115,undefinedCC116LSB:116,undefinedCC117LSB:117,undefinedCC118LSB:118,undefinedCC119LSB:119,allSoundOff:120,resetAllControllers:121,localControlOnOff:122,allNotesOff:123,omniModeOff:124,omniModeOn:125,monoModeOn:126,polyModeOn:127},ut={pitchWheelRange:0,fineTuning:1,coarseTuning:2,modulationDepth:5,resetParameters:16383},ye={partParameter:1,drumPitch:24,drumPitchFine:25,drumLevel:26,drumPan:28,drumReverb:29,drumChorus:30,drumDelay:31,awe32:127,SF2:120},Ke={vibratoRate:8,vibratoDepth:9,vibratoDelay:10,tvfCutoffFrequency:32,tvfResonance:33,envelopeAttackTime:99,envelopeDecayTime:100,envelopeReleaseTime:102},We=class{ticks;statusByte;data;constructor(t,e,A){this.ticks=t,this.statusByte=e,this.data=A}},ws=(t,e)=>{for(let A=0;A<t.length;A++)e.push(t.charCodeAt(A))};function qn(t){if(!t.tracks)throw new Error("MIDI has no tracks!");let e=[];for(let s of t.tracks){let n=[],a=0,r;for(let i of s.events){let o=Math.max(0,i.ticks-a);if(i.statusByte===G.endOfTrack){a+=o;continue}let g;i.statusByte<=G.sequenceSpecific?(g=[255,i.statusByte,...UA(i.data.length),...i.data],r=void 0):i.statusByte===G.systemExclusive?(g=[240,...UA(i.data.length),...i.data],r=void 0):(g=[],r!==i.statusByte&&(r=i.statusByte,g.push(i.statusByte)),g.push(...i.data)),n.push(...UA(o),...g),a+=o}n.push(0,255,G.endOfTrack,0),e.push(n)}let A=[];ws("MThd",A),A.push(...sA(6,4),0,t.format,...sA(t.tracks.length,2),...sA(t.timeDivision,2));for(let s of e)ws("MTrk",A),A=A.concat(sA(s.length,4),s);return new Uint8Array(A).buffer}var nA=`SPESSASYNTH_EMBEDDED_BANK_${Math.random()}_DO_NOT_DELETE`,Jn=32767,Kn={time:0},Vn=.03,Xn=.07,Zn=.6;var hA=1/Math.cos(Math.PI/4)**2;var bs=121,Se=class{static getDefaultBank(t){return t==="gm2"?bs:0}static getDrumBank(t){switch(t){default:throw new Error(`${t} doesn't have a bank MSB for drums.`);case"gm2":return 120;case"xg":return 127}}static isXGDrum(t){return t===120||t===127}static isValidXGMSB(t){return this.isXGDrum(t)||t===64||t===bs}static isSystemXG(t){return t==="gm2"||t==="xg"}static addBankOffset(t,e,A){return this.isXGDrum(t)&&A?t:Math.min(t+e,127)}static subtractBankOffset(t,e,A){return this.isXGDrum(t)&&A?t:Math.max(0,t-e)}},ze=class zA{static toMIDIString(e){return e.isGMGSDrum?`DRUM:${e.program}`:`${e.bankLSB}:${e.bankMSB}:${e.program}`}static fromMIDIString(e){let A=e.split(":");if(A.length>3||A.length<2)throw new Error(`Invalid MIDI string: ${e}`);return e.startsWith("DRUM")?{bankMSB:0,bankLSB:0,program:Number.parseInt(A[1]),isGMGSDrum:!0}:{bankLSB:Number.parseInt(A[0]),bankMSB:Number.parseInt(A[1]),program:Number.parseInt(A[2]),isGMGSDrum:!1}}static toFullMIDIString(e){return`${this.toMIDIString(e)} ${e.isDrum?"D":"M"} ${e.name}`}static fromFullMIDIString(e){let A=e.indexOf(" "),s=e.indexOf(" ",A+1);if(A===-1||s===-1)throw new Error(`Invalid named MIDI string: ${e}`);let n=e.slice(0,Math.max(0,A)),a=e.slice(A+1,s),r=e.slice(Math.max(0,s+1));return{...zA.fromMIDIString(n),isDrum:a==="D",name:r}}static matches(e,A){return e.isGMGSDrum||A.isGMGSDrum?e.isGMGSDrum===A.isGMGSDrum&&e.program===A.program:e.program===A.program&&e.bankLSB===A.bankLSB&&e.bankMSB===A.bankMSB}static compare(e,A){return e.isGMGSDrum&&!A.isGMGSDrum?1:!e.isGMGSDrum&&A.isGMGSDrum?-1:e.program!==A.program?e.program-A.program:e.bankMSB!==A.bankMSB?e.bankMSB-A.bankMSB:e.bankLSB-A.bankLSB}static isXGDrum(e){return e.isDrum&&!e.isGMGSDrum}static selectPatch(e,A,s){if(e.length===0)throw new Error("No presets!");A.isGMGSDrum&&Se.isSystemXG(s)&&(A={...A,isGMGSDrum:!1,bankLSB:0,bankMSB:Se.getDrumBank(s)});let{isGMGSDrum:n,bankLSB:a,bankMSB:r,program:i}=A,o=Se.isSystemXG(s),g=Se.isXGDrum(r)&&o,l=e.find(I=>this.matches(I,A));if(l&&(!g||g&&this.isXGDrum(l)))return l;let C=I=>{h.info(`%cPreset %c${zA.toMIDIString(A)}%c not found. (${s}) Replaced with %c${this.toFullMIDIString(I)}`,d.warn,d.unrecognized,d.warn,d.value)};if(n){let I=e.find(E=>E.isGMGSDrum&&E.program===i);return I||(I=e.find(E=>E.isDrum&&E.program===i),I)?(C(I),I):(I=this.getAnyDrums(e,!1),C(I),I)}if(g){let I=e.find(E=>E.program===i&&E.isDrum&&!E.isGMGSDrum);return I||(I=e.find(E=>E.isDrum&&E.program===i),I&&I.program<49)?(C(I),I):(I=this.getAnyDrums(e,!0),C(I),I)}let B=e.filter(I=>I.program===i&&!I.isDrum);if(B.length===0)return C(e[0]),e[0];if(l=o?B.find(I=>I.bankLSB===a):B.find(I=>I.bankMSB===r),l)return C(l),l;if(a!==64||!o){let I=Math.max(r,a);if(l=B.find(E=>E.bankLSB===I||E.bankMSB===I),l)return C(l),l}return C(B[0]),B[0]}static getAnyDrums(e,A){let s=A?e.find(n=>this.isXGDrum(n)):e.find(n=>n.isGMGSDrum);return s||(e.find(n=>n.isDrum)??e[0])}},fe=Object.freeze({type:"Other"}),se=class $A{static analyzeSysEx(e){if(e.length<3)return fe;switch(e[0]){default:return fe;case 126:case 127:return this.analyzeGM(e);case 65:return this.analyzeGS(e);case 67:return this.analyzeXG(e)}}static analyzeRPN(e,A,s){switch(A){default:return fe;case ut.fineTuning:return{type:"Fine Tune",channel:e,value:(s-8192)/81.92};case ut.coarseTuning:return{type:"Key Shift",channel:e,value:(s>>7)-64}}}static analyzeNRPN(e,A,s){let n=A>>7,a=A&127;switch(n){default:return fe;case ye.partParameter:switch(a){default:return fe;case Ke.tvfCutoffFrequency:return{type:"Controller Change",channel:e,controller:f.brightness,value:s>>7};case Ke.tvfResonance:return{type:"Controller Change",channel:e,controller:f.filterResonance,value:s>>7};case Ke.envelopeAttackTime:return{type:"Controller Change",channel:e,controller:f.attackTime,value:s>>7};case Ke.envelopeDecayTime:return{type:"Controller Change",channel:e,controller:f.decayTime,value:s>>7};case Ke.envelopeReleaseTime:return{type:"Controller Change",channel:e,controller:f.releaseTime,value:s>>7}}case ye.drumPitch:case ye.drumPitchFine:case ye.drumLevel:case ye.drumPan:case ye.drumReverb:case ye.drumChorus:case ye.drumDelay:return{type:"Drum Setup"}}}static syxToChannel(e){return[9,0,1,2,3,4,5,6,7,8,10,11,12,13,14,15][e%16]}static channelToSyx(e){return[1,2,3,4,5,6,7,8,9,0,10,11,12,13,14,15][e%16]}static gsData(e,A,s,n){let a=128-(e+A+s+n.reduce((r,i)=>r+i,0))%128&127;return[65,16,66,18,e,A,s,...n,a,247]}static gsMessage(e,A,s,n,a){return new We(e,G.systemExclusive,new Uint8Array(this.gsData(A,s,n,a)))}static gsDrumChange(e,A,s){let n=16|this.channelToSyx(A);return this.gsMessage(e,40,n,21,[s])}static gsReset(e){return this.gsMessage(e,64,0,127,[0])}static analyzeGM(e){if(e.length<4)return fe;if(e[2]===4)switch(e[3]){default:return fe;case 3:return{type:"Master Fine Tune",value:((e[5]<<7|e[6])-8192)/81.92};case 4:return{type:"Master Key Shift",value:e[5]-64};case 5:if(e[4]!==1||e[5]!==1||e[6]!==1||e[7]!==1)return fe;switch(e[8]){default:return fe;case 1:switch(e[9]){default:return fe;case 1:case 2:return{type:"Reverb Param"}}case 2:switch(e[9]){default:return fe;case 1:case 2:case 3:case 4:return{type:"Chorus Param"}}}}if(e[2]!==9)return fe;switch(e[3]){default:return fe;case 1:return{type:"GM On"};case 2:return{type:"GM Off"};case 3:return{type:"GM2 On"}}}static analyzeXG(e){if(e[2]!==76||e.length<7)return fe;let A=e[3],s=e[4],n=e[5],a=e[6];if(A===0&&s===0)switch(n){default:return fe;case 0:return{type:"Master Fine Tune",value:(((e[6]&15)<<12|(e[7]&15)<<8|(e[8]&15)<<4|e[9]&15)-1024)/10};case 6:return{type:"Master Key Shift",value:a-64};case 126:case 127:return{type:"XG Reset"}}if(A===2&&s===1)return n<=21?{type:"Reverb Param"}:n<=53?{type:"Chorus Param"}:{type:"Variation Param"};if(A===3&&s===0)return{type:"Variation Param"};if(A===8){let r=s;if(r>=16)return fe;switch(n){default:return fe;case 1:return{type:"Controller Change",channel:r,controller:f.bankSelect,value:a};case 2:return{type:"Controller Change",channel:r,controller:f.bankSelectLSB,value:a};case 3:return{type:"Program Change",channel:r,value:a};case 5:return{type:"Controller Change",channel:r,controller:a===1?f.polyModeOn:f.monoModeOn,value:0};case 7:return{type:"Drums On",channel:r,isDrum:a>0};case 8:return{type:"Key Shift",channel:r,value:a-64};case 11:return{type:"Controller Change",channel:r,controller:f.mainVolume,value:a};case 14:return{type:"Controller Change",channel:r,controller:f.pan,value:a};case 18:return{type:"Controller Change",channel:r,controller:f.chorusDepth,value:a};case 19:return{type:"Controller Change",channel:r,controller:f.reverbDepth,value:a};case 21:return{type:"Controller Change",channel:r,controller:f.vibratoRate,value:a};case 22:return{type:"Controller Change",channel:r,controller:f.vibratoDepth,value:a};case 23:return{type:"Controller Change",channel:r,controller:f.vibratoDelay,value:a};case 24:return{type:"Controller Change",channel:r,controller:f.brightness,value:a};case 25:return{type:"Controller Change",channel:r,controller:f.filterResonance,value:a};case 26:return{type:"Controller Change",channel:r,controller:f.attackTime,value:a};case 27:return{type:"Controller Change",channel:r,controller:f.decayTime,value:a};case 12:return{type:"Controller Change",channel:r,controller:f.releaseTime,value:a}}}return A>>4===3?{type:"Drum Setup"}:fe}static analyzeGS(e){if(e.length<10||e[2]!==66||e[3]!==18)return fe;let A=e[4],s=e[5],n=e[6],a=e[7];if((A===0||A===64)&&s===0)switch(n){case 127:switch(a){case 0:return{type:"GS Reset"};case 127:return{type:"GM On"}}return fe;case 0:return{type:"Master Fine Tune",value:((a<<12|e[8]<<8|e[9]<<4|e[10])-1024)/10}}if(A===65)return{type:"Drum Setup"};if(A!==64)return fe;if(s===0&&n===5)return{type:"Master Key Shift",value:a-64};if(s===1){if(n>=48&&n<=55)return{type:"Reverb Param"};if(n>=56&&n<=64)return{type:"Chorus Param"};if(n>=80&&n<=90)return{type:"Delay Param"}}if(s===3&&n>=0&&n<=127)return{type:"Insertion Param"};if(s>>4===1){let r=$A.syxToChannel(s&15);switch(n){default:return fe;case 0:return{type:"Program Change",channel:r,value:a};case 19:return{type:"Controller Change",channel:r,controller:a===1?f.polyModeOn:f.monoModeOn,value:0};case 21:return{type:"Drums On",channel:r,isDrum:a>0};case 22:return{type:"Key Shift",channel:r,value:a-64};case 25:return{type:"Controller Change",channel:r,controller:f.mainVolume,value:a};case 28:return{type:"Controller Change",channel:r,controller:f.pan,value:a};case 33:return{type:"Controller Change",channel:r,controller:f.chorusDepth,value:a};case 34:return{type:"Controller Change",channel:r,controller:f.reverbDepth,value:a};case 42:return{type:"Fine Tune",channel:r,value:((a<<7|e[8])-8192)/81.92};case 44:return{type:"Controller Change",channel:r,controller:f.variationDepth,value:a};case 48:return{type:"Controller Change",channel:r,controller:f.vibratoRate,value:a};case 49:return{type:"Controller Change",channel:r,controller:f.vibratoDepth,value:a};case 50:return{type:"Controller Change",channel:r,controller:f.brightness,value:a};case 51:return{type:"Controller Change",channel:r,controller:f.filterResonance,value:a};case 52:return{type:"Controller Change",channel:r,controller:f.attackTime,value:a};case 53:return{type:"Controller Change",channel:r,controller:f.decayTime,value:a};case 54:return{type:"Controller Change",channel:r,controller:f.releaseTime,value:a};case 55:return{type:"Controller Change",channel:r,controller:f.vibratoDelay,value:a}}}if(s>>4===4){let r=$A.syxToChannel(s&15);switch(n){default:return fe;case 0:case 1:return{type:"Controller Change",channel:r,controller:f.bankSelectLSB,value:a};case 34:return{type:"Insertion Param"}}}return fe}},_n="Created using SpessaSynth";function Wn(t,e,A){let s="gm",n=[],a=new Array(t.tracks.length).fill(0),r=16+Math.max(...t.portChannelOffsetMap),i=[];for(let o=0;o<r;o++)i.push({program:0,isDrum:o%16===9,lastBank:void 0,lastBankLSB:void 0,hasBankSelect:!1});t.iterate((o,g,l)=>{let C=t.portChannelOffsetMap[a[g]];if(o.statusByte===G.midiPort){a[g]=o.data[0];return}let B=o.statusByte&240;if(B!==G.controllerChange&&B!==G.programChange&&B!==G.systemExclusive)return;if(B===G.systemExclusive){let k=se.analyzeSysEx(o.data);switch(k.type){default:return;case"Drums On":{let y=k.channel+C;i[y].isDrum=k.isDrum;return}case"XG Reset":s="xg";return;case"GS Reset":s="gs";return;case"GM Off":case"GM On":s="gm",n.push({tNum:g,e:o});return;case"GM2 On":s="gm2";return;case"Controller Change":{let y=t.tracks[g],b=new We(o.ticks,G.controllerChange|k.channel,new Uint8Array([k.controller,k.value]));y.events[l[g]]=b,o=b,h.info("%cReplaced a system exclusive with controller change!",d.info);break}case"Program Change":{let y=t.tracks[g],b=new We(o.ticks,G.programChange|k.channel,new Uint8Array([k.value]));y.events[l[g]]=b,o=b,h.info("%cReplaced a system exclusive with program change!",d.info);break}}}let I=(o.statusByte&15)+C,E=i[I];if(B===G.programChange){let k={program:o.data[0],bankLSB:E.lastBankLSB?.data?.[1]??0,bankMSB:Se.subtractBankOffset(E.lastBank?.data?.[1]??0,t.bankOffset,s==="xg"),isGMGSDrum:E.isDrum},y=A.getPreset(k,s);if(h.info(`%cInput patch: %c${ze.toMIDIString(k)}%c. Channel %c${I}%c. Changing patch to ${y.toString()}.`,d.info,d.unrecognized,d.info,d.recognized,d.info),o.data[0]=y.program,y.isGMGSDrum&&Se.isSystemXG(s)||E.lastBank===void 0||(E.lastBank.data[1]=Se.addBankOffset(y.bankMSB,e,s==="xg"),E.lastBankLSB===void 0))return;E.lastBankLSB.data[1]=y.bankLSB;return}let m=o.data[0]===f.bankSelectLSB;o.data[0]!==f.bankSelect&&!m||(E.hasBankSelect=!0,m?E.lastBankLSB=o:E.lastBank=o)});for(let o=0;o<i.length;o++){let g=i[o];if(g.hasBankSelect)continue;let l=o%16,C=G.programChange|l,B=Math.floor(o/16)*16,I=t.portChannelOffsetMap.indexOf(B),E=t.tracks.find(R=>R.port===I&&R.channels.has(l));if(E===void 0)continue;let m=E.events.findIndex(R=>R.statusByte===C);if(m===-1){let R=E.events.findIndex(Q=>Q.statusByte>128&&Q.statusByte<240&&(Q.statusByte&15)===l);if(R===-1)continue;let M=E.events[R].ticks,S=A.getPreset({bankMSB:0,bankLSB:0,program:0,isGMGSDrum:!1},s).program;E.addEvents(R,new We(M,G.programChange|l,new ee([S]))),m=R}h.info(`%cAdding bank select for %c${o}`,d.info,d.recognized);let k=E.events[m].ticks,y=A.getPreset({bankLSB:0,bankMSB:0,program:g.program,isGMGSDrum:g.isDrum},s),b=Se.addBankOffset(y.bankMSB,e,s==="xg");E.addEvents(m,new We(k,G.controllerChange|l,new ee([f.bankSelect,b])))}if(s==="gm"&&!Se.isSystemXG(s)){for(let g of n){let l=t.tracks[g.tNum];l.deleteEvent(l.events.indexOf(g.e))}let o=0;t.tracks[0].events[0].statusByte===G.trackName&&o++,t.tracks[0].addEvents(o,se.gsReset(0))}t.flush()}var Rs={bankOffset:0,metadata:{},correctBankOffset:!0,soundBank:void 0};function zn(t,e,A){let s=A.metadata;if(h.group("%cWriting the RMIDI File...",d.info),h.info("metadata",s),h.info("Initial bank offset",t.bankOffset),A.correctBankOffset){if(!A.soundBank)throw new Error("Sound bank must be provided if correcting bank offset.");Wn(t,A.bankOffset,A.soundBank)}let n=new ee(t.writeMIDI());s.name??=t.getName(),s.creationDate??=new Date,s.copyright??=_n,s.software??="SpessaSynth",Object.entries(s).forEach(o=>{let g=o;g[1]&&t.setRMIDInfo(g[0],g[1])});let a=[],r=(o,g)=>{a.push(U.write(o,g))};for(let o of Object.entries(t.rmidiInfo)){let g=o[0],l=o[1];switch(g){case"album":r("IALB",l),r("IPRD",l);break;case"software":r("ISFT",l);break;case"infoEncoding":r("IENC",l);break;case"creationDate":r("ICRD",l);break;case"picture":r("IPIC",l);break;case"name":r("INAM",l);break;case"artist":r("IART",l);break;case"genre":r("IGNR",l);break;case"copyright":r("ICOP",l);break;case"comment":r("ICMT",l);break;case"engineer":r("IENG",l);break;case"subject":r("ISBJ",l);break;case"midiEncoding":r("MENC",l);break}}let i=new ee(2);return hs(i,A.bankOffset,2),a.push(U.write("DBNK",i)),h.info("%cFinished!",d.info),h.groupEnd(),U.writeParts("RIFF",[$e("RMID"),U.write("data",n),U.writeParts("INFO",a,!0),new ee(e)]).buffer}var QA=class{rpnMSB={v:127,track:0,event:0};rpnLSB={v:127,track:0,event:0};nrpnMSB={v:0,track:0,event:0};nrpnLSB={v:0,track:0,event:0};dataMSB={v:0,track:0,event:0};dataLSB={v:0,track:0,event:0};channel;isRegistered=!0;constructor(t){this.channel=t}get paramMSB(){return this.isRegistered?this.rpnMSB:this.nrpnMSB}get paramLSB(){return this.isRegistered?this.rpnLSB:this.nrpnLSB}reset(){this.isRegistered=!0,this.rpnLSB.v=127,this.rpnMSB.v=127,this.nrpnMSB.v=0,this.nrpnLSB.v=0,this.resetData()}controllerChange(t,e,A,s){switch(t){case f.registeredParameterMSB:this.resetData(),this.isRegistered=!0,this.rpnMSB={v:e,track:A,event:s};break;case f.registeredParameterLSB:this.resetData(),this.isRegistered=!0,this.rpnLSB={v:e,track:A,event:s};break;case f.nonRegisteredParameterMSB:this.resetData(),this.isRegistered=!1,this.nrpnMSB={v:e,track:A,event:s};break;case f.nonRegisteredParameterLSB:this.resetData(),this.isRegistered=!1,this.nrpnLSB={v:e,track:A,event:s};break;case f.dataEntryMSB:return this.dataMSB={v:e,track:A,event:s},this.analyze();case f.dataEntryLSB:return this.dataLSB={v:e,track:A,event:s},this.analyze()}}resetData(){this.dataLSB.v=0,this.dataMSB.v=0}analyze(){let t=this.dataMSB.v<<7|this.dataLSB.v;return this.isRegistered?se.analyzeRPN(this.channel,this.rpnMSB.v<<7|this.rpnLSB.v,t):se.analyzeNRPN(this.channel,this.nrpnMSB.v<<7|this.nrpnLSB.v,t)}};function $n(t,e){h.groupCollapsed("%cSearching for all used programs and keys...",d.info);let A=16+Math.max(...t.portChannelOffsetMap),s=[],n="gs",a=0,r=B=>{n=B,a=0;for(let I=0;I<A;I++){let E=s[I];E.isDrum=I%16===9,E.bankMSB=Se.getDefaultBank(B),E.bankLSB=0,E.keyShift=0,E.param.reset()}};for(let B=0;B<A;B++){let I=B%16===9;s.push({preset:e.getPreset({bankLSB:0,bankMSB:0,isGMGSDrum:I,program:0},n),bankMSB:0,bankLSB:0,param:new QA(B),isDrum:I,keyShift:0})}let i=new Map,o=t.tracks.map(B=>B.port),g=t.portChannelOffsetMap,{timeline:l,tracks:C}=t;for(let B of l){let I=B.tr,E=B.ev,m=C[I].events[E];if(m.statusByte===G.midiPort&&t.tracks[I].channels.size>0){let b=m.data[0];g[b]===void 0&&(h.warn(`Invalid port ${b} on track ${I}. (No offset found in the MIDI map.`),b=0),o[I]=b;continue}let k=m.statusByte&240;if(k!==G.noteOn&&k!==G.controllerChange&&k!==G.programChange&&k!==G.systemExclusive)continue;let y=g[o[I]]||0;switch(k){case G.programChange:{let b=s[(m.statusByte&15)+y];b.preset=e.getPreset({bankMSB:b.bankMSB,bankLSB:b.bankLSB,program:m.data[0],isGMGSDrum:b.isDrum},n);break}case G.controllerChange:{let b=s[(m.statusByte&15)+y],R=m.data[0],M=m.data[1];switch(R){case f.registeredParameterMSB:case f.registeredParameterLSB:case f.nonRegisteredParameterLSB:case f.nonRegisteredParameterMSB:b.param.controllerChange(R,M,I,E);break;case f.dataEntryMSB:case f.dataEntryLSB:{let S=b.param.controllerChange(R,M,I,E);S?.type==="Key Shift"&&(b.keyShift=b.isDrum?0:S.value);break}case f.resetAllControllers:b.param.reset();break;case f.bankSelect:b.bankMSB=M;break;case f.bankSelectLSB:b.bankLSB=M;break}break}case G.noteOn:{let b=s[(m.statusByte&15)+y];if(m.data[1]===0||!b.preset)continue;let R=i.get(b.preset);R||(R=new Map,i.set(b.preset,R));let M=m.data[0]+(b.isDrum?0:a)+b.keyShift,S=R.get(M);S||(S=new Set,R.set(M,S)),S.add(m.data[1]);break}case G.systemExclusive:{let b=se.analyzeSysEx(m.data);switch(b.type){default:break;case"XG Reset":r("xg"),h.info("%cXG on detected!",d.recognized);break;case"GM2 On":r("gm2"),h.info("%cGM2 on detected!",d.recognized);break;case"GM On":r("gm"),h.info("%cGM on detected!",d.recognized);break;case"GM Off":case"GS Reset":r("gs"),h.info("%cGS on detected!",d.recognized);break;case"Master Key Shift":a=b.value;break;case"Key Shift":{let R=s[b.channel];R.keyShift=R.isDrum?0:b.value;break}case"Drums On":{let R=b.channel+y;s[R].isDrum=b.isDrum;break}case"Program Change":{let R=s[b.channel+y];R.preset=e.getPreset({bankMSB:R.bankMSB,bankLSB:R.bankLSB,program:b.value,isGMGSDrum:R.isDrum},n);break}case"Controller Change":{let R=b.channel+y;b.controller===f.bankSelectLSB?s[R].bankLSB=b.value:b.controller===f.bankSelect&&(s[R].bankMSB=b.value)}}}}}for(let[B,I]of i.entries())I.size===0&&(h.info(`%cDetected change but no keys for %c${B.name}`,d.info,d.value),i.delete(B));return h.groupEnd(),i}var jn=t=>(t.data=new ee(t.data.buffer),6e7/xt(t.data,3));function ea(t,e=0){let A=[];for(let C=0;C<16;C++)A.push([]);let s=0,n=60/(120*t.timeDivision),a=0,r=0,i=[];for(let C=0;C<16;C++)i.push([]);let o=(C,B)=>{let I=i[B].findIndex(m=>m.midiNote===C),E=i[B][I];if(E){let m=s-E.start;E.length=m,B===9&&(E.length=Math.max(m,e)),i[B].splice(I,1)}r--},{timeline:g,tracks:l}=t;for(;a<g.length;){let C=g[a],B=l[C.tr].events[C.ev],I=B.statusByte>>4,E=B.statusByte&15;if(I===8)o(B.data[0],E);else if(I===9)if(B.data[1]===0)o(B.data[0],E);else{o(B.data[0],E);let m={midiNote:B.data[0],start:s,length:-1,velocity:B.data[1]/127};A[E].push(m),i[E].push(m),r++}else B.statusByte===81&&(n=60/(jn(B)*t.timeDivision));if(++a>=g.length)break;s+=n*(l[g[a].tr].events[g[a].ev].ticks-B.ticks)}if(r>0)for(let[C,B]of i.entries())for(let I of B){let E=s-I.start;I.length=E,C===9&&(I.length=Math.max(E,e))}return A}var ta={character:49,preLowpass:50,level:51,time:52,delayFeedback:53,preDelayTime:55},Aa={preLowpass:57,level:58,feedback:59,delay:60,rate:61,depth:62,sendLevelToReverb:63,sendLevelToDelay:64},sa={preLowpass:81,timeCenter:82,timeRatioLeft:83,timeRatioRight:84,levelCenter:85,levelLeft:86,levelRight:87,level:88,feedback:89,sendLevelToReverb:90};function Mt(t,e,A,s){return new We(s,G.controllerChange|t%16,new ee([e,A]))}function na(t,e){h.groupCollapsed("%cApplying changes to the MIDI file...",d.info);let{channels:A,reverbParams:s,chorusParams:n,delayParams:a,insertionParams:r}=e;h.info("Desired channel changes",A),h.info("Desired reverb parameters",s),h.info("Desired chorus parameters",n),h.info("Desired delay parameters",a),h.info("Desired insertion parameters",r);let i=e.drumSetupParams==="clear",o=new Set,g=new Map;if(A)for(let[p,D]of A)D==="clear"?o.add(p):g.set(p,D);let l="gs",C=!1,B=0,I=0,E=t.tracks.map(p=>p.port),m={},k=0,y=(p,D)=>{t.tracks[p].channels.size!==0&&(k===0&&(k+=16,m[D]=0),m[D]===void 0&&(m[D]=k,k+=16),E[p]=D)};for(let[p,D]of t.tracks.entries())y(p,D.port);let b=k,R=[];for(let p=0;p<b;p++)R.push({isFirstNoteOn:!0,param:new QA(p),clearedParams:{pLSB:!0,pMSB:!0,data:!0},keyShift:g.get(p)?.keyShift??0,fineTune:g.get(p)?.fineTune??0});if(t.iterate((p,D,q)=>{let K=t.tracks[D],O=q[D],Y=()=>{K.deleteEvent(O),q[D]--},H=W=>{let _=R[W],$=_.param,ne=$.paramMSB,ae=$.paramLSB;h.info(`%cClearing Non/Registered Parameter on ${W}. Clear MSB: %c${_.clearedParams.pMSB}%c, clear LSB: %c${_.clearedParams.pLSB}%c, clear data: %c${_.clearedParams.data}.`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized),_.clearedParams.data||(Y(),D===ne.track&&O<ne.event&&ne.event--,D===ae.track&&O<ae.event&&ae.event--,_.clearedParams.data=!0),_.clearedParams.pMSB||(t.tracks[ne.track].deleteEvent(ne.event),q[ne.track]--,ne.track===ae.track&&ne.event<ae.event&&ae.event--,_.clearedParams.pMSB=!0),_.clearedParams.pLSB||(t.tracks[ae.track].deleteEvent(ae.event),q[ae.track]--,_.clearedParams.pLSB=!0)},Z=(W,_=0)=>{K.addEvents(O+_,W),q[D]++},T=m[E[D]]||0;if(p.statusByte===G.midiPort){y(D,p.data[0]);return}if(p.statusByte<G.noteOff||p.statusByte>G.systemExclusive)return;let F=p.statusByte&240,u=p.statusByte&15,x=u+T;if(p.statusByte!==G.systemExclusive&&o.has(x)){Y();return}let P=R[x],te=g.get(x);switch(F){case G.noteOn:if(!te)break;if(P.isFirstNoteOn){if(P.isFirstNoteOn=!1,te.controllers)for(let[_,$]of te.controllers)$!=="clear"&&Z(Mt(u,_,$,p.ticks));if(P.fineTune!==0){let _=Math.floor(P.fineTune*81.92)+8192,$=Mt(u,f.registeredParameterMSB,0,p.ticks),ne=Mt(u,f.registeredParameterLSB,1,p.ticks),ae=Mt(x,f.dataEntryMSB,_>>7&127,p.ticks);Z(Mt(u,f.dataEntryLSB,_&127,p.ticks)),Z(ae),Z(ne),Z($)}let W=te.patch;if(W&&W!=="clear"){h.info(`%cSetting %c${x}%c to %c${ze.toMIDIString(W)}%c. Track num: %c${D}`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized);let _=W.bankMSB,$=W.bankLSB,ne=W.program;Z(new We(p.ticks,G.programChange|u,new ee([ne])));let ae=(J,ie)=>{Z(Mt(u,J?f.bankSelectLSB:f.bankSelect,ie,p.ticks))};Se.isSystemXG(l)&&W.isGMGSDrum&&(h.info(`%cAdding XG Drum change on track %c${D}`,d.recognized,d.value),_=Se.getDrumBank(l),$=0),ae(!1,_),ae(!0,$),W.isGMGSDrum&&!Se.isSystemXG(l)&&u!==9&&(h.info(`%cAdding GS Drum change on track %c${D}`,d.recognized,d.value),Z(se.gsDrumChange(p.ticks,u,1)))}}p.data[0]+=P.keyShift;break;case G.noteOff:if(!te)break;p.data[0]+=P.keyShift;break;case G.programChange:if(te?.patch){Y();return}break;case G.controllerChange:{let W=p.data[0],_=p.data[1];if(te?.controllers?.get(W)){Y();return}switch(W){case f.bankSelect:case f.bankSelectLSB:te?.patch&&Y();return;case f.registeredParameterLSB:case f.registeredParameterMSB:case f.nonRegisteredParameterMSB:case f.nonRegisteredParameterLSB:W===f.nonRegisteredParameterLSB||W===f.registeredParameterLSB?P.clearedParams.pLSB=!1:P.clearedParams.pMSB=!1,P.param.controllerChange(W,_,D,O);return;case f.dataEntryMSB:case f.dataEntryLSB:{P.clearedParams.data=!1;let $=P.param.controllerChange(W,_,D,O);if(!$)return;switch($.type){case"Drum Setup":i&&H(x);return;case"Controller Change":{let ne=$.controller,ae=$.channel;if(te?.controllers?.get(ne)){H(ae);return}(ne===f.bankSelect||ne===f.bankSelectLSB)&&te?.patch&&H(ae);break}case"Fine Tune":if(P.fineTune){if(P.isFirstNoteOn){let ne=P.fineTune+$.value;P.keyShift+=Math.trunc(ne/100),P.fineTune=ne%100,h.info(`%cFine tuning already present on ${x}, new relative tune: %c${ne} cents`,d.info,d.recognized)}H(x)}return}P.clearedParams.pLSB=!0,P.clearedParams.pMSB=!0;return}default:return}}case G.systemExclusive:{let W=se.analyzeSysEx(p.data);switch(W.type){default:return;case"XG Reset":h.info("%cXG system on detected",d.info),l="xg",C=!0,B=D,I=O;for(let _ of R)_.param.reset(),_.clearedParams={pLSB:!0,pMSB:!0,data:!0};return;case"GM2 On":h.info("%cGM2 system on detected",d.info),l="gm2",C=!0,B=D,I=O;for(let _ of R)_.param.reset(),_.clearedParams={pLSB:!0,pMSB:!0,data:!0};return;case"GS Reset":h.info("%cGS on detected!",d.recognized),C=!0,B=D,I=O;for(let _ of R)_.param.reset(),_.clearedParams={pLSB:!0,pMSB:!0,data:!0};return;case"GM Off":case"GM On":h.info("%cGM on detected, removing!",d.info),Y(),C=!1;return;case"Drum Setup":i&&Y();return;case"Reverb Param":s&&Y();return;case"Chorus Param":n&&Y();return;case"Delay Param":a&&Y();return;case"Insertion Param":r&&Y();return;case"Program Change":g.get(W.channel+T)?.patch&&Y();return;case"Fine Tune":{let _=g.get(W.channel+T),$=R[W.channel+T];if($.isFirstNoteOn&&_){let ne=$.fineTune+W.value;$.keyShift+=Math.trunc(ne/100),$.fineTune=ne%100,h.info(`%cFine tuning already present on ${W.channel+T}, new relative tune: %c${ne} cents`,d.info,d.recognized),Y()}break}case"Controller Change":{let _=W.controller,$=g.get(W.channel+T);if($?.controllers?.get(_)!==void 0){Y();return}(_===f.bankSelect||_===f.bankSelectLSB)&&$?.patch&&Y();return}}}}}),!C&&[...g.values()].some(p=>p.patch&&p.patch!=="clear")){let p=0;t.tracks[0].events[0].statusByte===G.trackName&&p++,t.tracks[0].addEvents(p,se.gsReset(0)),B=0,I=p,h.info("%cGS on not detected. Adding it.",d.info)}let M=Math.max(0,t.firstNoteOn),S=t.tracks[B],Q=I+1;if(s&&s!=="clear"){let p=ta,D=s;S.addEvents(Q,se.gsMessage(M,64,1,p.level,[D.level]),se.gsMessage(M,64,1,p.preLowpass,[D.preLowpass]),se.gsMessage(M,64,1,p.character,[D.character]),se.gsMessage(M,64,1,p.time,[D.time]),se.gsMessage(M,64,1,p.delayFeedback,[D.delayFeedback]),se.gsMessage(M,64,1,p.preDelayTime,[D.preDelayTime]))}if(n&&n!=="clear"){let p=Aa,D=n;S.addEvents(Q,se.gsMessage(M,64,1,p.level,[D.level]),se.gsMessage(M,64,1,p.preLowpass,[D.preLowpass]),se.gsMessage(M,64,1,p.feedback,[D.feedback]),se.gsMessage(M,64,1,p.delay,[D.delay]),se.gsMessage(M,64,1,p.rate,[D.rate]),se.gsMessage(M,64,1,p.depth,[D.depth]),se.gsMessage(M,64,1,p.sendLevelToReverb,[D.sendLevelToReverb]),se.gsMessage(M,64,1,p.sendLevelToDelay,[D.sendLevelToDelay]))}if(a&&a!=="clear"){let p=sa,D=a;S.addEvents(Q,se.gsMessage(M,64,1,p.level,[D.level]),se.gsMessage(M,64,1,p.preLowpass,[D.preLowpass]),se.gsMessage(M,64,1,p.timeCenter,[D.timeCenter]),se.gsMessage(M,64,1,p.timeRatioLeft,[D.timeRatioLeft]),se.gsMessage(M,64,1,p.timeRatioRight,[D.timeRatioRight]),se.gsMessage(M,64,1,p.levelCenter,[D.levelCenter]),se.gsMessage(M,64,1,p.levelLeft,[D.levelLeft]),se.gsMessage(M,64,1,p.levelRight,[D.levelRight]),se.gsMessage(M,64,1,p.feedback,[D.feedback]),se.gsMessage(M,64,1,p.sendLevelToReverb,[D.sendLevelToReverb]))}if(r&&r!=="clear"){let p=r;for(let D=0;D<p.channels.length;D++)p.channels[D]&&S.addEvents(M,se.gsMessage(M,64,64|se.channelToSyx(D),34,[1]));for(let D=0;D<p.params.length;D++){let q=p.params[D];q!==255&&S.addEvents(Q,se.gsMessage(M,64,3,D+3,[q]))}S.addEvents(Q,se.gsMessage(M,64,3,0,[p.type>>8,p.type&127]))}t.flush(),h.groupEnd()}var RA=class An{name="";port=0;channels=new Set;events=[];static copyFrom(e){let A=new An;return A.copyFrom(e),A}copyFrom(e){this.name=e.name,this.port=e.port,this.channels=new Set(e.channels),this.events=e.events.map(A=>new We(A.ticks,A.statusByte,new ee(A.data)))}addEvent(e,A){this.events.splice(A,0,e)}addEvents(e,...A){this.events.splice(e,0,...A)}deleteEvent(e){this.events.splice(e,1)}pushEvent(e){this.events.push(e)}},aa={8:2,9:2,10:2,11:2,12:1,13:1,14:2};function Cs(t,e,A){h.groupCollapsed("%cParsing MIDI File...",d.info),t.fileName=A;let s=r=>{let i=Ee(r,4),o=Nt(r,4),g={type:i,size:o,data:new ee(o)},l=r.slice(r.currentIndex,r.currentIndex+g.size);return g.data.set(l,0),r.currentIndex+=g.size,g},n=s(e);if(n.type!=="MThd")throw h.groupEnd(),new SyntaxError(`Invalid MIDI Header! Expected "MThd", got "${n.type}"`);if(n.size!==6)throw h.groupEnd(),new RangeError(`Invalid MIDI header chunk size! Expected 6, got ${n.size}`);t.format=Nt(n.data,2);let a=Nt(n.data,2);t.timeDivision=Nt(n.data,2);for(let r=0;r<a;r++){let i=new RA,o=s(e);if(o.type!=="MTrk")throw h.groupEnd(),new SyntaxError(`Invalid track header! Expected "MTrk" got "${o.type}"`);let g,l=0;t.format===2&&r>0&&(l+=t.tracks[r-1].events[t.tracks[r-1].events.length-1].ticks);let C=o.data;for(;C.currentIndex<o.size;){l+=Qe(C);let B=C[C.currentIndex],I;if(g!==void 0&&B<128)I=g;else{if(B<128)throw h.groupEnd(),new SyntaxError(`Unexpected byte with no running byte. (${B})`);I=B,C.currentIndex++}let E;I>=G.noteOff&&I<G.systemExclusive?(E=aa[I>>4],g=I):I===G.systemExclusive?E=Qe(C):I===255?(I=C[C.currentIndex++],E=Qe(C)):E=0;let m=new ee(E);m.set(C.slice(C.currentIndex,C.currentIndex+E)),i.pushEvent(new We(l,I,m)),C.currentIndex+=E}t.tracks.push(i),h.info(`%cParsed %c${t.tracks.length}%c / %c${t.tracks.length}`,d.info,d.value,d.info,d.value)}h.info("%cAll tracks parsed correctly!",d.recognized),t.flush(!1),h.groupEnd()}function Bs(t){return t.toISOString().split(".")[0]+"Z"}var ra=[new Map([["domingo","Sunday"],["segunda-feira","Monday"],["ter\xE7a-feira","Tuesday"],["quarta-feira","Wednesday"],["quinta-feira","Thursday"],["sexta-feira","Friday"],["s\xE1bado","Saturday"],["janeiro","January"],["fevereiro","February"],["mar\xE7o","March"],["abril","April"],["maio","May"],["junho","June"],["julho","July"],["agosto","August"],["setembro","September"],["outubro","October"],["novembro","November"],["dezembro","December"]])];function ia(t){for(let e of ra){let A=t;for(let[n,a]of e.entries()){let r=new RegExp(n,"gi");A=A.replace(r,a)}let s=new Date(A);if(!Number.isNaN(s.getTime()))return s}}function oa(t){let e=/^(\d{2})\.(\d{2})\.(\d{4})$/.exec(t);if(e){let A=Number.parseInt(e[1]),s=Number.parseInt(e[2])-1,n=Number.parseInt(e[3]),a=new Date(n,s,A);if(!Number.isNaN(a.getTime()))return a}}function ga(t){let e=/^(\d{1,2})\s{1,2}(\d{1,2})\s{1,2}(\d{2})$/.exec(t);if(e){let A=e[1],s=(Number.parseInt(e[2])+1).toString(),n=e[3],a=new Date(`${s}/${A}/${n}`);if(!Number.isNaN(a.getTime()))return a}}function Ia(t){let e=/\b\d{4}\b/.exec(t);return e?new Date(e[0]):void 0}function Es(t){if(t=t.trim(),t.length===0)return new Date;let e=t.replaceAll(/\b(\d+)(st|nd|rd|th)\b/g,"$1").replace(/\s+at\s+/i," "),A=new Date(e);if(Number.isNaN(A.getTime())){let s=ia(t);if(s)return s;let n=oa(t);if(n)return n;let a=ga(t);if(a)return a;let r=Ia(t);return r||(h.warn(`Invalid date: "${t}". Replacing with the current date!`),new Date)}return A}function ca(t,e,A){e.currentIndex+=8;let s=Ee(e,4);if(s!=="RMID")throw h.groupEnd(),new SyntaxError(`Invalid RMIDI Header! Expected "RMID", got "${s}"`);let n=U.read(e);if(n.header!=="data")throw h.groupEnd(),new SyntaxError(`Invalid RMIDI Chunk header! Expected "data", got "${n.header}"`);let a=n.data,r=!1,i=!1;for(;e.currentIndex<e.length;){let o=e.currentIndex,g=U.read(e,!0);if(g.header==="RIFF"){let l=Ee(g.data,4).toLowerCase();l==="sfbk"||l==="sfpk"||l==="dls "?(h.info("%cFound embedded soundbank!",d.recognized),t.embeddedSoundBank=e.slice(o,o+g.size).buffer):h.warn(`Unknown RIFF chunk: "${l}"`),l==="dls "?t.isDLSRMIDI=!0:r=!0}else if(g.header==="LIST"&&Ee(g.data,4)==="INFO")for(h.info("%cFound RMIDI INFO chunk!",d.recognized);g.data.currentIndex<g.size;){let l=U.read(g.data,!0),C=l.header,B=l.data;switch(C){default:h.warn(`Unknown RMIDI Info: ${C}`);break;case"INAM":t.rmidiInfo.name=B;break;case"IALB":case"IPRD":t.rmidiInfo.album=B;break;case"ICRT":case"ICRD":t.rmidiInfo.creationDate=B;break;case"IART":t.rmidiInfo.artist=B;break;case"IGNR":t.rmidiInfo.genre=B;break;case"IPIC":t.rmidiInfo.picture=B;break;case"ICOP":t.rmidiInfo.copyright=B;break;case"ICMT":t.rmidiInfo.comment=B;break;case"IENG":t.rmidiInfo.engineer=B;break;case"ISFT":t.rmidiInfo.software=B;break;case"ISBJ":t.rmidiInfo.subject=B;break;case"IENC":t.rmidiInfo.infoEncoding=B;break;case"MENC":t.rmidiInfo.midiEncoding=B;break;case"DBNK":t.bankOffset=cs(B,2),i=!0;break}}}r&&!i&&(t.bankOffset=1),t.isDLSRMIDI&&(t.bankOffset=0),t.embeddedSoundBank===void 0&&(t.bankOffset=0),Cs(t,a,A)}var xA={XMFFileType:0,nodeName:1,nodeIDNumber:2,resourceFormat:3,filenameOnDisk:4,filenameExtensionOnDisk:5,macOSFileTypeAndCreator:6,mimeType:7,title:8,copyrightNotice:9,comment:10,autoStart:11,preload:12,contentDescription:13,ID3Metadata:14},vt={inLineResource:1,inFileResource:2,inFileNode:3,externalFile:4,externalXMF:5,XMFFileURIandNodeID:6},HA={StandardMIDIFile:0,StandardMIDIFileType1:1,DLS1:2,DLS2:3,DLS22:4,mobileDLS:5,unknown:-1,folder:-2},ha={standard:0,MMA:1,registered:2,nonRegistered:3},aA={none:0,MMAUnpacker:1,registered:2,nonRegistered:3},la=class sn{length;itemCount;metadataLength;metadata={};nodeData;innerNodes=[];packedContent=!1;nodeUnpackers=[];resourceFormat="unknown";referenceTypeID;constructor(e){let A=e.currentIndex;this.length=Qe(e),this.itemCount=Qe(e);let s=Qe(e),n=s-(e.currentIndex-A),a=e.slice(e.currentIndex,e.currentIndex+n);e.currentIndex+=n,this.metadataLength=Qe(a);let r=a.slice(a.currentIndex,a.currentIndex+this.metadataLength);a.currentIndex+=this.metadataLength;let i,o;for(;r.currentIndex<r.length;){r[r.currentIndex]===0?(r.currentIndex++,i=Qe(r),Object.values(xA).includes(i)?o=Object.keys(xA).find(I=>xA[I]===i)??"":(h.info(`Unknown field specifier: ${i}`),o=`unknown_${i}`)):(i=Ee(r,Qe(r)),o=i);let B=Qe(r);if(B===0){let I=Qe(r),E=r.slice(r.currentIndex,r.currentIndex+I);r.currentIndex+=I;let m=Qe(E);this.metadata[o]=m<4?Ee(E,I-1):E.slice(E.currentIndex)}else h.info(`International content: ${B}`),r.currentIndex+=Qe(r)}let g=a.currentIndex,l=Qe(a),C=a.slice(a.currentIndex,g+l);if(a.currentIndex=g+l,l>0)for(this.packedContent=!0;C.currentIndex<l;){let B={id:Qe(C)};switch(B.id){case aA.nonRegistered:case aA.registered:throw h.groupEnd(),new Error(`Unsupported unpacker ID: ${B.id}`);default:throw h.groupEnd(),new Error(`Unknown unpacker ID: ${B.id}`);case aA.none:B.standardID=Qe(C);break;case aA.MMAUnpacker:{let I=C[C.currentIndex++];I===0&&(I<<=8,I|=C[C.currentIndex++],I<<=8,I|=C[C.currentIndex++]);let E=Qe(C);B.manufacturerID=I,B.manufacturerInternalID=E}break}B.decodedSize=Qe(C),this.nodeUnpackers.push(B)}switch(e.currentIndex=A+s,this.referenceTypeID=Qe(e),this.nodeData=e.slice(e.currentIndex,A+this.length),e.currentIndex=A+this.length,this.referenceTypeID){case vt.inLineResource:break;case vt.externalXMF:case vt.inFileNode:case vt.XMFFileURIandNodeID:case vt.externalFile:case vt.inFileResource:throw h.groupEnd(),new Error(`Unsupported reference type: ${this.referenceTypeID}`);default:throw h.groupEnd(),new Error(`Unknown reference type: ${this.referenceTypeID}`)}if(this.isFile){if(this.packedContent){let I=this.nodeData.slice(2);h.info(`%cPacked content. Attempting to deflate. Target size: %c${this.nodeUnpackers[0].decodedSize}`,d.warn,d.value);try{this.nodeData=new ee(js(I).buffer)}catch(E){if(h.groupEnd(),E instanceof Error)throw new Error(`Error unpacking XMF file contents: ${E.message}.`,{cause:E})}}let B=this.metadata.resourceFormat;if(B===void 0)h.warn("No resource format for this file node!");else{B[0]!==ha.standard&&(h.info(`Non-standard formatTypeID: ${B.toString()}`),this.resourceFormat=B.toString());let I=B[1];Object.values(HA).includes(I)?this.resourceFormat=Object.keys(HA).find(E=>HA[E]===I):h.info(`Unrecognized resource format: ${I}`)}}else for(this.resourceFormat="folder";this.nodeData.currentIndex<this.nodeData.length;){let B=this.nodeData.currentIndex,I=Qe(this.nodeData),E=this.nodeData.slice(B,B+I);this.nodeData.currentIndex=B+I,this.innerNodes.push(new sn(E))}}get isFile(){return this.itemCount===0}};function Ca(t,e,A){t.bankOffset=0;let s=Ee(e,4);if(s!=="XMF_")throw h.groupEnd(),new SyntaxError(`Invalid XMF Header! Expected "_XMF", got "${s}"`);h.group("%cParsing XMF file...",d.info);let n=Ee(e,4);if(h.info(`%cXMF version: %c${n}`,d.info,d.recognized),n==="2.00"){let g=Nt(e,4),l=Nt(e,4);h.info(`%cFile Type ID: %c${g}%c, File Type Revision ID: %c${l}`,d.info,d.recognized,d.info,d.recognized)}Qe(e);let a=Qe(e);e.currentIndex+=a,e.currentIndex=Qe(e);let r=new la(e),i,o=g=>{let l=(C,B)=>{g.metadata[C]!==void 0&&typeof g.metadata[C]=="string"&&(t.rmidiInfo[B]=$e(g.metadata[C]))};if(l("nodeName","name"),l("title","name"),l("copyrightNotice","copyright"),l("comment","comment"),g.isFile)switch(g.resourceFormat){default:return;case"DLS1":case"DLS2":case"DLS22":case"mobileDLS":h.info("%cFound embedded DLS!",d.recognized),t.embeddedSoundBank=g.nodeData.buffer;break;case"StandardMIDIFile":case"StandardMIDIFileType1":h.info("%cFound embedded MIDI!",d.recognized),i=g.nodeData;break}else for(let C of g.innerNodes)o(C)};if(o(r),h.groupEnd(),!i)throw new Error("No MIDI data in the XMF file!");Cs(t,i,A)}function Ba(t,e){let A=new Map,s=e.systemParameters.keyShift,n=e.systemParameters.fineTune;for(let a=0;a<e.midiChannels.length;a++){let r=e.midiChannels[a];if(r.systemParameters.isMuted){A.set(a,"clear");continue}let i=r.systemParameters.keyShift+(r.drumChannel?0:s),o=r.systemParameters.fineTune+(r.drumChannel?0:n),g;r.systemParameters.presetLock&&r.patch&&(g={...r.patch});let l=new Map;for(let C=0;C<128;C++){if(!r.lockedControllers[C]||C===f.bankSelect)continue;let B=r.midiControllers[C]>>7;l.set(C,B)}A.set(a,{keyShift:i,fineTune:o,patch:g,controllers:l})}t.modify({channels:A,drumSetupParams:e.systemParameters.drumLock?"clear":void 0,reverbParams:e.systemParameters.reverbLock?e.reverbProcessor:void 0,chorusParams:e.systemParameters.chorusLock?e.chorusProcessor:void 0,delayParams:e.systemParameters.delayLock?e.delayProcessor:void 0,insertionParams:e.systemParameters.insertionEffectLock?e.insertionProcessor:void 0})}var Dt=class jA{tracks=[];timeline=[];timeDivision=480;duration=0;tempoChanges=[{ticks:0,tempo:120}];extraMetadata=[];lyrics=[];firstNoteOn=0;keyRange={min:0,max:127};lastVoiceEventTick=0;portChannelOffsetMap=[0];loop={start:0,end:0,type:"hard"};fileName;format=0;rmidiInfo={};bankOffset=0;isKaraokeFile=!1;isMultiPort=!1;isDLSRMIDI=!1;embeddedSoundBank;binaryName;get infoEncoding(){let e=this.rmidiInfo.infoEncoding;if(!e)return;let A=e.byteLength;return e[e.byteLength-1]===0&&A--,_e(e,A)}static fromArrayBuffer(e,A=""){let s=new jA,n=new ee(e);switch(_e(n,4)){case"RIFF":ca(s,n,A);break;case"XMF_":Ca(s,n,A);break;default:Cs(s,n,A);break}return s}static async fromFile(e){return this.fromArrayBuffer(await e.arrayBuffer(),e.name)}static copyFrom(e){let A=new jA;return A.copyFrom(e),A}copyFrom(e){this.copyMetadataFrom(e),this.embeddedSoundBank=e?.embeddedSoundBank?.slice(0)??void 0,this.tracks=e.tracks.map(A=>RA.copyFrom(A)),this.timeline=e.timeline.map(A=>({...A}))}midiTicksToSeconds(e){if(e=Math.max(e,0),this.tempoChanges.length===0)throw new Error("There are no tempo changes in the sequence. At least one is needed.");if(this.tempoChanges[this.tempoChanges.length-1].ticks!==0)throw new Error(`The last tempo change is not at 0 ticks. Got ${this.tempoChanges[this.tempoChanges.length-1].ticks} ticks.`);let A=this.tempoChanges.findIndex(n=>n.ticks<=e),s=0;for(;A<this.tempoChanges.length;){let n=this.tempoChanges[A++],a=e-n.ticks;s+=a*60/(n.tempo*this.timeDivision),e=n.ticks}return s}secondsToMIDITicks(e){if(e=Math.max(e,0),e===0)return 0;if(this.tempoChanges.length===0)throw new Error("There are no tempo changes in the sequence. At least one is needed.");if(this.tempoChanges[this.tempoChanges.length-1].ticks!==0)throw new Error(`The last tempo change is not at 0 ticks. Got ${this.tempoChanges[this.tempoChanges.length-1].ticks} ticks.`);let A=e,s=0;for(let n=this.tempoChanges.length-1;n>=0;n--){let a=this.tempoChanges[n],r=this.tempoChanges[n-1],i=r?r.ticks-a.ticks:1/0,o=60/(a.tempo*this.timeDivision),g=i*o;if(A<=g)return s+=Math.round(A/o),s;s+=i,A-=g}return s}getUsedProgramsAndKeys(e){return $n(this,e)}preloadSynth(e){h.groupCollapsed("%cPreloading samples...",d.info);let A=this.getUsedProgramsAndKeys(e.soundBankManager);for(let[s,n]of A.entries()){h.info(`%cPreloading used samples on %c${s.name}%c...`,d.info,d.recognized,d.info);for(let[a,r]of n.entries())for(let i of r)e.getVoicesForPreset(s,a,i)}h.groupEnd()}flush(e=!0){if(e)for(let A of this.tracks)A.events.sort((s,n)=>s.ticks-n.ticks);this.parseInternal()}getNoteTimes(e=0){return ea(this,e)}writeMIDI(){return qn(this)}writeRMIDI(e,A=Rs){return zn(this,e,bA(A,Rs))}modify(e){na(this,e)}applySnapshot(e){Ba(this,e)}getName(e="Shift_JIS"){let A="",s=this.getRMIDInfo("name");if(s)return s.trim();if(this.binaryName){e=this.getRMIDInfo("midiEncoding")??e;try{A=new TextDecoder(e).decode(this.binaryName).trim()}catch(n){h.warn(`Failed to decode MIDI name: ${n}`)}}return A||this.fileName}getExtraMetadata(e="Shift_JIS"){e=this.infoEncoding??e;let A=new TextDecoder(e);return this.extraMetadata.map(s=>A.decode(s.data).replaceAll(/@T|@A/g,"").trim())}setRMIDInfo(e,A){if(this.rmidiInfo.infoEncoding=$e("utf-8",!0),e==="picture")this.rmidiInfo.picture=new Uint8Array(A);else if(e==="creationDate")this.rmidiInfo.creationDate=$e(Bs(A),!0);else{let s=new TextEncoder().encode(A);this.rmidiInfo[e]=new Uint8Array([...s,0])}}getRMIDInfo(e){if(!this.rmidiInfo[e])return;let A=this.infoEncoding??"UTF-8";if(e==="picture")return this.rmidiInfo[e].buffer;if(e==="creationDate")return Es(_e(this.rmidiInfo[e]));try{let s=new TextDecoder(A),n=this.rmidiInfo[e];return n[n.length-1]===0&&(n=n?.slice(0,-1)),s.decode(n.buffer).trim()}catch(s){h.warn(`Failed to decode ${e} name: ${s}`);return}}iterate(e){let A=new Array(this.tracks.length).fill(0),s=this.tracks.length;for(;s>0;){let n=0,a=1/0;for(let o=0;o<this.tracks.length;o++){let g=this.tracks[o].events;A[o]>=g.length||g[A[o]].ticks<a&&(n=o,a=g[A[o]].ticks)}let r=this.tracks[n].events;if(A[n]>=r.length){s--;continue}let i=A[n];e(r[i],n,A),A[n]++}}copyMetadataFrom(e){this.fileName=e.fileName,this.timeDivision=e.timeDivision,this.duration=e.duration,this.firstNoteOn=e.firstNoteOn,this.lastVoiceEventTick=e.lastVoiceEventTick,this.format=e.format,this.bankOffset=e.bankOffset,this.isKaraokeFile=e.isKaraokeFile,this.isMultiPort=e.isMultiPort,this.isDLSRMIDI=e.isDLSRMIDI,this.isDLSRMIDI=e.isDLSRMIDI,this.tempoChanges=[...e.tempoChanges],this.extraMetadata=e.extraMetadata.map(A=>new We(A.ticks,A.statusByte,new ee(A.data))),this.lyrics=e.lyrics.map(A=>new We(A.ticks,A.statusByte,new ee(A.data))),this.portChannelOffsetMap=[...e.portChannelOffsetMap],this.binaryName=e?.binaryName?.slice(),this.loop={...e.loop},this.keyRange={...e.keyRange},this.rmidiInfo={};for(let A of Object.entries(e.rmidiInfo)){let s=A[0],n=A[1];this.rmidiInfo[s]=new Uint8Array(n)}}parseInternal(){h.group("%cInterpreting MIDI events...",d.info);let e=!1;this.tempoChanges=[{ticks:0,tempo:120}],this.extraMetadata=[],this.lyrics=[],this.firstNoteOn=0,this.keyRange={max:0,min:127},this.lastVoiceEventTick=0,this.portChannelOffsetMap=[0],this.loop={start:0,end:0,type:"hard"},this.isKaraokeFile=!1,this.isMultiPort=!1;let A=!1;this.rmidiInfo.name!==void 0&&(A=!0);let s=null,n=null,a="hard";for(let g of this.tracks){let l=new Set,C=!1;for(let I=0;I<g.events.length;I++){let E=g.events[I];if(E.statusByte>=128&&E.statusByte<240)switch(C=!0,E.ticks>this.lastVoiceEventTick&&(this.lastVoiceEventTick=E.ticks),E.statusByte&240){case G.controllerChange:switch(E.data[0]){case 2:case 111:E.data[1]===0&&(s=E.ticks);break;case 116:s=E.ticks;break;case 4:case 117:n===null&&(E.data[0]!==4||E.data[0]===4&&E.data[1]===0)?(a="soft",n=E.ticks):(n=0,a="hard");break;case 0:this.isDLSRMIDI&&E.data[1]!==0&&E.data[1]!==127&&(h.info("%cDLS RMIDI with offset 1 detected!",d.recognized),this.bankOffset=1)}break;case G.noteOn:{l.add(E.statusByte&15);let k=E.data[0];this.keyRange.min=Math.min(this.keyRange.min,k),this.keyRange.max=Math.max(this.keyRange.max,k);break}}let m=_e(E.data);switch(E.statusByte){case G.endOfTrack:I!==g.events.length-1&&(g.deleteEvent(I),I--,h.warn("Unexpected EndOfTrack. Removing!"));break;case G.setTempo:this.tempoChanges.push({ticks:E.ticks,tempo:6e7/xt(E.data,3)});break;case G.marker:switch(m.trim().toLowerCase()){default:break;case"start":case"loopstart":s=E.ticks;break;case"loopend":n=E.ticks}break;case G.copyright:this.extraMetadata.push(E);break;case G.lyric:m.trim().startsWith("@KMIDI KARAOKE FILE")&&(this.isKaraokeFile=!0,h.info("%cKaraoke MIDI detected!",d.recognized)),this.isKaraokeFile?E.statusByte=G.text:this.lyrics.push(E);case G.text:{let k=m.trim();k.startsWith("@KMIDI KARAOKE FILE")?(this.isKaraokeFile=!0,h.info("%cKaraoke MIDI detected!",d.recognized)):this.isKaraokeFile&&(k.startsWith("@T")||k.startsWith("@A")?e?this.extraMetadata.push(E):(this.binaryName=E.data.slice(2),e=!0,A=!0):k.startsWith("@")||this.lyrics.push(E));break}}}g.channels=l,g.name="";let B=g.events.find(I=>I.statusByte===G.trackName);B&&this.tracks.indexOf(g)>0&&(g.name=_e(B.data),!C&&!g.name.toLowerCase().includes("setup")&&this.extraMetadata.push(B))}this.tempoChanges.reverse(),h.info("%cCorrecting loops, ports and detecting notes...",d.info);let r=[];for(let g of this.tracks){let l=g.events.find(C=>(C.statusByte&240)===G.noteOn);l&&r.push(l.ticks)}this.firstNoteOn=Math.min(...r),h.info(`%cFirst note-on detected at: %c${this.firstNoteOn}%c ticks!`,d.info,d.recognized,d.info),s??=this.firstNoteOn,(n===null||n===0)&&(n=this.lastVoiceEventTick),this.loop={start:s,end:n,type:a},this.lastVoiceEventTick=Math.max(this.lastVoiceEventTick,this.loop.end),h.info(`%cLoop points: start: %c${this.loop.start}%c end: %c${this.loop.end}`,d.info,d.recognized,d.info,d.recognized);let i=0;this.portChannelOffsetMap=[];for(let g of this.tracks)if(g.port=-1,g.channels.size!==0)for(let l of g.events){if(l.statusByte!==G.midiPort)continue;let C=l.data[0];g.port=C,this.portChannelOffsetMap[C]===void 0&&(this.portChannelOffsetMap[C]=i,i+=16)}this.portChannelOffsetMap=[...this.portChannelOffsetMap].map(g=>g??0);let o=1/0;for(let g of this.tracks)g.port!==-1&&o>g.port&&(o=g.port);o===1/0&&(o=0);for(let g of this.tracks)(g.port===-1||g.port===void 0)&&(g.port=o);if(this.portChannelOffsetMap.length===0&&(this.portChannelOffsetMap=[0]),this.portChannelOffsetMap.length<2?h.info("%cNo additional MIDI Ports detected.",d.info):(this.isMultiPort=!0,h.info("%cMIDI Ports detected!",d.recognized)),!A)if(this.tracks.length>1){if(!this.tracks[0].events.some(g=>g.statusByte>=G.noteOn&&g.statusByte<G.polyPressure)){let g=this.tracks[0].events.find(l=>l.statusByte===G.trackName);g&&(this.binaryName=g.data)}}else{let g=this.tracks[0].events.find(l=>l.statusByte===G.trackName);g&&(this.binaryName=g.data)}if(this.extraMetadata=this.extraMetadata.filter(g=>g.data.length>0),this.lyrics.sort((g,l)=>g.ticks-l.ticks),!this.tracks.some(g=>g.events[0].ticks===0)){let g=this.tracks[0],l=this?.binaryName?.buffer;l||(l=new Uint8Array(0).buffer),g.addEvents(0,new We(0,G.trackName,new ee(l)))}this.duration=this.midiTicksToSeconds(this.lastVoiceEventTick),this.timeline.length=0,this.iterate((g,l,C)=>{this.timeline.push(Object.freeze({ev:C[l],tr:l}))}),this.binaryName?.length===0&&(this.binaryName=void 0),h.info(`%cMIDI file parsed. Total tick time: %c${this.lastVoiceEventTick}%c, total seconds time: %c${_A(Math.ceil(this.duration)).time}`,d.info,d.recognized,d.info,d.recognized),h.groupEnd()}};function Ea(t,e){if(this.externalMIDIPlayback&&t.statusByte>=128){this.sendMIDIMessage([t.statusByte,...t.data]);return}let A=this._midiData.tracks[e],s,n=0;t.statusByte>=128&&t.statusByte<240?(s=t.statusByte&240,n=t.statusByte&15):s=t.statusByte;let a=this.midiPortChannelOffsets[this.currentMIDIPorts[e]]||0;switch(n+=a,s){case G.noteOn:{let r=t.data[1];r>0?(this.synth.noteOn(n,t.data[0],r),this.playingNotes[n].set(t.data[0],r)):(this.synth.noteOff(n,t.data[0]),this.playingNotes[n].delete(t.data[0]));break}case G.noteOff:this.synth.noteOff(n,t.data[0]),this.playingNotes[n].delete(t.data[0]);break;case G.pitchWheel:this.synth.pitchWheel(n,t.data[1]<<7|t.data[0]);break;case G.controllerChange:if(this._midiData.isMultiPort&&A.channels.size===0)return;this.synth.controllerChange(n,t.data[0],t.data[1]);break;case G.programChange:if(this._midiData.isMultiPort&&A.channels.size===0)return;this.synth.programChange(n,t.data[0]);break;case G.polyPressure:this.synth.polyPressure(n,t.data[0],t.data[1]);break;case G.channelPressure:this.synth.channelPressure(n,t.data[0]);break;case G.systemExclusive:this.synth.systemExclusive(t.data,a);break;case G.setTempo:{let r=6e7/xt(t.data,3);this.oneTickToSeconds=60/(r*this._midiData.timeDivision),this.oneTickToSeconds===0&&(this.oneTickToSeconds=60/(120*this._midiData.timeDivision),h.info("invalid tempo! falling back to 120 BPM"));break}case G.timeSignature:case G.endOfTrack:case G.midiChannelPrefix:case G.songPosition:case G.activeSensing:case G.keySignature:case G.sequenceNumber:case G.sequenceSpecific:case G.text:case G.lyric:case G.copyright:case G.trackName:case G.marker:case G.cuePoint:case G.instrumentName:case G.programName:break;case G.midiPort:this.assignMIDIPort(e,t.data[0]);break;case G.reset:this.synth.stopAllChannels(),this.synth.reset();break;default:h.info(`%cUnrecognized Event: %c${t.statusByte}%c status byte: %c${Object.keys(G).find(r=>G[r]===s)}`,d.warn,d.unrecognized,d.warn,d.value);break}s>=0&&s<128&&this.callEvent("metaEvent",{event:t,trackIndex:e})}function da(){if(this.paused||!this._midiData)return;let t=this.currentTime;for(;this.playedTime<t;){let{timeline:e,tracks:A,lastVoiceEventTick:s,loop:n}=this._midiData,a=e[this.index++],r=A[a.tr].events[a.ev];if(this.processEvent(r,a.tr),this.loopCount>0&&n.end<=r.ticks){this.loopCount!==1/0&&(this.loopCount--,this.callEvent("loopCountChange",{newCount:this.loopCount})),n.type==="soft"?this.jumpToTick(n.start):this.setTimeTicks(n.start);return}if(this.index>=e.length||r.ticks>=s){this.songIsFinished();return}let i=e[this.index],o=A[i.tr].events[i.ev];this.playedTime+=this.oneTickToSeconds*(o.ticks-r.ticks)}}function fa(t,e){this._midiData.tracks[t].channels.size!==0&&(this.midiPortChannelOffset===0&&(this.midiPortChannelOffset+=16,this.midiPortChannelOffsets[e]=0),this.midiPortChannelOffsets[e]===void 0&&(this.synth.midiChannels.length<this.midiPortChannelOffset+15&&this.addNewMIDIPort(),this.midiPortChannelOffsets[e]=this.midiPortChannelOffset,this.midiPortChannelOffset+=16),this.currentMIDIPorts[t]=e)}function Qa(t){if(!t.tracks)throw new Error("This MIDI has no tracks!");if(t.duration===0){h.warn("This MIDI file has a duration of exactly 0 seconds."),this.pausedTime=0,this.isFinished=!0;return}this.oneTickToSeconds=60/(120*t.timeDivision),this._midiData=t,this.isFinished=!1,this.synth.clearEmbeddedSoundBank(),this._midiData.embeddedSoundBank!==void 0&&(h.info("%cEmbedded soundbank detected! Using it.",d.recognized),this.synth.setEmbeddedSoundBank(this._midiData.embeddedSoundBank,this._midiData.bankOffset),this.preload&&this._midiData.preloadSynth(this.synth)),this.currentMIDIPorts=this._midiData.tracks.map(e=>e.port),this.midiPortChannelOffset=0,this.midiPortChannelOffsets={};for(let[e,A]of this._midiData.tracks.entries())this.assignMIDIPort(e,A.port);this.firstNoteTime=this._midiData.midiTicksToSeconds(this._midiData.firstNoteOn),h.info(`%cTotal song time: ${_A(Math.ceil(this._midiData.duration)).time}`,d.recognized),this.callEvent("songChange",{songIndex:this._songIndex}),this._midiData.duration<=.2&&(h.warn(`%cVery short song: (${_A(Math.round(this._midiData.duration)).time}). Disabling loop!`,d.warn),this.loopCount=0),this.currentTime=0}function ua(){this.lastNote=this.channelSystem==="xg"?60:-1}var mt=new Int16Array(128).fill(0),Me=(t,e)=>mt[t]=e<<7;Me(f.mainVolume,100);Me(f.balance,64);Me(f.expression,127);Me(f.pan,64);Me(f.filterResonance,64);Me(f.releaseTime,64);Me(f.attackTime,64);Me(f.brightness,64);Me(f.decayTime,64);Me(f.vibratoRate,64);Me(f.vibratoDepth,64);Me(f.vibratoDelay,64);Me(f.generalPurposeController6,64);Me(f.generalPurposeController8,64);Me(f.registeredParameterLSB,127);Me(f.registeredParameterMSB,127);Me(f.nonRegisteredParameterLSB,0);Me(f.nonRegisteredParameterMSB,0);var uA=new Int8Array(128).fill(127);uA[35]=0;uA[36]=0;function ma(t=!0){for(let e=0;e<128;e++){if(this.lockedControllers[e]){this.synthCore.callEvent("controllerChange",{channel:this.channel,controller:e,value:this._midiControllers[e]>>7});continue}let A=mt[e];this._midiControllers[e]!==A&&e!==f.portamentoControl&&e!==f.dataEntryMSB&&e!==f.registeredParameterMSB&&e!==f.registeredParameterLSB&&e!==f.nonRegisteredParameterMSB&&e!==f.nonRegisteredParameterLSB&&this.controllerChange(e,A>>7,t)}this.synthCore.systemParameters.insertionEffectLock||this.setMIDIParameter("efxAssign",!1),this.setMIDIParameter("rxChannel",this.channel),this.setMIDIParameter("assignMode",2),this.setMIDIParameter("randomPan",!1),this.setMIDIParameter("cc1",16),this.setMIDIParameter("cc2",17),this.setMIDIParameter("drumMap",this.channel%16===9?1:0),this.pitchWheel(8192),this.pitchWheelRange(2,!1),this.keyShift(0,!1),this.fineTune(0,!1),this.setMIDIParameter("pressure",0),this.modulationDepth(50,!1),!this.lockedControllers[f.monoModeOn]&&!this.lockedControllers[f.polyModeOn]&&this.setMIDIParameter("polyMode",!0),this.octaveTuning.fill(0),ua.call(this),this.resetDrumParams(),this.resetGeneratorOverrides(),this.resetGeneratorOffsets(),this.dynamicModulators.resetModulators(),this.sf2NRPNGeneratorLSB=0,this.lastParameterIsRegistered=!0,this._midiControllers[f.nonRegisteredParameterLSB]=0,this._midiControllers[f.nonRegisteredParameterMSB]=0,this._midiControllers[f.registeredParameterLSB]=16256,this._midiControllers[f.registeredParameterMSB]=16256,this._midiControllers[f.dataEntryMSB]=0,this._midiControllers[f.dataEntryLSB]=0,this.setBankMSB(Se.getDefaultBank(this.channelSystem)),this.setBankLSB(0),this.setGSDrums(!1),this.setDrums(this.channel%16===9),this.programChange(0)}var nn=[f.modulationWheel,f.expression,f.sustainPedal,f.portamentoOnOff,f.sostenutoPedal,f.softPedal,f.registeredParameterMSB,f.registeredParameterLSB];function pa(){this.pitchWheel(8192),this.setMIDIParameter("pressure",0);for(let t of nn){let e=mt[t];e!==this._midiControllers[t]&&this.controllerChange(t,e>>7)}}var rA=new Set([f.dataDecrement,f.dataIncrement,f.dataEntryMSB,f.dataEntryLSB,f.registeredParameterLSB,f.registeredParameterMSB,f.nonRegisteredParameterLSB,f.nonRegisteredParameterMSB,f.bankSelect,f.bankSelectLSB,f.resetAllControllers,f.monoModeOn,f.polyModeOn]);function ya(t,e=void 0){if(!this._midiData)return!1;this.oneTickToSeconds=60/(120*this._midiData.timeDivision),this.sendMIDIReset(),this.playedTime=0,this.index=0;let A=this.synth.midiChannels.length,s=[];for(let g=0;g<A;g++)s.push({pitchWheel:8192,controllers:new Int16Array(mt),param:new QA(g),portamentoNote:-1});let n,a=0;function r(g){let l=s[g];l.pitchWheel=8192,l.param.reset();for(let C of nn)l.controllers[C]=mt[C]}let{timeline:i,tracks:o}=this._midiData;for(;;){let g=i[this.index],l=g.tr,C=o[l],B=C.events[g.ev];if(e===void 0){if(this.playedTime>=t)break}else if(B.ticks>=e)break;let I,E=0;B.statusByte>=128&&B.statusByte<240?(I=B.statusByte&240,E=B.statusByte&15):I=B.statusByte;let m=E+(this.midiPortChannelOffsets[C.port]||0);s[m]??={pitchWheel:8192,controllers:new Int16Array(mt),param:new QA(m),portamentoNote:-1};let k=s[m];switch(I){case G.noteOn:k.portamentoNote=B.data[0];break;case G.noteOff:break;case G.pitchWheel:k.pitchWheel=B.data[1]<<7|B.data[0];break;case G.systemExclusive:{let R=se.analyzeSysEx(B.data);switch(R.type){default:this.processEvent(B,l);break;case"Controller Change":{let{controller:M,value:S,channel:Q}=R;if(this._midiData.isMultiPort&&C.channels.size===0)break;if(M===f.resetAllControllers){r(Q);break}rA.has(M)?this.sendMIDICC(Q,M,S):s[Q].controllers[M]=S<<7}}break}case G.controllerChange:{if(this._midiData.isMultiPort&&C.channels.size===0)break;let R=B.data[0],M=B.data[1];switch(R){default:if(R===f.resetAllControllers){r(m);break}rA.has(R)?this.sendMIDICC(m,R,M):k.controllers[R]=M<<7;break;case f.registeredParameterMSB:case f.registeredParameterLSB:case f.nonRegisteredParameterLSB:case f.nonRegisteredParameterMSB:k.param.controllerChange(R,M,0,0),this.sendMIDICC(m,R,M);break;case f.dataEntryMSB:case f.dataEntryLSB:{let S=k.param.controllerChange(R,M,0,0);this.sendMIDICC(m,R,M),S.type==="Controller Change"&&(rA.has(S.controller)?this.sendMIDICC(m,S.controller,S.value):k.controllers[S.controller]=S.value<<7);break}}break}case G.setTempo:{let R=6e7/xt(B.data,3);this.oneTickToSeconds=60/(R*this._midiData.timeDivision),n=B,a=l;break}default:this.processEvent(B,l);break}let y=i[++this.index],b=o[y.tr].events[y.ev];if(b===void 0)return this.stop(),!1;this.playedTime+=this.oneTickToSeconds*(b.ticks-B.ticks)}for(let g=0;g<A;g++){let l=s[g];this.sendMIDIPitchWheel(g,l.pitchWheel),l.portamentoNote>=0&&(this.externalMIDIPlayback?this.sendMIDICC(g,f.portamentoControl,l.portamentoNote):this.synth.midiChannels[g].setLastNote(l.portamentoNote));for(let C=0;C<128;C++){let B=l.controllers[C]>>7;B!==mt[C]&&!rA.has(C)&&this.sendMIDICC(g,C,B)}}return n&&this.callEvent("metaEvent",{event:n,trackIndex:a}),this.paused&&(this.pausedTime=this.playedTime),!0}var an=class{songs=[];shuffledSongIndexes=[];synth;externalMIDIPlayback=!1;retriggerPausedNotes=!0;loopCount=0;skipToFirstNoteOn=!0;isFinished=!1;preload=!0;onEventCall;processTick=da.bind(this);firstNoteTime=0;oneTickToSeconds=0;index=0;playedTime=0;pausedTime=-1;absoluteStartTime=0;playingNotes=[];currentMIDIPorts=[];midiPortChannelOffset=0;midiPortChannelOffsets={};assignMIDIPort=fa.bind(this);loadNewSequence=Qa.bind(this);processEvent=Ea.bind(this);setTimeTo=ya.bind(this);constructor(t){this.synth=t,this.absoluteStartTime=this.synth.currentTime;for(let e=0;e<16;e++)this.playingNotes.push(new Map)}_midiData;get midiData(){return this._midiData}get duration(){return this._midiData?.duration??0}_songIndex=0;get songIndex(){return this._songIndex}set songIndex(t){this._songIndex=t,this._songIndex=Math.max(0,t%this.songs.length),this.loadCurrentSong()}_shuffleMode=!1;get shuffleMode(){return this._shuffleMode}set shuffleMode(t){this._shuffleMode=t}_playbackRate=1;get playbackRate(){return this._playbackRate}set playbackRate(t){let e=this.currentTime;this._playbackRate=t,this.recalculateStartTime(e)}get currentTime(){return this.pausedTime!==void 0?this.pausedTime:(this.synth.currentTime-this.absoluteStartTime)*this._playbackRate}set currentTime(t){if(this._midiData)if(this.paused&&(this.pausedTime=t),t>this._midiData.duration||t<0)this.skipToFirstNoteOn?this.setTimeTicks(this._midiData.firstNoteOn-1):this.setTimeTicks(0);else if(this.skipToFirstNoteOn&&t<this.firstNoteTime){this.setTimeTicks(this._midiData.firstNoteOn-1);return}else{for(let e of this.playingNotes)e.clear();this.callEvent("timeChange",{newTime:t}),this.setTimeTo(t),this.recalculateStartTime(t)}}get paused(){return this.pausedTime!==void 0}play(){if(!this._midiData){h.warn("No songs loaded in the sequencer. Ignoring the play call.");return}if(this.currentTime>=this._midiData.duration&&(this.currentTime=0),this.paused&&this.recalculateStartTime(this.pausedTime??0),this.retriggerPausedNotes&&!this.externalMIDIPlayback)for(let t=0;t<this.playingNotes.length;t++){let e=this.playingNotes[t];for(let[A,s]of e)this.sendMIDINoteOn(t,A,s)}this.pausedTime=void 0}pause(){this.pauseInternal(!1)}loadNewSongList(t){if(this.songs=t,this.songs.length!==0){if(this._songIndex=0,this.shuffleSongIndexes(),this.callEvent("songListChange",{newSongList:[...this.songs]}),this.preload){h.group("%cPreloading all songs...",d.info);for(let e of this.songs)e.embeddedSoundBank===void 0&&e.preloadSynth(this.synth);h.groupEnd()}this.loadCurrentSong()}}callEvent(t,e){this?.onEventCall?.({type:t,data:e})}pauseInternal(t){this.paused||(this.stop(),this.callEvent("pause",{isFinished:t}),t&&this.callEvent("songEnded",{}))}songIsFinished(){if(this.isFinished=!0,this.songs.length===1){this.pauseInternal(!0);return}this._songIndex++,this._songIndex%=this.songs.length,this.loadCurrentSong()}stop(){this.pausedTime=this.currentTime,this.sendMIDIAllOff()}addNewMIDIPort(){for(let t=0;t<16;t++)this.synth.createMIDIChannel(),this.playingNotes.push(new Map)}sendMIDIMessage(t){if(!this.externalMIDIPlayback){h.warn(`Attempting to send ${zs(t)} to the synthesizer via sendMIDIMessage. This shouldn't happen!`);return}this.callEvent("midiMessage",{message:t,time:this.synth.currentTime})}sendMIDIAllOff(){for(let t=0;t<16;t++)this.sendMIDICC(t,f.sustainPedal,0);if(!this.externalMIDIPlayback){this.synth.stopAllChannels();return}for(let t=0;t<this.playingNotes.length;t++){let e=this.playingNotes[t];for(let A of e.keys())this.sendMIDINoteOff(t,A)}for(let t=0;t<16;t++)this.sendMIDICC(t,f.allNotesOff,0)}sendMIDIReset(){if(this.sendMIDIAllOff(),!this.externalMIDIPlayback){this.synth.reset();return}this.sendMIDISysEx(se.gsData(64,0,127,[0]))}loadCurrentSong(){let t=this._songIndex;this._shuffleMode&&(t=this.shuffledSongIndexes[this._songIndex]),this.loadNewSequence(this.songs[t])}shuffleSongIndexes(){let t=this.songs.map((e,A)=>A);for(this.shuffledSongIndexes.length=0;t.length>0;){let e=t[Math.floor(Math.random()*t.length)];this.shuffledSongIndexes.push(e),t.splice(t.indexOf(e),1)}}setTimeTicks(t){if(!this._midiData)return;for(let s of this.playingNotes)s.clear();let e=this._midiData.midiTicksToSeconds(t);this.callEvent("timeChange",{newTime:e});let A=this.setTimeTo(0,t);this.recalculateStartTime(this.playedTime)}recalculateStartTime(t){this.absoluteStartTime=this.synth.currentTime-t/this._playbackRate}jumpToTick(t){if(!this._midiData)return;this.sendMIDIAllOff();let e=this._midiData,A=e.midiTicksToSeconds(t);this.callEvent("timeChange",{newTime:A}),this.recalculateStartTime(A),this.playedTime=A;let s=e.timeline.findIndex(a=>e.tracks[a.tr].events[a.ev].ticks>=t);this.index=s===-1?e.timeline.length:s;let n=e.tempoChanges.find(a=>a.ticks<=t);this.oneTickToSeconds=60/(n.tempo*e.timeDivision)}sendMIDINoteOn(t,e,A){if(!this.externalMIDIPlayback){this.synth.noteOn(t,e,A);return}t%=16,this.sendMIDIMessage([G.noteOn|t,e,A])}sendMIDINoteOff(t,e){if(!this.externalMIDIPlayback){this.synth.noteOff(t,e);return}t%=16,this.sendMIDIMessage([G.noteOff|t,e,64])}sendMIDICC(t,e,A){if(!this.externalMIDIPlayback){this.synth.controllerChange(t,e,A);return}t%=16,this.sendMIDIMessage([G.controllerChange|t,e,A])}sendMIDISysEx(t){if(!this.externalMIDIPlayback){this.synth.systemExclusive(t);return}this.sendMIDIMessage([G.systemExclusive,...t])}sendMIDIPitchWheel(t,e){if(!this.externalMIDIPlayback){this.synth.pitchWheel(t,e);return}t%=16,this.sendMIDIMessage([G.pitchWheel|t,e&127,e>>7])}},Sa={linear:0,nearestNeighbor:1,hermite:2},Zt=Zt!==void 0?Zt:{},Fs=!1,rn;Zt.isInitialized=new Promise(t=>rn=t);var ka=function(t){var e,A,s,n,a,r,i,o="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",g="",l=0;t=t.replace(/[^A-Za-z0-9\+\/\=]/g,"");do n=o.indexOf(t.charAt(l++)),a=o.indexOf(t.charAt(l++)),r=o.indexOf(t.charAt(l++)),i=o.indexOf(t.charAt(l++)),e=n<<2|a>>4,A=(15&a)<<4|r>>2,s=(3&r)<<6|i,g+=String.fromCharCode(e),r!==64&&(g+=String.fromCharCode(A)),i!==64&&(g+=String.fromCharCode(s));while(l<t.length);return g};(function(){var t,e,A,s,n,a,r,i,o,g,l,C,B,I=I!==void 0?I:{};I.wasmBinary=Uint8Array.from(ka("AGFzbQEAAAABpQEYYAJ/fwF/YAF/AGAAAX9gBH9/f38AYAAAYAN/f38Bf2ABfwF/YAJ/fwBgBn9/f39/fwF/YAR/f39/AX9gBX9/f39/AX9gB39/f39/f38Bf2AGf39/f39/AGAIf39/f39/f38Bf2AFf39/f38AYAd/f39/f39/AGADf39/AGABfwF9YAF9AX1gAnx/AXxgAnx/AX9gA3x8fwF8YAJ8fAF8YAF8AXwCngIPA2VudgZtZW1vcnkCAIACA2VudgV0YWJsZQFwAQQEA2Vudgl0YWJsZUJhc2UDfwADZW52DkRZTkFNSUNUT1BfUFRSA38AA2VudghTVEFDS1RPUAN/AANlbnYJU1RBQ0tfTUFYA38ABmdsb2JhbAhJbmZpbml0eQN8AANlbnYFYWJvcnQAAQNlbnYNZW5sYXJnZU1lbW9yeQACA2Vudg5nZXRUb3RhbE1lbW9yeQACA2VudhdhYm9ydE9uQ2Fubm90R3Jvd01lbW9yeQACA2Vudg5fX19hc3NlcnRfZmFpbAADA2VudgtfX19zZXRFcnJObwABA2VudgZfYWJvcnQABANlbnYWX2Vtc2NyaXB0ZW5fbWVtY3B5X2JpZwAFA3d2BgYCAQcHAQIBAQcBCAcFAAkGCQoHBgYGBgEFBgIBBgYKAAgLAAYGBgYGBgYBAAoMDAMGBQANCAoJAAwODA8OAQAGBgcEABAJEAERAAADBQwAAAMHBxIGAQAABwIFEwMOBw8HBgYQFAoVExYXFxcXFgQFBQYFAAYkB38BIwELfwEjAgt/ASMDC38BQQALfwFBAAt8ASMEC38BQQALB9MCFRBfX2dyb3dXYXNtTWVtb3J5AAgRX19fZXJybm9fbG9jYXRpb24AYwVfZnJlZQBfB19tYWxsb2MAXgdfbWVtY3B5AHkHX21lbXNldAB6BV9zYnJrAHsXX3N0Yl92b3JiaXNfanNfY2hhbm5lbHMAJhRfc3RiX3ZvcmJpc19qc19jbG9zZQAlFV9zdGJfdm9yYmlzX2pzX2RlY29kZQAoE19zdGJfdm9yYmlzX2pzX29wZW4AJBpfc3RiX3ZvcmJpc19qc19zYW1wbGVfcmF0ZQAnC2R5bkNhbGxfaWlpAHwTZXN0YWJsaXNoU3RhY2tTcGFjZQAMC2dldFRlbXBSZXQwAA8LcnVuUG9zdFNldHMAeAtzZXRUZW1wUmV0MAAOCHNldFRocmV3AA0Kc3RhY2tBbGxvYwAJDHN0YWNrUmVzdG9yZQALCXN0YWNrU2F2ZQAKCQoBACMACwR9VFl9Csb2A3YGACAAQAALGwEBfyMGIQEjBiAAaiQGIwZBD2pBcHEkBiABCwQAIwYLBgAgACQGCwoAIAAkBiABJAcLEAAjCEUEQCAAJAggASQJCwsGACAAJAsLBAAjCwsRACAABEAgABARIAAgABASCwvvBwEKfyAAQYADaiEHIAcoAgAhBQJAIAUEQCAAQfwBaiEEIAQoAgAhASABQQBKBEAgAEHwAGohCANAIAUgAkEYbGpBEGohCSAJKAIAIQEgAQRAIAgoAgAhAyAFIAJBGGxqQQ1qIQogCi0AACEGIAZB/wFxIQYgAyAGQbAQbGpBBGohAyADKAIAIQMgA0EASgRAQQAhAwNAIAEgA0ECdGohASABKAIAIQEgACABEBIgA0EBaiEDIAgoAgAhASAKLQAAIQYgBkH/AXEhBiABIAZBsBBsakEEaiEBIAEoAgAhBiAJKAIAIQEgAyAGSA0ACwsgACABEBILIAUgAkEYbGpBFGohASABKAIAIQEgACABEBIgAkEBaiECIAQoAgAhASACIAFODQMgBygCACEFDAAACwALCwsgAEHwAGohAyADKAIAIQEgAQRAIABB7ABqIQUgBSgCACECIAJBAEoEQEEAIQIDQAJAIAEgAkGwEGxqQQhqIQQgBCgCACEEIAAgBBASIAEgAkGwEGxqQRxqIQQgBCgCACEEIAAgBBASIAEgAkGwEGxqQSBqIQQgBCgCACEEIAAgBBASIAEgAkGwEGxqQaQQaiEEIAQoAgAhBCAAIAQQEiABIAJBsBBsakGoEGohASABKAIAIQEgAUUhBCABQXxqIQFBACABIAQbIQEgACABEBIgAkEBaiECIAUoAgAhASACIAFODQAgAygCACEBDAELCyADKAIAIQELIAAgARASCyAAQfgBaiEBIAEoAgAhASAAIAEQEiAHKAIAIQEgACABEBIgAEGIA2ohAyADKAIAIQEgAQRAIABBhANqIQUgBSgCACECIAJBAEoEQEEAIQIDQCABIAJBKGxqQQRqIQEgASgCACEBIAAgARASIAJBAWohAiAFKAIAIQcgAygCACEBIAIgB0gNAAsLIAAgARASCyAAQQRqIQIgAigCACEBIAFBAEoEQEEAIQEDQCAAQZQGaiABQQJ0aiEDIAMoAgAhAyAAIAMQEiAAQZQHaiABQQJ0aiEDIAMoAgAhAyAAIAMQEiAAQdgHaiABQQJ0aiEDIAMoAgAhAyAAIAMQEiABQQFqIQEgAigCACEDIAEgA0ghAyABQRBJIQUgBSADcQ0ACwtBACEBA0AgAEGgCGogAUECdGohAiACKAIAIQIgACACEBIgAEGoCGogAUECdGohAiACKAIAIQIgACACEBIgAEGwCGogAUECdGohAiACKAIAIQIgACACEBIgAEG4CGogAUECdGohAiACKAIAIQIgACACEBIgAEHACGogAUECdGohAiACKAIAIQIgACACEBIgAUEBaiEBIAFBAkcNAAsLGwAgAEHEAGohACAAKAIAIQAgAEUEQCABEF8LC3wBAX8gAEHUB2ohASABQQA2AgAgAEGAC2ohASABQQA2AgAgAEH4CmohASABQQA2AgAgAEGcCGohASABQQA2AgAgAEHVCmohASABQQA6AAAgAEH8CmohASABQQA2AgAgAEHUC2ohASABQQA2AgAgAEHYC2ohACAAQQA2AgAL8AQBB38jBiELIwZBEGokBiALQQhqIQcgC0EEaiEKIAshCCAAQSRqIQYgBiwAACEGAn8gBgR/IABBgAtqIQYgBigCACEGIAZBf0oEQCAFQQA2AgAgACABIAIQFgwCCyAAQRRqIQYgBiABNgIAIAEgAmohAiAAQRxqIQkgCSACNgIAIABB2ABqIQIgAkEANgIAIABBABAXIQkgCUUEQCAFQQA2AgBBAAwCCyAAIAcgCCAKEBghCSAJBEAgBygCACECIAgoAgAhCSAKKAIAIQggACACIAkgCBAaIQogByAKNgIAIABBBGohAiACKAIAIQggCEEASgRAQQAhAgNAIABBlAZqIAJBAnRqIQcgBygCACEHIAcgCUECdGohByAAQdQGaiACQQJ0aiEMIAwgBzYCACACQQFqIQIgAiAISA0ACwsgAwRAIAMgCDYCAAsgBSAKNgIAIABB1AZqIQAgBCAANgIAIAYoAgAhACAAIAFrDAILAkACQAJAAkACQCACKAIAIgNBIGsOBAECAgACCyACQQA2AgAgAEHUAGohAiAAEBkhAwJAIANBf0cEQANAIAIoAgAhAyADDQIgABAZIQMgA0F/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ACECIABBmAhqIQYgBigCACEHIAUgA2shCSAJIAdqIQkgAiAJSSEJIAIgB0khDSACIAdrIQJBACACIA0bIQIgAiADaiECIAIgBUohByAFIAIgBxshAiAJBEAgASACNgIAIAYoAgAhACAAIAJqIQAgBiAANgIAQQEMBgsLCyAAQfQKaiECIAIoAgAhAiADIB9rIQYgBiACaiEGIABBmAhqIQIgAiAGNgIAIAhBATYCAAwBBSAAQZgIaiECIAYNAQsMAQsgBCADayEDIAIoAgAhBCADIARqIQMgAiADNgIACyATKAIAIQIgAgRAIABByABqIQIgAigCACECIABB0ABqIQAgACgCACEAIAIgAEcEQEHTE0HEE0HkGkHnFBAECwsgASAFNgIAQQELIQAgHCQGIAALqAIBBX8gAEHoCmohBSAFKAIAIQICQCACQQBIBEBBACEABSACIAFIBEAgAUEYSgRAIABBGBAsIQIgAUFoaiEBIAAgARAsIQAgAEEYdCEAIAAgAmohACAADwsgAkUEQCAAQeQKaiECIAJBADYCAAsgAEHkCmohAwJAAkACQANAIAAQLiECIAJBf0YNASAFKAIAIQQgAiAEdCECIAMoAgAhBiAGIAJqIQIgAyACNgIAIAUgBEEIaiICNgIAIAIgAUgNAAwCAAsACyAFQX82AgBBACEADAQLIARBeEgEQEEAIQAMBAsLCyAAQeQKaiEEIAQoAgAhA0EBIAF0IQAgAEF/aiEAIAMgAHEhACADIAF2IQMgBCADNgIAIAIgAWshASAFIAE2AgALCyAAC40CAAJAIABBAEgEf0EABSAAQYCAAUgEQCAAQRBIBEAgAEGACGohACAALAAAIQAMAwsgAEGABEgEQCAAQQV2IQAgAEGACGohACAALAAAIQAgAEEFaiEABSAAQQp2IQAgAEGACGohACAALAAAIQAgAEEKaiEACwwCCyAAQYCAgAhIBH8gAEGAgCBIBH8gAEEPdiEAIABBgAhqIQAgACwAACEAIABBD2oFIABBFHYhACAAQYAIaiEAIAAsAAAhACAAQRRqCwUgAEGAgICAAkgEfyAAQRl2IQAgAEGACGohACAALAAAIQAgAEEZagUgAEEediEAIABBgAhqIQAgACwAACEAIABBHmoLCwshAAsgAAuiAQEDfyAAQdQKaiECIAIsAAAhAQJAAkAgAQ0AIABB3ApqIQEgASgCACEBIAEEQEF/IQMFIAAQLyEBIAEEQCACLAAAIQEgAQ0CQaEUQcQTQfYLQbUUEAQFQX8hAwsLDAELIAFBf2pBGHRBGHUhASACIAE6AAAgAEHsCmohASABKAIAIQIgAkEBaiECIAEgAjYCACAAEDAhACAAQf8BcSEDCyADC6wCAQd/IABB3ApqIQIgAigCACEBAkAgAUUEQCAAQdgKaiEEIAQoAgAhASABQX9GBEAgAEHQCGohASABKAIAIQEgAUF/aiEBIABB4ApqIQMgAyABNgIAIAAQMSEBIAFFBEAgAkEBNgIADAMLIABB0wpqIQEgASwAACEBIAFBAXEhASABBH8gBCgCAAUgAEEgEBUMAwshAQsgAUEBaiEHIAQgBzYCACAAQdQIaiABaiEDIAMsAAAhBiAGQf8BcSEDIAZBf0cEQCACQQE2AgAgAEHgCmohAiACIAE2AgALIABB0AhqIQEgASgCACEBIAcgAU4EQCAEQX82AgALIABB1ApqIQAgACwAACEBIAEEQEHFFEHEE0HoC0HaFBAEBSAAIAY6AAAgAyEFCwsLIAULUQEDfyAAQRRqIQMgAygCACEBIABBHGohAiACKAIAIQIgASACSQR/IAFBAWohACADIAA2AgAgASwAAAUgAEHUAGohACAAQQE2AgBBAAshACAACyABAX8gABAyIQEgAQR/IAAQMwUgAEEeEBVBAAshACAAC2ABAX8gABAwIQEgAUH/AXFBzwBGBEAgABAwIQEgAUH/AXFB5wBGBEAgABAwIQEgAUH/AXFB5wBGBEAgABAwIQAgAEH/AXFB0wBGIQAFQQAhAAsFQQAhAAsFQQAhAAsgAAvZAwEGfyAAEDAhAQJ/IAFB/wFxBH8gAEEfEBVBAAUgABAwIQEgAEHTCmohAiACIAE6AAAgABAjIQUgABAjIQIgABAjGiAAECMhASAAQcwIaiEDIAMgATYCACAAECMaIAAQMCEBIAFB/wFxIQEgAEHQCGohAyADIAE2AgAgAEHUCGohBCAAIAQgARAiIQEgAUUEQCAAQQoQFUEADAILIABB8ApqIQQgBEF+NgIAIAIgBXEhAQJAIAFBf0cEQCADKAIAIQEgAUEASgRAA0ACQCABQX9qIQIgAEHUCGogAmohBiAGLAAAIQYgBkF/Rw0AIAFBAUwNBCACIQEMAQsLIAQgAjYCACAAQfQKaiEBIAEgBTYCAAsLCyAAQdUKaiEBIAEsAAAhASABBEAgAygCACEDIANBAEoEf0EAIQJBACEBA0AgAEHUCGogAWohBCAELQAAIQQgBEH/AXEhBCACIARqIQIgAUEBaiEBIAEgA0gNAAsgAkEbagVBGwshASAAQShqIQIgAigCACECIAEgA2ohASABIAJqIQEgAEEsaiEDIAMgAjYCACAAQTBqIQIgAiABNgIAIABBNGohASABIAU2AgALIABB2ApqIQAgAEEANgIAQQELCyEAIAALowEBB38gAEHoCmohAyADKAIAIQECQCABQRlIBEAgAEHkCmohBCABRQRAIARBADYCAAsgAEHUCmohBSAAQdwKaiEGA0AgBigCACEBIAEEQCAFLAAAIQEgAUUNAwsgABAuIQIgAkF/Rg0CIAMoAgAhASACIAF0IQIgBCgCACEHIAcgAmohAiAEIAI2AgAgAUEIaiECIAMgAjYCACABQRFIDQALCwsLrQUBCX8gABA0IAFBIGohAiACKAIAIQUCQAJAIAVFIgNFDQAgAUGkEGohAiACKAIAIQIgAg0AQX8hAQwBCyABQQRqIQIgAigCACECAkACQCACQQhKBEAgAUGkEGohAyADKAIAIQMgAw0BBSADDQELDAELIABB5ApqIQggCCgCACEJIAkQOiEHIAFBrBBqIQIgAigCACECIAJBAUoEQCABQaQQaigCACEKQQAhAwNAIAJBAXYhBSAFIANqIQQgCiAEQQJ0aiEGIAYoAgAhBiAGIAdLIQYgAiAFayECIAMgBCAGGyEDIAUgAiAGGyECIAJBAUoNAAsFQQAhAwsgAUEXaiECIAIsAAAhAiACRQRAIAFBqBBqIQIgAigCACECIAIgA0ECdGohAiACKAIAIQMLIAFBCGohASABKAIAIQEgASADaiEBIAEtAAAhASABQf8BcSEBIABB6ApqIQIgAigCACEAIAAgAUgEf0EAIQBBfwUgACABayEAIAkgAXYhASAIIAE2AgAgAwshASACIAA2AgAMAQsgAUEXaiEDIAMsAAAhAyADBEBBgRVBxBNB6gxBjBUQBAsCQCACQQBKBEAgASgCCCEIIABB5ApqIQlBACEBA0ACQCAIIAFqIQMgAywAACEEIARB/wFxIQMgBEF/RwRAIAUgAUECdGoh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IwZBEGokBiACIQECfCAAvUIgiKdB/////wdxIgNB/MOk/wNJBHwgA0GewZryA0kEfEQAAAAAAADwPwUgAEQAAAAAAAAAABByCwUgACAAoSADQf//v/8HSw0BGgJAAkACQAJAIAAgARBuQQNxDgMAAQIDCyABKwMAIAErAwgQcgwECyABKwMAIAErAwhBARBwmgwDCyABKwMAIAErAwgQcpoMAgsgASsDACABKwMIQQEQcAsLIQAgAiQGIAALywEBA38jBiECIwZBEGokBiACIQECQCAAvUIgiKdB/////wdxIgNB/MOk/wNJBEAgA0GAgMDyA08EQCAARAAAAAAAAAAAQQAQcCEACwUgA0H//7//B0sEQCAAIAChIQAMAgsCQAJAAkACQAJAIAAgARBuQQNxDgMAAQIDCyABKwMAIAErAwhBARBwIQAMBQsgASsDACABKwMIEHIhAAwECyABKwMAIAErAwhBARBwmiEADAMLIAErAwAgASsDCBBymiEACwsLIAIkBiAAC5sDAwJ/AX4CfCAAvSIDQj+IpyEBAnwCfwJAIANCIIinQf////8HcSICQarGmIQESwR8IANC////////////AINCgICAgICAgPj/AFYEQCAADwsgAETvOfr+Qi6GQGQEQCAARAAAAAAAAOB/og8FIABE0rx63SsjhsBjIABEUTAt1RBJh8BjcUUNAkQAAAAAAAAAACIADwsABSACQcLc2P4DSwRAIAJBscXC/wNLDQIgAUEBcyABawwDCyACQYCAwPEDSwR8QQAhASAABSAARAAAAAAAAPA/oA8LCwwCCyAARP6CK2VHFfc/oiABQQN0QYATaisDAKCqCyEBIAAgAbciBEQAAOD+Qi7mP6KhIgAgBER2PHk17znqPaIiBaELIQQgACAEIAQgBCAEoiIAIAAgACAAIABE0KS+cmk3Zj6iRPFr0sVBvbu+oKJELN4lr2pWET+gokSTvb4WbMFmv6CiRD5VVVVVVcU/oKKhIgCiRAAAAAAAAABAIAChoyAFoaBEAAAAAAAA8D+gIQAgAUUEQCAADwsgACABEGULnwMDAn8BfgV8IAC9IgNCIIinIQECfyADQgBTIgIgAUGAgMAASXIEfyADQv///////////wCDQgBRBEBEAAAAAAAA8L8gACAAoqMPCyACRQRAIABEAAAAAAAAUEOi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mgDjqR0AXmGRAAgb5gCFmWUAoBRfAI1AaACA2P8AJ3NNAAYGMQDKVhUAyahzAHviYABrjMAAQcMSC11A+yH5PwAAAAAtRHQ+AAAAgJhG+DwAAABgUcx4OwAAAICDG/A5AAAAQCAlejgAAACAIoLjNgAAAAAd82k1AAAAAAAA4D8AAAAAAADgvwAAAAAAAPA/AAAAAAAA+D8AQagTCwgG0M9D6/1MPgBBuxMLigZAA7jiP09nZ1MuL3N0Yl92b3JiaXMuYwBmLT5hbGxvYy5hbGxvY19idWZmZXJfbGVuZ3RoX2luX2J5dGVzID09IGYtPnRlbXBfb2Zmc2V0AHZvcmJpc19kZWNvZGVfaW5pdGlhbABmLT5ieXRlc19pbl9zZWcgPiAwAGdldDhfcGFja2V0X3JhdwBmLT5ieXRlc19pbl9zZWcgPT0gMABuZXh0X3NlZ21lbnQAdm9yYmlzX2RlY29kZV9wYWNrZXRfcmVzdAAhYy0+c3BhcnNlAGNvZGVib29rX2RlY29kZV9zY2FsYXJfcmF3ACFjLT5zcGFyc2UgfHwgeiA8IGMtPnNvcnRlZF9lbnRyaWVzAGNvZGVib29rX2RlY29kZV9kZWludGVybGVhdmVfcmVwZWF0AHogPCBjLT5zb3J0ZWRfZW50cmllcwBjb2RlYm9va19kZWNvZGVfc3RhcnQAKG4gJiAzKSA9PSAwAGltZGN0X3N0ZXAzX2l0ZXIwX2xvb3AAMABnZXRfd2luZG93AGYtPnRlbXBfb2Zmc2V0ID09IGYtPmFsbG9jLmFsbG9jX2J1ZmZlcl9sZW5ndGhfaW5fYnl0ZXMAc3RhcnRfZGVjb2RlcgB2b3JiaXNjLT5zb3J0ZWRfZW50cmllcyA9PSAwAGNvbXB1dGVfY29kZXdvcmRzAHogPj0gMCAmJiB6IDwgMzIAbGVuW2ldID49IDAgJiYgbGVuW2ldIDwgMzIAYXZhaWxhYmxlW3ldID09IDAAayA9PSBjLT5zb3J0ZWRfZW50cmllcwBjb21wdXRlX3NvcnRlZF9odWZmbWFuAGMtPnNvcnRlZF9jb2Rld29yZHNbeF0gPT0gY29kZQBsZW4gIT0gTk9fQ09ERQBpbmNsdWRlX2luX3NvcnQAcG93KChmbG9hdCkgcisxLCBkaW0pID4gZW50cmllcwBsb29rdXAxX3ZhbHVlcwAoaW50KSBmbG9vcihwb3coKGZsb2F0KSByLCBkaW0pKSA8PSBlbnRyaWVzAOoPBG5hbWUB4g9+AAVhYm9ydAENZW5sYXJnZU1lbW9yeQIOZ2V0VG90YWxNZW1vcnkDF2Fib3J0T25DYW5ub3RHcm93TWVtb3J5BA5fX19hc3NlcnRfZmFpbAULX19fc2V0RXJyTm8GBl9hYm9ydAcWX2Vtc2NyaXB0ZW5fbWVtY3B5X2JpZwgQX19ncm93V2FzbU1lbW9yeQkKc3RhY2tBbGxvYwoJc3RhY2tTYXZlCwxzdGFja1Jlc3RvcmUME2VzdGFibGlzaFN0YWNrU3BhY2UNCHNldFRocmV3DgtzZXRUZW1wUmV0MA8LZ2V0VGVtcFJldDAQEV9zdGJfdm9yYmlzX2Nsb3NlEQ5fdm9yYmlzX2RlaW5pdBILX3NldHVwX2ZyZWUTGl9zdGJfdm9yYmlzX2ZsdXNoX3B1c2hkYXRhFCFfc3RiX3ZvcmJpc19kZWNvZGVfZnJhbWVfcHVzaGRhdGEVBl9lcnJvchYgX3ZvcmJpc19zZWFyY2hfZm9yX3BhZ2VfcHVzaGRhdGEXGF9pc193aG9sZV9wYWNrZXRfcHJlc2VudBgVX3ZvcmJpc19kZWNvZGVfcGFja2V0GQxfZ2V0OF9wYWNrZXQaFF92b3JiaXNfZmluaXNoX2ZyYW1lGxlfc3RiX3ZvcmJpc19vcGVuX3B1c2hkYXRhHAxfdm9yYmlzX2luaXQdDl9zdGFydF9kZWNvZGVyHg1fdm9yYmlzX2FsbG9jHxtfc3RiX3ZvcmJpc19nZXRfZmlsZV9vZmZzZXQgE19tYXliZV9zdGFydF9wYWNrZXQhDV9mbHVzaF9wYWNrZXQiBV9nZXRuIwZfZ2V0MzIkE19zdGJfdm9yYmlzX2pzX29wZW4lFF9zdGJfdm9yYmlzX2pzX2Nsb3NlJhdfc3RiX3ZvcmJpc19qc19jaGFubmVscycaX3N0Yl92b3JiaXNfanNfc2FtcGxlX3JhdGUoFV9zdGJfdm9yYmlzX2pzX2RlY29kZSkNX2NyYzMyX3VwZGF0ZSoWX3ZvcmJpc19kZWNvZGVfaW5pdGlhbCsaX3ZvcmJpc19kZWNvZGVfcGFja2V0X3Jlc3QsCV9nZXRfYml0cy0FX2lsb2cuEF9nZXQ4X3BhY2tldF9yYXcvDV9uZXh0X3NlZ21lbnQwBV9nZXQ4MQtfc3RhcnRfcGFnZTIQX2NhcHR1cmVfcGF0dGVybjMdX3N0YXJ0X3BhZ2Vfbm9fY2FwdHVyZXBhdHRlcm40DV9wcmVwX2h1ZmZtYW41G19jb2RlYm9va19kZWNvZGVfc2NhbGFyX3JhdzYOX3ByZWRpY3RfcG9pbnQ3D19kZWNvZGVfcmVzaWR1ZTgJX2RvX2Zsb29yOQ1faW52ZXJzZV9tZGN0OgxfYml0X3JldmVyc2U7EV9tYWtlX2Jsb2NrX2FycmF5PBJfc2V0dXBfdGVtcF9tYWxsb2M9JF9jb2RlYm9va19kZWNvZGVfZGVpbnRlcmxlYXZlX3JlcGVhdD4PX3Jlc2lkdWVfZGVjb2RlPxVfY29kZWJvb2tfZGVjb2RlX3N0ZXBAEF9jb2RlYm9va19kZWNvZGVBFl9jb2RlYm9va19kZWNvZGVfc3RhcnRCCl9kcmF3X2xpbmVDF19pbWRjdF9zdGVwM19pdGVyMF9sb29wRBlfaW1kY3Rfc3RlcDNfaW5uZXJfcl9sb29wRRlfaW1kY3Rfc3RlcDNfaW5uZXJfc19sb29wRh9faW1kY3Rfc3RlcDNfaW5uZXJfc19sb29wX2xkNjU0RwhfaXRlcl81NEgLX2dldF93aW5kb3dJEF92b3JiaXNfdmFsaWRhdGVKDV9zdGFydF9wYWNrZXRLBV9za2lwTAtfY3JjMzJfaW5pdE0NX3NldHVwX21hbGxvY04QX3NldHVwX3RlbXBfZnJlZU8SX2NvbXB1dGVfY29kZXdvcmRzUBdfY29tcHV0ZV9zb3J0ZWRfaHVmZm1hblEcX2NvbXB1dGVfYWNjZWxlcmF0ZWRfaHVmZm1hblIPX2Zsb2F0MzJfdW5wYWNrUw9fbG9va3VwMV92YWx1ZXNUDl9wb2ludF9jb21wYXJlVQpfbmVpZ2hib3JzVg9faW5pdF9ibG9ja3NpemVXCl9hZGRfZW50cnlYEF9pbmNsdWRlX2luX3NvcnRZD191aW50MzJfY29tcGFyZVoYX2NvbXB1dGVfdHdpZGRsZV9mYWN0b3JzWw9fY29tcHV0ZV93aW5kb3dcE19jb21wdXRlX2JpdHJldmVyc2VdB19zcXVhcmVeB19tYWxsb2NfBV9mcmVlYAhfcmVhbGxvY2ESX3RyeV9yZWFsbG9jX2NodW5rYg5fZGlzcG9zZV9jaHVua2MRX19fZXJybm9fbG9jYXRpb25kB19tZW1jbXBlB19zY2FsYm5mBl9xc29ydGcFX3NpZnRoBF9zaHJpCF90cmlua2xlagRfc2hsawVfcG50emwIX2FfY3R6X2xtBl9jeWNsZW4LX19fcmVtX3BpbzJvEV9fX3JlbV9waW8yX2xhcmdlcAZfX19zaW5xBl9sZGV4cHIGX19fY29zcwRfY29zdARfc2ludQRfZXhwdgRfbG9ndwRfcG93eAtydW5Qb3N0U2V0c3kHX21lbWNweXoHX21lbXNldHsFX3Nicmt8C2R5bkNhbGxfaWlpfQJiMA=="),function(v){return v.charCodeAt(0)});var I=I!==void 0?I:{},E={};for(t in I)I.hasOwnProperty(t)&&(E[t]=I[t]);I.arguments=[],I.thisProgram="./this.program",I.quit=function(v,w){throw w},I.preRun=[],I.postRun=[];var m=!1,k=!1,y=!1,b=!1;m=typeof window=="object",k=typeof importScripts=="function",y=typeof process=="object"&&typeof aaa=="function"&&!m&&!k,b=!m&&!y&&!k;var R="";function M(v){return I.locateFile?I.locateFile(v,R):R+v}y?(R="/",I.read=function(w,L){var z;return e||(e=void 0),A||(A=void 0),w=A.normalize(w),z=e.readFileSync(w),L?z:z.toString()},I.readBinary=function(w){var L=I.read(w,!0);return L.buffer||(L=new Uint8Array(L)),Y(L.buffer),L},process.argv.length>1&&(I.thisProgram=process.argv[1].replace(/\\/g,"/")),I.arguments=process.argv.slice(2),process.on("uncaughtException",function(v){if(!(v instanceof Ye))throw v}),process.on("unhandledRejection",function(v,w){process.exit(1)}),I.quit=function(v){process.exit(v)},I.inspect=function(){return"[Emscripten Module object]"}):b?(typeof read<"u"&&(I.read=function(w){return read(w)}),I.readBinary=function(w){var L;return typeof readbuffer=="function"?new Uint8Array(readbuffer(w)):(Y(typeof(L=read(w,"binary"))=="object"),L)},typeof scriptArgs<"u"?I.arguments=scriptArgs:typeof arguments<"u"&&(I.arguments=arguments),typeof quit=="function"&&(I.quit=function(v){quit(v)})):(m||k)&&(m?document.currentScript&&(R=document.currentScript.src):R=self.location.href,R=R.indexOf("blob:")!==0?R.split("/").slice(0,-1).join("/")+"/":"",I.read=function(w){var L=new XMLHttpRequest;return L.open("GET",w,!1),L.send(null),L.responseText},k&&(I.readBinary=function(w){var L=new XMLHttpRequest;return L.open("GET",w,!1),L.responseType="arraybuffer",L.send(null),new Uint8Array(L.response)}),I.readAsync=function(w,L,z){var re=new XMLHttpRequest;re.open("GET",w,!0),re.responseType="arraybuffer",re.onload=function(){if(re.status==200||re.status==0&&re.response){L(re.response);return}z()},re.onerror=z,re.send(null)},I.setWindowTitle=function(v){document.title=v});var S=I.print||(typeof console<"u"?console.log.bind(console):typeof print<"u"?print:null),Q=I.printErr||(typeof printErr<"u"?printErr:typeof console<"u"&&console.warn.bind(console)||S);for(t in E)E.hasOwnProperty(t)&&(I[t]=E[t]);function p(v){var w=o;return o=o+v+15&-16,w}function D(v,w){return w||(w=16),v=Math.ceil(v/w)*w}function q(v){q.shown||(q.shown={}),q.shown[v]||(q.shown[v]=1,Q(v))}E=void 0;var K={"f64-rem":function(v,w){return v%w},debugger:function(){}},O=0;function Y(v,w){v||je("Assertion failed: "+w)}function H(v){var w=I["_"+v];return Y(w,"Cannot call unknown function "+v+", make sure it is exported"),w}var Z={stackSave:function(){bt()},stackRestore:function(){Ct()},arrayToC:function(v){var w,L,z=it(v.length);return w=v,L=z,n.set(w,L),z},stringToC:function(v){var w=0;if(v!=null&&v!==0){var L=(v.length<<2)+1;w=it(L),te(v,w,L)}return w}},T={string:Z.stringToC,array:Z.arrayToC};function F(v,w,L,z,re){var ce=H(v),de=[],j=0;if(z)for(var Ne=0;Ne<z.length;Ne++){var De=T[L[Ne]];De?(j===0&&(j=bt()),de[Ne]=De(z[Ne])):de[Ne]=z[Ne]}var oe,Ce=ce.apply(null,de);return Ce=(oe=Ce,w==="string"?u(oe):w==="boolean"?!!oe:oe),j!==0&&Ct(j),Ce}function u(v,w){if(w===0||!v)return"";for(var L,z,re,ce=0,de=0;ce|=z=a[v+de>>0],(z!=0||w)&&(de++,!w||de!=w););w||(w=de);var j="";if(ce<128){for(;w>0;)re=String.fromCharCode.apply(String,a.subarray(v,v+Math.min(w,1024))),j=j?j+re:re,v+=1024,w-=1024;return j}return L=v,(function(De,oe){for(var Ce=oe;De[Ce];)++Ce;if(Ce-oe>16&&De.subarray&&x)return x.decode(De.subarray(oe,Ce));for(var he,Pe,Te,et,ft,ot="";;){if(!(he=De[oe++]))return ot;if(!(128&he)){ot+=String.fromCharCode(he);continue}if(Pe=63&De[oe++],(224&he)==192){ot+=String.fromCharCode((31&he)<<6|Pe);continue}if(Te=63&De[oe++],(240&he)==224?he=(15&he)<<12|Pe<<6|Te:(et=63&De[oe++],(248&he)==240?he=(7&he)<<18|Pe<<12|Te<<6|et:(ft=63&De[oe++],he=(252&he)==248?(3&he)<<24|Pe<<18|Te<<12|et<<6|ft:(1&he)<<30|Pe<<24|Te<<18|et<<12|ft<<6|63&De[oe++])),he<65536)ot+=String.fromCharCode(he);else{var tt=he-65536;ot+=String.fromCharCode(55296|tt>>10,56320|1023&tt)}}})(a,L)}var x=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function P(v,w,L,z){if(!(z>0))return 0;for(var re=L,ce=L+z-1,de=0;de<v.length;++de){var j=v.charCodeAt(de);if(j>=55296&&j<=57343&&(j=65536+((1023&j)<<10)|1023&v.charCodeAt(++de)),j<=127){if(L>=ce)break;w[L++]=j}else if(j<=2047){if(L+1>=ce)break;w[L++]=192|j>>6,w[L++]=128|63&j}else if(j<=65535){if(L+2>=ce)break;w[L++]=224|j>>12,w[L++]=128|j>>6&63,w[L++]=128|63&j}else if(j<=2097151){if(L+3>=ce)break;w[L++]=240|j>>18,w[L++]=128|j>>12&63,w[L++]=128|j>>6&63,w[L++]=128|63&j}else if(j<=67108863){if(L+4>=ce)break;w[L++]=248|j>>24,w[L++]=128|j>>18&63,w[L++]=128|j>>12&63,w[L++]=128|j>>6&63,w[L++]=128|63&j}else{if(L+5>=ce)break;w[L++]=252|j>>30,w[L++]=128|j>>24&63,w[L++]=128|j>>18&63,w[L++]=128|j>>12&63,w[L++]=128|j>>6&63,w[L++]=128|63&j}}return w[L]=0,L-re}function te(v,w,L){return P(v,a,w,L)}typeof TextDecoder<"u"&&new TextDecoder("utf-16le");function W(v,w){return v%w>0&&(v+=w-v%w),v}function _(v){I.buffer=s=v}function $(){I.HEAP8=n=new Int8Array(s),I.HEAP16=new Int16Array(s),I.HEAP32=r=new Int32Array(s),I.HEAPU8=a=new Uint8Array(s),I.HEAPU16=new Uint16Array(s),I.HEAPU32=new Uint32Array(s),I.HEAPF32=new Float32Array(s),I.HEAPF64=new Float64Array(s)}function ne(){var v=I.usingWasm?65536:16777216,w=2147483648-v;if(r[B>>2]>w)return!1;var L=J;for(J=Math.max(J,16777216);J<r[B>>2];)J=J<=536870912?W(2*J,v):Math.min(W((3*J+2147483648)/4,v),w);var z=I.reallocBuffer(J);return z&&z.byteLength==J?(_(z),$(),!0):(J=L,!1)}i=o=g=l=C=B=0,I.reallocBuffer||(I.reallocBuffer=function(v){try{if(ArrayBuffer.transfer)w=ArrayBuffer.transfer(s,v);else{var w,L=n;w=new ArrayBuffer(v),new Int8Array(w).set(L)}}catch{return!1}return!!Xe(w)&&w});try{Function.prototype.call.bind(Object.getOwnPropertyDescriptor(ArrayBuffer.prototype,"byteLength").get)(new ArrayBuffer(4))}catch{}var ae=I.TOTAL_STACK||5242880,J=I.TOTAL_MEMORY||16777216;function ie(){return J}function pe(v){for(;v.length>0;){var w=v.shift();if(typeof w=="function"){w();continue}var L=w.func;typeof L=="number"?w.arg===void 0?I.dynCall_v(L):I.dynCall_vi(L,w.arg):L(w.arg===void 0?null:w.arg)}}J<ae&&Q("TOTAL_MEMORY should be larger than TOTAL_STACK, was "+J+"! (TOTAL_STACK="+ae+")"),I.buffer?s=I.buffer:(typeof WebAssembly=="object"&&typeof WebAssembly.Memory=="function"?(I.wasmMemory=new WebAssembly.Memory({initial:J/65536}),s=I.wasmMemory.buffer):s=new ArrayBuffer(J),I.buffer=s),$();var ve=[],Be=[],be=[],Ue=[],ht=!1;function lt(v){ve.unshift(v)}function jt(v){Ue.unshift(v)}var eA=Math.floor,Oe=0,Et=null,Re=null;I.preloadedImages={},I.preloadedAudios={};var Ot="data:application/octet-stream;base64,";function wt(v){return String.prototype.startsWith?v.startsWith(Ot):v.indexOf(Ot)===0}(function(){var w="main.wast",L="main.wasm",z="main.temp.asm";wt(w)||(w=M(w)),wt(L)||(L=M(L)),wt(z)||(z=M(z));var re={global:null,env:null,asm2wasm:K,parent:I},ce=null;function de(){try{if(I.wasmBinary)return new Uint8Array(I.wasmBinary);if(I.readBinary)return I.readBinary(L);throw"both async and sync fetching of the wasm failed"}catch(oe){je(oe)}}I.asmPreload=I.asm;var j=I.reallocBuffer,Ne=function(oe){oe=W(oe,I.usingWasm?65536:16777216);var Ce=I.buffer.byteLength;if(I.usingWasm)try{return I.wasmMemory.grow((oe-Ce)/65536)!==-1?I.buffer=I.wasmMemory.buffer:null}catch{return null}};I.reallocBuffer=function(oe){return De==="asmjs"?j(oe):Ne(oe)};var De="";I.asm=function(oe,Ce,he){if(!(Ce=Ce).table){var Pe,Te=I.wasmTableSize;Te===void 0&&(Te=1024);var et=I.wasmMaxTableSize;typeof WebAssembly=="object"&&typeof WebAssembly.Table=="function"?et!==void 0?Ce.table=new WebAssembly.Table({initial:Te,maximum:et,element:"anyfunc"}):Ce.table=new WebAssembly.Table({initial:Te,element:"anyfunc"}):Ce.table=Array(Te),I.wasmTable=Ce.table}return Ce.memoryBase||(Ce.memoryBase=I.STATIC_BASE),Ce.tableBase||(Ce.tableBase=0),Pe=(function(ot,tt,Ss){if(typeof WebAssembly!="object")return Q("no native wasm support detected"),!1;if(!(I.wasmMemory instanceof WebAssembly.Memory))return Q("no native wasm Memory in use"),!1;function Rt(qe,nt){if((ce=qe.exports).memory){var AA=ce.memory,ks=I.buffer,Ds;AA.byteLength<ks.byteLength&&Q("the new buffer in mergeMemory is smaller than the previous one. in native wasm, we should grow memory here"),Ds=new Int8Array(ks),new Int8Array(AA).set(Ds),_(AA),$()}I.asm=ce,I.usingWasm=!0,(function(fi){if(Oe--,I.monitorRunDependencies&&I.monitorRunDependencies(Oe),Oe==0&&(Et!==null&&(clearInterval(Et),Et=null),Re)){var On=Re;Re=null,On()}})("wasm-instantiate")}if(tt.memory=I.wasmMemory,re.global={NaN:NaN,Infinity:1/0},re["global.Math"]=Math,re.env=tt,Oe++,I.monitorRunDependencies&&I.monitorRunDependencies(Oe),I.instantiateWasm)try{return I.instantiateWasm(re,Rt)}catch(qe){return Q("Module.instantiateWasm callback failed with error: "+qe),!1}function Ft(qe){Rt(qe.instance,qe.module)}function tA(qe){(!I.wasmBinary&&(m||k)&&typeof fetch=="function"?fetch(L,{credentials:"same-origin"}).then(function(nt){if(!nt.ok)throw"failed to load wasm binary file at '"+L+"'";return nt.arrayBuffer()}).catch(function(){return de()}):new Promise(function(nt,AA){nt(de())})).then(function(nt){return WebAssembly.instantiate(nt,re)}).then(qe).catch(function(nt){Q("failed to asynchronously prepare wasm: "+nt),je(nt)})}return I.wasmBinary||typeof WebAssembly.instantiateStreaming!="function"||wt(L)||typeof fetch!="function"?tA(Ft):WebAssembly.instantiateStreaming(fetch(L,{credentials:"same-origin"}),re).then(Ft).catch(function(qe){Q("wasm streaming compile failed: "+qe),Q("falling back to ArrayBuffer instantiation"),tA(Ft)}),{}})(oe,Ce,he),Y(Pe,"no binaryen method succeeded."),Pe},I.asm})(),o=(i=1024)+4816,Be.push(),I.STATIC_BASE=i,I.STATIC_BUMP=4816;var TA=o;o+=16,B=p(4),l=(g=D(o))+ae,C=D(l),r[B>>2]=C,I.wasmTableSize=4,I.wasmMaxTableSize=4,I.asmGlobalArg={},I.asmLibraryArg={abort:je,assert:Y,enlargeMemory:ne,getTotalMemory:ie,abortOnCannotGrowMemory:function(){je("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_MEMORY=X with X higher than the current value "+J+", (2) compile with -s ALLOW_MEMORY_GROWTH=1 which allows increasing the size at runtime, or (3) if you want malloc to return NULL (0) instead of this abort, compile with -s ABORTING_MALLOC=0 ")},invoke_iii:function(w,L,z){var re=bt();try{return I.dynCall_iii(w,L,z)}catch(ce){if(Ct(re),typeof ce!="number"&&ce!=="longjmp")throw ce;I.setThrew(1,0)}},___assert_fail:function(w,L,z,re){je("Assertion failed: "+u(w)+", at: "+[L?u(L):"unknown filename",z,re?u(re):"unknown function"])},___setErrNo:function(w){return I.___errno_location&&(r[I.___errno_location()>>2]=w),w},_abort:function(){I.abort()},_emscripten_memcpy_big:function(w,L,z){return a.set(a.subarray(L,L+z),w),w},_llvm_floor_f64:eA,DYNAMICTOP_PTR:B,tempDoublePtr:TA,ABORT:O,STACKTOP:g,STACK_MAX:l};var Yt=I.asm(I.asmGlobalArg,I.asmLibraryArg,s);I.asm=Yt,I.___errno_location=function(){return I.asm.___errno_location.apply(null,arguments)};var Xe=I._emscripten_replace_memory=function(){return I.asm._emscripten_replace_memory.apply(null,arguments)};I._free=function(){return I.asm._free.apply(null,arguments)},I._malloc=function(){return I.asm._malloc.apply(null,arguments)},I._memcpy=function(){return I.asm._memcpy.apply(null,arguments)},I._memset=function(){return I.asm._memset.apply(null,arguments)},I._sbrk=function(){return I.asm._sbrk.apply(null,arguments)},I._stb_vorbis_js_channels=function(){return I.asm._stb_vorbis_js_channels.apply(null,arguments)},I._stb_vorbis_js_close=function(){return I.asm._stb_vorbis_js_close.apply(null,arguments)},I._stb_vorbis_js_decode=function(){return I.asm._stb_vorbis_js_decode.apply(null,arguments)},I._stb_vorbis_js_open=function(){return I.asm._stb_vorbis_js_open.apply(null,arguments)},I._stb_vorbis_js_sample_rate=function(){return I.asm._stb_vorbis_js_sample_rate.apply(null,arguments)},I.establishStackSpace=function(){return I.asm.establishStackSpace.apply(null,arguments)},I.getTempRet0=function(){return I.asm.getTempRet0.apply(null,arguments)},I.runPostSets=function(){return I.asm.runPostSets.apply(null,arguments)},I.setTempRet0=function(){return I.asm.setTempRet0.apply(null,arguments)},I.setThrew=function(){return I.asm.setThrew.apply(null,arguments)};var it=I.stackAlloc=function(){return I.asm.stackAlloc.apply(null,arguments)},Ct=I.stackRestore=function(){return I.asm.stackRestore.apply(null,arguments)},bt=I.stackSave=function(){return I.asm.stackSave.apply(null,arguments)};function Ye(v){this.name="ExitStatus",this.message="Program terminated with exit("+v+")",this.status=v}function dt(v){v=v||I.arguments,!(Oe>0)&&((function(){if(I.preRun)for(typeof I.preRun=="function"&&(I.preRun=[I.preRun]);I.preRun.length;)lt(I.preRun.shift());pe(ve)})(),!(Oe>0)&&(I.calledRun||(I.setStatus?(I.setStatus("Running..."),setTimeout(function(){setTimeout(function(){I.setStatus("")},1),w()},1)):w())));function w(){!I.calledRun&&(I.calledRun=!0,O||(ht||(ht=!0,pe(Be)),pe(be),I.onRuntimeInitialized&&I.onRuntimeInitialized(),(function(){if(I.postRun)for(typeof I.postRun=="function"&&(I.postRun=[I.postRun]);I.postRun.length;)jt(I.postRun.shift());pe(Ue)})()))}}function je(v){throw I.onAbort&&I.onAbort(v),v!==void 0?(S(v),Q(v),v=JSON.stringify(v)):v="",O=!0,"abort("+v+"). Build with -s ASSERTIONS=1 for more info."}if(I.dynCall_iii=function(){return I.asm.dynCall_iii.apply(null,arguments)},I.asm=Yt,I.ccall=F,I.cwrap=function(w,L,z,re){var ce=(z=z||[]).every(function(de){return de==="number"});return L!=="string"&&ce&&!re?H(w):function(){return F(w,L,z,arguments,re)}},Ye.prototype=Error(),Ye.prototype.constructor=Ye,Re=function v(){I.calledRun||dt(),I.calledRun||(Re=v)},I.run=dt,I.abort=je,I.preInit)for(typeof I.preInit=="function"&&(I.preInit=[I.preInit]);I.preInit.length>0;)I.preInit.pop()();I.noExitRuntime=!0,dt(),I.onRuntimeInitialized=()=>{Fs=!0,rn()},Zt.decode=function(v){return(function(L){if(!Fs)throw Error("SF3 decoder has not been initialized yet. Did you await synth.isReady?");var z={};function re(Rt){return new Int32Array(I.HEAPU8.buffer,Rt,1)[0]}function ce(Rt,Ft){var tA=new ArrayBuffer(Ft*Float32Array.BYTES_PER_ELEMENT),qe=new Float32Array(tA);return qe.set(new Float32Array(I.HEAPU8.buffer,Rt,Ft)),qe}z.open=I.cwrap("stb_vorbis_js_open","number",[]),z.close=I.cwrap("stb_vorbis_js_close","void",["number"]),z.channels=I.cwrap("stb_vorbis_js_channels","number",["number"]),z.sampleRate=I.cwrap("stb_vorbis_js_sample_rate","number",["number"]),z.decode=I.cwrap("stb_vorbis_js_decode","number",["number","number","number","number","number"]);var de,j,Ne,De,oe=z.open(),Ce=(de=L,j=L.byteLength,Ne=I._malloc(j),(De=new Uint8Array(I.HEAPU8.buffer,Ne,j)).set(new Uint8Array(de,0,j)),De),he=I._malloc(4),Pe=I._malloc(4),Te=z.decode(oe,Ce.byteOffset,Ce.byteLength,he,Pe);if(I._free(Ce.byteOffset),Te<0)throw z.close(oe),I._free(he),Error("stbvorbis decode failed: "+Te);for(var et=z.channels(oe),ft=Array(et),ot=new Int32Array(I.HEAPU32.buffer,re(he),et),tt=0;tt<et;tt++)ft[tt]=ce(ot[tt],Te),I._free(ot[tt]);var Ss=z.sampleRate(oe);return z.close(oe),I._free(re(he)),I._free(he),{data:ft,sampleRate:Ss,eof:!0,error:null}})(v)}})();var FA=Zt,Da={effectsEnabled:!0,maxBufferSize:128,initialTime:0,eventsEnabled:!0};var wa=class{keyMappings=[];addMapping(t,e,A){this.keyMappings[t]??=[],this.keyMappings[t][e]=A}deleteMapping(t,e){this.keyMappings[t]?.[e]!==void 0&&(this.keyMappings[t][e]=void 0)}clearMappings(){this.keyMappings=[]}setMappings(t){this.keyMappings=t}getMappings(){return this.keyMappings}getVelocity(t,e){return this.keyMappings[t]?.[e]?.velocity??-1}getGain(t,e){return this.keyMappings[t]?.[e]?.gain??1}hasOverridePatch(t,e){let A=this.keyMappings[t]?.[e]?.patch?.bankMSB;return A!==void 0&&A>=0}getPatch(t,e){let A=this.keyMappings[t]?.[e];if(A)return A.patch;throw new Error("No modifier.")}};function ba(t){for(this.keyModifierManager.setMappings(t.keyMappings);this.midiChannels.length<t.midiChannels.length;)this.createMIDIChannel(!0);for(let A=0;A<t.midiChannels.length;A++)this.midiChannels[A].applySnapshot(t.midiChannels[A]);for(let[A,s]of Object.entries(t.reverbProcessor))this.reverbProcessor[A]=s;for(let[A,s]of Object.entries(this.chorusProcessor))this.chorusProcessor[A]=s;for(let[A,s]of Object.entries(this.delayProcessor))this.delayProcessor[A]=s;let e=t.insertionProcessor;this.systemExclusive(se.gsData(64,3,0,[e.type>>8,e.type&127]));for(let A=0;A<e.params.length;A++)e.params[A]!==255&&this.systemExclusive(se.gsData(64,3,3+A,[e.params[A]]));for(let A=0;A<e.channels.length;A++)this.systemExclusive(se.gsData(64,64|se.channelToSyx(A),34,[e.channels[A]?1:0]));for(let[A,s]of Object.entries(this.midiParameters))this.setMIDIParameter(A,s);for(let[A,s]of Object.entries(this.systemParameters))this.setSystemParameter(A,s)}function Ra(){return{midiParameters:{...this.midiParameters},systemParameters:{...this.systemParameters},midiChannels:this.midiChannels.map(t=>t.getSnapshot()),keyMappings:this.keyModifierManager.getMappings(),reverbProcessor:this.reverbProcessor.getSnapshot(),chorusProcessor:this.chorusProcessor.getSnapshot(),delayProcessor:this.delayProcessor.getSnapshot(),insertionProcessor:this.getInsertionSnapshot()}}var on={effectsEnabled:!0,eventsEnabled:!0,voiceCap:350,autoAllocateVoices:!1,reverbGain:1,reverbLock:!1,chorusGain:1,chorusLock:!1,delayGain:1,delayLock:!1,insertionEffectLock:!1,drumLock:!1,blackMIDIMode:!1,deviceID:-1,gain:1,pan:0,keyShift:0,fineTune:0,interpolationType:Sa.hermite,nrpnParamLock:!1,monophonicRetrigger:!1};function Fa(t,e){if(this.systemParameters[t]===e)return;let A=this.systemParameters[t];this.systemParameters[t]=e;for(let s of this.midiChannels)s.updateInternalParams();switch(t){default:break;case"voiceCap":{let s=Math.min(e,1e6);this.systemParameters.voiceCap=s;for(let n=s;n<this.voices.length;n++)this.voices[n].isActive=!1;s>this.voices.length&&(h.warn(`Allocating ${s-this.voices.length} new voices!`),this.allocateNewVoices(s-this.voices.length));break}case"keyShift":A!==e&&this.stopAllChannels(!0)}}var ds=-15e3,es=new Float32Array(15e3-ds+1);for(let t=0;t<es.length;t++){let e=ds+t;es[t]=Math.pow(2,e/1200)}function mA(t){return t<=-32767?0:es[t-ds]}var pA=-2e4,gn=16500,ts=new Float32Array(gn-pA+1);for(let t=0;t<ts.length;t++){let e=pA+t;ts[t]=440*Math.pow(2,(e-6900)/1200)}function As(t){return t<pA||t>gn?440*Math.pow(2,(t-6900)/1200):ts[t-pA|0]}var Pt=-16600,Tt=new Float32Array(16e3-Pt+1);for(let t=0;t<Tt.length;t++){let e=Pt+t;Tt[t]=Math.pow(10,-e/200)}function yA(t){return Tt[t-Pt|0]}var Ma=.03,fs=class Kt{static smoothingConstant=1;static cachedCoefficients=new Map;resonanceCb=0;currentInitialFc=13500;a0=0;a1=0;a2=0;a3=0;a4=0;x1=0;x2=0;y1=0;y2=0;lastTargetCutoff=1/0;initialized=!1;sampleRate;maxCutoff;constructor(e){this.sampleRate=e,this.maxCutoff=e*.45}static initCache(e){Kt.smoothingConstant=Ma*(44100/e);let A=new Kt(e);A.resonanceCb=0;for(let s=1500;s<13500;s++)A.currentInitialFc=s,A.calculateCoefficients(s)}init(){this.lastTargetCutoff=1/0,this.resonanceCb=0,this.currentInitialFc=13500,this.a0=0,this.a1=0,this.a2=0,this.a3=0,this.a4=0,this.x1=0,this.x2=0,this.y1=0,this.y2=0,this.initialized=!1}calculateCoefficients(e){e=e|0;let A=this.resonanceCb,s=Kt.cachedCoefficients.get(A+e*961);if(s!==void 0){this.a0=s.a0,this.a1=s.a1,this.a2=s.a2,this.a3=s.a3,this.a4=s.a4;return}let n=As(e);n=Math.min(n,this.maxCutoff);let a=yA(-(A-3.01)),r=1/Math.sqrt(yA(-A)),i=2*Math.PI*n/this.sampleRate,o=Math.cos(i),g=Math.sin(i)/(2*a),l=(1-o)*r,C=l/2,B=C,I=1+g,E=-2*o,m=1-g,k={a0:C/I,a1:l/I,a2:B/I,a3:E/I,a4:m/I};this.a0=k.a0,this.a1=k.a1,this.a2=k.a2,this.a3=k.a3,this.a4=k.a4,Kt.cachedCoefficients.set(A+e*961,k)}},c=Object.freeze({invalid:-1,startAddrsOffset:0,endAddrOffset:1,startloopAddrsOffset:2,endloopAddrsOffset:3,startAddrsCoarseOffset:4,modLfoToPitch:5,vibLfoToPitch:6,modEnvToPitch:7,initialFilterFc:8,initialFilterQ:9,modLfoToFilterFc:10,modEnvToFilterFc:11,endAddrsCoarseOffset:12,modLfoToVolume:13,chorusEffectsSend:15,reverbEffectsSend:16,pan:17,delayModLFO:21,freqModLFO:22,delayVibLFO:23,freqVibLFO:24,delayModEnv:25,attackModEnv:26,holdModEnv:27,decayModEnv:28,sustainModEnv:29,releaseModEnv:30,keyNumToModEnvHold:31,keyNumToModEnvDecay:32,delayVolEnv:33,attackVolEnv:34,holdVolEnv:35,decayVolEnv:36,sustainVolEnv:37,releaseVolEnv:38,keyNumToVolEnvHold:39,keyNumToVolEnvDecay:40,instrument:41,keyRange:43,velRange:44,startloopAddrsCoarseOffset:45,keyNum:46,velocity:47,initialAttenuation:48,endloopAddrsCoarseOffset:50,coarseTune:51,fineTune:52,sampleID:53,sampleModes:54,scaleTuning:56,exclusiveClass:57,overridingRootKey:58,endOper:60,amplitude:61,vibLfoRate:62,vibLfoAmplitudeDepth:63,vibLfoToFilterFc:64,modLfoRate:65,modLfoAmplitudeDepth:66}),In=Math.max(...Object.values(c)),St=In+1,Ve=Object.freeze({[c.invalid]:{min:0,max:0,def:0,nrpn:0},[c.endOper]:{min:0,max:0,def:0,nrpn:0},[c.instrument]:{min:0,max:0,def:0,nrpn:0},[c.sampleID]:{min:0,max:0,def:0,nrpn:0},[c.keyRange]:{min:0,max:0,def:0,nrpn:0},[c.velRange]:{min:0,max:0,def:0,nrpn:0},[c.startAddrsOffset]:{min:0,max:32768,def:0,nrpn:1},[c.endAddrOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.startloopAddrsOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.endloopAddrsOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.startAddrsCoarseOffset]:{min:0,max:32768,def:0,nrpn:1},[c.modLfoToPitch]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.vibLfoToPitch]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.modEnvToPitch]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.initialFilterFc]:{min:1500,max:13500,def:13500,nrpn:2},[c.initialFilterQ]:{min:0,max:960,def:0,nrpn:1},[c.modLfoToFilterFc]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.modEnvToFilterFc]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.endAddrsCoarseOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.modLfoToVolume]:{min:-960,max:960,def:0,nrpn:1},[c.chorusEffectsSend]:{min:0,max:1e3,def:0,nrpn:1},[c.reverbEffectsSend]:{min:0,max:1e3,def:0,nrpn:1},[c.pan]:{min:-500,max:500,def:0,nrpn:1},[c.delayModLFO]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.freqModLFO]:{min:-16e3,max:4500,def:0,nrpn:4},[c.delayVibLFO]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.freqVibLFO]:{min:-16e3,max:4500,def:0,nrpn:4},[c.delayModEnv]:{min:-32768,max:5e3,def:-32768,nrpn:2},[c.attackModEnv]:{min:-32768,max:8e3,def:-32768,nrpn:2},[c.holdModEnv]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.decayModEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.sustainModEnv]:{min:0,max:1e3,def:0,nrpn:1},[c.releaseModEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.keyNumToModEnvHold]:{min:-1200,max:1200,def:0,nrpn:1},[c.keyNumToModEnvDecay]:{min:-1200,max:1200,def:0,nrpn:1},[c.delayVolEnv]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.attackVolEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.holdVolEnv]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.decayVolEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.sustainVolEnv]:{min:0,max:1440,def:0,nrpn:1},[c.releaseVolEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.keyNumToVolEnvHold]:{min:-1200,max:1200,def:0,nrpn:1},[c.keyNumToVolEnvDecay]:{min:-1200,max:1200,def:0,nrpn:1},[c.startloopAddrsCoarseOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.keyNum]:{min:-1,max:127,def:-1,nrpn:1},[c.velocity]:{min:-1,max:127,def:-1,nrpn:1},[c.initialAttenuation]:{min:0,max:1440,def:0,nrpn:1},[c.endloopAddrsCoarseOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.coarseTune]:{min:-120,max:120,def:0,nrpn:1},[c.fineTune]:{min:-12700,max:12700,def:0,nrpn:1},[c.scaleTuning]:{min:0,max:1200,def:100,nrpn:1},[c.exclusiveClass]:{min:0,max:99999,def:0,nrpn:0},[c.overridingRootKey]:{min:-1,max:127,def:-1,nrpn:0},[c.sampleModes]:{min:0,max:3,def:0,nrpn:0},[c.amplitude]:{min:-1e3,max:1e3,def:0,nrpn:1},[c.vibLfoRate]:{min:-1e3,max:1e3,def:0,nrpn:1},[c.vibLfoToFilterFc]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.vibLfoAmplitudeDepth]:{min:0,max:1e3,def:0,nrpn:1},[c.modLfoRate]:{min:-1e3,max:1e3,def:0,nrpn:1},[c.modLfoAmplitudeDepth]:{min:0,max:1e3,def:0,nrpn:1}}),Je=960,iA=900,va=class{outputGain=0;attenuationCb=Je;state=0;sampleRate;updateInterval;sampleTime=0;releaseStartCb=Je;releaseStartTimeSamples=0;attackDuration=0;decayDuration=0;releaseDuration=0;sustainCb=0;delayEnd=0;attackEnd=0;holdEnd=0;decayEnd=0;enteredRelease=!1;canEndOnSilentSustain=!1;constructor(t,e){this.sampleRate=t,this.updateInterval=e}startRelease(t){this.releaseStartTimeSamples=this.sampleTime;let e=t.overrideReleaseVolEnv||t.modulatedGenerators[c.releaseVolEnv];if(this.releaseDuration=this.timecentsToSamples(Math.max(-7200,e)),this.enteredRelease)this.releaseStartCb=this.attenuationCb;else{let s=Math.max(0,Math.min(Je,this.sustainCb)),n=s/Je,a=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToVolEnvDecay];switch(this.decayDuration=this.timecentsToSamples(t.modulatedGenerators[c.decayVolEnv]+a)*n,this.state){case 0:this.releaseStartCb=Je;break;case 1:{let r=1-(this.attackEnd-this.releaseStartTimeSamples)/this.attackDuration;this.releaseStartCb=200*Math.log10(r)*-1;break}case 2:this.releaseStartCb=0;break;case 3:this.releaseStartCb=(1-(this.decayEnd-this.releaseStartTimeSamples)/this.decayDuration)*s;break;case 4:this.releaseStartCb=s;break}this.releaseStartCb=Math.max(0,Math.min(this.releaseStartCb,Je)),this.attenuationCb=this.releaseStartCb}this.enteredRelease=!0;let A=(Je-this.releaseStartCb)/Je;this.releaseDuration*=A,this.releaseStartCb>=iA&&(t.isActive=!1)}init(t){this.enteredRelease=!1,this.state=0,this.sampleTime=0,this.outputGain=0,this.canEndOnSilentSustain=t.modulatedGenerators[c.sustainVolEnv]>=iA,this.sustainCb=Math.min(Je,t.modulatedGenerators[c.sustainVolEnv]),this.attackDuration=this.timecentsToSamples(t.modulatedGenerators[c.attackVolEnv]);let e=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToVolEnvDecay],A=this.sustainCb/Je;this.decayDuration=this.timecentsToSamples(t.modulatedGenerators[c.decayVolEnv]+e)*A,this.delayEnd=this.timecentsToSamples(t.modulatedGenerators[c.delayVolEnv]),this.attackEnd=this.attackDuration+this.delayEnd;let s=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToVolEnvHold];this.holdEnd=this.timecentsToSamples(t.modulatedGenerators[c.holdVolEnv]+s)+this.attackEnd,this.decayEnd=this.decayDuration+this.holdEnd,this.attackEnd<=this.updateInterval&&(this.state=2)}process(t,e){let{releaseStartTimeSamples:A,releaseStartCb:s,releaseDuration:n,delayEnd:a,attackEnd:r,attackDuration:i,holdEnd:o,decayEnd:g,decayDuration:l,sustainCb:C}=this,B=this.sampleTime+=t;if(this.enteredRelease){let I=B-A,E=Je-s;return this.attenuationCb=I/n*E+s,this.outputGain=Tt[this.attenuationCb-Pt|0]*e,this.attenuationCb<iA}switch(this.state){case 0:if(B<a)return this.attenuationCb=Je,this.outputGain=0,!0;this.state++;case 1:if(B<r){this.attenuationCb=0;let I=1-(r-B)/i;return this.outputGain=I*e,!0}this.state++;case 2:if(B<o)return this.attenuationCb=0,this.outputGain=e,!0;this.state++;case 3:if(B<g)return this.attenuationCb=(1-(g-B)/l)*C,this.outputGain=e*Tt[this.attenuationCb-Pt|0],!0;this.state++;case 4:return this.canEndOnSilentSustain&&C>=iA?(this.attenuationCb=Je,this.outputGain=0,!1):(this.attenuationCb=C,this.outputGain=e*Tt[C-Pt|0],!0)}}timecentsToSamples(t){return Math.max(0,Math.floor(mA(t)*this.sampleRate))}},Fe={monoSample:1,rightSample:2,leftSample:4,linkedSample:8,romMonoSample:32769,romRightSample:32770,romLeftSample:32772,romLinkedSample:32776},Ie={noController:0,noteOnVelocity:2,noteOnKeyNum:3,polyPressure:10,channelPressure:13,pitchWheel:14,pitchWheelRange:16,link:127},le={linear:0,concave:1,convex:2,switch:3};var xe=16384,SA=Object.keys(le).length,It=new Float32Array(xe+1),yt=new Float32Array(xe+1);It[0]=0;It[It.length-1]=1;yt[0]=0;yt[yt.length-1]=1;for(let t=1;t<xe-1;t++){let e=-.4166666666666667*Math.log(t/(It.length-1))/Math.LN10;yt[t]=1-e,It[It.length-1-t]=e}function cn(t,e,A){let s=!!(t&2);switch(t&1&&(A=1-A),e){case le.linear:return s?A*2-1:A;case le.switch:return A=A>.5?1:0,s?A*2-1:A;case le.concave:return s?(A=A*2-1,A<0?-It[Math.trunc(A*-xe)]:It[Math.trunc(A*xe)]):It[Math.trunc(A*xe)];case le.convex:return s?(A=A*2-1,A<0?-yt[Math.trunc(A*-xe)]:yt[Math.trunc(A*xe)]):yt[Math.trunc(A*xe)]}}var OA=1,ss=new Float32Array(1e3);for(let t=0;t<ss.length;t++)ss[t]=cn(0,le.convex,t/1e3);var Ga=class{attackDuration=0;decayDuration=0;holdDuration=0;releaseDuration=0;sustainLevel=0;delayEnd=0;attackEnd=0;holdEnd=0;releaseStartLevel=0;currentValue=0;enteredRelease=!1;decayEnd=0;process(t,e){return this.enteredRelease?this.releaseStartLevel===0?0:Math.max(0,(1-(e-t.releaseStartTime)/this.releaseDuration)*this.releaseStartLevel):(e<this.delayEnd?this.currentValue=0:e<this.attackEnd?this.currentValue=ss[~~((1-(this.attackEnd-e)/this.attackDuration)*1e3)]:e<this.holdEnd?this.currentValue=OA:e<this.decayEnd?this.currentValue=(1-(this.decayEnd-e)/this.decayDuration)*(this.sustainLevel-OA)+OA:this.currentValue=this.sustainLevel,this.currentValue)}startRelease(t){this.releaseStartLevel=this.currentValue,this.enteredRelease=!0;let e=this.tc2Sec(Math.max(t.modulatedGenerators[c.releaseModEnv],-7200));this.releaseDuration=e*this.releaseStartLevel}init(t){this.enteredRelease=!1,this.sustainLevel=1-t.modulatedGenerators[c.sustainModEnv]/1e3,this.attackDuration=this.tc2Sec(t.modulatedGenerators[c.attackModEnv]);let e=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToModEnvDecay],A=this.tc2Sec(t.modulatedGenerators[c.decayModEnv]+e);this.decayDuration=A*(1-this.sustainLevel);let s=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToModEnvHold];this.holdDuration=this.tc2Sec(s+t.modulatedGenerators[c.holdModEnv]),this.delayEnd=t.startTime+this.tc2Sec(t.modulatedGenerators[c.delayModEnv]),this.attackEnd=this.delayEnd+this.attackDuration,this.holdEnd=this.attackEnd+this.holdDuration,this.decayEnd=this.holdEnd+this.decayDuration}tc2Sec(t){return t<=-10114?0:mA(t)}},Qs=class{isLooping=!1;sampleData;playbackStep=0;loopStart=0;loopEnd=0;loopLength=0;end=0;cursor=0},La=class extends Qs{process(t,e,A){let s=e*this.playbackStep,n=this.sampleData,{loopEnd:a,loopLength:r,loopStart:i,end:o}=this,g=this.cursor;if(this.isLooping)for(let l=0;l<t;l++){g>i&&(g=i+(g-i)%r);let C=g|0,B=C+1;B>=a&&(B-=r);let I=g-C,E=n[B],m=n[C];A[l]=m+(E-m)*I,g+=s}else for(let l=0;l<t;l++){let C=g|0,B=C+1;if(B>=o)return A.fill(0,l,t),!1;let I=g-C,E=n[B],m=n[C];A[l]=m+(E-m)*I,g+=s}return this.cursor=g,!0}},Na=class extends Qs{process(t,e,A){let s=e*this.playbackStep,n=this.sampleData,{loopLength:a,loopStart:r,end:i}=this,o=this.cursor;if(this.isLooping)for(let g=0;g<t;g++)o>r&&(o=r+(o-r)%a),A[g]=n[o|0],o+=s;else for(let g=0;g<t;g++){if(o>=i)return A.fill(0,g,t),!1;A[g]=n[o|0],o+=s}return this.cursor=o,!0}},Pa=class extends Qs{process(t,e,A){let s=e*this.playbackStep,n=this.sampleData,{loopEnd:a,loopLength:r,loopStart:i,end:o}=this,g=this.cursor;if(this.isLooping)for(let l=0;l<t;l++){g>i&&(g=i+(g-i)%r);let C=g|0,B=C+1,I=C+2,E=C+3,m=g-C;B>=a&&(B-=r),I>=a&&(I-=r),E>=a&&(E-=r);let k=n[C],y=n[B],b=n[I],R=n[E],M=(b-k)*.5,S=y-b,Q=M+S,p=Q+S+(R-y)*.5,D=Q+p;A[l]=((p*m-D)*m+M)*m+y,g+=s}else for(let l=0;l<t;l++){let C=g|0,B=C+1,I=C+2,E=C+3,m=g-C;if(E>=o)return A.fill(0,l,t),!1;let k=n[C],y=n[B],b=n[I],R=n[E],M=(b-k)*.5,S=y-b,Q=M+S,p=Q+S+(R-y)*.5,D=Q+p;A[l]=((p*m-D)*m+M)*m+y,g+=s}return this.cursor=g,!0}},Ta=-2320,Ua=class{oscillators=[new La,new Na,new Pa];wavetable=this.oscillators[on.interpolationType];filter;generators=new Int16Array(St);modulatedGenerators=new Int16Array(St);modulators=new Array;modulatorValues=new Int16Array(64);modEnv=new Ga;volEnv;resonanceOffset=0;priority=0;isActive=!1;hasRendered=!1;isInRelease=!1;isHeld=!1;channel=0;midiNote=0;targetKey=0;velocity=0;rootKey=0;pressure=0;gainModifier=1;loopingMode=0;startTime=0;releaseStartTime=1/0;tuningCents=0;tuningRatio=1;currentPan=0;portamentoFromKey=-1;portamentoDuration=0;overridePan=0;pitchOffset=0;reverbSend=1;chorusSend=1;delaySend=1;exclusiveClass=0;overrideReleaseVolEnv=0;vibLfoPhase=0;vibLfoStartTime=0;modLfoPhase=0;modLfoStartTime=0;constructor(t,e){this.volEnv=new va(t,e),this.filter=new fs(t)}exclusiveRelease(t,e=Xn){this.overrideReleaseVolEnv=Ta,this.isInRelease=!1,this.releaseVoice(t,e)}releaseVoice(t,e=Vn){this.releaseStartTime=t,this.releaseStartTime-this.startTime<e&&(this.releaseStartTime=this.startTime+e)}setup(t,e,A){this.isActive=!0,this.isInRelease=!1,this.hasRendered=!1,this.isHeld=!1,this.releaseStartTime=1/0,this.pressure=0,this.overrideReleaseVolEnv=0,this.portamentoDuration=0,this.portamentoFromKey=-1,this.vibLfoPhase=.25,this.modLfoPhase=.25,this.startTime=t,this.channel=e,this.midiNote=A}};function pt(t,e){return(t>>e&1)>0}function YA(t){return t?1:0}var st=class ns{isBipolar;isNegative;index;isCC;curveType;constructor(e=Ie.noController,A=le.linear,s=!1,n=!1,a=!1){this.isBipolar=n,this.isNegative=a,this.index=e,this.isCC=s,this.curveType=A}get sourceName(){return this.isCC?Object.keys(f).find(e=>f[e]===this.index)??this.index.toString():Object.keys(Ie).find(e=>Ie[e]===this.index)??this.index.toString()}get curveTypeName(){return Object.keys(le).find(e=>le[e]===this.curveType)??this.curveType.toString()}static fromSourceEnum(e){let A=pt(e,9),s=pt(e,8),n=pt(e,7);return new ns(e&127,e>>10&3,n,A,s)}static copyFrom(e){return new ns(e.index,e.curveType,e.isCC,e.isBipolar,e.isNegative)}toString(){return`${this.sourceName} ${this.curveTypeName} ${this.isBipolar?"bipolar":"unipolar"} ${this.isNegative?"negative":"positive"}`}toSourceEnum(){return this.curveType<<10|YA(this.isBipolar)<<9|YA(this.isNegative)<<8|YA(this.isCC)<<7|this.index}isIdentical(e){return this.index===e.index&&this.isNegative===e.isNegative&&this.isCC===e.isCC&&this.isBipolar===e.isBipolar&&this.curveType===e.curveType}getValue(e,A,s){let n;if(this.isCC)n=e.midiControllers[this.index];else switch(this.index){default:case Ie.noController:n=16383;break;case Ie.noteOnVelocity:n=s.velocity<<7;break;case Ie.noteOnKeyNum:n=s.targetKey<<7;break;case Ie.polyPressure:n=s.pressure<<7;break;case Ie.channelPressure:n=e.midiParameters.pressure<<7;break;case Ie.pitchWheel:n=A;break;case Ie.pitchWheelRange:n=Math.floor(e.midiParameters.pitchWheelRange*128)}let a=(this.isBipolar?2:0)|(this.isNegative?1:0);return hn[xe*(this.curveType*SA+a)+n]}},hn=new Float32Array(xe*4*SA);for(let t=0;t<SA;t++)for(let e=0;e<4;e++){let A=xe*(t*SA+e);for(let s=0;s<xe;s++)hn[A+s]=cn(e,t,s/xe)}function Ze(t,e,A,s,n){return new st(n,t,s,e,A).toSourceEnum()}var ln=Ze(le.linear,!0,!1,!0,f.filterResonance),ke=class as{destination=c.initialAttenuation;transformAmount=0;transformType=0;primarySource;secondarySource;constructor(e=new st,A=new st,s=c.invalid,n=0,a=0){this.primarySource=e,this.secondarySource=A,this.destination=s,this.transformAmount=n,this.transformType=a}get destinationName(){return Object.keys(c).find(e=>c[e]===this.destination)}static isIdentical(e,A,s=!1){return e.primarySource.isIdentical(A.primarySource)&&e.secondarySource.isIdentical(A.secondarySource)&&e.destination===A.destination&&e.transformType===A.transformType&&(!s||e.transformAmount===A.transformAmount)}static copyFrom(e){return new as(st.copyFrom(e.primarySource),st.copyFrom(e.secondarySource),e.destination,e.transformAmount,e.transformType)}toString(){return`Source: ${this.primarySource.toString()}
|
|
1
|
+
function xt(t,e,A=0){let s=0;for(let n=0;n<e;n++)s=s<<8|t[A+n];return s>>>0}function Nt(t,e){let A=xt(t,e,t.currentIndex);return t.currentIndex+=e,A}function sA(t,e){let A=new Array(e).fill(0);for(let s=e-1;s>=0;s--)A[s]=t&255,t>>=8;return A}function V(t,e){let A=cs(t,e,t.currentIndex);return t.currentIndex+=e,A}function cs(t,e,A=0){let s=0;for(let n=0;n<e;n++)s|=t[A+n]<<n*8;return s>>>0}function hs(t,e,A){for(let s=0;s<A;s++)t[t.currentIndex++]=e>>s*8&255}function Ae(t,e){t[t.currentIndex++]=e&255,t[t.currentIndex++]=e>>8}function ge(t,e){hs(t,e,4)}function ls(t,e){let A=e<<8|t;return A>32767?A-65536:A}function Yn(t){return t>127?t-256:t}var ee=class extends Uint8Array{currentIndex=0;slice(t,e){let A=super.slice(t,e);return A.currentIndex=0,A}};function _e(t,e=t.length,A=0){let s="";for(let n=0;n<e;n++){let a=t[A+n];if(a===0)return s;s+=String.fromCharCode(a)}return s}function Ee(t,e){let A=t.currentIndex;return t.currentIndex+=e,_e(t,e,A)}function $e(t,e=!1,A=!1){let s=t.length;e&&s++,A&&s%2!==0&&s++;let n=new ee(s);return Le(n,t),n}function Le(t,e,A=0){A>0&&e.length>A&&(e=e.slice(0,A));for(let s=0;s<e.length;s++)t[t.currentIndex++]=e.charCodeAt(s);if(A>e.length)for(let s=0;s<A-e.length;s++)t[t.currentIndex++]=0;return t}function Qe(t){let e=0;for(;t;){let A=t[t.currentIndex++];if(e=e<<7|A&127,A>>7!==1)break}return e}function UA(t){let e=[t&127];for(t>>=7;t>0;)e.unshift(t&127|128),t>>=7;return e}function _A(t){t=Math.floor(t);let e=Math.floor(t/60),A=Math.round(t-e*60);return{minutes:e,seconds:A,time:`${e.toString().padStart(2,"0")}:${A.toString().padStart(2,"0")}`}}function zs(t){let e="";for(let A=0;A<t.length;A++){let s=t[A].toString(16).padStart(2,"0").toUpperCase();e+=s,A<t.length-1&&(e+=" ")}return e}var d={warn:"color: orange;",unrecognized:"color: red;",info:"color: aqua;",recognized:"color: lime",value:"color: yellow; background-color: black;"},$s;(()=>{var t=Uint8Array,e=Uint16Array,A=Int32Array,s=new t([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,0,0,0]),n=new t([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,0,0]),a=new t([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),r=function(T,F){for(var u=new e(31),x=0;x<31;++x)u[x]=F+=1<<T[x-1];for(var P=new A(u[30]),x=1;x<30;++x)for(var te=u[x];te<u[x+1];++te)P[te]=te-u[x]<<5|x;return{b:u,r:P}},o=r(s,2),i=o.b,g=o.r;i[28]=258,g[258]=28;var l=r(n,0),B=l.b;l.r;var C=new e(32768);for(p=0;p<32768;++p)I=(p&43690)>>1|(p&21845)<<1,I=(I&52428)>>2|(I&13107)<<2,I=(I&61680)>>4|(I&3855)<<4,C[p]=((I&65280)>>8|(I&255)<<8)>>1;var I,p,E=function(T,F,u){for(var x=T.length,P=0,te=new e(F);P<x;++P)T[P]&&++te[T[P]-1];var W=new e(F);for(P=1;P<F;++P)W[P]=W[P-1]+te[P-1]<<1;var _;if(u){_=new e(1<<F);var $=15-F;for(P=0;P<x;++P)if(T[P])for(var ne=P<<4|T[P],ae=F-T[P],J=W[T[P]-1]++<<ae,ie=J|(1<<ae)-1;J<=ie;++J)_[C[J]>>$]=ne}else for(_=new e(x),P=0;P<x;++P)T[P]&&(_[P]=C[W[T[P]-1]++]>>15-T[P]);return _},y=new t(288);for(p=0;p<144;++p)y[p]=8;var p;for(p=144;p<256;++p)y[p]=9;var p;for(p=256;p<280;++p)y[p]=7;var p;for(p=280;p<288;++p)y[p]=8;var p,k=new t(32);for(p=0;p<32;++p)k[p]=5;var p,R=E(y,9,1),b=E(k,5,1),M=function(T){for(var F=T[0],u=1;u<T.length;++u)T[u]>F&&(F=T[u]);return F},S=function(T,F,u){var x=F/8|0;return(T[x]|T[x+1]<<8)>>(F&7)&u},Q=function(T,F){var u=F/8|0;return(T[u]|T[u+1]<<8|T[u+2]<<16)>>(F&7)},m=function(T){return(T+7)/8|0},D=function(T,F,u){return(F==null||F<0)&&(F=0),(u==null||u>T.length)&&(u=T.length),new t(T.subarray(F,u))},q=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],K=function(T,F,u){var x=new Error(F||q[T]);if(x.code=T,Error.captureStackTrace&&Error.captureStackTrace(x,K),!u)throw x;return x},O=function(T,F,u,x){var P=T.length,te=x?x.length:0;if(!P||F.f&&!F.l)return u||new t(0);var W=!u,_=W||F.i!=2,$=F.i;W&&(u=new t(P*3));var ne=function(Ce){var he=u.length;if(Ce>he){var Te=new t(Math.max(he*2,Ce));Te.set(u),u=Te}},ae=F.f||0,J=F.p||0,ie=F.b||0,pe=F.l,ve=F.d,Be=F.m,be=F.n,xe=P*8;do{if(!pe){ae=S(T,J,1);var ht=S(T,J+1,3);if(J+=3,ht)if(ht==1)pe=R,ve=b,Be=9,be=5;else if(ht==2){var lt=S(T,J,31)+257,jt=S(T,J+10,15)+4,eA=lt+S(T,J+5,31)+1;J+=14;for(var Ye=new t(eA),Et=new t(19),Re=0;Re<jt;++Re)Et[a[Re]]=S(T,J+Re*3,7);J+=jt*3;for(var Ot=M(Et),wt=(1<<Ot)-1,TA=E(Et,Ot,1),Re=0;Re<eA;){var Yt=TA[S(T,J,wt)];J+=Yt&15;var Xe=Yt>>4;if(Xe<16)Ye[Re++]=Xe;else{var it=0,Ct=0;for(Xe==16?(Ct=3+S(T,J,3),J+=2,it=Ye[Re-1]):Xe==17?(Ct=3+S(T,J,7),J+=3):Xe==18&&(Ct=11+S(T,J,127),J+=7);Ct--;)Ye[Re++]=it}}var bt=Ye.subarray(0,lt),qe=Ye.subarray(lt);Be=M(bt),be=M(qe),pe=E(bt,Be,1),ve=E(qe,be,1)}else K(1);else{var Xe=m(J)+4,dt=T[Xe-4]|T[Xe-3]<<8,je=Xe+dt;if(je>P){$&&K(0);break}_&&ne(ie+dt),u.set(T.subarray(Xe,je),ie),F.b=ie+=dt,F.p=J=je*8,F.f=ae;continue}if(J>xe){$&&K(0);break}}_&&ne(ie+131072);for(var v=(1<<Be)-1,w=(1<<be)-1,L=J;;L=J){var it=pe[Q(T,J)&v],z=it>>4;if(J+=it&15,J>xe){$&&K(0);break}if(it||K(2),z<256)u[ie++]=z;else if(z==256){L=J,pe=null;break}else{var re=z-254;if(z>264){var Re=z-257,ce=s[Re];re=S(T,J,(1<<ce)-1)+i[Re],J+=ce}var de=ve[Q(T,J)&w],j=de>>4;de||K(3),J+=de&15;var qe=B[j];if(j>3){var ce=n[j];qe+=Q(T,J)&(1<<ce)-1,J+=ce}if(J>xe){$&&K(0);break}_&&ne(ie+131072);var Ne=ie+re;if(ie<qe){var De=te-qe,oe=Math.min(qe,Ne);for(De+ie<0&&K(3);ie<oe;++ie)u[ie]=x[De+ie]}for(;ie<Ne;++ie)u[ie]=u[ie-qe]}}F.l=pe,F.p=L,F.b=ie,F.f=ae,pe&&(ae=1,F.m=Be,F.d=ve,F.n=be)}while(!ae);return ie!=u.length&&W?D(u,0,ie):u.subarray(0,ie)},Y=new t(0);function H(T,F){return O(T,{i:2},F&&F.out,F&&F.dictionary)}var Z=typeof TextDecoder<"u"&&new TextDecoder;try{Z.decode(Y,{stream:!0})}catch{}$s=H})();var js=$s,U=class en{header;size;data;constructor(e,A,s){this.header=e,this.size=A,this.data=s}static read(e,A=!0,s=!1){let n=Ee(e,4),a=V(e,4);n===""&&(a=0);let r=A?e.slice(e.currentIndex,e.currentIndex+a):new ee(0);return(A||s)&&(e.currentIndex+=a,a%2!==0&&e.currentIndex++),new en(n,a,r)}static write(e,A,s=!1,n=!1){if(e.length!==4)throw new Error(`Invalid header length: ${e}`);let a=8,r=e,o=A.length;s&&o++;let i=o;n&&(a+=4,i+=4,r="LIST");let g=a+o;g%2!==0&&g++;let l=new ee(g);return Le(l,r),ge(l,i),n&&Le(l,e),l.set(A,a),l}static getParts(e,A,s=!1){let n=e,a=A.reduce((i,g)=>g.length+i,0);s&&(a+=4,n="LIST");let r=new ee(4);ge(r,a);let o=[$e(n),r];return s&&o.push($e(e)),o.push(...A),a%2!==0&&o.push(new Uint8Array(1)),o}static writeParts(e,A,s=!1){let n=8,a=e,r=A.reduce((l,B)=>B.length+l,0),o=r;s&&(n+=4,o+=4,a="LIST");let i=n+r;i%2!==0&&i++;let g=new ee(i);Le(g,a),ge(g,o),s&&Le(g,e);for(let l of A)g.set(l,n),n+=l.length;return g}static findListType(e,A){return e.find(s=>s.header!=="LIST"?!1:(s.data.currentIndex=4,_e(s.data,4)===A))}};function bA(t,e){return{...e,...t}}var h=class WA{static infoEnabled=!1;static warnEnabled=!0;static groupEnabled=!1;static setLogLevel(e,A,s){this.infoEnabled=e,this.warnEnabled=A,this.groupEnabled=s}static info(...e){this.infoEnabled&&console.info(...e)}static warn(...e){this.warnEnabled&&console.warn(...e)}static group(...e){this.groupEnabled&&console.group(...e)}static groupCollapsed(...e){this.groupEnabled&&console.groupCollapsed(...e)}static groupEnd(){this.groupEnabled&&console.groupEnd()}static unsupported(e,A,s=""){this.infoEnabled&&this.info(`%cUnsupported %c${e}%c message: %c${zs(A)}%c. ${s}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn)}static gmInfo(e,A,s=""){this.infoEnabled&&this.coolInfo(`General MIDI ${e}`,A,s)}static gmFail(e,A){this.infoEnabled&&this.unsupported(`General MIDI ${e}`,A)}static gsInfo(e,A,s=""){this.infoEnabled&&this.coolInfo(`Roland GS ${e}`,A,s)}static gsFail(e,A,s=""){this.infoEnabled&&this.unsupported(`Roland GS ${e}`,A,s)}static xgInfo(e,A,s=""){this.infoEnabled&&this.coolInfo(`Yamaha XG ${e}`,A,s)}static xgFail(e,A,s=""){this.infoEnabled&&this.unsupported(`Yamaha XG ${e}`,A,s)}static coolInfo(e,A,s=""){this.infoEnabled&&(s?WA.info(`%c${e}%c is now set to %c${A}%c ${s}.`,d.recognized,d.info,d.value,d.info):WA.info(`%c${e}%c is now set to %c${A}%c.`,d.recognized,d.info,d.value,d.info))}},tn={ConsoleColors:d,readBigEndian:xt,readLittleEndian:cs,readLittleEndianIndexed:V,readBinaryString:_e,readBinaryStringIndexed:Ee,readVariableLengthQuantity:Qe,inflateSync:js},G={noteOff:128,noteOn:144,polyPressure:160,controllerChange:176,programChange:192,channelPressure:208,pitchWheel:224,systemExclusive:240,timecode:241,songPosition:242,songSelect:243,tuneRequest:246,clock:248,start:250,continue:251,stop:252,activeSensing:254,reset:255,sequenceNumber:0,text:1,copyright:2,trackName:3,instrumentName:4,lyric:5,marker:6,cuePoint:7,programName:8,midiChannelPrefix:32,midiPort:33,endOfTrack:47,setTempo:81,smpteOffset:84,timeSignature:88,keySignature:89,sequenceSpecific:127},f={bankSelect:0,modulationWheel:1,breathController:2,undefinedCC3:3,footController:4,portamentoTime:5,dataEntryMSB:6,mainVolume:7,balance:8,undefinedCC9:9,pan:10,expression:11,effectControl1:12,effectControl2:13,undefinedCC14:14,undefinedCC15:15,generalPurposeController1:16,generalPurposeController2:17,generalPurposeController3:18,generalPurposeController4:19,undefinedCC20:20,undefinedCC21:21,undefinedCC22:22,undefinedCC23:23,undefinedCC24:24,undefinedCC25:25,undefinedCC26:26,undefinedCC27:27,undefinedCC28:28,undefinedCC29:29,undefinedCC30:30,undefinedCC31:31,bankSelectLSB:32,modulationWheelLSB:33,breathControllerLSB:34,undefinedCC3LSB:35,footControllerLSB:36,portamentoTimeLSB:37,dataEntryLSB:38,mainVolumeLSB:39,balanceLSB:40,undefinedCC9LSB:41,panLSB:42,expressionLSB:43,effectControl1LSB:44,effectControl2LSB:45,undefinedCC14LSB:46,undefinedCC15LSB:47,undefinedCC16LSB:48,undefinedCC17LSB:49,undefinedCC18LSB:50,undefinedCC19LSB:51,undefinedCC20LSB:52,undefinedCC21LSB:53,undefinedCC22LSB:54,undefinedCC23LSB:55,undefinedCC24LSB:56,undefinedCC25LSB:57,undefinedCC26LSB:58,undefinedCC27LSB:59,undefinedCC28LSB:60,undefinedCC29LSB:61,undefinedCC30LSB:62,undefinedCC31LSB:63,sustainPedal:64,portamentoOnOff:65,sostenutoPedal:66,softPedal:67,legatoFootswitch:68,hold2Pedal:69,soundVariation:70,filterResonance:71,releaseTime:72,attackTime:73,brightness:74,decayTime:75,vibratoRate:76,vibratoDepth:77,vibratoDelay:78,soundController10:79,generalPurposeController5:80,generalPurposeController6:81,generalPurposeController7:82,generalPurposeController8:83,portamentoControl:84,undefinedCC85:85,undefinedCC86:86,undefinedCC87:87,undefinedCC88:88,undefinedCC89:89,undefinedCC90:90,reverbDepth:91,tremoloDepth:92,chorusDepth:93,variationDepth:94,phaserDepth:95,dataIncrement:96,dataDecrement:97,nonRegisteredParameterLSB:98,nonRegisteredParameterMSB:99,registeredParameterLSB:100,registeredParameterMSB:101,undefinedCC102LSB:102,undefinedCC103LSB:103,undefinedCC104LSB:104,undefinedCC105LSB:105,undefinedCC106LSB:106,undefinedCC107LSB:107,undefinedCC108LSB:108,undefinedCC109LSB:109,undefinedCC110LSB:110,undefinedCC111LSB:111,undefinedCC112LSB:112,undefinedCC113LSB:113,undefinedCC114LSB:114,undefinedCC115LSB:115,undefinedCC116LSB:116,undefinedCC117LSB:117,undefinedCC118LSB:118,undefinedCC119LSB:119,allSoundOff:120,resetAllControllers:121,localControlOnOff:122,allNotesOff:123,omniModeOff:124,omniModeOn:125,monoModeOn:126,polyModeOn:127},ut={pitchWheelRange:0,fineTuning:1,coarseTuning:2,modulationDepth:5,resetParameters:16383},ye={partParameter:1,drumPitch:24,drumPitchFine:25,drumLevel:26,drumPan:28,drumReverb:29,drumChorus:30,drumDelay:31,awe32:127,SF2:120},Pe={vibratoRate:8,vibratoDepth:9,vibratoDelay:10,tvfCutoffFrequency:32,tvfResonance:33,envelopeAttackTime:99,envelopeDecayTime:100,envelopeReleaseTime:102},We=class{ticks;statusByte;data;constructor(t,e,A){this.ticks=t,this.statusByte=e,this.data=A}},ws=(t,e)=>{for(let A=0;A<t.length;A++)e.push(t.charCodeAt(A))};function qn(t){if(!t.tracks)throw new Error("MIDI has no tracks!");let e=[];for(let s of t.tracks){let n=[],a=0,r;for(let o of s.events){let i=Math.max(0,o.ticks-a);if(o.statusByte===G.endOfTrack){a+=i;continue}let g;o.statusByte<=G.sequenceSpecific?(g=[255,o.statusByte,...UA(o.data.length),...o.data],r=void 0):o.statusByte===G.systemExclusive?(g=[240,...UA(o.data.length),...o.data],r=void 0):(g=[],r!==o.statusByte&&(r=o.statusByte,g.push(o.statusByte)),g.push(...o.data)),n.push(...UA(i),...g),a+=i}n.push(0,255,G.endOfTrack,0),e.push(n)}let A=[];ws("MThd",A),A.push(...sA(6,4),0,t.format,...sA(t.tracks.length,2),...sA(t.timeDivision,2));for(let s of e)ws("MTrk",A),A=A.concat(sA(s.length,4),s);return new Uint8Array(A).buffer}var nA=`SPESSASYNTH_EMBEDDED_BANK_${Math.random()}_DO_NOT_DELETE`,Jn=32767,Kn={time:0},Vn=.03,Xn=.07,Zn=.6;var hA=1/Math.cos(Math.PI/4)**2;var bs=121,Se=class{static getDefaultBank(t){return t==="gm2"?bs:0}static getDrumBank(t){switch(t){default:throw new Error(`${t} doesn't have a bank MSB for drums.`);case"gm2":return 120;case"xg":return 127}}static isXGDrum(t){return t===120||t===127}static isValidXGMSB(t){return this.isXGDrum(t)||t===64||t===bs}static isSystemXG(t){return t==="gm2"||t==="xg"}static addBankOffset(t,e,A){return this.isXGDrum(t)&&A?t:Math.min(t+e,127)}static subtractBankOffset(t,e,A){return this.isXGDrum(t)&&A?t:Math.max(0,t-e)}},ze=class zA{static toMIDIString(e){return e.isGMGSDrum?`DRUM:${e.program}`:`${e.bankLSB}:${e.bankMSB}:${e.program}`}static fromMIDIString(e){let A=e.split(":");if(A.length>3||A.length<2)throw new Error(`Invalid MIDI string: ${e}`);return e.startsWith("DRUM")?{bankMSB:0,bankLSB:0,program:Number.parseInt(A[1]),isGMGSDrum:!0}:{bankLSB:Number.parseInt(A[0]),bankMSB:Number.parseInt(A[1]),program:Number.parseInt(A[2]),isGMGSDrum:!1}}static toFullMIDIString(e){return`${this.toMIDIString(e)} ${e.isDrum?"D":"M"} ${e.name}`}static fromFullMIDIString(e){let A=e.indexOf(" "),s=e.indexOf(" ",A+1);if(A===-1||s===-1)throw new Error(`Invalid named MIDI string: ${e}`);let n=e.slice(0,Math.max(0,A)),a=e.slice(A+1,s),r=e.slice(Math.max(0,s+1));return{...zA.fromMIDIString(n),isDrum:a==="D",name:r}}static matches(e,A){return e.isGMGSDrum||A.isGMGSDrum?e.isGMGSDrum===A.isGMGSDrum&&e.program===A.program:e.program===A.program&&e.bankLSB===A.bankLSB&&e.bankMSB===A.bankMSB}static compare(e,A){return e.isGMGSDrum&&!A.isGMGSDrum?1:!e.isGMGSDrum&&A.isGMGSDrum?-1:e.program!==A.program?e.program-A.program:e.bankMSB!==A.bankMSB?e.bankMSB-A.bankMSB:e.bankLSB-A.bankLSB}static isXGDrum(e){return e.isDrum&&!e.isGMGSDrum}static selectPatch(e,A,s){if(e.length===0)throw new Error("No presets!");A.isGMGSDrum&&Se.isSystemXG(s)&&(A={...A,isGMGSDrum:!1,bankLSB:0,bankMSB:Se.getDrumBank(s)});let{isGMGSDrum:n,bankLSB:a,bankMSB:r,program:o}=A,i=Se.isSystemXG(s),g=Se.isXGDrum(r)&&i,l=e.find(I=>this.matches(I,A));if(l&&(!g||g&&this.isXGDrum(l)))return l;let B=I=>{h.info(`%cPreset %c${zA.toMIDIString(A)}%c not found. (${s}) Replaced with %c${this.toFullMIDIString(I)}`,d.warn,d.unrecognized,d.warn,d.value)};if(n){let I=e.find(E=>E.isGMGSDrum&&E.program===o);return I||(I=e.find(E=>E.isDrum&&E.program===o),I)?(B(I),I):(I=this.getAnyDrums(e,!1),B(I),I)}if(g){let I=e.find(E=>E.program===o&&E.isDrum&&!E.isGMGSDrum);return I||(I=e.find(E=>E.isDrum&&E.program===o),I&&I.program<49)?(B(I),I):(I=this.getAnyDrums(e,!0),B(I),I)}let C=e.filter(I=>I.program===o&&!I.isDrum);if(C.length===0)return B(e[0]),e[0];if(l=i?C.find(I=>I.bankLSB===a):C.find(I=>I.bankMSB===r),l)return B(l),l;if(a!==64||!i){let I=Math.max(r,a);if(l=C.find(E=>E.bankLSB===I||E.bankMSB===I),l)return B(l),l}return B(C[0]),C[0]}static getAnyDrums(e,A){let s=A?e.find(n=>this.isXGDrum(n)):e.find(n=>n.isGMGSDrum);return s||(e.find(n=>n.isDrum)??e[0])}},fe=Object.freeze({type:"Other"}),se=class $A{static analyzeSysEx(e){if(e.length<3)return fe;switch(e[0]){default:return fe;case 126:case 127:return this.analyzeGM(e);case 65:return this.analyzeGS(e);case 67:return this.analyzeXG(e)}}static analyzeRPN(e,A,s){switch(A){default:return fe;case ut.fineTuning:return{type:"Fine Tune",channel:e,value:(s-8192)/81.92};case ut.coarseTuning:return{type:"Key Shift",channel:e,value:(s>>7)-64}}}static analyzeNRPN(e,A,s){let n=A>>7,a=A&127;switch(n){default:return fe;case ye.partParameter:switch(a){default:return fe;case Pe.vibratoRate:return{type:"Controller Change",channel:e,controller:f.vibratoRate,value:s>>7};case Pe.vibratoDepth:return{type:"Controller Change",channel:e,controller:f.vibratoDepth,value:s>>7};case Pe.vibratoDelay:return{type:"Controller Change",channel:e,controller:f.vibratoDelay,value:s>>7};case Pe.tvfCutoffFrequency:return{type:"Controller Change",channel:e,controller:f.brightness,value:s>>7};case Pe.tvfResonance:return{type:"Controller Change",channel:e,controller:f.filterResonance,value:s>>7};case Pe.envelopeAttackTime:return{type:"Controller Change",channel:e,controller:f.attackTime,value:s>>7};case Pe.envelopeDecayTime:return{type:"Controller Change",channel:e,controller:f.decayTime,value:s>>7};case Pe.envelopeReleaseTime:return{type:"Controller Change",channel:e,controller:f.releaseTime,value:s>>7}}case ye.drumPitch:case ye.drumPitchFine:case ye.drumLevel:case ye.drumPan:case ye.drumReverb:case ye.drumChorus:case ye.drumDelay:return{type:"Drum Setup"}}}static syxToChannel(e){return[9,0,1,2,3,4,5,6,7,8,10,11,12,13,14,15][e%16]}static channelToSyx(e){return[1,2,3,4,5,6,7,8,9,0,10,11,12,13,14,15][e%16]}static gsData(e,A,s,n){let a=128-(e+A+s+n.reduce((r,o)=>r+o,0))%128&127;return[65,16,66,18,e,A,s,...n,a,247]}static gsMessage(e,A,s,n,a){return new We(e,G.systemExclusive,new Uint8Array(this.gsData(A,s,n,a)))}static gsDrumChange(e,A,s){let n=16|this.channelToSyx(A);return this.gsMessage(e,40,n,21,[s])}static gsReset(e){return this.gsMessage(e,64,0,127,[0])}static analyzeGM(e){if(e.length<4)return fe;if(e[2]===4)switch(e[3]){default:return fe;case 3:return{type:"Master Fine Tune",value:((e[5]<<7|e[6])-8192)/81.92};case 4:return{type:"Master Key Shift",value:e[5]-64};case 5:if(e[4]!==1||e[5]!==1||e[6]!==1||e[7]!==1)return fe;switch(e[8]){default:return fe;case 1:switch(e[9]){default:return fe;case 1:case 2:return{type:"Reverb Param"}}case 2:switch(e[9]){default:return fe;case 1:case 2:case 3:case 4:return{type:"Chorus Param"}}}}if(e[2]!==9)return fe;switch(e[3]){default:return fe;case 1:return{type:"GM On"};case 2:return{type:"GM Off"};case 3:return{type:"GM2 On"}}}static analyzeXG(e){if(e[2]!==76||e.length<7)return fe;let A=e[3],s=e[4],n=e[5],a=e[6];if(A===0&&s===0)switch(n){default:return fe;case 0:return{type:"Master Fine Tune",value:(((e[6]&15)<<12|(e[7]&15)<<8|(e[8]&15)<<4|e[9]&15)-1024)/10};case 6:return{type:"Master Key Shift",value:a-64};case 126:case 127:return{type:"XG Reset"}}if(A===2&&s===1)return n<=21?{type:"Reverb Param"}:n<=53?{type:"Chorus Param"}:{type:"Variation Param"};if(A===3&&s===0)return{type:"Variation Param"};if(A===8){let r=s;if(r>=16)return fe;switch(n){default:return fe;case 1:return{type:"Controller Change",channel:r,controller:f.bankSelect,value:a};case 2:return{type:"Controller Change",channel:r,controller:f.bankSelectLSB,value:a};case 3:return{type:"Program Change",channel:r,value:a};case 5:return{type:"Controller Change",channel:r,controller:a===1?f.polyModeOn:f.monoModeOn,value:0};case 7:return{type:"Drums On",channel:r,isDrum:a>0};case 8:return{type:"Key Shift",channel:r,value:a-64};case 11:return{type:"Controller Change",channel:r,controller:f.mainVolume,value:a};case 14:return{type:"Controller Change",channel:r,controller:f.pan,value:a};case 18:return{type:"Controller Change",channel:r,controller:f.chorusDepth,value:a};case 19:return{type:"Controller Change",channel:r,controller:f.reverbDepth,value:a};case 21:return{type:"Controller Change",channel:r,controller:f.vibratoRate,value:a};case 22:return{type:"Controller Change",channel:r,controller:f.vibratoDepth,value:a};case 23:return{type:"Controller Change",channel:r,controller:f.vibratoDelay,value:a};case 24:return{type:"Controller Change",channel:r,controller:f.brightness,value:a};case 25:return{type:"Controller Change",channel:r,controller:f.filterResonance,value:a};case 26:return{type:"Controller Change",channel:r,controller:f.attackTime,value:a};case 27:return{type:"Controller Change",channel:r,controller:f.decayTime,value:a};case 12:return{type:"Controller Change",channel:r,controller:f.releaseTime,value:a}}}return A>>4===3?{type:"Drum Setup"}:fe}static analyzeGS(e){if(e.length<10||e[2]!==66||e[3]!==18)return fe;let A=e[4],s=e[5],n=e[6],a=e[7];if((A===0||A===64)&&s===0)switch(n){case 127:switch(a){case 0:return{type:"GS Reset"};case 127:return{type:"GM On"}}return fe;case 0:return{type:"Master Fine Tune",value:((a<<12|e[8]<<8|e[9]<<4|e[10])-1024)/10}}if(A===65)return{type:"Drum Setup"};if(A!==64)return fe;if(s===0&&n===5)return{type:"Master Key Shift",value:a-64};if(s===1){if(n>=48&&n<=55)return{type:"Reverb Param"};if(n>=56&&n<=64)return{type:"Chorus Param"};if(n>=80&&n<=90)return{type:"Delay Param"}}if(s===3&&n>=0&&n<=127)return{type:"Insertion Param"};if(s>>4===1){let r=$A.syxToChannel(s&15);switch(n){default:return fe;case 0:return{type:"Program Change",channel:r,value:a};case 19:return{type:"Controller Change",channel:r,controller:a===1?f.polyModeOn:f.monoModeOn,value:0};case 21:return{type:"Drums On",channel:r,isDrum:a>0};case 22:return{type:"Key Shift",channel:r,value:a-64};case 25:return{type:"Controller Change",channel:r,controller:f.mainVolume,value:a};case 28:return{type:"Controller Change",channel:r,controller:f.pan,value:a};case 33:return{type:"Controller Change",channel:r,controller:f.chorusDepth,value:a};case 34:return{type:"Controller Change",channel:r,controller:f.reverbDepth,value:a};case 42:return{type:"Fine Tune",channel:r,value:((a<<7|e[8])-8192)/81.92};case 44:return{type:"Controller Change",channel:r,controller:f.variationDepth,value:a};case 48:return{type:"Controller Change",channel:r,controller:f.vibratoRate,value:a};case 49:return{type:"Controller Change",channel:r,controller:f.vibratoDepth,value:a};case 50:return{type:"Controller Change",channel:r,controller:f.brightness,value:a};case 51:return{type:"Controller Change",channel:r,controller:f.filterResonance,value:a};case 52:return{type:"Controller Change",channel:r,controller:f.attackTime,value:a};case 53:return{type:"Controller Change",channel:r,controller:f.decayTime,value:a};case 54:return{type:"Controller Change",channel:r,controller:f.releaseTime,value:a};case 55:return{type:"Controller Change",channel:r,controller:f.vibratoDelay,value:a}}}if(s>>4===4){let r=$A.syxToChannel(s&15);switch(n){default:return fe;case 0:case 1:return{type:"Controller Change",channel:r,controller:f.bankSelectLSB,value:a};case 34:return{type:"Insertion Param"}}}return fe}},_n="Created using SpessaSynth";function Wn(t,e,A){let s="gm",n=[],a=new Array(t.tracks.length).fill(0),r=16+Math.max(...t.portChannelOffsetMap),o=[];for(let i=0;i<r;i++)o.push({program:0,isDrum:i%16===9,lastBank:void 0,lastBankLSB:void 0,hasBankSelect:!1});t.iterate((i,g,l)=>{let B=t.portChannelOffsetMap[a[g]];if(i.statusByte===G.midiPort){a[g]=i.data[0];return}let C=i.statusByte&240;if(C!==G.controllerChange&&C!==G.programChange&&C!==G.systemExclusive)return;if(C===G.systemExclusive){let k=se.analyzeSysEx(i.data);switch(k.type){default:return;case"Drums On":{let p=k.channel+B;o[p].isDrum=k.isDrum;return}case"XG Reset":s="xg";return;case"GS Reset":s="gs";return;case"GM Off":case"GM On":s="gm",n.push({tNum:g,e:i});return;case"GM2 On":s="gm2";return;case"Controller Change":{let p=t.tracks[g],R=new We(i.ticks,G.controllerChange|k.channel,new Uint8Array([k.controller,k.value]));p.events[l[g]]=R,i=R,h.info("%cReplaced a system exclusive with controller change!",d.info);break}case"Program Change":{let p=t.tracks[g],R=new We(i.ticks,G.programChange|k.channel,new Uint8Array([k.value]));p.events[l[g]]=R,i=R,h.info("%cReplaced a system exclusive with program change!",d.info);break}}}let I=(i.statusByte&15)+B,E=o[I];if(C===G.programChange){let k={program:i.data[0],bankLSB:E.lastBankLSB?.data?.[1]??0,bankMSB:Se.subtractBankOffset(E.lastBank?.data?.[1]??0,t.bankOffset,s==="xg"),isGMGSDrum:E.isDrum},p=A.getPreset(k,s);if(h.info(`%cInput patch: %c${ze.toMIDIString(k)}%c. Channel %c${I}%c. Changing patch to ${p.toString()}.`,d.info,d.unrecognized,d.info,d.recognized,d.info),i.data[0]=p.program,p.isGMGSDrum&&Se.isSystemXG(s)||E.lastBank===void 0||(E.lastBank.data[1]=Se.addBankOffset(p.bankMSB,e,s==="xg"),E.lastBankLSB===void 0))return;E.lastBankLSB.data[1]=p.bankLSB;return}let y=i.data[0]===f.bankSelectLSB;i.data[0]!==f.bankSelect&&!y||(E.hasBankSelect=!0,y?E.lastBankLSB=i:E.lastBank=i)});for(let i=0;i<o.length;i++){let g=o[i];if(g.hasBankSelect)continue;let l=i%16,B=G.programChange|l,C=Math.floor(i/16)*16,I=t.portChannelOffsetMap.indexOf(C),E=t.tracks.find(b=>b.port===I&&b.channels.has(l));if(E===void 0)continue;let y=E.events.findIndex(b=>b.statusByte===B);if(y===-1){let b=E.events.findIndex(Q=>Q.statusByte>128&&Q.statusByte<240&&(Q.statusByte&15)===l);if(b===-1)continue;let M=E.events[b].ticks,S=A.getPreset({bankMSB:0,bankLSB:0,program:0,isGMGSDrum:!1},s).program;E.addEvents(b,new We(M,G.programChange|l,new ee([S]))),y=b}h.info(`%cAdding bank select for %c${i}`,d.info,d.recognized);let k=E.events[y].ticks,p=A.getPreset({bankLSB:0,bankMSB:0,program:g.program,isGMGSDrum:g.isDrum},s),R=Se.addBankOffset(p.bankMSB,e,s==="xg");E.addEvents(y,new We(k,G.controllerChange|l,new ee([f.bankSelect,R])))}if(s==="gm"&&!Se.isSystemXG(s)){for(let g of n){let l=t.tracks[g.tNum];l.deleteEvent(l.events.indexOf(g.e))}let i=0;t.tracks[0].events[0].statusByte===G.trackName&&i++,t.tracks[0].addEvents(i,se.gsReset(0))}t.flush()}var Rs={bankOffset:0,metadata:{},correctBankOffset:!0,soundBank:void 0};function zn(t,e,A){let s=A.metadata;if(h.group("%cWriting the RMIDI File...",d.info),h.info("metadata",s),h.info("Initial bank offset",t.bankOffset),A.correctBankOffset){if(!A.soundBank)throw new Error("Sound bank must be provided if correcting bank offset.");Wn(t,A.bankOffset,A.soundBank)}let n=new ee(t.writeMIDI());s.name??=t.getName(),s.creationDate??=new Date,s.copyright??=_n,s.software??="SpessaSynth",Object.entries(s).forEach(i=>{let g=i;g[1]&&t.setRMIDInfo(g[0],g[1])});let a=[],r=(i,g)=>{a.push(U.write(i,g))};for(let i of Object.entries(t.rmidiInfo)){let g=i[0],l=i[1];switch(g){case"album":r("IALB",l),r("IPRD",l);break;case"software":r("ISFT",l);break;case"infoEncoding":r("IENC",l);break;case"creationDate":r("ICRD",l);break;case"picture":r("IPIC",l);break;case"name":r("INAM",l);break;case"artist":r("IART",l);break;case"genre":r("IGNR",l);break;case"copyright":r("ICOP",l);break;case"comment":r("ICMT",l);break;case"engineer":r("IENG",l);break;case"subject":r("ISBJ",l);break;case"midiEncoding":r("MENC",l);break}}let o=new ee(2);return hs(o,A.bankOffset,2),a.push(U.write("DBNK",o)),h.info("%cFinished!",d.info),h.groupEnd(),U.writeParts("RIFF",[$e("RMID"),U.write("data",n),U.writeParts("INFO",a,!0),new ee(e)]).buffer}var QA=class{rpnMSB={v:127,track:0,event:0};rpnLSB={v:127,track:0,event:0};nrpnMSB={v:0,track:0,event:0};nrpnLSB={v:0,track:0,event:0};dataMSB={v:0,track:0,event:0};dataLSB={v:0,track:0,event:0};channel;isRegistered=!0;constructor(t){this.channel=t}get paramMSB(){return this.isRegistered?this.rpnMSB:this.nrpnMSB}get paramLSB(){return this.isRegistered?this.rpnLSB:this.nrpnLSB}reset(){this.isRegistered=!0,this.rpnLSB.v=127,this.rpnMSB.v=127,this.nrpnMSB.v=0,this.nrpnLSB.v=0,this.resetData()}controllerChange(t,e,A,s){switch(t){case f.registeredParameterMSB:this.resetData(),this.isRegistered=!0,this.rpnMSB={v:e,track:A,event:s};break;case f.registeredParameterLSB:this.resetData(),this.isRegistered=!0,this.rpnLSB={v:e,track:A,event:s};break;case f.nonRegisteredParameterMSB:this.resetData(),this.isRegistered=!1,this.nrpnMSB={v:e,track:A,event:s};break;case f.nonRegisteredParameterLSB:this.resetData(),this.isRegistered=!1,this.nrpnLSB={v:e,track:A,event:s};break;case f.dataEntryMSB:return this.dataMSB={v:e,track:A,event:s},this.analyze();case f.dataEntryLSB:return this.dataLSB={v:e,track:A,event:s},this.analyze()}}resetData(){this.dataLSB.v=0,this.dataMSB.v=0}analyze(){let t=this.dataMSB.v<<7|this.dataLSB.v;return this.isRegistered?se.analyzeRPN(this.channel,this.rpnMSB.v<<7|this.rpnLSB.v,t):se.analyzeNRPN(this.channel,this.nrpnMSB.v<<7|this.nrpnLSB.v,t)}};function $n(t,e){h.groupCollapsed("%cSearching for all used programs and keys...",d.info);let A=16+Math.max(...t.portChannelOffsetMap),s=[],n="gs",a=0,r=C=>{n=C,a=0;for(let I=0;I<A;I++){let E=s[I];E.isDrum=I%16===9,E.bankMSB=Se.getDefaultBank(C),E.bankLSB=0,E.keyShift=0,E.param.reset()}};for(let C=0;C<A;C++){let I=C%16===9;s.push({preset:e.getPreset({bankLSB:0,bankMSB:0,isGMGSDrum:I,program:0},n),bankMSB:0,bankLSB:0,param:new QA(C),isDrum:I,keyShift:0})}let o=new Map,i=t.tracks.map(C=>C.port),g=t.portChannelOffsetMap,{timeline:l,tracks:B}=t;for(let C of l){let I=C.tr,E=C.ev,y=B[I].events[E];if(y.statusByte===G.midiPort&&t.tracks[I].channels.size>0){let R=y.data[0];g[R]===void 0&&(h.warn(`Invalid port ${R} on track ${I}. (No offset found in the MIDI map.`),R=0),i[I]=R;continue}let k=y.statusByte&240;if(k!==G.noteOn&&k!==G.controllerChange&&k!==G.programChange&&k!==G.systemExclusive)continue;let p=g[i[I]]||0;switch(k){case G.programChange:{let R=s[(y.statusByte&15)+p];R.preset=e.getPreset({bankMSB:R.bankMSB,bankLSB:R.bankLSB,program:y.data[0],isGMGSDrum:R.isDrum},n);break}case G.controllerChange:{let R=s[(y.statusByte&15)+p],b=y.data[0],M=y.data[1];switch(b){case f.registeredParameterMSB:case f.registeredParameterLSB:case f.nonRegisteredParameterLSB:case f.nonRegisteredParameterMSB:R.param.controllerChange(b,M,I,E);break;case f.dataEntryMSB:case f.dataEntryLSB:{let S=R.param.controllerChange(b,M,I,E);S?.type==="Key Shift"&&(R.keyShift=R.isDrum?0:S.value);break}case f.resetAllControllers:R.param.reset();break;case f.bankSelect:R.bankMSB=M;break;case f.bankSelectLSB:R.bankLSB=M;break}break}case G.noteOn:{let R=s[(y.statusByte&15)+p];if(y.data[1]===0||!R.preset)continue;let b=o.get(R.preset);b||(b=new Map,o.set(R.preset,b));let M=y.data[0]+(R.isDrum?0:a)+R.keyShift,S=b.get(M);S||(S=new Set,b.set(M,S)),S.add(y.data[1]);break}case G.systemExclusive:{let R=se.analyzeSysEx(y.data);switch(R.type){default:break;case"XG Reset":r("xg"),h.info("%cXG on detected!",d.recognized);break;case"GM2 On":r("gm2"),h.info("%cGM2 on detected!",d.recognized);break;case"GM On":r("gm"),h.info("%cGM on detected!",d.recognized);break;case"GM Off":case"GS Reset":r("gs"),h.info("%cGS on detected!",d.recognized);break;case"Master Key Shift":a=R.value;break;case"Key Shift":{let b=s[R.channel];b.keyShift=b.isDrum?0:R.value;break}case"Drums On":{let b=R.channel+p;s[b].isDrum=R.isDrum;break}case"Program Change":{let b=s[R.channel+p];b.preset=e.getPreset({bankMSB:b.bankMSB,bankLSB:b.bankLSB,program:R.value,isGMGSDrum:b.isDrum},n);break}case"Controller Change":{let b=R.channel+p;R.controller===f.bankSelectLSB?s[b].bankLSB=R.value:R.controller===f.bankSelect&&(s[b].bankMSB=R.value)}}}}}for(let[C,I]of o.entries())I.size===0&&(h.info(`%cDetected change but no keys for %c${C.name}`,d.info,d.value),o.delete(C));return h.groupEnd(),o}var jn=t=>(t.data=new ee(t.data.buffer),6e7/xt(t.data,3));function ea(t,e=0){let A=[];for(let B=0;B<16;B++)A.push([]);let s=0,n=60/(120*t.timeDivision),a=0,r=0,o=[];for(let B=0;B<16;B++)o.push([]);let i=(B,C)=>{let I=o[C].findIndex(y=>y.midiNote===B),E=o[C][I];if(E){let y=s-E.start;E.length=y,C===9&&(E.length=Math.max(y,e)),o[C].splice(I,1)}r--},{timeline:g,tracks:l}=t;for(;a<g.length;){let B=g[a],C=l[B.tr].events[B.ev],I=C.statusByte>>4,E=C.statusByte&15;if(I===8)i(C.data[0],E);else if(I===9)if(C.data[1]===0)i(C.data[0],E);else{i(C.data[0],E);let y={midiNote:C.data[0],start:s,length:-1,velocity:C.data[1]/127};A[E].push(y),o[E].push(y),r++}else C.statusByte===81&&(n=60/(jn(C)*t.timeDivision));if(++a>=g.length)break;s+=n*(l[g[a].tr].events[g[a].ev].ticks-C.ticks)}if(r>0)for(let[B,C]of o.entries())for(let I of C){let E=s-I.start;I.length=E,B===9&&(I.length=Math.max(E,e))}return A}var ta={character:49,preLowpass:50,level:51,time:52,delayFeedback:53,preDelayTime:55},Aa={preLowpass:57,level:58,feedback:59,delay:60,rate:61,depth:62,sendLevelToReverb:63,sendLevelToDelay:64},sa={preLowpass:81,timeCenter:82,timeRatioLeft:83,timeRatioRight:84,levelCenter:85,levelLeft:86,levelRight:87,level:88,feedback:89,sendLevelToReverb:90};function Mt(t,e,A,s){return new We(s,G.controllerChange|t%16,new ee([e,A]))}function na(t,e){h.groupCollapsed("%cApplying changes to the MIDI file...",d.info);let{channels:A,reverbParams:s,chorusParams:n,delayParams:a,insertionParams:r}=e;h.info("Desired channel changes",A),h.info("Desired reverb parameters",s),h.info("Desired chorus parameters",n),h.info("Desired delay parameters",a),h.info("Desired insertion parameters",r);let o=e.drumSetupParams==="clear",i=new Set,g=new Map;if(A)for(let[m,D]of A)D==="clear"?i.add(m):g.set(m,D);let l="gs",B=!1,C=0,I=0,E=t.tracks.map(m=>m.port),y={},k=0,p=(m,D)=>{t.tracks[m].channels.size!==0&&(k===0&&(k+=16,y[D]=0),y[D]===void 0&&(y[D]=k,k+=16),E[m]=D)};for(let[m,D]of t.tracks.entries())p(m,D.port);let R=k,b=[];for(let m=0;m<R;m++)b.push({isFirstNoteOn:!0,param:new QA(m),clearedParams:{pLSB:!0,pMSB:!0,data:!0},keyShift:g.get(m)?.keyShift??0,fineTune:g.get(m)?.fineTune??0});if(t.iterate((m,D,q)=>{let K=t.tracks[D],O=q[D],Y=()=>{K.deleteEvent(O),q[D]--},H=W=>{let _=b[W],$=_.param,ne=$.paramMSB,ae=$.paramLSB;h.info(`%cClearing Non/Registered Parameter on ${W}. Clear MSB: %c${_.clearedParams.pMSB}%c, clear LSB: %c${_.clearedParams.pLSB}%c, clear data: %c${_.clearedParams.data}.`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized),_.clearedParams.data||(Y(),D===ne.track&&O<ne.event&&ne.event--,D===ae.track&&O<ae.event&&ae.event--,_.clearedParams.data=!0),_.clearedParams.pMSB||(t.tracks[ne.track].deleteEvent(ne.event),q[ne.track]--,ne.track===ae.track&&ne.event<ae.event&&ae.event--,_.clearedParams.pMSB=!0),_.clearedParams.pLSB||(t.tracks[ae.track].deleteEvent(ae.event),q[ae.track]--,_.clearedParams.pLSB=!0)},Z=(W,_=0)=>{K.addEvents(O+_,W),q[D]++},T=y[E[D]]||0;if(m.statusByte===G.midiPort){p(D,m.data[0]);return}if(m.statusByte<G.noteOff||m.statusByte>G.systemExclusive)return;let F=m.statusByte&240,u=m.statusByte&15,x=u+T;if(m.statusByte!==G.systemExclusive&&i.has(x)){Y();return}let P=b[x],te=g.get(x);switch(F){case G.noteOn:if(!te)break;if(P.isFirstNoteOn){if(P.isFirstNoteOn=!1,te.controllers)for(let[_,$]of te.controllers)$!=="clear"&&Z(Mt(u,_,$,m.ticks));if(P.fineTune!==0){let _=Math.floor(P.fineTune*81.92)+8192,$=Mt(u,f.registeredParameterMSB,0,m.ticks),ne=Mt(u,f.registeredParameterLSB,1,m.ticks),ae=Mt(x,f.dataEntryMSB,_>>7&127,m.ticks);Z(Mt(u,f.dataEntryLSB,_&127,m.ticks)),Z(ae),Z(ne),Z($)}let W=te.patch;if(W&&W!=="clear"){h.info(`%cSetting %c${x}%c to %c${ze.toMIDIString(W)}%c. Track num: %c${D}`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized);let _=W.bankMSB,$=W.bankLSB,ne=W.program;Z(new We(m.ticks,G.programChange|u,new ee([ne])));let ae=(J,ie)=>{Z(Mt(u,J?f.bankSelectLSB:f.bankSelect,ie,m.ticks))};Se.isSystemXG(l)&&W.isGMGSDrum&&(h.info(`%cAdding XG Drum change on track %c${D}`,d.recognized,d.value),_=Se.getDrumBank(l),$=0),ae(!1,_),ae(!0,$),W.isGMGSDrum&&!Se.isSystemXG(l)&&u!==9&&(h.info(`%cAdding GS Drum change on track %c${D}`,d.recognized,d.value),Z(se.gsDrumChange(m.ticks,u,1)))}}m.data[0]+=P.keyShift;break;case G.noteOff:if(!te)break;m.data[0]+=P.keyShift;break;case G.programChange:if(te?.patch){Y();return}break;case G.controllerChange:{let W=m.data[0],_=m.data[1];if(te?.controllers?.get(W)){Y();return}switch(W){case f.bankSelect:case f.bankSelectLSB:te?.patch&&Y();return;case f.registeredParameterLSB:case f.registeredParameterMSB:case f.nonRegisteredParameterMSB:case f.nonRegisteredParameterLSB:W===f.nonRegisteredParameterLSB||W===f.registeredParameterLSB?P.clearedParams.pLSB=!1:P.clearedParams.pMSB=!1,P.param.controllerChange(W,_,D,O);return;case f.dataEntryMSB:case f.dataEntryLSB:{P.clearedParams.data=!1;let $=P.param.controllerChange(W,_,D,O);if(!$)return;switch($.type){case"Drum Setup":o&&H(x);return;case"Controller Change":{let ne=$.controller,ae=$.channel;if(te?.controllers?.get(ne)){H(ae);return}(ne===f.bankSelect||ne===f.bankSelectLSB)&&te?.patch&&H(ae);break}case"Fine Tune":if(P.fineTune){if(P.isFirstNoteOn){let ne=P.fineTune+$.value;P.keyShift+=Math.trunc(ne/100),P.fineTune=ne%100,h.info(`%cFine tuning already present on ${x}, new relative tune: %c${ne} cents`,d.info,d.recognized)}H(x)}return}P.clearedParams.pLSB=!0,P.clearedParams.pMSB=!0;return}default:return}}case G.systemExclusive:{let W=se.analyzeSysEx(m.data);switch(W.type){default:return;case"XG Reset":h.info("%cXG system on detected",d.info),l="xg",B=!0,C=D,I=O;for(let _ of b)_.param.reset(),_.clearedParams={pLSB:!0,pMSB:!0,data:!0};return;case"GM2 On":h.info("%cGM2 system on detected",d.info),l="gm2",B=!0,C=D,I=O;for(let _ of b)_.param.reset(),_.clearedParams={pLSB:!0,pMSB:!0,data:!0};return;case"GS Reset":h.info("%cGS on detected!",d.recognized),B=!0,C=D,I=O;for(let _ of b)_.param.reset(),_.clearedParams={pLSB:!0,pMSB:!0,data:!0};return;case"GM Off":case"GM On":h.info("%cGM on detected, removing!",d.info),Y(),B=!1;return;case"Drum Setup":o&&Y();return;case"Reverb Param":s&&Y();return;case"Chorus Param":n&&Y();return;case"Delay Param":a&&Y();return;case"Insertion Param":r&&Y();return;case"Program Change":g.get(W.channel+T)?.patch&&Y();return;case"Fine Tune":{let _=g.get(W.channel+T),$=b[W.channel+T];if($.isFirstNoteOn&&_){let ne=$.fineTune+W.value;$.keyShift+=Math.trunc(ne/100),$.fineTune=ne%100,h.info(`%cFine tuning already present on ${W.channel+T}, new relative tune: %c${ne} cents`,d.info,d.recognized),Y()}break}case"Controller Change":{let _=W.controller,$=g.get(W.channel+T);if($?.controllers?.get(_)!==void 0){Y();return}(_===f.bankSelect||_===f.bankSelectLSB)&&$?.patch&&Y();return}}}}}),!B&&[...g.values()].some(m=>m.patch&&m.patch!=="clear")){let m=0;t.tracks[0].events[0].statusByte===G.trackName&&m++,t.tracks[0].addEvents(m,se.gsReset(0)),C=0,I=m,h.info("%cGS on not detected. Adding it.",d.info)}let M=Math.max(0,t.firstNoteOn),S=t.tracks[C],Q=I+1;if(s&&s!=="clear"){let m=ta,D=s;S.addEvents(Q,se.gsMessage(M,64,1,m.level,[D.level]),se.gsMessage(M,64,1,m.preLowpass,[D.preLowpass]),se.gsMessage(M,64,1,m.character,[D.character]),se.gsMessage(M,64,1,m.time,[D.time]),se.gsMessage(M,64,1,m.delayFeedback,[D.delayFeedback]),se.gsMessage(M,64,1,m.preDelayTime,[D.preDelayTime]))}if(n&&n!=="clear"){let m=Aa,D=n;S.addEvents(Q,se.gsMessage(M,64,1,m.level,[D.level]),se.gsMessage(M,64,1,m.preLowpass,[D.preLowpass]),se.gsMessage(M,64,1,m.feedback,[D.feedback]),se.gsMessage(M,64,1,m.delay,[D.delay]),se.gsMessage(M,64,1,m.rate,[D.rate]),se.gsMessage(M,64,1,m.depth,[D.depth]),se.gsMessage(M,64,1,m.sendLevelToReverb,[D.sendLevelToReverb]),se.gsMessage(M,64,1,m.sendLevelToDelay,[D.sendLevelToDelay]))}if(a&&a!=="clear"){let m=sa,D=a;S.addEvents(Q,se.gsMessage(M,64,1,m.level,[D.level]),se.gsMessage(M,64,1,m.preLowpass,[D.preLowpass]),se.gsMessage(M,64,1,m.timeCenter,[D.timeCenter]),se.gsMessage(M,64,1,m.timeRatioLeft,[D.timeRatioLeft]),se.gsMessage(M,64,1,m.timeRatioRight,[D.timeRatioRight]),se.gsMessage(M,64,1,m.levelCenter,[D.levelCenter]),se.gsMessage(M,64,1,m.levelLeft,[D.levelLeft]),se.gsMessage(M,64,1,m.levelRight,[D.levelRight]),se.gsMessage(M,64,1,m.feedback,[D.feedback]),se.gsMessage(M,64,1,m.sendLevelToReverb,[D.sendLevelToReverb]))}if(r&&r!=="clear"){let m=r;for(let D=0;D<m.channels.length;D++)m.channels[D]&&S.addEvents(M,se.gsMessage(M,64,64|se.channelToSyx(D),34,[1]));for(let D=0;D<m.params.length;D++){let q=m.params[D];q!==255&&S.addEvents(Q,se.gsMessage(M,64,3,D+3,[q]))}S.addEvents(Q,se.gsMessage(M,64,3,0,[m.type>>8,m.type&127]))}t.flush(),h.groupEnd()}var RA=class An{name="";port=0;channels=new Set;events=[];static copyFrom(e){let A=new An;return A.copyFrom(e),A}copyFrom(e){this.name=e.name,this.port=e.port,this.channels=new Set(e.channels),this.events=e.events.map(A=>new We(A.ticks,A.statusByte,new ee(A.data)))}addEvent(e,A){this.events.splice(A,0,e)}addEvents(e,...A){this.events.splice(e,0,...A)}deleteEvent(e){this.events.splice(e,1)}pushEvent(e){this.events.push(e)}},aa={8:2,9:2,10:2,11:2,12:1,13:1,14:2};function Cs(t,e,A){h.groupCollapsed("%cParsing MIDI File...",d.info),t.fileName=A;let s=r=>{let o=Ee(r,4),i=Nt(r,4),g={type:o,size:i,data:new ee(i)},l=r.slice(r.currentIndex,r.currentIndex+g.size);return g.data.set(l,0),r.currentIndex+=g.size,g},n=s(e);if(n.type!=="MThd")throw h.groupEnd(),new SyntaxError(`Invalid MIDI Header! Expected "MThd", got "${n.type}"`);if(n.size!==6)throw h.groupEnd(),new RangeError(`Invalid MIDI header chunk size! Expected 6, got ${n.size}`);t.format=Nt(n.data,2);let a=Nt(n.data,2);t.timeDivision=Nt(n.data,2);for(let r=0;r<a;r++){let o=new RA,i=s(e);if(i.type!=="MTrk")throw h.groupEnd(),new SyntaxError(`Invalid track header! Expected "MTrk" got "${i.type}"`);let g,l=0;t.format===2&&r>0&&(l+=t.tracks[r-1].events[t.tracks[r-1].events.length-1].ticks);let B=i.data;for(;B.currentIndex<i.size;){l+=Qe(B);let C=B[B.currentIndex],I;if(g!==void 0&&C<128)I=g;else{if(C<128)throw h.groupEnd(),new SyntaxError(`Unexpected byte with no running byte. (${C})`);I=C,B.currentIndex++}let E;I>=G.noteOff&&I<G.systemExclusive?(E=aa[I>>4],g=I):I===G.systemExclusive?E=Qe(B):I===255?(I=B[B.currentIndex++],E=Qe(B)):E=0;let y=new ee(E);y.set(B.slice(B.currentIndex,B.currentIndex+E)),o.pushEvent(new We(l,I,y)),B.currentIndex+=E}t.tracks.push(o),h.info(`%cParsed %c${t.tracks.length}%c / %c${t.tracks.length}`,d.info,d.value,d.info,d.value)}h.info("%cAll tracks parsed correctly!",d.recognized),t.flush(!1),h.groupEnd()}function Bs(t){return t.toISOString().split(".")[0]+"Z"}var ra=[new Map([["domingo","Sunday"],["segunda-feira","Monday"],["ter\xE7a-feira","Tuesday"],["quarta-feira","Wednesday"],["quinta-feira","Thursday"],["sexta-feira","Friday"],["s\xE1bado","Saturday"],["janeiro","January"],["fevereiro","February"],["mar\xE7o","March"],["abril","April"],["maio","May"],["junho","June"],["julho","July"],["agosto","August"],["setembro","September"],["outubro","October"],["novembro","November"],["dezembro","December"]])];function ia(t){for(let e of ra){let A=t;for(let[n,a]of e.entries()){let r=new RegExp(n,"gi");A=A.replace(r,a)}let s=new Date(A);if(!Number.isNaN(s.getTime()))return s}}function oa(t){let e=/^(\d{2})\.(\d{2})\.(\d{4})$/.exec(t);if(e){let A=Number.parseInt(e[1]),s=Number.parseInt(e[2])-1,n=Number.parseInt(e[3]),a=new Date(n,s,A);if(!Number.isNaN(a.getTime()))return a}}function ga(t){let e=/^(\d{1,2})\s{1,2}(\d{1,2})\s{1,2}(\d{2})$/.exec(t);if(e){let A=e[1],s=(Number.parseInt(e[2])+1).toString(),n=e[3],a=new Date(`${s}/${A}/${n}`);if(!Number.isNaN(a.getTime()))return a}}function Ia(t){let e=/\b\d{4}\b/.exec(t);return e?new Date(e[0]):void 0}function Es(t){if(t=t.trim(),t.length===0)return new Date;let e=t.replaceAll(/\b(\d+)(st|nd|rd|th)\b/g,"$1").replace(/\s+at\s+/i," "),A=new Date(e);if(Number.isNaN(A.getTime())){let s=ia(t);if(s)return s;let n=oa(t);if(n)return n;let a=ga(t);if(a)return a;let r=Ia(t);return r||(h.warn(`Invalid date: "${t}". Replacing with the current date!`),new Date)}return A}function ca(t,e,A){e.currentIndex+=8;let s=Ee(e,4);if(s!=="RMID")throw h.groupEnd(),new SyntaxError(`Invalid RMIDI Header! Expected "RMID", got "${s}"`);let n=U.read(e);if(n.header!=="data")throw h.groupEnd(),new SyntaxError(`Invalid RMIDI Chunk header! Expected "data", got "${n.header}"`);let a=n.data,r=!1,o=!1;for(;e.currentIndex<e.length;){let i=e.currentIndex,g=U.read(e,!0);if(g.header==="RIFF"){let l=Ee(g.data,4).toLowerCase();l==="sfbk"||l==="sfpk"||l==="dls "?(h.info("%cFound embedded soundbank!",d.recognized),t.embeddedSoundBank=e.slice(i,i+g.size).buffer):h.warn(`Unknown RIFF chunk: "${l}"`),l==="dls "?t.isDLSRMIDI=!0:r=!0}else if(g.header==="LIST"&&Ee(g.data,4)==="INFO")for(h.info("%cFound RMIDI INFO chunk!",d.recognized);g.data.currentIndex<g.size;){let l=U.read(g.data,!0),B=l.header,C=l.data;switch(B){default:h.warn(`Unknown RMIDI Info: ${B}`);break;case"INAM":t.rmidiInfo.name=C;break;case"IALB":case"IPRD":t.rmidiInfo.album=C;break;case"ICRT":case"ICRD":t.rmidiInfo.creationDate=C;break;case"IART":t.rmidiInfo.artist=C;break;case"IGNR":t.rmidiInfo.genre=C;break;case"IPIC":t.rmidiInfo.picture=C;break;case"ICOP":t.rmidiInfo.copyright=C;break;case"ICMT":t.rmidiInfo.comment=C;break;case"IENG":t.rmidiInfo.engineer=C;break;case"ISFT":t.rmidiInfo.software=C;break;case"ISBJ":t.rmidiInfo.subject=C;break;case"IENC":t.rmidiInfo.infoEncoding=C;break;case"MENC":t.rmidiInfo.midiEncoding=C;break;case"DBNK":t.bankOffset=cs(C,2),o=!0;break}}}r&&!o&&(t.bankOffset=1),t.isDLSRMIDI&&(t.bankOffset=0),t.embeddedSoundBank===void 0&&(t.bankOffset=0),Cs(t,a,A)}var xA={XMFFileType:0,nodeName:1,nodeIDNumber:2,resourceFormat:3,filenameOnDisk:4,filenameExtensionOnDisk:5,macOSFileTypeAndCreator:6,mimeType:7,title:8,copyrightNotice:9,comment:10,autoStart:11,preload:12,contentDescription:13,ID3Metadata:14},vt={inLineResource:1,inFileResource:2,inFileNode:3,externalFile:4,externalXMF:5,XMFFileURIandNodeID:6},HA={StandardMIDIFile:0,StandardMIDIFileType1:1,DLS1:2,DLS2:3,DLS22:4,mobileDLS:5,unknown:-1,folder:-2},ha={standard:0,MMA:1,registered:2,nonRegistered:3},aA={none:0,MMAUnpacker:1,registered:2,nonRegistered:3},la=class sn{length;itemCount;metadataLength;metadata={};nodeData;innerNodes=[];packedContent=!1;nodeUnpackers=[];resourceFormat="unknown";referenceTypeID;constructor(e){let A=e.currentIndex;this.length=Qe(e),this.itemCount=Qe(e);let s=Qe(e),n=s-(e.currentIndex-A),a=e.slice(e.currentIndex,e.currentIndex+n);e.currentIndex+=n,this.metadataLength=Qe(a);let r=a.slice(a.currentIndex,a.currentIndex+this.metadataLength);a.currentIndex+=this.metadataLength;let o,i;for(;r.currentIndex<r.length;){r[r.currentIndex]===0?(r.currentIndex++,o=Qe(r),Object.values(xA).includes(o)?i=Object.keys(xA).find(I=>xA[I]===o)??"":(h.info(`Unknown field specifier: ${o}`),i=`unknown_${o}`)):(o=Ee(r,Qe(r)),i=o);let C=Qe(r);if(C===0){let I=Qe(r),E=r.slice(r.currentIndex,r.currentIndex+I);r.currentIndex+=I;let y=Qe(E);this.metadata[i]=y<4?Ee(E,I-1):E.slice(E.currentIndex)}else h.info(`International content: ${C}`),r.currentIndex+=Qe(r)}let g=a.currentIndex,l=Qe(a),B=a.slice(a.currentIndex,g+l);if(a.currentIndex=g+l,l>0)for(this.packedContent=!0;B.currentIndex<l;){let C={id:Qe(B)};switch(C.id){case aA.nonRegistered:case aA.registered:throw h.groupEnd(),new Error(`Unsupported unpacker ID: ${C.id}`);default:throw h.groupEnd(),new Error(`Unknown unpacker ID: ${C.id}`);case aA.none:C.standardID=Qe(B);break;case aA.MMAUnpacker:{let I=B[B.currentIndex++];I===0&&(I<<=8,I|=B[B.currentIndex++],I<<=8,I|=B[B.currentIndex++]);let E=Qe(B);C.manufacturerID=I,C.manufacturerInternalID=E}break}C.decodedSize=Qe(B),this.nodeUnpackers.push(C)}switch(e.currentIndex=A+s,this.referenceTypeID=Qe(e),this.nodeData=e.slice(e.currentIndex,A+this.length),e.currentIndex=A+this.length,this.referenceTypeID){case vt.inLineResource:break;case vt.externalXMF:case vt.inFileNode:case vt.XMFFileURIandNodeID:case vt.externalFile:case vt.inFileResource:throw h.groupEnd(),new Error(`Unsupported reference type: ${this.referenceTypeID}`);default:throw h.groupEnd(),new Error(`Unknown reference type: ${this.referenceTypeID}`)}if(this.isFile){if(this.packedContent){let I=this.nodeData.slice(2);h.info(`%cPacked content. Attempting to deflate. Target size: %c${this.nodeUnpackers[0].decodedSize}`,d.warn,d.value);try{this.nodeData=new ee(js(I).buffer)}catch(E){if(h.groupEnd(),E instanceof Error)throw new Error(`Error unpacking XMF file contents: ${E.message}.`,{cause:E})}}let C=this.metadata.resourceFormat;if(C===void 0)h.warn("No resource format for this file node!");else{C[0]!==ha.standard&&(h.info(`Non-standard formatTypeID: ${C.toString()}`),this.resourceFormat=C.toString());let I=C[1];Object.values(HA).includes(I)?this.resourceFormat=Object.keys(HA).find(E=>HA[E]===I):h.info(`Unrecognized resource format: ${I}`)}}else for(this.resourceFormat="folder";this.nodeData.currentIndex<this.nodeData.length;){let C=this.nodeData.currentIndex,I=Qe(this.nodeData),E=this.nodeData.slice(C,C+I);this.nodeData.currentIndex=C+I,this.innerNodes.push(new sn(E))}}get isFile(){return this.itemCount===0}};function Ca(t,e,A){t.bankOffset=0;let s=Ee(e,4);if(s!=="XMF_")throw h.groupEnd(),new SyntaxError(`Invalid XMF Header! Expected "_XMF", got "${s}"`);h.group("%cParsing XMF file...",d.info);let n=Ee(e,4);if(h.info(`%cXMF version: %c${n}`,d.info,d.recognized),n==="2.00"){let g=Nt(e,4),l=Nt(e,4);h.info(`%cFile Type ID: %c${g}%c, File Type Revision ID: %c${l}`,d.info,d.recognized,d.info,d.recognized)}Qe(e);let a=Qe(e);e.currentIndex+=a,e.currentIndex=Qe(e);let r=new la(e),o,i=g=>{let l=(B,C)=>{g.metadata[B]!==void 0&&typeof g.metadata[B]=="string"&&(t.rmidiInfo[C]=$e(g.metadata[B]))};if(l("nodeName","name"),l("title","name"),l("copyrightNotice","copyright"),l("comment","comment"),g.isFile)switch(g.resourceFormat){default:return;case"DLS1":case"DLS2":case"DLS22":case"mobileDLS":h.info("%cFound embedded DLS!",d.recognized),t.embeddedSoundBank=g.nodeData.buffer;break;case"StandardMIDIFile":case"StandardMIDIFileType1":h.info("%cFound embedded MIDI!",d.recognized),o=g.nodeData;break}else for(let B of g.innerNodes)i(B)};if(i(r),h.groupEnd(),!o)throw new Error("No MIDI data in the XMF file!");Cs(t,o,A)}function Ba(t,e){let A=new Map,s=e.systemParameters.keyShift,n=e.systemParameters.fineTune;for(let a=0;a<e.midiChannels.length;a++){let r=e.midiChannels[a];if(r.systemParameters.isMuted){A.set(a,"clear");continue}let o=r.systemParameters.keyShift+(r.drumChannel?0:s),i=r.systemParameters.fineTune+(r.drumChannel?0:n),g;r.systemParameters.presetLock&&r.patch&&(g={...r.patch});let l=new Map;for(let B=0;B<128;B++){if(!r.lockedControllers[B]||B===f.bankSelect)continue;let C=r.midiControllers[B]>>7;l.set(B,C)}A.set(a,{keyShift:o,fineTune:i,patch:g,controllers:l})}t.modify({channels:A,drumSetupParams:e.systemParameters.drumLock?"clear":void 0,reverbParams:e.systemParameters.reverbLock?e.reverbProcessor:void 0,chorusParams:e.systemParameters.chorusLock?e.chorusProcessor:void 0,delayParams:e.systemParameters.delayLock?e.delayProcessor:void 0,insertionParams:e.systemParameters.insertionEffectLock?e.insertionProcessor:void 0})}var Dt=class jA{tracks=[];timeline=[];timeDivision=480;duration=0;tempoChanges=[{ticks:0,tempo:120}];extraMetadata=[];lyrics=[];firstNoteOn=0;keyRange={min:0,max:127};lastVoiceEventTick=0;portChannelOffsetMap=[0];loop={start:0,end:0,type:"hard"};fileName;format=0;rmidiInfo={};bankOffset=0;isKaraokeFile=!1;isMultiPort=!1;isDLSRMIDI=!1;embeddedSoundBank;binaryName;get infoEncoding(){let e=this.rmidiInfo.infoEncoding;if(!e)return;let A=e.byteLength;return e[e.byteLength-1]===0&&A--,_e(e,A)}static fromArrayBuffer(e,A=""){let s=new jA,n=new ee(e);switch(_e(n,4)){case"RIFF":ca(s,n,A);break;case"XMF_":Ca(s,n,A);break;default:Cs(s,n,A);break}return s}static async fromFile(e){return this.fromArrayBuffer(await e.arrayBuffer(),e.name)}static copyFrom(e){let A=new jA;return A.copyFrom(e),A}copyFrom(e){this.copyMetadataFrom(e),this.embeddedSoundBank=e?.embeddedSoundBank?.slice(0)??void 0,this.tracks=e.tracks.map(A=>RA.copyFrom(A)),this.timeline=e.timeline.map(A=>({...A}))}midiTicksToSeconds(e){if(e=Math.max(e,0),this.tempoChanges.length===0)throw new Error("There are no tempo changes in the sequence. At least one is needed.");if(this.tempoChanges[this.tempoChanges.length-1].ticks!==0)throw new Error(`The last tempo change is not at 0 ticks. Got ${this.tempoChanges[this.tempoChanges.length-1].ticks} ticks.`);let A=this.tempoChanges.findIndex(n=>n.ticks<=e),s=0;for(;A<this.tempoChanges.length;){let n=this.tempoChanges[A++],a=e-n.ticks;s+=a*60/(n.tempo*this.timeDivision),e=n.ticks}return s}secondsToMIDITicks(e){if(e=Math.max(e,0),e===0)return 0;if(this.tempoChanges.length===0)throw new Error("There are no tempo changes in the sequence. At least one is needed.");if(this.tempoChanges[this.tempoChanges.length-1].ticks!==0)throw new Error(`The last tempo change is not at 0 ticks. Got ${this.tempoChanges[this.tempoChanges.length-1].ticks} ticks.`);let A=e,s=0;for(let n=this.tempoChanges.length-1;n>=0;n--){let a=this.tempoChanges[n],r=this.tempoChanges[n-1],o=r?r.ticks-a.ticks:1/0,i=60/(a.tempo*this.timeDivision),g=o*i;if(A<=g)return s+=Math.round(A/i),s;s+=o,A-=g}return s}getUsedProgramsAndKeys(e){return $n(this,e)}preloadSynth(e){h.groupCollapsed("%cPreloading samples...",d.info);let A=this.getUsedProgramsAndKeys(e.soundBankManager);for(let[s,n]of A.entries()){h.info(`%cPreloading used samples on %c${s.name}%c...`,d.info,d.recognized,d.info);for(let[a,r]of n.entries())for(let o of r)e.getVoicesForPreset(s,a,o)}h.groupEnd()}flush(e=!0){if(e)for(let A of this.tracks)A.events.sort((s,n)=>s.ticks-n.ticks);this.parseInternal()}getNoteTimes(e=0){return ea(this,e)}writeMIDI(){return qn(this)}writeRMIDI(e,A=Rs){return zn(this,e,bA(A,Rs))}modify(e){na(this,e)}applySnapshot(e){Ba(this,e)}getName(e="Shift_JIS"){let A="",s=this.getRMIDInfo("name");if(s)return s.trim();if(this.binaryName){e=this.getRMIDInfo("midiEncoding")??e;try{A=new TextDecoder(e).decode(this.binaryName).trim()}catch(n){h.warn(`Failed to decode MIDI name: ${n}`)}}return A||this.fileName}getExtraMetadata(e="Shift_JIS"){e=this.infoEncoding??e;let A=new TextDecoder(e);return this.extraMetadata.map(s=>A.decode(s.data).replaceAll(/@T|@A/g,"").trim())}setRMIDInfo(e,A){if(this.rmidiInfo.infoEncoding=$e("utf-8",!0),e==="picture")this.rmidiInfo.picture=new Uint8Array(A);else if(e==="creationDate")this.rmidiInfo.creationDate=$e(Bs(A),!0);else{let s=new TextEncoder().encode(A);this.rmidiInfo[e]=new Uint8Array([...s,0])}}getRMIDInfo(e){if(!this.rmidiInfo[e])return;let A=this.infoEncoding??"UTF-8";if(e==="picture")return this.rmidiInfo[e].buffer;if(e==="creationDate")return Es(_e(this.rmidiInfo[e]));try{let s=new TextDecoder(A),n=this.rmidiInfo[e];return n[n.length-1]===0&&(n=n?.slice(0,-1)),s.decode(n.buffer).trim()}catch(s){h.warn(`Failed to decode ${e} name: ${s}`);return}}iterate(e){let A=new Array(this.tracks.length).fill(0),s=this.tracks.length;for(;s>0;){let n=0,a=1/0;for(let i=0;i<this.tracks.length;i++){let g=this.tracks[i].events;A[i]>=g.length||g[A[i]].ticks<a&&(n=i,a=g[A[i]].ticks)}let r=this.tracks[n].events;if(A[n]>=r.length){s--;continue}let o=A[n];e(r[o],n,A),A[n]++}}copyMetadataFrom(e){this.fileName=e.fileName,this.timeDivision=e.timeDivision,this.duration=e.duration,this.firstNoteOn=e.firstNoteOn,this.lastVoiceEventTick=e.lastVoiceEventTick,this.format=e.format,this.bankOffset=e.bankOffset,this.isKaraokeFile=e.isKaraokeFile,this.isMultiPort=e.isMultiPort,this.isDLSRMIDI=e.isDLSRMIDI,this.isDLSRMIDI=e.isDLSRMIDI,this.tempoChanges=[...e.tempoChanges],this.extraMetadata=e.extraMetadata.map(A=>new We(A.ticks,A.statusByte,new ee(A.data))),this.lyrics=e.lyrics.map(A=>new We(A.ticks,A.statusByte,new ee(A.data))),this.portChannelOffsetMap=[...e.portChannelOffsetMap],this.binaryName=e?.binaryName?.slice(),this.loop={...e.loop},this.keyRange={...e.keyRange},this.rmidiInfo={};for(let A of Object.entries(e.rmidiInfo)){let s=A[0],n=A[1];this.rmidiInfo[s]=new Uint8Array(n)}}parseInternal(){h.group("%cInterpreting MIDI events...",d.info);let e=!1;this.tempoChanges=[{ticks:0,tempo:120}],this.extraMetadata=[],this.lyrics=[],this.firstNoteOn=0,this.keyRange={max:0,min:127},this.lastVoiceEventTick=0,this.portChannelOffsetMap=[0],this.loop={start:0,end:0,type:"hard"},this.isKaraokeFile=!1,this.isMultiPort=!1;let A=!1;this.rmidiInfo.name!==void 0&&(A=!0);let s=null,n=null,a="hard";for(let g of this.tracks){let l=new Set,B=!1;for(let I=0;I<g.events.length;I++){let E=g.events[I];if(E.statusByte>=128&&E.statusByte<240)switch(B=!0,E.ticks>this.lastVoiceEventTick&&(this.lastVoiceEventTick=E.ticks),E.statusByte&240){case G.controllerChange:switch(E.data[0]){case 2:case 111:E.data[1]===0&&(s=E.ticks);break;case 116:s=E.ticks;break;case 4:case 117:n===null&&(E.data[0]!==4||E.data[0]===4&&E.data[1]===0)?(a="soft",n=E.ticks):(n=0,a="hard");break;case 0:this.isDLSRMIDI&&E.data[1]!==0&&E.data[1]!==127&&(h.info("%cDLS RMIDI with offset 1 detected!",d.recognized),this.bankOffset=1)}break;case G.noteOn:{l.add(E.statusByte&15);let k=E.data[0];this.keyRange.min=Math.min(this.keyRange.min,k),this.keyRange.max=Math.max(this.keyRange.max,k);break}}let y=_e(E.data);switch(E.statusByte){case G.endOfTrack:I!==g.events.length-1&&(g.deleteEvent(I),I--,h.warn("Unexpected EndOfTrack. Removing!"));break;case G.setTempo:this.tempoChanges.push({ticks:E.ticks,tempo:6e7/xt(E.data,3)});break;case G.marker:switch(y.trim().toLowerCase()){default:break;case"start":case"loopstart":s=E.ticks;break;case"loopend":n=E.ticks}break;case G.copyright:this.extraMetadata.push(E);break;case G.lyric:y.trim().startsWith("@KMIDI KARAOKE FILE")&&(this.isKaraokeFile=!0,h.info("%cKaraoke MIDI detected!",d.recognized)),this.isKaraokeFile?E.statusByte=G.text:this.lyrics.push(E);case G.text:{let k=y.trim();k.startsWith("@KMIDI KARAOKE FILE")?(this.isKaraokeFile=!0,h.info("%cKaraoke MIDI detected!",d.recognized)):this.isKaraokeFile&&(k.startsWith("@T")||k.startsWith("@A")?e?this.extraMetadata.push(E):(this.binaryName=E.data.slice(2),e=!0,A=!0):k.startsWith("@")||this.lyrics.push(E));break}}}g.channels=l,g.name="";let C=g.events.find(I=>I.statusByte===G.trackName);C&&this.tracks.indexOf(g)>0&&(g.name=_e(C.data),!B&&!g.name.toLowerCase().includes("setup")&&this.extraMetadata.push(C))}this.tempoChanges.reverse(),h.info("%cCorrecting loops, ports and detecting notes...",d.info);let r=[];for(let g of this.tracks){let l=g.events.find(B=>(B.statusByte&240)===G.noteOn);l&&r.push(l.ticks)}this.firstNoteOn=Math.min(...r),h.info(`%cFirst note-on detected at: %c${this.firstNoteOn}%c ticks!`,d.info,d.recognized,d.info),s??=this.firstNoteOn,(n===null||n===0)&&(n=this.lastVoiceEventTick),this.loop={start:s,end:n,type:a},this.lastVoiceEventTick=Math.max(this.lastVoiceEventTick,this.loop.end),h.info(`%cLoop points: start: %c${this.loop.start}%c end: %c${this.loop.end}`,d.info,d.recognized,d.info,d.recognized);let o=0;this.portChannelOffsetMap=[];for(let g of this.tracks)if(g.port=-1,g.channels.size!==0)for(let l of g.events){if(l.statusByte!==G.midiPort)continue;let B=l.data[0];g.port=B,this.portChannelOffsetMap[B]===void 0&&(this.portChannelOffsetMap[B]=o,o+=16)}this.portChannelOffsetMap=[...this.portChannelOffsetMap].map(g=>g??0);let i=1/0;for(let g of this.tracks)g.port!==-1&&i>g.port&&(i=g.port);i===1/0&&(i=0);for(let g of this.tracks)(g.port===-1||g.port===void 0)&&(g.port=i);if(this.portChannelOffsetMap.length===0&&(this.portChannelOffsetMap=[0]),this.portChannelOffsetMap.length<2?h.info("%cNo additional MIDI Ports detected.",d.info):(this.isMultiPort=!0,h.info("%cMIDI Ports detected!",d.recognized)),!A)if(this.tracks.length>1){if(!this.tracks[0].events.some(g=>g.statusByte>=G.noteOn&&g.statusByte<G.polyPressure)){let g=this.tracks[0].events.find(l=>l.statusByte===G.trackName);g&&(this.binaryName=g.data)}}else{let g=this.tracks[0].events.find(l=>l.statusByte===G.trackName);g&&(this.binaryName=g.data)}if(this.extraMetadata=this.extraMetadata.filter(g=>g.data.length>0),this.lyrics.sort((g,l)=>g.ticks-l.ticks),!this.tracks.some(g=>g.events[0].ticks===0)){let g=this.tracks[0],l=this?.binaryName?.buffer;l||(l=new Uint8Array(0).buffer),g.addEvents(0,new We(0,G.trackName,new ee(l)))}this.duration=this.midiTicksToSeconds(this.lastVoiceEventTick),this.timeline.length=0,this.iterate((g,l,B)=>{this.timeline.push(Object.freeze({ev:B[l],tr:l}))}),this.binaryName?.length===0&&(this.binaryName=void 0),h.info(`%cMIDI file parsed. Total tick time: %c${this.lastVoiceEventTick}%c, total seconds time: %c${_A(Math.ceil(this.duration)).time}`,d.info,d.recognized,d.info,d.recognized),h.groupEnd()}};function Ea(t,e){if(this.externalMIDIPlayback&&t.statusByte>=128){this.sendMIDIMessage([t.statusByte,...t.data]);return}let A=this._midiData.tracks[e],s,n=0;t.statusByte>=128&&t.statusByte<240?(s=t.statusByte&240,n=t.statusByte&15):s=t.statusByte;let a=this.midiPortChannelOffsets[this.currentMIDIPorts[e]]||0;switch(n+=a,s){case G.noteOn:{let r=t.data[1];r>0?(this.synth.noteOn(n,t.data[0],r),this.playingNotes[n].set(t.data[0],r)):(this.synth.noteOff(n,t.data[0]),this.playingNotes[n].delete(t.data[0]));break}case G.noteOff:this.synth.noteOff(n,t.data[0]),this.playingNotes[n].delete(t.data[0]);break;case G.pitchWheel:this.synth.pitchWheel(n,t.data[1]<<7|t.data[0]);break;case G.controllerChange:if(this._midiData.isMultiPort&&A.channels.size===0)return;this.synth.controllerChange(n,t.data[0],t.data[1]);break;case G.programChange:if(this._midiData.isMultiPort&&A.channels.size===0)return;this.synth.programChange(n,t.data[0]);break;case G.polyPressure:this.synth.polyPressure(n,t.data[0],t.data[1]);break;case G.channelPressure:this.synth.channelPressure(n,t.data[0]);break;case G.systemExclusive:this.synth.systemExclusive(t.data,a);break;case G.setTempo:{let r=6e7/xt(t.data,3);this.oneTickToSeconds=60/(r*this._midiData.timeDivision),this.oneTickToSeconds===0&&(this.oneTickToSeconds=60/(120*this._midiData.timeDivision),h.info("invalid tempo! falling back to 120 BPM"));break}case G.timeSignature:case G.endOfTrack:case G.midiChannelPrefix:case G.songPosition:case G.activeSensing:case G.keySignature:case G.sequenceNumber:case G.sequenceSpecific:case G.text:case G.lyric:case G.copyright:case G.trackName:case G.marker:case G.cuePoint:case G.instrumentName:case G.programName:break;case G.midiPort:this.assignMIDIPort(e,t.data[0]);break;case G.reset:this.synth.stopAllChannels(),this.synth.reset();break;default:h.info(`%cUnrecognized Event: %c${t.statusByte}%c status byte: %c${Object.keys(G).find(r=>G[r]===s)}`,d.warn,d.unrecognized,d.warn,d.value);break}s>=0&&s<128&&this.callEvent("metaEvent",{event:t,trackIndex:e})}function da(){if(this.paused||!this._midiData)return;let t=this.currentTime;for(;this.playedTime<t;){let{timeline:e,tracks:A,lastVoiceEventTick:s,loop:n}=this._midiData,a=e[this.index++],r=A[a.tr].events[a.ev];if(this.processEvent(r,a.tr),this.loopCount>0&&n.end<=r.ticks){this.loopCount!==1/0&&(this.loopCount--,this.callEvent("loopCountChange",{newCount:this.loopCount})),n.type==="soft"?this.jumpToTick(n.start):this.setTimeTicks(n.start);return}if(this.index>=e.length||r.ticks>=s){this.songIsFinished();return}let o=e[this.index],i=A[o.tr].events[o.ev];this.playedTime+=this.oneTickToSeconds*(i.ticks-r.ticks)}}function fa(t,e){this._midiData.tracks[t].channels.size!==0&&(this.midiPortChannelOffset===0&&(this.midiPortChannelOffset+=16,this.midiPortChannelOffsets[e]=0),this.midiPortChannelOffsets[e]===void 0&&(this.synth.midiChannels.length<this.midiPortChannelOffset+15&&this.addNewMIDIPort(),this.midiPortChannelOffsets[e]=this.midiPortChannelOffset,this.midiPortChannelOffset+=16),this.currentMIDIPorts[t]=e)}function Qa(t){if(!t.tracks)throw new Error("This MIDI has no tracks!");if(t.duration===0){h.warn("This MIDI file has a duration of exactly 0 seconds."),this.pausedTime=0,this.isFinished=!0;return}this.oneTickToSeconds=60/(120*t.timeDivision),this._midiData=t,this.isFinished=!1,this.synth.clearEmbeddedSoundBank(),this._midiData.embeddedSoundBank!==void 0&&(h.info("%cEmbedded soundbank detected! Using it.",d.recognized),this.synth.setEmbeddedSoundBank(this._midiData.embeddedSoundBank,this._midiData.bankOffset),this.preload&&this._midiData.preloadSynth(this.synth)),this.currentMIDIPorts=this._midiData.tracks.map(e=>e.port),this.midiPortChannelOffset=0,this.midiPortChannelOffsets={};for(let[e,A]of this._midiData.tracks.entries())this.assignMIDIPort(e,A.port);this.firstNoteTime=this._midiData.midiTicksToSeconds(this._midiData.firstNoteOn),h.info(`%cTotal song time: ${_A(Math.ceil(this._midiData.duration)).time}`,d.recognized),this.callEvent("songChange",{songIndex:this._songIndex}),this._midiData.duration<=.2&&(h.warn(`%cVery short song: (${_A(Math.round(this._midiData.duration)).time}). Disabling loop!`,d.warn),this.loopCount=0),this.currentTime=0}function ua(){this.lastNote=this.channelSystem==="xg"?60:-1}var mt=new Int16Array(128).fill(0),Me=(t,e)=>mt[t]=e<<7;Me(f.mainVolume,100);Me(f.balance,64);Me(f.expression,127);Me(f.pan,64);Me(f.filterResonance,64);Me(f.releaseTime,64);Me(f.attackTime,64);Me(f.brightness,64);Me(f.decayTime,64);Me(f.vibratoRate,64);Me(f.vibratoDepth,64);Me(f.vibratoDelay,64);Me(f.generalPurposeController6,64);Me(f.generalPurposeController8,64);Me(f.registeredParameterLSB,127);Me(f.registeredParameterMSB,127);Me(f.nonRegisteredParameterLSB,0);Me(f.nonRegisteredParameterMSB,0);var uA=new Int8Array(128).fill(127);uA[35]=0;uA[36]=0;function ma(t=!0){for(let e=0;e<128;e++){if(this.lockedControllers[e]){this.synthCore.callEvent("controllerChange",{channel:this.channel,controller:e,value:this._midiControllers[e]>>7});continue}let A=mt[e];this._midiControllers[e]!==A&&e!==f.portamentoControl&&e!==f.dataEntryMSB&&e!==f.registeredParameterMSB&&e!==f.registeredParameterLSB&&e!==f.nonRegisteredParameterMSB&&e!==f.nonRegisteredParameterLSB&&this.controllerChange(e,A>>7,t)}this.synthCore.systemParameters.insertionEffectLock||this.setMIDIParameter("efxAssign",!1),this.setMIDIParameter("rxChannel",this.channel),this.setMIDIParameter("assignMode",2),this.setMIDIParameter("randomPan",!1),this.setMIDIParameter("cc1",16),this.setMIDIParameter("cc2",17),this.setMIDIParameter("drumMap",this.channel%16===9?1:0),this.pitchWheel(8192),this.pitchWheelRange(2,!1),this.keyShift(0,!1),this.fineTune(0,!1),this.setMIDIParameter("pressure",0),this.modulationDepth(50,!1),!this.lockedControllers[f.monoModeOn]&&!this.lockedControllers[f.polyModeOn]&&this.setMIDIParameter("polyMode",!0),this.octaveTuning.fill(0),ua.call(this),this.resetDrumParams(),this.resetGeneratorOverrides(),this.resetGeneratorOffsets(),this.dynamicModulators.resetModulators(),this.sf2NRPNGeneratorLSB=0,this.lastParameterIsRegistered=!0,this._midiControllers[f.nonRegisteredParameterLSB]=0,this._midiControllers[f.nonRegisteredParameterMSB]=0,this._midiControllers[f.registeredParameterLSB]=16256,this._midiControllers[f.registeredParameterMSB]=16256,this._midiControllers[f.dataEntryMSB]=0,this._midiControllers[f.dataEntryLSB]=0,this.setBankMSB(Se.getDefaultBank(this.channelSystem)),this.setBankLSB(0),this.setGSDrums(!1),this.setDrums(this.channel%16===9),this.programChange(0)}var nn=[f.modulationWheel,f.expression,f.sustainPedal,f.portamentoOnOff,f.sostenutoPedal,f.softPedal,f.registeredParameterMSB,f.registeredParameterLSB];function pa(){this.pitchWheel(8192),this.setMIDIParameter("pressure",0);for(let t of nn){let e=mt[t];e!==this._midiControllers[t]&&this.controllerChange(t,e>>7)}}var rA=new Set([f.dataDecrement,f.dataIncrement,f.dataEntryMSB,f.dataEntryLSB,f.registeredParameterLSB,f.registeredParameterMSB,f.nonRegisteredParameterLSB,f.nonRegisteredParameterMSB,f.bankSelect,f.bankSelectLSB,f.resetAllControllers,f.monoModeOn,f.polyModeOn]);function ya(t,e=void 0){if(!this._midiData)return!1;this.oneTickToSeconds=60/(120*this._midiData.timeDivision),this.sendMIDIReset(),this.playedTime=0,this.index=0;let A=this.synth.midiChannels.length,s=[];for(let g=0;g<A;g++)s.push({pitchWheel:8192,controllers:new Int16Array(mt),param:new QA(g),portamentoNote:-1});let n,a=0;function r(g){let l=s[g];l.pitchWheel=8192,l.param.reset();for(let B of nn)l.controllers[B]=mt[B]}let{timeline:o,tracks:i}=this._midiData;for(;;){let g=o[this.index],l=g.tr,B=i[l],C=B.events[g.ev];if(e===void 0){if(this.playedTime>=t)break}else if(C.ticks>=e)break;let I,E=0;C.statusByte>=128&&C.statusByte<240?(I=C.statusByte&240,E=C.statusByte&15):I=C.statusByte;let y=E+(this.midiPortChannelOffsets[B.port]||0);s[y]??={pitchWheel:8192,controllers:new Int16Array(mt),param:new QA(y),portamentoNote:-1};let k=s[y];switch(I){case G.noteOn:k.portamentoNote=C.data[0];break;case G.noteOff:break;case G.pitchWheel:k.pitchWheel=C.data[1]<<7|C.data[0];break;case G.systemExclusive:{let b=se.analyzeSysEx(C.data);switch(b.type){default:this.processEvent(C,l);break;case"Controller Change":{let{controller:M,value:S,channel:Q}=b;if(this._midiData.isMultiPort&&B.channels.size===0)break;if(M===f.resetAllControllers){r(Q);break}rA.has(M)?this.sendMIDICC(Q,M,S):s[Q].controllers[M]=S<<7}}break}case G.controllerChange:{if(this._midiData.isMultiPort&&B.channels.size===0)break;let b=C.data[0],M=C.data[1];switch(b){default:if(b===f.resetAllControllers){r(y);break}rA.has(b)?this.sendMIDICC(y,b,M):k.controllers[b]=M<<7;break;case f.registeredParameterMSB:case f.registeredParameterLSB:case f.nonRegisteredParameterLSB:case f.nonRegisteredParameterMSB:k.param.controllerChange(b,M,0,0),this.sendMIDICC(y,b,M);break;case f.dataEntryMSB:case f.dataEntryLSB:{let S=k.param.controllerChange(b,M,0,0);this.sendMIDICC(y,b,M),S.type==="Controller Change"&&(rA.has(S.controller)?this.sendMIDICC(y,S.controller,S.value):k.controllers[S.controller]=S.value<<7);break}}break}case G.setTempo:{let b=6e7/xt(C.data,3);this.oneTickToSeconds=60/(b*this._midiData.timeDivision),n=C,a=l;break}default:this.processEvent(C,l);break}let p=o[++this.index],R=i[p.tr].events[p.ev];if(R===void 0)return this.stop(),!1;this.playedTime+=this.oneTickToSeconds*(R.ticks-C.ticks)}for(let g=0;g<A;g++){let l=s[g];this.sendMIDIPitchWheel(g,l.pitchWheel),l.portamentoNote>=0&&(this.externalMIDIPlayback?this.sendMIDICC(g,f.portamentoControl,l.portamentoNote):this.synth.midiChannels[g].setLastNote(l.portamentoNote));for(let B=0;B<128;B++){let C=l.controllers[B]>>7;C!==mt[B]&&!rA.has(B)&&this.sendMIDICC(g,B,C)}}return n&&this.callEvent("metaEvent",{event:n,trackIndex:a}),this.paused&&(this.pausedTime=this.playedTime),!0}var an=class{songs=[];shuffledSongIndexes=[];synth;externalMIDIPlayback=!1;retriggerPausedNotes=!0;loopCount=0;skipToFirstNoteOn=!0;isFinished=!1;preload=!0;onEventCall;processTick=da.bind(this);firstNoteTime=0;oneTickToSeconds=0;index=0;playedTime=0;pausedTime=-1;absoluteStartTime=0;playingNotes=[];currentMIDIPorts=[];midiPortChannelOffset=0;midiPortChannelOffsets={};assignMIDIPort=fa.bind(this);loadNewSequence=Qa.bind(this);processEvent=Ea.bind(this);setTimeTo=ya.bind(this);constructor(t){this.synth=t,this.absoluteStartTime=this.synth.currentTime;for(let e=0;e<16;e++)this.playingNotes.push(new Map)}_midiData;get midiData(){return this._midiData}get duration(){return this._midiData?.duration??0}_songIndex=0;get songIndex(){return this._songIndex}set songIndex(t){this._songIndex=t,this._songIndex=Math.max(0,t%this.songs.length),this.loadCurrentSong()}_shuffleMode=!1;get shuffleMode(){return this._shuffleMode}set shuffleMode(t){this._shuffleMode=t}_playbackRate=1;get playbackRate(){return this._playbackRate}set playbackRate(t){let e=this.currentTime;this._playbackRate=t,this.recalculateStartTime(e)}get currentTime(){return this.pausedTime!==void 0?this.pausedTime:(this.synth.currentTime-this.absoluteStartTime)*this._playbackRate}set currentTime(t){if(this._midiData)if(this.paused&&(this.pausedTime=t),t>this._midiData.duration||t<0)this.skipToFirstNoteOn?this.setTimeTicks(this._midiData.firstNoteOn-1):this.setTimeTicks(0);else if(this.skipToFirstNoteOn&&t<this.firstNoteTime){this.setTimeTicks(this._midiData.firstNoteOn-1);return}else{for(let e of this.playingNotes)e.clear();this.callEvent("timeChange",{newTime:t}),this.setTimeTo(t),this.recalculateStartTime(t)}}get paused(){return this.pausedTime!==void 0}play(){if(!this._midiData){h.warn("No songs loaded in the sequencer. Ignoring the play call.");return}if(this.currentTime>=this._midiData.duration&&(this.currentTime=0),this.paused&&this.recalculateStartTime(this.pausedTime??0),this.retriggerPausedNotes&&!this.externalMIDIPlayback)for(let t=0;t<this.playingNotes.length;t++){let e=this.playingNotes[t];for(let[A,s]of e)this.sendMIDINoteOn(t,A,s)}this.pausedTime=void 0}pause(){this.pauseInternal(!1)}loadNewSongList(t){if(this.songs=t,this.songs.length!==0){if(this._songIndex=0,this.shuffleSongIndexes(),this.callEvent("songListChange",{newSongList:[...this.songs]}),this.preload){h.group("%cPreloading all songs...",d.info);for(let e of this.songs)e.embeddedSoundBank===void 0&&e.preloadSynth(this.synth);h.groupEnd()}this.loadCurrentSong()}}callEvent(t,e){this?.onEventCall?.({type:t,data:e})}pauseInternal(t){this.paused||(this.stop(),this.callEvent("pause",{isFinished:t}),t&&this.callEvent("songEnded",{}))}songIsFinished(){if(this.isFinished=!0,this.songs.length===1){this.pauseInternal(!0);return}this._songIndex++,this._songIndex%=this.songs.length,this.loadCurrentSong()}stop(){this.pausedTime=this.currentTime,this.sendMIDIAllOff()}addNewMIDIPort(){for(let t=0;t<16;t++)this.synth.createMIDIChannel(),this.playingNotes.push(new Map)}sendMIDIMessage(t){if(!this.externalMIDIPlayback){h.warn(`Attempting to send ${zs(t)} to the synthesizer via sendMIDIMessage. This shouldn't happen!`);return}this.callEvent("midiMessage",{message:t,time:this.synth.currentTime})}sendMIDIAllOff(){for(let t=0;t<16;t++)this.sendMIDICC(t,f.sustainPedal,0);if(!this.externalMIDIPlayback){this.synth.stopAllChannels();return}for(let t=0;t<this.playingNotes.length;t++){let e=this.playingNotes[t];for(let A of e.keys())this.sendMIDINoteOff(t,A)}for(let t=0;t<16;t++)this.sendMIDICC(t,f.allNotesOff,0)}sendMIDIReset(){if(this.sendMIDIAllOff(),!this.externalMIDIPlayback){this.synth.reset();return}this.sendMIDISysEx(se.gsData(64,0,127,[0]))}loadCurrentSong(){let t=this._songIndex;this._shuffleMode&&(t=this.shuffledSongIndexes[this._songIndex]),this.loadNewSequence(this.songs[t])}shuffleSongIndexes(){let t=this.songs.map((e,A)=>A);for(this.shuffledSongIndexes.length=0;t.length>0;){let e=t[Math.floor(Math.random()*t.length)];this.shuffledSongIndexes.push(e),t.splice(t.indexOf(e),1)}}setTimeTicks(t){if(!this._midiData)return;for(let s of this.playingNotes)s.clear();let e=this._midiData.midiTicksToSeconds(t);this.callEvent("timeChange",{newTime:e});let A=this.setTimeTo(0,t);this.recalculateStartTime(this.playedTime)}recalculateStartTime(t){this.absoluteStartTime=this.synth.currentTime-t/this._playbackRate}jumpToTick(t){if(!this._midiData)return;this.sendMIDIAllOff();let e=this._midiData,A=e.midiTicksToSeconds(t);this.callEvent("timeChange",{newTime:A}),this.recalculateStartTime(A),this.playedTime=A;let s=e.timeline.findIndex(a=>e.tracks[a.tr].events[a.ev].ticks>=t);this.index=s===-1?e.timeline.length:s;let n=e.tempoChanges.find(a=>a.ticks<=t);this.oneTickToSeconds=60/(n.tempo*e.timeDivision)}sendMIDINoteOn(t,e,A){if(!this.externalMIDIPlayback){this.synth.noteOn(t,e,A);return}t%=16,this.sendMIDIMessage([G.noteOn|t,e,A])}sendMIDINoteOff(t,e){if(!this.externalMIDIPlayback){this.synth.noteOff(t,e);return}t%=16,this.sendMIDIMessage([G.noteOff|t,e,64])}sendMIDICC(t,e,A){if(!this.externalMIDIPlayback){this.synth.controllerChange(t,e,A);return}t%=16,this.sendMIDIMessage([G.controllerChange|t,e,A])}sendMIDISysEx(t){if(!this.externalMIDIPlayback){this.synth.systemExclusive(t);return}this.sendMIDIMessage([G.systemExclusive,...t])}sendMIDIPitchWheel(t,e){if(!this.externalMIDIPlayback){this.synth.pitchWheel(t,e);return}t%=16,this.sendMIDIMessage([G.pitchWheel|t,e&127,e>>7])}},Sa={linear:0,nearestNeighbor:1,hermite:2},Zt=Zt!==void 0?Zt:{},Fs=!1,rn;Zt.isInitialized=new Promise(t=>rn=t);var ka=function(t){var e,A,s,n,a,r,o,i="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",g="",l=0;t=t.replace(/[^A-Za-z0-9\+\/\=]/g,"");do n=i.indexOf(t.charAt(l++)),a=i.indexOf(t.charAt(l++)),r=i.indexOf(t.charAt(l++)),o=i.indexOf(t.charAt(l++)),e=n<<2|a>>4,A=(15&a)<<4|r>>2,s=(3&r)<<6|o,g+=String.fromCharCode(e),r!==64&&(g+=String.fromCharCode(A)),o!==64&&(g+=String.fromCharCode(s));while(l<t.length);return g};(function(){var t,e,A,s,n,a,r,o,i,g,l,B,C,I=I!==void 0?I:{};I.wasmBinary=Uint8Array.from(ka("AGFzbQEAAAABpQEYYAJ/fwF/YAF/AGAAAX9gBH9/f38AYAAAYAN/f38Bf2ABfwF/YAJ/fwBgBn9/f39/fwF/YAR/f39/AX9gBX9/f39/AX9gB39/f39/f38Bf2AGf39/f39/AGAIf39/f39/f38Bf2AFf39/f38AYAd/f39/f39/AGADf39/AGABfwF9YAF9AX1gAnx/AXxgAnx/AX9gA3x8fwF8YAJ8fAF8YAF8AXwCngIPA2VudgZtZW1vcnkCAIACA2VudgV0YWJsZQFwAQQEA2Vudgl0YWJsZUJhc2UDfwADZW52DkRZTkFNSUNUT1BfUFRSA38AA2VudghTVEFDS1RPUAN/AANlbnYJU1RBQ0tfTUFYA38ABmdsb2JhbAhJbmZpbml0eQN8AANlbnYFYWJvcnQAAQNlbnYNZW5sYXJnZU1lbW9yeQACA2Vudg5nZXRUb3RhbE1lbW9yeQACA2VudhdhYm9ydE9uQ2Fubm90R3Jvd01lbW9yeQACA2Vudg5fX19hc3NlcnRfZmFpbAADA2VudgtfX19zZXRFcnJObwABA2VudgZfYWJvcnQABANlbnYWX2Vtc2NyaXB0ZW5fbWVtY3B5X2JpZwAFA3d2BgYCAQcHAQIBAQcBCAcFAAkGCQoHBgYGBgEFBgIBBgYKAAgLAAYGBgYGBgYBAAoMDAMGBQANCAoJAAwODA8OAQAGBgcEABAJEAERAAADBQwAAAMHBxIGAQAABwIFEwMOBw8HBgYQFAoVExYXFxcXFgQFBQYFAAYkB38BIwELfwEjAgt/ASMDC38BQQALfwFBAAt8ASMEC38BQQALB9MCFRBfX2dyb3dXYXNtTWVtb3J5AAgRX19fZXJybm9fbG9jYXRpb24AYwVfZnJlZQBfB19tYWxsb2MAXgdfbWVtY3B5AHkHX21lbXNldAB6BV9zYnJrAHsXX3N0Yl92b3JiaXNfanNfY2hhbm5lbHMAJhRfc3RiX3ZvcmJpc19qc19jbG9zZQAlFV9zdGJfdm9yYmlzX2pzX2RlY29kZQAoE19zdGJfdm9yYmlzX2pzX29wZW4AJBpfc3RiX3ZvcmJpc19qc19zYW1wbGVfcmF0ZQAnC2R5bkNhbGxfaWlpAHwTZXN0YWJsaXNoU3RhY2tTcGFjZQAMC2dldFRlbXBSZXQwAA8LcnVuUG9zdFNldHMAeAtzZXRUZW1wUmV0MAAOCHNldFRocmV3AA0Kc3RhY2tBbGxvYwAJDHN0YWNrUmVzdG9yZQALCXN0YWNrU2F2ZQAKCQoBACMACwR9VFl9Csb2A3YGACAAQAALGwEBfyMGIQEjBiAAaiQGIwZBD2pBcHEkBiABCwQAIwYLBgAgACQGCwoAIAAkBiABJAcLEAAjCEUEQCAAJAggASQJCwsGACAAJAsLBAAjCwsRACAABEAgABARIAAgABASCwvvBwEKfyAAQYADaiEHIAcoAgAhBQJAIAUEQCAAQfwBaiEEIAQoAgAhASABQQBKBEAgAEHwAGohCANAIAUgAkEYbGpBEGohCSAJKAIAIQEgAQRAIAgoAgAhAyAFIAJBGGxqQQ1qIQogCi0AACEGIAZB/wFxIQYgAyAGQbAQbGpBBGohAyADKAIAIQMgA0EASgRAQQAhAwNAIAEgA0ECdGohASABKAIAIQEgACABEBIgA0EBaiEDIAgoAgAhASAKLQAAIQYgBkH/AXEhBiABIAZBsBBsakEEaiEBIAEoAgAhBiAJKAIAIQEgAyAGSA0ACwsgACABEBILIAUgAkEYbGpBFGohASABKAIAIQEgACABEBIgAkEBaiECIAQoAgAhASACIAFODQMgBygCACEFDAAACwALCwsgAEHwAGohAyADKAIAIQEgAQRAIABB7ABqIQUgBSgCACECIAJBAEoEQEEAIQIDQAJAIAEgAkGwEGxqQQhqIQQgBCgCACEEIAAgBBASIAEgAkGwEGxqQRxqIQQgBCgCACEEIAAgBBASIAEgAkGwEGxqQSBqIQQgBCgCACEEIAAgBBASIAEgAkGwEGxqQaQQaiEEIAQoAgAhBCAAIAQQEiABIAJBsBBsakGoEGohASABKAIAIQEgAUUhBCABQXxqIQFBACABIAQbIQEgACABEBIgAkEBaiECIAUoAgAhASACIAFODQAgAygCACEBDAELCyADKAIAIQELIAAgARASCyAAQfgBaiEBIAEoAgAhASAAIAEQEiAHKAIAIQEgACABEBIgAEGIA2ohAyADKAIAIQEgAQRAIABBhANqIQUgBSgCACECIAJBAEoEQEEAIQIDQCABIAJBKGxqQQRqIQEgASgCACEBIAAgARASIAJBAWohAiAFKAIAIQcgAygCACEBIAIgB0gNAAsLIAAgARASCyAAQQRqIQIgAigCACEBIAFBAEoEQEEAIQEDQCAAQZQGaiABQQJ0aiEDIAMoAgAhAyAAIAMQEiAAQZQHaiABQQJ0aiEDIAMoAgAhAyAAIAMQEiAAQdgHaiABQQJ0aiEDIAMoAgAhAyAAIAMQEiABQQFqIQEgAigCACEDIAEgA0ghAyABQRBJIQUgBSADcQ0ACwtBACEBA0AgAEGgCGogAUECdGohAiACKAIAIQIgACACEBIgAEGoCGogAUECdGohAiACKAIAIQIgACACEBIgAEGwCGogAUECdGohAiACKAIAIQIgACACEBIgAEG4CGogAUECdGohAiACKAIAIQIgACACEBIgAEHACGogAUECdGohAiACKAIAIQIgACACEBIgAUEBaiEBIAFBAkcNAAsLGwAgAEHEAGohACAAKAIAIQAgAEUEQCABEF8LC3wBAX8gAEHUB2ohASABQQA2AgAgAEGAC2ohASABQQA2AgAgAEH4CmohASABQQA2AgAgAEGcCGohASABQQA2AgAgAEHVCmohASABQQA6AAAgAEH8CmohASABQQA2AgAgAEHUC2ohASABQQA2AgAgAEHYC2ohACAAQQA2AgAL8AQBB38jBiELIwZBEGokBiALQQhqIQcgC0EEaiEKIAshCCAAQSRqIQYgBiwAACEGAn8gBgR/IABBgAtqIQYgBigCACEGIAZBf0oEQCAFQQA2AgAgACABIAIQFgwCCyAAQRRqIQYgBiABNgIAIAEgAmohAiAAQRxqIQkgCSACNgIAIABB2ABqIQIgAkEANgIAIABBABAXIQkgCUUEQCAFQQA2AgBBAAwCCyAAIAcgCCAKEBghCSAJBEAgBygCACECIAgoAgAhCSAKKAIAIQggACACIAkgCBAaIQogByAKNgIAIABBBGohAiACKAIAIQggCEEASgRAQQAhAgNAIABBlAZqIAJBAnRqIQcgBygCACEHIAcgCUECdGohByAAQdQGaiACQQJ0aiEMIAwgBzYCACACQQFqIQIgAiAISA0ACwsgAwRAIAMgCDYCAAsgBSAKNgIAIABB1AZqIQAgBCAANgIAIAYoAgAhACAAIAFrDAILAkACQAJAAkACQCACKAIAIgNBIGsOBAECAgACCyACQQA2AgAgAEHUAGohAiAAEBkhAwJAIANBf0cEQANAIAIoAgAhAyADDQIgABAZIQMgA0F/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ACECIABBmAhqIQYgBigCACEHIAUgA2shCSAJIAdqIQkgAiAJSSEJIAIgB0khDSACIAdrIQJBACACIA0bIQIgAiADaiECIAIgBUohByAFIAIgBxshAiAJBEAgASACNgIAIAYoAgAhACAAIAJqIQAgBiAANgIAQQEMBgsLCyAAQfQKaiECIAIoAgAhAiADIB9rIQYgBiACaiEGIABBmAhqIQIgAiAGNgIAIAhBATYCAAwBBSAAQZgIaiECIAYNAQsMAQsgBCADayEDIAIoAgAhBCADIARqIQMgAiADNgIACyATKAIAIQIgAgRAIABByABqIQIgAigCACECIABB0ABqIQAgACgCACEAIAIgAEcEQEHTE0HEE0HkGkHnFBAECwsgASAFNgIAQQELIQAgHCQGIAALqAIBBX8gAEHoCmohBSAFKAIAIQICQCACQQBIBEBBACEABSACIAFIBEAgAUEYSgRAIABBGBAsIQIgAUFoaiEBIAAgARAsIQAgAEEYdCEAIAAgAmohACAADwsgAkUEQCAAQeQKaiECIAJBADYCAAsgAEHkCmohAwJAAkACQANAIAAQLiECIAJBf0YNASAFKAIAIQQgAiAEdCECIAMoAgAhBiAGIAJqIQIgAyACNgIAIAUgBEEIaiICNgIAIAIgAUgNAAwCAAsACyAFQX82AgBBACEADAQLIARBeEgEQEEAIQAMBAsLCyAAQeQKaiEEIAQoAgAhA0EBIAF0IQAgAEF/aiEAIAMgAHEhACADIAF2IQMgBCADNgIAIAIgAWshASAFIAE2AgALCyAAC40CAAJAIABBAEgEf0EABSAAQYCAAUgEQCAAQRBIBEAgAEGACGohACAALAAAIQAMAwsgAEGABEgEQCAAQQV2IQAgAEGACGohACAALAAAIQAgAEEFaiEABSAAQQp2IQAgAEGACGohACAALAAAIQAgAEEKaiEACwwCCyAAQYCAgAhIBH8gAEGAgCBIBH8gAEEPdiEAIABBgAhqIQAgACwAACEAIABBD2oFIABBFHYhACAAQYAIaiEAIAAsAAAhACAAQRRqCwUgAEGAgICAAkgEfyAAQRl2IQAgAEGACGohACAALAAAIQAgAEEZagUgAEEediEAIABBgAhqIQAgACwAACEAIABBHmoLCwshAAsgAAuiAQEDfyAAQdQKaiECIAIsAAAhAQJAAkAgAQ0AIABB3ApqIQEgASgCACEBIAEEQEF/IQMFIAAQLyEBIAEEQCACLAAAIQEgAQ0CQaEUQcQTQfYLQbUUEAQFQX8hAwsLDAELIAFBf2pBGHRBGHUhASACIAE6AAAgAEHsCmohASABKAIAIQIgAkEBaiECIAEgAjYCACAAEDAhACAAQf8BcSEDCyADC6wCAQd/IABB3ApqIQIgAigCACEBAkAgAUUEQCAAQdgKaiEEIAQoAgAhASABQX9GBEAgAEHQCGohASABKAIAIQEgAUF/aiEBIABB4ApqIQMgAyABNgIAIAAQMSEBIAFFBEAgAkEBNgIADAMLIABB0wpqIQEgASwAACEBIAFBAXEhASABBH8gBCgCAAUgAEEgEBUMAwshAQsgAUEBaiEHIAQgBzYCACAAQdQIaiABaiEDIAMsAAAhBiAGQf8BcSEDIAZBf0cEQCACQQE2AgAgAEHgCmohAiACIAE2AgALIABB0AhqIQEgASgCACEBIAcgAU4EQCAEQX82AgALIABB1ApqIQAgACwAACEBIAEEQEHFFEHEE0HoC0HaFBAEBSAAIAY6AAAgAyEFCwsLIAULUQEDfyAAQRRqIQMgAygCACEBIABBHGohAiACKAIAIQIgASACSQR/IAFBAWohACADIAA2AgAgASwAAAUgAEHUAGohACAAQQE2AgBBAAshACAACyABAX8gABAyIQEgAQR/IAAQMwUgAEEeEBVBAAshACAAC2ABAX8gABAwIQEgAUH/AXFBzwBGBEAgABAwIQEgAUH/AXFB5wBGBEAgABAwIQEgAUH/AXFB5wBGBEAgABAwIQAgAEH/AXFB0wBGIQAFQQAhAAsFQQAhAAsFQQAhAAsgAAvZAwEGfyAAEDAhAQJ/IAFB/wFxBH8gAEEfEBVBAAUgABAwIQEgAEHTCmohAiACIAE6AAAgABAjIQUgABAjIQIgABAjGiAAECMhASAAQcwIaiEDIAMgATYCACAAECMaIAAQMCEBIAFB/wFxIQEgAEHQCGohAyADIAE2AgAgAEHUCGohBCAAIAQgARAiIQEgAUUEQCAAQQoQFUEADAILIABB8ApqIQQgBEF+NgIAIAIgBXEhAQJAIAFBf0cEQCADKAIAIQEgAUEASgRAA0ACQCABQX9qIQIgAEHUCGogAmohBiAGLAAAIQYgBkF/Rw0AIAFBAUwNBCACIQEMAQsLIAQgAjYCACAAQfQKaiEBIAEgBTYCAAsLCyAAQdUKaiEBIAEsAAAhASABBEAgAygCACEDIANBAEoEf0EAIQJBACEBA0AgAEHUCGogAWohBCAELQAAIQQgBEH/AXEhBCACIARqIQIgAUEBaiEBIAEgA0gNAAsgAkEbagVBGwshASAAQShqIQIgAigCACECIAEgA2ohASABIAJqIQEgAEEsaiEDIAMgAjYCACAAQTBqIQIgAiABNgIAIABBNGohASABIAU2AgALIABB2ApqIQAgAEEANgIAQQELCyEAIAALowEBB38gAEHoCmohAyADKAIAIQECQCABQRlIBEAgAEHkCmohBCABRQRAIARBADYCAAsgAEHUCmohBSAAQdwKaiEGA0AgBigCACEBIAEEQCAFLAAAIQEgAUUNAwsgABAuIQIgAkF/Rg0CIAMoAgAhASACIAF0IQIgBCgCACEHIAcgAmohAiAEIAI2AgAgAUEIaiECIAMgAjYCACABQRFIDQALCwsLrQUBCX8gABA0IAFBIGohAiACKAIAIQUCQAJAIAVFIgNFDQAgAUGkEGohAiACKAIAIQIgAg0AQX8hAQwBCyABQQRqIQIgAigCACECAkACQCACQQhKBEAgAUGkEGohAyADKAIAIQMgAw0BBSADDQELDAELIABB5ApqIQggCCgCACEJIAkQOiEHIAFBrBBqIQIgAigCACECIAJBAUoEQCABQaQQaigCACEKQQAhAwNAIAJBAXYhBSAFIANqIQQgCiAEQQJ0aiEGIAYoAgAhBiAGIAdLIQYgAiAFayECIAMgBCAGGyEDIAUgAiAGGyECIAJBAUoNAAsFQQAhAwsgAUEXaiECIAIsAAAhAiACRQRAIAFBqBBqIQIgAigCACECIAIgA0ECdGohAiACKAIAIQMLIAFBCGohASABKAIAIQEgASADaiEBIAEtAAAhASABQf8BcSEBIABB6ApqIQIgAigCACEAIAAgAUgEf0EAIQBBfwUgACABayEAIAkgAXYhASAIIAE2AgAgAwshASACIAA2AgAMAQsgAUEXaiEDIAMsAAAhAyADBEBBgRVBxBNB6gxBjBUQBAsCQCACQQBKBEAgASgCCCEIIABB5ApqIQlBACEBA0ACQCAIIAFqIQMgAywAACEEIARB/wFxIQMgBEF/RwRAIAUgAUECdGoh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IwZBEGokBiACIQECfCAAvUIgiKdB/////wdxIgNB/MOk/wNJBHwgA0GewZryA0kEfEQAAAAAAADwPwUgAEQAAAAAAAAAABByCwUgACAAoSADQf//v/8HSw0BGgJAAkACQAJAIAAgARBuQQNxDgMAAQIDCyABKwMAIAErAwgQcgwECyABKwMAIAErAwhBARBwmgwDCyABKwMAIAErAwgQcpoMAgsgASsDACABKwMIQQEQcAsLIQAgAiQGIAALywEBA38jBiECIwZBEGokBiACIQECQCAAvUIgiKdB/////wdxIgNB/MOk/wNJBEAgA0GAgMDyA08EQCAARAAAAAAAAAAAQQAQcCEACwUgA0H//7//B0sEQCAAIAChIQAMAgsCQAJAAkACQAJAIAAgARBuQQNxDgMAAQIDCyABKwMAIAErAwhBARBwIQAMBQsgASsDACABKwMIEHIhAAwECyABKwMAIAErAwhBARBwmiEADAMLIAErAwAgASsDCBBymiEACwsLIAIkBiAAC5sDAwJ/AX4CfCAAvSIDQj+IpyEBAnwCfwJAIANCIIinQf////8HcSICQarGmIQESwR8IANC////////////AINCgICAgICAgPj/AFYEQCAADwsgAETvOfr+Qi6GQGQEQCAARAAAAAAAAOB/og8FIABE0rx63SsjhsBjIABEUTAt1RBJh8BjcUUNAkQAAAAAAAAAACIADwsABSACQcLc2P4DSwRAIAJBscXC/wNLDQIgAUEBcyABawwDCyACQYCAwPEDSwR8QQAhASAABSAARAAAAAAAAPA/oA8LCwwCCyAARP6CK2VHFfc/oiABQQN0QYATaisDAKCqCyEBIAAgAbciBEQAAOD+Qi7mP6KhIgAgBER2PHk17znqPaIiBaELIQQgACAEIAQgBCAEoiIAIAAgACAAIABE0KS+cmk3Zj6iRPFr0sVBvbu+oKJELN4lr2pWET+gokSTvb4WbMFmv6CiRD5VVVVVVcU/oKKhIgCiRAAAAAAAAABAIAChoyAFoaBEAAAAAAAA8D+gIQAgAUUEQCAADwsgACABEGULnwMDAn8BfgV8IAC9IgNCIIinIQECfyADQgBTIgIgAUGAgMAASXIEfyADQv///////////wCDQgBRBEBEAAAAAAAA8L8gACAAoqMPCyACRQRAIABEAAAAAAAAUEOi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mgDjqR0AXmGRAAgb5gCFmWUAoBRfAI1AaACA2P8AJ3NNAAYGMQDKVhUAyahzAHviYABrjMAAQcMSC11A+yH5PwAAAAAtRHQ+AAAAgJhG+DwAAABgUcx4OwAAAICDG/A5AAAAQCAlejgAAACAIoLjNgAAAAAd82k1AAAAAAAA4D8AAAAAAADgvwAAAAAAAPA/AAAAAAAA+D8AQagTCwgG0M9D6/1MPgBBuxMLigZAA7jiP09nZ1MuL3N0Yl92b3JiaXMuYwBmLT5hbGxvYy5hbGxvY19idWZmZXJfbGVuZ3RoX2luX2J5dGVzID09IGYtPnRlbXBfb2Zmc2V0AHZvcmJpc19kZWNvZGVfaW5pdGlhbABmLT5ieXRlc19pbl9zZWcgPiAwAGdldDhfcGFja2V0X3JhdwBmLT5ieXRlc19pbl9zZWcgPT0gMABuZXh0X3NlZ21lbnQAdm9yYmlzX2RlY29kZV9wYWNrZXRfcmVzdAAhYy0+c3BhcnNlAGNvZGVib29rX2RlY29kZV9zY2FsYXJfcmF3ACFjLT5zcGFyc2UgfHwgeiA8IGMtPnNvcnRlZF9lbnRyaWVzAGNvZGVib29rX2RlY29kZV9kZWludGVybGVhdmVfcmVwZWF0AHogPCBjLT5zb3J0ZWRfZW50cmllcwBjb2RlYm9va19kZWNvZGVfc3RhcnQAKG4gJiAzKSA9PSAwAGltZGN0X3N0ZXAzX2l0ZXIwX2xvb3AAMABnZXRfd2luZG93AGYtPnRlbXBfb2Zmc2V0ID09IGYtPmFsbG9jLmFsbG9jX2J1ZmZlcl9sZW5ndGhfaW5fYnl0ZXMAc3RhcnRfZGVjb2RlcgB2b3JiaXNjLT5zb3J0ZWRfZW50cmllcyA9PSAwAGNvbXB1dGVfY29kZXdvcmRzAHogPj0gMCAmJiB6IDwgMzIAbGVuW2ldID49IDAgJiYgbGVuW2ldIDwgMzIAYXZhaWxhYmxlW3ldID09IDAAayA9PSBjLT5zb3J0ZWRfZW50cmllcwBjb21wdXRlX3NvcnRlZF9odWZmbWFuAGMtPnNvcnRlZF9jb2Rld29yZHNbeF0gPT0gY29kZQBsZW4gIT0gTk9fQ09ERQBpbmNsdWRlX2luX3NvcnQAcG93KChmbG9hdCkgcisxLCBkaW0pID4gZW50cmllcwBsb29rdXAxX3ZhbHVlcwAoaW50KSBmbG9vcihwb3coKGZsb2F0KSByLCBkaW0pKSA8PSBlbnRyaWVzAOoPBG5hbWUB4g9+AAVhYm9ydAENZW5sYXJnZU1lbW9yeQIOZ2V0VG90YWxNZW1vcnkDF2Fib3J0T25DYW5ub3RHcm93TWVtb3J5BA5fX19hc3NlcnRfZmFpbAULX19fc2V0RXJyTm8GBl9hYm9ydAcWX2Vtc2NyaXB0ZW5fbWVtY3B5X2JpZwgQX19ncm93V2FzbU1lbW9yeQkKc3RhY2tBbGxvYwoJc3RhY2tTYXZlCwxzdGFja1Jlc3RvcmUME2VzdGFibGlzaFN0YWNrU3BhY2UNCHNldFRocmV3DgtzZXRUZW1wUmV0MA8LZ2V0VGVtcFJldDAQEV9zdGJfdm9yYmlzX2Nsb3NlEQ5fdm9yYmlzX2RlaW5pdBILX3NldHVwX2ZyZWUTGl9zdGJfdm9yYmlzX2ZsdXNoX3B1c2hkYXRhFCFfc3RiX3ZvcmJpc19kZWNvZGVfZnJhbWVfcHVzaGRhdGEVBl9lcnJvchYgX3ZvcmJpc19zZWFyY2hfZm9yX3BhZ2VfcHVzaGRhdGEXGF9pc193aG9sZV9wYWNrZXRfcHJlc2VudBgVX3ZvcmJpc19kZWNvZGVfcGFja2V0GQxfZ2V0OF9wYWNrZXQaFF92b3JiaXNfZmluaXNoX2ZyYW1lGxlfc3RiX3ZvcmJpc19vcGVuX3B1c2hkYXRhHAxfdm9yYmlzX2luaXQdDl9zdGFydF9kZWNvZGVyHg1fdm9yYmlzX2FsbG9jHxtfc3RiX3ZvcmJpc19nZXRfZmlsZV9vZmZzZXQgE19tYXliZV9zdGFydF9wYWNrZXQhDV9mbHVzaF9wYWNrZXQiBV9nZXRuIwZfZ2V0MzIkE19zdGJfdm9yYmlzX2pzX29wZW4lFF9zdGJfdm9yYmlzX2pzX2Nsb3NlJhdfc3RiX3ZvcmJpc19qc19jaGFubmVscycaX3N0Yl92b3JiaXNfanNfc2FtcGxlX3JhdGUoFV9zdGJfdm9yYmlzX2pzX2RlY29kZSkNX2NyYzMyX3VwZGF0ZSoWX3ZvcmJpc19kZWNvZGVfaW5pdGlhbCsaX3ZvcmJpc19kZWNvZGVfcGFja2V0X3Jlc3QsCV9nZXRfYml0cy0FX2lsb2cuEF9nZXQ4X3BhY2tldF9yYXcvDV9uZXh0X3NlZ21lbnQwBV9nZXQ4MQtfc3RhcnRfcGFnZTIQX2NhcHR1cmVfcGF0dGVybjMdX3N0YXJ0X3BhZ2Vfbm9fY2FwdHVyZXBhdHRlcm40DV9wcmVwX2h1ZmZtYW41G19jb2RlYm9va19kZWNvZGVfc2NhbGFyX3JhdzYOX3ByZWRpY3RfcG9pbnQ3D19kZWNvZGVfcmVzaWR1ZTgJX2RvX2Zsb29yOQ1faW52ZXJzZV9tZGN0OgxfYml0X3JldmVyc2U7EV9tYWtlX2Jsb2NrX2FycmF5PBJfc2V0dXBfdGVtcF9tYWxsb2M9JF9jb2RlYm9va19kZWNvZGVfZGVpbnRlcmxlYXZlX3JlcGVhdD4PX3Jlc2lkdWVfZGVjb2RlPxVfY29kZWJvb2tfZGVjb2RlX3N0ZXBAEF9jb2RlYm9va19kZWNvZGVBFl9jb2RlYm9va19kZWNvZGVfc3RhcnRCCl9kcmF3X2xpbmVDF19pbWRjdF9zdGVwM19pdGVyMF9sb29wRBlfaW1kY3Rfc3RlcDNfaW5uZXJfcl9sb29wRRlfaW1kY3Rfc3RlcDNfaW5uZXJfc19sb29wRh9faW1kY3Rfc3RlcDNfaW5uZXJfc19sb29wX2xkNjU0RwhfaXRlcl81NEgLX2dldF93aW5kb3dJEF92b3JiaXNfdmFsaWRhdGVKDV9zdGFydF9wYWNrZXRLBV9za2lwTAtfY3JjMzJfaW5pdE0NX3NldHVwX21hbGxvY04QX3NldHVwX3RlbXBfZnJlZU8SX2NvbXB1dGVfY29kZXdvcmRzUBdfY29tcHV0ZV9zb3J0ZWRfaHVmZm1hblEcX2NvbXB1dGVfYWNjZWxlcmF0ZWRfaHVmZm1hblIPX2Zsb2F0MzJfdW5wYWNrUw9fbG9va3VwMV92YWx1ZXNUDl9wb2ludF9jb21wYXJlVQpfbmVpZ2hib3JzVg9faW5pdF9ibG9ja3NpemVXCl9hZGRfZW50cnlYEF9pbmNsdWRlX2luX3NvcnRZD191aW50MzJfY29tcGFyZVoYX2NvbXB1dGVfdHdpZGRsZV9mYWN0b3JzWw9fY29tcHV0ZV93aW5kb3dcE19jb21wdXRlX2JpdHJldmVyc2VdB19zcXVhcmVeB19tYWxsb2NfBV9mcmVlYAhfcmVhbGxvY2ESX3RyeV9yZWFsbG9jX2NodW5rYg5fZGlzcG9zZV9jaHVua2MRX19fZXJybm9fbG9jYXRpb25kB19tZW1jbXBlB19zY2FsYm5mBl9xc29ydGcFX3NpZnRoBF9zaHJpCF90cmlua2xlagRfc2hsawVfcG50emwIX2FfY3R6X2xtBl9jeWNsZW4LX19fcmVtX3BpbzJvEV9fX3JlbV9waW8yX2xhcmdlcAZfX19zaW5xBl9sZGV4cHIGX19fY29zcwRfY29zdARfc2ludQRfZXhwdgRfbG9ndwRfcG93eAtydW5Qb3N0U2V0c3kHX21lbWNweXoHX21lbXNldHsFX3Nicmt8C2R5bkNhbGxfaWlpfQJiMA=="),function(v){return v.charCodeAt(0)});var I=I!==void 0?I:{},E={};for(t in I)I.hasOwnProperty(t)&&(E[t]=I[t]);I.arguments=[],I.thisProgram="./this.program",I.quit=function(v,w){throw w},I.preRun=[],I.postRun=[];var y=!1,k=!1,p=!1,R=!1;y=typeof window=="object",k=typeof importScripts=="function",p=typeof process=="object"&&typeof aaa=="function"&&!y&&!k,R=!y&&!p&&!k;var b="";function M(v){return I.locateFile?I.locateFile(v,b):b+v}p?(b="/",I.read=function(w,L){var z;return e||(e=void 0),A||(A=void 0),w=A.normalize(w),z=e.readFileSync(w),L?z:z.toString()},I.readBinary=function(w){var L=I.read(w,!0);return L.buffer||(L=new Uint8Array(L)),Y(L.buffer),L},process.argv.length>1&&(I.thisProgram=process.argv[1].replace(/\\/g,"/")),I.arguments=process.argv.slice(2),process.on("uncaughtException",function(v){if(!(v instanceof qe))throw v}),process.on("unhandledRejection",function(v,w){process.exit(1)}),I.quit=function(v){process.exit(v)},I.inspect=function(){return"[Emscripten Module object]"}):R?(typeof read<"u"&&(I.read=function(w){return read(w)}),I.readBinary=function(w){var L;return typeof readbuffer=="function"?new Uint8Array(readbuffer(w)):(Y(typeof(L=read(w,"binary"))=="object"),L)},typeof scriptArgs<"u"?I.arguments=scriptArgs:typeof arguments<"u"&&(I.arguments=arguments),typeof quit=="function"&&(I.quit=function(v){quit(v)})):(y||k)&&(y?document.currentScript&&(b=document.currentScript.src):b=self.location.href,b=b.indexOf("blob:")!==0?b.split("/").slice(0,-1).join("/")+"/":"",I.read=function(w){var L=new XMLHttpRequest;return L.open("GET",w,!1),L.send(null),L.responseText},k&&(I.readBinary=function(w){var L=new XMLHttpRequest;return L.open("GET",w,!1),L.responseType="arraybuffer",L.send(null),new Uint8Array(L.response)}),I.readAsync=function(w,L,z){var re=new XMLHttpRequest;re.open("GET",w,!0),re.responseType="arraybuffer",re.onload=function(){if(re.status==200||re.status==0&&re.response){L(re.response);return}z()},re.onerror=z,re.send(null)},I.setWindowTitle=function(v){document.title=v});var S=I.print||(typeof console<"u"?console.log.bind(console):typeof print<"u"?print:null),Q=I.printErr||(typeof printErr<"u"?printErr:typeof console<"u"&&console.warn.bind(console)||S);for(t in E)E.hasOwnProperty(t)&&(I[t]=E[t]);function m(v){var w=i;return i=i+v+15&-16,w}function D(v,w){return w||(w=16),v=Math.ceil(v/w)*w}function q(v){q.shown||(q.shown={}),q.shown[v]||(q.shown[v]=1,Q(v))}E=void 0;var K={"f64-rem":function(v,w){return v%w},debugger:function(){}},O=0;function Y(v,w){v||je("Assertion failed: "+w)}function H(v){var w=I["_"+v];return Y(w,"Cannot call unknown function "+v+", make sure it is exported"),w}var Z={stackSave:function(){bt()},stackRestore:function(){Ct()},arrayToC:function(v){var w,L,z=it(v.length);return w=v,L=z,n.set(w,L),z},stringToC:function(v){var w=0;if(v!=null&&v!==0){var L=(v.length<<2)+1;w=it(L),te(v,w,L)}return w}},T={string:Z.stringToC,array:Z.arrayToC};function F(v,w,L,z,re){var ce=H(v),de=[],j=0;if(z)for(var Ne=0;Ne<z.length;Ne++){var De=T[L[Ne]];De?(j===0&&(j=bt()),de[Ne]=De(z[Ne])):de[Ne]=z[Ne]}var oe,Ce=ce.apply(null,de);return Ce=(oe=Ce,w==="string"?u(oe):w==="boolean"?!!oe:oe),j!==0&&Ct(j),Ce}function u(v,w){if(w===0||!v)return"";for(var L,z,re,ce=0,de=0;ce|=z=a[v+de>>0],(z!=0||w)&&(de++,!w||de!=w););w||(w=de);var j="";if(ce<128){for(;w>0;)re=String.fromCharCode.apply(String,a.subarray(v,v+Math.min(w,1024))),j=j?j+re:re,v+=1024,w-=1024;return j}return L=v,(function(De,oe){for(var Ce=oe;De[Ce];)++Ce;if(Ce-oe>16&&De.subarray&&x)return x.decode(De.subarray(oe,Ce));for(var he,Te,Ue,et,ft,ot="";;){if(!(he=De[oe++]))return ot;if(!(128&he)){ot+=String.fromCharCode(he);continue}if(Te=63&De[oe++],(224&he)==192){ot+=String.fromCharCode((31&he)<<6|Te);continue}if(Ue=63&De[oe++],(240&he)==224?he=(15&he)<<12|Te<<6|Ue:(et=63&De[oe++],(248&he)==240?he=(7&he)<<18|Te<<12|Ue<<6|et:(ft=63&De[oe++],he=(252&he)==248?(3&he)<<24|Te<<18|Ue<<12|et<<6|ft:(1&he)<<30|Te<<24|Ue<<18|et<<12|ft<<6|63&De[oe++])),he<65536)ot+=String.fromCharCode(he);else{var tt=he-65536;ot+=String.fromCharCode(55296|tt>>10,56320|1023&tt)}}})(a,L)}var x=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function P(v,w,L,z){if(!(z>0))return 0;for(var re=L,ce=L+z-1,de=0;de<v.length;++de){var j=v.charCodeAt(de);if(j>=55296&&j<=57343&&(j=65536+((1023&j)<<10)|1023&v.charCodeAt(++de)),j<=127){if(L>=ce)break;w[L++]=j}else if(j<=2047){if(L+1>=ce)break;w[L++]=192|j>>6,w[L++]=128|63&j}else if(j<=65535){if(L+2>=ce)break;w[L++]=224|j>>12,w[L++]=128|j>>6&63,w[L++]=128|63&j}else if(j<=2097151){if(L+3>=ce)break;w[L++]=240|j>>18,w[L++]=128|j>>12&63,w[L++]=128|j>>6&63,w[L++]=128|63&j}else if(j<=67108863){if(L+4>=ce)break;w[L++]=248|j>>24,w[L++]=128|j>>18&63,w[L++]=128|j>>12&63,w[L++]=128|j>>6&63,w[L++]=128|63&j}else{if(L+5>=ce)break;w[L++]=252|j>>30,w[L++]=128|j>>24&63,w[L++]=128|j>>18&63,w[L++]=128|j>>12&63,w[L++]=128|j>>6&63,w[L++]=128|63&j}}return w[L]=0,L-re}function te(v,w,L){return P(v,a,w,L)}typeof TextDecoder<"u"&&new TextDecoder("utf-16le");function W(v,w){return v%w>0&&(v+=w-v%w),v}function _(v){I.buffer=s=v}function $(){I.HEAP8=n=new Int8Array(s),I.HEAP16=new Int16Array(s),I.HEAP32=r=new Int32Array(s),I.HEAPU8=a=new Uint8Array(s),I.HEAPU16=new Uint16Array(s),I.HEAPU32=new Uint32Array(s),I.HEAPF32=new Float32Array(s),I.HEAPF64=new Float64Array(s)}function ne(){var v=I.usingWasm?65536:16777216,w=2147483648-v;if(r[C>>2]>w)return!1;var L=J;for(J=Math.max(J,16777216);J<r[C>>2];)J=J<=536870912?W(2*J,v):Math.min(W((3*J+2147483648)/4,v),w);var z=I.reallocBuffer(J);return z&&z.byteLength==J?(_(z),$(),!0):(J=L,!1)}o=i=g=l=B=C=0,I.reallocBuffer||(I.reallocBuffer=function(v){try{if(ArrayBuffer.transfer)w=ArrayBuffer.transfer(s,v);else{var w,L=n;w=new ArrayBuffer(v),new Int8Array(w).set(L)}}catch{return!1}return!!Xe(w)&&w});try{Function.prototype.call.bind(Object.getOwnPropertyDescriptor(ArrayBuffer.prototype,"byteLength").get)(new ArrayBuffer(4))}catch{}var ae=I.TOTAL_STACK||5242880,J=I.TOTAL_MEMORY||16777216;function ie(){return J}function pe(v){for(;v.length>0;){var w=v.shift();if(typeof w=="function"){w();continue}var L=w.func;typeof L=="number"?w.arg===void 0?I.dynCall_v(L):I.dynCall_vi(L,w.arg):L(w.arg===void 0?null:w.arg)}}J<ae&&Q("TOTAL_MEMORY should be larger than TOTAL_STACK, was "+J+"! (TOTAL_STACK="+ae+")"),I.buffer?s=I.buffer:(typeof WebAssembly=="object"&&typeof WebAssembly.Memory=="function"?(I.wasmMemory=new WebAssembly.Memory({initial:J/65536}),s=I.wasmMemory.buffer):s=new ArrayBuffer(J),I.buffer=s),$();var ve=[],Be=[],be=[],xe=[],ht=!1;function lt(v){ve.unshift(v)}function jt(v){xe.unshift(v)}var eA=Math.floor,Ye=0,Et=null,Re=null;I.preloadedImages={},I.preloadedAudios={};var Ot="data:application/octet-stream;base64,";function wt(v){return String.prototype.startsWith?v.startsWith(Ot):v.indexOf(Ot)===0}(function(){var w="main.wast",L="main.wasm",z="main.temp.asm";wt(w)||(w=M(w)),wt(L)||(L=M(L)),wt(z)||(z=M(z));var re={global:null,env:null,asm2wasm:K,parent:I},ce=null;function de(){try{if(I.wasmBinary)return new Uint8Array(I.wasmBinary);if(I.readBinary)return I.readBinary(L);throw"both async and sync fetching of the wasm failed"}catch(oe){je(oe)}}I.asmPreload=I.asm;var j=I.reallocBuffer,Ne=function(oe){oe=W(oe,I.usingWasm?65536:16777216);var Ce=I.buffer.byteLength;if(I.usingWasm)try{return I.wasmMemory.grow((oe-Ce)/65536)!==-1?I.buffer=I.wasmMemory.buffer:null}catch{return null}};I.reallocBuffer=function(oe){return De==="asmjs"?j(oe):Ne(oe)};var De="";I.asm=function(oe,Ce,he){if(!(Ce=Ce).table){var Te,Ue=I.wasmTableSize;Ue===void 0&&(Ue=1024);var et=I.wasmMaxTableSize;typeof WebAssembly=="object"&&typeof WebAssembly.Table=="function"?et!==void 0?Ce.table=new WebAssembly.Table({initial:Ue,maximum:et,element:"anyfunc"}):Ce.table=new WebAssembly.Table({initial:Ue,element:"anyfunc"}):Ce.table=Array(Ue),I.wasmTable=Ce.table}return Ce.memoryBase||(Ce.memoryBase=I.STATIC_BASE),Ce.tableBase||(Ce.tableBase=0),Te=(function(ot,tt,Ss){if(typeof WebAssembly!="object")return Q("no native wasm support detected"),!1;if(!(I.wasmMemory instanceof WebAssembly.Memory))return Q("no native wasm Memory in use"),!1;function Rt(Je,nt){if((ce=Je.exports).memory){var AA=ce.memory,ks=I.buffer,Ds;AA.byteLength<ks.byteLength&&Q("the new buffer in mergeMemory is smaller than the previous one. in native wasm, we should grow memory here"),Ds=new Int8Array(ks),new Int8Array(AA).set(Ds),_(AA),$()}I.asm=ce,I.usingWasm=!0,(function(fi){if(Ye--,I.monitorRunDependencies&&I.monitorRunDependencies(Ye),Ye==0&&(Et!==null&&(clearInterval(Et),Et=null),Re)){var On=Re;Re=null,On()}})("wasm-instantiate")}if(tt.memory=I.wasmMemory,re.global={NaN:NaN,Infinity:1/0},re["global.Math"]=Math,re.env=tt,Ye++,I.monitorRunDependencies&&I.monitorRunDependencies(Ye),I.instantiateWasm)try{return I.instantiateWasm(re,Rt)}catch(Je){return Q("Module.instantiateWasm callback failed with error: "+Je),!1}function Ft(Je){Rt(Je.instance,Je.module)}function tA(Je){(!I.wasmBinary&&(y||k)&&typeof fetch=="function"?fetch(L,{credentials:"same-origin"}).then(function(nt){if(!nt.ok)throw"failed to load wasm binary file at '"+L+"'";return nt.arrayBuffer()}).catch(function(){return de()}):new Promise(function(nt,AA){nt(de())})).then(function(nt){return WebAssembly.instantiate(nt,re)}).then(Je).catch(function(nt){Q("failed to asynchronously prepare wasm: "+nt),je(nt)})}return I.wasmBinary||typeof WebAssembly.instantiateStreaming!="function"||wt(L)||typeof fetch!="function"?tA(Ft):WebAssembly.instantiateStreaming(fetch(L,{credentials:"same-origin"}),re).then(Ft).catch(function(Je){Q("wasm streaming compile failed: "+Je),Q("falling back to ArrayBuffer instantiation"),tA(Ft)}),{}})(oe,Ce,he),Y(Te,"no binaryen method succeeded."),Te},I.asm})(),i=(o=1024)+4816,Be.push(),I.STATIC_BASE=o,I.STATIC_BUMP=4816;var TA=i;i+=16,C=m(4),l=(g=D(i))+ae,B=D(l),r[C>>2]=B,I.wasmTableSize=4,I.wasmMaxTableSize=4,I.asmGlobalArg={},I.asmLibraryArg={abort:je,assert:Y,enlargeMemory:ne,getTotalMemory:ie,abortOnCannotGrowMemory:function(){je("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_MEMORY=X with X higher than the current value "+J+", (2) compile with -s ALLOW_MEMORY_GROWTH=1 which allows increasing the size at runtime, or (3) if you want malloc to return NULL (0) instead of this abort, compile with -s ABORTING_MALLOC=0 ")},invoke_iii:function(w,L,z){var re=bt();try{return I.dynCall_iii(w,L,z)}catch(ce){if(Ct(re),typeof ce!="number"&&ce!=="longjmp")throw ce;I.setThrew(1,0)}},___assert_fail:function(w,L,z,re){je("Assertion failed: "+u(w)+", at: "+[L?u(L):"unknown filename",z,re?u(re):"unknown function"])},___setErrNo:function(w){return I.___errno_location&&(r[I.___errno_location()>>2]=w),w},_abort:function(){I.abort()},_emscripten_memcpy_big:function(w,L,z){return a.set(a.subarray(L,L+z),w),w},_llvm_floor_f64:eA,DYNAMICTOP_PTR:C,tempDoublePtr:TA,ABORT:O,STACKTOP:g,STACK_MAX:l};var Yt=I.asm(I.asmGlobalArg,I.asmLibraryArg,s);I.asm=Yt,I.___errno_location=function(){return I.asm.___errno_location.apply(null,arguments)};var Xe=I._emscripten_replace_memory=function(){return I.asm._emscripten_replace_memory.apply(null,arguments)};I._free=function(){return I.asm._free.apply(null,arguments)},I._malloc=function(){return I.asm._malloc.apply(null,arguments)},I._memcpy=function(){return I.asm._memcpy.apply(null,arguments)},I._memset=function(){return I.asm._memset.apply(null,arguments)},I._sbrk=function(){return I.asm._sbrk.apply(null,arguments)},I._stb_vorbis_js_channels=function(){return I.asm._stb_vorbis_js_channels.apply(null,arguments)},I._stb_vorbis_js_close=function(){return I.asm._stb_vorbis_js_close.apply(null,arguments)},I._stb_vorbis_js_decode=function(){return I.asm._stb_vorbis_js_decode.apply(null,arguments)},I._stb_vorbis_js_open=function(){return I.asm._stb_vorbis_js_open.apply(null,arguments)},I._stb_vorbis_js_sample_rate=function(){return I.asm._stb_vorbis_js_sample_rate.apply(null,arguments)},I.establishStackSpace=function(){return I.asm.establishStackSpace.apply(null,arguments)},I.getTempRet0=function(){return I.asm.getTempRet0.apply(null,arguments)},I.runPostSets=function(){return I.asm.runPostSets.apply(null,arguments)},I.setTempRet0=function(){return I.asm.setTempRet0.apply(null,arguments)},I.setThrew=function(){return I.asm.setThrew.apply(null,arguments)};var it=I.stackAlloc=function(){return I.asm.stackAlloc.apply(null,arguments)},Ct=I.stackRestore=function(){return I.asm.stackRestore.apply(null,arguments)},bt=I.stackSave=function(){return I.asm.stackSave.apply(null,arguments)};function qe(v){this.name="ExitStatus",this.message="Program terminated with exit("+v+")",this.status=v}function dt(v){v=v||I.arguments,!(Ye>0)&&((function(){if(I.preRun)for(typeof I.preRun=="function"&&(I.preRun=[I.preRun]);I.preRun.length;)lt(I.preRun.shift());pe(ve)})(),!(Ye>0)&&(I.calledRun||(I.setStatus?(I.setStatus("Running..."),setTimeout(function(){setTimeout(function(){I.setStatus("")},1),w()},1)):w())));function w(){!I.calledRun&&(I.calledRun=!0,O||(ht||(ht=!0,pe(Be)),pe(be),I.onRuntimeInitialized&&I.onRuntimeInitialized(),(function(){if(I.postRun)for(typeof I.postRun=="function"&&(I.postRun=[I.postRun]);I.postRun.length;)jt(I.postRun.shift());pe(xe)})()))}}function je(v){throw I.onAbort&&I.onAbort(v),v!==void 0?(S(v),Q(v),v=JSON.stringify(v)):v="",O=!0,"abort("+v+"). Build with -s ASSERTIONS=1 for more info."}if(I.dynCall_iii=function(){return I.asm.dynCall_iii.apply(null,arguments)},I.asm=Yt,I.ccall=F,I.cwrap=function(w,L,z,re){var ce=(z=z||[]).every(function(de){return de==="number"});return L!=="string"&&ce&&!re?H(w):function(){return F(w,L,z,arguments,re)}},qe.prototype=Error(),qe.prototype.constructor=qe,Re=function v(){I.calledRun||dt(),I.calledRun||(Re=v)},I.run=dt,I.abort=je,I.preInit)for(typeof I.preInit=="function"&&(I.preInit=[I.preInit]);I.preInit.length>0;)I.preInit.pop()();I.noExitRuntime=!0,dt(),I.onRuntimeInitialized=()=>{Fs=!0,rn()},Zt.decode=function(v){return(function(L){if(!Fs)throw Error("SF3 decoder has not been initialized yet. Did you await synth.isReady?");var z={};function re(Rt){return new Int32Array(I.HEAPU8.buffer,Rt,1)[0]}function ce(Rt,Ft){var tA=new ArrayBuffer(Ft*Float32Array.BYTES_PER_ELEMENT),Je=new Float32Array(tA);return Je.set(new Float32Array(I.HEAPU8.buffer,Rt,Ft)),Je}z.open=I.cwrap("stb_vorbis_js_open","number",[]),z.close=I.cwrap("stb_vorbis_js_close","void",["number"]),z.channels=I.cwrap("stb_vorbis_js_channels","number",["number"]),z.sampleRate=I.cwrap("stb_vorbis_js_sample_rate","number",["number"]),z.decode=I.cwrap("stb_vorbis_js_decode","number",["number","number","number","number","number"]);var de,j,Ne,De,oe=z.open(),Ce=(de=L,j=L.byteLength,Ne=I._malloc(j),(De=new Uint8Array(I.HEAPU8.buffer,Ne,j)).set(new Uint8Array(de,0,j)),De),he=I._malloc(4),Te=I._malloc(4),Ue=z.decode(oe,Ce.byteOffset,Ce.byteLength,he,Te);if(I._free(Ce.byteOffset),Ue<0)throw z.close(oe),I._free(he),Error("stbvorbis decode failed: "+Ue);for(var et=z.channels(oe),ft=Array(et),ot=new Int32Array(I.HEAPU32.buffer,re(he),et),tt=0;tt<et;tt++)ft[tt]=ce(ot[tt],Ue),I._free(ot[tt]);var Ss=z.sampleRate(oe);return z.close(oe),I._free(re(he)),I._free(he),{data:ft,sampleRate:Ss,eof:!0,error:null}})(v)}})();var FA=Zt,Da={effectsEnabled:!0,maxBufferSize:128,initialTime:0,eventsEnabled:!0};var wa=class{keyMappings=[];addMapping(t,e,A){this.keyMappings[t]??=[],this.keyMappings[t][e]=A}deleteMapping(t,e){this.keyMappings[t]?.[e]!==void 0&&(this.keyMappings[t][e]=void 0)}clearMappings(){this.keyMappings=[]}setMappings(t){this.keyMappings=t}getMappings(){return this.keyMappings}getVelocity(t,e){return this.keyMappings[t]?.[e]?.velocity??-1}getGain(t,e){return this.keyMappings[t]?.[e]?.gain??1}hasOverridePatch(t,e){let A=this.keyMappings[t]?.[e]?.patch?.bankMSB;return A!==void 0&&A>=0}getPatch(t,e){let A=this.keyMappings[t]?.[e];if(A)return A.patch;throw new Error("No modifier.")}};function ba(t){for(this.keyModifierManager.setMappings(t.keyMappings);this.midiChannels.length<t.midiChannels.length;)this.createMIDIChannel(!0);for(let A=0;A<t.midiChannels.length;A++)this.midiChannels[A].applySnapshot(t.midiChannels[A]);for(let[A,s]of Object.entries(t.reverbProcessor))this.reverbProcessor[A]=s;for(let[A,s]of Object.entries(this.chorusProcessor))this.chorusProcessor[A]=s;for(let[A,s]of Object.entries(this.delayProcessor))this.delayProcessor[A]=s;let e=t.insertionProcessor;this.systemExclusive(se.gsData(64,3,0,[e.type>>8,e.type&127]));for(let A=0;A<e.params.length;A++)e.params[A]!==255&&this.systemExclusive(se.gsData(64,3,3+A,[e.params[A]]));for(let A=0;A<e.channels.length;A++)this.systemExclusive(se.gsData(64,64|se.channelToSyx(A),34,[e.channels[A]?1:0]));for(let[A,s]of Object.entries(this.midiParameters))this.setMIDIParameter(A,s);for(let[A,s]of Object.entries(this.systemParameters))this.setSystemParameter(A,s)}function Ra(){return{midiParameters:{...this.midiParameters},systemParameters:{...this.systemParameters},midiChannels:this.midiChannels.map(t=>t.getSnapshot()),keyMappings:this.keyModifierManager.getMappings(),reverbProcessor:this.reverbProcessor.getSnapshot(),chorusProcessor:this.chorusProcessor.getSnapshot(),delayProcessor:this.delayProcessor.getSnapshot(),insertionProcessor:this.getInsertionSnapshot()}}var on={effectsEnabled:!0,eventsEnabled:!0,voiceCap:350,autoAllocateVoices:!1,reverbGain:1,reverbLock:!1,chorusGain:1,chorusLock:!1,delayGain:1,delayLock:!1,insertionEffectLock:!1,drumLock:!1,blackMIDIMode:!1,deviceID:-1,gain:1,pan:0,keyShift:0,fineTune:0,interpolationType:Sa.hermite,nrpnParamLock:!1,monophonicRetrigger:!1};function Fa(t,e){if(this.systemParameters[t]===e)return;let A=this.systemParameters[t];this.systemParameters[t]=e;for(let s of this.midiChannels)s.updateInternalParams();switch(t){default:break;case"voiceCap":{let s=Math.min(e,1e6);this.systemParameters.voiceCap=s;for(let n=s;n<this.voices.length;n++)this.voices[n].isActive=!1;s>this.voices.length&&(h.warn(`Allocating ${s-this.voices.length} new voices!`),this.allocateNewVoices(s-this.voices.length));break}case"keyShift":A!==e&&this.stopAllChannels(!0)}}var ds=-15e3,es=new Float32Array(15e3-ds+1);for(let t=0;t<es.length;t++){let e=ds+t;es[t]=Math.pow(2,e/1200)}function mA(t){return t<=-32767?0:es[t-ds]}var pA=-2e4,gn=16500,ts=new Float32Array(gn-pA+1);for(let t=0;t<ts.length;t++){let e=pA+t;ts[t]=440*Math.pow(2,(e-6900)/1200)}function As(t){return t<pA||t>gn?440*Math.pow(2,(t-6900)/1200):ts[t-pA|0]}var Pt=-16600,Tt=new Float32Array(16e3-Pt+1);for(let t=0;t<Tt.length;t++){let e=Pt+t;Tt[t]=Math.pow(10,-e/200)}function yA(t){return Tt[t-Pt|0]}var Ma=.03,fs=class Kt{static smoothingConstant=1;static cachedCoefficients=new Map;resonanceCb=0;currentInitialFc=13500;a0=0;a1=0;a2=0;a3=0;a4=0;x1=0;x2=0;y1=0;y2=0;lastTargetCutoff=1/0;initialized=!1;sampleRate;maxCutoff;constructor(e){this.sampleRate=e,this.maxCutoff=e*.45}static initCache(e){Kt.smoothingConstant=Ma*(44100/e);let A=new Kt(e);A.resonanceCb=0;for(let s=1500;s<13500;s++)A.currentInitialFc=s,A.calculateCoefficients(s)}init(){this.lastTargetCutoff=1/0,this.resonanceCb=0,this.currentInitialFc=13500,this.a0=0,this.a1=0,this.a2=0,this.a3=0,this.a4=0,this.x1=0,this.x2=0,this.y1=0,this.y2=0,this.initialized=!1}calculateCoefficients(e){e=e|0;let A=this.resonanceCb,s=Kt.cachedCoefficients.get(A+e*961);if(s!==void 0){this.a0=s.a0,this.a1=s.a1,this.a2=s.a2,this.a3=s.a3,this.a4=s.a4;return}let n=As(e);n=Math.min(n,this.maxCutoff);let a=yA(-(A-3.01)),r=1/Math.sqrt(yA(-A)),o=2*Math.PI*n/this.sampleRate,i=Math.cos(o),g=Math.sin(o)/(2*a),l=(1-i)*r,B=l/2,C=B,I=1+g,E=-2*i,y=1-g,k={a0:B/I,a1:l/I,a2:C/I,a3:E/I,a4:y/I};this.a0=k.a0,this.a1=k.a1,this.a2=k.a2,this.a3=k.a3,this.a4=k.a4,Kt.cachedCoefficients.set(A+e*961,k)}},c=Object.freeze({invalid:-1,startAddrsOffset:0,endAddrOffset:1,startloopAddrsOffset:2,endloopAddrsOffset:3,startAddrsCoarseOffset:4,modLfoToPitch:5,vibLfoToPitch:6,modEnvToPitch:7,initialFilterFc:8,initialFilterQ:9,modLfoToFilterFc:10,modEnvToFilterFc:11,endAddrsCoarseOffset:12,modLfoToVolume:13,chorusEffectsSend:15,reverbEffectsSend:16,pan:17,delayModLFO:21,freqModLFO:22,delayVibLFO:23,freqVibLFO:24,delayModEnv:25,attackModEnv:26,holdModEnv:27,decayModEnv:28,sustainModEnv:29,releaseModEnv:30,keyNumToModEnvHold:31,keyNumToModEnvDecay:32,delayVolEnv:33,attackVolEnv:34,holdVolEnv:35,decayVolEnv:36,sustainVolEnv:37,releaseVolEnv:38,keyNumToVolEnvHold:39,keyNumToVolEnvDecay:40,instrument:41,keyRange:43,velRange:44,startloopAddrsCoarseOffset:45,keyNum:46,velocity:47,initialAttenuation:48,endloopAddrsCoarseOffset:50,coarseTune:51,fineTune:52,sampleID:53,sampleModes:54,scaleTuning:56,exclusiveClass:57,overridingRootKey:58,endOper:60,amplitude:61,vibLfoRate:62,vibLfoAmplitudeDepth:63,vibLfoToFilterFc:64,modLfoRate:65,modLfoAmplitudeDepth:66}),In=Math.max(...Object.values(c)),St=In+1,Ve=Object.freeze({[c.invalid]:{min:0,max:0,def:0,nrpn:0},[c.endOper]:{min:0,max:0,def:0,nrpn:0},[c.instrument]:{min:0,max:0,def:0,nrpn:0},[c.sampleID]:{min:0,max:0,def:0,nrpn:0},[c.keyRange]:{min:0,max:0,def:0,nrpn:0},[c.velRange]:{min:0,max:0,def:0,nrpn:0},[c.startAddrsOffset]:{min:0,max:32768,def:0,nrpn:1},[c.endAddrOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.startloopAddrsOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.endloopAddrsOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.startAddrsCoarseOffset]:{min:0,max:32768,def:0,nrpn:1},[c.modLfoToPitch]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.vibLfoToPitch]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.modEnvToPitch]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.initialFilterFc]:{min:1500,max:13500,def:13500,nrpn:2},[c.initialFilterQ]:{min:0,max:960,def:0,nrpn:1},[c.modLfoToFilterFc]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.modEnvToFilterFc]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.endAddrsCoarseOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.modLfoToVolume]:{min:-960,max:960,def:0,nrpn:1},[c.chorusEffectsSend]:{min:0,max:1e3,def:0,nrpn:1},[c.reverbEffectsSend]:{min:0,max:1e3,def:0,nrpn:1},[c.pan]:{min:-500,max:500,def:0,nrpn:1},[c.delayModLFO]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.freqModLFO]:{min:-16e3,max:4500,def:0,nrpn:4},[c.delayVibLFO]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.freqVibLFO]:{min:-16e3,max:4500,def:0,nrpn:4},[c.delayModEnv]:{min:-32768,max:5e3,def:-32768,nrpn:2},[c.attackModEnv]:{min:-32768,max:8e3,def:-32768,nrpn:2},[c.holdModEnv]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.decayModEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.sustainModEnv]:{min:0,max:1e3,def:0,nrpn:1},[c.releaseModEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.keyNumToModEnvHold]:{min:-1200,max:1200,def:0,nrpn:1},[c.keyNumToModEnvDecay]:{min:-1200,max:1200,def:0,nrpn:1},[c.delayVolEnv]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.attackVolEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.holdVolEnv]:{min:-12e3,max:5e3,def:-12e3,nrpn:2},[c.decayVolEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.sustainVolEnv]:{min:0,max:1440,def:0,nrpn:1},[c.releaseVolEnv]:{min:-12e3,max:8e3,def:-12e3,nrpn:2},[c.keyNumToVolEnvHold]:{min:-1200,max:1200,def:0,nrpn:1},[c.keyNumToVolEnvDecay]:{min:-1200,max:1200,def:0,nrpn:1},[c.startloopAddrsCoarseOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.keyNum]:{min:-1,max:127,def:-1,nrpn:1},[c.velocity]:{min:-1,max:127,def:-1,nrpn:1},[c.initialAttenuation]:{min:0,max:1440,def:0,nrpn:1},[c.endloopAddrsCoarseOffset]:{min:-32768,max:32768,def:0,nrpn:1},[c.coarseTune]:{min:-120,max:120,def:0,nrpn:1},[c.fineTune]:{min:-12700,max:12700,def:0,nrpn:1},[c.scaleTuning]:{min:0,max:1200,def:100,nrpn:1},[c.exclusiveClass]:{min:0,max:99999,def:0,nrpn:0},[c.overridingRootKey]:{min:-1,max:127,def:-1,nrpn:0},[c.sampleModes]:{min:0,max:3,def:0,nrpn:0},[c.amplitude]:{min:-1e3,max:1e3,def:0,nrpn:1},[c.vibLfoRate]:{min:-1e3,max:1e3,def:0,nrpn:1},[c.vibLfoToFilterFc]:{min:-12e3,max:12e3,def:0,nrpn:2},[c.vibLfoAmplitudeDepth]:{min:0,max:1e3,def:0,nrpn:1},[c.modLfoRate]:{min:-1e3,max:1e3,def:0,nrpn:1},[c.modLfoAmplitudeDepth]:{min:0,max:1e3,def:0,nrpn:1}}),Ke=960,iA=900,va=class{outputGain=0;attenuationCb=Ke;state=0;sampleRate;updateInterval;sampleTime=0;releaseStartCb=Ke;releaseStartTimeSamples=0;attackDuration=0;decayDuration=0;releaseDuration=0;sustainCb=0;delayEnd=0;attackEnd=0;holdEnd=0;decayEnd=0;enteredRelease=!1;canEndOnSilentSustain=!1;constructor(t,e){this.sampleRate=t,this.updateInterval=e}startRelease(t){this.releaseStartTimeSamples=this.sampleTime;let e=t.overrideReleaseVolEnv||t.modulatedGenerators[c.releaseVolEnv];if(this.releaseDuration=this.timecentsToSamples(Math.max(-7200,e)),this.enteredRelease)this.releaseStartCb=this.attenuationCb;else{let s=Math.max(0,Math.min(Ke,this.sustainCb)),n=s/Ke,a=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToVolEnvDecay];switch(this.decayDuration=this.timecentsToSamples(t.modulatedGenerators[c.decayVolEnv]+a)*n,this.state){case 0:this.releaseStartCb=Ke;break;case 1:{let r=1-(this.attackEnd-this.releaseStartTimeSamples)/this.attackDuration;this.releaseStartCb=200*Math.log10(r)*-1;break}case 2:this.releaseStartCb=0;break;case 3:this.releaseStartCb=(1-(this.decayEnd-this.releaseStartTimeSamples)/this.decayDuration)*s;break;case 4:this.releaseStartCb=s;break}this.releaseStartCb=Math.max(0,Math.min(this.releaseStartCb,Ke)),this.attenuationCb=this.releaseStartCb}this.enteredRelease=!0;let A=(Ke-this.releaseStartCb)/Ke;this.releaseDuration*=A,this.releaseStartCb>=iA&&(t.isActive=!1)}init(t){this.enteredRelease=!1,this.state=0,this.sampleTime=0,this.outputGain=0,this.canEndOnSilentSustain=t.modulatedGenerators[c.sustainVolEnv]>=iA,this.sustainCb=Math.min(Ke,t.modulatedGenerators[c.sustainVolEnv]),this.attackDuration=this.timecentsToSamples(t.modulatedGenerators[c.attackVolEnv]);let e=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToVolEnvDecay],A=this.sustainCb/Ke;this.decayDuration=this.timecentsToSamples(t.modulatedGenerators[c.decayVolEnv]+e)*A,this.delayEnd=this.timecentsToSamples(t.modulatedGenerators[c.delayVolEnv]),this.attackEnd=this.attackDuration+this.delayEnd;let s=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToVolEnvHold];this.holdEnd=this.timecentsToSamples(t.modulatedGenerators[c.holdVolEnv]+s)+this.attackEnd,this.decayEnd=this.decayDuration+this.holdEnd,this.attackEnd<=this.updateInterval&&(this.state=2)}process(t,e){let{releaseStartTimeSamples:A,releaseStartCb:s,releaseDuration:n,delayEnd:a,attackEnd:r,attackDuration:o,holdEnd:i,decayEnd:g,decayDuration:l,sustainCb:B}=this,C=this.sampleTime+=t;if(this.enteredRelease){let I=C-A,E=Ke-s;return this.attenuationCb=I/n*E+s,this.outputGain=Tt[this.attenuationCb-Pt|0]*e,this.attenuationCb<iA}switch(this.state){case 0:if(C<a)return this.attenuationCb=Ke,this.outputGain=0,!0;this.state++;case 1:if(C<r){this.attenuationCb=0;let I=1-(r-C)/o;return this.outputGain=I*e,!0}this.state++;case 2:if(C<i)return this.attenuationCb=0,this.outputGain=e,!0;this.state++;case 3:if(C<g)return this.attenuationCb=(1-(g-C)/l)*B,this.outputGain=e*Tt[this.attenuationCb-Pt|0],!0;this.state++;case 4:return this.canEndOnSilentSustain&&B>=iA?(this.attenuationCb=Ke,this.outputGain=0,!1):(this.attenuationCb=B,this.outputGain=e*Tt[B-Pt|0],!0)}}timecentsToSamples(t){return Math.max(0,Math.floor(mA(t)*this.sampleRate))}},Fe={monoSample:1,rightSample:2,leftSample:4,linkedSample:8,romMonoSample:32769,romRightSample:32770,romLeftSample:32772,romLinkedSample:32776},Ie={noController:0,noteOnVelocity:2,noteOnKeyNum:3,polyPressure:10,channelPressure:13,pitchWheel:14,pitchWheelRange:16,link:127},le={linear:0,concave:1,convex:2,switch:3};var He=16384,SA=Object.keys(le).length,It=new Float32Array(He+1),yt=new Float32Array(He+1);It[0]=0;It[It.length-1]=1;yt[0]=0;yt[yt.length-1]=1;for(let t=1;t<He-1;t++){let e=-.4166666666666667*Math.log(t/(It.length-1))/Math.LN10;yt[t]=1-e,It[It.length-1-t]=e}function cn(t,e,A){let s=!!(t&2);switch(t&1&&(A=1-A),e){case le.linear:return s?A*2-1:A;case le.switch:return A=A>.5?1:0,s?A*2-1:A;case le.concave:return s?(A=A*2-1,A<0?-It[Math.trunc(A*-He)]:It[Math.trunc(A*He)]):It[Math.trunc(A*He)];case le.convex:return s?(A=A*2-1,A<0?-yt[Math.trunc(A*-He)]:yt[Math.trunc(A*He)]):yt[Math.trunc(A*He)]}}var OA=1,ss=new Float32Array(1e3);for(let t=0;t<ss.length;t++)ss[t]=cn(0,le.convex,t/1e3);var Ga=class{attackDuration=0;decayDuration=0;holdDuration=0;releaseDuration=0;sustainLevel=0;delayEnd=0;attackEnd=0;holdEnd=0;releaseStartLevel=0;currentValue=0;enteredRelease=!1;decayEnd=0;process(t,e){return this.enteredRelease?this.releaseStartLevel===0?0:Math.max(0,(1-(e-t.releaseStartTime)/this.releaseDuration)*this.releaseStartLevel):(e<this.delayEnd?this.currentValue=0:e<this.attackEnd?this.currentValue=ss[~~((1-(this.attackEnd-e)/this.attackDuration)*1e3)]:e<this.holdEnd?this.currentValue=OA:e<this.decayEnd?this.currentValue=(1-(this.decayEnd-e)/this.decayDuration)*(this.sustainLevel-OA)+OA:this.currentValue=this.sustainLevel,this.currentValue)}startRelease(t){this.releaseStartLevel=this.currentValue,this.enteredRelease=!0;let e=this.tc2Sec(Math.max(t.modulatedGenerators[c.releaseModEnv],-7200));this.releaseDuration=e*this.releaseStartLevel}init(t){this.enteredRelease=!1,this.sustainLevel=1-t.modulatedGenerators[c.sustainModEnv]/1e3,this.attackDuration=this.tc2Sec(t.modulatedGenerators[c.attackModEnv]);let e=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToModEnvDecay],A=this.tc2Sec(t.modulatedGenerators[c.decayModEnv]+e);this.decayDuration=A*(1-this.sustainLevel);let s=(60-t.targetKey)*t.modulatedGenerators[c.keyNumToModEnvHold];this.holdDuration=this.tc2Sec(s+t.modulatedGenerators[c.holdModEnv]),this.delayEnd=t.startTime+this.tc2Sec(t.modulatedGenerators[c.delayModEnv]),this.attackEnd=this.delayEnd+this.attackDuration,this.holdEnd=this.attackEnd+this.holdDuration,this.decayEnd=this.holdEnd+this.decayDuration}tc2Sec(t){return t<=-10114?0:mA(t)}},Qs=class{isLooping=!1;sampleData;playbackStep=0;loopStart=0;loopEnd=0;loopLength=0;end=0;cursor=0},La=class extends Qs{process(t,e,A){let s=e*this.playbackStep,n=this.sampleData,{loopEnd:a,loopLength:r,end:o}=this,i=this.cursor;if(this.isLooping)for(let g=0;g<t;g++){i>a&&(i-=r);let l=i|0,B=l+1;B>a&&(B-=r);let C=i-l,I=n[B],E=n[l];A[g]=E+(I-E)*C,i+=s}else for(let g=0;g<t;g++){let l=i|0,B=l+1;if(B>=o)return A.fill(0,g,t),!1;let C=i-l,I=n[B],E=n[l];A[g]=E+(I-E)*C,i+=s}return this.cursor=i,!0}},Na=class extends Qs{process(t,e,A){let s=e*this.playbackStep,n=this.sampleData,{loopEnd:a,loopLength:r,end:o}=this,i=this.cursor;if(this.isLooping)for(let g=0;g<t;g++)i>a&&(i-=r),A[g]=n[i|0],i+=s;else for(let g=0;g<t;g++){if(i>=o)return A.fill(0,g,t),!1;A[g]=n[i|0],i+=s}return this.cursor=i,!0}},Pa=class extends Qs{process(t,e,A){let s=e*this.playbackStep,n=this.sampleData,{loopEnd:a,loopLength:r,end:o}=this,i=this.cursor;if(this.isLooping)for(let g=0;g<t;g++){i>a&&(i-=r);let l=i|0,B=l+1,C=l+2,I=l+3,E=i-l;B>a&&(B-=r),C>a&&(C-=r),I>a&&(I-=r);let y=n[l],k=n[B],p=n[C],R=n[I],b=(p-y)*.5,M=k-p,S=b+M,Q=S+M+(R-k)*.5,m=S+Q;A[g]=((Q*E-m)*E+b)*E+k,i+=s}else for(let g=0;g<t;g++){let l=i|0,B=l+1,C=l+2,I=l+3,E=i-l;if(I>=o)return A.fill(0,g,t),!1;let y=n[l],k=n[B],p=n[C],R=n[I],b=(p-y)*.5,M=k-p,S=b+M,Q=S+M+(R-k)*.5,m=S+Q;A[g]=((Q*E-m)*E+b)*E+k,i+=s}return this.cursor=i,!0}},Ta=-2320,Ua=class{oscillators=[new La,new Na,new Pa];wavetable=this.oscillators[on.interpolationType];filter;generators=new Int16Array(St);modulatedGenerators=new Int16Array(St);modulators=new Array;modulatorValues=new Int16Array(64);modEnv=new Ga;volEnv;resonanceOffset=0;priority=0;isActive=!1;hasRendered=!1;isInRelease=!1;isHeld=!1;channel=0;midiNote=0;targetKey=0;velocity=0;rootKey=0;pressure=0;gainModifier=1;loopingMode=0;startTime=0;releaseStartTime=1/0;tuningCents=0;tuningRatio=1;currentPan=0;portamentoFromKey=-1;portamentoDuration=0;overridePan=0;pitchOffset=0;reverbSend=1;chorusSend=1;delaySend=1;exclusiveClass=0;overrideReleaseVolEnv=0;vibLfoPhase=0;vibLfoStartTime=0;modLfoPhase=0;modLfoStartTime=0;constructor(t,e){this.volEnv=new va(t,e),this.filter=new fs(t)}exclusiveRelease(t,e=Xn){this.overrideReleaseVolEnv=Ta,this.isInRelease=!1,this.releaseVoice(t,e)}releaseVoice(t,e=Vn){this.releaseStartTime=t,this.releaseStartTime-this.startTime<e&&(this.releaseStartTime=this.startTime+e)}setup(t,e,A){this.isActive=!0,this.isInRelease=!1,this.hasRendered=!1,this.isHeld=!1,this.releaseStartTime=1/0,this.pressure=0,this.overrideReleaseVolEnv=0,this.portamentoDuration=0,this.portamentoFromKey=-1,this.vibLfoPhase=.25,this.modLfoPhase=.25,this.startTime=t,this.channel=e,this.midiNote=A}};function pt(t,e){return(t>>e&1)>0}function YA(t){return t?1:0}var st=class ns{isBipolar;isNegative;index;isCC;curveType;constructor(e=Ie.noController,A=le.linear,s=!1,n=!1,a=!1){this.isBipolar=n,this.isNegative=a,this.index=e,this.isCC=s,this.curveType=A}get sourceName(){return this.isCC?Object.keys(f).find(e=>f[e]===this.index)??this.index.toString():Object.keys(Ie).find(e=>Ie[e]===this.index)??this.index.toString()}get curveTypeName(){return Object.keys(le).find(e=>le[e]===this.curveType)??this.curveType.toString()}static fromSourceEnum(e){let A=pt(e,9),s=pt(e,8),n=pt(e,7);return new ns(e&127,e>>10&3,n,A,s)}static copyFrom(e){return new ns(e.index,e.curveType,e.isCC,e.isBipolar,e.isNegative)}toString(){return`${this.sourceName} ${this.curveTypeName} ${this.isBipolar?"bipolar":"unipolar"} ${this.isNegative?"negative":"positive"}`}toSourceEnum(){return this.curveType<<10|YA(this.isBipolar)<<9|YA(this.isNegative)<<8|YA(this.isCC)<<7|this.index}isIdentical(e){return this.index===e.index&&this.isNegative===e.isNegative&&this.isCC===e.isCC&&this.isBipolar===e.isBipolar&&this.curveType===e.curveType}getValue(e,A,s){let n;if(this.isCC)n=e.midiControllers[this.index];else switch(this.index){default:case Ie.noController:n=16383;break;case Ie.noteOnVelocity:n=s.velocity<<7;break;case Ie.noteOnKeyNum:n=s.targetKey<<7;break;case Ie.polyPressure:n=s.pressure<<7;break;case Ie.channelPressure:n=e.midiParameters.pressure<<7;break;case Ie.pitchWheel:n=A;break;case Ie.pitchWheelRange:n=Math.floor(e.midiParameters.pitchWheelRange*128)}let a=(this.isBipolar?2:0)|(this.isNegative?1:0);return hn[He*(this.curveType*SA+a)+n]}},hn=new Float32Array(He*4*SA);for(let t=0;t<SA;t++)for(let e=0;e<4;e++){let A=He*(t*SA+e);for(let s=0;s<He;s++)hn[A+s]=cn(e,t,s/He)}function Ze(t,e,A,s,n){return new st(n,t,s,e,A).toSourceEnum()}var ln=Ze(le.linear,!0,!1,!0,f.filterResonance),ke=class as{destination=c.initialAttenuation;transformAmount=0;transformType=0;primarySource;secondarySource;constructor(e=new st,A=new st,s=c.invalid,n=0,a=0){this.primarySource=e,this.secondarySource=A,this.destination=s,this.transformAmount=n,this.transformType=a}get destinationName(){return Object.keys(c).find(e=>c[e]===this.destination)}static isIdentical(e,A,s=!1){return e.primarySource.isIdentical(A.primarySource)&&e.secondarySource.isIdentical(A.secondarySource)&&e.destination===A.destination&&e.transformType===A.transformType&&(!s||e.transformAmount===A.transformAmount)}static copyFrom(e){return new as(st.copyFrom(e.primarySource),st.copyFrom(e.secondarySource),e.destination,e.transformAmount,e.transformType)}toString(){return`Source: ${this.primarySource.toString()}
|
|
2
2
|
Secondary source: ${this.secondarySource.toString()}
|
|
3
3
|
to: ${this.destinationName}
|
|
4
|
-
amount: ${this.transformAmount}`+(this.transformType===2?"absolute value":"")}write(e,A){Ae(e,this.primarySource.toSourceEnum()),Ae(e,this.destination),Ae(e,this.transformAmount),Ae(e,this.secondarySource.toSourceEnum()),Ae(e,this.transformType),A&&A.mod++}sumTransform(e){let A=as.copyFrom(this);return A.transformAmount+=e.transformAmount,A}},ue=class extends ke{constructor(t,e,A,s,n){super(st.fromSourceEnum(t),st.fromSourceEnum(e),A,s,n),this.destination>In&&(this.destination=c.invalid)}},xa=[new ue(Ze(le.concave,!1,!0,!1,Ie.noteOnVelocity),0,c.initialAttenuation,960,0),new ue(129,0,c.vibLfoToPitch,50,0),new ue(Ze(le.concave,!1,!0,!0,f.mainVolume),0,c.initialAttenuation,960,0),new ue(13,0,c.vibLfoToPitch,50,0),new ue(526,16,c.fineTune,12700,0),new ue(650,0,c.pan,500,0),new ue(Ze(le.concave,!1,!0,!0,f.expression),0,c.initialAttenuation,960,0),new ue(219,0,c.reverbEffectsSend,200,0),new ue(221,0,c.chorusEffectsSend,200,0)],Ha=[new ue(Ze(le.convex,!0,!1,!0,f.attackTime),0,c.attackVolEnv,6e3,0),new ue(Ze(le.linear,!0,!1,!0,f.releaseTime),0,c.releaseVolEnv,3600,0),new ue(Ze(le.linear,!0,!1,!0,f.decayTime),0,c.decayVolEnv,3600,0),new ue(Ze(le.linear,!0,!1,!0,f.brightness),0,c.initialFilterFc,9600,0),new ue(ln,0,c.initialFilterQ,250,0),new ue(Ze(le.switch,!1,!1,!0,f.softPedal),0,c.initialAttenuation,50,0),new ue(Ze(le.switch,!1,!1,!0,f.softPedal),0,c.initialFilterFc,-2400,0),new ue(Ze(le.linear,!0,!1,!0,f.balance),0,c.pan,500,0)],Cn=[...xa,...Ha],Ge=class{type;value=0;constructor(t,e,A=!0){if(this.type=t,e===void 0)throw new Error("No value provided.");if(this.value=Math.round(e),A){let s=Ve[t];s!==void 0&&(this.value=Math.max(s.min,Math.min(s.max,this.value)))}}write(t){Ae(t,this.type),Ae(t,this.value)}toString(){return`${Object.keys(c).find(t=>c[t]===this.type)}: ${this.value}`}},zt=class{velRange={min:-1,max:127};keyRange={min:-1,max:127};generators=[];modulators=[];get hasKeyRange(){return this.keyRange.min!==-1}get hasVelRange(){return this.velRange.min!==-1}get fineTuning(){let t=this.getGenerator(c.coarseTune,0),e=this.getGenerator(c.fineTune,0);return t*100+e}set fineTuning(t){let e=Math.trunc(t/100),A=t%100;this.setGenerator(c.coarseTune,e),this.setGenerator(c.fineTune,A)}addToGenerator(t,e,A=!0){let s=this.getGenerator(t,Ve[t].def);this.setGenerator(t,e+s,A)}setGenerator(t,e,A=!0){switch(t){case c.sampleID:throw new Error("Use setSample()");case c.instrument:throw new Error("Use setInstrument()");case c.velRange:case c.keyRange:throw new Error("Set the range manually")}if(e===null){this.generators=this.generators.filter(n=>n.type!==t);return}let s=this.generators.findIndex(n=>n.type===t);s===-1?this.addGenerators(new Ge(t,e,A)):this.generators[s]=new Ge(t,e,A)}addGenerators(...t){for(let e of t)switch(e.type){default:this.generators.push(e);break;case c.sampleID:case c.instrument:break;case c.velRange:this.velRange.min=e.value&127,this.velRange.max=e.value>>8&127;break;case c.keyRange:this.keyRange.min=e.value&127,this.keyRange.max=e.value>>8&127}}addModulators(...t){this.modulators.push(...t)}getGenerator(t,e){return this.generators.find(A=>A.type===t)?.value??e}copyFrom(t){this.generators=t.generators.map(e=>new Ge(e.type,e.value,!1)),this.modulators=t.modulators.map(ke.copyFrom.bind(ke)),this.velRange={...t.velRange},this.keyRange={...t.keyRange}}getWriteGenerators(t){let e=this.generators.filter(A=>A.type!==c.sampleID&&A.type!==c.instrument&&A.type!==c.keyRange&&A.type!==c.velRange);if(!t)throw new Error("No bank provided! ");return this.hasVelRange&&e.unshift(new Ge(c.velRange,this.velRange.max<<8|Math.max(this.velRange.min,0),!1)),this.hasKeyRange&&e.unshift(new Ge(c.keyRange,this.keyRange.max<<8|Math.max(this.keyRange.min,0),!1)),e}},Oa=48e3,MA=class{name;sampleRate;originalKey;pitchCorrection;linkedSample;sampleType;loopStart;loopEnd;linkedTo=[];dataOverridden=!0;compressedData;audioData;constructor(t,e,A,s,n,a,r){this.name=t,this.sampleRate=e,this.originalKey=A,this.pitchCorrection=s,this.loopStart=a,this.loopEnd=r,this.sampleType=n}get isCompressed(){return this.compressedData!==void 0}get isLinked(){return this.sampleType===Fe.rightSample||this.sampleType===Fe.leftSample||this.sampleType===Fe.linkedSample}get useCount(){return this.linkedTo.length}getRawData(t){return this.compressedData&&t&&!this.dataOverridden?this.compressedData:this.encodeS16LE()}resampleData(t){let e=this.getAudioData(),A=t/this.sampleRate,s=new Float32Array(Math.floor(e.length*A));for(let n=0;n<s.length;n++)s[n]=e[Math.floor(n*(1/A))];e=s,this.sampleRate=t,this.loopStart=Math.floor(this.loopStart*A),this.loopEnd=Math.floor(this.loopEnd*A),this.audioData=e}async compressSample(t){if(!this.isCompressed)try{let e=this.getAudioData();(this.sampleRate<8e3||this.sampleRate>96e3)&&(this.resampleData(Oa),e=this.getAudioData());let A=await t(e,this.sampleRate);this.setCompressedData(A)}catch(e){h.warn(`Failed to compress ${this.name}. Leaving as uncompressed!`,e),this.compressedData=void 0}}setSampleType(t){if(this.sampleType=t,this.isLinked||(this.linkedSample&&(this.linkedSample.linkedSample=void 0,this.linkedSample.sampleType=t),this.linkedSample=void 0),(t&32768)>0)throw new Error("ROM samples are not supported.")}unlinkSample(){this.setSampleType(Fe.monoSample)}setLinkedSample(t,e){if(t.linkedSample)throw new Error(`${t.name} is linked tp ${t.linkedSample.name}. Unlink it first.`);switch(this.linkedSample=t,t.linkedSample=this,e){case Fe.leftSample:this.setSampleType(Fe.leftSample),t.setSampleType(Fe.rightSample);break;case Fe.rightSample:this.setSampleType(Fe.rightSample),t.setSampleType(Fe.leftSample);break;case Fe.linkedSample:this.setSampleType(Fe.linkedSample),t.setSampleType(Fe.linkedSample);break;default:throw new Error("Invalid sample type: "+e)}}linkTo(t){this.linkedTo.push(t)}unlinkFrom(t){let e=this.linkedTo.indexOf(t);if(e===-1){h.warn(`Cannot unlink ${t.name} from ${this.name}: not linked.`);return}this.linkedTo.splice(e,1)}getAudioData(){if(this.audioData)return this.audioData;if(this.isCompressed)return this.audioData=this.decodeVorbis(),this.audioData;throw new Error("Sample data is undefined for a BasicSample instance.")}setAudioData(t,e){this.audioData=t,this.sampleRate=e,this.dataOverridden=!0,this.compressedData=void 0}setCompressedData(t){this.audioData=void 0,this.compressedData=t,this.dataOverridden=!1}encodeS16LE(){let t=this.getAudioData(),e=new Int16Array(t.length),A=t.length;for(let s=0;s<A;s++){let n=t[s]*32768;n>32767?n=32767:n<-32768&&(n=-32768),e[s]=n}return new ee(e.buffer)}decodeVorbis(){if(this.audioData)return this.audioData;if(!this.compressedData)throw new Error("Compressed data is missing.");try{let t=FA.decode(this.compressedData).data[0];if(t===void 0)return h.warn(`Error decoding sample ${this.name}: Vorbis decode returned undefined.`),new Float32Array(0);for(let e=0;e<t.length;e++)t[e]=Math.max(-1,Math.min(t[e],.999969482421875));return t}catch(t){return h.warn(`Error decoding sample ${this.name}: ${t}`),new Float32Array(this.loopEnd+1)}}},Ya=class extends MA{constructor(){super("",44100,60,0,Fe.monoSample,0,0)}},Bn=class extends zt{parentInstrument;useCount;constructor(t,e){super(),this.parentInstrument=t,this._sample=e,e.linkTo(this.parentInstrument),this.useCount=t.useCount}_sample;get sample(){return this._sample}set sample(t){this._sample&&this._sample.unlinkFrom(this.parentInstrument),this._sample=t,t.linkTo(this.parentInstrument)}getWriteGenerators(t){let e=super.getWriteGenerators(t),A=t.samples.indexOf(this.sample);if(A===-1)throw new Error(`${this.sample.name} does not exist in ${t.soundBankInfo.name}! Cannot write sampleID generator.`);return e.push(new Ge(c.sampleID,A,!1)),e}},En=class extends zt{parentPreset;constructor(t,e){super(),this.parentPreset=t,this._instrument=e,this._instrument.linkTo(this.parentPreset)}_instrument;get instrument(){return this._instrument}set instrument(t){this._instrument&&this._instrument.unlinkFrom(this.parentPreset),this._instrument=t,this._instrument.linkTo(this.parentPreset)}getWriteGenerators(t){let e=super.getWriteGenerators(t);if(!t)throw new Error("Instrument ID cannot be determined without the sound bank itself.");let A=t.instruments.indexOf(this.instrument);if(A===-1)throw new Error(`${this.instrument.name} does not exist in ${t.soundBankInfo.name}! Cannot write instrument generator.`);return e.push(new Ge(c.instrument,A,!1)),e}},rs=new Int16Array(St);for(let t=0;t<rs.length;t++)Ve[t]&&(rs[t]=Ve[t].def);var _t=class at{parentSoundBank;name="";program=0;bankMSB=0;bankLSB=0;isGMGSDrum=!1;zones=[];globalZone;library=0;genre=0;morphology=0;constructor(e,A=new zt){this.parentSoundBank=e,this.globalZone=A}get isDrum(){let e=this.parentSoundBank.isXGBank;return this.isGMGSDrum||e&&Se.isXGDrum(this.bankMSB)}static isInRange(e,A){return A>=e.min&&A<=e.max}static addUniqueModulators(e,A){for(let s of A)e.some(n=>ke.isIdentical(s,n))||e.push(s)}static subtractRanges(e,A){return{min:Math.max(e.min,A.min),max:Math.min(e.max,A.max)}}delete(){for(let e of this.zones)e.instrument?.unlinkFrom(this)}deleteZone(e){this.zones[e]?.instrument?.unlinkFrom(this),this.zones.splice(e,1)}createZone(e){let A=new En(this,e);return this.zones.push(A),A}preload(e,A){for(let s=e;s<A+1;s++)for(let n=0;n<128;n++)for(let a of this.getVoiceParameters(s,n))a.sample.getAudioData()}matches(e){return ze.matches(this,e)}getVoiceParameters(e,A){let s=new Array;for(let n of this.zones){if(!at.isInRange(n.hasKeyRange?n.keyRange:this.globalZone.keyRange,e)||!at.isInRange(n.hasVelRange?n.velRange:this.globalZone.velRange,A))continue;let a=n.instrument;if(!a||a.zones.length===0)continue;let r=new Int16Array(St);for(let o of this.globalZone.generators)r[o.type]=o.value;for(let o of n.generators)r[o.type]=o.value;let i=[...n.modulators];at.addUniqueModulators(i,this.globalZone.modulators);for(let o of a.zones){if(!at.isInRange(o.hasKeyRange?o.keyRange:a.globalZone.keyRange,e)||!at.isInRange(o.hasVelRange?o.velRange:a.globalZone.velRange,A))continue;let g=[...o.modulators];at.addUniqueModulators(g,a.globalZone.modulators),at.addUniqueModulators(g,this.parentSoundBank.defaultModulators);for(let C of i){let B=g.findIndex(I=>ke.isIdentical(C,I));B===-1?g.push(C):g[B]=g[B].sumTransform(C)}let l=new Int16Array(rs);for(let C of a.globalZone.generators)l[C.type]=C.value;for(let C of o.generators)l[C.type]=C.value;for(let C=0;C<l.length;C++)l[C]=Math.max(-32768,Math.min(32767,l[C]+r[C]));l[c.initialAttenuation]=Math.floor(l[c.initialAttenuation]*.4),s.push({sample:o.sample,generators:l,modulators:g})}}return s}toMIDIString(){return ze.toMIDIString(this)}toString(){return ze.toFullMIDIString(this)}toFlattenedInstrument(){let e=(g,l)=>{g.push(...l.filter(C=>!g.some(B=>B.type===C.type)))},A=(g,l)=>{g.push(...l.filter(C=>!g.some(B=>ke.isIdentical(C,B))))},s=new Wt;s.name=this.name;let n=[],a=[],r=this.globalZone;n.push(...r.generators),a.push(...r.modulators);let i=r.keyRange,o=r.velRange;for(let g of this.zones){if(!g.instrument)throw new Error("No instrument in a preset zone.");let l=g.keyRange;g.hasKeyRange||(l=i);let C=g.velRange;g.hasVelRange||(C=o);let B=g.generators.map(S=>new Ge(S.type,S.value));e(B,n);let I=[...g.modulators];A(I,a);let E=g.instrument,m=E.zones,k=[],y=[],b=E.globalZone;k.push(...b.generators),y.push(...b.modulators);let R=b.keyRange,M=b.velRange;for(let S of m){if(!S.sample)throw new Error("No sample in an instrument zone.");let Q=S.keyRange;S.hasKeyRange||(Q=R);let p=S.velRange;if(S.hasVelRange||(p=M),Q=at.subtractRanges(Q,l),p=at.subtractRanges(p,C),Q.max<Q.min||p.max<p.min)continue;let D=S.generators.map(H=>new Ge(H.type,H.value));e(D,k);let q=[...S.modulators];A(q,y);let K=[...q];for(let H of I){let Z=K.findIndex(T=>ke.isIdentical(H,T));Z===-1?K.push(H):K[Z]=K[Z].sumTransform(H)}let O=D.map(H=>new Ge(H.type,H.value));for(let H of B){if(H.type===c.velRange||H.type===c.keyRange||H.type===c.instrument||H.type===c.endOper||H.type===c.sampleModes)continue;let Z=D.findIndex(T=>T.type===H.type);if(Z===-1){let T=Ve[H.type].def+H.value;O.push(new Ge(H.type,T))}else{let T=O[Z].value+H.value;O[Z]=new Ge(H.type,T)}}O=O.filter(H=>H.type!==c.sampleID&&H.type!==c.keyRange&&H.type!==c.velRange&&H.type!==c.endOper&&H.type!==c.instrument&&(!(H.type in Ve)||H.value!==Ve[H.type].def));let Y=s.createZone(S.sample);Y.keyRange=Q,Y.velRange=p,Y.keyRange.min===0&&Y.keyRange.max===127&&(Y.keyRange.min=-1),Y.velRange.min===0&&Y.velRange.max===127&&(Y.velRange.min=-1),Y.addGenerators(...O),Y.addModulators(...K)}}return s}write(e,A){h.info(`%cWriting ${this.name}...`,d.info),Le(e.pdta,this.name.slice(0,20),20),Le(e.xdta,this.name.slice(20),20),Ae(e.pdta,this.program);let s=this.bankMSB;this.isGMGSDrum?s=128:this.bankMSB===0&&(s=this.bankLSB),Ae(e.pdta,s),e.xdta.currentIndex+=4,Ae(e.pdta,A&65535),Ae(e.xdta,A>>16),ge(e.pdta,this.library),ge(e.pdta,this.genre),ge(e.pdta,this.morphology),e.xdta.currentIndex+=12}},qa=new Set([c.velRange,c.keyRange,c.instrument,c.sampleID,c.exclusiveClass,c.endOper,c.sampleModes,c.startloopAddrsOffset,c.startloopAddrsCoarseOffset,c.endloopAddrsOffset,c.endloopAddrsCoarseOffset,c.startAddrsOffset,c.startAddrsCoarseOffset,c.endAddrOffset,c.endAddrsCoarseOffset,c.initialAttenuation,c.fineTune,c.coarseTune,c.keyNumToVolEnvHold,c.keyNumToVolEnvDecay,c.keyNumToModEnvHold,c.keyNumToModEnvDecay]),Wt=class{name="";zones=[];globalZone=new zt;linkedTo=[];get useCount(){return this.linkedTo.length}createZone(t){let e=new Bn(this,t);return this.zones.push(e),e}linkTo(t){this.linkedTo.push(t);for(let e of this.zones)e.useCount++}unlinkFrom(t){let e=this.linkedTo.indexOf(t);if(e===-1){h.warn(`Cannot unlink ${t.name} from ${this.name}: not linked.`);return}this.linkedTo.splice(e,1);for(let A of this.zones)A.useCount--}deleteUnusedZones(){this.zones=this.zones.filter(t=>{let e=t.useCount>0;return e||t.sample.unlinkFrom(this),e})}delete(){if(this.useCount>0)throw new Error(`Cannot delete an instrument that is used by: ${this.linkedTo.map(t=>t.name).toString()}.`);for(let t of this.zones)t.sample.unlinkFrom(this)}deleteZone(t,e=!1){let A=this.zones[t];return A.useCount-=1,A.useCount<1||e?(A.sample.unlinkFrom(this),this.zones.splice(t,1),!0):!1}globalize(){let t=this.globalZone;for(let A=0;A<58;A++){if(qa.has(A))continue;A=A;let s={},n=Ve[A]?.def||0;s[n]=0;for(let a of this.zones){let r=a.getGenerator(A,void 0);r===void 0?s[n]++:s[r]===void 0?s[r]=1:s[r]++;let i;switch(A){default:continue;case c.decayVolEnv:i=c.keyNumToVolEnvDecay;break;case c.holdVolEnv:i=c.keyNumToVolEnvHold;break;case c.decayModEnv:i=c.keyNumToModEnvDecay;break;case c.holdModEnv:i=c.keyNumToModEnvHold}if(a.getGenerator(i,void 0)!==void 0){s={};break}}if(Object.keys(s).length>0){let a=["0",0];for(let[i,o]of Object.entries(s))o>a[1]&&(a=[i,o]);let r=Number.parseInt(a[0]);r!==n&&t.setGenerator(A,r,!1);for(let i of this.zones){let o=i.getGenerator(A,void 0);o===void 0?r!==n&&i.setGenerator(A,n):o===r&&i.setGenerator(A,null)}}}let e=this.zones.length===0?[]:this.zones[0].modulators.map(A=>ke.copyFrom(A));for(let A of e){let s=!0;for(let n of this.zones)s&&(n.modulators.find(a=>ke.isIdentical(a,A))||(s=!1));if(s){t.addModulators(ke.copyFrom(A));for(let n of this.zones){let a=n.modulators.find(r=>ke.isIdentical(r,A));a&&a.transformAmount===A.transformAmount&&n.modulators.splice(n.modulators.indexOf(a),1)}}}}write(t,e){h.info(`%cWriting ${this.name}...`,d.info),Le(t.pdta,this.name.slice(0,20),20),Le(t.xdta,this.name.slice(20),20),Ae(t.pdta,e&65535),Ae(t.xdta,e>>>16)}};function Ja(t,e,A,s){let n=0,a=[],r=[];for(let l of t.samples){let C=l.getRawData(!0);n++,s?.(n/t.samples.length),h.info(`%cWrote sample %c${n}. ${l.name}%c of %c${t.samples.length}.`,d.info,d.recognized,d.info,d.recognized),a.push(C),r.push(C.length),l.isCompressed||a.push(new Uint8Array(92))}let i=U.getParts("smpl",a),o=U.getParts("sdta",i,!0),g=0;for(let[l,C]of t.samples.entries()){let B=r[l],I,E;C.isCompressed?(I=g,E=I+B):(I=g/2,E=I+B/2,g+=92),g+=B,e.push(I),A.push(E)}return o}var Ka=class extends MA{linkedSampleIndex;s16leData;startByteOffset;endByteOffset;sampleID;constructor(t,e,A,s,n,a,r,i,o,g,l,C){let B=(g&16)>0;g&=-17,super(t,a,r,i,g,s-e/2,n-e/2),this.dataOverridden=!1,this.name=t,this.startByteOffset=e,this.endByteOffset=A,this.sampleID=C;let I=l instanceof ee?l.currentIndex:0;l instanceof ee?B?(this.loopStart+=this.startByteOffset/2,this.loopEnd+=this.startByteOffset/2,this.setCompressedData(l.slice(this.startByteOffset/2+I,this.endByteOffset/2+I))):this.s16leData=l.slice(I+this.startByteOffset,I+this.endByteOffset):this.setAudioData(l.slice(this.startByteOffset/2,this.endByteOffset/2),a),this.linkedSampleIndex=o}getLinkedSample(t){if(this.linkedSample||!this.isLinked)return;let e=t[this.linkedSampleIndex];e?e.linkedSample?(h.info(`%cInvalid linked sample for ${this.name}: ${e.name} is already linked to ${e.linkedSample.name}`,d.warn),this.unlinkSample()):this.setLinkedSample(e,this.sampleType):(h.info(`%cInvalid linked sample for ${this.name}. Setting to mono.`,d.warn),this.unlinkSample())}getAudioData(){if(this.audioData)return this.audioData;if(this.isCompressed)return super.getAudioData();if(!this.s16leData)throw console.error(this),new Error("Unexpected lack of audio data.");let t=this.endByteOffset-this.startByteOffset;if(t<1)return h.warn(`Invalid sample ${this.name}! Invalid length: ${t}`),new Float32Array(1);let e=new Float32Array(t/2),A=new Int16Array(this.s16leData.buffer);for(let[s,n]of A.entries())e[s]=n/32768;return this.audioData=e,e}getRawData(t){return this.dataOverridden||this.compressedData?super.getRawData(t):this.s16leData??new Uint8Array(0)}};function Ms(t,e,A=!0){let s=[],n=0;for(;t.data.length>t.data.currentIndex;){let a=Va(n,t.data,e);s.push(a),n++}if(s.pop(),A)for(let a of s)a.getLinkedSample(s);return s}function Va(t,e,A){let s=Ee(e,20),n=V(e,4)*2,a=V(e,4)*2,r=V(e,4),i=V(e,4),o=V(e,4),g=e[e.currentIndex++];g>127&&(g=60);let l=Yn(e[e.currentIndex++]),C=V(e,2),B=V(e,2);return new Ka(s,n,a,r,i,o,g,l,C,B,A,t)}function Xa(t,e,A){let n=46*(t.samples.length+1),a=new ee(n),r=new ee(n),i=0;for(let[o,g]of t.samples.entries()){Le(a,g.name.slice(0,20),20),Le(r,g.name.slice(20),20);let l=e[o];ge(a,l),r.currentIndex+=4;let C=A[o];ge(a,C),r.currentIndex+=4;let B=g.loopStart+l,I=g.loopEnd+l;g.isCompressed&&(B-=l,I-=l),ge(a,B),ge(a,I),ge(a,g.sampleRate),a[a.currentIndex++]=g.originalKey,a[a.currentIndex++]=g.pitchCorrection,r.currentIndex+=14;let E=g.linkedSample?t.samples.indexOf(g.linkedSample):0;Ae(a,Math.max(0,E)&65535),Ae(r,Math.max(0,E)>>16),i=Math.max(i,E);let m=g.sampleType;g.isCompressed&&(m|=16),Ae(a,m),r.currentIndex+=2}return Le(a,"EOS",46),Le(r,"EOS",46),{pdta:U.write("shdr",a),xdta:U.write("shdr",r)}}function vs(t,e=!1){let A=e?t.presets:t.instruments,s=e?"pgen":"igen",n=e?"pmod":"imod",a=e?"pbag":"ibag",r=e?"phdr":"inst",i=e?38:22,o=0,g=new Array,l=0,C=new Array,B=new Array,I=new Array,E=0,m=new Array,k=p=>{g.push(o);let D=p.getWriteGenerators(t);o+=D.length,B.push(...D),C.push(l);let q=p.modulators;l+=q.length,I.push(...q)};for(let p of A){m.push(E),k(p.globalZone);for(let D of p.zones)k(D);E+=p.zones.length+1}B.push(new Ge(0,0,!1)),I.push(new ue(0,0,0,0,0)),g.push(o),C.push(l),m.push(E);let y=new ee(B.length*4);for(let p of B)p.write(y);let b=new ee(I.length*10);for(let p of I)p.write(b);let R=C.length*4,M={pdta:new ee(R),xdta:new ee(R)};for(let[p,D]of C.entries()){let q=g[p];Ae(M.pdta,q&65535),Ae(M.pdta,D&65535),Ae(M.xdta,q>>16),Ae(M.xdta,D>>16)}let S=(A.length+1)*i,Q={pdta:new ee(S),xdta:new ee(S)};for(let[p,D]of A.entries())D.write(Q,m[p]);return e?(Le(Q.pdta,"EOP",20),Q.pdta.currentIndex+=4,Ae(Q.pdta,E&65535),Q.pdta.currentIndex+=12,Le(Q.xdta,"",20),Q.xdta.currentIndex+=4,Ae(Q.xdta,E>>16),Q.xdta.currentIndex+=12):(Le(Q.pdta,"EOI",20),Ae(Q.pdta,E&65535),Le(Q.xdta,"",20),Ae(Q.xdta,E>>16)),{writeXdta:Math.max(o,l,E)>65535,gen:{pdta:U.write(s,y),xdta:U.write(n,new ee(4))},mod:{pdta:U.write(n,b),xdta:U.write(n,new ee(10))},bag:{pdta:U.write(a,M.pdta),xdta:U.write(a,M.xdta)},hdr:{pdta:U.write(r,Q.pdta),xdta:U.write(r,Q.xdta)}}}var dn={writeDefaultModulators:!0,writeExtendedLimits:!0,software:"SpessaSynth"};function Za(t,e){let A=bA(e,dn);h.groupCollapsed("%cSaving soundbank...",d.info),h.group("%cWriting INFO...",d.info);let s=[],n=(y,b)=>{b&&s.push(...U.getParts(y,[$e(b,!0,!0)]))},a=t.soundBankInfo;{let y=new ee(4);Ae(y,a.version.major),Ae(y,a.version.minor),s.push(U.write("ifil",y))}if(n("isng",a.soundEngine),n("INAM",a.name),n("irom",a.romInfo),a.romVersion){let y=new ee(4);Ae(y,a.romVersion.major),Ae(y,a.romVersion.minor),s.push(U.write("iver",y))}n("ICRD",Bs(a.creationDate)),n("IENG",a.engineer),n("IPRD",a.product),n("ICOP",a.copyright),n("ICMT",a?.subject?(a?.comment?a.comment+`
|
|
5
|
-
`:"")+a.subject:a?.comment);let r=A.software;if(n("ISFT",r),t.defaultModulators.some(y=>!Cn.some(b=>ke.isIdentical(b,y,!0)))&&A?.writeDefaultModulators){let y=t.defaultModulators;h.info(`%cWriting %c${y.length}%c default modulators...`,d.info,d.recognized,d.info);let b=new ee(10+y.length*10);for(let R of y)R.write(b);hs(b,0,10),s.push(...U.getParts("DMOD",[b]))}h.groupEnd(),h.info("%cWriting SDTA...",d.info);let i=[],o=[],g=Ja(t,i,o);h.info("%cWriting PDTA...",d.info),h.info("%cWriting SHDR...",d.info);let l=Xa(t,i,o);h.group("%cWriting instruments...",d.info);let C=vs(t,!1);h.groupEnd(),h.group("%cWriting presets...",d.info);let B=vs(t,!0);h.groupEnd();let I=[B.hdr,B.bag,B.mod,B.gen,C.hdr,C.bag,C.mod,C.gen,l],E=U.getParts("pdta",I.map(y=>y.pdta),!0);A.writeExtendedLimits&&(C.writeXdta||B.writeXdta||t.presets.some(y=>y.name.length>20)||t.instruments.some(y=>y.name.length>20)||t.samples.some(y=>y.name.length>20))&&(h.info("%cWriting the xdta chunk as writeExtendedLimits is enabled and at least one condition was met.",d.info,d.value),s.push(...U.getParts("xdta",I.map(y=>y.xdta),!0)));let m=U.getParts("INFO",s,!0);h.info("%cWriting the output file...",d.info);let k=U.writeParts("RIFF",[$e("sfbk"),...m,...g,...E]);return h.info(`%cSaved successfully! Final file size: %c${k.length}`,d.info,d.recognized),h.groupEnd(),k.buffer}var Ht=class{static verifyHeader(t,...e){for(let A of e)if(t.header.toLowerCase()===A.toLowerCase())return;this.parsingError(`Invalid DLS chunk header! Expected "${e.join(", or ")}" got "${t.header.toLowerCase()}"`)}static verifyText(t,...e){for(let A of e)if(t.toLowerCase()===A.toLowerCase())return;this.parsingError(`FourCC error: Expected "${e.join(", or ")}" got "${t.toLowerCase()}"`)}static parsingError(t){throw h.groupEnd(),new Error(`DLS parse error: ${t} The file may be corrupted.`)}static verifyAndReadList(t,...e){this.verifyHeader(t,"LIST"),t.data.currentIndex=0,this.verifyText(Ee(t.data,4),...e);let A=[];for(;t.data.length>t.data.currentIndex;)A.push(U.read(t.data));return A}},X={none:0,modLfo:1,velocity:2,keyNum:3,volEnv:4,modEnv:5,pitchWheel:6,polyPressure:7,channelPressure:8,vibratoLfo:9,modulationWheel:129,volume:135,pan:138,expression:139,chorus:221,reverb:219,pitchWheelRange:256,fineTune:257,coarseTune:258},N={none:0,gain:1,reserved:2,pitch:3,pan:4,keyNum:5,chorusSend:128,reverbSend:129,modLfoFreq:260,modLfoDelay:261,vibLfoFreq:276,vibLfoDelay:277,volEnvAttack:518,volEnvDecay:519,reservedEG1:520,volEnvRelease:521,volEnvSustain:522,volEnvDelay:523,volEnvHold:524,modEnvAttack:778,modEnvDecay:779,reservedEG2:780,modEnvRelease:781,modEnvSustain:782,modEnvDelay:783,modEnvHold:784,filterCutoff:1280,filterQ:1281},Gs={forward:0,loopAndRelease:1},oA=20,gA=16,Ut=class Vt extends Ht{gain=0;unityNote=60;fineTune=0;loops=new Array;fulOptions=2;static copyFrom(e){let A=new Vt;return A.unityNote=e.unityNote,A.gain=e.gain,A.fineTune=e.fineTune,A.loops=e.loops.map(s=>({...s})),A.fulOptions=e.fulOptions,A}static read(e){this.verifyHeader(e,"wsmp");let A=new Vt,s=V(e.data,4);if(s!==oA&&h.warn(`Wsmp cbSize mismatch: got ${s}, expected ${oA}.`),A.unityNote=V(e.data,2),A.fineTune=ls(e.data[e.data.currentIndex++],e.data[e.data.currentIndex++]),A.gain=V(e.data,4)|0,A.fulOptions=V(e.data,4),V(e.data,4)!==0){let n=V(e.data,4);n!==gA&&h.warn(`CbSize for loop in wsmp mismatch. Expected ${gA}, got ${n}.`);let a=V(e.data,4),r=V(e.data,4),i=V(e.data,4);A.loops.push({loopStart:r,loopLength:i,loopType:a})}return A}static fromSFSample(e){let A=new Vt;return A.unityNote=e.originalKey,A.fineTune=e.pitchCorrection,(e.loopEnd!==0||e.loopStart!==0)&&A.loops.push({loopStart:e.loopStart,loopLength:e.loopEnd-e.loopStart,loopType:Gs.forward}),A}static fromSFZone(e){let A=new Vt;A.unityNote=e.getGenerator(c.overridingRootKey,e.sample.originalKey),e.getGenerator(c.scaleTuning,100)===0&&e.keyRange.max-e.keyRange.min===0&&(A.unityNote=e.keyRange.min),A.fineTune=e.fineTuning+e.sample.pitchCorrection,A.gain=-(e.getGenerator(c.initialAttenuation,0)*.4)<<16;let s=e.getGenerator(c.sampleModes,0);if(s!==0){let n=e.sample.loopStart+e.getGenerator(c.startloopAddrsOffset,0)+e.getGenerator(c.startloopAddrsCoarseOffset,0)*32768,a=e.sample.loopEnd+e.getGenerator(c.endloopAddrsOffset,0)+e.getGenerator(c.endloopAddrsCoarseOffset,0)*32768,r;switch(s){case 1:default:r=0;break;case 3:r=1}A.loops.push({loopType:r,loopStart:n,loopLength:a-n})}return A}toSFZone(e,A){let s=0,n=this.loops[0];n&&(s=n.loopType===Gs.loopAndRelease?3:1),s!==0&&e.setGenerator(c.sampleModes,s);let a=-(this.gain>>16)/.4;if(a!==0&&e.setGenerator(c.initialAttenuation,a),e.fineTuning=this.fineTune-A.pitchCorrection,this.unityNote!==A.originalKey&&e.setGenerator(c.overridingRootKey,this.unityNote),n){let r=n.loopStart-A.loopStart,i=n.loopStart+n.loopLength-A.loopEnd;if(r!==0){let o=r%32768;e.setGenerator(c.startloopAddrsOffset,o);let g=Math.trunc(r/32768);g!==0&&e.setGenerator(c.startloopAddrsCoarseOffset,g)}if(i!==0){let o=i%32768;e.setGenerator(c.endloopAddrsOffset,o);let g=Math.trunc(i/32768);g!==0&&e.setGenerator(c.endloopAddrsCoarseOffset,g)}}}write(){let e=new ee(oA+this.loops.length*gA);ge(e,oA),Ae(e,this.unityNote),Ae(e,this.fineTune),ge(e,this.gain),ge(e,this.fulOptions),ge(e,this.loops.length);for(let A of this.loops)ge(e,gA),ge(e,A.loopType),ge(e,A.loopStart),ge(e,A.loopLength);return U.write("wsmp",e)}},qA={PCM:1,ALAW:6};function _a(t,e){let A=Math.pow(2,e*8-1),s=Math.pow(2,e*8),n,a=!1;e===1?(n=255,a=!0):n=A;let r=t.length/e,i=new Float32Array(r);if(e===2){let o=new Int16Array(t.buffer);for(let[g,l]of o.entries())i[g]=l/32768}else for(let o=0;o<i.length;o++){let g=V(t,e);a?i[o]=g/n-.5:(g>=A&&(g-=s),i[o]=g/n)}return i}function Wa(t,e){let A=t.length/e,s=new Float32Array(A);for(let n=0;n<s.length;n++){let a=V(t,e),r=a^85;r&=127;let i=r>>4,o=r&15;i>0&&(o+=16),o=(o<<4)+8,i>1&&(o=o<<i-1),s[n]=(a>127?o:-o)/32768}return s}var za=class extends MA{wFormatTag;bytesPerSample;rawData;constructor(t,e,A,s,n,a,r,i,o){super(t,e,A,s,Fe.monoSample,n,a),this.dataOverridden=!1,this.rawData=r.data,this.wFormatTag=i,this.bytesPerSample=o}getAudioData(){if(!this.rawData)return new Float32Array(0);if(!this.audioData){let t;switch(this.wFormatTag){default:h.warn(`Failed to decode sample. Unknown wFormatTag: ${this.wFormatTag}`),t=new Float32Array(this.rawData.length/this.bytesPerSample);break;case qA.PCM:t=_a(this.rawData,this.bytesPerSample);break;case qA.ALAW:t=Wa(this.rawData,this.bytesPerSample);break}this.setAudioData(t,this.sampleRate)}return this.audioData??new Float32Array(0)}getRawData(t){return this.dataOverridden||this.isCompressed?super.getRawData(t):this.wFormatTag===qA.PCM&&this.bytesPerSample===2?this.rawData:this.encodeS16LE()}},Ls=class is extends Ht{waveSample=new Ut;wFormatTag;bytesPerSample;sampleRate;dataChunk;name="Unnamed sample";constructor(e,A,s,n){super(),this.wFormatTag=e,this.bytesPerSample=A,this.sampleRate=s,this.dataChunk=n}static read(e){let A=this.verifyAndReadList(e,"wave"),s=A.find(B=>B.header==="fmt ");if(!s)throw new Error("No fmt chunk in the wave file!");let n=V(s.data,2),a=V(s.data,2);if(a!==1)throw new Error(`Only mono samples are supported. Fmt reports ${a} channels.`);let r=V(s.data,4);V(s.data,4),V(s.data,2);let i=V(s.data,2)/8,o=A.find(B=>B.header==="data");if(!o)throw new Error("No data chunk in the WAVE chunk!");let g=new is(n,i,r,o),l=U.findListType(A,"INFO");if(l){let B=U.read(l.data);for(;B.header!=="INAM"&&l.data.currentIndex<l.data.length;)B=U.read(l.data);B.header==="INAM"&&(g.name=Ee(B.data,B.size).trim())}let C=A.find(B=>B.header==="wsmp");return C&&(g.waveSample=Ut.read(C)),g}static fromSFSample(e){let A=e.getRawData(!1),s=new is(1,2,e.sampleRate,new U("data",A.length,new ee(A.buffer)));return s.name=e.name,s.waveSample=Ut.fromSFSample(e),s}toSFSample(e){let A=this.waveSample.unityNote,s=this.waveSample.fineTune,n=Math.trunc(s/100);A+=n,s-=n*100;let a=0,r=0,i=this.waveSample.loops?.[0];i&&(a=i.loopStart,r=i.loopStart+i.loopLength);let o=new za(this.name,this.sampleRate,A,s,a,r,this.dataChunk,this.wFormatTag,this.bytesPerSample);e.addSamples(o)}write(){let e=this.writeFmt(),A=this.waveSample.write(),s=U.getParts("data",[this.dataChunk.data]),n=U.write("INAM",$e(this.name,!0)),a=U.write("INFO",n,!1,!0);return h.info(`%cSaved %c${this.name}%c successfully!`,d.recognized,d.value,d.recognized),U.getParts("wave",[e,A,...s,a],!0)}writeFmt(){let e=new ee(18);return Ae(e,this.wFormatTag),Ae(e,1),ge(e,this.sampleRate),ge(e,this.sampleRate*2),Ae(e,2),Ae(e,this.bytesPerSample*8),U.write("fmt ",e)}},At=class os{source;transform;bipolar;invert;constructor(e=X.none,A=le.linear,s=!1,n=!1){this.source=e,this.transform=A,this.bipolar=s,this.invert=n}get sourceName(){return Object.keys(X).find(e=>X[e]===this.source)??this.source.toString()}get transformName(){return Object.keys(le).find(e=>le[e]===this.transform)??this.transform.toString()}static copyFrom(e){return new os(e.source,e.transform,e.bipolar,e.invert)}static fromSFSource(e){let A;if(e.isCC)switch(e.index){case f.modulationWheel:A=X.modulationWheel;break;case f.mainVolume:A=X.volume;break;case f.pan:A=X.pan;break;case f.expression:A=X.expression;break;case f.chorusDepth:A=X.chorus;break;case f.reverbDepth:A=X.reverb;break}else switch(e.index){case Ie.noController:A=X.none;break;case Ie.noteOnKeyNum:A=X.keyNum;break;case Ie.noteOnVelocity:A=X.velocity;break;case Ie.pitchWheel:A=X.pitchWheel;break;case Ie.pitchWheelRange:A=X.pitchWheelRange;break;case Ie.polyPressure:A=X.polyPressure;break;case Ie.channelPressure:A=X.channelPressure}if(A!==void 0)return new os(A,e.curveType,e.isBipolar,e.isNegative)}toString(){return`${this.sourceName} ${this.transformName} ${this.bipolar?"bipolar":"unipolar"} ${this.invert?"inverted":"positive"}`}toTransformFlag(){return this.transform|(this.bipolar?1:0)<<4|(this.invert?1:0)<<5}toSFSource(){let e,A=!1;switch(this.source){default:case X.modLfo:case X.vibratoLfo:case X.coarseTune:case X.fineTune:case X.modEnv:return;case X.keyNum:e=Ie.noteOnKeyNum;break;case X.none:e=Ie.noController;break;case X.modulationWheel:e=f.modulationWheel,A=!0;break;case X.pan:e=f.pan,A=!0;break;case X.reverb:e=f.reverbDepth,A=!0;break;case X.chorus:e=f.chorusDepth,A=!0;break;case X.expression:e=f.expression,A=!0;break;case X.volume:e=f.mainVolume,A=!0;break;case X.velocity:e=Ie.noteOnVelocity;break;case X.polyPressure:e=Ie.polyPressure;break;case X.channelPressure:e=Ie.channelPressure;break;case X.pitchWheel:e=Ie.pitchWheel;break;case X.pitchWheelRange:e=Ie.pitchWheelRange;break}if(e!==void 0)return new st(e,this.transform,A,this.bipolar,this.invert)}},fn=new ue(219,0,c.reverbEffectsSend,1e3,0),Qn=new ue(221,0,c.chorusEffectsSend,1e3,0);new ue(129,0,c.vibLfoToPitch,0,0);new ue(13,0,c.vibLfoToPitch,0,0);var $a=new Set([c.sampleModes,c.initialAttenuation,c.keyRange,c.velRange,c.sampleID,c.fineTune,c.coarseTune,c.startAddrsOffset,c.startAddrsCoarseOffset,c.endAddrOffset,c.endAddrsCoarseOffset,c.startloopAddrsOffset,c.startloopAddrsCoarseOffset,c.endloopAddrsOffset,c.endloopAddrsCoarseOffset,c.overridingRootKey,c.exclusiveClass]),qt=class Qt{source;control;destination;scale;transform;constructor(e=new At,A=new At,s,n,a){this.source=e,this.control=A,this.destination=s,this.transform=n,this.scale=a}get isStaticParameter(){return this.source.source===X.none&&this.control.source===X.none}get shortScale(){return this.scale>>16}get transformName(){return Object.keys(le).find(e=>le[e]===this.transform)??this.transform.toString()}get destinationName(){return Object.keys(N).find(e=>N[e]===this.destination)??this.destination.toString()}static read(e){let A=V(e,2),s=V(e,2),n=V(e,2),a=V(e,2),r=V(e,4)|0,i=a&15,o=new At(s,a>>4&15,pt(a,8),pt(a,9));return new Qt(new At(A,a>>10&15,pt(a,14),pt(a,15)),o,n,i,r)}static fromSFModulator(e,A){let s=l=>{h.warn(`Failed converting SF modulator into DLS:
|
|
4
|
+
amount: ${this.transformAmount}`+(this.transformType===2?"absolute value":"")}write(e,A){Ae(e,this.primarySource.toSourceEnum()),Ae(e,this.destination),Ae(e,this.transformAmount),Ae(e,this.secondarySource.toSourceEnum()),Ae(e,this.transformType),A&&A.mod++}sumTransform(e){let A=as.copyFrom(this);return A.transformAmount+=e.transformAmount,A}},ue=class extends ke{constructor(t,e,A,s,n){super(st.fromSourceEnum(t),st.fromSourceEnum(e),A,s,n),this.destination>In&&(this.destination=c.invalid)}},xa=[new ue(Ze(le.concave,!1,!0,!1,Ie.noteOnVelocity),0,c.initialAttenuation,960,0),new ue(129,0,c.vibLfoToPitch,50,0),new ue(Ze(le.concave,!1,!0,!0,f.mainVolume),0,c.initialAttenuation,960,0),new ue(13,0,c.vibLfoToPitch,50,0),new ue(526,16,c.fineTune,12700,0),new ue(650,0,c.pan,500,0),new ue(Ze(le.concave,!1,!0,!0,f.expression),0,c.initialAttenuation,960,0),new ue(219,0,c.reverbEffectsSend,200,0),new ue(221,0,c.chorusEffectsSend,200,0)],Ha=[new ue(Ze(le.convex,!0,!1,!0,f.attackTime),0,c.attackVolEnv,6e3,0),new ue(Ze(le.linear,!0,!1,!0,f.releaseTime),0,c.releaseVolEnv,3600,0),new ue(Ze(le.linear,!0,!1,!0,f.decayTime),0,c.decayVolEnv,3600,0),new ue(Ze(le.linear,!0,!1,!0,f.brightness),0,c.initialFilterFc,9600,0),new ue(ln,0,c.initialFilterQ,250,0),new ue(Ze(le.switch,!1,!1,!0,f.softPedal),0,c.initialAttenuation,50,0),new ue(Ze(le.switch,!1,!1,!0,f.softPedal),0,c.initialFilterFc,-2400,0),new ue(Ze(le.linear,!0,!1,!0,f.balance),0,c.pan,500,0)],Cn=[...xa,...Ha],Ge=class{type;value=0;constructor(t,e,A=!0){if(this.type=t,e===void 0)throw new Error("No value provided.");if(this.value=Math.round(e),A){let s=Ve[t];s!==void 0&&(this.value=Math.max(s.min,Math.min(s.max,this.value)))}}write(t){Ae(t,this.type),Ae(t,this.value)}toString(){return`${Object.keys(c).find(t=>c[t]===this.type)}: ${this.value}`}},zt=class{velRange={min:-1,max:127};keyRange={min:-1,max:127};generators=[];modulators=[];get hasKeyRange(){return this.keyRange.min!==-1}get hasVelRange(){return this.velRange.min!==-1}get fineTuning(){let t=this.getGenerator(c.coarseTune,0),e=this.getGenerator(c.fineTune,0);return t*100+e}set fineTuning(t){let e=Math.trunc(t/100),A=t%100;this.setGenerator(c.coarseTune,e),this.setGenerator(c.fineTune,A)}addToGenerator(t,e,A=!0){let s=this.getGenerator(t,Ve[t].def);this.setGenerator(t,e+s,A)}setGenerator(t,e,A=!0){switch(t){case c.sampleID:throw new Error("Use setSample()");case c.instrument:throw new Error("Use setInstrument()");case c.velRange:case c.keyRange:throw new Error("Set the range manually")}if(e===null){this.generators=this.generators.filter(n=>n.type!==t);return}let s=this.generators.findIndex(n=>n.type===t);s===-1?this.addGenerators(new Ge(t,e,A)):this.generators[s]=new Ge(t,e,A)}addGenerators(...t){for(let e of t)switch(e.type){default:this.generators.push(e);break;case c.sampleID:case c.instrument:break;case c.velRange:this.velRange.min=e.value&127,this.velRange.max=e.value>>8&127;break;case c.keyRange:this.keyRange.min=e.value&127,this.keyRange.max=e.value>>8&127}}addModulators(...t){this.modulators.push(...t)}getGenerator(t,e){return this.generators.find(A=>A.type===t)?.value??e}copyFrom(t){this.generators=t.generators.map(e=>new Ge(e.type,e.value,!1)),this.modulators=t.modulators.map(ke.copyFrom.bind(ke)),this.velRange={...t.velRange},this.keyRange={...t.keyRange}}getWriteGenerators(t){let e=this.generators.filter(A=>A.type!==c.sampleID&&A.type!==c.instrument&&A.type!==c.keyRange&&A.type!==c.velRange);if(!t)throw new Error("No bank provided! ");return this.hasVelRange&&e.unshift(new Ge(c.velRange,this.velRange.max<<8|Math.max(this.velRange.min,0),!1)),this.hasKeyRange&&e.unshift(new Ge(c.keyRange,this.keyRange.max<<8|Math.max(this.keyRange.min,0),!1)),e}},Oa=48e3,MA=class{name;sampleRate;originalKey;pitchCorrection;linkedSample;sampleType;loopStart;loopEnd;linkedTo=[];dataOverridden=!0;compressedData;audioData;constructor(t,e,A,s,n,a,r){this.name=t,this.sampleRate=e,this.originalKey=A,this.pitchCorrection=s,this.loopStart=a,this.loopEnd=r,this.sampleType=n}get isCompressed(){return this.compressedData!==void 0}get isLinked(){return this.sampleType===Fe.rightSample||this.sampleType===Fe.leftSample||this.sampleType===Fe.linkedSample}get useCount(){return this.linkedTo.length}getRawData(t){return this.compressedData&&t&&!this.dataOverridden?this.compressedData:this.encodeS16LE()}resampleData(t){let e=this.getAudioData(),A=t/this.sampleRate,s=new Float32Array(Math.floor(e.length*A));for(let n=0;n<s.length;n++)s[n]=e[Math.floor(n*(1/A))];e=s,this.sampleRate=t,this.loopStart=Math.floor(this.loopStart*A),this.loopEnd=Math.floor(this.loopEnd*A),this.audioData=e}async compressSample(t){if(!this.isCompressed)try{let e=this.getAudioData();(this.sampleRate<8e3||this.sampleRate>96e3)&&(this.resampleData(Oa),e=this.getAudioData());let A=await t(e,this.sampleRate);this.setCompressedData(A)}catch(e){h.warn(`Failed to compress ${this.name}. Leaving as uncompressed!`,e),this.compressedData=void 0}}setSampleType(t){if(this.sampleType=t,this.isLinked||(this.linkedSample&&(this.linkedSample.linkedSample=void 0,this.linkedSample.sampleType=t),this.linkedSample=void 0),(t&32768)>0)throw new Error("ROM samples are not supported.")}unlinkSample(){this.setSampleType(Fe.monoSample)}setLinkedSample(t,e){if(t.linkedSample)throw new Error(`${t.name} is linked tp ${t.linkedSample.name}. Unlink it first.`);switch(this.linkedSample=t,t.linkedSample=this,e){case Fe.leftSample:this.setSampleType(Fe.leftSample),t.setSampleType(Fe.rightSample);break;case Fe.rightSample:this.setSampleType(Fe.rightSample),t.setSampleType(Fe.leftSample);break;case Fe.linkedSample:this.setSampleType(Fe.linkedSample),t.setSampleType(Fe.linkedSample);break;default:throw new Error("Invalid sample type: "+e)}}linkTo(t){this.linkedTo.push(t)}unlinkFrom(t){let e=this.linkedTo.indexOf(t);if(e===-1){h.warn(`Cannot unlink ${t.name} from ${this.name}: not linked.`);return}this.linkedTo.splice(e,1)}getAudioData(){if(this.audioData)return this.audioData;if(this.isCompressed)return this.audioData=this.decodeVorbis(),this.audioData;throw new Error("Sample data is undefined for a BasicSample instance.")}setAudioData(t,e){this.audioData=t,this.sampleRate=e,this.dataOverridden=!0,this.compressedData=void 0}setCompressedData(t){this.audioData=void 0,this.compressedData=t,this.dataOverridden=!1}encodeS16LE(){let t=this.getAudioData(),e=new Int16Array(t.length),A=t.length;for(let s=0;s<A;s++){let n=t[s]*32768;n>32767?n=32767:n<-32768&&(n=-32768),e[s]=n}return new ee(e.buffer)}decodeVorbis(){if(this.audioData)return this.audioData;if(!this.compressedData)throw new Error("Compressed data is missing.");try{let t=FA.decode(this.compressedData).data[0];if(t===void 0)return h.warn(`Error decoding sample ${this.name}: Vorbis decode returned undefined.`),new Float32Array(0);for(let e=0;e<t.length;e++)t[e]=Math.max(-1,Math.min(t[e],.999969482421875));return t}catch(t){return h.warn(`Error decoding sample ${this.name}: ${t}`),new Float32Array(this.loopEnd+1)}}},Ya=class extends MA{constructor(){super("",44100,60,0,Fe.monoSample,0,0)}},Bn=class extends zt{parentInstrument;useCount;constructor(t,e){super(),this.parentInstrument=t,this._sample=e,e.linkTo(this.parentInstrument),this.useCount=t.useCount}_sample;get sample(){return this._sample}set sample(t){this._sample&&this._sample.unlinkFrom(this.parentInstrument),this._sample=t,t.linkTo(this.parentInstrument)}getWriteGenerators(t){let e=super.getWriteGenerators(t),A=t.samples.indexOf(this.sample);if(A===-1)throw new Error(`${this.sample.name} does not exist in ${t.soundBankInfo.name}! Cannot write sampleID generator.`);return e.push(new Ge(c.sampleID,A,!1)),e}},En=class extends zt{parentPreset;constructor(t,e){super(),this.parentPreset=t,this._instrument=e,this._instrument.linkTo(this.parentPreset)}_instrument;get instrument(){return this._instrument}set instrument(t){this._instrument&&this._instrument.unlinkFrom(this.parentPreset),this._instrument=t,this._instrument.linkTo(this.parentPreset)}getWriteGenerators(t){let e=super.getWriteGenerators(t);if(!t)throw new Error("Instrument ID cannot be determined without the sound bank itself.");let A=t.instruments.indexOf(this.instrument);if(A===-1)throw new Error(`${this.instrument.name} does not exist in ${t.soundBankInfo.name}! Cannot write instrument generator.`);return e.push(new Ge(c.instrument,A,!1)),e}},rs=new Int16Array(St);for(let t=0;t<rs.length;t++)Ve[t]&&(rs[t]=Ve[t].def);var _t=class at{parentSoundBank;name="";program=0;bankMSB=0;bankLSB=0;isGMGSDrum=!1;zones=[];globalZone;library=0;genre=0;morphology=0;constructor(e,A=new zt){this.parentSoundBank=e,this.globalZone=A}get isDrum(){let e=this.parentSoundBank.isXGBank;return this.isGMGSDrum||e&&Se.isXGDrum(this.bankMSB)}static isInRange(e,A){return A>=e.min&&A<=e.max}static addUniqueModulators(e,A){for(let s of A)e.some(n=>ke.isIdentical(s,n))||e.push(s)}static subtractRanges(e,A){return{min:Math.max(e.min,A.min),max:Math.min(e.max,A.max)}}delete(){for(let e of this.zones)e.instrument?.unlinkFrom(this)}deleteZone(e){this.zones[e]?.instrument?.unlinkFrom(this),this.zones.splice(e,1)}createZone(e){let A=new En(this,e);return this.zones.push(A),A}preload(e,A){for(let s=e;s<A+1;s++)for(let n=0;n<128;n++)for(let a of this.getVoiceParameters(s,n))a.sample.getAudioData()}matches(e){return ze.matches(this,e)}getVoiceParameters(e,A){let s=new Array;for(let n of this.zones){if(!at.isInRange(n.hasKeyRange?n.keyRange:this.globalZone.keyRange,e)||!at.isInRange(n.hasVelRange?n.velRange:this.globalZone.velRange,A))continue;let a=n.instrument;if(!a||a.zones.length===0)continue;let r=new Int16Array(St);for(let i of this.globalZone.generators)r[i.type]=i.value;for(let i of n.generators)r[i.type]=i.value;let o=[...n.modulators];at.addUniqueModulators(o,this.globalZone.modulators);for(let i of a.zones){if(!at.isInRange(i.hasKeyRange?i.keyRange:a.globalZone.keyRange,e)||!at.isInRange(i.hasVelRange?i.velRange:a.globalZone.velRange,A))continue;let g=[...i.modulators];at.addUniqueModulators(g,a.globalZone.modulators),at.addUniqueModulators(g,this.parentSoundBank.defaultModulators);for(let B of o){let C=g.findIndex(I=>ke.isIdentical(B,I));C===-1?g.push(B):g[C]=g[C].sumTransform(B)}let l=new Int16Array(rs);for(let B of a.globalZone.generators)l[B.type]=B.value;for(let B of i.generators)l[B.type]=B.value;for(let B=0;B<l.length;B++)l[B]=Math.max(-32768,Math.min(32767,l[B]+r[B]));l[c.initialAttenuation]=Math.floor(l[c.initialAttenuation]*.4),s.push({sample:i.sample,generators:l,modulators:g})}}return s}toMIDIString(){return ze.toMIDIString(this)}toString(){return ze.toFullMIDIString(this)}toFlattenedInstrument(){let e=(g,l)=>{g.push(...l.filter(B=>!g.some(C=>C.type===B.type)))},A=(g,l)=>{g.push(...l.filter(B=>!g.some(C=>ke.isIdentical(B,C))))},s=new Wt;s.name=this.name;let n=[],a=[],r=this.globalZone;n.push(...r.generators),a.push(...r.modulators);let o=r.keyRange,i=r.velRange;for(let g of this.zones){if(!g.instrument)throw new Error("No instrument in a preset zone.");let l=g.keyRange;g.hasKeyRange||(l=o);let B=g.velRange;g.hasVelRange||(B=i);let C=g.generators.map(S=>new Ge(S.type,S.value));e(C,n);let I=[...g.modulators];A(I,a);let E=g.instrument,y=E.zones,k=[],p=[],R=E.globalZone;k.push(...R.generators),p.push(...R.modulators);let b=R.keyRange,M=R.velRange;for(let S of y){if(!S.sample)throw new Error("No sample in an instrument zone.");let Q=S.keyRange;S.hasKeyRange||(Q=b);let m=S.velRange;if(S.hasVelRange||(m=M),Q=at.subtractRanges(Q,l),m=at.subtractRanges(m,B),Q.max<Q.min||m.max<m.min)continue;let D=S.generators.map(H=>new Ge(H.type,H.value));e(D,k);let q=[...S.modulators];A(q,p);let K=[...q];for(let H of I){let Z=K.findIndex(T=>ke.isIdentical(H,T));Z===-1?K.push(H):K[Z]=K[Z].sumTransform(H)}let O=D.map(H=>new Ge(H.type,H.value));for(let H of C){if(H.type===c.velRange||H.type===c.keyRange||H.type===c.instrument||H.type===c.endOper||H.type===c.sampleModes)continue;let Z=D.findIndex(T=>T.type===H.type);if(Z===-1){let T=Ve[H.type].def+H.value;O.push(new Ge(H.type,T))}else{let T=O[Z].value+H.value;O[Z]=new Ge(H.type,T)}}O=O.filter(H=>H.type!==c.sampleID&&H.type!==c.keyRange&&H.type!==c.velRange&&H.type!==c.endOper&&H.type!==c.instrument&&(!(H.type in Ve)||H.value!==Ve[H.type].def));let Y=s.createZone(S.sample);Y.keyRange=Q,Y.velRange=m,Y.keyRange.min===0&&Y.keyRange.max===127&&(Y.keyRange.min=-1),Y.velRange.min===0&&Y.velRange.max===127&&(Y.velRange.min=-1),Y.addGenerators(...O),Y.addModulators(...K)}}return s}write(e,A){h.info(`%cWriting ${this.name}...`,d.info),Le(e.pdta,this.name.slice(0,20),20),Le(e.xdta,this.name.slice(20),20),Ae(e.pdta,this.program);let s=this.bankMSB;this.isGMGSDrum?s=128:this.bankMSB===0&&(s=this.bankLSB),Ae(e.pdta,s),e.xdta.currentIndex+=4,Ae(e.pdta,A&65535),Ae(e.xdta,A>>16),ge(e.pdta,this.library),ge(e.pdta,this.genre),ge(e.pdta,this.morphology),e.xdta.currentIndex+=12}},qa=new Set([c.velRange,c.keyRange,c.instrument,c.sampleID,c.exclusiveClass,c.endOper,c.sampleModes,c.startloopAddrsOffset,c.startloopAddrsCoarseOffset,c.endloopAddrsOffset,c.endloopAddrsCoarseOffset,c.startAddrsOffset,c.startAddrsCoarseOffset,c.endAddrOffset,c.endAddrsCoarseOffset,c.initialAttenuation,c.fineTune,c.coarseTune,c.keyNumToVolEnvHold,c.keyNumToVolEnvDecay,c.keyNumToModEnvHold,c.keyNumToModEnvDecay]),Wt=class{name="";zones=[];globalZone=new zt;linkedTo=[];get useCount(){return this.linkedTo.length}createZone(t){let e=new Bn(this,t);return this.zones.push(e),e}linkTo(t){this.linkedTo.push(t);for(let e of this.zones)e.useCount++}unlinkFrom(t){let e=this.linkedTo.indexOf(t);if(e===-1){h.warn(`Cannot unlink ${t.name} from ${this.name}: not linked.`);return}this.linkedTo.splice(e,1);for(let A of this.zones)A.useCount--}deleteUnusedZones(){this.zones=this.zones.filter(t=>{let e=t.useCount>0;return e||t.sample.unlinkFrom(this),e})}delete(){if(this.useCount>0)throw new Error(`Cannot delete an instrument that is used by: ${this.linkedTo.map(t=>t.name).toString()}.`);for(let t of this.zones)t.sample.unlinkFrom(this)}deleteZone(t,e=!1){let A=this.zones[t];return A.useCount-=1,A.useCount<1||e?(A.sample.unlinkFrom(this),this.zones.splice(t,1),!0):!1}globalize(){let t=this.globalZone;for(let A=0;A<58;A++){if(qa.has(A))continue;A=A;let s={},n=Ve[A]?.def||0;s[n]=0;for(let a of this.zones){let r=a.getGenerator(A,void 0);r===void 0?s[n]++:s[r]===void 0?s[r]=1:s[r]++;let o;switch(A){default:continue;case c.decayVolEnv:o=c.keyNumToVolEnvDecay;break;case c.holdVolEnv:o=c.keyNumToVolEnvHold;break;case c.decayModEnv:o=c.keyNumToModEnvDecay;break;case c.holdModEnv:o=c.keyNumToModEnvHold}if(a.getGenerator(o,void 0)!==void 0){s={};break}}if(Object.keys(s).length>0){let a=["0",0];for(let[o,i]of Object.entries(s))i>a[1]&&(a=[o,i]);let r=Number.parseInt(a[0]);r!==n&&t.setGenerator(A,r,!1);for(let o of this.zones){let i=o.getGenerator(A,void 0);i===void 0?r!==n&&o.setGenerator(A,n):i===r&&o.setGenerator(A,null)}}}let e=this.zones.length===0?[]:this.zones[0].modulators.map(A=>ke.copyFrom(A));for(let A of e){let s=!0;for(let n of this.zones)s&&(n.modulators.find(a=>ke.isIdentical(a,A))||(s=!1));if(s){t.addModulators(ke.copyFrom(A));for(let n of this.zones){let a=n.modulators.find(r=>ke.isIdentical(r,A));a&&a.transformAmount===A.transformAmount&&n.modulators.splice(n.modulators.indexOf(a),1)}}}}write(t,e){h.info(`%cWriting ${this.name}...`,d.info),Le(t.pdta,this.name.slice(0,20),20),Le(t.xdta,this.name.slice(20),20),Ae(t.pdta,e&65535),Ae(t.xdta,e>>>16)}};function Ja(t,e,A,s){let n=0,a=[],r=[];for(let l of t.samples){let B=l.getRawData(!0);n++,s?.(n/t.samples.length),h.info(`%cWrote sample %c${n}. ${l.name}%c of %c${t.samples.length}.`,d.info,d.recognized,d.info,d.recognized),a.push(B),r.push(B.length),l.isCompressed||a.push(new Uint8Array(92))}let o=U.getParts("smpl",a),i=U.getParts("sdta",o,!0),g=0;for(let[l,B]of t.samples.entries()){let C=r[l],I,E;B.isCompressed?(I=g,E=I+C):(I=g/2,E=I+C/2,g+=92),g+=C,e.push(I),A.push(E)}return i}var Ka=class extends MA{linkedSampleIndex;s16leData;startByteOffset;endByteOffset;sampleID;constructor(t,e,A,s,n,a,r,o,i,g,l,B){let C=(g&16)>0;g&=-17,super(t,a,r,o,g,s-e/2,n-e/2),this.dataOverridden=!1,this.name=t,this.startByteOffset=e,this.endByteOffset=A,this.sampleID=B;let I=l instanceof ee?l.currentIndex:0;l instanceof ee?C?(this.loopStart+=this.startByteOffset/2,this.loopEnd+=this.startByteOffset/2,this.setCompressedData(l.slice(this.startByteOffset/2+I,this.endByteOffset/2+I))):this.s16leData=l.slice(I+this.startByteOffset,I+this.endByteOffset):this.setAudioData(l.slice(this.startByteOffset/2,this.endByteOffset/2),a),this.linkedSampleIndex=i}getLinkedSample(t){if(this.linkedSample||!this.isLinked)return;let e=t[this.linkedSampleIndex];e?e.linkedSample?(h.info(`%cInvalid linked sample for ${this.name}: ${e.name} is already linked to ${e.linkedSample.name}`,d.warn),this.unlinkSample()):this.setLinkedSample(e,this.sampleType):(h.info(`%cInvalid linked sample for ${this.name}. Setting to mono.`,d.warn),this.unlinkSample())}getAudioData(){if(this.audioData)return this.audioData;if(this.isCompressed)return super.getAudioData();if(!this.s16leData)throw console.error(this),new Error("Unexpected lack of audio data.");let t=this.endByteOffset-this.startByteOffset;if(t<1)return h.warn(`Invalid sample ${this.name}! Invalid length: ${t}`),new Float32Array(1);let e=new Float32Array(t/2),A=new Int16Array(this.s16leData.buffer);for(let[s,n]of A.entries())e[s]=n/32768;return this.audioData=e,e}getRawData(t){return this.dataOverridden||this.compressedData?super.getRawData(t):this.s16leData??new Uint8Array(0)}};function Ms(t,e,A=!0){let s=[],n=0;for(;t.data.length>t.data.currentIndex;){let a=Va(n,t.data,e);s.push(a),n++}if(s.pop(),A)for(let a of s)a.getLinkedSample(s);return s}function Va(t,e,A){let s=Ee(e,20),n=V(e,4)*2,a=V(e,4)*2,r=V(e,4),o=V(e,4),i=V(e,4),g=e[e.currentIndex++];g>127&&(g=60);let l=Yn(e[e.currentIndex++]),B=V(e,2),C=V(e,2);return new Ka(s,n,a,r,o,i,g,l,B,C,A,t)}function Xa(t,e,A){let n=46*(t.samples.length+1),a=new ee(n),r=new ee(n),o=0;for(let[i,g]of t.samples.entries()){Le(a,g.name.slice(0,20),20),Le(r,g.name.slice(20),20);let l=e[i];ge(a,l),r.currentIndex+=4;let B=A[i];ge(a,B),r.currentIndex+=4;let C=g.loopStart+l,I=g.loopEnd+l;g.isCompressed&&(C-=l,I-=l),ge(a,C),ge(a,I),ge(a,g.sampleRate),a[a.currentIndex++]=g.originalKey,a[a.currentIndex++]=g.pitchCorrection,r.currentIndex+=14;let E=g.linkedSample?t.samples.indexOf(g.linkedSample):0;Ae(a,Math.max(0,E)&65535),Ae(r,Math.max(0,E)>>16),o=Math.max(o,E);let y=g.sampleType;g.isCompressed&&(y|=16),Ae(a,y),r.currentIndex+=2}return Le(a,"EOS",46),Le(r,"EOS",46),{pdta:U.write("shdr",a),xdta:U.write("shdr",r)}}function vs(t,e=!1){let A=e?t.presets:t.instruments,s=e?"pgen":"igen",n=e?"pmod":"imod",a=e?"pbag":"ibag",r=e?"phdr":"inst",o=e?38:22,i=0,g=new Array,l=0,B=new Array,C=new Array,I=new Array,E=0,y=new Array,k=m=>{g.push(i);let D=m.getWriteGenerators(t);i+=D.length,C.push(...D),B.push(l);let q=m.modulators;l+=q.length,I.push(...q)};for(let m of A){y.push(E),k(m.globalZone);for(let D of m.zones)k(D);E+=m.zones.length+1}C.push(new Ge(0,0,!1)),I.push(new ue(0,0,0,0,0)),g.push(i),B.push(l),y.push(E);let p=new ee(C.length*4);for(let m of C)m.write(p);let R=new ee(I.length*10);for(let m of I)m.write(R);let b=B.length*4,M={pdta:new ee(b),xdta:new ee(b)};for(let[m,D]of B.entries()){let q=g[m];Ae(M.pdta,q&65535),Ae(M.pdta,D&65535),Ae(M.xdta,q>>16),Ae(M.xdta,D>>16)}let S=(A.length+1)*o,Q={pdta:new ee(S),xdta:new ee(S)};for(let[m,D]of A.entries())D.write(Q,y[m]);return e?(Le(Q.pdta,"EOP",20),Q.pdta.currentIndex+=4,Ae(Q.pdta,E&65535),Q.pdta.currentIndex+=12,Le(Q.xdta,"",20),Q.xdta.currentIndex+=4,Ae(Q.xdta,E>>16),Q.xdta.currentIndex+=12):(Le(Q.pdta,"EOI",20),Ae(Q.pdta,E&65535),Le(Q.xdta,"",20),Ae(Q.xdta,E>>16)),{writeXdta:Math.max(i,l,E)>65535,gen:{pdta:U.write(s,p),xdta:U.write(n,new ee(4))},mod:{pdta:U.write(n,R),xdta:U.write(n,new ee(10))},bag:{pdta:U.write(a,M.pdta),xdta:U.write(a,M.xdta)},hdr:{pdta:U.write(r,Q.pdta),xdta:U.write(r,Q.xdta)}}}var dn={writeDefaultModulators:!0,writeExtendedLimits:!0,software:"SpessaSynth"};function Za(t,e){let A=bA(e,dn);h.groupCollapsed("%cSaving soundbank...",d.info),h.group("%cWriting INFO...",d.info);let s=[],n=(p,R)=>{R&&s.push(...U.getParts(p,[$e(R,!0,!0)]))},a=t.soundBankInfo;{let p=new ee(4);Ae(p,a.version.major),Ae(p,a.version.minor),s.push(U.write("ifil",p))}if(n("isng",a.soundEngine),n("INAM",a.name),n("irom",a.romInfo),a.romVersion){let p=new ee(4);Ae(p,a.romVersion.major),Ae(p,a.romVersion.minor),s.push(U.write("iver",p))}n("ICRD",Bs(a.creationDate)),n("IENG",a.engineer),n("IPRD",a.product),n("ICOP",a.copyright),n("ICMT",a?.subject?(a?.comment?a.comment+`
|
|
5
|
+
`:"")+a.subject:a?.comment);let r=A.software;if(n("ISFT",r),t.defaultModulators.some(p=>!Cn.some(R=>ke.isIdentical(R,p,!0)))&&A?.writeDefaultModulators){let p=t.defaultModulators;h.info(`%cWriting %c${p.length}%c default modulators...`,d.info,d.recognized,d.info);let R=new ee(10+p.length*10);for(let b of p)b.write(R);hs(R,0,10),s.push(...U.getParts("DMOD",[R]))}h.groupEnd(),h.info("%cWriting SDTA...",d.info);let o=[],i=[],g=Ja(t,o,i);h.info("%cWriting PDTA...",d.info),h.info("%cWriting SHDR...",d.info);let l=Xa(t,o,i);h.group("%cWriting instruments...",d.info);let B=vs(t,!1);h.groupEnd(),h.group("%cWriting presets...",d.info);let C=vs(t,!0);h.groupEnd();let I=[C.hdr,C.bag,C.mod,C.gen,B.hdr,B.bag,B.mod,B.gen,l],E=U.getParts("pdta",I.map(p=>p.pdta),!0);A.writeExtendedLimits&&(B.writeXdta||C.writeXdta||t.presets.some(p=>p.name.length>20)||t.instruments.some(p=>p.name.length>20)||t.samples.some(p=>p.name.length>20))&&(h.info("%cWriting the xdta chunk as writeExtendedLimits is enabled and at least one condition was met.",d.info,d.value),s.push(...U.getParts("xdta",I.map(p=>p.xdta),!0)));let y=U.getParts("INFO",s,!0);h.info("%cWriting the output file...",d.info);let k=U.writeParts("RIFF",[$e("sfbk"),...y,...g,...E]);return h.info(`%cSaved successfully! Final file size: %c${k.length}`,d.info,d.recognized),h.groupEnd(),k.buffer}var Ht=class{static verifyHeader(t,...e){for(let A of e)if(t.header.toLowerCase()===A.toLowerCase())return;this.parsingError(`Invalid DLS chunk header! Expected "${e.join(", or ")}" got "${t.header.toLowerCase()}"`)}static verifyText(t,...e){for(let A of e)if(t.toLowerCase()===A.toLowerCase())return;this.parsingError(`FourCC error: Expected "${e.join(", or ")}" got "${t.toLowerCase()}"`)}static parsingError(t){throw h.groupEnd(),new Error(`DLS parse error: ${t} The file may be corrupted.`)}static verifyAndReadList(t,...e){this.verifyHeader(t,"LIST"),t.data.currentIndex=0,this.verifyText(Ee(t.data,4),...e);let A=[];for(;t.data.length>t.data.currentIndex;)A.push(U.read(t.data));return A}},X={none:0,modLfo:1,velocity:2,keyNum:3,volEnv:4,modEnv:5,pitchWheel:6,polyPressure:7,channelPressure:8,vibratoLfo:9,modulationWheel:129,volume:135,pan:138,expression:139,chorus:221,reverb:219,pitchWheelRange:256,fineTune:257,coarseTune:258},N={none:0,gain:1,reserved:2,pitch:3,pan:4,keyNum:5,chorusSend:128,reverbSend:129,modLfoFreq:260,modLfoDelay:261,vibLfoFreq:276,vibLfoDelay:277,volEnvAttack:518,volEnvDecay:519,reservedEG1:520,volEnvRelease:521,volEnvSustain:522,volEnvDelay:523,volEnvHold:524,modEnvAttack:778,modEnvDecay:779,reservedEG2:780,modEnvRelease:781,modEnvSustain:782,modEnvDelay:783,modEnvHold:784,filterCutoff:1280,filterQ:1281},Gs={forward:0,loopAndRelease:1},oA=20,gA=16,Ut=class Vt extends Ht{gain=0;unityNote=60;fineTune=0;loops=new Array;fulOptions=2;static copyFrom(e){let A=new Vt;return A.unityNote=e.unityNote,A.gain=e.gain,A.fineTune=e.fineTune,A.loops=e.loops.map(s=>({...s})),A.fulOptions=e.fulOptions,A}static read(e){this.verifyHeader(e,"wsmp");let A=new Vt,s=V(e.data,4);if(s!==oA&&h.warn(`Wsmp cbSize mismatch: got ${s}, expected ${oA}.`),A.unityNote=V(e.data,2),A.fineTune=ls(e.data[e.data.currentIndex++],e.data[e.data.currentIndex++]),A.gain=V(e.data,4)|0,A.fulOptions=V(e.data,4),V(e.data,4)!==0){let n=V(e.data,4);n!==gA&&h.warn(`CbSize for loop in wsmp mismatch. Expected ${gA}, got ${n}.`);let a=V(e.data,4),r=V(e.data,4),o=V(e.data,4);A.loops.push({loopStart:r,loopLength:o,loopType:a})}return A}static fromSFSample(e){let A=new Vt;return A.unityNote=e.originalKey,A.fineTune=e.pitchCorrection,(e.loopEnd!==0||e.loopStart!==0)&&A.loops.push({loopStart:e.loopStart,loopLength:e.loopEnd-e.loopStart,loopType:Gs.forward}),A}static fromSFZone(e){let A=new Vt;A.unityNote=e.getGenerator(c.overridingRootKey,e.sample.originalKey),e.getGenerator(c.scaleTuning,100)===0&&e.keyRange.max-e.keyRange.min===0&&(A.unityNote=e.keyRange.min),A.fineTune=e.fineTuning+e.sample.pitchCorrection,A.gain=-(e.getGenerator(c.initialAttenuation,0)*.4)<<16;let s=e.getGenerator(c.sampleModes,0);if(s!==0){let n=e.sample.loopStart+e.getGenerator(c.startloopAddrsOffset,0)+e.getGenerator(c.startloopAddrsCoarseOffset,0)*32768,a=e.sample.loopEnd+e.getGenerator(c.endloopAddrsOffset,0)+e.getGenerator(c.endloopAddrsCoarseOffset,0)*32768,r;switch(s){case 1:default:r=0;break;case 3:r=1}A.loops.push({loopType:r,loopStart:n,loopLength:a-n})}return A}toSFZone(e,A){let s=0,n=this.loops[0];n&&(s=n.loopType===Gs.loopAndRelease?3:1),s!==0&&e.setGenerator(c.sampleModes,s);let a=-(this.gain>>16)/.4;if(a!==0&&e.setGenerator(c.initialAttenuation,a),e.fineTuning=this.fineTune-A.pitchCorrection,this.unityNote!==A.originalKey&&e.setGenerator(c.overridingRootKey,this.unityNote),n){let r=n.loopStart-A.loopStart,o=n.loopStart+n.loopLength-A.loopEnd;if(r!==0){let i=r%32768;e.setGenerator(c.startloopAddrsOffset,i);let g=Math.trunc(r/32768);g!==0&&e.setGenerator(c.startloopAddrsCoarseOffset,g)}if(o!==0){let i=o%32768;e.setGenerator(c.endloopAddrsOffset,i);let g=Math.trunc(o/32768);g!==0&&e.setGenerator(c.endloopAddrsCoarseOffset,g)}}}write(){let e=new ee(oA+this.loops.length*gA);ge(e,oA),Ae(e,this.unityNote),Ae(e,this.fineTune),ge(e,this.gain),ge(e,this.fulOptions),ge(e,this.loops.length);for(let A of this.loops)ge(e,gA),ge(e,A.loopType),ge(e,A.loopStart),ge(e,A.loopLength);return U.write("wsmp",e)}},qA={PCM:1,ALAW:6};function _a(t,e){let A=Math.pow(2,e*8-1),s=Math.pow(2,e*8),n,a=!1;e===1?(n=255,a=!0):n=A;let r=t.length/e,o=new Float32Array(r);if(e===2){let i=new Int16Array(t.buffer);for(let[g,l]of i.entries())o[g]=l/32768}else for(let i=0;i<o.length;i++){let g=V(t,e);a?o[i]=g/n-.5:(g>=A&&(g-=s),o[i]=g/n)}return o}function Wa(t,e){let A=t.length/e,s=new Float32Array(A);for(let n=0;n<s.length;n++){let a=V(t,e),r=a^85;r&=127;let o=r>>4,i=r&15;o>0&&(i+=16),i=(i<<4)+8,o>1&&(i=i<<o-1),s[n]=(a>127?i:-i)/32768}return s}var za=class extends MA{wFormatTag;bytesPerSample;rawData;constructor(t,e,A,s,n,a,r,o,i){super(t,e,A,s,Fe.monoSample,n,a),this.dataOverridden=!1,this.rawData=r.data,this.wFormatTag=o,this.bytesPerSample=i}getAudioData(){if(!this.rawData)return new Float32Array(0);if(!this.audioData){let t;switch(this.wFormatTag){default:h.warn(`Failed to decode sample. Unknown wFormatTag: ${this.wFormatTag}`),t=new Float32Array(this.rawData.length/this.bytesPerSample);break;case qA.PCM:t=_a(this.rawData,this.bytesPerSample);break;case qA.ALAW:t=Wa(this.rawData,this.bytesPerSample);break}this.setAudioData(t,this.sampleRate)}return this.audioData??new Float32Array(0)}getRawData(t){return this.dataOverridden||this.isCompressed?super.getRawData(t):this.wFormatTag===qA.PCM&&this.bytesPerSample===2?this.rawData:this.encodeS16LE()}},Ls=class is extends Ht{waveSample=new Ut;wFormatTag;bytesPerSample;sampleRate;dataChunk;name="Unnamed sample";constructor(e,A,s,n){super(),this.wFormatTag=e,this.bytesPerSample=A,this.sampleRate=s,this.dataChunk=n}static read(e){let A=this.verifyAndReadList(e,"wave"),s=A.find(C=>C.header==="fmt ");if(!s)throw new Error("No fmt chunk in the wave file!");let n=V(s.data,2),a=V(s.data,2);if(a!==1)throw new Error(`Only mono samples are supported. Fmt reports ${a} channels.`);let r=V(s.data,4);V(s.data,4),V(s.data,2);let o=V(s.data,2)/8,i=A.find(C=>C.header==="data");if(!i)throw new Error("No data chunk in the WAVE chunk!");let g=new is(n,o,r,i),l=U.findListType(A,"INFO");if(l){let C=U.read(l.data);for(;C.header!=="INAM"&&l.data.currentIndex<l.data.length;)C=U.read(l.data);C.header==="INAM"&&(g.name=Ee(C.data,C.size).trim())}let B=A.find(C=>C.header==="wsmp");return B&&(g.waveSample=Ut.read(B)),g}static fromSFSample(e){let A=e.getRawData(!1),s=new is(1,2,e.sampleRate,new U("data",A.length,new ee(A.buffer)));return s.name=e.name,s.waveSample=Ut.fromSFSample(e),s}toSFSample(e){let A=this.waveSample.unityNote,s=this.waveSample.fineTune,n=Math.trunc(s/100);A+=n,s-=n*100;let a=0,r=0,o=this.waveSample.loops?.[0];o&&(a=o.loopStart,r=o.loopStart+o.loopLength);let i=new za(this.name,this.sampleRate,A,s,a,r,this.dataChunk,this.wFormatTag,this.bytesPerSample);e.addSamples(i)}write(){let e=this.writeFmt(),A=this.waveSample.write(),s=U.getParts("data",[this.dataChunk.data]),n=U.write("INAM",$e(this.name,!0)),a=U.write("INFO",n,!1,!0);return h.info(`%cSaved %c${this.name}%c successfully!`,d.recognized,d.value,d.recognized),U.getParts("wave",[e,A,...s,a],!0)}writeFmt(){let e=new ee(18);return Ae(e,this.wFormatTag),Ae(e,1),ge(e,this.sampleRate),ge(e,this.sampleRate*2),Ae(e,2),Ae(e,this.bytesPerSample*8),U.write("fmt ",e)}},At=class os{source;transform;bipolar;invert;constructor(e=X.none,A=le.linear,s=!1,n=!1){this.source=e,this.transform=A,this.bipolar=s,this.invert=n}get sourceName(){return Object.keys(X).find(e=>X[e]===this.source)??this.source.toString()}get transformName(){return Object.keys(le).find(e=>le[e]===this.transform)??this.transform.toString()}static copyFrom(e){return new os(e.source,e.transform,e.bipolar,e.invert)}static fromSFSource(e){let A;if(e.isCC)switch(e.index){case f.modulationWheel:A=X.modulationWheel;break;case f.mainVolume:A=X.volume;break;case f.pan:A=X.pan;break;case f.expression:A=X.expression;break;case f.chorusDepth:A=X.chorus;break;case f.reverbDepth:A=X.reverb;break}else switch(e.index){case Ie.noController:A=X.none;break;case Ie.noteOnKeyNum:A=X.keyNum;break;case Ie.noteOnVelocity:A=X.velocity;break;case Ie.pitchWheel:A=X.pitchWheel;break;case Ie.pitchWheelRange:A=X.pitchWheelRange;break;case Ie.polyPressure:A=X.polyPressure;break;case Ie.channelPressure:A=X.channelPressure}if(A!==void 0)return new os(A,e.curveType,e.isBipolar,e.isNegative)}toString(){return`${this.sourceName} ${this.transformName} ${this.bipolar?"bipolar":"unipolar"} ${this.invert?"inverted":"positive"}`}toTransformFlag(){return this.transform|(this.bipolar?1:0)<<4|(this.invert?1:0)<<5}toSFSource(){let e,A=!1;switch(this.source){default:case X.modLfo:case X.vibratoLfo:case X.coarseTune:case X.fineTune:case X.modEnv:return;case X.keyNum:e=Ie.noteOnKeyNum;break;case X.none:e=Ie.noController;break;case X.modulationWheel:e=f.modulationWheel,A=!0;break;case X.pan:e=f.pan,A=!0;break;case X.reverb:e=f.reverbDepth,A=!0;break;case X.chorus:e=f.chorusDepth,A=!0;break;case X.expression:e=f.expression,A=!0;break;case X.volume:e=f.mainVolume,A=!0;break;case X.velocity:e=Ie.noteOnVelocity;break;case X.polyPressure:e=Ie.polyPressure;break;case X.channelPressure:e=Ie.channelPressure;break;case X.pitchWheel:e=Ie.pitchWheel;break;case X.pitchWheelRange:e=Ie.pitchWheelRange;break}if(e!==void 0)return new st(e,this.transform,A,this.bipolar,this.invert)}},fn=new ue(219,0,c.reverbEffectsSend,1e3,0),Qn=new ue(221,0,c.chorusEffectsSend,1e3,0);new ue(129,0,c.vibLfoToPitch,0,0);new ue(13,0,c.vibLfoToPitch,0,0);var $a=new Set([c.sampleModes,c.initialAttenuation,c.keyRange,c.velRange,c.sampleID,c.fineTune,c.coarseTune,c.startAddrsOffset,c.startAddrsCoarseOffset,c.endAddrOffset,c.endAddrsCoarseOffset,c.startloopAddrsOffset,c.startloopAddrsCoarseOffset,c.endloopAddrsOffset,c.endloopAddrsCoarseOffset,c.overridingRootKey,c.exclusiveClass]),qt=class Qt{source;control;destination;scale;transform;constructor(e=new At,A=new At,s,n,a){this.source=e,this.control=A,this.destination=s,this.transform=n,this.scale=a}get isStaticParameter(){return this.source.source===X.none&&this.control.source===X.none}get shortScale(){return this.scale>>16}get transformName(){return Object.keys(le).find(e=>le[e]===this.transform)??this.transform.toString()}get destinationName(){return Object.keys(N).find(e=>N[e]===this.destination)??this.destination.toString()}static read(e){let A=V(e,2),s=V(e,2),n=V(e,2),a=V(e,2),r=V(e,4)|0,o=a&15,i=new At(s,a>>4&15,pt(a,8),pt(a,9));return new Qt(new At(A,a>>10&15,pt(a,14),pt(a,15)),i,n,o,r)}static fromSFModulator(e,A){let s=l=>{h.warn(`Failed converting SF modulator into DLS:
|
|
6
6
|
${e.toString()}
|
|
7
|
-
(${l})`)};if(e.transformType!==0){s("Absolute transform type is not supported");return}if(ke.isIdentical(e,Qn,!0)||ke.isIdentical(e,fn,!0))return;let n=At.fromSFSource(e.primarySource);if(!n){s("Invalid primary source");return}let a=At.fromSFSource(e.secondarySource);if(!a){s("Invalid secondary source");return}let r=Qt.fromSFDestination(e.destination,e.transformAmount);if(r===void 0){s("Invalid destination");return}let
|
|
7
|
+
(${l})`)};if(e.transformType!==0){s("Absolute transform type is not supported");return}if(ke.isIdentical(e,Qn,!0)||ke.isIdentical(e,fn,!0))return;let n=At.fromSFSource(e.primarySource);if(!n){s("Invalid primary source");return}let a=At.fromSFSource(e.secondarySource);if(!a){s("Invalid secondary source");return}let r=Qt.fromSFDestination(e.destination,e.transformAmount);if(r===void 0){s("Invalid destination");return}let o=e.transformAmount,i;if(typeof r=="number")i=r;else if(i=r.destination,o=r.amount,r.source!==X.none){if(a.source!==X.none&&n.source!==X.none){s("Articulation generators with secondary source are not supported");return}n.source!==X.none&&(a=n),n=new At(r.source,le.linear,r.isBipolar)}let g=new Qt(n,a,i,0,o<<16);A.connectionBlocks.push(g)}static copyFrom(e){return new Qt(At.copyFrom(e.source),At.copyFrom(e.control),e.destination,e.transform,e.scale)}static fromSFGenerator(e,A){if($a.has(e.type))return;let s=i=>{h.warn(`Failed converting SF2 generator into DLS:
|
|
8
8
|
${e.toString()}
|
|
9
|
-
(${
|
|
9
|
+
(${i})`)},n=Qt.fromSFDestination(e.type,e.value);if(n===void 0){s("Invalid type");return}let a=new At,r,o=e.value;typeof n=="number"?r=n:(r=n.destination,o=n.amount,a.source=n.source,a.bipolar=n.isBipolar),A.connectionBlocks.push(new Qt(a,new At,r,0,o<<16))}static fromSFDestination(e,A){switch(e){default:return;case c.initialAttenuation:return{destination:N.gain,amount:-A,isBipolar:!1,source:X.none};case c.fineTune:return N.pitch;case c.pan:return N.pan;case c.keyNum:return N.keyNum;case c.reverbEffectsSend:return N.reverbSend;case c.chorusEffectsSend:return N.chorusSend;case c.freqModLFO:return N.modLfoFreq;case c.delayModLFO:return N.modLfoDelay;case c.delayVibLFO:return N.vibLfoDelay;case c.freqVibLFO:return N.vibLfoFreq;case c.delayVolEnv:return N.volEnvDelay;case c.attackVolEnv:return N.volEnvAttack;case c.holdVolEnv:return N.volEnvHold;case c.decayVolEnv:return N.volEnvDecay;case c.sustainVolEnv:return{destination:N.volEnvSustain,amount:1e3-A,isBipolar:!1,source:X.none};case c.releaseVolEnv:return N.volEnvRelease;case c.delayModEnv:return N.modEnvDelay;case c.attackModEnv:return N.modEnvAttack;case c.holdModEnv:return N.modEnvHold;case c.decayModEnv:return N.modEnvDecay;case c.sustainModEnv:return{destination:N.modEnvSustain,amount:1e3-A,isBipolar:!1,source:X.none};case c.releaseModEnv:return N.modEnvRelease;case c.initialFilterFc:return N.filterCutoff;case c.initialFilterQ:return N.filterQ;case c.modEnvToFilterFc:return{source:X.modEnv,destination:N.filterCutoff,amount:A,isBipolar:!1};case c.modEnvToPitch:return{source:X.modEnv,destination:N.pitch,amount:A,isBipolar:!1};case c.modLfoToFilterFc:return{source:X.modLfo,destination:N.filterCutoff,amount:A,isBipolar:!0};case c.modLfoToVolume:return{source:X.modLfo,destination:N.gain,amount:A,isBipolar:!0};case c.modLfoToPitch:return{source:X.modLfo,destination:N.pitch,amount:A,isBipolar:!0};case c.vibLfoToPitch:return{source:X.vibratoLfo,destination:N.pitch,amount:A,isBipolar:!0};case c.keyNumToVolEnvHold:return{source:X.keyNum,destination:N.volEnvHold,amount:A,isBipolar:!0};case c.keyNumToVolEnvDecay:return{source:X.keyNum,destination:N.volEnvDecay,amount:A,isBipolar:!0};case c.keyNumToModEnvHold:return{source:X.keyNum,destination:N.modEnvHold,amount:A,isBipolar:!0};case c.keyNumToModEnvDecay:return{source:X.keyNum,destination:N.modEnvDecay,amount:A,isBipolar:!0};case c.scaleTuning:return{source:X.keyNum,destination:N.pitch,amount:A*128,isBipolar:!1}}}toString(){return`Source: ${this.source.toString()},
|
|
10
10
|
Control: ${this.control.toString()},
|
|
11
11
|
Scale: ${this.scale} >> 16 = ${this.shortScale},
|
|
12
12
|
Output transform: ${this.transformName}
|
|
13
13
|
Destination: ${this.destinationName}`}write(){let e=new ee(12);return Ae(e,this.source.source),Ae(e,this.control.source),Ae(e,this.destination),Ae(e,this.transform|this.control.toTransformFlag()<<4|this.source.toTransformFlag()<<10),ge(e,this.scale),e}toSFGenerator(e){let A=this.destination,s=this.shortScale;switch(A){default:h.info(`%cFailed converting DLS articulator into SF generator: %c${this.toString()}%c
|
|
14
|
-
(invalid destination)`,d.warn,d.value,d.unrecognized);return;case N.pan:e.setGenerator(c.pan,s);break;case N.gain:e.addToGenerator(c.initialAttenuation,-s/.4);break;case N.filterCutoff:e.setGenerator(c.initialFilterFc,s);break;case N.filterQ:e.setGenerator(c.initialFilterQ,s);break;case N.modLfoFreq:e.setGenerator(c.freqModLFO,s);break;case N.modLfoDelay:e.setGenerator(c.delayModLFO,s);break;case N.vibLfoFreq:e.setGenerator(c.freqVibLFO,s);break;case N.vibLfoDelay:e.setGenerator(c.delayVibLFO,s);break;case N.volEnvDelay:e.setGenerator(c.delayVolEnv,s);break;case N.volEnvAttack:e.setGenerator(c.attackVolEnv,s);break;case N.volEnvHold:e.setGenerator(c.holdVolEnv,s);break;case N.volEnvDecay:e.setGenerator(c.decayVolEnv,s);break;case N.volEnvRelease:e.setGenerator(c.releaseVolEnv,s);break;case N.volEnvSustain:e.setGenerator(c.sustainVolEnv,1e3-s);break;case N.modEnvDelay:e.setGenerator(c.delayModEnv,s);break;case N.modEnvAttack:e.setGenerator(c.attackModEnv,s);break;case N.modEnvHold:e.setGenerator(c.holdModEnv,s);break;case N.modEnvDecay:e.setGenerator(c.decayModEnv,s);break;case N.modEnvRelease:e.setGenerator(c.releaseModEnv,s);break;case N.modEnvSustain:e.setGenerator(c.sustainModEnv,1e3-s);break;case N.reverbSend:e.setGenerator(c.reverbEffectsSend,s);break;case N.chorusSend:e.setGenerator(c.chorusEffectsSend,s);break;case N.pitch:e.fineTuning+=s;break}}toSFModulator(e){let A=this.shortScale,s,n,a=new st,r=this.toCombinedSFDestination();if(r){s=r;let
|
|
14
|
+
(invalid destination)`,d.warn,d.value,d.unrecognized);return;case N.pan:e.setGenerator(c.pan,s);break;case N.gain:e.addToGenerator(c.initialAttenuation,-s/.4);break;case N.filterCutoff:e.setGenerator(c.initialFilterFc,s);break;case N.filterQ:e.setGenerator(c.initialFilterQ,s);break;case N.modLfoFreq:e.setGenerator(c.freqModLFO,s);break;case N.modLfoDelay:e.setGenerator(c.delayModLFO,s);break;case N.vibLfoFreq:e.setGenerator(c.freqVibLFO,s);break;case N.vibLfoDelay:e.setGenerator(c.delayVibLFO,s);break;case N.volEnvDelay:e.setGenerator(c.delayVolEnv,s);break;case N.volEnvAttack:e.setGenerator(c.attackVolEnv,s);break;case N.volEnvHold:e.setGenerator(c.holdVolEnv,s);break;case N.volEnvDecay:e.setGenerator(c.decayVolEnv,s);break;case N.volEnvRelease:e.setGenerator(c.releaseVolEnv,s);break;case N.volEnvSustain:e.setGenerator(c.sustainVolEnv,1e3-s);break;case N.modEnvDelay:e.setGenerator(c.delayModEnv,s);break;case N.modEnvAttack:e.setGenerator(c.attackModEnv,s);break;case N.modEnvHold:e.setGenerator(c.holdModEnv,s);break;case N.modEnvDecay:e.setGenerator(c.decayModEnv,s);break;case N.modEnvRelease:e.setGenerator(c.releaseModEnv,s);break;case N.modEnvSustain:e.setGenerator(c.sustainModEnv,1e3-s);break;case N.reverbSend:e.setGenerator(c.reverbEffectsSend,s);break;case N.chorusSend:e.setGenerator(c.chorusEffectsSend,s);break;case N.pitch:e.fineTuning+=s;break}}toSFModulator(e){let A=this.shortScale,s,n,a=new st,r=this.toCombinedSFDestination();if(r){s=r;let i=this.control.toSFSource();if(!i){this.failedConversion("Invalid control");return}n=i}else{let i=this.toSFDestination();if(!i){this.failedConversion("Invalid destination");return}typeof i=="object"?(A=i.newAmount,s=i.gen):s=i;let g=this.source.toSFSource();if(!g){this.failedConversion("Invalid source");return}n=g;let l=this.control.toSFSource();if(!l){this.failedConversion("Invalid control");return}a=l}this.transform!==le.linear&&n.curveType===le.linear&&(n.curveType=this.transform),s===c.initialAttenuation&&((this.source.source===X.velocity||this.source.source===X.volume||this.source.source===X.expression)&&(n.isNegative=!0),A=Math.min(960,Math.max(0,A)));let o=new ke(n,a,s,A,0);e.addModulators(o)}toCombinedSFDestination(){let e=this.source.source,A=this.destination;return e===X.vibratoLfo&&A===N.pitch?c.vibLfoToPitch:e===X.modLfo&&A===N.pitch?c.modLfoToPitch:e===X.modLfo&&A===N.filterCutoff?c.modLfoToFilterFc:e===X.modLfo&&A===N.gain?c.modLfoToVolume:e===X.modEnv&&A===N.filterCutoff?c.modEnvToFilterFc:e===X.modEnv&&A===N.pitch?c.modEnvToPitch:void 0}failedConversion(e){h.info(`%cFailed converting DLS articulator into SF2:
|
|
15
15
|
%c${this.toString()}%c
|
|
16
|
-
(${e})`,d.warn,d.value,d.unrecognized)}toSFDestination(){let e=this.shortScale;switch(this.destination){default:case N.none:return;case N.pan:return c.pan;case N.gain:return{gen:c.initialAttenuation,newAmount:-e};case N.pitch:return c.fineTune;case N.keyNum:return c.overridingRootKey;case N.volEnvDelay:return c.delayVolEnv;case N.volEnvAttack:return c.attackVolEnv;case N.volEnvHold:return c.holdVolEnv;case N.volEnvDecay:return c.decayVolEnv;case N.volEnvSustain:return{gen:c.sustainVolEnv,newAmount:1e3-e};case N.volEnvRelease:return c.releaseVolEnv;case N.modEnvDelay:return c.delayModEnv;case N.modEnvAttack:return c.attackModEnv;case N.modEnvHold:return c.holdModEnv;case N.modEnvDecay:return c.decayModEnv;case N.modEnvSustain:return{gen:c.sustainModEnv,newAmount:1e3-e};case N.modEnvRelease:return c.releaseModEnv;case N.filterCutoff:return c.initialFilterFc;case N.filterQ:return c.initialFilterQ;case N.chorusSend:return c.chorusEffectsSend;case N.reverbSend:return c.reverbEffectsSend;case N.modLfoFreq:return c.freqModLFO;case N.modLfoDelay:return c.delayModLFO;case N.vibLfoFreq:return c.freqVibLFO;case N.vibLfoDelay:return c.delayVibLFO}}},un=class extends Ht{connectionBlocks=new Array;mode="dls2";get length(){return this.connectionBlocks.length}copyFrom(t){this.mode=t.mode;for(let e of t.connectionBlocks)this.connectionBlocks.push(qt.copyFrom(e))}fromSFZone(t){this.mode="dls2";let e=new zt;e.copyFrom(t);for(let A of e.generators){let s;switch(A.type){default:continue;case c.keyNumToVolEnvDecay:s=c.decayVolEnv;break;case c.keyNumToVolEnvHold:s=c.holdVolEnv;break;case c.keyNumToModEnvDecay:s=c.decayModEnv;break;case c.keyNumToModEnvHold:s=c.holdModEnv}let n=e.getGenerator(s,void 0),a=A.value*-128;if(n===void 0)continue;let r=n-60/128*a;e.setGenerator(A.type,a,!1),e.setGenerator(s,r,!1)}for(let A of e.generators)qt.fromSFGenerator(A,this);for(let A of e.modulators)qt.fromSFModulator(A,this)}read(t){let e=U.findListType(t,"lart"),A=U.findListType(t,"lar2");if(e)for(this.mode="dls1";e.data.currentIndex<e.data.length;){let s=U.read(e.data);if(s.header!=="art1"&&s.header!=="art2")continue;let n=s.data,a=V(n,4);a!==8&&h.warn(`CbSize in articulation mismatch. Expected 8, got ${a}`);let r=V(n,4);for(let i=0;i<r;i++)this.connectionBlocks.push(qt.read(n))}else if(A)for(this.mode="dls2";A.data.currentIndex<A.data.length;){let s=U.read(A.data);if(s.header!=="art1"&&s.header!=="art2")continue;let n=s.data,a=V(n,4);a!==8&&h.warn(`CbSize in articulation mismatch. Expected 8, got ${a}`);let r=V(n,4);for(let i=0;i<r;i++)this.connectionBlocks.push(qt.read(n))}}write(){let t=new ee(8);ge(t,8),ge(t,this.connectionBlocks.length);let e=this.connectionBlocks.map(s=>s.write()),A=U.getParts(this.mode==="dls2"?"art2":"art1",[t,...e]);return U.getParts(this.mode==="dls2"?"lar2":"lart",A,!0)}toSFZone(t){let e=(A,s,n,a)=>{let r=A/-128;if(t.setGenerator(s,r),r<=120){let i=Math.round(.46875*A),o=this.connectionBlocks.find(g=>g.isStaticParameter&&g.destination===a);o&&t.setGenerator(n,i+o.shortScale)}};for(let A of this.connectionBlocks){let s=A.shortScale,n=A.source.source,a=A.control.source,r=A.destination;if(A.isStaticParameter){A.toSFGenerator(t);continue}if(a===X.none)if(n===X.keyNum){if(r===N.pitch){t.setGenerator(c.scaleTuning,s/128);continue}if(r===N.modEnvHold||r===N.modEnvDecay||r===N.volEnvHold||r===N.volEnvDecay)continue}else{let i=A.toCombinedSFDestination();if(i){t.setGenerator(i,s);continue}}A.toSFModulator(t)}for(let A of this.connectionBlocks){if(A.source.source!==X.keyNum)continue;let s=A.shortScale;switch(A.destination){default:case N.volEnvHold:e(s,c.keyNumToVolEnvHold,c.holdVolEnv,N.volEnvHold);break;case N.volEnvDecay:e(s,c.keyNumToVolEnvDecay,c.decayVolEnv,N.volEnvDecay);break;case N.modEnvHold:e(s,c.keyNumToModEnvHold,c.holdModEnv,N.modEnvHold);break;case N.modEnvDecay:e(s,c.keyNumToModEnvDecay,c.decayModEnv,N.modEnvDecay);break}}if(this.mode==="dls1"){t.setGenerator(c.delayVibLFO,t.getGenerator(c.delayModLFO,null)),t.setGenerator(c.freqVibLFO,t.getGenerator(c.freqModLFO,null)),t.setGenerator(c.vibLfoToPitch,t.getGenerator(c.modLfoToPitch,null)),t.setGenerator(c.modLfoToPitch,null);for(let A of t.modulators)A.destination===c.modLfoToPitch&&(A.destination=c.vibLfoToPitch)}}},JA=class lA{channel=1;tableIndex;fusOptions=0;phaseGroup=0;constructor(e){this.tableIndex=e}static copyFrom(e){let A=new lA(e.tableIndex);return A.channel=e.channel,A.phaseGroup=e.phaseGroup,A.fusOptions=e.fusOptions,A}static read(e){let A=V(e.data,2),s=V(e.data,2),n=V(e.data,4),a=new lA(V(e.data,4));return a.channel=n,a.fusOptions=A,a.phaseGroup=s,a}static fromSFZone(e,A){let s=e.indexOf(A.sample);if(s===-1)throw new Error(`Wave link error: Sample ${A.sample.name} does not exist in the sample list.`);let n=new lA(s);switch(A.sample.sampleType){default:case Fe.leftSample:case Fe.monoSample:n.channel=Math.trunc(1);break;case Fe.rightSample:n.channel=2}return n}write(){let e=new ee(12);return Ae(e,this.fusOptions),Ae(e,this.phaseGroup),ge(e,this.channel),ge(e,this.tableIndex),U.write("wlnk",e)}},CA=class Lt extends Ht{articulation=new un;keyRange={min:0,max:127};velRange={min:0,max:127};keyGroup=0;fusOptions=0;usLayer=0;waveSample;waveLink;constructor(e,A){super(),this.waveSample=A,this.waveLink=e}static copyFrom(e){let A=new Lt(JA.copyFrom(e.waveLink),Ut.copyFrom(e.waveSample));return A.keyGroup=e.keyGroup,A.keyRange={...e.keyRange},A.velRange={...e.velRange},A.usLayer=e.usLayer,A.fusOptions=e.fusOptions,A.articulation.copyFrom(e.articulation),A}static read(e,A){let s=this.verifyAndReadList(A,"rgn ","rgn2"),n=s.find(m=>m.header==="wsmp"),a=n?Ut.read(n):void 0,r=s.find(m=>m.header==="wlnk");if(!r){h.warn("Invalid DLS region: missing 'wlnk' chunk! Discarding...");return}let i=JA.read(r),o=s.find(m=>m.header==="rgnh");if(!o){h.warn("Invalid DLS region: missing 'rgnh' chunk! Discarding...");return}let g=e[i.tableIndex];g||Lt.parsingError(`Invalid sample index: ${i.tableIndex}. Samples available: ${e.length}`),a??=g.waveSample;let l=new Lt(i,a),C=V(o.data,2),B=V(o.data,2),I=V(o.data,2),E=V(o.data,2);return I===0&&E===0&&(E=127,I=0),l.keyRange.max=B,l.keyRange.min=C,l.velRange.max=E,l.velRange.min=I,l.fusOptions=V(o.data,2),l.keyGroup=V(o.data,2),o.data.length-o.data.currentIndex>=2&&(l.usLayer=V(o.data,2)),l.articulation.read(s),l}static fromSFZone(e,A){let s=Ut.fromSFZone(e),n=new Lt(JA.fromSFZone(A,e),s);return n.keyRange.min=Math.max(e.keyRange.min,0),n.keyRange.max=e.keyRange.max,n.velRange.min=Math.max(e.velRange.min,0),n.velRange.max=e.velRange.max,n.keyGroup=e.getGenerator(c.exclusiveClass,0),n.articulation.fromSFZone(e),n}write(){let e=[this.writeHeader(),this.waveSample.write(),this.waveLink.write(),...this.articulation.write()];return U.getParts("rgn2",e,!0)}toSFZone(e,A){let s=A[this.waveLink.tableIndex];s||Lt.parsingError(`Invalid sample index: ${this.waveLink.tableIndex}`);let n=e.createZone(s);return n.keyRange=this.keyRange,n.velRange=this.velRange,this.keyRange.max===127&&this.keyRange.min===0&&(n.keyRange.min=-1),this.velRange.max===127&&this.velRange.min===0&&(n.velRange.min=-1),this.keyGroup!==0&&n.setGenerator(c.exclusiveClass,this.keyGroup),this.waveSample.toSFZone(n,s),this.articulation.toSFZone(n),n.generators=n.generators.filter(a=>a.value!==Ve[a.type].def),n}writeHeader(){let e=new ee(14);return Ae(e,Math.max(this.keyRange.min,0)),Ae(e,this.keyRange.max),Ae(e,Math.max(this.velRange.min,0)),Ae(e,this.velRange.max),Ae(e,this.fusOptions),Ae(e,this.keyGroup),Ae(e,this.usLayer),U.write("rgnh",e)}},KA=class BA extends Ht{articulation=new un;regions=new Array;name="Unnamed";bankLSB=0;bankMSB=0;isGMGSDrum=!1;program=0;static copyFrom(e){let A=new BA;A.name=e.name,A.isGMGSDrum=e.isGMGSDrum,A.bankMSB=e.bankMSB,A.bankLSB=e.bankLSB,A.program=e.program,A.articulation.copyFrom(e.articulation);for(let s of e.regions)A.regions.push(CA.copyFrom(s));return A}static read(e,A){let s=this.verifyAndReadList(A,"ins "),n=s.find(C=>C.header==="insh");if(!n)throw h.groupEnd(),new Error("No instrument header!");let a="",r=U.findListType(s,"INFO");if(r){let C=U.read(r.data);for(;C.header!=="INAM";)C=U.read(r.data);a=Ee(C.data,C.data.length).trim()}a.length===0&&(a="Unnamed Instrument");let i=new BA;i.name=a;let o=V(n.data,4),g=V(n.data,4);i.program=V(n.data,4)&127,i.bankMSB=g>>>8&127,i.bankLSB=g&127,i.isGMGSDrum=g>>>31>0,h.groupCollapsed(`%cParsing %c"${a}"%c...`,d.info,d.recognized,d.info);let l=U.findListType(s,"lrgn");if(!l)throw h.groupEnd(),new Error("No region list!");i.articulation.read(s);for(let C=0;C<o;C++){let B=U.read(l.data);this.verifyHeader(B,"LIST");let I=Ee(B.data,4);I!=="rgn "&&I!=="rgn2"&&(h.groupEnd(),this.parsingError(`Invalid DLS region! Expected "rgn " or "rgn2" got "${I}"`));let E=CA.read(e,B);E&&i.regions.push(E)}return h.groupEnd(),i}static fromSFPreset(e,A){let s=new BA;s.name=e.name,s.bankLSB=e.bankLSB,s.bankMSB=e.bankMSB,s.program=e.program,s.isGMGSDrum=e.isGMGSDrum,h.group(`%cConverting %c${e.toString()}%c to DLS...`,d.info,d.value,d.info);let n=e.toFlattenedInstrument();for(let a of n.zones)s.regions.push(CA.fromSFZone(a,A));return h.groupEnd(),s}write(){h.groupCollapsed(`%cWriting %c${this.name}%c...`,d.info,d.recognized,d.info);let e=[this.writeHeader()],A=this.regions.flatMap(n=>n.write());e.push(...U.getParts("lrgn",A,!0)),this.articulation.length>0&&e.push(...this.articulation.write());let s=U.write("INAM",$e(this.name,!0));return e.push(U.write("INFO",s,!1,!0)),h.groupEnd(),U.writeParts("ins ",e,!0)}toSFPreset(e){let A=new _t(e);A.name=this.name,A.bankMSB=this.bankMSB,A.bankLSB=this.bankLSB,A.isGMGSDrum=this.isGMGSDrum,A.program=this.program;let s=new Wt;s.name=this.name,A.createZone(s),this.articulation.toSFZone(s.globalZone);for(let n of this.regions)n.toSFZone(s,e.samples);s.globalize(),s.globalZone.modulators.some(n=>n.destination===c.reverbEffectsSend)||s.globalZone.addModulators(ke.copyFrom(fn)),s.globalZone.modulators.some(n=>n.destination===c.chorusEffectsSend)||s.globalZone.addModulators(ke.copyFrom(Qn)),s.globalZone.generators=s.globalZone.generators.filter(n=>n.value!==Ve[n.type].def),e.addPresets(A),e.addInstruments(s)}writeHeader(){let e=new ee(12);ge(e,this.regions.length);let A=(this.bankMSB&127)<<8|this.bankLSB&127;return this.isGMGSDrum&&(A|=1<<31),ge(e,A),ge(e,this.program&127),U.write("insh",e)}},gs={software:"SpessaSynth"},mn=class Is extends Ht{samples=new Array;instruments=new Array;soundBankInfo={name:"Unnamed DLS sound bank",creationDate:new Date,software:"SpessaSynth",soundEngine:"DLS Level 2.2",product:"SpessaSynth DLS",version:{major:2,minor:4}};static read(e){if(!e)throw new Error("No data provided!");let A=new ee(e);h.group("%cParsing DLS file...",d.info);let s=U.read(A,!1);this.verifyHeader(s,"RIFF"),this.verifyText(Ee(A,4).toLowerCase(),"dls ");let n=[];for(;A.currentIndex<A.length;)n.push(U.read(A));let a=new Is,r=U.findListType(n,"INFO");if(r)for(;r.data.currentIndex<r.data.length;){let E=U.read(r.data),m=E.header,k=Ee(E.data,E.size);switch(m){case"INAM":a.soundBankInfo.name=k;break;case"ICRD":a.soundBankInfo.creationDate=Es(k);break;case"ICMT":a.soundBankInfo.comment=k;break;case"ISBJ":a.soundBankInfo.subject=k;break;case"ICOP":a.soundBankInfo.copyright=k;break;case"IENG":a.soundBankInfo.engineer=k;break;case"IPRD":a.soundBankInfo.product=k;break;case"ISFT":a.soundBankInfo.software=k}}this.printInfo(a);let i=n.find(E=>E.header==="colh");if(!i)return this.parsingError("No colh chunk!"),5;let o=V(i.data,4);h.info(`%cInstruments amount: %c${o}`,d.info,d.recognized);let g=U.findListType(n,"wvpl");if(!g)return this.parsingError("No wvpl chunk!"),5;let l=this.verifyAndReadList(g,"wvpl");for(let E of l)a.samples.push(Ls.read(E));let C=U.findListType(n,"lins");if(!C)return this.parsingError("No lins chunk!"),5;let B=this.verifyAndReadList(C,"lins");h.groupCollapsed("%cLoading instruments...",d.info),B.length!==o&&h.warn(`Colh reported invalid amount of instruments. Detected ${B.length}, expected ${o}`);for(let E of B)a.instruments.push(KA.read(a.samples,E));h.groupEnd();let I=n.find(E=>E.header==="pgal");if(I){h.info("%cFound the instrument aliasing chunk!",d.recognized);let E=I.data;(E[0]!==0||E[1]!==1||E[2]!==2||E[3]!==3)&&(E.currentIndex+=4);let m=a.instruments.find(y=>Se.isXGDrum(y.bankMSB)||y.isGMGSDrum);if(!m)return h.warn("MobileBAE aliasing chunk without a drum preset. Aborting!"),a;let k=E.slice(E.currentIndex,E.currentIndex+128);E.currentIndex+=128;for(let y=0;y<128;y++){let b=k[y];if(b===y)continue;let R=m.regions.find(S=>S.keyRange.max===b&&S.keyRange.min===b);if(!R){h.warn(`Invalid drum alias ${y} to ${b}: region does not exist.`);continue}let M=CA.copyFrom(R);M.keyRange.max=y,M.keyRange.min=y,m.regions.push(M)}for(E.currentIndex+=4;E.currentIndex<E.length;){let y=V(E,2),b=y&127,R=y>>7&127,M=E[E.currentIndex++],S=E[E.currentIndex++];S!==0&&h.warn(`Invalid alias byte. Expected 0, got ${S}`);let Q=V(E,2),p=Q&127,D=Q>>7&127,q=E[E.currentIndex++];S=E[E.currentIndex++],S!==0&&h.warn(`Invalid alias header. Expected 0, got ${S}`);let K=a.instruments.find(Y=>Y.bankLSB===p&&Y.bankMSB===D&&Y.program===q&&!Y.isGMGSDrum);if(!K){h.warn(`Invalid alias. Missing instrument: ${p}:${D}:${q}`);continue}let O=KA.copyFrom(K);O.bankMSB=R,O.bankLSB=b,O.program=M,a.instruments.push(O)}}return h.info(`%cParsing finished! %c"${a.soundBankInfo.name||"UNNAMED"}"%c has %c${a.instruments.length}%c instruments and %c${a.samples.length}%c samples.`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized,d.info),h.groupEnd(),a}static fromSF(e,A){h.groupCollapsed("%cSaving SF2 to DLS level 2...",d.info);let s=new Is;s.soundBankInfo={...e.soundBankInfo};for(let n=0;n<e.samples.length;n++){let a=e.samples[n];s.samples.push(Ls.fromSFSample(a)),A?.(n/e.samples.length)}for(let n of e.presets)s.instruments.push(KA.fromSFPreset(n,e.samples));return h.info("%cConversion complete!",d.recognized),h.groupEnd(),s}static printInfo(e){for(let[A,s]of Object.entries(e.soundBankInfo))if(typeof s=="object"&&"major"in s){let n=s;h.info(`%c${A}: %c"${n.major}.${n.minor}"`,d.info,d.recognized)}else h.info(`%c${A}: %c${s.toLocaleString()}`,d.info,d.recognized)}write(e=gs){let A=bA(e,gs);h.groupCollapsed("%cSaving DLS...",d.info);let s=new ee(4);ge(s,this.instruments.length);let n=U.write("colh",s);h.groupCollapsed("%cWriting instruments...",d.info);let a=U.getParts("lins",this.instruments.map(y=>y.write()),!0);h.info("%cSuccess!",d.recognized),h.groupEnd(),h.groupCollapsed("%cWriting WAVE samples...",d.info);let r=0,i=[],o=[],g=0;for(let y of this.samples){let b=y.write();A.progressFunction?.(g/this.samples.length),h.info(`%cWrote sample %c${g}. ${y.name}%c of %c${this.samples.length}.`,d.info,d.recognized,d.info,d.recognized),i.push(r),r+=b.reduce((R,M)=>R+M.length,0),o.push(...b),g++}let l=U.getParts("wvpl",o,!0);h.info("%cSucceeded!",d.recognized);let C=new ee(8+4*i.length);ge(C,8),ge(C,i.length);for(let y of i)ge(C,y);let B=U.write("ptbl",C);this.soundBankInfo.software=A.software;let I=[],E=this.soundBankInfo,m=(y,b)=>{b&&I.push(...U.getParts(y,[$e(b,!0)]))};m("INAM",E.name),m("ICMT",E.comment),m("ICOP",E.copyright),m("ICRD",Bs(E.creationDate)),m("IENG",E.engineer),m("IPRD",E.product),m("ISFT",A.software),m("ISBJ",E.subject),h.info("%cCombining everything...");let k=U.writeParts("RIFF",[$e("DLS "),n,...a,B,...l,...U.getParts("INFO",I,!0)]);return h.info("%cSaved successfully!",d.recognized),h.groupEnd(),k.buffer}toSF(){h.group("%cConverting DLS to SF2...",d.info);let e=new pn;e.soundBankInfo.version.minor=4,e.soundBankInfo.version.major=2,e.soundBankInfo={...this.soundBankInfo};for(let A of this.samples)A.toSFSample(e);for(let A of this.instruments)A.toSFPreset(e);return e.flush(),h.info("%cConversion complete!",d.recognized),h.groupEnd(),e}},pn=class EA{static isSF3DecoderReady=FA.isInitialized;soundBankInfo={name:"Unnamed",creationDate:new Date,software:"SpessaSynth",soundEngine:"E-mu 10K2",version:{major:2,minor:4}};presets=[];samples=[];instruments=[];defaultModulators=Cn.map(ke.copyFrom.bind(ke));customDefaultModulators=!1;_isXGBank=!1;get isXGBank(){return this._isXGBank}static mergeSoundBanks(...e){let A=e.shift();if(!A)throw new Error("No sound banks provided!");let s=A.presets;for(;e.length>0;){let a=e?.shift()?.presets;if(a)for(let r of a)s.some(i=>r.matches(i))||s.push(r)}let n=new EA;return n.addCompletePresets(s),n.soundBankInfo={...A.soundBankInfo},n}static getSampleSoundBankFile(){let e=new EA,A=new Float32Array(128);for(let r=0;r<128;r++)A[r]=r/128*2-1;let s=new Ya;s.name="Saw",s.originalKey=65,s.pitchCorrection=20,s.loopEnd=127,s.setAudioData(A,44100),e.addSamples(s);let n=new Wt;n.name="Saw Wave",n.globalZone.addGenerators(new Ge(c.initialAttenuation,375),new Ge(c.releaseVolEnv,-1e3),new Ge(c.sampleModes,1)),n.createZone(s),n.createZone(s).setGenerator(c.fineTune,-9),e.addInstruments(n);let a=new _t(e);return a.name="Saw Wave",a.createZone(n),e.addPresets(a),e.soundBankInfo.name="Dummy",e.flush(),e.writeSF2()}static copyFrom(e){let A=new EA;for(let s of e.presets)A.clonePreset(s);return A.soundBankInfo={...e.soundBankInfo},A}addCompletePresets(e){this.addPresets(...e);let A=[];for(let n of e)for(let a of n.zones)a.instrument&&!A.includes(a.instrument)&&A.push(a.instrument);this.addInstruments(...A);let s=[];for(let n of A)for(let a of n.zones)a.sample&&!s.includes(a.sample)&&s.push(a.sample);this.addSamples(...s)}async setSampleFormat(e){let A=0,s=e.format,n=e.progressFunction;for(let a of this.samples){switch(s){default:case"pcm":a.setAudioData(a.getAudioData(),a.sampleRate);break;case"compressed":{let r=e.compressionFunction;if(!r)throw new Error(`No compression function supplied but '${s}' was requested.`);await a.compressSample(r)}}A++,n?.(A/this.samples.length),h.info(`%cEncoded sample %c${A}. ${a.name}%c of %c${this.samples.length}%c. Compressed: %c${a.isCompressed}%c.`,d.info,d.recognized,d.info,d.recognized,d.info,a.isCompressed?d.recognized:d.unrecognized,d.info)}switch(s){default:case"pcm":this.soundBankInfo.version.major=2,this.soundBankInfo.version.minor=4;break;case"compressed":this.soundBankInfo.version.major=3,this.soundBankInfo.version.minor=0}}writeDLS(e=gs){let A=e.progressFunction;return mn.fromSF(this,A?s=>A(s/2):void 0).write({...e,progressFunction:A?s=>A(.5+s/2):void 0})}writeSF2(e=dn){return Za(this,e)}addPresets(...e){this.presets.push(...e)}addInstruments(...e){this.instruments.push(...e)}addSamples(...e){this.samples.push(...e)}cloneSample(e){let A=this.samples.find(n=>n.name===e.name);if(A)return A;let s=new MA(e.name,e.sampleRate,e.originalKey,e.pitchCorrection,e.sampleType,e.loopStart,e.loopEnd);if(e.isCompressed?s.setCompressedData(e.getRawData(!0)):s.setAudioData(e.getAudioData(),e.sampleRate),this.addSamples(s),e.linkedSample){let n=this.cloneSample(e.linkedSample);n.linkedSample||s.setLinkedSample(n,s.sampleType)}return s}cloneInstrument(e){let A=this.instruments.find(n=>n.name===e.name);if(A)return A;let s=new Wt;s.name=e.name,s.globalZone.copyFrom(e.globalZone);for(let n of e.zones)s.createZone(this.cloneSample(n.sample)).copyFrom(n);return this.addInstruments(s),s}clonePreset(e){let A=this.presets.find(n=>n.name===e.name);if(A)return A;let s=new _t(this);s.name=e.name,s.bankMSB=e.bankMSB,s.bankLSB=e.bankLSB,s.isGMGSDrum=e.isGMGSDrum,s.program=e.program,s.library=e.library,s.genre=e.genre,s.morphology=e.morphology,s.globalZone.copyFrom(e.globalZone);for(let n of e.zones)s.createZone(this.cloneInstrument(n.instrument)).copyFrom(n);return this.addPresets(s),s}flush(){this.presets.sort(ze.compare.bind(ze)),this.parseInternal()}trim(e){let A=(s,n)=>{let a=0;for(let r=0;r<s.zones.length;r++){let i=s.zones[r],o=i.keyRange,g=i.velRange,l=!1;for(let[C,B]of n)if(C>=o.min&&C<=o.max&&[...B].some(I=>I>=g.min&&I<=g.max)){l=!0;break}l||(h.info(`%c${i.sample.name}%c removed from %c${s.name}%c.`,d.recognized,d.info,d.recognized,d.info),s.deleteZone(r)&&(a++,r--,h.info(`%c${i.sample.name}%c deleted`,d.recognized,d.info)),i.sample.useCount<1&&this.deleteSample(i.sample))}return a};h.groupCollapsed("%cTrimming sound bank...",d.info),h.info("Combinations to trim for:",e);for(let s=0;s<this.presets.length;s++){let n=this.presets[s],a=e.get(n);if(a===void 0)h.info(`%cDeleting preset %c${n.name}%c and its zones`,d.info,d.recognized,d.info),this.deletePreset(n),s--;else{h.groupCollapsed(`%cTrimming %c${n.name}`,d.info,d.recognized),h.info(`Keys for ${n.name}:`,a);let r=0;for(let i=0;i<n.zones.length;i++){let o=n.zones[i],g=o.keyRange,l=o.velRange,C=!1;for(let[B,I]of a)if(B>=g.min&&B<=g.max&&[...I].some(E=>E>=l.min&&E<=l.max)){C=!0;let E=A(o.instrument,a);h.info(`%cTrimmed off %c${E}%c instrument zones from %c${o.instrument.name}`,d.info,d.recognized,d.info,d.recognized);break}C||(r++,n.deleteZone(i),o.instrument.useCount<1&&this.deleteInstrument(o.instrument),i--)}h.info(`%cTrimmed off %c${r}%c preset zones from %c${n.name}`,d.info,d.recognized,d.info,d.recognized),h.groupEnd()}}this.removeUnusedElements(),h.info("%cSound bank modified!",d.recognized),h.groupEnd()}removeUnusedElements(){this.instruments=this.instruments.filter(e=>{e.deleteUnusedZones();let A=e.useCount<1;return A&&e.delete(),!A}),this.samples=this.samples.filter(e=>{let A=e.useCount<1;return A&&e.unlinkSample(),!A})}deleteInstrument(e){e.delete(),this.instruments.splice(this.instruments.indexOf(e),1)}deletePreset(e){e.delete(),this.presets.splice(this.presets.indexOf(e),1)}deleteSample(e){e.unlinkSample(),this.samples.splice(this.samples.indexOf(e),1)}getPreset(e,A){return ze.selectPatch(this.presets,e,A)}destroySoundBank(){this.presets.length=0,this.instruments.length=0,this.samples.length=0}parsingError(e){throw new Error(`SF parsing error: ${e} The file may be corrupted.`)}parseInternal(){this._isXGBank=!1;let e=new Set([0,1,2,3,4,5,6,7,8,9,16,17,24,25,26,27,28,29,30,31,32,33,40,41,48,56,57,58,64,65,66,126,127]);for(let A of this.presets)if(Se.isXGDrum(A.bankMSB)&&(this._isXGBank=!0,!e.has(A.program))){this._isXGBank=!1,h.info(`%cThis bank is not valid XG. Preset %c${A.toString()}%c is not a valid XG drum. XG mode will use presets on bank 128.`,d.info,d.value,d.info);break}}printInfo(){for(let[e,A]of Object.entries(this.soundBankInfo))if(typeof A=="object"&&"major"in A){let s=A;h.info(`%c${e}: %c"${s.major}.${s.minor}"`,d.info,d.recognized)}else h.info(`%c${e}: %c${A.toLocaleString()}`,d.info,d.recognized)}},ja=class extends Ge{constructor(t){let e=t.currentIndex,A=t[e+1]<<8|t[e],s=ls(t[e+2],t[e+3]);t.currentIndex+=4,super(A,s,!1)}};function Ns(t){let e=[];for(;t.data.length>t.data.currentIndex;)e.push(new ja(t.data));return e.pop(),e}function er(t,e,A,s,n){let a=t.gen,r=t.mod,i=0,o=0;for(let g of n)for(let l=0;l<g.zonesCount;l++){let C=a[o++],B=a[o],I=e.slice(C,B),E=r[i++],m=r[i],k=A.slice(E,m);I.some(y=>y.type===c.instrument)?g.createSoundFontZone(k,I,s):(g.globalZone.addGenerators(...I),g.globalZone.addModulators(...k))}}var tr=class extends _t{zoneStartIndex;zonesCount=0;constructor(t,e){super(e),this.name=Ee(t.data,20),this.program=V(t.data,2);let A=V(t.data,2);this.bankMSB=A&127,this.isGMGSDrum=(A&128)>0,this.bankLSB=A>>8,this.zoneStartIndex=V(t.data,2),this.library=V(t.data,4),this.genre=V(t.data,4),this.morphology=V(t.data,4)}createSoundFontZone(t,e,A){let s=e.find(r=>r.type===c.instrument),n;if(s)n=A[s.value];else throw new Error("No instrument ID found in preset zone.");if(!n)throw new Error(`Invalid instrument ID: ${s.value}, available instruments: ${A.length}`);let a=new En(this,n);return a.addGenerators(...e),a.addModulators(...t),this.zones.push(a),a}};function Ps(t,e){let A=[];for(;t.data.length>t.data.currentIndex;){let s=new tr(t,e);if(A.length>0){let n=A[A.length-1];n.zonesCount=s.zoneStartIndex-n.zoneStartIndex}A.push(s)}return A.pop(),A}var Ar=class extends Wt{zoneStartIndex;zonesCount=0;constructor(t){super(),this.name=Ee(t.data,20),this.zoneStartIndex=V(t.data,2)}createSoundFontZone(t,e,A){let s=e.find(r=>r.type===c.sampleID),n;if(s)n=A[s.value];else throw new Error("No sample ID found in instrument zone.");if(!n)throw new Error(`Invalid sample ID: ${s.value}, available samples: ${A.length}`);let a=new Bn(this,n);return a.addGenerators(...e),a.addModulators(...t),this.zones.push(a),a}};function Ts(t){let e=[];for(;t.data.length>t.data.currentIndex;){let A=new Ar(t);if(e.length>0){let s=e[e.length-1];s.zonesCount=A.zoneStartIndex-s.zoneStartIndex}e.push(A)}return e.pop(),e}function VA(t){let e=[];for(;t.data.length>t.data.currentIndex;){let A=t.data,s=V(A,2),n=V(A,2),a=ls(A[A.currentIndex++],A[A.currentIndex++]),r=V(A,2),i=V(A,2);e.push(new ue(s,r,n,a,i))}return e.pop(),e}function sr(t,e,A,s,n){let a=t.gen,r=t.mod,i=0,o=0;for(let g of n)for(let l=0;l<g.zonesCount;l++){let C=a[o++],B=a[o],I=e.slice(C,B),E=r[i++],m=r[i],k=A.slice(E,m);I.some(y=>y.type===c.sampleID)?g.createSoundFontZone(k,I,s):(g.globalZone.addGenerators(...I),g.globalZone.addModulators(...k))}}function IA(t){let e=[],A=[];for(;t.data.length>t.data.currentIndex;)A.push(V(t.data,2)),e.push(V(t.data,2));return{mod:e,gen:A}}var nr=class extends pn{sampleDataStartIndex=0;constructor(t,e=!0){if(super(),e)throw new Error("Using the constructor directly is deprecated. Use SoundBankLoader.fromArrayBuffer() instead.");let A=new ee(t);h.group("%cParsing a SoundFont2 file...",d.info),A||(h.groupEnd(),this.parsingError("No data provided!"));let s=U.read(A,!1);this.verifyHeader(s,"riff");let n=Ee(A,4).toLowerCase();if(n!=="sfbk"&&n!=="sfpk")throw h.groupEnd(),new SyntaxError(`Invalid soundFont! Expected "sfbk" or "sfpk" got "${n}"`);let a=n==="sfpk",r=U.read(A);this.verifyHeader(r,"list");let i=Ee(r.data,4);if(i!=="INFO")throw h.groupEnd(),new SyntaxError(`Invalid soundFont! Expected "INFO" got "${i}"`);let o;for(;r.data.length>r.data.currentIndex;){let F=U.read(r.data),u=_e(F.data,F.data.length),x=F.header;switch(x){case"ifil":case"iver":{let P=V(F.data,2),te=V(F.data,2);x==="ifil"?this.soundBankInfo.version={major:P,minor:te}:this.soundBankInfo.romVersion={major:P,minor:te};break}case"DMOD":this.defaultModulators=VA(F),this.customDefaultModulators=!0;break;case"LIST":Ee(F.data,4)==="xdta"&&(h.info("%cExtended SF2 found!",d.recognized),o=F);break;case"ICRD":this.soundBankInfo.creationDate=Es(Ee(F.data,F.data.length));break;case"ISFT":this.soundBankInfo.software=u;break;case"IPRD":this.soundBankInfo.product=u;break;case"IENG":this.soundBankInfo.engineer=u;break;case"ICOP":this.soundBankInfo.copyright=u;break;case"INAM":this.soundBankInfo.name=u;break;case"ICMT":this.soundBankInfo.comment=u;break;case"irom":this.soundBankInfo.romInfo=u;break;case"isng":this.soundBankInfo.soundEngine=u}}this.printInfo();let g={};o!==void 0&&(g.phdr=U.read(o.data),g.pbag=U.read(o.data),g.pmod=U.read(o.data),g.pgen=U.read(o.data),g.inst=U.read(o.data),g.ibag=U.read(o.data),g.imod=U.read(o.data),g.igen=U.read(o.data),g.shdr=U.read(o.data));let l=U.read(A,!1);this.verifyHeader(l,"list"),this.verifyText(Ee(A,4),"sdta"),h.info("%cVerifying smpl chunk...",d.warn);let C=U.read(A,!1);this.verifyHeader(C,"smpl");let B;if(a){h.info("%cSF2Pack detected, attempting to decode the smpl chunk...",d.info);try{B=FA.decode(A.buffer.slice(A.currentIndex,A.currentIndex+l.size-12)).data[0]}catch(F){throw h.groupEnd(),new Error(`SF2Pack Ogg Vorbis decode error: ${F}`,{cause:F})}h.info(`%cDecoded the smpl chunk! Length: %c${B.length}`,d.info,d.value)}else B=A,this.sampleDataStartIndex=A.currentIndex;h.info(`%cSkipping sample chunk, length: %c${l.size-12}`,d.info,d.value),A.currentIndex+=l.size-12,h.info("%cLoading preset data chunk...",d.warn);let I=U.read(A);this.verifyHeader(I,"list"),Ee(I.data,4);let E=U.read(I.data);this.verifyHeader(E,"phdr");let m=U.read(I.data);this.verifyHeader(m,"pbag");let k=U.read(I.data);this.verifyHeader(k,"pmod");let y=U.read(I.data);this.verifyHeader(y,"pgen");let b=U.read(I.data);this.verifyHeader(b,"inst");let R=U.read(I.data);this.verifyHeader(R,"ibag");let M=U.read(I.data);this.verifyHeader(M,"imod");let S=U.read(I.data);this.verifyHeader(S,"igen");let Q=U.read(I.data);this.verifyHeader(Q,"shdr"),h.info("%cParsing samples...",d.info),A.currentIndex=this.sampleDataStartIndex;let p=Ms(Q,B,o===void 0);if(o&&g.shdr){let F=Ms(g.shdr,new Float32Array(1),!1);if(F.length===p.length)for(let[u,x]of p.entries())x.name+=F[u].name,x.linkedSampleIndex|=F[u].linkedSampleIndex<<16}for(let F of p)F.name=F.name.trim();this.samples.push(...p);let D=Ns(S),q=VA(M),K=Ts(b);if(o&&g.inst){let F=Ts(g.inst);if(F.length===K.length){for(let[u,x]of K.entries())x.name+=F[u].name,x.zoneStartIndex|=F[u].zoneStartIndex<<16;for(let[u,x]of K.entries())u<K.length-1&&(x.zonesCount=K[u+1].zoneStartIndex-x.zoneStartIndex)}}for(let F of K)F.name=F.name.trim();this.instruments.push(...K);let O=IA(R);if(o&&g.ibag){let F=IA(g.ibag);for(let u=0;u<O.mod.length;u++)O.mod[u]|=F.mod[u]<<16;for(let u=0;u<O.gen.length;u++)O.gen[u]|=F.gen[u]<<16}sr(O,D,q,this.samples,K);let Y=Ns(y),H=VA(k),Z=Ps(E,this);if(o&&g.phdr){let F=Ps(g.phdr,this);if(F.length===Z.length){for(let[u,x]of Z.entries())x.name+=F[u].name,x.zoneStartIndex|=F[u].zoneStartIndex<<16;for(let[u,x]of Z.entries())u<Z.length-1&&(x.zonesCount=Z[u+1].zoneStartIndex-x.zoneStartIndex)}}for(let F of Z)F.name=F.name.trim();this.addPresets(...Z);let T=IA(m);if(o&&g.pbag){let F=IA(g.pbag);for(let u=0;u<T.mod.length;u++)T.mod[u]|=F.mod[u]<<16;for(let u=0;u<T.gen.length;u++)T.gen[u]|=F.gen[u]<<16}er(T,Y,H,this.instruments,Z),this.flush(),h.info(`%cParsing finished! %c"${this.soundBankInfo.name}"%c has %c${this.presets.length}%c presets,
|
|
17
|
-
%c${this.instruments.length}%c instruments and %c${this.samples.length}%c samples.`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized,d.info),h.groupEnd()}verifyHeader(t,e){t.header.toLowerCase()!==e.toLowerCase()&&(h.groupEnd(),this.parsingError(`Invalid chunk header! Expected "${e.toLowerCase()}" got "${t.header.toLowerCase()}"`))}verifyText(t,e){t.toLowerCase()!==e.toLowerCase()&&(h.groupEnd(),this.parsingError(`Invalid FourCC: Expected "${e.toLowerCase()}" got "${t.toLowerCase()}"\``))}},$t=class{static fromArrayBuffer(t){return Ee(new ee(t.slice(8,12)),4).toLowerCase()==="dls "?this.loadDLS(t):new nr(t,!1)}static loadDLS(t){return mn.read(t).toSF()}},kA=class yn extends ke{isEffectModulator;isDefaultResonantModulator;isModWheelModulator;constructor(e,A,s,n,a,r,i,o){super(e,A,s,n,a),this.isEffectModulator=r,this.isDefaultResonantModulator=i,this.isModWheelModulator=o}static fromData(e,A,s,n,a){let r=e.toSourceEnum(),i=A.toSourceEnum();return new yn(e,A,s,n,a,(r===219||r===221)&&i===0&&(s===c.reverbEffectsSend||s===c.chorusEffectsSend),r===ln&&i===0&&s===c.initialFilterQ,(e.isCC&&e.index===f.modulationWheel||A.isCC&&A.index===f.modulationWheel)&&(s===c.modLfoToPitch||s===c.vibLfoToPitch))}static fromModulator(e){return this.fromData(e.primarySource,e.secondarySource,e.destination,e.transformAmount,e.transformType)}},ar=class{sampleData;generators;modulators;exclusiveClass;targetKey;velocity;rootKey;loopStart;loopEnd;playbackStep;loopingMode;constructor(t,e,A,s){let n=t.sample,a=t.generators;this.modulators=t.modulators.map(kA.fromModulator.bind(kA)),this.generators=a,this.rootKey=n.originalKey,a[c.overridingRootKey]>-1&&(this.rootKey=a[c.overridingRootKey]),this.targetKey=e,a[c.keyNum]>-1&&(this.targetKey=a[c.keyNum]),this.velocity=A,a[c.velocity]>-1&&(this.velocity=a[c.velocity]),this.exclusiveClass=a[c.exclusiveClass],this.loopStart=n.loopStart,this.loopEnd=n.loopEnd,this.sampleData=n.getAudioData(),this.playbackStep=n.sampleRate/s*Math.pow(2,n.pitchCorrection/1200),this.loopingMode=a[c.sampleModes]}},Us=Math.PI/2,dA=-500,Sn=500,us=Sn-dA,kn=new Float32Array(us+1),Dn=new Float32Array(us+1);for(let t=dA;t<=Sn;t++){let e=(t-dA)/us,A=t-dA;kn[A]=Math.cos(Us*e),Dn[A]=Math.sin(Us*e)}function rr(t,e,A,s,n,a){if(!t.isInRelease&&e>=t.releaseStartTime&&(t.isInRelease=!0,t.volEnv.startRelease(t),t.modEnv.startRelease(t),t.loopingMode===3&&(t.wavetable.isLooping=!1)),t.hasRendered=!0,!t.isActive)return;let r=this.synthCore,i=r.sampleRate,o=t.modulatedGenerators,g=t.targetKey,l=t.pitchOffset+o[c.fineTune]+this.octaveTuning[g]+this.currentTuning,C=o[c.coarseTune],B=r.tunings[this.preset.program*128+t.midiNote];if(B!==-1&&(g=Math.trunc(B),C+=B-g),t.portamentoFromKey>-1){let u=Math.min((e-t.startTime)/t.portamentoDuration,1),x=g-t.portamentoFromKey;C-=x*(1-u)}l+=(g-t.rootKey)*o[c.scaleTuning];let I=0,E=0,m=t.gainModifier*(1+o[c.amplitude]/1e3);if(e>=t.vibLfoStartTime){let u=o[c.vibLfoToPitch],x=o[c.vibLfoToFilterFc],P=o[c.vibLfoAmplitudeDepth];if(u!==0||x!==0||P!==0){let te=Math.max(0,As(o[c.freqVibLFO])+o[c.vibLfoRate]/100)*a/i,W=1-4*Math.abs(t.vibLfoPhase-.5);(t.vibLfoPhase+=te)>=1&&(t.vibLfoPhase-=1),l+=W*u,I+=W*x,m*=1-(W+1)/2*(P/1e3)}}if(e>=t.modLfoStartTime){let u=o[c.modLfoToPitch],x=o[c.modLfoToVolume],P=o[c.modLfoToFilterFc],te=o[c.modLfoAmplitudeDepth];if(u!==0||P!==0||x!==0||te!==0){let W=Math.max(0,As(o[c.freqModLFO])+o[c.modLfoRate]/100)*a/i,_=1-4*Math.abs(t.modLfoPhase-.5);(t.modLfoPhase+=W)>=1&&(t.modLfoPhase-=1),l+=_*u,E+=-_*x,I+=_*P,m*=1-(_+1)/2*(te/1e3)}}let k=o[c.modEnvToPitch],y=o[c.modEnvToFilterFc];if(y!==0||k!==0){let u=t.modEnv.process(t,e);I+=u*y,l+=u*k}E-=t.resonanceOffset;let b=l+C*100,R=b|0;R!==t.tuningCents&&(t.tuningCents=R,t.tuningRatio=Math.pow(2,b/1200));let M=yA(o[c.initialAttenuation])*yA(E);if(t.loopingMode===2&&!t.isInRelease){t.isActive=t.volEnv.process(a,M);return}let S=r.voiceBuffer;t.isActive=t.wavetable.process(a,t.tuningRatio,S);let Q=t.volEnv.outputGain,p=t.volEnv.process(a,M),D=(t.volEnv.outputGain-Q)/a;{let u=t.filter,x=o[c.initialFilterFc];u.initialized?u.currentInitialFc+=(x-u.currentInitialFc)*fs.smoothingConstant:(u.initialized=!0,u.currentInitialFc=x);let P=u.currentInitialFc+I,te=o[c.initialFilterQ];if(u.currentInitialFc>13499&&P>13499&&te===0){u.currentInitialFc=13500;for(let W=0;W<a;W++)S[W]*=Q,Q+=D}else{(Math.abs(u.lastTargetCutoff-P)>1||u.resonanceCb!==te)&&(u.lastTargetCutoff=P,u.resonanceCb=te,u.calculateCoefficients(P));let{a0:W,a1:_,a2:$,a3:ne,a4:ae}=u,{x1:J,x2:ie,y1:pe,y2:ve}=u;for(let Be=0;Be<a;Be++){let be=S[Be],Ue=W*be+_*J+$*ie-ne*pe-ve*ae;ie=J,J=be,ve=pe,pe=Ue,S[Be]=Ue*Q,Q+=D}u.x1=J,u.x2=ie,u.y1=pe,u.y2=ve}}t.isActive=t.isActive&&p;let q;t.overridePan?q=t.overridePan:(t.currentPan+=(o[c.pan]-t.currentPan)*r.panSmoothingFactor,q=t.currentPan);let{systemParameters:K}=r,O=this.currentGain*m,Y=Math.min(Math.max(-500,q+this.currentPan),500)+500|0,H=kn[Y]*O,Z=Dn[Y]*O;if(this._midiParameters.efxAssign){let u=r.insertionInputL,x=r.insertionInputR;for(let P=0;P<a;P++){let te=S[P];u[P]+=H*te,x[P]+=Z*te}return}for(let u=0;u<a;u++){let x=S[u],P=u+n;A[P]+=H*x,s[P]+=Z*x}if(!K.effectsEnabled)return;let T=o[c.reverbEffectsSend]*t.reverbSend;if(T>0){let u=K.reverbGain*O*(T/1e3),x=r.reverbInput;for(let P=0;P<a;P++)x[P]+=u*S[P]}let F=o[c.chorusEffectsSend]*t.chorusSend;if(F>0){let u=K.chorusGain*(F/1e3)*O,x=r.chorusInput;for(let P=0;P<a;P++)x[P]+=u*S[P]}if(r.delayActive){let u=this._midiControllers[f.variationDepth]*t.delaySend;if(u>0){let x=O*K.delayGain*((u>>7)/127),P=r.delayInput;for(let te=0;te<a;te++)P[te]+=x*S[te]}}}function ir(t,e,A=!0){if(t>127||e<0)throw new Error("Invalid MIDI Controller.");if(t>=f.modulationWheelLSB&&t<=f.effectControl2LSB){let s=t-32;if(this.lockedControllers[s])return;this._midiControllers[s]=this._midiControllers[s]&16256|e&127,this.computeModulatorsAll(1,s)}if(!this.lockedControllers[t]){switch(this._midiControllers[t]=e<<7|this._midiControllers[t]&127,t){case f.omniModeOff:case f.omniModeOn:case f.allNotesOff:this.stopAllNotes();break;case f.allSoundOff:this.stopAllNotes(!0);break;case f.polyModeOn:this.stopAllNotes(!0),this.setMIDIParameter("polyMode",!0);break;case f.monoModeOn:this.stopAllNotes(!0),this.setMIDIParameter("polyMode",!1);break;case f.bankSelect:this.setBankMSB(e),this.channel%16===9&&Se.isSystemXG(this.channelSystem)&&this.setBankMSB(127);break;case f.bankSelectLSB:this.setBankLSB(e);break;case f.variationDepth:this.synthCore.delayActive=!0;break;case f.registeredParameterLSB:case f.registeredParameterMSB:this._midiControllers[f.dataEntryMSB]=0,this.lastParameterIsRegistered=!0;break;case f.nonRegisteredParameterMSB:this.sf2NRPNGeneratorLSB=0,this._midiControllers[f.dataEntryMSB]=0,this.lastParameterIsRegistered=!1;break;case f.nonRegisteredParameterLSB:if(this._midiControllers[f.nonRegisteredParameterMSB]>>7===ye.SF2)switch(this.sf2NRPNGeneratorLSB%100!==0&&(this.sf2NRPNGeneratorLSB=0),e){case 100:this.sf2NRPNGeneratorLSB+=100;break;case 101:this.sf2NRPNGeneratorLSB+=1e3;break;case 102:this.sf2NRPNGeneratorLSB+=1e4;break;default:e<100&&(this.sf2NRPNGeneratorLSB+=e)}this._midiControllers[f.dataEntryMSB]=0,this.lastParameterIsRegistered=!1;break;case f.dataEntryMSB:case f.dataEntryLSB:this.dataEntry();break;case f.resetAllControllers:this.resetRP15();break;case f.sustainPedal:if(e<64){let s=0;if(this._voiceCount>0){for(let n of this.synthCore.voices)if(n.channel===this.channel&&n.isActive&&n.isHeld&&(n.isHeld=!1,n.releaseVoice(this.synthCore.currentTime),++s>=this._voiceCount))break}}break;case f.portamentoControl:this.lastNote=e,this.portamentoForce=!0;break;default:this.computeModulatorsAll(1,t);break}A&&this.synthCore.callEvent("controllerChange",{channel:this.channel,controller:t,value:e})}}var or=[c.delayModLFO,c.freqModLFO,c.delayVibLFO,c.freqVibLFO,c.delayModEnv,c.attackModEnv,c.holdModEnv,c.decayModEnv,c.sustainModEnv,c.releaseModEnv,c.delayVolEnv,c.attackVolEnv,c.holdVolEnv,c.decayVolEnv,c.sustainVolEnv,c.releaseVolEnv,c.fineTune,c.modLfoToPitch,c.vibLfoToPitch,c.modEnvToPitch,c.modLfoToVolume,c.initialFilterFc,c.initialFilterQ,c.modLfoToFilterFc,c.modEnvToFilterFc,c.chorusEffectsSend,c.reverbEffectsSend],gt=(t,e,A)=>Math.max(e,Math.min(A,t)),cA=t=>Math.max(-32768,1200*Math.log2(t/1e3)),gr=t=>6900+1200*Math.log2(t/440);function Ir(t,e){let A=e&127;e-=8192;let s=or[t];s||h.unsupported(`AWE32 LSB for ${this.channel}`,[t],"Invalid Generator Number");let n,a,r,i;switch(s){default:break;case c.delayModLFO:case c.delayVibLFO:case c.delayVolEnv:case c.delayModEnv:n=4*gt(e,0,5900),this.setGeneratorOverride(s,cA(n));break;case c.attackVolEnv:case c.attackModEnv:n=gt(e,0,5940),this.setGeneratorOverride(s,cA(n));break;case c.holdVolEnv:case c.holdModEnv:n=gt(e,0,8191),this.setGeneratorOverride(s,cA(n));break;case c.decayModEnv:case c.decayVolEnv:case c.releaseVolEnv:case c.releaseModEnv:n=4*gt(e,0,5940),this.setGeneratorOverride(s,cA(n));break;case c.freqVibLFO:case c.freqModLFO:a=.084*A,this.setGeneratorOverride(s,gr(a),!0);break;case c.sustainVolEnv:case c.sustainModEnv:r=A*7.5,this.setGeneratorOverride(s,r);break;case c.fineTune:this.setGeneratorOverride(s,e,!0);break;case c.modLfoToPitch:case c.vibLfoToPitch:i=gt(e,-127,127)*9.375,this.setGeneratorOverride(s,i,!0);break;case c.modEnvToPitch:i=gt(e,-127,127)*9.375,this.setGeneratorOverride(s,i);break;case c.modLfoToVolume:r=1.875*A,this.setGeneratorOverride(s,r,!0);break;case c.initialFilterFc:{let o=4335+59*A;this.setGeneratorOverride(s,o,!0);break}case c.initialFilterQ:r=215*(A/127),this.setGeneratorOverride(s,r,!0);break;case c.modLfoToFilterFc:i=gt(e,-64,63)*56.25,this.setGeneratorOverride(s,i,!0);break;case c.modEnvToFilterFc:i=gt(e,-64,63)*56.25,this.setGeneratorOverride(s,i);break;case c.chorusEffectsSend:case c.reverbEffectsSend:this.setGeneratorOverride(s,gt(e,0,255)*(1e3/255));break}}function cr(){let t=this._midiControllers[f.dataEntryMSB];if(this.lastParameterIsRegistered){let n=this._midiControllers[f.registeredParameterMSB]|this._midiControllers[f.registeredParameterLSB]>>7;switch(n){default:h.info(`%cUnrecognized RPN for %c${this.channel}%c: %c(0x${n.toString(16)})%c data value: %c${t}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn,d.value);break;case ut.pitchWheelRange:this.pitchWheelRange(t/128);break;case ut.coarseTuning:{let a=(t>>7)-64;this.keyShift(a);break}case ut.fineTuning:{let a=t-8192;this.fineTune(a/81.92);break}case ut.modulationDepth:this.modulationDepth(t/1.28);break;case ut.resetParameters:break}return}let e=this._midiControllers[f.nonRegisteredParameterMSB]>>7,A=this._midiControllers[f.nonRegisteredParameterLSB]>>7,s=t>>7;if(!(this.synthCore.systemParameters.drumLock&&e>=ye.drumPitch&&e<=ye.drumDelay))switch(e){default:h.info(`%cUnrecognized NRPN for %c${this.channel}%c: %c(0x${e.toString(16).toUpperCase()} 0x${A.toString(16).toUpperCase()})%c data value: %c${s}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn,d.value);break;case ye.partParameter:{let n=this._systemParameters.nrpnParamLock??this.synthCore.systemParameters.nrpnParamLock;switch(A){default:h.info(`%cUnrecognized NRPN for %c${this.channel}%c: %c(0x${e.toString(16)} 0x${A.toString(16)})%c data value: %c${s}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn,d.value);break;case Ke.vibratoRate:this.controllerChange(f.vibratoRate,s);break;case Ke.vibratoDepth:this.controllerChange(f.vibratoDepth,s);break;case Ke.vibratoDelay:this.controllerChange(f.vibratoDelay,s);break;case Ke.tvfCutoffFrequency:if(n)return;this.controllerChange(f.brightness,s),h.coolInfo(`Filter cutoff for ${this.channel}`,s.toString(),"");break;case Ke.tvfResonance:if(n)return;this.controllerChange(f.filterResonance,s),h.coolInfo(`Filter resonance for ${this.channel}`,s.toString(),"");break;case Ke.envelopeAttackTime:if(n)return;this.controllerChange(f.attackTime,s),h.coolInfo(`EG attack time for ${this.channel}`,s.toString(),"");break;case Ke.envelopeDecayTime:if(n)return;this.controllerChange(f.decayTime,s),h.coolInfo(`EG decay time for ${this.channel}`,s.toString(),"");break;case Ke.envelopeReleaseTime:if(n)return;this.controllerChange(f.releaseTime,s),h.coolInfo(`EG release time for ${this.channel}`,s.toString(),"");break}break}case ye.drumPitch:{let n=this.channelSystem==="xg"||this.patch.bankLSB===1?(s-64)*100:(s-64)*50;this.drumParams[A].pitch=n,h.coolInfo(`Drum ${A} pitch for ${this.channel}`,n,"cents");break}case ye.drumPitchFine:{let n=s-64;this.drumParams[A].pitch+=n,h.coolInfo(`Drum ${A} pitch fine for ${this.channel}`,this.drumParams[A].pitch,"cents");break}case ye.drumLevel:this.drumParams[A].gain=s/120,h.coolInfo(`Drum ${A} level for ${this.channel}`,s,"");break;case ye.drumPan:this.drumParams[A].pan=s,h.coolInfo(`Drum ${A} pan for ${this.channel}`,s,"");break;case ye.drumReverb:this.drumParams[A].reverbGain=s/127,h.coolInfo(`Drum ${A} reverb level for ${this.channel}`,s,"");break;case ye.drumChorus:this.drumParams[A].chorusGain=s/127,h.coolInfo(`Drum ${A} chorus level for ${this.channel}`,s,"");break;case ye.drumDelay:this.drumParams[A].delayGain=s/127,h.coolInfo(`Drum ${A} delay level for ${this.channel}`,t,"");break;case ye.awe32:Ir.call(this,A,t);break;case ye.SF2:{if(A>100)break;let n=this.sf2NRPNGeneratorLSB,a=t-8192;this.setGeneratorOffset(n,a);break}}}var hr=40;function lr(t){if(t<1)return 0;{let e=[1,2,4,8,16,32,64,80,96,112,120,124],A=[1,.5,.25,.125,.0625,.03125,.0625,.0625,.0625,.125,.25,1/3],s=[-.16653127382501215,.11863875218299408,.029479047361245264,-.005442312089231738,.1451520875973037,-.005056281449558275,-.005095486882876532,.03334009551111544,-.09361368678020432,.14132569702451822,-.15805565301011382,-.09918856955881927],n=[.028212773333433472,-.3388502064992847,-.15839529890929713,-.12398131766775483,-.2874848552685111,.012254866302537692,.005957797193345771,-.03745899330347374,.12911781869810196,-.15867193224162568,.504406322732748,.3786845131875458],a=[.7218950861255283,.5574536226347168,.47133893237025826,.48597095327079914,.44336276333518854,.6076986311801551,.30851975971827794,.30514889345633955,.3302511933827384,.153822885219165,.1302280559047337,.49865530675491687],r=[-2.2218487496163566,-1.6382721639824072,-1.3010299956639813,-.958607314841775,-.6020599913279624,-.3010299956639812,.31386722036915343,.6232492903979004,.9242792860618817,1.290034611362518,1.4265112613645752,1.9030899869919435],i=[2,4,8,16,32,64,80,96,112,120,124],o=-1;for(let l=i.length-1;l>=0;l--)if(i[l]<t){o=l;break}o+=1;let g=(t-e[o])*A[o];return Math.exp(2.302585092994046*(((s[o]*g+n[o])*g+a[o])*g+r[o]))/hr}}function Cr(t,e){return lr(t)*e}var Jt=(t,e,A)=>Math.max(e,Math.min(A,t));function Br(t,e){if(e<1){this.noteOff(t);return}e=Jt(e,0,127);let A=this.synthCore.systemParameters.blackMIDIMode;if(A&&this.synthCore.voiceCount>200&&e<40||A&&e<10||this._systemParameters.isMuted||!this.preset)return;let s=t+this.currentKeyShift;if(t>127||t<0)return;let n=this.preset.program,a=this.synthCore.tunings[n*128+t];a>=0&&(s=Math.trunc(a)),((this._systemParameters.monophonicRetrigger??this.synthCore.systemParameters.monophonicRetrigger)||this._midiParameters.assignMode===0)&&this.killNote(t);let r=this.synthCore.keyModifierManager.getVelocity(this.channel,t);r>-1&&(e=r);let i=this.synthCore.keyModifierManager.getGain(this.channel,t),o=this.lastNote,g=this.portamentoForce||this._midiControllers[f.portamentoOnOff]>=8192,l=this._midiControllers[f.portamentoTime]>>7,C=g&&!this._drumChannel&&o>=0&&o!==t&&l>0,B=-1,I=0;if(C){let S=Math.abs(t-o);B=o,I=Cr(l,S),this.portamentoForce=!1}if(this.lastNote=t,!this._midiParameters.polyMode){let S=0;if(this._voiceCount>0){for(let Q of this.synthCore.voices)if(Q.isActive&&Q.channel===this.channel&&(Q.exclusiveRelease(this.synthCore.currentTime,0),++S>=this._voiceCount))break}}let E=this.synthCore.getVoices(this.channel,s,e),m=0,k=0,y=0,b=1,R=1,M=1;if(this._midiParameters.randomPan&&(m=Math.round(Math.random()*1e3-500)),this._drumChannel){let S=this.drumParams[t];if(!S.rxNoteOn)return;let Q=S.pan-64;if(Q!==0)if(Q===-64)m=Math.round(Math.random()*1e3-500);else{let p=(this._midiControllers[f.pan]>>7)-64;m=Math.max(-63,Math.min(Q+p,63))/63*500||1}y=S.pitch,k=S.exclusiveClass,b=S.reverbGain,R=S.chorusGain,M=S.delayGain,i===1&&(i=S.gain)}for(let S of E){let Q=this.synthCore.assignVoice(),p=this.synthCore.currentTime;if(Q.setup(p,this.channel,t),Q.wavetable=Q.oscillators[this._systemParameters.interpolationType??this.synthCore.systemParameters.interpolationType],Q.targetKey=S.targetKey,Q.velocity=S.velocity,Q.generators.set(S.generators),Q.exclusiveClass=k||S.exclusiveClass,Q.rootKey=S.rootKey,Q.loopingMode=S.loopingMode,Q.wavetable.sampleData=S.sampleData,Q.wavetable.playbackStep=S.playbackStep,this.dynamicModulators.active){Q.modulators=[...S.modulators];for(let H of this.dynamicModulators.modulatorList){let Z=Q.modulators.findIndex(T=>ke.isIdentical(T,H.mod));Z===-1?Q.modulators.push(H.mod):Q.modulators[Z]=H.mod}}else Q.modulators=S.modulators;if(Q.modulators.length>Q.modulatorValues.length&&(h.warn(`${Q.modulators.length} modulators! Increasing modulatorValues table.`),Q.modulatorValues=new Int16Array(Q.modulators.length)),this.generators.overridesEnabled){let H=this.generators.overrides;for(let Z=0;Z<St;Z++){let T=H[Z];T!==32767&&(Q.generators[Z]=T)}}if(Q.exclusiveClass!==0&&this._midiParameters.polyMode){let H=0;if(this._voiceCount>0){for(let Z of this.synthCore.voices)if(Z.isActive&&Z.channel===this.channel&&Z.exclusiveClass===Q.exclusiveClass&&Z.hasRendered&&(Z.exclusiveRelease(this.synthCore.currentTime),++H>=this._voiceCount))break}}this.computeModulators(Q),Q.volEnv.init(Q),Q.modEnv.init(Q),Q.filter.init(),Q.vibLfoStartTime=p+mA(Q.modulatedGenerators[c.delayVibLFO]),Q.modLfoStartTime=p+mA(Q.modulatedGenerators[c.delayModLFO]);let D=Q.modulatedGenerators[c.startAddrsOffset]+Q.modulatedGenerators[c.startAddrsCoarseOffset]*32768,q=Q.modulatedGenerators[c.endAddrOffset]+Q.modulatedGenerators[c.endAddrsCoarseOffset]*32768,K=Q.modulatedGenerators[c.startloopAddrsOffset]+Q.modulatedGenerators[c.startloopAddrsCoarseOffset]*32768,O=Q.modulatedGenerators[c.endloopAddrsOffset]+Q.modulatedGenerators[c.endloopAddrsCoarseOffset]*32768,Y=S.sampleData.length-1;if(Q.wavetable.cursor=Jt(D,0,Y),Q.wavetable.end=Jt(Y+q,0,Y),Q.wavetable.loopStart=Jt(S.loopStart+K,0,Y),Q.wavetable.loopEnd=Jt(S.loopEnd+O,0,Y),Q.wavetable.loopEnd<Q.wavetable.loopStart){let H=Q.wavetable.loopStart;Q.wavetable.loopStart=Q.wavetable.loopEnd,Q.wavetable.loopEnd=H}Q.wavetable.loopEnd-Q.wavetable.loopStart<1&&(Q.loopingMode===1||Q.loopingMode===3)&&(Q.loopingMode=0),Q.wavetable.loopLength=Q.wavetable.loopEnd-Q.wavetable.loopStart,Q.wavetable.isLooping=Q.loopingMode===1||Q.loopingMode===3,Q.portamentoFromKey=B,Q.portamentoDuration=I,Q.overridePan=m,Q.gainModifier=i,Q.pitchOffset=y,Q.reverbSend=b,Q.chorusSend=R,Q.delaySend=M,Q.currentPan=Math.max(-500,Math.min(500,m||Q.modulatedGenerators[c.pan]))}this._voiceCount+=E.length,this.synthCore.callEvent("noteOn",{midiNote:t,channel:this.channel,velocity:e})}function Er(t){if(t>127||t<0)return;if(this.synthCore.systemParameters.blackMIDIMode&&!this._drumChannel||this._drumChannel&&this.drumParams[t].rxNoteOff){this.killNote(t),this.synthCore.callEvent("noteOff",{midiNote:t,channel:this.channel});return}let e=this._midiControllers[f.sustainPedal]>=8192,A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&s.midiNote===t&&!s.isInRelease&&(e?s.isHeld=!0:s.releaseVoice(this.synthCore.currentTime),++A>=this._voiceCount))break}this.synthCore.callEvent("noteOff",{midiNote:t,channel:this.channel})}function dr(t){if(this._systemParameters.presetLock)return;this.patch.program=t;let e=this.synthCore.soundBankManager.getPreset(this.patch,this.channelSystem);!e&&(e=this.synthCore.missingPresetHandler(this.patch,this.channelSystem),!e)||(this.preset=e,e.isDrum!==this._drumChannel&&this.setDrumFlag(e.isDrum),this.resetDrumParams(),this.synthCore.callEvent("programChange",{channel:this.channel,bankLSB:this.preset.bankLSB,bankMSB:this.preset.bankMSB,program:this.preset.program,name:this.preset.name,isGMGSDrum:this.preset.isGMGSDrum,isDrum:this.preset.isDrum}))}var fr=[kA.fromModulator(new ue(Ze(le.linear,!0,!1,!0,f.vibratoRate),0,c.vibLfoRate,1e3,0))],Qr=class{modulatorList=[];active=!1;channel;constructor(t){this.channel=t}resetModulators(){this.modulatorList=fr.map(t=>({mod:t,id:this.getModulatorID(t.primarySource.toSourceEnum(),t.destination,t.primarySource.isBipolar,t.primarySource.isNegative)})),this.active=!1}setupReceiver(t,e,A,s,n,a=!1){this.active=!0;let r=e-64,i=r/64,o=e/127;switch(t&15){case 0:this.setModulator(A,s,c.fineTune,r*100,a),h.coolInfo(`Channel ${this.channel} ${n} pitch control`,r,"semitones");break;case 1:this.setModulator(A,s,c.initialFilterFc,i*9600,a),h.coolInfo(`Channel ${this.channel} ${n} filter control`,i*9600,"cents");break;case 2:this.setModulator(A,s,c.amplitude,i*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} amplitude control`,i*100,"%");break;case 3:this.setModulator(A,s,c.vibLfoRate,i*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 rate control`,i*10,"Hz");break;case 4:this.setModulator(A,s,c.vibLfoToPitch,o*600,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 pitch depth control`,o*600,"cents");break;case 5:this.setModulator(A,s,c.vibLfoToFilterFc,o*2400,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 filter depth control`,o*2400,"cents");break;case 6:this.setModulator(A,s,c.vibLfoAmplitudeDepth,o*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 amplitude depth control`,o*100,"%");break;case 7:this.setModulator(A,s,c.modLfoRate,i*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 rate control`,i*10,"Hz");break;case 8:this.setModulator(A,s,c.modLfoToPitch,o*600,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 pitch depth control`,o*600,"cents");break;case 9:this.setModulator(A,s,c.modLfoToFilterFc,o*2400,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 filter depth control`,o*2400,"cents");break;case 10:this.setModulator(A,s,c.modLfoAmplitudeDepth,o*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 amplitude depth control`,o*100,"%");break}}setModulator(t,e,A,s,n=!1,a=!1){let r=this.getModulatorID(t,A,n,a);s===0&&this.deleteModulator(r);let i=this.modulatorList.find(o=>o.id===r);if(i)i.mod.transformAmount=s;else{let o=kA.fromData(new st(t,le.linear,e,n),new st,A,s,0);this.modulatorList.push({mod:o,id:r})}}getModulatorID(t,e,A,s){return`${t}-${e}-${A}-${s}`}deleteModulator(t){this.modulatorList=this.modulatorList.filter(e=>e.id!==t)}},ur=1e3/200;function mr(t,e,A){let s=t.modulators[A];if(s.transformAmount===0)return t.modulatorValues[A]=0,0;let n=s.primarySource.getValue(this,e,t),a=s.secondarySource.getValue(this,e,t),r=s.transformAmount;s.isEffectModulator&&r<=1e3&&(r*=ur,r=Math.min(r,1e3));let i=n*a*r;return s.transformType===2&&(i=Math.abs(i)),s.isDefaultResonantModulator&&(t.resonanceOffset=Math.max(0,i/2)),s.isModWheelModulator&&(i*=this._midiParameters.modulationDepth),t.modulatorValues[A]=i,i}function pr(t,e=-1,A=0){let s=t.modulators,n=t.generators;if(this.generators.offsetsEnabled){let o=this.generators.offsets;n=new Int16Array(n);for(let g=0;g<n.length;g++)n[g]+=o[g]}let a=t.modulatedGenerators,r=this.perNotePitch?this.pitchWheels[t.midiNote]:this._midiParameters.pitchWheel;if(e===-1){a.set(n);for(let o=0;o<s.length;o++){let g=s[o];a[g.destination]=Math.min(32767,Math.max(-32768,a[g.destination]+this.computeModulator(t,r,o)))}for(let o=0;o<a.length;o++){let g=Ve[o];g&&(a[o]=Math.min(g.max,Math.max(g.min,a[o])))}return}let i=!!e;for(let o=0;o<s.length;o++){let g=s[o];if(g.primarySource.isCC===i&&g.primarySource.index===A||g.secondarySource.isCC===i&&g.secondarySource.index===A){let l=g.destination,C=n[l];this.computeModulator(t,r,o);for(let I=0;I<s.length;I++)s[I].destination===l&&(C+=t.modulatorValues[I]);let B=Ve[l];a[l]=Math.max(B.min,Math.min(C,B.max))}}}var wn=class bn{pitch=0;gain=1;exclusiveClass=0;pan=64;reverbGain=0;chorusGain=1;delayGain=1;rxNoteOn=!0;rxNoteOff=!1;static copyFrom(e){let A=new bn;return A.pitch=e.pitch,A.chorusGain=e.chorusGain,A.reverbGain=e.reverbGain,A.exclusiveClass=e.exclusiveClass,A.gain=e.gain,A.pan=e.pan,A.rxNoteOff=e.rxNoteOff,A.rxNoteOn=e.rxNoteOn,A}};function yr(){return{patch:this.preset?{...this.patch,name:this.preset.name,isDrum:this.preset.isDrum}:void 0,lockedSystem:this.lockedSystem,midiControllers:this._midiControllers.slice(),lockedControllers:[...this.lockedControllers],pitchWheels:this.pitchWheels.slice(),generators:{...this.generators,offsets:this.generators.offsets.slice(),overrides:this.generators.overrides.slice()},midiParameters:{...this._midiParameters},systemParameters:{...this._systemParameters},octaveTuning:this.octaveTuning.slice(),perNotePitch:this.perNotePitch,drumParams:this.drumParams.map(t=>({...t})),drumChannel:this._drumChannel,channelNumber:this.channel}}function Sr(t){this.setDrums(t.drumChannel),this._midiControllers.set(t.midiControllers);for(let e=0;e<128;e++)this.lockController(e,t.lockedControllers[e]);this.pitchWheels.set(t.pitchWheels),this.octaveTuning.set(t.octaveTuning),this.perNotePitch=t.perNotePitch,this.generators.offsets.set(t.generators.offsets),this.generators.overrides.set(t.generators.overrides);for(let e=0;e<128;e++)this.drumParams[e]=wn.copyFrom(t.drumParams[e]);this.setSystemParameter("presetLock",!1),t.patch&&this.setPatch(t.patch),this.lockedSystem=t.lockedSystem;for(let[e,A]of Object.entries(this._midiParameters))this.setMIDIParameter(e,A);for(let[e,A]of Object.entries(this._systemParameters))this.setSystemParameter(e,A)}var kr={pitchWheel:8192,pitchWheelRange:2,pressure:0,modulationDepth:1,rxChannel:0,polyMode:!0,keyShift:0,randomPan:!1,assignMode:2,efxAssign:!1,cc1:16,cc2:17,drumMap:0,fineTune:0},Dr={presetLock:!1,isMuted:!1,gain:1,pan:0,keyShift:0,fineTune:0,interpolationType:null,nrpnParamLock:null,monophonicRetrigger:null};function wr(t,e){if(this._systemParameters[t]===e)return;let A=this._systemParameters[t];switch(this._systemParameters[t]=e,this.updateInternalParams(),t){default:break;case"presetLock":e&&(this.lockedSystem=this.synthCore.midiParameters.system);break;case"isMuted":e&&this.stopAllNotes(!0);break;case"keyShift":!this._drumChannel&&A!==e&&this.stopAllNotes(!0)}}var br=class{pitchWheels=new Int16Array(128).fill(8192);lockedControllers=new Array(128).fill(!1);drumParams=[];dynamicModulators;sf2NRPNGeneratorLSB=0;patch={bankMSB:0,bankLSB:0,program:0,isGMGSDrum:!1};preset;lockedSystem="gs";channel;synthCore;setSystemParameter=wr.bind(this);noteOn=Br.bind(this);noteOff=Er.bind(this);programChange=dr.bind(this);controllerChange=ir.bind(this);reset=ma.bind(this);renderVoice=rr.bind(this);_midiControllers=new Int16Array(128);octaveTuning=new Int8Array(128);resetRP15=pa.bind(this);dataEntry=cr.bind(this);_midiParameters={...kr};_systemParameters={...Dr};lastParameterIsRegistered=!0;perNotePitch=!1;currentPan=0;currentTuning=0;currentKeyShift=0;currentGain=0;lastNote=-1;portamentoForce=!1;generators={offsets:new Int16Array(St),offsetsEnabled:!1,overrides:new Int16Array(St),overridesEnabled:!1};computeModulator=mr.bind(this);computeModulators=pr.bind(this);constructor(t,e,A){this.synthCore=t,this.preset=e,this.channel=A,this._midiParameters.rxChannel=A,this.dynamicModulators=new Qr(A),this.resetGeneratorOverrides(),this.resetGeneratorOffsets();for(let s=0;s<128;s++)this.drumParams.push(new wn);this.resetDrumParams()}_voiceCount=0;get voiceCount(){return this._voiceCount}set voiceCount(t){this._voiceCount=t}_drumChannel=!1;get drumChannel(){return this._drumChannel}get midiControllers(){return this._midiControllers}get systemParameters(){return this._systemParameters}get midiParameters(){return this._midiParameters}get channelSystem(){return this._systemParameters.presetLock?this.lockedSystem:this.synthCore.midiParameters.system}lockController(t,e){this.lockedControllers[t]=e}setDrums(t){if(Se.isSystemXG(this.channelSystem))if(t)this.setBankMSB(Se.getDrumBank(this.channelSystem)),this.setBankLSB(0);else{if(this.channel%16===9)throw new Error(`Cannot disable drums on channel ${this.channel} for XG.`);this.setBankMSB(0),this.setBankLSB(0)}else this.setGSDrums(t);this.setDrumFlag(t),this.programChange(this.patch.program)}stopAllNotes(t=!1){if(t){let e=0;if(this._voiceCount>0){for(let A of this.synthCore.voices)if(A.channel===this.channel&&A.isActive&&(A.isActive=!1,++e>=this._voiceCount))break}this.clearVoiceCount()}else{let e=0;if(this._voiceCount>0){for(let A of this.synthCore.voices)if(A.channel===this.channel&&A.isActive&&(A.releaseVoice(this.synthCore.currentTime),++e>=this._voiceCount))break}}this.synthCore.callEvent("stopAll",{channel:this.channel,force:t})}setMIDIParameter(t,e){switch(this._midiParameters[t]=e,t){case"pitchWheel":this.computeModulatorsAll(0,Ie.pitchWheel);break;case"pressure":this.computeModulatorsAll(0,Ie.channelPressure);break}this.updateInternalParams(),this.synthCore.callEvent("channelParamChange",{channel:this.channel,parameter:t,value:e})}clearVoiceCount(){this._voiceCount=0}setOctaveTuning(t){if(t.length!==12)throw new Error("Tuning is not the length of 12.");for(let e=0;e<128;e++)this.octaveTuning[e]=t[e%12]}modulationDepth(t,e=!0){this.setMIDIParameter("modulationDepth",t/50),e&&h.info(`%cChannel ${this.channel} modulation depth. Cents: %c${Math.round(t)}`,d.info,d.value)}keyShift(t,e=!0){this._drumChannel&&(t=0),this._midiParameters.keyShift!==t&&(this.setMIDIParameter("keyShift",t),e&&h.info(`%cKey shift for %c${this.channel}%c is now set to %c${t}.`,d.info,d.recognized,d.info,d.value))}fineTune(t,e=!0){this.setMIDIParameter("fineTune",t),e&&h.info(`%cFine tuning for %c${this.channel}%c is now set to %c${Math.round(t)}%c cents.`,d.info,d.recognized,d.info,d.value,d.info)}pitchWheel(t,e=-1){e===-1?(this.perNotePitch=!1,this.setMIDIParameter("pitchWheel",t)):(this.perNotePitch||this.pitchWheels.fill(this._midiParameters.pitchWheel),this.perNotePitch=!0,this.pitchWheels[e]=t,this.computeModulatorsAll(0,Ie.pitchWheel))}polyPressure(t,e){let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.isActive&&s.channel===this.channel&&s.midiNote===t&&(s.pressure=e,this.computeModulators(s,0,Ie.polyPressure),++A>=this._voiceCount))break}this.synthCore.callEvent("polyPressure",{channel:this.channel,midiNote:t,pressure:e})}pitchWheelRange(t,e=!0){this.setMIDIParameter("pitchWheelRange",t),e&&h.coolInfo(`Pitch Wheel Range for ${this.channel}`,t,"semitones")}updateInternalParams(){let t=this.synthCore.systemParameters,e=this._systemParameters,A=this.synthCore.midiParameters,s=this._midiParameters,n=this._drumChannel?e.keyShift:t.keyShift+A.keyShift+e.keyShift+s.keyShift;this.currentKeyShift=Math.trunc(n),this.currentTuning=this._drumChannel?e.fineTune:t.fineTune+A.fineTune+e.fineTune+s.fineTune;let a=t.pan+A.pan+e.pan;this.currentPan=a*500,this.currentGain=Zn*t.gain*A.gain*e.gain}setPatch(t){this.setBankMSB(t.bankMSB),this.setBankLSB(t.bankLSB),this.setGSDrums(t.isGMGSDrum),this.programChange(t.program)}setGSDrums(t){t!==this.patch.isGMGSDrum&&(this.setBankLSB(0),this.setBankMSB(0),this.patch.isGMGSDrum=t)}killNote(t,e=-12e3){let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&s.midiNote===t&&(s.overrideReleaseVolEnv=e,s.isInRelease=!1,s.releaseVoice(this.synthCore.currentTime),++A>=this._voiceCount))break}}applySnapshot(t){Sr.call(this,t)}getSnapshot(){return yr.call(this)}setLastNote(t){this.lastNote=t}destroy(){this.preset=void 0,this.lockedControllers=void 0,this._systemParameters=void 0,this._midiControllers=void 0,this._midiParameters=void 0}resetGeneratorOverrides(){this.generators.overrides.fill(Jn),this.generators.overridesEnabled=!1}setGeneratorOverride(t,e,A=!1){if(this.generators.overrides[t]=e,this.generators.overridesEnabled=!0,A){let s=0;if(this._voiceCount>0){for(let n of this.synthCore.voices)if(n.channel===this.channel&&n.isActive&&(n.generators[t]=e,this.computeModulators(n),++s>=this._voiceCount))break}}}resetGeneratorOffsets(){this.generators.offsets.fill(0),this.generators.offsetsEnabled=!1}setGeneratorOffset(t,e){this.generators.offsets[t]=e*Ve[t].nrpn,this.generators.offsetsEnabled=!0;let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&(this.computeModulators(s),++A>=this._voiceCount))break}}resetDrumParams(){if(!(this.synthCore.systemParameters.drumLock||!this._drumChannel))for(let t=0;t<128;t++){let e=this.drumParams[t];e.pitch=0,e.gain=1,e.exclusiveClass=0,e.pan=64,e.reverbGain=uA[t]/127,e.chorusGain=this.channelSystem==="xg"?uA[t]/127:0,e.delayGain=0,e.rxNoteOn=!0,e.rxNoteOff=!1}}computeModulatorsAll(t,e){let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&(this.computeModulators(s,t,e),++A>=this._voiceCount))break}}setBankMSB(t){this._systemParameters.presetLock||(this.patch.bankMSB=t)}setBankLSB(t){this._systemParameters.presetLock||(this.patch.bankLSB=t)}setDrumFlag(t){this._systemParameters.presetLock||!this.preset||this._drumChannel===t||(this._drumChannel=t,this.keyShift(this._midiParameters.keyShift,!1))}},Rr=class extends _t{constructor(t,e){super(t.parentSoundBank,t.globalZone),this.bankMSB=Se.addBankOffset(t.bankMSB,e,!0),this.name=t.name,this.bankLSB=t.bankLSB,this.isGMGSDrum=t.isGMGSDrum,this.program=t.program,this.genre=t.genre,this.morphology=t.morphology,this.library=t.library,this.zones=t.zones}},Fr=class{soundBankList=[];presetListChangeCallback;selectablePresetList=[];constructor(t){this.presetListChangeCallback=t}_presetList=[];get presetList(){return[...this._presetList]}get priorityOrder(){return this.soundBankList.map(t=>t.id)}set priorityOrder(t){this.soundBankList.sort((e,A)=>t.indexOf(e.id)-t.indexOf(A.id)),this.generatePresetList()}deleteSoundBank(t){if(this.soundBankList.length===0){h.warn("1 soundbank left. Aborting!");return}let e=this.soundBankList.findIndex(A=>A.id===t);if(e===-1)throw new Error(`No sound bank with id "${t}"`);this.soundBankList.splice(e,1),this.generatePresetList()}addSoundBank(t,e,A=0){let s=this.soundBankList.find(n=>n.id===e);s===void 0?this.soundBankList.push({id:e,soundBank:t,bankOffset:A}):(s.soundBank=t,s.bankOffset=A),this.generatePresetList()}getPreset(t,e){if(!(this.soundBankList.length===0||this.selectablePresetList.length===0))return ze.selectPatch(this.selectablePresetList,t,e)}destroy(){for(let t of this.soundBankList)t.soundBank.destroySoundBank();this.soundBankList=[]}generatePresetList(){let t=new Array,e=new Set;for(let A of this.soundBankList){let s=A.soundBank,n=A.bankOffset;for(let a of s.presets){let r=new Rr(a,n);e.has(r.toMIDIString())||(e.add(r.toMIDIString()),t.push(r))}}t.sort(ze.compare.bind(ze)),this.selectablePresetList=t,this._presetList=t.map(A=>({bankMSB:A.bankMSB,bankLSB:A.bankLSB,program:A.program,isGMGSDrum:A.isGMGSDrum,name:A.name,isDrum:A.isDrum})),this.presetListChangeCallback()}};function xs(t,e,A){let s=t,n=e<<7|A;return t===127&&e===127&&A===127?-1:s+n*61e-6}function Mr(t,e=0){switch(t[2]){case 4:switch(t[3]){default:h.gmFail("Device Control",t);break;case 1:{let A=t[5]<<7|t[4];this.setMIDIParameter("gain",A/16384),h.gmInfo("Master Volume",A);break}case 2:{let A=((t[5]<<7|t[4])-8192)/8192;this.setMIDIParameter("pan",A),h.gmInfo("Master Balance",A);break}case 3:{let A=((t[5]<<7|t[6])-8192)/81.92;this.setMIDIParameter("fineTune",A),h.gmInfo("Master Fine Tuning",A,"cents");break}case 4:{let A=t[5]-64;this.setMIDIParameter("keyShift",A),h.gmInfo("Master Coarse Tuning",A,"keys");break}case 5:if(t[4]!==1||t[5]!==1||t[6]!==1||t[7]!==1){h.gmFail("Global Parameter Control",t);break}switch(t[8]){default:h.gmFail("Global Parameter Control",t);break;case 1:{let A=t[10];switch(t[9]){default:h.gmFail("Reverb Parameter Control",t);break;case 0:{let s=A===8?5:A;this.setReverbMacro(s),h.gmInfo("Reverb Type",s);break}case 1:this.reverbProcessor.time=A,h.gmInfo("Reverb Time",A)}break}case 2:{let A=t[10];switch(t[9]){default:h.gmFail("Chorus Parameter Control",t);break;case 0:this.setChorusMacro(A),h.gmInfo("Chorus Type",A);break;case 1:this.chorusProcessor.rate=A,h.gmInfo("Chorus Mod Rate",A);break;case 2:this.chorusProcessor.depth=A,h.gmInfo("Chorus Mod Depth",A);break;case 3:this.chorusProcessor.feedback=A,h.gmInfo("Chorus Mod Feedback",A);break;case 4:this.chorusProcessor.sendLevelToReverb=A,h.gmInfo("Chorus Send to Reverb",A);break}}}}break;case 9:switch(t[3]){default:h.gmFail("System Exclusive",t);break;case 1:h.coolInfo("MIDI System","General MIDI 1"),this.reset("gm");break;case 2:h.coolInfo("MIDI System","Roland GS"),this.reset("gs");break;case 3:h.coolInfo("MIDI System","General MIDI 2"),this.reset("gm2");break}break;case 8:{let A=4;switch(t[3]){case 1:{let s=t[A++],n=_e(t,16,A);if(A+=16,t.length<384){h.warn(`The Bulk Tuning Dump is too short! (${t.length} bytes, at least 384 are expected)`);return}for(let a=0;a<128;a++)this.tunings[s*128+a]=xs(t[A++],t[A++],t[A++]);h.gmInfo("Bulk Tuning Dump",`${n}, program ${s}`);break}case 2:case 7:{t[3]===7&&A++;let s=t[A++],n=t[A++];for(let a=0;a<n;a++){let r=t[A++];this.tunings[s*128+r]=xs(t[A++],t[A++],t[A++])}h.gmInfo("Single Note Tuning",`program: ${s}. Keys affected: ${n}`);break}case 9:case 8:{let s=new Int8Array(12);if(t[3]===8)for(let n=0;n<12;n++)s[n]=t[7+n]-64;else for(let n=0;n<24;n+=2){let a=(t[7+n]<<7|t[8+n])-8192;s[n/2]=Math.floor(a/81.92)}(t[4]&1)===1&&this.midiChannels[14+e].setOctaveTuning(s),(t[4]>>1&1)===1&&this.midiChannels[15+e].setOctaveTuning(s);for(let n=0;n<7;n++)(t[5]>>n&1)===1&&this.midiChannels[7+n+e].setOctaveTuning(s);for(let n=0;n<7;n++)(t[6]>>n&1)===1&&this.midiChannels[n+e].setOctaveTuning(s);h.gmInfo("Octave Scale Tuning",s.join(" "));break}default:h.gmFail("MIDI Tuning Standard",t);break}break}default:h.gmFail("Universal System Exclusive",t)}}function vr(t,e=0){if(t[3]===18)switch(t[2]){case 66:{let A=t[4],s=t[5],n=t[6],a=Math.min(t[7],127);if(A===0&&s===0&&n===127&&a===0){h.coolInfo("MIDI System","Roland GS"),this.reset("gs");return}if(A===64){if(s===0){switch(n){case 0:{let r=((a<<12|t[8]<<8|t[9]<<4|t[10])-1024)/10;this.setMIDIParameter("fineTune",r),h.gsInfo("Master Tune",r,"cents");break}case 4:h.gsInfo("Master Volume",a);break;case 5:{let r=a-64;h.gsInfo("Master Key-Shift",r,"keys"),this.setMIDIParameter("keyShift",r);break}case 6:h.gsInfo("Master Pan",a),this.setMIDIParameter("pan",(a-64)/64);break;case 127:a===0?(h.coolInfo("MIDI System","Roland GS"),this.reset("gs")):a===127&&(h.coolInfo("MIDI System","General MIDI 1"),this.reset("gm"));break;default:h.gsFail("System Parameter",t);break}return}if(s===1){let r=n>=48&&n<=55,i=n>=56&&n<=64,o=n>=80&&n<=90;if(r&&this.systemParameters.reverbLock||i&&this.systemParameters.chorusLock||o&&this.systemParameters.delayLock)return;switch(this.delayActive||=n===64||o,n){default:h.gsFail("Patch Common Parameter",[n]);break;case 0:{let g=_e(t,16,7);h.gsInfo("Patch name",g);break}case 48:this.setReverbMacro(a),h.gsInfo("Reverb Macro",a);break;case 49:this.reverbProcessor.character=a,h.gsInfo("Reverb Character",a),this.callEvent("effectChange",{effect:"reverb",parameter:"character",value:a});break;case 50:this.reverbProcessor.preLowpass=a,h.gsInfo("Reverb Pre-LPF",a),this.callEvent("effectChange",{effect:"reverb",parameter:"preLowpass",value:a});break;case 51:this.reverbProcessor.level=a,h.gsInfo("Reverb Level",a),this.callEvent("effectChange",{effect:"reverb",parameter:"level",value:a});break;case 52:this.reverbProcessor.time=a,h.gsInfo("Reverb Time",a),this.callEvent("effectChange",{effect:"reverb",parameter:"time",value:a});break;case 53:this.reverbProcessor.delayFeedback=a,h.gsInfo("Reverb Delay Feedback",a),this.callEvent("effectChange",{effect:"reverb",parameter:"delayFeedback",value:a});break;case 54:break;case 55:this.reverbProcessor.preDelayTime=a,h.gsInfo("Reverb Predelay Time",a),this.callEvent("effectChange",{effect:"reverb",parameter:"preDelayTime",value:a});break;case 56:this.setChorusMacro(a),h.gsInfo("Chorus Macro",a);break;case 57:this.chorusProcessor.preLowpass=a,h.gsInfo("Chorus Pre-LPF",a),this.callEvent("effectChange",{effect:"chorus",parameter:"preLowpass",value:a});break;case 58:this.chorusProcessor.level=a,h.gsInfo("Chorus Level",a),this.callEvent("effectChange",{effect:"chorus",parameter:"level",value:a});break;case 59:this.chorusProcessor.feedback=a,h.gsInfo("Chorus Feedback",a),this.callEvent("effectChange",{effect:"chorus",parameter:"feedback",value:a});break;case 60:this.chorusProcessor.delay=a,h.gsInfo("Chorus Delay",a),this.callEvent("effectChange",{effect:"chorus",parameter:"delay",value:a});break;case 61:this.chorusProcessor.rate=a,h.gsInfo("Chorus Rate",a),this.callEvent("effectChange",{effect:"chorus",parameter:"rate",value:a});break;case 62:this.chorusProcessor.depth=a,h.gsInfo("Chorus Depth",a),this.callEvent("effectChange",{effect:"chorus",parameter:"depth",value:a});break;case 63:this.chorusProcessor.sendLevelToReverb=a,h.gsInfo("Chorus Send Level To Reverb",a),this.callEvent("effectChange",{effect:"chorus",parameter:"sendLevelToReverb",value:a});break;case 64:this.chorusProcessor.sendLevelToDelay=a,h.gsInfo("Chorus Send Level To Delay",a),this.callEvent("effectChange",{effect:"chorus",parameter:"sendLevelToDelay",value:a});break;case 80:this.setDelayMacro(a),h.gsInfo("Delay Macro",a);break;case 81:this.delayProcessor.preLowpass=a,h.gsInfo("Delay Pre-LPF",a),this.callEvent("effectChange",{effect:"delay",parameter:"preLowpass",value:a});break;case 82:this.delayProcessor.timeCenter=a,h.gsInfo("Delay Time Center",a),this.callEvent("effectChange",{effect:"delay",parameter:"timeCenter",value:a});break;case 83:this.delayProcessor.timeRatioLeft=a,h.gsInfo("Delay Time Ratio Left",a),this.callEvent("effectChange",{effect:"delay",parameter:"timeRatioLeft",value:a});break;case 84:this.delayProcessor.timeRatioRight=a,h.gsInfo("Delay Time Ratio Right",a),this.callEvent("effectChange",{effect:"delay",parameter:"timeRatioRight",value:a});break;case 85:this.delayProcessor.levelCenter=a,h.gsInfo("Delay Level Center",a),this.callEvent("effectChange",{effect:"delay",parameter:"levelCenter",value:a});break;case 86:this.delayProcessor.levelLeft=a,h.gsInfo("Delay Level Left",a),this.callEvent("effectChange",{effect:"delay",parameter:"levelLeft",value:a});break;case 87:this.delayProcessor.levelRight=a,h.gsInfo("Delay Level Right",a),this.callEvent("effectChange",{effect:"delay",parameter:"levelRight",value:a});break;case 88:this.delayProcessor.level=a,h.gsInfo("Delay Level",a),this.callEvent("effectChange",{effect:"delay",parameter:"level",value:a});break;case 89:this.delayProcessor.feedback=a,h.gsInfo("Delay Feedback",a),this.callEvent("effectChange",{effect:"delay",parameter:"feedback",value:a});break;case 90:this.delayProcessor.sendLevelToReverb=a,h.gsInfo("Delay Send Level To Reverb",a),this.callEvent("effectChange",{effect:"delay",parameter:"sendLevelToReverb",value:a});break}break}if(s===3){if(this.systemParameters.insertionEffectLock)return;if(n>=3&&n<=25&&(this.insertionParams[n-3]=a),n>=3&&n<=22){this.insertionProcessor.setParameter(n,a),h.gsInfo(`EFX Parameter ${n-2}`,a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return}switch(n){default:h.gsFail("Insertion Effect",[n]);return;case 0:{let r=a<<8|t[8],i=this.insertionEffects.get(r);i?(h.gsInfo("EFX Type",r.toString(16)),this.insertionProcessor=i):(this.insertionProcessor=this.insertionFallback,h.gsFail("EFX Processor",[r],"Using Thru.")),this.resetInsertionParams(),this.insertionProcessor.reset(),this.callEvent("effectChange",{effect:"insertion",parameter:0,value:r});return}case 23:this.insertionProcessor.sendLevelToReverb=a/127*hA,h.gsInfo("EFX Send Level to Reverb",a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return;case 24:this.insertionProcessor.sendLevelToChorus=a/127*hA,h.gsInfo("EFX Send Level to Chorus",a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return;case 25:this.insertionProcessor.sendLevelToDelay=a/127*hA,this.delayActive=!0,h.gsInfo("EFX Send Level to Delay",a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return}}if(s>>4===1){let r=se.syxToChannel(s&15)+e,i=this.midiChannels[r];switch(n){default:h.gsFail(`Patch Part Parameter for ${r}`,[n]);return;case 0:i.controllerChange(f.bankSelect,a),i.programChange(t[8]);break;case 2:{let o=a===16?-1:a+e;i.setMIDIParameter("rxChannel",o),this.customChannelNumbers||=o!==i.channel,h.gsInfo(`Rx. Channel on ${r}`,o);break}case 19:i.setMIDIParameter("polyMode",a===1),h.gsInfo(`Mono/poly on ${r}`,i.midiParameters.polyMode?"POLY":"MONO");break;case 20:i.setMIDIParameter("assignMode",a),h.gsInfo(`Assign mode on ${r}`,a);break;case 21:{i.setMIDIParameter("drumMap",a);let o=a>0;i.setGSDrums(o),h.gsInfo(`Drums on ${r}`,o.toString());return}case 22:{let o=a-64;i.keyShift(o);return}case 25:i.controllerChange(f.mainVolume,a);return;case 28:{let o=a,g=o===0;i.setMIDIParameter("randomPan",g),g?h.gsInfo(`Random pan on ${r}`,"ON"):i.controllerChange(f.pan,o);break}case 31:i.setMIDIParameter("cc1",a),h.gsInfo("CC1 Controller Number",a);break;case 32:i.setMIDIParameter("cc2",a),h.gsInfo("CC2 Controller Number",a);break;case 33:i.controllerChange(f.chorusDepth,a);break;case 34:i.controllerChange(f.reverbDepth,a);break;case 42:{let o=((a<<7|t[8])-8192)/81.92;i.fineTune(o);break}case 44:i.controllerChange(f.variationDepth,a);break;case 48:i.controllerChange(f.vibratoRate,a);break;case 49:i.controllerChange(f.vibratoDepth,a);break;case 50:i.controllerChange(f.brightness,a);break;case 51:i.controllerChange(f.filterResonance,a);break;case 52:i.controllerChange(f.attackTime,a);break;case 53:i.controllerChange(f.decayTime,a);break;case 54:i.controllerChange(f.releaseTime,a);break;case 55:i.controllerChange(f.vibratoDelay,a);break;case 64:{let o=t.length-9,g=new Int8Array(12);for(let l=0;l<o;l++)g[l]=t[l+7]-64;i.setOctaveTuning(g),h.gsInfo(`Octave Scale Tuning on ${r}`,g.join(", "));break}}return}if(s>>4===2){let r=se.syxToChannel(s&15)+e,i=this.midiChannels[r];switch(n&240){default:h.gsFail(`Patch Parameter Controller for ${r}`,[n&240]);break;case 0:if((n&15)===4){let o=a/127*600;i.modulationDepth(o);break}i.dynamicModulators.setupReceiver(n,a,f.modulationWheel,!0,"mod wheel");break;case 16:if((n&15)===0){let o=a-64;i.pitchWheelRange(o);break}i.dynamicModulators.setupReceiver(n,a,Ie.pitchWheel,!1,"pitch wheel",!0);break;case 32:i.dynamicModulators.setupReceiver(n,a,Ie.channelPressure,!1,"channel pressure");break;case 48:i.dynamicModulators.setupReceiver(n,a,Ie.polyPressure,!1,"poly pressure");break;case 64:i.dynamicModulators.setupReceiver(n,a,i.midiParameters.cc1,!0,"CC1");break;case 80:i.dynamicModulators.setupReceiver(n,a,i.midiParameters.cc2,!0,"CC2")}return}if(s>>4===4){let r=se.syxToChannel(s&15)+e,i=this.midiChannels[r];switch(n){default:h.gsFail("Patch Part Parameter",[n]);break;case 0:case 1:i.controllerChange(f.bankSelectLSB,a);break;case 34:{if(this.systemParameters.insertionEffectLock)return;let o=a===1;i.setMIDIParameter("efxAssign",o),this.insertionActive||=o,h.gsInfo(`EFX assign for ${r}`,o?"EFX":"BYPASS")}}return}h.gsFail("Patch Parameter",t);return}if(A===65){if(this.systemParameters.drumLock)return;let r=(s>>4)+1,i=n,o=s&15;switch(o){default:h.gsFail("Drum Setup",[o]);return;case 0:{let g=_e(t,12,7);h.gsInfo(`Patch Name for MAP${r}`,g);break}case 1:{let g=a-60;for(let l of this.midiChannels)l.midiParameters.drumMap===r&&(l.drumParams[i].pitch=g*(l.patch.bankLSB===1?100:50));h.gsInfo(`Drum Pitch for MAP${r}, key ${i}`,g);break}case 2:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].gain=a/120);h.gsInfo(`Drum Level for MAP${r}, key ${i}`,a);break;case 3:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].exclusiveClass=a);h.gsInfo(`Drum Assign Group for MAP${r}, key ${i}`,a);break;case 4:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].pan=a);h.gsInfo(`Drum Pan for MAP${r}, key ${i}`,a);break;case 5:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].reverbGain=a/127);h.gsInfo(`Drum Reverb for MAP${r}, key ${i}`,a);break;case 6:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].chorusGain=a/127);h.gsInfo(`Drum Chorus for MAP${r}, key ${i}`,a);break;case 7:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].rxNoteOff=a===1);h.gsInfo(`Drum Note Off for MAP${r}, key ${i}`,a===1?"ON":"OFF");break;case 8:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].rxNoteOn=a===1);h.gsInfo(`Drum Note On for MAP${r}, key ${i}`,a===1?"ON":"OFF");break;case 9:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[i].delayGain=a/127);h.gsInfo(`Drum Delay for MAP${r}, key ${i}`,a);break}return}h.gsFail("System Exclusive",t);return}case 69:t[4]===16&&(t[5]===0?this.callEvent("displayMessage",[...t]):t[5]===1?this.callEvent("displayMessage",[...t]):h.gsFail("Display Data",t));return;case 22:if(t[4]===16){this.setMIDIParameter("gain",t[7]/100),h.coolInfo("Roland Master Volume Control",t[7]);return}else h.unsupported("Roland",t)}else{h.unsupported("Roland",t);return}}function Gr(t,e=0){if(t[2]===76){let A=t[3],s=t[4],n=t[5],a=t[6];if(A===0&&s===0){switch(n){case 0:{let r=(((t[6]&15)<<12|(t[7]&15)<<8|(t[8]&15)<<4|t[9]&15)-1024)/10;this.setMIDIParameter("fineTune",r),h.xgInfo("Master Tune",r,"cents")}break;case 4:this.setMIDIParameter("gain",a/127),h.xgInfo("Master Volume",a);break;case 5:{let r=127-a;this.setMIDIParameter("gain",r/127),h.xgInfo("Master Attenuation",a);break}case 6:{let r=a-64;this.setMIDIParameter("keyShift",r),h.xgInfo("Master Transpose",a);break}case 127:case 126:h.coolInfo("MIDI System","Yamaha XG"),this.reset("xg");break}return}if(A===2&&s===1){let r,i=n;i<=21?r="Reverb":i<=53?r="Chorus":r="Variation",h.xgFail(`${r} parameter`,[i]);return}if(A===8){let r=s+e;if(r>=this.midiChannels.length){h.xgFail("Part Setup",t,`Invalid part number: ${r}`);return}let i=this.midiChannels[r];switch(n){default:h.xgFail("Part Setup",[t[5]]);break;case 1:i.controllerChange(f.bankSelect,a);break;case 2:i.controllerChange(f.bankSelectLSB,a);break;case 3:i.programChange(a);break;case 4:{let o=a+e;i.setMIDIParameter("rxChannel",o),this.customChannelNumbers||=o!==i.channel,h.xgInfo(`Rev. Channel on ${r}`,o);break}case 5:{let o=a===1;i.setMIDIParameter("polyMode",o),h.xgInfo(`Mono/poly on ${r}`,o?"POLY":"MONO");break}case 7:{let o=a!==0;i.setDrums(o),h.xgInfo(`Part Mode on ${r}`,o?"DRUM":"MELODIC");break}case 8:{let o=a-64;i.keyShift(o);break}case 11:i.controllerChange(f.mainVolume,a);break;case 14:{let o=a,g=o===0;i.setMIDIParameter("randomPan",g),g?h.xgInfo(`Random Pan for ${r}`,"ON"):i.controllerChange(f.pan,o);break}case 18:i.controllerChange(f.chorusDepth,a);break;case 19:i.controllerChange(f.reverbDepth,a);break;case 21:i.controllerChange(f.vibratoRate,a);break;case 22:i.controllerChange(f.vibratoDepth,a);break;case 23:i.controllerChange(f.vibratoDelay,a);break;case 24:i.controllerChange(f.brightness,a);break;case 25:i.controllerChange(f.filterResonance,a);break;case 26:i.controllerChange(f.attackTime,a);break;case 27:i.controllerChange(f.decayTime,a);break;case 28:i.controllerChange(f.releaseTime,a);break;case 35:{let o=a-64;i.pitchWheelRange(o)}}return}if(A>>4===3){if(this.systemParameters.drumLock)return;let r=s;switch(n){default:h.xgFail("Drum Setup",[n]);return;case 0:{let i=(a-64)*100;for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].pitch=i);h.xgInfo(`Drum Pitch for key ${r}`,i,"semitones");break}case 1:{let i=a-64;for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].pitch+=i,h.xgInfo(`Drum Pitch for key ${r}`,o.drumParams[r].pitch,"semitones"));break}case 2:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].gain=a/120);h.xgInfo(`Drum Level for key ${r}`,a);break;case 3:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].exclusiveClass=a);h.xgInfo(`Drum Alternate Group for key ${r}`,a);break;case 4:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].pan=a);h.xgInfo(`Drum Pan for key ${r}`,a);break;case 5:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].reverbGain=a/127);h.xgInfo(`Drum Reverb for key ${r}`,a);break;case 6:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].chorusGain=a/127);h.xgInfo(`Drum Chorus for key ${r}`,a);break;case 9:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].rxNoteOff=a===1);h.xgInfo(`Drum Note Off for key ${r}`,a===1?"ON":"OFF");break;case 10:for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].rxNoteOn=a===1);h.xgInfo(`Drum Note On for key ${r}`,a===1?"ON":"OFF");break}return}if(A===6||A===7){this.callEvent("displayMessage",[...t]);return}h.xgFail("System Exclusive",t,"Unknown address")}else h.xgFail("System Exclusive",t)}function Lr(t,e=0){e+=this.portSelectChannelOffset;let A=t[0];if(!(this.systemParameters.deviceID!==-1&&t[1]!==127&&this.systemParameters.deviceID!==t[1]))switch(A){default:h.unsupported("System Exclusive",t,`Unknown manufacturer: ${A}`);break;case 126:case 127:Mr.call(this,t,e);break;case 65:vr.call(this,t,e);break;case 67:Gr.call(this,t,e);break;case 245:if(t.length<2)return;for(this.portSelectChannelOffset=(t[1]-1)*16;this.midiChannels.length<=this.portSelectChannelOffset;){h.info(`%cPort select, channel offset %c${this.portSelectChannelOffset}%c. Creating a new port!`,d.info,d.value,d.info);for(let s=0;s<16;s++)this.createMIDIChannel(!0)}break}}var Rn=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=0;reset(){}process(t,e,A,s,n,a,r,i,o){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:C}=this;for(let B=0;B<o;B++){let I=t[B],E=e[B],m=i+B;A[m]+=I,s[m]+=E;let k=(I+E)*.5;n[B]+=k*g,a[B]+=k*l,r[B]+=k*C}}setParameter(t,e){}},ct=class{static data=[[0,200,200,0,0,.05,.05,315,250,200,250,100,-180,0],[.1,205,205,.1,5,.1,.1,315,250,200,250,110,-180,1],[.2,210,210,.2,10,.15,.15,315,250,200,250,120,-180,2],[.3,215,215,.3,15,.2,.2,315,250,200,250,130,-180,3],[.4,220,220,.4,20,.25,.25,315,250,200,250,140,-180,4],[.5,225,225,.5,25,.3,.3,315,250,200,250,150,-180,5],[.6,230,230,.6,30,.35,.35,315,250,200,250,160,-168,5],[.7,235,235,.7,35,.4,.4,315,250,200,250,170,-168,5],[.8,240,240,.8,40,.45,.45,400,315,250,315,180,-168,5],[.9,245,245,.9,45,.5,.5,400,315,250,315,190,-168,5],[1,250,250,1,50,.55,.55,400,315,250,315,200,-156,5],[1.1,255,255,1.1,55,.6,.6,400,315,250,315,210,-156,5],[1.2,260,260,1.2,60,.65,.65,400,315,250,315,220,-156,5],[1.3,265,265,1.3,65,.7,.7,400,315,250,315,230,-156,5],[1.4,270,270,1.4,70,.75,.75,400,315,250,315,240,-144,5],[1.5,275,275,1.5,75,.8,.8,400,315,250,315,250,-144,5],[1.6,280,280,1.6,80,.85,.85,500,400,315,400,260,-144,5],[1.7,285,285,1.7,85,.9,.9,500,400,315,400,270,-144,5],[1.8,290,290,1.8,90,.95,.95,500,400,315,400,280,-132,5],[1.9,295,295,1.9,95,1,1,500,400,315,400,290,-132,5],[2,300,300,2,100,1.05,1.05,500,400,315,400,300,-132,5],[2.1,305,305,2.1,105,1.1,1.1,500,400,315,400,320,-132,5],[2.2,310,310,2.2,110,1.15,1.15,500,400,315,400,340,-120,5],[2.3,315,315,2.3,115,1.2,1.2,500,400,315,400,360,-120,5],[2.4,320,320,2.4,120,1.25,1.25,630,500,400,500,380,-120,5],[2.5,325,325,2.5,125,1.3,1.3,630,500,400,500,400,-120,5],[2.6,330,330,2.6,130,1.35,1.35,630,500,400,500,420,-108,5],[2.7,335,335,2.7,135,1.4,1.4,630,500,400,500,440,-108,5],[2.8,340,340,2.8,140,1.45,1.45,630,500,400,500,460,-108,5],[2.9,345,345,2.9,145,1.5,1.5,630,500,400,500,480,-108,5],[3,350,350,3,150,1.55,1.55,630,500,400,500,500,-96,6],[3.1,355,355,3.1,155,1.6,1.6,630,500,400,500,520,-96,6],[3.2,360,360,3.2,160,1.65,1.65,800,630,500,630,540,-96,6],[3.3,365,365,3.3,165,1.7,1.7,800,630,500,630,560,-96,6],[3.4,370,370,3.4,170,1.75,1.75,800,630,500,630,580,-84,6],[3.5,375,375,3.5,175,1.8,1.8,800,630,500,630,600,-84,6],[3.6,380,380,3.6,180,1.85,1.85,800,630,500,630,620,-84,6],[3.7,385,385,3.7,185,1.9,1.9,800,630,500,630,640,-84,6],[3.8,390,390,3.8,190,1.95,1.95,800,630,500,630,660,-72,6],[3.9,395,395,3.9,195,2,2,800,630,500,630,680,-72,6],[4,400,400,4,200,2.05,2.05,1e3,800,630,800,700,-72,6],[4.1,405,405,4.1,205,2.1,2.1,1e3,800,630,800,720,-72,6],[4.2,410,410,4.2,210,2.15,2.15,1e3,800,630,800,740,-60,6],[4.3,415,415,4.3,215,2.2,2.2,1e3,800,630,800,760,-60,6],[4.4,420,420,4.4,220,2.25,2.25,1e3,800,630,800,780,-60,6],[4.5,425,425,4.5,225,2.3,2.3,1e3,800,630,800,800,-60,6],[4.6,430,430,4.6,230,2.35,2.35,1e3,800,630,800,820,-48,6],[4.7,435,435,4.7,235,2.4,2.4,1e3,800,630,800,840,-48,6],[4.8,440,440,4.8,240,2.45,2.45,1250,1e3,800,1e3,860,-48,9],[4.9,445,445,4.9,245,2.5,2.5,1250,1e3,800,1e3,880,-48,9],[5,450,450,5,250,2.55,2.55,1250,1e3,800,1e3,900,-36,9],[5.5,455,455,5.5,255,2.6,2.6,1250,1e3,800,1e3,920,-36,9],[6,460,460,6,260,2.65,2.65,1250,1e3,800,1e3,940,-36,9],[6.5,465,465,6.5,265,2.7,2.7,1250,1e3,800,1e3,960,-36,9],[7,470,470,7,270,2.75,2.75,1250,1e3,800,1e3,980,-24,9],[7.5,475,475,7.5,275,2.8,2.8,1250,1e3,800,1e3,1e3,-24,9],[8,480,480,8,280,2.85,2.85,1600,1250,1e3,1250,1100,-24,9],[8.5,485,485,8.5,285,2.9,2.9,1600,1250,1e3,1250,1200,-24,9],[9,490,490,9,290,2.95,2.95,1600,1250,1e3,1250,1300,-12,9],[9.5,495,495,9.5,295,3,3,1600,1250,1e3,1250,1400,-12,9],[10,500,500,10,300,3.05,3.05,1600,1250,1e3,1250,1500,-12,9],[11,505,505,11,305,3.1,3.1,1600,1250,1e3,1250,1600,-12,9],[12,510,510,12,310,3.15,3.15,1600,1250,1e3,1250,1700,0,9],[13,515,515,13,315,3.2,3.2,1600,1250,1e3,1250,1800,0,9],[14,520,520,14,320,3.25,3.25,2e3,1600,1250,1600,1900,0,12],[15,525,525,15,325,3.3,3.3,2e3,1600,1250,1600,2e3,0,12],[16,530,530,16,330,3.35,3.35,2e3,1600,1250,1600,2100,12,12],[17,535,535,17,335,3.4,3.4,2e3,1600,1250,1600,2200,12,12],[18,540,540,18,340,3.45,3.45,2e3,1600,1250,1600,2300,12,12],[19,545,545,19,345,3.5,3.5,2e3,1600,1250,1600,2400,12,12],[20,550,550,20,350,3.55,3.55,2e3,1600,1250,1600,2500,24,12],[21,560,555,21,355,3.6,3.6,2e3,1600,1250,1600,2600,24,12],[22,570,560,22,360,3.65,3.65,2500,2e3,1600,2e3,2700,24,12],[23,580,565,23,365,3.7,3.7,2500,2e3,1600,2e3,2800,24,12],[24,590,570,24,370,3.75,3.75,2500,2e3,1600,2e3,2900,36,12],[25,600,575,25,375,3.8,3.8,2500,2e3,1600,2e3,3e3,36,12],[26,610,580,26,380,3.85,3.85,2500,2e3,1600,2e3,3100,36,12],[27,620,585,27,385,3.9,3.9,2500,2e3,1600,2e3,3200,36,12],[28,630,590,28,390,3.95,3.95,2500,2e3,1600,2e3,3300,48,12],[29,640,595,29,395,4,4,2500,2e3,1600,2e3,3400,48,12],[30,650,600,30,400,4.05,4.05,3150,2500,2e3,2500,3500,48,10],[31,660,610,31,405,4.1,4.1,3150,2500,2e3,2500,3600,48,10],[32,670,620,32,410,4.15,4.15,3150,2500,2e3,2500,3700,60,10],[33,680,630,33,415,4.2,4.2,3150,2500,2e3,2500,3800,60,10],[34,690,640,34,420,4.25,4.25,3150,2500,2e3,2500,3900,60,10],[35,700,650,35,425,4.3,4.3,3150,2500,2e3,2500,4e3,60,10],[36,710,660,36,430,4.35,4.35,3150,2500,2e3,2500,4100,72,10],[37,720,670,37,435,4.4,4.4,3150,2500,2e3,2500,4200,72,10],[38,730,680,38,440,4.45,4.45,4e3,3150,2500,3150,4300,72,11],[39,740,690,39,445,4.5,4.5,4e3,3150,2500,3150,4400,72,11],[40,750,700,40,450,4.55,4.55,4e3,3150,2500,3150,4500,84,11],[41,760,710,50,455,4.6,4.6,4e3,3150,2500,3150,4600,84,11],[42,770,720,60,460,4.65,4.65,4e3,3150,2500,3150,4700,84,11],[43,780,730,70,465,4.7,4.7,4e3,3150,2500,3150,4800,84,11],[44,790,740,80,470,4.75,4.75,4e3,3150,2500,3150,4900,96,11],[45,800,750,90,475,4.8,4.8,4e3,3150,2500,3150,5e3,96,11],[46,810,760,100,480,4.85,4.85,5e3,4e3,3150,4e3,5100,96,12],[47,820,770,110,485,4.9,4.9,5e3,4e3,3150,4e3,5200,96,12],[48,830,780,120,490,4.95,4.95,5e3,4e3,3150,4e3,5300,108,12],[49,840,790,130,495,5,5,5e3,4e3,3150,4e3,5400,108,12],[50,850,800,140,500,5.1,5.05,5e3,4e3,3150,4e3,5500,108,12],[52,860,810,150,505,5.2,5.1,5e3,4e3,3150,4e3,5600,108,12],[54,870,820,160,510,5.3,5.15,5e3,4e3,3150,4e3,5700,120,12],[56,880,830,170,515,5.4,5.2,5e3,4e3,3150,4e3,5800,120,12],[58,890,840,180,520,5.5,5.25,6300,5e3,4e3,5e3,5900,120,13],[60,900,850,190,525,5.6,5.3,6300,5e3,4e3,5e3,6e3,120,13],[62,910,860,200,530,5.7,5.35,6300,5e3,4e3,5e3,6100,132,13],[64,920,870,210,535,5.8,5.4,6300,5e3,4e3,5e3,6200,132,13],[66,930,880,220,540,5.9,5.45,6300,5e3,4e3,5e3,6300,132,13],[68,940,890,230,545,6,5.5,6300,5e3,4e3,5e3,6400,132,13],[70,950,900,240,550,6.1,5.55,6300,5e3,4e3,5e3,6500,144,13],[72,960,910,250,555,6.2,5.6,6300,5e3,4e3,5e3,6600,144,13],[74,970,920,260,560,6.3,5.65,8e3,6300,5e3,6300,6700,144,14],[76,980,930,270,565,6.4,5.7,8e3,6300,5e3,6300,6800,144,14],[78,990,940,280,570,6.5,5.75,8e3,6300,5e3,6300,6900,156,14],[80,1e3,950,290,575,6.6,5.8,8e3,6300,5e3,6300,7e3,156,14],[82,1e3,960,300,580,6.7,5.85,8e3,6300,5e3,6300,7100,156,14],[84,1e3,970,320,585,6.8,5.9,8e3,6300,5e3,6300,7200,156,14],[86,1e3,980,340,590,6.9,5.95,8e3,6300,5e3,6300,7300,168,14],[88,1e3,990,360,595,7,6,8e3,6300,5e3,6300,7400,168,14],[90,1e3,1e3,380,600,7.5,6.05,13500,8e3,6300,13500,7500,168,15],[92,1e3,1e3,400,605,8,6.1,13500,8e3,6300,13500,7600,168,15],[94,1e3,1e3,420,610,8.5,6.15,13500,8e3,6300,13500,7700,-180,15],[96,1e3,1e3,440,615,9,6.2,13500,8e3,6300,13500,7800,-180,15],[98,1e3,1e3,460,620,9.5,6.25,13500,8e3,6300,13500,7900,-180,15],[100,1e3,1e3,480,625,10,6.3,13500,8e3,6300,13500,8e3,-180,15],[100,1e3,1e3,500,630,10,6.35,13500,8e3,6300,13500,8e3,-180,15],[100,1e3,1e3,500,635,10,6.4,13500,8e3,6300,13500,8e3,-180,15]];static preDelayTime(t){return this.data[t][0]}static delayTime1(t){return this.data[t][1]}static delayTime2(t){return this.data[t][2]}static delayTime3(t){return this.data[t][3]}static delayTime4(t){return this.data[t][4]}static rate1(t){return this.data[t][5]}static rate2(t){return this.data[t][6]}static hfDamp(t){return this.data[t][7]}static cutoffFreq(t){return this.data[t][8]}static eqFreq(t){return this.data[t][9]}static lpf(t){return this.data[t][10]}static manual(t){return this.data[t][11]}static azimuth(t){return this.data[t][12]}static accl(t){return this.data[t][13]}},Hs=Math.PI/2,fA=-64,Fn=63,ms=Fn-fA,DA=new Float32Array(ms+1),wA=new Float32Array(ms+1);for(let t=fA;t<=Fn;t++){let e=(t-fA)/ms,A=t-fA;DA[A]=Math.cos(Hs*e),wA[A]=Math.sin(Hs*e)}function me(t){t.x1=t.x2=t.y1=t.y2=0}var He={b0:1,b1:0,b2:0,a0:1,a1:0,a2:0};function kt(t,e,A,s,n){let a=e.b0*t+e.b1*s.x1+e.b2*s.x2-e.a1*s.y1-e.a2*s.y2;s.x2=s.x1,s.x1=t,s.y2=s.y1,s.y1=a;let r=A.b0*a+A.b1*n.x1+A.b2*n.x2-A.a1*n.y1-A.a2*n.y2;return n.x2=n.x1,n.x1=a,n.y2=n.y1,n.y1=r,r}function rt(t,e,A){let s=e.b0*t+e.b1*A.x1+e.b2*A.x2-e.a1*A.y1-e.a2*A.y2;return A.x2=A.x1,A.x1=t,A.y2=A.y1,A.y1=s,s}function Bt(t,e,A,s,n){let a=Math.pow(10,e/40),r=2*Math.PI*A/s,i=Math.cos(r),o=Math.sin(r)/2*Math.sqrt((a+1/a)*(1/1-1)+2),g,l,C,B,I,E;n?(g=a*(a+1-(a-1)*i+2*Math.sqrt(a)*o),l=2*a*(a-1-(a+1)*i),C=a*(a+1-(a-1)*i-2*Math.sqrt(a)*o),B=a+1+(a-1)*i+2*Math.sqrt(a)*o,I=-2*(a-1+(a+1)*i),E=a+1+(a-1)*i-2*Math.sqrt(a)*o):(g=a*(a+1+(a-1)*i+2*Math.sqrt(a)*o),l=-2*a*(a-1+(a+1)*i),C=a*(a+1+(a-1)*i-2*Math.sqrt(a)*o),B=a+1-(a-1)*i+2*Math.sqrt(a)*o,I=2*(a-1-(a+1)*i),E=a+1-(a-1)*i-2*Math.sqrt(a)*o),t.b0=g/B,t.b1=l/B,t.b2=C/B,t.a0=1,t.a1=I/B,t.a2=E/B}var we={x1:0,x2:0,y1:0,y2:0},Nr=class{type=256;sendLevelToReverb=0;sendLevelToChorus=0;sendLevelToDelay=0;sampleRate;level=1;lowFreq=400;lowGain=5;hiFreq=8e3;hiGain=-12;m1Freq=1600;m1Q=.5;m1Gain=8;m2Freq=1e3;m2Q=.5;m2Gain=-8;lowCoeffs={...He};m1Coeffs={...He};m2Coeffs={...He};hiCoeffs={...He};lowStateL={...we};lowStateR={...we};m1StateL={...we};m1StateR={...we};m2StateL={...we};m2StateR={...we};hiStateL={...we};hiStateR={...we};constructor(t){this.sampleRate=t,this.reset(),this.updateCoefficients()}reset(){this.level=1,this.lowFreq=400,this.lowGain=5,this.hiGain=-12,this.hiFreq=8e3,this.m1Freq=1600,this.m1Q=.5,this.m1Gain=8,this.m2Freq=1e3,this.m2Q=.5,this.m2Gain=-8,me(this.lowStateL),me(this.lowStateR),me(this.m1StateL),me(this.m1StateR),me(this.m2StateL),me(this.m2StateR),me(this.hiStateL),me(this.hiStateR),this.updateCoefficients()}setParameter(t,e){switch(t){default:break;case 3:this.lowFreq=e===1?400:200;break;case 4:this.lowGain=e-64;break;case 5:this.hiFreq=e===1?8e3:4e3;break;case 6:this.hiGain=e-64;break;case 7:this.m1Freq=ct.eqFreq(e);break;case 8:this.m1Q=[.5,1,2,4,9][e]||1;break;case 9:this.m1Gain=e-64;break;case 10:this.m2Freq=ct.eqFreq(e);break;case 11:this.m2Q=[.5,1,2,4,9][e]||1;break;case 12:this.m2Gain=e-64;break;case 22:this.level=e/127;break}this.updateCoefficients()}process(t,e,A,s,n,a,r,i,o){let{level:g,sendLevelToChorus:l,sendLevelToDelay:C,sendLevelToReverb:B,lowCoeffs:I,lowStateL:E,lowStateR:m,m1Coeffs:k,m1StateL:y,m1StateR:b,m2StateL:R,m2StateR:M,m2Coeffs:S,hiCoeffs:Q,hiStateL:p,hiStateR:D}=this;for(let q=0;q<o;q++){let K=t[q],O=e[q];K=rt(K,I,E),O=rt(O,I,m),K=rt(K,k,y),O=rt(O,k,b),K=rt(K,S,R),O=rt(O,S,M),K=rt(K,Q,p),O=rt(O,Q,D);let Y=i+q;A[Y]+=K*g,s[Y]+=O*g;let H=.5*(K+O);n[q]+=H*B,a[q]+=H*l,r[q]+=H*C}}updateCoefficients(){Pr(this.lowCoeffs,this.lowFreq,this.lowGain/2,this.sampleRate),Os(this.m1Coeffs,this.m1Freq,this.m1Gain,this.m1Q,this.sampleRate),Os(this.m2Coeffs,this.m2Freq,this.m2Gain,this.m2Q,this.sampleRate),Tr(this.hiCoeffs,this.hiFreq,this.hiGain/2,this.sampleRate)}},Mn=1;function Os(t,e,A,s,n){let a=Math.pow(10,A/40),r=2*Math.PI*e/n,i=Math.cos(r),o=Math.sin(r)/(2*s),g=1+o*a,l=-2*i,C=1-o*a,B=1+o/a,I=-2*i,E=1-o/a;t.a0=1,t.a1=I/B,t.a2=E/B,t.b0=g/B,t.b1=l/B,t.b2=C/B}function Pr(t,e,A,s){let n=Math.pow(10,A/40),a=2*Math.PI*e/s,r=Math.cos(a),i=Math.sin(a)/2*Math.sqrt((n+1/n)*(1/Mn-1)+2),o=n*(n+1-(n-1)*r+2*Math.sqrt(n)*i),g=2*n*(n-1-(n+1)*r),l=n*(n+1-(n-1)*r-2*Math.sqrt(n)*i),C=n+1+(n-1)*r+2*Math.sqrt(n)*i,B=-2*(n-1+(n+1)*r),I=n+1+(n-1)*r-2*Math.sqrt(n)*i;t.a0=1,t.a1=B/C,t.a2=I/C,t.b0=o/C,t.b1=g/C,t.b2=l/C}function Tr(t,e,A,s){let n=Math.pow(10,A/40),a=2*Math.PI*e/s,r=Math.cos(a),i=Math.sin(a)/2*Math.sqrt((n+1/n)*(1/Mn-1)+2),o=n*(n+1+(n-1)*r+2*Math.sqrt(n)*i),g=-2*n*(n-1+(n+1)*r),l=n*(n+1+(n-1)*r-2*Math.sqrt(n)*i),C=n+1-(n-1)*r+2*Math.sqrt(n)*i,B=2*(n-1-(n+1)*r),I=n+1-(n-1)*r-2*Math.sqrt(n)*i;t.a0=1,t.a1=B/C,t.a2=I/C,t.b0=o/C,t.b1=g/C,t.b2=l/C}var Gt=8,XA=128,Ys=4,ZA=600,Ur=.9,qs=.35,vn=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=288;manual=620;rate=.85;depth=64/XA;reso=16/127;mix=1;lowGain=0;hiGain=0;prevInL;prevOutL;prevInR;prevOutR;lowShelfCoef={...He};highShelfCoef={...He};manualOffset=ZA;lowShelfStateL={x1:0,x2:0,y1:0,y2:0};lowShelfStateR={x1:0,x2:0,y1:0,y2:0};highShelfStateL={x1:0,x2:0,y1:0,y2:0};highShelfStateR={x1:0,x2:0,y1:0,y2:0};prevL=0;prevR=0;level=104/127;phase=qs;sampleRate;constructor(t){this.sampleRate=t,this.prevInL=new Float32Array(Gt),this.prevOutL=new Float32Array(Gt),this.prevInR=new Float32Array(Gt),this.prevOutR=new Float32Array(Gt),this.reset()}reset(){this.phase=qs,this.setManual(620),this.rate=.85,this.depth=64/XA,this.reso=16/127,this.mix=1,this.lowGain=0,this.hiGain=0,this.level=104/127,me(this.highShelfStateL),me(this.highShelfStateR),me(this.lowShelfStateL),me(this.lowShelfStateR),this.updateShelves(),this.clearAllPass()}process(t,e,A,s,n,a,r,i,o){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:C,level:B,manual:I,manualOffset:E,mix:m,lowShelfCoef:k,lowShelfStateR:y,lowShelfStateL:b,highShelfCoef:R,highShelfStateL:M,highShelfStateR:S,prevInL:Q,prevInR:p,prevOutL:D,prevOutR:q,sampleRate:K,depth:O}=this,{prevL:Y,prevR:H,phase:Z}=this,T=this.rate/this.sampleRate,F=this.reso*Ur;for(let u=0;u<o;u++){let x=kt(t[u],k,R,b,M),P=kt(e[u],k,R,y,S),te=2*Math.abs(Z-.5);(Z+=T)>=1&&(Z-=1);let W=E+I*(1-O*te),_=Math.tan(Math.PI*W/K),$=Math.max(-.9999,Math.min(.9999,(1-_)/(1+_))),ne=x+F*Y,ae=P+F*H;for(let Be=0;Be<Gt;Be++){let be=-$*ne+Q[Be]+$*D[Be];Q[Be]=ne,D[Be]=be,ne=be;let Ue=-$*ae+p[Be]+$*q[Be];p[Be]=ae,q[Be]=Ue,ae=Ue}Y=ne,H=ae;let J=(x+ne*m)*B,ie=(P+ae*m)*B,pe=i+u;A[pe]+=J,s[pe]+=ie;let ve=(J+ie)*.5;n[u]+=ve*g,a[u]+=ve*l,r[u]+=ve*C}this.phase=Z,this.prevL=Y,this.prevR=H}setParameter(t,e){switch(t){default:break;case 3:this.setManual(ct.manual(e));break;case 4:this.rate=ct.rate1(e);break;case 5:this.depth=e/XA;break;case 6:this.reso=e/127;break;case 7:this.mix=e/127;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}setManual(t){t>1e3?(this.manualOffset=ZA*1.5*Ys,this.manual=t):(this.manualOffset=ZA,this.manual=t*Ys)}clearAllPass(){this.prevR=0,this.prevL=0;for(let t=0;t<Gt;t++)this.prevInL[t]=0,this.prevOutL[t]=0,this.prevInR[t]=0,this.prevOutR[t]=0}updateShelves(){Bt(this.lowShelfCoef,this.lowGain,200,this.sampleRate,!0),Bt(this.highShelfCoef,this.hiGain,4e3,this.sampleRate,!1)}},Js=Math.PI*2,xr=.935,Hr=2,Or=.01,Ks=127,Yr=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=294;modWave=1;modRate=3.05;modDepth=96;lowGain=0;hiGain=0;level=Ks/127;currentPan=0;phase=0;lsCoeffs={...He};hsCoeffs={...He};lsStateR={...we};lsStateL={...we};hsStateR={...we};hsStateL={...we};sampleRate;constructor(t){this.sampleRate=t,this.reset()}reset(){this.modWave=1,this.modRate=3.05,this.modDepth=96,this.lowGain=0,this.hiGain=0,this.level=Ks/127,this.currentPan=0,this.phase=0,me(this.hsStateR),me(this.hsStateL),me(this.lsStateR),me(this.lsStateL),this.updateShelves()}process(t,e,A,s,n,a,r,i,o){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:C,level:B,lsCoeffs:I,lsStateL:E,lsStateR:m,hsCoeffs:k,hsStateR:y,hsStateL:b,modWave:R}=this,M=Math.pow(this.modDepth/127,Hr),S=2/(1+M)*xr,Q=this.modRate/this.sampleRate,{phase:p,currentPan:D}=this;for(let q=0;q<o;q++){let K=kt(t[q],I,k,E,b),O=kt(e[q],I,k,m,y),Y;switch(R){default:Y=1-4*Math.abs(p-.5);break;case 1:Y=p>.5?-1:-Math.cos((p-.75)*Js);break;case 2:Y=Math.sin(Js*p);break;case 3:Y=1-2*p;break;case 4:Y=2*p-1;break}(p+=Q)>=1&&(p-=1),D+=(Y-D)*Or;let H=D*M,Z=(1-H)*.5*S,T=(1+H)*.5*S,F=K*B*Z,u=O*B*T,x=i+q;A[x]+=F,s[x]+=u;let P=(F+u)*.5;n[q]+=P*g,a[q]+=P*l,r[q]+=P*C}this.currentPan=D,this.phase=p}setParameter(t,e){switch(t){default:break;case 3:this.modWave=e;break;case 4:this.modRate=ct.rate1(e);break;case 5:this.modDepth=e;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}updateShelves(){Bt(this.lsCoeffs,this.lowGain,200,this.sampleRate,!0),Bt(this.hsCoeffs,this.hiGain,4e3,this.sampleRate,!1)}},Vs=96,qr=.1,Jr=.1,Kr=27,Vr=28,Xr=-28,Zr=400,_r=.62,Wr=.005,Gn=5,Xs=Gn*.5,Ln=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=289;filType=1;sens=0;manual=68;peak=62;rate=2.05;depth=72;polarity=1;pan=0;lowGain=0;hiGain=0;level=Vs/127;coeffs={...He};state={...we};hpCoeffs={...He};hpState={...we};phase=0;lsCoeffs={...He};hsCoeffs={...He};lsState={...we};hsState={...we};sampleRate;lastFc=this.manual;attackCoeff;releaseCoeff;envelope=0;constructor(t){this.sampleRate=t,this.attackCoeff=Math.exp(-1/(qr*t)),this.releaseCoeff=Math.exp(-1/(Jr*t)),this.reset()}reset(){this.filType=1,this.sens=0,this.setManual(68),this.peak=62,this.rate=2.05,this.depth=72,this.polarity=1,this.lowGain=0,this.hiGain=0,this.pan=0,this.level=Vs/127,this.phase=.2,this.lastFc=this.manual,me(this.hsState),me(this.lsState),me(this.state),me(this.hpState),this.updateShelves()}process(t,e,A,s,n,a,r,i,o){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:C,level:B,lsCoeffs:I,lsState:E,hsCoeffs:m,hsState:k,coeffs:y,state:b,sampleRate:R,filType:M,manual:S,pan:Q,attackCoeff:p,releaseCoeff:D,hpState:q,hpCoeffs:K}=this,{phase:O,lastFc:Y,envelope:H}=this,Z=this.rate/this.sampleRate,T=Math.pow(10,this.peak/127*Vr/20),F=Math.pow(10,this.peak/127*Xr/20),u=this.polarity===0?-1:Gn,x=this.depth/127*u,P=this.sens/127,te=Q+64|0,W=DA[te],_=wA[te];for(let $=0;$<o;$++){let ne=kt((t[$]+e[$])*.5,I,m,E,k),ae=Math.abs(ne);H=ae>H?p*H+(1-p)*ae:D*H+(1-D)*ae;let J=2*Math.abs(O-.5)*x;(O+=Z)>=1&&(O-=1);let ie=J>=Xs||u<0?1:Math.sin(J*Math.PI/(2*Xs)),pe=S*(1+P*H*Kr),ve=Math.max(20,pe*(1+ie*J));Y+=(Math.max(10,ve)-Y)*Wr,zr(y,Y,T,R);let Be=ne;M===1&&($r(K,Zr,F,R),Be=rt(Be,K,q));let be=rt(Be,y,b)*B,Ue=be*W,ht=be*_,lt=i+$;A[lt]+=Ue,s[lt]+=ht,n[$]+=be*g,a[$]+=be*l,r[$]+=be*C}this.phase=O,this.lastFc=Y,this.envelope=H}setParameter(t,e){switch(t){default:break;case 3:this.filType=e;break;case 4:this.sens=e;break;case 5:this.setManual(e);break;case 6:this.peak=e;break;case 7:this.rate=ct.rate1(e);break;case 8:this.depth=e;break;case 9:this.polarity=e;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 21:this.pan=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}setManual(t){let e=t*_r,A=ct.manual(Math.floor(e)),s=ct.manual(Math.ceil(e)),n=e-Math.floor(e);this.manual=A+(s-A)*n}updateShelves(){Bt(this.lsCoeffs,this.lowGain,200,this.sampleRate,!0),Bt(this.hsCoeffs,this.hiGain,4e3,this.sampleRate,!1)}};function zr(t,e,A,s){let n=2*Math.PI*e/s,a=Math.cos(n),r=Math.sin(n)/(2*A),i=1-a,o=i/2,g=o,l=1+r,C=-2*a,B=1-r;t.a0=1,t.a1=C/l,t.a2=B/l,t.b0=o/l,t.b1=i/l,t.b2=g/l}function $r(t,e,A,s){let n=2*Math.PI*e/s,a=Math.cos(n),r=Math.sin(n)/(2*A),i=(1+a)/2,o=-(1+a),g=i,l=1+r,C=-2*a,B=1-r;t.a0=1,t.a1=C/l,t.a2=B/l,t.b0=i/l,t.b1=o/l,t.b2=g/l}var Zs=127,jr=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=4360;phPan=0;awPan=127;level=Zs/127;phaser;autoWah;bufferPh;bufferAw;constructor(t,e){this.phaser=new vn(t),this.autoWah=new Ln(t),this.bufferAw=new Float32Array(e),this.bufferPh=new Float32Array(e),this.phaser.sendLevelToReverb=0,this.phaser.sendLevelToChorus=0,this.phaser.sendLevelToDelay=0,this.autoWah.sendLevelToReverb=0,this.autoWah.sendLevelToChorus=0,this.autoWah.sendLevelToDelay=0,this.reset()}reset(){this.phPan=0,this.awPan=127,this.level=Zs/127,this.phaser.reset(),this.autoWah.reset(),this.phaser.setParameter(22,127),this.autoWah.setParameter(22,127)}process(t,e,A,s,n,a,r,i,o){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:C,level:B}=this,{bufferPh:I,bufferAw:E}=this;this.bufferPh.fill(0),this.phaser.process(t,t,I,I,I,I,I,0,o),this.bufferAw.fill(0),this.autoWah.process(e,e,E,E,E,E,E,0,o);let m=this.phPan|0,k=DA[m],y=wA[m],b=this.awPan|0,R=DA[b],M=wA[b];for(let S=0;S<o;S++){let Q=I[S]*.5*B,p=E[S]*.5*B,D=Q*k+p*R,q=Q*y+p*M,K=i+S;A[K]+=D,s[K]+=q;let O=(D+q)*.5;n[S]+=O*g,a[S]+=O*l,r[S]+=O*C}}setParameter(t,e){if(t>=3&&t<=7){this.phaser.setParameter(t,e);return}if(t>=8&&t<=14){this.autoWah.setParameter(t-5,e);return}switch(t){default:break;case 18:this.phPan=e;break;case 19:this.phaser.setParameter(22,e);break;case 20:this.awPan=e;break;case 21:this.autoWah.setParameter(22,e);break;case 22:this.level=e/127;break}}},_s=127,Ws=Math.PI*2,ei=.01,ti=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=293;modWave=1;modRate=3.05;modDepth=96;lowGain=0;hiGain=0;level=_s/127;phase=0;currentGain=1;lsCoeffs={...He};hsCoeffs={...He};lsStateR={...we};lsStateL={...we};hsStateR={...we};hsStateL={...we};sampleRate;constructor(t){this.sampleRate=t,this.reset()}reset(){this.modWave=1,this.modRate=3.05,this.modDepth=96,this.lowGain=0,this.hiGain=0,this.level=_s/127,this.phase=0,this.currentGain=1,me(this.hsStateR),me(this.hsStateL),me(this.lsStateR),me(this.lsStateL),this.updateShelves()}process(t,e,A,s,n,a,r,i,o){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:C,level:B,lsCoeffs:I,lsStateL:E,lsStateR:m,hsCoeffs:k,hsStateR:y,hsStateL:b,modDepth:R,modWave:M}=this,S=this.modRate/this.sampleRate,{currentGain:Q,phase:p}=this;for(let D=0;D<o;D++){let q=kt(t[D],I,k,E,b),K=kt(e[D],I,k,m,y),O;switch(M){default:O=1-4*Math.abs(p-.5);break;case 1:O=p>.5?-1:-Math.cos((p-.75)*Ws);break;case 2:O=Math.sin(Ws*p);break;case 3:O=1-2*p;break;case 4:O=2*p-1;break}(p+=S)>=1&&(p-=1);let Y=1-(O/2+.5)*(R/127);Q+=(Y-Q)*ei;let H=q*B*Q,Z=K*B*Q,T=i+D;A[T]+=H,s[T]+=Z;let F=(H+Z)*.5;n[D]+=F*g,a[D]+=F*l,r[D]+=F*C}this.phase=p,this.currentGain=Q}setParameter(t,e){switch(t){default:break;case 3:this.modWave=e;break;case 4:this.modRate=ct.rate1(e);break;case 5:this.modDepth=e;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}updateShelves(){Bt(this.lsCoeffs,this.lowGain,200,this.sampleRate,!0),Bt(this.hsCoeffs,this.hiGain,4e3,this.sampleRate,!1)}},Ai=[Rn,Nr,vn,Yr,Ln,jr,ti],si=class{preDelay=0;preLPF=.5;inputDiffusion1=.75;inputDiffusion2=.625;decay=.5;decayDiffusion1=.7;decayDiffusion2=.5;damping=.005;excursionRate=.1;excursionDepth=.2;gain=1;sampleRate;lp1=0;lp2=0;lp3=0;excPhase=0;pDWrite=0;taps;pDelay;pDLength;delays=new Array;constructor(t){this.sampleRate=t,this.pDLength=t,this.pDelay=new Float32Array(this.pDLength);for(let e of[.004771345,.003595309,.012734787,.009307483,.022579886,.149625349,.060481839,.1249958,.030509727,.141695508,.089244313,.106280031])this.makeDelayLine(e);this.taps=Int16Array.from([.008937872,.099929438,.064278754,.067067639,.066866033,.006283391,.035818689,.011861161,.121870905,.041262054,.08981553,.070931756,.011256342,.004065724],e=>Math.round(e*this.sampleRate))}process(t,e,A,s,n){let a=this.preDelay|0,r=this.inputDiffusion1,i=this.inputDiffusion2,o=this.decay,g=this.decayDiffusion1,l=this.decayDiffusion2,C=1-this.damping,B=this.excursionRate/this.sampleRate,I=this.excursionDepth*this.sampleRate/1e3,E=this.pDWrite;for(let m=0;m<n;m++)this.pDelay[(E+m)%this.pDLength]=t[m];for(let m=0;m<n;m++){this.lp1+=this.preLPF*(this.pDelay[(this.pDLength+this.pDWrite-a+m)%this.pDLength]-this.lp1);let k=this.writeDelay(0,this.lp1-r*this.readDelay(0));k=this.writeDelay(1,r*(k-this.readDelay(1))+this.readDelay(0)),k=this.writeDelay(2,r*k+this.readDelay(1)-i*this.readDelay(2)),k=this.writeDelay(3,i*(k-this.readDelay(3))+this.readDelay(2));let y=i*k+this.readDelay(3),b=I*(1+Math.cos(this.excPhase*6.28)),R=I*(1+Math.sin(this.excPhase*6.2847)),M=this.writeDelay(4,y+o*this.readDelay(11)+g*this.readDelayCAt(4,b));this.writeDelay(5,this.readDelayCAt(4,b)-g*M),this.lp2+=C*(this.readDelay(5)-this.lp2),M=this.writeDelay(6,o*this.lp2-l*this.readDelay(6)),this.writeDelay(7,this.readDelay(6)+l*M),M=this.writeDelay(8,y+o*this.readDelay(7)+g*this.readDelayCAt(8,R)),this.writeDelay(9,this.readDelayCAt(8,R)-g*M),this.lp3+=C*(this.readDelay(9)-this.lp3),M=this.writeDelay(10,o*this.lp3-l*this.readDelay(10)),this.writeDelay(11,this.readDelay(10)+l*M);let S=this.readDelayAt(9,this.taps[0])+this.readDelayAt(9,this.taps[1])-this.readDelayAt(10,this.taps[2])+this.readDelayAt(11,this.taps[3])-this.readDelayAt(5,this.taps[4])-this.readDelayAt(6,this.taps[5])-this.readDelayAt(7,this.taps[6]),Q=m+s;e[Q]+=S*this.gain;let p=this.readDelayAt(5,this.taps[7])+this.readDelayAt(5,this.taps[8])-this.readDelayAt(6,this.taps[9])+this.readDelayAt(7,this.taps[10])-this.readDelayAt(9,this.taps[11])-this.readDelayAt(10,this.taps[12])-this.readDelayAt(11,this.taps[13]);A[Q]+=p*this.gain,this.excPhase+=B;for(let D=0,q=this.delays[0];D<this.delays.length;q=this.delays[++D])q[1]=q[1]+1&q[3],q[2]=q[2]+1&q[3]}this.pDWrite=(E+n)%this.pDLength}makeDelayLine(t){let e=Math.round(t*this.sampleRate),A=2**Math.ceil(Math.log2(e));this.delays.push([new Float32Array(A),e-1,0,A-1])}writeDelay(t,e){return this.delays[t][0][this.delays[t][1]]=e}readDelay(t){return this.delays[t][0][this.delays[t][2]]}readDelayAt(t,e){let A=this.delays[t];return A[0][A[2]+e&A[3]]}readDelayCAt(t,e){let A=this.delays[t],s=e-~~e,n=A[3],a=~~e+A[2]-1,r=A[0][a++&n],i=A[0][a++&n],o=A[0][a++&n],g=A[0][a&n],l=(3*(i-o)-r+g)/2,C=2*o+r-(5*i+g)/2,B=(o-r)/2;return((l*s+C)*s+B)*s+i}},Xt=class{feedback=0;gain=1;buffer;bufferLength;writeIndex=0;constructor(t){this.buffer=new Float32Array(t),this.bufferLength=this.buffer.length,this._time=t-5}_time;get time(){return this._time}set time(t){this._time=Math.min(this.bufferLength,t)|0}clear(){this.buffer.fill(0)}process(t,e,A){let s=this.writeIndex,n=this._time,a=this.buffer,r=this.bufferLength,i=this.feedback,o=this.gain;for(let g=0;g<A;g++){let l=s-n;l<0&&(l+=r);let C=a[l];e[g]=C*o,a[s]=t[g]+C*i,++s>=r&&(s=0)}this.writeIndex=s}},ni=1.5,ai=class{dattorro;delayLeft;delayRight;delayLeftOutput;delayRightOutput;delayLeftInput;delayPreLPF;sampleRate;preLPFfc=8e3;preLPFa=0;preLPFz=0;characterTimeCoefficient=1;characterGainCoefficient=1;characterLPFCoefficient=0;delayGain=1;panDelayFeedback=0;constructor(t,e){this.sampleRate=t,this.delayLeftOutput=new Float32Array(e),this.delayRightOutput=new Float32Array(e),this.delayLeftInput=new Float32Array(e),this.delayPreLPF=new Float32Array(e),this.dattorro=new si(t),this.delayLeft=new Xt(t),this.delayRight=new Xt(t)}_delayFeedback=0;get delayFeedback(){return this._delayFeedback}set delayFeedback(t){this._delayFeedback=t,this.updateFeedback()}_character=0;get character(){return this._character}set character(t){switch(this._character=t,this.dattorro.damping=.005,this.characterTimeCoefficient=1,this.characterGainCoefficient=1,this.characterLPFCoefficient=0,this.dattorro.inputDiffusion1=.75,this.dattorro.inputDiffusion2=.625,this.dattorro.decayDiffusion1=.7,this.dattorro.decayDiffusion2=.5,this.dattorro.excursionRate=.5,this.dattorro.excursionDepth=.7,t){case 0:this.dattorro.damping=.85,this.characterTimeCoefficient=.9,this.characterGainCoefficient=.9,this.characterLPFCoefficient=.2;break;case 1:this.dattorro.damping=.2,this.characterGainCoefficient=.7,this.characterTimeCoefficient=1,this.dattorro.decayDiffusion2=.64,this.dattorro.decayDiffusion1=.6,this.characterLPFCoefficient=.2;break;case 2:this.dattorro.damping=.56,this.characterGainCoefficient=.75,this.characterTimeCoefficient=1,this.dattorro.decayDiffusion2=.64,this.dattorro.decayDiffusion1=.6,this.characterLPFCoefficient=.1;break;case 3:this.dattorro.damping=.3,this.characterGainCoefficient=1.25,this.characterTimeCoefficient=1.3,this.characterLPFCoefficient=0,this.dattorro.decayDiffusion2=.7,this.dattorro.decayDiffusion1=.66;break;case 4:this.characterGainCoefficient=1,this.characterTimeCoefficient=1.2,this.characterLPFCoefficient=.1,this.dattorro.damping=.1,this.dattorro.decayDiffusion2=.69,this.dattorro.decayDiffusion1=.67;break;case 5:this.characterGainCoefficient=.75,this.dattorro.damping=.65,this.characterTimeCoefficient=.5;break}this.updateTime(),this.updateGain(),this.updateLowpass(),this.updateFeedback(),this.delayLeft.clear(),this.delayRight.clear()}_time=0;get time(){return this._time}set time(t){this._time=t,this.updateTime()}_preDelayTime=0;get preDelayTime(){return this._preDelayTime}set preDelayTime(t){this._preDelayTime=t,this.dattorro.preDelay=t/1e3*this.sampleRate}_level=0;get level(){return this._level}set level(t){this._level=t,this.updateGain()}_preLowpass=0;get preLowpass(){return this._preLowpass}set preLowpass(t){this._preLowpass=t,this.preLPFfc=8e3*.63**this._preLowpass;let e=Math.exp(-2*Math.PI*this.preLPFfc/this.sampleRate);this.preLPFa=1-e,this.updateLowpass()}process(t,e,A,s,n){switch(this._character){default:this.dattorro.process(t,e,A,s,n);return;case 6:{let a;if(this._preLowpass>0){let o=this.delayPreLPF,g=this.preLPFz,l=this.preLPFa;for(let C=0;C<n;C++){let B=t[C];g+=l*(B-g),o[C]=g}this.preLPFz=g,a=o}else a=t;this.delayLeft.process(a,this.delayLeftOutput,n);let r=this.delayGain,i=this.delayLeftOutput;for(let o=0,g=s;o<n;o++,g++){let l=i[o]*r;A[g]+=l,e[g]+=l}return}case 7:{let a;if(this._preLowpass>0){let C=this.delayPreLPF,B=this.preLPFz,I=this.preLPFa;for(let E=0;E<n;E++){let m=t[E];B+=I*(m-B),C[E]=B}this.preLPFz=B,a=C}else a=t;let r=this.panDelayFeedback,{delayLeftInput:i,delayLeftOutput:o,delayRightOutput:g}=this;for(let C=0;C<n;C++)i[C]=a[C]+g[C]*r;this.delayLeft.process(i,o,n),this.delayRight.process(o,g,n);let l=this.delayGain;for(let C=0,B=s;C<n;C++,B++)e[B]+=o[C]*l,A[B]+=g[C]*l;return}}}getSnapshot(){return{level:this._level,preLowpass:this._preLowpass,character:this._character,time:this._time,delayFeedback:this._delayFeedback,preDelayTime:this._preDelayTime}}updateFeedback(){let t=1-(1-this._delayFeedback/127)**1.9;this._character===6?this.delayLeft.feedback=t*.73:(this.delayLeft.feedback=this.delayRight.feedback=0,this.panDelayFeedback=t*.73)}updateLowpass(){this.dattorro.preLPF=Math.min(1,.1+(7-this.preLowpass)/14+this.characterLPFCoefficient)}updateGain(){this.dattorro.gain=this._level/345*this.characterGainCoefficient,this.delayGain=this._level/127*ni}updateTime(){let t=this._time/127;this.dattorro.decay=this.characterTimeCoefficient*(.05+.65*t);let e=Math.max(21,t*this.sampleRate*.4468|0);this.character===7?this.delayRight.time=this.delayLeft.time=Math.floor(e/2):this.delayLeft.time=e}},ri=1.3,ii=class{preLPFfc=8e3;preLPFa=0;preLPFz=0;leftDelayBuffer;rightDelayBuffer;sampleRate;phase=0;write=0;gain=.5;reverbGain=0;delayGain=0;depthSamples=0;delaySamples=1;rateInc=0;feedbackGain=0;constructor(t,e){this.sampleRate=t,this.leftDelayBuffer=new Float32Array(t),this.rightDelayBuffer=new Float32Array(t),this.preLowpass=0}_sendLevelToReverb=0;get sendLevelToReverb(){return this._sendLevelToReverb}set sendLevelToReverb(t){this._sendLevelToReverb=t,this.reverbGain=t/127}_sendLevelToDelay=0;get sendLevelToDelay(){return this._sendLevelToDelay}set sendLevelToDelay(t){this._sendLevelToDelay=t,this.delayGain=t/127}_preLowpass=0;get preLowpass(){return this._preLowpass}set preLowpass(t){this._preLowpass=t,this.preLPFfc=8e3*.63**this._preLowpass;let e=Math.exp(-2*Math.PI*this.preLPFfc/this.sampleRate);this.preLPFa=1-e}_depth=0;get depth(){return this._depth}set depth(t){this._depth=t,this.depthSamples=t/127*.025*this.sampleRate}_delay=0;get delay(){return this._delay}set delay(t){this._delay=t,this.delaySamples=Math.max(1,t/127*.025*this.sampleRate)}_feedback=0;get feedback(){return this._feedback}set feedback(t){this._feedback=t,this.feedbackGain=t*.00763}_rate=0;get rate(){return this._rate}set rate(t){this._rate=t;let e=t*.122;this.rateInc=e/this.sampleRate}_level=64;get level(){return this._level}set level(t){this.gain=t/127*ri,this._level=t}process(t,e,A,s,n,a,r){let i=this.leftDelayBuffer,o=this.rightDelayBuffer,g=this.rateInc,l=i.length,C=this.depthSamples,B=this.delaySamples,I=this.gain,E=this.reverbGain,m=this.delayGain,k=this.feedbackGain,y=this._preLowpass>0,b=this.phase,R=this.write,M=this.preLPFz,S=this.preLPFa;for(let Q=0;Q<r;Q++){let p=t[Q];y&&(M+=S*(p-M),p=M);let D=2*Math.abs(b-.5),q=Math.max(1,Math.min(B+D*C,l)),K=R-q;K<0&&(K+=l);let O=K|0,Y=O+1;Y>=l&&(Y-=l);let H=K-O,Z=i[O]*(1-H)+i[Y]*H;i[R]=p+Z*k;let T=Math.max(1,Math.min(B+(1-D)*C,l)),F=R-T;F<0&&(F+=l),O=F|0,Y=O+1,Y>=l&&(Y-=l),H=F-O;let u=o[O]*(1-H)+o[Y]*H,x=Q+a;e[x]+=Z*I,A[x]+=u*I;let P=(Z+u)/2;s[Q]+=P*E,n[Q]+=P*m,o[R]=p+u*k,++R>=l&&(R=0),(b+=g)>=1&&(b-=1)}this.write=R,this.phase=b,this.preLPFz=M}getSnapshot(){return{preLowpass:this._preLowpass,depth:this._depth,delay:this._delay,sendLevelToDelay:this._sendLevelToDelay,sendLevelToReverb:this._sendLevelToReverb,rate:this._rate,feedback:this._feedback,level:this._level}}},oi=[{start:1,end:20,timeStart:.1,resolution:.1},{start:20,end:35,timeStart:2,resolution:.2},{start:35,end:45,timeStart:5,resolution:.5},{start:45,end:55,timeStart:10,resolution:1},{start:55,end:70,timeStart:20,resolution:2},{start:70,end:80,timeStart:50,resolution:5},{start:80,end:90,timeStart:100,resolution:10},{start:90,end:105,timeStart:200,resolution:20},{start:105,end:116,timeStart:500,resolution:50}],gi=1.66,Ii=class{preLPFfc=8e3;preLPFa=0;preLPFz=0;delayLeft;delayRight;delayCenter;sampleRate;delayCenterOutput;delayPreLPF;delayCenterTime;delayLeftMultiplier=.04;delayRightMultiplier=.04;gain=0;reverbGain=0;constructor(t,e){this.sampleRate=t,this.delayCenterOutput=new Float32Array(e),this.delayPreLPF=new Float32Array(e),this.delayCenterTime=.34*t,this.delayCenter=new Xt(t),this.delayLeft=new Xt(t),this.delayRight=new Xt(t)}_sendLevelToReverb=0;get sendLevelToReverb(){return this._sendLevelToReverb}set sendLevelToReverb(t){this._sendLevelToReverb=t,this.reverbGain=t/127}_preLowpass=0;get preLowpass(){return this._preLowpass}set preLowpass(t){this._preLowpass=t,this.preLPFfc=8e3*.63**this._preLowpass;let e=Math.exp(-2*Math.PI*this.preLPFfc/this.sampleRate);this.preLPFa=1-e}_levelRight=0;get levelRight(){return this._levelRight}set levelRight(t){this._levelRight=t,this.updateGain()}_level=64;get level(){return this._level}set level(t){this._level=t,this.gain=t/127*gi}_levelCenter=127;get levelCenter(){return this._levelCenter}set levelCenter(t){this._levelCenter=t,this.updateGain()}_levelLeft=0;get levelLeft(){return this._levelLeft}set levelLeft(t){this._levelLeft=t,this.updateGain()}_feedback=16;get feedback(){return this._feedback}set feedback(t){this._feedback=t,this.delayLeft.feedback=this.delayRight.feedback=0,this.delayCenter.feedback=(t-64)/66}_timeRatioRight=0;get timeRatioRight(){return this._timeRatioRight}set timeRatioRight(t){this._timeRatioRight=t,this.delayRightMultiplier=t*(100/2400),this.delayRight.time=this.delayCenterTime*this.delayRightMultiplier}_timeRatioLeft=0;get timeRatioLeft(){return this._timeRatioLeft}set timeRatioLeft(t){this._timeRatioLeft=t,this.delayLeftMultiplier=t*(100/2400),this.delayLeft.time=this.delayCenterTime*this.delayLeftMultiplier}_timeCenter=12;get timeCenter(){return this._timeCenter}set timeCenter(t){this._timeCenter=t;let e=.1;for(let A of oi)if(t>=A.start&&t<A.end){e=A.timeStart+(t-A.start)*A.resolution;break}this.delayCenterTime=Math.max(2,this.sampleRate*(e/1e3)),this.delayCenter.time=this.delayCenterTime,this.delayLeft.time=this.delayCenterTime*this.delayLeftMultiplier,this.delayRight.time=this.delayCenterTime*this.delayRightMultiplier}process(t,e,A,s,n,a){let r;if(this._preLowpass>0){let C=this.delayPreLPF,B=this.preLPFz,I=this.preLPFa;for(let E=0;E<a;E++){let m=t[E];B+=I*(m-B),C[E]=B}this.preLPFz=B,r=C}else r=t;let{gain:i,reverbGain:o}=this;this.delayCenter.process(r,this.delayCenterOutput,a);let g=this.delayCenterOutput;for(let C=0,B=n;C<a;C++,B++){let I=g[C];s[C]+=I*o;let E=I*i;e[B]+=E,A[B]+=E}for(let C=0;C<a;C++)g[C]+=t[C];let l=this.delayPreLPF;this.delayLeft.process(g,l,a);for(let C=0,B=n;C<a;C++,B++){let I=l[C];e[B]+=I*i,s[C]+=I*o}this.delayRight.process(g,l,a);for(let C=0,B=n;C<a;C++,B++){let I=l[C];A[B]+=I*i,s[C]+=I*o}}getSnapshot(){return{level:this._level,preLowpass:this._preLowpass,timeCenter:this._timeCenter,timeRatioRight:this._timeRatioRight,timeRatioLeft:this._timeRatioLeft,levelCenter:this._levelCenter,levelLeft:this._levelLeft,levelRight:this._levelRight,feedback:this._feedback,sendLevelToReverb:this._sendLevelToReverb}}updateGain(){this.delayCenter.gain=this._levelCenter/127,this.delayLeft.gain=this._levelLeft/127,this.delayRight.gain=this._levelRight/127}},ci={gain:1,pan:0,keyShift:0,fineTune:0,system:"gs"};function hi(t,e){this.midiParameters[t]=e;for(let A of this.midiChannels)A.updateInternalParams();this.callEvent("globalParamChange",{parameter:t,value:e})}function li(t){this.setMIDIParameter("gain",1),this.setMIDIParameter("pan",0),this.setMIDIParameter("keyShift",0),this.setMIDIParameter("fineTune",0),this.setMIDIParameter("system",t)}var Ci=.01,Bi=.05,Ei=class{voices;midiChannels=[];maxBufferSize;voiceBuffer;insertionInputL;insertionInputR;reverbInput;chorusInput;delayInput;delayActive=!1;soundBankManager=new Fr(this.updatePresetList.bind(this));keyModifierManager=new wa;sampleRate;tunings=new Float32Array(16384).fill(-1);midiParameters={...ci};systemParameters={...on};currentTime=0;defaultPreset;drumPreset;gainSmoothingFactor;panSmoothingFactor;eventCallbackHandler;missingPresetHandler;cachedVoices=new Map;setSystemParameter=Fa.bind(this);systemExclusive=Lr.bind(this);reverbProcessor;chorusProcessor;delayProcessor;customChannelNumbers=!1;setMIDIParameter=hi.bind(this);resetMIDIParameters=li.bind(this);insertionFallback=new Rn;insertionProcessor=this.insertionFallback;insertionEffects=new Map;insertionActive=!1;portSelectChannelOffset=0;insertionParams=new Uint8Array(23).fill(255);lastPriorityAssignmentTime=0;eventQueue=[];sampleTime;constructor(t,e,A,s){this.eventCallbackHandler=t,this.missingPresetHandler=e,this.sampleRate=A,this.sampleTime=1/A,this.currentTime=s.initialTime,this.setSystemParameter("effectsEnabled",s.effectsEnabled),this.setSystemParameter("eventsEnabled",s.eventsEnabled),this.maxBufferSize=s.maxBufferSize,this.gainSmoothingFactor=Ci*(44100/A),this.panSmoothingFactor=Bi*(44100/A),fs.initCache(this.sampleRate);let n=this.maxBufferSize;this.reverbProcessor=s.reverbProcessor??new ai(A,n),this.chorusProcessor=s.chorusProcessor??new ii(A,n),this.delayProcessor=s.delayProcessor??new Ii(A,n),this.voiceBuffer=new Float32Array(n),this.insertionInputL=new Float32Array(n),this.insertionInputR=new Float32Array(n),this.reverbInput=new Float32Array(n),this.chorusInput=new Float32Array(n),this.delayInput=new Float32Array(n);for(let a of Ai)this.registerInsertionProcessor(a);this.resetInsertionParams(),this.voices=[],this.allocateNewVoices(this.systemParameters.voiceCap)}_voiceCount=0;get voiceCount(){return this._voiceCount}controllerChange(t,e,A){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.controllerChange(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].controllerChange(e,A)}noteOn(t,e,A){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.noteOn(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].noteOn(e,A)}noteOff(t,e){if(this.customChannelNumbers){for(let A of this.midiChannels)A.midiParameters.rxChannel===t&&A.noteOff(e);return}this.midiChannels[t+this.portSelectChannelOffset].noteOff(e)}polyPressure(t,e,A){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.polyPressure(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].polyPressure(e,A)}channelPressure(t,e){if(this.customChannelNumbers){for(let A of this.midiChannels)A.midiParameters.rxChannel===t&&A.setMIDIParameter("pressure",e);return}this.midiChannels[t+this.portSelectChannelOffset].setMIDIParameter("pressure",e)}pitchWheel(t,e,A=-1){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.pitchWheel(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].pitchWheel(e,A)}programChange(t,e){if(this.customChannelNumbers){for(let A of this.midiChannels)A.midiParameters.rxChannel===t&&A.programChange(e);return}this.midiChannels[t+this.portSelectChannelOffset].programChange(e)}assignVoice(){for(let e=0;e<this.systemParameters.voiceCap;e++){let A=this.voices[e];if(!A.isActive)return A.priority=1/0,A}if(this.systemParameters.autoAllocateVoices){this.allocateNewVoices(1);let e=this.voices[this.voices.length-1];return this.voices.push(e),this.systemParameters.voiceCap++,h.info("%cAllocating a new voice!",d.info),e}this.assignVoicePriorities();let t=this.voices[0];for(let e=0;e<this.systemParameters.voiceCap;e++){let A=this.voices[e];A.priority<t.priority&&(t=A)}return t.priority=1/0,t}stopAllChannels(t){h.info("%cStop all received!",d.info);for(let e of this.midiChannels)e.stopAllNotes(t)}processMessage(t,e=0,A=Kn){let s=A.time;s>this.currentTime?(this.eventQueue.push({message:t,channelOffset:e,time:s}),this.eventQueue.sort((n,a)=>n.time-a.time)):this.processMessageInternal(t,e)}destroySynthProcessor(){this.voices.length=0;for(let t of this.midiChannels)t.destroy();this.clearCache(),this.midiChannels.length=0,this.soundBankManager.destroy()}getVoices(t,e,A){let s=this.midiChannels[t],n=this.keyModifierManager.hasOverridePatch(t,e),a=s.preset;if(n){let r=this.keyModifierManager.getPatch(t,e);a=this.soundBankManager.getPreset(r,this.midiParameters.system)}return a?this.getVoicesForPreset(a,e,A):[]}createMIDIChannel(t){let e=new br(this,this.defaultPreset,this.midiChannels.length);this.midiChannels.push(e),t&&(this.callEvent("channelAdded",void 0),e.setDrums(!0))}reset(t="gs"){if(this.callEvent("reset",t),this.resetMIDIParameters(t),this.tunings.fill(-1),this.portSelectChannelOffset=0,this.customChannelNumbers=!1,this.setReverbMacro(4),this.setChorusMacro(2),this.setDelayMacro(0),this.systemParameters.delayLock||(this.delayActive=!1),this.resetInsertion(),!(!this.drumPreset||!this.defaultPreset))for(let e of this.midiChannels)e.reset(!1)}process(t,e,A=0,s=0){this.processSplit([[t,e]],t,e,A,s)}processSplit(t,e,A,s=0,n=0){if(this.eventQueue.length>0){let o=this.currentTime;for(;this.eventQueue[0]?.time<=o;){let g=this.eventQueue.shift();g&&this.processMessageInternal(g.message,g.channelOffset)}}s=Math.max(s,0);let a=n||t[0][0].length-s;if(a>this.maxBufferSize)throw new Error(`Requested ${a} samples, but maxBufferSize is ${this.maxBufferSize}`);this.reverbInput.fill(0),this.chorusInput.fill(0),this.delayActive&&this.delayInput.fill(0),this.insertionActive&&(this.insertionInputL.fill(0),this.insertionInputR.fill(0));for(let o of this.midiChannels)o.clearVoiceCount();this._voiceCount=0;let r=this.systemParameters.voiceCap,i=t.length;for(let o=0;o<r;o++){let g=this.voices[o],l=this.midiChannels[g.channel];if(!g.isActive)continue;let C=g.channel%i;l.renderVoice(g,this.currentTime,t[C][0],t[C][1],s,a),l.voiceCount++,this._voiceCount++}if(this.systemParameters.effectsEnabled){let{chorusInput:o,delayInput:g,reverbInput:l,insertionInputR:C,insertionInputL:B}=this;this.insertionActive&&this.insertionProcessor.process(B,C,e,A,l,o,g,s,a),this.chorusProcessor.process(o,e,A,l,g,s,a),this.delayActive&&this.midiParameters.system!=="xg"&&this.delayProcessor.process(g,e,A,l,s,a),this.reverbProcessor.process(l,e,A,s,a)}this.currentTime+=a*this.sampleTime}getVoicesForPreset(t,e,A){let s=this.getCachedVoice(t,e,A);if(s!==void 0)return s;let n=new Array;for(let a of t.getVoiceParameters(e,A)){let r=a.sample;if(a.sample.getAudioData()===void 0){h.warn(`Discarding invalid sample: ${r.name}`);continue}n.push(new ar(a,e,A,this.sampleRate))}return this.setCachedVoice(t,e,A,n),n}clearCache(){this.cachedVoices.clear()}callEvent(t,e){this.eventCallbackHandler(t,e)}getInsertionSnapshot(){return{type:this.insertionProcessor.type,params:this.insertionParams.slice(),channels:this.midiChannels.map(t=>t.midiParameters.efxAssign)}}resetInsertionParams(){this.insertionParams.fill(255),this.insertionParams[20]=40,this.insertionParams[21]=0,this.insertionParams[22]=0}resetInsertion(){this.systemParameters.insertionEffectLock||(this.insertionActive=!1,this.insertionProcessor=this.insertionFallback,this.insertionProcessor.reset(),this.insertionProcessor.sendLevelToReverb=40/127*hA,this.insertionProcessor.sendLevelToChorus=0,this.insertionProcessor.sendLevelToDelay=0,this.resetInsertionParams(),this.callEvent("effectChange",{effect:"insertion",parameter:0,value:this.insertionProcessor.type}))}setReverbMacro(t){if(this.systemParameters.reverbLock)return;let e=this.reverbProcessor;switch(e.level=64,e.preDelayTime=0,e.character=t,t){case 0:e.character=0,e.preLowpass=3,e.time=80,e.delayFeedback=0,e.preDelayTime=0;break;case 1:e.preLowpass=4,e.time=56,e.delayFeedback=0;break;case 2:e.preLowpass=0,e.time=72,e.delayFeedback=0;break;case 3:e.preLowpass=4,e.time=72,e.delayFeedback=0;break;case 4:e.preLowpass=0,e.time=64,e.delayFeedback=0;break;case 5:e.preLowpass=0,e.time=88,e.delayFeedback=0;break;case 6:e.preLowpass=0,e.time=32,e.delayFeedback=40;break;case 7:e.preLowpass=0,e.time=64,e.delayFeedback=32;break;default:h.warn(`Invalid reverb macro: ${t}`);return}this.callEvent("effectChange",{effect:"reverb",parameter:"macro",value:t})}setChorusMacro(t){if(this.systemParameters.chorusLock)return;let e=this.chorusProcessor;switch(e.level=64,e.preLowpass=0,e.delay=127,e.sendLevelToDelay=0,e.sendLevelToReverb=0,t){case 0:e.feedback=0,e.delay=112,e.rate=3,e.depth=5;break;case 1:e.feedback=5,e.delay=80,e.rate=9,e.depth=19;break;case 2:e.feedback=8,e.delay=80,e.rate=3,e.depth=19;break;case 3:e.feedback=16,e.delay=64,e.rate=9,e.depth=16;break;case 4:e.feedback=64,e.delay=127,e.rate=2,e.depth=24;break;case 5:e.feedback=112,e.delay=127,e.rate=1,e.depth=5;break;case 6:e.feedback=0,e.depth=127,e.rate=0,e.depth=127;break;case 7:e.feedback=80,e.depth=127,e.rate=0,e.depth=127;break;default:h.warn(`Invalid chorus macro: ${t}`);return}this.callEvent("effectChange",{effect:"chorus",parameter:"macro",value:t})}setDelayMacro(t){if(this.systemParameters.delayLock)return;let e=this.delayProcessor;switch(e.level=64,e.preLowpass=0,e.sendLevelToReverb=0,e.levelRight=e.levelLeft=0,e.levelCenter=127,t){case 0:e.timeCenter=97,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=80;break;case 1:e.timeCenter=106,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=80;break;case 2:e.timeCenter=115,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=72;break;case 3:e.timeCenter=83,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=72;break;case 4:e.timeCenter=105,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=125,e.levelRight=60,e.feedback=74;break;case 5:e.timeCenter=109,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=125,e.levelRight=60,e.feedback=71;break;case 6:e.timeCenter=115,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=120,e.levelRight=64,e.feedback=73;break;case 7:e.timeCenter=93,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=120,e.levelRight=64,e.feedback=72;break;case 8:e.timeCenter=109,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=114,e.levelRight=60,e.feedback=61,e.sendLevelToReverb=36;break;case 9:e.timeCenter=110,e.timeRatioLeft=21,e.timeRatioRight=32,e.levelCenter=97,e.levelLeft=127,e.levelRight=67,e.feedback=40;break;default:h.warn(`Invalid delay macro: ${t}`);return}this.callEvent("effectChange",{effect:"delay",parameter:"macro",value:t})}getCachedVoice(t,e,A){return this.cachedVoices.get(this.getCachedVoiceIndex(t,e,A))}setCachedVoice(t,e,A,s){this.cachedVoices.set(this.getCachedVoiceIndex(t,e,A),s)}allocateNewVoices(t){for(let e=0;e<t;e++)this.voices.push(new Ua(this.sampleRate,this.maxBufferSize))}registerInsertionProcessor(t){let e=new t(this.sampleRate,this.maxBufferSize);this.insertionEffects.set(e.type,e)}processMessageInternal(t,e){let A=t[0],s,n=0;switch(A>=128&&A<240?(s=A&240,n=A&15):s=A,n+=e,s){case G.noteOn:{let a=t[2];a>0?this.noteOn(n,t[1],a):this.noteOff(n,t[1]);break}case G.noteOff:this.noteOff(n,t[1]);break;case G.pitchWheel:this.pitchWheel(n,t[2]<<7|t[1]);break;case G.controllerChange:this.controllerChange(n,t[1],t[2]);break;case G.programChange:this.programChange(n,t[1]);break;case G.polyPressure:this.polyPressure(n,t[1],t[2]);break;case G.channelPressure:this.channelPressure(n,t[1]);break;case G.systemExclusive:this.systemExclusive(new ee(t.slice(1)),e);break;case G.reset:this.stopAllChannels(!1),this.reset();break;default:break}}assignVoicePriorities(){if(this.lastPriorityAssignmentTime===this.currentTime)return;h.info("%cPolyphony exceeded, stealing voices",d.warn),this.lastPriorityAssignmentTime=this.currentTime;let t=this.systemParameters.voiceCap;for(let e=0;e<t;e++){let A=this.voices[e];A.priority=0,this.midiChannels[A.channel].drumChannel&&(A.priority+=5),A.isInRelease&&(A.priority-=5),A.priority+=A.velocity/25,A.priority-=A.volEnv.state,A.isInRelease&&(A.priority-=5),A.priority-=A.volEnv.attenuationCb/200}}updatePresetList(){let t=this.soundBankManager.presetList;this.clearCache(),this.callEvent("presetListChange",t),this.getDefaultPresets();for(let e of this.midiChannels){let A=e.systemParameters.presetLock;e.setSystemParameter("presetLock",!1),e.programChange(e.patch.program),e.setSystemParameter("presetLock",A)}this.reset()}getDefaultPresets(){this.defaultPreset=this.soundBankManager.getPreset({bankLSB:0,bankMSB:0,program:0,isGMGSDrum:!1},"xg"),this.drumPreset=this.soundBankManager.getPreset({bankLSB:0,bankMSB:0,program:0,isGMGSDrum:!0},"gs")}getCachedVoiceIndex(t,e,A){let s=t.bankMSB,n=t.bankLSB,{isGMGSDrum:a,program:r}=t;return a&&(s=128,n=0),s+n*128+r*16384+2097152*e+268435456*A}},Nn=class{processorInitialized=FA.isInitialized;sampleRate;onEventCall;process;processSplit;systemExclusive;controllerChange;noteOn;noteOff;polyPressure;channelPressure;pitchWheel;programChange;processMessage;synthCore;savedSnapshot;constructor(t,e={}){let A=bA(e,Da);if(this.sampleRate=t,!Number.isFinite(A.initialTime)||!Number.isFinite(t))throw new TypeError(`Initial time or sample rate is invalid! initial time: ${A.initialTime}, sample rate: ${t}`);this.synthCore=new Ei(this.callEvent.bind(this),this.missingPreset.bind(this),this.sampleRate,A);let s=this.synthCore;this.process=s.process.bind(s),this.processSplit=s.processSplit.bind(s),this.systemExclusive=s.systemExclusive.bind(s),this.controllerChange=s.controllerChange.bind(s),this.noteOn=s.noteOn.bind(s),this.noteOff=s.noteOff.bind(s),this.polyPressure=s.polyPressure.bind(s),this.channelPressure=s.channelPressure.bind(s),this.pitchWheel=s.pitchWheel.bind(s),this.programChange=s.programChange.bind(s),this.processMessage=s.processMessage.bind(s);for(let n=0;n<16;n++)this.synthCore.createMIDIChannel(!1);this.processorInitialized.then(()=>{h.info("%cSpessaSynth is ready!",d.recognized)})}get midiChannels(){return this.synthCore.midiChannels}get midiParameters(){return this.synthCore.midiParameters}get systemParameters(){return this.synthCore.systemParameters}get voiceCount(){return this.synthCore.voiceCount}get currentTime(){return this.synthCore.currentTime}get reverbProcessor(){return this.synthCore.reverbProcessor}get chorusProcessor(){return this.synthCore.chorusProcessor}get delayProcessor(){return this.synthCore.delayProcessor}get soundBankManager(){return this.synthCore.soundBankManager}get keyModifierManager(){return this.synthCore.keyModifierManager}onMissingPreset=(t,e)=>{h.warn(`No preset found for ${ze.toMIDIString(t)}! Did you forget to add a sound bank?`)};setSystemParameter(t,e){this.synthCore.setSystemParameter(t,e)}reset(){this.synthCore.reset()}applySnapshot(t){this.savedSnapshot=t,ba.call(this.synthCore,t),this.reset()}getSnapshot(){return Ra.call(this.synthCore)}setEmbeddedSoundBank(t,e){let A=$t.fromArrayBuffer(t);this.synthCore.soundBankManager.addSoundBank(A,nA,e);let s=this.synthCore.soundBankManager.priorityOrder;s.pop(),s.unshift(nA),this.synthCore.soundBankManager.priorityOrder=s,this.savedSnapshot!==void 0&&this.applySnapshot(this.savedSnapshot),h.info(`%cEmbedded sound bank set at offset %c${e}`,d.recognized,d.value)}clearEmbeddedSoundBank(){this.synthCore.soundBankManager.soundBankList.some(t=>t.id===nA)&&this.synthCore.soundBankManager.deleteSoundBank(nA)}createMIDIChannel(){this.synthCore.createMIDIChannel(!0)}stopAllChannels(t=!1){this.synthCore.stopAllChannels(t)}destroySynthProcessor(){this.synthCore.destroySynthProcessor()}clearCache(){this.synthCore.clearCache()}getVoicesForPreset(t,e,A){return this.synthCore.getVoicesForPreset(t,e,A)}callEvent(t,e){this.onEventCall?.({type:t,data:e})}missingPreset(t,e){return this.onMissingPreset(t,e)}};var vA=tn.ConsoleColors;var Pn="spessasynth-worklet-processor";function Tn(t,e){return{...e,...t}}var Un={skipToFirstNoteOn:!0,initialPlaybackRate:1};var ps=class extends RA{events=[];constructor(e){super(),super.copyFrom(e),this.events=[]}},GA=class t extends Dt{tracks;timeline=[];embeddedSoundBank=void 0;embeddedSoundBankSize;constructor(e){super(),super.copyMetadataFrom(e),this.tracks=e.tracks.map(A=>new ps(A)),this.embeddedSoundBankSize=e instanceof t?e.embeddedSoundBankSize:e?.embeddedSoundBank?.byteLength}};var LA={shuffleOn:1,shuffleOff:2,index:3};var xn=-1;var Hn=1,NA=class{synthesizer;sequencers=new Array;post;lastSequencerSync=0;voiceCounts=new Array(16).fill(0);alive=!1;eventsEnabled;constructor(e,A,s){this.synthesizer=new Nn(e,A),this.eventsEnabled=A.eventsEnabled??!1,this.post=s,this.synthesizer.onEventCall=n=>{if(n.type==="channelAdded"){let a=this.synthesizer.midiChannels.length;for(let r=this.voiceCounts.length;r<a;r++)this.voiceCounts.push(0)}this.post({type:"eventCall",data:n,currentTime:this.synthesizer.currentTime})}}createNewSequencer(){let e=new an(this.synthesizer),A=this.sequencers.length;this.sequencers.push(e),e.onEventCall=s=>{if(this.eventsEnabled){if(s.type==="songListChange"){let a=s.data.newSongList.map(r=>new GA(r));this.post({type:"sequencerReturn",data:{type:s.type,data:{newSongList:a,shuffledSongIndexes:e.shuffledSongIndexes},id:A},currentTime:this.synthesizer.currentTime});return}this.post({type:"sequencerReturn",data:{...s,id:A},currentTime:this.synthesizer.currentTime})}}}postReady(e,A,s=[]){this.post({type:"isFullyInitialized",data:{type:e,data:A},currentTime:this.synthesizer.currentTime},s)}postProgress(e,A){this.post({type:"renderingProgress",data:{type:e,data:A},currentTime:this.synthesizer.currentTime})}destroy(){this.synthesizer.destroySynthProcessor(),delete this.synthesizer,delete this.sequencers}handleMessage(e){let A=e.channelNumber,s;if(A>=0&&(s=this.synthesizer.midiChannels[A],s===void 0)){h.warn(`Trying to access channel ${A} which does not exist... ignoring!`);return}switch(e.type){case"midiMessage":{this.synthesizer.processMessage(e.data.messageData,e.data.channelOffset,e.data.options);break}case"ccReset":{this.synthesizer.reset();break}case"stopAll":{A===xn?this.synthesizer.stopAllChannels(e.data===1):s?.stopAllNotes(e.data===1);break}case"addNewChannel":{this.synthesizer.createMIDIChannel();break}case"setGlobalSystemParameter":{this.synthesizer.setSystemParameter(e.data.type,e.data.data);break}case"setChannelSystemParameter":{s?.setSystemParameter(e.data.type,e.data.data);break}case"setDrums":{s?.setDrums(e.data);break}case"lockController":{s?.lockController(e.data.controller,e.data.isLocked);break}case"sequencerSpecific":{let n=this.sequencers[e.data.id];if(!n)return;let a=e.data;switch(a.type){default:break;case"loadNewSongList":{try{let i=a.data.map(o=>"duration"in o?Dt.copyFrom(o):Dt.fromArrayBuffer(o.binary,o.fileName));n.loadNewSongList(i)}catch(r){console.error(r),this.post({type:"sequencerReturn",data:{type:"midiError",data:r,id:e.data.id},currentTime:this.synthesizer.currentTime})}break}case"pause":{n.pause();break}case"play":{n.play();break}case"setTime":{n.currentTime=a.data;break}case"changeMIDIMessageSending":{n.externalMIDIPlayback=a.data;break}case"setPlaybackRate":{n.playbackRate=a.data;break}case"setLoopCount":{n.loopCount=a.data;break}case"changeSong":{switch(a.data.changeType){case LA.shuffleOff:{n.shuffleMode=!1;break}case LA.shuffleOn:{n.shuffleMode=!0;break}case LA.index:{a.data.data!==void 0&&(n.songIndex=a.data.data);break}}break}case"getMIDI":{if(!n.midiData)throw new Error("No MIDI is loaded!");this.post({type:"sequencerReturn",data:{type:"getMIDI",data:n.midiData,id:e.data.id},currentTime:this.synthesizer.currentTime});break}case"setSkipToFirstNote":{n.skipToFirstNoteOn=a.data;break}}break}case"soundBankManager":{try{let n=this.synthesizer.soundBankManager,a=e.data,r;switch(a.type){case"addSoundBank":{r=$t.fromArrayBuffer(a.data.soundBankBuffer),n.addSoundBank(r,a.data.id,a.data.bankOffset),this.postReady("soundBankManager",null);break}case"deleteSoundBank":{n.deleteSoundBank(a.data),this.postReady("soundBankManager",null);break}case"rearrangeSoundBanks":n.priorityOrder=a.data,this.postReady("soundBankManager",null)}}catch(n){this.post({type:"soundBankError",data:n,currentTime:this.synthesizer.currentTime})}break}case"keyModifierManager":{let n=e.data,a=this.synthesizer.keyModifierManager;switch(n.type){default:return;case"addMapping":{a.addMapping(n.data.channel,n.data.midiNote,n.data.mapping);break}case"clearMappings":{a.clearMappings();break}case"deleteMapping":a.deleteMapping(n.data.channel,n.data.midiNote)}break}case"requestSynthesizerSnapshot":{let n=this.synthesizer.getSnapshot();this.postReady("synthesizerSnapshot",n);break}case"requestNewSequencer":{this.createNewSequencer();break}case"setLogLevel":{h.setLogLevel(e.data.enableInfo,e.data.enableWarning,e.data.enableGroup);break}case"destroyWorklet":{this.alive=!1,this.synthesizer.destroySynthProcessor(),this.destroy();break}default:{h.warn("Unrecognized event!",e);break}}}};var PA=class extends NA{alive=!0;oneOutputMode;port;constructor(e,A,s,n){super(e,{effectsEnabled:!n.oneOutput,eventsEnabled:n?.eventsEnabled,initialTime:A},(a,r)=>{s.postMessage(a,r)}),this.port=s,this.oneOutputMode=n.oneOutput,this.synthesizer.processorInitialized.then(()=>{this.port.onmessage=a=>this.handleMessage(a.data),this.postReady("sf3Decoder",null)})}process(e,A){if(!this.alive)return!1;for(let i of this.sequencers)i.processTick();if(this.oneOutputMode){let i=A[0],o=[];for(let g=0;g<32;g+=2)o.push([i[g],i[g+1]]);this.synthesizer.setSystemParameter("effectsEnabled",!1),this.synthesizer.processSplit(o,i[0],i[0])}else this.synthesizer.processSplit(A.slice(1),A[0][0],A[0][1]);let s=this.synthesizer.currentTime;if(this.eventsEnabled&&s-this.lastSequencerSync>Hn){for(let i=0;i<this.sequencers.length;i++)this.post({type:"sequencerReturn",data:{type:"sync",data:this.sequencers[i].currentTime,id:i},currentTime:s});this.lastSequencerSync=s}let n=this.synthesizer.midiChannels,a=this.voiceCounts,r=!1;for(let i=0;i<n.length;i++)r||=n[i].voiceCount!==a[i],a[i]=n[i].voiceCount;return r&&this.post({type:"voiceCountChange",currentTime:s,data:a}),!0}handleMessage(e){if(e.type==="startOfflineRender"){this.startOfflineRender(e.data);return}super.handleMessage(e)}startOfflineRender(e){this.sequencers.length===0&&this.createNewSequencer();let A=this.sequencers[0];for(let[n,a]of e.soundBankList.entries())try{this.synthesizer.soundBankManager.addSoundBank($t.fromArrayBuffer(a.soundBankBuffer),`bank-${n}`,a.bankOffset)}catch(r){this.post({type:"soundBankError",data:r,currentTime:this.synthesizer.currentTime})}e.snapshot!==void 0&&this.synthesizer.applySnapshot(e.snapshot),h.info("%cStarting to render the audio data!",vA.info),A.loopCount=e.loopCount,this.synthesizer.setSystemParameter("autoAllocateVoices",!0);let s=Tn(e.sequencerOptions,Un);A.skipToFirstNoteOn=s.skipToFirstNoteOn,A.playbackRate=s.initialPlaybackRate;try{A.loadNewSongList([Dt.copyFrom(e.midiSequence)]),A.play()}catch(n){console.error(n),this.post({type:"sequencerReturn",data:{type:"midiError",data:n,id:0},currentTime:this.synthesizer.currentTime})}this.postReady("startOfflineRender",null)}};var ys=class extends AudioWorkletProcessor{core;constructor(e){super(),this.core=new PA(sampleRate,currentTime,this.port,e.processorOptions)}process(e,A){return this.core.process(e,A)}};registerProcessor(Pn,ys);h.info("%cProcessor successfully registered!",vA.recognized);
|
|
16
|
+
(${e})`,d.warn,d.value,d.unrecognized)}toSFDestination(){let e=this.shortScale;switch(this.destination){default:case N.none:return;case N.pan:return c.pan;case N.gain:return{gen:c.initialAttenuation,newAmount:-e};case N.pitch:return c.fineTune;case N.keyNum:return c.overridingRootKey;case N.volEnvDelay:return c.delayVolEnv;case N.volEnvAttack:return c.attackVolEnv;case N.volEnvHold:return c.holdVolEnv;case N.volEnvDecay:return c.decayVolEnv;case N.volEnvSustain:return{gen:c.sustainVolEnv,newAmount:1e3-e};case N.volEnvRelease:return c.releaseVolEnv;case N.modEnvDelay:return c.delayModEnv;case N.modEnvAttack:return c.attackModEnv;case N.modEnvHold:return c.holdModEnv;case N.modEnvDecay:return c.decayModEnv;case N.modEnvSustain:return{gen:c.sustainModEnv,newAmount:1e3-e};case N.modEnvRelease:return c.releaseModEnv;case N.filterCutoff:return c.initialFilterFc;case N.filterQ:return c.initialFilterQ;case N.chorusSend:return c.chorusEffectsSend;case N.reverbSend:return c.reverbEffectsSend;case N.modLfoFreq:return c.freqModLFO;case N.modLfoDelay:return c.delayModLFO;case N.vibLfoFreq:return c.freqVibLFO;case N.vibLfoDelay:return c.delayVibLFO}}},un=class extends Ht{connectionBlocks=new Array;mode="dls2";get length(){return this.connectionBlocks.length}copyFrom(t){this.mode=t.mode;for(let e of t.connectionBlocks)this.connectionBlocks.push(qt.copyFrom(e))}fromSFZone(t){this.mode="dls2";let e=new zt;e.copyFrom(t);for(let A of e.generators){let s;switch(A.type){default:continue;case c.keyNumToVolEnvDecay:s=c.decayVolEnv;break;case c.keyNumToVolEnvHold:s=c.holdVolEnv;break;case c.keyNumToModEnvDecay:s=c.decayModEnv;break;case c.keyNumToModEnvHold:s=c.holdModEnv}let n=e.getGenerator(s,void 0),a=A.value*-128;if(n===void 0)continue;let r=n-60/128*a;e.setGenerator(A.type,a,!1),e.setGenerator(s,r,!1)}for(let A of e.generators)qt.fromSFGenerator(A,this);for(let A of e.modulators)qt.fromSFModulator(A,this)}read(t){let e=U.findListType(t,"lart"),A=U.findListType(t,"lar2");if(e)for(this.mode="dls1";e.data.currentIndex<e.data.length;){let s=U.read(e.data);if(s.header!=="art1"&&s.header!=="art2")continue;let n=s.data,a=V(n,4);a!==8&&h.warn(`CbSize in articulation mismatch. Expected 8, got ${a}`);let r=V(n,4);for(let o=0;o<r;o++)this.connectionBlocks.push(qt.read(n))}else if(A)for(this.mode="dls2";A.data.currentIndex<A.data.length;){let s=U.read(A.data);if(s.header!=="art1"&&s.header!=="art2")continue;let n=s.data,a=V(n,4);a!==8&&h.warn(`CbSize in articulation mismatch. Expected 8, got ${a}`);let r=V(n,4);for(let o=0;o<r;o++)this.connectionBlocks.push(qt.read(n))}}write(){let t=new ee(8);ge(t,8),ge(t,this.connectionBlocks.length);let e=this.connectionBlocks.map(s=>s.write()),A=U.getParts(this.mode==="dls2"?"art2":"art1",[t,...e]);return U.getParts(this.mode==="dls2"?"lar2":"lart",A,!0)}toSFZone(t){let e=(A,s,n,a)=>{let r=A/-128;if(t.setGenerator(s,r),r<=120){let o=Math.round(.46875*A),i=this.connectionBlocks.find(g=>g.isStaticParameter&&g.destination===a);i&&t.setGenerator(n,o+i.shortScale)}};for(let A of this.connectionBlocks){let s=A.shortScale,n=A.source.source,a=A.control.source,r=A.destination;if(A.isStaticParameter){A.toSFGenerator(t);continue}if(a===X.none)if(n===X.keyNum){if(r===N.pitch){t.setGenerator(c.scaleTuning,s/128);continue}if(r===N.modEnvHold||r===N.modEnvDecay||r===N.volEnvHold||r===N.volEnvDecay)continue}else{let o=A.toCombinedSFDestination();if(o){t.setGenerator(o,s);continue}}A.toSFModulator(t)}for(let A of this.connectionBlocks){if(A.source.source!==X.keyNum)continue;let s=A.shortScale;switch(A.destination){default:case N.volEnvHold:e(s,c.keyNumToVolEnvHold,c.holdVolEnv,N.volEnvHold);break;case N.volEnvDecay:e(s,c.keyNumToVolEnvDecay,c.decayVolEnv,N.volEnvDecay);break;case N.modEnvHold:e(s,c.keyNumToModEnvHold,c.holdModEnv,N.modEnvHold);break;case N.modEnvDecay:e(s,c.keyNumToModEnvDecay,c.decayModEnv,N.modEnvDecay);break}}if(this.mode==="dls1"){t.setGenerator(c.delayVibLFO,t.getGenerator(c.delayModLFO,null)),t.setGenerator(c.freqVibLFO,t.getGenerator(c.freqModLFO,null)),t.setGenerator(c.vibLfoToPitch,t.getGenerator(c.modLfoToPitch,null)),t.setGenerator(c.modLfoToPitch,null);for(let A of t.modulators)A.destination===c.modLfoToPitch&&(A.destination=c.vibLfoToPitch)}}},JA=class lA{channel=1;tableIndex;fusOptions=0;phaseGroup=0;constructor(e){this.tableIndex=e}static copyFrom(e){let A=new lA(e.tableIndex);return A.channel=e.channel,A.phaseGroup=e.phaseGroup,A.fusOptions=e.fusOptions,A}static read(e){let A=V(e.data,2),s=V(e.data,2),n=V(e.data,4),a=new lA(V(e.data,4));return a.channel=n,a.fusOptions=A,a.phaseGroup=s,a}static fromSFZone(e,A){let s=e.indexOf(A.sample);if(s===-1)throw new Error(`Wave link error: Sample ${A.sample.name} does not exist in the sample list.`);let n=new lA(s);switch(A.sample.sampleType){default:case Fe.leftSample:case Fe.monoSample:n.channel=Math.trunc(1);break;case Fe.rightSample:n.channel=2}return n}write(){let e=new ee(12);return Ae(e,this.fusOptions),Ae(e,this.phaseGroup),ge(e,this.channel),ge(e,this.tableIndex),U.write("wlnk",e)}},CA=class Lt extends Ht{articulation=new un;keyRange={min:0,max:127};velRange={min:0,max:127};keyGroup=0;fusOptions=0;usLayer=0;waveSample;waveLink;constructor(e,A){super(),this.waveSample=A,this.waveLink=e}static copyFrom(e){let A=new Lt(JA.copyFrom(e.waveLink),Ut.copyFrom(e.waveSample));return A.keyGroup=e.keyGroup,A.keyRange={...e.keyRange},A.velRange={...e.velRange},A.usLayer=e.usLayer,A.fusOptions=e.fusOptions,A.articulation.copyFrom(e.articulation),A}static read(e,A){let s=this.verifyAndReadList(A,"rgn ","rgn2"),n=s.find(y=>y.header==="wsmp"),a=n?Ut.read(n):void 0,r=s.find(y=>y.header==="wlnk");if(!r){h.warn("Invalid DLS region: missing 'wlnk' chunk! Discarding...");return}let o=JA.read(r),i=s.find(y=>y.header==="rgnh");if(!i){h.warn("Invalid DLS region: missing 'rgnh' chunk! Discarding...");return}let g=e[o.tableIndex];g||Lt.parsingError(`Invalid sample index: ${o.tableIndex}. Samples available: ${e.length}`),a??=g.waveSample;let l=new Lt(o,a),B=V(i.data,2),C=V(i.data,2),I=V(i.data,2),E=V(i.data,2);return I===0&&E===0&&(E=127,I=0),l.keyRange.max=C,l.keyRange.min=B,l.velRange.max=E,l.velRange.min=I,l.fusOptions=V(i.data,2),l.keyGroup=V(i.data,2),i.data.length-i.data.currentIndex>=2&&(l.usLayer=V(i.data,2)),l.articulation.read(s),l}static fromSFZone(e,A){let s=Ut.fromSFZone(e),n=new Lt(JA.fromSFZone(A,e),s);return n.keyRange.min=Math.max(e.keyRange.min,0),n.keyRange.max=e.keyRange.max,n.velRange.min=Math.max(e.velRange.min,0),n.velRange.max=e.velRange.max,n.keyGroup=e.getGenerator(c.exclusiveClass,0),n.articulation.fromSFZone(e),n}write(){let e=[this.writeHeader(),this.waveSample.write(),this.waveLink.write(),...this.articulation.write()];return U.getParts("rgn2",e,!0)}toSFZone(e,A){let s=A[this.waveLink.tableIndex];s||Lt.parsingError(`Invalid sample index: ${this.waveLink.tableIndex}`);let n=e.createZone(s);return n.keyRange=this.keyRange,n.velRange=this.velRange,this.keyRange.max===127&&this.keyRange.min===0&&(n.keyRange.min=-1),this.velRange.max===127&&this.velRange.min===0&&(n.velRange.min=-1),this.keyGroup!==0&&n.setGenerator(c.exclusiveClass,this.keyGroup),this.waveSample.toSFZone(n,s),this.articulation.toSFZone(n),n.generators=n.generators.filter(a=>a.value!==Ve[a.type].def),n}writeHeader(){let e=new ee(14);return Ae(e,Math.max(this.keyRange.min,0)),Ae(e,this.keyRange.max),Ae(e,Math.max(this.velRange.min,0)),Ae(e,this.velRange.max),Ae(e,this.fusOptions),Ae(e,this.keyGroup),Ae(e,this.usLayer),U.write("rgnh",e)}},KA=class BA extends Ht{articulation=new un;regions=new Array;name="Unnamed";bankLSB=0;bankMSB=0;isGMGSDrum=!1;program=0;static copyFrom(e){let A=new BA;A.name=e.name,A.isGMGSDrum=e.isGMGSDrum,A.bankMSB=e.bankMSB,A.bankLSB=e.bankLSB,A.program=e.program,A.articulation.copyFrom(e.articulation);for(let s of e.regions)A.regions.push(CA.copyFrom(s));return A}static read(e,A){let s=this.verifyAndReadList(A,"ins "),n=s.find(B=>B.header==="insh");if(!n)throw h.groupEnd(),new Error("No instrument header!");let a="",r=U.findListType(s,"INFO");if(r){let B=U.read(r.data);for(;B.header!=="INAM";)B=U.read(r.data);a=Ee(B.data,B.data.length).trim()}a.length===0&&(a="Unnamed Instrument");let o=new BA;o.name=a;let i=V(n.data,4),g=V(n.data,4);o.program=V(n.data,4)&127,o.bankMSB=g>>>8&127,o.bankLSB=g&127,o.isGMGSDrum=g>>>31>0,h.groupCollapsed(`%cParsing %c"${a}"%c...`,d.info,d.recognized,d.info);let l=U.findListType(s,"lrgn");if(!l)throw h.groupEnd(),new Error("No region list!");o.articulation.read(s);for(let B=0;B<i;B++){let C=U.read(l.data);this.verifyHeader(C,"LIST");let I=Ee(C.data,4);I!=="rgn "&&I!=="rgn2"&&(h.groupEnd(),this.parsingError(`Invalid DLS region! Expected "rgn " or "rgn2" got "${I}"`));let E=CA.read(e,C);E&&o.regions.push(E)}return h.groupEnd(),o}static fromSFPreset(e,A){let s=new BA;s.name=e.name,s.bankLSB=e.bankLSB,s.bankMSB=e.bankMSB,s.program=e.program,s.isGMGSDrum=e.isGMGSDrum,h.group(`%cConverting %c${e.toString()}%c to DLS...`,d.info,d.value,d.info);let n=e.toFlattenedInstrument();for(let a of n.zones)s.regions.push(CA.fromSFZone(a,A));return h.groupEnd(),s}write(){h.groupCollapsed(`%cWriting %c${this.name}%c...`,d.info,d.recognized,d.info);let e=[this.writeHeader()],A=this.regions.flatMap(n=>n.write());e.push(...U.getParts("lrgn",A,!0)),this.articulation.length>0&&e.push(...this.articulation.write());let s=U.write("INAM",$e(this.name,!0));return e.push(U.write("INFO",s,!1,!0)),h.groupEnd(),U.writeParts("ins ",e,!0)}toSFPreset(e){let A=new _t(e);A.name=this.name,A.bankMSB=this.bankMSB,A.bankLSB=this.bankLSB,A.isGMGSDrum=this.isGMGSDrum,A.program=this.program;let s=new Wt;s.name=this.name,A.createZone(s),this.articulation.toSFZone(s.globalZone);for(let n of this.regions)n.toSFZone(s,e.samples);s.globalize(),s.globalZone.modulators.some(n=>n.destination===c.reverbEffectsSend)||s.globalZone.addModulators(ke.copyFrom(fn)),s.globalZone.modulators.some(n=>n.destination===c.chorusEffectsSend)||s.globalZone.addModulators(ke.copyFrom(Qn)),s.globalZone.generators=s.globalZone.generators.filter(n=>n.value!==Ve[n.type].def),e.addPresets(A),e.addInstruments(s)}writeHeader(){let e=new ee(12);ge(e,this.regions.length);let A=(this.bankMSB&127)<<8|this.bankLSB&127;return this.isGMGSDrum&&(A|=1<<31),ge(e,A),ge(e,this.program&127),U.write("insh",e)}},gs={software:"SpessaSynth"},mn=class Is extends Ht{samples=new Array;instruments=new Array;soundBankInfo={name:"Unnamed DLS sound bank",creationDate:new Date,software:"SpessaSynth",soundEngine:"DLS Level 2.2",product:"SpessaSynth DLS",version:{major:2,minor:4}};static read(e){if(!e)throw new Error("No data provided!");let A=new ee(e);h.group("%cParsing DLS file...",d.info);let s=U.read(A,!1);this.verifyHeader(s,"RIFF"),this.verifyText(Ee(A,4).toLowerCase(),"dls ");let n=[];for(;A.currentIndex<A.length;)n.push(U.read(A));let a=new Is,r=U.findListType(n,"INFO");if(r)for(;r.data.currentIndex<r.data.length;){let E=U.read(r.data),y=E.header,k=Ee(E.data,E.size);switch(y){case"INAM":a.soundBankInfo.name=k;break;case"ICRD":a.soundBankInfo.creationDate=Es(k);break;case"ICMT":a.soundBankInfo.comment=k;break;case"ISBJ":a.soundBankInfo.subject=k;break;case"ICOP":a.soundBankInfo.copyright=k;break;case"IENG":a.soundBankInfo.engineer=k;break;case"IPRD":a.soundBankInfo.product=k;break;case"ISFT":a.soundBankInfo.software=k}}this.printInfo(a);let o=n.find(E=>E.header==="colh");if(!o)return this.parsingError("No colh chunk!"),5;let i=V(o.data,4);h.info(`%cInstruments amount: %c${i}`,d.info,d.recognized);let g=U.findListType(n,"wvpl");if(!g)return this.parsingError("No wvpl chunk!"),5;let l=this.verifyAndReadList(g,"wvpl");for(let E of l)a.samples.push(Ls.read(E));let B=U.findListType(n,"lins");if(!B)return this.parsingError("No lins chunk!"),5;let C=this.verifyAndReadList(B,"lins");h.groupCollapsed("%cLoading instruments...",d.info),C.length!==i&&h.warn(`Colh reported invalid amount of instruments. Detected ${C.length}, expected ${i}`);for(let E of C)a.instruments.push(KA.read(a.samples,E));h.groupEnd();let I=n.find(E=>E.header==="pgal");if(I){h.info("%cFound the instrument aliasing chunk!",d.recognized);let E=I.data;(E[0]!==0||E[1]!==1||E[2]!==2||E[3]!==3)&&(E.currentIndex+=4);let y=a.instruments.find(p=>Se.isXGDrum(p.bankMSB)||p.isGMGSDrum);if(!y)return h.warn("MobileBAE aliasing chunk without a drum preset. Aborting!"),a;let k=E.slice(E.currentIndex,E.currentIndex+128);E.currentIndex+=128;for(let p=0;p<128;p++){let R=k[p];if(R===p)continue;let b=y.regions.find(S=>S.keyRange.max===R&&S.keyRange.min===R);if(!b){h.warn(`Invalid drum alias ${p} to ${R}: region does not exist.`);continue}let M=CA.copyFrom(b);M.keyRange.max=p,M.keyRange.min=p,y.regions.push(M)}for(E.currentIndex+=4;E.currentIndex<E.length;){let p=V(E,2),R=p&127,b=p>>7&127,M=E[E.currentIndex++],S=E[E.currentIndex++];S!==0&&h.warn(`Invalid alias byte. Expected 0, got ${S}`);let Q=V(E,2),m=Q&127,D=Q>>7&127,q=E[E.currentIndex++];S=E[E.currentIndex++],S!==0&&h.warn(`Invalid alias header. Expected 0, got ${S}`);let K=a.instruments.find(Y=>Y.bankLSB===m&&Y.bankMSB===D&&Y.program===q&&!Y.isGMGSDrum);if(!K){h.warn(`Invalid alias. Missing instrument: ${m}:${D}:${q}`);continue}let O=KA.copyFrom(K);O.bankMSB=b,O.bankLSB=R,O.program=M,a.instruments.push(O)}}return h.info(`%cParsing finished! %c"${a.soundBankInfo.name||"UNNAMED"}"%c has %c${a.instruments.length}%c instruments and %c${a.samples.length}%c samples.`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized,d.info),h.groupEnd(),a}static fromSF(e,A){h.groupCollapsed("%cSaving SF2 to DLS level 2...",d.info);let s=new Is;s.soundBankInfo={...e.soundBankInfo};for(let n=0;n<e.samples.length;n++){let a=e.samples[n];s.samples.push(Ls.fromSFSample(a)),A?.(n/e.samples.length)}for(let n of e.presets)s.instruments.push(KA.fromSFPreset(n,e.samples));return h.info("%cConversion complete!",d.recognized),h.groupEnd(),s}static printInfo(e){for(let[A,s]of Object.entries(e.soundBankInfo))if(typeof s=="object"&&"major"in s){let n=s;h.info(`%c${A}: %c"${n.major}.${n.minor}"`,d.info,d.recognized)}else h.info(`%c${A}: %c${s.toLocaleString()}`,d.info,d.recognized)}write(e=gs){let A=bA(e,gs);h.groupCollapsed("%cSaving DLS...",d.info);let s=new ee(4);ge(s,this.instruments.length);let n=U.write("colh",s);h.groupCollapsed("%cWriting instruments...",d.info);let a=U.getParts("lins",this.instruments.map(p=>p.write()),!0);h.info("%cSuccess!",d.recognized),h.groupEnd(),h.groupCollapsed("%cWriting WAVE samples...",d.info);let r=0,o=[],i=[],g=0;for(let p of this.samples){let R=p.write();A.progressFunction?.(g/this.samples.length),h.info(`%cWrote sample %c${g}. ${p.name}%c of %c${this.samples.length}.`,d.info,d.recognized,d.info,d.recognized),o.push(r),r+=R.reduce((b,M)=>b+M.length,0),i.push(...R),g++}let l=U.getParts("wvpl",i,!0);h.info("%cSucceeded!",d.recognized);let B=new ee(8+4*o.length);ge(B,8),ge(B,o.length);for(let p of o)ge(B,p);let C=U.write("ptbl",B);this.soundBankInfo.software=A.software;let I=[],E=this.soundBankInfo,y=(p,R)=>{R&&I.push(...U.getParts(p,[$e(R,!0)]))};y("INAM",E.name),y("ICMT",E.comment),y("ICOP",E.copyright),y("ICRD",Bs(E.creationDate)),y("IENG",E.engineer),y("IPRD",E.product),y("ISFT",A.software),y("ISBJ",E.subject),h.info("%cCombining everything...");let k=U.writeParts("RIFF",[$e("DLS "),n,...a,C,...l,...U.getParts("INFO",I,!0)]);return h.info("%cSaved successfully!",d.recognized),h.groupEnd(),k.buffer}toSF(){h.group("%cConverting DLS to SF2...",d.info);let e=new pn;e.soundBankInfo.version.minor=4,e.soundBankInfo.version.major=2,e.soundBankInfo={...this.soundBankInfo};for(let A of this.samples)A.toSFSample(e);for(let A of this.instruments)A.toSFPreset(e);return e.flush(),h.info("%cConversion complete!",d.recognized),h.groupEnd(),e}},pn=class EA{static isSF3DecoderReady=FA.isInitialized;soundBankInfo={name:"Unnamed",creationDate:new Date,software:"SpessaSynth",soundEngine:"E-mu 10K2",version:{major:2,minor:4}};presets=[];samples=[];instruments=[];defaultModulators=Cn.map(ke.copyFrom.bind(ke));customDefaultModulators=!1;_isXGBank=!1;get isXGBank(){return this._isXGBank}static mergeSoundBanks(...e){let A=e.shift();if(!A)throw new Error("No sound banks provided!");let s=A.presets;for(;e.length>0;){let a=e?.shift()?.presets;if(a)for(let r of a)s.some(o=>r.matches(o))||s.push(r)}let n=new EA;return n.addCompletePresets(s),n.soundBankInfo={...A.soundBankInfo},n}static getSampleSoundBankFile(){let e=new EA,A=new Float32Array(128);for(let r=0;r<128;r++)A[r]=r/128*2-1;let s=new Ya;s.name="Saw",s.originalKey=65,s.pitchCorrection=20,s.loopEnd=127,s.setAudioData(A,44100),e.addSamples(s);let n=new Wt;n.name="Saw Wave",n.globalZone.addGenerators(new Ge(c.initialAttenuation,375),new Ge(c.releaseVolEnv,-1e3),new Ge(c.sampleModes,1)),n.createZone(s),n.createZone(s).setGenerator(c.fineTune,-9),e.addInstruments(n);let a=new _t(e);return a.name="Saw Wave",a.createZone(n),e.addPresets(a),e.soundBankInfo.name="Dummy",e.flush(),e.writeSF2()}static copyFrom(e){let A=new EA;for(let s of e.presets)A.clonePreset(s);return A.soundBankInfo={...e.soundBankInfo},A}addCompletePresets(e){this.addPresets(...e);let A=[];for(let n of e)for(let a of n.zones)a.instrument&&!A.includes(a.instrument)&&A.push(a.instrument);this.addInstruments(...A);let s=[];for(let n of A)for(let a of n.zones)a.sample&&!s.includes(a.sample)&&s.push(a.sample);this.addSamples(...s)}async setSampleFormat(e){let A=0,s=e.format,n=e.progressFunction;for(let a of this.samples){switch(s){default:case"pcm":a.setAudioData(a.getAudioData(),a.sampleRate);break;case"compressed":{let r=e.compressionFunction;if(!r)throw new Error(`No compression function supplied but '${s}' was requested.`);await a.compressSample(r)}}A++,n?.(A/this.samples.length),h.info(`%cEncoded sample %c${A}. ${a.name}%c of %c${this.samples.length}%c. Compressed: %c${a.isCompressed}%c.`,d.info,d.recognized,d.info,d.recognized,d.info,a.isCompressed?d.recognized:d.unrecognized,d.info)}switch(s){default:case"pcm":this.soundBankInfo.version.major=2,this.soundBankInfo.version.minor=4;break;case"compressed":this.soundBankInfo.version.major=3,this.soundBankInfo.version.minor=0}}writeDLS(e=gs){let A=e.progressFunction;return mn.fromSF(this,A?s=>A(s/2):void 0).write({...e,progressFunction:A?s=>A(.5+s/2):void 0})}writeSF2(e=dn){return Za(this,e)}addPresets(...e){this.presets.push(...e)}addInstruments(...e){this.instruments.push(...e)}addSamples(...e){this.samples.push(...e)}cloneSample(e){let A=this.samples.find(n=>n.name===e.name);if(A)return A;let s=new MA(e.name,e.sampleRate,e.originalKey,e.pitchCorrection,e.sampleType,e.loopStart,e.loopEnd);if(e.isCompressed?s.setCompressedData(e.getRawData(!0)):s.setAudioData(e.getAudioData(),e.sampleRate),this.addSamples(s),e.linkedSample){let n=this.cloneSample(e.linkedSample);n.linkedSample||s.setLinkedSample(n,s.sampleType)}return s}cloneInstrument(e){let A=this.instruments.find(n=>n.name===e.name);if(A)return A;let s=new Wt;s.name=e.name,s.globalZone.copyFrom(e.globalZone);for(let n of e.zones)s.createZone(this.cloneSample(n.sample)).copyFrom(n);return this.addInstruments(s),s}clonePreset(e){let A=this.presets.find(n=>n.name===e.name);if(A)return A;let s=new _t(this);s.name=e.name,s.bankMSB=e.bankMSB,s.bankLSB=e.bankLSB,s.isGMGSDrum=e.isGMGSDrum,s.program=e.program,s.library=e.library,s.genre=e.genre,s.morphology=e.morphology,s.globalZone.copyFrom(e.globalZone);for(let n of e.zones)s.createZone(this.cloneInstrument(n.instrument)).copyFrom(n);return this.addPresets(s),s}flush(){this.presets.sort(ze.compare.bind(ze)),this.parseInternal()}trim(e){let A=(s,n)=>{let a=0;for(let r=0;r<s.zones.length;r++){let o=s.zones[r],i=o.keyRange,g=o.velRange,l=!1;for(let[B,C]of n)if(B>=i.min&&B<=i.max&&[...C].some(I=>I>=g.min&&I<=g.max)){l=!0;break}l||(h.info(`%c${o.sample.name}%c removed from %c${s.name}%c.`,d.recognized,d.info,d.recognized,d.info),s.deleteZone(r)&&(a++,r--,h.info(`%c${o.sample.name}%c deleted`,d.recognized,d.info)),o.sample.useCount<1&&this.deleteSample(o.sample))}return a};h.groupCollapsed("%cTrimming sound bank...",d.info),h.info("Combinations to trim for:",e);for(let s=0;s<this.presets.length;s++){let n=this.presets[s],a=e.get(n);if(a===void 0)h.info(`%cDeleting preset %c${n.name}%c and its zones`,d.info,d.recognized,d.info),this.deletePreset(n),s--;else{h.groupCollapsed(`%cTrimming %c${n.name}`,d.info,d.recognized),h.info(`Keys for ${n.name}:`,a);let r=0;for(let o=0;o<n.zones.length;o++){let i=n.zones[o],g=i.keyRange,l=i.velRange,B=!1;for(let[C,I]of a)if(C>=g.min&&C<=g.max&&[...I].some(E=>E>=l.min&&E<=l.max)){B=!0;let E=A(i.instrument,a);h.info(`%cTrimmed off %c${E}%c instrument zones from %c${i.instrument.name}`,d.info,d.recognized,d.info,d.recognized);break}B||(r++,n.deleteZone(o),i.instrument.useCount<1&&this.deleteInstrument(i.instrument),o--)}h.info(`%cTrimmed off %c${r}%c preset zones from %c${n.name}`,d.info,d.recognized,d.info,d.recognized),h.groupEnd()}}this.removeUnusedElements(),h.info("%cSound bank modified!",d.recognized),h.groupEnd()}removeUnusedElements(){this.instruments=this.instruments.filter(e=>{e.deleteUnusedZones();let A=e.useCount<1;return A&&e.delete(),!A}),this.samples=this.samples.filter(e=>{let A=e.useCount<1;return A&&e.unlinkSample(),!A})}deleteInstrument(e){e.delete(),this.instruments.splice(this.instruments.indexOf(e),1)}deletePreset(e){e.delete(),this.presets.splice(this.presets.indexOf(e),1)}deleteSample(e){e.unlinkSample(),this.samples.splice(this.samples.indexOf(e),1)}getPreset(e,A){return ze.selectPatch(this.presets,e,A)}destroySoundBank(){this.presets.length=0,this.instruments.length=0,this.samples.length=0}parsingError(e){throw new Error(`SF parsing error: ${e} The file may be corrupted.`)}parseInternal(){this._isXGBank=!1;let e=new Set([0,1,2,3,4,5,6,7,8,9,16,17,24,25,26,27,28,29,30,31,32,33,40,41,48,56,57,58,64,65,66,126,127]);for(let A of this.presets)if(Se.isXGDrum(A.bankMSB)&&(this._isXGBank=!0,!e.has(A.program))){this._isXGBank=!1,h.info(`%cThis bank is not valid XG. Preset %c${A.toString()}%c is not a valid XG drum. XG mode will use presets on bank 128.`,d.info,d.value,d.info);break}}printInfo(){for(let[e,A]of Object.entries(this.soundBankInfo))if(typeof A=="object"&&"major"in A){let s=A;h.info(`%c${e}: %c"${s.major}.${s.minor}"`,d.info,d.recognized)}else h.info(`%c${e}: %c${A.toLocaleString()}`,d.info,d.recognized)}},ja=class extends Ge{constructor(t){let e=t.currentIndex,A=t[e+1]<<8|t[e],s=ls(t[e+2],t[e+3]);t.currentIndex+=4,super(A,s,!1)}};function Ns(t){let e=[];for(;t.data.length>t.data.currentIndex;)e.push(new ja(t.data));return e.pop(),e}function er(t,e,A,s,n){let a=t.gen,r=t.mod,o=0,i=0;for(let g of n)for(let l=0;l<g.zonesCount;l++){let B=a[i++],C=a[i],I=e.slice(B,C),E=r[o++],y=r[o],k=A.slice(E,y);I.some(p=>p.type===c.instrument)?g.createSoundFontZone(k,I,s):(g.globalZone.addGenerators(...I),g.globalZone.addModulators(...k))}}var tr=class extends _t{zoneStartIndex;zonesCount=0;constructor(t,e){super(e),this.name=Ee(t.data,20),this.program=V(t.data,2);let A=V(t.data,2);this.bankMSB=A&127,this.isGMGSDrum=(A&128)>0,this.bankLSB=A>>8,this.zoneStartIndex=V(t.data,2),this.library=V(t.data,4),this.genre=V(t.data,4),this.morphology=V(t.data,4)}createSoundFontZone(t,e,A){let s=e.find(r=>r.type===c.instrument),n;if(s)n=A[s.value];else throw new Error("No instrument ID found in preset zone.");if(!n)throw new Error(`Invalid instrument ID: ${s.value}, available instruments: ${A.length}`);let a=new En(this,n);return a.addGenerators(...e),a.addModulators(...t),this.zones.push(a),a}};function Ps(t,e){let A=[];for(;t.data.length>t.data.currentIndex;){let s=new tr(t,e);if(A.length>0){let n=A[A.length-1];n.zonesCount=s.zoneStartIndex-n.zoneStartIndex}A.push(s)}return A.pop(),A}var Ar=class extends Wt{zoneStartIndex;zonesCount=0;constructor(t){super(),this.name=Ee(t.data,20),this.zoneStartIndex=V(t.data,2)}createSoundFontZone(t,e,A){let s=e.find(r=>r.type===c.sampleID),n;if(s)n=A[s.value];else throw new Error("No sample ID found in instrument zone.");if(!n)throw new Error(`Invalid sample ID: ${s.value}, available samples: ${A.length}`);let a=new Bn(this,n);return a.addGenerators(...e),a.addModulators(...t),this.zones.push(a),a}};function Ts(t){let e=[];for(;t.data.length>t.data.currentIndex;){let A=new Ar(t);if(e.length>0){let s=e[e.length-1];s.zonesCount=A.zoneStartIndex-s.zoneStartIndex}e.push(A)}return e.pop(),e}function VA(t){let e=[];for(;t.data.length>t.data.currentIndex;){let A=t.data,s=V(A,2),n=V(A,2),a=ls(A[A.currentIndex++],A[A.currentIndex++]),r=V(A,2),o=V(A,2);e.push(new ue(s,r,n,a,o))}return e.pop(),e}function sr(t,e,A,s,n){let a=t.gen,r=t.mod,o=0,i=0;for(let g of n)for(let l=0;l<g.zonesCount;l++){let B=a[i++],C=a[i],I=e.slice(B,C),E=r[o++],y=r[o],k=A.slice(E,y);I.some(p=>p.type===c.sampleID)?g.createSoundFontZone(k,I,s):(g.globalZone.addGenerators(...I),g.globalZone.addModulators(...k))}}function IA(t){let e=[],A=[];for(;t.data.length>t.data.currentIndex;)A.push(V(t.data,2)),e.push(V(t.data,2));return{mod:e,gen:A}}var nr=class extends pn{sampleDataStartIndex=0;constructor(t,e=!0){if(super(),e)throw new Error("Using the constructor directly is deprecated. Use SoundBankLoader.fromArrayBuffer() instead.");let A=new ee(t);h.group("%cParsing a SoundFont2 file...",d.info),A||(h.groupEnd(),this.parsingError("No data provided!"));let s=U.read(A,!1);this.verifyHeader(s,"riff");let n=Ee(A,4).toLowerCase();if(n!=="sfbk"&&n!=="sfpk")throw h.groupEnd(),new SyntaxError(`Invalid soundFont! Expected "sfbk" or "sfpk" got "${n}"`);let a=n==="sfpk",r=U.read(A);this.verifyHeader(r,"list");let o=Ee(r.data,4);if(o!=="INFO")throw h.groupEnd(),new SyntaxError(`Invalid soundFont! Expected "INFO" got "${o}"`);let i;for(;r.data.length>r.data.currentIndex;){let F=U.read(r.data),u=_e(F.data,F.data.length),x=F.header;switch(x){case"ifil":case"iver":{let P=V(F.data,2),te=V(F.data,2);x==="ifil"?this.soundBankInfo.version={major:P,minor:te}:this.soundBankInfo.romVersion={major:P,minor:te};break}case"DMOD":this.defaultModulators=VA(F),this.customDefaultModulators=!0;break;case"LIST":Ee(F.data,4)==="xdta"&&(h.info("%cExtended SF2 found!",d.recognized),i=F);break;case"ICRD":this.soundBankInfo.creationDate=Es(Ee(F.data,F.data.length));break;case"ISFT":this.soundBankInfo.software=u;break;case"IPRD":this.soundBankInfo.product=u;break;case"IENG":this.soundBankInfo.engineer=u;break;case"ICOP":this.soundBankInfo.copyright=u;break;case"INAM":this.soundBankInfo.name=u;break;case"ICMT":this.soundBankInfo.comment=u;break;case"irom":this.soundBankInfo.romInfo=u;break;case"isng":this.soundBankInfo.soundEngine=u}}this.printInfo();let g={};i!==void 0&&(g.phdr=U.read(i.data),g.pbag=U.read(i.data),g.pmod=U.read(i.data),g.pgen=U.read(i.data),g.inst=U.read(i.data),g.ibag=U.read(i.data),g.imod=U.read(i.data),g.igen=U.read(i.data),g.shdr=U.read(i.data));let l=U.read(A,!1);this.verifyHeader(l,"list"),this.verifyText(Ee(A,4),"sdta"),h.info("%cVerifying smpl chunk...",d.warn);let B=U.read(A,!1);this.verifyHeader(B,"smpl");let C;if(a){h.info("%cSF2Pack detected, attempting to decode the smpl chunk...",d.info);try{C=FA.decode(A.buffer.slice(A.currentIndex,A.currentIndex+l.size-12)).data[0]}catch(F){throw h.groupEnd(),new Error(`SF2Pack Ogg Vorbis decode error: ${F}`,{cause:F})}h.info(`%cDecoded the smpl chunk! Length: %c${C.length}`,d.info,d.value)}else C=A,this.sampleDataStartIndex=A.currentIndex;h.info(`%cSkipping sample chunk, length: %c${l.size-12}`,d.info,d.value),A.currentIndex+=l.size-12,h.info("%cLoading preset data chunk...",d.warn);let I=U.read(A);this.verifyHeader(I,"list"),Ee(I.data,4);let E=U.read(I.data);this.verifyHeader(E,"phdr");let y=U.read(I.data);this.verifyHeader(y,"pbag");let k=U.read(I.data);this.verifyHeader(k,"pmod");let p=U.read(I.data);this.verifyHeader(p,"pgen");let R=U.read(I.data);this.verifyHeader(R,"inst");let b=U.read(I.data);this.verifyHeader(b,"ibag");let M=U.read(I.data);this.verifyHeader(M,"imod");let S=U.read(I.data);this.verifyHeader(S,"igen");let Q=U.read(I.data);this.verifyHeader(Q,"shdr"),h.info("%cParsing samples...",d.info),A.currentIndex=this.sampleDataStartIndex;let m=Ms(Q,C,i===void 0);if(i&&g.shdr){let F=Ms(g.shdr,new Float32Array(1),!1);if(F.length===m.length)for(let[u,x]of m.entries())x.name+=F[u].name,x.linkedSampleIndex|=F[u].linkedSampleIndex<<16}for(let F of m)F.name=F.name.trim();this.samples.push(...m);let D=Ns(S),q=VA(M),K=Ts(R);if(i&&g.inst){let F=Ts(g.inst);if(F.length===K.length){for(let[u,x]of K.entries())x.name+=F[u].name,x.zoneStartIndex|=F[u].zoneStartIndex<<16;for(let[u,x]of K.entries())u<K.length-1&&(x.zonesCount=K[u+1].zoneStartIndex-x.zoneStartIndex)}}for(let F of K)F.name=F.name.trim();this.instruments.push(...K);let O=IA(b);if(i&&g.ibag){let F=IA(g.ibag);for(let u=0;u<O.mod.length;u++)O.mod[u]|=F.mod[u]<<16;for(let u=0;u<O.gen.length;u++)O.gen[u]|=F.gen[u]<<16}sr(O,D,q,this.samples,K);let Y=Ns(p),H=VA(k),Z=Ps(E,this);if(i&&g.phdr){let F=Ps(g.phdr,this);if(F.length===Z.length){for(let[u,x]of Z.entries())x.name+=F[u].name,x.zoneStartIndex|=F[u].zoneStartIndex<<16;for(let[u,x]of Z.entries())u<Z.length-1&&(x.zonesCount=Z[u+1].zoneStartIndex-x.zoneStartIndex)}}for(let F of Z)F.name=F.name.trim();this.addPresets(...Z);let T=IA(y);if(i&&g.pbag){let F=IA(g.pbag);for(let u=0;u<T.mod.length;u++)T.mod[u]|=F.mod[u]<<16;for(let u=0;u<T.gen.length;u++)T.gen[u]|=F.gen[u]<<16}er(T,Y,H,this.instruments,Z),this.flush(),h.info(`%cParsing finished! %c"${this.soundBankInfo.name}"%c has %c${this.presets.length}%c presets,
|
|
17
|
+
%c${this.instruments.length}%c instruments and %c${this.samples.length}%c samples.`,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized,d.info,d.recognized,d.info),h.groupEnd()}verifyHeader(t,e){t.header.toLowerCase()!==e.toLowerCase()&&(h.groupEnd(),this.parsingError(`Invalid chunk header! Expected "${e.toLowerCase()}" got "${t.header.toLowerCase()}"`))}verifyText(t,e){t.toLowerCase()!==e.toLowerCase()&&(h.groupEnd(),this.parsingError(`Invalid FourCC: Expected "${e.toLowerCase()}" got "${t.toLowerCase()}"\``))}},$t=class{static fromArrayBuffer(t){return Ee(new ee(t.slice(8,12)),4).toLowerCase()==="dls "?this.loadDLS(t):new nr(t,!1)}static loadDLS(t){return mn.read(t).toSF()}},kA=class yn extends ke{isEffectModulator;isDefaultResonantModulator;isModWheelModulator;constructor(e,A,s,n,a,r,o,i){super(e,A,s,n,a),this.isEffectModulator=r,this.isDefaultResonantModulator=o,this.isModWheelModulator=i}static fromData(e,A,s,n,a){let r=e.toSourceEnum(),o=A.toSourceEnum();return new yn(e,A,s,n,a,(r===219||r===221)&&o===0&&(s===c.reverbEffectsSend||s===c.chorusEffectsSend),r===ln&&o===0&&s===c.initialFilterQ,(e.isCC&&e.index===f.modulationWheel||A.isCC&&A.index===f.modulationWheel)&&(s===c.modLfoToPitch||s===c.vibLfoToPitch))}static fromModulator(e){return this.fromData(e.primarySource,e.secondarySource,e.destination,e.transformAmount,e.transformType)}},ar=class{sampleData;generators;modulators;exclusiveClass;targetKey;velocity;rootKey;loopStart;loopEnd;playbackStep;loopingMode;constructor(t,e,A,s){let n=t.sample,a=t.generators;this.modulators=t.modulators.map(kA.fromModulator.bind(kA)),this.generators=a,this.rootKey=n.originalKey,a[c.overridingRootKey]>-1&&(this.rootKey=a[c.overridingRootKey]),this.targetKey=e,a[c.keyNum]>-1&&(this.targetKey=a[c.keyNum]),this.velocity=A,a[c.velocity]>-1&&(this.velocity=a[c.velocity]),this.exclusiveClass=a[c.exclusiveClass],this.loopStart=n.loopStart,this.loopEnd=n.loopEnd,this.sampleData=n.getAudioData(),this.playbackStep=n.sampleRate/s*Math.pow(2,n.pitchCorrection/1200),this.loopingMode=a[c.sampleModes]}},Us=Math.PI/2,dA=-500,Sn=500,us=Sn-dA,kn=new Float32Array(us+1),Dn=new Float32Array(us+1);for(let t=dA;t<=Sn;t++){let e=(t-dA)/us,A=t-dA;kn[A]=Math.cos(Us*e),Dn[A]=Math.sin(Us*e)}function rr(t,e,A,s,n,a){if(!t.isInRelease&&e>=t.releaseStartTime&&(t.isInRelease=!0,t.volEnv.startRelease(t),t.modEnv.startRelease(t),t.loopingMode===3&&(t.wavetable.isLooping=!1)),t.hasRendered=!0,!t.isActive)return;let r=this.synthCore,o=r.sampleRate,i=t.modulatedGenerators,g=t.targetKey,l=t.pitchOffset+i[c.fineTune]+this.octaveTuning[g]+this.currentTuning,B=i[c.coarseTune],C=r.tunings[this.preset.program*128+t.midiNote];if(C!==-1&&(g=Math.trunc(C),B+=C-g),t.portamentoFromKey>-1){let u=Math.min((e-t.startTime)/t.portamentoDuration,1),x=g-t.portamentoFromKey;B-=x*(1-u)}l+=(g-t.rootKey)*i[c.scaleTuning];let I=0,E=0,y=t.gainModifier*(1+i[c.amplitude]/1e3);if(e>=t.vibLfoStartTime){let u=i[c.vibLfoToPitch],x=i[c.vibLfoToFilterFc],P=i[c.vibLfoAmplitudeDepth];if(u!==0||x!==0||P!==0){let te=Math.max(0,As(i[c.freqVibLFO])+i[c.vibLfoRate]/100)*a/o,W=1-4*Math.abs(t.vibLfoPhase-.5);(t.vibLfoPhase+=te)>=1&&(t.vibLfoPhase-=1),l+=W*u,I+=W*x,y*=1-(W+1)/2*(P/1e3)}}if(e>=t.modLfoStartTime){let u=i[c.modLfoToPitch],x=i[c.modLfoToVolume],P=i[c.modLfoToFilterFc],te=i[c.modLfoAmplitudeDepth];if(u!==0||P!==0||x!==0||te!==0){let W=Math.max(0,As(i[c.freqModLFO])+i[c.modLfoRate]/100)*a/o,_=1-4*Math.abs(t.modLfoPhase-.5);(t.modLfoPhase+=W)>=1&&(t.modLfoPhase-=1),l+=_*u,E+=-_*x,I+=_*P,y*=1-(_+1)/2*(te/1e3)}}let k=i[c.modEnvToPitch],p=i[c.modEnvToFilterFc];if(p!==0||k!==0){let u=t.modEnv.process(t,e);I+=u*p,l+=u*k}E-=t.resonanceOffset;let R=l+B*100,b=R|0;b!==t.tuningCents&&(t.tuningCents=b,t.tuningRatio=Math.pow(2,R/1200));let M=yA(i[c.initialAttenuation])*yA(E);if(t.loopingMode===2&&!t.isInRelease){t.isActive=t.volEnv.process(a,M);return}let S=r.voiceBuffer;t.isActive=t.wavetable.process(a,t.tuningRatio,S);let Q=t.volEnv.outputGain,m=t.volEnv.process(a,M),D=(t.volEnv.outputGain-Q)/a;{let u=t.filter,x=i[c.initialFilterFc];u.initialized?u.currentInitialFc+=(x-u.currentInitialFc)*fs.smoothingConstant:(u.initialized=!0,u.currentInitialFc=x);let P=u.currentInitialFc+I,te=i[c.initialFilterQ];if(u.currentInitialFc>13499&&P>13499&&te===0){u.currentInitialFc=13500;for(let W=0;W<a;W++)S[W]*=Q,Q+=D}else{(Math.abs(u.lastTargetCutoff-P)>1||u.resonanceCb!==te)&&(u.lastTargetCutoff=P,u.resonanceCb=te,u.calculateCoefficients(P));let{a0:W,a1:_,a2:$,a3:ne,a4:ae}=u,{x1:J,x2:ie,y1:pe,y2:ve}=u;for(let Be=0;Be<a;Be++){let be=S[Be],xe=W*be+_*J+$*ie-ne*pe-ve*ae;ie=J,J=be,ve=pe,pe=xe,S[Be]=xe*Q,Q+=D}u.x1=J,u.x2=ie,u.y1=pe,u.y2=ve}}t.isActive=t.isActive&&m;let q;t.overridePan?q=t.overridePan:(t.currentPan+=(i[c.pan]-t.currentPan)*r.panSmoothingFactor,q=t.currentPan);let{systemParameters:K}=r,O=this.currentGain*y,Y=Math.min(Math.max(-500,q+this.currentPan),500)+500|0,H=kn[Y]*O,Z=Dn[Y]*O;if(this._midiParameters.efxAssign){let u=r.insertionInputL,x=r.insertionInputR;for(let P=0;P<a;P++){let te=S[P];u[P]+=H*te,x[P]+=Z*te}return}for(let u=0;u<a;u++){let x=S[u],P=u+n;A[P]+=H*x,s[P]+=Z*x}if(!K.effectsEnabled)return;let T=i[c.reverbEffectsSend]*t.reverbSend;if(T>0){let u=K.reverbGain*O*(T/1e3),x=r.reverbInput;for(let P=0;P<a;P++)x[P]+=u*S[P]}let F=i[c.chorusEffectsSend]*t.chorusSend;if(F>0){let u=K.chorusGain*(F/1e3)*O,x=r.chorusInput;for(let P=0;P<a;P++)x[P]+=u*S[P]}if(r.delayActive){let u=this._midiControllers[f.variationDepth]*t.delaySend;if(u>0){let x=O*K.delayGain*((u>>7)/127),P=r.delayInput;for(let te=0;te<a;te++)P[te]+=x*S[te]}}}function ir(t,e,A=!0){if(t>127||e<0)throw new Error("Invalid MIDI Controller.");if(t>=f.modulationWheelLSB&&t<=f.effectControl2LSB){let s=t-32;if(this.lockedControllers[s])return;this._midiControllers[s]=this._midiControllers[s]&16256|e&127,this.computeModulatorsAll(1,s)}if(!this.lockedControllers[t]){switch(this._midiControllers[t]=e<<7|this._midiControllers[t]&127,t){case f.omniModeOff:case f.omniModeOn:case f.allNotesOff:this.stopAllNotes();break;case f.allSoundOff:this.stopAllNotes(!0);break;case f.polyModeOn:this.stopAllNotes(!0),this.setMIDIParameter("polyMode",!0);break;case f.monoModeOn:this.stopAllNotes(!0),this.setMIDIParameter("polyMode",!1);break;case f.bankSelect:this.setBankMSB(e),this.channel%16===9&&Se.isSystemXG(this.channelSystem)&&this.setBankMSB(127);break;case f.bankSelectLSB:this.setBankLSB(e);break;case f.variationDepth:this.synthCore.delayActive=!0;break;case f.registeredParameterLSB:case f.registeredParameterMSB:this._midiControllers[f.dataEntryMSB]=0,this.lastParameterIsRegistered=!0;break;case f.nonRegisteredParameterMSB:this.sf2NRPNGeneratorLSB=0,this._midiControllers[f.dataEntryMSB]=0,this.lastParameterIsRegistered=!1;break;case f.nonRegisteredParameterLSB:if(this._midiControllers[f.nonRegisteredParameterMSB]>>7===ye.SF2)switch(this.sf2NRPNGeneratorLSB%100!==0&&(this.sf2NRPNGeneratorLSB=0),e){case 100:this.sf2NRPNGeneratorLSB+=100;break;case 101:this.sf2NRPNGeneratorLSB+=1e3;break;case 102:this.sf2NRPNGeneratorLSB+=1e4;break;default:e<100&&(this.sf2NRPNGeneratorLSB+=e)}this._midiControllers[f.dataEntryMSB]=0,this.lastParameterIsRegistered=!1;break;case f.dataEntryMSB:case f.dataEntryLSB:this.dataEntry();break;case f.resetAllControllers:this.resetRP15();break;case f.sustainPedal:if(e<64){let s=0;if(this._voiceCount>0){for(let n of this.synthCore.voices)if(n.channel===this.channel&&n.isActive&&n.isHeld&&(n.isHeld=!1,n.releaseVoice(this.synthCore.currentTime),++s>=this._voiceCount))break}}break;case f.portamentoControl:this.lastNote=e,this.portamentoForce=!0;break;default:this.computeModulatorsAll(1,t);break}A&&this.synthCore.callEvent("controllerChange",{channel:this.channel,controller:t,value:e})}}var or=[c.delayModLFO,c.freqModLFO,c.delayVibLFO,c.freqVibLFO,c.delayModEnv,c.attackModEnv,c.holdModEnv,c.decayModEnv,c.sustainModEnv,c.releaseModEnv,c.delayVolEnv,c.attackVolEnv,c.holdVolEnv,c.decayVolEnv,c.sustainVolEnv,c.releaseVolEnv,c.fineTune,c.modLfoToPitch,c.vibLfoToPitch,c.modEnvToPitch,c.modLfoToVolume,c.initialFilterFc,c.initialFilterQ,c.modLfoToFilterFc,c.modEnvToFilterFc,c.chorusEffectsSend,c.reverbEffectsSend],gt=(t,e,A)=>Math.max(e,Math.min(A,t)),cA=t=>Math.max(-32768,1200*Math.log2(t/1e3)),gr=t=>6900+1200*Math.log2(t/440);function Ir(t,e){let A=e&127;e-=8192;let s=or[t];s||h.unsupported(`AWE32 LSB for ${this.channel}`,[t],"Invalid Generator Number");let n,a,r,o;switch(s){default:break;case c.delayModLFO:case c.delayVibLFO:case c.delayVolEnv:case c.delayModEnv:n=4*gt(e,0,5900),this.setGeneratorOverride(s,cA(n));break;case c.attackVolEnv:case c.attackModEnv:n=gt(e,0,5940),this.setGeneratorOverride(s,cA(n));break;case c.holdVolEnv:case c.holdModEnv:n=gt(e,0,8191),this.setGeneratorOverride(s,cA(n));break;case c.decayModEnv:case c.decayVolEnv:case c.releaseVolEnv:case c.releaseModEnv:n=4*gt(e,0,5940),this.setGeneratorOverride(s,cA(n));break;case c.freqVibLFO:case c.freqModLFO:a=.084*A,this.setGeneratorOverride(s,gr(a),!0);break;case c.sustainVolEnv:case c.sustainModEnv:r=A*7.5,this.setGeneratorOverride(s,r);break;case c.fineTune:this.setGeneratorOverride(s,e,!0);break;case c.modLfoToPitch:case c.vibLfoToPitch:o=gt(e,-127,127)*9.375,this.setGeneratorOverride(s,o,!0);break;case c.modEnvToPitch:o=gt(e,-127,127)*9.375,this.setGeneratorOverride(s,o);break;case c.modLfoToVolume:r=1.875*A,this.setGeneratorOverride(s,r,!0);break;case c.initialFilterFc:{let i=4335+59*A;this.setGeneratorOverride(s,i,!0);break}case c.initialFilterQ:r=215*(A/127),this.setGeneratorOverride(s,r,!0);break;case c.modLfoToFilterFc:o=gt(e,-64,63)*56.25,this.setGeneratorOverride(s,o,!0);break;case c.modEnvToFilterFc:o=gt(e,-64,63)*56.25,this.setGeneratorOverride(s,o);break;case c.chorusEffectsSend:case c.reverbEffectsSend:this.setGeneratorOverride(s,gt(e,0,255)*(1e3/255));break}}function cr(){let t=this._midiControllers[f.dataEntryMSB];if(this.lastParameterIsRegistered){let n=this._midiControllers[f.registeredParameterMSB]|this._midiControllers[f.registeredParameterLSB]>>7;switch(n){default:h.info(`%cUnrecognized RPN for %c${this.channel}%c: %c(0x${n.toString(16)})%c data value: %c${t}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn,d.value);break;case ut.pitchWheelRange:this.pitchWheelRange(t/128);break;case ut.coarseTuning:{let a=(t>>7)-64;this.keyShift(a);break}case ut.fineTuning:{let a=t-8192;this.fineTune(a/81.92);break}case ut.modulationDepth:this.modulationDepth(t/1.28);break;case ut.resetParameters:break}return}let e=this._midiControllers[f.nonRegisteredParameterMSB]>>7,A=this._midiControllers[f.nonRegisteredParameterLSB]>>7,s=t>>7;if(!(this.synthCore.systemParameters.drumLock&&e>=ye.drumPitch&&e<=ye.drumDelay))switch(e){default:h.info(`%cUnrecognized NRPN for %c${this.channel}%c: %c(0x${e.toString(16).toUpperCase()} 0x${A.toString(16).toUpperCase()})%c data value: %c${s}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn,d.value);break;case ye.partParameter:{let n=this._systemParameters.nrpnParamLock??this.synthCore.systemParameters.nrpnParamLock;switch(A){default:h.info(`%cUnrecognized NRPN for %c${this.channel}%c: %c(0x${e.toString(16)} 0x${A.toString(16)})%c data value: %c${s}`,d.warn,d.recognized,d.warn,d.unrecognized,d.warn,d.value);break;case Pe.vibratoRate:this.controllerChange(f.vibratoRate,s);break;case Pe.vibratoDepth:this.controllerChange(f.vibratoDepth,s);break;case Pe.vibratoDelay:this.controllerChange(f.vibratoDelay,s);break;case Pe.tvfCutoffFrequency:if(n)return;this.controllerChange(f.brightness,s),h.coolInfo(`Filter cutoff for ${this.channel}`,s.toString(),"");break;case Pe.tvfResonance:if(n)return;this.controllerChange(f.filterResonance,s),h.coolInfo(`Filter resonance for ${this.channel}`,s.toString(),"");break;case Pe.envelopeAttackTime:if(n)return;this.controllerChange(f.attackTime,s),h.coolInfo(`EG attack time for ${this.channel}`,s.toString(),"");break;case Pe.envelopeDecayTime:if(n)return;this.controllerChange(f.decayTime,s),h.coolInfo(`EG decay time for ${this.channel}`,s.toString(),"");break;case Pe.envelopeReleaseTime:if(n)return;this.controllerChange(f.releaseTime,s),h.coolInfo(`EG release time for ${this.channel}`,s.toString(),"");break}break}case ye.drumPitch:{let n=this.channelSystem==="xg"||this.patch.bankLSB===1?(s-64)*100:(s-64)*50;this.drumParams[A].pitch=n,h.coolInfo(`Drum ${A} pitch for ${this.channel}`,n,"cents");break}case ye.drumPitchFine:{let n=s-64;this.drumParams[A].pitch+=n,h.coolInfo(`Drum ${A} pitch fine for ${this.channel}`,this.drumParams[A].pitch,"cents");break}case ye.drumLevel:this.drumParams[A].gain=s/120,h.coolInfo(`Drum ${A} level for ${this.channel}`,s,"");break;case ye.drumPan:this.drumParams[A].pan=s,h.coolInfo(`Drum ${A} pan for ${this.channel}`,s,"");break;case ye.drumReverb:this.drumParams[A].reverbGain=s/127,h.coolInfo(`Drum ${A} reverb level for ${this.channel}`,s,"");break;case ye.drumChorus:this.drumParams[A].chorusGain=s/127,h.coolInfo(`Drum ${A} chorus level for ${this.channel}`,s,"");break;case ye.drumDelay:this.drumParams[A].delayGain=s/127,h.coolInfo(`Drum ${A} delay level for ${this.channel}`,t,"");break;case ye.awe32:Ir.call(this,A,t);break;case ye.SF2:{if(A>100)break;let n=this.sf2NRPNGeneratorLSB,a=t-8192;this.setGeneratorOffset(n,a);break}}}var hr=40;function lr(t){if(t<1)return 0;{let e=[1,2,4,8,16,32,64,80,96,112,120,124],A=[1,.5,.25,.125,.0625,.03125,.0625,.0625,.0625,.125,.25,1/3],s=[-.16653127382501215,.11863875218299408,.029479047361245264,-.005442312089231738,.1451520875973037,-.005056281449558275,-.005095486882876532,.03334009551111544,-.09361368678020432,.14132569702451822,-.15805565301011382,-.09918856955881927],n=[.028212773333433472,-.3388502064992847,-.15839529890929713,-.12398131766775483,-.2874848552685111,.012254866302537692,.005957797193345771,-.03745899330347374,.12911781869810196,-.15867193224162568,.504406322732748,.3786845131875458],a=[.7218950861255283,.5574536226347168,.47133893237025826,.48597095327079914,.44336276333518854,.6076986311801551,.30851975971827794,.30514889345633955,.3302511933827384,.153822885219165,.1302280559047337,.49865530675491687],r=[-2.2218487496163566,-1.6382721639824072,-1.3010299956639813,-.958607314841775,-.6020599913279624,-.3010299956639812,.31386722036915343,.6232492903979004,.9242792860618817,1.290034611362518,1.4265112613645752,1.9030899869919435],o=[2,4,8,16,32,64,80,96,112,120,124],i=-1;for(let l=o.length-1;l>=0;l--)if(o[l]<t){i=l;break}i+=1;let g=(t-e[i])*A[i];return Math.exp(2.302585092994046*(((s[i]*g+n[i])*g+a[i])*g+r[i]))/hr}}function Cr(t,e){return lr(t)*e}var Jt=(t,e,A)=>Math.max(e,Math.min(A,t));function Br(t,e){if(e<1){this.noteOff(t);return}e=Jt(e,0,127);let A=this.synthCore.systemParameters.blackMIDIMode;if(A&&this.synthCore.voiceCount>200&&e<40||A&&e<10||this._systemParameters.isMuted||!this.preset)return;let s=t+this.currentKeyShift;if(t>127||t<0)return;let n=this.preset.program,a=this.synthCore.tunings[n*128+t];a>=0&&(s=Math.trunc(a)),((this._systemParameters.monophonicRetrigger??this.synthCore.systemParameters.monophonicRetrigger)||this._midiParameters.assignMode===0)&&this.killNote(t);let r=this.synthCore.keyModifierManager.getVelocity(this.channel,t);r>-1&&(e=r);let o=this.synthCore.keyModifierManager.getGain(this.channel,t),i=this.lastNote,g=this.portamentoForce||this._midiControllers[f.portamentoOnOff]>=8192,l=this._midiControllers[f.portamentoTime]>>7,B=g&&!this._drumChannel&&i>=0&&i!==t&&l>0,C=-1,I=0;if(B){let S=Math.abs(t-i);C=i,I=Cr(l,S),this.portamentoForce=!1}if(this.lastNote=t,!this._midiParameters.polyMode){let S=0;if(this._voiceCount>0){for(let Q of this.synthCore.voices)if(Q.isActive&&Q.channel===this.channel&&(Q.exclusiveRelease(this.synthCore.currentTime,0),++S>=this._voiceCount))break}}let E=this.synthCore.getVoices(this.channel,s,e),y=0,k=0,p=0,R=1,b=1,M=1;if(this._midiParameters.randomPan&&(y=Math.round(Math.random()*1e3-500)),this._drumChannel){let S=this.drumParams[t];if(!S.rxNoteOn)return;let Q=S.pan-64;if(Q!==0)if(Q===-64)y=Math.round(Math.random()*1e3-500);else{let m=(this._midiControllers[f.pan]>>7)-64;y=Math.max(-63,Math.min(Q+m,63))/63*500||1}p=S.pitch,k=S.exclusiveClass,R=S.reverbGain,b=S.chorusGain,M=S.delayGain,o===1&&(o=S.gain)}for(let S of E){let Q=this.synthCore.assignVoice(),m=this.synthCore.currentTime;if(Q.setup(m,this.channel,t),Q.wavetable=Q.oscillators[this._systemParameters.interpolationType??this.synthCore.systemParameters.interpolationType],Q.targetKey=S.targetKey,Q.velocity=S.velocity,Q.generators.set(S.generators),Q.exclusiveClass=k||S.exclusiveClass,Q.rootKey=S.rootKey,Q.loopingMode=S.loopingMode,Q.wavetable.sampleData=S.sampleData,Q.wavetable.playbackStep=S.playbackStep,this.dynamicModulators.active){Q.modulators=[...S.modulators];for(let H of this.dynamicModulators.modulatorList){let Z=Q.modulators.findIndex(T=>ke.isIdentical(T,H.mod));Z===-1?Q.modulators.push(H.mod):Q.modulators[Z]=H.mod}}else Q.modulators=S.modulators;if(Q.modulators.length>Q.modulatorValues.length&&(h.warn(`${Q.modulators.length} modulators! Increasing modulatorValues table.`),Q.modulatorValues=new Int16Array(Q.modulators.length)),this.generators.overridesEnabled){let H=this.generators.overrides;for(let Z=0;Z<St;Z++){let T=H[Z];T!==32767&&(Q.generators[Z]=T)}}if(Q.exclusiveClass!==0&&this._midiParameters.polyMode){let H=0;if(this._voiceCount>0){for(let Z of this.synthCore.voices)if(Z.isActive&&Z.channel===this.channel&&Z.exclusiveClass===Q.exclusiveClass&&Z.hasRendered&&(Z.exclusiveRelease(this.synthCore.currentTime),++H>=this._voiceCount))break}}this.computeModulators(Q),Q.volEnv.init(Q),Q.modEnv.init(Q),Q.filter.init(),Q.vibLfoStartTime=m+mA(Q.modulatedGenerators[c.delayVibLFO]),Q.modLfoStartTime=m+mA(Q.modulatedGenerators[c.delayModLFO]);let D=Q.modulatedGenerators[c.startAddrsOffset]+Q.modulatedGenerators[c.startAddrsCoarseOffset]*32768,q=Q.modulatedGenerators[c.endAddrOffset]+Q.modulatedGenerators[c.endAddrsCoarseOffset]*32768,K=Q.modulatedGenerators[c.startloopAddrsOffset]+Q.modulatedGenerators[c.startloopAddrsCoarseOffset]*32768,O=Q.modulatedGenerators[c.endloopAddrsOffset]+Q.modulatedGenerators[c.endloopAddrsCoarseOffset]*32768,Y=S.sampleData.length-1;if(Q.wavetable.cursor=Jt(D,0,Y),Q.wavetable.end=Jt(Y+q,0,Y),Q.wavetable.loopStart=Jt(S.loopStart+K,0,Y),Q.wavetable.loopEnd=Jt(S.loopEnd+O,0,Y),Q.wavetable.loopEnd<Q.wavetable.loopStart){let H=Q.wavetable.loopStart;Q.wavetable.loopStart=Q.wavetable.loopEnd,Q.wavetable.loopEnd=H}Q.wavetable.loopEnd-Q.wavetable.loopStart<1&&(Q.loopingMode===1||Q.loopingMode===3)&&(Q.loopingMode=0),Q.wavetable.loopLength=Q.wavetable.loopEnd-Q.wavetable.loopStart+1,Q.wavetable.isLooping=Q.loopingMode===1||Q.loopingMode===3,Q.portamentoFromKey=C,Q.portamentoDuration=I,Q.overridePan=y,Q.gainModifier=o,Q.pitchOffset=p,Q.reverbSend=R,Q.chorusSend=b,Q.delaySend=M,Q.currentPan=Math.max(-500,Math.min(500,y||Q.modulatedGenerators[c.pan]))}this._voiceCount+=E.length,this.synthCore.callEvent("noteOn",{midiNote:t,channel:this.channel,velocity:e})}function Er(t){if(t>127||t<0)return;if(this.synthCore.systemParameters.blackMIDIMode&&!this._drumChannel||this._drumChannel&&this.drumParams[t].rxNoteOff){this.killNote(t),this.synthCore.callEvent("noteOff",{midiNote:t,channel:this.channel});return}let e=this._midiControllers[f.sustainPedal]>=8192,A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&s.midiNote===t&&!s.isInRelease&&(e?s.isHeld=!0:s.releaseVoice(this.synthCore.currentTime),++A>=this._voiceCount))break}this.synthCore.callEvent("noteOff",{midiNote:t,channel:this.channel})}function dr(t){if(this._systemParameters.presetLock)return;this.patch.program=t;let e=this.synthCore.soundBankManager.getPreset(this.patch,this.channelSystem);!e&&(e=this.synthCore.missingPresetHandler(this.patch,this.channelSystem),!e)||(this.preset=e,e.isDrum!==this._drumChannel&&this.setDrumFlag(e.isDrum),this.resetDrumParams(),this.synthCore.callEvent("programChange",{channel:this.channel,bankLSB:this.preset.bankLSB,bankMSB:this.preset.bankMSB,program:this.preset.program,name:this.preset.name,isGMGSDrum:this.preset.isGMGSDrum,isDrum:this.preset.isDrum}))}var fr=[kA.fromModulator(new ue(Ze(le.linear,!0,!1,!0,f.vibratoRate),0,c.vibLfoRate,1e3,0))],Qr=class{modulatorList=[];active=!1;channel;constructor(t){this.channel=t}resetModulators(){this.modulatorList=fr.map(t=>({mod:t,id:this.getModulatorID(t.primarySource.toSourceEnum(),t.destination,t.primarySource.isBipolar,t.primarySource.isNegative)})),this.active=!1}setupReceiver(t,e,A,s,n,a=!1){this.active=!0;let r=e-64,o=r/64,i=e/127;switch(t&15){case 0:this.setModulator(A,s,c.fineTune,r*100,a),h.coolInfo(`Channel ${this.channel} ${n} pitch control`,r,"semitones");break;case 1:this.setModulator(A,s,c.initialFilterFc,o*9600,a),h.coolInfo(`Channel ${this.channel} ${n} filter control`,o*9600,"cents");break;case 2:this.setModulator(A,s,c.amplitude,o*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} amplitude control`,o*100,"%");break;case 3:this.setModulator(A,s,c.vibLfoRate,o*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 rate control`,o*10,"Hz");break;case 4:this.setModulator(A,s,c.vibLfoToPitch,i*600,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 pitch depth control`,i*600,"cents");break;case 5:this.setModulator(A,s,c.vibLfoToFilterFc,i*2400,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 filter depth control`,i*2400,"cents");break;case 6:this.setModulator(A,s,c.vibLfoAmplitudeDepth,i*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO1 amplitude depth control`,i*100,"%");break;case 7:this.setModulator(A,s,c.modLfoRate,o*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 rate control`,o*10,"Hz");break;case 8:this.setModulator(A,s,c.modLfoToPitch,i*600,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 pitch depth control`,i*600,"cents");break;case 9:this.setModulator(A,s,c.modLfoToFilterFc,i*2400,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 filter depth control`,i*2400,"cents");break;case 10:this.setModulator(A,s,c.modLfoAmplitudeDepth,i*1e3,a),h.coolInfo(`Channel ${this.channel} ${n} LFO2 amplitude depth control`,i*100,"%");break}}setModulator(t,e,A,s,n=!1,a=!1){let r=this.getModulatorID(t,A,n,a);s===0&&this.deleteModulator(r);let o=this.modulatorList.find(i=>i.id===r);if(o)o.mod.transformAmount=s;else{let i=kA.fromData(new st(t,le.linear,e,n),new st,A,s,0);this.modulatorList.push({mod:i,id:r})}}getModulatorID(t,e,A,s){return`${t}-${e}-${A}-${s}`}deleteModulator(t){this.modulatorList=this.modulatorList.filter(e=>e.id!==t)}},ur=1e3/200;function mr(t,e,A){let s=t.modulators[A];if(s.transformAmount===0)return t.modulatorValues[A]=0,0;let n=s.primarySource.getValue(this,e,t),a=s.secondarySource.getValue(this,e,t),r=s.transformAmount;s.isEffectModulator&&r<=1e3&&(r*=ur,r=Math.min(r,1e3));let o=n*a*r;return s.transformType===2&&(o=Math.abs(o)),s.isDefaultResonantModulator&&(t.resonanceOffset=Math.max(0,o/2)),s.isModWheelModulator&&(o*=this._midiParameters.modulationDepth),t.modulatorValues[A]=o,o}function pr(t,e=-1,A=0){let s=t.modulators,n=t.generators;if(this.generators.offsetsEnabled){let i=this.generators.offsets;n=new Int16Array(n);for(let g=0;g<n.length;g++)n[g]+=i[g]}let a=t.modulatedGenerators,r=this.perNotePitch?this.pitchWheels[t.midiNote]:this._midiParameters.pitchWheel;if(e===-1){a.set(n);for(let i=0;i<s.length;i++){let g=s[i];a[g.destination]=Math.min(32767,Math.max(-32768,a[g.destination]+this.computeModulator(t,r,i)))}for(let i=0;i<a.length;i++){let g=Ve[i];g&&(a[i]=Math.min(g.max,Math.max(g.min,a[i])))}return}let o=!!e;for(let i=0;i<s.length;i++){let g=s[i];if(g.primarySource.isCC===o&&g.primarySource.index===A||g.secondarySource.isCC===o&&g.secondarySource.index===A){let l=g.destination,B=n[l];this.computeModulator(t,r,i);for(let I=0;I<s.length;I++)s[I].destination===l&&(B+=t.modulatorValues[I]);let C=Ve[l];a[l]=Math.max(C.min,Math.min(B,C.max))}}}var wn=class bn{pitch=0;gain=1;exclusiveClass=0;pan=64;reverbGain=0;chorusGain=1;delayGain=1;rxNoteOn=!0;rxNoteOff=!1;static copyFrom(e){let A=new bn;return A.pitch=e.pitch,A.chorusGain=e.chorusGain,A.reverbGain=e.reverbGain,A.exclusiveClass=e.exclusiveClass,A.gain=e.gain,A.pan=e.pan,A.rxNoteOff=e.rxNoteOff,A.rxNoteOn=e.rxNoteOn,A}};function yr(){return{patch:this.preset?{...this.patch,name:this.preset.name,isDrum:this.preset.isDrum}:void 0,lockedSystem:this.lockedSystem,midiControllers:this._midiControllers.slice(),lockedControllers:[...this.lockedControllers],pitchWheels:this.pitchWheels.slice(),generators:{...this.generators,offsets:this.generators.offsets.slice(),overrides:this.generators.overrides.slice()},midiParameters:{...this._midiParameters},systemParameters:{...this._systemParameters},octaveTuning:this.octaveTuning.slice(),perNotePitch:this.perNotePitch,drumParams:this.drumParams.map(t=>({...t})),drumChannel:this._drumChannel,channelNumber:this.channel}}function Sr(t){this.setDrums(t.drumChannel),this._midiControllers.set(t.midiControllers);for(let e=0;e<128;e++)this.lockController(e,t.lockedControllers[e]);this.pitchWheels.set(t.pitchWheels),this.octaveTuning.set(t.octaveTuning),this.perNotePitch=t.perNotePitch,this.generators.offsets.set(t.generators.offsets),this.generators.overrides.set(t.generators.overrides),this.generators.offsetsEnabled=t.generators.offsetsEnabled,this.generators.overridesEnabled=t.generators.overridesEnabled;for(let e=0;e<128;e++)this.drumParams[e]=wn.copyFrom(t.drumParams[e]);this.setSystemParameter("presetLock",!1),t.patch&&this.setPatch(t.patch),this.lockedSystem=t.lockedSystem;for(let[e,A]of Object.entries(this._midiParameters))this.setMIDIParameter(e,A);for(let[e,A]of Object.entries(this._systemParameters))this.setSystemParameter(e,A)}var kr={pitchWheel:8192,pitchWheelRange:2,pressure:0,modulationDepth:1,rxChannel:0,polyMode:!0,keyShift:0,randomPan:!1,assignMode:2,efxAssign:!1,cc1:16,cc2:17,drumMap:0,fineTune:0},Dr={presetLock:!1,isMuted:!1,gain:1,pan:0,keyShift:0,fineTune:0,interpolationType:null,nrpnParamLock:null,monophonicRetrigger:null};function wr(t,e){if(this._systemParameters[t]===e)return;let A=this._systemParameters[t];switch(this._systemParameters[t]=e,this.updateInternalParams(),t){default:break;case"presetLock":e&&(this.lockedSystem=this.synthCore.midiParameters.system);break;case"isMuted":e&&this.stopAllNotes(!0);break;case"keyShift":!this._drumChannel&&A!==e&&this.stopAllNotes(!0)}}var br=class{pitchWheels=new Int16Array(128).fill(8192);lockedControllers=new Array(128).fill(!1);drumParams=[];dynamicModulators;sf2NRPNGeneratorLSB=0;patch={bankMSB:0,bankLSB:0,program:0,isGMGSDrum:!1};preset;lockedSystem="gs";channel;synthCore;setSystemParameter=wr.bind(this);noteOn=Br.bind(this);noteOff=Er.bind(this);programChange=dr.bind(this);controllerChange=ir.bind(this);reset=ma.bind(this);renderVoice=rr.bind(this);_midiControllers=new Int16Array(128);octaveTuning=new Int8Array(128);resetRP15=pa.bind(this);dataEntry=cr.bind(this);_midiParameters={...kr};_systemParameters={...Dr};lastParameterIsRegistered=!0;perNotePitch=!1;currentPan=0;currentTuning=0;currentKeyShift=0;currentGain=0;lastNote=-1;portamentoForce=!1;generators={offsets:new Int16Array(St),offsetsEnabled:!1,overrides:new Int16Array(St),overridesEnabled:!1};computeModulator=mr.bind(this);computeModulators=pr.bind(this);constructor(t,e,A){this.synthCore=t,this.preset=e,this.channel=A,this._midiParameters.rxChannel=A,this.dynamicModulators=new Qr(A),this.resetGeneratorOverrides(),this.resetGeneratorOffsets();for(let s=0;s<128;s++)this.drumParams.push(new wn);this.resetDrumParams()}_voiceCount=0;get voiceCount(){return this._voiceCount}set voiceCount(t){this._voiceCount=t}_drumChannel=!1;get drumChannel(){return this._drumChannel}get midiControllers(){return this._midiControllers}get systemParameters(){return this._systemParameters}get midiParameters(){return this._midiParameters}get channelSystem(){return this._systemParameters.presetLock?this.lockedSystem:this.synthCore.midiParameters.system}lockController(t,e){this.lockedControllers[t]=e}setDrums(t){if(Se.isSystemXG(this.channelSystem))if(t)this.setBankMSB(Se.getDrumBank(this.channelSystem)),this.setBankLSB(0);else{if(this.channel%16===9)throw new Error(`Cannot disable drums on channel ${this.channel} for XG.`);this.setBankMSB(0),this.setBankLSB(0)}else this.setGSDrums(t);this.setDrumFlag(t),this.programChange(this.patch.program)}stopAllNotes(t=!1){if(t){let e=0;if(this._voiceCount>0){for(let A of this.synthCore.voices)if(A.channel===this.channel&&A.isActive&&(A.isActive=!1,++e>=this._voiceCount))break}this.clearVoiceCount()}else{let e=0;if(this._voiceCount>0){for(let A of this.synthCore.voices)if(A.channel===this.channel&&A.isActive&&(A.releaseVoice(this.synthCore.currentTime),++e>=this._voiceCount))break}}this.synthCore.callEvent("stopAll",{channel:this.channel,force:t})}setMIDIParameter(t,e){switch(this._midiParameters[t]=e,t){case"pitchWheel":this.computeModulatorsAll(0,Ie.pitchWheel);break;case"pressure":this.computeModulatorsAll(0,Ie.channelPressure);break}this.updateInternalParams(),this.synthCore.callEvent("channelParamChange",{channel:this.channel,parameter:t,value:e})}clearVoiceCount(){this._voiceCount=0}setOctaveTuning(t){if(t.length!==12)throw new Error("Tuning is not the length of 12.");for(let e=0;e<128;e++)this.octaveTuning[e]=t[e%12]}modulationDepth(t,e=!0){this.setMIDIParameter("modulationDepth",t/50),e&&h.info(`%cChannel ${this.channel} modulation depth. Cents: %c${Math.round(t)}`,d.info,d.value)}keyShift(t,e=!0){this._drumChannel&&(t=0),this._midiParameters.keyShift!==t&&(this.setMIDIParameter("keyShift",t),e&&h.info(`%cKey shift for %c${this.channel}%c is now set to %c${t}.`,d.info,d.recognized,d.info,d.value))}fineTune(t,e=!0){this.setMIDIParameter("fineTune",t),e&&h.info(`%cFine tuning for %c${this.channel}%c is now set to %c${Math.round(t)}%c cents.`,d.info,d.recognized,d.info,d.value,d.info)}pitchWheel(t,e=-1){e===-1?(this.perNotePitch=!1,this.setMIDIParameter("pitchWheel",t)):(this.perNotePitch||this.pitchWheels.fill(this._midiParameters.pitchWheel),this.perNotePitch=!0,this.pitchWheels[e]=t,this.computeModulatorsAll(0,Ie.pitchWheel))}polyPressure(t,e){let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.isActive&&s.channel===this.channel&&s.midiNote===t&&(s.pressure=e,this.computeModulators(s,0,Ie.polyPressure),++A>=this._voiceCount))break}this.synthCore.callEvent("polyPressure",{channel:this.channel,midiNote:t,pressure:e})}pitchWheelRange(t,e=!0){this.setMIDIParameter("pitchWheelRange",t),e&&h.coolInfo(`Pitch Wheel Range for ${this.channel}`,t,"semitones")}updateInternalParams(){let t=this.synthCore.systemParameters,e=this._systemParameters,A=this.synthCore.midiParameters,s=this._midiParameters,n=this._drumChannel?e.keyShift:t.keyShift+A.keyShift+e.keyShift+s.keyShift;this.currentKeyShift=Math.trunc(n),this.currentTuning=this._drumChannel?e.fineTune:t.fineTune+A.fineTune+e.fineTune+s.fineTune;let a=t.pan+A.pan+e.pan;this.currentPan=a*500,this.currentGain=Zn*t.gain*A.gain*e.gain}setPatch(t){this.setBankMSB(t.bankMSB),this.setBankLSB(t.bankLSB),this.setGSDrums(t.isGMGSDrum),this.programChange(t.program)}setGSDrums(t){t!==this.patch.isGMGSDrum&&(this.setBankLSB(0),this.setBankMSB(0),this.patch.isGMGSDrum=t)}killNote(t,e=-12e3){let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&s.midiNote===t&&(s.overrideReleaseVolEnv=e,s.isInRelease=!1,s.releaseVoice(this.synthCore.currentTime),++A>=this._voiceCount))break}}applySnapshot(t){Sr.call(this,t)}getSnapshot(){return yr.call(this)}setLastNote(t){this.lastNote=t}destroy(){this.preset=void 0,this.lockedControllers=void 0,this._systemParameters=void 0,this._midiControllers=void 0,this._midiParameters=void 0}resetGeneratorOverrides(){this.generators.overrides.fill(Jn),this.generators.overridesEnabled=!1}setGeneratorOverride(t,e,A=!1){if(this.generators.overrides[t]=e,this.generators.overridesEnabled=!0,A){let s=0;if(this._voiceCount>0){for(let n of this.synthCore.voices)if(n.channel===this.channel&&n.isActive&&(n.generators[t]=e,this.computeModulators(n),++s>=this._voiceCount))break}}}resetGeneratorOffsets(){this.generators.offsets.fill(0),this.generators.offsetsEnabled=!1}setGeneratorOffset(t,e){this.generators.offsets[t]=e*Ve[t].nrpn,this.generators.offsetsEnabled=!0;let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&(this.computeModulators(s),++A>=this._voiceCount))break}}resetDrumParams(){if(!(this.synthCore.systemParameters.drumLock||!this._drumChannel))for(let t=0;t<128;t++){let e=this.drumParams[t];e.pitch=0,e.gain=1,e.exclusiveClass=0,e.pan=64,e.reverbGain=uA[t]/127,e.chorusGain=this.channelSystem==="xg"?uA[t]/127:0,e.delayGain=0,e.rxNoteOn=!0,e.rxNoteOff=!1}}computeModulatorsAll(t,e){let A=0;if(this._voiceCount>0){for(let s of this.synthCore.voices)if(s.channel===this.channel&&s.isActive&&(this.computeModulators(s,t,e),++A>=this._voiceCount))break}}setBankMSB(t){this._systemParameters.presetLock||(this.patch.bankMSB=t)}setBankLSB(t){this._systemParameters.presetLock||(this.patch.bankLSB=t)}setDrumFlag(t){this._systemParameters.presetLock||!this.preset||this._drumChannel===t||(this._drumChannel=t,this.keyShift(this._midiParameters.keyShift,!1))}},Rr=class extends _t{constructor(t,e){super(t.parentSoundBank,t.globalZone),this.bankMSB=Se.addBankOffset(t.bankMSB,e,!0),this.name=t.name,this.bankLSB=t.bankLSB,this.isGMGSDrum=t.isGMGSDrum,this.program=t.program,this.genre=t.genre,this.morphology=t.morphology,this.library=t.library,this.zones=t.zones}},Fr=class{soundBankList=[];presetListChangeCallback;selectablePresetList=[];constructor(t){this.presetListChangeCallback=t}_presetList=[];get presetList(){return[...this._presetList]}get priorityOrder(){return this.soundBankList.map(t=>t.id)}set priorityOrder(t){this.soundBankList.sort((e,A)=>t.indexOf(e.id)-t.indexOf(A.id)),this.generatePresetList()}deleteSoundBank(t){if(this.soundBankList.length===0){h.warn("1 soundbank left. Aborting!");return}let e=this.soundBankList.findIndex(A=>A.id===t);if(e===-1)throw new Error(`No sound bank with id "${t}"`);this.soundBankList.splice(e,1),this.generatePresetList()}addSoundBank(t,e,A=0){let s=this.soundBankList.find(n=>n.id===e);s===void 0?this.soundBankList.push({id:e,soundBank:t,bankOffset:A}):(s.soundBank=t,s.bankOffset=A),this.generatePresetList()}getPreset(t,e){if(!(this.soundBankList.length===0||this.selectablePresetList.length===0))return ze.selectPatch(this.selectablePresetList,t,e)}destroy(){for(let t of this.soundBankList)t.soundBank.destroySoundBank();this.soundBankList=[]}generatePresetList(){let t=new Array,e=new Set;for(let A of this.soundBankList){let s=A.soundBank,n=A.bankOffset;for(let a of s.presets){let r=new Rr(a,n);e.has(r.toMIDIString())||(e.add(r.toMIDIString()),t.push(r))}}t.sort(ze.compare.bind(ze)),this.selectablePresetList=t,this._presetList=t.map(A=>({bankMSB:A.bankMSB,bankLSB:A.bankLSB,program:A.program,isGMGSDrum:A.isGMGSDrum,name:A.name,isDrum:A.isDrum})),this.presetListChangeCallback()}};function xs(t,e,A){let s=t,n=e<<7|A;return t===127&&e===127&&A===127?-1:s+n*61e-6}function Mr(t,e=0){switch(t[2]){case 4:switch(t[3]){default:h.gmFail("Device Control",t);break;case 1:{let A=t[5]<<7|t[4];this.setMIDIParameter("gain",A/16384),h.gmInfo("Master Volume",A);break}case 2:{let A=((t[5]<<7|t[4])-8192)/8192;this.setMIDIParameter("pan",A),h.gmInfo("Master Balance",A);break}case 3:{let A=((t[5]<<7|t[6])-8192)/81.92;this.setMIDIParameter("fineTune",A),h.gmInfo("Master Fine Tuning",A,"cents");break}case 4:{let A=t[5]-64;this.setMIDIParameter("keyShift",A),h.gmInfo("Master Coarse Tuning",A,"keys");break}case 5:if(t[4]!==1||t[5]!==1||t[6]!==1||t[7]!==1){h.gmFail("Global Parameter Control",t);break}switch(t[8]){default:h.gmFail("Global Parameter Control",t);break;case 1:{let A=t[10];switch(t[9]){default:h.gmFail("Reverb Parameter Control",t);break;case 0:{let s=A===8?5:A;this.setReverbMacro(s),h.gmInfo("Reverb Type",s);break}case 1:this.reverbProcessor.time=A,h.gmInfo("Reverb Time",A)}break}case 2:{let A=t[10];switch(t[9]){default:h.gmFail("Chorus Parameter Control",t);break;case 0:this.setChorusMacro(A),h.gmInfo("Chorus Type",A);break;case 1:this.chorusProcessor.rate=A,h.gmInfo("Chorus Mod Rate",A);break;case 2:this.chorusProcessor.depth=A,h.gmInfo("Chorus Mod Depth",A);break;case 3:this.chorusProcessor.feedback=A,h.gmInfo("Chorus Mod Feedback",A);break;case 4:this.chorusProcessor.sendLevelToReverb=A,h.gmInfo("Chorus Send to Reverb",A);break}}}}break;case 9:switch(t[3]){default:h.gmFail("System Exclusive",t);break;case 1:h.coolInfo("MIDI System","General MIDI 1"),this.reset("gm");break;case 2:h.coolInfo("MIDI System","Roland GS"),this.reset("gs");break;case 3:h.coolInfo("MIDI System","General MIDI 2"),this.reset("gm2");break}break;case 8:{let A=4;switch(t[3]){case 1:{let s=t[A++],n=_e(t,16,A);if(A+=16,t.length<384){h.warn(`The Bulk Tuning Dump is too short! (${t.length} bytes, at least 384 are expected)`);return}for(let a=0;a<128;a++)this.tunings[s*128+a]=xs(t[A++],t[A++],t[A++]);h.gmInfo("Bulk Tuning Dump",`${n}, program ${s}`);break}case 2:case 7:{t[3]===7&&A++;let s=t[A++],n=t[A++];for(let a=0;a<n;a++){let r=t[A++];this.tunings[s*128+r]=xs(t[A++],t[A++],t[A++])}h.gmInfo("Single Note Tuning",`program: ${s}. Keys affected: ${n}`);break}case 9:case 8:{let s=new Int8Array(12);if(t[3]===8)for(let n=0;n<12;n++)s[n]=t[7+n]-64;else for(let n=0;n<24;n+=2){let a=(t[7+n]<<7|t[8+n])-8192;s[n/2]=Math.floor(a/81.92)}(t[4]&1)===1&&this.midiChannels[14+e].setOctaveTuning(s),(t[4]>>1&1)===1&&this.midiChannels[15+e].setOctaveTuning(s);for(let n=0;n<7;n++)(t[5]>>n&1)===1&&this.midiChannels[7+n+e].setOctaveTuning(s);for(let n=0;n<7;n++)(t[6]>>n&1)===1&&this.midiChannels[n+e].setOctaveTuning(s);h.gmInfo("Octave Scale Tuning",s.join(" "));break}default:h.gmFail("MIDI Tuning Standard",t);break}break}default:h.gmFail("Universal System Exclusive",t)}}function vr(t,e=0){if(t[3]===18)switch(t[2]){case 66:{let A=t[4],s=t[5],n=t[6],a=Math.min(t[7],127);if(A===0&&s===0&&n===127&&a===0){h.coolInfo("MIDI System","Roland GS"),this.reset("gs");return}if(A===64){if(s===0){switch(n){case 0:{let r=((a<<12|t[8]<<8|t[9]<<4|t[10])-1024)/10;this.setMIDIParameter("fineTune",r),h.gsInfo("Master Tune",r,"cents");break}case 4:h.gsInfo("Master Volume",a);break;case 5:{let r=a-64;h.gsInfo("Master Key-Shift",r,"keys"),this.setMIDIParameter("keyShift",r);break}case 6:h.gsInfo("Master Pan",a),this.setMIDIParameter("pan",(a-64)/64);break;case 127:a===0?(h.coolInfo("MIDI System","Roland GS"),this.reset("gs")):a===127&&(h.coolInfo("MIDI System","General MIDI 1"),this.reset("gm"));break;default:h.gsFail("System Parameter",t);break}return}if(s===1){let r=n>=48&&n<=55,o=n>=56&&n<=64,i=n>=80&&n<=90;if(r&&this.systemParameters.reverbLock||o&&this.systemParameters.chorusLock||i&&this.systemParameters.delayLock)return;switch(this.delayActive||=n===64||i,n){default:h.gsFail("Patch Common Parameter",[n]);break;case 0:{let g=_e(t,16,7);h.gsInfo("Patch name",g);break}case 48:this.setReverbMacro(a),h.gsInfo("Reverb Macro",a);break;case 49:this.reverbProcessor.character=a,h.gsInfo("Reverb Character",a),this.callEvent("effectChange",{effect:"reverb",parameter:"character",value:a});break;case 50:this.reverbProcessor.preLowpass=a,h.gsInfo("Reverb Pre-LPF",a),this.callEvent("effectChange",{effect:"reverb",parameter:"preLowpass",value:a});break;case 51:this.reverbProcessor.level=a,h.gsInfo("Reverb Level",a),this.callEvent("effectChange",{effect:"reverb",parameter:"level",value:a});break;case 52:this.reverbProcessor.time=a,h.gsInfo("Reverb Time",a),this.callEvent("effectChange",{effect:"reverb",parameter:"time",value:a});break;case 53:this.reverbProcessor.delayFeedback=a,h.gsInfo("Reverb Delay Feedback",a),this.callEvent("effectChange",{effect:"reverb",parameter:"delayFeedback",value:a});break;case 54:break;case 55:this.reverbProcessor.preDelayTime=a,h.gsInfo("Reverb Predelay Time",a),this.callEvent("effectChange",{effect:"reverb",parameter:"preDelayTime",value:a});break;case 56:this.setChorusMacro(a),h.gsInfo("Chorus Macro",a);break;case 57:this.chorusProcessor.preLowpass=a,h.gsInfo("Chorus Pre-LPF",a),this.callEvent("effectChange",{effect:"chorus",parameter:"preLowpass",value:a});break;case 58:this.chorusProcessor.level=a,h.gsInfo("Chorus Level",a),this.callEvent("effectChange",{effect:"chorus",parameter:"level",value:a});break;case 59:this.chorusProcessor.feedback=a,h.gsInfo("Chorus Feedback",a),this.callEvent("effectChange",{effect:"chorus",parameter:"feedback",value:a});break;case 60:this.chorusProcessor.delay=a,h.gsInfo("Chorus Delay",a),this.callEvent("effectChange",{effect:"chorus",parameter:"delay",value:a});break;case 61:this.chorusProcessor.rate=a,h.gsInfo("Chorus Rate",a),this.callEvent("effectChange",{effect:"chorus",parameter:"rate",value:a});break;case 62:this.chorusProcessor.depth=a,h.gsInfo("Chorus Depth",a),this.callEvent("effectChange",{effect:"chorus",parameter:"depth",value:a});break;case 63:this.chorusProcessor.sendLevelToReverb=a,h.gsInfo("Chorus Send Level To Reverb",a),this.callEvent("effectChange",{effect:"chorus",parameter:"sendLevelToReverb",value:a});break;case 64:this.chorusProcessor.sendLevelToDelay=a,h.gsInfo("Chorus Send Level To Delay",a),this.callEvent("effectChange",{effect:"chorus",parameter:"sendLevelToDelay",value:a});break;case 80:this.setDelayMacro(a),h.gsInfo("Delay Macro",a);break;case 81:this.delayProcessor.preLowpass=a,h.gsInfo("Delay Pre-LPF",a),this.callEvent("effectChange",{effect:"delay",parameter:"preLowpass",value:a});break;case 82:this.delayProcessor.timeCenter=a,h.gsInfo("Delay Time Center",a),this.callEvent("effectChange",{effect:"delay",parameter:"timeCenter",value:a});break;case 83:this.delayProcessor.timeRatioLeft=a,h.gsInfo("Delay Time Ratio Left",a),this.callEvent("effectChange",{effect:"delay",parameter:"timeRatioLeft",value:a});break;case 84:this.delayProcessor.timeRatioRight=a,h.gsInfo("Delay Time Ratio Right",a),this.callEvent("effectChange",{effect:"delay",parameter:"timeRatioRight",value:a});break;case 85:this.delayProcessor.levelCenter=a,h.gsInfo("Delay Level Center",a),this.callEvent("effectChange",{effect:"delay",parameter:"levelCenter",value:a});break;case 86:this.delayProcessor.levelLeft=a,h.gsInfo("Delay Level Left",a),this.callEvent("effectChange",{effect:"delay",parameter:"levelLeft",value:a});break;case 87:this.delayProcessor.levelRight=a,h.gsInfo("Delay Level Right",a),this.callEvent("effectChange",{effect:"delay",parameter:"levelRight",value:a});break;case 88:this.delayProcessor.level=a,h.gsInfo("Delay Level",a),this.callEvent("effectChange",{effect:"delay",parameter:"level",value:a});break;case 89:this.delayProcessor.feedback=a,h.gsInfo("Delay Feedback",a),this.callEvent("effectChange",{effect:"delay",parameter:"feedback",value:a});break;case 90:this.delayProcessor.sendLevelToReverb=a,h.gsInfo("Delay Send Level To Reverb",a),this.callEvent("effectChange",{effect:"delay",parameter:"sendLevelToReverb",value:a});break}break}if(s===3){if(this.systemParameters.insertionEffectLock)return;if(n>=3&&n<=25&&(this.insertionParams[n-3]=a),n>=3&&n<=22){this.insertionProcessor.setParameter(n,a),h.gsInfo(`EFX Parameter ${n-2}`,a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return}switch(n){default:h.gsFail("Insertion Effect",[n]);return;case 0:{let r=a<<8|t[8],o=this.insertionEffects.get(r);o?(h.gsInfo("EFX Type",r.toString(16)),this.insertionProcessor=o):(this.insertionProcessor=this.insertionFallback,h.gsFail("EFX Processor",[r],"Using Thru.")),this.resetInsertionParams(),this.insertionProcessor.reset(),this.callEvent("effectChange",{effect:"insertion",parameter:0,value:r});return}case 23:this.insertionProcessor.sendLevelToReverb=a/127*hA,h.gsInfo("EFX Send Level to Reverb",a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return;case 24:this.insertionProcessor.sendLevelToChorus=a/127*hA,h.gsInfo("EFX Send Level to Chorus",a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return;case 25:this.insertionProcessor.sendLevelToDelay=a/127*hA,this.delayActive=!0,h.gsInfo("EFX Send Level to Delay",a),this.callEvent("effectChange",{effect:"insertion",parameter:n,value:a});return}}if(s>>4===1){let r=se.syxToChannel(s&15)+e,o=this.midiChannels[r];switch(n){default:h.gsFail(`Patch Part Parameter for ${r}`,[n]);return;case 0:o.controllerChange(f.bankSelect,a),o.programChange(t[8]);break;case 2:{let i=a===16?-1:a+e;o.setMIDIParameter("rxChannel",i),this.customChannelNumbers||=i!==o.channel,h.gsInfo(`Rx. Channel on ${r}`,i);break}case 19:o.setMIDIParameter("polyMode",a===1),h.gsInfo(`Mono/poly on ${r}`,o.midiParameters.polyMode?"POLY":"MONO");break;case 20:o.setMIDIParameter("assignMode",a),h.gsInfo(`Assign mode on ${r}`,a);break;case 21:{o.setMIDIParameter("drumMap",a);let i=a>0;o.setGSDrums(i),h.gsInfo(`Drums on ${r}`,i.toString());return}case 22:{let i=a-64;o.keyShift(i);return}case 25:o.controllerChange(f.mainVolume,a);return;case 28:{let i=a,g=i===0;o.setMIDIParameter("randomPan",g),g?h.gsInfo(`Random pan on ${r}`,"ON"):o.controllerChange(f.pan,i);break}case 31:o.setMIDIParameter("cc1",a),h.gsInfo("CC1 Controller Number",a);break;case 32:o.setMIDIParameter("cc2",a),h.gsInfo("CC2 Controller Number",a);break;case 33:o.controllerChange(f.chorusDepth,a);break;case 34:o.controllerChange(f.reverbDepth,a);break;case 42:{let i=((a<<7|t[8])-8192)/81.92;o.fineTune(i);break}case 44:o.controllerChange(f.variationDepth,a);break;case 48:o.controllerChange(f.vibratoRate,a);break;case 49:o.controllerChange(f.vibratoDepth,a);break;case 50:o.controllerChange(f.brightness,a);break;case 51:o.controllerChange(f.filterResonance,a);break;case 52:o.controllerChange(f.attackTime,a);break;case 53:o.controllerChange(f.decayTime,a);break;case 54:o.controllerChange(f.releaseTime,a);break;case 55:o.controllerChange(f.vibratoDelay,a);break;case 64:{let i=t.length-9,g=new Int8Array(12);for(let l=0;l<i;l++)g[l]=t[l+7]-64;o.setOctaveTuning(g),h.gsInfo(`Octave Scale Tuning on ${r}`,g.join(", "));break}}return}if(s>>4===2){let r=se.syxToChannel(s&15)+e,o=this.midiChannels[r];switch(n&240){default:h.gsFail(`Patch Parameter Controller for ${r}`,[n&240]);break;case 0:if((n&15)===4){let i=a/127*600;o.modulationDepth(i);break}o.dynamicModulators.setupReceiver(n,a,f.modulationWheel,!0,"mod wheel");break;case 16:if((n&15)===0){let i=a-64;o.pitchWheelRange(i);break}o.dynamicModulators.setupReceiver(n,a,Ie.pitchWheel,!1,"pitch wheel",!0);break;case 32:o.dynamicModulators.setupReceiver(n,a,Ie.channelPressure,!1,"channel pressure");break;case 48:o.dynamicModulators.setupReceiver(n,a,Ie.polyPressure,!1,"poly pressure");break;case 64:o.dynamicModulators.setupReceiver(n,a,o.midiParameters.cc1,!0,"CC1");break;case 80:o.dynamicModulators.setupReceiver(n,a,o.midiParameters.cc2,!0,"CC2")}return}if(s>>4===4){let r=se.syxToChannel(s&15)+e,o=this.midiChannels[r];switch(n){default:h.gsFail("Patch Part Parameter",[n]);break;case 0:case 1:o.controllerChange(f.bankSelectLSB,a);break;case 34:{if(this.systemParameters.insertionEffectLock)return;let i=a===1;o.setMIDIParameter("efxAssign",i),this.insertionActive||=i,h.gsInfo(`EFX assign for ${r}`,i?"EFX":"BYPASS")}}return}h.gsFail("Patch Parameter",t);return}if(A===65){if(this.systemParameters.drumLock)return;let r=(s>>4)+1,o=n,i=s&15;switch(i){default:h.gsFail("Drum Setup",[i]);return;case 0:{let g=_e(t,12,7);h.gsInfo(`Patch Name for MAP${r}`,g);break}case 1:{let g=a-60;for(let l of this.midiChannels)l.midiParameters.drumMap===r&&(l.drumParams[o].pitch=g*(l.patch.bankLSB===1?100:50));h.gsInfo(`Drum Pitch for MAP${r}, key ${o}`,g);break}case 2:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].gain=a/120);h.gsInfo(`Drum Level for MAP${r}, key ${o}`,a);break;case 3:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].exclusiveClass=a);h.gsInfo(`Drum Assign Group for MAP${r}, key ${o}`,a);break;case 4:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].pan=a);h.gsInfo(`Drum Pan for MAP${r}, key ${o}`,a);break;case 5:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].reverbGain=a/127);h.gsInfo(`Drum Reverb for MAP${r}, key ${o}`,a);break;case 6:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].chorusGain=a/127);h.gsInfo(`Drum Chorus for MAP${r}, key ${o}`,a);break;case 7:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].rxNoteOff=a===1);h.gsInfo(`Drum Note Off for MAP${r}, key ${o}`,a===1?"ON":"OFF");break;case 8:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].rxNoteOn=a===1);h.gsInfo(`Drum Note On for MAP${r}, key ${o}`,a===1?"ON":"OFF");break;case 9:for(let g of this.midiChannels)g.midiParameters.drumMap===r&&(g.drumParams[o].delayGain=a/127);h.gsInfo(`Drum Delay for MAP${r}, key ${o}`,a);break}return}h.gsFail("System Exclusive",t);return}case 69:t[4]===16&&(t[5]===0?this.callEvent("displayMessage",[...t]):t[5]===1?this.callEvent("displayMessage",[...t]):h.gsFail("Display Data",t));return;case 22:if(t[4]===16){this.setMIDIParameter("gain",t[7]/100),h.coolInfo("Roland Master Volume Control",t[7]);return}else h.unsupported("Roland",t)}else{h.unsupported("Roland",t);return}}function Gr(t,e=0){if(t[2]===76){let A=t[3],s=t[4],n=t[5],a=t[6];if(A===0&&s===0){switch(n){case 0:{let r=(((t[6]&15)<<12|(t[7]&15)<<8|(t[8]&15)<<4|t[9]&15)-1024)/10;this.setMIDIParameter("fineTune",r),h.xgInfo("Master Tune",r,"cents")}break;case 4:this.setMIDIParameter("gain",a/127),h.xgInfo("Master Volume",a);break;case 5:{let r=127-a;this.setMIDIParameter("gain",r/127),h.xgInfo("Master Attenuation",a);break}case 6:{let r=a-64;this.setMIDIParameter("keyShift",r),h.xgInfo("Master Transpose",a);break}case 127:case 126:h.coolInfo("MIDI System","Yamaha XG"),this.reset("xg");break}return}if(A===2&&s===1){let r,o=n;o<=21?r="Reverb":o<=53?r="Chorus":r="Variation",h.xgFail(`${r} parameter`,[o]);return}if(A===8){let r=s+e;if(r>=this.midiChannels.length){h.xgFail("Part Setup",t,`Invalid part number: ${r}`);return}let o=this.midiChannels[r];switch(n){default:h.xgFail("Part Setup",[t[5]]);break;case 1:o.controllerChange(f.bankSelect,a);break;case 2:o.controllerChange(f.bankSelectLSB,a);break;case 3:o.programChange(a);break;case 4:{let i=a+e;o.setMIDIParameter("rxChannel",i),this.customChannelNumbers||=i!==o.channel,h.xgInfo(`Rev. Channel on ${r}`,i);break}case 5:{let i=a===1;o.setMIDIParameter("polyMode",i),h.xgInfo(`Mono/poly on ${r}`,i?"POLY":"MONO");break}case 7:{let i=a!==0;o.setDrums(i),h.xgInfo(`Part Mode on ${r}`,i?"DRUM":"MELODIC");break}case 8:{let i=a-64;o.keyShift(i);break}case 11:o.controllerChange(f.mainVolume,a);break;case 14:{let i=a,g=i===0;o.setMIDIParameter("randomPan",g),g?h.xgInfo(`Random Pan for ${r}`,"ON"):o.controllerChange(f.pan,i);break}case 18:o.controllerChange(f.chorusDepth,a);break;case 19:o.controllerChange(f.reverbDepth,a);break;case 21:o.controllerChange(f.vibratoRate,a);break;case 22:o.controllerChange(f.vibratoDepth,a);break;case 23:o.controllerChange(f.vibratoDelay,a);break;case 24:o.controllerChange(f.brightness,a);break;case 25:o.controllerChange(f.filterResonance,a);break;case 26:o.controllerChange(f.attackTime,a);break;case 27:o.controllerChange(f.decayTime,a);break;case 28:o.controllerChange(f.releaseTime,a);break;case 35:{let i=a-64;o.pitchWheelRange(i)}}return}if(A>>4===3){if(this.systemParameters.drumLock)return;let r=s;switch(n){default:h.xgFail("Drum Setup",[n]);return;case 0:{let o=(a-64)*100;for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].pitch=o);h.xgInfo(`Drum Pitch for key ${r}`,o,"semitones");break}case 1:{let o=a-64;for(let i of this.midiChannels)i.drumChannel&&(i.drumParams[r].pitch+=o,h.xgInfo(`Drum Pitch for key ${r}`,i.drumParams[r].pitch,"semitones"));break}case 2:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].gain=a/120);h.xgInfo(`Drum Level for key ${r}`,a);break;case 3:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].exclusiveClass=a);h.xgInfo(`Drum Alternate Group for key ${r}`,a);break;case 4:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].pan=a);h.xgInfo(`Drum Pan for key ${r}`,a);break;case 5:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].reverbGain=a/127);h.xgInfo(`Drum Reverb for key ${r}`,a);break;case 6:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].chorusGain=a/127);h.xgInfo(`Drum Chorus for key ${r}`,a);break;case 9:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].rxNoteOff=a===1);h.xgInfo(`Drum Note Off for key ${r}`,a===1?"ON":"OFF");break;case 10:for(let o of this.midiChannels)o.drumChannel&&(o.drumParams[r].rxNoteOn=a===1);h.xgInfo(`Drum Note On for key ${r}`,a===1?"ON":"OFF");break}return}if(A===6||A===7){this.callEvent("displayMessage",[...t]);return}h.xgFail("System Exclusive",t,"Unknown address")}else h.xgFail("System Exclusive",t)}function Lr(t,e=0){e+=this.portSelectChannelOffset;let A=t[0];if(!(this.systemParameters.deviceID!==-1&&t[1]!==127&&this.systemParameters.deviceID!==t[1]))switch(A){default:h.unsupported("System Exclusive",t,`Unknown manufacturer: ${A}`);break;case 126:case 127:Mr.call(this,t,e);break;case 65:vr.call(this,t,e);break;case 67:Gr.call(this,t,e);break;case 245:if(t.length<2)return;for(this.portSelectChannelOffset=(t[1]-1)*16;this.midiChannels.length<=this.portSelectChannelOffset;){h.info(`%cPort select, channel offset %c${this.portSelectChannelOffset}%c. Creating a new port!`,d.info,d.value,d.info);for(let s=0;s<16;s++)this.createMIDIChannel(!0)}break}}var Rn=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=0;reset(){}process(t,e,A,s,n,a,r,o,i){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:B}=this;for(let C=0;C<i;C++){let I=t[C],E=e[C],y=o+C;A[y]+=I,s[y]+=E;let k=(I+E)*.5;n[C]+=k*g,a[C]+=k*l,r[C]+=k*B}}setParameter(t,e){}},ct=class{static data=[[0,200,200,0,0,.05,.05,315,250,200,250,100,-180,0],[.1,205,205,.1,5,.1,.1,315,250,200,250,110,-180,1],[.2,210,210,.2,10,.15,.15,315,250,200,250,120,-180,2],[.3,215,215,.3,15,.2,.2,315,250,200,250,130,-180,3],[.4,220,220,.4,20,.25,.25,315,250,200,250,140,-180,4],[.5,225,225,.5,25,.3,.3,315,250,200,250,150,-180,5],[.6,230,230,.6,30,.35,.35,315,250,200,250,160,-168,5],[.7,235,235,.7,35,.4,.4,315,250,200,250,170,-168,5],[.8,240,240,.8,40,.45,.45,400,315,250,315,180,-168,5],[.9,245,245,.9,45,.5,.5,400,315,250,315,190,-168,5],[1,250,250,1,50,.55,.55,400,315,250,315,200,-156,5],[1.1,255,255,1.1,55,.6,.6,400,315,250,315,210,-156,5],[1.2,260,260,1.2,60,.65,.65,400,315,250,315,220,-156,5],[1.3,265,265,1.3,65,.7,.7,400,315,250,315,230,-156,5],[1.4,270,270,1.4,70,.75,.75,400,315,250,315,240,-144,5],[1.5,275,275,1.5,75,.8,.8,400,315,250,315,250,-144,5],[1.6,280,280,1.6,80,.85,.85,500,400,315,400,260,-144,5],[1.7,285,285,1.7,85,.9,.9,500,400,315,400,270,-144,5],[1.8,290,290,1.8,90,.95,.95,500,400,315,400,280,-132,5],[1.9,295,295,1.9,95,1,1,500,400,315,400,290,-132,5],[2,300,300,2,100,1.05,1.05,500,400,315,400,300,-132,5],[2.1,305,305,2.1,105,1.1,1.1,500,400,315,400,320,-132,5],[2.2,310,310,2.2,110,1.15,1.15,500,400,315,400,340,-120,5],[2.3,315,315,2.3,115,1.2,1.2,500,400,315,400,360,-120,5],[2.4,320,320,2.4,120,1.25,1.25,630,500,400,500,380,-120,5],[2.5,325,325,2.5,125,1.3,1.3,630,500,400,500,400,-120,5],[2.6,330,330,2.6,130,1.35,1.35,630,500,400,500,420,-108,5],[2.7,335,335,2.7,135,1.4,1.4,630,500,400,500,440,-108,5],[2.8,340,340,2.8,140,1.45,1.45,630,500,400,500,460,-108,5],[2.9,345,345,2.9,145,1.5,1.5,630,500,400,500,480,-108,5],[3,350,350,3,150,1.55,1.55,630,500,400,500,500,-96,6],[3.1,355,355,3.1,155,1.6,1.6,630,500,400,500,520,-96,6],[3.2,360,360,3.2,160,1.65,1.65,800,630,500,630,540,-96,6],[3.3,365,365,3.3,165,1.7,1.7,800,630,500,630,560,-96,6],[3.4,370,370,3.4,170,1.75,1.75,800,630,500,630,580,-84,6],[3.5,375,375,3.5,175,1.8,1.8,800,630,500,630,600,-84,6],[3.6,380,380,3.6,180,1.85,1.85,800,630,500,630,620,-84,6],[3.7,385,385,3.7,185,1.9,1.9,800,630,500,630,640,-84,6],[3.8,390,390,3.8,190,1.95,1.95,800,630,500,630,660,-72,6],[3.9,395,395,3.9,195,2,2,800,630,500,630,680,-72,6],[4,400,400,4,200,2.05,2.05,1e3,800,630,800,700,-72,6],[4.1,405,405,4.1,205,2.1,2.1,1e3,800,630,800,720,-72,6],[4.2,410,410,4.2,210,2.15,2.15,1e3,800,630,800,740,-60,6],[4.3,415,415,4.3,215,2.2,2.2,1e3,800,630,800,760,-60,6],[4.4,420,420,4.4,220,2.25,2.25,1e3,800,630,800,780,-60,6],[4.5,425,425,4.5,225,2.3,2.3,1e3,800,630,800,800,-60,6],[4.6,430,430,4.6,230,2.35,2.35,1e3,800,630,800,820,-48,6],[4.7,435,435,4.7,235,2.4,2.4,1e3,800,630,800,840,-48,6],[4.8,440,440,4.8,240,2.45,2.45,1250,1e3,800,1e3,860,-48,9],[4.9,445,445,4.9,245,2.5,2.5,1250,1e3,800,1e3,880,-48,9],[5,450,450,5,250,2.55,2.55,1250,1e3,800,1e3,900,-36,9],[5.5,455,455,5.5,255,2.6,2.6,1250,1e3,800,1e3,920,-36,9],[6,460,460,6,260,2.65,2.65,1250,1e3,800,1e3,940,-36,9],[6.5,465,465,6.5,265,2.7,2.7,1250,1e3,800,1e3,960,-36,9],[7,470,470,7,270,2.75,2.75,1250,1e3,800,1e3,980,-24,9],[7.5,475,475,7.5,275,2.8,2.8,1250,1e3,800,1e3,1e3,-24,9],[8,480,480,8,280,2.85,2.85,1600,1250,1e3,1250,1100,-24,9],[8.5,485,485,8.5,285,2.9,2.9,1600,1250,1e3,1250,1200,-24,9],[9,490,490,9,290,2.95,2.95,1600,1250,1e3,1250,1300,-12,9],[9.5,495,495,9.5,295,3,3,1600,1250,1e3,1250,1400,-12,9],[10,500,500,10,300,3.05,3.05,1600,1250,1e3,1250,1500,-12,9],[11,505,505,11,305,3.1,3.1,1600,1250,1e3,1250,1600,-12,9],[12,510,510,12,310,3.15,3.15,1600,1250,1e3,1250,1700,0,9],[13,515,515,13,315,3.2,3.2,1600,1250,1e3,1250,1800,0,9],[14,520,520,14,320,3.25,3.25,2e3,1600,1250,1600,1900,0,12],[15,525,525,15,325,3.3,3.3,2e3,1600,1250,1600,2e3,0,12],[16,530,530,16,330,3.35,3.35,2e3,1600,1250,1600,2100,12,12],[17,535,535,17,335,3.4,3.4,2e3,1600,1250,1600,2200,12,12],[18,540,540,18,340,3.45,3.45,2e3,1600,1250,1600,2300,12,12],[19,545,545,19,345,3.5,3.5,2e3,1600,1250,1600,2400,12,12],[20,550,550,20,350,3.55,3.55,2e3,1600,1250,1600,2500,24,12],[21,560,555,21,355,3.6,3.6,2e3,1600,1250,1600,2600,24,12],[22,570,560,22,360,3.65,3.65,2500,2e3,1600,2e3,2700,24,12],[23,580,565,23,365,3.7,3.7,2500,2e3,1600,2e3,2800,24,12],[24,590,570,24,370,3.75,3.75,2500,2e3,1600,2e3,2900,36,12],[25,600,575,25,375,3.8,3.8,2500,2e3,1600,2e3,3e3,36,12],[26,610,580,26,380,3.85,3.85,2500,2e3,1600,2e3,3100,36,12],[27,620,585,27,385,3.9,3.9,2500,2e3,1600,2e3,3200,36,12],[28,630,590,28,390,3.95,3.95,2500,2e3,1600,2e3,3300,48,12],[29,640,595,29,395,4,4,2500,2e3,1600,2e3,3400,48,12],[30,650,600,30,400,4.05,4.05,3150,2500,2e3,2500,3500,48,10],[31,660,610,31,405,4.1,4.1,3150,2500,2e3,2500,3600,48,10],[32,670,620,32,410,4.15,4.15,3150,2500,2e3,2500,3700,60,10],[33,680,630,33,415,4.2,4.2,3150,2500,2e3,2500,3800,60,10],[34,690,640,34,420,4.25,4.25,3150,2500,2e3,2500,3900,60,10],[35,700,650,35,425,4.3,4.3,3150,2500,2e3,2500,4e3,60,10],[36,710,660,36,430,4.35,4.35,3150,2500,2e3,2500,4100,72,10],[37,720,670,37,435,4.4,4.4,3150,2500,2e3,2500,4200,72,10],[38,730,680,38,440,4.45,4.45,4e3,3150,2500,3150,4300,72,11],[39,740,690,39,445,4.5,4.5,4e3,3150,2500,3150,4400,72,11],[40,750,700,40,450,4.55,4.55,4e3,3150,2500,3150,4500,84,11],[41,760,710,50,455,4.6,4.6,4e3,3150,2500,3150,4600,84,11],[42,770,720,60,460,4.65,4.65,4e3,3150,2500,3150,4700,84,11],[43,780,730,70,465,4.7,4.7,4e3,3150,2500,3150,4800,84,11],[44,790,740,80,470,4.75,4.75,4e3,3150,2500,3150,4900,96,11],[45,800,750,90,475,4.8,4.8,4e3,3150,2500,3150,5e3,96,11],[46,810,760,100,480,4.85,4.85,5e3,4e3,3150,4e3,5100,96,12],[47,820,770,110,485,4.9,4.9,5e3,4e3,3150,4e3,5200,96,12],[48,830,780,120,490,4.95,4.95,5e3,4e3,3150,4e3,5300,108,12],[49,840,790,130,495,5,5,5e3,4e3,3150,4e3,5400,108,12],[50,850,800,140,500,5.1,5.05,5e3,4e3,3150,4e3,5500,108,12],[52,860,810,150,505,5.2,5.1,5e3,4e3,3150,4e3,5600,108,12],[54,870,820,160,510,5.3,5.15,5e3,4e3,3150,4e3,5700,120,12],[56,880,830,170,515,5.4,5.2,5e3,4e3,3150,4e3,5800,120,12],[58,890,840,180,520,5.5,5.25,6300,5e3,4e3,5e3,5900,120,13],[60,900,850,190,525,5.6,5.3,6300,5e3,4e3,5e3,6e3,120,13],[62,910,860,200,530,5.7,5.35,6300,5e3,4e3,5e3,6100,132,13],[64,920,870,210,535,5.8,5.4,6300,5e3,4e3,5e3,6200,132,13],[66,930,880,220,540,5.9,5.45,6300,5e3,4e3,5e3,6300,132,13],[68,940,890,230,545,6,5.5,6300,5e3,4e3,5e3,6400,132,13],[70,950,900,240,550,6.1,5.55,6300,5e3,4e3,5e3,6500,144,13],[72,960,910,250,555,6.2,5.6,6300,5e3,4e3,5e3,6600,144,13],[74,970,920,260,560,6.3,5.65,8e3,6300,5e3,6300,6700,144,14],[76,980,930,270,565,6.4,5.7,8e3,6300,5e3,6300,6800,144,14],[78,990,940,280,570,6.5,5.75,8e3,6300,5e3,6300,6900,156,14],[80,1e3,950,290,575,6.6,5.8,8e3,6300,5e3,6300,7e3,156,14],[82,1e3,960,300,580,6.7,5.85,8e3,6300,5e3,6300,7100,156,14],[84,1e3,970,320,585,6.8,5.9,8e3,6300,5e3,6300,7200,156,14],[86,1e3,980,340,590,6.9,5.95,8e3,6300,5e3,6300,7300,168,14],[88,1e3,990,360,595,7,6,8e3,6300,5e3,6300,7400,168,14],[90,1e3,1e3,380,600,7.5,6.05,13500,8e3,6300,13500,7500,168,15],[92,1e3,1e3,400,605,8,6.1,13500,8e3,6300,13500,7600,168,15],[94,1e3,1e3,420,610,8.5,6.15,13500,8e3,6300,13500,7700,-180,15],[96,1e3,1e3,440,615,9,6.2,13500,8e3,6300,13500,7800,-180,15],[98,1e3,1e3,460,620,9.5,6.25,13500,8e3,6300,13500,7900,-180,15],[100,1e3,1e3,480,625,10,6.3,13500,8e3,6300,13500,8e3,-180,15],[100,1e3,1e3,500,630,10,6.35,13500,8e3,6300,13500,8e3,-180,15],[100,1e3,1e3,500,635,10,6.4,13500,8e3,6300,13500,8e3,-180,15]];static preDelayTime(t){return this.data[t][0]}static delayTime1(t){return this.data[t][1]}static delayTime2(t){return this.data[t][2]}static delayTime3(t){return this.data[t][3]}static delayTime4(t){return this.data[t][4]}static rate1(t){return this.data[t][5]}static rate2(t){return this.data[t][6]}static hfDamp(t){return this.data[t][7]}static cutoffFreq(t){return this.data[t][8]}static eqFreq(t){return this.data[t][9]}static lpf(t){return this.data[t][10]}static manual(t){return this.data[t][11]}static azimuth(t){return this.data[t][12]}static accl(t){return this.data[t][13]}},Hs=Math.PI/2,fA=-64,Fn=63,ms=Fn-fA,DA=new Float32Array(ms+1),wA=new Float32Array(ms+1);for(let t=fA;t<=Fn;t++){let e=(t-fA)/ms,A=t-fA;DA[A]=Math.cos(Hs*e),wA[A]=Math.sin(Hs*e)}function me(t){t.x1=t.x2=t.y1=t.y2=0}var Oe={b0:1,b1:0,b2:0,a0:1,a1:0,a2:0};function kt(t,e,A,s,n){let a=e.b0*t+e.b1*s.x1+e.b2*s.x2-e.a1*s.y1-e.a2*s.y2;s.x2=s.x1,s.x1=t,s.y2=s.y1,s.y1=a;let r=A.b0*a+A.b1*n.x1+A.b2*n.x2-A.a1*n.y1-A.a2*n.y2;return n.x2=n.x1,n.x1=a,n.y2=n.y1,n.y1=r,r}function rt(t,e,A){let s=e.b0*t+e.b1*A.x1+e.b2*A.x2-e.a1*A.y1-e.a2*A.y2;return A.x2=A.x1,A.x1=t,A.y2=A.y1,A.y1=s,s}function Bt(t,e,A,s,n){let a=Math.pow(10,e/40),r=2*Math.PI*A/s,o=Math.cos(r),i=Math.sin(r)/2*Math.sqrt((a+1/a)*(1/1-1)+2),g,l,B,C,I,E;n?(g=a*(a+1-(a-1)*o+2*Math.sqrt(a)*i),l=2*a*(a-1-(a+1)*o),B=a*(a+1-(a-1)*o-2*Math.sqrt(a)*i),C=a+1+(a-1)*o+2*Math.sqrt(a)*i,I=-2*(a-1+(a+1)*o),E=a+1+(a-1)*o-2*Math.sqrt(a)*i):(g=a*(a+1+(a-1)*o+2*Math.sqrt(a)*i),l=-2*a*(a-1+(a+1)*o),B=a*(a+1+(a-1)*o-2*Math.sqrt(a)*i),C=a+1-(a-1)*o+2*Math.sqrt(a)*i,I=2*(a-1-(a+1)*o),E=a+1-(a-1)*o-2*Math.sqrt(a)*i),t.b0=g/C,t.b1=l/C,t.b2=B/C,t.a0=1,t.a1=I/C,t.a2=E/C}var we={x1:0,x2:0,y1:0,y2:0},Nr=class{type=256;sendLevelToReverb=0;sendLevelToChorus=0;sendLevelToDelay=0;sampleRate;level=1;lowFreq=400;lowGain=5;hiFreq=8e3;hiGain=-12;m1Freq=1600;m1Q=.5;m1Gain=8;m2Freq=1e3;m2Q=.5;m2Gain=-8;lowCoeffs={...Oe};m1Coeffs={...Oe};m2Coeffs={...Oe};hiCoeffs={...Oe};lowStateL={...we};lowStateR={...we};m1StateL={...we};m1StateR={...we};m2StateL={...we};m2StateR={...we};hiStateL={...we};hiStateR={...we};constructor(t){this.sampleRate=t,this.reset(),this.updateCoefficients()}reset(){this.level=1,this.lowFreq=400,this.lowGain=5,this.hiGain=-12,this.hiFreq=8e3,this.m1Freq=1600,this.m1Q=.5,this.m1Gain=8,this.m2Freq=1e3,this.m2Q=.5,this.m2Gain=-8,me(this.lowStateL),me(this.lowStateR),me(this.m1StateL),me(this.m1StateR),me(this.m2StateL),me(this.m2StateR),me(this.hiStateL),me(this.hiStateR),this.updateCoefficients()}setParameter(t,e){switch(t){default:break;case 3:this.lowFreq=e===1?400:200;break;case 4:this.lowGain=e-64;break;case 5:this.hiFreq=e===1?8e3:4e3;break;case 6:this.hiGain=e-64;break;case 7:this.m1Freq=ct.eqFreq(e);break;case 8:this.m1Q=[.5,1,2,4,9][e]||1;break;case 9:this.m1Gain=e-64;break;case 10:this.m2Freq=ct.eqFreq(e);break;case 11:this.m2Q=[.5,1,2,4,9][e]||1;break;case 12:this.m2Gain=e-64;break;case 22:this.level=e/127;break}this.updateCoefficients()}process(t,e,A,s,n,a,r,o,i){let{level:g,sendLevelToChorus:l,sendLevelToDelay:B,sendLevelToReverb:C,lowCoeffs:I,lowStateL:E,lowStateR:y,m1Coeffs:k,m1StateL:p,m1StateR:R,m2StateL:b,m2StateR:M,m2Coeffs:S,hiCoeffs:Q,hiStateL:m,hiStateR:D}=this;for(let q=0;q<i;q++){let K=t[q],O=e[q];K=rt(K,I,E),O=rt(O,I,y),K=rt(K,k,p),O=rt(O,k,R),K=rt(K,S,b),O=rt(O,S,M),K=rt(K,Q,m),O=rt(O,Q,D);let Y=o+q;A[Y]+=K*g,s[Y]+=O*g;let H=.5*(K+O);n[q]+=H*C,a[q]+=H*l,r[q]+=H*B}}updateCoefficients(){Pr(this.lowCoeffs,this.lowFreq,this.lowGain/2,this.sampleRate),Os(this.m1Coeffs,this.m1Freq,this.m1Gain,this.m1Q,this.sampleRate),Os(this.m2Coeffs,this.m2Freq,this.m2Gain,this.m2Q,this.sampleRate),Tr(this.hiCoeffs,this.hiFreq,this.hiGain/2,this.sampleRate)}},Mn=1;function Os(t,e,A,s,n){let a=Math.pow(10,A/40),r=2*Math.PI*e/n,o=Math.cos(r),i=Math.sin(r)/(2*s),g=1+i*a,l=-2*o,B=1-i*a,C=1+i/a,I=-2*o,E=1-i/a;t.a0=1,t.a1=I/C,t.a2=E/C,t.b0=g/C,t.b1=l/C,t.b2=B/C}function Pr(t,e,A,s){let n=Math.pow(10,A/40),a=2*Math.PI*e/s,r=Math.cos(a),o=Math.sin(a)/2*Math.sqrt((n+1/n)*(1/Mn-1)+2),i=n*(n+1-(n-1)*r+2*Math.sqrt(n)*o),g=2*n*(n-1-(n+1)*r),l=n*(n+1-(n-1)*r-2*Math.sqrt(n)*o),B=n+1+(n-1)*r+2*Math.sqrt(n)*o,C=-2*(n-1+(n+1)*r),I=n+1+(n-1)*r-2*Math.sqrt(n)*o;t.a0=1,t.a1=C/B,t.a2=I/B,t.b0=i/B,t.b1=g/B,t.b2=l/B}function Tr(t,e,A,s){let n=Math.pow(10,A/40),a=2*Math.PI*e/s,r=Math.cos(a),o=Math.sin(a)/2*Math.sqrt((n+1/n)*(1/Mn-1)+2),i=n*(n+1+(n-1)*r+2*Math.sqrt(n)*o),g=-2*n*(n-1+(n+1)*r),l=n*(n+1+(n-1)*r-2*Math.sqrt(n)*o),B=n+1-(n-1)*r+2*Math.sqrt(n)*o,C=2*(n-1-(n+1)*r),I=n+1-(n-1)*r-2*Math.sqrt(n)*o;t.a0=1,t.a1=C/B,t.a2=I/B,t.b0=i/B,t.b1=g/B,t.b2=l/B}var Gt=8,XA=128,Ys=4,ZA=600,Ur=.9,qs=.35,vn=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=288;manual=620;rate=.85;depth=64/XA;reso=16/127;mix=1;lowGain=0;hiGain=0;prevInL;prevOutL;prevInR;prevOutR;lowShelfCoef={...Oe};highShelfCoef={...Oe};manualOffset=ZA;lowShelfStateL={x1:0,x2:0,y1:0,y2:0};lowShelfStateR={x1:0,x2:0,y1:0,y2:0};highShelfStateL={x1:0,x2:0,y1:0,y2:0};highShelfStateR={x1:0,x2:0,y1:0,y2:0};prevL=0;prevR=0;level=104/127;phase=qs;sampleRate;constructor(t){this.sampleRate=t,this.prevInL=new Float32Array(Gt),this.prevOutL=new Float32Array(Gt),this.prevInR=new Float32Array(Gt),this.prevOutR=new Float32Array(Gt),this.reset()}reset(){this.phase=qs,this.setManual(620),this.rate=.85,this.depth=64/XA,this.reso=16/127,this.mix=1,this.lowGain=0,this.hiGain=0,this.level=104/127,me(this.highShelfStateL),me(this.highShelfStateR),me(this.lowShelfStateL),me(this.lowShelfStateR),this.updateShelves(),this.clearAllPass()}process(t,e,A,s,n,a,r,o,i){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:B,level:C,manual:I,manualOffset:E,mix:y,lowShelfCoef:k,lowShelfStateR:p,lowShelfStateL:R,highShelfCoef:b,highShelfStateL:M,highShelfStateR:S,prevInL:Q,prevInR:m,prevOutL:D,prevOutR:q,sampleRate:K,depth:O}=this,{prevL:Y,prevR:H,phase:Z}=this,T=this.rate/this.sampleRate,F=this.reso*Ur;for(let u=0;u<i;u++){let x=kt(t[u],k,b,R,M),P=kt(e[u],k,b,p,S),te=2*Math.abs(Z-.5);(Z+=T)>=1&&(Z-=1);let W=E+I*(1-O*te),_=Math.tan(Math.PI*W/K),$=Math.max(-.9999,Math.min(.9999,(1-_)/(1+_))),ne=x+F*Y,ae=P+F*H;for(let Be=0;Be<Gt;Be++){let be=-$*ne+Q[Be]+$*D[Be];Q[Be]=ne,D[Be]=be,ne=be;let xe=-$*ae+m[Be]+$*q[Be];m[Be]=ae,q[Be]=xe,ae=xe}Y=ne,H=ae;let J=(x+ne*y)*C,ie=(P+ae*y)*C,pe=o+u;A[pe]+=J,s[pe]+=ie;let ve=(J+ie)*.5;n[u]+=ve*g,a[u]+=ve*l,r[u]+=ve*B}this.phase=Z,this.prevL=Y,this.prevR=H}setParameter(t,e){switch(t){default:break;case 3:this.setManual(ct.manual(e));break;case 4:this.rate=ct.rate1(e);break;case 5:this.depth=e/XA;break;case 6:this.reso=e/127;break;case 7:this.mix=e/127;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}setManual(t){t>1e3?(this.manualOffset=ZA*1.5*Ys,this.manual=t):(this.manualOffset=ZA,this.manual=t*Ys)}clearAllPass(){this.prevR=0,this.prevL=0;for(let t=0;t<Gt;t++)this.prevInL[t]=0,this.prevOutL[t]=0,this.prevInR[t]=0,this.prevOutR[t]=0}updateShelves(){Bt(this.lowShelfCoef,this.lowGain,200,this.sampleRate,!0),Bt(this.highShelfCoef,this.hiGain,4e3,this.sampleRate,!1)}},Js=Math.PI*2,xr=.935,Hr=2,Or=.01,Ks=127,Yr=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=294;modWave=1;modRate=3.05;modDepth=96;lowGain=0;hiGain=0;level=Ks/127;currentPan=0;phase=0;lsCoeffs={...Oe};hsCoeffs={...Oe};lsStateR={...we};lsStateL={...we};hsStateR={...we};hsStateL={...we};sampleRate;constructor(t){this.sampleRate=t,this.reset()}reset(){this.modWave=1,this.modRate=3.05,this.modDepth=96,this.lowGain=0,this.hiGain=0,this.level=Ks/127,this.currentPan=0,this.phase=0,me(this.hsStateR),me(this.hsStateL),me(this.lsStateR),me(this.lsStateL),this.updateShelves()}process(t,e,A,s,n,a,r,o,i){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:B,level:C,lsCoeffs:I,lsStateL:E,lsStateR:y,hsCoeffs:k,hsStateR:p,hsStateL:R,modWave:b}=this,M=Math.pow(this.modDepth/127,Hr),S=2/(1+M)*xr,Q=this.modRate/this.sampleRate,{phase:m,currentPan:D}=this;for(let q=0;q<i;q++){let K=kt(t[q],I,k,E,R),O=kt(e[q],I,k,y,p),Y;switch(b){default:Y=1-4*Math.abs(m-.5);break;case 1:Y=m>.5?-1:-Math.cos((m-.75)*Js);break;case 2:Y=Math.sin(Js*m);break;case 3:Y=1-2*m;break;case 4:Y=2*m-1;break}(m+=Q)>=1&&(m-=1),D+=(Y-D)*Or;let H=D*M,Z=(1-H)*.5*S,T=(1+H)*.5*S,F=K*C*Z,u=O*C*T,x=o+q;A[x]+=F,s[x]+=u;let P=(F+u)*.5;n[q]+=P*g,a[q]+=P*l,r[q]+=P*B}this.currentPan=D,this.phase=m}setParameter(t,e){switch(t){default:break;case 3:this.modWave=e;break;case 4:this.modRate=ct.rate1(e);break;case 5:this.modDepth=e;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}updateShelves(){Bt(this.lsCoeffs,this.lowGain,200,this.sampleRate,!0),Bt(this.hsCoeffs,this.hiGain,4e3,this.sampleRate,!1)}},Vs=96,qr=.1,Jr=.1,Kr=27,Vr=28,Xr=-28,Zr=400,_r=.62,Wr=.005,Gn=5,Xs=Gn*.5,Ln=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=289;filType=1;sens=0;manual=68;peak=62;rate=2.05;depth=72;polarity=1;pan=0;lowGain=0;hiGain=0;level=Vs/127;coeffs={...Oe};state={...we};hpCoeffs={...Oe};hpState={...we};phase=0;lsCoeffs={...Oe};hsCoeffs={...Oe};lsState={...we};hsState={...we};sampleRate;lastFc=this.manual;attackCoeff;releaseCoeff;envelope=0;constructor(t){this.sampleRate=t,this.attackCoeff=Math.exp(-1/(qr*t)),this.releaseCoeff=Math.exp(-1/(Jr*t)),this.reset()}reset(){this.filType=1,this.sens=0,this.setManual(68),this.peak=62,this.rate=2.05,this.depth=72,this.polarity=1,this.lowGain=0,this.hiGain=0,this.pan=0,this.level=Vs/127,this.phase=.2,this.lastFc=this.manual,me(this.hsState),me(this.lsState),me(this.state),me(this.hpState),this.updateShelves()}process(t,e,A,s,n,a,r,o,i){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:B,level:C,lsCoeffs:I,lsState:E,hsCoeffs:y,hsState:k,coeffs:p,state:R,sampleRate:b,filType:M,manual:S,pan:Q,attackCoeff:m,releaseCoeff:D,hpState:q,hpCoeffs:K}=this,{phase:O,lastFc:Y,envelope:H}=this,Z=this.rate/this.sampleRate,T=Math.pow(10,this.peak/127*Vr/20),F=Math.pow(10,this.peak/127*Xr/20),u=this.polarity===0?-1:Gn,x=this.depth/127*u,P=this.sens/127,te=Q+64|0,W=DA[te],_=wA[te];for(let $=0;$<i;$++){let ne=kt((t[$]+e[$])*.5,I,y,E,k),ae=Math.abs(ne);H=ae>H?m*H+(1-m)*ae:D*H+(1-D)*ae;let J=2*Math.abs(O-.5)*x;(O+=Z)>=1&&(O-=1);let ie=J>=Xs||u<0?1:Math.sin(J*Math.PI/(2*Xs)),pe=S*(1+P*H*Kr),ve=Math.max(20,pe*(1+ie*J));Y+=(Math.max(10,ve)-Y)*Wr,zr(p,Y,T,b);let Be=ne;M===1&&($r(K,Zr,F,b),Be=rt(Be,K,q));let be=rt(Be,p,R)*C,xe=be*W,ht=be*_,lt=o+$;A[lt]+=xe,s[lt]+=ht,n[$]+=be*g,a[$]+=be*l,r[$]+=be*B}this.phase=O,this.lastFc=Y,this.envelope=H}setParameter(t,e){switch(t){default:break;case 3:this.filType=e;break;case 4:this.sens=e;break;case 5:this.setManual(e);break;case 6:this.peak=e;break;case 7:this.rate=ct.rate1(e);break;case 8:this.depth=e;break;case 9:this.polarity=e;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 21:this.pan=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}setManual(t){let e=t*_r,A=ct.manual(Math.floor(e)),s=ct.manual(Math.ceil(e)),n=e-Math.floor(e);this.manual=A+(s-A)*n}updateShelves(){Bt(this.lsCoeffs,this.lowGain,200,this.sampleRate,!0),Bt(this.hsCoeffs,this.hiGain,4e3,this.sampleRate,!1)}};function zr(t,e,A,s){let n=2*Math.PI*e/s,a=Math.cos(n),r=Math.sin(n)/(2*A),o=1-a,i=o/2,g=i,l=1+r,B=-2*a,C=1-r;t.a0=1,t.a1=B/l,t.a2=C/l,t.b0=i/l,t.b1=o/l,t.b2=g/l}function $r(t,e,A,s){let n=2*Math.PI*e/s,a=Math.cos(n),r=Math.sin(n)/(2*A),o=(1+a)/2,i=-(1+a),g=o,l=1+r,B=-2*a,C=1-r;t.a0=1,t.a1=B/l,t.a2=C/l,t.b0=o/l,t.b1=i/l,t.b2=g/l}var Zs=127,jr=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=4360;phPan=0;awPan=127;level=Zs/127;phaser;autoWah;bufferPh;bufferAw;constructor(t,e){this.phaser=new vn(t),this.autoWah=new Ln(t),this.bufferAw=new Float32Array(e),this.bufferPh=new Float32Array(e),this.phaser.sendLevelToReverb=0,this.phaser.sendLevelToChorus=0,this.phaser.sendLevelToDelay=0,this.autoWah.sendLevelToReverb=0,this.autoWah.sendLevelToChorus=0,this.autoWah.sendLevelToDelay=0,this.reset()}reset(){this.phPan=0,this.awPan=127,this.level=Zs/127,this.phaser.reset(),this.autoWah.reset(),this.phaser.setParameter(22,127),this.autoWah.setParameter(22,127)}process(t,e,A,s,n,a,r,o,i){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:B,level:C}=this,{bufferPh:I,bufferAw:E}=this;this.bufferPh.fill(0),this.phaser.process(t,t,I,I,I,I,I,0,i),this.bufferAw.fill(0),this.autoWah.process(e,e,E,E,E,E,E,0,i);let y=this.phPan|0,k=DA[y],p=wA[y],R=this.awPan|0,b=DA[R],M=wA[R];for(let S=0;S<i;S++){let Q=I[S]*.5*C,m=E[S]*.5*C,D=Q*k+m*b,q=Q*p+m*M,K=o+S;A[K]+=D,s[K]+=q;let O=(D+q)*.5;n[S]+=O*g,a[S]+=O*l,r[S]+=O*B}}setParameter(t,e){if(t>=3&&t<=7){this.phaser.setParameter(t,e);return}if(t>=8&&t<=14){this.autoWah.setParameter(t-5,e);return}switch(t){default:break;case 18:this.phPan=e;break;case 19:this.phaser.setParameter(22,e);break;case 20:this.awPan=e;break;case 21:this.autoWah.setParameter(22,e);break;case 22:this.level=e/127;break}}},_s=127,Ws=Math.PI*2,ei=.01,ti=class{sendLevelToReverb=40/127;sendLevelToChorus=0;sendLevelToDelay=0;type=293;modWave=1;modRate=3.05;modDepth=96;lowGain=0;hiGain=0;level=_s/127;phase=0;currentGain=1;lsCoeffs={...Oe};hsCoeffs={...Oe};lsStateR={...we};lsStateL={...we};hsStateR={...we};hsStateL={...we};sampleRate;constructor(t){this.sampleRate=t,this.reset()}reset(){this.modWave=1,this.modRate=3.05,this.modDepth=96,this.lowGain=0,this.hiGain=0,this.level=_s/127,this.phase=0,this.currentGain=1,me(this.hsStateR),me(this.hsStateL),me(this.lsStateR),me(this.lsStateL),this.updateShelves()}process(t,e,A,s,n,a,r,o,i){let{sendLevelToReverb:g,sendLevelToChorus:l,sendLevelToDelay:B,level:C,lsCoeffs:I,lsStateL:E,lsStateR:y,hsCoeffs:k,hsStateR:p,hsStateL:R,modDepth:b,modWave:M}=this,S=this.modRate/this.sampleRate,{currentGain:Q,phase:m}=this;for(let D=0;D<i;D++){let q=kt(t[D],I,k,E,R),K=kt(e[D],I,k,y,p),O;switch(M){default:O=1-4*Math.abs(m-.5);break;case 1:O=m>.5?-1:-Math.cos((m-.75)*Ws);break;case 2:O=Math.sin(Ws*m);break;case 3:O=1-2*m;break;case 4:O=2*m-1;break}(m+=S)>=1&&(m-=1);let Y=1-(O/2+.5)*(b/127);Q+=(Y-Q)*ei;let H=q*C*Q,Z=K*C*Q,T=o+D;A[T]+=H,s[T]+=Z;let F=(H+Z)*.5;n[D]+=F*g,a[D]+=F*l,r[D]+=F*B}this.phase=m,this.currentGain=Q}setParameter(t,e){switch(t){default:break;case 3:this.modWave=e;break;case 4:this.modRate=ct.rate1(e);break;case 5:this.modDepth=e;break;case 19:this.lowGain=e-64;break;case 20:this.hiGain=e-64;break;case 22:this.level=e/127;break}this.updateShelves()}updateShelves(){Bt(this.lsCoeffs,this.lowGain,200,this.sampleRate,!0),Bt(this.hsCoeffs,this.hiGain,4e3,this.sampleRate,!1)}},Ai=[Rn,Nr,vn,Yr,Ln,jr,ti],si=class{preDelay=0;preLPF=.5;inputDiffusion1=.75;inputDiffusion2=.625;decay=.5;decayDiffusion1=.7;decayDiffusion2=.5;damping=.005;excursionRate=.1;excursionDepth=.2;gain=1;sampleRate;lp1=0;lp2=0;lp3=0;excPhase=0;pDWrite=0;taps;pDelay;pDLength;delays=new Array;constructor(t){this.sampleRate=t,this.pDLength=t,this.pDelay=new Float32Array(this.pDLength);for(let e of[.004771345,.003595309,.012734787,.009307483,.022579886,.149625349,.060481839,.1249958,.030509727,.141695508,.089244313,.106280031])this.makeDelayLine(e);this.taps=Int16Array.from([.008937872,.099929438,.064278754,.067067639,.066866033,.006283391,.035818689,.011861161,.121870905,.041262054,.08981553,.070931756,.011256342,.004065724],e=>Math.round(e*this.sampleRate))}process(t,e,A,s,n){let a=this.preDelay|0,r=this.inputDiffusion1,o=this.inputDiffusion2,i=this.decay,g=this.decayDiffusion1,l=this.decayDiffusion2,B=1-this.damping,C=this.excursionRate/this.sampleRate,I=this.excursionDepth*this.sampleRate/1e3,E=this.pDWrite;for(let y=0;y<n;y++)this.pDelay[(E+y)%this.pDLength]=t[y];for(let y=0;y<n;y++){this.lp1+=this.preLPF*(this.pDelay[(this.pDLength+this.pDWrite-a+y)%this.pDLength]-this.lp1);let k=this.writeDelay(0,this.lp1-r*this.readDelay(0));k=this.writeDelay(1,r*(k-this.readDelay(1))+this.readDelay(0)),k=this.writeDelay(2,r*k+this.readDelay(1)-o*this.readDelay(2)),k=this.writeDelay(3,o*(k-this.readDelay(3))+this.readDelay(2));let p=o*k+this.readDelay(3),R=I*(1+Math.cos(this.excPhase*6.28)),b=I*(1+Math.sin(this.excPhase*6.2847)),M=this.writeDelay(4,p+i*this.readDelay(11)+g*this.readDelayCAt(4,R));this.writeDelay(5,this.readDelayCAt(4,R)-g*M),this.lp2+=B*(this.readDelay(5)-this.lp2),M=this.writeDelay(6,i*this.lp2-l*this.readDelay(6)),this.writeDelay(7,this.readDelay(6)+l*M),M=this.writeDelay(8,p+i*this.readDelay(7)+g*this.readDelayCAt(8,b)),this.writeDelay(9,this.readDelayCAt(8,b)-g*M),this.lp3+=B*(this.readDelay(9)-this.lp3),M=this.writeDelay(10,i*this.lp3-l*this.readDelay(10)),this.writeDelay(11,this.readDelay(10)+l*M);let S=this.readDelayAt(9,this.taps[0])+this.readDelayAt(9,this.taps[1])-this.readDelayAt(10,this.taps[2])+this.readDelayAt(11,this.taps[3])-this.readDelayAt(5,this.taps[4])-this.readDelayAt(6,this.taps[5])-this.readDelayAt(7,this.taps[6]),Q=y+s;e[Q]+=S*this.gain;let m=this.readDelayAt(5,this.taps[7])+this.readDelayAt(5,this.taps[8])-this.readDelayAt(6,this.taps[9])+this.readDelayAt(7,this.taps[10])-this.readDelayAt(9,this.taps[11])-this.readDelayAt(10,this.taps[12])-this.readDelayAt(11,this.taps[13]);A[Q]+=m*this.gain,this.excPhase+=C;for(let D=0,q=this.delays[0];D<this.delays.length;q=this.delays[++D])q[1]=q[1]+1&q[3],q[2]=q[2]+1&q[3]}this.pDWrite=(E+n)%this.pDLength}makeDelayLine(t){let e=Math.round(t*this.sampleRate),A=2**Math.ceil(Math.log2(e));this.delays.push([new Float32Array(A),e-1,0,A-1])}writeDelay(t,e){return this.delays[t][0][this.delays[t][1]]=e}readDelay(t){return this.delays[t][0][this.delays[t][2]]}readDelayAt(t,e){let A=this.delays[t];return A[0][A[2]+e&A[3]]}readDelayCAt(t,e){let A=this.delays[t],s=e-~~e,n=A[3],a=~~e+A[2]-1,r=A[0][a++&n],o=A[0][a++&n],i=A[0][a++&n],g=A[0][a&n],l=(3*(o-i)-r+g)/2,B=2*i+r-(5*o+g)/2,C=(i-r)/2;return((l*s+B)*s+C)*s+o}},Xt=class{feedback=0;gain=1;buffer;bufferLength;writeIndex=0;constructor(t){this.buffer=new Float32Array(t),this.bufferLength=this.buffer.length,this._time=t-5}_time;get time(){return this._time}set time(t){this._time=Math.min(this.bufferLength,t)|0}clear(){this.buffer.fill(0)}process(t,e,A){let s=this.writeIndex,n=this._time,a=this.buffer,r=this.bufferLength,o=this.feedback,i=this.gain;for(let g=0;g<A;g++){let l=s-n;l<0&&(l+=r);let B=a[l];e[g]=B*i,a[s]=t[g]+B*o,++s>=r&&(s=0)}this.writeIndex=s}},ni=1.5,ai=class{dattorro;delayLeft;delayRight;delayLeftOutput;delayRightOutput;delayLeftInput;delayPreLPF;sampleRate;preLPFfc=8e3;preLPFa=0;preLPFz=0;characterTimeCoefficient=1;characterGainCoefficient=1;characterLPFCoefficient=0;delayGain=1;panDelayFeedback=0;constructor(t,e){this.sampleRate=t,this.delayLeftOutput=new Float32Array(e),this.delayRightOutput=new Float32Array(e),this.delayLeftInput=new Float32Array(e),this.delayPreLPF=new Float32Array(e),this.dattorro=new si(t),this.delayLeft=new Xt(t),this.delayRight=new Xt(t)}_delayFeedback=0;get delayFeedback(){return this._delayFeedback}set delayFeedback(t){this._delayFeedback=t,this.updateFeedback()}_character=0;get character(){return this._character}set character(t){switch(this._character=t,this.dattorro.damping=.005,this.characterTimeCoefficient=1,this.characterGainCoefficient=1,this.characterLPFCoefficient=0,this.dattorro.inputDiffusion1=.75,this.dattorro.inputDiffusion2=.625,this.dattorro.decayDiffusion1=.7,this.dattorro.decayDiffusion2=.5,this.dattorro.excursionRate=.5,this.dattorro.excursionDepth=.7,t){case 0:this.dattorro.damping=.85,this.characterTimeCoefficient=.9,this.characterGainCoefficient=.9,this.characterLPFCoefficient=.2;break;case 1:this.dattorro.damping=.2,this.characterGainCoefficient=.7,this.characterTimeCoefficient=1,this.dattorro.decayDiffusion2=.64,this.dattorro.decayDiffusion1=.6,this.characterLPFCoefficient=.2;break;case 2:this.dattorro.damping=.56,this.characterGainCoefficient=.75,this.characterTimeCoefficient=1,this.dattorro.decayDiffusion2=.64,this.dattorro.decayDiffusion1=.6,this.characterLPFCoefficient=.1;break;case 3:this.dattorro.damping=.3,this.characterGainCoefficient=1.25,this.characterTimeCoefficient=1.3,this.characterLPFCoefficient=0,this.dattorro.decayDiffusion2=.7,this.dattorro.decayDiffusion1=.66;break;case 4:this.characterGainCoefficient=1,this.characterTimeCoefficient=1.2,this.characterLPFCoefficient=.1,this.dattorro.damping=.1,this.dattorro.decayDiffusion2=.69,this.dattorro.decayDiffusion1=.67;break;case 5:this.characterGainCoefficient=.75,this.dattorro.damping=.65,this.characterTimeCoefficient=.5;break}this.updateTime(),this.updateGain(),this.updateLowpass(),this.updateFeedback(),this.delayLeft.clear(),this.delayRight.clear()}_time=0;get time(){return this._time}set time(t){this._time=t,this.updateTime()}_preDelayTime=0;get preDelayTime(){return this._preDelayTime}set preDelayTime(t){this._preDelayTime=t,this.dattorro.preDelay=t/1e3*this.sampleRate}_level=0;get level(){return this._level}set level(t){this._level=t,this.updateGain()}_preLowpass=0;get preLowpass(){return this._preLowpass}set preLowpass(t){this._preLowpass=t,this.preLPFfc=8e3*.63**this._preLowpass;let e=Math.exp(-2*Math.PI*this.preLPFfc/this.sampleRate);this.preLPFa=1-e,this.updateLowpass()}process(t,e,A,s,n){switch(this._character){default:this.dattorro.process(t,e,A,s,n);return;case 6:{let a;if(this._preLowpass>0){let i=this.delayPreLPF,g=this.preLPFz,l=this.preLPFa;for(let B=0;B<n;B++){let C=t[B];g+=l*(C-g),i[B]=g}this.preLPFz=g,a=i}else a=t;this.delayLeft.process(a,this.delayLeftOutput,n);let r=this.delayGain,o=this.delayLeftOutput;for(let i=0,g=s;i<n;i++,g++){let l=o[i]*r;A[g]+=l,e[g]+=l}return}case 7:{let a;if(this._preLowpass>0){let B=this.delayPreLPF,C=this.preLPFz,I=this.preLPFa;for(let E=0;E<n;E++){let y=t[E];C+=I*(y-C),B[E]=C}this.preLPFz=C,a=B}else a=t;let r=this.panDelayFeedback,{delayLeftInput:o,delayLeftOutput:i,delayRightOutput:g}=this;for(let B=0;B<n;B++)o[B]=a[B]+g[B]*r;this.delayLeft.process(o,i,n),this.delayRight.process(i,g,n);let l=this.delayGain;for(let B=0,C=s;B<n;B++,C++)e[C]+=i[B]*l,A[C]+=g[B]*l;return}}}getSnapshot(){return{level:this._level,preLowpass:this._preLowpass,character:this._character,time:this._time,delayFeedback:this._delayFeedback,preDelayTime:this._preDelayTime}}updateFeedback(){let t=1-(1-this._delayFeedback/127)**1.9;this._character===6?this.delayLeft.feedback=t*.73:(this.delayLeft.feedback=this.delayRight.feedback=0,this.panDelayFeedback=t*.73)}updateLowpass(){this.dattorro.preLPF=Math.min(1,.1+(7-this.preLowpass)/14+this.characterLPFCoefficient)}updateGain(){this.dattorro.gain=this._level/345*this.characterGainCoefficient,this.delayGain=this._level/127*ni}updateTime(){let t=this._time/127;this.dattorro.decay=this.characterTimeCoefficient*(.05+.65*t);let e=Math.max(21,t*this.sampleRate*.4468|0);this.character===7?this.delayRight.time=this.delayLeft.time=Math.floor(e/2):this.delayLeft.time=e}},ri=1.3,ii=class{preLPFfc=8e3;preLPFa=0;preLPFz=0;leftDelayBuffer;rightDelayBuffer;sampleRate;phase=0;write=0;gain=.5;reverbGain=0;delayGain=0;depthSamples=0;delaySamples=1;rateInc=0;feedbackGain=0;constructor(t,e){this.sampleRate=t,this.leftDelayBuffer=new Float32Array(t),this.rightDelayBuffer=new Float32Array(t),this.preLowpass=0}_sendLevelToReverb=0;get sendLevelToReverb(){return this._sendLevelToReverb}set sendLevelToReverb(t){this._sendLevelToReverb=t,this.reverbGain=t/127}_sendLevelToDelay=0;get sendLevelToDelay(){return this._sendLevelToDelay}set sendLevelToDelay(t){this._sendLevelToDelay=t,this.delayGain=t/127}_preLowpass=0;get preLowpass(){return this._preLowpass}set preLowpass(t){this._preLowpass=t,this.preLPFfc=8e3*.63**this._preLowpass;let e=Math.exp(-2*Math.PI*this.preLPFfc/this.sampleRate);this.preLPFa=1-e}_depth=0;get depth(){return this._depth}set depth(t){this._depth=t,this.depthSamples=t/127*.025*this.sampleRate}_delay=0;get delay(){return this._delay}set delay(t){this._delay=t,this.delaySamples=Math.max(1,t/127*.025*this.sampleRate)}_feedback=0;get feedback(){return this._feedback}set feedback(t){this._feedback=t,this.feedbackGain=t*.00763}_rate=0;get rate(){return this._rate}set rate(t){this._rate=t;let e=t*.122;this.rateInc=e/this.sampleRate}_level=64;get level(){return this._level}set level(t){this.gain=t/127*ri,this._level=t}process(t,e,A,s,n,a,r){let o=this.leftDelayBuffer,i=this.rightDelayBuffer,g=this.rateInc,l=o.length,B=this.depthSamples,C=this.delaySamples,I=this.gain,E=this.reverbGain,y=this.delayGain,k=this.feedbackGain,p=this._preLowpass>0,R=this.phase,b=this.write,M=this.preLPFz,S=this.preLPFa;for(let Q=0;Q<r;Q++){let m=t[Q];p&&(M+=S*(m-M),m=M);let D=2*Math.abs(R-.5),q=Math.max(1,Math.min(C+D*B,l)),K=b-q;K<0&&(K+=l);let O=K|0,Y=O+1;Y>=l&&(Y-=l);let H=K-O,Z=o[O]*(1-H)+o[Y]*H;o[b]=m+Z*k;let T=Math.max(1,Math.min(C+(1-D)*B,l)),F=b-T;F<0&&(F+=l),O=F|0,Y=O+1,Y>=l&&(Y-=l),H=F-O;let u=i[O]*(1-H)+i[Y]*H,x=Q+a;e[x]+=Z*I,A[x]+=u*I;let P=(Z+u)/2;s[Q]+=P*E,n[Q]+=P*y,i[b]=m+u*k,++b>=l&&(b=0),(R+=g)>=1&&(R-=1)}this.write=b,this.phase=R,this.preLPFz=M}getSnapshot(){return{preLowpass:this._preLowpass,depth:this._depth,delay:this._delay,sendLevelToDelay:this._sendLevelToDelay,sendLevelToReverb:this._sendLevelToReverb,rate:this._rate,feedback:this._feedback,level:this._level}}},oi=[{start:1,end:20,timeStart:.1,resolution:.1},{start:20,end:35,timeStart:2,resolution:.2},{start:35,end:45,timeStart:5,resolution:.5},{start:45,end:55,timeStart:10,resolution:1},{start:55,end:70,timeStart:20,resolution:2},{start:70,end:80,timeStart:50,resolution:5},{start:80,end:90,timeStart:100,resolution:10},{start:90,end:105,timeStart:200,resolution:20},{start:105,end:116,timeStart:500,resolution:50}],gi=1.66,Ii=class{preLPFfc=8e3;preLPFa=0;preLPFz=0;delayLeft;delayRight;delayCenter;sampleRate;delayCenterOutput;delayPreLPF;delayCenterTime;delayLeftMultiplier=.04;delayRightMultiplier=.04;gain=0;reverbGain=0;constructor(t,e){this.sampleRate=t,this.delayCenterOutput=new Float32Array(e),this.delayPreLPF=new Float32Array(e),this.delayCenterTime=.34*t,this.delayCenter=new Xt(t),this.delayLeft=new Xt(t),this.delayRight=new Xt(t)}_sendLevelToReverb=0;get sendLevelToReverb(){return this._sendLevelToReverb}set sendLevelToReverb(t){this._sendLevelToReverb=t,this.reverbGain=t/127}_preLowpass=0;get preLowpass(){return this._preLowpass}set preLowpass(t){this._preLowpass=t,this.preLPFfc=8e3*.63**this._preLowpass;let e=Math.exp(-2*Math.PI*this.preLPFfc/this.sampleRate);this.preLPFa=1-e}_levelRight=0;get levelRight(){return this._levelRight}set levelRight(t){this._levelRight=t,this.updateGain()}_level=64;get level(){return this._level}set level(t){this._level=t,this.gain=t/127*gi}_levelCenter=127;get levelCenter(){return this._levelCenter}set levelCenter(t){this._levelCenter=t,this.updateGain()}_levelLeft=0;get levelLeft(){return this._levelLeft}set levelLeft(t){this._levelLeft=t,this.updateGain()}_feedback=16;get feedback(){return this._feedback}set feedback(t){this._feedback=t,this.delayLeft.feedback=this.delayRight.feedback=0,this.delayCenter.feedback=(t-64)/66}_timeRatioRight=0;get timeRatioRight(){return this._timeRatioRight}set timeRatioRight(t){this._timeRatioRight=t,this.delayRightMultiplier=t*(100/2400),this.delayRight.time=this.delayCenterTime*this.delayRightMultiplier}_timeRatioLeft=0;get timeRatioLeft(){return this._timeRatioLeft}set timeRatioLeft(t){this._timeRatioLeft=t,this.delayLeftMultiplier=t*(100/2400),this.delayLeft.time=this.delayCenterTime*this.delayLeftMultiplier}_timeCenter=12;get timeCenter(){return this._timeCenter}set timeCenter(t){this._timeCenter=t;let e=.1;for(let A of oi)if(t>=A.start&&t<A.end){e=A.timeStart+(t-A.start)*A.resolution;break}this.delayCenterTime=Math.max(2,this.sampleRate*(e/1e3)),this.delayCenter.time=this.delayCenterTime,this.delayLeft.time=this.delayCenterTime*this.delayLeftMultiplier,this.delayRight.time=this.delayCenterTime*this.delayRightMultiplier}process(t,e,A,s,n,a){let r;if(this._preLowpass>0){let B=this.delayPreLPF,C=this.preLPFz,I=this.preLPFa;for(let E=0;E<a;E++){let y=t[E];C+=I*(y-C),B[E]=C}this.preLPFz=C,r=B}else r=t;let{gain:o,reverbGain:i}=this;this.delayCenter.process(r,this.delayCenterOutput,a);let g=this.delayCenterOutput;for(let B=0,C=n;B<a;B++,C++){let I=g[B];s[B]+=I*i;let E=I*o;e[C]+=E,A[C]+=E}for(let B=0;B<a;B++)g[B]+=t[B];let l=this.delayPreLPF;this.delayLeft.process(g,l,a);for(let B=0,C=n;B<a;B++,C++){let I=l[B];e[C]+=I*o,s[B]+=I*i}this.delayRight.process(g,l,a);for(let B=0,C=n;B<a;B++,C++){let I=l[B];A[C]+=I*o,s[B]+=I*i}}getSnapshot(){return{level:this._level,preLowpass:this._preLowpass,timeCenter:this._timeCenter,timeRatioRight:this._timeRatioRight,timeRatioLeft:this._timeRatioLeft,levelCenter:this._levelCenter,levelLeft:this._levelLeft,levelRight:this._levelRight,feedback:this._feedback,sendLevelToReverb:this._sendLevelToReverb}}updateGain(){this.delayCenter.gain=this._levelCenter/127,this.delayLeft.gain=this._levelLeft/127,this.delayRight.gain=this._levelRight/127}},ci={gain:1,pan:0,keyShift:0,fineTune:0,system:"gs"};function hi(t,e){this.midiParameters[t]=e;for(let A of this.midiChannels)A.updateInternalParams();this.callEvent("globalParamChange",{parameter:t,value:e})}function li(t){this.setMIDIParameter("gain",1),this.setMIDIParameter("pan",0),this.setMIDIParameter("keyShift",0),this.setMIDIParameter("fineTune",0),this.setMIDIParameter("system",t)}var Ci=.01,Bi=.05,Ei=class{voices=[];midiChannels=[];maxBufferSize;voiceBuffer;insertionInputL;insertionInputR;reverbInput;chorusInput;delayInput;delayActive=!1;soundBankManager=new Fr(this.updatePresetList.bind(this));keyModifierManager=new wa;sampleRate;tunings=new Float32Array(16384).fill(-1);midiParameters={...ci};systemParameters={...on};currentTime=0;defaultPreset;drumPreset;gainSmoothingFactor;panSmoothingFactor;eventCallbackHandler;missingPresetHandler;cachedVoices=new Map;setSystemParameter=Fa.bind(this);systemExclusive=Lr.bind(this);reverbProcessor;chorusProcessor;delayProcessor;customChannelNumbers=!1;setMIDIParameter=hi.bind(this);resetMIDIParameters=li.bind(this);insertionFallback=new Rn;insertionProcessor=this.insertionFallback;insertionEffects=new Map;insertionActive=!1;portSelectChannelOffset=0;insertionParams=new Uint8Array(23).fill(255);lastPriorityAssignmentTime=0;eventQueue=[];sampleTime;constructor(t,e,A,s){this.eventCallbackHandler=t,this.missingPresetHandler=e,this.sampleRate=A,this.sampleTime=1/A,this.currentTime=s.initialTime,this.setSystemParameter("effectsEnabled",s.effectsEnabled),this.setSystemParameter("eventsEnabled",s.eventsEnabled),this.maxBufferSize=s.maxBufferSize,this.gainSmoothingFactor=Ci*(44100/A),this.panSmoothingFactor=Bi*(44100/A),fs.initCache(this.sampleRate);let n=this.maxBufferSize;this.reverbProcessor=s.reverbProcessor??new ai(A,n),this.chorusProcessor=s.chorusProcessor??new ii(A,n),this.delayProcessor=s.delayProcessor??new Ii(A,n),this.voiceBuffer=new Float32Array(n),this.insertionInputL=new Float32Array(n),this.insertionInputR=new Float32Array(n),this.reverbInput=new Float32Array(n),this.chorusInput=new Float32Array(n),this.delayInput=new Float32Array(n);for(let a of Ai)this.registerInsertionProcessor(a);this.resetInsertionParams(),this.allocateNewVoices(this.systemParameters.voiceCap)}_voiceCount=0;get voiceCount(){return this._voiceCount}controllerChange(t,e,A){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.controllerChange(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].controllerChange(e,A)}noteOn(t,e,A){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.noteOn(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].noteOn(e,A)}noteOff(t,e){if(this.customChannelNumbers){for(let A of this.midiChannels)A.midiParameters.rxChannel===t&&A.noteOff(e);return}this.midiChannels[t+this.portSelectChannelOffset].noteOff(e)}polyPressure(t,e,A){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.polyPressure(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].polyPressure(e,A)}channelPressure(t,e){if(this.customChannelNumbers){for(let A of this.midiChannels)A.midiParameters.rxChannel===t&&A.setMIDIParameter("pressure",e);return}this.midiChannels[t+this.portSelectChannelOffset].setMIDIParameter("pressure",e)}pitchWheel(t,e,A=-1){if(this.customChannelNumbers){for(let s of this.midiChannels)s.midiParameters.rxChannel===t&&s.pitchWheel(e,A);return}this.midiChannels[t+this.portSelectChannelOffset].pitchWheel(e,A)}programChange(t,e){if(this.customChannelNumbers){for(let A of this.midiChannels)A.midiParameters.rxChannel===t&&A.programChange(e);return}this.midiChannels[t+this.portSelectChannelOffset].programChange(e)}assignVoice(){for(let e=0;e<this.systemParameters.voiceCap;e++){let A=this.voices[e];if(!A.isActive)return A.priority=1/0,A}if(this.systemParameters.autoAllocateVoices){h.info(`%cAllocating a new voice, total count %c${this.systemParameters.voiceCap+1}.`,d.info,d.value),this.allocateNewVoices(1);let e=this.voices[this.voices.length-1];return this.systemParameters.voiceCap++,e.priority=1/0,e}this.assignVoicePriorities();let t=this.voices[0];for(let e=0;e<this.systemParameters.voiceCap;e++){let A=this.voices[e];A.priority<t.priority&&(t=A)}return t.priority=1/0,t}stopAllChannels(t){h.info("%cStop all received!",d.info);for(let e of this.midiChannels)e.stopAllNotes(t)}processMessage(t,e=0,A=Kn){let s=A.time;s>this.currentTime?(this.eventQueue.push({message:t,channelOffset:e,time:s}),this.eventQueue.sort((n,a)=>n.time-a.time)):this.processMessageInternal(t,e)}destroySynthProcessor(){this.voices.length=0;for(let t of this.midiChannels)t.destroy();this.clearCache(),this.midiChannels.length=0,this.soundBankManager.destroy()}getVoices(t,e,A){let s=this.midiChannels[t],n=this.keyModifierManager.hasOverridePatch(t,e),a=s.preset;if(n){let r=this.keyModifierManager.getPatch(t,e);a=this.soundBankManager.getPreset(r,this.midiParameters.system)}return a?this.getVoicesForPreset(a,e,A):[]}createMIDIChannel(t){let e=new br(this,this.defaultPreset,this.midiChannels.length);this.midiChannels.push(e),t&&(this.callEvent("channelAdded",void 0),e.setDrums(!0))}reset(t="gs"){if(this.callEvent("reset",t),this.resetMIDIParameters(t),this.tunings.fill(-1),this.portSelectChannelOffset=0,this.customChannelNumbers=!1,this.setReverbMacro(4),this.setChorusMacro(2),this.setDelayMacro(0),this.systemParameters.delayLock||(this.delayActive=!1),this.resetInsertion(),!(!this.drumPreset||!this.defaultPreset))for(let e of this.midiChannels)e.reset(!1)}process(t,e,A=0,s=0){this.processSplit([[t,e]],t,e,A,s)}processSplit(t,e,A,s=0,n=0){if(this.eventQueue.length>0){let i=this.currentTime;for(;this.eventQueue[0]?.time<=i;){let g=this.eventQueue.shift();g&&this.processMessageInternal(g.message,g.channelOffset)}}s=Math.max(s,0);let a=n||t[0][0].length-s;if(a>this.maxBufferSize)throw new Error(`Requested ${a} samples, but maxBufferSize is ${this.maxBufferSize}`);this.reverbInput.fill(0),this.chorusInput.fill(0),this.delayActive&&this.delayInput.fill(0),this.insertionActive&&(this.insertionInputL.fill(0),this.insertionInputR.fill(0));for(let i of this.midiChannels)i.clearVoiceCount();this._voiceCount=0;let r=this.systemParameters.voiceCap,o=t.length;for(let i=0;i<r;i++){let g=this.voices[i],l=this.midiChannels[g.channel];if(!g.isActive)continue;let B=g.channel%o;l.renderVoice(g,this.currentTime,t[B][0],t[B][1],s,a),l.voiceCount++,this._voiceCount++}if(this.systemParameters.effectsEnabled){let{chorusInput:i,delayInput:g,reverbInput:l,insertionInputR:B,insertionInputL:C}=this;this.insertionActive&&this.insertionProcessor.process(C,B,e,A,l,i,g,s,a),this.chorusProcessor.process(i,e,A,l,g,s,a),this.delayActive&&this.midiParameters.system!=="xg"&&this.delayProcessor.process(g,e,A,l,s,a),this.reverbProcessor.process(l,e,A,s,a)}this.currentTime+=a*this.sampleTime}getVoicesForPreset(t,e,A){let s=this.getCachedVoice(t,e,A);if(s!==void 0)return s;let n=new Array;for(let a of t.getVoiceParameters(e,A)){let r=a.sample;if(a.sample.getAudioData()===void 0){h.warn(`Discarding invalid sample: ${r.name}`);continue}n.push(new ar(a,e,A,this.sampleRate))}return this.setCachedVoice(t,e,A,n),n}clearCache(){this.cachedVoices.clear()}callEvent(t,e){this.eventCallbackHandler(t,e)}getInsertionSnapshot(){return{type:this.insertionProcessor.type,params:this.insertionParams.slice(),channels:this.midiChannels.map(t=>t.midiParameters.efxAssign)}}resetInsertionParams(){this.insertionParams.fill(255),this.insertionParams[20]=40,this.insertionParams[21]=0,this.insertionParams[22]=0}resetInsertion(){this.systemParameters.insertionEffectLock||(this.insertionActive=!1,this.insertionProcessor=this.insertionFallback,this.insertionProcessor.reset(),this.resetInsertionParams(),this.insertionProcessor.sendLevelToReverb=40/127*hA,this.insertionProcessor.sendLevelToChorus=0,this.insertionProcessor.sendLevelToDelay=0,this.callEvent("effectChange",{effect:"insertion",parameter:0,value:this.insertionProcessor.type}))}setReverbMacro(t){if(this.systemParameters.reverbLock)return;let e=this.reverbProcessor;switch(e.level=64,e.preDelayTime=0,e.character=t,t){case 0:e.character=0,e.preLowpass=3,e.time=80,e.delayFeedback=0,e.preDelayTime=0;break;case 1:e.preLowpass=4,e.time=56,e.delayFeedback=0;break;case 2:e.preLowpass=0,e.time=72,e.delayFeedback=0;break;case 3:e.preLowpass=4,e.time=72,e.delayFeedback=0;break;case 4:e.preLowpass=0,e.time=64,e.delayFeedback=0;break;case 5:e.preLowpass=0,e.time=88,e.delayFeedback=0;break;case 6:e.preLowpass=0,e.time=32,e.delayFeedback=40;break;case 7:e.preLowpass=0,e.time=64,e.delayFeedback=32;break;default:h.warn(`Invalid reverb macro: ${t}`);return}this.callEvent("effectChange",{effect:"reverb",parameter:"macro",value:t})}setChorusMacro(t){if(this.systemParameters.chorusLock)return;let e=this.chorusProcessor;switch(e.level=64,e.preLowpass=0,e.delay=127,e.sendLevelToDelay=0,e.sendLevelToReverb=0,t){case 0:e.feedback=0,e.delay=112,e.rate=3,e.depth=5;break;case 1:e.feedback=5,e.delay=80,e.rate=9,e.depth=19;break;case 2:e.feedback=8,e.delay=80,e.rate=3,e.depth=19;break;case 3:e.feedback=16,e.delay=64,e.rate=9,e.depth=16;break;case 4:e.feedback=64,e.delay=127,e.rate=2,e.depth=24;break;case 5:e.feedback=112,e.delay=127,e.rate=1,e.depth=5;break;case 6:e.feedback=0,e.depth=127,e.rate=0,e.depth=127;break;case 7:e.feedback=80,e.depth=127,e.rate=0,e.depth=127;break;default:h.warn(`Invalid chorus macro: ${t}`);return}this.callEvent("effectChange",{effect:"chorus",parameter:"macro",value:t})}setDelayMacro(t){if(this.systemParameters.delayLock)return;let e=this.delayProcessor;switch(e.level=64,e.preLowpass=0,e.sendLevelToReverb=0,e.levelRight=e.levelLeft=0,e.levelCenter=127,t){case 0:e.timeCenter=97,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=80;break;case 1:e.timeCenter=106,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=80;break;case 2:e.timeCenter=115,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=72;break;case 3:e.timeCenter=83,e.timeRatioRight=e.timeRatioLeft=1,e.feedback=72;break;case 4:e.timeCenter=105,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=125,e.levelRight=60,e.feedback=74;break;case 5:e.timeCenter=109,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=125,e.levelRight=60,e.feedback=71;break;case 6:e.timeCenter=115,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=120,e.levelRight=64,e.feedback=73;break;case 7:e.timeCenter=93,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=120,e.levelRight=64,e.feedback=72;break;case 8:e.timeCenter=109,e.timeRatioLeft=12,e.timeRatioRight=24,e.levelCenter=0,e.levelLeft=114,e.levelRight=60,e.feedback=61,e.sendLevelToReverb=36;break;case 9:e.timeCenter=110,e.timeRatioLeft=21,e.timeRatioRight=32,e.levelCenter=97,e.levelLeft=127,e.levelRight=67,e.feedback=40;break;default:h.warn(`Invalid delay macro: ${t}`);return}this.callEvent("effectChange",{effect:"delay",parameter:"macro",value:t})}getCachedVoice(t,e,A){return this.cachedVoices.get(this.getCachedVoiceIndex(t,e,A))}setCachedVoice(t,e,A,s){this.cachedVoices.set(this.getCachedVoiceIndex(t,e,A),s)}allocateNewVoices(t){for(let e=0;e<t;e++)this.voices.push(new Ua(this.sampleRate,this.maxBufferSize))}registerInsertionProcessor(t){let e=new t(this.sampleRate,this.maxBufferSize);this.insertionEffects.set(e.type,e)}processMessageInternal(t,e){let A=t[0],s,n=0;switch(A>=128&&A<240?(s=A&240,n=A&15):s=A,n+=e,s){case G.noteOn:{let a=t[2];a>0?this.noteOn(n,t[1],a):this.noteOff(n,t[1]);break}case G.noteOff:this.noteOff(n,t[1]);break;case G.pitchWheel:this.pitchWheel(n,t[2]<<7|t[1]);break;case G.controllerChange:this.controllerChange(n,t[1],t[2]);break;case G.programChange:this.programChange(n,t[1]);break;case G.polyPressure:this.polyPressure(n,t[1],t[2]);break;case G.channelPressure:this.channelPressure(n,t[1]);break;case G.systemExclusive:this.systemExclusive(new ee(t.slice(1)),e);break;case G.reset:this.stopAllChannels(!1),this.reset();break;default:break}}assignVoicePriorities(){if(this.lastPriorityAssignmentTime===this.currentTime)return;h.info("%cPolyphony exceeded, stealing voices",d.warn),this.lastPriorityAssignmentTime=this.currentTime;let t=this.systemParameters.voiceCap;for(let e=0;e<t;e++){let A=this.voices[e];A.priority=0,this.midiChannels[A.channel].drumChannel&&(A.priority+=5),A.isInRelease&&(A.priority-=5),A.priority+=A.velocity/25,A.priority-=A.volEnv.state,A.isInRelease&&(A.priority-=5),A.priority-=A.volEnv.attenuationCb/200}}updatePresetList(){let t=this.soundBankManager.presetList;this.clearCache(),this.callEvent("presetListChange",t),this.getDefaultPresets();for(let e of this.midiChannels){let A=e.systemParameters.presetLock;e.setSystemParameter("presetLock",!1),e.programChange(e.patch.program),e.setSystemParameter("presetLock",A)}this.reset()}getDefaultPresets(){this.defaultPreset=this.soundBankManager.getPreset({bankLSB:0,bankMSB:0,program:0,isGMGSDrum:!1},"xg"),this.drumPreset=this.soundBankManager.getPreset({bankLSB:0,bankMSB:0,program:0,isGMGSDrum:!0},"gs")}getCachedVoiceIndex(t,e,A){let s=t.bankMSB,n=t.bankLSB,{isGMGSDrum:a,program:r}=t;return a&&(s=128,n=0),s+n*128+r*16384+2097152*e+268435456*A}},Nn=class{processorInitialized=FA.isInitialized;sampleRate;onEventCall;process;processSplit;systemExclusive;controllerChange;noteOn;noteOff;polyPressure;channelPressure;pitchWheel;programChange;processMessage;synthCore;savedSnapshot;constructor(t,e={}){let A=bA(e,Da);if(this.sampleRate=t,!Number.isFinite(A.initialTime)||!Number.isFinite(t))throw new TypeError(`Initial time or sample rate is invalid! initial time: ${A.initialTime}, sample rate: ${t}`);this.synthCore=new Ei(this.callEvent.bind(this),this.missingPreset.bind(this),this.sampleRate,A);let s=this.synthCore;this.process=s.process.bind(s),this.processSplit=s.processSplit.bind(s),this.systemExclusive=s.systemExclusive.bind(s),this.controllerChange=s.controllerChange.bind(s),this.noteOn=s.noteOn.bind(s),this.noteOff=s.noteOff.bind(s),this.polyPressure=s.polyPressure.bind(s),this.channelPressure=s.channelPressure.bind(s),this.pitchWheel=s.pitchWheel.bind(s),this.programChange=s.programChange.bind(s),this.processMessage=s.processMessage.bind(s);for(let n=0;n<16;n++)this.synthCore.createMIDIChannel(!1);this.processorInitialized.then(()=>{h.info("%cSpessaSynth is ready!",d.recognized)})}get midiChannels(){return this.synthCore.midiChannels}get midiParameters(){return this.synthCore.midiParameters}get systemParameters(){return this.synthCore.systemParameters}get voiceCount(){return this.synthCore.voiceCount}get currentTime(){return this.synthCore.currentTime}get reverbProcessor(){return this.synthCore.reverbProcessor}get chorusProcessor(){return this.synthCore.chorusProcessor}get delayProcessor(){return this.synthCore.delayProcessor}get soundBankManager(){return this.synthCore.soundBankManager}get keyModifierManager(){return this.synthCore.keyModifierManager}onMissingPreset=(t,e)=>{h.warn(`No preset found for ${ze.toMIDIString(t)}! Did you forget to add a sound bank?`)};setSystemParameter(t,e){this.synthCore.setSystemParameter(t,e)}reset(){this.synthCore.reset()}applySnapshot(t){this.savedSnapshot=t,ba.call(this.synthCore,t),this.reset()}getSnapshot(){return Ra.call(this.synthCore)}setEmbeddedSoundBank(t,e){let A=$t.fromArrayBuffer(t);this.synthCore.soundBankManager.addSoundBank(A,nA,e);let s=this.synthCore.soundBankManager.priorityOrder;s.pop(),s.unshift(nA),this.synthCore.soundBankManager.priorityOrder=s,this.savedSnapshot!==void 0&&this.applySnapshot(this.savedSnapshot),h.info(`%cEmbedded sound bank set at offset %c${e}`,d.recognized,d.value)}clearEmbeddedSoundBank(){this.synthCore.soundBankManager.soundBankList.some(t=>t.id===nA)&&this.synthCore.soundBankManager.deleteSoundBank(nA)}createMIDIChannel(){this.synthCore.createMIDIChannel(!0)}stopAllChannels(t=!1){this.synthCore.stopAllChannels(t)}destroySynthProcessor(){this.synthCore.destroySynthProcessor()}clearCache(){this.synthCore.clearCache()}getVoicesForPreset(t,e,A){return this.synthCore.getVoicesForPreset(t,e,A)}callEvent(t,e){this.onEventCall?.({type:t,data:e})}missingPreset(t,e){return this.onMissingPreset(t,e)}};var vA=tn.ConsoleColors;var Pn="spessasynth-worklet-processor";function Tn(t,e){return{...e,...t}}var Un={skipToFirstNoteOn:!0,initialPlaybackRate:1};var ps=class extends RA{events=[];constructor(e){super(),super.copyFrom(e),this.events=[]}},GA=class t extends Dt{tracks;timeline=[];embeddedSoundBank=void 0;embeddedSoundBankSize;constructor(e){super(),super.copyMetadataFrom(e),this.tracks=e.tracks.map(A=>new ps(A)),this.embeddedSoundBankSize=e instanceof t?e.embeddedSoundBankSize:e?.embeddedSoundBank?.byteLength}};var LA={shuffleOn:1,shuffleOff:2,index:3};var xn=-1;var Hn=1,NA=class{synthesizer;sequencers=new Array;post;lastSequencerSync=0;voiceCounts=new Array(16).fill(0);alive=!1;eventsEnabled;constructor(e,A,s){this.synthesizer=new Nn(e,A),this.eventsEnabled=A.eventsEnabled??!1,this.post=s,this.synthesizer.onEventCall=n=>{if(n.type==="channelAdded"){let a=this.synthesizer.midiChannels.length;for(let r=this.voiceCounts.length;r<a;r++)this.voiceCounts.push(0)}this.post({type:"eventCall",data:n,currentTime:this.synthesizer.currentTime})}}createNewSequencer(){let e=new an(this.synthesizer),A=this.sequencers.length;this.sequencers.push(e),e.onEventCall=s=>{if(this.eventsEnabled){if(s.type==="songListChange"){let a=s.data.newSongList.map(r=>new GA(r));this.post({type:"sequencerReturn",data:{type:s.type,data:{newSongList:a,shuffledSongIndexes:e.shuffledSongIndexes},id:A},currentTime:this.synthesizer.currentTime});return}this.post({type:"sequencerReturn",data:{...s,id:A},currentTime:this.synthesizer.currentTime})}}}postReady(e,A,s=[]){this.post({type:"isFullyInitialized",data:{type:e,data:A},currentTime:this.synthesizer.currentTime},s)}postProgress(e,A){this.post({type:"renderingProgress",data:{type:e,data:A},currentTime:this.synthesizer.currentTime})}destroy(){this.synthesizer.destroySynthProcessor(),delete this.synthesizer,delete this.sequencers}handleMessage(e){let A=e.channelNumber,s;if(A>=0&&(s=this.synthesizer.midiChannels[A],s===void 0)){h.warn(`Trying to access channel ${A} which does not exist... ignoring!`);return}switch(e.type){case"midiMessage":{this.synthesizer.processMessage(e.data.messageData,e.data.channelOffset,e.data.options);break}case"ccReset":{this.synthesizer.reset();break}case"stopAll":{A===xn?this.synthesizer.stopAllChannels(e.data===1):s?.stopAllNotes(e.data===1);break}case"addNewChannel":{this.synthesizer.createMIDIChannel();break}case"setGlobalSystemParameter":{this.synthesizer.setSystemParameter(e.data.type,e.data.data);break}case"setChannelSystemParameter":{s?.setSystemParameter(e.data.type,e.data.data);break}case"setDrums":{s?.setDrums(e.data);break}case"lockController":{s?.lockController(e.data.controller,e.data.isLocked);break}case"sequencerSpecific":{let n=this.sequencers[e.data.id];if(!n)return;let a=e.data;switch(a.type){default:break;case"loadNewSongList":{try{let o=a.data.map(i=>"duration"in i?Dt.copyFrom(i):Dt.fromArrayBuffer(i.binary,i.fileName));n.loadNewSongList(o)}catch(r){console.error(r),this.post({type:"sequencerReturn",data:{type:"midiError",data:r,id:e.data.id},currentTime:this.synthesizer.currentTime})}break}case"pause":{n.pause();break}case"play":{n.play();break}case"setTime":{n.currentTime=a.data;break}case"changeMIDIMessageSending":{n.externalMIDIPlayback=a.data;break}case"setPlaybackRate":{n.playbackRate=a.data;break}case"setLoopCount":{n.loopCount=a.data;break}case"changeSong":{switch(a.data.changeType){case LA.shuffleOff:{n.shuffleMode=!1;break}case LA.shuffleOn:{n.shuffleMode=!0;break}case LA.index:{a.data.data!==void 0&&(n.songIndex=a.data.data);break}}break}case"getMIDI":{if(!n.midiData)throw new Error("No MIDI is loaded!");this.post({type:"sequencerReturn",data:{type:"getMIDI",data:n.midiData,id:e.data.id},currentTime:this.synthesizer.currentTime});break}case"setSkipToFirstNote":{n.skipToFirstNoteOn=a.data;break}}break}case"soundBankManager":{try{let n=this.synthesizer.soundBankManager,a=e.data,r;switch(a.type){case"addSoundBank":{r=$t.fromArrayBuffer(a.data.soundBankBuffer),n.addSoundBank(r,a.data.id,a.data.bankOffset),this.postReady("soundBankManager",null);break}case"deleteSoundBank":{n.deleteSoundBank(a.data),this.postReady("soundBankManager",null);break}case"rearrangeSoundBanks":n.priorityOrder=a.data,this.postReady("soundBankManager",null)}}catch(n){this.post({type:"soundBankError",data:n,currentTime:this.synthesizer.currentTime})}break}case"keyModifierManager":{let n=e.data,a=this.synthesizer.keyModifierManager;switch(n.type){default:return;case"addMapping":{a.addMapping(n.data.channel,n.data.midiNote,n.data.mapping);break}case"clearMappings":{a.clearMappings();break}case"deleteMapping":a.deleteMapping(n.data.channel,n.data.midiNote)}break}case"requestSynthesizerSnapshot":{let n=this.synthesizer.getSnapshot();this.postReady("synthesizerSnapshot",n);break}case"requestNewSequencer":{this.createNewSequencer();break}case"setLogLevel":{h.setLogLevel(e.data.enableInfo,e.data.enableWarning,e.data.enableGroup);break}case"destroyWorklet":{this.alive=!1,this.synthesizer.destroySynthProcessor(),this.destroy();break}default:{h.warn("Unrecognized event!",e);break}}}};var PA=class extends NA{alive=!0;oneOutputMode;port;constructor(e,A,s,n){super(e,{effectsEnabled:!n.oneOutput,eventsEnabled:n?.eventsEnabled,initialTime:A},(a,r)=>{s.postMessage(a,r)}),this.port=s,this.oneOutputMode=n.oneOutput,this.synthesizer.processorInitialized.then(()=>{this.port.onmessage=a=>this.handleMessage(a.data),this.postReady("sf3Decoder",null)})}process(e,A){if(!this.alive)return!1;for(let o of this.sequencers)o.processTick();if(this.oneOutputMode){let o=A[0],i=[];for(let g=0;g<32;g+=2)i.push([o[g],o[g+1]]);this.synthesizer.setSystemParameter("effectsEnabled",!1),this.synthesizer.processSplit(i,o[0],o[0])}else this.synthesizer.processSplit(A.slice(1),A[0][0],A[0][1]);let s=this.synthesizer.currentTime;if(this.eventsEnabled&&s-this.lastSequencerSync>Hn){for(let o=0;o<this.sequencers.length;o++)this.post({type:"sequencerReturn",data:{type:"sync",data:this.sequencers[o].currentTime,id:o},currentTime:s});this.lastSequencerSync=s}let n=this.synthesizer.midiChannels,a=this.voiceCounts,r=!1;for(let o=0;o<n.length;o++)r||=n[o].voiceCount!==a[o],a[o]=n[o].voiceCount;return r&&this.post({type:"voiceCountChange",currentTime:s,data:a}),!0}handleMessage(e){if(e.type==="startOfflineRender"){this.startOfflineRender(e.data);return}super.handleMessage(e)}startOfflineRender(e){this.sequencers.length===0&&this.createNewSequencer();let A=this.sequencers[0];for(let[n,a]of e.soundBankList.entries())try{this.synthesizer.soundBankManager.addSoundBank($t.fromArrayBuffer(a.soundBankBuffer),`bank-${n}`,a.bankOffset)}catch(r){this.post({type:"soundBankError",data:r,currentTime:this.synthesizer.currentTime})}e.snapshot!==void 0&&this.synthesizer.applySnapshot(e.snapshot),h.info("%cStarting to render the audio data!",vA.info),A.loopCount=e.loopCount,this.synthesizer.setSystemParameter("autoAllocateVoices",!0);let s=Tn(e.sequencerOptions,Un);A.skipToFirstNoteOn=s.skipToFirstNoteOn,A.playbackRate=s.initialPlaybackRate;try{A.loadNewSongList([Dt.copyFrom(e.midiSequence)]),A.play()}catch(n){console.error(n),this.post({type:"sequencerReturn",data:{type:"midiError",data:n,id:0},currentTime:this.synthesizer.currentTime})}this.postReady("startOfflineRender",null)}};var ys=class extends AudioWorkletProcessor{core;constructor(e){super(),this.core=new PA(sampleRate,currentTime,this.port,e.processorOptions)}process(e,A){return this.core.process(e,A)}};registerProcessor(Pn,ys);h.info("%cProcessor successfully registered!",vA.recognized);
|
|
18
18
|
//# sourceMappingURL=spessasynth_processor.min.js.map
|