From 3232c4a51b4cc5625319b05fe74a5ade97bd7117 Mon Sep 17 00:00:00 2001 From: dumbmoron Date: Sat, 7 Sep 2024 11:41:56 +0000 Subject: [PATCH] web/libav: simplify reading probe data --- web/src/lib/libav.ts | 24 ++++-------------------- 1 file changed, 4 insertions(+), 20 deletions(-) diff --git a/web/src/lib/libav.ts b/web/src/lib/libav.ts index 2226c8b9..9a1f1021 100644 --- a/web/src/lib/libav.ts +++ b/web/src/lib/libav.ts @@ -28,38 +28,22 @@ export default class LibAVWrapper { if (!this.libav) throw new Error("LibAV wasn't initialized"); const libav = await this.libav; - const OUT_FILE = 'output.json'; await libav.mkreadaheadfile('input', blob); - await libav.mkwriterdev(OUT_FILE); - - let writtenData = new Uint8Array(0); - - libav.onwrite = (name, pos, data) => { - if (name !== OUT_FILE) return; - - const newLen = Math.max(pos + data.length, writtenData.length); - if (newLen > writtenData.length) { - const newData = new Uint8Array(newLen); - newData.set(writtenData); - writtenData = newData; - } - writtenData.set(data, pos); - }; - await libav.ffprobe([ '-v', 'quiet', '-print_format', 'json', '-show_format', '-show_streams', 'input', - '-o', OUT_FILE + '-o', 'output.json' ]); - await libav.unlink(OUT_FILE); await libav.unlinkreadaheadfile('input'); - const copy = new Uint8Array(writtenData); + const copy = await libav.readFile('output.json'); const text = new TextDecoder().decode(copy); + await libav.unlink('output.json'); + return JSON.parse(text) as FfprobeData; }