speechrecorderng 2.25.3 → 3.0.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/esm2020/lib/audio/array_audio_buffer.mjs +101 -0
- package/esm2020/lib/audio/array_audio_buffer_input_stream.mjs +86 -0
- package/esm2020/lib/audio/audio_data_holder.mjs +109 -0
- package/esm2020/lib/audio/audio_display.mjs +5 -5
- package/esm2020/lib/audio/audio_player.mjs +9 -7
- package/esm2020/lib/audio/capture/capture.mjs +6 -1
- package/esm2020/lib/audio/dsp/level_measure.mjs +97 -55
- package/esm2020/lib/audio/io/stream.mjs +3 -3
- package/esm2020/lib/audio/persistor.mjs +5 -6
- package/esm2020/lib/audio/playback/array_audio_buffer_source_node.mjs +265 -0
- package/esm2020/lib/audio/playback/player.mjs +184 -50
- package/esm2020/lib/audio/ui/audio_canvas_layer_comp.mjs +25 -13
- package/esm2020/lib/audio/ui/audio_display_scroll_pane.mjs +2 -2
- package/esm2020/lib/audio/ui/audiosignal.mjs +206 -77
- package/esm2020/lib/audio/ui/container.mjs +14 -14
- package/esm2020/lib/audio/ui/livelevel.mjs +15 -2
- package/esm2020/lib/audio/ui/sonagram.mjs +343 -160
- package/esm2020/lib/io/stream.mjs +77 -1
- package/esm2020/lib/net/uploader.mjs +15 -3
- package/esm2020/lib/speechrecorder/recording.mjs +52 -7
- package/esm2020/lib/speechrecorder/recordings/recordings.service.mjs +99 -7
- package/esm2020/lib/speechrecorder/session/audiorecorder.mjs +117 -101
- package/esm2020/lib/speechrecorder/session/basicrecorder.mjs +34 -6
- package/esm2020/lib/speechrecorder/session/progress.mjs +2 -2
- package/esm2020/lib/speechrecorder/session/prompting.mjs +2 -2
- package/esm2020/lib/speechrecorder/session/recorder_combi_pane.mjs +6 -3
- package/esm2020/lib/speechrecorder/session/recording_file_cache.mjs +182 -0
- package/esm2020/lib/speechrecorder/session/recording_list.mjs +23 -10
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-meta.component.mjs +12 -6
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-u-i.component.mjs +5 -5
- package/esm2020/lib/speechrecorder/session/recordingfile/recording-file-view.component.mjs +13 -9
- package/esm2020/lib/speechrecorder/session/recordingfile/recordingfile-service.mjs +8 -5
- package/esm2020/lib/speechrecorder/session/sessionmanager.mjs +118 -95
- package/esm2020/lib/speechrecorderng.component.mjs +2 -2
- package/esm2020/lib/speechrecorderng.module.mjs +5 -4
- package/esm2020/lib/spr.module.version.mjs +2 -2
- package/esm2020/lib/ui/recordingitem_display.mjs +2 -2
- package/fesm2015/speechrecorderng.mjs +2321 -743
- package/fesm2015/speechrecorderng.mjs.map +1 -1
- package/fesm2020/speechrecorderng.mjs +2321 -753
- package/fesm2020/speechrecorderng.mjs.map +1 -1
- package/lib/audio/array_audio_buffer.d.ts +15 -0
- package/lib/audio/array_audio_buffer_input_stream.d.ts +14 -0
- package/lib/audio/audio_data_holder.d.ts +29 -0
- package/lib/audio/audio_display.d.ts +2 -1
- package/lib/audio/audio_player.d.ts +2 -1
- package/lib/audio/capture/capture.d.ts +2 -0
- package/lib/audio/dsp/level_measure.d.ts +2 -1
- package/lib/audio/persistor.d.ts +4 -3
- package/lib/audio/playback/array_audio_buffer_source_node.d.ts +24 -0
- package/lib/audio/playback/player.d.ts +6 -0
- package/lib/audio/ui/audio_canvas_layer_comp.d.ts +4 -1
- package/lib/audio/ui/audio_display_scroll_pane.d.ts +2 -1
- package/lib/audio/ui/audiosignal.d.ts +3 -2
- package/lib/audio/ui/container.d.ts +3 -2
- package/lib/audio/ui/livelevel.d.ts +3 -1
- package/lib/audio/ui/sonagram.d.ts +3 -2
- package/lib/io/stream.d.ts +17 -0
- package/lib/net/uploader.d.ts +6 -1
- package/lib/speechrecorder/recording.d.ts +15 -3
- package/lib/speechrecorder/recordings/recordings.service.d.ts +2 -0
- package/lib/speechrecorder/session/audiorecorder.d.ts +2 -7
- package/lib/speechrecorder/session/basicrecorder.d.ts +9 -3
- package/lib/speechrecorder/session/progress.d.ts +1 -1
- package/lib/speechrecorder/session/prompting.d.ts +1 -1
- package/lib/speechrecorder/session/recorder_combi_pane.d.ts +3 -1
- package/lib/speechrecorder/session/recording_file_cache.d.ts +30 -0
- package/lib/speechrecorder/session/recording_list.d.ts +3 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-meta.component.d.ts +2 -1
- package/lib/speechrecorder/session/recordingfile/recording-file-view.component.d.ts +1 -0
- package/lib/speechrecorder/session/sessionmanager.d.ts +5 -11
- package/lib/speechrecorderng.module.d.ts +2 -1
- package/lib/spr.module.version.d.ts +1 -1
- package/package.json +1 -1
|
@@ -120,47 +120,66 @@ export class PeakLevelInterceptor {
|
|
|
120
120
|
}
|
|
121
121
|
}
|
|
122
122
|
export class LevelMeasure {
|
|
123
|
+
//private bufferLevelInfos=new Array<LevelInfo>();
|
|
124
|
+
//private peakLevelInfo!:LevelInfo;
|
|
123
125
|
constructor() {
|
|
124
126
|
this.worker = null;
|
|
125
127
|
this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction);
|
|
126
128
|
}
|
|
127
|
-
calcBufferLevelInfos(
|
|
129
|
+
calcBufferLevelInfos(audioDataHolder, bufferTimeLength) {
|
|
128
130
|
return new Promise((resolve) => {
|
|
129
|
-
let chs =
|
|
130
|
-
let bufferFrameLength = Math.round(
|
|
131
|
-
let
|
|
131
|
+
let chs = audioDataHolder.numberOfChannels;
|
|
132
|
+
let bufferFrameLength = Math.round(audioDataHolder.sampleRate * bufferTimeLength);
|
|
133
|
+
let ais = audioDataHolder.audioInputStream();
|
|
134
|
+
let audioBuffers = new Array(chs);
|
|
135
|
+
let trBuffers = new Array(chs);
|
|
132
136
|
for (let ch = 0; ch < chs; ch++) {
|
|
133
|
-
|
|
134
|
-
let adChCopy = new Float32Array(adCh.length);
|
|
135
|
-
adChCopy.set(adCh);
|
|
136
|
-
buffers[ch] = adChCopy.buffer;
|
|
137
|
+
audioBuffers[ch] = new Float32Array(bufferFrameLength);
|
|
137
138
|
}
|
|
139
|
+
let bufferLevelInfos = new Array();
|
|
140
|
+
let peakLevelInfo = new LevelInfo(chs);
|
|
138
141
|
this.worker = new Worker(this.workerURL);
|
|
139
142
|
this.worker.onmessage = (me) => {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
+
if (me.data.linLevelBuffers) {
|
|
144
|
+
let linLevelArrs = new Array(chs);
|
|
145
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
146
|
+
linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);
|
|
147
|
+
}
|
|
148
|
+
let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);
|
|
149
|
+
let framePos = 0;
|
|
150
|
+
for (let bi = 0; bi < bufferCount; bi++) {
|
|
151
|
+
let minLevels = new Array(chs);
|
|
152
|
+
let maxLevels = new Array(chs);
|
|
153
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
154
|
+
let linLvlArrPos = bi * 2;
|
|
155
|
+
minLevels[ch] = linLevelArrs[ch][linLvlArrPos];
|
|
156
|
+
maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
|
|
157
|
+
}
|
|
158
|
+
let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);
|
|
159
|
+
bufferLevelInfos.push(bli);
|
|
160
|
+
peakLevelInfo.merge(bli);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
if (me.data.eod === true) {
|
|
164
|
+
// end of data, terminate worker and return result
|
|
165
|
+
this.terminateWorker();
|
|
166
|
+
resolve(new LevelInfos(bufferLevelInfos, peakLevelInfo));
|
|
143
167
|
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
let bufferLevelInfos = new Array();
|
|
147
|
-
let peakLevelInfo = new LevelInfo(chs);
|
|
148
|
-
for (let bi = 0; bi < bufferCount; bi++) {
|
|
149
|
-
let minLevels = new Array(chs);
|
|
150
|
-
let maxLevels = new Array(chs);
|
|
168
|
+
else {
|
|
169
|
+
let read = ais.read(audioBuffers);
|
|
151
170
|
for (let ch = 0; ch < chs; ch++) {
|
|
152
|
-
let
|
|
153
|
-
|
|
154
|
-
maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];
|
|
171
|
+
let copy = new Float32Array(audioBuffers[ch]);
|
|
172
|
+
trBuffers[ch] = copy.buffer;
|
|
155
173
|
}
|
|
156
|
-
|
|
157
|
-
bufferLevelInfos.push(bli);
|
|
158
|
-
peakLevelInfo.merge(bli);
|
|
174
|
+
this.worker?.postMessage({ bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs, len: read }, trBuffers);
|
|
159
175
|
}
|
|
160
|
-
this.terminateWorker();
|
|
161
|
-
resolve(new LevelInfos(bufferLevelInfos, peakLevelInfo));
|
|
162
176
|
};
|
|
163
|
-
|
|
177
|
+
let read = ais.read(audioBuffers);
|
|
178
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
179
|
+
let copy = new Float32Array(audioBuffers[ch]);
|
|
180
|
+
trBuffers[ch] = copy.buffer;
|
|
181
|
+
}
|
|
182
|
+
this.worker?.postMessage({ bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs, len: read }, trBuffers);
|
|
164
183
|
});
|
|
165
184
|
}
|
|
166
185
|
terminateWorker() {
|
|
@@ -171,40 +190,63 @@ export class LevelMeasure {
|
|
|
171
190
|
*/
|
|
172
191
|
workerFunction() {
|
|
173
192
|
self.onmessage = function (msg) {
|
|
174
|
-
let
|
|
193
|
+
let len = msg.data.len;
|
|
175
194
|
let bufferFrameLength = msg.data.bufferFrameLength;
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
195
|
+
if (len == -1) {
|
|
196
|
+
// start
|
|
197
|
+
postMessage({
|
|
198
|
+
eod: false,
|
|
199
|
+
bufferFrameLength: bufferFrameLength,
|
|
200
|
+
frameLength: len
|
|
201
|
+
});
|
|
180
202
|
}
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
203
|
+
if (len == 0) {
|
|
204
|
+
postMessage({
|
|
205
|
+
eod: true,
|
|
206
|
+
bufferFrameLength: bufferFrameLength,
|
|
207
|
+
frameLength: len
|
|
208
|
+
});
|
|
185
209
|
}
|
|
186
|
-
|
|
210
|
+
else {
|
|
211
|
+
let chs = msg.data.chs;
|
|
212
|
+
let audioData = new Array(chs);
|
|
213
|
+
let linLevels = new Array(chs);
|
|
187
214
|
for (let ch = 0; ch < chs; ch++) {
|
|
188
|
-
|
|
189
|
-
for (let s = 0; s < frameLength; s++) {
|
|
190
|
-
let bi = Math.floor(s / bufferFrameLength);
|
|
191
|
-
let lvlArrPos = bi * 2;
|
|
192
|
-
//let bs = s % bufferFrameLength;
|
|
193
|
-
let chSample = chData[s];
|
|
194
|
-
if (chSample < linLevels[ch][lvlArrPos]) {
|
|
195
|
-
linLevels[ch][lvlArrPos] = chSample;
|
|
196
|
-
}
|
|
197
|
-
lvlArrPos++;
|
|
198
|
-
if (chSample > linLevels[ch][lvlArrPos]) {
|
|
199
|
-
linLevels[ch][lvlArrPos] = chSample;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
215
|
+
audioData[ch] = new Float32Array(msg.data.audioData[ch]);
|
|
202
216
|
}
|
|
203
|
-
|
|
217
|
+
//let frameLength = audioData[0].length;
|
|
218
|
+
let bufferCount = Math.ceil(len / bufferFrameLength);
|
|
204
219
|
for (let ch = 0; ch < chs; ch++) {
|
|
205
|
-
|
|
220
|
+
linLevels[ch] = new Float32Array(bufferCount * 2);
|
|
221
|
+
}
|
|
222
|
+
if (audioData && chs > 0) {
|
|
223
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
224
|
+
let chData = audioData[ch];
|
|
225
|
+
for (let s = 0; s < len; s++) {
|
|
226
|
+
let bi = Math.floor(s / bufferFrameLength);
|
|
227
|
+
let lvlArrPos = bi * 2;
|
|
228
|
+
//let bs = s % bufferFrameLength;
|
|
229
|
+
let chSample = chData[s];
|
|
230
|
+
if (chSample < linLevels[ch][lvlArrPos]) {
|
|
231
|
+
linLevels[ch][lvlArrPos] = chSample;
|
|
232
|
+
}
|
|
233
|
+
lvlArrPos++;
|
|
234
|
+
if (chSample > linLevels[ch][lvlArrPos]) {
|
|
235
|
+
linLevels[ch][lvlArrPos] = chSample;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
const linLevelBufs = new Array(chs);
|
|
240
|
+
for (let ch = 0; ch < chs; ch++) {
|
|
241
|
+
linLevelBufs[ch] = linLevels[ch].buffer;
|
|
242
|
+
}
|
|
243
|
+
postMessage({
|
|
244
|
+
eod: false,
|
|
245
|
+
bufferFrameLength: bufferFrameLength,
|
|
246
|
+
frameLength: len,
|
|
247
|
+
linLevelBuffers: linLevelBufs
|
|
248
|
+
}, linLevelBufs);
|
|
206
249
|
}
|
|
207
|
-
postMessage({ bufferFrameLength: bufferFrameLength, frameLength: frameLength, linLevelBuffers: linLevelBufs }, linLevelBufs);
|
|
208
250
|
}
|
|
209
251
|
};
|
|
210
252
|
}
|
|
@@ -348,4 +390,4 @@ export class StreamLevelMeasure {
|
|
|
348
390
|
this.worker?.terminate();
|
|
349
391
|
}
|
|
350
392
|
}
|
|
351
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"level_measure.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/dsp/level_measure.ts"],"names":[],"mappings":"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","sourcesContent":["import {DSPUtils} from \"../../dsp/utils\";\r\nimport {SequenceAudioFloat32OutStream} from \"../io/stream\";\r\nimport {Arrays, WorkerHelper} from \"../../utils/utils\";\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\n\r\n\r\n\r\nexport class LevelInfo {\r\n\r\n  private readonly _minLinLevels: Array<number>;\r\n  private readonly _maxLinLevels: Array<number>;\r\n\r\n  constructor(public readonly channelCount: number,\r\n              public startFrame: number = 0,\r\n              public frameLength: number = 0,\r\n              minLinLevels?: Array<number>,\r\n              maxLinLevels?: Array<number>) {\r\n    this._minLinLevels = this.checkOrInitArray(minLinLevels);\r\n    this._maxLinLevels = this.checkOrInitArray(maxLinLevels);\r\n  }\r\n\r\n  get minLinLevels() {\r\n    return this._minLinLevels;\r\n  }\r\n\r\n  get maxLinLevels() {\r\n    return this._maxLinLevels;\r\n  }\r\n\r\n  private checkOrInitArray(arr: Array<number> | undefined): Array<number> {\r\n    if (arr) {\r\n      if (arr.length !== this.channelCount)\r\n        throw  new Error(\"Level arrays must be equal to channel count \" + this.channelCount);\r\n      return arr;\r\n    } else {\r\n      return new Array<number>(this.channelCount)\r\n    }\r\n  }\r\n\r\n  merge(levelInfo: LevelInfo) {\r\n    if (levelInfo === null) {\r\n      return;\r\n    }\r\n    if (this.channelCount !== levelInfo.channelCount) {\r\n      throw new Error(\"Channel count of level info to merge must be equal. (\" + this.channelCount + \" != \" + levelInfo.channelCount + \")\");\r\n    }\r\n\r\n    let endFrame = this.startFrame + this.frameLength;\r\n    let mergeEndFrame = levelInfo.startFrame + levelInfo.frameLength;\r\n\r\n    if (levelInfo.startFrame < this.startFrame) {\r\n      this.startFrame = levelInfo.startFrame;\r\n    }\r\n\r\n    if (mergeEndFrame > endFrame) {\r\n      this.frameLength = mergeEndFrame - this.startFrame;\r\n    }\r\n\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n\r\n      if (levelInfo.minLinLevels[ch] < this.minLinLevels[ch]) {\r\n        this.minLinLevels[ch] = levelInfo.minLinLevels[ch];\r\n      }\r\n      if (levelInfo.maxLinLevels[ch] > this.maxLinLevels[ch]) {\r\n        this.maxLinLevels[ch] = levelInfo.maxLinLevels[ch];\r\n      }\r\n    }\r\n  }\r\n\r\n  levelsLin(): Array<number> {\r\n    let lvlsLin = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsLin[ch] = Math.max(Math.abs(this.minLinLevels[ch]), Math.abs(this.maxLinLevels[ch]));\r\n    }\r\n    return lvlsLin;\r\n  }\r\n\r\n  powerLevelsDB(): Array<number> {\r\n    let lvlsDb = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsDb[ch] = DSPUtils.toPowerLevelInDB(this.levelsLin()[ch]);\r\n    }\r\n    return lvlsDb;\r\n  }\r\n\r\n  powerLevelDB(): number {\r\n    let pLvlsDb = this.powerLevelsDB();\r\n    return Math.max(...pLvlsDb);\r\n  }\r\n\r\n  clone(): LevelInfo {\r\n    return new LevelInfo(this.channelCount, this.startFrame, this.frameLength, Arrays.cloneNumberArray(this.minLinLevels),\r\n      Arrays.cloneNumberArray(this.maxLinLevels));\r\n  }\r\n}\r\n\r\nexport class LevelInfos {\r\n  constructor(public readonly bufferLevelInfos: Array<LevelInfo>, public readonly peakLevelInfo: LevelInfo) {\r\n  }\r\n\r\n  framesPerBuffer():number{\r\n    if(this.bufferLevelInfos.length>0){\r\n      return this.bufferLevelInfos[0].frameLength;\r\n    }\r\n    return this.peakLevelInfo.frameLength/this.bufferLevelInfos.length;\r\n  }\r\n}\r\n\r\n\r\nexport interface LevelListener {\r\n  channelCount: number;\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\nexport interface PeakLevelListener {\r\n  update(peakLevel:number): void;\r\n}\r\n\r\nexport interface PeakLevelListener {\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\nexport class PeakLevelInterceptor implements LevelListener{\r\n  get peakDbLvl(): number {\r\n    return this._peakDbLvl;\r\n  }\r\n  get channelCount(): number {\r\n    return this._channelCount;\r\n  }\r\n\r\n  set channelCount(value: number) {\r\n    this._channelCount = value;\r\n    if(this.levelListener){\r\n      this.levelListener.channelCount=value;\r\n    }\r\n  }\r\n\r\n  private _channelCount: number=0;\r\n\r\n  private _peakDbLvl = MIN_DB_LEVEL;\r\n\r\n\r\n\r\n  constructor(private levelListener?:LevelListener) {}\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void{\r\n    let peakDBVal = levelInfo.powerLevelDB();\r\n    if (this.peakDbLvl < peakDBVal) {\r\n      this._peakDbLvl = peakDBVal;\r\n    }\r\n  }\r\n\r\n  streamFinished(): void{\r\n    if(this.levelListener){\r\n      this.levelListener.streamFinished();\r\n    }\r\n  }\r\n\r\n  reset(): void{\r\n    this._peakDbLvl = MIN_DB_LEVEL;\r\n    if(this.levelListener){\r\n      this.levelListener.reset();\r\n    }\r\n  }\r\n}\r\n\r\ndeclare function postMessage(message: any, transfer?: Array<any>): void;\r\n\r\n\r\nexport class LevelMeasure {\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  calcBufferLevelInfos(audioBuffer: AudioBuffer, bufferTimeLength: number): Promise<LevelInfos> {\r\n    return new Promise<LevelInfos>((resolve)=>{\r\n      let chs = audioBuffer.numberOfChannels;\r\n      let bufferFrameLength=Math.round(audioBuffer.sampleRate*bufferTimeLength);\r\n      let buffers = new Array<any>(chs);\r\n      for (let ch = 0; ch < chs; ch++) {\r\n        let adCh=audioBuffer.getChannelData(ch);\r\n        let adChCopy=new Float32Array(adCh.length);\r\n        adChCopy.set(adCh);\r\n        buffers[ch] = adChCopy.buffer;\r\n      }\r\n\r\n      this.worker = new Worker(this.workerURL);\r\n      this.worker.onmessage = (me) => {\r\n\r\n        let linLevelArrs=new Array<Float32Array>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n        }\r\n\r\n        let bufferCount=Math.ceil(me.data.frameLength/me.data.bufferFrameLength);\r\n        let framePos=0;\r\n        let bufferLevelInfos=new Array<LevelInfo>();\r\n        let peakLevelInfo=new LevelInfo(chs);\r\n        for(let bi=0;bi<bufferCount;bi++) {\r\n          let minLevels = new Array<number>(chs);\r\n          let maxLevels = new Array<number>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let linLvlArrPos=bi*2;\r\n            minLevels[ch]=linLevelArrs[ch][linLvlArrPos];\r\n            maxLevels[ch]=linLevelArrs[ch][linLvlArrPos+1];\r\n          }\r\n          let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n          bufferLevelInfos.push(bli);\r\n          peakLevelInfo.merge(bli);\r\n        }\r\n        this.terminateWorker();\r\n        resolve(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n      };\r\n\r\n      this.worker.postMessage({bufferFrameLength:bufferFrameLength,audioData: buffers, chs: chs}, buffers);\r\n\r\n    });\r\n\r\n  }\r\n\r\n\r\n  private terminateWorker() {\r\n    this.worker?.terminate();\r\n\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n\r\n      let chs = msg.data.chs;\r\n      let bufferFrameLength = msg.data.bufferFrameLength;\r\n\r\n      let audioData = new Array<Float32Array>(chs);\r\n      let linLevels = new Array<Float32Array>(chs);\r\n\r\n      for (let ch = 0; ch < chs; ch++) {\r\n        audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n      }\r\n      let frameLength = audioData[0].length;\r\n      let bufferCount=Math.ceil(frameLength/bufferFrameLength);\r\n      for (let ch = 0; ch < chs; ch++) {\r\n        linLevels[ch] = new Float32Array(bufferCount*2);\r\n      }\r\n      if (audioData && chs > 0) {\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          let chData = audioData[ch];\r\n\r\n          for (let s = 0; s < frameLength; s++) {\r\n            let bi = Math.floor(s / bufferFrameLength);\r\n            let lvlArrPos = bi * 2;\r\n            //let bs = s % bufferFrameLength;\r\n            let chSample=chData[s];\r\n            if (chSample < linLevels[ch][lvlArrPos]) {\r\n              linLevels[ch][lvlArrPos] = chSample;\r\n            }\r\n            lvlArrPos++;\r\n            if (chSample > linLevels[ch][lvlArrPos]) {\r\n              linLevels[ch][lvlArrPos] = chSample;\r\n            }\r\n          }\r\n        }\r\n        const linLevelBufs = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelBufs[ch] = linLevels[ch].buffer;\r\n        }\r\n        postMessage({bufferFrameLength:bufferFrameLength,frameLength:frameLength,linLevelBuffers: linLevelBufs}, linLevelBufs);\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport class StreamLevelMeasure implements SequenceAudioFloat32OutStream {\r\n\r\n  currentLevelInfos: LevelInfo|null=null;\r\n  peakLevelInfo: LevelInfo|null=null;\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  private channelCount: number=0;\r\n  private bufferIndex: number = 0;\r\n  private frameCount: number = 0;\r\n\r\n  levelListener: LevelListener|null=null;\r\n  peakLevelListener: ((peakLvlInDb:number)=>void)|null=null;\r\n  private peakLevelInDb:number=MIN_DB_LEVEL;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  setFormat(channels: number, sampleRate: number) {\r\n    this.channelCount = channels;\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    this.worker = new Worker(this.workerURL);\r\n    this.worker.onmessage = (me) => {\r\n      let streamFinished = me.data.streamFinished;\r\n      if (streamFinished) {\r\n        if (this.levelListener) {\r\n          this.levelListener.streamFinished()\r\n        }\r\n      } else {\r\n\r\n        let minLevels = new Array<number>(this.channelCount);\r\n        let maxLevels = new Array<number>(this.channelCount);\r\n        for (let ch = 0; ch < this.channelCount; ch++) {\r\n          let fls = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          minLevels[ch] = fls[0];\r\n          maxLevels[ch] = fls[1];\r\n        }\r\n        let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.fraemLength, minLevels, maxLevels);\r\n        this.updateLevels(bi);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  nextStream() {\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    if (this.levelListener) {\r\n      this.levelListener.reset();\r\n      this.levelListener.channelCount = this.channelCount;\r\n    }\r\n    if (this.peakLevelListener) {\r\n      this.peakLevelInDb=MIN_DB_LEVEL;\r\n      this.peakLevelListener(this.peakLevelInDb);\r\n    }\r\n  }\r\n\r\n  write(bufferData: Array<Float32Array>): number {\r\n    let bufArrCopies = new Array<Float32Array>(bufferData.length);\r\n    let buffers = new Array<any>(bufferData.length);\r\n    for (let ch = 0; ch < bufferData.length; ch++) {\r\n      bufArrCopies[ch] = bufferData[ch].slice();\r\n      buffers[ch] = bufArrCopies[ch].buffer;\r\n    }\r\n    this.worker?.postMessage({\r\n      streamFinished: false,\r\n      audioData: buffers,\r\n      chs: this.channelCount,\r\n      bufferIndex: this.bufferIndex\r\n    }, buffers);\r\n    this.bufferIndex++;\r\n    return bufArrCopies[0].length;\r\n  }\r\n\r\n  flush() {\r\n    this.worker?.postMessage({streamFinished: true});\r\n\r\n  }\r\n\r\n  close() {\r\n      this.worker?.terminate();\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n      let streamFinished = msg.data.streamFinished;\r\n      if (streamFinished) {\r\n        postMessage({streamFinished: true});\r\n      } else {\r\n        let chs = msg.data.chs;\r\n        let frameLength = null;\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(2);\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        if (audioData) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n            if (frameLength === null) {\r\n              frameLength = chData.length;\r\n            }\r\n            for (let s = 0; s < frameLength; s++) {\r\n              let chSample=chData[s];\r\n              if (chSample < linLevels[ch][0]) {\r\n                linLevels[ch][0] = chSample;\r\n              }\r\n              if (chSample > linLevels[ch][1]) {\r\n                linLevels[ch][1] = chSample;\r\n              }\r\n            }\r\n          }\r\n        }\r\n        let linLevelBufs = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelBufs[ch] = linLevels[ch].buffer;\r\n        }\r\n        postMessage({streamFinished: false, frameLength: frameLength, linLevelBuffers: linLevelBufs}, linLevelBufs);\r\n      }\r\n    }\r\n  }\r\n\r\n  updateLevels(bufferLevelInfo: LevelInfo) {\r\n\r\n    this.currentLevelInfos = bufferLevelInfo;\r\n    if(this.peakLevelInfo) {\r\n      this.peakLevelInfo.merge(bufferLevelInfo);\r\n      if (this.levelListener) {\r\n        this.levelListener.update(this.currentLevelInfos, this.peakLevelInfo.clone());\r\n      }\r\n      if(this.peakLevelListener){\r\n        let peakDBVal = bufferLevelInfo.powerLevelDB();\r\n        if (this.peakLevelInDb < peakDBVal) {\r\n          this.peakLevelInDb = peakDBVal;\r\n          // the event comes from outside of an Angular zone\r\n          this.peakLevelListener(this.peakLevelInDb);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  stop() {\r\n    this.worker?.terminate();\r\n  }\r\n\r\n\r\n}\r\n"]}
|
|
393
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"level_measure.js","sourceRoot":"","sources":["../../../../../../projects/speechrecorderng/src/lib/audio/dsp/level_measure.ts"],"names":[],"mappings":"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","sourcesContent":["import {DSPUtils} from \"../../dsp/utils\";\r\nimport {SequenceAudioFloat32OutStream} from \"../io/stream\";\r\nimport {Arrays, WorkerHelper} from \"../../utils/utils\";\r\nimport {AudioDataHolder} from \"../audio_data_holder\";\r\n\r\nexport const MIN_DB_LEVEL = -40.0;\r\n\r\n\r\n\r\nexport class LevelInfo {\r\n\r\n  private readonly _minLinLevels: Array<number>;\r\n  private readonly _maxLinLevels: Array<number>;\r\n\r\n  constructor(public readonly channelCount: number,\r\n              public startFrame: number = 0,\r\n              public frameLength: number = 0,\r\n              minLinLevels?: Array<number>,\r\n              maxLinLevels?: Array<number>) {\r\n    this._minLinLevels = this.checkOrInitArray(minLinLevels);\r\n    this._maxLinLevels = this.checkOrInitArray(maxLinLevels);\r\n  }\r\n\r\n  get minLinLevels() {\r\n    return this._minLinLevels;\r\n  }\r\n\r\n  get maxLinLevels() {\r\n    return this._maxLinLevels;\r\n  }\r\n\r\n  private checkOrInitArray(arr: Array<number> | undefined): Array<number> {\r\n    if (arr) {\r\n      if (arr.length !== this.channelCount)\r\n        throw  new Error(\"Level arrays must be equal to channel count \" + this.channelCount);\r\n      return arr;\r\n    } else {\r\n      return new Array<number>(this.channelCount)\r\n    }\r\n  }\r\n\r\n  merge(levelInfo: LevelInfo) {\r\n    if (levelInfo === null) {\r\n      return;\r\n    }\r\n    if (this.channelCount !== levelInfo.channelCount) {\r\n      throw new Error(\"Channel count of level info to merge must be equal. (\" + this.channelCount + \" != \" + levelInfo.channelCount + \")\");\r\n    }\r\n\r\n    let endFrame = this.startFrame + this.frameLength;\r\n    let mergeEndFrame = levelInfo.startFrame + levelInfo.frameLength;\r\n\r\n    if (levelInfo.startFrame < this.startFrame) {\r\n      this.startFrame = levelInfo.startFrame;\r\n    }\r\n\r\n    if (mergeEndFrame > endFrame) {\r\n      this.frameLength = mergeEndFrame - this.startFrame;\r\n    }\r\n\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n\r\n      if (levelInfo.minLinLevels[ch] < this.minLinLevels[ch]) {\r\n        this.minLinLevels[ch] = levelInfo.minLinLevels[ch];\r\n      }\r\n      if (levelInfo.maxLinLevels[ch] > this.maxLinLevels[ch]) {\r\n        this.maxLinLevels[ch] = levelInfo.maxLinLevels[ch];\r\n      }\r\n    }\r\n  }\r\n\r\n  levelsLin(): Array<number> {\r\n    let lvlsLin = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsLin[ch] = Math.max(Math.abs(this.minLinLevels[ch]), Math.abs(this.maxLinLevels[ch]));\r\n    }\r\n    return lvlsLin;\r\n  }\r\n\r\n  powerLevelsDB(): Array<number> {\r\n    let lvlsDb = new Array<number>(this.channelCount);\r\n    for (let ch = 0; ch < this.channelCount; ch++) {\r\n      lvlsDb[ch] = DSPUtils.toPowerLevelInDB(this.levelsLin()[ch]);\r\n    }\r\n    return lvlsDb;\r\n  }\r\n\r\n  powerLevelDB(): number {\r\n    let pLvlsDb = this.powerLevelsDB();\r\n    return Math.max(...pLvlsDb);\r\n  }\r\n\r\n  clone(): LevelInfo {\r\n    return new LevelInfo(this.channelCount, this.startFrame, this.frameLength, Arrays.cloneNumberArray(this.minLinLevels),\r\n      Arrays.cloneNumberArray(this.maxLinLevels));\r\n  }\r\n}\r\n\r\nexport class LevelInfos {\r\n  constructor(public readonly bufferLevelInfos: Array<LevelInfo>, public readonly peakLevelInfo: LevelInfo) {\r\n  }\r\n\r\n  framesPerBuffer():number{\r\n    if(this.bufferLevelInfos.length>0){\r\n      return this.bufferLevelInfos[0].frameLength;\r\n    }\r\n    return this.peakLevelInfo.frameLength/this.bufferLevelInfos.length;\r\n  }\r\n}\r\n\r\n\r\nexport interface LevelListener {\r\n  channelCount: number;\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\nexport interface PeakLevelListener {\r\n  update(peakLevel:number): void;\r\n}\r\n\r\nexport interface PeakLevelListener {\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void;\r\n\r\n  streamFinished(): void;\r\n\r\n  reset(): void;\r\n}\r\n\r\nexport class PeakLevelInterceptor implements LevelListener{\r\n  get peakDbLvl(): number {\r\n    return this._peakDbLvl;\r\n  }\r\n  get channelCount(): number {\r\n    return this._channelCount;\r\n  }\r\n\r\n  set channelCount(value: number) {\r\n    this._channelCount = value;\r\n    if(this.levelListener){\r\n      this.levelListener.channelCount=value;\r\n    }\r\n  }\r\n\r\n  private _channelCount: number=0;\r\n\r\n  private _peakDbLvl = MIN_DB_LEVEL;\r\n\r\n\r\n\r\n  constructor(private levelListener?:LevelListener) {}\r\n\r\n  update(levelInfo: LevelInfo, peakLevelInfo: LevelInfo): void{\r\n    let peakDBVal = levelInfo.powerLevelDB();\r\n    if (this.peakDbLvl < peakDBVal) {\r\n      this._peakDbLvl = peakDBVal;\r\n    }\r\n  }\r\n\r\n  streamFinished(): void{\r\n    if(this.levelListener){\r\n      this.levelListener.streamFinished();\r\n    }\r\n  }\r\n\r\n  reset(): void{\r\n    this._peakDbLvl = MIN_DB_LEVEL;\r\n    if(this.levelListener){\r\n      this.levelListener.reset();\r\n    }\r\n  }\r\n}\r\n\r\ndeclare function postMessage(message: any, transfer?: Array<any>): void;\r\n\r\n\r\nexport class LevelMeasure {\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  //private bufferLevelInfos=new Array<LevelInfo>();\r\n  //private peakLevelInfo!:LevelInfo;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  calcBufferLevelInfos(audioDataHolder:AudioDataHolder, bufferTimeLength: number): Promise<LevelInfos> {\r\n    return new Promise<LevelInfos>((resolve)=>{\r\n      let chs = audioDataHolder.numberOfChannels;\r\n      let bufferFrameLength=Math.round(audioDataHolder.sampleRate*bufferTimeLength);\r\n      let ais=audioDataHolder.audioInputStream();\r\n      let audioBuffers = new Array<Float32Array>(chs);\r\n      let trBuffers=new Array<any>(chs);\r\n      for (let ch = 0; ch < chs; ch++) {\r\n        audioBuffers[ch]=new Float32Array(bufferFrameLength);\r\n      }\r\n      let bufferLevelInfos=new Array<LevelInfo>();\r\n      let peakLevelInfo=new LevelInfo(chs);\r\n\r\n\r\n      this.worker = new Worker(this.workerURL);\r\n      this.worker.onmessage = (me) => {\r\n\r\n        if(me.data.linLevelBuffers) {\r\n          let linLevelArrs = new Array<Float32Array>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            linLevelArrs[ch] = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          }\r\n\r\n          let bufferCount = Math.ceil(me.data.frameLength / me.data.bufferFrameLength);\r\n          let framePos = 0;\r\n\r\n          for (let bi = 0; bi < bufferCount; bi++) {\r\n            let minLevels = new Array<number>(chs);\r\n            let maxLevels = new Array<number>(chs);\r\n            for (let ch = 0; ch < chs; ch++) {\r\n              let linLvlArrPos = bi * 2;\r\n              minLevels[ch] = linLevelArrs[ch][linLvlArrPos];\r\n              maxLevels[ch] = linLevelArrs[ch][linLvlArrPos + 1];\r\n            }\r\n            let bli = new LevelInfo(chs, framePos, me.data.bufferFrameLength, minLevels, maxLevels);\r\n            bufferLevelInfos.push(bli);\r\n            peakLevelInfo.merge(bli);\r\n          }\r\n\r\n        }\r\n        if(me.data.eod===true) {\r\n          // end of data, terminate worker and return result\r\n          this.terminateWorker();\r\n          resolve(new LevelInfos(bufferLevelInfos, peakLevelInfo));\r\n        }else{\r\n          let read=ais.read(audioBuffers);\r\n          for(let ch=0;ch<chs;ch++){\r\n            let copy=new Float32Array(audioBuffers[ch]);\r\n            trBuffers[ch]=copy.buffer;\r\n          }\r\n          this.worker?.postMessage({bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs,len:read}, trBuffers);\r\n        }\r\n      };\r\n\r\n      let read=ais.read(audioBuffers);\r\n      for(let ch=0;ch<chs;ch++){\r\n        let copy=new Float32Array(audioBuffers[ch]);\r\n        trBuffers[ch]=copy.buffer;\r\n      }\r\n      this.worker?.postMessage({bufferFrameLength: bufferFrameLength, audioData: trBuffers, chs: chs,len:read}, trBuffers);\r\n    });\r\n\r\n  }\r\n\r\n\r\n  private terminateWorker() {\r\n    this.worker?.terminate();\r\n\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n\r\n      let len=msg.data.len;\r\n      let bufferFrameLength = msg.data.bufferFrameLength;\r\n      if(len==-1){\r\n        // start\r\n        postMessage({\r\n          eod:false,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }\r\n\r\n      if(len==0) {\r\n        postMessage({\r\n          eod:true,\r\n          bufferFrameLength: bufferFrameLength,\r\n          frameLength: len\r\n        });\r\n      }else{\r\n        let chs = msg.data.chs;\r\n\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        //let frameLength = audioData[0].length;\r\n\r\n        let bufferCount = Math.ceil(len / bufferFrameLength);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(bufferCount * 2);\r\n        }\r\n        if (audioData && chs > 0) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n\r\n            for (let s = 0; s < len; s++) {\r\n              let bi = Math.floor(s / bufferFrameLength);\r\n              let lvlArrPos = bi * 2;\r\n              //let bs = s % bufferFrameLength;\r\n              let chSample = chData[s];\r\n              if (chSample < linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n              lvlArrPos++;\r\n              if (chSample > linLevels[ch][lvlArrPos]) {\r\n                linLevels[ch][lvlArrPos] = chSample;\r\n              }\r\n            }\r\n          }\r\n          const linLevelBufs = new Array<any>(chs);\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            linLevelBufs[ch] = linLevels[ch].buffer;\r\n          }\r\n          postMessage({\r\n            eod:false,\r\n            bufferFrameLength: bufferFrameLength,\r\n            frameLength: len,\r\n            linLevelBuffers: linLevelBufs\r\n          }, linLevelBufs);\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\nexport class StreamLevelMeasure implements SequenceAudioFloat32OutStream {\r\n\r\n  currentLevelInfos: LevelInfo|null=null;\r\n  peakLevelInfo: LevelInfo|null=null;\r\n\r\n  private readonly workerURL: string;\r\n  private worker: Worker|null=null;\r\n  private channelCount: number=0;\r\n  private bufferIndex: number = 0;\r\n  private frameCount: number = 0;\r\n\r\n  levelListener: LevelListener|null=null;\r\n  peakLevelListener: ((peakLvlInDb:number)=>void)|null=null;\r\n  private peakLevelInDb:number=MIN_DB_LEVEL;\r\n\r\n  constructor() {\r\n    this.workerURL = WorkerHelper.buildWorkerBlobURL(this.workerFunction)\r\n  }\r\n\r\n  setFormat(channels: number, sampleRate: number) {\r\n    this.channelCount = channels;\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    this.worker = new Worker(this.workerURL);\r\n    this.worker.onmessage = (me) => {\r\n      let streamFinished = me.data.streamFinished;\r\n      if (streamFinished) {\r\n        if (this.levelListener) {\r\n          this.levelListener.streamFinished()\r\n        }\r\n      } else {\r\n\r\n        let minLevels = new Array<number>(this.channelCount);\r\n        let maxLevels = new Array<number>(this.channelCount);\r\n        for (let ch = 0; ch < this.channelCount; ch++) {\r\n          let fls = new Float32Array(me.data.linLevelBuffers[ch]);\r\n          minLevels[ch] = fls[0];\r\n          maxLevels[ch] = fls[1];\r\n        }\r\n        let bi = new LevelInfo(this.channelCount, this.frameCount, me.data.fraemLength, minLevels, maxLevels);\r\n        this.updateLevels(bi);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  nextStream() {\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    this.currentLevelInfos = new LevelInfo(this.channelCount);\r\n    this.peakLevelInfo = new LevelInfo(this.channelCount);\r\n    if (this.levelListener) {\r\n      this.levelListener.reset();\r\n      this.levelListener.channelCount = this.channelCount;\r\n    }\r\n    if (this.peakLevelListener) {\r\n      this.peakLevelInDb=MIN_DB_LEVEL;\r\n      this.peakLevelListener(this.peakLevelInDb);\r\n    }\r\n  }\r\n\r\n  write(bufferData: Array<Float32Array>): number {\r\n    let bufArrCopies = new Array<Float32Array>(bufferData.length);\r\n    let buffers = new Array<any>(bufferData.length);\r\n    for (let ch = 0; ch < bufferData.length; ch++) {\r\n      bufArrCopies[ch] = bufferData[ch].slice();\r\n      buffers[ch] = bufArrCopies[ch].buffer;\r\n    }\r\n    this.worker?.postMessage({\r\n      streamFinished: false,\r\n      audioData: buffers,\r\n      chs: this.channelCount,\r\n      bufferIndex: this.bufferIndex\r\n    }, buffers);\r\n    this.bufferIndex++;\r\n    return bufArrCopies[0].length;\r\n  }\r\n\r\n  flush() {\r\n    this.worker?.postMessage({streamFinished: true});\r\n\r\n  }\r\n\r\n  close() {\r\n      this.worker?.terminate();\r\n  }\r\n\r\n  /*\r\n   *  Method used as worker code.\r\n   */\r\n  workerFunction() {\r\n    self.onmessage = function (msg:MessageEvent) {\r\n      let streamFinished = msg.data.streamFinished;\r\n      if (streamFinished) {\r\n        postMessage({streamFinished: true});\r\n      } else {\r\n        let chs = msg.data.chs;\r\n        let frameLength = null;\r\n        let audioData = new Array<Float32Array>(chs);\r\n        let linLevels = new Array<Float32Array>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevels[ch] = new Float32Array(2);\r\n          audioData[ch] = new Float32Array(msg.data.audioData[ch]);\r\n        }\r\n\r\n        if (audioData) {\r\n          for (let ch = 0; ch < chs; ch++) {\r\n            let chData = audioData[ch];\r\n            if (frameLength === null) {\r\n              frameLength = chData.length;\r\n            }\r\n            for (let s = 0; s < frameLength; s++) {\r\n              let chSample=chData[s];\r\n              if (chSample < linLevels[ch][0]) {\r\n                linLevels[ch][0] = chSample;\r\n              }\r\n              if (chSample > linLevels[ch][1]) {\r\n                linLevels[ch][1] = chSample;\r\n              }\r\n            }\r\n          }\r\n        }\r\n        let linLevelBufs = new Array<any>(chs);\r\n        for (let ch = 0; ch < chs; ch++) {\r\n          linLevelBufs[ch] = linLevels[ch].buffer;\r\n        }\r\n        postMessage({streamFinished: false, frameLength: frameLength, linLevelBuffers: linLevelBufs}, linLevelBufs);\r\n      }\r\n    }\r\n  }\r\n\r\n  updateLevels(bufferLevelInfo: LevelInfo) {\r\n\r\n    this.currentLevelInfos = bufferLevelInfo;\r\n    if(this.peakLevelInfo) {\r\n      this.peakLevelInfo.merge(bufferLevelInfo);\r\n      if (this.levelListener) {\r\n        this.levelListener.update(this.currentLevelInfos, this.peakLevelInfo.clone());\r\n      }\r\n      if(this.peakLevelListener){\r\n        let peakDBVal = bufferLevelInfo.powerLevelDB();\r\n        if (this.peakLevelInDb < peakDBVal) {\r\n          this.peakLevelInDb = peakDBVal;\r\n          // the event comes from outside of an Angular zone\r\n          this.peakLevelListener(this.peakLevelInDb);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  stop() {\r\n    this.worker?.terminate();\r\n  }\r\n\r\n\r\n}\r\n"]}
|
|
@@ -7,11 +7,11 @@ export class SequenceAudioFloat32ChunkerOutStream extends Float32ArrayChunkerOut
|
|
|
7
7
|
this.sequenceAudioFloat32OutStream = outStream;
|
|
8
8
|
}
|
|
9
9
|
setFormat(channels, sampleRate) {
|
|
10
|
-
console.debug("SequenceAudioFloat32ChunkerOutStream:setFormat(channels: "
|
|
10
|
+
//console.debug("SequenceAudioFloat32ChunkerOutStream:setFormat(channels: "+channels+",sampleRate: "+sampleRate+")")
|
|
11
11
|
this.channels = channels;
|
|
12
12
|
this.sampleRate = sampleRate;
|
|
13
13
|
this.chunkSize = Math.round(sampleRate * this.chunkDurationSeconds);
|
|
14
|
-
console.debug("SequenceAudioFloat32ChunkerOutStream: chunkSize: "
|
|
14
|
+
//console.debug("SequenceAudioFloat32ChunkerOutStream: chunkSize: "+this.chunkSize);
|
|
15
15
|
this.sequenceAudioFloat32OutStream.setFormat(channels, sampleRate);
|
|
16
16
|
}
|
|
17
17
|
nextStream() {
|
|
@@ -56,4 +56,4 @@ export class SequenceAudioFloat32OutStreamMultiplier {
|
|
|
56
56
|
return toWrite;
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyZWFtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL2lvL3N0cmVhbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsNEJBQTRCLEVBQXdCLE1BQU0saUJBQWlCLENBQUM7QUFVcEYsTUFBTSxPQUFPLG9DQUFxQyxTQUFRLDRCQUE0QjtJQUlwRixZQUFZLFNBQXVDLEVBQVUsb0JBQTJCO1FBQ3RGLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUQwQyx5QkFBb0IsR0FBcEIsb0JBQW9CLENBQU87UUFGaEYsZUFBVSxHQUFhLElBQUksQ0FBQztRQUlsQyxJQUFJLENBQUMsNkJBQTZCLEdBQUMsU0FBUyxDQUFDO0lBQy9DLENBQUM7SUFFRCxTQUFTLENBQUMsUUFBZ0IsRUFBQyxVQUFpQjtRQUMxQyxvSEFBb0g7UUFDcEgsSUFBSSxDQUFDLFFBQVEsR0FBQyxRQUFRLENBQUM7UUFDdkIsSUFBSSxDQUFDLFVBQVUsR0FBQyxVQUFVLENBQUM7UUFDM0IsSUFBSSxDQUFDLFNBQVMsR0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsR0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUNoRSxvRkFBb0Y7UUFDcEYsSUFBSSxDQUFDLDZCQUE2QixDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUMsVUFBVSxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUNELFVBQVU7UUFDUixJQUFJLENBQUMsNkJBQTZCLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDbEQsQ0FBQztDQUNGO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sdUNBQXVDO0lBSWxEO1FBQ0UsSUFBSSxDQUFDLCtCQUErQixHQUFDLElBQUksS0FBSyxFQUFpQyxDQUFDO0lBQ2xGLENBQUM7SUFFRCxJQUFJLDhCQUE4QjtRQUNoQyxPQUFPLElBQUksQ0FBQywrQkFBK0IsQ0FBQztJQUM5QyxDQUFDO0lBRUQsU0FBUyxDQUFDLFFBQWdCLEVBQUMsVUFBaUI7UUFDMUMsS0FBSSxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsK0JBQStCLEVBQUM7WUFDL0MsRUFBRSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUMsVUFBVSxDQUFDLENBQUM7U0FDckM7SUFDSCxDQUFDO0lBQ0QsVUFBVTtRQUNSLEtBQUksSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLCtCQUErQixFQUFDO1lBQ2pELEVBQUUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztTQUNqQjtJQUNILENBQUM7SUFFRCxLQUFLO1FBQ0gsS0FBSSxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsK0JBQStCLEVBQUM7WUFDakQsRUFBRSxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQ1o7SUFDSCxDQUFDO0lBRUQsS0FBSztRQUNILEtBQUksSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLCtCQUErQixFQUFDO1lBQ2pELEVBQUUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNaO0lBQ0gsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUE0QjtRQUNoQyxJQUFJLE9BQU8sR0FBUSxPQUFPLENBQUMsTUFBTSxDQUFDO1FBQ2hDLEtBQUssSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLCtCQUErQixFQUFFO1lBQ25ELEVBQUUsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDbkI7UUFDSCxPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0Zsb2F0MzJBcnJheUNodW5rZXJPdXRTdHJlYW0sIEZsb2F0MzJBcnJheU91dFN0cmVhbX0gZnJvbSBcIi4uLy4uL2lvL3N0cmVhbVwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBdWRpb0Zsb2F0MzJPdXRTdHJlYW0gZXh0ZW5kcyBGbG9hdDMyQXJyYXlPdXRTdHJlYW17XHJcbiAgICBzZXRGb3JtYXQoY2hhbm5lbHM6IG51bWJlcixzYW1wbGVSYXRlOm51bWJlcik6dm9pZDtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTZXF1ZW5jZUF1ZGlvRmxvYXQzMk91dFN0cmVhbSBleHRlbmRzIEF1ZGlvRmxvYXQzMk91dFN0cmVhbXtcclxuICAgIG5leHRTdHJlYW0oKTp2b2lkO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgU2VxdWVuY2VBdWRpb0Zsb2F0MzJDaHVua2VyT3V0U3RyZWFtIGV4dGVuZHMgRmxvYXQzMkFycmF5Q2h1bmtlck91dFN0cmVhbSBpbXBsZW1lbnRzIFNlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFte1xyXG5cclxuICBwcml2YXRlIHNhbXBsZVJhdGU6bnVtYmVyfG51bGw9bnVsbDtcclxuICBwcml2YXRlIHNlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtOlNlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtO1xyXG4gIGNvbnN0cnVjdG9yKG91dFN0cmVhbTpTZXF1ZW5jZUF1ZGlvRmxvYXQzMk91dFN0cmVhbSwgcHJpdmF0ZSBjaHVua0R1cmF0aW9uU2Vjb25kczpudW1iZXIpe1xyXG4gICAgc3VwZXIob3V0U3RyZWFtKTtcclxuICAgIHRoaXMuc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW09b3V0U3RyZWFtO1xyXG4gIH1cclxuXHJcbiAgc2V0Rm9ybWF0KGNoYW5uZWxzOiBudW1iZXIsc2FtcGxlUmF0ZTpudW1iZXIpOnZvaWR7XHJcbiAgICAvL2NvbnNvbGUuZGVidWcoXCJTZXF1ZW5jZUF1ZGlvRmxvYXQzMkNodW5rZXJPdXRTdHJlYW06c2V0Rm9ybWF0KGNoYW5uZWxzOiBcIitjaGFubmVscytcIixzYW1wbGVSYXRlOiBcIitzYW1wbGVSYXRlK1wiKVwiKVxyXG4gICAgdGhpcy5jaGFubmVscz1jaGFubmVscztcclxuICAgIHRoaXMuc2FtcGxlUmF0ZT1zYW1wbGVSYXRlO1xyXG4gICAgdGhpcy5jaHVua1NpemU9TWF0aC5yb3VuZChzYW1wbGVSYXRlKnRoaXMuY2h1bmtEdXJhdGlvblNlY29uZHMpO1xyXG4gICAgLy9jb25zb2xlLmRlYnVnKFwiU2VxdWVuY2VBdWRpb0Zsb2F0MzJDaHVua2VyT3V0U3RyZWFtOiBjaHVua1NpemU6IFwiK3RoaXMuY2h1bmtTaXplKTtcclxuICAgIHRoaXMuc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW0uc2V0Rm9ybWF0KGNoYW5uZWxzLHNhbXBsZVJhdGUpO1xyXG4gIH1cclxuICBuZXh0U3RyZWFtKCk6dm9pZHtcclxuICAgIHRoaXMuc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW0ubmV4dFN0cmVhbSgpO1xyXG4gIH1cclxufVxyXG5cclxuLyoqXHJcbiAqIFN0cmVhbXMgYSBTZXF1ZW5jZUF1ZGlvRmxvYXQzMk91dFN0cmVhbSB0byBtdWx0aXBsZSBzdHJlYW1zXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgU2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW1NdWx0aXBsaWVyIGltcGxlbWVudHMgU2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW17XHJcblxyXG4gIHByaXZhdGUgX3NlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtcyE6QXJyYXk8U2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW0+O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHRoaXMuX3NlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtcz1uZXcgQXJyYXk8U2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW0+KCk7XHJcbiAgfVxyXG5cclxuICBnZXQgc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW1zKCk6IEFycmF5PFNlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtPiB7XHJcbiAgICByZXR1cm4gdGhpcy5fc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW1zO1xyXG4gIH1cclxuXHJcbiAgc2V0Rm9ybWF0KGNoYW5uZWxzOiBudW1iZXIsc2FtcGxlUmF0ZTpudW1iZXIpOnZvaWR7XHJcbiAgICBmb3IobGV0IG9zIG9mIHRoaXMuX3NlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtcyl7XHJcbiAgICAgICAgb3Muc2V0Rm9ybWF0KGNoYW5uZWxzLHNhbXBsZVJhdGUpO1xyXG4gICAgfVxyXG4gIH1cclxuICBuZXh0U3RyZWFtKCk6dm9pZHtcclxuICAgIGZvcihsZXQgb3Mgb2YgdGhpcy5fc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW1zKXtcclxuICAgICAgb3MubmV4dFN0cmVhbSgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgY2xvc2UoKTogdm9pZCB7XHJcbiAgICBmb3IobGV0IG9zIG9mIHRoaXMuX3NlcXVlbmNlQXVkaW9GbG9hdDMyT3V0U3RyZWFtcyl7XHJcbiAgICAgIG9zLmNsb3NlKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBmbHVzaCgpOiB2b2lkIHtcclxuICAgIGZvcihsZXQgb3Mgb2YgdGhpcy5fc2VxdWVuY2VBdWRpb0Zsb2F0MzJPdXRTdHJlYW1zKXtcclxuICAgICAgb3MuZmx1c2goKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHdyaXRlKGJ1ZmZlcnM6IEFycmF5PEZsb2F0MzJBcnJheT4pOiBudW1iZXIge1xyXG4gICAgbGV0IHRvV3JpdGU6bnVtYmVyPWJ1ZmZlcnMubGVuZ3RoO1xyXG4gICAgICBmb3IgKGxldCBvcyBvZiB0aGlzLl9zZXF1ZW5jZUF1ZGlvRmxvYXQzMk91dFN0cmVhbXMpIHtcclxuICAgICAgICBvcy53cml0ZShidWZmZXJzKTtcclxuICAgICAgfVxyXG4gICAgcmV0dXJuIHRvV3JpdGU7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
export class AudioClip {
|
|
2
|
-
constructor(
|
|
2
|
+
constructor(_audioDataHolder) {
|
|
3
|
+
this._audioDataHolder = _audioDataHolder;
|
|
3
4
|
this._selection = null;
|
|
4
5
|
this._levelInfos = null;
|
|
5
6
|
this.selectionObservers = new Array();
|
|
6
|
-
this._buffer = buffer;
|
|
7
7
|
}
|
|
8
|
-
get
|
|
9
|
-
return this.
|
|
8
|
+
get audioDataHolder() {
|
|
9
|
+
return this._audioDataHolder;
|
|
10
10
|
}
|
|
11
|
-
;
|
|
12
11
|
get selection() {
|
|
13
12
|
return this._selection;
|
|
14
13
|
}
|
|
@@ -73,4 +72,4 @@ export class Selection {
|
|
|
73
72
|
return "Selection: from: " + this.leftFrame + " to: " + this.rightFrame + " frame. Refers to sample rate :" + this._sampleRate;
|
|
74
73
|
}
|
|
75
74
|
}
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyc2lzdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3BlZWNocmVjb3JkZXJuZy9zcmMvbGliL2F1ZGlvL3BlcnNpc3Rvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sU0FBUztJQU1wQixZQUFvQixnQkFBZ0M7UUFBaEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFnQjtRQUo1QyxlQUFVLEdBQWdCLElBQUksQ0FBQztRQUN6QixnQkFBVyxHQUFtQixJQUFJLENBQUM7UUFLL0MsSUFBSSxDQUFDLGtCQUFrQixHQUFDLElBQUksS0FBSyxFQUErQixDQUFBO0lBQ2xFLENBQUM7SUFFRCxJQUFJLGVBQWU7UUFDakIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxTQUFTLENBQUMsS0FBcUI7UUFDakMsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7UUFDeEIsNENBQTRDO1FBQzVDLDRDQUE0QztRQUM1QyxvQ0FBb0M7UUFDcEMsY0FBYztRQUNkLE1BQU07UUFDTixLQUFJLElBQUksTUFBTSxJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBQztZQUN4QyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUE7U0FDYjtJQUNILENBQUM7SUFFRCxJQUFJLFVBQVU7UUFDWixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksVUFBVSxDQUFDLEtBQXdCO1FBQ3JDLElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO0lBQzNCLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxpQkFBNkMsRUFBQyxJQUFJLEdBQUMsS0FBSztRQUMzRSxJQUFJLGdCQUFnQixHQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUMsRUFBRSxDQUFBLENBQUMsR0FBRyxLQUFHLGlCQUFpQixDQUFDLENBQUMsQ0FBQTtRQUNuRixJQUFHLENBQUMsZ0JBQWdCLEVBQUU7WUFDcEIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1NBQ2hEO1FBQ0QsSUFBRyxJQUFJLEVBQUM7WUFDTixpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FBQTtTQUN4QjtJQUNILENBQUM7SUFFRCx1QkFBdUIsQ0FBQyxpQkFBNkM7UUFDbkUsSUFBSSxDQUFDLGtCQUFrQixHQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUMsRUFBRSxHQUFDLEdBQUcsS0FBRyxpQkFBaUIsQ0FBQSxDQUFBLENBQUMsQ0FBQyxDQUFBO0lBQzFGLENBQUM7Q0FDRjtBQVNELE1BQU0sT0FBTyxTQUFTO0lBS3BCLFlBQVksVUFBaUIsRUFBQyxVQUFpQixFQUFDLFFBQWU7UUFDN0QsSUFBSSxDQUFDLFdBQVcsR0FBQyxVQUFVLENBQUM7UUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBQyxVQUFVLENBQUE7UUFDM0IsSUFBSSxDQUFDLFNBQVMsR0FBQyxRQUFRLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksVUFBVTtRQUNaLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBQ0QsSUFBSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxJQUFJLFVBQVU7UUFDWixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksU0FBUztRQUNYLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQTtJQUNqRixDQUFDO0lBQ0QsSUFBSSxVQUFVO1FBQ1osT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFBO0lBQ2pGLENBQUM7SUFFRCxNQUFNLENBQUMsY0FBdUM7UUFDNUMsSUFBRyxjQUFjLEVBQUU7WUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksY0FBYyxDQUFDLFdBQVcsSUFBSSxJQUFJLENBQUMsV0FBVyxLQUFLLGNBQWMsQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLFNBQVMsS0FBSyxjQUFjLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDM0o7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRCxRQUFRO1FBQ04sT0FBTyxtQkFBbUIsR0FBQyxJQUFJLENBQUMsU0FBUyxHQUFDLE9BQU8sR0FBQyxJQUFJLENBQUMsVUFBVSxHQUFDLGlDQUFpQyxHQUFDLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDdkgsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtMZXZlbEluZm9zfSBmcm9tIFwiLi9kc3AvbGV2ZWxfbWVhc3VyZVwiO1xyXG5pbXBvcnQge0F1ZGlvRGF0YUhvbGRlcn0gZnJvbSBcIi4vYXVkaW9fZGF0YV9ob2xkZXJcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBBdWRpb0NsaXAge1xyXG5cclxuICBwcml2YXRlIF9zZWxlY3Rpb246U2VsZWN0aW9ufG51bGw9bnVsbDtcclxuICAgICAgICBwcml2YXRlIF9sZXZlbEluZm9zOkxldmVsSW5mb3MgfCBudWxsPW51bGw7XHJcbiAgcHJpdmF0ZSBzZWxlY3Rpb25PYnNlcnZlcnM6QXJyYXk8KGF1ZGlvQ2xpcDpBdWRpb0NsaXApPT52b2lkPjtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfYXVkaW9EYXRhSG9sZGVyOkF1ZGlvRGF0YUhvbGRlcikge1xyXG5cclxuICAgIHRoaXMuc2VsZWN0aW9uT2JzZXJ2ZXJzPW5ldyBBcnJheTwoYXVkaW9DbGlwOkF1ZGlvQ2xpcCk9PnZvaWQ+KClcclxuICB9XHJcblxyXG4gIGdldCBhdWRpb0RhdGFIb2xkZXIoKTogQXVkaW9EYXRhSG9sZGVyIHtcclxuICAgIHJldHVybiB0aGlzLl9hdWRpb0RhdGFIb2xkZXI7XHJcbiAgfVxyXG5cclxuICBnZXQgc2VsZWN0aW9uKCk6IFNlbGVjdGlvbnxudWxse1xyXG4gICAgcmV0dXJuIHRoaXMuX3NlbGVjdGlvbjtcclxuICB9XHJcblxyXG4gIHNldCBzZWxlY3Rpb24odmFsdWU6IFNlbGVjdGlvbnxudWxsKSB7XHJcbiAgICB0aGlzLl9zZWxlY3Rpb24gPSB2YWx1ZTtcclxuICAgIC8vIGxldCBvYnNDbnQ9dGhpcy5zZWxlY3Rpb25PYnNlcnZlcnMubGVuZ3RoXHJcbiAgICAvLyB0aGlzLnNlbGVjdGlvbk9ic2VydmVycy5mb3JFYWNoKChvYnMpPT4ge1xyXG4gICAgLy8gICBjb25zb2xlLmxvZyhcIkNhbGxpbmcgb2JzZXJ2ZXJcIilcclxuICAgIC8vICAgb2JzKHRoaXMpXHJcbiAgICAvLyB9KTtcclxuICAgIGZvcihsZXQgc2VsT2JzIG9mIHRoaXMuc2VsZWN0aW9uT2JzZXJ2ZXJzKXtcclxuICAgICAgc2VsT2JzKHRoaXMpXHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBnZXQgbGV2ZWxJbmZvcygpOiBMZXZlbEluZm9zIHwgbnVsbCB7XHJcbiAgICByZXR1cm4gdGhpcy5fbGV2ZWxJbmZvcztcclxuICB9XHJcblxyXG4gIHNldCBsZXZlbEluZm9zKHZhbHVlOiBMZXZlbEluZm9zIHwgbnVsbCkge1xyXG4gICAgdGhpcy5fbGV2ZWxJbmZvcyA9IHZhbHVlO1xyXG4gIH1cclxuXHJcbiAgYWRkU2VsZWN0aW9uT2JzZXJ2ZXIoc2VsZWN0aW9uT2JzZXJ2ZXI6KGF1ZGlvQ2xpcDpBdWRpb0NsaXApPT52b2lkLGluaXQ9ZmFsc2Upe1xyXG4gICAgbGV0IG9ic0FscmVhZHlJbkxpc3Q9dGhpcy5zZWxlY3Rpb25PYnNlcnZlcnMuZmluZCgob2JzKT0+KG9icz09PXNlbGVjdGlvbk9ic2VydmVyKSlcclxuICAgIGlmKCFvYnNBbHJlYWR5SW5MaXN0KSB7XHJcbiAgICAgIHRoaXMuc2VsZWN0aW9uT2JzZXJ2ZXJzLnB1c2goc2VsZWN0aW9uT2JzZXJ2ZXIpXHJcbiAgICB9XHJcbiAgICBpZihpbml0KXtcclxuICAgICAgc2VsZWN0aW9uT2JzZXJ2ZXIodGhpcylcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHJlbW92ZVNlbGVjdGlvbk9ic2VydmVyKHNlbGVjdGlvbk9ic2VydmVyOihhdWRpb0NsaXA6QXVkaW9DbGlwKT0+dm9pZCl7XHJcbiAgICB0aGlzLnNlbGVjdGlvbk9ic2VydmVycz10aGlzLnNlbGVjdGlvbk9ic2VydmVycy5maWx0ZXIoKG9icyk9PntvYnMhPT1zZWxlY3Rpb25PYnNlcnZlcn0pXHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFJlYWRlciB7XHJcbiAgcmVhZChkYXRhOiBCbG9iKTogQXVkaW9DbGlwO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgV3JpdGVyIHtcclxuICB3cml0ZShhdWRpb0RhdGE6IEF1ZGlvQ2xpcCk6IEJsb2I7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3Rpb257XHJcbiAgcHJpdmF0ZSBfc2FtcGxlUmF0ZTpudW1iZXI7XHJcbiAgcHJpdmF0ZSBfc3RhcnRGcmFtZTpudW1iZXI7XHJcbiAgcHJpdmF0ZSBfZW5kRnJhbWU6bnVtYmVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihzYW1wbGVSYXRlOm51bWJlcixzdGFydEZyYW1lOm51bWJlcixlbmRGcmFtZTpudW1iZXIpe1xyXG4gICAgdGhpcy5fc2FtcGxlUmF0ZT1zYW1wbGVSYXRlO1xyXG4gICAgdGhpcy5fc3RhcnRGcmFtZT1zdGFydEZyYW1lXHJcbiAgICB0aGlzLl9lbmRGcmFtZT1lbmRGcmFtZTtcclxuICB9XHJcblxyXG4gIGdldCBzYW1wbGVSYXRlKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gdGhpcy5fc2FtcGxlUmF0ZTtcclxuICB9XHJcbiAgZ2V0IGVuZEZyYW1lKCk6bnVtYmVye1xyXG4gICAgcmV0dXJuIHRoaXMuX2VuZEZyYW1lO1xyXG4gIH1cclxuICBnZXQgc3RhcnRGcmFtZSgpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIHRoaXMuX3N0YXJ0RnJhbWU7XHJcbiAgfVxyXG5cclxuICBnZXQgbGVmdEZyYW1lKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gKHRoaXMuX3N0YXJ0RnJhbWUgPD0gdGhpcy5fZW5kRnJhbWUpID8gdGhpcy5fc3RhcnRGcmFtZSA6IHRoaXMuX2VuZEZyYW1lXHJcbiAgfVxyXG4gIGdldCByaWdodEZyYW1lKCk6IG51bWJlciB7XHJcbiAgICByZXR1cm4gKHRoaXMuX3N0YXJ0RnJhbWUgPD0gdGhpcy5fZW5kRnJhbWUpID8gdGhpcy5fZW5kRnJhbWUgOiB0aGlzLl9zdGFydEZyYW1lXHJcbiAgfVxyXG5cclxuICBlcXVhbHMob3RoZXJTZWxlY3Rpb246U2VsZWN0aW9ufG51bGx8dW5kZWZpbmVkKTpib29sZWFue1xyXG4gICAgaWYob3RoZXJTZWxlY3Rpb24pIHtcclxuICAgICAgcmV0dXJuICh0aGlzLl9zYW1wbGVSYXRlID09IG90aGVyU2VsZWN0aW9uLl9zYW1wbGVSYXRlICYmIHRoaXMuX3N0YXJ0RnJhbWUgPT09IG90aGVyU2VsZWN0aW9uLl9zdGFydEZyYW1lICYmIHRoaXMuX2VuZEZyYW1lID09PSBvdGhlclNlbGVjdGlvbi5fZW5kRnJhbWUpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgdG9TdHJpbmcoKXtcclxuICAgIHJldHVybiBcIlNlbGVjdGlvbjogZnJvbTogXCIrdGhpcy5sZWZ0RnJhbWUrXCIgdG86IFwiK3RoaXMucmlnaHRGcmFtZStcIiBmcmFtZS4gUmVmZXJzIHRvIHNhbXBsZSByYXRlIDpcIit0aGlzLl9zYW1wbGVSYXRlO1xyXG4gIH1cclxufVxyXG5cclxuXHJcbiJdfQ==
|