spessasynth_lib 3.23.13 → 3.24.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/@types/midi_parser/midi_data.d.ts +2 -0
- package/@types/midi_parser/midi_sequence.d.ts +11 -0
- package/@types/synthetizer/synth_event_handler.d.ts +157 -60
- package/@types/utils/other.d.ts +5 -0
- package/README.md +1 -1
- package/midi_parser/basic_midi.js +2 -0
- package/midi_parser/midi_data.js +2 -0
- package/midi_parser/midi_loader.js +150 -26
- package/midi_parser/midi_sequence.js +13 -0
- package/package.json +1 -1
- package/sequencer/worklet_sequencer/process_event.js +22 -2
- package/synthetizer/synth_event_handler.js +92 -71
- package/synthetizer/worklet_processor.min.js +12 -12
- package/synthetizer/worklet_system/message_protocol/message_sending.js +1 -1
- package/synthetizer/worklet_system/worklet_methods/system_exclusive.js +77 -0
- package/utils/other.js +28 -1
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
var Fn=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(A,e)=>(typeof require<"u"?require:A)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var b=class extends Uint8Array{currentIndex;constructor(A){super(A),this.currentIndex=0}};function cA(t){let A=t.reduce((s,o)=>s+o.length,0),e=new b(A),n=0;for(let s of t)e.set(s,n),n+=s.length;return e}function vt(t){t=Math.floor(t);let A=Math.floor(t/60),e=Math.round(t-A*60);return{minutes:A,seconds:e,time:`${A.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`}}function Rn(t){return t.trim().replaceAll(".mid","").replaceAll(".rmi","").replaceAll("_"," ")}function SA(t){let A="";for(let e=0;e<t.length;e++){let n=t[e].toString(16).padStart(2,"0").toUpperCase();A+=n,A+=" "}return A}var g={warn:"color: orange;",unrecognized:"color: red;",info:"color: aqua;",recognized:"color: lime",value:"color: yellow; background-color: black;"};var fe=class{constructor(A,e,n){this.ticks=A,this.messageStatusByte=e,this.messageData=n}};function Gn(t){let A=t&240,e=t&15,n=e;switch(A){case 128:case 144:case 160:case 176:case 192:case 208:case 224:break;case 240:switch(e){case 0:n=-3;break;case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:case 11:case 12:case 13:case 14:n=-1;break;case 15:n=-2;break}break;default:n=-1}return n}var M={noteOff:128,noteOn:144,polyPressure:160,controllerChange:176,programChange:192,channelPressure:208,pitchBend: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};function be(t){let A=t&240,e=t&15,n=-1,s=t;return A>=128&&A<=224&&(n=e,s=A),{status:s,channel:n}}var k={bankSelect:0,modulationWheel:1,breathController:2,footController:4,portamentoTime:5,dataEntryMsb:6,mainVolume:7,balance:8,pan:10,expressionController:11,effectControl1:12,effectControl2:13,generalPurposeController1:16,generalPurposeController2:17,generalPurposeController3:18,generalPurposeController4:19,lsbForControl0BankSelect:32,lsbForControl1ModulationWheel:33,lsbForControl2BreathController:34,lsbForControl4FootController:36,lsbForControl5PortamentoTime:37,lsbForControl6DataEntry:38,lsbForControl7MainVolume:39,lsbForControl8Balance:40,lsbForControl10Pan:42,lsbForControl11ExpressionController:43,lsbForControl12EffectControl1:44,lsbForControl13EffectControl2:45,sustainPedal:64,portamentoOnOff:65,sostenutoPedal:66,softPedal:67,legatoFootswitch:68,hold2Pedal:69,soundVariation:70,timbreHarmonicContent:71,releaseTime:72,attackTime:73,brightness:74,soundController6:75,soundController7:76,soundController8:77,soundController9:78,soundController10:79,generalPurposeController5:80,generalPurposeController6:81,generalPurposeController7:82,generalPurposeController8:83,portamentoControl:84,reverbDepth:91,tremoloDepth:92,chorusDepth:93,detuneDepth:94,phaserDepth:95,dataIncrement:96,dataDecrement:97,NRPNLsb:98,NRPNMsb:99,RPNLsb:100,RPNMsb:101,allSoundOff:120,resetAllControllers:121,localControlOnOff:122,allNotesOff:123,omniModeOff:124,omniModeOn:125,monoModeOn:126,polyModeOn:127},Mn={8:2,9:2,10:2,11:2,12:1,13:1,14:2};var nA={noteOff:0,noteOn:1,ccChange:2,programChange:3,channelPressure:4,polyPressure:5,killNote:6,ccReset:7,setChannelVibrato:8,soundFontManager:9,stopAll:10,killNotes:11,muteChannel:12,addNewChannel:13,customcCcChange:14,debugMessage:15,systemExclusive:16,setMasterParameter:17,setDrums:18,pitchWheel:19,transpose:20,highPerformanceMode:21,lockController:22,sequencerSpecific:23,requestSynthesizerSnapshot:24,setLogLevel:25,keyModifierManager:26,setEffectsGain:27,destroyWorklet:28},me={mainVolume:0,masterPan:1,voicesCap:2,interpolationType:3},OA=-1,DA={channelProperties:0,eventCall:1,reportedCurrentTime:2,sequencerSpecific:3,synthesizerSnapshot:4,ready:5,soundfontError:6,identify:7};var xn=!1,Nn=!0,Xe=!1,bn=!0;function Ln(t,A,e,n){xn=t,Nn=A,Xe=e,bn=n}function p(...t){xn&&console.info(...t)}function T(...t){Nn&&console.warn(...t)}function Un(...t){bn&&console.table(...t)}function Ce(...t){Xe&&console.group(...t)}function QA(...t){Xe&&console.groupCollapsed(...t)}function V(){Xe&&console.groupEnd()}var pe={reloadSoundFont:0,addNewSoundFont:2,deleteSoundFont:3,rearrangeSoundFonts:4};var r={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,unused1:14,chorusEffectsSend:15,reverbEffectsSend:16,pan:17,unused2:18,unused3:19,unused4:20,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,reserved1:42,keyRange:43,velRange:44,startloopAddrsCoarseOffset:45,keyNum:46,velocity:47,initialAttenuation:48,reserved2:49,endloopAddrsCoarseOffset:50,coarseTune:51,fineTune:52,sampleID:53,sampleModes:54,reserved3:55,scaleTuning:56,exclusiveClass:57,overridingRootKey:58,unused5:59,endOper:60},J=[];J[r.startAddrsOffset]={min:0,max:32768,def:0};J[r.endAddrOffset]={min:-32768,max:32768,def:0};J[r.startloopAddrsOffset]={min:-32768,max:32768,def:0};J[r.endloopAddrsOffset]={min:-32768,max:32768,def:0};J[r.startAddrsCoarseOffset]={min:0,max:32768,def:0};J[r.modLfoToPitch]={min:-12e3,max:12e3,def:0};J[r.vibLfoToPitch]={min:-12e3,max:12e3,def:0};J[r.modEnvToPitch]={min:-12e3,max:12e3,def:0};J[r.initialFilterFc]={min:1500,max:13500,def:13500};J[r.initialFilterQ]={min:0,max:960,def:0};J[r.modLfoToFilterFc]={min:-12e3,max:12e3,def:0};J[r.modEnvToFilterFc]={min:-12e3,max:12e3,def:0};J[r.endAddrsCoarseOffset]={min:-32768,max:32768,def:0};J[r.modLfoToVolume]={min:-960,max:960,def:0};J[r.chorusEffectsSend]={min:0,max:1e3,def:0};J[r.reverbEffectsSend]={min:0,max:1e3,def:0};J[r.pan]={min:-500,max:500,def:0};J[r.delayModLFO]={min:-12e3,max:5e3,def:-12e3};J[r.freqModLFO]={min:-16e3,max:4500,def:0};J[r.delayVibLFO]={min:-12e3,max:5e3,def:-12e3};J[r.freqVibLFO]={min:-16e3,max:4500,def:0};J[r.delayModEnv]={min:-32768,max:5e3,def:-32768};J[r.attackModEnv]={min:-32768,max:8e3,def:-32768};J[r.holdModEnv]={min:-12e3,max:5e3,def:-12e3};J[r.decayModEnv]={min:-12e3,max:8e3,def:-12e3};J[r.sustainModEnv]={min:0,max:1e3,def:0};J[r.releaseModEnv]={min:-7200,max:8e3,def:-12e3};J[r.keyNumToModEnvHold]={min:-1200,max:1200,def:0};J[r.keyNumToModEnvDecay]={min:-1200,max:1200,def:0};J[r.delayVolEnv]={min:-12e3,max:5e3,def:-12e3};J[r.attackVolEnv]={min:-12e3,max:8e3,def:-12e3};J[r.holdVolEnv]={min:-12e3,max:5e3,def:-12e3};J[r.decayVolEnv]={min:-12e3,max:8e3,def:-12e3};J[r.sustainVolEnv]={min:0,max:1440,def:0};J[r.releaseVolEnv]={min:-7200,max:8e3,def:-12e3};J[r.keyNumToVolEnvHold]={min:-1200,max:1200,def:0};J[r.keyNumToVolEnvDecay]={min:-1200,max:1200,def:0};J[r.startloopAddrsCoarseOffset]={min:-32768,max:32768,def:0};J[r.keyNum]={min:-1,max:127,def:-1};J[r.velocity]={min:-1,max:127,def:-1};J[r.initialAttenuation]={min:-250,max:1440,def:0};J[r.endloopAddrsCoarseOffset]={min:-32768,max:32768,def:0};J[r.coarseTune]={min:-120,max:120,def:0};J[r.fineTune]={min:-12700,max:12700,def:0};J[r.scaleTuning]={min:0,max:1200,def:100};J[r.exclusiveClass]={min:0,max:99999,def:0};J[r.overridingRootKey]={min:-1,max:127,def:-1};J[r.sampleModes]={min:0,max:3,def:0};var N=class{generatorType=r.INVALID;generatorValue=0;constructor(A=r.INVALID,e=0,n=!0){if(this.generatorType=A,e===void 0)throw new Error("No value provided.");if(this.generatorValue=Math.round(e),n){let s=J[A];s!==void 0&&(this.generatorValue=Math.max(s.min,Math.min(s.max,this.generatorValue)))}}};function Tn(t,A,e){let n=J[t]||{min:0,max:32768,def:0},s=A.find(B=>B.generatorType===t),o=0;s&&(o=s.generatorValue);let i=e.find(B=>B.generatorType===t),a=n.def;i&&(a=i.generatorValue);let C=a+o;return t===r.initialAttenuation?C:Math.max(n.min,Math.min(n.max,C))}var q={noController:0,noteOnVelocity:2,noteOnKeyNum:3,polyPressure:10,channelPressure:13,pitchWheel:14,pitchWheelRange:16,link:127},uA={linear:0,concave:1,convex:2,switch:3},P=class t{currentValue=0;constructor(A){this.sourceEnum=A.srcEnum,this.modulatorDestination=A.dest,this.secondarySourceEnum=A.secSrcEnum,this.transformAmount=A.amt,this.transformType=A.transform,this.modulatorDestination>58&&(this.modulatorDestination=r.INVALID),this.sourcePolarity=this.sourceEnum>>9&1,this.sourceDirection=this.sourceEnum>>8&1,this.sourceUsesCC=this.sourceEnum>>7&1,this.sourceIndex=this.sourceEnum&127,this.sourceCurveType=this.sourceEnum>>10&3,this.secSrcPolarity=this.secondarySourceEnum>>9&1,this.secSrcDirection=this.secondarySourceEnum>>8&1,this.secSrcUsesCC=this.secondarySourceEnum>>7&1,this.secSrcIndex=this.secondarySourceEnum&127,this.secSrcCurveType=this.secondarySourceEnum>>10&3,this.isEffectModulator=(this.sourceEnum===219||this.sourceEnum===221)&&this.secondarySourceEnum===0&&(this.modulatorDestination===r.reverbEffectsSend||this.modulatorDestination===r.chorusEffectsSend)}static copy(A){return new t({srcEnum:A.sourceEnum,secSrcEnum:A.secondarySourceEnum,transform:A.transformType,amt:A.transformAmount,dest:A.modulatorDestination})}static isIdentical(A,e,n=!1){return A.sourceEnum===e.sourceEnum&&A.modulatorDestination===e.modulatorDestination&&A.secondarySourceEnum===e.secondarySourceEnum&&A.transformType===e.transformType&&(!n||A.transformAmount===e.transformAmount)}sumTransform(A){return new t({srcEnum:this.sourceEnum,secSrcEnum:this.secondarySourceEnum,dest:this.modulatorDestination,transform:this.transformType,amt:this.transformAmount+A.transformAmount})}debugString(){function A(s,o){return Object.keys(s).find(i=>s[i]===o)}let e=A(uA,this.sourceCurveType);e+=this.sourcePolarity===0?" unipolar ":" bipolar ",e+=this.sourceDirection===0?"forwards ":"backwards ",this.sourceUsesCC?e+=A(k,this.sourceIndex):e+=A(q,this.sourceIndex);let n=A(uA,this.secSrcCurveType);return n+=this.secSrcPolarity===0?" unipolar ":" bipolar ",n+=this.secSrcCurveType===0?"forwards ":"backwards ",this.secSrcUsesCC?n+=A(k,this.secSrcIndex):n+=A(q,this.secSrcIndex),`Modulator:
|
|
1
|
+
var Gs=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(A,e)=>(typeof require<"u"?require:A)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var b=class extends Uint8Array{currentIndex;constructor(A){super(A),this.currentIndex=0}};function lA(t){let A=t.reduce((n,o)=>n+o.length,0),e=new b(A),s=0;for(let n of t)e.set(n,s),s+=n.length;return e}function Pt(t){t=Math.floor(t);let A=Math.floor(t/60),e=Math.round(t-A*60);return{minutes:A,seconds:e,time:`${A.toString().padStart(2,"0")}:${e.toString().padStart(2,"0")}`}}function xs(t){return t.trim().replaceAll(".mid","").replaceAll(".kar","").replaceAll(".rmi","").replaceAll("_"," ").trim()}function DA(t){let A="";for(let e=0;e<t.length;e++){let s=t[e].toString(16).padStart(2,"0").toUpperCase();A+=s,A+=" "}return A}function Ms(t){let A=[];for(let e of t)(e===47||e===92)&&(e=10),A.push(e);return new Uint8Array(A)}var g={warn:"color: orange;",unrecognized:"color: red;",info:"color: aqua;",recognized:"color: lime",value:"color: yellow; background-color: black;"};var pe=class{constructor(A,e,s){this.ticks=A,this.messageStatusByte=e,this.messageData=s}};function Ns(t){let A=t&240,e=t&15,s=e;switch(A){case 128:case 144:case 160:case 176:case 192:case 208:case 224:break;case 240:switch(e){case 0:s=-3;break;case 1:case 2:case 3:case 4:case 5:case 6:case 7:case 8:case 9:case 10:case 11:case 12:case 13:case 14:s=-1;break;case 15:s=-2;break}break;default:s=-1}return s}var R={noteOff:128,noteOn:144,polyPressure:160,controllerChange:176,programChange:192,channelPressure:208,pitchBend: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};function Ue(t){let A=t&240,e=t&15,s=-1,n=t;return A>=128&&A<=224&&(s=e,n=A),{status:n,channel:s}}var k={bankSelect:0,modulationWheel:1,breathController:2,footController:4,portamentoTime:5,dataEntryMsb:6,mainVolume:7,balance:8,pan:10,expressionController:11,effectControl1:12,effectControl2:13,generalPurposeController1:16,generalPurposeController2:17,generalPurposeController3:18,generalPurposeController4:19,lsbForControl0BankSelect:32,lsbForControl1ModulationWheel:33,lsbForControl2BreathController:34,lsbForControl4FootController:36,lsbForControl5PortamentoTime:37,lsbForControl6DataEntry:38,lsbForControl7MainVolume:39,lsbForControl8Balance:40,lsbForControl10Pan:42,lsbForControl11ExpressionController:43,lsbForControl12EffectControl1:44,lsbForControl13EffectControl2:45,sustainPedal:64,portamentoOnOff:65,sostenutoPedal:66,softPedal:67,legatoFootswitch:68,hold2Pedal:69,soundVariation:70,timbreHarmonicContent:71,releaseTime:72,attackTime:73,brightness:74,soundController6:75,soundController7:76,soundController8:77,soundController9:78,soundController10:79,generalPurposeController5:80,generalPurposeController6:81,generalPurposeController7:82,generalPurposeController8:83,portamentoControl:84,reverbDepth:91,tremoloDepth:92,chorusDepth:93,detuneDepth:94,phaserDepth:95,dataIncrement:96,dataDecrement:97,NRPNLsb:98,NRPNMsb:99,RPNLsb:100,RPNMsb:101,allSoundOff:120,resetAllControllers:121,localControlOnOff:122,allNotesOff:123,omniModeOff:124,omniModeOn:125,monoModeOn:126,polyModeOn:127},bs={8:2,9:2,10:2,11:2,12:1,13:1,14:2};var nA={noteOff:0,noteOn:1,ccChange:2,programChange:3,channelPressure:4,polyPressure:5,killNote:6,ccReset:7,setChannelVibrato:8,soundFontManager:9,stopAll:10,killNotes:11,muteChannel:12,addNewChannel:13,customcCcChange:14,debugMessage:15,systemExclusive:16,setMasterParameter:17,setDrums:18,pitchWheel:19,transpose:20,highPerformanceMode:21,lockController:22,sequencerSpecific:23,requestSynthesizerSnapshot:24,setLogLevel:25,keyModifierManager:26,setEffectsGain:27,destroyWorklet:28},ye={mainVolume:0,masterPan:1,voicesCap:2,interpolationType:3},KA=-1,kA={channelProperties:0,eventCall:1,reportedCurrentTime:2,sequencerSpecific:3,synthesizerSnapshot:4,ready:5,soundfontError:6,identify:7};var Ls=!1,Us=!0,ze=!1,Ts=!0;function vs(t,A,e,s){Ls=t,Us=A,ze=e,Ts=s}function m(...t){Ls&&console.info(...t)}function T(...t){Us&&console.warn(...t)}function Hs(...t){Ts&&console.table(...t)}function Be(...t){ze&&console.group(...t)}function QA(...t){ze&&console.groupCollapsed(...t)}function Z(){ze&&console.groupEnd()}var Se={reloadSoundFont:0,addNewSoundFont:2,deleteSoundFont:3,rearrangeSoundFonts:4};var r={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,unused1:14,chorusEffectsSend:15,reverbEffectsSend:16,pan:17,unused2:18,unused3:19,unused4:20,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,reserved1:42,keyRange:43,velRange:44,startloopAddrsCoarseOffset:45,keyNum:46,velocity:47,initialAttenuation:48,reserved2:49,endloopAddrsCoarseOffset:50,coarseTune:51,fineTune:52,sampleID:53,sampleModes:54,reserved3:55,scaleTuning:56,exclusiveClass:57,overridingRootKey:58,unused5:59,endOper:60},J=[];J[r.startAddrsOffset]={min:0,max:32768,def:0};J[r.endAddrOffset]={min:-32768,max:32768,def:0};J[r.startloopAddrsOffset]={min:-32768,max:32768,def:0};J[r.endloopAddrsOffset]={min:-32768,max:32768,def:0};J[r.startAddrsCoarseOffset]={min:0,max:32768,def:0};J[r.modLfoToPitch]={min:-12e3,max:12e3,def:0};J[r.vibLfoToPitch]={min:-12e3,max:12e3,def:0};J[r.modEnvToPitch]={min:-12e3,max:12e3,def:0};J[r.initialFilterFc]={min:1500,max:13500,def:13500};J[r.initialFilterQ]={min:0,max:960,def:0};J[r.modLfoToFilterFc]={min:-12e3,max:12e3,def:0};J[r.modEnvToFilterFc]={min:-12e3,max:12e3,def:0};J[r.endAddrsCoarseOffset]={min:-32768,max:32768,def:0};J[r.modLfoToVolume]={min:-960,max:960,def:0};J[r.chorusEffectsSend]={min:0,max:1e3,def:0};J[r.reverbEffectsSend]={min:0,max:1e3,def:0};J[r.pan]={min:-500,max:500,def:0};J[r.delayModLFO]={min:-12e3,max:5e3,def:-12e3};J[r.freqModLFO]={min:-16e3,max:4500,def:0};J[r.delayVibLFO]={min:-12e3,max:5e3,def:-12e3};J[r.freqVibLFO]={min:-16e3,max:4500,def:0};J[r.delayModEnv]={min:-32768,max:5e3,def:-32768};J[r.attackModEnv]={min:-32768,max:8e3,def:-32768};J[r.holdModEnv]={min:-12e3,max:5e3,def:-12e3};J[r.decayModEnv]={min:-12e3,max:8e3,def:-12e3};J[r.sustainModEnv]={min:0,max:1e3,def:0};J[r.releaseModEnv]={min:-7200,max:8e3,def:-12e3};J[r.keyNumToModEnvHold]={min:-1200,max:1200,def:0};J[r.keyNumToModEnvDecay]={min:-1200,max:1200,def:0};J[r.delayVolEnv]={min:-12e3,max:5e3,def:-12e3};J[r.attackVolEnv]={min:-12e3,max:8e3,def:-12e3};J[r.holdVolEnv]={min:-12e3,max:5e3,def:-12e3};J[r.decayVolEnv]={min:-12e3,max:8e3,def:-12e3};J[r.sustainVolEnv]={min:0,max:1440,def:0};J[r.releaseVolEnv]={min:-7200,max:8e3,def:-12e3};J[r.keyNumToVolEnvHold]={min:-1200,max:1200,def:0};J[r.keyNumToVolEnvDecay]={min:-1200,max:1200,def:0};J[r.startloopAddrsCoarseOffset]={min:-32768,max:32768,def:0};J[r.keyNum]={min:-1,max:127,def:-1};J[r.velocity]={min:-1,max:127,def:-1};J[r.initialAttenuation]={min:-250,max:1440,def:0};J[r.endloopAddrsCoarseOffset]={min:-32768,max:32768,def:0};J[r.coarseTune]={min:-120,max:120,def:0};J[r.fineTune]={min:-12700,max:12700,def:0};J[r.scaleTuning]={min:0,max:1200,def:100};J[r.exclusiveClass]={min:0,max:99999,def:0};J[r.overridingRootKey]={min:-1,max:127,def:-1};J[r.sampleModes]={min:0,max:3,def:0};var N=class{generatorType=r.INVALID;generatorValue=0;constructor(A=r.INVALID,e=0,s=!0){if(this.generatorType=A,e===void 0)throw new Error("No value provided.");if(this.generatorValue=Math.round(e),s){let n=J[A];n!==void 0&&(this.generatorValue=Math.max(n.min,Math.min(n.max,this.generatorValue)))}}};function Ys(t,A,e){let s=J[t]||{min:0,max:32768,def:0},n=A.find(h=>h.generatorType===t),o=0;n&&(o=n.generatorValue);let i=e.find(h=>h.generatorType===t),a=s.def;i&&(a=i.generatorValue);let C=a+o;return t===r.initialAttenuation?C:Math.max(s.min,Math.min(s.max,C))}var K={noController:0,noteOnVelocity:2,noteOnKeyNum:3,polyPressure:10,channelPressure:13,pitchWheel:14,pitchWheelRange:16,link:127},uA={linear:0,concave:1,convex:2,switch:3},P=class t{currentValue=0;constructor(A){this.sourceEnum=A.srcEnum,this.modulatorDestination=A.dest,this.secondarySourceEnum=A.secSrcEnum,this.transformAmount=A.amt,this.transformType=A.transform,this.modulatorDestination>58&&(this.modulatorDestination=r.INVALID),this.sourcePolarity=this.sourceEnum>>9&1,this.sourceDirection=this.sourceEnum>>8&1,this.sourceUsesCC=this.sourceEnum>>7&1,this.sourceIndex=this.sourceEnum&127,this.sourceCurveType=this.sourceEnum>>10&3,this.secSrcPolarity=this.secondarySourceEnum>>9&1,this.secSrcDirection=this.secondarySourceEnum>>8&1,this.secSrcUsesCC=this.secondarySourceEnum>>7&1,this.secSrcIndex=this.secondarySourceEnum&127,this.secSrcCurveType=this.secondarySourceEnum>>10&3,this.isEffectModulator=(this.sourceEnum===219||this.sourceEnum===221)&&this.secondarySourceEnum===0&&(this.modulatorDestination===r.reverbEffectsSend||this.modulatorDestination===r.chorusEffectsSend)}static copy(A){return new t({srcEnum:A.sourceEnum,secSrcEnum:A.secondarySourceEnum,transform:A.transformType,amt:A.transformAmount,dest:A.modulatorDestination})}static isIdentical(A,e,s=!1){return A.sourceEnum===e.sourceEnum&&A.modulatorDestination===e.modulatorDestination&&A.secondarySourceEnum===e.secondarySourceEnum&&A.transformType===e.transformType&&(!s||A.transformAmount===e.transformAmount)}sumTransform(A){return new t({srcEnum:this.sourceEnum,secSrcEnum:this.secondarySourceEnum,dest:this.modulatorDestination,transform:this.transformType,amt:this.transformAmount+A.transformAmount})}debugString(){function A(n,o){return Object.keys(n).find(i=>n[i]===o)}let e=A(uA,this.sourceCurveType);e+=this.sourcePolarity===0?" unipolar ":" bipolar ",e+=this.sourceDirection===0?"forwards ":"backwards ",this.sourceUsesCC?e+=A(k,this.sourceIndex):e+=A(K,this.sourceIndex);let s=A(uA,this.secSrcCurveType);return s+=this.secSrcPolarity===0?" unipolar ":" bipolar ",s+=this.secSrcCurveType===0?"forwards ":"backwards ",this.secSrcUsesCC?s+=A(k,this.secSrcIndex):s+=A(K,this.secSrcIndex),`Modulator:
|
|
2
2
|
Source: ${e}
|
|
3
|
-
Secondary source: ${
|
|
3
|
+
Secondary source: ${s}
|
|
4
4
|
Destination: ${A(r,this.modulatorDestination)}
|
|
5
5
|
Trasform amount: ${this.transformAmount}
|
|
6
6
|
Transform type: ${this.transformType}
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
`}},Ht=960,Yt=uA.concave;function VA(t,A,e,n,s){return t<<10|A<<9|e<<8|n<<7|s}var Er=[new P({srcEnum:VA(Yt,0,1,0,q.noteOnVelocity),dest:r.initialAttenuation,amt:Ht,secSrcEnum:0,transform:0}),new P({srcEnum:129,dest:r.vibLfoToPitch,amt:50,secSrcEnum:0,transform:0}),new P({srcEnum:VA(Yt,0,1,1,k.mainVolume),dest:r.initialAttenuation,amt:Ht,secSrcEnum:0,transform:0}),new P({srcEnum:13,dest:r.vibLfoToPitch,amt:50,secSrcEnum:0,transform:0}),new P({srcEnum:526,dest:r.fineTune,amt:12700,secSrcEnum:16,transform:0}),new P({srcEnum:650,dest:r.pan,amt:500,secSrcEnum:0,transform:0}),new P({srcEnum:VA(Yt,0,1,1,k.expressionController),dest:r.initialAttenuation,amt:Ht,secSrcEnum:0,transform:0}),new P({srcEnum:219,dest:r.reverbEffectsSend,amt:200,secSrcEnum:0,transform:0}),new P({srcEnum:221,dest:r.chorusEffectsSend,amt:200,secSrcEnum:0,transform:0})],Cr=[new P({srcEnum:VA(uA.linear,0,0,0,q.polyPressure),dest:r.vibLfoToPitch,amt:50,secSrcEnum:0,transform:0}),new P({srcEnum:VA(uA.linear,0,0,1,k.tremoloDepth),dest:r.modLfoToVolume,amt:24,secSrcEnum:0,transform:0}),new P({srcEnum:VA(uA.linear,1,0,1,k.releaseTime),dest:r.releaseVolEnv,amt:1200,secSrcEnum:0,transform:0}),new P({srcEnum:VA(uA.linear,1,0,1,k.brightness),dest:r.initialFilterFc,amt:6e3,secSrcEnum:0,transform:0}),new P({srcEnum:VA(uA.linear,1,0,1,k.timbreHarmonicContent),dest:r.initialFilterQ,amt:250,secSrcEnum:0,transform:0})],_e=Er.concat(Cr);var dA=128,ze=147,ye=new Int16Array(ze).fill(0),kA=(t,A)=>ye[t]=A<<7;kA(k.mainVolume,100);kA(k.balance,64);kA(k.expressionController,127);kA(k.pan,64);kA(k.timbreHarmonicContent,64);kA(k.releaseTime,64);kA(k.attackTime,64);kA(k.brightness,64);kA(k.soundController6,64);kA(k.soundController7,64);kA(k.soundController8,64);kA(k.soundController9,64);kA(k.generalPurposeController6,64);kA(k.generalPurposeController8,64);kA(dA+q.pitchWheel,64);kA(dA+q.pitchWheelRange,2);var hA={channelTuning:0,channelTransposeFine:1,modulationMultiplier:2,masterTuning:3,channelTuningSemitones:4},Jt=Object.keys(hA).length,Pt=new Float32Array(Jt);Pt[hA.modulationMultiplier]=1;var wA={Idle:0,RPCoarse:1,RPFine:2,NRPCoarse:3,NRPFine:4,DataCoarse:5,DataFine:6};function vn(t=!1){let A={midiControllers:new Int16Array(ze),lockedControllers:Array(ze).fill(!1),customControllers:new Float32Array(Jt),NRPCoarse:0,NRPFine:0,RPValue:0,dataEntryState:wA.Idle,voices:[],sustainedVoices:[],cachedVoices:[],preset:this.defaultPreset,presetUsesOverride:!1,channelTransposeKeyShift:0,channelOctaveTuning:new Int8Array(12),keyCentTuning:new Int16Array(128),channelVibrato:{delay:0,depth:0,rate:0},velocityOverride:0,lockGSNRPNParams:!1,holdPedal:!1,isMuted:!1,drumChannel:!1,lockPreset:!1};for(let e=0;e<128;e++)A.cachedVoices.push([]);this.workletProcessorChannels.push(A),this.resetControllers(this.workletProcessorChannels.length-1),this.sendChannelProperties(),t&&this.callEvent("newchannel",void 0)}function ne(t,A){t.lockPreset||(t.bank=A)}function XA(t){return t.drumChannel?128:t.bank}var qt={velocityOverride:128};var je={addMapping:0,deleteMapping:1,clearMappings:2},$e=class{_keyMappings=[];handleMessage(A,e){switch(A){default:return;case je.addMapping:this.addMapping(...e);break;case je.clearMappings:this.clearMappings();break;case je.deleteMapping:this.deleteMapping(...e)}}addMapping(A,e,n){this._keyMappings[A]===void 0&&(this._keyMappings[A]=[]),this._keyMappings[A][e]=n}deleteMapping(A,e){this._keyMappings[A]?.[e]!==void 0&&(this._keyMappings[A][e]=void 0)}clearMappings(){this._keyMappings=[]}setMappings(A){this._keyMappings=A}getMappings(){return this._keyMappings}getVelocity(A,e){let n=this._keyMappings[A]?.[e];return n?n.velocity:-1}hasOverridePatch(A,e){let n=this._keyMappings[A]?.[e]?.patch?.bank;return n!==void 0&&n>=0}getPatch(A,e){let n=this._keyMappings[A]?.[e];if(n)return n.patch;throw new Error("No modifier.")}};var Hn="spessasynth-worklet-system",Yn=350,GA=9,At=16,et="gs";var NA={loadNewSongList:0,pause:1,stop:2,play:3,setTime:4,changeMIDIMessageSending:5,setPlaybackRate:6,setLoop:7,changeSong:8,getMIDI:9,setSkipToFirstNote:10,setPreservePlaybackState:11},bA={midiEvent:0,songChange:1,textEvent:2,timeChange:3,pause:4,getMIDI:5,midiError:6};function _A(t,A){let e=0;for(let n=8*(A-1);n>=0;n-=8)e|=t[t.currentIndex++]<<n;return e>>>0}function Jn(t,A){if(this.ignoreEvents)return;if(this.sendMIDIMessages&&t.messageStatusByte>=128){this.sendMIDIMessage([t.messageStatusByte,...t.messageData]);return}let e=be(t.messageStatusByte),n=this.midiPortChannelOffsets[this.midiPorts[A]]||0;switch(e.channel+=n,e.status){case M.noteOn:let s=t.messageData[1];if(s>0)this.synth.noteOn(e.channel,t.messageData[0],s),this.playingNotes.push({midiNote:t.messageData[0],channel:e.channel,velocity:s});else{this.synth.noteOff(e.channel,t.messageData[0]);let a=this.playingNotes.findIndex(C=>C.midiNote===t.messageData[0]&&C.channel===e.channel);a!==-1&&this.playingNotes.splice(a,1)}break;case M.noteOff:this.synth.noteOff(e.channel,t.messageData[0]);let o=this.playingNotes.findIndex(a=>a.midiNote===t.messageData[0]&&a.channel===e.channel);o!==-1&&this.playingNotes.splice(o,1);break;case M.pitchBend:this.synth.pitchWheel(e.channel,t.messageData[1],t.messageData[0]);break;case M.controllerChange:this.synth.controllerChange(e.channel,t.messageData[0],t.messageData[1]);break;case M.programChange:this.synth.programChange(e.channel,t.messageData[0]);break;case M.polyPressure:this.synth.polyPressure(e.channel,t.messageData[0],t.messageData[1]);break;case M.channelPressure:this.synth.channelPressure(e.channel,t.messageData[0]);break;case M.systemExclusive:this.synth.systemExclusive(t.messageData,n);break;case M.setTempo:this.oneTickToSeconds=60/(Br(t)*this.midiData.timeDivision),this.oneTickToSeconds===0&&(this.oneTickToSeconds=60/(120*this.midiData.timeDivision),T("invalid tempo! falling back to 120 BPM"));break;case M.timeSignature:case M.endOfTrack:case M.midiChannelPrefix:case M.songPosition:case M.activeSensing:case M.keySignature:case M.sequenceNumber:case M.sequenceSpecific:break;case M.text:case M.lyric:case M.copyright:case M.trackName:case M.marker:case M.cuePoint:case M.instrumentName:case M.programName:let i=-1;e.status===M.lyric&&(i=Math.min(this.midiData.lyrics.indexOf(t.messageData)+1,this.midiData.lyrics.length-1)),this.post(bA.textEvent,[t.messageData,e.status,i]);break;case M.midiPort:this.assignMIDIPort(A,t.messageData[0]);break;case M.reset:this.synth.stopAllChannels(),this.synth.resetAllControllers();break;default:T(`%cUnrecognized Event: %c${t.messageStatusByte}%c status byte: %c${Object.keys(M).find(a=>M[a]===e.status)}`,g.warn,g.unrecognized,g.warn,g.value);break}}function Pn(){for(let t=0;t<16;t++)this.synth.createWorkletChannel(!0),t===GA&&this.synth.setDrums(this.synth.workletProcessorChannels.length-1,!0)}function Br(t){return t.messageData.currentIndex=0,6e7/_A(t.messageData,3)}function qn(){let t=this.currentTime;for(;this.playedTime<t;){let A=this._findFirstEventIndex(),e=this.tracks[A][this.eventIndex[A]];if(this._processEvent(e,A),this.eventIndex[A]++,A=this._findFirstEventIndex(),this.tracks[A].length<=this.eventIndex[A]){if(this.loop){this.setTimeTicks(this.midiData.loop.start);return}this.eventIndex[A]--,this.pause(!0),this.songs.length>1&&this.nextSong();return}let n=this.tracks[A][this.eventIndex[A]];if(this.playedTime+=this.oneTickToSeconds*(n.ticks-e.ticks),this.midiData.loop.end<=e.ticks&&this.loop&&this.currentLoopCount>0){this.currentLoopCount--,this.setTimeTicks(this.midiData.loop.start);return}else if(t>=this.duration){if(this.loop&&this.currentLoopCount>0){this.currentLoopCount--,this.setTimeTicks(this.midiData.loop.start);return}this.eventIndex[A]--,this.pause(!0),this.songs.length>1&&this.nextSong();return}}}function On(){let t=0,A=1/0;return this.tracks.forEach((e,n)=>{this.eventIndex[n]>=e.length||e[this.eventIndex[n]].ticks<A&&(t=n,A=e[this.eventIndex[n]].ticks)}),t}var Se=class{timeDivision=0;duration=0;tempoChanges=[{ticks:0,tempo:120}];copyright="";tracksAmount=0;lyrics=[];firstNoteOn=0;keyRange={min:0,max:127};lastVoiceEventTick=0;midiPorts=[0];midiPortChannelOffsets=[0];usedChannelsOnTrack=[];loop={start:0,end:0};midiName="";midiNameUsesFileName=!1;fileName="";rawMidiName=void 0;format=0;RMIDInfo={};bankOffset=0};var tt=class extends Se{isEmbedded=!1;constructor(A){super(),this.timeDivision=A.timeDivision,this.duration=A.duration,this.tempoChanges=A.tempoChanges,this.copyright=A.copyright,this.tracksAmount=A.tracksAmount,this.lyrics=A.lyrics,this.firstNoteOn=A.firstNoteOn,this.keyRange=A.keyRange,this.lastVoiceEventTick=A.lastVoiceEventTick,this.midiPorts=A.midiPorts,this.midiPortChannelOffsets=A.midiPortChannelOffsets,this.usedChannelsOnTrack=A.usedChannelsOnTrack,this.loop=A.loop,this.midiName=A.midiName,this.midiNameUsesFileName=A.midiNameUsesFileName,this.fileName=A.fileName,this.rawMidiName=A.rawMidiName,this.format=A.format,this.RMIDInfo=A.RMIDInfo,this.bankOffset=A.bankOffset,this.isEmbedded=A.embeddedSoundFont!==void 0}},ma={duration:99999,firstNoteOn:0,loop:{start:0,end:123456},lastVoiceEventTick:123456,lyrics:[],copyright:"",midiPorts:[],midiPortChannelOffsets:[],tracksAmount:0,tempoChanges:[{ticks:0,tempo:120}],fileName:"NOT_LOADED.mid",midiName:"Loading...",rawMidiName:new Uint8Array([76,111,97,100,105,110,103,46,46,46]),usedChannelsOnTrack:[],timeDivision:0,keyRange:{min:0,max:127},isEmbedded:!1,RMIDInfo:{},bankOffset:0,midiNameUsesFileName:!1,format:0};function F(t,A){let e=0;for(let n=0;n<A;n++)e|=t[t.currentIndex++]<<n*8;return e>>>0}function De(t,A,e){for(let n=0;n<e;n++)t[t.currentIndex++]=A>>n*8&255}function L(t,A){t[t.currentIndex++]=A&255,t[t.currentIndex++]=A>>8}function K(t,A){De(t,A,4)}function se(t,A){let e=A<<8|t;return e>32767?e-65536:e}function Vn(t){return t>127?t-256:t}function _(t,A,e=void 0,n=!0){if(e){let s=t.slice(t.currentIndex,t.currentIndex+A);return t.currentIndex+=A,new TextDecoder(e.replace(/[^\x20-\x7E]/g,"")).decode(s.buffer)}else{let s=!1,o="";for(let i=0;i<A;i++){let a=t[t.currentIndex++];if(!s){if((a<32||a>127)&&a!==10){if(n){s=!0;continue}else if(a===0){s=!0;continue}}o+=String.fromCharCode(a)}}return o}}function Kn(t,A=0){let e=t.length;A>0&&(e=A);let n=new b(e);return yA(n,t,A),n}function Be(t){return Kn(t,t.length+1)}function yA(t,A,e=0){e>0&&A.length>e&&(A=A.slice(0,e));for(let n=0;n<A.length;n++)t[t.currentIndex++]=A.charCodeAt(n);if(e>A.length)for(let n=0;n<e-A.length;n++)t[t.currentIndex++]=0;return t}var oA=class{constructor(A,e,n){this.header=A,this.size=e,this.chunkData=n}};function z(t,A=!0,e=!1){let n=_(t,4),s=F(t,4),o;return A&&(o=new b(t.buffer.slice(t.currentIndex,t.currentIndex+s))),(A||e)&&(t.currentIndex+=s),s%2!==0&&t[t.currentIndex]===0&&t.currentIndex++,new oA(n,s,o)}function gA(t,A=void 0){let e=8+t.size;t.size%2!==0&&e++,A&&(e+=A.length);let n=new b(e);return A&&(n.set(A,n.currentIndex),n.currentIndex+=A.length),yA(n,t.header),K(n,e-8-(A?.length||0)),n.set(t.chunkData,n.currentIndex),n}function tA(t,A,e=!1,n=!1){if(e){let B=new Uint8Array(A.length+1);B.set(A),A=B}let s=8,o=s+A.length,i=A.length;o%2!==0&&o++;let a=t;n&&(o+=4,i+=4,s+=4,a="LIST");let C=new b(o);return yA(C,a),K(C,i),n&&yA(C,t),C.set(A,s),C}function MA(t,A){return t.find(e=>e.header!=="LIST"?!1:(e.chunkData.currentIndex=0,_(e.chunkData,4)===A))}function nt(t){let A=0;for(;t;){let e=t[t.currentIndex++];if(A=A<<7|e&127,e>>7!==1)break}return A}var st={name:"INAM",album:"IPRD",album2:"IALB",artist:"IART",genre:"IGNR",picture:"IPIC",copyright:"ICOP",creationDate:"ICRD",comment:"ICMT",engineer:"IENG",software:"ISFT",encoding:"IENC",midiEncoding:"MENC",bankOffset:"DBNK"};var ot=class t extends Se{embeddedSoundFont=void 0;tracks=[];static copyFrom(A){let e=new t;return e.midiName=A.midiName,e.midiNameUsesFileName=A.midiNameUsesFileName,e.fileName=A.fileName,e.timeDivision=A.timeDivision,e.duration=A.duration,e.copyright=A.copyright,e.tracksAmount=A.tracksAmount,e.firstNoteOn=A.firstNoteOn,e.keyRange={...A.keyRange},e.lastVoiceEventTick=A.lastVoiceEventTick,e.loop={...A.loop},e.format=A.format,e.bankOffset=A.bankOffset,e.tempoChanges=[...A.tempoChanges],e.lyrics=A.lyrics.map(n=>new Uint8Array(n)),e.midiPorts=[...A.midiPorts],e.midiPortChannelOffsets=[...A.midiPortChannelOffsets],e.usedChannelsOnTrack=A.usedChannelsOnTrack.map(n=>new Set(n)),e.rawMidiName=A.rawMidiName?new Uint8Array(A.rawMidiName):void 0,e.embeddedSoundFont=A.embeddedSoundFont?A.embeddedSoundFont.slice():void 0,e.RMIDInfo={...A.RMIDInfo},e.tracks=A.tracks.map(n=>[...n]),e}flush(){let A=[];for(let s of this.tracks){s.sort((i,a)=>i.ticks-a.ticks);let o=s.find(i=>(i.messageStatusByte&240)===M.noteOn);o&&A.push(o.ticks)}this.firstNoteOn=Math.min(...A),this.lastVoiceEventTick=0,this.tempoChanges=[{ticks:0,tempo:120}],this.midiPorts=[],this.midiPortChannelOffsets=[];let e=0;this.usedChannelsOnTrack=this.tracks.map(()=>new Set),this.tracks.forEach((s,o)=>{this.midiPorts.push(-1),s.forEach(i=>{if(i.messageStatusByte>=128&&i.messageStatusByte<240&&i.ticks>this.lastVoiceEventTick&&(this.lastVoiceEventTick=i.ticks),i.messageStatusByte===M.setTempo)this.tempoChanges.push({ticks:i.ticks,tempo:6e7/_A(i.messageData,3)});else if((i.messageStatusByte&240)===M.noteOn)this.usedChannelsOnTrack[o].add(i.messageData[0]);else if(i.messageStatusByte===M.midiPort){let a=i.messageData[0];this.midiPorts[o]=a,this.midiPortChannelOffsets[a]===void 0&&(this.midiPortChannelOffsets[a]=e,e+=16)}})}),this.loop={start:this.firstNoteOn,end:this.lastVoiceEventTick},this.tempoChanges.reverse(),this.duration=he(this.lastVoiceEventTick,this);let n=0;for(let s of this.midiPorts)if(s!==-1){n=s;break}this.midiPorts=this.midiPorts.map(s=>s===-1?n:s),this.midiPortChannelOffsets.length===0&&(this.midiPortChannelOffsets=[0])}};function he(t,A){let e=0;for(;t>0;){let n=A.tempoChanges.find(o=>o.ticks<t),s=t-n.ticks;e+=s*60/(n.tempo*A.timeDivision),t-=s}return e}var hr=new Uint8Array([65,16,69,18,16,0,0]),rt=class extends ot{constructor(A,e=""){super(),QA("%cParsing MIDI File...",g.info);let n=new b(A),s,o=!1,i=!1,a=!1,C=_(n,4);if(n.currentIndex-=4,C==="RIFF"){n.currentIndex+=8;let y=_(n,4,void 0,!1);if(y!=="RMID")throw V(),new SyntaxError(`Invalid RMIDI Header! Expected "RMID", got "${y}"`);let S=z(n);if(S.header!=="data")throw V(),new SyntaxError(`Invalid RMIDI Chunk header! Expected "data", got "${y}"`);for(s=S.chunkData;n.currentIndex<=n.length;){let w=n.currentIndex,H=z(n,!0);if(H.header==="RIFF"){let R=_(H.chunkData,4).toLowerCase();R==="sfbk"||R==="sfpk"||R==="dls "?(p("%cFound embedded soundfont!",g.recognized),this.embeddedSoundFont=n.slice(w,w+H.size).buffer):T(`Unknown RIFF chunk: "${R}"`),R==="dls "&&(a=!0)}else if(H.header==="LIST"&&_(H.chunkData,4)==="INFO"){for(p("%cFound RMIDI INFO chunk!",g.recognized),this.RMIDInfo={};H.chunkData.currentIndex<=H.size;){let x=z(H.chunkData,!0);this.RMIDInfo[x.header]=x.chunkData}this.RMIDInfo.ICOP&&(o=!0,this.copyright=_(this.RMIDInfo.ICOP,this.RMIDInfo.ICOP.length,void 0,!1).replaceAll(`
|
|
10
|
-
`," ")),this.RMIDInfo.INAM&&(this.rawMidiName=this.RMIDInfo[
|
|
11
|
-
`," "),i=!0),this.RMIDInfo.IALB&&!this.RMIDInfo.IPRD&&(this.RMIDInfo.IPRD=this.RMIDInfo.IALB),this.RMIDInfo.PRD&&!this.RMIDInfo.IALB&&(this.RMIDInfo.IALB=this.RMIDInfo.IPRD),this.bankOffset=1,this.RMIDInfo[
|
|
12
|
-
`)
|
|
13
|
-
`;this.copyright+=iA,p(`%cDecoded Roland SC message! %c${iA}`,g.recognized,g.value)}break;default:if((I&240)===M.controllerChange)switch(AA[0]){case 2:case 116:d=x;break;case 4:case 117:Q===null?Q=x:Q=0;break;case 0:a&&AA[1]!==0&&AA[1]!==127&&(p("%cDLS RMIDI with offset 1 detected!",g.recognized),this.bankOffset=1)}}}this.tracks.push(S),this.usedChannelsOnTrack.push(H),p(`%cParsed %c${this.tracks.length}%c / %c${this.tracksAmount}`,g.info,g.value,g.info,g.value)}p("%cAll tracks parsed correctly!",g.recognized),QA("%cCorrecting loops, ports and detecting notes...",g.info);let c=[];for(let y of this.tracks){let S=y.find(w=>(w.messageStatusByte&240)===M.noteOn);S&&c.push(S.ticks)}this.firstNoteOn=Math.min(...c),p(`%cFirst note-on detected at: %c${this.firstNoteOn}%c ticks!`,g.info,g.recognized,g.info),d!==null&&Q===null?(d=this.firstNoteOn,Q=this.lastVoiceEventTick):(d===null&&(d=this.firstNoteOn),(Q===null||Q===0)&&(Q=this.lastVoiceEventTick)),this.loop={start:d,end:Q},p(`%cLoop points: start: %c${this.loop.start}%c end: %c${this.loop.end}`,g.info,g.recognized,g.info,g.recognized);let f=0;for(let y of this.midiPorts)if(y!==-1){f=y;break}if(this.midiPorts=this.midiPorts.map(y=>y===-1?f:y),this.midiPortChannelOffsets.length===0&&(this.midiPortChannelOffsets=[0]),this.midiPortChannelOffsets.length<2?p("%cNo additional MIDI Ports detected.",g.info):p("%cMIDI Ports detected!",g.recognized),!i)if(this.tracks.length>1){if(this.tracks[0].find(y=>y.messageStatusByte>=M.noteOn&&y.messageStatusByte<M.polyPressure)===void 0){let y=this.tracks[0].find(S=>S.messageStatusByte===M.trackName);y&&(this.rawMidiName=y.messageData,this.midiName=_(y.messageData,y.messageData.length,void 0,!1))}}else{let y=this.tracks[0].find(S=>S.messageStatusByte===M.trackName);y&&(this.rawMidiName=y.messageData,this.midiName=_(y.messageData,y.messageData.length,void 0,!1))}if(this.fileName=e,this.midiName=this.midiName.trim(),this.midiNameUsesFileName=!1,this.midiName.length===0){p("%cNo name detected. Using the alt name!",g.info),this.midiName=Rn(e),this.midiNameUsesFileName=!0,this.rawMidiName=new Uint8Array(this.midiName.length);for(let y=0;y<this.midiName.length;y++)this.rawMidiName[y]=this.midiName.charCodeAt(y)}else p(`%cMIDI Name detected! %c"${this.midiName}"`,g.info,g.recognized);this.tempoChanges.reverse(),this.duration=he(this.lastVoiceEventTick,this),V(),p(`%cMIDI file parsed. Total tick time: %c${this.lastVoiceEventTick}%c, total seconds time: %c${this.duration}`,g.info,g.recognized,g.info,g.recognized),V()}readMIDIChunk(A){let e={};e.type=_(A,4),e.size=_A(A,4),e.data=new b(e.size);let n=A.slice(A.currentIndex,A.currentIndex+e.size);return e.data.set(n,0),A.currentIndex+=e.size,e}};function Zn(t,A){QA("%cSearching for all used programs and keys...",g.info);let e=16+t.midiPortChannelOffsets.reduce((Q,l)=>l>Q?l:Q),n=[];for(let Q=0;Q<e;Q++){let l=Q%16===GA?128:0;n.push({program:0,bank:l,drums:Q%16===GA,string:`${l}:0`})}function s(Q){let l=A.getPreset(Q.bank,Q.program);Q.bank=l.bank,Q.program=l.program,Q.string=Q.bank+":"+Q.program,o[Q.string]||(p(`%cDetected a new preset: %c${Q.string}`,g.info,g.recognized),o[Q.string]=new Set)}let o={},i=Array(t.tracks.length).fill(0),a=t.tracks.length;function C(){let Q=0,l=1/0;return t.tracks.forEach((c,f)=>{i[f]>=c.length||c[i[f]].ticks<l&&(Q=f,l=c[i[f]].ticks)}),Q}let B=t.midiPorts.slice(),d="gs";for(;a>0;){let Q=C(),l=t.tracks[Q];if(i[Q]>=l.length){a--;continue}let c=l[i[Q]];if(i[Q]++,c.messageStatusByte===M.midiPort){B[Q]=c.messageData[0];continue}let f=c.messageStatusByte&240;if(f!==M.noteOn&&f!==M.controllerChange&&f!==M.programChange&&f!==M.systemExclusive)continue;let y=(c.messageStatusByte&15)+t.midiPortChannelOffsets[B[Q]]||0,S=n[y];switch(f){case M.programChange:S.program=c.messageData[0],s(S);break;case M.controllerChange:if(c.messageData[0]!==k.bankSelect||d==="gs"&&S.drums)continue;let w=c.messageData[1],H=Math.max(0,w-t.bankOffset);if(d==="xg"){let G=w===120||w===126||w===127;G!==S.drums?(S.drums=G,S.bank=S.drums?128:H,s(S)):S.bank=S.drums?128:H;continue}n[y].bank=H;break;case M.noteOn:if(c.messageData[1]===0)continue;s(S),o[S.string].add(`${c.messageData[0]}-${c.messageData[1]}`);break;case M.systemExclusive:if(c.messageData[0]!==65||c.messageData[2]!==66||c.messageData[3]!==18||c.messageData[4]!==64||!(c.messageData[5]&16)||c.messageData[6]!==21){c.messageData[0]===67&&c.messageData[2]===76&&c.messageData[5]===126&&c.messageData[6]===0&&(d="xg");continue}let R=[9,0,1,2,3,4,5,6,7,8,10,11,12,13,14,15][c.messageData[5]&15]+t.midiPortChannelOffsets[B[Q]],x=!!(c.messageData[7]>0&&c.messageData[5]>>4);S=n[R],S.drums=x,S.bank=x?128:0,s(S);break}}for(let Q of Object.keys(o))o[Q].size===0&&(p(`%cDetected change but no keys for %c${Q}`,g.info,g.value),delete o[Q]);return V(),o}function Wn(t,A){this.midiData.usedChannelsOnTrack[t].size!==0&&(this.midiPortChannelOffset===0&&(this.midiPortChannelOffset+=16,this.midiPortChannelOffsets[A]=0),this.midiPortChannelOffsets[A]===void 0&&(this.synth.workletProcessorChannels.length<this.midiPortChannelOffset+15&&this._addNewMidiPort(),this.midiPortChannelOffsets[A]=this.midiPortChannelOffset,this.midiPortChannelOffset+=16),this.midiPorts[t]=A)}function Xn(t,A=!0){if(this.stop(),!t.tracks)throw new Error("This MIDI has no tracks!");if(this.oneTickToSeconds=60/(120*t.timeDivision),this.midiData=t,this.currentLoopCount=this.loopCount,this.midiData.embeddedSoundFont!==void 0)p("%cEmbedded soundfont detected! Using it.",g.recognized),this.synth.setEmbeddedSoundFont(this.midiData.embeddedSoundFont,this.midiData.bankOffset);else{this.synth.overrideSoundfont&&this.synth.clearSoundFont(!0,!0),QA("%cPreloading samples...",g.info);let e=Zn(this.midiData,this.synth.soundfontManager);for(let[n,s]of Object.entries(e)){let o=parseInt(n.split(":")[0]),i=parseInt(n.split(":")[1]),a=this.synth.getPreset(o,i);p(`%cPreloading used samples on %c${a.presetName}%c...`,g.info,g.recognized,g.info);for(let C of s){let B=C.split("-");a.preloadSpecific(parseInt(B[0]),parseInt(B[1]))}}V()}if(this.tracks=this.midiData.tracks,this.midiPorts=this.midiData.midiPorts,this.midiPortChannelOffset=0,this.midiPortChannelOffsets={},this.midiData.midiPorts.forEach((e,n)=>{this.assignMIDIPort(n,e)}),this.duration=this.midiData.duration,this.firstNoteTime=he(this.midiData.firstNoteOn,this.midiData),p(`%cTotal song time: ${vt(Math.ceil(this.duration)).time}`,g.recognized),this.post(bA.songChange,[new tt(this.midiData),this.songIndex,A]),this.duration<=1&&(T(`%cVery short song: (${vt(Math.round(this.duration)).time}). Disabling loop!`,g.warn),this.loop=!1),A)this.play(!0);else{let e=this._skipToFirstNoteOn?this.midiData.firstNoteOn-1:0;this.setTimeTicks(e),this.pause()}}function _n(t,A=!0){this.songs=t.reduce((e,n)=>{if(n.duration)return e.push(n),e;try{e.push(new rt(n.binary,n.altName||""))}catch(s){return this.post(bA.midiError,s.message),e}return e},[]),!(this.songs.length<1)&&(this.songIndex=0,this.songs.length>1&&(this.loop=!1),this.loadNewSequence(this.songs[this.songIndex],A))}function zn(){if(this.songs.length===1){this.currentTime=0;return}this.songIndex++,this.songIndex%=this.songs.length,this.loadNewSequence(this.songs[this.songIndex])}function jn(){if(this.songs.length===1){this.currentTime=0;return}this.songIndex--,this.songIndex<0&&(this.songIndex=this.songs.length-1),this.loadNewSequence(this.songs[this.songIndex])}var Le=ye.slice(0,128);function $n(t,A=void 0){this.oneTickToSeconds=60/(120*this.midiData.timeDivision),this.synth.resetAllControllers(),this.sendMIDIReset(),this._resetTimers();let e=this.synth.workletProcessorChannels.length,n=Array(e).fill(8192),s=[];for(let a=0;a<e;a++)s.push({program:-1,bank:0,actualBank:0});let o=a=>a===k.dataDecrement||a===k.dataIncrement||a===k.dataEntryMsb||a===k.dataDecrement||a===k.lsbForControl6DataEntry||a===k.RPNLsb||a===k.RPNMsb||a===k.NRPNLsb||a===k.NRPNMsb||a===k.bankSelect||a===k.lsbForControl0BankSelect||a===k.resetAllControllers,i=[];for(let a=0;a<e;a++)i.push(Array.from(Le));for(;;){let a=this._findFirstEventIndex(),C=this.tracks[a][this.eventIndex[a]];if(A!==void 0){if(C.ticks>=A)break}else if(this.playedTime>=t)break;let B=be(C.messageStatusByte),d=B.channel+(this.midiPortChannelOffsets[this.midiPorts[a]]||0);switch(B.status){case M.noteOn:case M.noteOff:case M.keySignature:break;case M.pitchBend:n[d]=C.messageData[1]<<7|C.messageData[0];break;case M.programChange:let l=s[d];l.program=C.messageData[0],l.actualBank=l.bank;break;case M.controllerChange:let c=C.messageData[0];if(o(c)){let f=C.messageData[1];if(c===k.bankSelect){s[d].bank=f;break}else c===k.resetAllControllers&&(i[d]=Array.from(Le));this.sendMIDIMessages?this.sendMIDICC(d,c,f):this.synth.controllerChange(d,c,f)}else i[d]===void 0&&(i[d]=Array.from(Le)),i[d][c]=C.messageData[1];break;default:this._processEvent(C,a);break}this.eventIndex[a]++,a=this._findFirstEventIndex();let Q=this.tracks[a][this.eventIndex[a]];if(Q===void 0)return this.stop(),!1;this.playedTime+=this.oneTickToSeconds*(Q.ticks-C.ticks)}if(this.sendMIDIMessages){for(let a=0;a<e;a++)if(n[a]!==void 0&&this.sendMIDIPitchWheel(a,n[a]>>7,n[a]&127),i[a]!==void 0&&i[a].forEach((C,B)=>{C!==Le[B]&&!o(B)&&this.sendMIDICC(a,B,C)}),s[a].program>=0&&s[a].actualBank>=0){let C=s[a].actualBank;this.sendMIDICC(a,k.bankSelect,C),this.sendMIDIProgramChange(a,s[a].program)}}else for(let a=0;a<e;a++)if(n[a]!==void 0&&this.synth.pitchWheel(a,n[a]>>7,n[a]&127),i[a]!==void 0&&i[a].forEach((C,B)=>{C!==Le[B]&&!o(B)&&this.synth.controllerChange(a,B,C)}),s[a].program>=0&&s[a].actualBank>=0){let C=s[a].actualBank;this.synth.controllerChange(a,k.bankSelect,C),this.synth.programChange(a,s[a].program)}return!0}function As(t=!1){if(this.midiData!==void 0){if(t){this.pausedTime=void 0,this.currentTime=0;return}if(this.currentTime>=this.duration){this.pausedTime=void 0,this.currentTime=0;return}this.paused&&(this._recalculateStartTime(this.pausedTime),this.pausedTime=void 0),this.sendMIDIMessages||this.playingNotes.forEach(A=>{this.synth.noteOn(A.channel,A.midiNote,A.velocity,!1,!0)}),this.setProcessHandler()}}function es(t){this.stop(),this.playingNotes=[],this.pausedTime=void 0,this.post(bA.timeChange,currentTime-he(t,this.midiData));let A=this._playTo(0,t);this._recalculateStartTime(this.playedTime),A&&this.play()}function ts(t){this.absoluteStartTime=currentTime-t/this._playbackRate}function ns(t,A){switch(t){default:break;case NA.loadNewSongList:this.loadNewSongList(A[0],A[1]);break;case NA.pause:this.pause();break;case NA.play:this.play(A);break;case NA.stop:this.stop();break;case NA.setTime:this.currentTime=A;break;case NA.changeMIDIMessageSending:this.sendMIDIMessages=A;break;case NA.setPlaybackRate:this.playbackRate=A;break;case NA.setLoop:this.loop=A;break;case NA.changeSong:A?this.nextSong():this.previousSong();break;case NA.getMIDI:this.post(bA.getMIDI,this.midiData);break;case NA.setSkipToFirstNote:this._skipToFirstNoteOn=A;break;case NA.setPreservePlaybackState:this.preservePlaybackState=A}}function ss(t,A=void 0){this.synth.enableEventSystem&&this.synth.post({messageType:DA.sequencerSpecific,messageData:{messageType:t,messageData:A}})}function os(t){this.post(bA.midiEvent,t)}function rs(t,A,e){t%=16,this.sendMIDIMessages&&this.sendMIDIMessage([M.controllerChange|t,A,e])}function is(t,A){t%=16,this.sendMIDIMessages&&this.sendMIDIMessage([M.programChange|t,A])}function as(t,A,e){t%=16,this.sendMIDIMessages&&this.sendMIDIMessage([M.pitchBend|t,e,A])}function gs(){if(this.sendMIDIMessages){this.sendMIDIMessage([M.reset]);for(let t=0;t<At;t++)this.sendMIDIMessage([M.controllerChange|t,k.allSoundOff,0]),this.sendMIDIMessage([M.controllerChange|t,k.resetAllControllers,0])}}var BA=class{constructor(A){this.synth=A,this.ignoreEvents=!1,this.sendMIDIMessages=!1,this.loopCount=1/0,this.currentLoopCount=this.loopCount,this.eventIndex=[],this.songIndex=0,this.playedTime=0,this.pausedTime=void 0,this.absoluteStartTime=currentTime,this._playbackRate=1,this.playingNotes=[],this.loop=!0,this.midiData=void 0,this.midiPorts=[],this.midiPortChannelOffset=0,this.midiPortChannelOffsets={},this._skipToFirstNoteOn=!0,this.preservePlaybackState=!1}set playbackRate(A){let e=this.currentTime;this._playbackRate=A,this.currentTime=e}get currentTime(){return this.pausedTime!==void 0?this.pausedTime:(currentTime-this.absoluteStartTime)*this._playbackRate}set currentTime(A){if(A>this.duration||A<0){this._skipToFirstNoteOn?this.setTimeTicks(this.midiData.firstNoteOn-1):this.setTimeTicks(0);return}if(this._skipToFirstNoteOn&&A<this.firstNoteTime){this.setTimeTicks(this.midiData.firstNoteOn-1);return}this.stop(),this.playingNotes=[];let e=this.paused&&this.preservePlaybackState;this.pausedTime=void 0,this.post(bA.timeChange,currentTime-A),this._playTo(A),this._recalculateStartTime(A),e?this.pause():this.play()}get paused(){return this.pausedTime!==void 0}pause(A=!1){if(this.paused){T("Already paused");return}this.pausedTime=this.currentTime,this.stop(),this.post(bA.pause,A)}stop(){this.clearProcessHandler();for(let A=0;A<16;A++)this.synth.controllerChange(A,k.sustainPedal,0);if(this.synth.stopAllChannels(),this.sendMIDIMessages){for(let A of this.playingNotes)this.sendMIDIMessage([M.noteOff|A.channel%16,A.midiNote]);for(let A=0;A<At;A++)this.sendMIDICC(A,k.allNotesOff,0)}}_resetTimers(){this.playedTime=0,this.eventIndex=Array(this.tracks.length).fill(0)}setProcessHandler(){this.synth.processTickCallback=this._processTick.bind(this)}clearProcessHandler(){this.synth.processTickCallback=void 0}};BA.prototype.sendMIDIMessage=os;BA.prototype.sendMIDIReset=gs;BA.prototype.sendMIDICC=rs;BA.prototype.sendMIDIProgramChange=is;BA.prototype.sendMIDIPitchWheel=as;BA.prototype.assignMIDIPort=Wn;BA.prototype.post=ss;BA.prototype.processMessage=ns;BA.prototype._processEvent=Jn;BA.prototype._addNewMidiPort=Pn;BA.prototype._processTick=qn;BA.prototype._findFirstEventIndex=On;BA.prototype.loadNewSequence=Xn;BA.prototype.loadNewSongList=_n;BA.prototype.nextSong=zn;BA.prototype.previousSong=jn;BA.prototype.play=As;BA.prototype._playTo=$n;BA.prototype.setTimeTicks=es;BA.prototype._recalculateStartTime=ts;var Ot=new Float32Array(30001);for(let t=0;t<Ot.length;t++){let A=-15e3+t;Ot[t]=Math.pow(2,A/1200)}function KA(t){return t<=-32767?0:Ot[t- -15e3]}var it=-2e4,Is=16500,Vt=new Float32Array(Is-it+1);for(let t=0;t<Vt.length;t++){let A=it+t;Vt[t]=440*Math.pow(2,(A-6900)/1200)}function Ue(t){return t<it||t>Is?440*Math.pow(2,(t-6900)/1200):Vt[~~t-it]}var Zt=-1660,cr=1600,Kt=new Float32Array((cr-Zt)*100+1);for(let t=0;t<Kt.length;t++){let A=(Zt*100+t)/100;Kt[t]=Math.pow(10,-A/20)}function JA(t){return Kt[Math.floor((t-Zt)*100)]}function at(t,A,e){if(e<t)return 0;let n=(e-t)/(1/A)+.25;return Math.abs(n-~~(n+.5))*4-1}var fA=16384,$A=new Float32Array(fA+1),ce=new Float32Array(fA+1);$A[0]=0;$A[$A.length-1]=1;ce[0]=0;ce[ce.length-1]=1;for(let t=1;t<fA-1;t++){let A=-.4166666666666667*Math.log(t/($A.length-1))/Math.LN10;ce[t]=1-A,$A[$A.length-1-t]=A}function le(t,A,e,n){switch(t&&(e=1-e),A){case uA.linear:return n?e*2-1:e;case uA.switch:return e=e>.5?1:0,n?e*2-1:e;case uA.concave:return n?(e=e*2-1,e<0?-$A[~~(e*-fA)]:$A[~~(e*fA)]):$A[~~(e*fA)];case uA.convex:return n?(e=e*2-1,e<0?-ce[~~(e*-fA)]:ce[~~(e*fA)]):ce[~~(e*fA)]}}var Wt=1,Xt=new Float32Array(1e3);for(let t=0;t<Xt.length;t++)Xt[t]=le(0,uA.convex,t/1e3,0);var PA=class t{attackDuration=0;decayDuration=0;holdDuration=0;releaseDuration=0;sustainLevel=0;delayEnd=0;attackEnd=0;holdEnd=0;decayEnd=0;releaseStartLevel=0;currentValue=0;static startRelease(A){t.recalculate(A)}static recalculate(A){let e=A.modulationEnvelope;A.isInRelease&&(e.releaseStartLevel=t.getValue(A,A.releaseStartTime,!0)),e.sustainLevel=1-A.modulatedGenerators[r.sustainModEnv]/1e3,e.attackDuration=KA(A.modulatedGenerators[r.attackModEnv]);let n=(60-A.midiNote)*A.modulatedGenerators[r.keyNumToModEnvDecay],s=KA(A.modulatedGenerators[r.decayModEnv]+n);e.decayDuration=s*(1-e.sustainLevel);let o=(60-A.midiNote)*A.modulatedGenerators[r.keyNumToModEnvHold];e.holdDuration=KA(o+A.modulatedGenerators[r.holdModEnv]);let i=KA(A.modulatedGenerators[r.releaseModEnv]);e.releaseDuration=i*e.releaseStartLevel,e.delayEnd=A.startTime+KA(A.modulatedGenerators[r.delayModEnv]),e.attackEnd=e.delayEnd+e.attackDuration,e.holdEnd=e.attackEnd+e.holdDuration,e.decayEnd=e.holdEnd+e.decayDuration}static getValue(A,e,n=!1){let s=A.modulationEnvelope;return A.isInRelease&&!n?s.releaseStartLevel===0?0:Math.max(0,(1-(e-A.releaseStartTime)/s.releaseDuration)*s.releaseStartLevel):(e<s.delayEnd?s.currentValue=0:e<s.attackEnd?s.currentValue=Xt[~~((1-(s.attackEnd-e)/s.attackDuration)*1e3)]:e<s.holdEnd?s.currentValue=Wt:e<s.decayEnd?s.currentValue=(1-(s.decayEnd-e)/s.decayDuration)*(s.sustainLevel-Wt)+Wt:s.currentValue=s.sustainLevel,s.currentValue)}};var ke={linear:0,nearestNeighbor:1,fourthOrder:2};function Es(t,A){let e=t.sample,n=e.cursor,s=e.sampleData;if(e.isLooping){let o=e.loopEnd-e.loopStart;for(let i=0;i<A.length;i++){for(;n>=e.loopEnd;)n-=o;let a=~~n,C=a+1;for(;C>=e.loopEnd;)C-=o;let B=n-a,d=s[C],Q=s[a];A[i]=Q+(d-Q)*B,n+=e.playbackStep*t.currentTuningCalculated}}else{if(e.loopingMode===2&&!t.isInRelease)return;for(let o=0;o<A.length;o++){let i=~~n,a=i+1;if(a>=e.end){t.finished=!0;return}let C=n-i,B=s[a],d=s[i];A[o]=d+(B-d)*C,n+=e.playbackStep*t.currentTuningCalculated}}t.sample.cursor=n}function Cs(t,A){let e=t.sample,n=e.cursor,s=e.loopEnd-e.loopStart,o=e.sampleData;if(t.sample.isLooping)for(let i=0;i<A.length;i++){for(;n>=e.loopEnd;)n-=s;let a=~~n+1;for(;a>=e.loopEnd;)a-=s;A[i]=o[a],n+=e.playbackStep*t.currentTuningCalculated}else{if(e.loopingMode===2&&!t.isInRelease)return;for(let i=0;i<A.length;i++){let a=~~n+1;if(a>=e.end){t.finished=!0;return}A[i]=o[a],n+=e.playbackStep*t.currentTuningCalculated}}e.cursor=n}function Bs(t,A){let e=t.sample,n=e.cursor,s=e.sampleData;if(e.isLooping){let o=e.loopEnd-e.loopStart;for(let i=0;i<A.length;i++){for(;n>=e.loopEnd;)n-=o;let a=~~n,C=a+1,B=C+1,d=B+1,Q=n-a;C>=e.loopEnd&&(C-=o),B>=e.loopEnd&&(B-=o),d>=e.loopEnd&&(d-=o);let l=s[a],c=s[C],f=s[B],y=s[d],S=.5*(f-l),w=l-2.5*c+2*f-.5*y,H=.5*(y-l)+1.5*(c-f);A[i]=((H*Q+w)*Q+S)*Q+c,n+=e.playbackStep*t.currentTuningCalculated}}else{if(e.loopingMode===2&&!t.isInRelease)return;for(let o=0;o<A.length;o++){let i=~~n,a=i+1,C=a+1,B=C+1,d=n-i;if(a>=e.end||C>=e.end||B>=e.end){t.finished=!0;return}let Q=s[i],l=s[a],c=s[C],f=s[B],y=.5*(c-Q),S=Q-2.5*l+2*c-.5*f,w=.5*(f-Q)+1.5*(l-c);A[o]=((w*d+S)*d+y)*d+l,n+=e.playbackStep*t.currentTuningCalculated}}t.sample.cursor=n}var hs=.01,LA=100,_t=90,lr=15e-6,qA=class t{currentSampleTime=0;sampleRate;currentAttenuationDb=LA;state=0;releaseStartDb=LA;releaseStartTimeSamples=0;currentReleaseGain=1;attackDuration=0;decayDuration=0;releaseDuration=0;attenuation=0;attenuationTargetGain=0;attenuationTarget=0;sustainDbRelative=0;delayEnd=0;attackEnd=0;holdEnd=0;decayEnd=0;constructor(A,e){this.sampleRate=A,this.canEndOnSilentSustain=e/10>=_t}static startRelease(A){A.volumeEnvelope.releaseStartTimeSamples=A.volumeEnvelope.currentSampleTime,A.volumeEnvelope.currentReleaseGain=JA(A.volumeEnvelope.currentAttenuationDb),t.recalculate(A)}static recalculate(A){let e=A.volumeEnvelope,n=B=>Math.max(0,Math.floor(KA(B)*e.sampleRate));e.attenuationTarget=Math.max(0,Math.min(A.modulatedGenerators[r.initialAttenuation],1440))/10,e.attenuationTargetGain=JA(e.attenuationTarget),e.sustainDbRelative=Math.min(LA,A.modulatedGenerators[r.sustainVolEnv]/10);let s=Math.min(LA,e.sustainDbRelative);e.attackDuration=n(A.modulatedGenerators[r.attackVolEnv]);let o=A.modulatedGenerators[r.decayVolEnv],i=(60-A.targetKey)*A.modulatedGenerators[r.keyNumToVolEnvDecay],a=s/LA;e.decayDuration=n(o+i)*a,e.releaseDuration=n(A.modulatedGenerators[r.releaseVolEnv]),e.delayEnd=n(A.modulatedGenerators[r.delayVolEnv]),e.attackEnd=e.attackDuration+e.delayEnd;let C=(60-A.targetKey)*A.modulatedGenerators[r.keyNumToVolEnvHold];if(e.holdEnd=n(A.modulatedGenerators[r.holdVolEnv]+C)+e.attackEnd,e.decayEnd=e.decayDuration+e.holdEnd,e.state===0&&e.attackEnd===0&&(e.state=2),A.isInRelease){let B=Math.max(0,Math.min(LA,e.sustainDbRelative)),d=B/LA;switch(e.decayDuration=n(o+i)*d,e.state){case 0:e.releaseStartDb=LA;break;case 1:let l=1-(e.attackEnd-e.releaseStartTimeSamples)/e.attackDuration;e.releaseStartDb=20*Math.log10(l)*-1;break;case 2:e.releaseStartDb=0;break;case 3:e.releaseStartDb=(1-(e.decayEnd-e.releaseStartTimeSamples)/e.decayDuration)*B;break;case 4:e.releaseStartDb=B;break}e.releaseStartDb=Math.max(0,Math.min(e.releaseStartDb,LA)),e.releaseStartDb>=_t&&(A.finished=!0),e.currentReleaseGain=JA(e.releaseStartDb);let Q=(LA-e.releaseStartDb)/LA;e.releaseDuration*=Q}}static apply(A,e,n,s){let o=A.volumeEnvelope,i=n/10,a=s;if(A.isInRelease){let B=o.currentSampleTime-o.releaseStartTimeSamples;if(B>=o.releaseDuration){for(let Q=0;Q<e.length;Q++)e[Q]=0;A.finished=!0;return}let d=LA-o.releaseStartDb;for(let Q=0;Q<e.length;Q++){o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a;let l=B/o.releaseDuration*d+o.releaseStartDb;o.currentReleaseGain=o.attenuation*JA(l+i),e[Q]*=o.currentReleaseGain,o.currentSampleTime++,B++}o.currentReleaseGain<=lr&&(A.finished=!0);return}let C=0;switch(o.state){case 0:for(;o.currentSampleTime<o.delayEnd;)if(o.currentAttenuationDb=LA,e[C]=0,o.currentSampleTime++,++C>=e.length)return;o.state++;case 1:for(;o.currentSampleTime<o.attackEnd;){o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a;let B=1-(o.attackEnd-o.currentSampleTime)/o.attackDuration;if(e[C]*=B*o.attenuation*JA(i),o.currentAttenuationDb=0,o.currentSampleTime++,++C>=e.length)return}o.state++;case 2:for(;o.currentSampleTime<o.holdEnd;)if(o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a,e[C]*=o.attenuation*JA(i),o.currentAttenuationDb=0,o.currentSampleTime++,++C>=e.length)return;o.state++;case 3:for(;o.currentSampleTime<o.decayEnd;)if(o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a,o.currentAttenuationDb=(1-(o.decayEnd-o.currentSampleTime)/o.decayDuration)*o.sustainDbRelative,e[C]*=o.attenuation*JA(o.currentAttenuationDb+i),o.currentSampleTime++,++C>=e.length)return;o.state++;case 4:for(o.canEndOnSilentSustain&&o.sustainDbRelative>=_t&&(A.finished=!0);;)if(o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a,e[C]*=o.attenuation*JA(o.sustainDbRelative+i),o.currentAttenuationDb=o.sustainDbRelative,o.currentSampleTime++,++C>=e.length)return}}};var we=class t{a0=0;a1=0;a2=0;a3=0;a4=0;x1=0;x2=0;y1=0;y2=0;reasonanceCb=0;reasonanceGain=1;cutoffCents=13501;cutoffHz=20001;static apply(A,e,n,s){if(s&&n>13499&&A.filter.reasonanceCb===0)return;let o=A.filter;(o.cutoffCents!==n||o.reasonanceCb!==A.modulatedGenerators[r.initialFilterQ])&&(o.cutoffCents=n,o.reasonanceCb=A.modulatedGenerators[r.initialFilterQ],t.calculateCoefficients(o));for(let i=0;i<e.length;i++){let a=e[i],C=o.a0*a+o.a1*o.x1+o.a2*o.x2-o.a3*o.y1-o.a4*o.y2;o.x2=o.x1,o.x1=a,o.y2=o.y1,o.y1=C,e[i]=C}}static calculateCoefficients(A){A.cutoffHz=Ue(A.cutoffCents),A.cutoffHz=Math.min(A.cutoffHz,.45*sampleRate);let e=A.reasonanceCb/10;A.reasonanceGain=JA(-1*(e-3.01));let n=1/Math.sqrt(JA(-e)),s=2*Math.PI*A.cutoffHz/sampleRate,o=Math.cos(s),i=Math.sin(s)/(2*A.reasonanceGain),a=(1-o)*n,C=a/2,B=C,d=1+i,Q=-2*o,l=1-i;A.a0=C/d,A.a1=a/d,A.a2=B/d,A.a3=Q/d,A.a4=l/d}};var cs=.05;function ls(t,A,e,n,s,o){if(A.isInRelease||currentTime>=A.releaseStartTime&&(A.isInRelease=!0,qA.startRelease(A),PA.startRelease(A),A.sample.loopingMode===3&&(A.sample.isLooping=!1)),A.modulatedGenerators[r.initialAttenuation]>2500){A.isInRelease&&(A.finished=!0);return}let i=A.targetKey,a=A.modulatedGenerators[r.fineTune]+t.customControllers[hA.channelTuning]+t.customControllers[hA.channelTransposeFine]+t.customControllers[hA.masterTuning]+t.channelOctaveTuning[A.midiNote%12]+t.keyCentTuning[A.midiNote],C=A.modulatedGenerators[r.coarseTune]+t.customControllers[hA.channelTuningSemitones],B=this.tunings[t.preset.program]?.[A.realKey];B?.midiNote>=0&&(i=B.midiNote,a+=B.centTuning),a+=(i-A.sample.rootKey)*A.modulatedGenerators[r.scaleTuning];let d=A.modulatedGenerators[r.vibLfoToPitch];if(d!==0){let I=A.startTime+KA(A.modulatedGenerators[r.delayVibLFO]),rA=Ue(A.modulatedGenerators[r.freqVibLFO]),Z=at(I,rA,currentTime);a+=Z*(d*t.customControllers[hA.modulationMultiplier])}let Q=A.modulatedGenerators[r.initialFilterFc],l=Q,c=A.modulatedGenerators[r.modLfoToPitch],f=A.modulatedGenerators[r.modLfoToVolume],y=A.modulatedGenerators[r.modLfoToFilterFc],S=0;if(c+y+f!==0){let I=A.startTime+KA(A.modulatedGenerators[r.delayModLFO]),rA=Ue(A.modulatedGenerators[r.freqModLFO]),Z=at(I,rA,currentTime);a+=Z*(c*t.customControllers[hA.modulationMultiplier]),S=-Z*f,l+=Z*y}if(t.channelVibrato.depth>0){let I=at(A.startTime+t.channelVibrato.delay,t.channelVibrato.rate,currentTime);I&&(a+=I*t.channelVibrato.depth)}let w=A.modulatedGenerators[r.modEnvToPitch],H=A.modulatedGenerators[r.modEnvToFilterFc],R=PA.getValue(A,currentTime);l+=R*H,a+=R*w;let x=~~(a+C*100);x!==A.currentTuningCents&&(A.currentTuningCents=x,A.currentTuningCalculated=Math.pow(2,x/1200));let G=new Float32Array(e.length);switch(this.interpolationType){case ke.linear:default:Es(A,G);break;case ke.nearestNeighbor:Cs(A,G);break;case ke.fourthOrder:Bs(A,G)}we.apply(A,G,l,Q>13499),qA.apply(A,G,S,this.volumeEnvelopeSmoothingFactor),this.panVoice(A,G,e,n,s,o)}function Qr(t,A){let e=0;return t.drumChannel&&(e+=5),A.isInRelease&&(e-=5),e+=A.velocity/25,e-=A.volumeEnvelope.state,A.isInRelease&&(e-=5),e-=A.volumeEnvelope.currentAttenuationDb/50,e}function Qs(t){let A=[];for(let n of this.workletProcessorChannels)for(let s of n.voices)if(!s.finished){let o=Qr(n,s);A.push({channel:n,voice:s,priority:o})}A.sort((n,s)=>n.priority-s.priority);let e=A.slice(0,t);for(let{channel:n,voice:s}of e){let o=n.voices.indexOf(s);o>-1&&n.voices.splice(o,1)}}function us(t,A=ds){t.releaseStartTime=currentTime,t.releaseStartTime-t.startTime<A&&(t.releaseStartTime=t.startTime+A)}var zA=zA!==void 0?zA:{},fs=!1,ms;zA.isInitialized=new Promise(t=>ms=t);var ur=function(t){var A,e,n,s,o,i,a,C="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",B="",d=0;t=t.replace(/[^A-Za-z0-9\+\/\=]/g,"");do s=C.indexOf(t.charAt(d++)),o=C.indexOf(t.charAt(d++)),i=C.indexOf(t.charAt(d++)),a=C.indexOf(t.charAt(d++)),A=s<<2|o>>4,e=(15&o)<<4|i>>2,n=(3&i)<<6|a,B+=String.fromCharCode(A),i!==64&&(B+=String.fromCharCode(e)),a!==64&&(B+=String.fromCharCode(n));while(d<t.length);return B};(function(){var t,A,e,n,s,o,i,a,C,B,d,Q,l,c,f,y,S,w,H,R,x,G,I=I!==void 0?I:{};I.wasmBinary=Uint8Array.from(ur("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/Rw0ACwsLIAVBADYCACAGKAIAIQAgACABawwFCwwBCwwBCyAAQdQHaiEEIAQoAgAhBCAERQRAIAJBADYCACAAQdQAaiECIAAQGSEDAkAgA0F/RwRAA0AgAigCACEDIAMNAiAAEBkhAyADQX9HDQALCwsgBUEANgIAIAYoAgAhACAAIAFrDAMLCyAAEBMgAiADNgIAIAVBADYCAEEBBSAAQQIQFUEACwshACALJAYgAAsJACAAIAE2AlgLpgoBDH8gAEGAC2ohCiAKKAIAIQYCQAJAAkAgBkEATA0AA0AgACAEQRRsakGQC2ohAyADQQA2AgAgBEEBaiEEIAQgBkgNAAsgBkEESA0ADAELIAJBBEgEQEEAIQIFIAJBfWohBkEAIQIDQAJAIAEgAmohBCAELAAAIQMgA0HPAEYEQCAEQcATQQQQZCEEIARFBEAgAkEaaiEJIAkgBk4NAiACQRtqIQcgASAJaiELIAssAAAhAyADQf8BcSEFIAcgBWohBCAEIAZODQIgBUEbaiEEIAMEQEEAIQMDQCADIAdqIQggASAIaiEIIAgtAAAhCCAIQf8BcSEIIAQgCGohBCADQQFqIQMgAyAFRw0ACyAEIQMFIAQhAwtBACEEQQAhBQNAIAUgAmohByABIAdqIQcgBywAACEHIAQgBxApIQQgBUEBaiEFIAVBFkcNAAtBFiEFA0AgBEEAECkhBCAFQQFqIQUgBUEaRw0ACyAKKAIAIQUgBUEBaiEHIAogBzYCACADQWZqIQMgACAFQRRsakGIC2ohCCAIIAM2AgAgACAFQRRsakGMC2ohAyADIAQ2AgAgAkEWaiEEIAEgBGohBCAELQAAIQQgBEH/AXEhBCACQRdqIQMgASADaiEDIAMtAAAhAyADQf8BcSEDIANBCHQhAyADIARyIQQgAkEYaiEDIAEgA2ohAyADLQAAIQMgA0H/AXEhAyADQRB0IQMgBCADciEEIAJBGWohAyABIANqIQMgAy0AACEDIANB/wFxIQMgA0EYdCEDIAQgA3IhBCAAQYQLaiAFQRRsaiEDIAMgBDYCACALLQAAIQQgBEH/AXEhBCAJIARqIQQgASAEaiEEIAQsAAAhBCAEQX9GBH9BfwUgAkEGaiEEIAEgBGohBCAELQAAIQQgBEH/AXEhBCACQQdqIQMgASADaiEDIAMtAAAhAyADQf8BcSEDIANBCHQhAyADIARyIQQgAkEIaiEDIAEgA2ohAyADLQAAIQMgA0H/AXEhAyADQRB0IQMgBCADciEEIAJBCWohAyABIANqIQMgAy0AACEDIANB/wFxIQMgA0EYdCEDIAQgA3ILIQQgACAFQRRsakGUC2ohAyADIAQ2AgAgACAFQRRsakGQC2ohBCAEIAk2AgAgB0EERgRAIAYhAgwDCwsLIAJBAWohAiACIAZIDQEgBiECCwsgCigCACEGIAZBAEoNAQsMAQsgAiEEIAYhAkEAIQYDQAJAIABBhAtqIAZBFGxqIQkgACAGQRRsakGQC2ohAyADKAIAIQsgACAGQRRsakGIC2ohDSANKAIAIQggBCALayEDIAggA0ohBSADIAggBRshByAAIAZBFGxqQYwLaiEOIA4oAgAhAyAHQQBKBEBBACEFA0AgBSALaiEMIAEgDGohDCAMLAAAIQwgAyAMECkhAyAFQQFqIQUgBSAHSA0ACwsgCCAHayEFIA0gBTYCACAOIAM2AgAgBQRAIAZBAWohBgUgCSgCACEFIAMgBUYNASACQX9qIQIgCiACNgIAIAkgAEGEC2ogAkEUbGoiAikCADcCACAJIAIpAgg3AgggCSACKAIQNgIQIAooAgAhAgsgBiACSA0BIAQhAgwCCwsgByALaiECIApBfzYCACAAQdQHaiEBIAFBADYCACAAQdgKaiEBIAFBfzYCACAAIAZBFGxqQZQLaiEBIAEoAgAhASAAQZgIaiEEIAQgATYCACABQX9HIQEgAEGcCGohACAAIAE2AgALIAILhgUBCH8gAEHYCmohAiACKAIAIQMgAEEUaiECIAIoAgAhAgJ/AkAgA0F/RgR/QQEhAwwBBSAAQdAIaiEEIAQoAgAhBQJAIAMgBUgEQANAIABB1AhqIANqIQQgBCwAACEGIAZB/wFxIQQgAiAEaiECIAZBf0cNAiADQQFqIQMgAyAFSA0ACwsLIAFBAEchBiAFQX9qIQQgAyAESCEEIAYgBHEEQCAAQRUQFUEADAMLIABBHGohBCAEKAIAIQQgAiAESwR/IABBARAVQQAFIAMgBUYhBCADQX9GIQMgBCADcgR/QQAhAwwDBUEBCwsLDAELIAAoAhwhCCAAQdQHaiEGIAFBAEchBCACIQECQAJAAkACQAJAAkACQAJAAkADQCABQRpqIQUgBSAITw0BIAFBwBNBBBBkIQIgAg0CIAFBBGohAiACLAAAIQIgAg0DIAMEQCAGKAIAIQIgAgRAIAFBBWohAiACLAAAIQIgAkEBcSECIAINBgsFIAFBBWohAiACLAAAIQIgAkEBcSECIAJFDQYLIAUsAAAhAiACQf8BcSEHIAFBG2ohCSAJIAdqIQEgASAISw0GAkAgAgRAQQAhAgNAIAkgAmohAyADLAAAIQUgBUH/AXEhAyABIANqIQEgBUF/Rw0CIAJBAWohAiACIAdJDQALBUEAIQILCyAHQX9qIQMgAiADSCEDIAQgA3ENByABIAhLDQhBASACIAdHDQoaQQAhAwwAAAsACyAAQQEQFUEADAgLIABBFRAVQQAMBwsgAEEVEBVBAAwGCyAAQRUQFUEADAULIABBFRAVQQAMBAsgAEEBEBVBAAwDCyAAQRUQFUEADAILIABBARAVC0EACyEAIAALewEFfyMGIQUjBkEQaiQGIAVBCGohBiAFQQRqIQQgBSEHIAAgAiAEIAMgBSAGECohBCAEBH8gBigCACEEIABBkANqIARBBmxqIQggAigCACEGIAMoAgAhBCAHKAIAIQMgACABIAggBiAEIAMgAhArBUEACyEAIAUkBiAACxsBAX8gABAuIQEgAEHoCmohACAAQQA2AgAgAQv5AwIMfwN9IABB1AdqIQkgCSgCACEGIAYEfyAAIAYQSCELIABBBGohBCAEKAIAIQogCkEASgRAIAZBAEohDCAGQX9qIQ0DQCAMBEAgAEGUBmogBUECdGooAgAhDiAAQZQHaiAFQQJ0aigCACEPQQAhBANAIAQgAmohByAOIAdBAnRqIQcgByoCACEQIAsgBEECdGohCCAIKgIAIREgECARlCEQIA8gBEECdGohCCAIKgIAIREgDSAEayEIIAsgCEECdGohCCAIKgIAIRIgESASlCERIBAgEZIhECAHIBA4AgAgBEEBaiEEIAQgBkcNAAsLIAVBAWohBSAFIApIDQALCyAJKAIABSAAQQRqIQQgBCgCACEKQQALIQsgASADayEHIAkgBzYCACAKQQBKBEAgASADSiEJQQAhBQNAIAkEQCAAQZQGaiAFQQJ0aigCACEMIABBlAdqIAVBAnRqKAIAIQ1BACEGIAMhBANAIAwgBEECdGohBCAEKAIAIQQgDSAGQQJ0aiEOIA4gBDYCACAGQQFqIQYgBiADaiEEIAYgB0cNAAsLIAVBAWohBSAFIApIDQALCyALRSEEIAEgA0ghBSABIAMgBRshASABIAJrIQEgAEH8CmohACAEBEBBACEBBSAAKAIAIQIgAiABaiECIAAgAjYCAAsgAQvRAQECfyMGIQYjBkHgC2okBiAGIQUgBSAEEBwgBUEUaiEEIAQgADYCACAAIAFqIQEgBUEcaiEEIAQgATYCACAFQSRqIQEgAUEBOgAAIAUQHSEBIAEEQCAFEB4hASABBEAgASAFQdwLEHkaIAFBFGohBCAEKAIAIQQgBCAAayEAIAIgADYCACADQQA2AgAFIAUQEUEAIQELBSAFQdQAaiEAIAAoAgAhACAARSEAIAVB2ABqIQEgASgCACEBIAMgAUEBIAAbNgIAQQAhAQsgBiQGIAELrQECAX8BfiAAQQBB3AsQehogAQRAIABBxABqIQIgASkCACEDIAIgAzcCACAAQcgAaiECIANCIIghAyADpyEBIAFBA2ohASABQXxxIQEgAiABNgIAIABB0ABqIQIgAiABNgIACyAAQdQAaiEBIAFBADYCACAAQdgAaiEBIAFBADYCACAAQRRqIQEgAUEANgIAIABB8ABqIQEgAUEANgIAIABBgAtqIQAgAEF/NgIAC9BNAiN/A30jBiEZIwZBgAhqJAYgGUHwB2ohAiAZIgxB7AdqIR0gDEHoB2ohHiAAEDEhAQJ/IAEEQCAAQdMKaiEBIAEtAAAhASABQf8BcSEBIAFBAnEhAyADRQRAIABBIhAVQQAMAgsgAUEEcSEDIAMEQCAAQSIQFUEADAILIAFBAXEhASABBEAgAEEiEBVBAAwCCyAAQdAIaiEBIAEoAgAhASABQQFHBEAgAEEiEBVBAAwCCyAAQdQIaiEBAkACQCABLAAAQR5rIgEEQCABQSJGBEAMAgUMAwsACyAAEDAhASABQf8BcUEBRwRAIABBIhAVQQAMBAsgACACQQYQIiEBIAFFBEAgAEEKEBVBAAwECyACEEkhASABRQRAIABBIhAVQQAMBAsgABAjIQEgAQRAIABBIhAVQQAMBAsgABAwIQEgAUH/AXEhAyAAQQRqIRMgEyADNgIAIAFB/wFxRQRAIABBIhAVQQAMBAsgAUH/AXFBEEoEQCAAQQUQFUEADAQLIAAQIyEBIAAgATYCACABRQRAIABBIhAVQQAMBAsgABAjGiAAECMaIAAQIxogABAwIQMgA0H/AXEhBCAEQQ9xIQEgBEEEdiEEQQEgAXQhBSAAQeQAaiEaIBogBTYCAEEBIAR0IQUgAEHoAGohFCAUIAU2AgAgAUF6aiEFIAVBB0sEQCAAQRQQFUEADAQLIANBoH9qQRh0QRh1IQMgA0EASARAIABBFBAVQQAMBAsgASAESwRAIABBFBAVQQAMBAsgABAwIQEgAUEBcSEBIAFFBEAgAEEiEBVBAAwECyAAEDEhAUEAIAFFDQMaIAAQSiEBQQAgAUUNAxogAEHUCmohAwNAIAAQLyEBIAAgARBLIANBADoAACABDQALIAAQSiEBQQAgAUUNAxogAEEkaiEBIAEsAAAhAQJAIAEEQCAAQQEQFyEBIAENASAAQdgAaiEAIAAoAgAhAUEAIAFBFUcNBRogAEEUNgIAQQAMBQsLEEwgABAZIQEgAUEFRwRAIABBFBAVQQAMBAtBACEBA0AgABAZIQMgA0H/AXEhAyACIAFqIQQgBCADOgAAIAFBAWohASABQQZHDQALIAIQSSEBIAFFBEAgAEEUEBVBAAwECyAAQQgQLCEBIAFBAWohASAAQewAaiENIA0gATYCACABQbAQbCEBIAAgARBNIQEgAEHwAGohFSAVIAE2AgAgAUUEQCAAQQMQFUEADAQLIA0oAgAhAiACQbAQbCECIAFBACACEHoaIA0oAgAhAQJAIAFBAEoEQCAAQRBqIRYDQAJAIBUoAgAhCiAKIAZBsBBsaiEJIABBCBAsIQEgAUH/AXEhASABQcIARwRAQT8hAQwBCyAAQQgQLCEBIAFB/wFxIQEgAUHDAEcEQEHBACEBDAELIABBCBAsIQEgAUH/AXEhASABQdYARwRAQcMAIQEMAQsgAEEIECwhASAAQQgQLCECIAJBCHQhAiABQf8BcSEBIAIgAXIhASAJIAE2AgAgAEEIECwhASAAQQgQLCECIABBCBAsIQMgA0EQdCEDIAJBCHQhAiACQYD+A3EhAiABQf8BcSEBIAIgAXIhASABIANyIQEgCiAGQbAQbGpBBGohDiAOIAE2AgAgAEEBECwhASABQQBHIgMEf0EABSAAQQEQLAshASABQf8BcSECIAogBkGwEGxqQRdqIREgESACOgAAIAkoAgAhBCAOKAIAIQEgBEUEQCABBH9ByAAhAQwCBUEACyEBCyACQf8BcQRAIAAgARA8IQIFIAAgARBNIQIgCiAGQbAQbGpBCGohASABIAI2AgALIAJFBEBBzQAhAQwBCwJAIAMEQCAAQQUQLCEDIA4oAgAhASABQQBMBEBBACEDDAILQQAhBANAIANBAWohBSABIARrIQEgARAtIQEgACABECwhASABIARqIQMgDigCACEPIAMgD0oEQEHTACEBDAQLIAIgBGohBCAFQf8BcSEPIAQgDyABEHoaIA4oAgAhASABIANKBH8gAyEEIAUhAwwBBUEACyEDCwUgDigCACEBIAFBAEwEQEEAIQMMAgtBACEDQQAhAQNAIBEsAAAhBAJAAkAgBEUNACAAQQEQLCEEIAQNACACIANqIQQgBEF/OgAADAELIABBBRAsIQQgBEEBaiEEIARB/wFxIQUgAiADaiEPIA8gBToAACABQQFqIQEgBEH/AXEhBCAEQSBGBEBB2gAhAQwFCwsgA0EBaiEDIA4oAgAhBCADIARIDQALIAEhAyAEIQELCyARLAAAIQQCfwJAIAQEfyABQQJ1IQQgAyAETgRAIBYoAgAhAyABIANKBEAgFiABNgIACyAAIAEQTSEBIAogBkGwEGxqQQhqIQMgAyABNgIAIAFFBEBB4QAhAQwFCyAOKAIAIQQgASACIAQQeRogDigCACEBIAAgAiABEE4gAygCACECIBFBADoAACAOKAIAIQQMAgsgCiAGQbAQbGpBrBBqIQQgBCADNgIAIAMEfyAAIAMQTSEBIAogBkGwEGxqQQhqIQMgAyABNgIAIAFFBEBB6wAhAQwFCyAEKAIAIQEgAUECdCEBIAAgARA8IQEgCiAGQbAQbGpBIGohAyADIAE2AgAgAUUEQEHtACEBDAULIAQoAgAhASABQQJ0IQEgACABEDwhBSAFRQRAQfAAIQEMBQsgDigCACEBIAQoAgAhDyAFIQcgBQVBACEPQQAhB0EACyEDIA9BA3QhBSAFIAFqIQUgFigCACEPIAUgD00EQCABIQUgBAwDCyAWIAU2AgAgASEFIAQFIAEhBAwBCwwBCyAEQQBKBEBBACEBQQAhAwNAIAIgA2ohBSAFLAAAIQUgBUH/AXFBCkohDyAFQX9HIQUgDyAFcSEFIAVBAXEhBSABIAVqIQEgA0EBaiEDIAMgBEgNAAsFQQAhAQsgCiAGQbAQbGpBrBBqIQ8gDyABNgIAIARBAnQhASAAIAEQTSEBIAogBkGwEGxqQSBqIQMgAyABNgIAIAFFBEBB6QAhAQwCC0EAIQMgDigCACEFQQAhByAPCyEBIAkgAiAFIAMQTyEEIARFBEBB9AAhAQwBCyABKAIAIQQgBARAIARBAnQhBCAEQQRqIQQgACAEEE0hBCAKIAZBsBBsakGkEGohBSAFIAQ2AgAgBEUEQEH5ACEBDAILIAEoAgAhBCAEQQJ0IQQgBEEEaiEEIAAgBBBNIQQgCiAGQbAQbGpBqBBqIQUgBSAENgIAIARFBEBB+wAhAQwCCyAEQQRqIQ8gBSAPNgIAIARBfzYCACAJIAIgAxBQCyARLAAAIQMgAwRAIAEoAgAhAyADQQJ0IQMgACAHIAMQTiAKIAZBsBBsakEgaiEDIAMoAgAhBCABKAIAIQUgBUECdCEFIAAgBCAFEE4gDigCACEEIAAgAiAEEE4gA0EANgIACyAJEFEgAEEEECwhAiACQf8BcSEDIAogBkGwEGxqQRVqIQUgBSADOgAAIAJB/wFxIQIgAkECSwRAQYABIQEMAQsgAgRAIABBIBAsIQIgAhBSISUgCiAGQbAQbGpBDGohDyAPICU4AgAgAEEgECwhAiACEFIhJSAKIAZBsBBsakEQaiEbIBsgJTgCACAAQQQQLCECIAJBAWohAiACQf8BcSECIAogBkGwEGxqQRRqIQQgBCACOgAAIABBARAsIQIgAkH/AXEhAiAKIAZBsBBsakEWaiEcIBwgAjoAACAFLAAAIQsgDigCACECIAkoAgAhAyALQQFGBH8gAiADEFMFIAMgAmwLIQIgCiAGQbAQbGpBGGohCyALIAI2AgAgAkUEQEGGASEBDAILIAJBAXQhAiAAIAIQPCEQIBBFBEBBiAEhAQwCCyALKAIAIQIgAkEASgRAQQAhAgNAIAQtAAAhAyADQf8BcSEDIAAgAxAsIQMgA0F/RgRAQYwBIQEMBAsgA0H//wNxIQMgECACQQF0aiEXIBcgAzsBACACQQFqIQIgCygCACEDIAIgA0gNAAsgAyECCyAFLAAAIQMCQCADQQFGBEAgESwAACEDIANBAEciFwRAIAEoAgAhAyADRQRAIAIhAQwDCwUgDigCACEDCyAKIAZBsBBsaiAAIANBAnQgCSgCAGwQTSIfNgIcIB9FBEBBkwEhAQwECyABIA4gFxshASABKAIAIQ4gDkEASgRAIAogBkGwEGxqQagQaiEgIAkoAgAiCkEASiEJQwAAAAAhJUEAIQEDQCAXBH8gICgCACECIAIgAUECdGohAiACKAIABSABCyEEIAkEQCALKAIAIRggHCwAAEUhISAKIAFsISJBACEDQQEhAgNAIAQgAm4hEiASIBhwIRIgECASQQF0aiESIBIvAQAhEiASQf//A3GyISQgGyoCACEmICYgJJQhJCAPKgIAISYgJCAmkiEkICUgJJIhJCAiIANqIRIgHyASQQJ0aiESIBIgJDgCACAlICQgIRshJSADQQFqIQMgAyAKSCISBEBBfyAYbiEjIAIgI0sEQEGeASEBDAkLIBggAmwhAgsgEg0ACwsgAUEBaiEBIAEgDkgNAAsLIAVBAjoAACALKAIAIQEFIAJBAnQhASAAIAEQTSECIAogBkGwEGxqQRxqIQEgASACNgIAIAsoAgAhCCACRQRAQaUBIQEMBAsgCEEATARAIAghAQwCCyAcLAAARSEDQwAAAAAhJUEAIQEDQCAQIAFBAXRqIQQgBC8BACEEIARB//8DcbIhJCAbKgIAISYgJiAklCEkIA8qAgAhJiAkICaSISQgJSAkkiEkIAIgAUECdGohBCAEICQ4AgAgJSAkIAMbISUgAUEBaiEBIAEgCEgNAAsgCCEBCwsgAUEBdCEBIAAgECABEE4LIAZBAWohBiANKAIAIQEgBiABSA0BDAMLCwJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAgAUE/aw5nABYBFgIWFhYWAxYWFhYEFhYWFhYFFhYWFhYWBhYWFhYWFgcWFhYWFhYWCBYJFgoWFgsWFhYMFhYWFg0WDhYWFhYPFhYWFhYQFhEWFhYSFhYWFhYWExYWFhYWFhYWFhYUFhYWFhYWFRYLIABBFBAVQQAMGwsgAEEUEBVBAAwaCyAAQRQQFUEADBkLIABBFBAVQQAMGAsgAEEDEBVBAAwXCyAAQRQQFUEADBYLIABBFBAVQQAMFQsgAEEDEBVBAAwUCyAAQQMQFUEADBMLIABBAxAVQQAMEgsgAEEDEBVBAAwRCyAAQQMQFUEADBALIBEsAAAhASABBEAgACAHQQAQTgsgAEEUEBVBAAwPCyAAQQMQFUEADA4LIABBAxAVQQAMDQsgAEEUEBVBAAwMCyAAQRQQFUEADAsLIABBAxAVQQAMCgsgCygCACEBIAFBAXQhASAAIBAgARBOIABBFBAVQQAMCQsgCygCACEBIAFBAXQhASAAIBAgARBOIABBAxAVQQAMCAsgGEEBdCEBIAAgECABEE4gAEEUEBVBAAwHCyAIQQF0IQEgACAQIAEQTiAAQQMQFUEADAYLCwsgAEEGECwhASABQQFqIQEgAUH/AXEhAgJAIAIEQEEAIQEDQAJAIABBEBAsIQMgA0UhAyADRQ0AIAFBAWohASABIAJJDQEMAwsLIABBFBAVQQAMBQsLIABBBhAsIQEgAUEBaiEBIABB9ABqIQ8gDyABNgIAIAFBvAxsIQEgACABEE0hASAAQfgBaiEOIA4gATYCACABRQRAIABBAxAVQQAMBAsgDygCACEBAn8gAUEASgR/QQAhBEEAIQcCQAJAAkACQAJAAkADQCAAQRAQLCEBIAFB//8DcSECIABB+ABqIAdBAXRqIQMgAyACOwEAIAFB//8DcSEBIAFBAUsNASABRQ0CIA4oAgAhBSAAQQUQLCEBIAFB/wFxIQIgBSAHQbwMbGohCiAKIAI6AAAgAUH/AXEhASABBEBBfyEBQQAhAgNAIABBBBAsIQMgA0H/AXEhCCAFIAdBvAxsakEBaiACaiEGIAYgCDoAACADQf8BcSEDIAMgAUohCCADIAEgCBshAyACQQFqIQIgCi0AACEBIAFB/wFxIQEgAiABSQRAIAMhAQwBCwtBACEBA0AgAEEDECwhAiACQQFqIQIgAkH/AXEhAiAFIAdBvAxsakEhaiABaiEIIAggAjoAACAAQQIQLCECIAJB/wFxIQIgBSAHQbwMbGpBMWogAWohCCAIIAI6AAACQAJAIAJB/wFxRQ0AIABBCBAsIQIgAkH/AXEhBiAFIAdBvAxsakHBAGogAWohECAQIAY6AAAgAkH/AXEhAiANKAIAIQYgAiAGTg0HIAgsAAAhAiACQR9HDQAMAQtBACECA0AgAEEIECwhBiAGQf//A2ohBiAGQf//A3EhECAFIAdBvAxsakHSAGogAUEEdGogAkEBdGohCSAJIBA7AQAgBkEQdCEGIAZBEHUhBiANKAIAIRAgBiAQSCEGIAZFDQggAkEBaiECIAgtAAAhBiAGQf8BcSEGQQEgBnQhBiACIAZIDQALCyABQQFqIQIgASADSARAIAIhAQwBCwsLIABBAhAsIQEgAUEBaiEBIAFB/wFxIQEgBSAHQbwMbGpBtAxqIQIgAiABOgAAIABBBBAsIQEgAUH/AXEhAiAFIAdBvAxsakG1DGohECAQIAI6AAAgBSAHQbwMbGpB0gJqIQkgCUEAOwEAIAFB/wFxIQFBASABdCEBIAFB//8DcSEBIAUgB0G8DGxqQdQCaiECIAIgATsBACAFIAdBvAxsakG4DGohBiAGQQI2AgAgCiwAACEBAkACQCABBEBBACEIQQIhAwNAIAUgB0G8DGxqQQFqIAhqIQIgAi0AACECIAJB/wFxIQIgBSAHQbwMbGpBIWogAmohAiACLAAAIQsgCwRAQQAhAQNAIBAtAAAhAyADQf8BcSEDIAAgAxAsIQMgA0H//wNxIQsgBigCACEDIAUgB0G8DGxqQdICaiADQQF0aiERIBEgCzsBACADQQFqIQMgBiADNgIAIAFBAWohASACLQAAIQsgC0H/AXEhCyABIAtJDQALIAosAAAhAgUgASECCyADIQEgCEEBaiEIIAJB/wFxIQMgCCADSQRAIAEhAyACIQEMAQsLIAFBAEoNAQVBAiEBDAELDAELQQAhAgNAIAUgB0G8DGxqQdICaiACQQF0aiEDIAMuAQAhAyAMIAJBAnRqIQggCCADOwEAIAJB//8DcSEDIAwgAkECdGpBAmohCCAIIAM7AQAgAkEBaiECIAIgAUgNAAsLIAwgAUEEQQEQZiAGKAIAIQECQCABQQBKBEBBACEBA0AgDCABQQJ0akECaiECIAIuAQAhAiACQf8BcSECIAUgB0G8DGxqQcYGaiABaiEDIAMgAjoAACABQQFqIQEgBigCACECIAEgAkgNAAsgAkECTARAIAIhAQwCC0ECIQEDQCAJIAEgHSAeEFUgHSgCACECIAJB/wFxIQIgBSAHQbwMbGpBwAhqIAFBAXRqIQMgAyACOgAAIB4oAgAhAiACQf8BcSECIAUgB0G8DGxqIAFBAXRqQcEIaiEDIAMgAjoAACABQQFqIQEgBigCACECIAEgAkgNAAsgAiEBCwsgASAESiECIAEgBCACGyEEIAdBAWohByAPKAIAIQEgByABSA0ADAUACwALIABBFBAVQQAMCgsgDigCACEBIABBCBAsIQIgAkH/AXEhAiABIAdBvAxsaiEDIAMgAjoAACAAQRAQLCECIAJB//8DcSECIAEgB0G8DGxqQQJqIQMgAyACOwEAIABBEBAsIQIgAkH//wNxIQIgASAHQbwMbGpBBGohAyADIAI7AQAgAEEGECwhAiACQf8BcSECIAEgB0G8DGxqQQZqIQMgAyACOgAAIABBCBAsIQIgAkH/AXEhAiABIAdBvAxsakEHaiEDIAMgAjoAACAAQQQQLCECIAJBAWohAiACQf8BcSEEIAEgB0G8DGxqQQhqIQMgAyAEOgAAIAJB/wFxIQIgAgRAIAEgB0G8DGxqQQlqIQJBACEBA0AgAEEIECwhByAHQf8BcSEHIAIgAWohBCAEIAc6AAAgAUEBaiEBIAMtAAAhByAHQf8BcSEHIAEgB0kNAAsLIABBBBAVQQAMCQsgAEEUEBUMAgsgAEEUEBUMAQsgBEEBdAwCC0EADAUFQQALCyEQIABBBhAsIQEgAUEBaiEBIABB/AFqIQUgBSABNgIAIAFBGGwhASAAIAEQTSEBIABBgANqIQ4gDiABNgIAIAFFBEAgAEEDEBVBAAwECyAFKAIAIQIgAkEYbCECIAFBACACEHoaIAUoAgAhAQJAIAFBAEoEQEEAIQcCQAJAAkACQAJAAkACQAJAA0AgDigCACEEIABBEBAsIQEgAUH//wNxIQIgAEGAAmogB0EBdGohAyADIAI7AQAgAUH//wNxIQEgAUECSw0BIABBGBAsIQIgBCAHQRhsaiEBIAEgAjYCACAAQRgQLCECIAQgB0EYbGpBBGohAyADIAI2AgAgASgCACEBIAIgAUkNAiAAQRgQLCEBIAFBAWohASAEIAdBGGxqQQhqIQIgAiABNgIAIABBBhAsIQEgAUEBaiEBIAFB/wFxIQEgBCAHQRhsakEMaiEIIAggAToAACAAQQgQLCEBIAFB/wFxIQIgBCAHQRhsakENaiEGIAYgAjoAACABQf8BcSEBIA0oAgAhAiABIAJODQMgCCwAACEBIAEEf0EAIQEDQCAAQQMQLCEDIABBARAsIQIgAgR/IABBBRAsBUEACyECIAJBA3QhAiACIANqIQIgAkH/AXEhAiAMIAFqIQMgAyACOgAAIAFBAWohASAILQAAIQIgAkH/AXEhAyABIANJDQALIAJB/wFxBUEACyEBIAFBBHQhASAAIAEQTSEBIAQgB0EYbGpBFGohCiAKIAE2AgAgAUUNBCAILAAAIQIgAgRAQQAhAgNAIAwgAmotAAAhC0EAIQMDQEEBIAN0IQkgCSALcSEJIAkEQCAAQQgQLCEJIAlB//8DcSERIAooAgAhASABIAJBBHRqIANBAXRqIRYgFiAROwEAIAlBEHQhCSAJQRB1IQkgDSgCACERIBEgCUwNCQUgASACQQR0aiADQQF0aiEJIAlBfzsBAAsgA0EBaiEDIANBCEkNAAsgAkEBaiECIAgtAAAhAyADQf8BcSEDIAIgA0kNAAsLIBUoAgAhASAGLQAAIQIgAkH/AXEhAiABIAJBsBBsakEEaiEBIAEoAgAhASABQQJ0IQEgACABEE0hASAEIAdBGGxqQRBqIQogCiABNgIAIAFFDQYgFSgCACECIAYtAAAhAyADQf8BcSEDIAIgA0GwEGxqQQRqIQIgAigCACECIAJBAnQhAiABQQAgAhB6GiAVKAIAIQIgBi0AACEBIAFB/wFxIQMgAiADQbAQbGpBBGohASABKAIAIQEgAUEASgRAQQAhAQNAIAIgA0GwEGxqIQIgAigCACEDIAAgAxBNIQIgCigCACEEIAQgAUECdGohBCAEIAI2AgAgCigCACECIAIgAUECdGohAiACKAIAIQQgBEUNCQJAIANBAEoEQCAILQAAIQkgA0F/aiECIAlB/wFxIQkgASAJcCEJIAlB/wFxIQkgBCACaiEEIAQgCToAACADQQFGDQEgASEDA0AgCC0AACEJIAlB/wFxIQQgAyAEbSEDIAooAgAgAUECdGohBCAEKAIAIQsgAkF/aiEEIAlB/wFxIQkgAyAJbyEJIAlB/wFxIQkgCyAEaiELIAsgCToAACACQQFKBEAgBCECDAELCwsLIAFBAWohASAVKAIAIQIgBi0AACEDIANB/wFxIQMgAiADQbAQbGpBBGohBCAEKAIAIQQgASAESA0ACwsgB0EBaiEHIAUoAgAhASAHIAFIDQAMCgALAAsgAEEUEBUMBgsgAEEUEBUMBQsgAEEUEBUMBAsgAEEDEBUMAwsgAEEUEBUMAgsgAEEDEBUMAQsgAEEDEBULQQAMBQsLIABBBhAsIQEgAUEBaiEBIABBhANqIQcgByABNgIAIAFBKGwhASAAIAEQTSEBIABBiANqIQogCiABNgIAIAFFBEAgAEEDEBVBAAwECyAHKAIAIQIgAkEobCECIAFBACACEHoaIAcoAgAhAQJAIAFBAEoEQEEAIQECQAJAAkACQAJAAkACQAJAAkACQANAIAooAgAhBCAEIAFBKGxqIQwgAEEQECwhAiACDQEgEygCACECIAJBA2whAiAAIAIQTSECIAQgAUEobGpBBGohCCAIIAI2AgAgAkUNAiAAQQEQLCECIAIEfyAAQQQQLCECIAJBAWohAiACQf8BcQVBAQshAiAEIAFBKGxqQQhqIQYgBiACOgAAIABBARAsIQICQCACBEAgAEEIECwhAiACQQFqIQIgAkH//wNxIQMgDCADOwEAIAJB//8DcSECIAJFDQFBACECIBMoAgAhAwNAIANBf2ohAyADEC0hAyAAIAMQLCEDIANB/wFxIQMgCCgCACENIA0gAkEDbGohDSANIAM6AAAgEygCACEDIANBf2ohAyADEC0hAyAAIAMQLCENIA1B/wFxIQkgCCgCACEDIAMgAkEDbGpBAWohCyALIAk6AAAgAyACQQNsaiEDIAMsAAAhCyALQf8BcSERIBMoAgAhAyADIBFMDQYgDUH/AXEhDSADIA1MDQcgCyAJQRh0QRh1RiENIA0NCCACQQFqIQIgDC8BACENIA1B//8DcSENIAIgDUkNAAsFIAxBADsBAAsLIABBAhAsIQIgAg0GIAYsAAAhAyATKAIAIgxBAEohAgJAAkAgA0H/AXFBAUoEQCACRQ0BQQAhAgNAIABBBBAsIQMgA0H/AXEhAyAIKAIAIQwgDCACQQNsakECaiEMIAwgAzoAACAGLQAAIQwgDEH/AXEgA0ohAyADRQ0LIAJBAWohAiATKAIAIQMgAiADSA0ACwwBBSACBEAgCCgCACEIQQAhAgNAIAggAkEDbGpBAmohDSANQQA6AAAgAkEBaiECIAIgDEgNAAsLIAMNAQsMAQtBACECA0AgAEEIECwaIABBCBAsIQMgA0H/AXEhCCAEIAFBKGxqQQlqIAJqIQMgAyAIOgAAIABBCBAsIQggCEH/AXEhDCAEIAFBKGxqQRhqIAJqIQ0gDSAMOgAAIAMtAAAhAyADQf8BcSEDIA8oAgAhDCAMIANMDQogCEH/AXEhAyAFKAIAIQggAyAISCEDIANFDQsgAkEBaiECIAYtAAAhAyADQf8BcSEDIAIgA0kNAAsLIAFBAWohASAHKAIAIQIgASACSA0ADAwACwALIABBFBAVQQAMDgsgAEEDEBVBAAwNCyAAQRQQFUEADAwLIABBFBAVQQAMCwsgAEEUEBVBAAwKCyAAQRQQFUEADAkLIABBFBAVQQAMCAsgAEEUEBVBAAwHCyAAQRQQFUEADAYACwALCyAAQQYQLCEBIAFBAWohASAAQYwDaiECIAIgATYCAAJAIAFBAEoEQEEAIQECQAJAAkACQANAIABBARAsIQMgA0H/AXEhAyAAQZADaiABQQZsaiEEIAQgAzoAACAAQRAQLCEDIANB//8DcSEEIAAgAUEGbGpBkgNqIQMgAyAEOwEAIABBEBAsIQQgBEH//wNxIQggACABQQZsakGUA2ohBCAEIAg7AQAgAEEIECwhCCAIQf8BcSEGIAAgAUEGbGpBkQNqIQwgDCAGOgAAIAMuAQAhAyADDQEgBC4BACEDIAMNAiAIQf8BcSEDIAcoAgAhBCADIARIIQMgA0UNAyABQQFqIQEgAigCACEDIAEgA0gNAAwGAAsACyAAQRQQFUEADAgLIABBFBAVQQAMBwsgAEEUEBVBAAwGAAsACwsgABAhIABB1AdqIQEgAUEANgIAIBMoAgAhAQJAIAFBAEoEQEEAIQEDQAJAIBQoAgAhAiACQQJ0IQIgACACEE0hAyAAQZQGaiABQQJ0aiECIAIgAzYCACAUKAIAIQMgA0EBdCEDIANB/v///wdxIQMgACADEE0hByAAQZQHaiABQQJ0aiEDIAMgBzYCACAAIBAQTSEHIABB2AdqIAFBAnRqIQQgBCAHNgIAIAIoAgAhAiACRQ0AIAMoAgAhAyADRSEDIAdFIQcgByADcg0AIBQoAgAhAyADQQJ0IQMgAkEAIAMQehogAUEBaiEBIBMoAgAhAiABIAJIDQEMAwsLIABBAxAVQQAMBQsLIBooAgAhASAAQQAgARBWIQFBACABRQ0DGiAUKAIAIQEgAEEBIAEQViEBQQAgAUUNAxogGigCACEBIABB3ABqIQIgAiABNgIAIBQoAgAhASAAQeAAaiECIAIgATYCACABQQF0IQIgAkH+////B3EhBCAFKAIAIQggCEEASgR/IA4oAgAhByABQQJtIQNBACECQQAhAQNAIAcgAUEYbGohBSAFKAIAIQUgBSADSSEGIAUgAyAGGyEGIAcgAUEYbGpBBGohBSAFKAIAIQUgBSADSSEMIAUgAyAMGyEFIAUgBmshBSAHIAFBGGxqQQhqIQYgBigCACEGIAUgBm4hBSAFIAJKIQYgBSACIAYbIQIgAUEBaiEBIAEgCEgNAAsgAkECdCEBIAFBBGoFQQQLIQEgEygCACECIAIgAWwhASAAQQxqIQIgBCABSyEDIAIgBCABIAMbIgI2AgAgAEHVCmohASABQQE6AAAgAEHEAGohASABKAIAIQECQCABBEAgAEHQAGohASABKAIAIQEgAEHIAGohAyADKAIAIQMgASADRwRAQcwWQcQTQaAgQYQXEAQLIABBzABqIQMgAygCACEDIAJB3AtqIQIgAiADaiECIAIgAU0NASAAQQMQFUEADAULCyAAEB8hASAAQShqIQAgACABNgIAQQEMAwsgACACQQYQIiEBIAFBAEchASACLAAAIQMgA0HmAEYhAyABIANxBEAgAkEBaiEBIAEsAAAhASABQekARgRAIAJBAmohASABLAAAIQEgAUHzAEYEQCACQQNqIQEgASwAACEBIAFB6ABGBEAgAkEEaiEBIAEsAAAhASABQeUARgRAIAJBBWohASABLAAAIQEgAUHhAEYEQCAAEDAhASABQf8BcUHkAEYEQCAAEDAhASABQf8BcUUEQCAAQSYQFUEADAoLCwsLCwsLCwsgAEEiEBULQQALIQAgGSQGIAALDwEBfyAAQdwLEE0hASABCz8BAX8gAEEkaiEBIAEsAAAhASABBH9BAAUgAEEUaiEBIAEoAgAhASAAQRhqIQAgACgCACEAIAEgAGsLIQAgAAuBAgECfyAAQdgKaiEBIAEoAgAhAQJ/AkAgAUF/Rw0AIAAQMCEBIABB1ABqIQIgAigCACECIAIEf0EABSABQf8BcUHPAEcEQCAAQR4QFUEADAMLIAAQMCEBIAFB/wFxQecARwRAIABBHhAVQQAMAwsgABAwIQEgAUH/AXFB5wBHBEAgAEEeEBVBAAwDCyAAEDAhASABQf8BcUHTAEcEQCAAQR4QFUEADAMLIAAQMyEBIAEEQCAAQdMKaiEBIAEsAAAhASABQQFxIQEgAUUNAiAAQdwKaiEBIAFBADYCACAAQdQKaiEBIAFBADoAACAAQSAQFQtBAAsMAQsgABBKCyEAIAALFAEBfwNAIAAQLiEBIAFBf0cNAAsLZQEEfyAAQRRqIQMgAygCACEFIAUgAmohBiAAQRxqIQQgBCgCACEEIAYgBEsEfyAAQdQAaiEAIABBATYCAEEABSABIAUgAhB5GiADKAIAIQAgACACaiEAIAMgADYCAEEBCyEAIAALaAECfyAAEDAhAiACQf8BcSECIAAQMCEBIAFB/wFxIQEgAUEIdCEBIAEgAnIhAiAAEDAhASABQf8BcSEBIAFBEHQhASACIAFyIQIgABAwIQAgAEH/AXEhACAAQRh0IQAgAiAAciEAIAALEwEBf0EEEF4hACAAQQA2AgAgAAsTAQF/IAAoAgAhASABEBAgABBfCyEAIAAoAgAhACAABH8gAEEEaiEAIAAoAgAFQQALIQAgAAsaACAAKAIAIQAgAAR/IAAoAgAFQQALIQAgAAvbBwISfwF9IwYhECMGQRBqJAYgEEEEaiELIBAhDCAEQQA2AgAgACgCACEGAkACQCAGDQBBICEFA0ACQCALQQA2AgAgDEEANgIAIAUgAkohBiACIAUgBhshBiABIAYgCyAMQQAQGyEKIAAgCjYCAAJAAkACQAJAIAwoAgAOAgEAAgsgAiAFTCEHIAdBAXMhBSAFQQFxIQUgBiAFdCEFQQFBAiAHGyEGIAYhCUEAIAggBxshCCAFIQYMAgsgCygCACEHIAQoAgAhBSAFIAdqIQUgBCAFNgIAIAEgB2ohAUEAIQkgAiAHayECDAELQQEhCUF/IQgLAkACQAJAIAlBA3EOAwABAAELDAELDAELIAoEQCAKIQYMAwUgBiEFDAILAAsLIAkEfyAIBSAKIQYMAQshEgwBCyAGQQRqIQogCigCACEIIAhBAnQhCCAIEF4hDSANRQRAEAYLIAooAgAhCCAIQQBKBEAgCEECdCEIIA1BACAIEHoaC0EAIQVBACEKIAEhCCAGIQECQAJAAkADQCALQQA2AgAgDEEANgIAIAJBIEghBiACQSAgBhshCSABIAggCUEAIAsgDBAUIQEgAUUEQEEgIQYgCSEBA0AgAiAGSiEGIAZFDQQgAUEBdCEGIAYgAkohASACIAYgARshASAAKAIAIQkgCSAIIAFBACALIAwQFCEJIAlFDQALIAkhAQsgBCgCACEGIAYgAWohBiAEIAY2AgAgCCABaiEIIAIgAWshBiAMKAIAIREgESAKaiEJAkACQCAFIAlIBEAgBUUhAiAFQQF0IQFBgCAgASACGyECIAAoAgAhASABQQRqIQUgBSgCACEFIAVBAEoEQCACQQJ0IQ5BACEBA0AgDSABQQJ0aiEHIAcoAgAhBSAFIA4QYCEFIAVFDQYgByAFNgIAIAFBAWohASAAKAIAIQcgB0EEaiEFIAUoAgAhBSABIAVIDQALIAUhDiAHIQEMAgsFIAAoAgAiAUEEaiEHIAUhAiAHKAIAIQ4MAQsMAQsgDkEASgRAIBFBAEohEyALKAIAIRRBACEHA0AgEwRAIBQgB0ECdGooAgAhFSANIAdBAnRqKAIAIRZBACEFA0AgFSAFQQJ0aiEPIA8qAgAhFyAXQwAAgD9eBEBDAACAPyEXBSAXQwAAgL9dBEBDAACAvyEXCwsgBSAKaiEPIBYgD0ECdGohDyAPIBc4AgAgBUEBaiEFIAUgEUcNAAsLIAdBAWohBSAFIA5IBEAgBSEHDAELCwsLIAIhBSAJIQogBiECDAAACwALEAYMAQsgAyANNgIAIAohEgsLIBAkBiASCzwBAX8gAEEIdCECIAFB/wFxIQEgAEEYdiEAIAAgAXMhACAAQQJ0QdAZaiEAIAAoAgAhACAAIAJzIQAgAAvvBAEFfyAAQdgLaiEGIAZBADYCACAAQdQLaiEGIAZBADYCACAAQdQAaiEIIAgoAgAhBgJ/IAYEf0EABSAAQSRqIQcCQAJAA0ACQCAAECAhBkEAIAZFDQUaIABBARAsIQYgBkUNACAHLAAAIQYgBg0CA0AgABAZIQYgBkF/Rw0ACyAIKAIAIQYgBkUNAUEADAULCwwBCyAAQSMQFUEADAILIABBxABqIQYgBigCACEGIAYEQCAAQcgAaiEGIAYoAgAhByAAQdAAaiEGIAYoAgAhBiAHIAZHBEBB0xNBxBNBuhhBixQQBAsLIABBjANqIQcgBygCACEGIAZBf2ohBiAGEC0hBiAAIAYQLCEIIAhBf0YEf0EABSAHKAIAIQYgCCAGSAR/IAUgCDYCACAAQZADaiAIQQZsaiEHIAcsAAAhBQJAAkAgBQR/IABB6ABqIQUgBSgCACEFIABBARAsIQYgAEEBECwhCCAGQQBHIQkgBywAACEGIAZFIQcgBUEBdSEGIAkgB3IEfwwCBSAAQeQAaiEKIAooAgAhCSAFIAlrIQkgCUECdSEJIAEgCTYCACAKKAIAIQEgASAFaiEJIAYhASAJQQJ1CwUgAEHkAGohBSAFKAIAIQZBACEIIAYhBSAGQQF1IQZBASEHDAELIQYMAQsgAUEANgIAIAYhAQsgAiAGNgIAIAhBAEchAiACIAdyBEAgAyABNgIABSAFQQNsIQIgAEHkAGohASABKAIAIQAgAiAAayEAIABBAnUhACADIAA2AgAgASgCACEAIAAgAmohACAAQQJ1IQULIAQgBTYCAEEBBUEACwsLCyEAIAALjB0CJ38DfSMGIRwjBkGAFGokBiAcQYAMaiEdIBxBgARqISQgHEGAAmohFCAcISAgAi0AACEHIAdB/wFxIQcgAEHcAGogB0ECdGohByAHKAIAIR4gAEGIA2ohByAHKAIAIRYgAkEBaiEHIActAAAhByAHQf8BcSEXIBYgF0EobGohIiAeQQF1IR9BACAfayEpIABBBGohGiAaKAIAIQcCfwJAIAdBAEoEfyAWIBdBKGxqQQRqISogAEH4AWohKyAAQfAAaiElIABB6ApqIRggAEHkCmohISAUQQFqISwDQAJAICooAgAhByAHIA1BA2xqQQJqIQcgBy0AACEHIAdB/wFxIQcgHSANQQJ0aiEVIBVBADYCACAWIBdBKGxqQQlqIAdqIQcgBy0AACEHIAdB/wFxIQ8gAEH4AGogD0EBdGohByAHLgEAIQcgB0UNACArKAIAIRAgAEEBECwhBwJAAkAgB0UNACAQIA9BvAxsakG0DGohByAHLQAAIQcgB0H/AXEhByAHQX9qIQcgB0ECdEGQCGohByAHKAIAISMgAEHYB2ogDUECdGohByAHKAIAIRkgIxAtIQcgB0F/aiEHIAAgBxAsIQggCEH//wNxIQggGSAIOwEAIAAgBxAsIQcgB0H//wNxIQcgGUECaiEIIAggBzsBACAQIA9BvAxsaiEmICYsAAAhByAHBEBBACETQQIhBwNAIBAgD0G8DGxqQQFqIBNqIQggCC0AACEIIAhB/wFxIRsgECAPQbwMbGpBIWogG2ohCCAILAAAIQwgDEH/AXEhJyAQIA9BvAxsakExaiAbaiEIIAgsAAAhCCAIQf8BcSEoQQEgKHQhCSAJQX9qIS0gCARAICUoAgAhCyAQIA9BvAxsakHBAGogG2ohCCAILQAAIQggCEH/AXEhCiALIApBsBBsaiEOIBgoAgAhCCAIQQpIBEAgABA0CyAhKAIAIQkgCUH/B3EhCCALIApBsBBsakEkaiAIQQF0aiEIIAguAQAhCCAIQX9KBEAgCyAKQbAQbGpBCGohDiAOKAIAIQ4gDiAIaiEOIA4tAAAhDiAOQf8BcSEOIAkgDnYhCSAhIAk2AgAgGCgCACEJIAkgDmshCSAJQQBIIQ5BACAJIA4bIRFBfyAIIA4bIQkgGCARNgIABSAAIA4QNSEJCyALIApBsBBsakEXaiEIIAgsAAAhCCAIBEAgCyAKQbAQbGpBqBBqIQggCCgCACEIIAggCUECdGohCCAIKAIAIQkLBUEAIQkLIAwEQEEAIQsgByEIA0AgCSAtcSEKIBAgD0G8DGxqQdIAaiAbQQR0aiAKQQF0aiEKIAouAQAhDCAJICh1IQogDEF/SgR/ICUoAgAhDiAOIAxBsBBsaiESIBgoAgAhCSAJQQpIBEAgABA0CyAhKAIAIREgEUH/B3EhCSAOIAxBsBBsakEkaiAJQQF0aiEJIAkuAQAhCSAJQX9KBEAgDiAMQbAQbGpBCGohEiASKAIAIRIgEiAJaiESIBItAAAhEiASQf8BcSESIBEgEnYhESAhIBE2AgAgGCgCACERIBEgEmshESARQQBIIRJBACARIBIbIRFBfyAJIBIbIQkgGCARNgIABSAAIBIQNSEJCyAOIAxBsBBsakEXaiERIBEsAAAhESARBEAgDiAMQbAQbGpBqBBqIQwgDCgCACEMIAwgCUECdGohCSAJKAIAIQkLIAlB//8DcQVBAAshCSAZIAhBAXRqIAk7AQAgCEEBaiEIIAtBAWohCyALICdHBEAgCiEJDAELCyAHICdqIQcLIBNBAWohEyAmLQAAIQggCEH/AXEhCCATIAhJDQALCyAYKAIAIQcgB0F/Rg0AICxBAToAACAUQQE6AAAgECAPQbwMbGpBuAxqIQcgBygCACETIBNBAkoEQCAjQf//A2ohG0ECIQcDQCAQIA9BvAxsakHACGogB0EBdGohCCAILQAAIQggCEH/AXEhCyAQIA9BvAxsaiAHQQF0akHBCGohCCAILQAAIQggCEH/AXEhCiAQIA9BvAxsakHSAmogB0EBdGohCCAILwEAIQggCEH//wNxIQggECAPQbwMbGpB0gJqIAtBAXRqIQkgCS8BACEJIAlB//8DcSEJIBAgD0G8DGxqQdICaiAKQQF0aiEMIAwvAQAhDCAMQf//A3EhDCAZIAtBAXRqIQ4gDi4BACEOIBkgCkEBdGohFSAVLgEAIRUgCCAJIAwgDiAVEDYhCCAZIAdBAXRqIQ4gDi4BACEJICMgCGshDAJAAkAgCQRAIAwgCEghFSAMIAggFRtBAXQhFSAUIApqIQogCkEBOgAAIBQgC2ohCyALQQE6AAAgFCAHaiELIAtBAToAACAVIAlMBEAgDCAISg0DIBsgCWshCAwCCyAJQQFxIQsgCwR/IAlBAWohCSAJQQF2IQkgCCAJawUgCUEBdSEJIAkgCGoLIQgFIBQgB2ohCSAJQQA6AAALCyAOIAg7AQALIAdBAWohByAHIBNIDQALCyATQQBKBEBBACEHA0AgFCAHaiEIIAgsAAAhCCAIRQRAIBkgB0EBdGohCCAIQX87AQALIAdBAWohByAHIBNHDQALCwwBCyAVQQE2AgALIA1BAWohDSAaKAIAIQcgDSAHSA0BDAMLCyAAQRUQFUEABQwBCwwBCyAAQcQAaiETIBMoAgAhCSAJBEAgAEHIAGohCCAIKAIAIQggAEHQAGohDSANKAIAIQ0gCCANRwRAQdMTQcQTQc8ZQecUEAQLCyAHQQJ0IQggJCAdIAgQeRogIi4BACEIIAgEQCAWIBdBKGxqKAIEIQ0gCEH//wNxIQxBACEIA0AgDSAIQQNsaiELIAstAAAhCyALQf8BcSELIB0gC0ECdGohCyALKAIAIQ8gHSANIAhBA2xqLQABQQJ0aiEKAkACQCAPRQ0AIAooAgAhDyAPRQ0ADAELIApBADYCACALQQA2AgALIAhBAWohCCAIIAxJDQALCyAWIBdBKGxqQQhqIQsgCywAACEIIAgEQCAWIBdBKGxqQQRqIQxBACEJIAchDQNAAkAgDUEASgRAIAwoAgAhD0EAIQdBACEIA0AgDyAIQQNsakECaiEKIAotAAAhCiAKQf8BcSEKIAkgCkYEQCAdIAhBAnRqIQogCigCACEQICAgB2ohCiAQBEAgCkEBOgAAIBQgB0ECdGohCiAKQQA2AgAFIApBADoAACAAQZQGaiAIQQJ0aiEKIAooAgAhCiAUIAdBAnRqIRAgECAKNgIACyAHQQFqIQcLIAhBAWohCCAIIA1IDQALBUEAIQcLIBYgF0EobGpBGGogCWohCCAILQAAIQggCEH/AXEhCCAAIBQgByAfIAggIBA3IAlBAWohCSALLQAAIQcgB0H/AXEhByAJIAdPDQAgGigCACENDAELCyATKAIAIQkLIAkEQCAAQcgAaiEHIAcoAgAhByAAQdAAaiEIIAgoAgAhCCAHIAhHBEBB0xNBxBNB8BlB5xQQBAsLICIuAQAhByAHBEAgFiAXQShsaigCBCENIB5BAUohDCAHQf//A3EhCANAIAhBf2ohCSANIAlBA2xqIQcgBy0AACEHIAdB/wFxIQcgAEGUBmogB0ECdGohByAHKAIAISAgDSAJQQNsakEBaiEHIActAAAhByAHQf8BcSEHIABBlAZqIAdBAnRqIQcgBygCACEPIAwEQEEAIQcDQCAgIAdBAnRqIQsgCyoCACEuIA8gB0ECdGoiECoCACIvQwAAAABeIQogLkMAAAAAXgRAIAoEQCAuITAgLiAvkyEuBSAuIC+SITALBSAKBEAgLiEwIC4gL5IhLgUgLiAvkyEwCwsgCyAwOAIAIBAgLjgCACAHQQFqIQcgByAfSA0ACwsgCEEBSgRAIAkhCAwBCwsLIBooAgAhByAHQQBKBEAgH0ECdCEJQQAhBwNAICQgB0ECdGohCCAIKAIAIQ0gAEGUBmogB0ECdGohCCANBEAgCCgCACEIIAhBACAJEHoaBSAIKAIAIQggAEHYB2ogB0ECdGohDSANKAIAIQ0gACAiIAcgHiAIIA0QOAsgB0EBaiEHIBooAgAhCCAHIAhIDQALIAhBAEoEQEEAIQcDQCAAQZQGaiAHQQJ0aiEIIAgoAgAhCCACLQAAIQkgCUH/AXEhCSAIIB4gACAJEDkgB0EBaiEHIBooAgAhCCAHIAhIDQALCwsgABAhIABB1QpqIQIgAiwAACEHIAcEQCAAQZgIaiEGIAYgKTYCACAeIAVrIQYgAEH4CmohByAHIAY2AgAgAEGcCGohBiAGQQE2AgAgAkEAOgAABSAAQfgKaiEHIAcoAgAhAiACBEAgBCADayEIIAIgCEgEQCACIANqIQMgBiADNgIAIAdBADYCAAUgAiAIayECIAcgAjYCACAGIAQ2AgAgBCEDCwsLIABB4ApqIQIgAigCACECIABB8ApqIQYgBigCACEHIABBnAhqIggoAgAhBgJAAkAgAiAHRgRAIAYEQCAAQdMKaiECIAIsAAAhAiACQQRxIQIgAgRAIABB9ApqIQIgAigCACECIABBmAhqIQYgBigCACEHIAUgA2shCSAJIAdqIQkgAiAJSSEJIAIgB0khDSACIAdrIQJBACACIA0bIQIgAiADaiECIAIgBUohByAFIAIgBxshAiAJBEAgASACNgIAIAYoAgAhACAAIAJqIQAgBiAANgIAQQEMBgsLCyAAQfQKaiECIAIoAgAhAiADIB9rIQYgBiACaiEGIABBmAhqIQIgAiAGNgIAIAhBATYCAAwBBSAAQZgIaiECIAYNAQsMAQsgBCADayEDIAIoAgAhBCADIARqIQMgAiADNgIACyATKAIAIQIgAgRAIABByABqIQIgAigCACECIABB0ABqIQAgACgCACEAIAIgAEcEQEHTE0HEE0HkGkHnFBAECwsgASAFNgIAQQELIQAgHCQGIAALqAIBBX8gAEHoCmohBSAFKAIAIQICQCACQQBIBEBBACEABSACIAFIBEAgAUEYSgRAIABBGBAsIQIgAUFoaiEBIAAgARAsIQAgAEEYdCEAIAAgAmohACAADwsgAkUEQCAAQeQKaiECIAJBADYCAAsgAEHkCmohAwJAAkACQANAIAAQLiECIAJBf0YNASAFKAIAIQQgAiAEdCECIAMoAgAhBiAGIAJqIQIgAyACNgIAIAUgBEEIaiICNgIAIAIgAUgNAAwCAAsACyAFQX82AgBBACEADAQLIARBeEgEQEEAIQAMBAsLCyAAQeQKaiEEIAQoAgAhA0EBIAF0IQAgAEF/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(E){return E.charCodeAt(0)});var I=I!==void 0?I:{},rA={};for(t in I)I.hasOwnProperty(t)&&(rA[t]=I[t]);I.arguments=[],I.thisProgram="./this.program",I.quit=function(E,h){throw h},I.preRun=[],I.postRun=[];var Z=!1,AA=!1,$=!1,IA=!1;Z=typeof window=="object",AA=typeof importScripts=="function",$=typeof process=="object"&&typeof Fn=="function"&&!Z&&!AA,IA=!Z&&!$&&!AA;var sA="";function iA(E){return I.locateFile?I.locateFile(E,sA):sA+E}$?(sA=__dirname+"/",I.read=function(h,u){var m;return A||(A=void 0),e||(e=void 0),h=e.normalize(h),m=A.readFileSync(h),u?m:m.toString()},I.readBinary=function(h){var u=I.read(h,!0);return u.buffer||(u=new Uint8Array(u)),te(u.buffer),u},process.argv.length>1&&(I.thisProgram=process.argv[1].replace(/\\/g,"/")),I.arguments=process.argv.slice(2),typeof module<"u",process.on("uncaughtException",function(E){if(!(E instanceof Me))throw E}),process.on("unhandledRejection",function(E,h){process.exit(1)}),I.quit=function(E){process.exit(E)},I.inspect=function(){return"[Emscripten Module object]"}):IA?(typeof read<"u"&&(I.read=function(h){return read(h)}),I.readBinary=function(h){var u;return typeof readbuffer=="function"?new Uint8Array(readbuffer(h)):(te(typeof(u=read(h,"binary"))=="object"),u)},typeof scriptArgs<"u"?I.arguments=scriptArgs:typeof arguments<"u"&&(I.arguments=arguments),typeof quit=="function"&&(I.quit=function(E){quit(E)})):(Z||AA)&&(Z?document.currentScript&&(sA=document.currentScript.src):sA=self.location.href,sA=sA.indexOf("blob:")!==0?sA.split("/").slice(0,-1).join("/")+"/":"",I.read=function(h){var u=new XMLHttpRequest;return u.open("GET",h,!1),u.send(null),u.responseText},AA&&(I.readBinary=function(h){var u=new XMLHttpRequest;return u.open("GET",h,!1),u.responseType="arraybuffer",u.send(null),new Uint8Array(u.response)}),I.readAsync=function(h,u,m){var U=new XMLHttpRequest;U.open("GET",h,!0),U.responseType="arraybuffer",U.onload=function(){if(U.status==200||U.status==0&&U.response){u(U.response);return}m()},U.onerror=m,U.send(null)},I.setWindowTitle=function(E){document.title=E});var eA=I.print||(typeof console<"u"?console.log.bind(console):typeof print<"u"?print:null),lA=I.printErr||(typeof printErr<"u"?printErr:typeof console<"u"&&console.warn.bind(console)||eA);for(t in rA)rA.hasOwnProperty(t)&&(I[t]=rA[t]);function UA(E){var h=c;return c=c+E+15&-16,h}function an(E){var h=C[R>>2],u=h+E+15&-16;return C[R>>2]=u,u>=mA&&!un()?(C[R>>2]=h,0):h}function gn(E,h){return h||(h=16),E=Math.ceil(E/h)*h}function jo(E){switch(E){case"i1":case"i8":return 1;case"i16":return 2;case"i32":case"float":return 4;case"i64":case"double":return 8;default:if(E[E.length-1]==="*")return 4;if(E[0]!=="i")return 0;var h=parseInt(E.substr(1));return te(h%8==0),h/8}}function Fe(E){Fe.shown||(Fe.shown={}),Fe.shown[E]||(Fe.shown[E]=1,lA(E))}rA=void 0;var $o={"f64-rem":function(E,h){return E%h},debugger:function(){}},St=[];function xr(E,h){for(var u=0,m=u;m<u+0;m++)if(!St[m])return St[m]=E,1+m;throw"Finished up all reserved function pointers. Use a higher value for RESERVED_FUNCTION_POINTERS."}function Nr(E){St[E-1]=null}var Dt={};function br(E,h){if(E){te(h),Dt[h]||(Dt[h]={});var u=Dt[h];return u[E]||(h.length===1?u[E]=function(){return kt(h,E)}:h.length===2?u[E]=function(U){return kt(h,E,[U])}:u[E]=function(){return kt(h,E,Array.prototype.slice.call(arguments))}),u[E]}}function Lr(E,h,u){return u?+(E>>>0)+4294967296*+(h>>>0):+(E>>>0)+4294967296*+(0|h)}function kt(E,h,u){return u&&u.length?I["dynCall_"+E].apply(null,[h].concat(u)):I["dynCall_"+E].call(null,h)}var Je=0,In=0;function te(E,h){E||jA("Assertion failed: "+h)}function En(E){var h=I["_"+E];return te(h,"Cannot call unknown function "+E+", make sure it is exported"),h}var Cn={stackSave:function(){bt()},stackRestore:function(){Nt()},arrayToC:function(E){var h,u,m=Ze(E.length);return h=E,u=m,s.set(h,u),m},stringToC:function(E){var h=0;if(E!=null&&E!==0){var u=(E.length<<2)+1;h=Ze(u),cn(E,h,u)}return h}},Ar={string:Cn.stringToC,array:Cn.arrayToC};function Bn(E,h,u,m,U){var X=En(E),j=[],Y=0;if(m)for(var pA=0;pA<m.length;pA++){var EA=Ar[u[pA]];EA?(Y===0&&(Y=bt()),j[pA]=EA(m[pA])):j[pA]=m[pA]}var CA,aA=X.apply(null,j);return aA=(CA=aA,h==="string"?Pe(CA):h==="boolean"?!!CA:CA),Y!==0&&Nt(Y),aA}function er(E,h,u,m){switch((u=u||"i8").charAt(u.length-1)==="*"&&(u="i32"),u){case"i1":case"i8":s[E>>0]=h;break;case"i16":i[E>>1]=h;break;case"i32":C[E>>2]=h;break;case"i64":tempI64=[h>>>0,+rr(tempDouble=h)>=1?tempDouble>0?(0|ar(+yn(tempDouble/4294967296),4294967295))>>>0:~~+ir((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0],C[E>>2]=tempI64[0],C[E+4>>2]=tempI64[1];break;case"float":d[E>>2]=h;break;case"double":Q[E>>3]=h;break;default:jA("invalid type for setValue: "+u)}}function Ur(E,h,u){switch((h=h||"i8").charAt(h.length-1)==="*"&&(h="i32"),h){case"i1":case"i8":return s[E>>0];case"i16":return i[E>>1];case"i32":case"i64":return C[E>>2];case"float":return d[E>>2];case"double":return Q[E>>3];default:jA("invalid type for getValue: "+h)}return null}function Tr(E,h,u,m){typeof E=="number"?(X=!0,j=E):(X=!1,j=E.length);var U=typeof h=="string"?h:null;if(Y=u==4?m:[typeof Ke=="function"?Ke:UA,Ze,UA,an][u===void 0?2:u](Math.max(j,U?1:h.length)),X){for(m=Y,te((3&Y)==0),pA=Y+(-4&j);m<pA;m+=4)C[m>>2]=0;for(pA=Y+j;m<pA;)s[m++>>0]=0;return Y}if(U==="i8")return E.subarray||E.slice?o.set(E,Y):o.set(new Uint8Array(E),Y),Y;for(var X,j,Y,pA,EA,CA,aA,W=0;W<j;){var RA=E[W];if((EA=U||h[W])===0){W++;continue}EA=="i64"&&(EA="i32"),er(Y+W,RA,EA),aA!==EA&&(CA=jo(EA),aA=EA),W+=CA}return Y}function vr(E){return f?Mt?Ke(E):an(E):UA(E)}function Pe(E,h){if(h===0||!E)return"";for(var u,m,U,X=0,j=0;X|=m=o[E+j>>0],(m!=0||h)&&(j++,!h||j!=h););h||(h=j);var Y="";if(X<128){for(;h>0;)U=String.fromCharCode.apply(String,o.subarray(E,E+Math.min(h,1024))),Y=Y?Y+U:U,E+=1024,h-=1024;return Y}return u=E,function(EA,CA){for(var aA=CA;EA[aA];)++aA;if(aA-CA>16&&EA.subarray&&hn)return hn.decode(EA.subarray(CA,aA));for(var W,RA,TA,vA,HA,Ee,YA="";;){if(!(W=EA[CA++]))return YA;if(!(128&W)){YA+=String.fromCharCode(W);continue}if(RA=63&EA[CA++],(224&W)==192){YA+=String.fromCharCode((31&W)<<6|RA);continue}if(TA=63&EA[CA++],(240&W)==224?W=(15&W)<<12|RA<<6|TA:(vA=63&EA[CA++],(248&W)==240?W=(7&W)<<18|RA<<12|TA<<6|vA:(HA=63&EA[CA++],W=(252&W)==248?(3&W)<<24|RA<<18|TA<<12|vA<<6|HA:(1&W)<<30|RA<<24|TA<<18|vA<<12|HA<<6|(Ee=63&EA[CA++]))),W<65536)YA+=String.fromCharCode(W);else{var xe=W-65536;YA+=String.fromCharCode(55296|xe>>10,56320|1023&xe)}}}(o,u)}function Hr(E){for(var h="";;){var u=s[E++>>0];if(!u)return h;h+=String.fromCharCode(u)}}function Yr(E,h){return function(m,U,X){for(var j=0;j<m.length;++j)s[U++>>0]=m.charCodeAt(j);X||(s[U>>0]=0)}(E,h,!1)}var hn=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function qe(E,h,u,m){if(!(m>0))return 0;for(var U=u,X=u+m-1,j=0;j<E.length;++j){var Y=E.charCodeAt(j);if(Y>=55296&&Y<=57343&&(Y=65536+((1023&Y)<<10)|1023&E.charCodeAt(++j)),Y<=127){if(u>=X)break;h[u++]=Y}else if(Y<=2047){if(u+1>=X)break;h[u++]=192|Y>>6,h[u++]=128|63&Y}else if(Y<=65535){if(u+2>=X)break;h[u++]=224|Y>>12,h[u++]=128|Y>>6&63,h[u++]=128|63&Y}else if(Y<=2097151){if(u+3>=X)break;h[u++]=240|Y>>18,h[u++]=128|Y>>12&63,h[u++]=128|Y>>6&63,h[u++]=128|63&Y}else if(Y<=67108863){if(u+4>=X)break;h[u++]=248|Y>>24,h[u++]=128|Y>>18&63,h[u++]=128|Y>>12&63,h[u++]=128|Y>>6&63,h[u++]=128|63&Y}else{if(u+5>=X)break;h[u++]=252|Y>>30,h[u++]=128|Y>>24&63,h[u++]=128|Y>>18&63,h[u++]=128|Y>>12&63,h[u++]=128|Y>>6&63,h[u++]=128|63&Y}}return h[u]=0,u-U}function cn(E,h,u){return qe(E,o,h,u)}function Oe(E){for(var h=0,u=0;u<E.length;++u){var m=E.charCodeAt(u);m>=55296&&m<=57343&&(m=65536+((1023&m)<<10)|1023&E.charCodeAt(++u)),m<=127?++h:m<=2047?h+=2:m<=65535?h+=3:m<=2097151?h+=4:m<=67108863?h+=5:h+=6}return h}var ln=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0;function Jr(E){for(var h=E,u=h>>1;i[u];)++u;if((h=u<<1)-E>32&&ln)return ln.decode(o.subarray(E,h));for(var m=0,U="";;){var X=i[E+2*m>>1];if(X==0)return U;++m,U+=String.fromCharCode(X)}}function Pr(E,h,u){if(u===void 0&&(u=2147483647),u<2)return 0;for(var m=h,U=(u-=2)<2*E.length?u/2:E.length,X=0;X<U;++X){var j=E.charCodeAt(X);i[h>>1]=j,h+=2}return i[h>>1]=0,h-m}function qr(E){return 2*E.length}function Or(E){for(var h=0,u="";;){var m=C[E+4*h>>2];if(m==0)return u;if(++h,m>=65536){var U=m-65536;u+=String.fromCharCode(55296|U>>10,56320|1023&U)}else u+=String.fromCharCode(m)}}function Vr(E,h,u){if(u===void 0&&(u=2147483647),u<4)return 0;for(var m=h,U=m+u-4,X=0;X<E.length;++X){var j=E.charCodeAt(X);if(j>=55296&&j<=57343&&(j=65536+((1023&j)<<10)|1023&E.charCodeAt(++X)),C[h>>2]=j,(h+=4)+4>U)break}return C[h>>2]=0,h-m}function Kr(E){for(var h=0,u=0;u<E.length;++u){var m=E.charCodeAt(u);m>=55296&&m<=57343&&++u,h+=4}return h}function Zr(E){var h=Oe(E)+1,u=Ke(h);return u&&qe(E,s,u,h),u}function Wr(E){var h=Oe(E)+1,u=Ze(h);return qe(E,s,u,h),u}function Xr(E){return E}function _r(){var E,h=function(){var m=Error();if(!m.stack){try{throw Error(0)}catch(U){m=U}if(!m.stack)return"(no stack trace available)"}return m.stack.toString()}();return I.extraStackTrace&&(h+=`
|
|
14
|
-
`+I.extraStackTrace()),(E=h).replace(/__Z[\w\d_]+/g,function(u){var m,U=m=u;return u===U?u:u+" ["+U+"]"})}function wt(E,h){return E%h>0&&(E+=h-E%h),E}function Qn(E){I.buffer=n=E}function Ft(){I.HEAP8=s=new Int8Array(n),I.HEAP16=i=new Int16Array(n),I.HEAP32=C=new Int32Array(n),I.HEAPU8=o=new Uint8Array(n),I.HEAPU16=a=new Uint16Array(n),I.HEAPU32=B=new Uint32Array(n),I.HEAPF32=d=new Float32Array(n),I.HEAPF64=Q=new Float64Array(n)}function un(){var E=I.usingWasm?65536:16777216,h=2147483648-E;if(C[R>>2]>h)return!1;var u=mA;for(mA=Math.max(mA,16777216);mA<C[R>>2];)mA=mA<=536870912?wt(2*mA,E):Math.min(wt((3*mA+2147483648)/4,E),h);var m=I.reallocBuffer(mA);return m&&m.byteLength==mA?(Qn(m),Ft(),!0):(mA=u,!1)}l=c=y=S=w=H=R=0,f=!1,I.reallocBuffer||(I.reallocBuffer=function(E){try{if(ArrayBuffer.transfer)h=ArrayBuffer.transfer(n,E);else{var h,u=s;h=new ArrayBuffer(E),new Int8Array(h).set(u)}}catch{return!1}return!!gr(h)&&h});try{(x=Function.prototype.call.bind(Object.getOwnPropertyDescriptor(ArrayBuffer.prototype,"byteLength").get))(new ArrayBuffer(4))}catch{x=function(h){return h.byteLength}}var Rt=I.TOTAL_STACK||5242880,mA=I.TOTAL_MEMORY||16777216;function tr(){return mA}function Re(E){for(;E.length>0;){var h=E.shift();if(typeof h=="function"){h();continue}var u=h.func;typeof u=="number"?h.arg===void 0?I.dynCall_v(u):I.dynCall_vi(u,h.arg):u(h.arg===void 0?null:h.arg)}}mA<Rt&&lA("TOTAL_MEMORY should be larger than TOTAL_STACK, was "+mA+"! (TOTAL_STACK="+Rt+")"),I.buffer?n=I.buffer:(typeof WebAssembly=="object"&&typeof WebAssembly.Memory=="function"?(I.wasmMemory=new WebAssembly.Memory({initial:mA/65536}),n=I.wasmMemory.buffer):n=new ArrayBuffer(mA),I.buffer=n),Ft();var dn=[],Gt=[],fn=[],mn=[],pn=[],Mt=!1,nr=!1;function sr(E){dn.unshift(E)}function zr(E){Gt.unshift(E)}function jr(E){fn.unshift(E)}function $r(E){mn.unshift(E)}function or(E){pn.unshift(E)}function Ai(E,h,u){var m,U;Fe("writeStringToMemory is deprecated and should not be called! Use stringToUTF8() instead!"),u&&(m=s[U=h+Oe(E)]),cn(E,h,1/0),u&&(s[U]=m)}function ei(E,h,u){return E>=0?E:h<=32?2*Math.abs(1<<h-1)+E:Math.pow(2,h)+E}function ti(E,h,u){if(E<=0)return E;var m=h<=32?Math.abs(1<<h-1):Math.pow(2,h-1);return E>=m&&(h<=32||E>m)&&(E=-2*m+E),E}var rr=Math.abs,ir=Math.ceil,yn=Math.floor,ar=Math.min,Ie=0,xt=null,Ge=null;function ni(E){return E}I.preloadedImages={},I.preloadedAudios={};var Sn="data:application/octet-stream;base64,";function Ve(E){return String.prototype.startsWith?E.startsWith(Sn):E.indexOf(Sn)===0}(function(){var h="main.wast",u="main.wasm",m="main.temp.asm.js";Ve(h)||(h=iA(h)),Ve(u)||(u=iA(u)),Ve(m)||(m=iA(m));var U={global:null,env:null,asm2wasm:$o,parent:I},X=null;function j(aA){return aA}function Y(){try{if(I.wasmBinary)return new Uint8Array(I.wasmBinary);if(I.readBinary)return I.readBinary(u);throw"both async and sync fetching of the wasm failed"}catch(aA){jA(aA)}}I.asmPreload=I.asm;var pA=I.reallocBuffer,EA=function(aA){aA=wt(aA,I.usingWasm?65536:16777216);var W=I.buffer.byteLength;if(I.usingWasm)try{var RA=I.wasmMemory.grow((aA-W)/65536);return RA!==-1?I.buffer=I.wasmMemory.buffer:null}catch{return null}};I.reallocBuffer=function(aA){return CA==="asmjs"?pA(aA):EA(aA)};var CA="";I.asm=function(aA,W,RA){var TA;if(!(W=TA=W).table){var vA,HA=I.wasmTableSize;HA===void 0&&(HA=1024);var Ee=I.wasmMaxTableSize;typeof WebAssembly=="object"&&typeof WebAssembly.Table=="function"?Ee!==void 0?W.table=new WebAssembly.Table({initial:HA,maximum:Ee,element:"anyfunc"}):W.table=new WebAssembly.Table({initial:HA,element:"anyfunc"}):W.table=Array(HA),I.wasmTable=W.table}return W.memoryBase||(W.memoryBase=I.STATIC_BASE),W.tableBase||(W.tableBase=0),vA=function(xe,ue,Ut){if(typeof WebAssembly!="object")return lA("no native wasm support detected"),!1;if(!(I.wasmMemory instanceof WebAssembly.Memory))return lA("no native wasm Memory in use"),!1;function We(ZA,WA){if((X=ZA.exports).memory){var Ne,Tt,wn;Ne=X.memory,Tt=I.buffer,Ne.byteLength<Tt.byteLength&&lA("the new buffer in mergeMemory is smaller than the previous one. in native wasm, we should grow memory here"),wn=new Int8Array(Tt),new Int8Array(Ne).set(wn),Qn(Ne),Ft()}I.asm=X,I.usingWasm=!0,function(Ii){if(Ie--,I.monitorRunDependencies&&I.monitorRunDependencies(Ie),Ie==0&&(xt!==null&&(clearInterval(xt),xt=null),Ge)){var Ir=Ge;Ge=null,Ir()}}("wasm-instantiate")}if(ue.memory=I.wasmMemory,U.global={NaN:NaN,Infinity:1/0},U["global.Math"]=Math,U.env=ue,Ie++,I.monitorRunDependencies&&I.monitorRunDependencies(Ie),I.instantiateWasm)try{return I.instantiateWasm(U,We)}catch(ZA){return lA("Module.instantiateWasm callback failed with error: "+ZA),!1}function de(ZA){We(ZA.instance,ZA.module)}function kn(ZA){(!I.wasmBinary&&(Z||AA)&&typeof fetch=="function"?fetch(u,{credentials:"same-origin"}).then(function(WA){if(!WA.ok)throw"failed to load wasm binary file at '"+u+"'";return WA.arrayBuffer()}).catch(function(){return Y()}):new Promise(function(WA,Ne){WA(Y())})).then(function(WA){return WebAssembly.instantiate(WA,U)}).then(ZA).catch(function(WA){lA("failed to asynchronously prepare wasm: "+WA),jA(WA)})}return I.wasmBinary||typeof WebAssembly.instantiateStreaming!="function"||Ve(u)||typeof fetch!="function"?kn(de):WebAssembly.instantiateStreaming(fetch(u,{credentials:"same-origin"}),U).then(de).catch(function(ZA){lA("wasm streaming compile failed: "+ZA),lA("falling back to ArrayBuffer instantiation"),kn(de)}),{}}(aA,W,RA),te(vA,"no binaryen method succeeded."),vA},I.asm})(),c=(l=1024)+4816,Gt.push(),I.STATIC_BASE=l,I.STATIC_BUMP=4816;var xA=c;function si(E){s[xA]=s[E],s[xA+1]=s[E+1],s[xA+2]=s[E+2],s[xA+3]=s[E+3]}function oi(E){s[xA]=s[E],s[xA+1]=s[E+1],s[xA+2]=s[E+2],s[xA+3]=s[E+3],s[xA+4]=s[E+4],s[xA+5]=s[E+5],s[xA+6]=s[E+6],s[xA+7]=s[E+7]}function ri(E,h,u){var m=u>0?u:Oe(E)+1,U=Array(m),X=qe(E,U,0,U.length);return h&&(U.length=X),U}function ii(E){for(var h=[],u=0;u<E.length;u++){var m=E[u];m>255&&(m&=255),h.push(String.fromCharCode(m))}return h.join("")}c+=16,R=UA(4),w=(y=S=gn(c))+Rt,H=gn(w),C[R>>2]=H,f=!0,I.wasmTableSize=4,I.wasmMaxTableSize=4,I.asmGlobalArg={},I.asmLibraryArg={abort:jA,assert:te,enlargeMemory:un,getTotalMemory:tr,abortOnCannotGrowMemory:function(){jA("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_MEMORY=X with X higher than the current value "+mA+", (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(h,u,m){var U=bt();try{return I.dynCall_iii(h,u,m)}catch(X){if(Nt(U),typeof X!="number"&&X!=="longjmp")throw X;I.setThrew(1,0)}},___assert_fail:function(h,u,m,U){jA("Assertion failed: "+Pe(h)+", at: "+[u?Pe(u):"unknown filename",m,U?Pe(U):"unknown function"])},___setErrNo:function(h){return I.___errno_location&&(C[I.___errno_location()>>2]=h),h},_abort:function(){I.abort()},_emscripten_memcpy_big:function(h,u,m){return o.set(o.subarray(u,u+m),h),h},_llvm_floor_f64:yn,DYNAMICTOP_PTR:R,tempDoublePtr:xA,ABORT:Je,STACKTOP:S,STACK_MAX:w};var Dn=I.asm(I.asmGlobalArg,I.asmLibraryArg,n);I.asm=Dn,I.___errno_location=function(){return I.asm.___errno_location.apply(null,arguments)};var gr=I._emscripten_replace_memory=function(){return I.asm._emscripten_replace_memory.apply(null,arguments)};I._free=function(){return I.asm._free.apply(null,arguments)};var Ke=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 Ze=I.stackAlloc=function(){return I.asm.stackAlloc.apply(null,arguments)},Nt=I.stackRestore=function(){return I.asm.stackRestore.apply(null,arguments)},bt=I.stackSave=function(){return I.asm.stackSave.apply(null,arguments)};function Me(E){this.name="ExitStatus",this.message="Program terminated with exit("+E+")",this.status=E}function Lt(E){E=E||I.arguments,!(Ie>0)&&(function(){if(I.preRun)for(typeof I.preRun=="function"&&(I.preRun=[I.preRun]);I.preRun.length;)sr(I.preRun.shift());Re(dn)}(),!(Ie>0)&&(I.calledRun||(I.setStatus?(I.setStatus("Running..."),setTimeout(function(){setTimeout(function(){I.setStatus("")},1),h()},1)):h())));function h(){!I.calledRun&&(I.calledRun=!0,Je||(Mt||(Mt=!0,Re(Gt)),Re(fn),I.onRuntimeInitialized&&I.onRuntimeInitialized(),function(){if(I.postRun)for(typeof I.postRun=="function"&&(I.postRun=[I.postRun]);I.postRun.length;)or(I.postRun.shift());Re(pn)}()))}}function ai(E,h){(!h||!I.noExitRuntime||E!==0)&&(I.noExitRuntime||(Je=!0,In=E,S=G,Re(mn),nr=!0,I.onExit&&I.onExit(E)),I.quit(E,new Me(E)))}function jA(E){throw I.onAbort&&I.onAbort(E),E!==void 0?(eA(E),lA(E),E=JSON.stringify(E)):E="",Je=!0,In=1,"abort("+E+"). Build with -s ASSERTIONS=1 for more info."}if(I.dynCall_iii=function(){return I.asm.dynCall_iii.apply(null,arguments)},I.asm=Dn,I.ccall=Bn,I.cwrap=function(h,u,m,U){var X=(m=m||[]).every(function(j){return j==="number"});return u!=="string"&&X&&!U?En(h):function(){return Bn(h,u,m,arguments,U)}},Me.prototype=Error(),Me.prototype.constructor=Me,Ge=function E(){I.calledRun||Lt(),I.calledRun||(Ge=E)},I.run=Lt,I.abort=jA,I.preInit)for(typeof I.preInit=="function"&&(I.preInit=[I.preInit]);I.preInit.length>0;)I.preInit.pop()();I.noExitRuntime=!0,Lt(),I.onRuntimeInitialized=()=>{fs=!0,ms()},zA.decode=function(E){return function(u){if(!fs)throw Error("Not initialized");var m={};function U(ue){return new Int32Array(I.HEAPU8.buffer,ue,1)[0]}function X(ue,Ut){var We=new ArrayBuffer(Ut*Float32Array.BYTES_PER_ELEMENT),de=new Float32Array(We);return de.set(new Float32Array(I.HEAPU8.buffer,ue,Ut)),de}m.open=I.cwrap("stb_vorbis_js_open","number",[]),m.close=I.cwrap("stb_vorbis_js_close","void",["number"]),m.channels=I.cwrap("stb_vorbis_js_channels","number",["number"]),m.sampleRate=I.cwrap("stb_vorbis_js_sample_rate","number",["number"]),m.decode=I.cwrap("stb_vorbis_js_decode","number",["number","number","number","number","number"]);var j,Y,pA,EA,CA=m.open(),aA=(j=u,Y=u.byteLength,pA=I._malloc(Y),(EA=new Uint8Array(I.HEAPU8.buffer,pA,Y)).set(new Uint8Array(j,0,Y)),EA),W=I._malloc(4),RA=I._malloc(4),TA=m.decode(CA,aA.byteOffset,aA.byteLength,W,RA);if(I._free(aA.byteOffset),TA<0)throw m.close(CA),I._free(W),Error("stbvorbis decode failed: "+TA);for(var vA=m.channels(CA),HA=Array(vA),Ee=new Int32Array(I.HEAPU32.buffer,U(W),vA),YA=0;YA<vA;YA++)HA[YA]=X(Ee[YA],TA),I._free(Ee[YA]);var xe=m.sampleRate(CA);return m.close(CA),I._free(U(W)),I._free(W),{data:HA,sampleRate:xe,eof:!0,error:null}}(E)}})();function ps(t){let A=t.messageData,e=t.channelNumber,n={};switch(e>=0&&(n=this.workletProcessorChannels[e]),t.messageType){case nA.noteOn:this.noteOn(e,A[0],A[1],A[2]);break;case nA.noteOff:this.noteOff(e,A);break;case nA.pitchWheel:this.pitchWheel(e,A[0],A[1]);break;case nA.ccChange:this.controllerChange(e,A[0],A[1],A[2]);break;case nA.customcCcChange:n.customControllers[A[0]]=A[1];break;case nA.killNote:this.killNote(e,A);break;case nA.programChange:this.programChange(e,A[0],A[1]);break;case nA.channelPressure:this.channelPressure(e,A);break;case nA.polyPressure:this.polyPressure(e,A[0],A[1]);break;case nA.ccReset:e===OA?this.resetAllControllers():this.resetControllers(e);break;case nA.systemExclusive:this.systemExclusive(A);break;case nA.setChannelVibrato:if(e===OA)for(let i=0;i<this.workletProcessorChannels.length;i++)A.rate===-1?this.disableAndLockGSNRPN(i):this.setVibrato(i,A.depth,A.rate,A.delay);else A.rate===-1?this.disableAndLockGSNRPN(e):this.setVibrato(e,A.depth,A.rate,A.delay);break;case nA.stopAll:e===OA?this.stopAllChannels(A===1):this.stopAll(e,A===1);break;case nA.killNotes:this.voiceKilling(A);break;case nA.muteChannel:this.muteChannel(e,A);break;case nA.addNewChannel:this.createWorkletChannel(!0);break;case nA.debugMessage:this.debugMessage();break;case nA.setMasterParameter:let s=A[0],o=A[1];switch(s){case me.masterPan:this.setMasterPan(o);break;case me.mainVolume:this.setMasterGain(o);break;case me.voicesCap:this.voiceCap=o;break;case me.interpolationType:this.interpolationType=o;break}break;case nA.setDrums:this.setDrums(e,A);break;case nA.transpose:e===OA?this.transposeAllChannels(A[0],A[1]):this.transposeChannel(e,A[0],A[1]);break;case nA.highPerformanceMode:this.highPerformanceMode=A;break;case nA.lockController:A[0]===OA?n.lockPreset=A[1]:n.lockedControllers[A[0]]=A[1];break;case nA.sequencerSpecific:this.sequencer.processMessage(A.messageType,A.messageData);break;case nA.soundFontManager:try{this.soundfontManager.handleMessage(A[0],A[1])}catch(i){this.post({messageType:DA.soundfontError,messageData:i})}this.clearSoundFont(!0,!1);break;case nA.keyModifierManager:this.keyModifierManager.handleMessage(A[0],A[1]);break;case nA.requestSynthesizerSnapshot:this.sendSynthesizerSnapshot();break;case nA.setLogLevel:Ln(A[0],A[1],A[2],A[3]);break;case nA.setEffectsGain:this.reverbGain=A[0],this.chorusGain=A[1];break;case nA.destroyWorklet:this.alive=!1;break;default:T("Unrecognized event:",A);break}}function ys(t,A){this.enableEventSystem&&this.post({messageType:DA.eventCall,messageData:{eventName:t,eventData:A}})}function Ss(){if(!this.enableEventSystem)return;let t=this.workletProcessorChannels.map(A=>{let e=(A.midiControllers[dA+q.pitchWheelRange]>>7)+(A.midiControllers[dA+q.pitchWheelRange]&127)/127;return{voicesAmount:A.voices.length,pitchBend:A.midiControllers[dA+q.pitchWheel],pitchBendRangeSemitones:e,isMuted:A.isMuted,isDrum:A.drumChannel}});this.post({messageType:DA.channelProperties,messageData:t})}function dr(t,A,e){let n=t,s=A<<7|e;return t===127&&A===127&&e===127?{midiNote:-1,centTuning:null}:{midiNote:n,centTuning:s*.0061}}function Ds(t,A=0){let e=t[0];if(!(this.deviceID!==OA&&t[1]!==127&&this.deviceID!==t[1]))switch(e){default:T(`%cUnrecognized SysEx: %c${SA(t)}`,g.warn,g.unrecognized);break;case 126:case 127:switch(t[2]){case 4:let s;switch(t[3]){case 1:let o=t[5]<<7|t[4];this.setMIDIVolume(o/16384),p(`%cMaster Volume. Volume: %c${o}`,g.info,g.value);break;case 2:let a=((t[5]<<7|t[4])-8192)/8192;this.setMasterPan(a),p(`%cMaster Pan. Pan: %c${a}`,g.info,g.value);break;case 3:let C=(t[5]<<7|t[6])-8192;s=Math.floor(C/81.92),this.setMasterTuning(s),p(`%cMaster Fine Tuning. Cents: %c${s}`,g.info,g.value);break;case 4:s=(t[5]-64)*100,this.setMasterTuning(s),p(`%cMaster Coarse Tuning. Cents: %c${s}`,g.info,g.value);break;default:T(`%cUnrecognized MIDI Device Control Real-time message: %c${SA(t)}`,g.warn,g.unrecognized)}break;case 9:t[3]===1?(p("%cGM system on",g.info),this.system="gm"):t[3]===3?(p("%cGM2 system on",g.info),this.system="gm2"):(p("%cGM system off, defaulting to GS",g.info),this.system="gs");break;case 8:switch(t[3]){case 2:case 7:let o=4;t[3]===7&&o++;let i=t[o++],a=t[o++];for(let B=0;B<a;B++)this.tunings[i][t[o++]]=dr(t[o++],t[o++],t[o++]);p(`%cSingle Note Tuning. Program: %c${i}%c Keys affected: %c${a}`,g.info,g.recognized,g.info,g.recognized);break;case 9:case 8:let C=new Int8Array(12);if(t[3]===8)for(let B=0;B<12;B++)C[B]=t[7+B]-64;else for(let B=0;B<24;B+=2){let d=(t[7+B]<<7|t[8+B])-8192;C[B/2]=Math.floor(d/81.92)}(t[4]&1)===1&&this.setOctaveTuning(14+A,C),(t[4]>>1&1)===1&&this.setOctaveTuning(15+A,C);for(let B=0;B<7;B++)(t[5]>>B&1)===1&&this.setOctaveTuning(7+B+A,C);for(let B=0;B<7;B++)(t[6]>>B&1)===1&&this.setOctaveTuning(B+A,C);p(`%cMIDI Octave Scale ${t[3]===8?"(1 byte)":"(2 bytes)"} tuning via Tuning: %c${C.join(" ")}`,g.info,g.value);break;default:T(`%cUnrecognized MIDI Tuning standard message: %c${SA(t)}`,g.warn,g.unrecognized);break}break;default:T(`%cUnrecognized MIDI Realtime/non realtime message: %c${SA(t)}`,g.warn,g.unrecognized)}break;case 65:let n=function(){T(`%cUnrecognized Roland %cGS %cSysEx: %c${SA(t)}`,g.warn,g.recognized,g.warn,g.unrecognized)};if(t[2]===66&&t[3]===18){let s=t[7];if(t[6]===127){s===0?(p("%cGS Reset received!",g.info),this.resetAllControllers(!1),this.system="gs"):s===127&&(p("%cGS system off, switching to GM2",g.info),this.resetAllControllers(!1),this.system="gm2");return}else if(t[4]===64){if((t[5]&16)>0){let o=[9,0,1,2,3,4,5,6,7,8,10,11,12,13,14,15][t[5]&15]+A;switch(t[6]){default:n();break;case 21:let i=s>0&&t[5]>>4;this.setDrums(o,i),p(`%cChannel %c${o}%c ${i?"is now a drum channel":"now isn't a drum channel"}%c via: %c${SA(t)}`,g.info,g.value,g.recognized,g.info,g.value);return;case 22:let a=s-64;this.transposeChannel(o,a),p(`%cChannel %c${o}%c pitch shift. Semitones %c${a}%c, with %c${SA(t)}`,g.info,g.recognized,g.info,g.value,g.info,g.value);return;case 28:let C=s;C===0&&(C=Math.floor(Math.random()*128)),this.controllerChange(o,k.pan,C);break;case 33:this.controllerChange(o,k.chorusDepth,s);break;case 34:this.controllerChange(o,k.reverbDepth,s);break;case 64:case 65:case 66:case 67:case 68:case 69:case 70:case 71:case 72:case 73:case 74:case 75:let B=t.length-9,d=new Int8Array(12);for(let l=0;l<B;l++)d[l]=t[l+7]-64;this.setOctaveTuning(o,d);let Q=s-64;p(`%cChannel %c${o}%c octave scale tuning. Cents %c${d.join(" ")}%c, with %c${SA(t)}`,g.info,g.recognized,g.info,g.value,g.info,g.value),this.setChannelTuning(o,Q);break}return}else if(t[5]===0&&t[6]===6){p(`%cRoland GS Master Pan set to: %c${s}%c with: %c${SA(t)}`,g.info,g.value,g.info,g.value),this.setMasterPan((s-64)/64);return}else if(t[5]===0&&t[6]===5){let o=s-64;p(`%cRoland GS Master Key-Shift set to: %c${o}%c with: %c${SA(t)}`,g.info,g.value,g.info,g.value),this.setMasterTuning(o*100);return}else if(t[5]===0&&t[6]===4){p(`%cRoland GS Master Volume set to: %c${s}%c with: %c${SA(t)}`,g.info,g.value,g.info,g.value),this.setMIDIVolume(s/127);return}}n();return}else if(t[2]===22&&t[3]===18&&t[4]===16){this.setMIDIVolume(t[7]/100),p(`%cRoland Master Volume control set to: %c${t[7]}%c via: %c${SA(t)}`,g.info,g.value,g.info,g.value);return}else{T(`%cUnrecognized Roland SysEx: %c${SA(t)}`,g.warn,g.unrecognized);return}case 67:if(t[2]===76)if(t[3]===0&&t[4]===0)switch(t[5]){case 4:let s=t[6];this.setMIDIVolume(s/127),p(`%cXG master volume. Volume: %c${s}`,g.info,g.recognized);break;case 6:let o=t[6]-64;this.transposeAllChannels(o),p(`%cXG master transpose. Volume: %c${o}`,g.info,g.recognized);break;case 126:p("%cXG system on",g.info),this.resetAllControllers(!1),this.system="xg";break}else if(t[3]===8){if(this.system!=="xg")return;let s=t[4]+A;if(s>=this.workletProcessorChannels.length)return;let o=t[6];switch(t[5]){case 1:this.controllerChange(s,k.bankSelect,o);break;case 2:this.controllerChange(s,k.lsbForControl0BankSelect,o);break;case 3:this.programChange(s,o);break;case 8:let i=this.workletProcessorChannels[s];if(i.drumChannel)return;let a=o-64;i.channelTransposeKeyShift=a;break;case 11:this.controllerChange(s,k.mainVolume,o);break;case 14:let C=o;C===0&&(C=Math.floor(Math.random()*127)),this.controllerChange(s,k.pan,C);break;case 19:this.controllerChange(s,k.reverbDepth,o);break;case 18:this.controllerChange(s,k.chorusDepth,o);break;default:T(`%cUnrecognized Yamaha XG Part Setup: %c${t[5].toString(16).toUpperCase()}`,g.warn,g.unrecognized)}}else this.system==="xg"&&T(`%cUnrecognized Yamaha XG SysEx: %c${SA(t)}`,g.warn,g.unrecognized);else this.system==="xg"&&T(`%cUnrecognized Yamaha SysEx: %c${SA(t)}`,g.warn,g.unrecognized);break}}var fr=1e3/200;function ks(t,A,e){if(A.transformAmount===0)return A.currentValue=0,0;let n;if(A.sourceUsesCC)n=t[A.sourceIndex];else{let B=A.sourceIndex+dA;switch(A.sourceIndex){case q.noController:n=16383;break;case q.noteOnKeyNum:n=e.midiNote<<7;break;case q.noteOnVelocity:n=e.velocity<<7;break;case q.polyPressure:n=e.pressure<<7;break;default:n=t[B];break}}let s=Qe[A.sourceCurveType][A.sourcePolarity][A.sourceDirection][n],o;if(A.secSrcUsesCC)o=t[A.secSrcIndex];else{let B=A.secSrcIndex+dA;switch(A.secSrcIndex){case q.noController:o=16383;break;case q.noteOnKeyNum:o=e.midiNote<<7;break;case q.noteOnVelocity:o=e.velocity<<7;break;case q.polyPressure:o=e.pressure<<7;break;default:o=t[B]}}let i=Qe[A.secSrcCurveType][A.secSrcPolarity][A.secSrcDirection][o],a=A.transformAmount;A.isEffectModulator&&a<=1e3&&(a*=fr,a=Math.min(a,1e3));let C=s*i*a;return A.transformType===2&&(C=Math.abs(C)),A.currentValue=C,C}function Ae(t,A,e=-1,n=0){let s=t.modulators,o=t.generators,i=t.modulatedGenerators;if(e===-1){i.set(o),s.forEach(B=>{let d=J[B.modulatorDestination],Q=i[B.modulatorDestination]+ks(A,B,t);i[B.modulatorDestination]=Math.max(d.min,Math.min(Q,d.max))}),qA.recalculate(t),PA.recalculate(t);return}let a=new Set([r.initialAttenuation,r.delayVolEnv,r.attackVolEnv,r.holdVolEnv,r.decayVolEnv,r.sustainVolEnv,r.releaseVolEnv,r.keyNumToVolEnvHold,r.keyNumToVolEnvDecay]),C=new Set;s.forEach(B=>{if(B.sourceUsesCC===e&&B.sourceIndex===n||B.secSrcUsesCC===e&&B.secSrcIndex===n){let d=B.modulatorDestination;C.has(d)||(i[d]=o[d],ks(A,B,t),s.forEach(Q=>{if(Q.modulatorDestination===d){let l=J[B.modulatorDestination],c=i[B.modulatorDestination]+Q.currentValue;i[B.modulatorDestination]=Math.max(l.min,Math.min(c,l.max))}}),C.add(d))}}),[...C].some(B=>a.has(B))&&qA.recalculate(t),PA.recalculate(t)}var Qe=[];for(let t=0;t<4;t++){Qe[t]=[[new Float32Array(fA),new Float32Array(fA)],[new Float32Array(fA),new Float32Array(fA)]];for(let A=0;A<fA;A++)Qe[t][0][0][A]=le(0,t,A/fA,0),Qe[t][1][0][A]=le(0,t,A/fA,1),Qe[t][0][1][A]=le(1,t,A/fA,0),Qe[t][1][1][A]=le(1,t,A/fA,1)}function ws(t,A,e,n=!1,s=!0,o=currentTime){if(e===0){this.noteOff(t,A);return}let i=this.workletProcessorChannels[t];if(this.highPerformanceMode&&this.totalVoicesAmount>200&&e<40||this.highPerformanceMode&&e<10||i.isMuted)return;let a=A+i.channelTransposeKeyShift,C=a;if(A>127||A<0)return;let B=i.preset.program;this.tunings[B]?.[A]?.midiNote>=0&&(C=this.tunings[B]?.[A].midiNote),i.velocityOverride>0&&(e=i.velocityOverride);let d=this.keyModifierManager.getVelocity(t,A);d>-1&&(e=d);let Q=this.getWorkletVoices(t,C,e,i,o,a,n),l=i.voices;Q.forEach(c=>{let f=c.generators[r.exclusiveClass];f!==0&&l.forEach(G=>{G.generators[r.exclusiveClass]===f&&(this.releaseVoice(G,Fs),G.modulatedGenerators[r.releaseVolEnv]=-7e3,G.modulatedGenerators[r.releaseModEnv]=-7e3,qA.recalculate(G),PA.recalculate(G))}),Ae(c,i.midiControllers);let y=c.modulatedGenerators[r.startAddrsOffset]+c.modulatedGenerators[r.startAddrsCoarseOffset]*32768,S=c.modulatedGenerators[r.endAddrOffset]+c.modulatedGenerators[r.endAddrsCoarseOffset]*32768,w=c.modulatedGenerators[r.startloopAddrsOffset]+c.modulatedGenerators[r.startloopAddrsCoarseOffset]*32768,H=c.modulatedGenerators[r.endloopAddrsOffset]+c.modulatedGenerators[r.endloopAddrsCoarseOffset]*32768,R=c.sample,x=G=>Math.max(0,Math.min(R.sampleData.length-1,G));if(R.cursor=x(R.cursor+y),R.end=x(R.end+S),R.loopStart=x(R.loopStart+w),R.loopEnd=x(R.loopEnd+H),R.loopEnd<R.loopStart){let G=R.loopStart;R.loopStart=R.loopEnd,R.loopEnd=G}R.loopEnd-R.loopStart<1&&(R.loopingMode=0,R.isLooping=!1),c.volumeEnvelope.attenuation=c.volumeEnvelope.attenuationTargetGain,c.currentPan=(Math.max(-500,Math.min(500,c.modulatedGenerators[r.pan]))+500)/1e3}),this.totalVoicesAmount+=Q.length,this.totalVoicesAmount>this.voiceCap&&this.voiceKilling(Q.length),l.push(...Q),s&&(this.sendChannelProperties(),this.callEvent("noteon",{midiNote:A,channel:t,velocity:e}))}function Rs(t,A){if(A>127||A<0){T("Received a noteOn for note",A,"Ignoring.");return}let e=A+this.workletProcessorChannels[t].channelTransposeKeyShift;if(this.highPerformanceMode&&!this.workletProcessorChannels[t].drumChannel){this.killNote(t,e);return}this.workletProcessorChannels[t].voices.forEach(s=>{s.realKey!==e||s.isInRelease===!0||(this.workletProcessorChannels[t].holdPedal?this.workletProcessorChannels[t].sustainedVoices.push(s):this.releaseVoice(s))}),this.callEvent("noteoff",{midiNote:A,channel:t})}function Gs(t,A){this.workletProcessorChannels[t].voices.forEach(e=>{e.realKey===A&&(e.modulatedGenerators[r.releaseVolEnv]=-12e3,this.releaseVoice(e))})}function Ms(t,A=!1){let e=this.workletProcessorChannels[t].voices;A?(e.length=0,this.workletProcessorChannels[t].sustainedVoices.length=0,this.sendChannelProperties()):(e.forEach(n=>{n.isInRelease||this.releaseVoice(n)}),this.workletProcessorChannels[t].sustainedVoices.forEach(n=>{this.releaseVoice(n)}))}function xs(t=!1){p("%cStop all received!",g.info);for(let A=0;A<this.workletProcessorChannels.length;A++)this.stopAll(A,t);this.callEvent("stopall",void 0)}function Ns(t,A=!1){this.transposition=0;for(let e=0;e<this.workletProcessorChannels.length;e++)this.transposeChannel(e,t,A);this.transposition=t}function bs(t,A,e=!1){let n=this.workletProcessorChannels[t];n.drumChannel||(A+=this.transposition);let s=Math.trunc(A),o=n.channelTransposeKeyShift+n.customControllers[hA.channelTransposeFine]/100;n.drumChannel&&!e||A===o||(s!==n.channelTransposeKeyShift&&this.stopAll(t,!1),n.channelTransposeKeyShift=s,n.customControllers[hA.channelTransposeFine]=(A-s)*100)}function Ls(t,A,e=!0){let n=this.workletProcessorChannels[t];A=Math.round(A),n.customControllers[hA.channelTuning]=A,e&&p(`%cChannel ${t} fine tuning. Cents: %c${A}`,g.info,g.value)}function Us(t,A){let e=this.workletProcessorChannels[t];A=Math.round(A),e.customControllers[hA.channelTuningSemitones]=A,p(`%cChannel ${t} coarse tuning. Semitones: %c${A}`,g.info,g.value)}function Ts(t){t=Math.round(t);for(let A=0;A<this.workletProcessorChannels.length;A++)this.workletProcessorChannels[A].customControllers[hA.masterTuning]=t}function vs(t,A){let e=this.workletProcessorChannels[t];A=Math.round(A),p(`%cChannel ${t} modulation depth. Cents: %c${A}`,g.info,g.value),e.customControllers[hA.modulationMultiplier]=A/50}function Hs(t,A,e){if(this.workletProcessorChannels[t].lockedControllers[dA+q.pitchWheel])return;let n=e|A<<7;this.callEvent("pitchwheel",{channel:t,MSB:A,LSB:e}),this.workletProcessorChannels[t].midiControllers[dA+q.pitchWheel]=n,this.workletProcessorChannels[t].voices.forEach(s=>Ae(s,this.workletProcessorChannels[t].midiControllers,0,q.pitchWheel)),this.sendChannelProperties()}function Ys(t,A){let e=this.workletProcessorChannels[t];e.midiControllers[dA+q.channelPressure]=A<<7,this.workletProcessorChannels[t].voices.forEach(n=>Ae(n,e.midiControllers,0,q.channelPressure)),this.callEvent("channelpressure",{channel:t,pressure:A})}function Js(t,A,e){this.workletProcessorChannels[t].voices.forEach(n=>{n.midiNote===A&&(n.pressure=e,Ae(n,this.workletProcessorChannels[t].midiControllers,0,q.polyPressure))}),this.callEvent("polypressure",{channel:t,midiNote:A,pressure:e})}function Ps(t,A){if(A.length!==12)throw new Error("Tuning is not the length of 12.");this.workletProcessorChannels[t].channelOctaveTuning=A}function qs(t,A,e,n=!1){let s=this.workletProcessorChannels[t];if(s===void 0){T(`Trying to access channel ${t} which does not exist... ignoring!`);return}if(A>127){if(!n)return;switch(A){default:return;case qt.velocityOverride:s.velocityOverride=e}}if(A>=k.lsbForControl1ModulationWheel&&A<=k.lsbForControl13EffectControl2&&A!==k.lsbForControl6DataEntry){let o=A-32;if(s.lockedControllers[o])return;s.midiControllers[o]=s.midiControllers[o]&16256|e&127,s.voices.forEach(i=>Ae(i,s.midiControllers,1,o))}switch(A){case k.allNotesOff:this.stopAll(t);break;case k.allSoundOff:this.stopAll(t,!0);break;case k.bankSelect:let o=e;if(!n){switch(this.system){case"gm":p(`%cIgnoring the Bank Select (${e}), as the synth is in GM mode.`,g.info);return;case"xg":o===120||o===126||o===127?this.setDrums(t,!0):t%16!==GA&&this.setDrums(t,!1);break;case"gm2":o===120&&this.setDrums(t,!0)}s.drumChannel&&(o=128),o===128&&!s.drumChannel&&(o=XA(s))}ne(s,o);break;case k.lsbForControl0BankSelect:this.system==="xg"?s.drumChannel||e!==127&&ne(s,e):this.system==="gm2"&&ne(s,e);break;case k.RPNLsb:s.RPValue=s.RPValue<<7|e,s.dataEntryState=wA.RPFine;break;case k.RPNMsb:s.RPValue=e,s.dataEntryState=wA.RPCoarse;break;case k.NRPNMsb:s.NRPCoarse=e,s.dataEntryState=wA.NRPCoarse;break;case k.NRPNLsb:s.NRPFine=e,s.dataEntryState=wA.NRPFine;break;case k.dataEntryMsb:this.dataEntryCoarse(t,e);break;case k.lsbForControl6DataEntry:this.dataEntryFine(t,e);break;case k.resetAllControllers:this.resetControllers(t);break;case k.sustainPedal:e>=64?s.holdPedal=!0:(s.holdPedal=!1,s.sustainedVoices.forEach(i=>{this.releaseVoice(i)}),s.sustainedVoices=[]);break;default:if(s.lockedControllers[A])return;s.midiControllers[A]=e<<7,s.voices.forEach(i=>Ae(i,s.midiControllers,1,A));break}this.callEvent("controllerchange",{channel:t,controllerNumber:A,controllerValue:e})}function Os(t){this.midiVolume=t,this.setMasterPan(this.pan)}function Vs(t){this.masterGain=t*zt,this.setMasterPan(this.pan)}function Ks(t){this.pan=t,t=t/2+.5,this.panLeft=1-t,this.panRight=t}function Zs(t,A){A&&this.stopAll(t,!0),this.workletProcessorChannels[t].isMuted=A,this.sendChannelProperties(),this.callEvent("mutechannel",{channel:t,isMuted:A})}function Ws(t){this.workletProcessorChannels[t].lockGSNRPNParams=!0,this.workletProcessorChannels[t].channelVibrato.rate=0,this.workletProcessorChannels[t].channelVibrato.delay=0,this.workletProcessorChannels[t].channelVibrato.depth=0}function Xs(t,A,e,n){this.workletProcessorChannels[t].lockGSNRPNParams||(this.workletProcessorChannels[t].channelVibrato.rate=e,this.workletProcessorChannels[t].channelVibrato.delay=n,this.workletProcessorChannels[t].channelVibrato.depth=A)}function _s(t,A){let e=this.workletProcessorChannels[t],n=()=>{e.channelVibrato.delay===0&&e.channelVibrato.rate===0&&e.channelVibrato.depth===0&&(e.channelVibrato.depth=50,e.channelVibrato.rate=8,e.channelVibrato.delay=.6)};switch(e.dataEntryState){default:case wA.Idle:break;case wA.NRPFine:if(this.system!=="gs"||e.lockGSNRPNParams)return;switch(e.NRPCoarse){default:if(A===64)return;T(`%cUnrecognized NRPN for %c${t}%c: %c(0x${e.NRPCoarse.toString(16).toUpperCase()} 0x${e.NRPFine.toString(16).toUpperCase()})%c data value: %c${A}`,g.warn,g.recognized,g.warn,g.unrecognized,g.warn,g.value);break;case 1:switch(e.NRPFine){default:if(A===64)return;T(`%cUnrecognized NRPN for %c${t}%c: %c(0x${e.NRPCoarse.toString(16)} 0x${e.NRPFine.toString(16)})%c data value: %c${A}`,g.warn,g.recognized,g.warn,g.unrecognized,g.warn,g.value);break;case 8:if(A===64)return;n(),e.channelVibrato.rate=A/64*8,p(`%cVibrato rate for %c${t}%c is now set to %c${A} = ${e.channelVibrato.rate}%cHz.`,g.info,g.recognized,g.info,g.value,g.info);break;case 9:if(A===64)return;n(),e.channelVibrato.depth=A/2,p(`%cVibrato depth for %c${t}%c is now set to %c${A} = ${e.channelVibrato.depth}%c cents range of detune.`,g.info,g.recognized,g.info,g.value,g.info);break;case 10:if(A===64)return;n(),e.channelVibrato.delay=A/64/3,p(`%cVibrato delay for %c${t}%c is now set to %c${A} = ${e.channelVibrato.delay}%c seconds.`,g.info,g.recognized,g.info,g.value,g.info);break;case 32:let o=A;this.controllerChange(t,k.brightness,A),p(`%cFilter cutoff for %c${t}%c is now set to %c${o}`,g.info,g.recognized,g.info,g.value)}break;case 29:let s=A;this.controllerChange(t,k.reverbDepth,s),p(`%cGS Drum reverb for %c${t}%c: %c${s}`,g.info,g.recognized,g.info,g.value);break}break;case wA.RPCoarse:case wA.RPFine:switch(e.RPValue){default:T(`%cUnrecognized RPN for %c${t}%c: %c(0x${e.RPValue.toString(16)})%c data value: %c${A}`,g.warn,g.recognized,g.warn,g.unrecognized,g.warn,g.value);break;case 0:e.midiControllers[dA+q.pitchWheelRange]=A<<7,p(`%cChannel ${t} bend range. Semitones: %c${A}`,g.info,g.value);break;case 2:this.setChannelTuningSemitones(t,A-64);break;case 1:this.setChannelTuning(t,A-64,!1);break;case 5:this.setModulationDepth(t,A*100);break;case 16383:this.resetParameters(t);break}}}function zs(t,A){let e=this.workletProcessorChannels[t];switch(e.dataEntryState){default:break;case wA.RPCoarse:case wA.RPFine:switch(e.RPValue){default:break;case 0:if(A===0)break;e.midiControllers[dA+q.pitchWheelRange]|=A;let n=(e.midiControllers[dA+q.pitchWheelRange]>>7)+A/127;p(`%cChannel ${t} bend range. Semitones: %c${n}`,g.info,g.value);break;case 1:let o=e.customControllers[hA.channelTuning]<<7|A;this.setChannelTuning(t,o*.01220703125);break;case 5:let a=e.customControllers[hA.modulationMultiplier]*50+A/128*100;this.setModulationDepth(t,a);break;case 16383:this.resetParameters(t);break}}}function js(t=!0){t&&p("%cResetting all controllers!",g.info),this.callEvent("allcontrollerreset",void 0);for(let A=0;A<this.workletProcessorChannels.length;A++){this.resetControllers(A);let e=this.workletProcessorChannels[A];e.lockPreset?this.callEvent("drumchange",{channel:A,isDrumChannel:e.drumChannel}):(e.presetUsesOverride=!0,ne(e,0),A%16===GA?(this.setPreset(A,this.drumPreset),e.drumChannel=!0,this.callEvent("drumchange",{channel:A,isDrumChannel:!0})):(e.drumChannel=!1,this.setPreset(A,this.defaultPreset),this.callEvent("drumchange",{channel:A,isDrumChannel:!1}))),this.callEvent("programchange",{channel:A,program:e.preset.program,bank:XA(e),userCalled:!1});for(let n=0;n<128;n++)this.workletProcessorChannels[A].lockedControllers[n]&&this.callEvent("controllerchange",{channel:A,controllerNumber:n,controllerValue:this.workletProcessorChannels[A].midiControllers[n]>>7});if(this.workletProcessorChannels[A].lockedControllers[dA+q.pitchWheel]===!1){let n=this.workletProcessorChannels[A].midiControllers[dA+q.pitchWheel],s=n>>7,o=n&127;this.callEvent("pitchwheel",{channel:A,MSB:s,LSB:o})}}this.tunings=[],this.tunings=[];for(let A=0;127>A;A++)this.tunings.push([]);this.setMIDIVolume(1),this.system=et}function $s(t){let A=this.workletProcessorChannels[t],e=A.lockedControllers.reduce((s,o,i)=>(o&&s.push(i),s),[]);A.channelOctaveTuning.fill(0),A.keyCentTuning.fill(0);for(let s=0;s<ye.length;s++){if(A.lockedControllers[s])return;let o=ye[s];A.midiControllers[s]!==o&&s<127&&this.callEvent("controllerchange",{channel:t,controllerNumber:s,controllerValue:o>>7}),A.midiControllers[s]=o}A.channelVibrato={rate:0,depth:0,delay:0},A.holdPedal=!1;let n=A.customControllers[hA.channelTransposeFine];A.customControllers.set(Pt),A.customControllers[hA.channelTransposeFine]=n,this.resetParameters(t)}function Ao(t){let A=this.workletProcessorChannels[t];A.NRPCoarse=0,A.NRPFine=0,A.RPValue=0,A.dataEntryState=wA.Idle}function eo(){let t=4;for(let n of this.instruments)t+=n.instrumentZones.reduce((s,o)=>(o.generators=o.generators.filter(i=>i.generatorType!==r.sampleID&&i.generatorType!==r.keyRange&&i.generatorType!==r.velRange),(o.velRange.max!==127||o.velRange.min!==0)&&o.generators.unshift({generatorType:r.velRange,generatorValue:o.velRange.max<<8|Math.max(o.velRange.min,0)}),(o.keyRange.max!==127||o.keyRange.min!==0)&&o.generators.unshift({generatorType:r.keyRange,generatorValue:o.keyRange.max<<8|Math.max(o.keyRange.min,0)}),o.isGlobal||o.generators.push({generatorType:r.sampleID,generatorValue:this.samples.indexOf(o.sample)}),o.generators.length*4+s),0);let A=new b(t),e=0;for(let n of this.instruments)for(let s of n.instrumentZones){s.generatorZoneStartIndex=e;for(let o of s.generators)L(A,o.generatorType),L(A,o.generatorValue),e++}return K(A,0),gA(new oA("igen",A.length,A))}function to(t,A,e,n,s){let o=this.samples.map((B,d)=>{e&&B.compressSample(n,s);let Q=B.getRawData();return p(`%cEncoded sample %c${d}. ${B.sampleName}%c of %c${this.samples.length}%c. Compressed: %c${B.isCompressed}%c.`,g.info,g.recognized,g.info,g.recognized,g.info,B.isCompressed?g.recognized:g.unrecognized,g.info),Q}),i=this.samples.reduce((B,d,Q)=>B+o[Q].length+46,0),a=new b(i);this.samples.forEach((B,d)=>{let Q=o[d],l,c,f=Q.length;B.isCompressed?(l=a.currentIndex,c=l+Q.length):(l=a.currentIndex/2,c=l+Q.length/2,f+=46),t.push(l),a.set(Q,a.currentIndex),a.currentIndex+=f,A.push(c)});let C=gA(new oA("smpl",a.length,a),new b([115,100,116,97]));return gA(new oA("LIST",C.length,C))}function no(t,A){let n=new b(46*(this.samples.length+1));return this.samples.forEach((s,o)=>{yA(n,s.sampleName,20);let i=t[o];K(n,i);let a=A[o];K(n,a);let C=s.sampleLoopStartIndex+i,B=s.sampleLoopEndIndex+i;s.isCompressed&&(C-=i,B-=i),K(n,C),K(n,B),K(n,s.sampleRate),n[n.currentIndex++]=s.samplePitch,n[n.currentIndex++]=s.samplePitchCorrection,L(n,s.sampleLink),L(n,s.sampleType)}),yA(n,"EOS",46),gA(new oA("shdr",n.length,n))}function so(){let t=10;for(let n of this.instruments)t+=n.instrumentZones.reduce((s,o)=>o.modulators.length*10+s,0);let A=new b(t),e=0;for(let n of this.instruments)for(let s of n.instrumentZones){s.modulatorZoneStartIndex=e;for(let o of s.modulators)L(A,o.sourceEnum),L(A,o.modulatorDestination),L(A,o.transformAmount),L(A,o.secondarySourceEnum),L(A,o.transformType),e++}return De(A,0,10),gA(new oA("imod",A.length,A))}function oo(){let t=this.instruments.reduce((o,i)=>i.instrumentZones.length*4+o,4),A=new b(t),e=0,n=0,s=0;for(let o of this.instruments){o.instrumentZoneIndex=e;for(let i of o.instrumentZones)i.zoneID=e,L(A,n),L(A,s),n+=i.generators.length,s+=i.modulators.length,e++}return L(A,n),L(A,s),gA(new oA("ibag",A.length,A))}function ro(){let t=this.instruments.length*22+22,A=new b(t),e=0,n=0;for(let s of this.instruments)yA(A,s.instrumentName,20),L(A,e),e+=s.instrumentZones.length,s.instrumentID=n,n++;return yA(A,"EOI",20),L(A,e),gA(new oA("inst",A.length,A))}function io(){let t=4;for(let n of this.presets)t+=n.presetZones.reduce((s,o)=>(o.generators=o.generators.filter(i=>i.generatorType!==r.instrument&&i.generatorType!==r.keyRange&&i.generatorType!==r.velRange),(o.velRange.max!==127||o.velRange.min!==0)&&o.generators.unshift({generatorType:r.velRange,generatorValue:o.velRange.max<<8|Math.max(o.velRange.min,0)}),(o.keyRange.max!==127||o.keyRange.min!==0)&&o.generators.unshift({generatorType:r.keyRange,generatorValue:o.keyRange.max<<8|Math.max(o.keyRange.min,0)}),o.isGlobal||o.generators.push({generatorType:r.instrument,generatorValue:this.instruments.indexOf(o.instrument)}),o.generators.length*4+s),0);let A=new b(t),e=0;for(let n of this.presets)for(let s of n.presetZones){s.generatorZoneStartIndex=e;for(let o of s.generators)L(A,o.generatorType),L(A,o.generatorValue);e+=s.generators.length}return L(A,0),L(A,0),gA(new oA("pgen",A.length,A))}function ao(){let t=10;for(let n of this.presets)t+=n.presetZones.reduce((s,o)=>o.modulators.length*10+s,0);let A=new b(t),e=0;for(let n of this.presets)for(let s of n.presetZones){s.modulatorZoneStartIndex=e;for(let o of s.modulators)L(A,o.sourceEnum),L(A,o.modulatorDestination),L(A,o.transformAmount),L(A,o.secondarySourceEnum),L(A,o.transformType),e++}return De(A,0,10),gA(new oA("pmod",A.length,A))}function go(){let t=this.presets.reduce((o,i)=>i.presetZones.length*4+o,4),A=new b(t),e=0,n=0,s=0;for(let o of this.presets){o.presetZoneStartIndex=e;for(let i of o.presetZones)i.zoneID=e,L(A,n),L(A,s),n+=i.generators.length,s+=i.modulators.length,e++}return L(A,n),L(A,s),gA(new oA("pbag",A.length,A))}function Io(){let t=this.presets.length*38+38,A=new b(t),e=0;for(let n of this.presets)yA(A,n.presetName,20),L(A,n.program),L(A,n.bank),L(A,e),K(A,n.library),K(A,n.genre),K(A,n.morphology),e+=n.presetZones.length;return yA(A,"EOP",20),L(A,0),L(A,0),L(A,e),K(A,0),K(A,0),K(A,0),gA(new oA("phdr",A.length,A))}var mr={compress:!1,compressionQuality:.5,compressionFunction:void 0};function Eo(t=mr){if(t.compress&&typeof t.compressionFunction!="function")throw new TypeError("No compression function supplied but compression enabled.");QA("%cSaving soundfont...",g.info),p(`%cCompression: %c${t?.compress||"false"}%c quality: %c${t?.compressionQuality||"none"}`,g.info,g.recognized,g.info,g.recognized),p("%cWriting INFO...",g.info);let A=[];this.soundFontInfo.ISFT="SpessaSynth",t?.compress&&(this.soundFontInfo.ifil="3.0");for(let[x,G]of Object.entries(this.soundFontInfo))if(x==="ifil"||x==="iver"){let I=parseInt(G.split(".")[0]),rA=parseInt(G.split(".")[1]),Z=new b(4);L(Z,I),L(Z,rA),A.push(gA(new oA(x,4,Z)))}else if(x==="DMOD")A.push(gA(new oA(x,G.length,G)));else{let I=new b(G.length);yA(I,G),A.push(gA(new oA(x,G.length,I)))}let e=cA([new b([73,78,70,79]),...A]),n=gA(new oA("LIST",e.length,e));p("%cWriting SDTA...",g.info);let s=[],o=[],i=to.call(this,s,o,t?.compress,t?.compressionQuality??.5,t.compressionFunction);p("%cWriting PDTA...",g.info),p("%cWriting SHDR...",g.info);let a=no.call(this,s,o);p("%cWriting IGEN...",g.info);let C=eo.call(this);p("%cWriting IMOD...",g.info);let B=so.call(this);p("%cWriting IBAG...",g.info);let d=oo.call(this);p("%cWriting INST...",g.info);let Q=ro.call(this),l=io.call(this);p("%cWriting PMOD...",g.info);let c=ao.call(this);p("%cWriting PBAG...",g.info);let f=go.call(this);p("%cWriting PHDR...",g.info);let y=Io.call(this),S=cA([new b([112,100,116,97]),y,f,c,l,Q,d,B,C,a]),w=gA(new oA("LIST",S.length,S));p("%cWriting the output file...",g.info);let H=cA([new b([115,102,98,107]),n,i,w]),R=gA(new oA("RIFF",H.length,H));return p(`%cSaved succesfully! Final file size: %c${R.length}`,g.info,g.recognized),V(),R}var Te=class{velRange={min:-1,max:127};keyRange={min:-1,max:127};isGlobal=!1;generators=[];modulators=[];get hasKeyRange(){return this.keyRange.min!==-1}get hasVelRange(){return this.velRange.min!==-1}getGeneratorValue(A,e){return this.generators.find(n=>n.generatorType===A)?.generatorValue??e}};var FA=class extends Te{sample=void 0;useCount=0;deleteZone(){this.useCount--,!this.isGlobal&&this.sample.useCount--}},oe=class extends Te{instrument=void 0;deleteZone(){this.isGlobal||this.instrument.removeUseCount()}};var pr=new Set([r.velRange,r.keyRange,r.instrument,r.exclusiveClass,r.endOper,r.sampleModes,r.startloopAddrsOffset,r.startloopAddrsCoarseOffset,r.endloopAddrsOffset,r.endloopAddrsCoarseOffset,r.startAddrsOffset,r.startAddrsCoarseOffset,r.endAddrOffset,r.endAddrsCoarseOffset,r.initialAttenuation,r.fineTune,r.coarseTune,r.keyNumToVolEnvHold,r.keyNumToVolEnvDecay,r.keyNumToModEnvHold,r.keyNumToModEnvDecay]);function Co(t,A=!0){function e(Q,l){Q.push(...l.filter(c=>!Q.find(f=>f.generatorType===c.generatorType)))}function n(Q,l){return{min:Math.max(Q.min,l.min),max:Math.min(Q.max,l.max)}}function s(Q,l){Q.push(...l.filter(c=>!Q.find(f=>P.isIdentical(c,f))))}let o=[],i=[],a=[],C={min:0,max:127},B={min:0,max:127},d=t.presetZones.find(Q=>Q.isGlobal);d&&(i.push(...d.generators),a.push(...d.modulators),C=d.keyRange,B=d.velRange);for(let Q of t.presetZones){if(Q.isGlobal)continue;let l=Q.keyRange;Q.hasKeyRange||(l=C);let c=Q.velRange;Q.hasVelRange||(c=B);let f=Q.generators.map(I=>new N(I.generatorType,I.generatorValue));e(f,i);let y=[...Q.modulators];s(y,a);let S=Q.instrument.instrumentZones,w=[],H=[],R={min:0,max:127},x={min:0,max:127},G=S.find(I=>I.isGlobal);G&&(w.push(...G.generators),H.push(...G.modulators),R=G.keyRange,x=G.velRange);for(let I of S){if(I.isGlobal)continue;let rA=I.keyRange;I.hasKeyRange||(rA=R);let Z=I.velRange;if(I.hasVelRange||(Z=x),rA=n(rA,l),Z=n(Z,c),rA.max<rA.min||Z.max<Z.min)continue;let AA=I.generators.map(eA=>new N(eA.generatorType,eA.generatorValue));e(AA,w);let $=[...I.modulators];s($,H);let IA=[...$];for(let eA of y){let lA=IA.findIndex(UA=>P.isIdentical(eA,UA));lA!==-1?IA[lA]=IA[lA].sumTransform(eA):IA.push(eA)}let sA=AA.map(eA=>new N(eA.generatorType,eA.generatorValue));for(let eA of f){if(eA.generatorType===r.velRange||eA.generatorType===r.keyRange||eA.generatorType===r.instrument||eA.generatorType===r.endOper||eA.generatorType===r.sampleModes)continue;let lA=AA.findIndex(UA=>UA.generatorType===eA.generatorType);if(lA!==-1){let UA=sA[lA].generatorValue+eA.generatorValue;sA[lA]=new N(eA.generatorType,UA)}else{let UA=J[eA.generatorType].def+eA.generatorValue;sA.push(new N(eA.generatorType,UA))}}sA=sA.filter(eA=>eA.generatorType!==r.sampleID&&eA.generatorType!==r.keyRange&&eA.generatorType!==r.velRange&&eA.generatorType!==r.endOper&&eA.generatorType!==r.instrument&&eA.generatorValue!==J[eA.generatorType].def);let iA=new FA;iA.keyRange=rA,iA.velRange=Z,iA.keyRange.min===0&&iA.keyRange.max===127&&(iA.keyRange.min=-1),iA.velRange.min===0&&iA.velRange.max===127&&(iA.velRange.min=-1),iA.isGlobal=!1,iA.sample=I.sample,iA.generators=sA,iA.modulators=IA,o.push(iA)}}if(A){let Q=new FA;Q.isGlobal=!0;for(let f=0;f<58;f++){if(pr.has(f))continue;let y={},S=J[f]?.def||0;y[S]=0;for(let w of o){let H=w.generators.find(G=>G.generatorType===f);if(H){let G=H.generatorValue;y[G]===void 0?y[G]=1:y[G]++}else y[S]++;let R;switch(f){default:continue;case r.decayVolEnv:R=r.keyNumToVolEnvDecay;break;case r.holdVolEnv:R=r.keyNumToVolEnvHold;break;case r.decayModEnv:R=r.keyNumToModEnvDecay;break;case r.holdModEnv:R=r.keyNumToModEnvHold}if(w.generators.find(G=>G.generatorType===R)!==void 0){y={};break}}if(Object.keys(y).length>0){let w=Object.entries(y).reduce((R,x)=>R[1]<x[1]?x:R,[0,0]),H=parseInt(w[0]);H!==S&&Q.generators.push(new N(f,H)),o.forEach(R=>{let x=R.generators.findIndex(G=>G.generatorType===f);x!==-1?R.generators[x].generatorValue===H&&R.generators.splice(x,1):H!==S&&R.generators.push(new N(f,S))})}}let c=o.find(f=>!f.isGlobal).modulators.map(f=>P.copy(f));for(let f of c){let y=!0;for(let S of o){if(S.isGlobal||!y)continue;S.modulators.find(H=>P.isIdentical(H,f))||(y=!1)}if(y===!0){Q.modulators.push(P.copy(f));for(let S of o){let w=S.modulators.find(H=>P.isIdentical(H,f));w.transformAmount===f.transformAmount&&S.modulators.splice(S.modulators.indexOf(w),1)}}}o.splice(0,0,Q)}return o}var Bo=20;function gt(t,A,e,n,s,o,i){let a=i===0?0:1,C=new b(Bo+a*16);K(C,Bo),L(C,A),L(C,e);let B=n*.4,d=Math.floor(B*-65536);K(C,d),K(C,2);let Q=o-s,l=0;switch(i){default:case 0:a=0;break;case 1:l=0,a=1;break;case 3:l=1,a=1}return K(C,a),a===1&&(K(C,16),K(C,l),K(C,s),K(C,Q)),tA("wsmp",C)}var v={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:219,reverb:221,pitchWheelRange:256,fineTune:257,coarseTune:258},It=new P({srcEnum:219,dest:r.reverbEffectsSend,amt:1e3,secSrcEnum:0,transform:0}),Et=new P({srcEnum:221,dest:r.chorusEffectsSend,amt:1e3,secSrcEnum:0,transform:0}),Ct=new P({srcEnum:129,dest:r.vibLfoToPitch,amt:0,secSrcEnum:0,transform:0}),Bt=new P({srcEnum:13,dest:r.vibLfoToPitch,amt:0,secSrcEnum:0,transform:0});var D={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,volEnvRelease:521,volEnvSustain:522,volEnvDelay:523,volEnvHold:524,modEnvAttack:778,modEnvDecay:779,modEnvRelease:781,modEnvSustain:782,modEnvDelay:783,modEnvHold:784,filterCutoff:1280,filterQ:1281};var ve=class{source;control;destination;scale;transform;constructor(A,e,n,s,o){this.source=A,this.control=e,this.destination=n,this.scale=s,this.transform=o}writeArticulator(){let A=new b(12);return L(A,this.source),L(A,this.control),L(A,this.destination),L(A,this.transform),K(A,this.scale<<16),A}};function ho(t,A){if(t)switch(A){default:return;case k.modulationWheel:return v.modulationWheel;case k.mainVolume:return v.volume;case k.pan:return v.pan;case k.expressionController:return v.expression;case k.chorusDepth:return v.chorus;case k.reverbDepth:return v.reverb}else switch(A){default:return;case q.noteOnKeyNum:return v.keyNum;case q.noteOnVelocity:return v.velocity;case q.noController:return v.none;case q.polyPressure:return v.polyPressure;case q.channelPressure:return v.channelPressure;case q.pitchWheel:return v.pitchWheel;case q.pitchWheelRange:return v.pitchWheelRange}}function co(t,A){switch(t){default:return;case r.initialAttenuation:return{dest:D.gain,amount:-A};case r.fineTune:return D.pitch;case r.pan:return D.pan;case r.keyNum:return D.keyNum;case r.reverbEffectsSend:return D.reverbSend;case r.chorusEffectsSend:return D.chorusSend;case r.freqModLFO:return D.modLfoFreq;case r.delayModLFO:return D.modLfoDelay;case r.delayVibLFO:return D.vibLfoDelay;case r.freqVibLFO:return D.vibLfoFreq;case r.delayVolEnv:return D.volEnvDelay;case r.attackVolEnv:return D.volEnvAttack;case r.holdVolEnv:return D.volEnvHold;case r.decayVolEnv:return D.volEnvDecay;case r.sustainVolEnv:return{dest:D.volEnvSustain,amount:1e3-A};case r.releaseVolEnv:return D.volEnvRelease;case r.delayModEnv:return D.modEnvDelay;case r.attackModEnv:return D.modEnvAttack;case r.holdModEnv:return D.modEnvHold;case r.decayModEnv:return D.modEnvDecay;case r.sustainModEnv:return{dest:D.modEnvSustain,amount:1e3-A};case r.releaseModEnv:return D.modEnvRelease;case r.initialFilterFc:return D.filterCutoff;case r.initialFilterQ:return D.filterQ}}function lo(t,A){switch(t){default:return;case r.modEnvToFilterFc:return{source:v.modEnv,dest:D.filterCutoff,amt:A,isBipolar:!1};case r.modEnvToPitch:return{source:v.modEnv,dest:D.pitch,amt:A,isBipolar:!1};case r.modLfoToFilterFc:return{source:v.modLfo,dest:D.filterCutoff,amt:A,isBipolar:!0};case r.modLfoToVolume:return{source:v.modLfo,dest:D.gain,amt:A,isBipolar:!0};case r.modLfoToPitch:return{source:v.modLfo,dest:D.pitch,amt:A,isBipolar:!0};case r.vibLfoToPitch:return{source:v.vibratoLfo,dest:D.pitch,amt:A,isBipolar:!0};case r.keyNumToVolEnvHold:return{source:v.keyNum,dest:D.volEnvHold,amt:A,isBipolar:!0};case r.keyNumToVolEnvDecay:return{source:v.keyNum,dest:D.volEnvDecay,amt:A,isBipolar:!0};case r.keyNumToModEnvHold:return{source:v.keyNum,dest:D.modEnvHold,amt:A,isBipolar:!0};case r.keyNumToModEnvDecay:return{source:v.keyNum,dest:D.modEnvDecay,amt:A,isBipolar:!0};case r.scaleTuning:return{source:v.keyNum,dest:D.pitch,amt:A*128,isBipolar:!1}}}function Qo(t){let A=co(t.generatorType,t.generatorValue),e=A,n=0,s=t.generatorValue;A?.amount!==void 0&&(s=A.amount,e=A.dest);let o=lo(t.generatorType,t.generatorValue);if(o!==void 0)s=o.amt,e=o.dest,n=o.source;else if(e===void 0){T(`Invalid generator type: ${t.generatorType}`);return}return new ve(n,0,e,s,0)}function uo(t){if(t.transformType!==0){T("Other transform types are not supported.");return}let A=ho(t.sourceUsesCC,t.sourceIndex),e=t.sourceCurveType,n=t.sourcePolarity,s=t.sourceDirection;if(A===void 0){T(`Invalid source: ${t.sourceIndex}, CC: ${t.sourceUsesCC}`);return}t.modulatorDestination===r.initialAttenuation&&(s=s===1?0:1);let o=ho(t.secSrcUsesCC,t.secSrcIndex),i=t.secSrcCurveType,a=t.secSrcPolarity,C=t.secSrcDirection;if(o===void 0){T(`Invalid secondary source: ${t.secSrcIndex}, CC: ${t.secSrcUsesCC}`);return}let B=co(t.modulatorDestination,t.transformAmount),d=B,Q=t.transformAmount;B?.dest!==void 0&&(d=B.dest,Q=B.amount);let l=lo(t.modulatorDestination,t.transformAmount);if(l!==void 0)Q=l.amt,o=A,i=e,a=n,C=s,e=uA.linear,n=l.isBipolar?1:0,s=0,A=l.source,d=l.dest;else if(d===void 0){T(`Invalid destination: ${t.modulatorDestination}`);return}let c=0;return c|=i<<4,c|=a<<8,c|=C<<9,c|=e,c|=n<<14,c|=s<<15,new ve(A,o,d,Q,c)}var yr=new Set([r.sampleModes,r.initialAttenuation,r.keyRange,r.velRange,r.sampleID,r.fineTune,r.coarseTune,r.startAddrsOffset,r.startAddrsCoarseOffset,r.endAddrOffset,r.endAddrsCoarseOffset,r.startloopAddrsOffset,r.startloopAddrsCoarseOffset,r.endloopAddrsOffset,r.endloopAddrsCoarseOffset,r.overridingRootKey,r.exclusiveClass]);function ht(t){for(let o=0;o<t.generators.length;o++){let i=t.generators[o];(i.generatorType===r.delayVolEnv||i.generatorType===r.attackVolEnv||i.generatorType===r.holdVolEnv||i.generatorType===r.decayVolEnv||i.generatorType===r.releaseVolEnv||i.generatorType===r.delayModEnv||i.generatorType===r.attackModEnv||i.generatorType===r.holdModEnv||i.generatorType===r.decayModEnv)&&(t.generators[o]=new N(i.generatorType,Math.min(i.generatorValue,6386),!1))}for(let o=0;o<t.generators.length;o++){let i=t.generators[o],a;switch(i.generatorType){default:continue;case r.keyNumToVolEnvDecay:a=r.decayVolEnv;break;case r.keyNumToVolEnvHold:a=r.holdVolEnv;break;case r.keyNumToModEnvDecay:a=r.decayModEnv;break;case r.keyNumToModEnvHold:a=r.holdModEnv}let C=t.generators.find(f=>f.generatorType===a);if(C===void 0)continue;let B=i.generatorValue*-128,d=60/128*B,Q=C.generatorValue-d,l=t.generators.indexOf(i),c=t.generators.indexOf(C);t.generators[c]=new N(a,Q,!1),t.generators[l]=new N(i.generatorType,B,!1)}let A=t.generators.reduce((o,i)=>{if(yr.has(i.generatorType))return o;let a=Qo(i);return a!==void 0?(o.push(a),p("%cSucceeded converting to DLS Articulator!",g.recognized)):T("Failed converting to DLS Articulator!"),o},[]),e=t.modulators.reduce((o,i)=>{if(P.isIdentical(i,Et,!0)||P.isIdentical(i,It,!0)||P.isIdentical(i,Ct,!0)||P.isIdentical(i,Bt,!0))return o;let a=uo(i);return a!==void 0?(o.push(a),p("%cSucceeded converting to DLS Articulator!",g.recognized)):T("Failed converting to DLS Articulator!"),o},[]);A.push(...e);let n=new b(8);K(n,8),K(n,A.length);let s=A.map(o=>o.writeArticulator());return tA("art2",cA([n,...s]))}function fo(t,A){let e=new b(12);L(e,Math.max(t.keyRange.min,0)),L(e,t.keyRange.max),L(e,Math.max(t.velRange.min,0)),L(e,t.velRange.max),L(e,0);let n=t.getGeneratorValue(r.exclusiveClass,0);L(e,n),L(e,0);let s=tA("rgnh",e),o=t.getGeneratorValue(r.overridingRootKey,t.sample.samplePitch);t.getGeneratorValue(r.scaleTuning,A.getGeneratorValue(r.scaleTuning,100))===0&&t.keyRange.max-t.keyRange.min===0&&(o=t.keyRange.min);let a=gt(t.sample,o,t.getGeneratorValue(r.fineTune,0)+t.getGeneratorValue(r.coarseTune,0)*100+t.sample.samplePitchCorrection,t.getGeneratorValue(r.initialAttenuation,0),t.sample.sampleLoopStartIndex+t.getGeneratorValue(r.startloopAddrsOffset,0)+t.getGeneratorValue(r.startloopAddrsCoarseOffset,0)*32768,t.sample.sampleLoopEndIndex+t.getGeneratorValue(r.endloopAddrsOffset,0)+t.getGeneratorValue(r.endloopAddrsCoarseOffset,0)*32768,t.getGeneratorValue(r.sampleModes,0)),C=new b(12);L(C,0),L(C,0),K(C,1),K(C,this.samples.indexOf(t.sample));let B=tA("wlnk",C),d=new b(0);if(t.modulators.length+t.generators.length>0){let Q=ht(t);d=tA("lar2",Q,!1,!0)}return tA("rgn2",cA([s,a,B,d]),!1,!0)}function mo(t){QA(`%cWriting %c${t.presetName}%c...`,g.info,g.recognized,g.info);let A=Co(t),e=A.reduce((l,c)=>c.isGlobal?l:l+1,0),n=new b(12);K(n,e);let s=(t.bank&127)<<8;t.bank===128&&(s|=1<<31),K(n,s),K(n,t.program&127);let o=tA("insh",n),i=new b(0),a=A.find(l=>l.isGlobal===!0);if(a){let l=ht(a);i=tA("lar2",l,!1,!0)}let C=cA(A.reduce((l,c)=>(c.isGlobal||l.push(fo.apply(this,[c,a])),l),[])),B=tA("lrgn",C,!1,!0),d=tA("INAM",Be(t.presetName)),Q=tA("INFO",d,!1,!0);return V(),tA("ins ",cA([o,B,i,Q]),!1,!0)}function po(){let t=cA(this.presets.map(A=>mo.apply(this,[A])));return tA("lins",t,!1,!0)}function yo(t){let A=new b(18);L(A,1),L(A,1),K(A,t.sampleRate),K(A,t.sampleRate*2),L(A,2),L(A,16);let e=tA("fmt ",A),n=1;t.sampleLoopStartIndex+Math.abs(t.getAudioData().length-t.sampleLoopEndIndex)<2&&(n=0);let s=gt(t,t.samplePitch,t.samplePitchCorrection,0,t.sampleLoopStartIndex,t.sampleLoopEndIndex,n),o=t.getAudioData(),i;if(t.isCompressed){let B=new Int16Array(o.length);for(let d=0;d<o.length;d++)B[d]=o[d]*32768;i=tA("data",new b(B.buffer))}else i=tA("data",t.getRawData());let a=tA("INAM",Be(t.sampleName)),C=tA("INFO",a,!1,!0);return p(`%cSaved %c${t.sampleName}%c succesfully!`,g.recognized,g.value,g.recognized),tA("wave",cA([e,s,i,C]),!1,!0)}function So(){let t=0,A=[],e=this.samples.map(n=>{let s=yo(n);return A.push(t),t+=s.length,s});return{data:tA("wvpl",cA(e),!1,!0),indexes:A}}function Do(){QA("%cSaving DLS...",g.info);let t=new b(4);K(t,this.presets.length);let A=tA("colh",t);QA("%cWriting instruments...",g.info);let e=po.apply(this);p("%cSuccess!",g.recognized),V(),QA("%cWriting WAVE samples...",g.info);let n=So.apply(this),s=n.data,o=n.indexes;p("%cSucceeded!",g.recognized),V();let i=new b(8+4*o.length);K(i,8),K(i,o.length);for(let Q of o)K(i,Q);let a=tA("ptbl",i);this.soundFontInfo.ICMT=(this.soundFontInfo.ICMT||"Soundfont")+`
|
|
15
|
-
Converted from SF2 to DLS using SpessaSynth`,this.soundFontInfo.ISFT="SpessaSynth";let C=[];for(let[Q,l]of Object.entries(this.soundFontInfo))Q!=="ICMT"&&Q!=="INAM"&&Q!=="ICRD"&&Q!=="IENG"&&Q!=="ICOP"&&Q!=="ISFT"&&Q!=="ISBJ"||C.push(tA(Q,Be(l),!0));let B=tA("INFO",cA(C),!1,!0),d=new b(A.length+e.length+a.length+s.length+B.length+4);return yA(d,"DLS "),d.set(cA([A,e,a,s,B]),4),p("%cSaved succesfully!",g.recognized),V(),tA("RIFF",d)}var Sr=48e3,re=class{constructor(A,e,n,s,o,i,a,C){this.sampleName=A,this.sampleRate=e,this.samplePitch=n,this.samplePitchCorrection=s,this.sampleLink=o,this.sampleType=i,this.sampleLoopStartIndex=a,this.sampleLoopEndIndex=C,this.isCompressed=(i&16)>0,this.compressedData=void 0,this.useCount=0,this.sampleData=void 0}getRawData(){let A=new Uint8Array(this.sampleData.length*2);for(let e=0;e<this.sampleData.length;e++){let n=Math.floor(this.sampleData[e]*32768);A[e*2]=n&255,A[e*2+1]=n>>8&255}return A}resampleData(A){let e=this.getAudioData(),n=A/this.sampleRate,s=new Float32Array(Math.floor(e.length*n));for(let o=0;o<s.length;o++)s[o]=e[Math.floor(o*(1/n))];e=s,this.sampleRate=A,this.sampleLoopStartIndex=Math.floor(this.sampleLoopStartIndex*n),this.sampleLoopEndIndex=Math.floor(this.sampleLoopEndIndex*n),this.sampleData=e}compressSample(A,e){if(!this.isCompressed)try{let n=this.getAudioData();(this.sampleRate<8e3||this.sampleRate>96e3)&&(this.resampleData(Sr),n=this.getAudioData()),this.compressedData=e([n],1,this.sampleRate,A),this.sampleType|=16,this.isCompressed=!0}catch{T(`Failed to compress ${this.sampleName}. Leaving as uncompressed!`),this.isCompressed=!1,this.compressedData=void 0,this.sampleType&=239}}getAudioData(){return this.sampleData}};var ie=class{constructor(){this.instrumentName="",this.instrumentZones=[],this._useCount=0}get useCount(){return this._useCount}addUseCount(){this._useCount++,this.instrumentZones.forEach(A=>A.useCount++)}removeUseCount(){this._useCount--;for(let A=0;A<this.instrumentZones.length;A++)this.safeDeleteZone(A)&&A--}deleteInstrument(){this.instrumentZones.forEach(A=>A.deleteZone()),this.instrumentZones.length=0}safeDeleteZone(A){return this.instrumentZones[A].useCount--,this.instrumentZones[A].useCount<1?(this.deleteZone(A),!0):!1}deleteZone(A){this.instrumentZones[A].deleteZone(),this.instrumentZones.splice(A,1)}};var ae=class{constructor(A){this.presetName="",this.program=0,this.bank=0,this.presetZones=[],this.sampleIDOffset=0,this.foundSamplesAndGenerators=[];for(let e=0;e<128;e++)this.foundSamplesAndGenerators[e]=[];this.library=0,this.genre=0,this.morphology=0,this.defaultModulators=A}deletePreset(){this.presetZones.forEach(A=>A.deleteZone()),this.presetZones.length=0}deleteZone(A){this.presetZones[A].deleteZone(),this.presetZones.splice(A,1)}preload(A,e){for(let n=A;n<e+1;n++)for(let s=0;s<128;s++)this.getSamplesAndGenerators(n,s).forEach(o=>{o.sample.isSampleLoaded||o.sample.getAudioData()})}preloadSpecific(A,e){this.getSamplesAndGenerators(A,e).forEach(n=>{n.sample.isSampleLoaded||n.sample.getAudioData()})}getSamplesAndGenerators(A,e){let n=this.foundSamplesAndGenerators[A][e];if(n)return n;if(this.presetZones.length<1)return[];function s(c,f){return f>=c.min&&f<=c.max}function o(c,f){c.push(...f.filter(y=>!c.find(S=>S.generatorType===y.generatorType)))}function i(c,f){c.push(...f.filter(y=>!c.find(S=>P.isIdentical(y,S))))}let a=[],C=this.presetZones[0].isGlobal?[...this.presetZones[0].generators]:[],B=this.presetZones[0].isGlobal?[...this.presetZones[0].modulators]:[],d=this.presetZones[0].isGlobal?this.presetZones[0].keyRange:{min:0,max:127},Q=this.presetZones[0].isGlobal?this.presetZones[0].velRange:{min:0,max:127};return this.presetZones.filter(c=>s(c.hasKeyRange?c.keyRange:d,A)&&s(c.hasVelRange?c.velRange:Q,e)&&!c.isGlobal).forEach(c=>{if(c.instrument.instrumentZones.length<1)return;let f=c.generators,y=c.modulators,S=c.instrument.instrumentZones[0],w=S.isGlobal?[...S.generators]:[],H=S.isGlobal?[...S.modulators]:[],R=S.isGlobal?S.keyRange:{min:0,max:127},x=S.isGlobal?S.velRange:{min:0,max:127};c.instrument.instrumentZones.filter(I=>s(I.hasKeyRange?I.keyRange:R,A)&&s(I.hasVelRange?I.velRange:x,e)&&!I.isGlobal).forEach(I=>{let rA=[...I.generators],Z=[...I.modulators];o(f,C),o(rA,w),i(y,B),i(Z,H),i(Z,this.defaultModulators);let AA=[...Z];for(let $=0;$<y.length;$++){let IA=y[$],sA=AA.findIndex(iA=>P.isIdentical(IA,iA));sA!==-1?AA[sA]=AA[sA].sumTransform(IA):AA.push(IA)}a.push({instrumentGenerators:rA,presetGenerators:f,modulators:AA,sample:I.sample,sampleID:I.generators.find($=>$.generatorType===r.sampleID).generatorValue})})}),this.foundSamplesAndGenerators[A][e]=a,a}};var ge=class t{constructor(A=void 0){this.soundFontInfo={},this.presets=[],this.samples=[],this.instruments=[],this.defaultModulators=_e.map(e=>P.copy(e)),A?.presets&&(this.presets.push(...A.presets),this.soundFontInfo=A.info)}static mergeSoundfonts(...A){let e=A.shift(),n=e.presets;for(;A.length;)A.shift().presets.forEach(o=>{n.find(i=>i.bank===o.bank&&i.program===o.program)===void 0&&n.push(o)});return new t({presets:n,info:e.soundFontInfo})}static getDummySoundfontFile(){let A=new t,e=new re("Saw",44100,65,20,0,0,0,127);e.sampleData=new Float32Array(128);for(let B=0;B<128;B++)e.sampleData[B]=B/128*2-1;A.samples.push(e);let n=new FA;n.isGlobal=!0,n.generators.push(new N(r.initialAttenuation,375)),n.generators.push(new N(r.releaseVolEnv,-1e3)),n.generators.push(new N(r.sampleModes,1));let s=new FA;s.sample=e;let o=new FA;o.sample=e,o.generators.push(new N(r.fineTune,-9));let i=new ie;i.instrumentName="Saw Wave",i.instrumentZones.push(n),i.instrumentZones.push(s),i.instrumentZones.push(o),A.instruments.push(i);let a=new oe;a.instrument=i;let C=new ae(A.defaultModulators);return C.presetName="Saw Wave",C.presetZones.push(a),A.presets.push(C),A.soundFontInfo.ifil="2.1",A.soundFontInfo.isng="EMU8000",A.soundFontInfo.INAM="Dummy",A.write().buffer}removeUnusedElements(){this.instruments.forEach(A=>{A.useCount<1&&A.instrumentZones.forEach(e=>{e.isGlobal||e.sample.useCount--})}),this.instruments=this.instruments.filter(A=>A.useCount>0),this.samples=this.samples.filter(A=>A.useCount>0)}deleteInstrument(A){if(A.useCount>0)throw new Error(`Cannot delete an instrument that has ${A.useCount} usages.`);this.instruments.splice(this.instruments.indexOf(A),1),A.deleteInstrument(),this.removeUnusedElements()}deletePreset(A){A.deletePreset(),this.presets.splice(this.presets.indexOf(A),1),this.removeUnusedElements()}deleteSample(A){if(A.useCount>0)throw new Error(`Cannot delete sample that has ${A.useCount} usages.`);this.samples.splice(this.samples.indexOf(A),1),this.removeUnusedElements()}setSampleIDOffset(A){this.presets.forEach(e=>e.sampleIDOffset=A)}getPresetNoFallback(A,e,n=!1){let s=this.presets.find(o=>o.bank===A&&o.program===e);if(s)return s;if(n!==!1)return A===128?this.presets.find(o=>o.bank===128):this.presets.find(o=>o.program===e)}getPreset(A,e){let n=this.presets.find(s=>s.bank===A&&s.program===e);return n||(A===128?(n=this.presets.find(s=>s.bank===128&&s.program===e),n||(n=this.presets.find(s=>s.bank===128))):n=this.presets.find(s=>s.program===e&&s.bank!==128),n&&T(`%cPreset ${A}.${e} not found. Replaced with %c${n.presetName} (${n.bank}.${n.program})`,g.warn,g.recognized)),n||(T(`Preset ${e} not found. Defaulting to`,this.presets[0].presetName),n=this.presets[0]),n}getPresetByName(A){let e=this.presets.find(n=>n.presetName===A);return e||(T("Preset not found. Defaulting to:",this.presets[0].presetName),e=this.presets[0]),e}parsingError(A){throw new Error(`SF parsing error: ${A} The file may be corrupted.`)}destroySoundfont(){delete this.presets,delete this.instruments,delete this.samples}};ge.prototype.write=Eo;ge.prototype.writeDLS=Do;function ko(t){QA("%cLoading instruments...",g.info);for(let A=0;A<this.instrumentAmount;A++)this.readDLSInstrument(z(t.chunkData));V()}var ct=class extends ae{constructor(A,e){super(_e),this.program=e&127,this.bank=A>>8&127,A>>31&&(this.bank=128),this.DLSInstrument=new ie,this.DLSInstrument.addUseCount();let s=new oe;s.instrument=this.DLSInstrument,this.presetZones=[s]}};function wo(t){this.verifyHeader(t,"LIST"),this.verifyText(_(t.chunkData,4),"ins ");let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(z(t.chunkData));let e=A.find(c=>c.header==="insh");if(!e)throw V(),new Error("No instrument header!");let n=F(e.chunkData,4),s=F(e.chunkData,4),o=F(e.chunkData,4),i=new ct(s,o),a="unnamedPreset",C=MA(A,"INFO");if(C){let c=z(C.chunkData);for(;c.header!=="INAM";)c=z(C.chunkData);a=_(c.chunkData,c.chunkData.length).trim()}i.presetName=a,i.DLSInstrument.instrumentName=a,Ce(`%cParsing %c"${a}"%c...`,g.info,g.recognized,g.info);let B=MA(A,"lrgn");if(!B)throw V(),new Error("No region list!");let d=new FA;d.isGlobal=!0;let Q=MA(A,"lart"),l=MA(A,"lar2");(l!==void 0||Q!==void 0)&&this.readLart(Q,l,d),d.generators=d.generators.filter(c=>c.generatorValue!==J[c.generatorType].def),d.modulators.find(c=>c.modulatorDestination===r.reverbEffectsSend)===void 0&&d.modulators.push(P.copy(It)),d.modulators.find(c=>c.modulatorDestination===r.chorusEffectsSend)===void 0&&d.modulators.push(P.copy(Et)),i.DLSInstrument.instrumentZones.push(d);for(let c=0;c<n;c++){let f=z(B.chunkData);this.verifyHeader(f,"LIST");let y=_(f.chunkData,4);y!=="rgn "&&y!=="rgn2"&&(V(),this.parsingError(`Invalid DLS region! Expected "rgn " or "rgn2" got "${y}"`));let S=this.readRegion(f);S&&i.DLSInstrument.instrumentZones.push(S)}this.presets.push(i),this.instruments.push(i.DLSInstrument),V()}function Fo(t){let A,e=!1;switch(t){default:case v.modLfo:case v.vibratoLfo:case v.coarseTune:case v.fineTune:case v.modEnv:return;case v.keyNum:A=q.noteOnKeyNum;break;case v.none:A=q.noController;break;case v.modulationWheel:A=k.modulationWheel,e=!0;break;case v.pan:A=k.pan,e=!0;break;case v.reverb:A=k.reverbDepth,e=!0;break;case v.chorus:A=k.chorusDepth,e=!0;break;case v.expression:A=k.expressionController,e=!0;break;case v.volume:A=k.mainVolume,e=!0;break;case v.velocity:A=q.noteOnVelocity;break;case v.polyPressure:A=q.polyPressure;break;case v.channelPressure:A=q.channelPressure;break;case v.pitchWheel:A=q.pitchWheel;break;case v.pitchWheelRange:A=q.pitchWheelRange;break}if(A===void 0)throw new Error(`Unknown DLS Source: ${t}`);return{enum:A,isCC:e}}function Dr(t,A){switch(t){default:case D.none:return;case D.pan:return r.pan;case D.gain:return{gen:r.initialAttenuation,newAmount:A*-1};case D.pitch:return r.fineTune;case D.keyNum:return r.overridingRootKey;case D.volEnvDelay:return r.delayVolEnv;case D.volEnvAttack:return r.attackVolEnv;case D.volEnvHold:return r.holdVolEnv;case D.volEnvDecay:return r.decayVolEnv;case D.volEnvSustain:return{gen:r.sustainVolEnv,newAmount:1e3-A};case D.volEnvRelease:return r.releaseVolEnv;case D.modEnvDelay:return r.delayModEnv;case D.modEnvAttack:return r.attackModEnv;case D.modEnvHold:return r.holdModEnv;case D.modEnvDecay:return r.decayModEnv;case D.modEnvSustain:return{gen:r.sustainModEnv,newAmount:(1e3-A)/10};case D.modEnvRelease:return r.releaseModEnv;case D.filterCutoff:return r.initialFilterFc;case D.filterQ:return r.initialFilterQ;case D.chorusSend:return r.chorusEffectsSend;case D.reverbSend:return r.reverbEffectsSend;case D.modLfoFreq:return r.freqModLFO;case D.modLfoDelay:return r.delayModLFO;case D.vibLfoFreq:return r.freqVibLFO;case D.vibLfoDelay:return r.delayVibLFO}}function kr(t,A){return t===v.vibratoLfo&&A===D.pitch?r.vibLfoToPitch:t===v.modLfo&&A===D.pitch?r.modLfoToPitch:t===v.modLfo&&A===D.filterCutoff?r.modLfoToFilterFc:t===v.modLfo&&A===D.gain?r.modLfoToVolume:t===v.modEnv&&A===D.filterCutoff?r.modEnvToFilterFc:t===v.modEnv&&A===D.pitch?r.modEnvToPitch:void 0}function Ro(t,A,e,n,s){let o=kr(t,e),i,a,C=!1,B=!1,d=s;if(o===void 0){let w=Dr(e,s);if(w===void 0){T(`Invalid destination: ${e}`);return}if(i=w,w.newAmount!==void 0&&(d=w.newAmount,i=w.gen),a=Fo(t),a===void 0){T(`Invalid source: ${t}`);return}}else i=o,C=!0,a={enum:q.noController,isCC:!1},B=!0;let Q=Fo(A);if(Q===void 0){T(`Invalid control: ${A}`);return}let l;if(B)l=0;else{let w=n&15,H=n>>10&15;H===uA.linear&&w!==uA.linear&&(H=w);let R=n>>14&1,x=n>>15&1;i===r.initialAttenuation&&s<0&&(x=1),l=VA(H,R,x,a.isCC,a.enum)}let c=n>>4&15,f=n>>8&1,y=n>>9&1,S=VA(c,f,y,Q.isCC,Q.enum);if(C){let w=S;S=l,l=w}return new P({srcEnum:l,secSrcEnum:S,dest:i,transform:0,amt:d})}function jt(t,A){let e=t.chunkData,n=[],s=[];F(e,4);let o=F(e,4);for(let i=0;i<o;i++){let a=F(e,2),C=F(e,2),B=F(e,2),d=F(e,2),l=(F(e,4)|0)>>16;if(a===0&&C===0&&d===0){let c;switch(B){case D.pan:c=new N(r.pan,l);break;case D.gain:c=new N(r.initialAttenuation,-l*10/.4);break;case D.filterCutoff:c=new N(r.initialFilterFc,l);break;case D.filterQ:c=new N(r.initialFilterQ,l);break;case D.modLfoFreq:c=new N(r.freqModLFO,l);break;case D.modLfoDelay:c=new N(r.delayModLFO,l);break;case D.vibLfoFreq:c=new N(r.freqVibLFO,l);break;case D.vibLfoDelay:c=new N(r.delayVibLFO,l);break;case D.volEnvDelay:c=new N(r.delayVolEnv,l);break;case D.volEnvAttack:c=new N(r.attackVolEnv,l);break;case D.volEnvHold:c=new N(r.holdVolEnv,l,!1);break;case D.volEnvDecay:c=new N(r.decayVolEnv,l,!1);break;case D.volEnvRelease:c=new N(r.releaseVolEnv,l);break;case D.volEnvSustain:let f=1e3-l;c=new N(r.sustainVolEnv,f);break;case D.modEnvDelay:c=new N(r.delayModEnv,l);break;case D.modEnvAttack:c=new N(r.attackModEnv,l);break;case D.modEnvHold:c=new N(r.holdModEnv,l,!1);break;case D.modEnvDecay:c=new N(r.decayModEnv,l,!1);break;case D.modEnvRelease:c=new N(r.releaseModEnv,l);break;case D.modEnvSustain:let y=1e3-l;c=new N(r.sustainModEnv,y);break;case D.reverbSend:c=new N(r.reverbEffectsSend,l);break;case D.chorusSend:c=new N(r.chorusEffectsSend,l);break;case D.pitch:let S=Math.floor(l/100),w=Math.floor(l-S*100);c=new N(r.fineTune,w),n.push(new N(r.coarseTune,S));break}c&&n.push(c)}else{let c=!0;if(C===v.none)if(a===v.modLfo&&B===D.pitch)n.push(new N(r.modLfoToPitch,l));else if(a===v.modLfo&&B===D.gain)n.push(new N(r.modLfoToVolume,l));else if(a===v.modLfo&&B===D.filterCutoff)n.push(new N(r.modLfoToFilterFc,l));else if(a===v.vibratoLfo&&B===D.pitch)n.push(new N(r.vibLfoToPitch,l));else if(a===v.modEnv&&B===D.pitch)n.push(new N(r.modEnvToPitch,l));else if(a===v.modEnv&&B===D.filterCutoff)n.push(new N(r.modEnvToFilterFc,l));else if(a===v.keyNum&&B===D.pitch)n.push(new N(r.scaleTuning,l/128));else if(a===v.keyNum&&B===D.volEnvHold){n.push(new N(r.keyNumToVolEnvHold,l/-128));let f=Math.round(60/128*l);n.forEach(y=>{y.generatorType===r.holdVolEnv&&(y.generatorValue+=f)})}else if(a===v.keyNum&&B===D.volEnvDecay){n.push(new N(r.keyNumToVolEnvDecay,l/-128));let f=Math.round(60/128*l);n.forEach(y=>{y.generatorType===r.decayVolEnv&&(y.generatorValue+=f)})}else if(a===v.keyNum&&B===D.modEnvHold){n.push(new N(r.keyNumToModEnvHold,l/-128));let f=Math.round(60/128*l);n.forEach(y=>{y.generatorType===r.holdModEnv&&(y.generatorValue+=f)})}else if(a===v.keyNum&&B===D.modEnvDecay){n.push(new N(r.keyNumToModEnvDecay,l/-128));let f=Math.round(60/128*l);n.forEach(y=>{y.generatorType===r.decayModEnv&&(y.generatorValue+=f)})}else c=!1;else c=!1;if(c===!1){let f=Ro(a,C,B,d,l);f?(s.push(f),p("%cSucceeded converting to SF2 Modulator!",g.recognized)):T("Failed converting to SF2 Modulator!")}}}return A&&s.push(P.copy(Ct),P.copy(Bt)),{modulators:s,generators:n}}function Go(t,A,e){if(t)for(;t.chunkData.currentIndex<t.chunkData.length;){let n=z(t.chunkData);this.verifyHeader(n,"art1");let s=jt(n,!0);e.generators.push(...s.generators),e.modulators.push(...s.modulators)}if(A)for(;A.chunkData.currentIndex<A.chunkData.length;){let n=z(A.chunkData);this.verifyHeader(n,"art2");let s=jt(n,!1);e.generators.push(...s.generators),e.modulators.push(...s.modulators)}}var lt=class extends FA{constructor(A,e){super(),this.keyRange=A,this.velRange=e,this.isGlobal=!0}setWavesample(A,e,n,s,o,i,a){e!==0&&this.generators.push(new N(r.sampleModes,e)),this.generators.push(new N(r.initialAttenuation,A)),this.isGlobal=!1,a-=o.samplePitchCorrection;let C=Math.trunc(a/100);C!==0&&this.generators.push(new N(r.coarseTune,C));let B=a-C*100;if(B!==0&&this.generators.push(new N(r.fineTune,B)),e!==0){let d=n.start-o.sampleLoopStartIndex,Q=n.end-o.sampleLoopEndIndex;if(d!==0){let l=d%32768;this.generators.push(new N(r.startloopAddrsOffset,l));let c=Math.trunc(d/32768);c!==0&&this.generators.push(new N(r.startloopAddrsCoarseOffset,c))}if(Q!==0){let l=Q%32768;this.generators.push(new N(r.endloopAddrsOffset,l));let c=Math.trunc(Q/32768);c!==0&&this.generators.push(new N(r.endloopAddrsCoarseOffset,c))}}s!==o.samplePitch&&this.generators.push(new N(r.overridingRootKey,s)),this.generators.push(new N(r.sampleID,i)),this.sample=o,o.useCount++}};function Mo(t){let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(z(t.chunkData));let e=A.find(Z=>Z.header==="rgnh"),n=F(e.chunkData,2),s=F(e.chunkData,2),o=F(e.chunkData,2),i=F(e.chunkData,2),a=new lt({min:n,max:s},{min:o,max:i});F(e.chunkData,2);let C=F(e.chunkData,2);C!==0&&a.generators.push(new N(r.exclusiveClass,C));let B=MA(A,"lart"),d=MA(A,"lar2");this.readLart(B,d,a),a.isGlobal=!1;let Q=A.find(Z=>Z.header==="wsmp");F(Q.chunkData,4);let l=F(Q.chunkData,2),c=se(Q.chunkData[Q.chunkData.currentIndex++],Q.chunkData[Q.chunkData.currentIndex++]),y=(F(Q.chunkData,4)|0)/-655360;F(Q.chunkData,4);let S=F(Q.chunkData,4),w,H={start:0,end:0};if(S===0)w=0;else{F(Q.chunkData,4),F(Q.chunkData,4)===0?w=1:w=3,H.start=F(Q.chunkData,4);let AA=F(Q.chunkData,4);H.end=H.start+AA}let R=A.find(Z=>Z.header==="wlnk");if(R===void 0)return;F(R.chunkData,2),F(R.chunkData,2),F(R.chunkData,4);let x=F(R.chunkData,4),G=this.samples[x];if(G===void 0)throw new Error("Invalid sample ID!");let rA=(y||G.sampleDbAttenuation)*10/.4;return a.setWavesample(rA,w,H,l,G,x,c),a}var Qt=class extends re{sampleDbAttenuation;sampleData;constructor(A,e,n,s,o,i,a,C){super(A,e,n,s,0,1,o,i),this.sampleData=a,this.sampleDbAttenuation=C}getAudioData(){return this.sampleData}getRawData(){if(this.isCompressed){if(!this.compressedData)throw new Error("Compressed but no data?? This shouldn't happen!!");return this.compressedData}return super.getRawData()}};var xo={PCM:1,ALAW:6};function wr(t,A){let e=Math.pow(2,A*8-1),n=Math.pow(2,A*8),s,o=!1;A===1?(s=255,o=!0):s=e;let i=t.size/A,a=new Float32Array(i);for(let C=0;C<a.length;C++){let B=F(t.chunkData,A);o?a[C]=B/s-.5:(B>=e&&(B-=n),a[C]=B/s)}return a}function Fr(t,A){let e=t.size/A,n=new Float32Array(e);for(let s=0;s<n.length;s++){let o=F(t.chunkData,A),i=o^85;i&=127;let a=i>>4,C=i&15;a>0&&(C+=16),C=(C<<4)+8,a>1&&(C=C<<a-1);let B=o>127?C:-C;n[s]=B/32678}return n}function No(t){QA("%cLoading Wave samples...",g.recognized);let A=0;for(;t.chunkData.currentIndex<t.chunkData.length;){let e=z(t.chunkData);this.verifyHeader(e,"LIST"),this.verifyText(_(e.chunkData,4),"wave");let n=[];for(;e.chunkData.currentIndex<e.chunkData.length;)n.push(z(e.chunkData));let s=n.find(G=>G.header==="fmt ");if(!s)throw new Error("No fmt chunk in the wave file!");let o=F(s.chunkData,2),i=F(s.chunkData,2);if(i!==1)throw new Error(`Only mono samples are supported. Fmt reports ${i} channels`);let a=F(s.chunkData,4);F(s.chunkData,4),F(s.chunkData,2);let B=F(s.chunkData,2)/8,d=!1,Q=n.find(G=>G.header==="data");Q||this.parsingError("No data chunk in the WAVE chunk!");let l;switch(o){default:d=!0,l=new Float32Array(Q.size/B);break;case xo.PCM:l=wr(Q,B);break;case xo.ALAW:l=Fr(Q,B);break}let c=MA(n,"INFO"),f=`Unnamed ${A}`;if(c){let G=z(c.chunkData);for(;G.header!=="INAM"&&c.chunkData.currentIndex<c.chunkData.length;)G=z(c.chunkData);G.header==="INAM"&&(f=_(G.chunkData,G.size).trim())}let y=60,S=0,w=0,H=l.length-1,R=0,x=n.find(G=>G.header==="wsmp");if(x){F(x.chunkData,4),y=F(x.chunkData,2),S=se(x.chunkData[x.chunkData.currentIndex++],x.chunkData[x.chunkData.currentIndex++]);let G=Math.trunc(S/100);if(y+=G,S-=G*100,R=(F(x.chunkData,4)|0)/-655360,F(x.chunkData,4),F(x.chunkData,4)===1){F(x.chunkData,8),w=F(x.chunkData,4);let Z=F(x.chunkData,4);H=w+Z}}else T("No wsmp chunk in wave... using sane defaults.");d&&console.error(`Failed to load '${f}': Unsupported format: (${o})`),this.samples.push(new Qt(f,a,y,S,w,H,l,R)),A++,p(`%cLoaded sample %c${f}`,g.info,g.recognized)}V()}var ee=class extends ge{constructor(A){super(),this.dataArray=new b(A),Ce("%cParsing DLS...",g.info),this.dataArray||(V(),this.parsingError("No data provided!"));let e=z(this.dataArray,!1);this.verifyHeader(e,"riff"),this.verifyText(_(this.dataArray,4).toLowerCase(),"dls ");let n=[];for(;this.dataArray.currentIndex<this.dataArray.length;)n.push(z(this.dataArray));this.soundFontInfo.ifil="2.1",this.soundFontInfo.isng="EMU8000",this.soundFontInfo.INAM="Unnamed DLS",this.soundFontInfo.IENG="Unknown",this.soundFontInfo.IPRD="SpessaSynth DLS",this.soundFontInfo.ICRD=new Date().toDateString();let s=MA(n,"INFO");if(s)for(;s.chunkData.currentIndex<s.chunkData.length;){let C=z(s.chunkData);this.soundFontInfo[C.header]=_(C.chunkData,C.size)}this.soundFontInfo.ICMT=this.soundFontInfo.ICMT||"(No description)",this.soundFontInfo.ISBJ&&(this.soundFontInfo.ICMT+=`
|
|
9
|
+
`}},qt=960,Kt=uA.concave;function OA(t,A,e,s,n){return t<<10|A<<9|e<<8|s<<7|n}var Br=[new P({srcEnum:OA(Kt,0,1,0,K.noteOnVelocity),dest:r.initialAttenuation,amt:qt,secSrcEnum:0,transform:0}),new P({srcEnum:129,dest:r.vibLfoToPitch,amt:50,secSrcEnum:0,transform:0}),new P({srcEnum:OA(Kt,0,1,1,k.mainVolume),dest:r.initialAttenuation,amt:qt,secSrcEnum:0,transform:0}),new P({srcEnum:13,dest:r.vibLfoToPitch,amt:50,secSrcEnum:0,transform:0}),new P({srcEnum:526,dest:r.fineTune,amt:12700,secSrcEnum:16,transform:0}),new P({srcEnum:650,dest:r.pan,amt:500,secSrcEnum:0,transform:0}),new P({srcEnum:OA(Kt,0,1,1,k.expressionController),dest:r.initialAttenuation,amt:qt,secSrcEnum:0,transform:0}),new P({srcEnum:219,dest:r.reverbEffectsSend,amt:200,secSrcEnum:0,transform:0}),new P({srcEnum:221,dest:r.chorusEffectsSend,amt:200,secSrcEnum:0,transform:0})],hr=[new P({srcEnum:OA(uA.linear,0,0,0,K.polyPressure),dest:r.vibLfoToPitch,amt:50,secSrcEnum:0,transform:0}),new P({srcEnum:OA(uA.linear,0,0,1,k.tremoloDepth),dest:r.modLfoToVolume,amt:24,secSrcEnum:0,transform:0}),new P({srcEnum:OA(uA.linear,1,0,1,k.releaseTime),dest:r.releaseVolEnv,amt:1200,secSrcEnum:0,transform:0}),new P({srcEnum:OA(uA.linear,1,0,1,k.brightness),dest:r.initialFilterFc,amt:6e3,secSrcEnum:0,transform:0}),new P({srcEnum:OA(uA.linear,1,0,1,k.timbreHarmonicContent),dest:r.initialFilterQ,amt:250,secSrcEnum:0,transform:0})],je=Br.concat(hr);var dA=128,$e=147,De=new Int16Array($e).fill(0),wA=(t,A)=>De[t]=A<<7;wA(k.mainVolume,100);wA(k.balance,64);wA(k.expressionController,127);wA(k.pan,64);wA(k.timbreHarmonicContent,64);wA(k.releaseTime,64);wA(k.attackTime,64);wA(k.brightness,64);wA(k.soundController6,64);wA(k.soundController7,64);wA(k.soundController8,64);wA(k.soundController9,64);wA(k.generalPurposeController6,64);wA(k.generalPurposeController8,64);wA(dA+K.pitchWheel,64);wA(dA+K.pitchWheelRange,2);var cA={channelTuning:0,channelTransposeFine:1,modulationMultiplier:2,masterTuning:3,channelTuningSemitones:4},Ot=Object.keys(cA).length,Vt=new Float32Array(Ot);Vt[cA.modulationMultiplier]=1;var FA={Idle:0,RPCoarse:1,RPFine:2,NRPCoarse:3,NRPFine:4,DataCoarse:5,DataFine:6};function Js(t=!1){let A={midiControllers:new Int16Array($e),lockedControllers:Array($e).fill(!1),customControllers:new Float32Array(Ot),NRPCoarse:0,NRPFine:0,RPValue:0,dataEntryState:FA.Idle,voices:[],sustainedVoices:[],cachedVoices:[],preset:this.defaultPreset,presetUsesOverride:!1,channelTransposeKeyShift:0,channelOctaveTuning:new Int8Array(12),keyCentTuning:new Int16Array(128),channelVibrato:{delay:0,depth:0,rate:0},velocityOverride:0,lockGSNRPNParams:!1,holdPedal:!1,isMuted:!1,drumChannel:!1,lockPreset:!1};for(let e=0;e<128;e++)A.cachedVoices.push([]);this.workletProcessorChannels.push(A),this.resetControllers(this.workletProcessorChannels.length-1),this.sendChannelProperties(),t&&this.callEvent("newchannel",void 0)}function ne(t,A){t.lockPreset||(t.bank=A)}function XA(t){return t.drumChannel?128:t.bank}var Zt={velocityOverride:128};var At={addMapping:0,deleteMapping:1,clearMappings:2},et=class{_keyMappings=[];handleMessage(A,e){switch(A){default:return;case At.addMapping:this.addMapping(...e);break;case At.clearMappings:this.clearMappings();break;case At.deleteMapping:this.deleteMapping(...e)}}addMapping(A,e,s){this._keyMappings[A]===void 0&&(this._keyMappings[A]=[]),this._keyMappings[A][e]=s}deleteMapping(A,e){this._keyMappings[A]?.[e]!==void 0&&(this._keyMappings[A][e]=void 0)}clearMappings(){this._keyMappings=[]}setMappings(A){this._keyMappings=A}getMappings(){return this._keyMappings}getVelocity(A,e){let s=this._keyMappings[A]?.[e];return s?s.velocity:-1}hasOverridePatch(A,e){let s=this._keyMappings[A]?.[e]?.patch?.bank;return s!==void 0&&s>=0}getPatch(A,e){let s=this._keyMappings[A]?.[e];if(s)return s.patch;throw new Error("No modifier.")}};var Ps="spessasynth-worklet-system",qs=350,xA=9,tt=16,st="gs";var bA={loadNewSongList:0,pause:1,stop:2,play:3,setTime:4,changeMIDIMessageSending:5,setPlaybackRate:6,setLoop:7,changeSong:8,getMIDI:9,setSkipToFirstNote:10,setPreservePlaybackState:11},LA={midiEvent:0,songChange:1,textEvent:2,timeChange:3,pause:4,getMIDI:5,midiError:6};function _A(t,A){let e=0;for(let s=8*(A-1);s>=0;s-=8)e|=t[t.currentIndex++]<<s;return e>>>0}function Ks(t,A){if(this.ignoreEvents)return;if(this.sendMIDIMessages&&t.messageStatusByte>=128){this.sendMIDIMessage([t.messageStatusByte,...t.messageData]);return}let e=Ue(t.messageStatusByte),s=this.midiPortChannelOffsets[this.midiPorts[A]]||0;switch(e.channel+=s,e.status){case R.noteOn:let n=t.messageData[1];if(n>0)this.synth.noteOn(e.channel,t.messageData[0],n),this.playingNotes.push({midiNote:t.messageData[0],channel:e.channel,velocity:n});else{this.synth.noteOff(e.channel,t.messageData[0]);let C=this.playingNotes.findIndex(h=>h.midiNote===t.messageData[0]&&h.channel===e.channel);C!==-1&&this.playingNotes.splice(C,1)}break;case R.noteOff:this.synth.noteOff(e.channel,t.messageData[0]);let o=this.playingNotes.findIndex(C=>C.midiNote===t.messageData[0]&&C.channel===e.channel);o!==-1&&this.playingNotes.splice(o,1);break;case R.pitchBend:this.synth.pitchWheel(e.channel,t.messageData[1],t.messageData[0]);break;case R.controllerChange:this.synth.controllerChange(e.channel,t.messageData[0],t.messageData[1]);break;case R.programChange:this.synth.programChange(e.channel,t.messageData[0]);break;case R.polyPressure:this.synth.polyPressure(e.channel,t.messageData[0],t.messageData[1]);break;case R.channelPressure:this.synth.channelPressure(e.channel,t.messageData[0]);break;case R.systemExclusive:this.synth.systemExclusive(t.messageData,s);break;case R.setTempo:this.oneTickToSeconds=60/(cr(t)*this.midiData.timeDivision),this.oneTickToSeconds===0&&(this.oneTickToSeconds=60/(120*this.midiData.timeDivision),T("invalid tempo! falling back to 120 BPM"));break;case R.timeSignature:case R.endOfTrack:case R.midiChannelPrefix:case R.songPosition:case R.activeSensing:case R.keySignature:case R.sequenceNumber:case R.sequenceSpecific:break;case R.text:case R.lyric:case R.copyright:case R.trackName:case R.marker:case R.cuePoint:case R.instrumentName:case R.programName:let i=-1;e.status===R.lyric&&(i=Math.min(this.midiData.lyricsTicks.indexOf(t.ticks)+1,this.midiData.lyrics.length-1));let a=e.status;this.midiData.isKaraokeFile&&(e.status===R.text||e.status===R.lyric)&&(i=Math.min(this.midiData.lyricsTicks.indexOf(t.ticks)+1,this.midiData.lyricsTicks.length),a=R.lyric),this.post(LA.textEvent,[t.messageData,a,i]);break;case R.midiPort:this.assignMIDIPort(A,t.messageData[0]);break;case R.reset:this.synth.stopAllChannels(),this.synth.resetAllControllers();break;default:T(`%cUnrecognized Event: %c${t.messageStatusByte}%c status byte: %c${Object.keys(R).find(C=>R[C]===e.status)}`,g.warn,g.unrecognized,g.warn,g.value);break}}function Os(){for(let t=0;t<16;t++)this.synth.createWorkletChannel(!0),t===xA&&this.synth.setDrums(this.synth.workletProcessorChannels.length-1,!0)}function cr(t){return t.messageData.currentIndex=0,6e7/_A(t.messageData,3)}function Vs(){let t=this.currentTime;for(;this.playedTime<t;){let A=this._findFirstEventIndex(),e=this.tracks[A][this.eventIndex[A]];if(this._processEvent(e,A),this.eventIndex[A]++,A=this._findFirstEventIndex(),this.tracks[A].length<=this.eventIndex[A]){if(this.loop){this.setTimeTicks(this.midiData.loop.start);return}this.eventIndex[A]--,this.pause(!0),this.songs.length>1&&this.nextSong();return}let s=this.tracks[A][this.eventIndex[A]];if(this.playedTime+=this.oneTickToSeconds*(s.ticks-e.ticks),this.midiData.loop.end<=e.ticks&&this.loop&&this.currentLoopCount>0){this.currentLoopCount--,this.setTimeTicks(this.midiData.loop.start);return}else if(t>=this.duration){if(this.loop&&this.currentLoopCount>0){this.currentLoopCount--,this.setTimeTicks(this.midiData.loop.start);return}this.eventIndex[A]--,this.pause(!0),this.songs.length>1&&this.nextSong();return}}}function Zs(){let t=0,A=1/0;return this.tracks.forEach((e,s)=>{this.eventIndex[s]>=e.length||e[this.eventIndex[s]].ticks<A&&(t=s,A=e[this.eventIndex[s]].ticks)}),t}var ke=class{timeDivision=0;duration=0;tempoChanges=[{ticks:0,tempo:120}];copyright="";tracksAmount=0;lyrics=[];lyricsTicks=[];firstNoteOn=0;keyRange={min:0,max:127};lastVoiceEventTick=0;midiPorts=[0];midiPortChannelOffsets=[0];usedChannelsOnTrack=[];loop={start:0,end:0};midiName="";midiNameUsesFileName=!1;fileName="";rawMidiName=void 0;format=0;RMIDInfo={};bankOffset=0;isKaraokeFile=!1};var nt=class extends ke{isEmbedded=!1;constructor(A){super(),this.timeDivision=A.timeDivision,this.duration=A.duration,this.tempoChanges=A.tempoChanges,this.copyright=A.copyright,this.tracksAmount=A.tracksAmount,this.lyrics=A.lyrics,this.lyricsTicks=A.lyricsTicks,this.firstNoteOn=A.firstNoteOn,this.keyRange=A.keyRange,this.lastVoiceEventTick=A.lastVoiceEventTick,this.midiPorts=A.midiPorts,this.midiPortChannelOffsets=A.midiPortChannelOffsets,this.usedChannelsOnTrack=A.usedChannelsOnTrack,this.loop=A.loop,this.midiName=A.midiName,this.midiNameUsesFileName=A.midiNameUsesFileName,this.fileName=A.fileName,this.rawMidiName=A.rawMidiName,this.format=A.format,this.RMIDInfo=A.RMIDInfo,this.bankOffset=A.bankOffset,this.isKaraokeFile=A.isKaraokeFile,this.isEmbedded=A.embeddedSoundFont!==void 0}},pa={duration:99999,firstNoteOn:0,loop:{start:0,end:123456},lastVoiceEventTick:123456,lyrics:[],copyright:"",midiPorts:[],midiPortChannelOffsets:[],tracksAmount:0,tempoChanges:[{ticks:0,tempo:120}],fileName:"NOT_LOADED.mid",midiName:"Loading...",rawMidiName:new Uint8Array([76,111,97,100,105,110,103,46,46,46]),usedChannelsOnTrack:[],timeDivision:0,keyRange:{min:0,max:127},isEmbedded:!1,RMIDInfo:{},bankOffset:0,midiNameUsesFileName:!1,format:0};function G(t,A){let e=0;for(let s=0;s<A;s++)e|=t[t.currentIndex++]<<s*8;return e>>>0}function we(t,A,e){for(let s=0;s<e;s++)t[t.currentIndex++]=A>>s*8&255}function L(t,A){t[t.currentIndex++]=A&255,t[t.currentIndex++]=A>>8}function W(t,A){we(t,A,4)}function oe(t,A){let e=A<<8|t;return e>32767?e-65536:e}function Ws(t){return t>127?t-256:t}function z(t,A,e=void 0,s=!0){if(e){let n=t.slice(t.currentIndex,t.currentIndex+A);return t.currentIndex+=A,new TextDecoder(e.replace(/[^\x20-\x7E]/g,"")).decode(n.buffer)}else{let n=!1,o="";for(let i=0;i<A;i++){let a=t[t.currentIndex++];if(!n){if((a<32||a>127)&&a!==10){if(s){n=!0;continue}else if(a===0){n=!0;continue}}o+=String.fromCharCode(a)}}return o}}function ot(t,A=0){let e=t.length;A>0&&(e=A);let s=new b(e);return SA(s,t,A),s}function he(t){return ot(t,t.length+1)}function SA(t,A,e=0){e>0&&A.length>e&&(A=A.slice(0,e));for(let s=0;s<A.length;s++)t[t.currentIndex++]=A.charCodeAt(s);if(e>A.length)for(let s=0;s<e-A.length;s++)t[t.currentIndex++]=0;return t}var rA=class{constructor(A,e,s){this.header=A,this.size=e,this.chunkData=s}};function j(t,A=!0,e=!1){let s=z(t,4),n=G(t,4),o;return A&&(o=new b(t.buffer.slice(t.currentIndex,t.currentIndex+n))),(A||e)&&(t.currentIndex+=n),n%2!==0&&t[t.currentIndex]===0&&t.currentIndex++,new rA(s,n,o)}function IA(t,A=void 0){let e=8+t.size;t.size%2!==0&&e++,A&&(e+=A.length);let s=new b(e);return A&&(s.set(A,s.currentIndex),s.currentIndex+=A.length),SA(s,t.header),W(s,e-8-(A?.length||0)),s.set(t.chunkData,s.currentIndex),s}function sA(t,A,e=!1,s=!1){if(e){let h=new Uint8Array(A.length+1);h.set(A),A=h}let n=8,o=n+A.length,i=A.length;o%2!==0&&o++;let a=t;s&&(o+=4,i+=4,n+=4,a="LIST");let C=new b(o);return SA(C,a),W(C,i),s&&SA(C,t),C.set(A,n),C}function MA(t,A){return t.find(e=>e.header!=="LIST"?!1:(e.chunkData.currentIndex=0,z(e.chunkData,4)===A))}function rt(t){let A=0;for(;t;){let e=t[t.currentIndex++];if(A=A<<7|e&127,e>>7!==1)break}return A}var it={name:"INAM",album:"IPRD",album2:"IALB",artist:"IART",genre:"IGNR",picture:"IPIC",copyright:"ICOP",creationDate:"ICRD",comment:"ICMT",engineer:"IENG",software:"ISFT",encoding:"IENC",midiEncoding:"MENC",bankOffset:"DBNK"};var at=class t extends ke{embeddedSoundFont=void 0;tracks=[];static copyFrom(A){let e=new t;return e.midiName=A.midiName,e.midiNameUsesFileName=A.midiNameUsesFileName,e.fileName=A.fileName,e.timeDivision=A.timeDivision,e.duration=A.duration,e.copyright=A.copyright,e.tracksAmount=A.tracksAmount,e.firstNoteOn=A.firstNoteOn,e.keyRange={...A.keyRange},e.lastVoiceEventTick=A.lastVoiceEventTick,e.loop={...A.loop},e.format=A.format,e.bankOffset=A.bankOffset,e.isKaraokeFile=A.isKaraokeFile,e.tempoChanges=[...A.tempoChanges],e.lyrics=A.lyrics.map(s=>new Uint8Array(s)),e.lyricsTicks=[...A.lyricsTicks],e.midiPorts=[...A.midiPorts],e.midiPortChannelOffsets=[...A.midiPortChannelOffsets],e.usedChannelsOnTrack=A.usedChannelsOnTrack.map(s=>new Set(s)),e.rawMidiName=A.rawMidiName?new Uint8Array(A.rawMidiName):void 0,e.embeddedSoundFont=A.embeddedSoundFont?A.embeddedSoundFont.slice():void 0,e.RMIDInfo={...A.RMIDInfo},e.tracks=A.tracks.map(s=>[...s]),e}flush(){let A=[];for(let n of this.tracks){n.sort((i,a)=>i.ticks-a.ticks);let o=n.find(i=>(i.messageStatusByte&240)===R.noteOn);o&&A.push(o.ticks)}this.firstNoteOn=Math.min(...A),this.lastVoiceEventTick=0,this.tempoChanges=[{ticks:0,tempo:120}],this.midiPorts=[],this.midiPortChannelOffsets=[];let e=0;this.usedChannelsOnTrack=this.tracks.map(()=>new Set),this.tracks.forEach((n,o)=>{this.midiPorts.push(-1),n.forEach(i=>{if(i.messageStatusByte>=128&&i.messageStatusByte<240&&i.ticks>this.lastVoiceEventTick&&(this.lastVoiceEventTick=i.ticks),i.messageStatusByte===R.setTempo)this.tempoChanges.push({ticks:i.ticks,tempo:6e7/_A(i.messageData,3)});else if((i.messageStatusByte&240)===R.noteOn)this.usedChannelsOnTrack[o].add(i.messageData[0]);else if(i.messageStatusByte===R.midiPort){let a=i.messageData[0];this.midiPorts[o]=a,this.midiPortChannelOffsets[a]===void 0&&(this.midiPortChannelOffsets[a]=e,e+=16)}})}),this.loop={start:this.firstNoteOn,end:this.lastVoiceEventTick},this.tempoChanges.reverse(),this.duration=ce(this.lastVoiceEventTick,this);let s=0;for(let n of this.midiPorts)if(n!==-1){s=n;break}this.midiPorts=this.midiPorts.map(n=>n===-1?s:n),this.midiPortChannelOffsets.length===0&&(this.midiPortChannelOffsets=[0])}};function ce(t,A){let e=0;for(;t>0;){let s=A.tempoChanges.find(o=>o.ticks<t),n=t-s.ticks;e+=n*60/(s.tempo*A.timeDivision),t-=n}return e}var gt=class extends at{constructor(A,e=""){super(),QA("%cParsing MIDI File...",g.info);let s=new b(A),n,o=!1,i=!1,a=!1,C=[],h=z(s,4);if(s.currentIndex-=4,h==="RIFF"){s.currentIndex+=8;let y=z(s,4,void 0,!1);if(y!=="RMID")throw Z(),new SyntaxError(`Invalid RMIDI Header! Expected "RMID", got "${y}"`);let w=j(s);if(w.header!=="data")throw Z(),new SyntaxError(`Invalid RMIDI Chunk header! Expected "data", got "${y}"`);for(n=w.chunkData;s.currentIndex<=s.length;){let x=s.currentIndex,F=j(s,!0);if(F.header==="RIFF"){let I=z(F.chunkData,4).toLowerCase();I==="sfbk"||I==="sfpk"||I==="dls "?(m("%cFound embedded soundfont!",g.recognized),this.embeddedSoundFont=s.slice(x,x+F.size).buffer):T(`Unknown RIFF chunk: "${I}"`),I==="dls "&&(a=!0)}else if(F.header==="LIST"&&z(F.chunkData,4)==="INFO"){for(m("%cFound RMIDI INFO chunk!",g.recognized),this.RMIDInfo={};F.chunkData.currentIndex<=F.size;){let tA=j(F.chunkData,!0);this.RMIDInfo[tA.header]=tA.chunkData}this.RMIDInfo.ICOP&&(o=!0,this.copyright=z(this.RMIDInfo.ICOP,this.RMIDInfo.ICOP.length,void 0,!1).replaceAll(`
|
|
10
|
+
`," ")),this.RMIDInfo.INAM&&(this.rawMidiName=this.RMIDInfo[it.name],this.midiName=z(this.rawMidiName,this.rawMidiName.length,void 0,!1).replaceAll(`
|
|
11
|
+
`," "),i=!0),this.RMIDInfo.IALB&&!this.RMIDInfo.IPRD&&(this.RMIDInfo.IPRD=this.RMIDInfo.IALB),this.RMIDInfo.PRD&&!this.RMIDInfo.IALB&&(this.RMIDInfo.IALB=this.RMIDInfo.IPRD),this.bankOffset=1,this.RMIDInfo[it.bankOffset]&&(this.bankOffset=G(this.RMIDInfo[it.bankOffset],2))}}a&&(this.bankOffset=0)}else n=s;let d=this.readMIDIChunk(n);if(d.type!=="MThd")throw Z(),new SyntaxError(`Invalid MIDI Header! Expected "MThd", got "${d.type}"`);if(d.size!==6)throw Z(),new RangeError(`Invalid MIDI header chunk size! Expected 6, got ${d.size}`);this.format=_A(d.data,2),this.tracksAmount=_A(d.data,2),this.timeDivision=_A(d.data,2),this.keyRange={min:127,max:0},this.lyrics=[],this.tempoChanges=[{ticks:0,tempo:120}];let Q=null,l=null,c=!1;this.lastVoiceEventTick=0,this.midiPorts=[];let f=0;this.midiPortChannelOffsets=[],this.usedChannelsOnTrack=[],this.tracks=[];for(let y=0;y<this.tracksAmount;y++){let w=[],x=this.readMIDIChunk(n),F=new Set;if(this.midiPorts.push(-1),x.type!=="MTrk")throw Z(),new SyntaxError(`Invalid track header! Expected "MTrk" got "${x.type}"`);let I=!1,tA,q=0;for(this.format===2&&y>0&&(q+=this.tracks[y-1][this.tracks[y-1].length-1].ticks);x.data.currentIndex<x.size;){q+=rt(x.data);let iA=x.data[x.data.currentIndex],V;if(tA!==void 0&&iA<128)V=tA;else{if(!tA&&iA<128)throw Z(),new SyntaxError(`Unexpected byte with no running byte. (${iA})`);V=x.data[x.data.currentIndex++]}let aA=Ns(V),oA;switch(aA){case-1:oA=0;break;case-2:V=x.data[x.data.currentIndex++],oA=rt(x.data);break;case-3:oA=rt(x.data);break;default:if(q>this.lastVoiceEventTick&&(this.lastVoiceEventTick=q),oA=bs[V>>4],(V&240)===R.noteOn){F.add(aA);let fA=x.data[x.data.currentIndex];this.keyRange.min=Math.min(this.keyRange.min,fA),this.keyRange.max=Math.max(this.keyRange.max,fA)}tA=V;break}let eA=new b(oA),AA=x.data.slice(x.data.currentIndex,x.data.currentIndex+oA);x.data.currentIndex+=oA,eA.set(AA,0);let hA=new pe(q,V,eA);switch(w.push(hA),aA){case-2:let fA=z(eA,eA.length);switch(V){case R.setTempo:this.tempoChanges.push({ticks:q,tempo:6e7/_A(AA,3)});break;case R.marker:switch(fA.trim().toLowerCase()){default:break;case"start":case"loopstart":Q=q;break;case"loopend":l=q}eA.currentIndex=0;break;case R.midiPort:let de=eA[0];this.midiPorts[y]=de,this.midiPortChannelOffsets[de]===void 0&&(this.midiPortChannelOffsets[de]=f,f+=16);break;case R.copyright:o||(eA.currentIndex=0,C.push(z(eA,eA.length,void 0,!1)));break;case R.lyric:if(fA.trim()==="@KMIDI KARAOKE FILE"&&(this.isKaraokeFile=!0,m("%cKaraoke MIDI detected!",g.recognized)),this.isKaraokeFile)hA.messageStatusByte=R.text,V=R.text;else{this.lyrics.push(eA),this.lyricsTicks.push(q);break}case R.text:let te=fA.trim();te==="@KMIDI KARAOKE FILE"?(this.isKaraokeFile=!0,m("%cKaraoke MIDI detected!",g.recognized)):this.isKaraokeFile&&(te.startsWith("@T")||te.startsWith("@A")?c?C.push(te.substring(2).trim()):(this.midiName=te.substring(2).trim(),c=!0,i=!0,this.rawMidiName=ot(this.midiName)):te[0]!=="@"&&(this.lyrics.push(Ms(eA)),this.lyricsTicks.push(q)));break}break;case-3:break;default:if(I=!0,(V&240)===R.controllerChange)switch(eA[0]){case 2:case 116:Q=q;break;case 4:case 117:l===null?l=q:l=0;break;case 0:a&&eA[1]!==0&&eA[1]!==127&&(m("%cDLS RMIDI with offset 1 detected!",g.recognized),this.bankOffset=1)}}}if(this.tracks.push(w),this.usedChannelsOnTrack.push(F),!I){let iA=w.find(V=>V.messageStatusByte===R.trackName);if(iA){iA.messageData.currentIndex=0;let V=z(iA.messageData,iA.messageData.length);C.push(V)}}m(`%cParsed %c${this.tracks.length}%c / %c${this.tracksAmount}`,g.info,g.value,g.info,g.value)}m("%cAll tracks parsed correctly!",g.recognized),QA("%cCorrecting loops, ports and detecting notes...",g.info);let M=[];for(let y of this.tracks){let w=y.find(x=>(x.messageStatusByte&240)===R.noteOn);w&&M.push(w.ticks)}this.firstNoteOn=Math.min(...M),m(`%cFirst note-on detected at: %c${this.firstNoteOn}%c ticks!`,g.info,g.recognized,g.info),Q!==null&&l===null?(Q=this.firstNoteOn,l=this.lastVoiceEventTick):(Q===null&&(Q=this.firstNoteOn),(l===null||l===0)&&(l=this.lastVoiceEventTick)),this.loop={start:Q,end:l},m(`%cLoop points: start: %c${this.loop.start}%c end: %c${this.loop.end}`,g.info,g.recognized,g.info,g.recognized);let D=0;for(let y of this.midiPorts)if(y!==-1){D=y;break}if(this.midiPorts=this.midiPorts.map(y=>y===-1?D:y),this.midiPortChannelOffsets.length===0&&(this.midiPortChannelOffsets=[0]),this.midiPortChannelOffsets.length<2?m("%cNo additional MIDI Ports detected.",g.info):m("%cMIDI Ports detected!",g.recognized),!i)if(this.tracks.length>1){if(this.tracks[0].find(y=>y.messageStatusByte>=R.noteOn&&y.messageStatusByte<R.polyPressure)===void 0){let y=this.tracks[0].find(w=>w.messageStatusByte===R.trackName);y&&(this.rawMidiName=y.messageData,y.messageData.currentIndex=0,this.midiName=z(y.messageData,y.messageData.length,void 0,!1))}}else{let y=this.tracks[0].find(w=>w.messageStatusByte===R.trackName);y&&(this.rawMidiName=y.messageData,y.messageData.currentIndex=0,this.midiName=z(y.messageData,y.messageData.length,void 0,!1))}if(o||(this.copyright=C.map(y=>y.trim().replace(/(\r?\n)+/g,`
|
|
12
|
+
`)).filter(y=>y.length>0).join(`
|
|
13
|
+
`)||""),this.fileName=e,this.midiName=this.midiName.trim(),this.midiNameUsesFileName=!1,this.midiName.length===0){m("%cNo name detected. Using the alt name!",g.info),this.midiName=xs(e),this.midiNameUsesFileName=!0,this.rawMidiName=new Uint8Array(this.midiName.length);for(let y=0;y<this.midiName.length;y++)this.rawMidiName[y]=this.midiName.charCodeAt(y)}else m(`%cMIDI Name detected! %c"${this.midiName}"`,g.info,g.recognized);let v=!0;for(let y of this.lyrics)if(y[0]===32||y[y.length-1]===32){v=!1;break}v&&(this.lyrics=this.lyrics.map(y=>{if(y[y.length-1]===45)return y;let w=new Uint8Array(y.length+1);return w.set(y,0),w[y.length]=32,w})),this.tempoChanges.reverse(),this.duration=ce(this.lastVoiceEventTick,this),Z(),m(`%cMIDI file parsed. Total tick time: %c${this.lastVoiceEventTick}%c, total seconds time: %c${this.duration}`,g.info,g.recognized,g.info,g.recognized),Z()}readMIDIChunk(A){let e={};e.type=z(A,4),e.size=_A(A,4),e.data=new b(e.size);let s=A.slice(A.currentIndex,A.currentIndex+e.size);return e.data.set(s,0),A.currentIndex+=e.size,e}};function Xs(t,A){QA("%cSearching for all used programs and keys...",g.info);let e=16+t.midiPortChannelOffsets.reduce((Q,l)=>l>Q?l:Q),s=[];for(let Q=0;Q<e;Q++){let l=Q%16===xA?128:0;s.push({program:0,bank:l,drums:Q%16===xA,string:`${l}:0`})}function n(Q){let l=A.getPreset(Q.bank,Q.program);Q.bank=l.bank,Q.program=l.program,Q.string=Q.bank+":"+Q.program,o[Q.string]||(m(`%cDetected a new preset: %c${Q.string}`,g.info,g.recognized),o[Q.string]=new Set)}let o={},i=Array(t.tracks.length).fill(0),a=t.tracks.length;function C(){let Q=0,l=1/0;return t.tracks.forEach((c,f)=>{i[f]>=c.length||c[i[f]].ticks<l&&(Q=f,l=c[i[f]].ticks)}),Q}let h=t.midiPorts.slice(),d="gs";for(;a>0;){let Q=C(),l=t.tracks[Q];if(i[Q]>=l.length){a--;continue}let c=l[i[Q]];if(i[Q]++,c.messageStatusByte===R.midiPort){h[Q]=c.messageData[0];continue}let f=c.messageStatusByte&240;if(f!==R.noteOn&&f!==R.controllerChange&&f!==R.programChange&&f!==R.systemExclusive)continue;let M=(c.messageStatusByte&15)+t.midiPortChannelOffsets[h[Q]]||0,D=s[M];switch(f){case R.programChange:D.program=c.messageData[0],n(D);break;case R.controllerChange:if(c.messageData[0]!==k.bankSelect||d==="gs"&&D.drums)continue;let v=c.messageData[1],y=Math.max(0,v-t.bankOffset);if(d==="xg"){let F=v===120||v===126||v===127;F!==D.drums?(D.drums=F,D.bank=D.drums?128:y,n(D)):D.bank=D.drums?128:y;continue}s[M].bank=y;break;case R.noteOn:if(c.messageData[1]===0)continue;n(D),o[D.string].add(`${c.messageData[0]}-${c.messageData[1]}`);break;case R.systemExclusive:if(c.messageData[0]!==65||c.messageData[2]!==66||c.messageData[3]!==18||c.messageData[4]!==64||!(c.messageData[5]&16)||c.messageData[6]!==21){c.messageData[0]===67&&c.messageData[2]===76&&c.messageData[5]===126&&c.messageData[6]===0&&(d="xg");continue}let w=[9,0,1,2,3,4,5,6,7,8,10,11,12,13,14,15][c.messageData[5]&15]+t.midiPortChannelOffsets[h[Q]],x=!!(c.messageData[7]>0&&c.messageData[5]>>4);D=s[w],D.drums=x,D.bank=x?128:0,n(D);break}}for(let Q of Object.keys(o))o[Q].size===0&&(m(`%cDetected change but no keys for %c${Q}`,g.info,g.value),delete o[Q]);return Z(),o}function _s(t,A){this.midiData.usedChannelsOnTrack[t].size!==0&&(this.midiPortChannelOffset===0&&(this.midiPortChannelOffset+=16,this.midiPortChannelOffsets[A]=0),this.midiPortChannelOffsets[A]===void 0&&(this.synth.workletProcessorChannels.length<this.midiPortChannelOffset+15&&this._addNewMidiPort(),this.midiPortChannelOffsets[A]=this.midiPortChannelOffset,this.midiPortChannelOffset+=16),this.midiPorts[t]=A)}function zs(t,A=!0){if(this.stop(),!t.tracks)throw new Error("This MIDI has no tracks!");if(this.oneTickToSeconds=60/(120*t.timeDivision),this.midiData=t,this.currentLoopCount=this.loopCount,this.midiData.embeddedSoundFont!==void 0)m("%cEmbedded soundfont detected! Using it.",g.recognized),this.synth.setEmbeddedSoundFont(this.midiData.embeddedSoundFont,this.midiData.bankOffset);else{this.synth.overrideSoundfont&&this.synth.clearSoundFont(!0,!0),QA("%cPreloading samples...",g.info);let e=Xs(this.midiData,this.synth.soundfontManager);for(let[s,n]of Object.entries(e)){let o=parseInt(s.split(":")[0]),i=parseInt(s.split(":")[1]),a=this.synth.getPreset(o,i);m(`%cPreloading used samples on %c${a.presetName}%c...`,g.info,g.recognized,g.info);for(let C of n){let h=C.split("-");a.preloadSpecific(parseInt(h[0]),parseInt(h[1]))}}Z()}if(this.tracks=this.midiData.tracks,this.midiPorts=this.midiData.midiPorts,this.midiPortChannelOffset=0,this.midiPortChannelOffsets={},this.midiData.midiPorts.forEach((e,s)=>{this.assignMIDIPort(s,e)}),this.duration=this.midiData.duration,this.firstNoteTime=ce(this.midiData.firstNoteOn,this.midiData),m(`%cTotal song time: ${Pt(Math.ceil(this.duration)).time}`,g.recognized),this.post(LA.songChange,[new nt(this.midiData),this.songIndex,A]),this.duration<=1&&(T(`%cVery short song: (${Pt(Math.round(this.duration)).time}). Disabling loop!`,g.warn),this.loop=!1),A)this.play(!0);else{let e=this._skipToFirstNoteOn?this.midiData.firstNoteOn-1:0;this.setTimeTicks(e),this.pause()}}function js(t,A=!0){this.songs=t.reduce((e,s)=>{if(s.duration)return e.push(s),e;try{e.push(new gt(s.binary,s.altName||""))}catch(n){return this.post(LA.midiError,n.message),e}return e},[]),!(this.songs.length<1)&&(this.songIndex=0,this.songs.length>1&&(this.loop=!1),this.loadNewSequence(this.songs[this.songIndex],A))}function $s(){if(this.songs.length===1){this.currentTime=0;return}this.songIndex++,this.songIndex%=this.songs.length,this.loadNewSequence(this.songs[this.songIndex])}function An(){if(this.songs.length===1){this.currentTime=0;return}this.songIndex--,this.songIndex<0&&(this.songIndex=this.songs.length-1),this.loadNewSequence(this.songs[this.songIndex])}var Te=De.slice(0,128);function en(t,A=void 0){this.oneTickToSeconds=60/(120*this.midiData.timeDivision),this.synth.resetAllControllers(),this.sendMIDIReset(),this._resetTimers();let e=this.synth.workletProcessorChannels.length,s=Array(e).fill(8192),n=[];for(let a=0;a<e;a++)n.push({program:-1,bank:0,actualBank:0});let o=a=>a===k.dataDecrement||a===k.dataIncrement||a===k.dataEntryMsb||a===k.dataDecrement||a===k.lsbForControl6DataEntry||a===k.RPNLsb||a===k.RPNMsb||a===k.NRPNLsb||a===k.NRPNMsb||a===k.bankSelect||a===k.lsbForControl0BankSelect||a===k.resetAllControllers,i=[];for(let a=0;a<e;a++)i.push(Array.from(Te));for(;;){let a=this._findFirstEventIndex(),C=this.tracks[a][this.eventIndex[a]];if(A!==void 0){if(C.ticks>=A)break}else if(this.playedTime>=t)break;let h=Ue(C.messageStatusByte),d=h.channel+(this.midiPortChannelOffsets[this.midiPorts[a]]||0);switch(h.status){case R.noteOn:case R.noteOff:case R.keySignature:break;case R.pitchBend:s[d]=C.messageData[1]<<7|C.messageData[0];break;case R.programChange:let l=n[d];l.program=C.messageData[0],l.actualBank=l.bank;break;case R.controllerChange:let c=C.messageData[0];if(o(c)){let f=C.messageData[1];if(c===k.bankSelect){n[d].bank=f;break}else c===k.resetAllControllers&&(i[d]=Array.from(Te));this.sendMIDIMessages?this.sendMIDICC(d,c,f):this.synth.controllerChange(d,c,f)}else i[d]===void 0&&(i[d]=Array.from(Te)),i[d][c]=C.messageData[1];break;default:this._processEvent(C,a);break}this.eventIndex[a]++,a=this._findFirstEventIndex();let Q=this.tracks[a][this.eventIndex[a]];if(Q===void 0)return this.stop(),!1;this.playedTime+=this.oneTickToSeconds*(Q.ticks-C.ticks)}if(this.sendMIDIMessages){for(let a=0;a<e;a++)if(s[a]!==void 0&&this.sendMIDIPitchWheel(a,s[a]>>7,s[a]&127),i[a]!==void 0&&i[a].forEach((C,h)=>{C!==Te[h]&&!o(h)&&this.sendMIDICC(a,h,C)}),n[a].program>=0&&n[a].actualBank>=0){let C=n[a].actualBank;this.sendMIDICC(a,k.bankSelect,C),this.sendMIDIProgramChange(a,n[a].program)}}else for(let a=0;a<e;a++)if(s[a]!==void 0&&this.synth.pitchWheel(a,s[a]>>7,s[a]&127),i[a]!==void 0&&i[a].forEach((C,h)=>{C!==Te[h]&&!o(h)&&this.synth.controllerChange(a,h,C)}),n[a].program>=0&&n[a].actualBank>=0){let C=n[a].actualBank;this.synth.controllerChange(a,k.bankSelect,C),this.synth.programChange(a,n[a].program)}return!0}function tn(t=!1){if(this.midiData!==void 0){if(t){this.pausedTime=void 0,this.currentTime=0;return}if(this.currentTime>=this.duration){this.pausedTime=void 0,this.currentTime=0;return}this.paused&&(this._recalculateStartTime(this.pausedTime),this.pausedTime=void 0),this.sendMIDIMessages||this.playingNotes.forEach(A=>{this.synth.noteOn(A.channel,A.midiNote,A.velocity,!1,!0)}),this.setProcessHandler()}}function sn(t){this.stop(),this.playingNotes=[],this.pausedTime=void 0,this.post(LA.timeChange,currentTime-ce(t,this.midiData));let A=this._playTo(0,t);this._recalculateStartTime(this.playedTime),A&&this.play()}function nn(t){this.absoluteStartTime=currentTime-t/this._playbackRate}function on(t,A){switch(t){default:break;case bA.loadNewSongList:this.loadNewSongList(A[0],A[1]);break;case bA.pause:this.pause();break;case bA.play:this.play(A);break;case bA.stop:this.stop();break;case bA.setTime:this.currentTime=A;break;case bA.changeMIDIMessageSending:this.sendMIDIMessages=A;break;case bA.setPlaybackRate:this.playbackRate=A;break;case bA.setLoop:this.loop=A;break;case bA.changeSong:A?this.nextSong():this.previousSong();break;case bA.getMIDI:this.post(LA.getMIDI,this.midiData);break;case bA.setSkipToFirstNote:this._skipToFirstNoteOn=A;break;case bA.setPreservePlaybackState:this.preservePlaybackState=A}}function rn(t,A=void 0){this.synth.enableEventSystem&&this.synth.post({messageType:kA.sequencerSpecific,messageData:{messageType:t,messageData:A}})}function an(t){this.post(LA.midiEvent,t)}function gn(t,A,e){t%=16,this.sendMIDIMessages&&this.sendMIDIMessage([R.controllerChange|t,A,e])}function In(t,A){t%=16,this.sendMIDIMessages&&this.sendMIDIMessage([R.programChange|t,A])}function En(t,A,e){t%=16,this.sendMIDIMessages&&this.sendMIDIMessage([R.pitchBend|t,e,A])}function Cn(){if(this.sendMIDIMessages){this.sendMIDIMessage([R.reset]);for(let t=0;t<tt;t++)this.sendMIDIMessage([R.controllerChange|t,k.allSoundOff,0]),this.sendMIDIMessage([R.controllerChange|t,k.resetAllControllers,0])}}var BA=class{constructor(A){this.synth=A,this.ignoreEvents=!1,this.sendMIDIMessages=!1,this.loopCount=1/0,this.currentLoopCount=this.loopCount,this.eventIndex=[],this.songIndex=0,this.playedTime=0,this.pausedTime=void 0,this.absoluteStartTime=currentTime,this._playbackRate=1,this.playingNotes=[],this.loop=!0,this.midiData=void 0,this.midiPorts=[],this.midiPortChannelOffset=0,this.midiPortChannelOffsets={},this._skipToFirstNoteOn=!0,this.preservePlaybackState=!1}set playbackRate(A){let e=this.currentTime;this._playbackRate=A,this.currentTime=e}get currentTime(){return this.pausedTime!==void 0?this.pausedTime:(currentTime-this.absoluteStartTime)*this._playbackRate}set currentTime(A){if(A>this.duration||A<0){this._skipToFirstNoteOn?this.setTimeTicks(this.midiData.firstNoteOn-1):this.setTimeTicks(0);return}if(this._skipToFirstNoteOn&&A<this.firstNoteTime){this.setTimeTicks(this.midiData.firstNoteOn-1);return}this.stop(),this.playingNotes=[];let e=this.paused&&this.preservePlaybackState;this.pausedTime=void 0,this.post(LA.timeChange,currentTime-A),this._playTo(A),this._recalculateStartTime(A),e?this.pause():this.play()}get paused(){return this.pausedTime!==void 0}pause(A=!1){if(this.paused){T("Already paused");return}this.pausedTime=this.currentTime,this.stop(),this.post(LA.pause,A)}stop(){this.clearProcessHandler();for(let A=0;A<16;A++)this.synth.controllerChange(A,k.sustainPedal,0);if(this.synth.stopAllChannels(),this.sendMIDIMessages){for(let A of this.playingNotes)this.sendMIDIMessage([R.noteOff|A.channel%16,A.midiNote]);for(let A=0;A<tt;A++)this.sendMIDICC(A,k.allNotesOff,0)}}_resetTimers(){this.playedTime=0,this.eventIndex=Array(this.tracks.length).fill(0)}setProcessHandler(){this.synth.processTickCallback=this._processTick.bind(this)}clearProcessHandler(){this.synth.processTickCallback=void 0}};BA.prototype.sendMIDIMessage=an;BA.prototype.sendMIDIReset=Cn;BA.prototype.sendMIDICC=gn;BA.prototype.sendMIDIProgramChange=In;BA.prototype.sendMIDIPitchWheel=En;BA.prototype.assignMIDIPort=_s;BA.prototype.post=rn;BA.prototype.processMessage=on;BA.prototype._processEvent=Ks;BA.prototype._addNewMidiPort=Os;BA.prototype._processTick=Vs;BA.prototype._findFirstEventIndex=Zs;BA.prototype.loadNewSequence=zs;BA.prototype.loadNewSongList=js;BA.prototype.nextSong=$s;BA.prototype.previousSong=An;BA.prototype.play=tn;BA.prototype._playTo=en;BA.prototype.setTimeTicks=sn;BA.prototype._recalculateStartTime=nn;var Wt=new Float32Array(30001);for(let t=0;t<Wt.length;t++){let A=-15e3+t;Wt[t]=Math.pow(2,A/1200)}function VA(t){return t<=-32767?0:Wt[t- -15e3]}var It=-2e4,Bn=16500,Xt=new Float32Array(Bn-It+1);for(let t=0;t<Xt.length;t++){let A=It+t;Xt[t]=440*Math.pow(2,(A-6900)/1200)}function ve(t){return t<It||t>Bn?440*Math.pow(2,(t-6900)/1200):Xt[~~t-It]}var zt=-1660,lr=1600,_t=new Float32Array((lr-zt)*100+1);for(let t=0;t<_t.length;t++){let A=(zt*100+t)/100;_t[t]=Math.pow(10,-A/20)}function JA(t){return _t[Math.floor((t-zt)*100)]}function Et(t,A,e){if(e<t)return 0;let s=(e-t)/(1/A)+.25;return Math.abs(s-~~(s+.5))*4-1}var mA=16384,$A=new Float32Array(mA+1),le=new Float32Array(mA+1);$A[0]=0;$A[$A.length-1]=1;le[0]=0;le[le.length-1]=1;for(let t=1;t<mA-1;t++){let A=-.4166666666666667*Math.log(t/($A.length-1))/Math.LN10;le[t]=1-A,$A[$A.length-1-t]=A}function Qe(t,A,e,s){switch(t&&(e=1-e),A){case uA.linear:return s?e*2-1:e;case uA.switch:return e=e>.5?1:0,s?e*2-1:e;case uA.concave:return s?(e=e*2-1,e<0?-$A[~~(e*-mA)]:$A[~~(e*mA)]):$A[~~(e*mA)];case uA.convex:return s?(e=e*2-1,e<0?-le[~~(e*-mA)]:le[~~(e*mA)]):le[~~(e*mA)]}}var jt=1,$t=new Float32Array(1e3);for(let t=0;t<$t.length;t++)$t[t]=Qe(0,uA.convex,t/1e3,0);var PA=class t{attackDuration=0;decayDuration=0;holdDuration=0;releaseDuration=0;sustainLevel=0;delayEnd=0;attackEnd=0;holdEnd=0;decayEnd=0;releaseStartLevel=0;currentValue=0;static startRelease(A){t.recalculate(A)}static recalculate(A){let e=A.modulationEnvelope;A.isInRelease&&(e.releaseStartLevel=t.getValue(A,A.releaseStartTime,!0)),e.sustainLevel=1-A.modulatedGenerators[r.sustainModEnv]/1e3,e.attackDuration=VA(A.modulatedGenerators[r.attackModEnv]);let s=(60-A.midiNote)*A.modulatedGenerators[r.keyNumToModEnvDecay],n=VA(A.modulatedGenerators[r.decayModEnv]+s);e.decayDuration=n*(1-e.sustainLevel);let o=(60-A.midiNote)*A.modulatedGenerators[r.keyNumToModEnvHold];e.holdDuration=VA(o+A.modulatedGenerators[r.holdModEnv]);let i=VA(A.modulatedGenerators[r.releaseModEnv]);e.releaseDuration=i*e.releaseStartLevel,e.delayEnd=A.startTime+VA(A.modulatedGenerators[r.delayModEnv]),e.attackEnd=e.delayEnd+e.attackDuration,e.holdEnd=e.attackEnd+e.holdDuration,e.decayEnd=e.holdEnd+e.decayDuration}static getValue(A,e,s=!1){let n=A.modulationEnvelope;return A.isInRelease&&!s?n.releaseStartLevel===0?0:Math.max(0,(1-(e-A.releaseStartTime)/n.releaseDuration)*n.releaseStartLevel):(e<n.delayEnd?n.currentValue=0:e<n.attackEnd?n.currentValue=$t[~~((1-(n.attackEnd-e)/n.attackDuration)*1e3)]:e<n.holdEnd?n.currentValue=jt:e<n.decayEnd?n.currentValue=(1-(n.decayEnd-e)/n.decayDuration)*(n.sustainLevel-jt)+jt:n.currentValue=n.sustainLevel,n.currentValue)}};var Fe={linear:0,nearestNeighbor:1,fourthOrder:2};function hn(t,A){let e=t.sample,s=e.cursor,n=e.sampleData;if(e.isLooping){let o=e.loopEnd-e.loopStart;for(let i=0;i<A.length;i++){for(;s>=e.loopEnd;)s-=o;let a=~~s,C=a+1;for(;C>=e.loopEnd;)C-=o;let h=s-a,d=n[C],Q=n[a];A[i]=Q+(d-Q)*h,s+=e.playbackStep*t.currentTuningCalculated}}else{if(e.loopingMode===2&&!t.isInRelease)return;for(let o=0;o<A.length;o++){let i=~~s,a=i+1;if(a>=e.end){t.finished=!0;return}let C=s-i,h=n[a],d=n[i];A[o]=d+(h-d)*C,s+=e.playbackStep*t.currentTuningCalculated}}t.sample.cursor=s}function cn(t,A){let e=t.sample,s=e.cursor,n=e.loopEnd-e.loopStart,o=e.sampleData;if(t.sample.isLooping)for(let i=0;i<A.length;i++){for(;s>=e.loopEnd;)s-=n;let a=~~s+1;for(;a>=e.loopEnd;)a-=n;A[i]=o[a],s+=e.playbackStep*t.currentTuningCalculated}else{if(e.loopingMode===2&&!t.isInRelease)return;for(let i=0;i<A.length;i++){let a=~~s+1;if(a>=e.end){t.finished=!0;return}A[i]=o[a],s+=e.playbackStep*t.currentTuningCalculated}}e.cursor=s}function ln(t,A){let e=t.sample,s=e.cursor,n=e.sampleData;if(e.isLooping){let o=e.loopEnd-e.loopStart;for(let i=0;i<A.length;i++){for(;s>=e.loopEnd;)s-=o;let a=~~s,C=a+1,h=C+1,d=h+1,Q=s-a;C>=e.loopEnd&&(C-=o),h>=e.loopEnd&&(h-=o),d>=e.loopEnd&&(d-=o);let l=n[a],c=n[C],f=n[h],M=n[d],D=.5*(f-l),v=l-2.5*c+2*f-.5*M,y=.5*(M-l)+1.5*(c-f);A[i]=((y*Q+v)*Q+D)*Q+c,s+=e.playbackStep*t.currentTuningCalculated}}else{if(e.loopingMode===2&&!t.isInRelease)return;for(let o=0;o<A.length;o++){let i=~~s,a=i+1,C=a+1,h=C+1,d=s-i;if(a>=e.end||C>=e.end||h>=e.end){t.finished=!0;return}let Q=n[i],l=n[a],c=n[C],f=n[h],M=.5*(c-Q),D=Q-2.5*l+2*c-.5*f,v=.5*(f-Q)+1.5*(l-c);A[o]=((v*d+D)*d+M)*d+l,s+=e.playbackStep*t.currentTuningCalculated}}t.sample.cursor=s}var Qn=.01,UA=100,As=90,Qr=15e-6,qA=class t{currentSampleTime=0;sampleRate;currentAttenuationDb=UA;state=0;releaseStartDb=UA;releaseStartTimeSamples=0;currentReleaseGain=1;attackDuration=0;decayDuration=0;releaseDuration=0;attenuation=0;attenuationTargetGain=0;attenuationTarget=0;sustainDbRelative=0;delayEnd=0;attackEnd=0;holdEnd=0;decayEnd=0;constructor(A,e){this.sampleRate=A,this.canEndOnSilentSustain=e/10>=As}static startRelease(A){A.volumeEnvelope.releaseStartTimeSamples=A.volumeEnvelope.currentSampleTime,A.volumeEnvelope.currentReleaseGain=JA(A.volumeEnvelope.currentAttenuationDb),t.recalculate(A)}static recalculate(A){let e=A.volumeEnvelope,s=h=>Math.max(0,Math.floor(VA(h)*e.sampleRate));e.attenuationTarget=Math.max(0,Math.min(A.modulatedGenerators[r.initialAttenuation],1440))/10,e.attenuationTargetGain=JA(e.attenuationTarget),e.sustainDbRelative=Math.min(UA,A.modulatedGenerators[r.sustainVolEnv]/10);let n=Math.min(UA,e.sustainDbRelative);e.attackDuration=s(A.modulatedGenerators[r.attackVolEnv]);let o=A.modulatedGenerators[r.decayVolEnv],i=(60-A.targetKey)*A.modulatedGenerators[r.keyNumToVolEnvDecay],a=n/UA;e.decayDuration=s(o+i)*a,e.releaseDuration=s(A.modulatedGenerators[r.releaseVolEnv]),e.delayEnd=s(A.modulatedGenerators[r.delayVolEnv]),e.attackEnd=e.attackDuration+e.delayEnd;let C=(60-A.targetKey)*A.modulatedGenerators[r.keyNumToVolEnvHold];if(e.holdEnd=s(A.modulatedGenerators[r.holdVolEnv]+C)+e.attackEnd,e.decayEnd=e.decayDuration+e.holdEnd,e.state===0&&e.attackEnd===0&&(e.state=2),A.isInRelease){let h=Math.max(0,Math.min(UA,e.sustainDbRelative)),d=h/UA;switch(e.decayDuration=s(o+i)*d,e.state){case 0:e.releaseStartDb=UA;break;case 1:let l=1-(e.attackEnd-e.releaseStartTimeSamples)/e.attackDuration;e.releaseStartDb=20*Math.log10(l)*-1;break;case 2:e.releaseStartDb=0;break;case 3:e.releaseStartDb=(1-(e.decayEnd-e.releaseStartTimeSamples)/e.decayDuration)*h;break;case 4:e.releaseStartDb=h;break}e.releaseStartDb=Math.max(0,Math.min(e.releaseStartDb,UA)),e.releaseStartDb>=As&&(A.finished=!0),e.currentReleaseGain=JA(e.releaseStartDb);let Q=(UA-e.releaseStartDb)/UA;e.releaseDuration*=Q}}static apply(A,e,s,n){let o=A.volumeEnvelope,i=s/10,a=n;if(A.isInRelease){let h=o.currentSampleTime-o.releaseStartTimeSamples;if(h>=o.releaseDuration){for(let Q=0;Q<e.length;Q++)e[Q]=0;A.finished=!0;return}let d=UA-o.releaseStartDb;for(let Q=0;Q<e.length;Q++){o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a;let l=h/o.releaseDuration*d+o.releaseStartDb;o.currentReleaseGain=o.attenuation*JA(l+i),e[Q]*=o.currentReleaseGain,o.currentSampleTime++,h++}o.currentReleaseGain<=Qr&&(A.finished=!0);return}let C=0;switch(o.state){case 0:for(;o.currentSampleTime<o.delayEnd;)if(o.currentAttenuationDb=UA,e[C]=0,o.currentSampleTime++,++C>=e.length)return;o.state++;case 1:for(;o.currentSampleTime<o.attackEnd;){o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a;let h=1-(o.attackEnd-o.currentSampleTime)/o.attackDuration;if(e[C]*=h*o.attenuation*JA(i),o.currentAttenuationDb=0,o.currentSampleTime++,++C>=e.length)return}o.state++;case 2:for(;o.currentSampleTime<o.holdEnd;)if(o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a,e[C]*=o.attenuation*JA(i),o.currentAttenuationDb=0,o.currentSampleTime++,++C>=e.length)return;o.state++;case 3:for(;o.currentSampleTime<o.decayEnd;)if(o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a,o.currentAttenuationDb=(1-(o.decayEnd-o.currentSampleTime)/o.decayDuration)*o.sustainDbRelative,e[C]*=o.attenuation*JA(o.currentAttenuationDb+i),o.currentSampleTime++,++C>=e.length)return;o.state++;case 4:for(o.canEndOnSilentSustain&&o.sustainDbRelative>=As&&(A.finished=!0);;)if(o.attenuation+=(o.attenuationTargetGain-o.attenuation)*a,e[C]*=o.attenuation*JA(o.sustainDbRelative+i),o.currentAttenuationDb=o.sustainDbRelative,o.currentSampleTime++,++C>=e.length)return}}};var Re=class t{a0=0;a1=0;a2=0;a3=0;a4=0;x1=0;x2=0;y1=0;y2=0;reasonanceCb=0;reasonanceGain=1;cutoffCents=13501;cutoffHz=20001;static apply(A,e,s,n){if(n&&s>13499&&A.filter.reasonanceCb===0)return;let o=A.filter;(o.cutoffCents!==s||o.reasonanceCb!==A.modulatedGenerators[r.initialFilterQ])&&(o.cutoffCents=s,o.reasonanceCb=A.modulatedGenerators[r.initialFilterQ],t.calculateCoefficients(o));for(let i=0;i<e.length;i++){let a=e[i],C=o.a0*a+o.a1*o.x1+o.a2*o.x2-o.a3*o.y1-o.a4*o.y2;o.x2=o.x1,o.x1=a,o.y2=o.y1,o.y1=C,e[i]=C}}static calculateCoefficients(A){A.cutoffHz=ve(A.cutoffCents),A.cutoffHz=Math.min(A.cutoffHz,.45*sampleRate);let e=A.reasonanceCb/10;A.reasonanceGain=JA(-1*(e-3.01));let s=1/Math.sqrt(JA(-e)),n=2*Math.PI*A.cutoffHz/sampleRate,o=Math.cos(n),i=Math.sin(n)/(2*A.reasonanceGain),a=(1-o)*s,C=a/2,h=C,d=1+i,Q=-2*o,l=1-i;A.a0=C/d,A.a1=a/d,A.a2=h/d,A.a3=Q/d,A.a4=l/d}};var un=.05;function dn(t,A,e,s,n,o){if(A.isInRelease||currentTime>=A.releaseStartTime&&(A.isInRelease=!0,qA.startRelease(A),PA.startRelease(A),A.sample.loopingMode===3&&(A.sample.isLooping=!1)),A.modulatedGenerators[r.initialAttenuation]>2500){A.isInRelease&&(A.finished=!0);return}let i=A.targetKey,a=A.modulatedGenerators[r.fineTune]+t.customControllers[cA.channelTuning]+t.customControllers[cA.channelTransposeFine]+t.customControllers[cA.masterTuning]+t.channelOctaveTuning[A.midiNote%12]+t.keyCentTuning[A.midiNote],C=A.modulatedGenerators[r.coarseTune]+t.customControllers[cA.channelTuningSemitones],h=this.tunings[t.preset.program]?.[A.realKey];h?.midiNote>=0&&(i=h.midiNote,a+=h.centTuning),a+=(i-A.sample.rootKey)*A.modulatedGenerators[r.scaleTuning];let d=A.modulatedGenerators[r.vibLfoToPitch];if(d!==0){let I=A.startTime+VA(A.modulatedGenerators[r.delayVibLFO]),tA=ve(A.modulatedGenerators[r.freqVibLFO]),q=Et(I,tA,currentTime);a+=q*(d*t.customControllers[cA.modulationMultiplier])}let Q=A.modulatedGenerators[r.initialFilterFc],l=Q,c=A.modulatedGenerators[r.modLfoToPitch],f=A.modulatedGenerators[r.modLfoToVolume],M=A.modulatedGenerators[r.modLfoToFilterFc],D=0;if(c+M+f!==0){let I=A.startTime+VA(A.modulatedGenerators[r.delayModLFO]),tA=ve(A.modulatedGenerators[r.freqModLFO]),q=Et(I,tA,currentTime);a+=q*(c*t.customControllers[cA.modulationMultiplier]),D=-q*f,l+=q*M}if(t.channelVibrato.depth>0){let I=Et(A.startTime+t.channelVibrato.delay,t.channelVibrato.rate,currentTime);I&&(a+=I*t.channelVibrato.depth)}let v=A.modulatedGenerators[r.modEnvToPitch],y=A.modulatedGenerators[r.modEnvToFilterFc],w=PA.getValue(A,currentTime);l+=w*y,a+=w*v;let x=~~(a+C*100);x!==A.currentTuningCents&&(A.currentTuningCents=x,A.currentTuningCalculated=Math.pow(2,x/1200));let F=new Float32Array(e.length);switch(this.interpolationType){case Fe.linear:default:hn(A,F);break;case Fe.nearestNeighbor:cn(A,F);break;case Fe.fourthOrder:ln(A,F)}Re.apply(A,F,l,Q>13499),qA.apply(A,F,D,this.volumeEnvelopeSmoothingFactor),this.panVoice(A,F,e,s,n,o)}function ur(t,A){let e=0;return t.drumChannel&&(e+=5),A.isInRelease&&(e-=5),e+=A.velocity/25,e-=A.volumeEnvelope.state,A.isInRelease&&(e-=5),e-=A.volumeEnvelope.currentAttenuationDb/50,e}function fn(t){let A=[];for(let s of this.workletProcessorChannels)for(let n of s.voices)if(!n.finished){let o=ur(s,n);A.push({channel:s,voice:n,priority:o})}A.sort((s,n)=>s.priority-n.priority);let e=A.slice(0,t);for(let{channel:s,voice:n}of e){let o=s.voices.indexOf(n);o>-1&&s.voices.splice(o,1)}}function mn(t,A=pn){t.releaseStartTime=currentTime,t.releaseStartTime-t.startTime<A&&(t.releaseStartTime=t.startTime+A)}var zA=zA!==void 0?zA:{},yn=!1,Sn;zA.isInitialized=new Promise(t=>Sn=t);var dr=function(t){var A,e,s,n,o,i,a,C="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",h="",d=0;t=t.replace(/[^A-Za-z0-9\+\/\=]/g,"");do n=C.indexOf(t.charAt(d++)),o=C.indexOf(t.charAt(d++)),i=C.indexOf(t.charAt(d++)),a=C.indexOf(t.charAt(d++)),A=n<<2|o>>4,e=(15&o)<<4|i>>2,s=(3&i)<<6|a,h+=String.fromCharCode(A),i!==64&&(h+=String.fromCharCode(e)),a!==64&&(h+=String.fromCharCode(s));while(d<t.length);return h};(function(){var t,A,e,s,n,o,i,a,C,h,d,Q,l,c,f,M,D,v,y,w,x,F,I=I!==void 0?I:{};I.wasmBinary=Uint8Array.from(dr("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(E){return E.charCodeAt(0)});var I=I!==void 0?I:{},tA={};for(t in I)I.hasOwnProperty(t)&&(tA[t]=I[t]);I.arguments=[],I.thisProgram="./this.program",I.quit=function(E,B){throw B},I.preRun=[],I.postRun=[];var q=!1,iA=!1,V=!1,aA=!1;q=typeof window=="object",iA=typeof importScripts=="function",V=typeof process=="object"&&typeof Gs=="function"&&!q&&!iA,aA=!q&&!V&&!iA;var oA="";function eA(E){return I.locateFile?I.locateFile(E,oA):oA+E}V?(oA=__dirname+"/",I.read=function(B,u){var p;return A||(A=void 0),e||(e=void 0),B=e.normalize(B),p=A.readFileSync(B),u?p:p.toString()},I.readBinary=function(B){var u=I.read(B,!0);return u.buffer||(u=new Uint8Array(u)),se(u.buffer),u},process.argv.length>1&&(I.thisProgram=process.argv[1].replace(/\\/g,"/")),I.arguments=process.argv.slice(2),typeof module<"u",process.on("uncaughtException",function(E){if(!(E instanceof Ne))throw E}),process.on("unhandledRejection",function(E,B){process.exit(1)}),I.quit=function(E){process.exit(E)},I.inspect=function(){return"[Emscripten Module object]"}):aA?(typeof read<"u"&&(I.read=function(B){return read(B)}),I.readBinary=function(B){var u;return typeof readbuffer=="function"?new Uint8Array(readbuffer(B)):(se(typeof(u=read(B,"binary"))=="object"),u)},typeof scriptArgs<"u"?I.arguments=scriptArgs:typeof arguments<"u"&&(I.arguments=arguments),typeof quit=="function"&&(I.quit=function(E){quit(E)})):(q||iA)&&(q?document.currentScript&&(oA=document.currentScript.src):oA=self.location.href,oA=oA.indexOf("blob:")!==0?oA.split("/").slice(0,-1).join("/")+"/":"",I.read=function(B){var u=new XMLHttpRequest;return u.open("GET",B,!1),u.send(null),u.responseText},iA&&(I.readBinary=function(B){var u=new XMLHttpRequest;return u.open("GET",B,!1),u.responseType="arraybuffer",u.send(null),new Uint8Array(u.response)}),I.readAsync=function(B,u,p){var U=new XMLHttpRequest;U.open("GET",B,!0),U.responseType="arraybuffer",U.onload=function(){if(U.status==200||U.status==0&&U.response){u(U.response);return}p()},U.onerror=p,U.send(null)},I.setWindowTitle=function(E){document.title=E});var AA=I.print||(typeof console<"u"?console.log.bind(console):typeof print<"u"?print:null),hA=I.printErr||(typeof printErr<"u"?printErr:typeof console<"u"&&console.warn.bind(console)||AA);for(t in tA)tA.hasOwnProperty(t)&&(I[t]=tA[t]);function fA(E){var B=c;return c=c+E+15&-16,B}function wt(E){var B=C[w>>2],u=B+E+15&-16;return C[w>>2]=u,u>=pA&&!fs()?(C[w>>2]=B,0):B}function de(E,B){return B||(B=16),E=Math.ceil(E/B)*B}function te(E){switch(E){case"i1":case"i8":return 1;case"i16":return 2;case"i32":case"float":return 4;case"i64":case"double":return 8;default:if(E[E.length-1]==="*")return 4;if(E[0]!=="i")return 0;var B=parseInt(E.substr(1));return se(B%8==0),B/8}}function Ge(E){Ge.shown||(Ge.shown={}),Ge.shown[E]||(Ge.shown[E]=1,hA(E))}tA=void 0;var er={"f64-rem":function(E,B){return E%B},debugger:function(){}},Ft=[];function Nr(E,B){for(var u=0,p=u;p<u+0;p++)if(!Ft[p])return Ft[p]=E,1+p;throw"Finished up all reserved function pointers. Use a higher value for RESERVED_FUNCTION_POINTERS."}function br(E){Ft[E-1]=null}var Rt={};function Lr(E,B){if(E){se(B),Rt[B]||(Rt[B]={});var u=Rt[B];return u[E]||(B.length===1?u[E]=function(){return Gt(B,E)}:B.length===2?u[E]=function(U){return Gt(B,E,[U])}:u[E]=function(){return Gt(B,E,Array.prototype.slice.call(arguments))}),u[E]}}function Ur(E,B,u){return u?+(E>>>0)+4294967296*+(B>>>0):+(E>>>0)+4294967296*+(0|B)}function Gt(E,B,u){return u&&u.length?I["dynCall_"+E].apply(null,[B].concat(u)):I["dynCall_"+E].call(null,B)}var qe=0,Cs=0;function se(E,B){E||jA("Assertion failed: "+B)}function Bs(E){var B=I["_"+E];return se(B,"Cannot call unknown function "+E+", make sure it is exported"),B}var hs={stackSave:function(){vt()},stackRestore:function(){Tt()},arrayToC:function(E){var B,u,p=Xe(E.length);return B=E,u=p,n.set(B,u),p},stringToC:function(E){var B=0;if(E!=null&&E!==0){var u=(E.length<<2)+1;B=Xe(u),Qs(E,B,u)}return B}},tr={string:hs.stringToC,array:hs.arrayToC};function cs(E,B,u,p,U){var _=Bs(E),$=[],Y=0;if(p)for(var yA=0;yA<p.length;yA++){var EA=tr[u[yA]];EA?(Y===0&&(Y=vt()),$[yA]=EA(p[yA])):$[yA]=p[yA]}var CA,gA=_.apply(null,$);return gA=(CA=gA,B==="string"?Ke(CA):B==="boolean"?!!CA:CA),Y!==0&&Tt(Y),gA}function sr(E,B,u,p){switch((u=u||"i8").charAt(u.length-1)==="*"&&(u="i32"),u){case"i1":case"i8":n[E>>0]=B;break;case"i16":i[E>>1]=B;break;case"i32":C[E>>2]=B;break;case"i64":tempI64=[B>>>0,+ar(tempDouble=B)>=1?tempDouble>0?(0|Ir(+Ds(tempDouble/4294967296),4294967295))>>>0:~~+gr((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0],C[E>>2]=tempI64[0],C[E+4>>2]=tempI64[1];break;case"float":d[E>>2]=B;break;case"double":Q[E>>3]=B;break;default:jA("invalid type for setValue: "+u)}}function Tr(E,B,u){switch((B=B||"i8").charAt(B.length-1)==="*"&&(B="i32"),B){case"i1":case"i8":return n[E>>0];case"i16":return i[E>>1];case"i32":case"i64":return C[E>>2];case"float":return d[E>>2];case"double":return Q[E>>3];default:jA("invalid type for getValue: "+B)}return null}function vr(E,B,u,p){typeof E=="number"?(_=!0,$=E):(_=!1,$=E.length);var U=typeof B=="string"?B:null;if(Y=u==4?p:[typeof We=="function"?We:fA,Xe,fA,wt][u===void 0?2:u](Math.max($,U?1:B.length)),_){for(p=Y,se((3&Y)==0),yA=Y+(-4&$);p<yA;p+=4)C[p>>2]=0;for(yA=Y+$;p<yA;)n[p++>>0]=0;return Y}if(U==="i8")return E.subarray||E.slice?o.set(E,Y):o.set(new Uint8Array(E),Y),Y;for(var _,$,Y,yA,EA,CA,gA,X=0;X<$;){var GA=E[X];if((EA=U||B[X])===0){X++;continue}EA=="i64"&&(EA="i32"),sr(Y+X,GA,EA),gA!==EA&&(CA=te(EA),gA=EA),X+=CA}return Y}function Hr(E){return f?Lt?We(E):wt(E):fA(E)}function Ke(E,B){if(B===0||!E)return"";for(var u,p,U,_=0,$=0;_|=p=o[E+$>>0],(p!=0||B)&&($++,!B||$!=B););B||(B=$);var Y="";if(_<128){for(;B>0;)U=String.fromCharCode.apply(String,o.subarray(E,E+Math.min(B,1024))),Y=Y?Y+U:U,E+=1024,B-=1024;return Y}return u=E,function(EA,CA){for(var gA=CA;EA[gA];)++gA;if(gA-CA>16&&EA.subarray&&ls)return ls.decode(EA.subarray(CA,gA));for(var X,GA,TA,vA,HA,Ce,YA="";;){if(!(X=EA[CA++]))return YA;if(!(128&X)){YA+=String.fromCharCode(X);continue}if(GA=63&EA[CA++],(224&X)==192){YA+=String.fromCharCode((31&X)<<6|GA);continue}if(TA=63&EA[CA++],(240&X)==224?X=(15&X)<<12|GA<<6|TA:(vA=63&EA[CA++],(248&X)==240?X=(7&X)<<18|GA<<12|TA<<6|vA:(HA=63&EA[CA++],X=(252&X)==248?(3&X)<<24|GA<<18|TA<<12|vA<<6|HA:(1&X)<<30|GA<<24|TA<<18|vA<<12|HA<<6|(Ce=63&EA[CA++]))),X<65536)YA+=String.fromCharCode(X);else{var be=X-65536;YA+=String.fromCharCode(55296|be>>10,56320|1023&be)}}}(o,u)}function Yr(E){for(var B="";;){var u=n[E++>>0];if(!u)return B;B+=String.fromCharCode(u)}}function Jr(E,B){return function(p,U,_){for(var $=0;$<p.length;++$)n[U++>>0]=p.charCodeAt($);_||(n[U>>0]=0)}(E,B,!1)}var ls=typeof TextDecoder<"u"?new TextDecoder("utf8"):void 0;function Oe(E,B,u,p){if(!(p>0))return 0;for(var U=u,_=u+p-1,$=0;$<E.length;++$){var Y=E.charCodeAt($);if(Y>=55296&&Y<=57343&&(Y=65536+((1023&Y)<<10)|1023&E.charCodeAt(++$)),Y<=127){if(u>=_)break;B[u++]=Y}else if(Y<=2047){if(u+1>=_)break;B[u++]=192|Y>>6,B[u++]=128|63&Y}else if(Y<=65535){if(u+2>=_)break;B[u++]=224|Y>>12,B[u++]=128|Y>>6&63,B[u++]=128|63&Y}else if(Y<=2097151){if(u+3>=_)break;B[u++]=240|Y>>18,B[u++]=128|Y>>12&63,B[u++]=128|Y>>6&63,B[u++]=128|63&Y}else if(Y<=67108863){if(u+4>=_)break;B[u++]=248|Y>>24,B[u++]=128|Y>>18&63,B[u++]=128|Y>>12&63,B[u++]=128|Y>>6&63,B[u++]=128|63&Y}else{if(u+5>=_)break;B[u++]=252|Y>>30,B[u++]=128|Y>>24&63,B[u++]=128|Y>>18&63,B[u++]=128|Y>>12&63,B[u++]=128|Y>>6&63,B[u++]=128|63&Y}}return B[u]=0,u-U}function Qs(E,B,u){return Oe(E,o,B,u)}function Ve(E){for(var B=0,u=0;u<E.length;++u){var p=E.charCodeAt(u);p>=55296&&p<=57343&&(p=65536+((1023&p)<<10)|1023&E.charCodeAt(++u)),p<=127?++B:p<=2047?B+=2:p<=65535?B+=3:p<=2097151?B+=4:p<=67108863?B+=5:B+=6}return B}var us=typeof TextDecoder<"u"?new TextDecoder("utf-16le"):void 0;function Pr(E){for(var B=E,u=B>>1;i[u];)++u;if((B=u<<1)-E>32&&us)return us.decode(o.subarray(E,B));for(var p=0,U="";;){var _=i[E+2*p>>1];if(_==0)return U;++p,U+=String.fromCharCode(_)}}function qr(E,B,u){if(u===void 0&&(u=2147483647),u<2)return 0;for(var p=B,U=(u-=2)<2*E.length?u/2:E.length,_=0;_<U;++_){var $=E.charCodeAt(_);i[B>>1]=$,B+=2}return i[B>>1]=0,B-p}function Kr(E){return 2*E.length}function Or(E){for(var B=0,u="";;){var p=C[E+4*B>>2];if(p==0)return u;if(++B,p>=65536){var U=p-65536;u+=String.fromCharCode(55296|U>>10,56320|1023&U)}else u+=String.fromCharCode(p)}}function Vr(E,B,u){if(u===void 0&&(u=2147483647),u<4)return 0;for(var p=B,U=p+u-4,_=0;_<E.length;++_){var $=E.charCodeAt(_);if($>=55296&&$<=57343&&($=65536+((1023&$)<<10)|1023&E.charCodeAt(++_)),C[B>>2]=$,(B+=4)+4>U)break}return C[B>>2]=0,B-p}function Zr(E){for(var B=0,u=0;u<E.length;++u){var p=E.charCodeAt(u);p>=55296&&p<=57343&&++u,B+=4}return B}function Wr(E){var B=Ve(E)+1,u=We(B);return u&&Oe(E,n,u,B),u}function Xr(E){var B=Ve(E)+1,u=Xe(B);return Oe(E,n,u,B),u}function _r(E){return E}function zr(){var E,B=function(){var p=Error();if(!p.stack){try{throw Error(0)}catch(U){p=U}if(!p.stack)return"(no stack trace available)"}return p.stack.toString()}();return I.extraStackTrace&&(B+=`
|
|
14
|
+
`+I.extraStackTrace()),(E=B).replace(/__Z[\w\d_]+/g,function(u){var p,U=p=u;return u===U?u:u+" ["+U+"]"})}function xt(E,B){return E%B>0&&(E+=B-E%B),E}function ds(E){I.buffer=s=E}function Mt(){I.HEAP8=n=new Int8Array(s),I.HEAP16=i=new Int16Array(s),I.HEAP32=C=new Int32Array(s),I.HEAPU8=o=new Uint8Array(s),I.HEAPU16=a=new Uint16Array(s),I.HEAPU32=h=new Uint32Array(s),I.HEAPF32=d=new Float32Array(s),I.HEAPF64=Q=new Float64Array(s)}function fs(){var E=I.usingWasm?65536:16777216,B=2147483648-E;if(C[w>>2]>B)return!1;var u=pA;for(pA=Math.max(pA,16777216);pA<C[w>>2];)pA=pA<=536870912?xt(2*pA,E):Math.min(xt((3*pA+2147483648)/4,E),B);var p=I.reallocBuffer(pA);return p&&p.byteLength==pA?(ds(p),Mt(),!0):(pA=u,!1)}l=c=M=D=v=y=w=0,f=!1,I.reallocBuffer||(I.reallocBuffer=function(E){try{if(ArrayBuffer.transfer)B=ArrayBuffer.transfer(s,E);else{var B,u=n;B=new ArrayBuffer(E),new Int8Array(B).set(u)}}catch{return!1}return!!Er(B)&&B});try{(x=Function.prototype.call.bind(Object.getOwnPropertyDescriptor(ArrayBuffer.prototype,"byteLength").get))(new ArrayBuffer(4))}catch{x=function(B){return B.byteLength}}var Nt=I.TOTAL_STACK||5242880,pA=I.TOTAL_MEMORY||16777216;function nr(){return pA}function xe(E){for(;E.length>0;){var B=E.shift();if(typeof B=="function"){B();continue}var u=B.func;typeof u=="number"?B.arg===void 0?I.dynCall_v(u):I.dynCall_vi(u,B.arg):u(B.arg===void 0?null:B.arg)}}pA<Nt&&hA("TOTAL_MEMORY should be larger than TOTAL_STACK, was "+pA+"! (TOTAL_STACK="+Nt+")"),I.buffer?s=I.buffer:(typeof WebAssembly=="object"&&typeof WebAssembly.Memory=="function"?(I.wasmMemory=new WebAssembly.Memory({initial:pA/65536}),s=I.wasmMemory.buffer):s=new ArrayBuffer(pA),I.buffer=s),Mt();var ms=[],bt=[],ps=[],ys=[],Ss=[],Lt=!1,or=!1;function rr(E){ms.unshift(E)}function jr(E){bt.unshift(E)}function $r(E){ps.unshift(E)}function Ai(E){ys.unshift(E)}function ir(E){Ss.unshift(E)}function ei(E,B,u){var p,U;Ge("writeStringToMemory is deprecated and should not be called! Use stringToUTF8() instead!"),u&&(p=n[U=B+Ve(E)]),Qs(E,B,1/0),u&&(n[U]=p)}function ti(E,B,u){return E>=0?E:B<=32?2*Math.abs(1<<B-1)+E:Math.pow(2,B)+E}function si(E,B,u){if(E<=0)return E;var p=B<=32?Math.abs(1<<B-1):Math.pow(2,B-1);return E>=p&&(B<=32||E>p)&&(E=-2*p+E),E}var ar=Math.abs,gr=Math.ceil,Ds=Math.floor,Ir=Math.min,Ee=0,Ut=null,Me=null;function ni(E){return E}I.preloadedImages={},I.preloadedAudios={};var ks="data:application/octet-stream;base64,";function Ze(E){return String.prototype.startsWith?E.startsWith(ks):E.indexOf(ks)===0}(function(){var B="main.wast",u="main.wasm",p="main.temp.asm.js";Ze(B)||(B=eA(B)),Ze(u)||(u=eA(u)),Ze(p)||(p=eA(p));var U={global:null,env:null,asm2wasm:er,parent:I},_=null;function $(gA){return gA}function Y(){try{if(I.wasmBinary)return new Uint8Array(I.wasmBinary);if(I.readBinary)return I.readBinary(u);throw"both async and sync fetching of the wasm failed"}catch(gA){jA(gA)}}I.asmPreload=I.asm;var yA=I.reallocBuffer,EA=function(gA){gA=xt(gA,I.usingWasm?65536:16777216);var X=I.buffer.byteLength;if(I.usingWasm)try{var GA=I.wasmMemory.grow((gA-X)/65536);return GA!==-1?I.buffer=I.wasmMemory.buffer:null}catch{return null}};I.reallocBuffer=function(gA){return CA==="asmjs"?yA(gA):EA(gA)};var CA="";I.asm=function(gA,X,GA){var TA;if(!(X=TA=X).table){var vA,HA=I.wasmTableSize;HA===void 0&&(HA=1024);var Ce=I.wasmMaxTableSize;typeof WebAssembly=="object"&&typeof WebAssembly.Table=="function"?Ce!==void 0?X.table=new WebAssembly.Table({initial:HA,maximum:Ce,element:"anyfunc"}):X.table=new WebAssembly.Table({initial:HA,element:"anyfunc"}):X.table=Array(HA),I.wasmTable=X.table}return X.memoryBase||(X.memoryBase=I.STATIC_BASE),X.tableBase||(X.tableBase=0),vA=function(be,fe,Yt){if(typeof WebAssembly!="object")return hA("no native wasm support detected"),!1;if(!(I.wasmMemory instanceof WebAssembly.Memory))return hA("no native wasm Memory in use"),!1;function _e(ZA,WA){if((_=ZA.exports).memory){var Le,Jt,Rs;Le=_.memory,Jt=I.buffer,Le.byteLength<Jt.byteLength&&hA("the new buffer in mergeMemory is smaller than the previous one. in native wasm, we should grow memory here"),Rs=new Int8Array(Jt),new Int8Array(Le).set(Rs),ds(Le),Mt()}I.asm=_,I.usingWasm=!0,function(Ei){if(Ee--,I.monitorRunDependencies&&I.monitorRunDependencies(Ee),Ee==0&&(Ut!==null&&(clearInterval(Ut),Ut=null),Me)){var Cr=Me;Me=null,Cr()}}("wasm-instantiate")}if(fe.memory=I.wasmMemory,U.global={NaN:NaN,Infinity:1/0},U["global.Math"]=Math,U.env=fe,Ee++,I.monitorRunDependencies&&I.monitorRunDependencies(Ee),I.instantiateWasm)try{return I.instantiateWasm(U,_e)}catch(ZA){return hA("Module.instantiateWasm callback failed with error: "+ZA),!1}function me(ZA){_e(ZA.instance,ZA.module)}function Fs(ZA){(!I.wasmBinary&&(q||iA)&&typeof fetch=="function"?fetch(u,{credentials:"same-origin"}).then(function(WA){if(!WA.ok)throw"failed to load wasm binary file at '"+u+"'";return WA.arrayBuffer()}).catch(function(){return Y()}):new Promise(function(WA,Le){WA(Y())})).then(function(WA){return WebAssembly.instantiate(WA,U)}).then(ZA).catch(function(WA){hA("failed to asynchronously prepare wasm: "+WA),jA(WA)})}return I.wasmBinary||typeof WebAssembly.instantiateStreaming!="function"||Ze(u)||typeof fetch!="function"?Fs(me):WebAssembly.instantiateStreaming(fetch(u,{credentials:"same-origin"}),U).then(me).catch(function(ZA){hA("wasm streaming compile failed: "+ZA),hA("falling back to ArrayBuffer instantiation"),Fs(me)}),{}}(gA,X,GA),se(vA,"no binaryen method succeeded."),vA},I.asm})(),c=(l=1024)+4816,bt.push(),I.STATIC_BASE=l,I.STATIC_BUMP=4816;var NA=c;function oi(E){n[NA]=n[E],n[NA+1]=n[E+1],n[NA+2]=n[E+2],n[NA+3]=n[E+3]}function ri(E){n[NA]=n[E],n[NA+1]=n[E+1],n[NA+2]=n[E+2],n[NA+3]=n[E+3],n[NA+4]=n[E+4],n[NA+5]=n[E+5],n[NA+6]=n[E+6],n[NA+7]=n[E+7]}function ii(E,B,u){var p=u>0?u:Ve(E)+1,U=Array(p),_=Oe(E,U,0,U.length);return B&&(U.length=_),U}function ai(E){for(var B=[],u=0;u<E.length;u++){var p=E[u];p>255&&(p&=255),B.push(String.fromCharCode(p))}return B.join("")}c+=16,w=fA(4),v=(M=D=de(c))+Nt,y=de(v),C[w>>2]=y,f=!0,I.wasmTableSize=4,I.wasmMaxTableSize=4,I.asmGlobalArg={},I.asmLibraryArg={abort:jA,assert:se,enlargeMemory:fs,getTotalMemory:nr,abortOnCannotGrowMemory:function(){jA("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_MEMORY=X with X higher than the current value "+pA+", (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(B,u,p){var U=vt();try{return I.dynCall_iii(B,u,p)}catch(_){if(Tt(U),typeof _!="number"&&_!=="longjmp")throw _;I.setThrew(1,0)}},___assert_fail:function(B,u,p,U){jA("Assertion failed: "+Ke(B)+", at: "+[u?Ke(u):"unknown filename",p,U?Ke(U):"unknown function"])},___setErrNo:function(B){return I.___errno_location&&(C[I.___errno_location()>>2]=B),B},_abort:function(){I.abort()},_emscripten_memcpy_big:function(B,u,p){return o.set(o.subarray(u,u+p),B),B},_llvm_floor_f64:Ds,DYNAMICTOP_PTR:w,tempDoublePtr:NA,ABORT:qe,STACKTOP:D,STACK_MAX:v};var ws=I.asm(I.asmGlobalArg,I.asmLibraryArg,s);I.asm=ws,I.___errno_location=function(){return I.asm.___errno_location.apply(null,arguments)};var Er=I._emscripten_replace_memory=function(){return I.asm._emscripten_replace_memory.apply(null,arguments)};I._free=function(){return I.asm._free.apply(null,arguments)};var We=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 Xe=I.stackAlloc=function(){return I.asm.stackAlloc.apply(null,arguments)},Tt=I.stackRestore=function(){return I.asm.stackRestore.apply(null,arguments)},vt=I.stackSave=function(){return I.asm.stackSave.apply(null,arguments)};function Ne(E){this.name="ExitStatus",this.message="Program terminated with exit("+E+")",this.status=E}function Ht(E){E=E||I.arguments,!(Ee>0)&&(function(){if(I.preRun)for(typeof I.preRun=="function"&&(I.preRun=[I.preRun]);I.preRun.length;)rr(I.preRun.shift());xe(ms)}(),!(Ee>0)&&(I.calledRun||(I.setStatus?(I.setStatus("Running..."),setTimeout(function(){setTimeout(function(){I.setStatus("")},1),B()},1)):B())));function B(){!I.calledRun&&(I.calledRun=!0,qe||(Lt||(Lt=!0,xe(bt)),xe(ps),I.onRuntimeInitialized&&I.onRuntimeInitialized(),function(){if(I.postRun)for(typeof I.postRun=="function"&&(I.postRun=[I.postRun]);I.postRun.length;)ir(I.postRun.shift());xe(Ss)}()))}}function gi(E,B){(!B||!I.noExitRuntime||E!==0)&&(I.noExitRuntime||(qe=!0,Cs=E,D=F,xe(ys),or=!0,I.onExit&&I.onExit(E)),I.quit(E,new Ne(E)))}function jA(E){throw I.onAbort&&I.onAbort(E),E!==void 0?(AA(E),hA(E),E=JSON.stringify(E)):E="",qe=!0,Cs=1,"abort("+E+"). Build with -s ASSERTIONS=1 for more info."}if(I.dynCall_iii=function(){return I.asm.dynCall_iii.apply(null,arguments)},I.asm=ws,I.ccall=cs,I.cwrap=function(B,u,p,U){var _=(p=p||[]).every(function($){return $==="number"});return u!=="string"&&_&&!U?Bs(B):function(){return cs(B,u,p,arguments,U)}},Ne.prototype=Error(),Ne.prototype.constructor=Ne,Me=function E(){I.calledRun||Ht(),I.calledRun||(Me=E)},I.run=Ht,I.abort=jA,I.preInit)for(typeof I.preInit=="function"&&(I.preInit=[I.preInit]);I.preInit.length>0;)I.preInit.pop()();I.noExitRuntime=!0,Ht(),I.onRuntimeInitialized=()=>{yn=!0,Sn()},zA.decode=function(E){return function(u){if(!yn)throw Error("Not initialized");var p={};function U(fe){return new Int32Array(I.HEAPU8.buffer,fe,1)[0]}function _(fe,Yt){var _e=new ArrayBuffer(Yt*Float32Array.BYTES_PER_ELEMENT),me=new Float32Array(_e);return me.set(new Float32Array(I.HEAPU8.buffer,fe,Yt)),me}p.open=I.cwrap("stb_vorbis_js_open","number",[]),p.close=I.cwrap("stb_vorbis_js_close","void",["number"]),p.channels=I.cwrap("stb_vorbis_js_channels","number",["number"]),p.sampleRate=I.cwrap("stb_vorbis_js_sample_rate","number",["number"]),p.decode=I.cwrap("stb_vorbis_js_decode","number",["number","number","number","number","number"]);var $,Y,yA,EA,CA=p.open(),gA=($=u,Y=u.byteLength,yA=I._malloc(Y),(EA=new Uint8Array(I.HEAPU8.buffer,yA,Y)).set(new Uint8Array($,0,Y)),EA),X=I._malloc(4),GA=I._malloc(4),TA=p.decode(CA,gA.byteOffset,gA.byteLength,X,GA);if(I._free(gA.byteOffset),TA<0)throw p.close(CA),I._free(X),Error("stbvorbis decode failed: "+TA);for(var vA=p.channels(CA),HA=Array(vA),Ce=new Int32Array(I.HEAPU32.buffer,U(X),vA),YA=0;YA<vA;YA++)HA[YA]=_(Ce[YA],TA),I._free(Ce[YA]);var be=p.sampleRate(CA);return p.close(CA),I._free(U(X)),I._free(X),{data:HA,sampleRate:be,eof:!0,error:null}}(E)}})();function Dn(t){let A=t.messageData,e=t.channelNumber,s={};switch(e>=0&&(s=this.workletProcessorChannels[e]),t.messageType){case nA.noteOn:this.noteOn(e,A[0],A[1],A[2]);break;case nA.noteOff:this.noteOff(e,A);break;case nA.pitchWheel:this.pitchWheel(e,A[0],A[1]);break;case nA.ccChange:this.controllerChange(e,A[0],A[1],A[2]);break;case nA.customcCcChange:s.customControllers[A[0]]=A[1];break;case nA.killNote:this.killNote(e,A);break;case nA.programChange:this.programChange(e,A[0],A[1]);break;case nA.channelPressure:this.channelPressure(e,A);break;case nA.polyPressure:this.polyPressure(e,A[0],A[1]);break;case nA.ccReset:e===KA?this.resetAllControllers():this.resetControllers(e);break;case nA.systemExclusive:this.systemExclusive(A);break;case nA.setChannelVibrato:if(e===KA)for(let i=0;i<this.workletProcessorChannels.length;i++)A.rate===-1?this.disableAndLockGSNRPN(i):this.setVibrato(i,A.depth,A.rate,A.delay);else A.rate===-1?this.disableAndLockGSNRPN(e):this.setVibrato(e,A.depth,A.rate,A.delay);break;case nA.stopAll:e===KA?this.stopAllChannels(A===1):this.stopAll(e,A===1);break;case nA.killNotes:this.voiceKilling(A);break;case nA.muteChannel:this.muteChannel(e,A);break;case nA.addNewChannel:this.createWorkletChannel(!0);break;case nA.debugMessage:this.debugMessage();break;case nA.setMasterParameter:let n=A[0],o=A[1];switch(n){case ye.masterPan:this.setMasterPan(o);break;case ye.mainVolume:this.setMasterGain(o);break;case ye.voicesCap:this.voiceCap=o;break;case ye.interpolationType:this.interpolationType=o;break}break;case nA.setDrums:this.setDrums(e,A);break;case nA.transpose:e===KA?this.transposeAllChannels(A[0],A[1]):this.transposeChannel(e,A[0],A[1]);break;case nA.highPerformanceMode:this.highPerformanceMode=A;break;case nA.lockController:A[0]===KA?s.lockPreset=A[1]:s.lockedControllers[A[0]]=A[1];break;case nA.sequencerSpecific:this.sequencer.processMessage(A.messageType,A.messageData);break;case nA.soundFontManager:try{this.soundfontManager.handleMessage(A[0],A[1])}catch(i){this.post({messageType:kA.soundfontError,messageData:i})}this.clearSoundFont(!0,!1);break;case nA.keyModifierManager:this.keyModifierManager.handleMessage(A[0],A[1]);break;case nA.requestSynthesizerSnapshot:this.sendSynthesizerSnapshot();break;case nA.setLogLevel:vs(A[0],A[1],A[2],A[3]);break;case nA.setEffectsGain:this.reverbGain=A[0],this.chorusGain=A[1];break;case nA.destroyWorklet:this.alive=!1;break;default:T("Unrecognized event:",A);break}}function kn(t,A){this.enableEventSystem&&this.post({messageType:kA.eventCall,messageData:{eventName:t,eventData:A}})}function wn(){if(!this.enableEventSystem)return;let t=this.workletProcessorChannels.map(A=>{let e=(A.midiControllers[dA+K.pitchWheelRange]>>7)+(A.midiControllers[dA+K.pitchWheelRange]&127)/127;return{voicesAmount:A.voices.length,pitchBend:A.midiControllers[dA+K.pitchWheel],pitchBendRangeSemitones:e,isMuted:A.isMuted,isDrum:A.drumChannel}});this.post({messageType:kA.channelProperties,messageData:t})}function fr(t,A,e){let s=t,n=A<<7|e;return t===127&&A===127&&e===127?{midiNote:-1,centTuning:null}:{midiNote:s,centTuning:n*.0061}}var es={SoundCanvasText:0,XGText:1,SoundCanvasDotDisplay:2};function Fn(t,A=0){let e=t[0];if(!(this.deviceID!==KA&&t[1]!==127&&this.deviceID!==t[1]))switch(e){default:T(`%cUnrecognized SysEx: %c${DA(t)}`,g.warn,g.unrecognized);break;case 126:case 127:switch(t[2]){case 4:let n;switch(t[3]){case 1:let o=t[5]<<7|t[4];this.setMIDIVolume(o/16384),m(`%cMaster Volume. Volume: %c${o}`,g.info,g.value);break;case 2:let a=((t[5]<<7|t[4])-8192)/8192;this.setMasterPan(a),m(`%cMaster Pan. Pan: %c${a}`,g.info,g.value);break;case 3:let C=(t[5]<<7|t[6])-8192;n=Math.floor(C/81.92),this.setMasterTuning(n),m(`%cMaster Fine Tuning. Cents: %c${n}`,g.info,g.value);break;case 4:n=(t[5]-64)*100,this.setMasterTuning(n),m(`%cMaster Coarse Tuning. Cents: %c${n}`,g.info,g.value);break;default:T(`%cUnrecognized MIDI Device Control Real-time message: %c${DA(t)}`,g.warn,g.unrecognized)}break;case 9:t[3]===1?(m("%cGM system on",g.info),this.system="gm"):t[3]===3?(m("%cGM2 system on",g.info),this.system="gm2"):(m("%cGM system off, defaulting to GS",g.info),this.system="gs");break;case 8:switch(t[3]){case 2:case 7:let o=4;t[3]===7&&o++;let i=t[o++],a=t[o++];for(let h=0;h<a;h++)this.tunings[i][t[o++]]=fr(t[o++],t[o++],t[o++]);m(`%cSingle Note Tuning. Program: %c${i}%c Keys affected: %c${a}`,g.info,g.recognized,g.info,g.recognized);break;case 9:case 8:let C=new Int8Array(12);if(t[3]===8)for(let h=0;h<12;h++)C[h]=t[7+h]-64;else for(let h=0;h<24;h+=2){let d=(t[7+h]<<7|t[8+h])-8192;C[h/2]=Math.floor(d/81.92)}(t[4]&1)===1&&this.setOctaveTuning(14+A,C),(t[4]>>1&1)===1&&this.setOctaveTuning(15+A,C);for(let h=0;h<7;h++)(t[5]>>h&1)===1&&this.setOctaveTuning(7+h+A,C);for(let h=0;h<7;h++)(t[6]>>h&1)===1&&this.setOctaveTuning(h+A,C);m(`%cMIDI Octave Scale ${t[3]===8?"(1 byte)":"(2 bytes)"} tuning via Tuning: %c${C.join(" ")}`,g.info,g.value);break;default:T(`%cUnrecognized MIDI Tuning standard message: %c${DA(t)}`,g.warn,g.unrecognized);break}break;default:T(`%cUnrecognized MIDI Realtime/non realtime message: %c${DA(t)}`,g.warn,g.unrecognized)}break;case 65:let s=function(){T(`%cUnrecognized Roland %cGS %cSysEx: %c${DA(t)}`,g.warn,g.recognized,g.warn,g.unrecognized)};if(t[2]===66&&t[3]===18){let n=t[7];if(t[6]===127){n===0?(m("%cGS Reset received!",g.info),this.resetAllControllers(!1),this.system="gs"):n===127&&(m("%cGS system off, switching to GM2",g.info),this.resetAllControllers(!1),this.system="gm2");return}else if(t[4]===64){if((t[5]&16)>0){let o=[9,0,1,2,3,4,5,6,7,8,10,11,12,13,14,15][t[5]&15]+A;switch(t[6]){default:s();break;case 21:let i=n>0&&t[5]>>4;this.setDrums(o,i),m(`%cChannel %c${o}%c ${i?"is now a drum channel":"now isn't a drum channel"}%c via: %c${DA(t)}`,g.info,g.value,g.recognized,g.info,g.value);return;case 22:let a=n-64;this.transposeChannel(o,a),m(`%cChannel %c${o}%c pitch shift. Semitones %c${a}%c, with %c${DA(t)}`,g.info,g.recognized,g.info,g.value,g.info,g.value);return;case 28:let C=n;C===0&&(C=Math.floor(Math.random()*128)),this.controllerChange(o,k.pan,C);break;case 33:this.controllerChange(o,k.chorusDepth,n);break;case 34:this.controllerChange(o,k.reverbDepth,n);break;case 64:case 65:case 66:case 67:case 68:case 69:case 70:case 71:case 72:case 73:case 74:case 75:let h=t.length-9,d=new Int8Array(12);for(let l=0;l<h;l++)d[l]=t[l+7]-64;this.setOctaveTuning(o,d);let Q=n-64;m(`%cChannel %c${o}%c octave scale tuning. Cents %c${d.join(" ")}%c, with %c${DA(t)}`,g.info,g.recognized,g.info,g.value,g.info,g.value),this.setChannelTuning(o,Q);break}return}else if(t[5]===0&&t[6]===6){m(`%cRoland GS Master Pan set to: %c${n}%c with: %c${DA(t)}`,g.info,g.value,g.info,g.value),this.setMasterPan((n-64)/64);return}else if(t[5]===0&&t[6]===5){let o=n-64;m(`%cRoland GS Master Key-Shift set to: %c${o}%c with: %c${DA(t)}`,g.info,g.value,g.info,g.value),this.setMasterTuning(o*100);return}else if(t[5]===0&&t[6]===4){m(`%cRoland GS Master Volume set to: %c${n}%c with: %c${DA(t)}`,g.info,g.value,g.info,g.value),this.setMIDIVolume(n/127);return}}s();return}else if(t[2]===69&&t[3]===18){if(t[4]===16&&t[6]===0)if(t[5]===0){let n=new Uint8Array(t.slice(7,t.length-2));this.callEvent("synthdisplay",{displayData:n,displayType:es.SoundCanvasText})}else if(t[5]===1){let n=new Uint8Array(t.slice(7,t.length-3));this.callEvent("synthdisplay",{displayData:n,displayType:es.SoundCanvasDotDisplay}),m(`%cRoland SC Display Dot Matrix via: %c${DA(t)}`,g.info,g.value)}else s()}else if(t[2]===22&&t[3]===18&&t[4]===16){this.setMIDIVolume(t[7]/100),m(`%cRoland Master Volume control set to: %c${t[7]}%c via: %c${DA(t)}`,g.info,g.value,g.info,g.value);return}else{T(`%cUnrecognized Roland SysEx: %c${DA(t)}`,g.warn,g.unrecognized);return}break;case 67:if(t[2]===76)if(t[3]===0&&t[4]===0)switch(t[5]){case 4:let n=t[6];this.setMIDIVolume(n/127),m(`%cXG master volume. Volume: %c${n}`,g.info,g.recognized);break;case 6:let o=t[6]-64;this.transposeAllChannels(o),m(`%cXG master transpose. Volume: %c${o}`,g.info,g.recognized);break;case 126:m("%cXG system on",g.info),this.resetAllControllers(!1),this.system="xg";break}else if(t[3]===8){if(this.system!=="xg")return;let n=t[4]+A;if(n>=this.workletProcessorChannels.length)return;let o=t[6];switch(t[5]){case 1:this.controllerChange(n,k.bankSelect,o);break;case 2:this.controllerChange(n,k.lsbForControl0BankSelect,o);break;case 3:this.programChange(n,o);break;case 8:let i=this.workletProcessorChannels[n];if(i.drumChannel)return;let a=o-64;i.channelTransposeKeyShift=a;break;case 11:this.controllerChange(n,k.mainVolume,o);break;case 14:let C=o;C===0&&(C=Math.floor(Math.random()*127)),this.controllerChange(n,k.pan,C);break;case 19:this.controllerChange(n,k.reverbDepth,o);break;case 18:this.controllerChange(n,k.chorusDepth,o);break;default:T(`%cUnrecognized Yamaha XG Part Setup: %c${t[5].toString(16).toUpperCase()}`,g.warn,g.unrecognized)}}else if(t[3]===6&&t[4]===0){let n=new Uint8Array(t.slice(5,t.length-1));this.callEvent("synthdisplay",{displayData:n,displayType:es.XGText})}else this.system==="xg"&&T(`%cUnrecognized Yamaha XG SysEx: %c${DA(t)}`,g.warn,g.unrecognized);else this.system==="xg"&&T(`%cUnrecognized Yamaha SysEx: %c${DA(t)}`,g.warn,g.unrecognized);break}}var mr=1e3/200;function Rn(t,A,e){if(A.transformAmount===0)return A.currentValue=0,0;let s;if(A.sourceUsesCC)s=t[A.sourceIndex];else{let h=A.sourceIndex+dA;switch(A.sourceIndex){case K.noController:s=16383;break;case K.noteOnKeyNum:s=e.midiNote<<7;break;case K.noteOnVelocity:s=e.velocity<<7;break;case K.polyPressure:s=e.pressure<<7;break;default:s=t[h];break}}let n=ue[A.sourceCurveType][A.sourcePolarity][A.sourceDirection][s],o;if(A.secSrcUsesCC)o=t[A.secSrcIndex];else{let h=A.secSrcIndex+dA;switch(A.secSrcIndex){case K.noController:o=16383;break;case K.noteOnKeyNum:o=e.midiNote<<7;break;case K.noteOnVelocity:o=e.velocity<<7;break;case K.polyPressure:o=e.pressure<<7;break;default:o=t[h]}}let i=ue[A.secSrcCurveType][A.secSrcPolarity][A.secSrcDirection][o],a=A.transformAmount;A.isEffectModulator&&a<=1e3&&(a*=mr,a=Math.min(a,1e3));let C=n*i*a;return A.transformType===2&&(C=Math.abs(C)),A.currentValue=C,C}function Ae(t,A,e=-1,s=0){let n=t.modulators,o=t.generators,i=t.modulatedGenerators;if(e===-1){i.set(o),n.forEach(h=>{let d=J[h.modulatorDestination],Q=i[h.modulatorDestination]+Rn(A,h,t);i[h.modulatorDestination]=Math.max(d.min,Math.min(Q,d.max))}),qA.recalculate(t),PA.recalculate(t);return}let a=new Set([r.initialAttenuation,r.delayVolEnv,r.attackVolEnv,r.holdVolEnv,r.decayVolEnv,r.sustainVolEnv,r.releaseVolEnv,r.keyNumToVolEnvHold,r.keyNumToVolEnvDecay]),C=new Set;n.forEach(h=>{if(h.sourceUsesCC===e&&h.sourceIndex===s||h.secSrcUsesCC===e&&h.secSrcIndex===s){let d=h.modulatorDestination;C.has(d)||(i[d]=o[d],Rn(A,h,t),n.forEach(Q=>{if(Q.modulatorDestination===d){let l=J[h.modulatorDestination],c=i[h.modulatorDestination]+Q.currentValue;i[h.modulatorDestination]=Math.max(l.min,Math.min(c,l.max))}}),C.add(d))}}),[...C].some(h=>a.has(h))&&qA.recalculate(t),PA.recalculate(t)}var ue=[];for(let t=0;t<4;t++){ue[t]=[[new Float32Array(mA),new Float32Array(mA)],[new Float32Array(mA),new Float32Array(mA)]];for(let A=0;A<mA;A++)ue[t][0][0][A]=Qe(0,t,A/mA,0),ue[t][1][0][A]=Qe(0,t,A/mA,1),ue[t][0][1][A]=Qe(1,t,A/mA,0),ue[t][1][1][A]=Qe(1,t,A/mA,1)}function Gn(t,A,e,s=!1,n=!0,o=currentTime){if(e===0){this.noteOff(t,A);return}let i=this.workletProcessorChannels[t];if(this.highPerformanceMode&&this.totalVoicesAmount>200&&e<40||this.highPerformanceMode&&e<10||i.isMuted)return;let a=A+i.channelTransposeKeyShift,C=a;if(A>127||A<0)return;let h=i.preset.program;this.tunings[h]?.[A]?.midiNote>=0&&(C=this.tunings[h]?.[A].midiNote),i.velocityOverride>0&&(e=i.velocityOverride);let d=this.keyModifierManager.getVelocity(t,A);d>-1&&(e=d);let Q=this.getWorkletVoices(t,C,e,i,o,a,s),l=i.voices;Q.forEach(c=>{let f=c.generators[r.exclusiveClass];f!==0&&l.forEach(F=>{F.generators[r.exclusiveClass]===f&&(this.releaseVoice(F,xn),F.modulatedGenerators[r.releaseVolEnv]=-7e3,F.modulatedGenerators[r.releaseModEnv]=-7e3,qA.recalculate(F),PA.recalculate(F))}),Ae(c,i.midiControllers);let M=c.modulatedGenerators[r.startAddrsOffset]+c.modulatedGenerators[r.startAddrsCoarseOffset]*32768,D=c.modulatedGenerators[r.endAddrOffset]+c.modulatedGenerators[r.endAddrsCoarseOffset]*32768,v=c.modulatedGenerators[r.startloopAddrsOffset]+c.modulatedGenerators[r.startloopAddrsCoarseOffset]*32768,y=c.modulatedGenerators[r.endloopAddrsOffset]+c.modulatedGenerators[r.endloopAddrsCoarseOffset]*32768,w=c.sample,x=F=>Math.max(0,Math.min(w.sampleData.length-1,F));if(w.cursor=x(w.cursor+M),w.end=x(w.end+D),w.loopStart=x(w.loopStart+v),w.loopEnd=x(w.loopEnd+y),w.loopEnd<w.loopStart){let F=w.loopStart;w.loopStart=w.loopEnd,w.loopEnd=F}w.loopEnd-w.loopStart<1&&(w.loopingMode=0,w.isLooping=!1),c.volumeEnvelope.attenuation=c.volumeEnvelope.attenuationTargetGain,c.currentPan=(Math.max(-500,Math.min(500,c.modulatedGenerators[r.pan]))+500)/1e3}),this.totalVoicesAmount+=Q.length,this.totalVoicesAmount>this.voiceCap&&this.voiceKilling(Q.length),l.push(...Q),n&&(this.sendChannelProperties(),this.callEvent("noteon",{midiNote:A,channel:t,velocity:e}))}function Mn(t,A){if(A>127||A<0){T("Received a noteOn for note",A,"Ignoring.");return}let e=A+this.workletProcessorChannels[t].channelTransposeKeyShift;if(this.highPerformanceMode&&!this.workletProcessorChannels[t].drumChannel){this.killNote(t,e);return}this.workletProcessorChannels[t].voices.forEach(n=>{n.realKey!==e||n.isInRelease===!0||(this.workletProcessorChannels[t].holdPedal?this.workletProcessorChannels[t].sustainedVoices.push(n):this.releaseVoice(n))}),this.callEvent("noteoff",{midiNote:A,channel:t})}function Nn(t,A){this.workletProcessorChannels[t].voices.forEach(e=>{e.realKey===A&&(e.modulatedGenerators[r.releaseVolEnv]=-12e3,this.releaseVoice(e))})}function bn(t,A=!1){let e=this.workletProcessorChannels[t].voices;A?(e.length=0,this.workletProcessorChannels[t].sustainedVoices.length=0,this.sendChannelProperties()):(e.forEach(s=>{s.isInRelease||this.releaseVoice(s)}),this.workletProcessorChannels[t].sustainedVoices.forEach(s=>{this.releaseVoice(s)}))}function Ln(t=!1){m("%cStop all received!",g.info);for(let A=0;A<this.workletProcessorChannels.length;A++)this.stopAll(A,t);this.callEvent("stopall",void 0)}function Un(t,A=!1){this.transposition=0;for(let e=0;e<this.workletProcessorChannels.length;e++)this.transposeChannel(e,t,A);this.transposition=t}function Tn(t,A,e=!1){let s=this.workletProcessorChannels[t];s.drumChannel||(A+=this.transposition);let n=Math.trunc(A),o=s.channelTransposeKeyShift+s.customControllers[cA.channelTransposeFine]/100;s.drumChannel&&!e||A===o||(n!==s.channelTransposeKeyShift&&this.stopAll(t,!1),s.channelTransposeKeyShift=n,s.customControllers[cA.channelTransposeFine]=(A-n)*100)}function vn(t,A,e=!0){let s=this.workletProcessorChannels[t];A=Math.round(A),s.customControllers[cA.channelTuning]=A,e&&m(`%cChannel ${t} fine tuning. Cents: %c${A}`,g.info,g.value)}function Hn(t,A){let e=this.workletProcessorChannels[t];A=Math.round(A),e.customControllers[cA.channelTuningSemitones]=A,m(`%cChannel ${t} coarse tuning. Semitones: %c${A}`,g.info,g.value)}function Yn(t){t=Math.round(t);for(let A=0;A<this.workletProcessorChannels.length;A++)this.workletProcessorChannels[A].customControllers[cA.masterTuning]=t}function Jn(t,A){let e=this.workletProcessorChannels[t];A=Math.round(A),m(`%cChannel ${t} modulation depth. Cents: %c${A}`,g.info,g.value),e.customControllers[cA.modulationMultiplier]=A/50}function Pn(t,A,e){if(this.workletProcessorChannels[t].lockedControllers[dA+K.pitchWheel])return;let s=e|A<<7;this.callEvent("pitchwheel",{channel:t,MSB:A,LSB:e}),this.workletProcessorChannels[t].midiControllers[dA+K.pitchWheel]=s,this.workletProcessorChannels[t].voices.forEach(n=>Ae(n,this.workletProcessorChannels[t].midiControllers,0,K.pitchWheel)),this.sendChannelProperties()}function qn(t,A){let e=this.workletProcessorChannels[t];e.midiControllers[dA+K.channelPressure]=A<<7,this.workletProcessorChannels[t].voices.forEach(s=>Ae(s,e.midiControllers,0,K.channelPressure)),this.callEvent("channelpressure",{channel:t,pressure:A})}function Kn(t,A,e){this.workletProcessorChannels[t].voices.forEach(s=>{s.midiNote===A&&(s.pressure=e,Ae(s,this.workletProcessorChannels[t].midiControllers,0,K.polyPressure))}),this.callEvent("polypressure",{channel:t,midiNote:A,pressure:e})}function On(t,A){if(A.length!==12)throw new Error("Tuning is not the length of 12.");this.workletProcessorChannels[t].channelOctaveTuning=A}function Vn(t,A,e,s=!1){let n=this.workletProcessorChannels[t];if(n===void 0){T(`Trying to access channel ${t} which does not exist... ignoring!`);return}if(A>127){if(!s)return;switch(A){default:return;case Zt.velocityOverride:n.velocityOverride=e}}if(A>=k.lsbForControl1ModulationWheel&&A<=k.lsbForControl13EffectControl2&&A!==k.lsbForControl6DataEntry){let o=A-32;if(n.lockedControllers[o])return;n.midiControllers[o]=n.midiControllers[o]&16256|e&127,n.voices.forEach(i=>Ae(i,n.midiControllers,1,o))}switch(A){case k.allNotesOff:this.stopAll(t);break;case k.allSoundOff:this.stopAll(t,!0);break;case k.bankSelect:let o=e;if(!s){switch(this.system){case"gm":m(`%cIgnoring the Bank Select (${e}), as the synth is in GM mode.`,g.info);return;case"xg":o===120||o===126||o===127?this.setDrums(t,!0):t%16!==xA&&this.setDrums(t,!1);break;case"gm2":o===120&&this.setDrums(t,!0)}n.drumChannel&&(o=128),o===128&&!n.drumChannel&&(o=XA(n))}ne(n,o);break;case k.lsbForControl0BankSelect:this.system==="xg"?n.drumChannel||e!==127&&ne(n,e):this.system==="gm2"&&ne(n,e);break;case k.RPNLsb:n.RPValue=n.RPValue<<7|e,n.dataEntryState=FA.RPFine;break;case k.RPNMsb:n.RPValue=e,n.dataEntryState=FA.RPCoarse;break;case k.NRPNMsb:n.NRPCoarse=e,n.dataEntryState=FA.NRPCoarse;break;case k.NRPNLsb:n.NRPFine=e,n.dataEntryState=FA.NRPFine;break;case k.dataEntryMsb:this.dataEntryCoarse(t,e);break;case k.lsbForControl6DataEntry:this.dataEntryFine(t,e);break;case k.resetAllControllers:this.resetControllers(t);break;case k.sustainPedal:e>=64?n.holdPedal=!0:(n.holdPedal=!1,n.sustainedVoices.forEach(i=>{this.releaseVoice(i)}),n.sustainedVoices=[]);break;default:if(n.lockedControllers[A])return;n.midiControllers[A]=e<<7,n.voices.forEach(i=>Ae(i,n.midiControllers,1,A));break}this.callEvent("controllerchange",{channel:t,controllerNumber:A,controllerValue:e})}function Zn(t){this.midiVolume=t,this.setMasterPan(this.pan)}function Wn(t){this.masterGain=t*ts,this.setMasterPan(this.pan)}function Xn(t){this.pan=t,t=t/2+.5,this.panLeft=1-t,this.panRight=t}function _n(t,A){A&&this.stopAll(t,!0),this.workletProcessorChannels[t].isMuted=A,this.sendChannelProperties(),this.callEvent("mutechannel",{channel:t,isMuted:A})}function zn(t){this.workletProcessorChannels[t].lockGSNRPNParams=!0,this.workletProcessorChannels[t].channelVibrato.rate=0,this.workletProcessorChannels[t].channelVibrato.delay=0,this.workletProcessorChannels[t].channelVibrato.depth=0}function jn(t,A,e,s){this.workletProcessorChannels[t].lockGSNRPNParams||(this.workletProcessorChannels[t].channelVibrato.rate=e,this.workletProcessorChannels[t].channelVibrato.delay=s,this.workletProcessorChannels[t].channelVibrato.depth=A)}function $n(t,A){let e=this.workletProcessorChannels[t],s=()=>{e.channelVibrato.delay===0&&e.channelVibrato.rate===0&&e.channelVibrato.depth===0&&(e.channelVibrato.depth=50,e.channelVibrato.rate=8,e.channelVibrato.delay=.6)};switch(e.dataEntryState){default:case FA.Idle:break;case FA.NRPFine:if(this.system!=="gs"||e.lockGSNRPNParams)return;switch(e.NRPCoarse){default:if(A===64)return;T(`%cUnrecognized NRPN for %c${t}%c: %c(0x${e.NRPCoarse.toString(16).toUpperCase()} 0x${e.NRPFine.toString(16).toUpperCase()})%c data value: %c${A}`,g.warn,g.recognized,g.warn,g.unrecognized,g.warn,g.value);break;case 1:switch(e.NRPFine){default:if(A===64)return;T(`%cUnrecognized NRPN for %c${t}%c: %c(0x${e.NRPCoarse.toString(16)} 0x${e.NRPFine.toString(16)})%c data value: %c${A}`,g.warn,g.recognized,g.warn,g.unrecognized,g.warn,g.value);break;case 8:if(A===64)return;s(),e.channelVibrato.rate=A/64*8,m(`%cVibrato rate for %c${t}%c is now set to %c${A} = ${e.channelVibrato.rate}%cHz.`,g.info,g.recognized,g.info,g.value,g.info);break;case 9:if(A===64)return;s(),e.channelVibrato.depth=A/2,m(`%cVibrato depth for %c${t}%c is now set to %c${A} = ${e.channelVibrato.depth}%c cents range of detune.`,g.info,g.recognized,g.info,g.value,g.info);break;case 10:if(A===64)return;s(),e.channelVibrato.delay=A/64/3,m(`%cVibrato delay for %c${t}%c is now set to %c${A} = ${e.channelVibrato.delay}%c seconds.`,g.info,g.recognized,g.info,g.value,g.info);break;case 32:let o=A;this.controllerChange(t,k.brightness,A),m(`%cFilter cutoff for %c${t}%c is now set to %c${o}`,g.info,g.recognized,g.info,g.value)}break;case 29:let n=A;this.controllerChange(t,k.reverbDepth,n),m(`%cGS Drum reverb for %c${t}%c: %c${n}`,g.info,g.recognized,g.info,g.value);break}break;case FA.RPCoarse:case FA.RPFine:switch(e.RPValue){default:T(`%cUnrecognized RPN for %c${t}%c: %c(0x${e.RPValue.toString(16)})%c data value: %c${A}`,g.warn,g.recognized,g.warn,g.unrecognized,g.warn,g.value);break;case 0:e.midiControllers[dA+K.pitchWheelRange]=A<<7,m(`%cChannel ${t} bend range. Semitones: %c${A}`,g.info,g.value);break;case 2:this.setChannelTuningSemitones(t,A-64);break;case 1:this.setChannelTuning(t,A-64,!1);break;case 5:this.setModulationDepth(t,A*100);break;case 16383:this.resetParameters(t);break}}}function Ao(t,A){let e=this.workletProcessorChannels[t];switch(e.dataEntryState){default:break;case FA.RPCoarse:case FA.RPFine:switch(e.RPValue){default:break;case 0:if(A===0)break;e.midiControllers[dA+K.pitchWheelRange]|=A;let s=(e.midiControllers[dA+K.pitchWheelRange]>>7)+A/127;m(`%cChannel ${t} bend range. Semitones: %c${s}`,g.info,g.value);break;case 1:let o=e.customControllers[cA.channelTuning]<<7|A;this.setChannelTuning(t,o*.01220703125);break;case 5:let a=e.customControllers[cA.modulationMultiplier]*50+A/128*100;this.setModulationDepth(t,a);break;case 16383:this.resetParameters(t);break}}}function eo(t=!0){t&&m("%cResetting all controllers!",g.info),this.callEvent("allcontrollerreset",void 0);for(let A=0;A<this.workletProcessorChannels.length;A++){this.resetControllers(A);let e=this.workletProcessorChannels[A];e.lockPreset?this.callEvent("drumchange",{channel:A,isDrumChannel:e.drumChannel}):(e.presetUsesOverride=!0,ne(e,0),A%16===xA?(this.setPreset(A,this.drumPreset),e.drumChannel=!0,this.callEvent("drumchange",{channel:A,isDrumChannel:!0})):(e.drumChannel=!1,this.setPreset(A,this.defaultPreset),this.callEvent("drumchange",{channel:A,isDrumChannel:!1}))),this.callEvent("programchange",{channel:A,program:e.preset.program,bank:XA(e),userCalled:!1});for(let s=0;s<128;s++)this.workletProcessorChannels[A].lockedControllers[s]&&this.callEvent("controllerchange",{channel:A,controllerNumber:s,controllerValue:this.workletProcessorChannels[A].midiControllers[s]>>7});if(this.workletProcessorChannels[A].lockedControllers[dA+K.pitchWheel]===!1){let s=this.workletProcessorChannels[A].midiControllers[dA+K.pitchWheel],n=s>>7,o=s&127;this.callEvent("pitchwheel",{channel:A,MSB:n,LSB:o})}}this.tunings=[],this.tunings=[];for(let A=0;127>A;A++)this.tunings.push([]);this.setMIDIVolume(1),this.system=st}function to(t){let A=this.workletProcessorChannels[t],e=A.lockedControllers.reduce((n,o,i)=>(o&&n.push(i),n),[]);A.channelOctaveTuning.fill(0),A.keyCentTuning.fill(0);for(let n=0;n<De.length;n++){if(A.lockedControllers[n])return;let o=De[n];A.midiControllers[n]!==o&&n<127&&this.callEvent("controllerchange",{channel:t,controllerNumber:n,controllerValue:o>>7}),A.midiControllers[n]=o}A.channelVibrato={rate:0,depth:0,delay:0},A.holdPedal=!1;let s=A.customControllers[cA.channelTransposeFine];A.customControllers.set(Vt),A.customControllers[cA.channelTransposeFine]=s,this.resetParameters(t)}function so(t){let A=this.workletProcessorChannels[t];A.NRPCoarse=0,A.NRPFine=0,A.RPValue=0,A.dataEntryState=FA.Idle}function no(){let t=4;for(let s of this.instruments)t+=s.instrumentZones.reduce((n,o)=>(o.generators=o.generators.filter(i=>i.generatorType!==r.sampleID&&i.generatorType!==r.keyRange&&i.generatorType!==r.velRange),(o.velRange.max!==127||o.velRange.min!==0)&&o.generators.unshift({generatorType:r.velRange,generatorValue:o.velRange.max<<8|Math.max(o.velRange.min,0)}),(o.keyRange.max!==127||o.keyRange.min!==0)&&o.generators.unshift({generatorType:r.keyRange,generatorValue:o.keyRange.max<<8|Math.max(o.keyRange.min,0)}),o.isGlobal||o.generators.push({generatorType:r.sampleID,generatorValue:this.samples.indexOf(o.sample)}),o.generators.length*4+n),0);let A=new b(t),e=0;for(let s of this.instruments)for(let n of s.instrumentZones){n.generatorZoneStartIndex=e;for(let o of n.generators)L(A,o.generatorType),L(A,o.generatorValue),e++}return W(A,0),IA(new rA("igen",A.length,A))}function oo(t,A,e,s,n){let o=this.samples.map((h,d)=>{e&&h.compressSample(s,n);let Q=h.getRawData();return m(`%cEncoded sample %c${d}. ${h.sampleName}%c of %c${this.samples.length}%c. Compressed: %c${h.isCompressed}%c.`,g.info,g.recognized,g.info,g.recognized,g.info,h.isCompressed?g.recognized:g.unrecognized,g.info),Q}),i=this.samples.reduce((h,d,Q)=>h+o[Q].length+46,0),a=new b(i);this.samples.forEach((h,d)=>{let Q=o[d],l,c,f=Q.length;h.isCompressed?(l=a.currentIndex,c=l+Q.length):(l=a.currentIndex/2,c=l+Q.length/2,f+=46),t.push(l),a.set(Q,a.currentIndex),a.currentIndex+=f,A.push(c)});let C=IA(new rA("smpl",a.length,a),new b([115,100,116,97]));return IA(new rA("LIST",C.length,C))}function ro(t,A){let s=new b(46*(this.samples.length+1));return this.samples.forEach((n,o)=>{SA(s,n.sampleName,20);let i=t[o];W(s,i);let a=A[o];W(s,a);let C=n.sampleLoopStartIndex+i,h=n.sampleLoopEndIndex+i;n.isCompressed&&(C-=i,h-=i),W(s,C),W(s,h),W(s,n.sampleRate),s[s.currentIndex++]=n.samplePitch,s[s.currentIndex++]=n.samplePitchCorrection,L(s,n.sampleLink),L(s,n.sampleType)}),SA(s,"EOS",46),IA(new rA("shdr",s.length,s))}function io(){let t=10;for(let s of this.instruments)t+=s.instrumentZones.reduce((n,o)=>o.modulators.length*10+n,0);let A=new b(t),e=0;for(let s of this.instruments)for(let n of s.instrumentZones){n.modulatorZoneStartIndex=e;for(let o of n.modulators)L(A,o.sourceEnum),L(A,o.modulatorDestination),L(A,o.transformAmount),L(A,o.secondarySourceEnum),L(A,o.transformType),e++}return we(A,0,10),IA(new rA("imod",A.length,A))}function ao(){let t=this.instruments.reduce((o,i)=>i.instrumentZones.length*4+o,4),A=new b(t),e=0,s=0,n=0;for(let o of this.instruments){o.instrumentZoneIndex=e;for(let i of o.instrumentZones)i.zoneID=e,L(A,s),L(A,n),s+=i.generators.length,n+=i.modulators.length,e++}return L(A,s),L(A,n),IA(new rA("ibag",A.length,A))}function go(){let t=this.instruments.length*22+22,A=new b(t),e=0,s=0;for(let n of this.instruments)SA(A,n.instrumentName,20),L(A,e),e+=n.instrumentZones.length,n.instrumentID=s,s++;return SA(A,"EOI",20),L(A,e),IA(new rA("inst",A.length,A))}function Io(){let t=4;for(let s of this.presets)t+=s.presetZones.reduce((n,o)=>(o.generators=o.generators.filter(i=>i.generatorType!==r.instrument&&i.generatorType!==r.keyRange&&i.generatorType!==r.velRange),(o.velRange.max!==127||o.velRange.min!==0)&&o.generators.unshift({generatorType:r.velRange,generatorValue:o.velRange.max<<8|Math.max(o.velRange.min,0)}),(o.keyRange.max!==127||o.keyRange.min!==0)&&o.generators.unshift({generatorType:r.keyRange,generatorValue:o.keyRange.max<<8|Math.max(o.keyRange.min,0)}),o.isGlobal||o.generators.push({generatorType:r.instrument,generatorValue:this.instruments.indexOf(o.instrument)}),o.generators.length*4+n),0);let A=new b(t),e=0;for(let s of this.presets)for(let n of s.presetZones){n.generatorZoneStartIndex=e;for(let o of n.generators)L(A,o.generatorType),L(A,o.generatorValue);e+=n.generators.length}return L(A,0),L(A,0),IA(new rA("pgen",A.length,A))}function Eo(){let t=10;for(let s of this.presets)t+=s.presetZones.reduce((n,o)=>o.modulators.length*10+n,0);let A=new b(t),e=0;for(let s of this.presets)for(let n of s.presetZones){n.modulatorZoneStartIndex=e;for(let o of n.modulators)L(A,o.sourceEnum),L(A,o.modulatorDestination),L(A,o.transformAmount),L(A,o.secondarySourceEnum),L(A,o.transformType),e++}return we(A,0,10),IA(new rA("pmod",A.length,A))}function Co(){let t=this.presets.reduce((o,i)=>i.presetZones.length*4+o,4),A=new b(t),e=0,s=0,n=0;for(let o of this.presets){o.presetZoneStartIndex=e;for(let i of o.presetZones)i.zoneID=e,L(A,s),L(A,n),s+=i.generators.length,n+=i.modulators.length,e++}return L(A,s),L(A,n),IA(new rA("pbag",A.length,A))}function Bo(){let t=this.presets.length*38+38,A=new b(t),e=0;for(let s of this.presets)SA(A,s.presetName,20),L(A,s.program),L(A,s.bank),L(A,e),W(A,s.library),W(A,s.genre),W(A,s.morphology),e+=s.presetZones.length;return SA(A,"EOP",20),L(A,0),L(A,0),L(A,e),W(A,0),W(A,0),W(A,0),IA(new rA("phdr",A.length,A))}var pr={compress:!1,compressionQuality:.5,compressionFunction:void 0};function ho(t=pr){if(t.compress&&typeof t.compressionFunction!="function")throw new TypeError("No compression function supplied but compression enabled.");QA("%cSaving soundfont...",g.info),m(`%cCompression: %c${t?.compress||"false"}%c quality: %c${t?.compressionQuality||"none"}`,g.info,g.recognized,g.info,g.recognized),m("%cWriting INFO...",g.info);let A=[];this.soundFontInfo.ISFT="SpessaSynth",t?.compress&&(this.soundFontInfo.ifil="3.0");for(let[x,F]of Object.entries(this.soundFontInfo))if(x==="ifil"||x==="iver"){let I=parseInt(F.split(".")[0]),tA=parseInt(F.split(".")[1]),q=new b(4);L(q,I),L(q,tA),A.push(IA(new rA(x,4,q)))}else if(x==="DMOD")A.push(IA(new rA(x,F.length,F)));else{let I=new b(F.length);SA(I,F),A.push(IA(new rA(x,F.length,I)))}let e=lA([new b([73,78,70,79]),...A]),s=IA(new rA("LIST",e.length,e));m("%cWriting SDTA...",g.info);let n=[],o=[],i=oo.call(this,n,o,t?.compress,t?.compressionQuality??.5,t.compressionFunction);m("%cWriting PDTA...",g.info),m("%cWriting SHDR...",g.info);let a=ro.call(this,n,o);m("%cWriting IGEN...",g.info);let C=no.call(this);m("%cWriting IMOD...",g.info);let h=io.call(this);m("%cWriting IBAG...",g.info);let d=ao.call(this);m("%cWriting INST...",g.info);let Q=go.call(this),l=Io.call(this);m("%cWriting PMOD...",g.info);let c=Eo.call(this);m("%cWriting PBAG...",g.info);let f=Co.call(this);m("%cWriting PHDR...",g.info);let M=Bo.call(this),D=lA([new b([112,100,116,97]),M,f,c,l,Q,d,h,C,a]),v=IA(new rA("LIST",D.length,D));m("%cWriting the output file...",g.info);let y=lA([new b([115,102,98,107]),s,i,v]),w=IA(new rA("RIFF",y.length,y));return m(`%cSaved succesfully! Final file size: %c${w.length}`,g.info,g.recognized),Z(),w}var He=class{velRange={min:-1,max:127};keyRange={min:-1,max:127};isGlobal=!1;generators=[];modulators=[];get hasKeyRange(){return this.keyRange.min!==-1}get hasVelRange(){return this.velRange.min!==-1}getGeneratorValue(A,e){return this.generators.find(s=>s.generatorType===A)?.generatorValue??e}};var RA=class extends He{sample=void 0;useCount=0;deleteZone(){this.useCount--,!this.isGlobal&&this.sample.useCount--}},re=class extends He{instrument=void 0;deleteZone(){this.isGlobal||this.instrument.removeUseCount()}};var yr=new Set([r.velRange,r.keyRange,r.instrument,r.exclusiveClass,r.endOper,r.sampleModes,r.startloopAddrsOffset,r.startloopAddrsCoarseOffset,r.endloopAddrsOffset,r.endloopAddrsCoarseOffset,r.startAddrsOffset,r.startAddrsCoarseOffset,r.endAddrOffset,r.endAddrsCoarseOffset,r.initialAttenuation,r.fineTune,r.coarseTune,r.keyNumToVolEnvHold,r.keyNumToVolEnvDecay,r.keyNumToModEnvHold,r.keyNumToModEnvDecay]);function co(t,A=!0){function e(Q,l){Q.push(...l.filter(c=>!Q.find(f=>f.generatorType===c.generatorType)))}function s(Q,l){return{min:Math.max(Q.min,l.min),max:Math.min(Q.max,l.max)}}function n(Q,l){Q.push(...l.filter(c=>!Q.find(f=>P.isIdentical(c,f))))}let o=[],i=[],a=[],C={min:0,max:127},h={min:0,max:127},d=t.presetZones.find(Q=>Q.isGlobal);d&&(i.push(...d.generators),a.push(...d.modulators),C=d.keyRange,h=d.velRange);for(let Q of t.presetZones){if(Q.isGlobal)continue;let l=Q.keyRange;Q.hasKeyRange||(l=C);let c=Q.velRange;Q.hasVelRange||(c=h);let f=Q.generators.map(I=>new N(I.generatorType,I.generatorValue));e(f,i);let M=[...Q.modulators];n(M,a);let D=Q.instrument.instrumentZones,v=[],y=[],w={min:0,max:127},x={min:0,max:127},F=D.find(I=>I.isGlobal);F&&(v.push(...F.generators),y.push(...F.modulators),w=F.keyRange,x=F.velRange);for(let I of D){if(I.isGlobal)continue;let tA=I.keyRange;I.hasKeyRange||(tA=w);let q=I.velRange;if(I.hasVelRange||(q=x),tA=s(tA,l),q=s(q,c),tA.max<tA.min||q.max<q.min)continue;let iA=I.generators.map(AA=>new N(AA.generatorType,AA.generatorValue));e(iA,v);let V=[...I.modulators];n(V,y);let aA=[...V];for(let AA of M){let hA=aA.findIndex(fA=>P.isIdentical(AA,fA));hA!==-1?aA[hA]=aA[hA].sumTransform(AA):aA.push(AA)}let oA=iA.map(AA=>new N(AA.generatorType,AA.generatorValue));for(let AA of f){if(AA.generatorType===r.velRange||AA.generatorType===r.keyRange||AA.generatorType===r.instrument||AA.generatorType===r.endOper||AA.generatorType===r.sampleModes)continue;let hA=iA.findIndex(fA=>fA.generatorType===AA.generatorType);if(hA!==-1){let fA=oA[hA].generatorValue+AA.generatorValue;oA[hA]=new N(AA.generatorType,fA)}else{let fA=J[AA.generatorType].def+AA.generatorValue;oA.push(new N(AA.generatorType,fA))}}oA=oA.filter(AA=>AA.generatorType!==r.sampleID&&AA.generatorType!==r.keyRange&&AA.generatorType!==r.velRange&&AA.generatorType!==r.endOper&&AA.generatorType!==r.instrument&&AA.generatorValue!==J[AA.generatorType].def);let eA=new RA;eA.keyRange=tA,eA.velRange=q,eA.keyRange.min===0&&eA.keyRange.max===127&&(eA.keyRange.min=-1),eA.velRange.min===0&&eA.velRange.max===127&&(eA.velRange.min=-1),eA.isGlobal=!1,eA.sample=I.sample,eA.generators=oA,eA.modulators=aA,o.push(eA)}}if(A){let Q=new RA;Q.isGlobal=!0;for(let f=0;f<58;f++){if(yr.has(f))continue;let M={},D=J[f]?.def||0;M[D]=0;for(let v of o){let y=v.generators.find(F=>F.generatorType===f);if(y){let F=y.generatorValue;M[F]===void 0?M[F]=1:M[F]++}else M[D]++;let w;switch(f){default:continue;case r.decayVolEnv:w=r.keyNumToVolEnvDecay;break;case r.holdVolEnv:w=r.keyNumToVolEnvHold;break;case r.decayModEnv:w=r.keyNumToModEnvDecay;break;case r.holdModEnv:w=r.keyNumToModEnvHold}if(v.generators.find(F=>F.generatorType===w)!==void 0){M={};break}}if(Object.keys(M).length>0){let v=Object.entries(M).reduce((w,x)=>w[1]<x[1]?x:w,[0,0]),y=parseInt(v[0]);y!==D&&Q.generators.push(new N(f,y)),o.forEach(w=>{let x=w.generators.findIndex(F=>F.generatorType===f);x!==-1?w.generators[x].generatorValue===y&&w.generators.splice(x,1):y!==D&&w.generators.push(new N(f,D))})}}let c=o.find(f=>!f.isGlobal).modulators.map(f=>P.copy(f));for(let f of c){let M=!0;for(let D of o){if(D.isGlobal||!M)continue;D.modulators.find(y=>P.isIdentical(y,f))||(M=!1)}if(M===!0){Q.modulators.push(P.copy(f));for(let D of o){let v=D.modulators.find(y=>P.isIdentical(y,f));v.transformAmount===f.transformAmount&&D.modulators.splice(D.modulators.indexOf(v),1)}}}o.splice(0,0,Q)}return o}var lo=20;function Ct(t,A,e,s,n,o,i){let a=i===0?0:1,C=new b(lo+a*16);W(C,lo),L(C,A),L(C,e);let h=s*.4,d=Math.floor(h*-65536);W(C,d),W(C,2);let Q=o-n,l=0;switch(i){default:case 0:a=0;break;case 1:l=0,a=1;break;case 3:l=1,a=1}return W(C,a),a===1&&(W(C,16),W(C,l),W(C,n),W(C,Q)),sA("wsmp",C)}var H={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:219,reverb:221,pitchWheelRange:256,fineTune:257,coarseTune:258},Bt=new P({srcEnum:219,dest:r.reverbEffectsSend,amt:1e3,secSrcEnum:0,transform:0}),ht=new P({srcEnum:221,dest:r.chorusEffectsSend,amt:1e3,secSrcEnum:0,transform:0}),ct=new P({srcEnum:129,dest:r.vibLfoToPitch,amt:0,secSrcEnum:0,transform:0}),lt=new P({srcEnum:13,dest:r.vibLfoToPitch,amt:0,secSrcEnum:0,transform:0});var S={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,volEnvRelease:521,volEnvSustain:522,volEnvDelay:523,volEnvHold:524,modEnvAttack:778,modEnvDecay:779,modEnvRelease:781,modEnvSustain:782,modEnvDelay:783,modEnvHold:784,filterCutoff:1280,filterQ:1281};var Ye=class{source;control;destination;scale;transform;constructor(A,e,s,n,o){this.source=A,this.control=e,this.destination=s,this.scale=n,this.transform=o}writeArticulator(){let A=new b(12);return L(A,this.source),L(A,this.control),L(A,this.destination),L(A,this.transform),W(A,this.scale<<16),A}};function Qo(t,A){if(t)switch(A){default:return;case k.modulationWheel:return H.modulationWheel;case k.mainVolume:return H.volume;case k.pan:return H.pan;case k.expressionController:return H.expression;case k.chorusDepth:return H.chorus;case k.reverbDepth:return H.reverb}else switch(A){default:return;case K.noteOnKeyNum:return H.keyNum;case K.noteOnVelocity:return H.velocity;case K.noController:return H.none;case K.polyPressure:return H.polyPressure;case K.channelPressure:return H.channelPressure;case K.pitchWheel:return H.pitchWheel;case K.pitchWheelRange:return H.pitchWheelRange}}function uo(t,A){switch(t){default:return;case r.initialAttenuation:return{dest:S.gain,amount:-A};case r.fineTune:return S.pitch;case r.pan:return S.pan;case r.keyNum:return S.keyNum;case r.reverbEffectsSend:return S.reverbSend;case r.chorusEffectsSend:return S.chorusSend;case r.freqModLFO:return S.modLfoFreq;case r.delayModLFO:return S.modLfoDelay;case r.delayVibLFO:return S.vibLfoDelay;case r.freqVibLFO:return S.vibLfoFreq;case r.delayVolEnv:return S.volEnvDelay;case r.attackVolEnv:return S.volEnvAttack;case r.holdVolEnv:return S.volEnvHold;case r.decayVolEnv:return S.volEnvDecay;case r.sustainVolEnv:return{dest:S.volEnvSustain,amount:1e3-A};case r.releaseVolEnv:return S.volEnvRelease;case r.delayModEnv:return S.modEnvDelay;case r.attackModEnv:return S.modEnvAttack;case r.holdModEnv:return S.modEnvHold;case r.decayModEnv:return S.modEnvDecay;case r.sustainModEnv:return{dest:S.modEnvSustain,amount:1e3-A};case r.releaseModEnv:return S.modEnvRelease;case r.initialFilterFc:return S.filterCutoff;case r.initialFilterQ:return S.filterQ}}function fo(t,A){switch(t){default:return;case r.modEnvToFilterFc:return{source:H.modEnv,dest:S.filterCutoff,amt:A,isBipolar:!1};case r.modEnvToPitch:return{source:H.modEnv,dest:S.pitch,amt:A,isBipolar:!1};case r.modLfoToFilterFc:return{source:H.modLfo,dest:S.filterCutoff,amt:A,isBipolar:!0};case r.modLfoToVolume:return{source:H.modLfo,dest:S.gain,amt:A,isBipolar:!0};case r.modLfoToPitch:return{source:H.modLfo,dest:S.pitch,amt:A,isBipolar:!0};case r.vibLfoToPitch:return{source:H.vibratoLfo,dest:S.pitch,amt:A,isBipolar:!0};case r.keyNumToVolEnvHold:return{source:H.keyNum,dest:S.volEnvHold,amt:A,isBipolar:!0};case r.keyNumToVolEnvDecay:return{source:H.keyNum,dest:S.volEnvDecay,amt:A,isBipolar:!0};case r.keyNumToModEnvHold:return{source:H.keyNum,dest:S.modEnvHold,amt:A,isBipolar:!0};case r.keyNumToModEnvDecay:return{source:H.keyNum,dest:S.modEnvDecay,amt:A,isBipolar:!0};case r.scaleTuning:return{source:H.keyNum,dest:S.pitch,amt:A*128,isBipolar:!1}}}function mo(t){let A=uo(t.generatorType,t.generatorValue),e=A,s=0,n=t.generatorValue;A?.amount!==void 0&&(n=A.amount,e=A.dest);let o=fo(t.generatorType,t.generatorValue);if(o!==void 0)n=o.amt,e=o.dest,s=o.source;else if(e===void 0){T(`Invalid generator type: ${t.generatorType}`);return}return new Ye(s,0,e,n,0)}function po(t){if(t.transformType!==0){T("Other transform types are not supported.");return}let A=Qo(t.sourceUsesCC,t.sourceIndex),e=t.sourceCurveType,s=t.sourcePolarity,n=t.sourceDirection;if(A===void 0){T(`Invalid source: ${t.sourceIndex}, CC: ${t.sourceUsesCC}`);return}t.modulatorDestination===r.initialAttenuation&&(n=n===1?0:1);let o=Qo(t.secSrcUsesCC,t.secSrcIndex),i=t.secSrcCurveType,a=t.secSrcPolarity,C=t.secSrcDirection;if(o===void 0){T(`Invalid secondary source: ${t.secSrcIndex}, CC: ${t.secSrcUsesCC}`);return}let h=uo(t.modulatorDestination,t.transformAmount),d=h,Q=t.transformAmount;h?.dest!==void 0&&(d=h.dest,Q=h.amount);let l=fo(t.modulatorDestination,t.transformAmount);if(l!==void 0)Q=l.amt,o=A,i=e,a=s,C=n,e=uA.linear,s=l.isBipolar?1:0,n=0,A=l.source,d=l.dest;else if(d===void 0){T(`Invalid destination: ${t.modulatorDestination}`);return}let c=0;return c|=i<<4,c|=a<<8,c|=C<<9,c|=e,c|=s<<14,c|=n<<15,new Ye(A,o,d,Q,c)}var Sr=new Set([r.sampleModes,r.initialAttenuation,r.keyRange,r.velRange,r.sampleID,r.fineTune,r.coarseTune,r.startAddrsOffset,r.startAddrsCoarseOffset,r.endAddrOffset,r.endAddrsCoarseOffset,r.startloopAddrsOffset,r.startloopAddrsCoarseOffset,r.endloopAddrsOffset,r.endloopAddrsCoarseOffset,r.overridingRootKey,r.exclusiveClass]);function Qt(t){for(let o=0;o<t.generators.length;o++){let i=t.generators[o];(i.generatorType===r.delayVolEnv||i.generatorType===r.attackVolEnv||i.generatorType===r.holdVolEnv||i.generatorType===r.decayVolEnv||i.generatorType===r.releaseVolEnv||i.generatorType===r.delayModEnv||i.generatorType===r.attackModEnv||i.generatorType===r.holdModEnv||i.generatorType===r.decayModEnv)&&(t.generators[o]=new N(i.generatorType,Math.min(i.generatorValue,6386),!1))}for(let o=0;o<t.generators.length;o++){let i=t.generators[o],a;switch(i.generatorType){default:continue;case r.keyNumToVolEnvDecay:a=r.decayVolEnv;break;case r.keyNumToVolEnvHold:a=r.holdVolEnv;break;case r.keyNumToModEnvDecay:a=r.decayModEnv;break;case r.keyNumToModEnvHold:a=r.holdModEnv}let C=t.generators.find(f=>f.generatorType===a);if(C===void 0)continue;let h=i.generatorValue*-128,d=60/128*h,Q=C.generatorValue-d,l=t.generators.indexOf(i),c=t.generators.indexOf(C);t.generators[c]=new N(a,Q,!1),t.generators[l]=new N(i.generatorType,h,!1)}let A=t.generators.reduce((o,i)=>{if(Sr.has(i.generatorType))return o;let a=mo(i);return a!==void 0?(o.push(a),m("%cSucceeded converting to DLS Articulator!",g.recognized)):T("Failed converting to DLS Articulator!"),o},[]),e=t.modulators.reduce((o,i)=>{if(P.isIdentical(i,ht,!0)||P.isIdentical(i,Bt,!0)||P.isIdentical(i,ct,!0)||P.isIdentical(i,lt,!0))return o;let a=po(i);return a!==void 0?(o.push(a),m("%cSucceeded converting to DLS Articulator!",g.recognized)):T("Failed converting to DLS Articulator!"),o},[]);A.push(...e);let s=new b(8);W(s,8),W(s,A.length);let n=A.map(o=>o.writeArticulator());return sA("art2",lA([s,...n]))}function yo(t,A){let e=new b(12);L(e,Math.max(t.keyRange.min,0)),L(e,t.keyRange.max),L(e,Math.max(t.velRange.min,0)),L(e,t.velRange.max),L(e,0);let s=t.getGeneratorValue(r.exclusiveClass,0);L(e,s),L(e,0);let n=sA("rgnh",e),o=t.getGeneratorValue(r.overridingRootKey,t.sample.samplePitch);t.getGeneratorValue(r.scaleTuning,A.getGeneratorValue(r.scaleTuning,100))===0&&t.keyRange.max-t.keyRange.min===0&&(o=t.keyRange.min);let a=Ct(t.sample,o,t.getGeneratorValue(r.fineTune,0)+t.getGeneratorValue(r.coarseTune,0)*100+t.sample.samplePitchCorrection,t.getGeneratorValue(r.initialAttenuation,0),t.sample.sampleLoopStartIndex+t.getGeneratorValue(r.startloopAddrsOffset,0)+t.getGeneratorValue(r.startloopAddrsCoarseOffset,0)*32768,t.sample.sampleLoopEndIndex+t.getGeneratorValue(r.endloopAddrsOffset,0)+t.getGeneratorValue(r.endloopAddrsCoarseOffset,0)*32768,t.getGeneratorValue(r.sampleModes,0)),C=new b(12);L(C,0),L(C,0),W(C,1),W(C,this.samples.indexOf(t.sample));let h=sA("wlnk",C),d=new b(0);if(t.modulators.length+t.generators.length>0){let Q=Qt(t);d=sA("lar2",Q,!1,!0)}return sA("rgn2",lA([n,a,h,d]),!1,!0)}function So(t){QA(`%cWriting %c${t.presetName}%c...`,g.info,g.recognized,g.info);let A=co(t),e=A.reduce((l,c)=>c.isGlobal?l:l+1,0),s=new b(12);W(s,e);let n=(t.bank&127)<<8;t.bank===128&&(n|=1<<31),W(s,n),W(s,t.program&127);let o=sA("insh",s),i=new b(0),a=A.find(l=>l.isGlobal===!0);if(a){let l=Qt(a);i=sA("lar2",l,!1,!0)}let C=lA(A.reduce((l,c)=>(c.isGlobal||l.push(yo.apply(this,[c,a])),l),[])),h=sA("lrgn",C,!1,!0),d=sA("INAM",he(t.presetName)),Q=sA("INFO",d,!1,!0);return Z(),sA("ins ",lA([o,h,i,Q]),!1,!0)}function Do(){let t=lA(this.presets.map(A=>So.apply(this,[A])));return sA("lins",t,!1,!0)}function ko(t){let A=new b(18);L(A,1),L(A,1),W(A,t.sampleRate),W(A,t.sampleRate*2),L(A,2),L(A,16);let e=sA("fmt ",A),s=1;t.sampleLoopStartIndex+Math.abs(t.getAudioData().length-t.sampleLoopEndIndex)<2&&(s=0);let n=Ct(t,t.samplePitch,t.samplePitchCorrection,0,t.sampleLoopStartIndex,t.sampleLoopEndIndex,s),o=t.getAudioData(),i;if(t.isCompressed){let h=new Int16Array(o.length);for(let d=0;d<o.length;d++)h[d]=o[d]*32768;i=sA("data",new b(h.buffer))}else i=sA("data",t.getRawData());let a=sA("INAM",he(t.sampleName)),C=sA("INFO",a,!1,!0);return m(`%cSaved %c${t.sampleName}%c succesfully!`,g.recognized,g.value,g.recognized),sA("wave",lA([e,n,i,C]),!1,!0)}function wo(){let t=0,A=[],e=this.samples.map(s=>{let n=ko(s);return A.push(t),t+=n.length,n});return{data:sA("wvpl",lA(e),!1,!0),indexes:A}}function Fo(){QA("%cSaving DLS...",g.info);let t=new b(4);W(t,this.presets.length);let A=sA("colh",t);QA("%cWriting instruments...",g.info);let e=Do.apply(this);m("%cSuccess!",g.recognized),Z(),QA("%cWriting WAVE samples...",g.info);let s=wo.apply(this),n=s.data,o=s.indexes;m("%cSucceeded!",g.recognized),Z();let i=new b(8+4*o.length);W(i,8),W(i,o.length);for(let Q of o)W(i,Q);let a=sA("ptbl",i);this.soundFontInfo.ICMT=(this.soundFontInfo.ICMT||"Soundfont")+`
|
|
15
|
+
Converted from SF2 to DLS using SpessaSynth`,this.soundFontInfo.ISFT="SpessaSynth";let C=[];for(let[Q,l]of Object.entries(this.soundFontInfo))Q!=="ICMT"&&Q!=="INAM"&&Q!=="ICRD"&&Q!=="IENG"&&Q!=="ICOP"&&Q!=="ISFT"&&Q!=="ISBJ"||C.push(sA(Q,he(l),!0));let h=sA("INFO",lA(C),!1,!0),d=new b(A.length+e.length+a.length+n.length+h.length+4);return SA(d,"DLS "),d.set(lA([A,e,a,n,h]),4),m("%cSaved succesfully!",g.recognized),Z(),sA("RIFF",d)}var Dr=48e3,ie=class{constructor(A,e,s,n,o,i,a,C){this.sampleName=A,this.sampleRate=e,this.samplePitch=s,this.samplePitchCorrection=n,this.sampleLink=o,this.sampleType=i,this.sampleLoopStartIndex=a,this.sampleLoopEndIndex=C,this.isCompressed=(i&16)>0,this.compressedData=void 0,this.useCount=0,this.sampleData=void 0}getRawData(){let A=new Uint8Array(this.sampleData.length*2);for(let e=0;e<this.sampleData.length;e++){let s=Math.floor(this.sampleData[e]*32768);A[e*2]=s&255,A[e*2+1]=s>>8&255}return A}resampleData(A){let e=this.getAudioData(),s=A/this.sampleRate,n=new Float32Array(Math.floor(e.length*s));for(let o=0;o<n.length;o++)n[o]=e[Math.floor(o*(1/s))];e=n,this.sampleRate=A,this.sampleLoopStartIndex=Math.floor(this.sampleLoopStartIndex*s),this.sampleLoopEndIndex=Math.floor(this.sampleLoopEndIndex*s),this.sampleData=e}compressSample(A,e){if(!this.isCompressed)try{let s=this.getAudioData();(this.sampleRate<8e3||this.sampleRate>96e3)&&(this.resampleData(Dr),s=this.getAudioData()),this.compressedData=e([s],1,this.sampleRate,A),this.sampleType|=16,this.isCompressed=!0}catch{T(`Failed to compress ${this.sampleName}. Leaving as uncompressed!`),this.isCompressed=!1,this.compressedData=void 0,this.sampleType&=239}}getAudioData(){return this.sampleData}};var ae=class{constructor(){this.instrumentName="",this.instrumentZones=[],this._useCount=0}get useCount(){return this._useCount}addUseCount(){this._useCount++,this.instrumentZones.forEach(A=>A.useCount++)}removeUseCount(){this._useCount--;for(let A=0;A<this.instrumentZones.length;A++)this.safeDeleteZone(A)&&A--}deleteInstrument(){this.instrumentZones.forEach(A=>A.deleteZone()),this.instrumentZones.length=0}safeDeleteZone(A){return this.instrumentZones[A].useCount--,this.instrumentZones[A].useCount<1?(this.deleteZone(A),!0):!1}deleteZone(A){this.instrumentZones[A].deleteZone(),this.instrumentZones.splice(A,1)}};var ge=class{constructor(A){this.presetName="",this.program=0,this.bank=0,this.presetZones=[],this.sampleIDOffset=0,this.foundSamplesAndGenerators=[];for(let e=0;e<128;e++)this.foundSamplesAndGenerators[e]=[];this.library=0,this.genre=0,this.morphology=0,this.defaultModulators=A}deletePreset(){this.presetZones.forEach(A=>A.deleteZone()),this.presetZones.length=0}deleteZone(A){this.presetZones[A].deleteZone(),this.presetZones.splice(A,1)}preload(A,e){for(let s=A;s<e+1;s++)for(let n=0;n<128;n++)this.getSamplesAndGenerators(s,n).forEach(o=>{o.sample.isSampleLoaded||o.sample.getAudioData()})}preloadSpecific(A,e){this.getSamplesAndGenerators(A,e).forEach(s=>{s.sample.isSampleLoaded||s.sample.getAudioData()})}getSamplesAndGenerators(A,e){let s=this.foundSamplesAndGenerators[A][e];if(s)return s;if(this.presetZones.length<1)return[];function n(c,f){return f>=c.min&&f<=c.max}function o(c,f){c.push(...f.filter(M=>!c.find(D=>D.generatorType===M.generatorType)))}function i(c,f){c.push(...f.filter(M=>!c.find(D=>P.isIdentical(M,D))))}let a=[],C=this.presetZones[0].isGlobal?[...this.presetZones[0].generators]:[],h=this.presetZones[0].isGlobal?[...this.presetZones[0].modulators]:[],d=this.presetZones[0].isGlobal?this.presetZones[0].keyRange:{min:0,max:127},Q=this.presetZones[0].isGlobal?this.presetZones[0].velRange:{min:0,max:127};return this.presetZones.filter(c=>n(c.hasKeyRange?c.keyRange:d,A)&&n(c.hasVelRange?c.velRange:Q,e)&&!c.isGlobal).forEach(c=>{if(c.instrument.instrumentZones.length<1)return;let f=c.generators,M=c.modulators,D=c.instrument.instrumentZones[0],v=D.isGlobal?[...D.generators]:[],y=D.isGlobal?[...D.modulators]:[],w=D.isGlobal?D.keyRange:{min:0,max:127},x=D.isGlobal?D.velRange:{min:0,max:127};c.instrument.instrumentZones.filter(I=>n(I.hasKeyRange?I.keyRange:w,A)&&n(I.hasVelRange?I.velRange:x,e)&&!I.isGlobal).forEach(I=>{let tA=[...I.generators],q=[...I.modulators];o(f,C),o(tA,v),i(M,h),i(q,y),i(q,this.defaultModulators);let iA=[...q];for(let V=0;V<M.length;V++){let aA=M[V],oA=iA.findIndex(eA=>P.isIdentical(aA,eA));oA!==-1?iA[oA]=iA[oA].sumTransform(aA):iA.push(aA)}a.push({instrumentGenerators:tA,presetGenerators:f,modulators:iA,sample:I.sample,sampleID:I.generators.find(V=>V.generatorType===r.sampleID).generatorValue})})}),this.foundSamplesAndGenerators[A][e]=a,a}};var Ie=class t{constructor(A=void 0){this.soundFontInfo={},this.presets=[],this.samples=[],this.instruments=[],this.defaultModulators=je.map(e=>P.copy(e)),A?.presets&&(this.presets.push(...A.presets),this.soundFontInfo=A.info)}static mergeSoundfonts(...A){let e=A.shift(),s=e.presets;for(;A.length;)A.shift().presets.forEach(o=>{s.find(i=>i.bank===o.bank&&i.program===o.program)===void 0&&s.push(o)});return new t({presets:s,info:e.soundFontInfo})}static getDummySoundfontFile(){let A=new t,e=new ie("Saw",44100,65,20,0,0,0,127);e.sampleData=new Float32Array(128);for(let h=0;h<128;h++)e.sampleData[h]=h/128*2-1;A.samples.push(e);let s=new RA;s.isGlobal=!0,s.generators.push(new N(r.initialAttenuation,375)),s.generators.push(new N(r.releaseVolEnv,-1e3)),s.generators.push(new N(r.sampleModes,1));let n=new RA;n.sample=e;let o=new RA;o.sample=e,o.generators.push(new N(r.fineTune,-9));let i=new ae;i.instrumentName="Saw Wave",i.instrumentZones.push(s),i.instrumentZones.push(n),i.instrumentZones.push(o),A.instruments.push(i);let a=new re;a.instrument=i;let C=new ge(A.defaultModulators);return C.presetName="Saw Wave",C.presetZones.push(a),A.presets.push(C),A.soundFontInfo.ifil="2.1",A.soundFontInfo.isng="EMU8000",A.soundFontInfo.INAM="Dummy",A.write().buffer}removeUnusedElements(){this.instruments.forEach(A=>{A.useCount<1&&A.instrumentZones.forEach(e=>{e.isGlobal||e.sample.useCount--})}),this.instruments=this.instruments.filter(A=>A.useCount>0),this.samples=this.samples.filter(A=>A.useCount>0)}deleteInstrument(A){if(A.useCount>0)throw new Error(`Cannot delete an instrument that has ${A.useCount} usages.`);this.instruments.splice(this.instruments.indexOf(A),1),A.deleteInstrument(),this.removeUnusedElements()}deletePreset(A){A.deletePreset(),this.presets.splice(this.presets.indexOf(A),1),this.removeUnusedElements()}deleteSample(A){if(A.useCount>0)throw new Error(`Cannot delete sample that has ${A.useCount} usages.`);this.samples.splice(this.samples.indexOf(A),1),this.removeUnusedElements()}setSampleIDOffset(A){this.presets.forEach(e=>e.sampleIDOffset=A)}getPresetNoFallback(A,e,s=!1){let n=this.presets.find(o=>o.bank===A&&o.program===e);if(n)return n;if(s!==!1)return A===128?this.presets.find(o=>o.bank===128):this.presets.find(o=>o.program===e)}getPreset(A,e){let s=this.presets.find(n=>n.bank===A&&n.program===e);return s||(A===128?(s=this.presets.find(n=>n.bank===128&&n.program===e),s||(s=this.presets.find(n=>n.bank===128))):s=this.presets.find(n=>n.program===e&&n.bank!==128),s&&T(`%cPreset ${A}.${e} not found. Replaced with %c${s.presetName} (${s.bank}.${s.program})`,g.warn,g.recognized)),s||(T(`Preset ${e} not found. Defaulting to`,this.presets[0].presetName),s=this.presets[0]),s}getPresetByName(A){let e=this.presets.find(s=>s.presetName===A);return e||(T("Preset not found. Defaulting to:",this.presets[0].presetName),e=this.presets[0]),e}parsingError(A){throw new Error(`SF parsing error: ${A} The file may be corrupted.`)}destroySoundfont(){delete this.presets,delete this.instruments,delete this.samples}};Ie.prototype.write=ho;Ie.prototype.writeDLS=Fo;function Ro(t){QA("%cLoading instruments...",g.info);for(let A=0;A<this.instrumentAmount;A++)this.readDLSInstrument(j(t.chunkData));Z()}var ut=class extends ge{constructor(A,e){super(je),this.program=e&127,this.bank=A>>8&127,A>>31&&(this.bank=128),this.DLSInstrument=new ae,this.DLSInstrument.addUseCount();let n=new re;n.instrument=this.DLSInstrument,this.presetZones=[n]}};function Go(t){this.verifyHeader(t,"LIST"),this.verifyText(z(t.chunkData,4),"ins ");let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(j(t.chunkData));let e=A.find(c=>c.header==="insh");if(!e)throw Z(),new Error("No instrument header!");let s=G(e.chunkData,4),n=G(e.chunkData,4),o=G(e.chunkData,4),i=new ut(n,o),a="unnamedPreset",C=MA(A,"INFO");if(C){let c=j(C.chunkData);for(;c.header!=="INAM";)c=j(C.chunkData);a=z(c.chunkData,c.chunkData.length).trim()}i.presetName=a,i.DLSInstrument.instrumentName=a,Be(`%cParsing %c"${a}"%c...`,g.info,g.recognized,g.info);let h=MA(A,"lrgn");if(!h)throw Z(),new Error("No region list!");let d=new RA;d.isGlobal=!0;let Q=MA(A,"lart"),l=MA(A,"lar2");(l!==void 0||Q!==void 0)&&this.readLart(Q,l,d),d.generators=d.generators.filter(c=>c.generatorValue!==J[c.generatorType].def),d.modulators.find(c=>c.modulatorDestination===r.reverbEffectsSend)===void 0&&d.modulators.push(P.copy(Bt)),d.modulators.find(c=>c.modulatorDestination===r.chorusEffectsSend)===void 0&&d.modulators.push(P.copy(ht)),i.DLSInstrument.instrumentZones.push(d);for(let c=0;c<s;c++){let f=j(h.chunkData);this.verifyHeader(f,"LIST");let M=z(f.chunkData,4);M!=="rgn "&&M!=="rgn2"&&(Z(),this.parsingError(`Invalid DLS region! Expected "rgn " or "rgn2" got "${M}"`));let D=this.readRegion(f);D&&i.DLSInstrument.instrumentZones.push(D)}this.presets.push(i),this.instruments.push(i.DLSInstrument),Z()}function xo(t){let A,e=!1;switch(t){default:case H.modLfo:case H.vibratoLfo:case H.coarseTune:case H.fineTune:case H.modEnv:return;case H.keyNum:A=K.noteOnKeyNum;break;case H.none:A=K.noController;break;case H.modulationWheel:A=k.modulationWheel,e=!0;break;case H.pan:A=k.pan,e=!0;break;case H.reverb:A=k.reverbDepth,e=!0;break;case H.chorus:A=k.chorusDepth,e=!0;break;case H.expression:A=k.expressionController,e=!0;break;case H.volume:A=k.mainVolume,e=!0;break;case H.velocity:A=K.noteOnVelocity;break;case H.polyPressure:A=K.polyPressure;break;case H.channelPressure:A=K.channelPressure;break;case H.pitchWheel:A=K.pitchWheel;break;case H.pitchWheelRange:A=K.pitchWheelRange;break}if(A===void 0)throw new Error(`Unknown DLS Source: ${t}`);return{enum:A,isCC:e}}function kr(t,A){switch(t){default:case S.none:return;case S.pan:return r.pan;case S.gain:return{gen:r.initialAttenuation,newAmount:A*-1};case S.pitch:return r.fineTune;case S.keyNum:return r.overridingRootKey;case S.volEnvDelay:return r.delayVolEnv;case S.volEnvAttack:return r.attackVolEnv;case S.volEnvHold:return r.holdVolEnv;case S.volEnvDecay:return r.decayVolEnv;case S.volEnvSustain:return{gen:r.sustainVolEnv,newAmount:1e3-A};case S.volEnvRelease:return r.releaseVolEnv;case S.modEnvDelay:return r.delayModEnv;case S.modEnvAttack:return r.attackModEnv;case S.modEnvHold:return r.holdModEnv;case S.modEnvDecay:return r.decayModEnv;case S.modEnvSustain:return{gen:r.sustainModEnv,newAmount:(1e3-A)/10};case S.modEnvRelease:return r.releaseModEnv;case S.filterCutoff:return r.initialFilterFc;case S.filterQ:return r.initialFilterQ;case S.chorusSend:return r.chorusEffectsSend;case S.reverbSend:return r.reverbEffectsSend;case S.modLfoFreq:return r.freqModLFO;case S.modLfoDelay:return r.delayModLFO;case S.vibLfoFreq:return r.freqVibLFO;case S.vibLfoDelay:return r.delayVibLFO}}function wr(t,A){return t===H.vibratoLfo&&A===S.pitch?r.vibLfoToPitch:t===H.modLfo&&A===S.pitch?r.modLfoToPitch:t===H.modLfo&&A===S.filterCutoff?r.modLfoToFilterFc:t===H.modLfo&&A===S.gain?r.modLfoToVolume:t===H.modEnv&&A===S.filterCutoff?r.modEnvToFilterFc:t===H.modEnv&&A===S.pitch?r.modEnvToPitch:void 0}function Mo(t,A,e,s,n){let o=wr(t,e),i,a,C=!1,h=!1,d=n;if(o===void 0){let v=kr(e,n);if(v===void 0){T(`Invalid destination: ${e}`);return}if(i=v,v.newAmount!==void 0&&(d=v.newAmount,i=v.gen),a=xo(t),a===void 0){T(`Invalid source: ${t}`);return}}else i=o,C=!0,a={enum:K.noController,isCC:!1},h=!0;let Q=xo(A);if(Q===void 0){T(`Invalid control: ${A}`);return}let l;if(h)l=0;else{let v=s&15,y=s>>10&15;y===uA.linear&&v!==uA.linear&&(y=v);let w=s>>14&1,x=s>>15&1;i===r.initialAttenuation&&n<0&&(x=1),l=OA(y,w,x,a.isCC,a.enum)}let c=s>>4&15,f=s>>8&1,M=s>>9&1,D=OA(c,f,M,Q.isCC,Q.enum);if(C){let v=D;D=l,l=v}return new P({srcEnum:l,secSrcEnum:D,dest:i,transform:0,amt:d})}function ss(t,A){let e=t.chunkData,s=[],n=[];G(e,4);let o=G(e,4);for(let i=0;i<o;i++){let a=G(e,2),C=G(e,2),h=G(e,2),d=G(e,2),l=(G(e,4)|0)>>16;if(a===0&&C===0&&d===0){let c;switch(h){case S.pan:c=new N(r.pan,l);break;case S.gain:c=new N(r.initialAttenuation,-l*10/.4);break;case S.filterCutoff:c=new N(r.initialFilterFc,l);break;case S.filterQ:c=new N(r.initialFilterQ,l);break;case S.modLfoFreq:c=new N(r.freqModLFO,l);break;case S.modLfoDelay:c=new N(r.delayModLFO,l);break;case S.vibLfoFreq:c=new N(r.freqVibLFO,l);break;case S.vibLfoDelay:c=new N(r.delayVibLFO,l);break;case S.volEnvDelay:c=new N(r.delayVolEnv,l);break;case S.volEnvAttack:c=new N(r.attackVolEnv,l);break;case S.volEnvHold:c=new N(r.holdVolEnv,l,!1);break;case S.volEnvDecay:c=new N(r.decayVolEnv,l,!1);break;case S.volEnvRelease:c=new N(r.releaseVolEnv,l);break;case S.volEnvSustain:let f=1e3-l;c=new N(r.sustainVolEnv,f);break;case S.modEnvDelay:c=new N(r.delayModEnv,l);break;case S.modEnvAttack:c=new N(r.attackModEnv,l);break;case S.modEnvHold:c=new N(r.holdModEnv,l,!1);break;case S.modEnvDecay:c=new N(r.decayModEnv,l,!1);break;case S.modEnvRelease:c=new N(r.releaseModEnv,l);break;case S.modEnvSustain:let M=1e3-l;c=new N(r.sustainModEnv,M);break;case S.reverbSend:c=new N(r.reverbEffectsSend,l);break;case S.chorusSend:c=new N(r.chorusEffectsSend,l);break;case S.pitch:let D=Math.floor(l/100),v=Math.floor(l-D*100);c=new N(r.fineTune,v),s.push(new N(r.coarseTune,D));break}c&&s.push(c)}else{let c=!0;if(C===H.none)if(a===H.modLfo&&h===S.pitch)s.push(new N(r.modLfoToPitch,l));else if(a===H.modLfo&&h===S.gain)s.push(new N(r.modLfoToVolume,l));else if(a===H.modLfo&&h===S.filterCutoff)s.push(new N(r.modLfoToFilterFc,l));else if(a===H.vibratoLfo&&h===S.pitch)s.push(new N(r.vibLfoToPitch,l));else if(a===H.modEnv&&h===S.pitch)s.push(new N(r.modEnvToPitch,l));else if(a===H.modEnv&&h===S.filterCutoff)s.push(new N(r.modEnvToFilterFc,l));else if(a===H.keyNum&&h===S.pitch)s.push(new N(r.scaleTuning,l/128));else if(a===H.keyNum&&h===S.volEnvHold){s.push(new N(r.keyNumToVolEnvHold,l/-128));let f=Math.round(60/128*l);s.forEach(M=>{M.generatorType===r.holdVolEnv&&(M.generatorValue+=f)})}else if(a===H.keyNum&&h===S.volEnvDecay){s.push(new N(r.keyNumToVolEnvDecay,l/-128));let f=Math.round(60/128*l);s.forEach(M=>{M.generatorType===r.decayVolEnv&&(M.generatorValue+=f)})}else if(a===H.keyNum&&h===S.modEnvHold){s.push(new N(r.keyNumToModEnvHold,l/-128));let f=Math.round(60/128*l);s.forEach(M=>{M.generatorType===r.holdModEnv&&(M.generatorValue+=f)})}else if(a===H.keyNum&&h===S.modEnvDecay){s.push(new N(r.keyNumToModEnvDecay,l/-128));let f=Math.round(60/128*l);s.forEach(M=>{M.generatorType===r.decayModEnv&&(M.generatorValue+=f)})}else c=!1;else c=!1;if(c===!1){let f=Mo(a,C,h,d,l);f?(n.push(f),m("%cSucceeded converting to SF2 Modulator!",g.recognized)):T("Failed converting to SF2 Modulator!")}}}return A&&n.push(P.copy(ct),P.copy(lt)),{modulators:n,generators:s}}function No(t,A,e){if(t)for(;t.chunkData.currentIndex<t.chunkData.length;){let s=j(t.chunkData);this.verifyHeader(s,"art1");let n=ss(s,!0);e.generators.push(...n.generators),e.modulators.push(...n.modulators)}if(A)for(;A.chunkData.currentIndex<A.chunkData.length;){let s=j(A.chunkData);this.verifyHeader(s,"art2");let n=ss(s,!1);e.generators.push(...n.generators),e.modulators.push(...n.modulators)}}var dt=class extends RA{constructor(A,e){super(),this.keyRange=A,this.velRange=e,this.isGlobal=!0}setWavesample(A,e,s,n,o,i,a){e!==0&&this.generators.push(new N(r.sampleModes,e)),this.generators.push(new N(r.initialAttenuation,A)),this.isGlobal=!1,a-=o.samplePitchCorrection;let C=Math.trunc(a/100);C!==0&&this.generators.push(new N(r.coarseTune,C));let h=a-C*100;if(h!==0&&this.generators.push(new N(r.fineTune,h)),e!==0){let d=s.start-o.sampleLoopStartIndex,Q=s.end-o.sampleLoopEndIndex;if(d!==0){let l=d%32768;this.generators.push(new N(r.startloopAddrsOffset,l));let c=Math.trunc(d/32768);c!==0&&this.generators.push(new N(r.startloopAddrsCoarseOffset,c))}if(Q!==0){let l=Q%32768;this.generators.push(new N(r.endloopAddrsOffset,l));let c=Math.trunc(Q/32768);c!==0&&this.generators.push(new N(r.endloopAddrsCoarseOffset,c))}}n!==o.samplePitch&&this.generators.push(new N(r.overridingRootKey,n)),this.generators.push(new N(r.sampleID,i)),this.sample=o,o.useCount++}};function bo(t){let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(j(t.chunkData));let e=A.find(q=>q.header==="rgnh"),s=G(e.chunkData,2),n=G(e.chunkData,2),o=G(e.chunkData,2),i=G(e.chunkData,2),a=new dt({min:s,max:n},{min:o,max:i});G(e.chunkData,2);let C=G(e.chunkData,2);C!==0&&a.generators.push(new N(r.exclusiveClass,C));let h=MA(A,"lart"),d=MA(A,"lar2");this.readLart(h,d,a),a.isGlobal=!1;let Q=A.find(q=>q.header==="wsmp");G(Q.chunkData,4);let l=G(Q.chunkData,2),c=oe(Q.chunkData[Q.chunkData.currentIndex++],Q.chunkData[Q.chunkData.currentIndex++]),M=(G(Q.chunkData,4)|0)/-655360;G(Q.chunkData,4);let D=G(Q.chunkData,4),v,y={start:0,end:0};if(D===0)v=0;else{G(Q.chunkData,4),G(Q.chunkData,4)===0?v=1:v=3,y.start=G(Q.chunkData,4);let iA=G(Q.chunkData,4);y.end=y.start+iA}let w=A.find(q=>q.header==="wlnk");if(w===void 0)return;G(w.chunkData,2),G(w.chunkData,2),G(w.chunkData,4);let x=G(w.chunkData,4),F=this.samples[x];if(F===void 0)throw new Error("Invalid sample ID!");let tA=(M||F.sampleDbAttenuation)*10/.4;return a.setWavesample(tA,v,y,l,F,x,c),a}var ft=class extends ie{sampleDbAttenuation;sampleData;constructor(A,e,s,n,o,i,a,C){super(A,e,s,n,0,1,o,i),this.sampleData=a,this.sampleDbAttenuation=C}getAudioData(){return this.sampleData}getRawData(){if(this.isCompressed){if(!this.compressedData)throw new Error("Compressed but no data?? This shouldn't happen!!");return this.compressedData}return super.getRawData()}};var Lo={PCM:1,ALAW:6};function Fr(t,A){let e=Math.pow(2,A*8-1),s=Math.pow(2,A*8),n,o=!1;A===1?(n=255,o=!0):n=e;let i=t.size/A,a=new Float32Array(i);for(let C=0;C<a.length;C++){let h=G(t.chunkData,A);o?a[C]=h/n-.5:(h>=e&&(h-=s),a[C]=h/n)}return a}function Rr(t,A){let e=t.size/A,s=new Float32Array(e);for(let n=0;n<s.length;n++){let o=G(t.chunkData,A),i=o^85;i&=127;let a=i>>4,C=i&15;a>0&&(C+=16),C=(C<<4)+8,a>1&&(C=C<<a-1);let h=o>127?C:-C;s[n]=h/32678}return s}function Uo(t){QA("%cLoading Wave samples...",g.recognized);let A=0;for(;t.chunkData.currentIndex<t.chunkData.length;){let e=j(t.chunkData);this.verifyHeader(e,"LIST"),this.verifyText(z(e.chunkData,4),"wave");let s=[];for(;e.chunkData.currentIndex<e.chunkData.length;)s.push(j(e.chunkData));let n=s.find(F=>F.header==="fmt ");if(!n)throw new Error("No fmt chunk in the wave file!");let o=G(n.chunkData,2),i=G(n.chunkData,2);if(i!==1)throw new Error(`Only mono samples are supported. Fmt reports ${i} channels`);let a=G(n.chunkData,4);G(n.chunkData,4),G(n.chunkData,2);let h=G(n.chunkData,2)/8,d=!1,Q=s.find(F=>F.header==="data");Q||this.parsingError("No data chunk in the WAVE chunk!");let l;switch(o){default:d=!0,l=new Float32Array(Q.size/h);break;case Lo.PCM:l=Fr(Q,h);break;case Lo.ALAW:l=Rr(Q,h);break}let c=MA(s,"INFO"),f=`Unnamed ${A}`;if(c){let F=j(c.chunkData);for(;F.header!=="INAM"&&c.chunkData.currentIndex<c.chunkData.length;)F=j(c.chunkData);F.header==="INAM"&&(f=z(F.chunkData,F.size).trim())}let M=60,D=0,v=0,y=l.length-1,w=0,x=s.find(F=>F.header==="wsmp");if(x){G(x.chunkData,4),M=G(x.chunkData,2),D=oe(x.chunkData[x.chunkData.currentIndex++],x.chunkData[x.chunkData.currentIndex++]);let F=Math.trunc(D/100);if(M+=F,D-=F*100,w=(G(x.chunkData,4)|0)/-655360,G(x.chunkData,4),G(x.chunkData,4)===1){G(x.chunkData,8),v=G(x.chunkData,4);let q=G(x.chunkData,4);y=v+q}}else T("No wsmp chunk in wave... using sane defaults.");d&&console.error(`Failed to load '${f}': Unsupported format: (${o})`),this.samples.push(new ft(f,a,M,D,v,y,l,w)),A++,m(`%cLoaded sample %c${f}`,g.info,g.recognized)}Z()}var ee=class extends Ie{constructor(A){super(),this.dataArray=new b(A),Be("%cParsing DLS...",g.info),this.dataArray||(Z(),this.parsingError("No data provided!"));let e=j(this.dataArray,!1);this.verifyHeader(e,"riff"),this.verifyText(z(this.dataArray,4).toLowerCase(),"dls ");let s=[];for(;this.dataArray.currentIndex<this.dataArray.length;)s.push(j(this.dataArray));this.soundFontInfo.ifil="2.1",this.soundFontInfo.isng="EMU8000",this.soundFontInfo.INAM="Unnamed DLS",this.soundFontInfo.IENG="Unknown",this.soundFontInfo.IPRD="SpessaSynth DLS",this.soundFontInfo.ICRD=new Date().toDateString();let n=MA(s,"INFO");if(n)for(;n.chunkData.currentIndex<n.chunkData.length;){let C=j(n.chunkData);this.soundFontInfo[C.header]=z(C.chunkData,C.size)}this.soundFontInfo.ICMT=this.soundFontInfo.ICMT||"(No description)",this.soundFontInfo.ISBJ&&(this.soundFontInfo.ICMT+=`
|
|
16
16
|
`+this.soundFontInfo.ISBJ,delete this.soundFontInfo.ISBJ),this.soundFontInfo.ICMT+=`
|
|
17
|
-
Converted from DLS to SF2 with SpessaSynth`;for(let[C,
|
|
18
|
-
%c${this.instruments.length}%c instruments and %c${this.samples.length}%c samples.`,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info),V()}verifyHeader(A,e){A.header.toLowerCase()!==e.toLowerCase()&&(V(),this.parsingError(`Invalid DLS chunk header! Expected "${e.toLowerCase()}" got "${A.header.toLowerCase()}"`))}verifyText(A,e){A.toLowerCase()!==e.toLowerCase()&&(V(),this.parsingError(`FourCC error: Expected "${e.toLowerCase()}" got "${A.toLowerCase()}"`))}parsingError(A){throw new Error(`DLS parse error: ${A} The file may be corrupted.`)}destroySoundfont(){super.destroySoundfont(),delete this.dataArray}};ee.prototype.readDLSInstrumentList=ko;ee.prototype.readDLSInstrument=wo;ee.prototype.readRegion=Mo;ee.prototype.readLart=Go;ee.prototype.readDLSSamples=No;var $t=class extends re{constructor(A,e,n,s,o,i,a,C,B,d,Q,l,c){super(A,i,a,C,B,d,s-e/2,o-e/2),this.sampleName=A,this.sampleStartIndex=e,this.sampleEndIndex=n,this.isSampleLoaded=!1,this.sampleID=l,this.sampleLength=this.sampleEndIndex-this.sampleStartIndex,this.sampleDataArray=Q,this.sampleData=new Float32Array(0),this.isCompressed&&(this.sampleLoopStartIndex+=this.sampleStartIndex/2,this.sampleLoopEndIndex+=this.sampleStartIndex/2,this.sampleLength=99999999),this.isDataRaw=c}getRawData(){let A=this.sampleDataArray;if(this.isCompressed){if(this.compressedData)return this.compressedData;let e=A.currentIndex;return A.slice(this.sampleStartIndex/2+e,this.sampleEndIndex/2+e)}else{this.isDataRaw||super.getRawData();let e=A.currentIndex;return A.slice(e+this.sampleStartIndex,e+this.sampleEndIndex)}}decodeVorbis(){if(this.sampleLength<1)return;let A=this.sampleDataArray,e=A.currentIndex,n=A.slice(this.sampleStartIndex/2+e,this.sampleEndIndex/2+e);this.sampleData=new Float32Array(0);try{let s=zA.decode(n.buffer);this.sampleData=s.data[0]}catch(s){T(`Error decoding sample ${this.sampleName}: ${s}`),this.sampleData=new Float32Array(this.sampleLoopEndIndex+1)}}getAudioData(){return this.isSampleLoaded?this.sampleData:this.sampleLength<1?new Float32Array(1):this.isCompressed?(this.decodeVorbis(),this.isSampleLoaded=!0,this.sampleData):this.isDataRaw?this.loadUncompressedData():this.getUncompressedReadyData()}loadUncompressedData(){if(this.isCompressed)return T("Trying to load a compressed sample via loadUncompressedData()... aborting!"),new Float32Array(0);let A=new Float32Array(this.sampleLength/2),e=this.sampleDataArray.currentIndex,n=new Int16Array(this.sampleDataArray.slice(e+this.sampleStartIndex,e+this.sampleEndIndex).buffer);for(let s=0;s<n.length;s++)A[s]=n[s]/32768;return this.sampleData=A,this.isSampleLoaded=!0,A}getUncompressedReadyData(){let A=this.sampleDataArray.slice(this.sampleStartIndex/2,this.sampleEndIndex/2);return this.sampleData=A,this.isSampleLoaded=!0,A}};function bo(t,A,e=!0){let n=[],s=0;for(;t.chunkData.length>t.chunkData.currentIndex;){let o=Rr(s,t.chunkData,A,e);n.push(o),s++}return n.length>1&&n.pop(),n}function Rr(t,A,e,n){let s=_(A,20),o=F(A,4)*2,i=F(A,4)*2,a=F(A,4),C=F(A,4),B=F(A,4),d=A[A.currentIndex++];d===255&&(d=60);let Q=Vn(A[A.currentIndex++]),l=F(A,2),c=F(A,2);return new $t(s,o,i,a,C,B,d,Q,l,c,e,t,n)}var An=class extends N{constructor(A){super();let e=A.currentIndex;this.generatorType=A[e+1]<<8|A[e],this.generatorValue=se(A[e+2],A[e+3]),A.currentIndex+=4}};function en(t){let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(new An(t.chunkData));return A.length>1&&A.pop(),A}var tn=class extends ie{constructor(A){super(),this.instrumentName=_(A.chunkData,20).trim(),this.instrumentZoneIndex=F(A.chunkData,2),this.instrumentZonesAmount=0}getInstrumentZones(A,e){this.instrumentZonesAmount=A;for(let n=this.instrumentZoneIndex;n<this.instrumentZonesAmount+this.instrumentZoneIndex;n++)this.instrumentZones.push(e[n])}};function Lo(t,A){let e=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let n=new tn(t);if(e.length>0){let s=n.instrumentZoneIndex-e[e.length-1].instrumentZoneIndex;e[e.length-1].getInstrumentZones(s,A)}e.push(n)}return e.length>1&&e.pop(),e}var nn=class extends FA{constructor(A){super(),this.generatorZoneStartIndex=F(A,2),this.modulatorZoneStartIndex=F(A,2),this.modulatorZoneSize=0,this.generatorZoneSize=0,this.isGlobal=!0}setZoneSize(A,e){this.modulatorZoneSize=A,this.generatorZoneSize=e}getGenerators(A){for(let e=this.generatorZoneStartIndex;e<this.generatorZoneStartIndex+this.generatorZoneSize;e++)this.generators.push(A[e])}getModulators(A){for(let e=this.modulatorZoneStartIndex;e<this.modulatorZoneStartIndex+this.modulatorZoneSize;e++)this.modulators.push(A[e])}getSample(A){let e=this.generators.find(n=>n.generatorType===r.sampleID);e&&(this.sample=A[e.generatorValue],this.isGlobal=!1,this.sample.useCount++)}getKeyRange(){let A=this.generators.find(e=>e.generatorType===r.keyRange);A&&(this.keyRange.min=A.generatorValue&127,this.keyRange.max=A.generatorValue>>8&127)}getVelRange(){let A=this.generators.find(e=>e.generatorType===r.velRange);A&&(this.velRange.min=A.generatorValue&127,this.velRange.max=A.generatorValue>>8&127)}};function Uo(t,A,e,n){let s=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let o=new nn(t.chunkData);if(s.length>0){let i=o.modulatorZoneStartIndex-s[s.length-1].modulatorZoneStartIndex,a=o.generatorZoneStartIndex-s[s.length-1].generatorZoneStartIndex;s[s.length-1].setZoneSize(i,a),s[s.length-1].getGenerators(A),s[s.length-1].getModulators(e),s[s.length-1].getSample(n),s[s.length-1].getKeyRange(),s[s.length-1].getVelRange()}s.push(o)}return s.length>1&&s.pop(),s}var sn=class extends oe{constructor(A){super(),this.generatorZoneStartIndex=F(A,2),this.modulatorZoneStartIndex=F(A,2),this.modulatorZoneSize=0,this.generatorZoneSize=0,this.isGlobal=!0}setZoneSize(A,e){this.modulatorZoneSize=A,this.generatorZoneSize=e}getGenerators(A){for(let e=this.generatorZoneStartIndex;e<this.generatorZoneStartIndex+this.generatorZoneSize;e++)this.generators.push(A[e])}getModulators(A){for(let e=this.modulatorZoneStartIndex;e<this.modulatorZoneStartIndex+this.modulatorZoneSize;e++)this.modulators.push(A[e])}getInstrument(A){let e=this.generators.find(n=>n.generatorType===r.instrument);e&&(this.instrument=A[e.generatorValue],this.instrument.addUseCount(),this.isGlobal=!1)}getKeyRange(){let A=this.generators.find(e=>e.generatorType===r.keyRange);A&&(this.keyRange.min=A.generatorValue&127,this.keyRange.max=A.generatorValue>>8&127)}getVelRange(){let A=this.generators.find(e=>e.generatorType===r.velRange);A&&(this.velRange.min=A.generatorValue&127,this.velRange.max=A.generatorValue>>8&127)}};function To(t,A,e,n){let s=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let o=new sn(t.chunkData);if(s.length>0){let i=o.modulatorZoneStartIndex-s[s.length-1].modulatorZoneStartIndex,a=o.generatorZoneStartIndex-s[s.length-1].generatorZoneStartIndex;s[s.length-1].setZoneSize(i,a),s[s.length-1].getGenerators(A),s[s.length-1].getModulators(e),s[s.length-1].getInstrument(n),s[s.length-1].getKeyRange(),s[s.length-1].getVelRange()}s.push(o)}return s.length>1&&s.pop(),s}var on=class extends ae{constructor(A,e){super(e),this.presetName=_(A.chunkData,20).trim().replace(/\d{3}:\d{3}/,""),this.program=F(A.chunkData,2),this.bank=F(A.chunkData,2),this.presetZoneStartIndex=F(A.chunkData,2),this.library=F(A.chunkData,4),this.genre=F(A.chunkData,4),this.morphology=F(A.chunkData,4),this.presetZonesAmount=0}getPresetZones(A,e){this.presetZonesAmount=A;for(let n=this.presetZoneStartIndex;n<this.presetZonesAmount+this.presetZoneStartIndex;n++)this.presetZones.push(e[n])}};function vo(t,A,e){let n=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let s=new on(t,e);if(n.length>0){let o=s.presetZoneStartIndex-n[n.length-1].presetZoneStartIndex;n[n.length-1].getPresetZones(o,A)}n.push(s)}return n.length>1&&n.pop(),n}var rn=class extends P{constructor(A){super({srcEnum:F(A,2),dest:F(A,2),amt:se(A[A.currentIndex++],A[A.currentIndex++]),secSrcEnum:F(A,2),transform:F(A,2)})}};function ut(t){let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(new rn(t.chunkData));return A}var dt=class extends ge{constructor(A,e=!0){super(),e&&console.warn("Using the constructor directly is deprecated. Use loadSoundFont instead."),this.dataArray=new b(A),Ce("%cParsing SoundFont...",g.info),this.dataArray||(V(),this.parsingError("No data provided!"));let n=z(this.dataArray,!1);this.verifyHeader(n,"riff");let s=_(this.dataArray,4).toLowerCase();if(s!=="sfbk"&&s!=="sfpk")throw V(),new SyntaxError(`Invalid soundFont! Expected "sfbk" or "sfpk" got "${s}"`);let o=s==="sfpk",i=z(this.dataArray);for(this.verifyHeader(i,"list"),_(i.chunkData,4);i.chunkData.length>i.chunkData.currentIndex;){let $=z(i.chunkData),IA;switch($.header.toLowerCase()){case"ifil":case"iver":IA=`${F($.chunkData,2)}.${F($.chunkData,2)}`,this.soundFontInfo[$.header]=IA;break;case"icmt":IA=_($.chunkData,$.chunkData.length,void 0,!1),this.soundFontInfo[$.header]=IA;break;case"dmod":let sA=ut($);sA.pop(),IA=`Modulators: ${sA.length}`;let iA=this.defaultModulators;this.defaultModulators=sA,this.defaultModulators.push(...iA.filter(eA=>!this.defaultModulators.find(lA=>P.isIdentical(eA,lA)))),this.soundFontInfo[$.header]=$.chunkData;break;default:IA=_($.chunkData,$.chunkData.length),this.soundFontInfo[$.header]=IA}p(`%c"${$.header}": %c"${IA}"`,g.info,g.recognized)}let a=z(this.dataArray,!1);this.verifyHeader(a,"list"),this.verifyText(_(this.dataArray,4),"sdta"),p("%cVerifying smpl chunk...",g.warn);let C=z(this.dataArray,!1);this.verifyHeader(C,"smpl");let B;if(o){p("%cSF2Pack detected, attempting to decode the smpl chunk...",g.info);try{B=zA.decode(this.dataArray.buffer.slice(this.dataArray.currentIndex,this.dataArray.currentIndex+a.size-12)).data[0]}catch($){throw V(),new Error(`SF2Pack Ogg Vorbis decode error: ${$}`)}p(`%cDecoded the smpl chunk! Length: %c${B.length}`,g.info,g.value)}else B=this.dataArray,this.sampleDataStartIndex=this.dataArray.currentIndex;p(`%cSkipping sample chunk, length: %c${a.size-12}`,g.info,g.value),this.dataArray.currentIndex+=a.size-12,p("%cLoading preset data chunk...",g.warn);let d=z(this.dataArray);this.verifyHeader(d,"list"),_(d.chunkData,4);let Q=z(d.chunkData);this.verifyHeader(Q,"phdr");let l=z(d.chunkData);this.verifyHeader(l,"pbag");let c=z(d.chunkData);this.verifyHeader(c,"pmod");let f=z(d.chunkData);this.verifyHeader(f,"pgen");let y=z(d.chunkData);this.verifyHeader(y,"inst");let S=z(d.chunkData);this.verifyHeader(S,"ibag");let w=z(d.chunkData);this.verifyHeader(w,"imod");let H=z(d.chunkData);this.verifyHeader(H,"igen");let R=z(d.chunkData);this.verifyHeader(R,"shdr"),this.dataArray.currentIndex=this.sampleDataStartIndex,this.samples.push(...bo(R,B,!o));let x=en(H),G=ut(w),I=Uo(S,x,G,this.samples);this.instruments=Lo(y,I);let rA=en(f),Z=ut(c),AA=To(l,rA,Z,this.instruments);this.presets.push(...vo(Q,AA,this.defaultModulators)),this.presets.sort(($,IA)=>$.program-IA.program+($.bank-IA.bank)),p(`%cParsing finished! %c"${this.soundFontInfo.INAM}"%c has %c${this.presets.length} %cpresets,
|
|
19
|
-
%c${this.instruments.length}%c instruments and %c${this.samples.length}%c samples.`,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info),V(),o&&delete this.dataArray}verifyHeader(A,e){A.header.toLowerCase()!==e.toLowerCase()&&(V(),this.parsingError(`Invalid chunk header! Expected "${e.toLowerCase()}" got "${A.header.toLowerCase()}"`))}verifyText(A,e){A.toLowerCase()!==e.toLowerCase()&&(V(),this.parsingError(`Invalid FourCC: Expected "${e.toLowerCase()}" got "${A.toLowerCase()}"\``))}destroySoundfont(){super.destroySoundfont(),delete this.dataArray}};function He(t){let A=t.slice(8,12),e=new b(A);return _(e,4,void 0,!1).toLowerCase()==="dls "?new ee(t):new dt(t,!1)}function Ho(t,A,e=!1){let n=this.workletProcessorChannels[t];if(n===void 0){T(`Trying to access channel ${t} which does not exist... ignoring!`);return}if(n.lockPreset)return;let s=XA(n),o,i;if(this.overrideSoundfont){let a=s===128?128:s-this.soundfontBankOffset,C=this.overrideSoundfont.getPresetNoFallback(a,A);C?(o=s,i=C,n.presetUsesOverride=!0):(i=this.soundfontManager.getPreset(s,A),o=i.bank,n.presetUsesOverride=!1)}else i=this.soundfontManager.getPreset(s,A),o=i.bank,n.presetUsesOverride=!1;this.setPreset(t,i),this.callEvent("programchange",{channel:t,program:i.program,bank:o,userCalled:e})}function Yo(t,A){if(this.overrideSoundfont){let e=t===128?128:t-this.soundfontBankOffset,n=this.overrideSoundfont.getPresetNoFallback(e,A);if(n)return n}return this.soundfontManager.getPreset(t,A)}function Jo(t,A){if(!this.workletProcessorChannels[t].lockPreset){delete this.workletProcessorChannels[t].preset,this.workletProcessorChannels[t].preset=A,this.workletProcessorChannels[t].cachedVoices=[];for(let e=0;e<128;e++)this.workletProcessorChannels[t].cachedVoices.push([])}}function Po(t,A){let e=this.workletProcessorChannels[t];e.lockPreset||e.drumChannel!==A&&(A?(e.channelTransposeKeyShift=0,e.drumChannel=!0,this.setPreset(t,this.getPreset(XA(e),e.preset.program))):(e.drumChannel=!1,this.setPreset(t,this.getPreset(XA(e),e.preset.program))),e.presetUsesOverride=!1,this.callEvent("drumchange",{channel:t,isDrumChannel:e.drumChannel}),this.sendChannelProperties())}function qo(){let t=this.soundfontManager.getPresetList();this.overrideSoundfont!==void 0&&this.overrideSoundfont.presets.forEach(A=>{let e=A.bank===128?128:A.bank+this.soundfontBankOffset,n=t.find(s=>s.bank===e&&s.program===A.program);n!==void 0?n.presetName=A.presetName:t.push({presetName:A.presetName,bank:e,program:A.program})}),this.callEvent("presetlistchange",t)}function Oo(t=!0,A=!0){this.stopAllChannels(!0),A&&(delete this.overrideSoundfont,this.overrideSoundfont=void 0),this.defaultPreset=this.getPreset(0,0),this.drumPreset=this.getPreset(128,0);for(let e=0;e<this.workletProcessorChannels.length;e++){let n=this.workletProcessorChannels[e];n.cachedVoices=[];for(let s=0;s<128;s++)n.cachedVoices.push([]);(!A||A&&n.presetUsesOverride)&&(n.lockPreset=!1),this.programChange(e,n.preset.program)}t&&this.sendPresetList()}function Vo(t,A=!1){this.clearSoundFont(!1,A);try{A?(this.overrideSoundfont=He(t),this.overrideSoundfont.setSampleIDOffset(this.soundfontManager.totalSoundfontOffset)):this.soundfontManager.reloadManager(t)}catch(e){this.post({messageType:DA.soundfontError,messageData:e});return}this.defaultPreset=this.getPreset(0,0),this.drumPreset=this.getPreset(128,0),this.workletProcessorChannels.forEach((e,n)=>{this.programChange(n,e.preset.program)}),this.post({messageType:DA.ready,messageData:void 0}),this.sendPresetList(),p("%cSpessaSynth is ready!",g.recognized)}function Ko(t,A){this.soundfontBankOffset=A,this.reloadSoundFont(t,!0),this.overrideSoundfont.samples.forEach(e=>e.getAudioData()),this._snapshot!==void 0&&(this.applySynthesizerSnapshot(this._snapshot),this.resetAllControllers())}var ft=class t{program;bank;patchName;lockPreset;midiControllers;lockedControllers;customControllers;lockVibrato;channelVibrato;channelTransposeKeyShift;channelOctaveTuning;keyCentTuning;isMuted;velocityOverride;drumChannel;static getChannelSnapshot(A,e){let n=A.workletProcessorChannels[e],s=new t;return s.program=n.preset.program,s.bank=XA(n),s.lockPreset=n.lockPreset,s.patchName=n.preset.presetName,s.midiControllers=n.midiControllers,s.lockedControllers=n.lockedControllers,s.customControllers=n.customControllers,s.channelVibrato=n.channelVibrato,s.lockVibrato=n.lockGSNRPNParams,s.channelTransposeKeyShift=n.channelTransposeKeyShift,s.channelOctaveTuning=n.channelOctaveTuning,s.keyCentTuning=n.keyCentTuning,s.isMuted=n.isMuted,s.velocityOverride=n.velocityOverride,s.drumChannel=n.drumChannel,s}static applyChannelSnapshot(A,e,n){let s=A.workletProcessorChannels[e];A.muteChannel(e,n.isMuted),A.setDrums(e,n.drumChannel),s.midiControllers=n.midiControllers,s.lockedControllers=n.lockedControllers,s.customControllers=n.customControllers,s.channelVibrato=n.channelVibrato,s.lockGSNRPNParams=n.lockVibrato,s.channelTransposeKeyShift=n.channelTransposeKeyShift,s.channelOctaveTuning=n.channelOctaveTuning,s.velocityOverride=n.velocityOverride,s.lockPreset=!1,ne(s,n.bank),A.programChange(e,n.program),s.lockPreset=n.lockPreset}},mt=class t{channelSnapshots;keyMappings;mainVolume;pan;interpolation;system;transposition;effectsConfig;static createSynthesizerSnapshot(A){let e=new t;return e.channelSnapshots=A.workletProcessorChannels.map((n,s)=>ft.getChannelSnapshot(A,s)),e.keyMappings=A.keyModifierManager.getMappings(),e.mainVolume=A.midiVolume,e.pan=A.pan,e.system=A.system,e.interpolation=A.interpolationType,e.transposition=A.transposition,e.effectsConfig={},e}static applySnapshot(A,e){for(A.system=e.system,A.setMasterGain(e.mainVolume),A.setMasterPan(e.pan),A.transposeAllChannels(e.transposition),A.interpolationType=e.interpolation,A.keyModifierManager.setMappings(e.keyMappings);A.workletProcessorChannels.length<e.channelSnapshots.length;)A.createWorkletChannel();e.channelSnapshots.forEach((n,s)=>{ft.applyChannelSnapshot(A,s,n)}),p("%cFinished restoring controllers!",g.info)}};function Zo(){this.post({messageType:DA.synthesizerSnapshot,messageData:mt.createSynthesizerSnapshot(this)})}function Wo(t){mt.applySnapshot(this,t),p("%cFinished applying snapshot!",g.info)}var pt=class{constructor(A,e){this.ready=e,this.totalSoundfontOffset=0,this.reloadManager(A)}_assingSampleOffsets(){let A=0;this.soundfontList.forEach(e=>{e.soundfont.setSampleIDOffset(A),A+=e.soundfont.samples.length}),this.totalSoundfontOffset=A}generatePresetList(){this._assingSampleOffsets();let A={};for(let e=this.soundfontList.length-1;e>=0;e--){let n=this.soundfontList[e],s=new Set;for(let o of n.soundfont.presets){let i=`${o.bank+n.bankOffset}-${o.program}`;s.has(i)||(s.add(i),A[i]=o.presetName)}}this.presetList=[];for(let[e,n]of Object.entries(A)){let s=e.split("-");this.presetList.push({presetName:n,program:parseInt(s[1]),bank:parseInt(s[0])})}}handleMessage(A,e){switch(A){case pe.addNewSoundFont:this.addNewSoundFont(e[0],e[1],e[2]);break;case pe.reloadSoundFont:this.reloadManager(e);break;case pe.deleteSoundFont:this.deleteSoundFont(e);break;case pe.rearrangeSoundFonts:this.rearrangeSoundFonts(e)}}getPresetList(){return this.presetList.slice()}reloadManager(A){let e=He(A);this.soundfontList=[],this.soundfontList.push({id:"main",bankOffset:0,soundfont:e}),this.generatePresetList(),this.ready()}deleteSoundFont(A){if(this.soundfontList.length===0){T("1 soundfont left. Aborting!");return}let e=this.soundfontList.findIndex(n=>n.id===A);if(e===-1){T(`No soundfont with id of "${A}" found. Aborting!`);return}delete this.soundfontList[e].soundfont.presets,delete this.soundfontList[e].soundfont.instruments,delete this.soundfontList[e].soundfont.samples,this.soundfontList.splice(e,1),this.generatePresetList()}addNewSoundFont(A,e,n){if(this.soundfontList.find(s=>s.id===e)!==void 0)throw new Error("Cannot overwrite the existing soundfont. Use soundfontManager.delete(id) instead.");this.soundfontList.push({id:e,soundfont:He(A),bankOffset:n}),this.generatePresetList(),this.ready()}rearrangeSoundFonts(A){this.soundfontList.sort((e,n)=>A.indexOf(e.id)-A.indexOf(n.id)),this.generatePresetList()}getPreset(A,e){if(this.soundfontList.length<1)throw new Error("No soundfonts! This should never happen.");for(let n of this.soundfontList){let s=n.soundfont.getPresetNoFallback(A-n.bankOffset,e);if(s!==void 0)return s}if(A!==128){for(let n of this.soundfontList){let s=n.soundfont.presets.find(o=>o.program===e);if(s)return s}return this.soundfontList[0].soundfont.presets[0]}else{for(let n of this.soundfontList){let s=n.soundfont.presets.find(o=>o.bank===128);if(s)return s}return this.soundfontList[0].soundfont.presets[0]}}destroyManager(){this.soundfontList.forEach(A=>{A.soundfont.destroySoundfont()}),delete this.soundfontList}};var yt=class{sampleData;playbackStep=0;cursor=0;rootKey=0;loopStart=0;loopEnd=0;end=0;loopingMode=0;isLooping=!1;constructor(A,e,n,s,o,i,a,C){this.sampleData=A,this.playbackStep=e,this.cursor=n,this.rootKey=s,this.loopStart=o,this.loopEnd=i,this.end=a,this.loopingMode=C,this.isLooping=this.loopingMode===1||this.loopingMode===3}},Ye=class t{sample;filter=new we;generators;modulators=[];modulatedGenerators;finished=!1;isInRelease=!1;channelNumber=0;velocity=0;midiNote=0;pressure=0;targetKey=0;modulationEnvelope=new PA;volumeEnvelope;startTime=0;releaseStartTime=1/0;currentTuningCents=0;currentTuningCalculated=1;currentPan=.5;realKey;constructor(A,e,n,s,o,i,a,C,B,d){this.sample=e,this.generators=B,this.modulatedGenerators=new Int16Array(B),this.modulators=d,this.velocity=s,this.midiNote=n,this.channelNumber=o,this.startTime=i,this.targetKey=a,this.realKey=C,this.volumeEnvelope=new qA(A,B[r.sustainVolEnv])}static copy(A,e){let n=A.sample,s=new yt(n.sampleData,n.playbackStep,n.cursor,n.rootKey,n.loopStart,n.loopEnd,n.end,n.loopingMode);return new t(A.volumeEnvelope.sampleRate,s,A.midiNote,A.velocity,A.channelNumber,e,A.targetKey,A.realKey,A.generators,A.modulators.map(o=>P.copy(o)))}};function Xo(t,A,e,n,s,o,i=!1){let a,C=n.cachedVoices[A]?.[e],B=this.keyModifierManager.hasOverridePatch(t,A);if(C!==void 0&&!B)return C.map(l=>Ye.copy(l,s));let d=!0,Q=n.preset;if(B){d=!1;let l=this.keyModifierManager.getPatch(t,A);Q=this.soundfontManager.getPreset(l.bank,l.program)}return a=Q.getSamplesAndGenerators(A,e).reduce((l,c)=>{if(c.sample.sampleData===void 0)return T(`Discarding invalid sample: ${c.sample.sampleName}`),l;let f=new Int16Array(60);for(let G=0;G<60;G++)f[G]=Tn(G,c.presetGenerators,c.instrumentGenerators);f[r.initialAttenuation]=Math.floor(f[r.initialAttenuation]*.4);let y=c.sample.samplePitch;f[r.overridingRootKey]>-1&&(y=f[r.overridingRootKey]);let S=A;f[r.keyNum]>-1&&(S=f[r.keyNum]);let w=c.sample.sampleLoopStartIndex,H=c.sample.sampleLoopEndIndex,R=f[r.sampleModes],x=new yt(c.sample.getAudioData(),c.sample.sampleRate/sampleRate*Math.pow(2,c.sample.samplePitchCorrection/1200),0,y,w,H,Math.floor(c.sample.sampleData.length)-1,R);return f[r.velocity]>-1&&(e=f[r.velocity]),i&&Un([{Sample:c.sample.sampleName,Generators:f,Modulators:c.modulators.map(G=>G.debugString()),Velocity:e,TargetKey:S,MidiNote:A,WorkletSample:x}]),l.push(new Ye(sampleRate,x,A,e,t,s,S,o,f,c.modulators.map(G=>P.copy(G)))),l},[]),d&&(n.cachedVoices[A][e]=a.map(l=>Ye.copy(l,s))),a}var Gr=4600,Mr=2e3,_o=Math.PI/2;function zo(t,A,e,n,s,o){if(isNaN(A[0]))return;let i=(Math.max(-500,Math.min(500,t.modulatedGenerators[r.pan]))+500)/1e3;t.currentPan+=(i-t.currentPan)*this.panSmoothingFactor;let a=this.currentGain,C=Math.cos(_o*t.currentPan)*a*this.panLeft,B=Math.sin(_o*t.currentPan)*a*this.panRight,d=this.reverbGain*t.modulatedGenerators[r.reverbEffectsSend]/Gr*a,Q=this.chorusGain*t.modulatedGenerators[r.chorusEffectsSend]/Mr;if(d>0&&!this.oneOutputMode){let l=s[0],c=s[1];for(let f=0;f<A.length;f++)l[f]+=d*A[f],c[f]+=d*A[f]}if(Q>0&&!this.oneOutputMode){let l=o[0],c=o[1],f=C*Q,y=B*Q;for(let S=0;S<A.length;S++)l[S]+=f*A[S],c[S]+=y*A[S]}if(C>0)for(let l=0;l<A.length;l++)e[l]+=C*A[l];if(B>0)for(let l=0;l<A.length;l++)n[l]+=B*A[l]}var ds=.03,Fs=.07,zt=1,O=class extends AudioWorkletProcessor{constructor(A){super(),this.oneOutputMode=A.processorOptions?.startRenderingData?.oneOutput===!0,this._outputsAmount=this.oneOutputMode?1:A.processorOptions.midiChannels,this.enableEventSystem=A.processorOptions.enableEventSystem,this.alive=!0,this.deviceID=OA,this.interpolationType=ke.fourthOrder,this.processTickCallback=void 0,this.sequencer=new BA(this),this.transposition=0,this.tunings=[];for(let e=0;e<127;e++)this.tunings.push([]);this.soundfontBankOffset=0,this.masterGain=zt,this.midiVolume=1,this.reverbGain=1,this.chorusGain=1,this.voiceCap=Yn,this.pan=0,this.panLeft=.5,this.highPerformanceMode=!1,this.keyModifierManager=new $e,this.overrideSoundfont=void 0,this.panRight=.5;try{this.soundfontManager=new pt(A.processorOptions.soundfont,this.postReady.bind(this))}catch(e){throw this.post({messageType:DA.soundfontError,messageData:e}),e}this.sendPresetList(),this.defaultPreset=this.getPreset(0,0),this.drumPreset=this.getPreset(128,0),this.workletProcessorChannels=[];for(let e=0;e<A.processorOptions.midiChannels;e++)this.createWorkletChannel(!1);this.workletProcessorChannels[GA].preset=this.drumPreset,this.workletProcessorChannels[GA].drumChannel=!0,this.volumeEnvelopeSmoothingFactor=hs*(44100/sampleRate),this.panSmoothingFactor=cs*(44100/sampleRate),this.system=et,this.totalVoicesAmount=0,this._snapshot=A.processorOptions?.startRenderingData?.snapshot,this.port.onmessage=e=>this.handleMessage(e.data),A.processorOptions.startRenderingData&&(this._snapshot!==void 0&&(this.applySynthesizerSnapshot(this._snapshot),this.resetAllControllers()),p("%cRendering enabled! Starting render.",g.info),A.processorOptions.startRenderingData.parsedMIDI&&(A.processorOptions.startRenderingData?.loopCount!==void 0?(this.sequencer.loopCount=A.processorOptions.startRenderingData?.loopCount,this.sequencer.loop=!0):this.sequencer.loop=!1,this.sequencer.loadNewSongList([A.processorOptions.startRenderingData.parsedMIDI]))),zA.isInitialized.then(()=>{this.postReady(),p("%cSpessaSynth is ready!",g.recognized)})}get currentGain(){return this.masterGain*this.midiVolume}post(A){this.enableEventSystem&&this.port.postMessage(A)}postReady(){this.enableEventSystem&&this.port.postMessage({messageType:DA.ready,messageData:void 0})}debugMessage(){p({channels:this.workletProcessorChannels,voicesAmount:this.totalVoicesAmount,outputAmount:this._outputsAmount,dumpedSamples:this.workletDumpedSamplesList})}process(A,e){if(!this.alive)return!1;this.processTickCallback&&this.processTickCallback();let n=0;return this.workletProcessorChannels.forEach((s,o)=>{if(s.voices.length<1||s.isMuted)return;let i,a,C,B,d;if(this.oneOutputMode){let l=e[0];i=o%16*2,a=l[i],C=l[i+1]}else i=o%this._outputsAmount+2,a=e[i][0],C=e[i][1],B=e[0],d=e[1];let Q=s.voices;s.voices=[],Q.forEach(l=>{this.renderVoice(s,l,a,C,B,d),l.finished||s.voices.push(l)}),n+=s.voices.length}),n!==this.totalVoicesAmount&&(this.totalVoicesAmount=n,this.sendChannelProperties()),!0}destroyWorkletProcessor(){this.alive=!1,this.workletProcessorChannels.forEach(A=>{delete A.midiControllers,delete A.voices,delete A.sustainedVoices,delete A.cachedVoices,delete A.lockedControllers,delete A.preset,delete A.customControllers}),delete this.workletProcessorChannels,delete this.sequencer.midiData,delete this.sequencer,this.soundfontManager.destroyManager(),delete this.soundfontManager}};O.prototype.renderVoice=ls;O.prototype.releaseVoice=us;O.prototype.voiceKilling=Qs;O.prototype.getWorkletVoices=Xo;O.prototype.handleMessage=ps;O.prototype.sendChannelProperties=Ss;O.prototype.callEvent=ys;O.prototype.systemExclusive=Ds;O.prototype.noteOn=ws;O.prototype.noteOff=Rs;O.prototype.polyPressure=Js;O.prototype.killNote=Gs;O.prototype.stopAll=Ms;O.prototype.stopAllChannels=xs;O.prototype.muteChannel=Zs;O.prototype.setVibrato=Xs;O.prototype.disableAndLockGSNRPN=Ws;O.prototype.dataEntryCoarse=_s;O.prototype.dataEntryFine=zs;O.prototype.createWorkletChannel=vn;O.prototype.controllerChange=qs;O.prototype.channelPressure=Ys;O.prototype.resetAllControllers=js;O.prototype.resetControllers=$s;O.prototype.resetParameters=Ao;O.prototype.setMasterGain=Vs;O.prototype.setMasterPan=Ks;O.prototype.setMIDIVolume=Os;O.prototype.transposeAllChannels=Ns;O.prototype.transposeChannel=bs;O.prototype.setChannelTuning=Ls;O.prototype.setChannelTuningSemitones=Us;O.prototype.setMasterTuning=Ts;O.prototype.setModulationDepth=vs;O.prototype.pitchWheel=Hs;O.prototype.setOctaveTuning=Ps;O.prototype.programChange=Ho;O.prototype.getPreset=Yo;O.prototype.setPreset=Jo;O.prototype.setDrums=Po;O.prototype.reloadSoundFont=Vo;O.prototype.clearSoundFont=Oo;O.prototype.setEmbeddedSoundFont=Ko;O.prototype.sendPresetList=qo;O.prototype.sendSynthesizerSnapshot=Zo;O.prototype.applySynthesizerSnapshot=Wo;O.prototype.panVoice=zo;registerProcessor(Hn,O);p("%cProcessor succesfully registered!",g.recognized);
|
|
17
|
+
Converted from DLS to SF2 with SpessaSynth`;for(let[C,h]of Object.entries(this.soundFontInfo))m(`%c"${C}": %c"${h}"`,g.info,g.recognized);let o=s.find(C=>C.header==="colh");o||(Z(),this.parsingError("No colh chunk!")),this.instrumentAmount=G(o.chunkData,4),m(`%cInstruments amount: %c${this.instrumentAmount}`,g.info,g.recognized);let i=MA(s,"wvpl");i||(Z(),this.parsingError("No wvpl chunk!")),this.readDLSSamples(i);let a=MA(s,"lins");a||(Z(),this.parsingError("No lins chunk!")),this.readDLSInstrumentList(a),this.presets.sort((C,h)=>C.program-h.program+(C.bank-h.bank)),m(`%cParsing finished! %c"${this.soundFontInfo.INAM||"UNNAMED"}"%c has %c${this.presets.length} %cpresets,
|
|
18
|
+
%c${this.instruments.length}%c instruments and %c${this.samples.length}%c samples.`,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info),Z()}verifyHeader(A,e){A.header.toLowerCase()!==e.toLowerCase()&&(Z(),this.parsingError(`Invalid DLS chunk header! Expected "${e.toLowerCase()}" got "${A.header.toLowerCase()}"`))}verifyText(A,e){A.toLowerCase()!==e.toLowerCase()&&(Z(),this.parsingError(`FourCC error: Expected "${e.toLowerCase()}" got "${A.toLowerCase()}"`))}parsingError(A){throw new Error(`DLS parse error: ${A} The file may be corrupted.`)}destroySoundfont(){super.destroySoundfont(),delete this.dataArray}};ee.prototype.readDLSInstrumentList=Ro;ee.prototype.readDLSInstrument=Go;ee.prototype.readRegion=bo;ee.prototype.readLart=No;ee.prototype.readDLSSamples=Uo;var ns=class extends ie{constructor(A,e,s,n,o,i,a,C,h,d,Q,l,c){super(A,i,a,C,h,d,n-e/2,o-e/2),this.sampleName=A,this.sampleStartIndex=e,this.sampleEndIndex=s,this.isSampleLoaded=!1,this.sampleID=l,this.sampleLength=this.sampleEndIndex-this.sampleStartIndex,this.sampleDataArray=Q,this.sampleData=new Float32Array(0),this.isCompressed&&(this.sampleLoopStartIndex+=this.sampleStartIndex/2,this.sampleLoopEndIndex+=this.sampleStartIndex/2,this.sampleLength=99999999),this.isDataRaw=c}getRawData(){let A=this.sampleDataArray;if(this.isCompressed){if(this.compressedData)return this.compressedData;let e=A.currentIndex;return A.slice(this.sampleStartIndex/2+e,this.sampleEndIndex/2+e)}else{this.isDataRaw||super.getRawData();let e=A.currentIndex;return A.slice(e+this.sampleStartIndex,e+this.sampleEndIndex)}}decodeVorbis(){if(this.sampleLength<1)return;let A=this.sampleDataArray,e=A.currentIndex,s=A.slice(this.sampleStartIndex/2+e,this.sampleEndIndex/2+e);this.sampleData=new Float32Array(0);try{let n=zA.decode(s.buffer);this.sampleData=n.data[0]}catch(n){T(`Error decoding sample ${this.sampleName}: ${n}`),this.sampleData=new Float32Array(this.sampleLoopEndIndex+1)}}getAudioData(){return this.isSampleLoaded?this.sampleData:this.sampleLength<1?new Float32Array(1):this.isCompressed?(this.decodeVorbis(),this.isSampleLoaded=!0,this.sampleData):this.isDataRaw?this.loadUncompressedData():this.getUncompressedReadyData()}loadUncompressedData(){if(this.isCompressed)return T("Trying to load a compressed sample via loadUncompressedData()... aborting!"),new Float32Array(0);let A=new Float32Array(this.sampleLength/2),e=this.sampleDataArray.currentIndex,s=new Int16Array(this.sampleDataArray.slice(e+this.sampleStartIndex,e+this.sampleEndIndex).buffer);for(let n=0;n<s.length;n++)A[n]=s[n]/32768;return this.sampleData=A,this.isSampleLoaded=!0,A}getUncompressedReadyData(){let A=this.sampleDataArray.slice(this.sampleStartIndex/2,this.sampleEndIndex/2);return this.sampleData=A,this.isSampleLoaded=!0,A}};function To(t,A,e=!0){let s=[],n=0;for(;t.chunkData.length>t.chunkData.currentIndex;){let o=Gr(n,t.chunkData,A,e);s.push(o),n++}return s.length>1&&s.pop(),s}function Gr(t,A,e,s){let n=z(A,20),o=G(A,4)*2,i=G(A,4)*2,a=G(A,4),C=G(A,4),h=G(A,4),d=A[A.currentIndex++];d===255&&(d=60);let Q=Ws(A[A.currentIndex++]),l=G(A,2),c=G(A,2);return new ns(n,o,i,a,C,h,d,Q,l,c,e,t,s)}var os=class extends N{constructor(A){super();let e=A.currentIndex;this.generatorType=A[e+1]<<8|A[e],this.generatorValue=oe(A[e+2],A[e+3]),A.currentIndex+=4}};function rs(t){let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(new os(t.chunkData));return A.length>1&&A.pop(),A}var is=class extends ae{constructor(A){super(),this.instrumentName=z(A.chunkData,20).trim(),this.instrumentZoneIndex=G(A.chunkData,2),this.instrumentZonesAmount=0}getInstrumentZones(A,e){this.instrumentZonesAmount=A;for(let s=this.instrumentZoneIndex;s<this.instrumentZonesAmount+this.instrumentZoneIndex;s++)this.instrumentZones.push(e[s])}};function vo(t,A){let e=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let s=new is(t);if(e.length>0){let n=s.instrumentZoneIndex-e[e.length-1].instrumentZoneIndex;e[e.length-1].getInstrumentZones(n,A)}e.push(s)}return e.length>1&&e.pop(),e}var as=class extends RA{constructor(A){super(),this.generatorZoneStartIndex=G(A,2),this.modulatorZoneStartIndex=G(A,2),this.modulatorZoneSize=0,this.generatorZoneSize=0,this.isGlobal=!0}setZoneSize(A,e){this.modulatorZoneSize=A,this.generatorZoneSize=e}getGenerators(A){for(let e=this.generatorZoneStartIndex;e<this.generatorZoneStartIndex+this.generatorZoneSize;e++)this.generators.push(A[e])}getModulators(A){for(let e=this.modulatorZoneStartIndex;e<this.modulatorZoneStartIndex+this.modulatorZoneSize;e++)this.modulators.push(A[e])}getSample(A){let e=this.generators.find(s=>s.generatorType===r.sampleID);e&&(this.sample=A[e.generatorValue],this.isGlobal=!1,this.sample.useCount++)}getKeyRange(){let A=this.generators.find(e=>e.generatorType===r.keyRange);A&&(this.keyRange.min=A.generatorValue&127,this.keyRange.max=A.generatorValue>>8&127)}getVelRange(){let A=this.generators.find(e=>e.generatorType===r.velRange);A&&(this.velRange.min=A.generatorValue&127,this.velRange.max=A.generatorValue>>8&127)}};function Ho(t,A,e,s){let n=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let o=new as(t.chunkData);if(n.length>0){let i=o.modulatorZoneStartIndex-n[n.length-1].modulatorZoneStartIndex,a=o.generatorZoneStartIndex-n[n.length-1].generatorZoneStartIndex;n[n.length-1].setZoneSize(i,a),n[n.length-1].getGenerators(A),n[n.length-1].getModulators(e),n[n.length-1].getSample(s),n[n.length-1].getKeyRange(),n[n.length-1].getVelRange()}n.push(o)}return n.length>1&&n.pop(),n}var gs=class extends re{constructor(A){super(),this.generatorZoneStartIndex=G(A,2),this.modulatorZoneStartIndex=G(A,2),this.modulatorZoneSize=0,this.generatorZoneSize=0,this.isGlobal=!0}setZoneSize(A,e){this.modulatorZoneSize=A,this.generatorZoneSize=e}getGenerators(A){for(let e=this.generatorZoneStartIndex;e<this.generatorZoneStartIndex+this.generatorZoneSize;e++)this.generators.push(A[e])}getModulators(A){for(let e=this.modulatorZoneStartIndex;e<this.modulatorZoneStartIndex+this.modulatorZoneSize;e++)this.modulators.push(A[e])}getInstrument(A){let e=this.generators.find(s=>s.generatorType===r.instrument);e&&(this.instrument=A[e.generatorValue],this.instrument.addUseCount(),this.isGlobal=!1)}getKeyRange(){let A=this.generators.find(e=>e.generatorType===r.keyRange);A&&(this.keyRange.min=A.generatorValue&127,this.keyRange.max=A.generatorValue>>8&127)}getVelRange(){let A=this.generators.find(e=>e.generatorType===r.velRange);A&&(this.velRange.min=A.generatorValue&127,this.velRange.max=A.generatorValue>>8&127)}};function Yo(t,A,e,s){let n=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let o=new gs(t.chunkData);if(n.length>0){let i=o.modulatorZoneStartIndex-n[n.length-1].modulatorZoneStartIndex,a=o.generatorZoneStartIndex-n[n.length-1].generatorZoneStartIndex;n[n.length-1].setZoneSize(i,a),n[n.length-1].getGenerators(A),n[n.length-1].getModulators(e),n[n.length-1].getInstrument(s),n[n.length-1].getKeyRange(),n[n.length-1].getVelRange()}n.push(o)}return n.length>1&&n.pop(),n}var Is=class extends ge{constructor(A,e){super(e),this.presetName=z(A.chunkData,20).trim().replace(/\d{3}:\d{3}/,""),this.program=G(A.chunkData,2),this.bank=G(A.chunkData,2),this.presetZoneStartIndex=G(A.chunkData,2),this.library=G(A.chunkData,4),this.genre=G(A.chunkData,4),this.morphology=G(A.chunkData,4),this.presetZonesAmount=0}getPresetZones(A,e){this.presetZonesAmount=A;for(let s=this.presetZoneStartIndex;s<this.presetZonesAmount+this.presetZoneStartIndex;s++)this.presetZones.push(e[s])}};function Jo(t,A,e){let s=[];for(;t.chunkData.length>t.chunkData.currentIndex;){let n=new Is(t,e);if(s.length>0){let o=n.presetZoneStartIndex-s[s.length-1].presetZoneStartIndex;s[s.length-1].getPresetZones(o,A)}s.push(n)}return s.length>1&&s.pop(),s}var Es=class extends P{constructor(A){super({srcEnum:G(A,2),dest:G(A,2),amt:oe(A[A.currentIndex++],A[A.currentIndex++]),secSrcEnum:G(A,2),transform:G(A,2)})}};function mt(t){let A=[];for(;t.chunkData.length>t.chunkData.currentIndex;)A.push(new Es(t.chunkData));return A}var pt=class extends Ie{constructor(A,e=!0){super(),e&&console.warn("Using the constructor directly is deprecated. Use loadSoundFont instead."),this.dataArray=new b(A),Be("%cParsing SoundFont...",g.info),this.dataArray||(Z(),this.parsingError("No data provided!"));let s=j(this.dataArray,!1);this.verifyHeader(s,"riff");let n=z(this.dataArray,4).toLowerCase();if(n!=="sfbk"&&n!=="sfpk")throw Z(),new SyntaxError(`Invalid soundFont! Expected "sfbk" or "sfpk" got "${n}"`);let o=n==="sfpk",i=j(this.dataArray);for(this.verifyHeader(i,"list"),z(i.chunkData,4);i.chunkData.length>i.chunkData.currentIndex;){let V=j(i.chunkData),aA;switch(V.header.toLowerCase()){case"ifil":case"iver":aA=`${G(V.chunkData,2)}.${G(V.chunkData,2)}`,this.soundFontInfo[V.header]=aA;break;case"icmt":aA=z(V.chunkData,V.chunkData.length,void 0,!1),this.soundFontInfo[V.header]=aA;break;case"dmod":let oA=mt(V);oA.pop(),aA=`Modulators: ${oA.length}`;let eA=this.defaultModulators;this.defaultModulators=oA,this.defaultModulators.push(...eA.filter(AA=>!this.defaultModulators.find(hA=>P.isIdentical(AA,hA)))),this.soundFontInfo[V.header]=V.chunkData;break;default:aA=z(V.chunkData,V.chunkData.length),this.soundFontInfo[V.header]=aA}m(`%c"${V.header}": %c"${aA}"`,g.info,g.recognized)}let a=j(this.dataArray,!1);this.verifyHeader(a,"list"),this.verifyText(z(this.dataArray,4),"sdta"),m("%cVerifying smpl chunk...",g.warn);let C=j(this.dataArray,!1);this.verifyHeader(C,"smpl");let h;if(o){m("%cSF2Pack detected, attempting to decode the smpl chunk...",g.info);try{h=zA.decode(this.dataArray.buffer.slice(this.dataArray.currentIndex,this.dataArray.currentIndex+a.size-12)).data[0]}catch(V){throw Z(),new Error(`SF2Pack Ogg Vorbis decode error: ${V}`)}m(`%cDecoded the smpl chunk! Length: %c${h.length}`,g.info,g.value)}else h=this.dataArray,this.sampleDataStartIndex=this.dataArray.currentIndex;m(`%cSkipping sample chunk, length: %c${a.size-12}`,g.info,g.value),this.dataArray.currentIndex+=a.size-12,m("%cLoading preset data chunk...",g.warn);let d=j(this.dataArray);this.verifyHeader(d,"list"),z(d.chunkData,4);let Q=j(d.chunkData);this.verifyHeader(Q,"phdr");let l=j(d.chunkData);this.verifyHeader(l,"pbag");let c=j(d.chunkData);this.verifyHeader(c,"pmod");let f=j(d.chunkData);this.verifyHeader(f,"pgen");let M=j(d.chunkData);this.verifyHeader(M,"inst");let D=j(d.chunkData);this.verifyHeader(D,"ibag");let v=j(d.chunkData);this.verifyHeader(v,"imod");let y=j(d.chunkData);this.verifyHeader(y,"igen");let w=j(d.chunkData);this.verifyHeader(w,"shdr"),this.dataArray.currentIndex=this.sampleDataStartIndex,this.samples.push(...To(w,h,!o));let x=rs(y),F=mt(v),I=Ho(D,x,F,this.samples);this.instruments=vo(M,I);let tA=rs(f),q=mt(c),iA=Yo(l,tA,q,this.instruments);this.presets.push(...Jo(Q,iA,this.defaultModulators)),this.presets.sort((V,aA)=>V.program-aA.program+(V.bank-aA.bank)),m(`%cParsing finished! %c"${this.soundFontInfo.INAM}"%c has %c${this.presets.length} %cpresets,
|
|
19
|
+
%c${this.instruments.length}%c instruments and %c${this.samples.length}%c samples.`,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info,g.recognized,g.info),Z(),o&&delete this.dataArray}verifyHeader(A,e){A.header.toLowerCase()!==e.toLowerCase()&&(Z(),this.parsingError(`Invalid chunk header! Expected "${e.toLowerCase()}" got "${A.header.toLowerCase()}"`))}verifyText(A,e){A.toLowerCase()!==e.toLowerCase()&&(Z(),this.parsingError(`Invalid FourCC: Expected "${e.toLowerCase()}" got "${A.toLowerCase()}"\``))}destroySoundfont(){super.destroySoundfont(),delete this.dataArray}};function Je(t){let A=t.slice(8,12),e=new b(A);return z(e,4,void 0,!1).toLowerCase()==="dls "?new ee(t):new pt(t,!1)}function Po(t,A,e=!1){let s=this.workletProcessorChannels[t];if(s===void 0){T(`Trying to access channel ${t} which does not exist... ignoring!`);return}if(s.lockPreset)return;let n=XA(s),o,i;if(this.overrideSoundfont){let a=n===128?128:n-this.soundfontBankOffset,C=this.overrideSoundfont.getPresetNoFallback(a,A);C?(o=n,i=C,s.presetUsesOverride=!0):(i=this.soundfontManager.getPreset(n,A),o=i.bank,s.presetUsesOverride=!1)}else i=this.soundfontManager.getPreset(n,A),o=i.bank,s.presetUsesOverride=!1;this.setPreset(t,i),this.callEvent("programchange",{channel:t,program:i.program,bank:o,userCalled:e})}function qo(t,A){if(this.overrideSoundfont){let e=t===128?128:t-this.soundfontBankOffset,s=this.overrideSoundfont.getPresetNoFallback(e,A);if(s)return s}return this.soundfontManager.getPreset(t,A)}function Ko(t,A){if(!this.workletProcessorChannels[t].lockPreset){delete this.workletProcessorChannels[t].preset,this.workletProcessorChannels[t].preset=A,this.workletProcessorChannels[t].cachedVoices=[];for(let e=0;e<128;e++)this.workletProcessorChannels[t].cachedVoices.push([])}}function Oo(t,A){let e=this.workletProcessorChannels[t];e.lockPreset||e.drumChannel!==A&&(A?(e.channelTransposeKeyShift=0,e.drumChannel=!0,this.setPreset(t,this.getPreset(XA(e),e.preset.program))):(e.drumChannel=!1,this.setPreset(t,this.getPreset(XA(e),e.preset.program))),e.presetUsesOverride=!1,this.callEvent("drumchange",{channel:t,isDrumChannel:e.drumChannel}),this.sendChannelProperties())}function Vo(){let t=this.soundfontManager.getPresetList();this.overrideSoundfont!==void 0&&this.overrideSoundfont.presets.forEach(A=>{let e=A.bank===128?128:A.bank+this.soundfontBankOffset,s=t.find(n=>n.bank===e&&n.program===A.program);s!==void 0?s.presetName=A.presetName:t.push({presetName:A.presetName,bank:e,program:A.program})}),this.callEvent("presetlistchange",t)}function Zo(t=!0,A=!0){this.stopAllChannels(!0),A&&(delete this.overrideSoundfont,this.overrideSoundfont=void 0),this.defaultPreset=this.getPreset(0,0),this.drumPreset=this.getPreset(128,0);for(let e=0;e<this.workletProcessorChannels.length;e++){let s=this.workletProcessorChannels[e];s.cachedVoices=[];for(let n=0;n<128;n++)s.cachedVoices.push([]);(!A||A&&s.presetUsesOverride)&&(s.lockPreset=!1),this.programChange(e,s.preset.program)}t&&this.sendPresetList()}function Wo(t,A=!1){this.clearSoundFont(!1,A);try{A?(this.overrideSoundfont=Je(t),this.overrideSoundfont.setSampleIDOffset(this.soundfontManager.totalSoundfontOffset)):this.soundfontManager.reloadManager(t)}catch(e){this.post({messageType:kA.soundfontError,messageData:e});return}this.defaultPreset=this.getPreset(0,0),this.drumPreset=this.getPreset(128,0),this.workletProcessorChannels.forEach((e,s)=>{this.programChange(s,e.preset.program)}),this.post({messageType:kA.ready,messageData:void 0}),this.sendPresetList(),m("%cSpessaSynth is ready!",g.recognized)}function Xo(t,A){this.soundfontBankOffset=A,this.reloadSoundFont(t,!0),this.overrideSoundfont.samples.forEach(e=>e.getAudioData()),this._snapshot!==void 0&&(this.applySynthesizerSnapshot(this._snapshot),this.resetAllControllers())}var yt=class t{program;bank;patchName;lockPreset;midiControllers;lockedControllers;customControllers;lockVibrato;channelVibrato;channelTransposeKeyShift;channelOctaveTuning;keyCentTuning;isMuted;velocityOverride;drumChannel;static getChannelSnapshot(A,e){let s=A.workletProcessorChannels[e],n=new t;return n.program=s.preset.program,n.bank=XA(s),n.lockPreset=s.lockPreset,n.patchName=s.preset.presetName,n.midiControllers=s.midiControllers,n.lockedControllers=s.lockedControllers,n.customControllers=s.customControllers,n.channelVibrato=s.channelVibrato,n.lockVibrato=s.lockGSNRPNParams,n.channelTransposeKeyShift=s.channelTransposeKeyShift,n.channelOctaveTuning=s.channelOctaveTuning,n.keyCentTuning=s.keyCentTuning,n.isMuted=s.isMuted,n.velocityOverride=s.velocityOverride,n.drumChannel=s.drumChannel,n}static applyChannelSnapshot(A,e,s){let n=A.workletProcessorChannels[e];A.muteChannel(e,s.isMuted),A.setDrums(e,s.drumChannel),n.midiControllers=s.midiControllers,n.lockedControllers=s.lockedControllers,n.customControllers=s.customControllers,n.channelVibrato=s.channelVibrato,n.lockGSNRPNParams=s.lockVibrato,n.channelTransposeKeyShift=s.channelTransposeKeyShift,n.channelOctaveTuning=s.channelOctaveTuning,n.velocityOverride=s.velocityOverride,n.lockPreset=!1,ne(n,s.bank),A.programChange(e,s.program),n.lockPreset=s.lockPreset}},St=class t{channelSnapshots;keyMappings;mainVolume;pan;interpolation;system;transposition;effectsConfig;static createSynthesizerSnapshot(A){let e=new t;return e.channelSnapshots=A.workletProcessorChannels.map((s,n)=>yt.getChannelSnapshot(A,n)),e.keyMappings=A.keyModifierManager.getMappings(),e.mainVolume=A.midiVolume,e.pan=A.pan,e.system=A.system,e.interpolation=A.interpolationType,e.transposition=A.transposition,e.effectsConfig={},e}static applySnapshot(A,e){for(A.system=e.system,A.setMasterGain(e.mainVolume),A.setMasterPan(e.pan),A.transposeAllChannels(e.transposition),A.interpolationType=e.interpolation,A.keyModifierManager.setMappings(e.keyMappings);A.workletProcessorChannels.length<e.channelSnapshots.length;)A.createWorkletChannel();e.channelSnapshots.forEach((s,n)=>{yt.applyChannelSnapshot(A,n,s)}),m("%cFinished restoring controllers!",g.info)}};function _o(){this.post({messageType:kA.synthesizerSnapshot,messageData:St.createSynthesizerSnapshot(this)})}function zo(t){St.applySnapshot(this,t),m("%cFinished applying snapshot!",g.info)}var Dt=class{constructor(A,e){this.ready=e,this.totalSoundfontOffset=0,this.reloadManager(A)}_assingSampleOffsets(){let A=0;this.soundfontList.forEach(e=>{e.soundfont.setSampleIDOffset(A),A+=e.soundfont.samples.length}),this.totalSoundfontOffset=A}generatePresetList(){this._assingSampleOffsets();let A={};for(let e=this.soundfontList.length-1;e>=0;e--){let s=this.soundfontList[e],n=new Set;for(let o of s.soundfont.presets){let i=`${o.bank+s.bankOffset}-${o.program}`;n.has(i)||(n.add(i),A[i]=o.presetName)}}this.presetList=[];for(let[e,s]of Object.entries(A)){let n=e.split("-");this.presetList.push({presetName:s,program:parseInt(n[1]),bank:parseInt(n[0])})}}handleMessage(A,e){switch(A){case Se.addNewSoundFont:this.addNewSoundFont(e[0],e[1],e[2]);break;case Se.reloadSoundFont:this.reloadManager(e);break;case Se.deleteSoundFont:this.deleteSoundFont(e);break;case Se.rearrangeSoundFonts:this.rearrangeSoundFonts(e)}}getPresetList(){return this.presetList.slice()}reloadManager(A){let e=Je(A);this.soundfontList=[],this.soundfontList.push({id:"main",bankOffset:0,soundfont:e}),this.generatePresetList(),this.ready()}deleteSoundFont(A){if(this.soundfontList.length===0){T("1 soundfont left. Aborting!");return}let e=this.soundfontList.findIndex(s=>s.id===A);if(e===-1){T(`No soundfont with id of "${A}" found. Aborting!`);return}delete this.soundfontList[e].soundfont.presets,delete this.soundfontList[e].soundfont.instruments,delete this.soundfontList[e].soundfont.samples,this.soundfontList.splice(e,1),this.generatePresetList()}addNewSoundFont(A,e,s){if(this.soundfontList.find(n=>n.id===e)!==void 0)throw new Error("Cannot overwrite the existing soundfont. Use soundfontManager.delete(id) instead.");this.soundfontList.push({id:e,soundfont:Je(A),bankOffset:s}),this.generatePresetList(),this.ready()}rearrangeSoundFonts(A){this.soundfontList.sort((e,s)=>A.indexOf(e.id)-A.indexOf(s.id)),this.generatePresetList()}getPreset(A,e){if(this.soundfontList.length<1)throw new Error("No soundfonts! This should never happen.");for(let s of this.soundfontList){let n=s.soundfont.getPresetNoFallback(A-s.bankOffset,e);if(n!==void 0)return n}if(A!==128){for(let s of this.soundfontList){let n=s.soundfont.presets.find(o=>o.program===e);if(n)return n}return this.soundfontList[0].soundfont.presets[0]}else{for(let s of this.soundfontList){let n=s.soundfont.presets.find(o=>o.bank===128);if(n)return n}return this.soundfontList[0].soundfont.presets[0]}}destroyManager(){this.soundfontList.forEach(A=>{A.soundfont.destroySoundfont()}),delete this.soundfontList}};var kt=class{sampleData;playbackStep=0;cursor=0;rootKey=0;loopStart=0;loopEnd=0;end=0;loopingMode=0;isLooping=!1;constructor(A,e,s,n,o,i,a,C){this.sampleData=A,this.playbackStep=e,this.cursor=s,this.rootKey=n,this.loopStart=o,this.loopEnd=i,this.end=a,this.loopingMode=C,this.isLooping=this.loopingMode===1||this.loopingMode===3}},Pe=class t{sample;filter=new Re;generators;modulators=[];modulatedGenerators;finished=!1;isInRelease=!1;channelNumber=0;velocity=0;midiNote=0;pressure=0;targetKey=0;modulationEnvelope=new PA;volumeEnvelope;startTime=0;releaseStartTime=1/0;currentTuningCents=0;currentTuningCalculated=1;currentPan=.5;realKey;constructor(A,e,s,n,o,i,a,C,h,d){this.sample=e,this.generators=h,this.modulatedGenerators=new Int16Array(h),this.modulators=d,this.velocity=n,this.midiNote=s,this.channelNumber=o,this.startTime=i,this.targetKey=a,this.realKey=C,this.volumeEnvelope=new qA(A,h[r.sustainVolEnv])}static copy(A,e){let s=A.sample,n=new kt(s.sampleData,s.playbackStep,s.cursor,s.rootKey,s.loopStart,s.loopEnd,s.end,s.loopingMode);return new t(A.volumeEnvelope.sampleRate,n,A.midiNote,A.velocity,A.channelNumber,e,A.targetKey,A.realKey,A.generators,A.modulators.map(o=>P.copy(o)))}};function jo(t,A,e,s,n,o,i=!1){let a,C=s.cachedVoices[A]?.[e],h=this.keyModifierManager.hasOverridePatch(t,A);if(C!==void 0&&!h)return C.map(l=>Pe.copy(l,n));let d=!0,Q=s.preset;if(h){d=!1;let l=this.keyModifierManager.getPatch(t,A);Q=this.soundfontManager.getPreset(l.bank,l.program)}return a=Q.getSamplesAndGenerators(A,e).reduce((l,c)=>{if(c.sample.sampleData===void 0)return T(`Discarding invalid sample: ${c.sample.sampleName}`),l;let f=new Int16Array(60);for(let F=0;F<60;F++)f[F]=Ys(F,c.presetGenerators,c.instrumentGenerators);f[r.initialAttenuation]=Math.floor(f[r.initialAttenuation]*.4);let M=c.sample.samplePitch;f[r.overridingRootKey]>-1&&(M=f[r.overridingRootKey]);let D=A;f[r.keyNum]>-1&&(D=f[r.keyNum]);let v=c.sample.sampleLoopStartIndex,y=c.sample.sampleLoopEndIndex,w=f[r.sampleModes],x=new kt(c.sample.getAudioData(),c.sample.sampleRate/sampleRate*Math.pow(2,c.sample.samplePitchCorrection/1200),0,M,v,y,Math.floor(c.sample.sampleData.length)-1,w);return f[r.velocity]>-1&&(e=f[r.velocity]),i&&Hs([{Sample:c.sample.sampleName,Generators:f,Modulators:c.modulators.map(F=>F.debugString()),Velocity:e,TargetKey:D,MidiNote:A,WorkletSample:x}]),l.push(new Pe(sampleRate,x,A,e,t,n,D,o,f,c.modulators.map(F=>P.copy(F)))),l},[]),d&&(s.cachedVoices[A][e]=a.map(l=>Pe.copy(l,n))),a}var xr=4600,Mr=2e3,$o=Math.PI/2;function Ar(t,A,e,s,n,o){if(isNaN(A[0]))return;let i=(Math.max(-500,Math.min(500,t.modulatedGenerators[r.pan]))+500)/1e3;t.currentPan+=(i-t.currentPan)*this.panSmoothingFactor;let a=this.currentGain,C=Math.cos($o*t.currentPan)*a*this.panLeft,h=Math.sin($o*t.currentPan)*a*this.panRight,d=this.reverbGain*t.modulatedGenerators[r.reverbEffectsSend]/xr*a,Q=this.chorusGain*t.modulatedGenerators[r.chorusEffectsSend]/Mr;if(d>0&&!this.oneOutputMode){let l=n[0],c=n[1];for(let f=0;f<A.length;f++)l[f]+=d*A[f],c[f]+=d*A[f]}if(Q>0&&!this.oneOutputMode){let l=o[0],c=o[1],f=C*Q,M=h*Q;for(let D=0;D<A.length;D++)l[D]+=f*A[D],c[D]+=M*A[D]}if(C>0)for(let l=0;l<A.length;l++)e[l]+=C*A[l];if(h>0)for(let l=0;l<A.length;l++)s[l]+=h*A[l]}var pn=.03,xn=.07,ts=1,O=class extends AudioWorkletProcessor{constructor(A){super(),this.oneOutputMode=A.processorOptions?.startRenderingData?.oneOutput===!0,this._outputsAmount=this.oneOutputMode?1:A.processorOptions.midiChannels,this.enableEventSystem=A.processorOptions.enableEventSystem,this.alive=!0,this.deviceID=KA,this.interpolationType=Fe.fourthOrder,this.processTickCallback=void 0,this.sequencer=new BA(this),this.transposition=0,this.tunings=[];for(let e=0;e<127;e++)this.tunings.push([]);this.soundfontBankOffset=0,this.masterGain=ts,this.midiVolume=1,this.reverbGain=1,this.chorusGain=1,this.voiceCap=qs,this.pan=0,this.panLeft=.5,this.highPerformanceMode=!1,this.keyModifierManager=new et,this.overrideSoundfont=void 0,this.panRight=.5;try{this.soundfontManager=new Dt(A.processorOptions.soundfont,this.postReady.bind(this))}catch(e){throw this.post({messageType:kA.soundfontError,messageData:e}),e}this.sendPresetList(),this.defaultPreset=this.getPreset(0,0),this.drumPreset=this.getPreset(128,0),this.workletProcessorChannels=[];for(let e=0;e<A.processorOptions.midiChannels;e++)this.createWorkletChannel(!1);this.workletProcessorChannels[xA].preset=this.drumPreset,this.workletProcessorChannels[xA].drumChannel=!0,this.volumeEnvelopeSmoothingFactor=Qn*(44100/sampleRate),this.panSmoothingFactor=un*(44100/sampleRate),this.system=st,this.totalVoicesAmount=0,this._snapshot=A.processorOptions?.startRenderingData?.snapshot,this.port.onmessage=e=>this.handleMessage(e.data),A.processorOptions.startRenderingData&&(this._snapshot!==void 0&&(this.applySynthesizerSnapshot(this._snapshot),this.resetAllControllers()),m("%cRendering enabled! Starting render.",g.info),A.processorOptions.startRenderingData.parsedMIDI&&(A.processorOptions.startRenderingData?.loopCount!==void 0?(this.sequencer.loopCount=A.processorOptions.startRenderingData?.loopCount,this.sequencer.loop=!0):this.sequencer.loop=!1,this.sequencer.loadNewSongList([A.processorOptions.startRenderingData.parsedMIDI]))),zA.isInitialized.then(()=>{this.postReady(),m("%cSpessaSynth is ready!",g.recognized)})}get currentGain(){return this.masterGain*this.midiVolume}post(A){this.enableEventSystem&&this.port.postMessage(A)}postReady(){this.enableEventSystem&&this.port.postMessage({messageType:kA.ready,messageData:void 0})}debugMessage(){m({channels:this.workletProcessorChannels,voicesAmount:this.totalVoicesAmount,outputAmount:this._outputsAmount,dumpedSamples:this.workletDumpedSamplesList})}process(A,e){if(!this.alive)return!1;this.processTickCallback&&this.processTickCallback();let s=0;return this.workletProcessorChannels.forEach((n,o)=>{if(n.voices.length<1||n.isMuted)return;let i,a,C,h,d;if(this.oneOutputMode){let l=e[0];i=o%16*2,a=l[i],C=l[i+1]}else i=o%this._outputsAmount+2,a=e[i][0],C=e[i][1],h=e[0],d=e[1];let Q=n.voices;n.voices=[],Q.forEach(l=>{this.renderVoice(n,l,a,C,h,d),l.finished||n.voices.push(l)}),s+=n.voices.length}),s!==this.totalVoicesAmount&&(this.totalVoicesAmount=s,this.sendChannelProperties()),!0}destroyWorkletProcessor(){this.alive=!1,this.workletProcessorChannels.forEach(A=>{delete A.midiControllers,delete A.voices,delete A.sustainedVoices,delete A.cachedVoices,delete A.lockedControllers,delete A.preset,delete A.customControllers}),delete this.workletProcessorChannels,delete this.sequencer.midiData,delete this.sequencer,this.soundfontManager.destroyManager(),delete this.soundfontManager}};O.prototype.renderVoice=dn;O.prototype.releaseVoice=mn;O.prototype.voiceKilling=fn;O.prototype.getWorkletVoices=jo;O.prototype.handleMessage=Dn;O.prototype.sendChannelProperties=wn;O.prototype.callEvent=kn;O.prototype.systemExclusive=Fn;O.prototype.noteOn=Gn;O.prototype.noteOff=Mn;O.prototype.polyPressure=Kn;O.prototype.killNote=Nn;O.prototype.stopAll=bn;O.prototype.stopAllChannels=Ln;O.prototype.muteChannel=_n;O.prototype.setVibrato=jn;O.prototype.disableAndLockGSNRPN=zn;O.prototype.dataEntryCoarse=$n;O.prototype.dataEntryFine=Ao;O.prototype.createWorkletChannel=Js;O.prototype.controllerChange=Vn;O.prototype.channelPressure=qn;O.prototype.resetAllControllers=eo;O.prototype.resetControllers=to;O.prototype.resetParameters=so;O.prototype.setMasterGain=Wn;O.prototype.setMasterPan=Xn;O.prototype.setMIDIVolume=Zn;O.prototype.transposeAllChannels=Un;O.prototype.transposeChannel=Tn;O.prototype.setChannelTuning=vn;O.prototype.setChannelTuningSemitones=Hn;O.prototype.setMasterTuning=Yn;O.prototype.setModulationDepth=Jn;O.prototype.pitchWheel=Pn;O.prototype.setOctaveTuning=On;O.prototype.programChange=Po;O.prototype.getPreset=qo;O.prototype.setPreset=Ko;O.prototype.setDrums=Oo;O.prototype.reloadSoundFont=Wo;O.prototype.clearSoundFont=Zo;O.prototype.setEmbeddedSoundFont=Xo;O.prototype.sendPresetList=Vo;O.prototype.sendSynthesizerSnapshot=_o;O.prototype.applySynthesizerSnapshot=zo;O.prototype.panVoice=Ar;registerProcessor(Ps,O);m("%cProcessor succesfully registered!",g.recognized);
|