@omnimedia/omnitool 1.0.0 → 1.1.0-10
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/LICENSE +21 -0
- package/README.md +120 -2
- package/package.json +59 -27
- package/s/_archive/types.ts +107 -0
- package/s/context.ts +7 -0
- package/s/demo/demo.bundle.ts +68 -0
- package/s/demo/demo.css +59 -0
- package/s/demo/routines/filmstrip-test.ts +68 -0
- package/s/demo/routines/load-video.ts +7 -0
- package/s/demo/routines/transcode-test.ts +46 -0
- package/s/demo/routines/transcriber-test.ts +34 -0
- package/s/demo/routines/transitions-test.ts +43 -0
- package/s/demo/routines/waveform-test.ts +12 -0
- package/s/driver/driver.test.ts +15 -0
- package/s/driver/driver.ts +124 -0
- package/s/driver/driver.worker.bundle.ts +7 -0
- package/s/driver/fns/host.ts +13 -0
- package/s/driver/fns/schematic.ts +106 -0
- package/s/driver/fns/work.ts +249 -0
- package/s/driver/parts/constants.ts +17 -0
- package/s/driver/parts/machina.ts +27 -0
- package/s/driver/utils/load-decoder-source.ts +12 -0
- package/s/driver/utils/sleep.ts +3 -0
- package/s/features/speech/transcribe/default-spec.ts +11 -0
- package/s/features/speech/transcribe/parts/load-pipe.ts +19 -0
- package/s/features/speech/transcribe/parts/prep-audio.ts +23 -0
- package/s/features/speech/transcribe/parts/transcribe.ts +70 -0
- package/s/features/speech/transcribe/transcriber.ts +46 -0
- package/s/features/speech/transcribe/types.ts +82 -0
- package/s/features/speech/transcribe/worker.bundle.ts +40 -0
- package/s/features/transition/parts/fragment.ts +24 -0
- package/s/features/transition/parts/types.ts +94 -0
- package/s/features/transition/parts/uniforms.ts +29 -0
- package/s/features/transition/parts/vertex.ts +31 -0
- package/s/features/transition/transition.ts +60 -0
- package/s/index.html.ts +58 -0
- package/s/index.ts +2 -39
- package/s/tests.test.ts +8 -0
- package/s/timeline/index.ts +15 -0
- package/s/timeline/parts/basics.ts +17 -0
- package/s/timeline/parts/compositor/export.ts +77 -0
- package/s/timeline/parts/compositor/parts/html-tree.ts +37 -0
- package/s/timeline/parts/compositor/parts/schedulers.ts +85 -0
- package/s/timeline/parts/compositor/parts/tree-builder.ts +184 -0
- package/s/timeline/parts/compositor/parts/webcodecs-tree.ts +30 -0
- package/s/timeline/parts/compositor/playback.ts +81 -0
- package/s/timeline/parts/compositor/samplers/html.ts +115 -0
- package/s/timeline/parts/compositor/samplers/webcodecs.ts +60 -0
- package/s/timeline/parts/filmstrip.ts +159 -0
- package/s/timeline/parts/item.ts +90 -0
- package/s/timeline/parts/media.ts +35 -0
- package/s/timeline/parts/resource-pool.ts +27 -0
- package/s/timeline/parts/resource.ts +11 -0
- package/s/timeline/parts/waveform.ts +62 -0
- package/s/timeline/sugar/builders.ts +102 -0
- package/s/timeline/sugar/o.ts +150 -0
- package/s/timeline/sugar/omni-test.ts +38 -0
- package/s/timeline/sugar/omni.ts +40 -0
- package/s/timeline/types.ts +29 -0
- package/s/timeline/utils/audio-stream.ts +15 -0
- package/s/timeline/utils/checksum.ts +20 -0
- package/s/timeline/utils/datafile.ts +21 -0
- package/s/timeline/utils/dummy-data.ts +7 -0
- package/s/timeline/utils/matrix.ts +33 -0
- package/s/timeline/utils/video-cursor.ts +40 -0
- package/s/tools/common/loader.ts +26 -0
- package/s/tools/common/transformer-pipeline.ts +26 -0
- package/s/tools/speech-recognition/common/model.ts +26 -0
- package/s/tools/speech-recognition/whisper/fns/host.ts +25 -0
- package/s/tools/speech-recognition/whisper/fns/schematic.ts +23 -0
- package/s/tools/speech-recognition/whisper/fns/work.ts +91 -0
- package/s/tools/speech-recognition/whisper/parts/types.ts +38 -0
- package/s/tools/speech-recognition/whisper/parts/worker.bundle.ts +7 -0
- package/s/tools/speech-recognition/whisper/tool.ts +70 -0
- package/x/context.d.ts +4 -0
- package/x/context.js +6 -0
- package/x/context.js.map +1 -0
- package/x/demo/demo.bundle.d.ts +1 -0
- package/x/demo/demo.bundle.js +55 -0
- package/x/demo/demo.bundle.js.map +1 -0
- package/x/demo/demo.bundle.min.js +120 -0
- package/x/demo/demo.bundle.min.js.map +7 -0
- package/x/demo/demo.css +59 -0
- package/x/demo/routines/filmstrip-test.d.ts +1 -0
- package/x/demo/routines/filmstrip-test.js +62 -0
- package/x/demo/routines/filmstrip-test.js.map +1 -0
- package/x/demo/routines/load-video.d.ts +1 -0
- package/x/demo/routines/load-video.js +6 -0
- package/x/demo/routines/load-video.js.map +1 -0
- package/x/demo/routines/transcode-test.d.ts +6 -0
- package/x/demo/routines/transcode-test.js +40 -0
- package/x/demo/routines/transcode-test.js.map +1 -0
- package/x/demo/routines/transcriber-test.d.ts +4 -0
- package/x/demo/routines/transcriber-test.js +33 -0
- package/x/demo/routines/transcriber-test.js.map +1 -0
- package/x/demo/routines/transitions-test.d.ts +5 -0
- package/x/demo/routines/transitions-test.js +35 -0
- package/x/demo/routines/transitions-test.js.map +1 -0
- package/x/demo/routines/waveform-test.d.ts +1 -0
- package/x/demo/routines/waveform-test.js +11 -0
- package/x/demo/routines/waveform-test.js.map +1 -0
- package/x/driver/driver.d.ts +20 -0
- package/x/driver/driver.js +104 -0
- package/x/driver/driver.js.map +1 -0
- package/x/driver/driver.test.d.ts +5 -0
- package/x/driver/driver.test.js +12 -0
- package/x/driver/driver.test.js.map +1 -0
- package/x/driver/driver.worker.bundle.d.ts +1 -0
- package/x/driver/driver.worker.bundle.js +4 -0
- package/x/driver/driver.worker.bundle.js.map +1 -0
- package/x/driver/driver.worker.bundle.min.js +3537 -0
- package/x/driver/driver.worker.bundle.min.js.map +7 -0
- package/x/driver/fns/host.d.ts +25 -0
- package/x/driver/fns/host.js +7 -0
- package/x/driver/fns/host.js.map +1 -0
- package/x/driver/fns/schematic.d.ts +84 -0
- package/x/driver/fns/schematic.js +2 -0
- package/x/driver/fns/schematic.js.map +1 -0
- package/x/driver/fns/work.d.ts +26 -0
- package/x/driver/fns/work.js +201 -0
- package/x/driver/fns/work.js.map +1 -0
- package/x/driver/parts/constants.d.ts +2 -0
- package/x/driver/parts/constants.js +17 -0
- package/x/driver/parts/constants.js.map +1 -0
- package/x/driver/parts/machina.d.ts +23 -0
- package/x/driver/parts/machina.js +14 -0
- package/x/driver/parts/machina.js.map +1 -0
- package/x/driver/utils/load-decoder-source.d.ts +3 -0
- package/x/driver/utils/load-decoder-source.js +11 -0
- package/x/driver/utils/load-decoder-source.js.map +1 -0
- package/x/driver/utils/sleep.d.ts +1 -0
- package/x/driver/utils/sleep.js +4 -0
- package/x/driver/utils/sleep.js.map +1 -0
- package/x/features/speech/transcribe/default-spec.d.ts +2 -0
- package/x/features/speech/transcribe/default-spec.js +8 -0
- package/x/features/speech/transcribe/default-spec.js.map +1 -0
- package/x/features/speech/transcribe/parts/load-pipe.d.ts +2 -0
- package/x/features/speech/transcribe/parts/load-pipe.js +13 -0
- package/x/features/speech/transcribe/parts/load-pipe.js.map +1 -0
- package/x/features/speech/transcribe/parts/prep-audio.d.ts +5 -0
- package/x/features/speech/transcribe/parts/prep-audio.js +21 -0
- package/x/features/speech/transcribe/parts/prep-audio.js.map +1 -0
- package/x/features/speech/transcribe/parts/transcribe.d.ts +5 -0
- package/x/features/speech/transcribe/parts/transcribe.js +56 -0
- package/x/features/speech/transcribe/parts/transcribe.js.map +1 -0
- package/x/features/speech/transcribe/transcriber.d.ts +5 -0
- package/x/features/speech/transcribe/transcriber.js +33 -0
- package/x/features/speech/transcribe/transcriber.js.map +1 -0
- package/x/features/speech/transcribe/types.d.ts +66 -0
- package/x/features/speech/transcribe/types.js.map +1 -0
- package/x/features/speech/transcribe/worker.bundle.d.ts +1 -0
- package/x/features/speech/transcribe/worker.bundle.js +33 -0
- package/x/features/speech/transcribe/worker.bundle.js.map +1 -0
- package/x/features/speech/transcribe/worker.bundle.min.js +2916 -0
- package/x/features/speech/transcribe/worker.bundle.min.js.map +7 -0
- package/x/features/transition/parts/fragment.d.ts +1 -0
- package/x/features/transition/parts/fragment.js +25 -0
- package/x/features/transition/parts/fragment.js.map +1 -0
- package/x/features/transition/parts/types.d.ts +23 -0
- package/x/features/transition/parts/types.js +2 -0
- package/x/features/transition/parts/types.js.map +1 -0
- package/x/features/transition/parts/uniforms.d.ts +31 -0
- package/x/features/transition/parts/uniforms.js +27 -0
- package/x/features/transition/parts/uniforms.js.map +1 -0
- package/x/features/transition/parts/vertex.d.ts +1 -0
- package/x/features/transition/parts/vertex.js +32 -0
- package/x/features/transition/parts/vertex.js.map +1 -0
- package/x/features/transition/transition.d.ts +5 -0
- package/x/features/transition/transition.js +50 -0
- package/x/features/transition/transition.js.map +1 -0
- package/x/index.d.ts +2 -9
- package/x/index.html +115 -0
- package/x/index.html.d.ts +2 -0
- package/x/index.html.js +52 -0
- package/x/index.html.js.map +1 -0
- package/x/index.js +2 -29
- package/x/index.js.map +1 -1
- package/x/tests.test.d.ts +1 -0
- package/x/tests.test.js +6 -0
- package/x/tests.test.js.map +1 -0
- package/x/timeline/index.d.ts +11 -0
- package/x/timeline/index.js +12 -0
- package/x/timeline/index.js.map +1 -0
- package/x/timeline/parts/basics.d.ts +12 -0
- package/x/timeline/parts/basics.js +2 -0
- package/x/timeline/parts/basics.js.map +1 -0
- package/x/timeline/parts/compositor/export.d.ts +9 -0
- package/x/timeline/parts/compositor/export.js +64 -0
- package/x/timeline/parts/compositor/export.js.map +1 -0
- package/x/timeline/parts/compositor/parts/html-tree.d.ts +3 -0
- package/x/timeline/parts/compositor/parts/html-tree.js +40 -0
- package/x/timeline/parts/compositor/parts/html-tree.js.map +1 -0
- package/x/timeline/parts/compositor/parts/schedulers.d.ts +15 -0
- package/x/timeline/parts/compositor/parts/schedulers.js +64 -0
- package/x/timeline/parts/compositor/parts/schedulers.js.map +1 -0
- package/x/timeline/parts/compositor/parts/tree-builder.d.ts +37 -0
- package/x/timeline/parts/compositor/parts/tree-builder.js +147 -0
- package/x/timeline/parts/compositor/parts/tree-builder.js.map +1 -0
- package/x/timeline/parts/compositor/parts/webcodecs-tree.d.ts +3 -0
- package/x/timeline/parts/compositor/parts/webcodecs-tree.js +28 -0
- package/x/timeline/parts/compositor/parts/webcodecs-tree.js.map +1 -0
- package/x/timeline/parts/compositor/playback.d.ts +19 -0
- package/x/timeline/parts/compositor/playback.js +71 -0
- package/x/timeline/parts/compositor/playback.js.map +1 -0
- package/x/timeline/parts/compositor/samplers/html.d.ts +3 -0
- package/x/timeline/parts/compositor/samplers/html.js +106 -0
- package/x/timeline/parts/compositor/samplers/html.js.map +1 -0
- package/x/timeline/parts/compositor/samplers/webcodecs.d.ts +2 -0
- package/x/timeline/parts/compositor/samplers/webcodecs.js +55 -0
- package/x/timeline/parts/compositor/samplers/webcodecs.js.map +1 -0
- package/x/timeline/parts/filmstrip.d.ts +39 -0
- package/x/timeline/parts/filmstrip.js +117 -0
- package/x/timeline/parts/filmstrip.js.map +1 -0
- package/x/timeline/parts/item.d.ts +68 -0
- package/x/timeline/parts/item.js +16 -0
- package/x/timeline/parts/item.js.map +1 -0
- package/x/timeline/parts/media.d.ts +10 -0
- package/x/timeline/parts/media.js +30 -0
- package/x/timeline/parts/media.js.map +1 -0
- package/x/timeline/parts/resource-pool.d.ts +7 -0
- package/x/timeline/parts/resource-pool.js +19 -0
- package/x/timeline/parts/resource-pool.js.map +1 -0
- package/x/timeline/parts/resource.d.ts +8 -0
- package/x/timeline/parts/resource.js +2 -0
- package/x/timeline/parts/resource.js.map +1 -0
- package/x/timeline/parts/waveform.d.ts +8 -0
- package/x/timeline/parts/waveform.js +51 -0
- package/x/timeline/parts/waveform.js.map +1 -0
- package/x/timeline/sugar/builders.d.ts +1 -0
- package/x/timeline/sugar/builders.js +104 -0
- package/x/timeline/sugar/builders.js.map +1 -0
- package/x/timeline/sugar/o.d.ts +32 -0
- package/x/timeline/sugar/o.js +114 -0
- package/x/timeline/sugar/o.js.map +1 -0
- package/x/timeline/sugar/omni-test.d.ts +1 -0
- package/x/timeline/sugar/omni-test.js +22 -0
- package/x/timeline/sugar/omni-test.js.map +1 -0
- package/x/timeline/sugar/omni.d.ts +14 -0
- package/x/timeline/sugar/omni.js +28 -0
- package/x/timeline/sugar/omni.js.map +1 -0
- package/x/timeline/types.d.ts +24 -0
- package/x/timeline/types.js +2 -0
- package/x/timeline/types.js.map +1 -0
- package/x/timeline/utils/audio-stream.d.ts +6 -0
- package/x/timeline/utils/audio-stream.js +17 -0
- package/x/timeline/utils/audio-stream.js.map +1 -0
- package/x/timeline/utils/checksum.d.ts +8 -0
- package/x/timeline/utils/checksum.js +21 -0
- package/x/timeline/utils/checksum.js.map +1 -0
- package/x/timeline/utils/datafile.d.ts +9 -0
- package/x/timeline/utils/datafile.js +20 -0
- package/x/timeline/utils/datafile.js.map +1 -0
- package/x/timeline/utils/dummy-data.d.ts +2 -0
- package/x/timeline/utils/dummy-data.js +3 -0
- package/x/timeline/utils/dummy-data.js.map +1 -0
- package/x/timeline/utils/matrix.d.ts +8 -0
- package/x/timeline/utils/matrix.js +26 -0
- package/x/timeline/utils/matrix.js.map +1 -0
- package/x/timeline/utils/video-cursor.d.ts +10 -0
- package/x/timeline/utils/video-cursor.js +36 -0
- package/x/timeline/utils/video-cursor.js.map +1 -0
- package/x/tools/common/loader.d.ts +19 -0
- package/x/tools/common/loader.js +18 -0
- package/x/tools/common/loader.js.map +1 -0
- package/x/tools/common/transformer-pipeline.d.ts +8 -0
- package/x/tools/common/transformer-pipeline.js +24 -0
- package/x/tools/common/transformer-pipeline.js.map +1 -0
- package/x/tools/speech-recognition/common/model.d.ts +14 -0
- package/x/tools/speech-recognition/common/model.js +16 -0
- package/x/tools/speech-recognition/common/model.js.map +1 -0
- package/x/tools/speech-recognition/whisper/fns/host.d.ts +13 -0
- package/x/tools/speech-recognition/whisper/fns/host.js +19 -0
- package/x/tools/speech-recognition/whisper/fns/host.js.map +1 -0
- package/x/tools/speech-recognition/whisper/fns/schematic.d.ts +19 -0
- package/x/tools/speech-recognition/whisper/fns/schematic.js +2 -0
- package/x/tools/speech-recognition/whisper/fns/schematic.js.map +1 -0
- package/x/tools/speech-recognition/whisper/fns/work.d.ts +12 -0
- package/x/tools/speech-recognition/whisper/fns/work.js +74 -0
- package/x/tools/speech-recognition/whisper/fns/work.js.map +1 -0
- package/x/tools/speech-recognition/whisper/parts/types.d.ts +31 -0
- package/x/tools/speech-recognition/whisper/parts/types.js +2 -0
- package/x/tools/speech-recognition/whisper/parts/types.js.map +1 -0
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.d.ts +1 -0
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.js +4 -0
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.js.map +1 -0
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js +8 -0
- package/x/tools/speech-recognition/whisper/parts/worker.bundle.min.js.map +7 -0
- package/x/tools/speech-recognition/whisper/tool.d.ts +12 -0
- package/x/tools/speech-recognition/whisper/tool.js +63 -0
- package/x/tools/speech-recognition/whisper/tool.js.map +1 -0
- package/s/parts/compositor.ts +0 -5
- package/s/parts/export.ts +0 -5
- package/s/parts/video-decoder.ts +0 -27
- package/s/parts/video-encoder.ts +0 -15
- package/s/tools/generate-id.ts +0 -7
- package/s/tools/mp4boxjs/LICENSE.md +0 -24
- package/s/tools/mp4boxjs/demuxer.ts +0 -106
- package/s/tools/mp4boxjs/mp4box.adapter.ts +0 -148
- package/s/tools/mp4boxjs/mp4box.js +0 -8206
- package/s/types.ts +0 -10
- package/x/parts/compositor.d.ts +0 -4
- package/x/parts/compositor.js +0 -5
- package/x/parts/compositor.js.map +0 -1
- package/x/parts/export.d.ts +0 -7
- package/x/parts/export.js +0 -5
- package/x/parts/export.js.map +0 -1
- package/x/parts/video-decoder.d.ts +0 -8
- package/x/parts/video-decoder.js +0 -20
- package/x/parts/video-decoder.js.map +0 -1
- package/x/parts/video-encoder.d.ts +0 -6
- package/x/parts/video-encoder.js +0 -12
- package/x/parts/video-encoder.js.map +0 -1
- package/x/tools/generate-id.d.ts +0 -1
- package/x/tools/generate-id.js +0 -8
- package/x/tools/generate-id.js.map +0 -1
- package/x/tools/mp4boxjs/demuxer.d.ts +0 -24
- package/x/tools/mp4boxjs/demuxer.js +0 -88
- package/x/tools/mp4boxjs/demuxer.js.map +0 -1
- package/x/tools/mp4boxjs/mp4box.adapter.d.ts +0 -128
- package/x/tools/mp4boxjs/mp4box.adapter.js +0 -11
- package/x/tools/mp4boxjs/mp4box.adapter.js.map +0 -1
- package/x/types.d.ts +0 -7
- package/x/types.js.map +0 -1
- /package/x/{types.js → features/speech/transcribe/types.js} +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../node_modules/@e280/renraku/s/core/taps/bind.ts", "../../node_modules/@e280/sten/s/themes/basic.ts", "../../node_modules/@e280/sten/s/themes/auto.ts", "../../node_modules/@e280/sten/s/colors/parts/codes.ts", "../../node_modules/@e280/sten/s/colors/parts/color-fns.ts", "../../node_modules/@e280/sten/s/colors/colorless.ts", "../../node_modules/@e280/sten/s/colors/colorful.ts", "../../node_modules/@e280/sten/s/utils/supports.ts", "../../node_modules/@e280/sten/s/colors/auto.ts", "../../node_modules/@e280/sten/s/shapers/errors.ts", "../../node_modules/@e280/sten/s/shapers/shaper.ts", "../../node_modules/@e280/sten/s/shapers/timestamp.ts", "../../node_modules/@e280/sten/s/shapers/auto.ts", "../../node_modules/@e280/sten/s/writers/deno.ts", "../../node_modules/@e280/sten/s/writers/node.ts", "../../node_modules/@e280/sten/s/writers/console.ts", "../../node_modules/@e280/sten/s/writers/auto.ts", "../../node_modules/@e280/sten/s/writers/void.ts", "../../node_modules/@e280/sten/s/shapers/none.ts", "../../node_modules/@e280/sten/s/logger.ts", "../../node_modules/@e280/renraku/s/core/taps/logger.ts", "../../node_modules/@e280/renraku/s/core/taps/error.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/data/bytes.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/data/hex.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/data/base58.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/data/base-x.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/data/base64.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/data/txt.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/is.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/deadline.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/defer.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/drill.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/ob.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/pubsub.ts", "../../node_modules/@e280/renraku/node_modules/@e280/stz/s/trash.ts", "../../node_modules/@e280/renraku/s/core/json-rpc.ts", "../../node_modules/@e280/renraku/s/core/errors.ts", "../../node_modules/@e280/renraku/s/core/execute.ts", "../../node_modules/@e280/renraku/s/core/endpoint.ts", "../../node_modules/@e280/renraku/s/core/remote-proxy.ts", "../../node_modules/@e280/renraku/s/core/remote.ts", "../../node_modules/@e280/renraku/s/core/mock.ts", "../../node_modules/@e280/renraku/s/transports/messenger/conduits/conduit.ts", "../../node_modules/@e280/renraku/s/transports/messenger/parts/helpers.ts", "../../node_modules/@e280/renraku/s/transports/messenger/conduits/postable.ts", "../../node_modules/@e280/renraku/s/transports/messenger/parts/meta.ts", "../../node_modules/@e280/renraku/s/defaults.ts", "../../node_modules/@e280/renraku/s/transports/messenger/parts/response-waiter.ts", "../../node_modules/@e280/renraku/s/transports/messenger/messenger.ts", "../../node_modules/@e280/comrade/s/parts/shells.ts", "../../node_modules/@e280/comrade/s/parts/default-tap.ts", "../../node_modules/@e280/comrade/s/parts/worker.ts", "../../node_modules/@e280/stz/s/data/bytes.ts", "../../node_modules/@e280/stz/s/data/hex.ts", "../../node_modules/@e280/stz/s/data/base58.ts", "../../node_modules/@e280/stz/s/data/base-x.ts", "../../node_modules/@e280/stz/s/data/base64.ts", "../../node_modules/@e280/stz/s/data/txt.ts", "../../node_modules/@e280/stz/s/is.ts", "../../node_modules/@e280/stz/s/queue/queue.ts", "../../node_modules/@e280/stz/s/coalesce.ts", "../../node_modules/@e280/stz/s/defer.ts", "../../node_modules/@e280/stz/s/ob.ts", "../../node_modules/@e280/stz/s/pubsub.ts", "../../node_modules/@e280/comrade/s/parts/thread.ts", "../../node_modules/@e280/comrade/s/parts/cluster.ts", "../../node_modules/@e280/comrade/s/comrade.ts", "../../node_modules/@e280/comrade/s/compat/browser.ts", "../../node_modules/@e280/comrade/s/index.browser.ts", "../../node_modules/mediabunny/dist/modules/src/misc.js", "../../node_modules/mediabunny/dist/modules/src/tags.js", "../../node_modules/mediabunny/dist/modules/src/codec.js", "../../node_modules/mediabunny/dist/modules/src/codec-data.js", "../../node_modules/mediabunny/dist/modules/src/isobmff/isobmff-misc.js", "../../node_modules/mediabunny/dist/modules/src/reader.js", "../../node_modules/mediabunny/dist/modules/src/isobmff/isobmff-reader.js", "../../node_modules/mediabunny/dist/modules/src/matroska/ebml.js", "../../node_modules/mediabunny/dist/modules/src/matroska/matroska-misc.js", "../../node_modules/mediabunny/dist/modules/shared/mp3-misc.js", "../../node_modules/mediabunny/dist/modules/src/mp3/mp3-reader.js", "../../node_modules/mediabunny/dist/modules/src/ogg/ogg-misc.js", "../../node_modules/mediabunny/dist/modules/src/ogg/ogg-reader.js", "../../node_modules/mediabunny/dist/modules/src/demuxer.js", "../../node_modules/mediabunny/dist/modules/src/custom-coder.js", "../../node_modules/mediabunny/dist/modules/src/packet.js", "../../node_modules/mediabunny/dist/modules/src/sample.js", "../../node_modules/mediabunny/dist/modules/src/media-sink.js", "../../node_modules/mediabunny/dist/modules/src/input-track.js", "../../node_modules/mediabunny/dist/modules/src/wave/wave-demuxer.js", "../../node_modules/mediabunny/dist/modules/src/source.js", "../../node_modules/mediabunny/dist/modules/src/isobmff/isobmff-demuxer.js", "../../node_modules/mediabunny/dist/modules/src/matroska/matroska-demuxer.js", "../../node_modules/mediabunny/dist/modules/src/mp3/mp3-demuxer.js", "../../node_modules/mediabunny/dist/modules/src/ogg/ogg-demuxer.js", "../../node_modules/mediabunny/dist/modules/src/adts/adts-reader.js", "../../node_modules/mediabunny/dist/modules/src/adts/adts-demuxer.js", "../../node_modules/mediabunny/dist/modules/src/input-format.js", "../../node_modules/mediabunny/dist/modules/src/input.js", "../../s/driver/parts/machina.ts", "../../s/driver/fns/host.ts", "../../s/driver/utils/load-decoder-source.ts", "../../s/driver/driver.ts", "../../s/context.ts", "../../node_modules/wavesurfer.js/dist/wavesurfer.esm.js", "../../s/timeline/parts/waveform.ts", "../../s/demo/routines/waveform-test.ts", "../../s/timeline/parts/filmstrip.ts", "../../s/demo/routines/filmstrip-test.ts", "../../s/features/speech/transcribe/parts/prep-audio.ts", "../../s/features/speech/transcribe/transcriber.ts", "../../s/demo/routines/transcriber-test.ts", "../../s/demo/routines/transcode-test.ts", "../../s/demo/demo.bundle.ts"],
|
|
4
|
+
"sourcesContent": ["\nimport {Tap, TapContext} from \"../types.js\"\n\nexport function bindTap(tap: Tap, ctx: TapContext): Tap {\n\treturn {\n\t\terror: o => tap.error({...ctx, ...o}),\n\t\trpcRequest: o => tap.rpcRequest({...ctx, ...o}),\n\t\trpcError: o => tap.rpcError({...ctx, ...o}),\n\t}\n}\n\n", "\nimport {asTheme} from \"./theme.js\"\n\nexport const basicTheme = () => asTheme(colors => ({\n\tplain: colors.none,\n\terrMessage: colors.mix(colors.brightRed, colors.bold),\n\terrName: colors.red,\n\terrStack: colors.mix(colors.red, colors.dim),\n\ttimestamp: colors.blue,\n\ttimestampErr: colors.red,\n}))\n\n", "\nimport {basicTheme} from \"./basic.js\"\n\nexport function autoTheme() {\n\treturn basicTheme()\n}\n\n", "\nexport const codes = Object.freeze({\n\n\t// regular colors\n\tblack: \"\\u001b[30m\",\n\tred: \"\\u001b[31m\",\n\tgreen: \"\\u001b[32m\",\n\tyellow: \"\\u001b[33m\",\n\tblue: \"\\u001b[34m\",\n\tmagenta: \"\\u001b[35m\",\n\tcyan: \"\\u001b[36m\",\n\twhite: \"\\u001b[37m\",\n\n\t// bright colors\n\tbrightBlack: \"\\u001b[90m\",\n\tbrightRed: \"\\u001b[91m\",\n\tbrightGreen: \"\\u001b[92m\",\n\tbrightYellow: \"\\u001b[93m\",\n\tbrightBlue: \"\\u001b[94m\",\n\tbrightMagenta: \"\\u001b[95m\",\n\tbrightCyan: \"\\u001b[96m\",\n\tbrightWhite: \"\\u001b[97m\",\n\n\t// background colors\n\tbgBlack: \"\\u001b[40m\",\n\tbgRed: \"\\u001b[41m\",\n\tbgGreen: \"\\u001b[42m\",\n\tbgYellow: \"\\u001b[43m\",\n\tbgBlue: \"\\u001b[44m\",\n\tbgMagenta: \"\\u001b[45m\",\n\tbgCyan: \"\\u001b[46m\",\n\tbgWhite: \"\\u001b[47m\",\n\n\t// bright background colors\n\tbgBrightBlack: \"\\u001b[100m\",\n\tbgBrightRed: \"\\u001b[101m\",\n\tbgBrightGreen: \"\\u001b[102m\",\n\tbgBrightYellow: \"\\u001b[103m\",\n\tbgBrightBlue: \"\\u001b[104m\",\n\tbgBrightMagenta: \"\\u001b[105m\",\n\tbgBrightCyan: \"\\u001b[106m\",\n\tbgBrightWhite: \"\\u001b[107m\",\n\n\t// styles\n\tbold: \"\\u001b[1m\",\n\tdim: \"\\u001b[2m\",\n\titalic: \"\\u001b[3m\",\n\tunderline: \"\\u001b[4m\",\n\tinverse: \"\\u001b[7m\",\n\thidden: \"\\u001b[8m\",\n\tstrikethrough: \"\\u001b[9m\",\n\n\t// reset\n\treset: \"\\u001b[0m\",\n})\n\n", "\nimport {codes} from \"./codes.js\"\n\nexport type ColorFn = (s: string) => string\n\nexport const colorFns = () => ({\n\tnone: (s: string) => s,\n\tuncolor,\n\tmix,\n\thex,\n\trgb,\n\tbgRgb,\n})\n\nexport function uncolor(s: string) {\n\treturn s.replace(\n\t\t/[\\u001b\\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g,\n\t\t\"\",\n\t)\n}\n\nexport function mix(...colorFns: ColorFn[]) {\n\treturn (s: string) => {\n\t\tfor (const fn of colorFns)\n\t\t\ts = fn(s)\n\t\treturn s\n\t}\n}\n\nexport function hex(hex: string) {\n\thex = hex.replace(/^#/, \"\")\n\tlet bigint: number\n\tlet r: number\n\tlet g: number\n\tlet b: number\n\n\tif (hex.length === 3)\n\t\tbigint = parseInt(hex.split('').map(c => c + c).join(''), 16)\n\telse if (hex.length === 6)\n\t\tbigint = parseInt(hex, 16)\n\telse\n\t\tthrow new Error('Invalid hex color')\n\n\tr = (bigint >> 16) & 255\n\tg = (bigint >> 8) & 255\n\tb = bigint & 255\n\treturn rgb(r, g, b)\n}\n\nexport function rgb(r: number, g: number, b: number) {\n\tconst code = `\\u001b[38;2;${r};${g};${b}m`\n\treturn (s: string) => `${code}${s}${codes.reset}`\n}\n\nexport function bgRgb(r: number, g: number, b: number) {\n\tconst code = `\\u001b[48;2;${r};${g};${b}m`\n\treturn (s: string) => `${code}${s}${codes.reset}`\n}\n\n", "\nimport {Colors} from \"./colorful.js\"\nimport {codes} from \"./parts/codes.js\"\nimport {colorFns} from \"./parts/color-fns.js\"\n\nexport const colorless = {\n\t...<{[key in keyof typeof codes]: (s: string) => string}>(\n\t\tObject.fromEntries(\n\t\t\tObject.entries(codes)\n\t\t\t\t.map(([key]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\t(s: string) => s,\n\t\t\t\t])\n\t\t)\n\t),\n\t...colorFns(),\n} as Colors\n\n", "\nimport {codes} from \"./parts/codes.js\"\nimport {colorFns} from \"./parts/color-fns.js\"\n\nexport type Colors = typeof colorful\n\nexport const colorful = {\n\t...<{[key in keyof typeof codes]: (s: string) => string}>(\n\t\tObject.fromEntries(\n\t\t\tObject.entries(codes)\n\t\t\t\t.map(([key, code]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\t(s: string) => `${code}${s}${codes.reset}`,\n\t\t\t\t])\n\t\t)\n\t),\n\t...colorFns(),\n}\n\n", "\ndeclare const Deno: any\n\nexport function isDeno() {\n\treturn typeof Deno !== \"undefined\" && typeof Deno.version !== \"undefined\"\n}\n\nexport function isNode() {\n\treturn (\n\t\ttypeof process !== \"undefined\" &&\n\t\tprocess.versions &&\n\t\tprocess.versions.node\n\t)\n}\n\nexport function isColorSupported() {\n\tif (isNode())\n\t\treturn (process.env.FORCE_COLOR) || (\n\t\t\tprocess.stdout.isTTY &&\n\t\t\tprocess.env.TERM !== \"dumb\"\n\t\t)\n\n\telse if (isDeno())\n\t\treturn (Deno.env.get(\"FORCE_COLOR\")) || (\n\t\t\tDeno.isatty(Deno.stdout.rid) &&\n\t\t\tDeno.env.get(\"TERM\") !== \"dumb\"\n\t\t)\n\n\telse\n\t\treturn false\n}\n\nexport function exit(code: number) {\n\tif (isNode())\n\t\tprocess.exit(code)\n\telse if (isDeno())\n\t\tDeno.exit(code)\n}\n\nexport function hasEnv(name: string): boolean {\n\tif (isNode())\n\t\treturn name in process.env\n\telse if (isDeno())\n\t\treturn Deno.env.get(name) !== undefined\n\treturn false\n}\n\nexport function hasArg(arg: string): boolean {\n\tif (isNode())\n\t\treturn process.argv.slice(1).includes(arg)\n\telse if (isDeno())\n\t\treturn Deno.args.includes(arg)\n\telse\n\t\treturn false\n}\n\nfunction findArgValue(name: string, args: string[]) {\n\tfor (const arg of args) {\n\t\tif (arg.includes(\"=\")) {\n\t\t\tconst [first, ...rest] = arg.split(\"=\")\n\t\t\tif (first === name)\n\t\t\t\treturn rest.join(\"=\")\n\t\t}\n\t}\n}\n\nexport function getArg(name: string) {\n\tif (isNode())\n\t\treturn findArgValue(name, process.argv.slice(1))\n\telse if (isDeno())\n\t\treturn findArgValue(name, Deno.args)\n}\n\nexport function getEnv(name: string): string | undefined {\n\tif (isNode())\n\t\treturn process.env[name]\n\telse if (isDeno())\n\t\treturn Deno.env.get(name)\n}\n\nexport async function writeStdout(line: string) {\n\tif (isNode())\n\t\tprocess.stdout.write(line + \"\\n\")\n\telse if (isDeno())\n\t\tawait Deno.stdout.write(new TextEncoder().encode(line + \"\\n\"))\n\telse\n\t\tconsole.log(line)\n}\n\nexport async function writeStderr(line: string) {\n\tif (isNode())\n\t\tprocess.stderr.write(line + \"\\n\")\n\telse if (isDeno())\n\t\tawait Deno.stderr.write(new TextEncoder().encode(line + \"\\n\"))\n\telse\n\t\tconsole.error(line)\n}\n\n", "\nimport {colorless} from \"./colorless.js\"\nimport {colorful, Colors} from \"./colorful.js\"\nimport {isColorSupported} from \"../utils/supports.js\"\n\nexport const autoColors = (): Colors => {\n\treturn isColorSupported()\n\t\t? colorful\n\t\t: colorless\n}\n\n", "\nimport {Shaper} from \"./shaper.js\"\n\nexport const errorsShaper = (): Shaper => ({colors, theme}) => {\n\tconst palette = theme(colors)\n\n\tfunction errstring(error: Error) {\n\t\tconst stack = error.stack\n\t\t\t? \"\\n\" + error.stack + \"\\n\"\n\t\t\t: \"\"\n\t\treturn [\n\t\t\tpalette.errName(error.name + \":\"),\n\t\t\tpalette.errMessage(error.message),\n\t\t].join(\" \") + palette.errStack(stack)\n\t}\n\n\tfunction processErrors(item: any) {\n\t\treturn (item && item instanceof Error)\n\t\t\t? errstring(item)\n\t\t\t: item\n\t}\n\n\tfunction processAll(item: any) {\n\t\treturn (item && item instanceof Error)\n\t\t\t? errstring(item)\n\t\t\t: palette.errMessage(item)\n\t}\n\n\treturn {\n\t\tstdout: items => items.map(processErrors),\n\t\tstderr: items => items.map(processAll),\n\t}\n}\n\n", "\nimport {Theme} from \"../themes/theme.js\"\nimport {Colors} from \"../colors/colorful.js\"\n\nexport type ShaperContext = {\n\tcolors: Colors\n\ttheme: Theme\n}\n\nexport type Shaper = (context: ShaperContext) => ShaperFns\n\nexport type ShaperFns = {\n\tstdout: (items: any[]) => any[]\n\tstderr: (items: any[]) => any[]\n}\n\nexport function asShaper(shaper: Shaper) {\n\treturn shaper\n}\n\nexport function combineShapers(...shapers: Shaper[]): Shaper {\n\treturn context => ({\n\t\tstdout: items => {\n\t\t\tfor (const shaper of shapers)\n\t\t\t\titems = shaper(context).stdout(items)\n\t\t\treturn items\n\t\t},\n\t\tstderr: items => {\n\t\t\tfor (const shaper of shapers)\n\t\t\t\titems = shaper(context).stderr(items)\n\t\t\treturn items\n\t\t},\n\t})\n}\n\n", "\nimport {Shaper} from \"./shaper.js\"\n\nexport type TimestampOptions = {\n\ticon: string | undefined\n\tnow: () => number\n}\n\nfunction defaultTimestampOptions(): TimestampOptions {\n\treturn {\n\t\ticon: \"\uD83D\uDEA8\",\n\t\tnow: () => Date.now(),\n\t}\n}\n\nexport const timestampShaper = (options?: Partial<TimestampOptions>): Shaper => ({colors, theme}) => {\n\tconst opts = {...defaultTimestampOptions(), ...options}\n\tconst palette = theme(colors)\n\n\tconst date = new Date(opts.now())\n\n\tconst year = date.getUTCFullYear().toString().padStart(4, \"0\")\n\tconst month = (date.getUTCMonth() + 1).toString().padStart(2, \"0\")\n\tconst day = date.getUTCDate().toString().padStart(2, \"0\")\n\tconst calendar = `${year}-${month}-${day}`\n\n\tconst hour = date.getUTCHours().toString().padStart(2, \"0\")\n\tconst minute = date.getUTCMinutes().toString().padStart(2, \"0\")\n\tconst second = date.getUTCSeconds().toString().padStart(2, \"0\")\n\tconst milliseconds = date.getUTCMilliseconds().toString().padStart(3, \"0\")\n\tconst clock = `${hour}:${minute}:${second}.${milliseconds}`\n\n\tconst stamp = `${calendar}::${clock}`\n\n\treturn {\n\t\tstdout: items => [\n\t\t\tpalette.timestamp(stamp),\n\t\t\t...items,\n\t\t],\n\t\tstderr: items => [\n\t\t\tpalette.timestampErr(stamp),\n\t\t\t...[opts.icon].filter(Boolean),\n\t\t\t...items,\n\t\t],\n\t}\n}\n\n", "\nimport {errorsShaper} from \"./errors.js\"\nimport {combineShapers} from \"./shaper.js\"\nimport {timestampShaper} from \"./timestamp.js\"\n\nexport function autoShaper() {\n\treturn combineShapers(\n\t\terrorsShaper(),\n\t\ttimestampShaper(),\n\t)\n}\n\n", "\nimport {Writer} from \"./writer.js\"\n\ndeclare const Deno: any\n\nexport const denoWriter = (): Writer => ({\n\tstdout: async line => {\n\t\tawait Deno.stdout.write(new TextEncoder().encode(line + \"\\n\"))\n\t},\n\tstderr: async line => {\n\t\tawait Deno.stderr.write(new TextEncoder().encode(line + \"\\n\"))\n\t},\n})\n\n", "\nimport {Writer} from \"./writer.js\"\n\nexport const nodeWriter = (): Writer => ({\n\tstdout: async(line: string) => void process.stdout.write(line + \"\\n\"),\n\tstderr: async(line: string) => void process.stderr.write(line + \"\\n\"),\n})\n\n", "\nimport {Writer} from \"./writer.js\"\n\nexport const consoleWriter = (): Writer => ({\n\tstdout: async line => console.log(line),\n\tstderr: async line => console.error(line),\n})\n\n", "\nimport {Writer} from \"./writer.js\"\nimport {denoWriter} from \"./deno.js\"\nimport {nodeWriter} from \"./node.js\"\nimport {consoleWriter} from \"./console.js\"\nimport {isDeno, isNode} from \"../utils/supports.js\"\n\nexport const autoWriter = (): Writer => {\n\tif (isDeno()) return denoWriter()\n\telse if (isNode()) return nodeWriter()\n\telse return consoleWriter()\n}\n\n", "\nimport {Writer} from \"./writer.js\"\n\nexport const voidWriter = (): Writer => ({\n\tstdout: async() => undefined,\n\tstderr: async() => undefined,\n})\n\n", "\nimport {Shaper} from \"./shaper.js\"\n\nexport function noneShaper(): Shaper {\n\treturn () => ({\n\t\tstdout: items => items,\n\t\tstderr: items => items,\n\t})\n}\n\n", "\nimport {Theme} from \"./themes/theme.js\"\nimport {Writer} from \"./writers/writer.js\"\nimport {autoTheme} from \"./themes/auto.js\"\nimport {autoColors} from \"./colors/auto.js\"\nimport {autoShaper} from \"./shapers/auto.js\"\nimport {autoWriter} from \"./writers/auto.js\"\nimport {basicTheme} from \"./themes/basic.js\"\nimport {denoWriter} from \"./writers/deno.js\"\nimport {nodeWriter} from \"./writers/node.js\"\nimport {voidWriter} from \"./writers/void.js\"\nimport {noneShaper} from \"./shapers/none.js\"\nimport {colorless} from \"./colors/colorless.js\"\nimport {errorsShaper} from \"./shapers/errors.js\"\nimport {consoleWriter} from \"./writers/console.js\"\nimport {colorful, Colors} from \"./colors/colorful.js\"\nimport {timestampShaper} from \"./shapers/timestamp.js\"\nimport {combineShapers, Shaper} from \"./shapers/shaper.js\"\n\nexport class Logger {\n\tstatic writers = {\n\t\tauto: autoWriter,\n\t\tvoid: voidWriter,\n\t\tdeno: denoWriter,\n\t\tnode: nodeWriter,\n\t\tconsole: consoleWriter,\n\t}\n\n\tstatic colors = {\n\t\tauto: autoColors,\n\t\tcolorful: () => colorful,\n\t\tcolorless: () => colorless,\n\t}\n\n\tstatic themes = {\n\t\tauto: autoTheme,\n\t\tbasic: basicTheme,\n\t}\n\n\tstatic shapers = {\n\t\tauto: autoShaper,\n\t\tnone: noneShaper,\n\t\terrors: errorsShaper,\n\t\ttimestamp: timestampShaper,\n\t}\n\n\twriter: Writer = Logger.writers.auto()\n\tcolors: Colors = Logger.colors.auto()\n\ttheme: Theme = Logger.themes.auto()\n\tshaper: Shaper = Logger.shapers.auto()\n\n\tasync log(...items: any[]) {\n\t\tawait this.writer.stdout(\n\t\t\tthis.shaper(this).stdout(items).join(\" \")\n\t\t)\n\t}\n\n\tasync error(...items: any[]) {\n\t\tawait this.writer.stderr(\n\t\t\tthis.shaper(this).stderr(items).join(\" \")\n\t\t)\n\t}\n\n\tsetWriter(writer: Writer) {\n\t\tthis.writer = writer\n\t\treturn this\n\t}\n\n\tsetColors(colors: Colors) {\n\t\tthis.colors = colors\n\t\treturn this\n\t}\n\n\tsetTheme(theme: Theme) {\n\t\tthis.theme = theme\n\t\treturn this\n\t}\n\n\tsetShaper(...shapers: Shaper[]) {\n\t\tthis.shaper = combineShapers(...shapers)\n\t\treturn this\n\t}\n}\n\n", "\nimport {Logger} from \"@e280/sten\"\nimport {Tap, HttpMeta, TapContext} from \"../types.js\"\n\nexport class LoggerTap extends Logger implements Tap {\n\tstatic dummy() {\n\t\treturn new this().setWriter(Logger.writers.void())\n\t}\n\n\trpcRequest: Tap[\"rpcRequest\"] = async({request, ...context}) => {\n\t\tconst g = this.colors.none\n\t\tthis.log(\n\t\t\t...this.#context(context),\n\t\t\tg(`${request.method}()`),\n\t\t)\n\t}\n\n\trpcError: Tap[\"rpcError\"] = async({request, error, ...context}) => {\n\t\tthis.error(\n\t\t\t...this.#context(context),\n\t\t\t`${request.method}()`,\n\t\t\terror,\n\t\t)\n\t}\n\n\t#context({meta, label, remote}: TapContext) {\n\t\tconst cRemote = this.colors.mix(this.colors.blue, this.colors.dim)\n\t\tconst cLocal = this.colors.mix(this.colors.cyan, this.colors.dim)\n\t\treturn [\n\t\t\tmeta\n\t\t\t\t? this.#meta(meta)\n\t\t\t\t: undefined,\n\t\t\tlabel\n\t\t\t\t? label\n\t\t\t\t: undefined,\n\t\t\tremote === undefined\n\t\t\t\t? undefined\n\t\t\t\t: remote\n\t\t\t\t\t? cRemote(\"<-\")\n\t\t\t\t\t: cLocal(\"->\"),\n\t\t].filter(Boolean)\n\t}\n\n\t#meta(meta: HttpMeta) {\n\t\tconst {headers} = meta.request\n\t\treturn [\n\t\t\tthis.colors.yellow(`[${meta.ip}]`),\n\t\t\tthis.colors.green(headers.origin ?headers.origin :\"(no-origin)\"),\n\t\t].join(\" \")\n\t}\n}\n\n", "\nimport {Tap} from \"../types.js\"\nimport {LoggerTap} from \"./logger.js\"\n\nexport class ErrorTap extends LoggerTap implements Tap {\n\trpcRequest: Tap[\"rpcRequest\"] = async() => {}\n}\n\n", "\nexport const Bytes = Object.freeze({\n\teq(a: Uint8Array, b: Uint8Array) {\n\t\tif (a.length !== b.length)\n\t\t\treturn false\n\t\tfor (let i = 0; i <= a.length; i++) {\n\t\t\tif (a.at(i) !== b.at(i))\n\t\t\t\treturn false\n\t\t}\n\t\treturn true\n\t},\n\n\trandom(count: number) {\n\t\treturn crypto.getRandomValues(new Uint8Array(count))\n\t},\n})\n\n", "\n/*\n\n256-bit hex ids look like this:\n\n\t8ff8dfbc7c994c5439d2dd327b9898aa6796f97fb396e262985f03f868707e32\n\t6b99284a2c4a1c5f101502bd009f9fb592ca4427e4375155e411ddd07ed9da6b\n\t2eb73fb00a2b9e38c855b5aa353b530d820a3a2dcea5013b7e4e277ddfe9d0ad\n\n*/\n\nimport {Bytes} from \"./bytes.js\"\n\nexport const Hex = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\treturn [...bytes]\n\t\t\t.map(byte => byte.toString(16).padStart(2, \"0\"))\n\t\t\t.join(\"\")\n\t},\n\n\ttoBytes(string: string) {\n\t\tif (string.length % 2 !== 0)\n\t\t\tthrow new Error(\"must have even number of hex characters\")\n\t\tconst bytes = new Uint8Array(string.length / 2)\n\t\tfor (let i = 0; i < string.length; i += 2)\n\t\t\tbytes[i / 2] = parseInt(string.slice(i, i + 2), 16)\n\t\treturn bytes\n\t},\n\n\t/** generate a random hex string. byteCount defaults to 32. */\n\trandom(byteCount = 32) {\n\t\treturn this.fromBytes(Bytes.random(byteCount))\n\t},\n\n\t/** @deprecated renamed to `fromBytes` */\n\tstring(bytes: Uint8Array) {\n\t\treturn Hex.fromBytes(bytes)\n\t},\n\n\t/** @deprecated renamed to `toBytes` */\n\tbytes(string: string) {\n\t\treturn Hex.toBytes(string)\n\t},\n})\n\n", "\n/*\n\n256-bit base58 ids look like this:\n\n\t9X1D9rdkDgRdykzmogNcxfopRc7TnbS869ow1E2ehCFS\n\tAmRKyNfq6jhhsd9qda1Y6rAVS2NLUqyTUvfcB2wUiiAC\n\t8skYcqBAXsejDcJzsZMo19PErt43DHP3bykaXBtMvdu\n\n*/\n\nimport {Hex} from \"./hex.js\"\nimport {Bytes} from \"./bytes.js\"\n\nconst base = 58\nconst characters = \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\"\n\nexport const Base58 = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\tlet intVal = BigInt(\"0x\" + Hex.fromBytes(bytes))\n\t\tlet encoded = \"\"\n\n\t\twhile (intVal > 0) {\n\t\t\tconst remainder = intVal % BigInt(base)\n\t\t\tintVal = intVal / BigInt(base)\n\t\t\tencoded = characters[Number(remainder)] + encoded\n\t\t}\n\n\t\tfor (const byte of bytes) {\n\t\t\tif (byte === 0) encoded = characters[0] + encoded\n\t\t\telse break\n\t\t}\n\n\t\treturn encoded\n\t},\n\n\ttoBytes(string: string) {\n\t\tlet intVal = BigInt(0)\n\n\t\tfor (const char of string) {\n\t\t\tconst index = characters.indexOf(char)\n\t\t\tif (index === -1) throw new Error(`Invalid character '${char}' in base58 string`)\n\t\t\tintVal = intVal * BigInt(base) + BigInt(index)\n\t\t}\n\n\t\tlet hex = intVal.toString(16)\n\t\tif (hex.length % 2 !== 0) hex = \"0\" + hex\n\t\tconst bytes = Hex.toBytes(hex)\n\n\t\tlet leadingZeroes = 0\n\t\tfor (const char of string) {\n\t\t\tif (char === characters[0]) leadingZeroes++\n\t\t\telse break\n\t\t}\n\n\t\tconst decoded = new Uint8Array(leadingZeroes + bytes.length)\n\t\tdecoded.set(bytes, leadingZeroes)\n\t\treturn decoded\n\t},\n\n\trandom(count = 32) {\n\t\treturn this.fromBytes(Bytes.random(count))\n\t},\n\n\t/** @deprecated renamed to `fromBytes` */\n\tstring(bytes: Uint8Array) {\n\t\treturn Base58.fromBytes(bytes)\n\t},\n\n\t/** @deprecated renamed to `toBytes` */\n\tbytes(string: string) {\n\t\treturn Base58.toBytes(string)\n\t},\n})\n\n", "\nimport {Bytes} from \"./bytes.js\"\n\nexport type Lexicon = {\n\tcharacters: string\n\tnegativePrefix?: string\n\tpadding?: {\n\t\tcharacter: string\n\t\tsize: number\n\t}\n}\n\nexport class BaseX {\n\tstatic lexicons = Object.freeze({\n\t\tbase2: {characters: \"01\"},\n\t\thex: {characters: \"0123456789abcdef\"},\n\t\tbase36: {characters: \"0123456789abcdefghijklmnopqrstuvwxyz\"},\n\t\tbase58: {characters: \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\"},\n\t\tbase62: {characters: \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\"},\n\t\tbase64url: {\n\t\t\tnegativePrefix: \"~\",\n\t\t\tcharacters: \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\",\n\t\t},\n\t\tbase64: {\n\t\t\tcharacters: \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",\n\t\t\tpadding: {character: \"=\", size: 4},\n\t\t},\n\t})\n\n\tprivate lookup: Record<string, number>\n\tprivate negativePrefix: string\n\n\tconstructor(public lexicon: Lexicon) {\n\t\tthis.lookup = Object.fromEntries(\n\t\t\t[...lexicon.characters].map((char, i) => [char, i])\n\t\t)\n\t\tthis.negativePrefix = lexicon.negativePrefix ?? \"-\"\n\t}\n\n\ttoBytes(s: string): Uint8Array {\n\t\tconst bitsPerChar = Math.log2(this.lexicon.characters.length)\n\t\tif (Number.isInteger(bitsPerChar)) {\n\t\t\t// Bitstream mode (for power-of-2 lexicons)\n\t\t\tlet bitBuffer = 0\n\t\t\tlet bitCount = 0\n\t\t\tconst output: number[] = []\n\n\t\t\tfor (const char of s) {\n\t\t\t\tif (char === this.lexicon.padding?.character) continue\n\t\t\t\tconst val = this.lookup[char]\n\t\t\t\tif (val === undefined) throw new Error(`Invalid character: ${char}`)\n\t\t\t\tbitBuffer = (bitBuffer << bitsPerChar) | val\n\t\t\t\tbitCount += bitsPerChar\n\n\t\t\t\twhile (bitCount >= 8) {\n\t\t\t\t\tbitCount -= 8\n\t\t\t\t\toutput.push((bitBuffer >> bitCount) & 0xFF)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn new Uint8Array(output)\n\t\t}\n\n\t\t// Radix mode fallback\n\t\tlet num = 0n\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tlet negative = false\n\t\tif (s.startsWith(this.negativePrefix)) {\n\t\t\ts = s.slice(this.negativePrefix.length)\n\t\t\tnegative = true\n\t\t}\n\t\tfor (const char of s) {\n\t\t\tconst val = this.lookup[char]\n\t\t\tif (val === undefined) throw new Error(`Invalid character: ${char}`)\n\t\t\tnum = num * base + BigInt(val)\n\t\t}\n\t\tconst out: number[] = []\n\t\twhile (num > 0n) {\n\t\t\tout.unshift(Number(num % 256n))\n\t\t\tnum = num / 256n\n\t\t}\n\t\treturn new Uint8Array(out)\n\t}\n\n\tfromBytes(bytes: Uint8Array): string {\n\t\tconst bitsPerChar = Math.log2(this.lexicon.characters.length)\n\t\tif (Number.isInteger(bitsPerChar)) {\n\t\t\t// Bitstream mode (for power-of-2 lexicons)\n\t\t\tlet bitBuffer = 0\n\t\t\tlet bitCount = 0\n\t\t\tlet out = \"\"\n\n\t\t\tfor (const byte of bytes) {\n\t\t\t\tbitBuffer = (bitBuffer << 8) | byte\n\t\t\t\tbitCount += 8\n\n\t\t\t\twhile (bitCount >= bitsPerChar) {\n\t\t\t\t\tbitCount -= bitsPerChar\n\t\t\t\t\tconst index = (bitBuffer >> bitCount) & ((1 << bitsPerChar) - 1)\n\t\t\t\t\tout += this.lexicon.characters[index]\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// \uD83E\uDE79 flush remaining bits\n\t\t\tif (bitCount > 0) {\n\t\t\t\tconst index = (bitBuffer << (bitsPerChar - bitCount)) & ((1 << bitsPerChar) - 1)\n\t\t\t\tout += this.lexicon.characters[index]\n\t\t\t}\n\n\t\t\t// Add padding if applicable\n\t\t\tif (this.lexicon.padding) {\n\t\t\t\twhile (out.length % this.lexicon.padding.size !== 0)\n\t\t\t\t\tout += this.lexicon.padding.character\n\t\t\t}\n\n\t\t\treturn out\n\t\t}\n\n\t\t// Radix mode fallback\n\t\tlet num = 0n\n\t\tfor (const byte of bytes)\n\t\t\tnum = (num << 8n) + BigInt(byte)\n\n\t\tif (num === 0n) return this.lexicon.characters[0]\n\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tlet out = \"\"\n\t\twhile (num > 0n) {\n\t\t\tout = this.lexicon.characters[Number(num % base)] + out\n\t\t\tnum = num / base\n\t\t}\n\t\treturn out\n\t}\n\n\ttoInteger(s: string) {\n\t\tif (!s) return 0\n\t\tlet n = 0n\n\t\tlet negative = false\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tif (s.startsWith(this.negativePrefix)) {\n\t\t\ts = s.slice(this.negativePrefix.length)\n\t\t\tnegative = true\n\t\t}\n\t\tfor (const char of s) {\n\t\t\tconst value = this.lookup[char]\n\t\t\tif (value === undefined) throw new Error(`Invalid character: ${char}`)\n\t\t\tn = n * base + BigInt(value)\n\t\t}\n\t\treturn Number(negative ? -n : n)\n\t}\n\n\tfromInteger(n: number) {\n\t\tn = Math.floor(n)\n\t\tconst negative = n < 0\n\t\tlet num = BigInt(negative ? -n : n)\n\t\tif (num === 0n) return this.lexicon.characters[0]\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tlet out = \"\"\n\t\twhile (num > 0n) {\n\t\t\tout = this.lexicon.characters[Number(num % base)] + out\n\t\t\tnum = num / base\n\t\t}\n\t\treturn negative ? `${this.negativePrefix}${out}` : out\n\t}\n\n\trandom(count = 32) {\n\t\treturn this.fromBytes(Bytes.random(count))\n\t}\n}\n\n", "\nimport {Bytes} from \"./bytes.js\"\n\nexport const Base64 = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\treturn (typeof btoa === \"function\")\n\t\t\t? btoa(String.fromCharCode(...bytes))\n\t\t\t: Buffer.from(bytes).toString(\"base64\")\n\t},\n\n\ttoBytes(string: string) {\n\t\treturn (typeof atob === \"function\")\n\t\t\t? Uint8Array.from(atob(string), char => char.charCodeAt(0))\n\t\t\t: Uint8Array.from(Buffer.from(string, \"base64\"))\n\t},\n\n\trandom(count = 32) {\n\t\treturn this.fromBytes(Bytes.random(count))\n\t},\n\n\t/** @deprecated rename to \"fromBytes\" */\n\tstring(bytes: Uint8Array) {\n\t\treturn Base64.fromBytes(bytes)\n\t},\n\n\t/** @deprecated rename to \"toBytes\" */\n\tbytes(string: string) {\n\t\treturn Base64.toBytes(string)\n\t},\n})\n\n", "\nexport const Txt = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\treturn new TextDecoder().decode(bytes)\n\t},\n\n\ttoBytes(string: string) {\n\t\treturn new TextEncoder().encode(string)\n\t},\n\n\t/** @deprecated renamed to `fromBytes` */\n\tstring(bytes: Uint8Array) {\n\t\treturn Txt.fromBytes(bytes)\n\t},\n\n\t/** @deprecated renamed to `toBytes` */\n\tbytes(string: string) {\n\t\treturn Txt.toBytes(string)\n\t},\n})\n\n", "\nexport const is = Object.freeze({\n\tset: <X>(x: X): x is NonNullable<X> =>\n\t\tx !== undefined && x !== null,\n\n\tunset: (x: any): x is (undefined | null) =>\n\t\tx === undefined || x === null,\n\n\tboolean: (x: any): x is boolean =>\n\t\ttypeof x === \"boolean\",\n\n\tnumber: (x: any): x is number =>\n\t\ttypeof x === \"number\",\n\n\tstring: (x: any): x is string =>\n\t\ttypeof x === \"string\",\n\n\tbigint: (x: any): x is bigint =>\n\t\ttypeof x === \"bigint\",\n\n\tobject: <X>(x: X): x is object & NonNullable<X> =>\n\t\ttypeof x === \"object\" && x !== null,\n\n\tarray: (x: any | any[]): x is any[] =>\n\t\tArray.isArray(x),\n\n\tfn: (x: any): x is (...a: any[]) => any =>\n\t\ttypeof x === \"function\",\n\n\tsymbol: (x: any): x is symbol =>\n\t\ttypeof x === \"symbol\",\n})\n\n", "\nexport class DeadlineError extends Error {\n\tname = this.constructor.name\n\tconstructor(public milliseconds: number) {\n\t\tsuper(`deadline exceeded (${(milliseconds / 1000).toFixed(1)} seconds)`)\n\t}\n}\n\n/** set a deadline for a fn to do something, will reject with a `DeadlineError` if it takes too long */\nexport function deadline<R>(milliseconds: number, fn: () => Promise<R>) {\n\tif (milliseconds <= 0 || milliseconds === Infinity)\n\t\treturn fn()\n\n\treturn new Promise<R>((resolve, reject) => {\n\t\tconst id = setTimeout(\n\t\t\t() => reject(new DeadlineError(milliseconds)),\n\t\t\tmilliseconds,\n\t\t)\n\t\tfn()\n\t\t\t.then(resolve)\n\t\t\t.catch(reject)\n\t\t\t.finally(() => clearTimeout(id))\n\t})\n}\n\n", "\n/** a promise which can be resolved from the outside */\nexport type Deferred<R = void> = {\n\tpromise: Promise<R>\n\tresolve: (result: R) => void\n\treject: (reason: any) => void\n\n\t/** ties the fate of this deferred promise to the outcome of the provided outsidePromise */\n\tentangle: (outsidePromise: Promise<R>) => Promise<R>\n}\n\n/** returns a deferred promise with exposed resolve and reject fns */\nexport function defer<R = void>(): Deferred<R> {\n\tlet resolve!: (result: R) => void\n\tlet reject!: (reason: any) => void\n\n\tconst promise = new Promise<R>((res, rej) => {\n\t\tresolve = res\n\t\treject = rej\n\t})\n\n\tfunction entangle(outside: Promise<R>) {\n\t\toutside.then(resolve).catch(reject)\n\t\treturn promise\n\t}\n\n\treturn {promise, resolve, reject, entangle}\n}\n\n", "\nimport {is} from \"./is.js\"\n\n/** return a value within an object tree, found at the given path. */\nexport function drill<xResult>(\n\t\tobject: {[key: string]: any},\n\t\tpath: string[],\n\t): xResult {\n\n\tlet current: any = object\n\n\tfor (const key of path) {\n\t\tcurrent = current[key]\n\t\tif (is.unset(current))\n\t\t\tbreak\n\t}\n\n\treturn current\n}\n\n", "\nexport function ob<Ob extends object>(o: Ob) {\n\treturn {\n\t\tmap: <Value>(transform: ObTransform<Ob, Value>) => (\n\t\t\tobMap(o, transform)\n\t\t),\n\t\tfilter: (predicate: ObPredicate<Ob>) => (\n\t\t\tobFilter(o, predicate)\n\t\t),\n\t}\n}\n\n////////////\n////////////\n\nob.pipe = Object.freeze({\n\tmap: <O extends {}, Value>(\n\t\t\ttransform: (value: O[keyof O], key: keyof O) => Value,\n\t\t) => (\n\t\t(o: O) => obMap(o, transform)\n\t),\n\tfilter: <O extends {}>(\n\t\t\ttransform: (value: O[keyof O], key: keyof O) => boolean,\n\t\t) => (\n\t\t(o: O) => obFilter(o, transform) as {[key: string]: O[keyof O]}\n\t),\n})\n\n////////////\n////////////\n\nexport type ObTransform<Ob extends object, Value> = (\n\t(value: Ob[keyof Ob], key: keyof Ob) => Value\n)\n\nexport type ObPredicate<Ob extends object> = (\n\t(value: Ob[keyof Ob], key: keyof Ob) => boolean\n)\n\n////////////\n////////////\n\nexport const obMap = <Ob extends object, Value>(\n\t\to: Ob,\n\t\ttransform: ObTransform<Ob, Value>,\n\t) => {\n\n\treturn Object.fromEntries(\n\t\tObject.entries(o).map(\n\t\t\t([key, value]: any) => [key, transform(value, key)]\n\t\t)\n\t) as {[P in keyof Ob]: Value}\n}\n\nexport const obFilter = <Ob extends object>(\n\t\to: Ob,\n\t\tpredicate: ObPredicate<Ob>,\n\t) => {\n\n\treturn Object.fromEntries(\n\t\tObject.entries(o).filter(\n\t\t\t([key, value]: any) => predicate(value, key)\n\t\t)\n\t) as {[P in keyof Ob]?: Ob[keyof Ob]}\n}\n\n", "\nimport {defer} from \"./defer.js\"\n\nexport type Listener<A extends any[]> = (...a: A) => (void | Promise<void>)\n\nexport interface Xub<A extends any[] = []> {\n\n\t/** publish to all subscribed listeners. */\n\tpub(...a: A): Promise<void>\n\n\t/** subscribe a listener function. */\n\tsub(fn: Listener<A>): () => void\n\n\t/**\n\t * subscribe a listener function.\n\t * @alias sub\n\t */\n\ton(fn: Listener<A>): () => void\n\n\t/** wait for the next published value */\n\tnext(): Promise<A>\n\n\t/** wipe all listeners attached to this. */\n\tclear(): void\n}\n\n/** subscriber fn that can be published to. */\nexport interface Sub<A extends any[] = []> extends Xub<A> {\n\t(fn: Listener<A>): () => void\n}\n\n/** publisher fn that can be published to. */\nexport interface Pub<A extends any[] = []> extends Xub<A> {\n\t(...a: A): Promise<void>\n}\n\nexport function xub<A extends any[] = []>() {\n\tconst set = new Set<Listener<A>>()\n\n\tfunction sub(fn: Listener<A>) {\n\t\tset.add(fn)\n\t\treturn () => { set.delete(fn) }\n\t}\n\n\tasync function pub(...a: A) {\n\t\tawait Promise.all([...set].map(fn => fn(...a)))\n\t}\n\n\tasync function next() {\n\t\tconst {promise, resolve} = defer<A>()\n\t\tconst unsubscribe = sub((...a) => {\n\t\t\tresolve(a)\n\t\t\tunsubscribe()\n\t\t})\n\t\treturn promise\n\t}\n\n\tfunction clear() {\n\t\tset.clear()\n\t}\n\n\tsub.pub = pub\n\tsub.sub = sub\n\tsub.on = sub\n\tsub.next = next\n\tsub.clear = clear\n\n\tpub.pub = pub\n\tpub.sub = sub\n\tpub.on = sub\n\tpub.next = next\n\tpub.clear = clear\n\n\treturn [pub, sub] as [Pub<A>, Sub<A>]\n}\n\n/** create a subscriber fn that can be published to */\nexport function sub<A extends any[] = []>(listener?: Listener<A>): Sub<A> {\n\tconst fn = xub<A>()[1]\n\tif (listener)\n\t\tfn.sub(listener)\n\treturn fn\n}\n\n/** create a publisher fn that can be subscribed to */\nexport function pub<A extends any[] = []>(listener?: Listener<A>): Pub<A> {\n\tconst fn = xub<A>()[0]\n\tif (listener)\n\t\tfn.sub(listener)\n\treturn fn\n}\n\n", "\n/** a trashcan where you can collect disposer fns, and dispose them all at once */\nexport class Trash {\n\t#fns: (() => void)[] = []\n\n\t/** add a disposer fn to the trashcan */\n\tadd(...fns: (() => void)[]) {\n\t\tthis.#fns.push(...fns)\n\t\treturn this\n\t}\n\n\t/** add a disposable object to the trashcan, and return the object */\n\tdisposable<X extends {dispose: () => void}>(x: X) {\n\t\treturn this.bag(x, () => x.dispose())\n\t}\n\n\t/** add an item's disposer fn, and return the item */\n\tbag<X>(x: X, fn: (x: X) => void) {\n\t\tthis.add(() => fn(x))\n\t\treturn x\n\t}\n\n\t/** dispose of everything in the trashcan */\n\tdispose() {\n\t\tfor (const fn of this.#fns.reverse())\n\t\t\tfn()\n\t\tthis.#fns = []\n\t}\n}\n\n", "\nexport namespace JsonRpc {\n\texport type Requestish = Request | Request[]\n\texport type Respondish = Response | Response[]\n\texport type Bidirectional = Requestish | Respondish\n\n\t/////////////////////////////////////////////////////////////\n\n\texport const version = \"2.0\"\n\n\texport type Request<P extends Params = any> = (\n\t\t| Query<P>\n\t\t| Notification<P>\n\t)\n\n\texport type Response<Result = any> = (\n\t\t| Success<Result>\n\t\t| Failure\n\t)\n\n\texport type Serializable = (\n\t\t| void\n\t\t| null\n\t\t| undefined\n\t\t| boolean\n\t\t| number\n\t\t| string\n\t\t| Serializable[]\n\t\t| {[key: string]: Serializable}\n\t)\n\n\t/////////////////////////////////////////////////////////////\n\n\texport type Id = number | string\n\texport type Params = Serializable[] | Record<string, Serializable>\n\n\texport type Notification<P extends Params> = {\n\t\tjsonrpc: string\n\t\tmethod: string\n\t\tparams: P\n\t}\n\n\texport type Query<P extends Params> = {\n\t\tid: Id\n\t\tjsonrpc: string\n\t\tmethod: string\n\t\tparams: P\n\t}\n\n\texport type Error = {\n\t\tcode: number\n\t\tmessage: string\n\t\tdata?: any\n\t}\n\n\texport type Success<Result> = {\n\t\tjsonrpc: \"2.0\"\n\t\tid: Id\n\t\tresult: Result\n\t}\n\n\texport type Failure = {\n\t\tjsonrpc: \"2.0\"\n\t\tid: Id\n\t\terror: Error\n\t}\n\n\t/////////////////////////////////////////////////////////////\n\n\texport function getId(request: Request): Id | null {\n\t\treturn \"id\" in request\n\t\t\t? request.id\n\t\t\t: null\n\t}\n\n\texport const errorCodes = {\n\t\tserverError: -32000,\n\t\tunexposedError: -32001,\n\t}\n}\n\n", "\n/**\n * An error that has a publicly viewable name and message.\n * - this error class, and its subclasses, are the only kinds of errors that renraku will send back to clients\n * - so if you want a client to be able to read an error message you throw, it must be a subclass of ExposedError\n */\nexport class ExposedError extends Error {\n\treadonly name = this.constructor.name\n}\n\n////////////////////////////////////////////////////\n\nexport class RemoteError extends Error {\n\treadonly name = this.constructor.name\n}\n\nexport class RemoteTimeoutError extends RemoteError {\n\treadonly name = this.constructor.name\n}\n\n////////////////////////////////////////////////////\n\nexport class HttpError extends Error {\n\treadonly name = this.constructor.name\n\treadonly code: number\n\n\tconstructor(code: number, message: string) {\n\t\tsuper(message)\n\t\tthis.code = code\n\t}\n}\n\n", "\nimport {Tap} from \"./types.js\"\nimport {JsonRpc} from \"./json-rpc.js\"\nimport {ExposedError} from \"./errors.js\"\n\nexport async function execute<R>({\n\t\ttap,\n\t\trequest,\n\t\taction,\n\t}: {\n\t\ttap: Tap\n\t\trequest: JsonRpc.Request\n\t\taction: () => Promise<R>\n\t}): Promise<JsonRpc.Response<R> | null> {\n\n\tconst id = JsonRpc.getId(request)\n\n\ttry {\n\t\tconst result = await action()\n\n\t\tif (id === null)\n\t\t\treturn null\n\n\t\treturn {\n\t\t\tid,\n\t\t\tresult,\n\t\t\tjsonrpc: JsonRpc.version,\n\t\t}\n\t}\n\n\tcatch (error) {\n\t\ttap.rpcError({request, error})\n\n\t\tif (id === null)\n\t\t\treturn null\n\n\t\treturn {\n\t\t\tid,\n\t\t\tjsonrpc: JsonRpc.version,\n\t\t\terror: (error instanceof ExposedError)\n\t\t\t\t? {\n\t\t\t\t\tcode: JsonRpc.errorCodes.serverError,\n\t\t\t\t\tmessage: error.message,\n\t\t\t\t}\n\t\t\t\t: {\n\t\t\t\t\tcode: JsonRpc.errorCodes.unexposedError,\n\t\t\t\t\tmessage: `unexposed error`,\n\t\t\t\t},\n\t\t}\n\t}\n}\n\n", "\nimport {drill} from \"@e280/stz\"\nimport {execute} from \"./execute.js\"\nimport {ErrorTap} from \"./taps/error.js\"\nimport {Endpoint, Fn, Fns, Tap} from \"./types.js\"\n\nexport type EndpointOptions<F extends Fns> = {\n\tfns: F\n\ttap?: Tap\n}\n\n/**\n * Create a renraku endpoint for your fns.\n * - an endpoint is a function that accepts json rpc requests\n * - for each request, it calls the appropriate fn\n * - it then returns the fn's in json rpc response format\n */\nexport function makeEndpoint<F extends Fns>(options: EndpointOptions<F>): Endpoint {\n\tconst tap = options.tap ?? new ErrorTap()\n\n\treturn async request => {\n\t\tconst path = request.method.split(\".\")\n\t\tconst fn = drill(options.fns, path) as Fn\n\t\tconst action = async() => await fn(...request.params)\n\n\t\ttap.rpcRequest({request})\n\n\t\tconst response = await execute({\n\t\t\ttap,\n\t\t\trequest,\n\t\t\taction,\n\t\t})\n\n\t\treturn response\n\t}\n}\n\n", "\nimport {Fn, Fns} from \"./types.js\"\n\nexport const tune = Symbol(\"tune\")\nexport const query = Symbol(\"query\")\nexport const notify = Symbol(\"notify\")\nexport const settings = Symbol(\"settings\")\n\nexport type TuneSymbol = typeof tune\nexport type QuerySymbol = typeof query\nexport type NotifySymbol = typeof notify\nexport type SettingsSymbol = typeof settings\n\nexport type Executor = (\n\tpath: string[],\n\targs: any[],\n\tsettings: Settings,\n) => Promise<any>\n\nexport type Settings = {\n\tnotify?: boolean\n\ttransfer?: Transferable[]\n}\n\nexport type Remote<F extends Fn | Fns> = (\n\tF extends Fn\n\t\t? F & {\n\t\t\t[tune]: (settings: Settings) => F\n\t\t\t[query]: F\n\t\t\t[notify]: F\n\t\t\t[settings]: Settings\n\t\t}\n\t\t: F extends Fns\n\t\t\t? {[K in keyof F]: Remote<F[K]>}\n\t\t\t: never\n)\n\nexport function remoteProxy<F extends Fns>(executor: Executor) {\n\n\tfunction recurse(path: string[]) {\n\t\tconst currentSettings: Settings = {notify: undefined}\n\n\t\treturn new Proxy((() => {}) as any, {\n\t\t\tapply: (_, _this, args) => {\n\t\t\t\treturn executor(path, args, currentSettings)\n\t\t\t},\n\t\t\tget: (target, key: string | QuerySymbol | NotifySymbol | TuneSymbol | SettingsSymbol) => {\n\n\t\t\t\tif (key === \"then\")\n\t\t\t\t\treturn undefined\n\n\t\t\t\tif (key === tune)\n\t\t\t\t\treturn (settings: Settings) => (...args: any[]) => executor(path, args, {\n\t\t\t\t\t\t...currentSettings,\n\t\t\t\t\t\t...settings,\n\t\t\t\t\t})\n\n\t\t\t\tif (key === notify)\n\t\t\t\t\treturn (...args: any[]) => executor(path, args, {\n\t\t\t\t\t\t...currentSettings,\n\t\t\t\t\t\tnotify: true,\n\t\t\t\t\t})\n\n\t\t\t\tif (key === query)\n\t\t\t\t\treturn (...args: any[]) => executor(path, args, {\n\t\t\t\t\t\t...currentSettings,\n\t\t\t\t\t\tnotify: false,\n\t\t\t\t\t})\n\n\t\t\t\tif (key === settings)\n\t\t\t\t\treturn currentSettings\n\n\t\t\t\tif (!target[key])\n\t\t\t\t\ttarget[key] = recurse([...path, key])\n\n\t\t\t\treturn target[key]\n\t\t\t},\n\t\t\tset: (target, key: string, value: any) => {\n\t\t\t\ttarget[key] = value\n\t\t\t\treturn true\n\t\t\t},\n\t\t})\n\t}\n\n\treturn recurse([]) as Remote<F>\n}\n\n", "\nimport {JsonRpc} from \"./json-rpc.js\"\nimport {RemoteError} from \"./errors.js\"\nimport {ErrorTap} from \"./taps/error.js\"\nimport {remoteProxy} from \"./remote-proxy.js\"\nimport {Endpoint, Fns, Tap} from \"./types.js\"\n\nexport type RemoteOptions = {\n\tendpoint: Endpoint\n\tlabel?: string\n\tnotify?: boolean\n\ttap?: Tap\n}\n\n/**\n * Create a renraku remote for the given endpoint.\n * - the remote uses js proxies to mirror the shape of your fns object\n * - so when you make async calls on the remote, it will convert those into json rpc requests that are actuated on the given endpoint\n * - the endpoint you provide could be making network calls, or doing something else, the remote doesn't care how the endpoint is implemented\n */\nexport function makeRemote<F extends Fns>(options: RemoteOptions) {\n\tconst {endpoint, tap = new ErrorTap()} = options\n\tlet id = 1\n\n\treturn remoteProxy<F>(async(\n\t\t\tpath,\n\t\t\tparams,\n\t\t\tsettings,\n\t\t) => {\n\n\t\tconst notify = settings.notify ?? options.notify ?? false\n\t\tconst transfer = settings.transfer\n\n\t\tconst base: JsonRpc.Notification<any[]> = {\n\t\t\tjsonrpc: \"2.0\" as const,\n\t\t\tmethod: path.join(\".\"),\n\t\t\tparams,\n\t\t}\n\n\t\tconst request: JsonRpc.Request = (\n\t\t\tnotify\n\t\t\t\t? base\n\t\t\t\t: {...base, id: id++}\n\t\t)\n\n\t\ttap.rpcRequest({request})\n\n\t\tconst response = await endpoint(request, {transfer})\n\n\t\tif (notify && !response)\n\t\t\treturn null\n\n\t\tif (!response)\n\t\t\tthrow new RemoteError(\"response was null, but shouldn't be, because the request was not a notification\")\n\n\t\tif (\"error\" in response)\n\t\t\tthrow new RemoteError(\n\t\t\t\toptions.label\n\t\t\t\t\t? `${options.label}: ${response.error.message}`\n\t\t\t\t\t: response.error.message\n\t\t\t)\n\n\t\treturn response.result\n\t})\n}\n\n", "\nimport {Fns} from \"./types.js\"\nimport {makeRemote} from \"./remote.js\"\nimport {Remote} from \"./remote-proxy.js\"\nimport {makeEndpoint, EndpointOptions} from \"./endpoint.js\"\n\n/**\n * Wrap your fns in an endpoint and remote.\n * - this gives you a real renraku remote where you can use the `tune` symbol and such\n * - this is useful for when you have special logic that relies on that special renraku functionality\n */\nexport function makeMock<F extends Fns>(options: EndpointOptions<F>): Remote<F> {\n\treturn makeRemote<F>({endpoint: makeEndpoint(options), tap: options.tap})\n}\n\n", "\nimport {pub} from \"@e280/stz\"\nimport {JsonRpc} from \"../../../core/json-rpc.js\"\n\nexport class Conduit {\n\trecv = pub<[incoming: JsonRpc.Bidirectional, {origin: string}]>()\n\tsendRequest = pub<[request: JsonRpc.Requestish, transfer: Transferable[] | undefined]>()\n\tsendResponse = pub<[response: JsonRpc.Respondish, transfer: Transferable[] | undefined]>()\n\n\tstatic makeEntangledPair({origin = \"example.e280.org\"}: {origin?: string} = {}) {\n\t\tconst a = new this()\n\t\tconst b = new this()\n\n\t\tconst disposers = [\n\t\t\ta.sendRequest.sub(data => b.recv(data, {origin})),\n\t\t\ta.sendResponse.sub(data => b.recv(data, {origin})),\n\t\t\tb.sendRequest.sub(data => a.recv(data, {origin})),\n\t\t\tb.sendResponse.sub(data => a.recv(data, {origin})),\n\t\t]\n\n\t\tconst dispose = () => disposers.forEach(fn => fn())\n\t\treturn [a, b, dispose] as [Conduit, Conduit, () => void]\n\t}\n}\n\n", "\nimport {defer} from \"@e280/stz\"\nimport {Endpoint} from \"../../../core/types.js\"\nimport {JsonRpc} from \"../../../core/json-rpc.js\"\nimport {Channel, ChannelMessage} from \"../types.js\"\nimport {ResponseWaiter} from \"./response-waiter.js\"\n\nexport function onMessage(channel: Channel, fn: (e: ChannelMessage) => void) {\n\tchannel.addEventListener(\"message\", fn)\n\treturn () => channel.removeEventListener(\"message\", fn)\n}\n\n////////////////\n\nexport type SendRequestFn = (\n\trequest: JsonRpc.Request,\n\ttransfer: Transferable[] | undefined,\n\tdone: Promise<JsonRpc.Response | null>,\n) => void\n\nexport function makeRemoteEndpoint(waiter: ResponseWaiter, sendRequest: SendRequestFn): Endpoint {\n\treturn async(request, {transfer} = {}) => {\n\t\tif (\"id\" in request) {\n\t\t\tconst done = defer<JsonRpc.Response | null>()\n\t\t\tsendRequest(request, transfer, done.promise)\n\t\t\treturn waiter.wait(request.id, request.method).then(response => {\n\t\t\t\tdone.resolve(response)\n\t\t\t\treturn response\n\t\t\t})\n\t\t}\n\t\telse {\n\t\t\tconst done = Promise.resolve(null)\n\t\t\tsendRequest(request, transfer, done)\n\t\t\treturn done\n\t\t}\n\t}\n}\n\nexport function interpretIncoming(json: JsonRpc.Bidirectional) {\n\tconst requests: JsonRpc.Request[] = []\n\tconst responses: JsonRpc.Response[] = []\n\n\tfor (const item of (Array.isArray(json) ? json : [json])) {\n\t\tif (\"method\" in item) requests.push(item)\n\t\telse responses.push(item)\n\t}\n\n\treturn {requests, responses}\n}\n\nexport async function handleIncomingRequests(\n\t\tlocalEndpoint: Endpoint,\n\t\trequests: JsonRpc.Request[],\n\t): Promise<JsonRpc.Respondish | null> {\n\n\tconst responses = (\n\t\tawait Promise.all(\n\t\t\trequests.map(async request => localEndpoint(request))\n\t\t)\n\t).filter(r => r !== null)\n\n\tif (responses.length === 0)\n\t\treturn null\n\n\treturn (responses.length === 1)\n\t\t? responses[0]\n\t\t: responses\n}\n\nexport function handleIncomingResponses(\n\t\twaiter: ResponseWaiter,\n\t\tresponses: JsonRpc.Response[],\n\t) {\n\n\tfor (const response of responses)\n\t\twaiter.deliverResponse(response)\n}\n\n", "\nimport {Trash} from \"@e280/stz\"\nimport {Conduit} from \"./conduit.js\"\nimport {PostableChannel} from \"../types.js\"\nimport {onMessage} from \"../parts/helpers.js\"\n\nexport class PostableConduit extends Conduit {\n\t#trash = new Trash()\n\n\tconstructor(channel: PostableChannel) {\n\t\tsuper()\n\t\tthis.#trash.add(\n\t\t\tthis.sendRequest.sub((m, transfer) => channel.postMessage(m, transfer)),\n\t\t\tthis.sendResponse.sub((m, transfer) => channel.postMessage(m, transfer)),\n\t\t\tonMessage(channel, e => this.recv(e.data, e)),\n\t\t)\n\t}\n\n\tdispose() {\n\t\tthis.#trash.dispose()\n\t}\n}\n\n", "\nimport {Fns} from \"../../../core/types.js\"\nimport {Remote} from \"../../../core/remote-proxy.js\"\n\nexport class MessengerMeta<RemoteFns extends Fns> {\n\ttransfer: Transferable[] | undefined\n\n\tconstructor(public remote: Remote<RemoteFns>) {}\n}\n\n", "\nexport const defaults = Object.freeze({\n\ttimeout: 60_000,\n\tmaxRequestBytes: 10_000_000,\n})\n\n", "\nimport {deadline, DeadlineError, defer, Deferred} from \"@e280/stz\"\n\nimport {JsonRpc} from \"../../../core/json-rpc.js\"\nimport {RemoteError} from \"../../../core/errors.js\"\n\ntype Pend = {\n\tmethod: string\n\tdeferred: Deferred<JsonRpc.Response>\n}\n\nexport class ResponseWaiter {\n\tpending = new Map<JsonRpc.Id, Pend>()\n\n\tconstructor(public timeout: number) {}\n\n\tasync wait(id: JsonRpc.Id, method: string) {\n\t\tconst deferred = defer<JsonRpc.Response>()\n\t\tthis.pending.set(id, {method, deferred})\n\t\treturn await deadline(this.timeout, () => deferred.promise)\n\t\t\t.catch(error => {\n\t\t\t\tif (error instanceof DeadlineError)\n\t\t\t\t\terror.message = `request #${id} ${method}(), ${error.message}`\n\t\t\t\tthrow error\n\t\t\t})\n\t}\n\n\tdeliverResponse(response: JsonRpc.Response) {\n\t\tconst pend = this.pending.get(response.id)\n\t\tif (pend) {\n\t\t\tif (\"error\" in response)\n\t\t\t\tpend.deferred.reject(new RemoteError(response.error.message))\n\t\t\telse\n\t\t\t\tpend.deferred.resolve(response)\n\t\t}\n\t}\n}\n\n", "\nimport {Trash} from \"@e280/stz\"\n\nimport {defaults} from \"../../defaults.js\"\nimport {MessengerOptions} from \"./types.js\"\nimport {MessengerMeta} from \"./parts/meta.js\"\nimport {JsonRpc} from \"../../core/json-rpc.js\"\nimport {bindTap} from \"../../core/taps/bind.js\"\nimport {makeRemote} from \"../../core/remote.js\"\nimport {Remote} from \"../../core/remote-proxy.js\"\nimport {Endpoint, Fns} from \"../../core/types.js\"\nimport {makeEndpoint} from \"../../core/endpoint.js\"\nimport {ResponseWaiter} from \"./parts/response-waiter.js\"\nimport {handleIncomingRequests, interpretIncoming, makeRemoteEndpoint} from \"./parts/helpers.js\"\n\n/**\n * Establish a renraku remote that communicates over the given conduit.\n * - supports two-way or one-way communication\n * - you can use a messenger to call a remote messenger\n * - you can use a messenger to respond to incoming requests\n */\nexport class Messenger<LocalFns extends Fns = any, RemoteFns extends Fns = any> {\n\tremote: Remote<RemoteFns>\n\tremoteEndpoint: Endpoint\n\n\t#waiter: ResponseWaiter\n\t#trash = new Trash()\n\n\tconstructor(private options: MessengerOptions<LocalFns, RemoteFns>) {\n\t\tconst {conduit, tap} = options\n\n\t\tthis.#waiter = new ResponseWaiter(options.timeout ?? defaults.timeout)\n\n\t\tthis.remoteEndpoint = makeRemoteEndpoint(\n\t\t\tthis.#waiter,\n\t\t\tconduit.sendRequest.pub.bind(conduit.sendRequest),\n\t\t)\n\n\t\tthis.remote = makeRemote<RemoteFns>({\n\t\t\tendpoint: this.remoteEndpoint,\n\t\t\ttap: tap && bindTap(tap, {remote: true}),\n\t\t})\n\n\t\tthis.#trash.add(conduit.recv.sub(m => this.recv(m)))\n\t}\n\n\tasync recv(incoming: JsonRpc.Bidirectional) {\n\t\tconst meta = new MessengerMeta<RemoteFns>(this.remote)\n\t\tconst {conduit, rpc, tap} = this.options\n\n\t\tconst {requests, responses} = interpretIncoming(incoming)\n\n\t\tfor (const response of responses)\n\t\t\tthis.#waiter.deliverResponse(response)\n\n\t\tif (!rpc)\n\t\t\treturn\n\n\t\tconst fns = await rpc(meta)\n\t\tconst endpoint = makeEndpoint({\n\t\t\tfns,\n\t\t\ttap: tap && bindTap(tap, {remote: false}),\n\t\t})\n\n\t\tconst outgoing = await handleIncomingRequests(endpoint, requests)\n\t\tif (outgoing)\n\t\t\tawait conduit.sendResponse(outgoing, meta.transfer)\n\t}\n\n\tdispose() {\n\t\tthis.#trash.dispose()\n\t}\n}\n\n", "\nimport {MessengerMeta, Remote} from \"@e280/renraku\"\nimport {MinistryFns, Schematic} from \"./types.js\"\n\nexport type HostShell<S extends Schematic> = {\n\thost: Remote<S[\"host\"]>\n\ttransfer: Transferable[] | undefined\n}\n\nexport type WorkShell<S extends Schematic> = {\n\twork: Remote<S[\"work\"]>\n\ttransfer: Transferable[] | undefined\n}\n\nexport const shells = {\n\tderive: {\n\t\thost: <S extends Schematic>(meta: MessengerMeta<MinistryFns<S>>): HostShell<S> => ({\n\t\t\thost: meta.remote.host,\n\t\t\tget transfer() { return meta.transfer },\n\t\t\tset transfer(t) { meta.transfer = t },\n\t\t}),\n\t\twork: <S extends Schematic>(meta: MessengerMeta<S[\"work\"]>): WorkShell<S> => ({\n\t\t\twork: meta.remote,\n\t\t\tget transfer() { return meta.transfer },\n\t\t\tset transfer(t) { meta.transfer = t },\n\t\t}),\n\t},\n\tmock: {\n\t\thost: <S extends Schematic>(): HostShell<S> => ({\n\t\t\thost: undefined as any,\n\t\t\ttransfer: undefined,\n\t\t}),\n\t\twork: <S extends Schematic>(): WorkShell<S> => ({\n\t\t\twork: undefined as any,\n\t\t\ttransfer: undefined,\n\t\t})\n\t},\n}\n\n", "\nimport {ErrorTap} from \"@e280/renraku\"\n\nexport const defaultTap = new ErrorTap()\n\n", "\nimport {Messenger, PostableConduit} from \"@e280/renraku\"\n\nimport {shells} from \"./shells.js\"\nimport {Compat} from \"../compat/types.js\"\nimport {defaultTap} from \"./default-tap.js\"\nimport {MinistryFns, Schematic, SetupWork, WorkerOpts} from \"./types.js\"\n\n/**\n * create a web worker\n */\nexport async function worker<S extends Schematic>(\n\t\tcompat: Compat,\n\t\tsetupWork: SetupWork<S>,\n\t\toptions: WorkerOpts = {},\n\t) {\n\n\tconst tap = options.tap ?? defaultTap\n\n\tconst messenger = new Messenger<S[\"work\"], MinistryFns<S>>({\n\t\ttap,\n\t\ttimeout: options.timeout ?? Infinity,\n\t\tconduit: new PostableConduit(compat.getSelf()),\n\t\trpc: async m => setupWork(\n\t\t\tshells.derive.host<S>(m),\n\t\t),\n\t})\n\n\tawait messenger.remote.infra.ready()\n\treturn messenger.remote.host\n}\n\n", "\nexport const Bytes = Object.freeze({\n\teq(a: Uint8Array, b: Uint8Array) {\n\t\tif (a.length !== b.length)\n\t\t\treturn false\n\t\tfor (let i = 0; i <= a.length; i++) {\n\t\t\tif (a.at(i) !== b.at(i))\n\t\t\t\treturn false\n\t\t}\n\t\treturn true\n\t},\n\n\trandom(count: number) {\n\t\treturn crypto.getRandomValues(new Uint8Array(count))\n\t},\n})\n\n", "\n/*\n\n256-bit hex ids look like this:\n\n\t8ff8dfbc7c994c5439d2dd327b9898aa6796f97fb396e262985f03f868707e32\n\t6b99284a2c4a1c5f101502bd009f9fb592ca4427e4375155e411ddd07ed9da6b\n\t2eb73fb00a2b9e38c855b5aa353b530d820a3a2dcea5013b7e4e277ddfe9d0ad\n\n*/\n\nimport {Bytes} from \"./bytes.js\"\n\nexport const Hex = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\treturn [...bytes]\n\t\t\t.map(byte => byte.toString(16).padStart(2, \"0\"))\n\t\t\t.join(\"\")\n\t},\n\n\ttoBytes(string: string) {\n\t\tif (string.length % 2 !== 0)\n\t\t\tthrow new Error(\"must have even number of hex characters\")\n\t\tconst bytes = new Uint8Array(string.length / 2)\n\t\tfor (let i = 0; i < string.length; i += 2)\n\t\t\tbytes[i / 2] = parseInt(string.slice(i, i + 2), 16)\n\t\treturn bytes\n\t},\n\n\t/** generate a random hex string. byteCount defaults to 32. */\n\trandom(byteCount = 32) {\n\t\treturn this.fromBytes(Bytes.random(byteCount))\n\t},\n\n\t/** @deprecated renamed to `fromBytes` */\n\tstring(bytes: Uint8Array) {\n\t\treturn Hex.fromBytes(bytes)\n\t},\n\n\t/** @deprecated renamed to `toBytes` */\n\tbytes(string: string) {\n\t\treturn Hex.toBytes(string)\n\t},\n})\n\n", "\n/*\n\n256-bit base58 ids look like this:\n\n\t9X1D9rdkDgRdykzmogNcxfopRc7TnbS869ow1E2ehCFS\n\tAmRKyNfq6jhhsd9qda1Y6rAVS2NLUqyTUvfcB2wUiiAC\n\t8skYcqBAXsejDcJzsZMo19PErt43DHP3bykaXBtMvdu\n\n*/\n\nimport {Hex} from \"./hex.js\"\nimport {Bytes} from \"./bytes.js\"\n\nconst base = 58\nconst characters = \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\"\n\nexport const Base58 = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\tlet intVal = BigInt(\"0x\" + Hex.fromBytes(bytes))\n\t\tlet encoded = \"\"\n\n\t\twhile (intVal > 0) {\n\t\t\tconst remainder = intVal % BigInt(base)\n\t\t\tintVal = intVal / BigInt(base)\n\t\t\tencoded = characters[Number(remainder)] + encoded\n\t\t}\n\n\t\tfor (const byte of bytes) {\n\t\t\tif (byte === 0) encoded = characters[0] + encoded\n\t\t\telse break\n\t\t}\n\n\t\treturn encoded\n\t},\n\n\ttoBytes(string: string) {\n\t\tlet intVal = BigInt(0)\n\n\t\tfor (const char of string) {\n\t\t\tconst index = characters.indexOf(char)\n\t\t\tif (index === -1) throw new Error(`Invalid character '${char}' in base58 string`)\n\t\t\tintVal = intVal * BigInt(base) + BigInt(index)\n\t\t}\n\n\t\tlet hex = intVal.toString(16)\n\t\tif (hex.length % 2 !== 0) hex = \"0\" + hex\n\t\tconst bytes = Hex.toBytes(hex)\n\n\t\tlet leadingZeroes = 0\n\t\tfor (const char of string) {\n\t\t\tif (char === characters[0]) leadingZeroes++\n\t\t\telse break\n\t\t}\n\n\t\tconst decoded = new Uint8Array(leadingZeroes + bytes.length)\n\t\tdecoded.set(bytes, leadingZeroes)\n\t\treturn decoded\n\t},\n\n\trandom(count = 32) {\n\t\treturn this.fromBytes(Bytes.random(count))\n\t},\n\n\t/** @deprecated renamed to `fromBytes` */\n\tstring(bytes: Uint8Array) {\n\t\treturn Base58.fromBytes(bytes)\n\t},\n\n\t/** @deprecated renamed to `toBytes` */\n\tbytes(string: string) {\n\t\treturn Base58.toBytes(string)\n\t},\n})\n\n", "\nimport {Bytes} from \"./bytes.js\"\n\nexport type Lexicon = {\n\tcharacters: string\n\tnegativePrefix?: string\n\tpadding?: {\n\t\tcharacter: string\n\t\tsize: number\n\t}\n}\n\nexport class BaseX {\n\tstatic lexicons = Object.freeze({\n\t\tbase2: {characters: \"01\"},\n\t\thex: {characters: \"0123456789abcdef\"},\n\t\tbase36: {characters: \"0123456789abcdefghijklmnopqrstuvwxyz\"},\n\t\tbase58: {characters: \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\"},\n\t\tbase62: {characters: \"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz\"},\n\t\tbase64url: {\n\t\t\tnegativePrefix: \"~\",\n\t\t\tcharacters: \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\",\n\t\t},\n\t\tbase64: {\n\t\t\tcharacters: \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",\n\t\t\tpadding: {character: \"=\", size: 4},\n\t\t},\n\t})\n\n\tprivate lookup: Record<string, number>\n\tprivate negativePrefix: string\n\n\tconstructor(public lexicon: Lexicon) {\n\t\tthis.lookup = Object.fromEntries(\n\t\t\t[...lexicon.characters].map((char, i) => [char, i])\n\t\t)\n\t\tthis.negativePrefix = lexicon.negativePrefix ?? \"-\"\n\t}\n\n\ttoBytes(s: string): Uint8Array {\n\t\tconst bitsPerChar = Math.log2(this.lexicon.characters.length)\n\t\tif (Number.isInteger(bitsPerChar)) {\n\t\t\t// Bitstream mode (for power-of-2 lexicons)\n\t\t\tlet bitBuffer = 0\n\t\t\tlet bitCount = 0\n\t\t\tconst output: number[] = []\n\n\t\t\tfor (const char of s) {\n\t\t\t\tif (char === this.lexicon.padding?.character) continue\n\t\t\t\tconst val = this.lookup[char]\n\t\t\t\tif (val === undefined) throw new Error(`Invalid character: ${char}`)\n\t\t\t\tbitBuffer = (bitBuffer << bitsPerChar) | val\n\t\t\t\tbitCount += bitsPerChar\n\n\t\t\t\twhile (bitCount >= 8) {\n\t\t\t\t\tbitCount -= 8\n\t\t\t\t\toutput.push((bitBuffer >> bitCount) & 0xFF)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn new Uint8Array(output)\n\t\t}\n\n\t\t// Radix mode fallback\n\t\tlet num = 0n\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tlet negative = false\n\t\tif (s.startsWith(this.negativePrefix)) {\n\t\t\ts = s.slice(this.negativePrefix.length)\n\t\t\tnegative = true\n\t\t}\n\t\tfor (const char of s) {\n\t\t\tconst val = this.lookup[char]\n\t\t\tif (val === undefined) throw new Error(`Invalid character: ${char}`)\n\t\t\tnum = num * base + BigInt(val)\n\t\t}\n\t\tconst out: number[] = []\n\t\twhile (num > 0n) {\n\t\t\tout.unshift(Number(num % 256n))\n\t\t\tnum = num / 256n\n\t\t}\n\t\treturn new Uint8Array(out)\n\t}\n\n\tfromBytes(bytes: Uint8Array): string {\n\t\tconst bitsPerChar = Math.log2(this.lexicon.characters.length)\n\t\tif (Number.isInteger(bitsPerChar)) {\n\t\t\t// Bitstream mode (for power-of-2 lexicons)\n\t\t\tlet bitBuffer = 0\n\t\t\tlet bitCount = 0\n\t\t\tlet out = \"\"\n\n\t\t\tfor (const byte of bytes) {\n\t\t\t\tbitBuffer = (bitBuffer << 8) | byte\n\t\t\t\tbitCount += 8\n\n\t\t\t\twhile (bitCount >= bitsPerChar) {\n\t\t\t\t\tbitCount -= bitsPerChar\n\t\t\t\t\tconst index = (bitBuffer >> bitCount) & ((1 << bitsPerChar) - 1)\n\t\t\t\t\tout += this.lexicon.characters[index]\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// \uD83E\uDE79 flush remaining bits\n\t\t\tif (bitCount > 0) {\n\t\t\t\tconst index = (bitBuffer << (bitsPerChar - bitCount)) & ((1 << bitsPerChar) - 1)\n\t\t\t\tout += this.lexicon.characters[index]\n\t\t\t}\n\n\t\t\t// Add padding if applicable\n\t\t\tif (this.lexicon.padding) {\n\t\t\t\twhile (out.length % this.lexicon.padding.size !== 0)\n\t\t\t\t\tout += this.lexicon.padding.character\n\t\t\t}\n\n\t\t\treturn out\n\t\t}\n\n\t\t// Radix mode fallback\n\t\tlet num = 0n\n\t\tfor (const byte of bytes)\n\t\t\tnum = (num << 8n) + BigInt(byte)\n\n\t\tif (num === 0n) return this.lexicon.characters[0]\n\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tlet out = \"\"\n\t\twhile (num > 0n) {\n\t\t\tout = this.lexicon.characters[Number(num % base)] + out\n\t\t\tnum = num / base\n\t\t}\n\t\treturn out\n\t}\n\n\ttoInteger(s: string) {\n\t\tif (!s) return 0\n\t\tlet n = 0n\n\t\tlet negative = false\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tif (s.startsWith(this.negativePrefix)) {\n\t\t\ts = s.slice(this.negativePrefix.length)\n\t\t\tnegative = true\n\t\t}\n\t\tfor (const char of s) {\n\t\t\tconst value = this.lookup[char]\n\t\t\tif (value === undefined) throw new Error(`Invalid character: ${char}`)\n\t\t\tn = n * base + BigInt(value)\n\t\t}\n\t\treturn Number(negative ? -n : n)\n\t}\n\n\tfromInteger(n: number) {\n\t\tn = Math.floor(n)\n\t\tconst negative = n < 0\n\t\tlet num = BigInt(negative ? -n : n)\n\t\tif (num === 0n) return this.lexicon.characters[0]\n\t\tconst base = BigInt(this.lexicon.characters.length)\n\t\tlet out = \"\"\n\t\twhile (num > 0n) {\n\t\t\tout = this.lexicon.characters[Number(num % base)] + out\n\t\t\tnum = num / base\n\t\t}\n\t\treturn negative ? `${this.negativePrefix}${out}` : out\n\t}\n\n\trandom(count = 32) {\n\t\treturn this.fromBytes(Bytes.random(count))\n\t}\n}\n\n", "\nimport {Bytes} from \"./bytes.js\"\n\nexport const Base64 = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\treturn (typeof btoa === \"function\")\n\t\t\t? btoa(String.fromCharCode(...bytes))\n\t\t\t: Buffer.from(bytes).toString(\"base64\")\n\t},\n\n\ttoBytes(string: string) {\n\t\treturn (typeof atob === \"function\")\n\t\t\t? Uint8Array.from(atob(string), char => char.charCodeAt(0))\n\t\t\t: Uint8Array.from(Buffer.from(string, \"base64\"))\n\t},\n\n\trandom(count = 32) {\n\t\treturn this.fromBytes(Bytes.random(count))\n\t},\n\n\t/** @deprecated rename to \"fromBytes\" */\n\tstring(bytes: Uint8Array) {\n\t\treturn Base64.fromBytes(bytes)\n\t},\n\n\t/** @deprecated rename to \"toBytes\" */\n\tbytes(string: string) {\n\t\treturn Base64.toBytes(string)\n\t},\n})\n\n", "\nexport const Txt = Object.freeze({\n\tfromBytes(bytes: Uint8Array) {\n\t\treturn new TextDecoder().decode(bytes)\n\t},\n\n\ttoBytes(string: string) {\n\t\treturn new TextEncoder().encode(string)\n\t},\n\n\t/** @deprecated renamed to `fromBytes` */\n\tstring(bytes: Uint8Array) {\n\t\treturn Txt.fromBytes(bytes)\n\t},\n\n\t/** @deprecated renamed to `toBytes` */\n\tbytes(string: string) {\n\t\treturn Txt.toBytes(string)\n\t},\n})\n\n", "\nexport const is = Object.freeze({\n\tset: <X>(x: X): x is NonNullable<X> =>\n\t\tx !== undefined && x !== null,\n\n\tunset: (x: any): x is (undefined | null) =>\n\t\tx === undefined || x === null,\n\n\tboolean: (x: any): x is boolean =>\n\t\ttypeof x === \"boolean\",\n\n\tnumber: (x: any): x is number =>\n\t\ttypeof x === \"number\",\n\n\tstring: (x: any): x is string =>\n\t\ttypeof x === \"string\",\n\n\tbigint: (x: any): x is bigint =>\n\t\ttypeof x === \"bigint\",\n\n\tobject: <X>(x: X): x is object & NonNullable<X> =>\n\t\ttypeof x === \"object\" && x !== null,\n\n\tarray: (x: any | any[]): x is any[] =>\n\t\tArray.isArray(x),\n\n\tfn: (x: any): x is (...a: any[]) => any =>\n\t\ttypeof x === \"function\",\n\n\tsymbol: (x: any): x is symbol =>\n\t\ttypeof x === \"symbol\",\n})\n\n", "\n/**\n * create a job queue that ensures the given fn is always called in sequence (not concurrently).\n */\nexport function queue<Args extends any[], Result>(\n\t\tfn: (...args: Args) => Promise<Result>\n\t): (...args: Args) => Promise<Result> {\n\n\tlet last: Promise<any> = Promise.resolve()\n\n\treturn (...args: Args): Promise<Result> => {\n\t\tconst job = () => fn(...args)\n\t\tconst current = last.then(job)\n\n\t\t// prevent unhandled rejection breaking the chain\n\t\tlast = current.catch(() => {})\n\n\t\treturn current\n\t}\n}\n\n", "\n/** return a single function that calls all the provided functions */\nexport function coalesce<A extends any[] = []>(...fns: ((...a: A) => void)[]) {\n\treturn (...a: A) => fns.forEach(fn => fn(...a))\n}\n\n", "\n/** a promise which can be resolved from the outside */\nexport type Deferred<R = void> = {\n\tpromise: Promise<R>\n\tresolve: (result: R) => void\n\treject: (reason: any) => void\n\n\t/** ties the fate of this deferred promise to the outcome of the provided outsidePromise */\n\tentangle: (outsidePromise: Promise<R>) => Promise<R>\n}\n\n/** returns a deferred promise with exposed resolve and reject fns */\nexport function defer<R = void>(): Deferred<R> {\n\tlet resolve!: (result: R) => void\n\tlet reject!: (reason: any) => void\n\n\tconst promise = new Promise<R>((res, rej) => {\n\t\tresolve = res\n\t\treject = rej\n\t})\n\n\tfunction entangle(outside: Promise<R>) {\n\t\toutside.then(resolve).catch(reject)\n\t\treturn promise\n\t}\n\n\treturn {promise, resolve, reject, entangle}\n}\n\n", "\nexport function ob<Ob extends object>(o: Ob) {\n\treturn {\n\t\tmap: <Value>(transform: ObTransform<Ob, Value>) => (\n\t\t\tobMap(o, transform)\n\t\t),\n\t\tfilter: (predicate: ObPredicate<Ob>) => (\n\t\t\tobFilter(o, predicate)\n\t\t),\n\t}\n}\n\n////////////\n////////////\n\nob.pipe = Object.freeze({\n\tmap: <O extends {}, Value>(\n\t\t\ttransform: (value: O[keyof O], key: keyof O) => Value,\n\t\t) => (\n\t\t(o: O) => obMap(o, transform)\n\t),\n\tfilter: <O extends {}>(\n\t\t\ttransform: (value: O[keyof O], key: keyof O) => boolean,\n\t\t) => (\n\t\t(o: O) => obFilter(o, transform) as {[key: string]: O[keyof O]}\n\t),\n})\n\n////////////\n////////////\n\nexport type ObTransform<Ob extends object, Value> = (\n\t(value: Ob[keyof Ob], key: keyof Ob) => Value\n)\n\nexport type ObPredicate<Ob extends object> = (\n\t(value: Ob[keyof Ob], key: keyof Ob) => boolean\n)\n\n////////////\n////////////\n\nconst obMap = <Ob extends object, Value>(\n\t\to: Ob,\n\t\ttransform: ObTransform<Ob, Value>,\n\t) => {\n\n\treturn Object.fromEntries(\n\t\tObject.entries(o).map(\n\t\t\t([key, value]: any) => [key, transform(value, key)]\n\t\t)\n\t) as {[P in keyof Ob]: Value}\n}\n\nconst obFilter = <Ob extends object>(\n\t\to: Ob,\n\t\tpredicate: ObPredicate<Ob>,\n\t) => {\n\n\treturn Object.fromEntries(\n\t\tObject.entries(o).filter(\n\t\t\t([key, value]: any) => predicate(value, key)\n\t\t)\n\t) as {[P in keyof Ob]?: Ob[keyof Ob]}\n}\n\n", "\nimport {defer} from \"./defer.js\"\n\nexport type Listener<A extends any[]> = (...a: A) => (void | Promise<void>)\n\nexport interface Xub<A extends any[] = []> {\n\n\t/** publish to all subscribed listeners. */\n\tpub(...a: A): Promise<void>\n\n\t/** subscribe a listener function. */\n\tsub(fn: Listener<A>): () => void\n\n\t/**\n\t * subscribe a listener function.\n\t * @alias sub\n\t */\n\ton(fn: Listener<A>): () => void\n\n\t/** wait for the next published value */\n\tnext(): Promise<A>\n\n\t/** wipe all listeners attached to this. */\n\tclear(): void\n}\n\n/** subscriber fn that can be published to. */\nexport interface Sub<A extends any[] = []> extends Xub<A> {\n\t(fn: Listener<A>): () => void\n}\n\n/** publisher fn that can be published to. */\nexport interface Pub<A extends any[] = []> extends Xub<A> {\n\t(...a: A): Promise<void>\n}\n\nexport function xub<A extends any[] = []>() {\n\tconst set = new Set<Listener<A>>()\n\n\tfunction sub(fn: Listener<A>) {\n\t\tset.add(fn)\n\t\treturn () => { set.delete(fn) }\n\t}\n\n\tasync function pub(...a: A) {\n\t\tawait Promise.all([...set].map(fn => fn(...a)))\n\t}\n\n\tasync function next() {\n\t\tconst {promise, resolve} = defer<A>()\n\t\tconst unsubscribe = sub((...a) => {\n\t\t\tresolve(a)\n\t\t\tunsubscribe()\n\t\t})\n\t\treturn promise\n\t}\n\n\tfunction clear() {\n\t\tset.clear()\n\t}\n\n\tsub.pub = pub\n\tsub.sub = sub\n\tsub.on = sub\n\tsub.next = next\n\tsub.clear = clear\n\n\tpub.pub = pub\n\tpub.sub = sub\n\tpub.on = sub\n\tpub.next = next\n\tpub.clear = clear\n\n\treturn [pub, sub] as [Pub<A>, Sub<A>]\n}\n\n/** create a subscriber fn that can be published to */\nexport function sub<A extends any[] = []>(listener?: Listener<A>): Sub<A> {\n\tconst fn = xub<A>()[1]\n\tif (listener)\n\t\tfn.sub(listener)\n\treturn fn\n}\n\n/** create a publisher fn that can be subscribed to */\nexport function pub<A extends any[] = []>(listener?: Listener<A>): Pub<A> {\n\tconst fn = xub<A>()[0]\n\tif (listener)\n\t\tfn.sub(listener)\n\treturn fn\n}\n\n", "\nimport {defer} from \"@e280/stz\"\nimport {Messenger, PostableConduit} from \"@e280/renraku\"\n\nimport {shells} from \"./shells.js\"\nimport {defaultTap} from \"./default-tap.js\"\nimport {Compat, CompatWorker} from \"../compat/types.js\"\nimport {Infra, MinistryFns, Schematic, ThreadOptions} from \"./types.js\"\n\nexport class Thread<S extends Schematic> {\n\tconstructor(\n\t\tpublic worker: CompatWorker,\n\t\tpublic messenger: Messenger<MinistryFns<S>, S[\"work\"]>,\n\t) {}\n\n\tstatic async make<S extends Schematic>(compat: Compat, options: ThreadOptions<S>) {\n\t\tconst tap = options.tap ?? defaultTap\n\t\tconst label = options.label ?? \"comrade\"\n\t\tconst worker = compat.loadWorker(options.workerUrl, label)\n\t\tconst readyprom = defer<void>()\n\n\t\tconst infra: Infra = {\n\t\t\tasync ready() {\n\t\t\t\treadyprom.resolve()\n\t\t\t},\n\t\t}\n\n\t\tconst messenger = new Messenger<MinistryFns<S>, S[\"work\"]>({\n\t\t\ttap,\n\t\t\ttimeout: options.timeout ?? Infinity,\n\t\t\tconduit: new PostableConduit(worker),\n\t\t\trpc: async m => ({\n\t\t\t\tinfra,\n\t\t\t\thost: options.setupHost(\n\t\t\t\t\tshells.derive.work<S>(m)\n\t\t\t\t),\n\t\t\t}),\n\t\t})\n\n\t\tawait readyprom.promise\n\t\treturn new this<S>(worker, messenger)\n\t}\n\n\tget work() {\n\t\treturn this.messenger.remote\n\t}\n\n\tterminate() {\n\t\tthis.worker.terminate()\n\t}\n}\n\n", "\nimport {defer} from \"@e280/stz\"\nimport {Endpoint, makeRemote, Remote, Tap} from \"@e280/renraku\"\n\nimport {Thread} from \"./thread.js\"\nimport {Compat} from \"../compat/types.js\"\nimport {defaultTap} from \"./default-tap.js\"\nimport {ClusterOptions, Schematic, Task} from \"./types.js\"\n\n/**\n * a pool of web workers\n * - please use `await Cluster.make(options)` to create your worker pool\n * - call your worker functions like `await cluster.remote.hello()`\n */\nexport class Cluster<S extends Schematic> {\n\n\tstatic async make<S extends Schematic>(compat: Compat, options: ClusterOptions<S>) {\n\t\tconst workerCount = options.workerCount ?? compat.guessOptimalThreadCount()\n\t\tconst threads = await Promise.all([...Array(workerCount)].map(\n\t\t\tasync(_, index) => Thread.make(compat, {\n\t\t\t\t...options,\n\t\t\t\tlabel: options.label ?? `${options.label ?? \"comrade\"}_${index + 1}`,\n\t\t\t})\n\t\t))\n\t\treturn new this<S>(threads, {tap: options.tap})\n\t}\n\n\twork: Remote<S[\"work\"]>\n\t#available = new Set<Thread<S>>()\n\t#tasks: Task[] = []\n\n\tconstructor(private threads: Thread<S>[], options: {tap?: Tap} = {}) {\n\t\tconst tap = options.tap ?? defaultTap\n\n\t\t// delegation\n\t\tconst remoteEndpoint: Endpoint = async(request, special) => this.#scheduleTask({\n\t\t\trequest,\n\t\t\tprom: defer(),\n\t\t\ttransfer: special?.transfer,\n\t\t})\n\n\t\t// remote proxy to call comrade fns\n\t\tthis.work = makeRemote({\n\t\t\ttap,\n\t\t\tendpoint: remoteEndpoint,\n\t\t})\n\n\t\t// in the beginning, all threads are available\n\t\tthreads.forEach(t => this.#available.add(t))\n\t}\n\n\tget threadCount() {\n\t\treturn this.threads.length\n\t}\n\n\tterminate() {\n\t\tfor (const thread of this.threads)\n\t\t\tthread.terminate()\n\t}\n\n\t#scheduleTask(task: Task) {\n\t\tthis.#tasks.push(task)\n\t\tthis.#distributeTasks()\n\t\treturn task.prom.promise\n\t}\n\n\t#distributeTasks() {\n\t\twhile (this.#available.size > 0 && this.#tasks.length > 0) {\n\t\t\tconst thread = [...this.#available].pop()!\n\t\t\tthis.#available.delete(thread)\n\n\t\t\tconst task = this.#tasks.shift()!\n\n\t\t\t// this thread is no longer available\n\t\t\tthis.#available.delete(thread)\n\n\t\t\t// call the thread endpoint\n\t\t\tconst callprom = thread.messenger.remoteEndpoint(task.request, {transfer: task.transfer})\n\n\t\t\t// resolve/reject the task prom when callprom is done\n\t\t\ttask.prom.entangle(callprom).finally(() => {\n\n\t\t\t\t// thread is ready again\n\t\t\t\tthis.#available.add(thread)\n\n\t\t\t\t// distribute more tasks\n\t\t\t\tthis.#distributeTasks()\n\t\t\t})\n\t\t}\n\t}\n}\n\n", "\nimport {makeMock, Tap} from \"@e280/renraku\"\n\nimport {worker} from \"./parts/worker.js\"\nimport {Compat} from \"./compat/types.js\"\nimport {Thread} from \"./parts/thread.js\"\nimport {shells} from \"./parts/shells.js\"\nimport {Cluster} from \"./parts/cluster.js\"\nimport {defaultTap} from \"./parts/default-tap.js\"\nimport {ClusterOptions, Mocks, Schematic, SetupHost, SetupWork, ThreadOptions, WorkerOpts} from \"./parts/types.js\"\n\nexport const setupComrade = (compat: Compat) => ({\n\tthread: <S extends Schematic>(options: ThreadOptions<S>) => Thread.make(compat, options),\n\tcluster: <S extends Schematic>(options: ClusterOptions<S>) => Cluster.make(compat, options),\n\n\tworker: <S extends Schematic>(\n\t\tsetupWork: SetupWork<S>,\n\t\toptions: WorkerOpts = {},\n\t) => worker(compat, setupWork, options),\n\n\twork: <S extends Schematic>(fn: SetupWork<S>) => fn,\n\thost: <S extends Schematic>(fn: SetupHost<S>) => fn,\n\n\tmocks<S extends Schematic>(options: {\n\t\t\ttap?: Tap\n\t\t\tsetupWork: SetupWork<S>\n\t\t\tsetupHost: SetupHost<S>\n\t\t}): Mocks<S> {\n\n\t\tconst {setupWork, setupHost, tap = defaultTap} = options\n\n\t\tconst hostShell = shells.mock.host<S>()\n\t\tconst workShell = shells.mock.work<S>()\n\n\t\tworkShell.work = makeMock({tap, fns: setupWork(hostShell)})\n\t\thostShell.host = makeMock({tap, fns: setupHost(workShell)})\n\n\t\treturn {\n\t\t\tworkShell,\n\t\t\thostShell,\n\t\t\twork: workShell.work,\n\t\t\thost: hostShell.host,\n\t\t}\n\t},\n\n\tmockWork<S extends Schematic>(setupWork: SetupWork<S>, tap: Tap = defaultTap) {\n\t\tconst hostShell = shells.mock.host<S>()\n\t\tconst workShell = shells.mock.work<S>()\n\n\t\tworkShell.work = makeMock({tap, fns: setupWork(hostShell)})\n\n\t\treturn {\n\t\t\tworkShell,\n\t\t\thostShell,\n\t\t\twork: workShell.work,\n\t\t\tmockHost: (setupHost: SetupHost<S>): Mocks<S> => {\n\t\t\t\thostShell.host = makeMock({tap, fns: setupHost(workShell)})\n\t\t\t\treturn {\n\t\t\t\t\tworkShell,\n\t\t\t\t\thostShell,\n\t\t\t\t\twork: workShell.work,\n\t\t\t\t\thost: hostShell.host,\n\t\t\t\t}\n\t\t\t},\n\t\t}\n\t},\n})\n\n", "\nimport {Compat, CompatWorker} from \"./types.js\"\n\nexport const setupBrowserCompat = (): Compat => ({\n\tgetSelf() {\n\t\treturn self\n\t},\n\n\tguessOptimalThreadCount() {\n\t\tconst count = navigator.hardwareConcurrency ?? 1\n\t\treturn Math.max(1, count - 1)\n\t},\n\n\tloadWorker(url, name) {\n\t\treturn new window.Worker(url, {name, type: \"module\"}) as CompatWorker\n\t},\n\n\tasync loadWasm(url) {\n\t\treturn WebAssembly.instantiateStreaming(fetch(url))\n\t},\n})\n\n", "\nimport {setupComrade} from \"./comrade.js\"\nimport {setupBrowserCompat} from \"./compat/browser.js\"\n\nexport const compat = setupBrowserCompat()\nexport const Comrade = setupComrade(compat)\n\nexport * from \"./exports.js\"\n\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nexport function assert(x) {\n if (!x) {\n throw new Error('Assertion failed.');\n }\n}\nexport const normalizeRotation = (rotation) => {\n const mappedRotation = (rotation % 360 + 360) % 360;\n if (mappedRotation === 0 || mappedRotation === 90 || mappedRotation === 180 || mappedRotation === 270) {\n return mappedRotation;\n }\n else {\n throw new Error(`Invalid rotation ${rotation}.`);\n }\n};\nexport const last = (arr) => {\n return arr && arr[arr.length - 1];\n};\nexport const isU32 = (value) => {\n return value >= 0 && value < 2 ** 32;\n};\nexport class Bitstream {\n constructor(bytes) {\n this.bytes = bytes;\n /** Current offset in bits. */\n this.pos = 0;\n }\n seekToByte(byteOffset) {\n this.pos = 8 * byteOffset;\n }\n readBit() {\n const byteIndex = Math.floor(this.pos / 8);\n const byte = this.bytes[byteIndex] ?? 0;\n const bitIndex = 0b111 - (this.pos & 0b111);\n const bit = (byte & (1 << bitIndex)) >> bitIndex;\n this.pos++;\n return bit;\n }\n readBits(n) {\n if (n === 1) {\n return this.readBit();\n }\n let result = 0;\n for (let i = 0; i < n; i++) {\n result <<= 1;\n result |= this.readBit();\n }\n return result;\n }\n writeBits(n, value) {\n const end = this.pos + n;\n for (let i = this.pos; i < end; i++) {\n const byteIndex = Math.floor(i / 8);\n let byte = this.bytes[byteIndex];\n const bitIndex = 0b111 - (i & 0b111);\n byte &= ~(1 << bitIndex);\n byte |= ((value & (1 << (end - i - 1))) >> (end - i - 1)) << bitIndex;\n this.bytes[byteIndex] = byte;\n }\n this.pos = end;\n }\n ;\n readAlignedByte() {\n // Ensure we're byte-aligned\n if (this.pos % 8 !== 0) {\n throw new Error('Bitstream is not byte-aligned.');\n }\n const byteIndex = this.pos / 8;\n const byte = this.bytes[byteIndex] ?? 0;\n this.pos += 8;\n return byte;\n }\n skipBits(n) {\n this.pos += n;\n }\n getBitsLeft() {\n return this.bytes.length * 8 - this.pos;\n }\n clone() {\n const clone = new Bitstream(this.bytes);\n clone.pos = this.pos;\n return clone;\n }\n}\n/** Reads an exponential-Golomb universal code from a Bitstream. */\nexport const readExpGolomb = (bitstream) => {\n let leadingZeroBits = 0;\n while (bitstream.readBits(1) === 0 && leadingZeroBits < 32) {\n leadingZeroBits++;\n }\n if (leadingZeroBits >= 32) {\n throw new Error('Invalid exponential-Golomb code.');\n }\n const result = (1 << leadingZeroBits) - 1 + bitstream.readBits(leadingZeroBits);\n return result;\n};\n/** Reads a signed exponential-Golomb universal code from a Bitstream. */\nexport const readSignedExpGolomb = (bitstream) => {\n const codeNum = readExpGolomb(bitstream);\n return ((codeNum & 1) === 0)\n ? -(codeNum >> 1)\n : ((codeNum + 1) >> 1);\n};\nexport const writeBits = (bytes, start, end, value) => {\n for (let i = start; i < end; i++) {\n const byteIndex = Math.floor(i / 8);\n let byte = bytes[byteIndex];\n const bitIndex = 0b111 - (i & 0b111);\n byte &= ~(1 << bitIndex);\n byte |= ((value & (1 << (end - i - 1))) >> (end - i - 1)) << bitIndex;\n bytes[byteIndex] = byte;\n }\n};\nexport const toUint8Array = (source) => {\n if (source instanceof Uint8Array) {\n return source;\n }\n else if (source instanceof ArrayBuffer) {\n return new Uint8Array(source);\n }\n else {\n return new Uint8Array(source.buffer, source.byteOffset, source.byteLength);\n }\n};\nexport const toDataView = (source) => {\n if (source instanceof DataView) {\n return source;\n }\n else if (source instanceof ArrayBuffer) {\n return new DataView(source);\n }\n else {\n return new DataView(source.buffer, source.byteOffset, source.byteLength);\n }\n};\nexport const textDecoder = new TextDecoder();\nexport const textEncoder = new TextEncoder();\nexport const isIso88591Compatible = (text) => {\n for (let i = 0; i < text.length; i++) {\n const code = text.charCodeAt(i);\n if (code > 255) {\n return false;\n }\n }\n return true;\n};\nconst invertObject = (object) => {\n return Object.fromEntries(Object.entries(object).map(([key, value]) => [value, key]));\n};\n// For the color space mappings, see Rec. ITU-T H.273.\nexport const COLOR_PRIMARIES_MAP = {\n bt709: 1, // ITU-R BT.709\n bt470bg: 5, // ITU-R BT.470BG\n smpte170m: 6, // ITU-R BT.601 525 - SMPTE 170M\n bt2020: 9, // ITU-R BT.202\n smpte432: 12, // SMPTE EG 432-1\n};\nexport const COLOR_PRIMARIES_MAP_INVERSE = invertObject(COLOR_PRIMARIES_MAP);\nexport const TRANSFER_CHARACTERISTICS_MAP = {\n 'bt709': 1, // ITU-R BT.709\n 'smpte170m': 6, // SMPTE 170M\n 'linear': 8, // Linear transfer characteristics\n 'iec61966-2-1': 13, // IEC 61966-2-1\n 'pg': 16, // Rec. ITU-R BT.2100-2 perceptual quantization (PQ) system\n 'hlg': 18, // Rec. ITU-R BT.2100-2 hybrid loggamma (HLG) system\n};\nexport const TRANSFER_CHARACTERISTICS_MAP_INVERSE = invertObject(TRANSFER_CHARACTERISTICS_MAP);\nexport const MATRIX_COEFFICIENTS_MAP = {\n 'rgb': 0, // Identity\n 'bt709': 1, // ITU-R BT.709\n 'bt470bg': 5, // ITU-R BT.470BG\n 'smpte170m': 6, // SMPTE 170M\n 'bt2020-ncl': 9, // ITU-R BT.2020-2 (non-constant luminance)\n};\nexport const MATRIX_COEFFICIENTS_MAP_INVERSE = invertObject(MATRIX_COEFFICIENTS_MAP);\nexport const colorSpaceIsComplete = (colorSpace) => {\n return (!!colorSpace\n && !!colorSpace.primaries\n && !!colorSpace.transfer\n && !!colorSpace.matrix\n && colorSpace.fullRange !== undefined);\n};\nexport const isAllowSharedBufferSource = (x) => {\n return (x instanceof ArrayBuffer\n || (typeof SharedArrayBuffer !== 'undefined' && x instanceof SharedArrayBuffer)\n || ArrayBuffer.isView(x));\n};\nexport class AsyncMutex {\n constructor() {\n this.currentPromise = Promise.resolve();\n }\n async acquire() {\n let resolver;\n const nextPromise = new Promise((resolve) => {\n resolver = resolve;\n });\n const currentPromiseAlias = this.currentPromise;\n this.currentPromise = nextPromise;\n await currentPromiseAlias;\n return resolver;\n }\n}\nexport const bytesToHexString = (bytes) => {\n return [...bytes].map(x => x.toString(16).padStart(2, '0')).join('');\n};\nexport const reverseBitsU32 = (x) => {\n x = ((x >> 1) & 0x55555555) | ((x & 0x55555555) << 1);\n x = ((x >> 2) & 0x33333333) | ((x & 0x33333333) << 2);\n x = ((x >> 4) & 0x0f0f0f0f) | ((x & 0x0f0f0f0f) << 4);\n x = ((x >> 8) & 0x00ff00ff) | ((x & 0x00ff00ff) << 8);\n x = ((x >> 16) & 0x0000ffff) | ((x & 0x0000ffff) << 16);\n return x >>> 0; // Ensure it's treated as an unsigned 32-bit integer\n};\n/** Returns the smallest index i such that val[i] === key, or -1 if no such index exists. */\nexport const binarySearchExact = (arr, key, valueGetter) => {\n let low = 0;\n let high = arr.length - 1;\n let ans = -1;\n while (low <= high) {\n const mid = (low + high) >> 1;\n const midVal = valueGetter(arr[mid]);\n if (midVal === key) {\n ans = mid;\n high = mid - 1; // Continue searching left to find the lowest index\n }\n else if (midVal < key) {\n low = mid + 1;\n }\n else {\n high = mid - 1;\n }\n }\n return ans;\n};\n/** Returns the largest index i such that val[i] <= key, or -1 if no such index exists. */\nexport const binarySearchLessOrEqual = (arr, key, valueGetter) => {\n let low = 0;\n let high = arr.length - 1;\n let ans = -1;\n while (low <= high) {\n const mid = (low + (high - low + 1) / 2) | 0;\n const midVal = valueGetter(arr[mid]);\n if (midVal <= key) {\n ans = mid;\n low = mid + 1;\n }\n else {\n high = mid - 1;\n }\n }\n return ans;\n};\n/** Assumes the array is already sorted. */\nexport const insertSorted = (arr, item, valueGetter) => {\n const insertionIndex = binarySearchLessOrEqual(arr, valueGetter(item), valueGetter);\n arr.splice(insertionIndex + 1, 0, item); // This even behaves correctly for the -1 case\n};\nexport const promiseWithResolvers = () => {\n let resolve;\n let reject;\n const promise = new Promise((res, rej) => {\n resolve = res;\n reject = rej;\n });\n return { promise, resolve: resolve, reject: reject };\n};\nexport const removeItem = (arr, item) => {\n const index = arr.indexOf(item);\n if (index !== -1) {\n arr.splice(index, 1);\n }\n};\nexport const findLast = (arr, predicate) => {\n for (let i = arr.length - 1; i >= 0; i--) {\n if (predicate(arr[i])) {\n return arr[i];\n }\n }\n return undefined;\n};\nexport const findLastIndex = (arr, predicate) => {\n for (let i = arr.length - 1; i >= 0; i--) {\n if (predicate(arr[i])) {\n return i;\n }\n }\n return -1;\n};\nexport const toAsyncIterator = async function* (source) {\n if (Symbol.iterator in source) {\n // @ts-expect-error Trust me\n yield* source[Symbol.iterator]();\n }\n else {\n // @ts-expect-error Trust me\n yield* source[Symbol.asyncIterator]();\n }\n};\nexport const validateAnyIterable = (iterable) => {\n if (!(Symbol.iterator in iterable) && !(Symbol.asyncIterator in iterable)) {\n throw new TypeError('Argument must be an iterable or async iterable.');\n }\n};\nexport const assertNever = (x) => {\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new Error(`Unexpected value: ${x}`);\n};\nexport const getUint24 = (view, byteOffset, littleEndian) => {\n const byte1 = view.getUint8(byteOffset);\n const byte2 = view.getUint8(byteOffset + 1);\n const byte3 = view.getUint8(byteOffset + 2);\n if (littleEndian) {\n return byte1 | (byte2 << 8) | (byte3 << 16);\n }\n else {\n return (byte1 << 16) | (byte2 << 8) | byte3;\n }\n};\nexport const getInt24 = (view, byteOffset, littleEndian) => {\n // The left shift pushes the most significant bit into the sign bit region, and the subsequent right shift\n // then correctly interprets the sign bit.\n return getUint24(view, byteOffset, littleEndian) << 8 >> 8;\n};\nexport const setUint24 = (view, byteOffset, value, littleEndian) => {\n // Ensure the value is within 24-bit unsigned range (0 to 16777215)\n value = value >>> 0; // Convert to unsigned 32-bit\n value = value & 0xFFFFFF; // Mask to 24 bits\n if (littleEndian) {\n view.setUint8(byteOffset, value & 0xFF);\n view.setUint8(byteOffset + 1, (value >>> 8) & 0xFF);\n view.setUint8(byteOffset + 2, (value >>> 16) & 0xFF);\n }\n else {\n view.setUint8(byteOffset, (value >>> 16) & 0xFF);\n view.setUint8(byteOffset + 1, (value >>> 8) & 0xFF);\n view.setUint8(byteOffset + 2, value & 0xFF);\n }\n};\nexport const setInt24 = (view, byteOffset, value, littleEndian) => {\n // Ensure the value is within 24-bit signed range (-8388608 to 8388607)\n value = clamp(value, -8388608, 8388607);\n // Convert negative values to their 24-bit representation\n if (value < 0) {\n value = (value + 0x1000000) & 0xFFFFFF;\n }\n setUint24(view, byteOffset, value, littleEndian);\n};\nexport const setInt64 = (view, byteOffset, value, littleEndian) => {\n if (littleEndian) {\n view.setUint32(byteOffset + 0, value, true);\n view.setInt32(byteOffset + 4, Math.floor(value / 2 ** 32), true);\n }\n else {\n view.setInt32(byteOffset + 0, Math.floor(value / 2 ** 32), true);\n view.setUint32(byteOffset + 4, value, true);\n }\n};\n/**\n * Calls a function on each value spat out by an async generator. The reason for writing this manually instead of\n * using a generator function is that the generator function queues return() calls - here, we forward them immediately.\n */\nexport const mapAsyncGenerator = (generator, map) => {\n return {\n async next() {\n const result = await generator.next();\n if (result.done) {\n return { value: undefined, done: true };\n }\n else {\n return { value: map(result.value), done: false };\n }\n },\n return() {\n return generator.return();\n },\n throw(error) {\n return generator.throw(error);\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n };\n};\nexport const clamp = (value, min, max) => {\n return Math.max(min, Math.min(max, value));\n};\nexport const UNDETERMINED_LANGUAGE = 'und';\nexport const roundToPrecision = (value, digits) => {\n const factor = 10 ** digits;\n return Math.round(value * factor) / factor;\n};\nexport const roundToMultiple = (value, multiple) => {\n return Math.round(value / multiple) * multiple;\n};\nexport const ilog = (x) => {\n let ret = 0;\n while (x) {\n ret++;\n x >>= 1;\n }\n return ret;\n};\nconst ISO_639_2_REGEX = /^[a-z]{3}$/;\nexport const isIso639Dash2LanguageCode = (x) => {\n return ISO_639_2_REGEX.test(x);\n};\n// Since the result will be truncated, add a bit of eps to compensate for floating point errors\nexport const SECOND_TO_MICROSECOND_FACTOR = 1e6 * (1 + Number.EPSILON);\nexport const mergeObjectsDeeply = (a, b) => {\n const result = { ...a };\n for (const key in b) {\n if (typeof a[key] === 'object'\n && a[key] !== null\n && typeof b[key] === 'object'\n && b[key] !== null) {\n result[key] = mergeObjectsDeeply(a[key], b[key]);\n }\n else {\n result[key] = b[key];\n }\n }\n return result;\n};\nexport const retriedFetch = async (url, requestInit, getRetryDelay) => {\n let attempts = 0;\n while (true) {\n try {\n return await fetch(url, requestInit);\n }\n catch (error) {\n attempts++;\n const retryDelayInSeconds = getRetryDelay(attempts);\n if (retryDelayInSeconds === null) {\n throw error;\n }\n console.error('Retrying failed fetch. Error:', error);\n if (!Number.isFinite(retryDelayInSeconds) || retryDelayInSeconds < 0) {\n throw new TypeError('Retry delay must be a non-negative finite number.');\n }\n if (retryDelayInSeconds > 0) {\n await new Promise(resolve => setTimeout(resolve, 1000 * retryDelayInSeconds));\n }\n }\n }\n};\nexport const computeRationalApproximation = (x, maxDenominator) => {\n // Handle negative numbers\n const sign = x < 0 ? -1 : 1;\n x = Math.abs(x);\n let prevNumerator = 0, prevDenominator = 1;\n let currNumerator = 1, currDenominator = 0;\n // Continued fraction algorithm\n let remainder = x;\n while (true) {\n const integer = Math.floor(remainder);\n // Calculate next convergent\n const nextNumerator = integer * currNumerator + prevNumerator;\n const nextDenominator = integer * currDenominator + prevDenominator;\n if (nextDenominator > maxDenominator) {\n return {\n numerator: sign * currNumerator,\n denominator: currDenominator,\n };\n }\n prevNumerator = currNumerator;\n prevDenominator = currDenominator;\n currNumerator = nextNumerator;\n currDenominator = nextDenominator;\n remainder = 1 / (remainder - integer);\n // Guard against precision issues\n if (!isFinite(remainder)) {\n break;\n }\n }\n return {\n numerator: sign * currNumerator,\n denominator: currDenominator,\n };\n};\nexport class CallSerializer {\n constructor() {\n this.currentPromise = Promise.resolve();\n }\n call(fn) {\n return this.currentPromise = this.currentPromise.then(fn);\n }\n}\nlet isSafariCache = null;\nexport const isSafari = () => {\n if (isSafariCache !== null) {\n return isSafariCache;\n }\n const result = !!(typeof navigator !== 'undefined'\n && navigator.vendor?.match(/apple/i)\n && !navigator.userAgent?.match(/crios/i)\n && !navigator.userAgent?.match(/fxios/i)\n && !navigator.userAgent?.match(/Opera|OPT\\//));\n isSafariCache = result;\n return result;\n};\n/** Acts like `??` except the condition is -1 and not null/undefined. */\nexport const coalesceIndex = (a, b) => {\n return a !== -1 ? a : b;\n};\nexport const closedIntervalsOverlap = (startA, endA, startB, endB) => {\n return startA <= endB && startB <= endA;\n};\nexport const keyValueIterator = function* (object) {\n for (const key in object) {\n const value = object[key];\n if (value === undefined) {\n continue;\n }\n yield { key, value };\n }\n};\nexport const imageMimeTypeToExtension = (mimeType) => {\n switch (mimeType.toLowerCase()) {\n case 'image/jpeg':\n case 'image/jpg':\n return '.jpg';\n case 'image/png':\n return '.png';\n case 'image/gif':\n return '.gif';\n case 'image/webp':\n return '.webp';\n case 'image/bmp':\n return '.bmp';\n case 'image/svg+xml':\n return '.svg';\n case 'image/tiff':\n return '.tiff';\n case 'image/avif':\n return '.avif';\n case 'image/x-icon':\n case 'image/vnd.microsoft.icon':\n return '.ico';\n default:\n return null;\n }\n};\nexport const base64ToBytes = (base64) => {\n const decoded = atob(base64);\n const bytes = new Uint8Array(decoded.length);\n for (let i = 0; i < decoded.length; i++) {\n bytes[i] = decoded.charCodeAt(i);\n }\n return bytes;\n};\nexport const bytesToBase64 = (bytes) => {\n let string = '';\n for (let i = 0; i < bytes.length; i++) {\n string += String.fromCharCode(bytes[i]);\n }\n return btoa(string);\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n/**\n * Image data with additional metadata.\n *\n * @group Metadata tags\n * @public\n */\nexport class RichImageData {\n /** Creates a new {@link RichImageData}. */\n constructor(\n /** The raw image data. */\n data, \n /** An RFC 6838 MIME type (e.g. image/jpeg, image/png, etc.) */\n mimeType) {\n this.data = data;\n this.mimeType = mimeType;\n }\n}\nexport const validateMetadataTags = (tags) => {\n if (!tags || typeof tags !== 'object') {\n throw new TypeError('tags must be an object.');\n }\n if (tags.title !== undefined && typeof tags.title !== 'string') {\n throw new TypeError('tags.title, when provided, must be a string.');\n }\n if (tags.description !== undefined && typeof tags.description !== 'string') {\n throw new TypeError('tags.description, when provided, must be a string.');\n }\n if (tags.artist !== undefined && typeof tags.artist !== 'string') {\n throw new TypeError('tags.artist, when provided, must be a string.');\n }\n if (tags.album !== undefined && typeof tags.album !== 'string') {\n throw new TypeError('tags.album, when provided, must be a string.');\n }\n if (tags.albumArtist !== undefined && typeof tags.albumArtist !== 'string') {\n throw new TypeError('tags.albumArtist, when provided, must be a string.');\n }\n if (tags.trackNumber !== undefined && (!Number.isInteger(tags.trackNumber) || tags.trackNumber <= 0)) {\n throw new TypeError('tags.trackNumber, when provided, must be a positive integer.');\n }\n if (tags.tracksTotal !== undefined\n && (!Number.isInteger(tags.tracksTotal) || tags.tracksTotal <= 0)) {\n throw new TypeError('tags.tracksTotal, when provided, must be a positive integer.');\n }\n if (tags.discNumber !== undefined && (!Number.isInteger(tags.discNumber) || tags.discNumber <= 0)) {\n throw new TypeError('tags.discNumber, when provided, must be a positive integer.');\n }\n if (tags.discsTotal !== undefined\n && (!Number.isInteger(tags.discsTotal) || tags.discsTotal <= 0)) {\n throw new TypeError('tags.discsTotal, when provided, must be a positive integer.');\n }\n if (tags.genre !== undefined && typeof tags.genre !== 'string') {\n throw new TypeError('tags.genre, when provided, must be a string.');\n }\n if (tags.date !== undefined && (!(tags.date instanceof Date) || Number.isNaN(tags.date.getTime()))) {\n throw new TypeError('tags.date, when provided, must be a valid Date.');\n }\n if (tags.lyrics !== undefined && typeof tags.lyrics !== 'string') {\n throw new TypeError('tags.lyrics, when provided, must be a string.');\n }\n if (tags.images !== undefined) {\n if (!Array.isArray(tags.images)) {\n throw new TypeError('tags.images, when provided, must be an array.');\n }\n for (const image of tags.images) {\n if (!image || typeof image !== 'object') {\n throw new TypeError('Each image in tags.images must be an object.');\n }\n if (!(image.data instanceof Uint8Array)) {\n throw new TypeError('Each image.data must be a Uint8Array.');\n }\n if (typeof image.mimeType !== 'string') {\n throw new TypeError('Each image.mimeType must be a string.');\n }\n if (!['coverFront', 'coverBack', 'unknown'].includes(image.kind)) {\n throw new TypeError('Each image.kind must be \\'coverFront\\', \\'coverBack\\', or \\'unknown\\'.');\n }\n }\n }\n if (tags.comment !== undefined && typeof tags.comment !== 'string') {\n throw new TypeError('tags.comment, when provided, must be a string.');\n }\n if (tags.raw !== undefined) {\n if (!tags.raw || typeof tags.raw !== 'object') {\n throw new TypeError('tags.raw, when provided, must be an object.');\n }\n for (const value of Object.values(tags.raw)) {\n if (value !== null\n && typeof value !== 'string'\n && !(value instanceof Uint8Array)\n && !(value instanceof RichImageData)) {\n throw new TypeError('Each value in tags.raw must be a string, Uint8Array, RichImageData, or null.');\n }\n }\n }\n};\nexport const metadataTagsAreEmpty = (tags) => {\n return tags.title === undefined\n && tags.description === undefined\n && tags.artist === undefined\n && tags.album === undefined\n && tags.albumArtist === undefined\n && tags.trackNumber === undefined\n && tags.tracksTotal === undefined\n && tags.discNumber === undefined\n && tags.discsTotal === undefined\n && tags.genre === undefined\n && tags.date === undefined\n && tags.lyrics === undefined\n && (!tags.images || tags.images.length === 0)\n && tags.comment === undefined\n && (tags.raw === undefined || Object.keys(tags.raw).length === 0);\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { Bitstream, COLOR_PRIMARIES_MAP, MATRIX_COEFFICIENTS_MAP, TRANSFER_CHARACTERISTICS_MAP, assert, bytesToHexString, isAllowSharedBufferSource, last, reverseBitsU32, toDataView, } from './misc.js';\n/**\n * List of known video codecs, ordered by encoding preference.\n * @group Codecs\n * @public\n */\nexport const VIDEO_CODECS = [\n 'avc',\n 'hevc',\n 'vp9',\n 'av1',\n 'vp8',\n];\n/**\n * List of known PCM (uncompressed) audio codecs, ordered by encoding preference.\n * @group Codecs\n * @public\n */\nexport const PCM_AUDIO_CODECS = [\n 'pcm-s16', // We don't prefix 'le' so we're compatible with the WebCodecs-registered PCM codec strings\n 'pcm-s16be',\n 'pcm-s24',\n 'pcm-s24be',\n 'pcm-s32',\n 'pcm-s32be',\n 'pcm-f32',\n 'pcm-f32be',\n 'pcm-f64',\n 'pcm-f64be',\n 'pcm-u8',\n 'pcm-s8',\n 'ulaw',\n 'alaw',\n];\n/**\n * List of known compressed audio codecs, ordered by encoding preference.\n * @group Codecs\n * @public\n */\nexport const NON_PCM_AUDIO_CODECS = [\n 'aac',\n 'opus',\n 'mp3',\n 'vorbis',\n 'flac',\n];\n/**\n * List of known audio codecs, ordered by encoding preference.\n * @group Codecs\n * @public\n */\nexport const AUDIO_CODECS = [\n ...NON_PCM_AUDIO_CODECS,\n ...PCM_AUDIO_CODECS,\n];\n/**\n * List of known subtitle codecs, ordered by encoding preference.\n * @group Codecs\n * @public\n */\nexport const SUBTITLE_CODECS = [\n 'webvtt',\n]; // TODO add the rest\n// https://en.wikipedia.org/wiki/Advanced_Video_Coding\nconst AVC_LEVEL_TABLE = [\n { maxMacroblocks: 99, maxBitrate: 64000, level: 0x0A }, // Level 1\n { maxMacroblocks: 396, maxBitrate: 192000, level: 0x0B }, // Level 1.1\n { maxMacroblocks: 396, maxBitrate: 384000, level: 0x0C }, // Level 1.2\n { maxMacroblocks: 396, maxBitrate: 768000, level: 0x0D }, // Level 1.3\n { maxMacroblocks: 396, maxBitrate: 2000000, level: 0x14 }, // Level 2\n { maxMacroblocks: 792, maxBitrate: 4000000, level: 0x15 }, // Level 2.1\n { maxMacroblocks: 1620, maxBitrate: 4000000, level: 0x16 }, // Level 2.2\n { maxMacroblocks: 1620, maxBitrate: 10000000, level: 0x1E }, // Level 3\n { maxMacroblocks: 3600, maxBitrate: 14000000, level: 0x1F }, // Level 3.1\n { maxMacroblocks: 5120, maxBitrate: 20000000, level: 0x20 }, // Level 3.2\n { maxMacroblocks: 8192, maxBitrate: 20000000, level: 0x28 }, // Level 4\n { maxMacroblocks: 8192, maxBitrate: 50000000, level: 0x29 }, // Level 4.1\n { maxMacroblocks: 8704, maxBitrate: 50000000, level: 0x2A }, // Level 4.2\n { maxMacroblocks: 22080, maxBitrate: 135000000, level: 0x32 }, // Level 5\n { maxMacroblocks: 36864, maxBitrate: 240000000, level: 0x33 }, // Level 5.1\n { maxMacroblocks: 36864, maxBitrate: 240000000, level: 0x34 }, // Level 5.2\n { maxMacroblocks: 139264, maxBitrate: 240000000, level: 0x3C }, // Level 6\n { maxMacroblocks: 139264, maxBitrate: 480000000, level: 0x3D }, // Level 6.1\n { maxMacroblocks: 139264, maxBitrate: 800000000, level: 0x3E }, // Level 6.2\n];\n// https://en.wikipedia.org/wiki/High_Efficiency_Video_Coding\nconst HEVC_LEVEL_TABLE = [\n { maxPictureSize: 36864, maxBitrate: 128000, tier: 'L', level: 30 }, // Level 1 (Low Tier)\n { maxPictureSize: 122880, maxBitrate: 1500000, tier: 'L', level: 60 }, // Level 2 (Low Tier)\n { maxPictureSize: 245760, maxBitrate: 3000000, tier: 'L', level: 63 }, // Level 2.1 (Low Tier)\n { maxPictureSize: 552960, maxBitrate: 6000000, tier: 'L', level: 90 }, // Level 3 (Low Tier)\n { maxPictureSize: 983040, maxBitrate: 10000000, tier: 'L', level: 93 }, // Level 3.1 (Low Tier)\n { maxPictureSize: 2228224, maxBitrate: 12000000, tier: 'L', level: 120 }, // Level 4 (Low Tier)\n { maxPictureSize: 2228224, maxBitrate: 30000000, tier: 'H', level: 120 }, // Level 4 (High Tier)\n { maxPictureSize: 2228224, maxBitrate: 20000000, tier: 'L', level: 123 }, // Level 4.1 (Low Tier)\n { maxPictureSize: 2228224, maxBitrate: 50000000, tier: 'H', level: 123 }, // Level 4.1 (High Tier)\n { maxPictureSize: 8912896, maxBitrate: 25000000, tier: 'L', level: 150 }, // Level 5 (Low Tier)\n { maxPictureSize: 8912896, maxBitrate: 100000000, tier: 'H', level: 150 }, // Level 5 (High Tier)\n { maxPictureSize: 8912896, maxBitrate: 40000000, tier: 'L', level: 153 }, // Level 5.1 (Low Tier)\n { maxPictureSize: 8912896, maxBitrate: 160000000, tier: 'H', level: 153 }, // Level 5.1 (High Tier)\n { maxPictureSize: 8912896, maxBitrate: 60000000, tier: 'L', level: 156 }, // Level 5.2 (Low Tier)\n { maxPictureSize: 8912896, maxBitrate: 240000000, tier: 'H', level: 156 }, // Level 5.2 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 60000000, tier: 'L', level: 180 }, // Level 6 (Low Tier)\n { maxPictureSize: 35651584, maxBitrate: 240000000, tier: 'H', level: 180 }, // Level 6 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 120000000, tier: 'L', level: 183 }, // Level 6.1 (Low Tier)\n { maxPictureSize: 35651584, maxBitrate: 480000000, tier: 'H', level: 183 }, // Level 6.1 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 240000000, tier: 'L', level: 186 }, // Level 6.2 (Low Tier)\n { maxPictureSize: 35651584, maxBitrate: 800000000, tier: 'H', level: 186 }, // Level 6.2 (High Tier)\n];\n// https://en.wikipedia.org/wiki/VP9\nexport const VP9_LEVEL_TABLE = [\n { maxPictureSize: 36864, maxBitrate: 200000, level: 10 }, // Level 1\n { maxPictureSize: 73728, maxBitrate: 800000, level: 11 }, // Level 1.1\n { maxPictureSize: 122880, maxBitrate: 1800000, level: 20 }, // Level 2\n { maxPictureSize: 245760, maxBitrate: 3600000, level: 21 }, // Level 2.1\n { maxPictureSize: 552960, maxBitrate: 7200000, level: 30 }, // Level 3\n { maxPictureSize: 983040, maxBitrate: 12000000, level: 31 }, // Level 3.1\n { maxPictureSize: 2228224, maxBitrate: 18000000, level: 40 }, // Level 4\n { maxPictureSize: 2228224, maxBitrate: 30000000, level: 41 }, // Level 4.1\n { maxPictureSize: 8912896, maxBitrate: 60000000, level: 50 }, // Level 5\n { maxPictureSize: 8912896, maxBitrate: 120000000, level: 51 }, // Level 5.1\n { maxPictureSize: 8912896, maxBitrate: 180000000, level: 52 }, // Level 5.2\n { maxPictureSize: 35651584, maxBitrate: 180000000, level: 60 }, // Level 6\n { maxPictureSize: 35651584, maxBitrate: 240000000, level: 61 }, // Level 6.1\n { maxPictureSize: 35651584, maxBitrate: 480000000, level: 62 }, // Level 6.2\n];\n// https://en.wikipedia.org/wiki/AV1\nconst AV1_LEVEL_TABLE = [\n { maxPictureSize: 147456, maxBitrate: 1500000, tier: 'M', level: 0 }, // Level 2.0 (Main Tier)\n { maxPictureSize: 278784, maxBitrate: 3000000, tier: 'M', level: 1 }, // Level 2.1 (Main Tier)\n { maxPictureSize: 665856, maxBitrate: 6000000, tier: 'M', level: 4 }, // Level 3.0 (Main Tier)\n { maxPictureSize: 1065024, maxBitrate: 10000000, tier: 'M', level: 5 }, // Level 3.1 (Main Tier)\n { maxPictureSize: 2359296, maxBitrate: 12000000, tier: 'M', level: 8 }, // Level 4.0 (Main Tier)\n { maxPictureSize: 2359296, maxBitrate: 30000000, tier: 'H', level: 8 }, // Level 4.0 (High Tier)\n { maxPictureSize: 2359296, maxBitrate: 20000000, tier: 'M', level: 9 }, // Level 4.1 (Main Tier)\n { maxPictureSize: 2359296, maxBitrate: 50000000, tier: 'H', level: 9 }, // Level 4.1 (High Tier)\n { maxPictureSize: 8912896, maxBitrate: 30000000, tier: 'M', level: 12 }, // Level 5.0 (Main Tier)\n { maxPictureSize: 8912896, maxBitrate: 100000000, tier: 'H', level: 12 }, // Level 5.0 (High Tier)\n { maxPictureSize: 8912896, maxBitrate: 40000000, tier: 'M', level: 13 }, // Level 5.1 (Main Tier)\n { maxPictureSize: 8912896, maxBitrate: 160000000, tier: 'H', level: 13 }, // Level 5.1 (High Tier)\n { maxPictureSize: 8912896, maxBitrate: 60000000, tier: 'M', level: 14 }, // Level 5.2 (Main Tier)\n { maxPictureSize: 8912896, maxBitrate: 240000000, tier: 'H', level: 14 }, // Level 5.2 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 60000000, tier: 'M', level: 15 }, // Level 5.3 (Main Tier)\n { maxPictureSize: 35651584, maxBitrate: 240000000, tier: 'H', level: 15 }, // Level 5.3 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 60000000, tier: 'M', level: 16 }, // Level 6.0 (Main Tier)\n { maxPictureSize: 35651584, maxBitrate: 240000000, tier: 'H', level: 16 }, // Level 6.0 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 100000000, tier: 'M', level: 17 }, // Level 6.1 (Main Tier)\n { maxPictureSize: 35651584, maxBitrate: 480000000, tier: 'H', level: 17 }, // Level 6.1 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 160000000, tier: 'M', level: 18 }, // Level 6.2 (Main Tier)\n { maxPictureSize: 35651584, maxBitrate: 800000000, tier: 'H', level: 18 }, // Level 6.2 (High Tier)\n { maxPictureSize: 35651584, maxBitrate: 160000000, tier: 'M', level: 19 }, // Level 6.3 (Main Tier)\n { maxPictureSize: 35651584, maxBitrate: 800000000, tier: 'H', level: 19 }, // Level 6.3 (High Tier)\n];\nconst VP9_DEFAULT_SUFFIX = '.01.01.01.01.00';\nconst AV1_DEFAULT_SUFFIX = '.0.110.01.01.01.0';\nexport const buildVideoCodecString = (codec, width, height, bitrate) => {\n if (codec === 'avc') {\n const profileIndication = 0x64; // High Profile\n const totalMacroblocks = Math.ceil(width / 16) * Math.ceil(height / 16);\n // Determine the level based on the table\n const levelInfo = AVC_LEVEL_TABLE.find(level => totalMacroblocks <= level.maxMacroblocks && bitrate <= level.maxBitrate) ?? last(AVC_LEVEL_TABLE);\n const levelIndication = levelInfo ? levelInfo.level : 0;\n const hexProfileIndication = profileIndication.toString(16).padStart(2, '0');\n const hexProfileCompatibility = '00';\n const hexLevelIndication = levelIndication.toString(16).padStart(2, '0');\n return `avc1.${hexProfileIndication}${hexProfileCompatibility}${hexLevelIndication}`;\n }\n else if (codec === 'hevc') {\n const profilePrefix = ''; // Profile space 0\n const profileIdc = 1; // Main Profile\n const compatibilityFlags = '6'; // Taken from the example in ISO 14496-15\n const pictureSize = width * height;\n const levelInfo = HEVC_LEVEL_TABLE.find(level => pictureSize <= level.maxPictureSize && bitrate <= level.maxBitrate) ?? last(HEVC_LEVEL_TABLE);\n const constraintFlags = 'B0'; // Progressive source flag\n return 'hev1.'\n + `${profilePrefix}${profileIdc}.`\n + `${compatibilityFlags}.`\n + `${levelInfo.tier}${levelInfo.level}.`\n + `${constraintFlags}`;\n }\n else if (codec === 'vp8') {\n return 'vp8'; // Easy, this one\n }\n else if (codec === 'vp9') {\n const profile = '00'; // Profile 0\n const pictureSize = width * height;\n const levelInfo = VP9_LEVEL_TABLE.find(level => pictureSize <= level.maxPictureSize && bitrate <= level.maxBitrate) ?? last(VP9_LEVEL_TABLE);\n const bitDepth = '08'; // 8-bit\n return `vp09.${profile}.${levelInfo.level.toString().padStart(2, '0')}.${bitDepth}`;\n }\n else if (codec === 'av1') {\n const profile = 0; // Main Profile, single digit\n const pictureSize = width * height;\n const levelInfo = AV1_LEVEL_TABLE.find(level => pictureSize <= level.maxPictureSize && bitrate <= level.maxBitrate) ?? last(AV1_LEVEL_TABLE);\n const level = levelInfo.level.toString().padStart(2, '0');\n const bitDepth = '08'; // 8-bit\n return `av01.${profile}.${level}${levelInfo.tier}.${bitDepth}`;\n }\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new TypeError(`Unhandled codec '${codec}'.`);\n};\nexport const generateVp9CodecConfigurationFromCodecString = (codecString) => {\n // Reference: https://www.webmproject.org/docs/container/#vp9-codec-feature-metadata-codecprivate\n const parts = codecString.split('.'); // We can derive the required values from the codec string\n const profile = Number(parts[1]);\n const level = Number(parts[2]);\n const bitDepth = Number(parts[3]);\n const chromaSubsampling = parts[4] ? Number(parts[4]) : 1;\n return [\n 1, 1, profile,\n 2, 1, level,\n 3, 1, bitDepth,\n 4, 1, chromaSubsampling,\n ];\n};\nexport const generateAv1CodecConfigurationFromCodecString = (codecString) => {\n // Reference: https://aomediacodec.github.io/av1-isobmff/\n const parts = codecString.split('.'); // We can derive the required values from the codec string\n const marker = 1;\n const version = 1;\n const firstByte = (marker << 7) + version;\n const profile = Number(parts[1]);\n const levelAndTier = parts[2];\n const level = Number(levelAndTier.slice(0, -1));\n const secondByte = (profile << 5) + level;\n const tier = levelAndTier.slice(-1) === 'H' ? 1 : 0;\n const bitDepth = Number(parts[3]);\n const highBitDepth = bitDepth === 8 ? 0 : 1;\n const twelveBit = 0;\n const monochrome = parts[4] ? Number(parts[4]) : 0;\n const chromaSubsamplingX = parts[5] ? Number(parts[5][0]) : 1;\n const chromaSubsamplingY = parts[5] ? Number(parts[5][1]) : 1;\n const chromaSamplePosition = parts[5] ? Number(parts[5][2]) : 0; // CSP_UNKNOWN\n const thirdByte = (tier << 7)\n + (highBitDepth << 6)\n + (twelveBit << 5)\n + (monochrome << 4)\n + (chromaSubsamplingX << 3)\n + (chromaSubsamplingY << 2)\n + chromaSamplePosition;\n const initialPresentationDelayPresent = 0; // Should be fine\n const fourthByte = initialPresentationDelayPresent;\n return [firstByte, secondByte, thirdByte, fourthByte];\n};\nexport const extractVideoCodecString = (trackInfo) => {\n const { codec, codecDescription, colorSpace, avcCodecInfo, hevcCodecInfo, vp9CodecInfo, av1CodecInfo } = trackInfo;\n if (codec === 'avc') {\n if (avcCodecInfo) {\n const bytes = new Uint8Array([\n avcCodecInfo.avcProfileIndication,\n avcCodecInfo.profileCompatibility,\n avcCodecInfo.avcLevelIndication,\n ]);\n return `avc1.${bytesToHexString(bytes)}`;\n }\n if (!codecDescription || codecDescription.byteLength < 4) {\n throw new TypeError('AVC decoder description is not provided or is not at least 4 bytes long.');\n }\n return `avc1.${bytesToHexString(codecDescription.subarray(1, 4))}`;\n }\n else if (codec === 'hevc') {\n let generalProfileSpace;\n let generalProfileIdc;\n let compatibilityFlags;\n let generalTierFlag;\n let generalLevelIdc;\n let constraintFlags;\n if (hevcCodecInfo) {\n generalProfileSpace = hevcCodecInfo.generalProfileSpace;\n generalProfileIdc = hevcCodecInfo.generalProfileIdc;\n compatibilityFlags = reverseBitsU32(hevcCodecInfo.generalProfileCompatibilityFlags);\n generalTierFlag = hevcCodecInfo.generalTierFlag;\n generalLevelIdc = hevcCodecInfo.generalLevelIdc;\n constraintFlags = [...hevcCodecInfo.generalConstraintIndicatorFlags];\n }\n else {\n if (!codecDescription || codecDescription.byteLength < 23) {\n throw new TypeError('HEVC decoder description is not provided or is not at least 23 bytes long.');\n }\n const view = toDataView(codecDescription);\n const profileByte = view.getUint8(1);\n generalProfileSpace = (profileByte >> 6) & 0x03;\n generalProfileIdc = profileByte & 0x1F;\n compatibilityFlags = reverseBitsU32(view.getUint32(2));\n generalTierFlag = (profileByte >> 5) & 0x01;\n generalLevelIdc = view.getUint8(12);\n constraintFlags = [];\n for (let i = 0; i < 6; i++) {\n constraintFlags.push(view.getUint8(6 + i));\n }\n }\n let codecString = 'hev1.';\n codecString += ['', 'A', 'B', 'C'][generalProfileSpace] + generalProfileIdc;\n codecString += '.';\n codecString += compatibilityFlags.toString(16).toUpperCase();\n codecString += '.';\n codecString += generalTierFlag === 0 ? 'L' : 'H';\n codecString += generalLevelIdc;\n while (constraintFlags.length > 0 && constraintFlags[constraintFlags.length - 1] === 0) {\n constraintFlags.pop();\n }\n if (constraintFlags.length > 0) {\n codecString += '.';\n codecString += constraintFlags.map(x => x.toString(16).toUpperCase()).join('.');\n }\n return codecString;\n }\n else if (codec === 'vp8') {\n return 'vp8'; // Easy, this one\n }\n else if (codec === 'vp9') {\n if (!vp9CodecInfo) {\n // Calculate level based on dimensions\n const pictureSize = trackInfo.width * trackInfo.height;\n let level = last(VP9_LEVEL_TABLE).level; // Default to highest level\n for (const entry of VP9_LEVEL_TABLE) {\n if (pictureSize <= entry.maxPictureSize) {\n level = entry.level;\n break;\n }\n }\n // We don't really know better, so let's return a general-purpose, common codec string and hope for the best\n return `vp09.00.${level.toString().padStart(2, '0')}.08`;\n }\n const profile = vp9CodecInfo.profile.toString().padStart(2, '0');\n const level = vp9CodecInfo.level.toString().padStart(2, '0');\n const bitDepth = vp9CodecInfo.bitDepth.toString().padStart(2, '0');\n const chromaSubsampling = vp9CodecInfo.chromaSubsampling.toString().padStart(2, '0');\n const colourPrimaries = vp9CodecInfo.colourPrimaries.toString().padStart(2, '0');\n const transferCharacteristics = vp9CodecInfo.transferCharacteristics.toString().padStart(2, '0');\n const matrixCoefficients = vp9CodecInfo.matrixCoefficients.toString().padStart(2, '0');\n const videoFullRangeFlag = vp9CodecInfo.videoFullRangeFlag.toString().padStart(2, '0');\n let string = `vp09.${profile}.${level}.${bitDepth}.${chromaSubsampling}`;\n string += `.${colourPrimaries}.${transferCharacteristics}.${matrixCoefficients}.${videoFullRangeFlag}`;\n if (string.endsWith(VP9_DEFAULT_SUFFIX)) {\n string = string.slice(0, -VP9_DEFAULT_SUFFIX.length);\n }\n return string;\n }\n else if (codec === 'av1') {\n if (!av1CodecInfo) {\n // Calculate level based on dimensions\n const pictureSize = trackInfo.width * trackInfo.height;\n let level = last(VP9_LEVEL_TABLE).level; // Default to highest level\n for (const entry of VP9_LEVEL_TABLE) {\n if (pictureSize <= entry.maxPictureSize) {\n level = entry.level;\n break;\n }\n }\n // We don't really know better, so let's return a general-purpose, common codec string and hope for the best\n return `av01.0.${level.toString().padStart(2, '0')}M.08`;\n }\n // https://aomediacodec.github.io/av1-isobmff/#codecsparam\n const profile = av1CodecInfo.profile; // Single digit\n const level = av1CodecInfo.level.toString().padStart(2, '0');\n const tier = av1CodecInfo.tier ? 'H' : 'M';\n const bitDepth = av1CodecInfo.bitDepth.toString().padStart(2, '0');\n const monochrome = av1CodecInfo.monochrome ? '1' : '0';\n const chromaSubsampling = 100 * av1CodecInfo.chromaSubsamplingX\n + 10 * av1CodecInfo.chromaSubsamplingY\n + 1 * (av1CodecInfo.chromaSubsamplingX && av1CodecInfo.chromaSubsamplingY\n ? av1CodecInfo.chromaSamplePosition\n : 0);\n // The defaults are 1 (ITU-R BT.709)\n const colorPrimaries = colorSpace?.primaries ? COLOR_PRIMARIES_MAP[colorSpace.primaries] : 1;\n const transferCharacteristics = colorSpace?.transfer ? TRANSFER_CHARACTERISTICS_MAP[colorSpace.transfer] : 1;\n const matrixCoefficients = colorSpace?.matrix ? MATRIX_COEFFICIENTS_MAP[colorSpace.matrix] : 1;\n const videoFullRangeFlag = colorSpace?.fullRange ? 1 : 0;\n let string = `av01.${profile}.${level}${tier}.${bitDepth}`;\n string += `.${monochrome}.${chromaSubsampling.toString().padStart(3, '0')}`;\n string += `.${colorPrimaries.toString().padStart(2, '0')}`;\n string += `.${transferCharacteristics.toString().padStart(2, '0')}`;\n string += `.${matrixCoefficients.toString().padStart(2, '0')}`;\n string += `.${videoFullRangeFlag}`;\n if (string.endsWith(AV1_DEFAULT_SUFFIX)) {\n string = string.slice(0, -AV1_DEFAULT_SUFFIX.length);\n }\n return string;\n }\n throw new TypeError(`Unhandled codec '${codec}'.`);\n};\nexport const buildAudioCodecString = (codec, numberOfChannels, sampleRate) => {\n if (codec === 'aac') {\n // If stereo or higher channels and lower sample rate, likely using HE-AAC v2 with PS\n if (numberOfChannels >= 2 && sampleRate <= 24000) {\n return 'mp4a.40.29'; // HE-AAC v2 (AAC LC + SBR + PS)\n }\n // If sample rate is low, likely using HE-AAC v1 with SBR\n if (sampleRate <= 24000) {\n return 'mp4a.40.5'; // HE-AAC v1 (AAC LC + SBR)\n }\n // Default to standard AAC-LC for higher sample rates\n return 'mp4a.40.2'; // AAC-LC\n }\n else if (codec === 'mp3') {\n return 'mp3';\n }\n else if (codec === 'opus') {\n return 'opus';\n }\n else if (codec === 'vorbis') {\n return 'vorbis';\n }\n else if (codec === 'flac') {\n return 'flac';\n }\n else if (PCM_AUDIO_CODECS.includes(codec)) {\n return codec;\n }\n throw new TypeError(`Unhandled codec '${codec}'.`);\n};\nexport const extractAudioCodecString = (trackInfo) => {\n const { codec, codecDescription, aacCodecInfo } = trackInfo;\n if (codec === 'aac') {\n if (!aacCodecInfo) {\n throw new TypeError('AAC codec info must be provided.');\n }\n if (aacCodecInfo.isMpeg2) {\n return 'mp4a.67';\n }\n else {\n const audioSpecificConfig = parseAacAudioSpecificConfig(codecDescription);\n return `mp4a.40.${audioSpecificConfig.objectType}`;\n }\n }\n else if (codec === 'mp3') {\n return 'mp3';\n }\n else if (codec === 'opus') {\n return 'opus';\n }\n else if (codec === 'vorbis') {\n return 'vorbis';\n }\n else if (codec === 'flac') {\n return 'flac';\n }\n else if (codec && PCM_AUDIO_CODECS.includes(codec)) {\n return codec;\n }\n throw new TypeError(`Unhandled codec '${codec}'.`);\n};\nexport const aacFrequencyTable = [\n 96000, 88200, 64000, 48000, 44100, 32000,\n 24000, 22050, 16000, 12000, 11025, 8000, 7350,\n];\nexport const aacChannelMap = [-1, 1, 2, 3, 4, 5, 6, 8];\nexport const parseAacAudioSpecificConfig = (bytes) => {\n if (!bytes || bytes.byteLength < 2) {\n throw new TypeError('AAC description must be at least 2 bytes long.');\n }\n const bitstream = new Bitstream(bytes);\n let objectType = bitstream.readBits(5);\n if (objectType === 31) {\n objectType = 32 + bitstream.readBits(6);\n }\n const frequencyIndex = bitstream.readBits(4);\n let sampleRate = null;\n if (frequencyIndex === 15) {\n sampleRate = bitstream.readBits(24);\n }\n else {\n if (frequencyIndex < aacFrequencyTable.length) {\n sampleRate = aacFrequencyTable[frequencyIndex];\n }\n }\n const channelConfiguration = bitstream.readBits(4);\n let numberOfChannels = null;\n if (channelConfiguration >= 1 && channelConfiguration <= 7) {\n numberOfChannels = aacChannelMap[channelConfiguration];\n }\n return {\n objectType,\n frequencyIndex,\n sampleRate,\n channelConfiguration,\n numberOfChannels,\n };\n};\nexport const OPUS_INTERNAL_SAMPLE_RATE = 48000;\nconst PCM_CODEC_REGEX = /^pcm-([usf])(\\d+)+(be)?$/;\nexport const parsePcmCodec = (codec) => {\n assert(PCM_AUDIO_CODECS.includes(codec));\n if (codec === 'ulaw') {\n return { dataType: 'ulaw', sampleSize: 1, littleEndian: true, silentValue: 255 };\n }\n else if (codec === 'alaw') {\n return { dataType: 'alaw', sampleSize: 1, littleEndian: true, silentValue: 213 };\n }\n const match = PCM_CODEC_REGEX.exec(codec);\n assert(match);\n let dataType;\n if (match[1] === 'u') {\n dataType = 'unsigned';\n }\n else if (match[1] === 's') {\n dataType = 'signed';\n }\n else {\n dataType = 'float';\n }\n const sampleSize = (Number(match[2]) / 8);\n const littleEndian = match[3] !== 'be';\n const silentValue = codec === 'pcm-u8' ? 2 ** 7 : 0;\n return { dataType, sampleSize, littleEndian, silentValue };\n};\nexport const inferCodecFromCodecString = (codecString) => {\n // Video codecs\n if (codecString.startsWith('avc1') || codecString.startsWith('avc3')) {\n return 'avc';\n }\n else if (codecString.startsWith('hev1') || codecString.startsWith('hvc1')) {\n return 'hevc';\n }\n else if (codecString === 'vp8') {\n return 'vp8';\n }\n else if (codecString.startsWith('vp09')) {\n return 'vp9';\n }\n else if (codecString.startsWith('av01')) {\n return 'av1';\n }\n // Audio codecs\n if (codecString.startsWith('mp4a.40') || codecString === 'mp4a.67') {\n return 'aac';\n }\n else if (codecString === 'mp3'\n || codecString === 'mp4a.69'\n || codecString === 'mp4a.6B'\n || codecString === 'mp4a.6b') {\n return 'mp3';\n }\n else if (codecString === 'opus') {\n return 'opus';\n }\n else if (codecString === 'vorbis') {\n return 'vorbis';\n }\n else if (codecString === 'flac') {\n return 'flac';\n }\n else if (codecString === 'ulaw') {\n return 'ulaw';\n }\n else if (codecString === 'alaw') {\n return 'alaw';\n }\n else if (PCM_CODEC_REGEX.test(codecString)) {\n return codecString;\n }\n // Subtitle codecs\n if (codecString === 'webvtt') {\n return 'webvtt';\n }\n return null;\n};\nexport const getVideoEncoderConfigExtension = (codec) => {\n if (codec === 'avc') {\n return {\n avc: {\n format: 'avc', // Ensure the format is not Annex B\n },\n };\n }\n else if (codec === 'hevc') {\n return {\n hevc: {\n format: 'hevc', // Ensure the format is not Annex B\n },\n };\n }\n return {};\n};\nexport const getAudioEncoderConfigExtension = (codec) => {\n if (codec === 'aac') {\n return {\n aac: {\n format: 'aac', // Ensure the format is not ADTS\n },\n };\n }\n else if (codec === 'opus') {\n return {\n opus: {\n format: 'opus',\n },\n };\n }\n return {};\n};\nconst VALID_VIDEO_CODEC_STRING_PREFIXES = ['avc1', 'avc3', 'hev1', 'hvc1', 'vp8', 'vp09', 'av01'];\nconst AVC_CODEC_STRING_REGEX = /^(avc1|avc3)\\.[0-9a-fA-F]{6}$/;\nconst HEVC_CODEC_STRING_REGEX = /^(hev1|hvc1)\\.(?:[ABC]?\\d+)\\.[0-9a-fA-F]{1,8}\\.[LH]\\d+(?:\\.[0-9a-fA-F]{1,2}){0,6}$/;\nconst VP9_CODEC_STRING_REGEX = /^vp09(?:\\.\\d{2}){3}(?:(?:\\.\\d{2}){5})?$/;\nconst AV1_CODEC_STRING_REGEX = /^av01\\.\\d\\.\\d{2}[MH]\\.\\d{2}(?:\\.\\d\\.\\d{3}\\.\\d{2}\\.\\d{2}\\.\\d{2}\\.\\d)?$/;\nexport const validateVideoChunkMetadata = (metadata) => {\n if (!metadata) {\n throw new TypeError('Video chunk metadata must be provided.');\n }\n if (typeof metadata !== 'object') {\n throw new TypeError('Video chunk metadata must be an object.');\n }\n if (!metadata.decoderConfig) {\n throw new TypeError('Video chunk metadata must include a decoder configuration.');\n }\n if (typeof metadata.decoderConfig !== 'object') {\n throw new TypeError('Video chunk metadata decoder configuration must be an object.');\n }\n if (typeof metadata.decoderConfig.codec !== 'string') {\n throw new TypeError('Video chunk metadata decoder configuration must specify a codec string.');\n }\n if (!VALID_VIDEO_CODEC_STRING_PREFIXES.some(prefix => metadata.decoderConfig.codec.startsWith(prefix))) {\n throw new TypeError('Video chunk metadata decoder configuration codec string must be a valid video codec string as specified in'\n + ' the WebCodecs Codec Registry.');\n }\n if (!Number.isInteger(metadata.decoderConfig.codedWidth) || metadata.decoderConfig.codedWidth <= 0) {\n throw new TypeError('Video chunk metadata decoder configuration must specify a valid codedWidth (positive integer).');\n }\n if (!Number.isInteger(metadata.decoderConfig.codedHeight) || metadata.decoderConfig.codedHeight <= 0) {\n throw new TypeError('Video chunk metadata decoder configuration must specify a valid codedHeight (positive integer).');\n }\n if (metadata.decoderConfig.description !== undefined) {\n if (!isAllowSharedBufferSource(metadata.decoderConfig.description)) {\n throw new TypeError('Video chunk metadata decoder configuration description, when defined, must be an ArrayBuffer or an'\n + ' ArrayBuffer view.');\n }\n }\n if (metadata.decoderConfig.colorSpace !== undefined) {\n const { colorSpace } = metadata.decoderConfig;\n if (typeof colorSpace !== 'object') {\n throw new TypeError('Video chunk metadata decoder configuration colorSpace, when provided, must be an object.');\n }\n const primariesValues = Object.keys(COLOR_PRIMARIES_MAP);\n if (colorSpace.primaries != null && !primariesValues.includes(colorSpace.primaries)) {\n throw new TypeError(`Video chunk metadata decoder configuration colorSpace primaries, when defined, must be one of`\n + ` ${primariesValues.join(', ')}.`);\n }\n const transferValues = Object.keys(TRANSFER_CHARACTERISTICS_MAP);\n if (colorSpace.transfer != null && !transferValues.includes(colorSpace.transfer)) {\n throw new TypeError(`Video chunk metadata decoder configuration colorSpace transfer, when defined, must be one of`\n + ` ${transferValues.join(', ')}.`);\n }\n const matrixValues = Object.keys(MATRIX_COEFFICIENTS_MAP);\n if (colorSpace.matrix != null && !matrixValues.includes(colorSpace.matrix)) {\n throw new TypeError(`Video chunk metadata decoder configuration colorSpace matrix, when defined, must be one of`\n + ` ${matrixValues.join(', ')}.`);\n }\n if (colorSpace.fullRange != null && typeof colorSpace.fullRange !== 'boolean') {\n throw new TypeError('Video chunk metadata decoder configuration colorSpace fullRange, when defined, must be a boolean.');\n }\n }\n if (metadata.decoderConfig.codec.startsWith('avc1') || metadata.decoderConfig.codec.startsWith('avc3')) {\n // AVC-specific validation\n if (!AVC_CODEC_STRING_REGEX.test(metadata.decoderConfig.codec)) {\n throw new TypeError('Video chunk metadata decoder configuration codec string for AVC must be a valid AVC codec string as'\n + ' specified in Section 3.4 of RFC 6381.');\n }\n // `description` may or may not be set, depending on if the format is AVCC or Annex B, so don't perform any\n // validation for it.\n // https://www.w3.org/TR/webcodecs-avc-codec-registration\n }\n else if (metadata.decoderConfig.codec.startsWith('hev1') || metadata.decoderConfig.codec.startsWith('hvc1')) {\n // HEVC-specific validation\n if (!HEVC_CODEC_STRING_REGEX.test(metadata.decoderConfig.codec)) {\n throw new TypeError('Video chunk metadata decoder configuration codec string for HEVC must be a valid HEVC codec string as'\n + ' specified in Section E.3 of ISO 14496-15.');\n }\n // `description` may or may not be set, depending on if the format is HEVC or Annex B, so don't perform any\n // validation for it.\n // https://www.w3.org/TR/webcodecs-hevc-codec-registration\n }\n else if (metadata.decoderConfig.codec.startsWith('vp8')) {\n // VP8-specific validation\n if (metadata.decoderConfig.codec !== 'vp8') {\n throw new TypeError('Video chunk metadata decoder configuration codec string for VP8 must be \"vp8\".');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('vp09')) {\n // VP9-specific validation\n if (!VP9_CODEC_STRING_REGEX.test(metadata.decoderConfig.codec)) {\n throw new TypeError('Video chunk metadata decoder configuration codec string for VP9 must be a valid VP9 codec string as'\n + ' specified in Section \"Codecs Parameter String\" of https://www.webmproject.org/vp9/mp4/.');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('av01')) {\n // AV1-specific validation\n if (!AV1_CODEC_STRING_REGEX.test(metadata.decoderConfig.codec)) {\n throw new TypeError('Video chunk metadata decoder configuration codec string for AV1 must be a valid AV1 codec string as'\n + ' specified in Section \"Codecs Parameter String\" of https://aomediacodec.github.io/av1-isobmff/.');\n }\n }\n};\nconst VALID_AUDIO_CODEC_STRING_PREFIXES = ['mp4a', 'mp3', 'opus', 'vorbis', 'flac', 'ulaw', 'alaw', 'pcm'];\nexport const validateAudioChunkMetadata = (metadata) => {\n if (!metadata) {\n throw new TypeError('Audio chunk metadata must be provided.');\n }\n if (typeof metadata !== 'object') {\n throw new TypeError('Audio chunk metadata must be an object.');\n }\n if (!metadata.decoderConfig) {\n throw new TypeError('Audio chunk metadata must include a decoder configuration.');\n }\n if (typeof metadata.decoderConfig !== 'object') {\n throw new TypeError('Audio chunk metadata decoder configuration must be an object.');\n }\n if (typeof metadata.decoderConfig.codec !== 'string') {\n throw new TypeError('Audio chunk metadata decoder configuration must specify a codec string.');\n }\n if (!VALID_AUDIO_CODEC_STRING_PREFIXES.some(prefix => metadata.decoderConfig.codec.startsWith(prefix))) {\n throw new TypeError('Audio chunk metadata decoder configuration codec string must be a valid audio codec string as specified in'\n + ' the WebCodecs Codec Registry.');\n }\n if (!Number.isInteger(metadata.decoderConfig.sampleRate) || metadata.decoderConfig.sampleRate <= 0) {\n throw new TypeError('Audio chunk metadata decoder configuration must specify a valid sampleRate (positive integer).');\n }\n if (!Number.isInteger(metadata.decoderConfig.numberOfChannels) || metadata.decoderConfig.numberOfChannels <= 0) {\n throw new TypeError('Audio chunk metadata decoder configuration must specify a valid numberOfChannels (positive integer).');\n }\n if (metadata.decoderConfig.description !== undefined) {\n if (!isAllowSharedBufferSource(metadata.decoderConfig.description)) {\n throw new TypeError('Audio chunk metadata decoder configuration description, when defined, must be an ArrayBuffer or an'\n + ' ArrayBuffer view.');\n }\n }\n if (metadata.decoderConfig.codec.startsWith('mp4a')\n // These three refer to MP3:\n && metadata.decoderConfig.codec !== 'mp4a.69'\n && metadata.decoderConfig.codec !== 'mp4a.6B'\n && metadata.decoderConfig.codec !== 'mp4a.6b') {\n // AAC-specific validation\n const validStrings = ['mp4a.40.2', 'mp4a.40.02', 'mp4a.40.5', 'mp4a.40.05', 'mp4a.40.29', 'mp4a.67'];\n if (!validStrings.includes(metadata.decoderConfig.codec)) {\n throw new TypeError('Audio chunk metadata decoder configuration codec string for AAC must be a valid AAC codec string as'\n + ' specified in https://www.w3.org/TR/webcodecs-aac-codec-registration/.');\n }\n if (!metadata.decoderConfig.description) {\n throw new TypeError('Audio chunk metadata decoder configuration for AAC must include a description, which is expected to be'\n + ' an AudioSpecificConfig as specified in ISO 14496-3.');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('mp3') || metadata.decoderConfig.codec.startsWith('mp4a')) {\n // MP3-specific validation\n if (metadata.decoderConfig.codec !== 'mp3'\n && metadata.decoderConfig.codec !== 'mp4a.69'\n && metadata.decoderConfig.codec !== 'mp4a.6B'\n && metadata.decoderConfig.codec !== 'mp4a.6b') {\n throw new TypeError('Audio chunk metadata decoder configuration codec string for MP3 must be \"mp3\", \"mp4a.69\" or'\n + ' \"mp4a.6B\".');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('opus')) {\n // Opus-specific validation\n if (metadata.decoderConfig.codec !== 'opus') {\n throw new TypeError('Audio chunk metadata decoder configuration codec string for Opus must be \"opus\".');\n }\n if (metadata.decoderConfig.description && metadata.decoderConfig.description.byteLength < 18) {\n // Description is optional for Opus per-spec, so we shouldn't enforce it\n throw new TypeError('Audio chunk metadata decoder configuration description, when specified, is expected to be an'\n + ' Identification Header as specified in Section 5.1 of RFC 7845.');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('vorbis')) {\n // Vorbis-specific validation\n if (metadata.decoderConfig.codec !== 'vorbis') {\n throw new TypeError('Audio chunk metadata decoder configuration codec string for Vorbis must be \"vorbis\".');\n }\n if (!metadata.decoderConfig.description) {\n throw new TypeError('Audio chunk metadata decoder configuration for Vorbis must include a description, which is expected to'\n + ' adhere to the format described in https://www.w3.org/TR/webcodecs-vorbis-codec-registration/.');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('flac')) {\n // FLAC-specific validation\n if (metadata.decoderConfig.codec !== 'flac') {\n throw new TypeError('Audio chunk metadata decoder configuration codec string for FLAC must be \"flac\".');\n }\n const minDescriptionSize = 4 + 4 + 34; // 'fLaC' + metadata block header + STREAMINFO block\n if (!metadata.decoderConfig.description || metadata.decoderConfig.description.byteLength < minDescriptionSize) {\n throw new TypeError('Audio chunk metadata decoder configuration for FLAC must include a description, which is expected to'\n + ' adhere to the format described in https://www.w3.org/TR/webcodecs-flac-codec-registration/.');\n }\n }\n else if (metadata.decoderConfig.codec.startsWith('pcm')\n || metadata.decoderConfig.codec.startsWith('ulaw')\n || metadata.decoderConfig.codec.startsWith('alaw')) {\n // PCM-specific validation\n if (!PCM_AUDIO_CODECS.includes(metadata.decoderConfig.codec)) {\n throw new TypeError('Audio chunk metadata decoder configuration codec string for PCM must be one of the supported PCM'\n + ` codecs (${PCM_AUDIO_CODECS.join(', ')}).`);\n }\n }\n};\nexport const validateSubtitleMetadata = (metadata) => {\n if (!metadata) {\n throw new TypeError('Subtitle metadata must be provided.');\n }\n if (typeof metadata !== 'object') {\n throw new TypeError('Subtitle metadata must be an object.');\n }\n if (!metadata.config) {\n throw new TypeError('Subtitle metadata must include a config object.');\n }\n if (typeof metadata.config !== 'object') {\n throw new TypeError('Subtitle metadata config must be an object.');\n }\n if (typeof metadata.config.description !== 'string') {\n throw new TypeError('Subtitle metadata config description must be a string.');\n }\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { VP9_LEVEL_TABLE } from './codec.js';\nimport { assert, assertNever, Bitstream, last, readExpGolomb, readSignedExpGolomb, toDataView, toUint8Array, } from './misc.js';\n// References for AVC/HEVC code:\n// ISO 14496-15\n// Rec. ITU-T H.264\n// Rec. ITU-T H.265\n// https://stackoverflow.com/questions/24884827\nexport var AvcNalUnitType;\n(function (AvcNalUnitType) {\n AvcNalUnitType[AvcNalUnitType[\"IDR\"] = 5] = \"IDR\";\n AvcNalUnitType[AvcNalUnitType[\"SPS\"] = 7] = \"SPS\";\n AvcNalUnitType[AvcNalUnitType[\"PPS\"] = 8] = \"PPS\";\n AvcNalUnitType[AvcNalUnitType[\"SPS_EXT\"] = 13] = \"SPS_EXT\";\n})(AvcNalUnitType || (AvcNalUnitType = {}));\nexport var HevcNalUnitType;\n(function (HevcNalUnitType) {\n HevcNalUnitType[HevcNalUnitType[\"RASL_N\"] = 8] = \"RASL_N\";\n HevcNalUnitType[HevcNalUnitType[\"RASL_R\"] = 9] = \"RASL_R\";\n HevcNalUnitType[HevcNalUnitType[\"BLA_W_LP\"] = 16] = \"BLA_W_LP\";\n HevcNalUnitType[HevcNalUnitType[\"RSV_IRAP_VCL23\"] = 23] = \"RSV_IRAP_VCL23\";\n HevcNalUnitType[HevcNalUnitType[\"VPS_NUT\"] = 32] = \"VPS_NUT\";\n HevcNalUnitType[HevcNalUnitType[\"SPS_NUT\"] = 33] = \"SPS_NUT\";\n HevcNalUnitType[HevcNalUnitType[\"PPS_NUT\"] = 34] = \"PPS_NUT\";\n HevcNalUnitType[HevcNalUnitType[\"PREFIX_SEI_NUT\"] = 39] = \"PREFIX_SEI_NUT\";\n HevcNalUnitType[HevcNalUnitType[\"SUFFIX_SEI_NUT\"] = 40] = \"SUFFIX_SEI_NUT\";\n})(HevcNalUnitType || (HevcNalUnitType = {}));\n/** Finds all NAL units in an AVC packet in Annex B format. */\nexport const findNalUnitsInAnnexB = (packetData) => {\n const nalUnits = [];\n let i = 0;\n while (i < packetData.length) {\n let startCodePos = -1;\n let startCodeLength = 0;\n for (let j = i; j < packetData.length - 3; j++) {\n // Check for 3-byte start code (0x000001)\n if (packetData[j] === 0 && packetData[j + 1] === 0 && packetData[j + 2] === 1) {\n startCodePos = j;\n startCodeLength = 3;\n break;\n }\n // Check for 4-byte start code (0x00000001)\n if (j < packetData.length - 4\n && packetData[j] === 0\n && packetData[j + 1] === 0\n && packetData[j + 2] === 0\n && packetData[j + 3] === 1) {\n startCodePos = j;\n startCodeLength = 4;\n break;\n }\n }\n if (startCodePos === -1) {\n break; // No more start codes found\n }\n // If this isn't the first start code, extract the previous NAL unit\n if (i > 0 && startCodePos > i) {\n const nalData = packetData.subarray(i, startCodePos);\n if (nalData.length > 0) {\n nalUnits.push(nalData);\n }\n }\n i = startCodePos + startCodeLength;\n }\n // Extract the last NAL unit if there is one\n if (i < packetData.length) {\n const nalData = packetData.subarray(i);\n if (nalData.length > 0) {\n nalUnits.push(nalData);\n }\n }\n return nalUnits;\n};\n/** Finds all NAL units in an AVC packet in length-prefixed format. */\nconst findNalUnitsInLengthPrefixed = (packetData, lengthSize) => {\n const nalUnits = [];\n let offset = 0;\n const dataView = new DataView(packetData.buffer, packetData.byteOffset, packetData.byteLength);\n while (offset + lengthSize <= packetData.length) {\n let nalUnitLength;\n if (lengthSize === 1) {\n nalUnitLength = dataView.getUint8(offset);\n }\n else if (lengthSize === 2) {\n nalUnitLength = dataView.getUint16(offset, false);\n }\n else if (lengthSize === 3) {\n nalUnitLength = (dataView.getUint16(offset, false) << 8) + dataView.getUint8(offset + 2);\n }\n else if (lengthSize === 4) {\n nalUnitLength = dataView.getUint32(offset, false);\n }\n else {\n assertNever(lengthSize);\n assert(false);\n }\n offset += lengthSize;\n const nalUnit = packetData.subarray(offset, offset + nalUnitLength);\n nalUnits.push(nalUnit);\n offset += nalUnitLength;\n }\n return nalUnits;\n};\nconst removeEmulationPreventionBytes = (data) => {\n const result = [];\n const len = data.length;\n for (let i = 0; i < len; i++) {\n // Look for the 0x000003 pattern\n if (i + 2 < len && data[i] === 0x00 && data[i + 1] === 0x00 && data[i + 2] === 0x03) {\n result.push(0x00, 0x00); // Push the first two bytes\n i += 2; // Skip the 0x03 byte\n }\n else {\n result.push(data[i]);\n }\n }\n return new Uint8Array(result);\n};\n/** Converts an AVC packet in Annex B format to length-prefixed format. */\nexport const transformAnnexBToLengthPrefixed = (packetData) => {\n const NAL_UNIT_LENGTH_SIZE = 4;\n const nalUnits = findNalUnitsInAnnexB(packetData);\n if (nalUnits.length === 0) {\n // If no NAL units were found, it's not valid Annex B data\n return null;\n }\n let totalSize = 0;\n for (const nalUnit of nalUnits) {\n totalSize += NAL_UNIT_LENGTH_SIZE + nalUnit.byteLength;\n }\n const avccData = new Uint8Array(totalSize);\n const dataView = new DataView(avccData.buffer);\n let offset = 0;\n // Write each NAL unit with its length prefix\n for (const nalUnit of nalUnits) {\n const length = nalUnit.byteLength;\n dataView.setUint32(offset, length, false);\n offset += 4;\n avccData.set(nalUnit, offset);\n offset += nalUnit.byteLength;\n }\n return avccData;\n};\nexport const extractAvcNalUnits = (packetData, decoderConfig) => {\n if (decoderConfig.description) {\n // Stream is length-prefixed. Let's extract the size of the length prefix from the decoder config\n const bytes = toUint8Array(decoderConfig.description);\n const lengthSizeMinusOne = bytes[4] & 0b11;\n const lengthSize = (lengthSizeMinusOne + 1);\n return findNalUnitsInLengthPrefixed(packetData, lengthSize);\n }\n else {\n // Stream is in Annex B format\n return findNalUnitsInAnnexB(packetData);\n }\n};\nconst extractNalUnitTypeForAvc = (data) => {\n return data[0] & 0x1F;\n};\n/** Builds an AvcDecoderConfigurationRecord from an AVC packet in Annex B format. */\nexport const extractAvcDecoderConfigurationRecord = (packetData) => {\n try {\n const nalUnits = findNalUnitsInAnnexB(packetData);\n const spsUnits = nalUnits.filter(unit => extractNalUnitTypeForAvc(unit) === AvcNalUnitType.SPS);\n const ppsUnits = nalUnits.filter(unit => extractNalUnitTypeForAvc(unit) === AvcNalUnitType.PPS);\n const spsExtUnits = nalUnits.filter(unit => extractNalUnitTypeForAvc(unit) === AvcNalUnitType.SPS_EXT);\n if (spsUnits.length === 0) {\n return null;\n }\n if (ppsUnits.length === 0) {\n return null;\n }\n // Let's get the first SPS for profile and level information\n const spsData = spsUnits[0];\n const bitstream = new Bitstream(removeEmulationPreventionBytes(spsData));\n bitstream.skipBits(1); // forbidden_zero_bit\n bitstream.skipBits(2); // nal_ref_idc\n const nal_unit_type = bitstream.readBits(5);\n if (nal_unit_type !== 7) { // SPS NAL unit type is 7\n console.error('Invalid SPS NAL unit type');\n return null;\n }\n const profile_idc = bitstream.readAlignedByte();\n const constraint_flags = bitstream.readAlignedByte();\n const level_idc = bitstream.readAlignedByte();\n const record = {\n configurationVersion: 1,\n avcProfileIndication: profile_idc,\n profileCompatibility: constraint_flags,\n avcLevelIndication: level_idc,\n lengthSizeMinusOne: 3, // Typically 4 bytes for length field\n sequenceParameterSets: spsUnits,\n pictureParameterSets: ppsUnits,\n chromaFormat: null,\n bitDepthLumaMinus8: null,\n bitDepthChromaMinus8: null,\n sequenceParameterSetExt: null,\n };\n if (profile_idc === 100\n || profile_idc === 110\n || profile_idc === 122\n || profile_idc === 144) {\n readExpGolomb(bitstream); // seq_parameter_set_id\n const chroma_format_idc = readExpGolomb(bitstream);\n if (chroma_format_idc === 3) {\n bitstream.skipBits(1); // separate_colour_plane_flag\n }\n const bit_depth_luma_minus8 = readExpGolomb(bitstream);\n const bit_depth_chroma_minus8 = readExpGolomb(bitstream);\n record.chromaFormat = chroma_format_idc;\n record.bitDepthLumaMinus8 = bit_depth_luma_minus8;\n record.bitDepthChromaMinus8 = bit_depth_chroma_minus8;\n record.sequenceParameterSetExt = spsExtUnits;\n }\n return record;\n }\n catch (error) {\n console.error('Error building AVC Decoder Configuration Record:', error);\n return null;\n }\n};\n/** Serializes an AvcDecoderConfigurationRecord into the format specified in Section 5.3.3.1 of ISO 14496-15. */\nexport const serializeAvcDecoderConfigurationRecord = (record) => {\n const bytes = [];\n // Write header\n bytes.push(record.configurationVersion);\n bytes.push(record.avcProfileIndication);\n bytes.push(record.profileCompatibility);\n bytes.push(record.avcLevelIndication);\n bytes.push(0xFC | (record.lengthSizeMinusOne & 0x03)); // Reserved bits (6) + lengthSizeMinusOne (2)\n // Reserved bits (3) + numOfSequenceParameterSets (5)\n bytes.push(0xE0 | (record.sequenceParameterSets.length & 0x1F));\n // Write SPS\n for (const sps of record.sequenceParameterSets) {\n const length = sps.byteLength;\n bytes.push(length >> 8); // High byte\n bytes.push(length & 0xFF); // Low byte\n for (let i = 0; i < length; i++) {\n bytes.push(sps[i]);\n }\n }\n bytes.push(record.pictureParameterSets.length);\n // Write PPS\n for (const pps of record.pictureParameterSets) {\n const length = pps.byteLength;\n bytes.push(length >> 8); // High byte\n bytes.push(length & 0xFF); // Low byte\n for (let i = 0; i < length; i++) {\n bytes.push(pps[i]);\n }\n }\n if (record.avcProfileIndication === 100\n || record.avcProfileIndication === 110\n || record.avcProfileIndication === 122\n || record.avcProfileIndication === 144) {\n assert(record.chromaFormat !== null);\n assert(record.bitDepthLumaMinus8 !== null);\n assert(record.bitDepthChromaMinus8 !== null);\n assert(record.sequenceParameterSetExt !== null);\n bytes.push(0xFC | (record.chromaFormat & 0x03)); // Reserved bits + chroma_format\n bytes.push(0xF8 | (record.bitDepthLumaMinus8 & 0x07)); // Reserved bits + bit_depth_luma_minus8\n bytes.push(0xF8 | (record.bitDepthChromaMinus8 & 0x07)); // Reserved bits + bit_depth_chroma_minus8\n bytes.push(record.sequenceParameterSetExt.length);\n // Write SPS Ext\n for (const spsExt of record.sequenceParameterSetExt) {\n const length = spsExt.byteLength;\n bytes.push(length >> 8); // High byte\n bytes.push(length & 0xFF); // Low byte\n for (let i = 0; i < length; i++) {\n bytes.push(spsExt[i]);\n }\n }\n }\n return new Uint8Array(bytes);\n};\nexport const extractHevcNalUnits = (packetData, decoderConfig) => {\n if (decoderConfig.description) {\n // Stream is length-prefixed. Let's extract the size of the length prefix from the decoder config\n const bytes = toUint8Array(decoderConfig.description);\n const lengthSizeMinusOne = bytes[21] & 0b11;\n const lengthSize = (lengthSizeMinusOne + 1);\n return findNalUnitsInLengthPrefixed(packetData, lengthSize);\n }\n else {\n // Stream is in Annex B format\n return findNalUnitsInAnnexB(packetData);\n }\n};\nexport const extractNalUnitTypeForHevc = (data) => {\n return (data[0] >> 1) & 0x3F;\n};\n/** Builds a HevcDecoderConfigurationRecord from an HEVC packet in Annex B format. */\nexport const extractHevcDecoderConfigurationRecord = (packetData) => {\n try {\n const nalUnits = findNalUnitsInAnnexB(packetData);\n const vpsUnits = nalUnits.filter(unit => extractNalUnitTypeForHevc(unit) === HevcNalUnitType.VPS_NUT);\n const spsUnits = nalUnits.filter(unit => extractNalUnitTypeForHevc(unit) === HevcNalUnitType.SPS_NUT);\n const ppsUnits = nalUnits.filter(unit => extractNalUnitTypeForHevc(unit) === HevcNalUnitType.PPS_NUT);\n const seiUnits = nalUnits.filter(unit => extractNalUnitTypeForHevc(unit) === HevcNalUnitType.PREFIX_SEI_NUT\n || extractNalUnitTypeForHevc(unit) === HevcNalUnitType.SUFFIX_SEI_NUT);\n if (spsUnits.length === 0 || ppsUnits.length === 0)\n return null;\n const sps = spsUnits[0];\n const bitstream = new Bitstream(removeEmulationPreventionBytes(sps));\n bitstream.skipBits(16); // NAL header\n bitstream.readBits(4); // sps_video_parameter_set_id\n const sps_max_sub_layers_minus1 = bitstream.readBits(3);\n const sps_temporal_id_nesting_flag = bitstream.readBits(1);\n const { general_profile_space, general_tier_flag, general_profile_idc, general_profile_compatibility_flags, general_constraint_indicator_flags, general_level_idc, } = parseProfileTierLevel(bitstream, sps_max_sub_layers_minus1);\n readExpGolomb(bitstream); // sps_seq_parameter_set_id\n const chroma_format_idc = readExpGolomb(bitstream);\n if (chroma_format_idc === 3)\n bitstream.skipBits(1); // separate_colour_plane_flag\n readExpGolomb(bitstream); // pic_width_in_luma_samples\n readExpGolomb(bitstream); // pic_height_in_luma_samples\n if (bitstream.readBits(1)) { // conformance_window_flag\n readExpGolomb(bitstream); // conf_win_left_offset\n readExpGolomb(bitstream); // conf_win_right_offset\n readExpGolomb(bitstream); // conf_win_top_offset\n readExpGolomb(bitstream); // conf_win_bottom_offset\n }\n const bit_depth_luma_minus8 = readExpGolomb(bitstream);\n const bit_depth_chroma_minus8 = readExpGolomb(bitstream);\n readExpGolomb(bitstream); // log2_max_pic_order_cnt_lsb_minus4\n const sps_sub_layer_ordering_info_present_flag = bitstream.readBits(1);\n const maxNum = sps_sub_layer_ordering_info_present_flag ? 0 : sps_max_sub_layers_minus1;\n for (let i = maxNum; i <= sps_max_sub_layers_minus1; i++) {\n readExpGolomb(bitstream); // sps_max_dec_pic_buffering_minus1[i]\n readExpGolomb(bitstream); // sps_max_num_reorder_pics[i]\n readExpGolomb(bitstream); // sps_max_latency_increase_plus1[i]\n }\n readExpGolomb(bitstream); // log2_min_luma_coding_block_size_minus3\n readExpGolomb(bitstream); // log2_diff_max_min_luma_coding_block_size\n readExpGolomb(bitstream); // log2_min_luma_transform_block_size_minus2\n readExpGolomb(bitstream); // log2_diff_max_min_luma_transform_block_size\n readExpGolomb(bitstream); // max_transform_hierarchy_depth_inter\n readExpGolomb(bitstream); // max_transform_hierarchy_depth_intra\n if (bitstream.readBits(1)) { // scaling_list_enabled_flag\n if (bitstream.readBits(1)) {\n skipScalingListData(bitstream);\n }\n }\n bitstream.skipBits(1); // amp_enabled_flag\n bitstream.skipBits(1); // sample_adaptive_offset_enabled_flag\n if (bitstream.readBits(1)) { // pcm_enabled_flag\n bitstream.skipBits(4); // pcm_sample_bit_depth_luma_minus1\n bitstream.skipBits(4); // pcm_sample_bit_depth_chroma_minus1\n readExpGolomb(bitstream); // log2_min_pcm_luma_coding_block_size_minus3\n readExpGolomb(bitstream); // log2_diff_max_min_pcm_luma_coding_block_size\n bitstream.skipBits(1); // pcm_loop_filter_disabled_flag\n }\n const num_short_term_ref_pic_sets = readExpGolomb(bitstream);\n skipAllStRefPicSets(bitstream, num_short_term_ref_pic_sets);\n if (bitstream.readBits(1)) { // long_term_ref_pics_present_flag\n const num_long_term_ref_pics_sps = readExpGolomb(bitstream);\n for (let i = 0; i < num_long_term_ref_pics_sps; i++) {\n readExpGolomb(bitstream); // lt_ref_pic_poc_lsb_sps[i]\n bitstream.skipBits(1); // used_by_curr_pic_lt_sps_flag[i]\n }\n }\n bitstream.skipBits(1); // sps_temporal_mvp_enabled_flag\n bitstream.skipBits(1); // strong_intra_smoothing_enabled_flag\n let min_spatial_segmentation_idc = 0;\n if (bitstream.readBits(1)) { // vui_parameters_present_flag\n min_spatial_segmentation_idc = parseVuiForMinSpatialSegmentationIdc(bitstream, sps_max_sub_layers_minus1);\n }\n // Parse PPS for parallelismType\n let parallelismType = 0;\n if (ppsUnits.length > 0) {\n const pps = ppsUnits[0];\n const ppsBitstream = new Bitstream(removeEmulationPreventionBytes(pps));\n ppsBitstream.skipBits(16); // NAL header\n readExpGolomb(ppsBitstream); // pps_pic_parameter_set_id\n readExpGolomb(ppsBitstream); // pps_seq_parameter_set_id\n ppsBitstream.skipBits(1); // dependent_slice_segments_enabled_flag\n ppsBitstream.skipBits(1); // output_flag_present_flag\n ppsBitstream.skipBits(3); // num_extra_slice_header_bits\n ppsBitstream.skipBits(1); // sign_data_hiding_enabled_flag\n ppsBitstream.skipBits(1); // cabac_init_present_flag\n readExpGolomb(ppsBitstream); // num_ref_idx_l0_default_active_minus1\n readExpGolomb(ppsBitstream); // num_ref_idx_l1_default_active_minus1\n readSignedExpGolomb(ppsBitstream); // init_qp_minus26\n ppsBitstream.skipBits(1); // constrained_intra_pred_flag\n ppsBitstream.skipBits(1); // transform_skip_enabled_flag\n if (ppsBitstream.readBits(1)) { // cu_qp_delta_enabled_flag\n readExpGolomb(ppsBitstream); // diff_cu_qp_delta_depth\n }\n readSignedExpGolomb(ppsBitstream); // pps_cb_qp_offset\n readSignedExpGolomb(ppsBitstream); // pps_cr_qp_offset\n ppsBitstream.skipBits(1); // pps_slice_chroma_qp_offsets_present_flag\n ppsBitstream.skipBits(1); // weighted_pred_flag\n ppsBitstream.skipBits(1); // weighted_bipred_flag\n ppsBitstream.skipBits(1); // transquant_bypass_enabled_flag\n const tiles_enabled_flag = ppsBitstream.readBits(1);\n const entropy_coding_sync_enabled_flag = ppsBitstream.readBits(1);\n if (!tiles_enabled_flag && !entropy_coding_sync_enabled_flag)\n parallelismType = 0;\n else if (tiles_enabled_flag && !entropy_coding_sync_enabled_flag)\n parallelismType = 2;\n else if (!tiles_enabled_flag && entropy_coding_sync_enabled_flag)\n parallelismType = 3;\n else\n parallelismType = 0;\n }\n const arrays = [\n ...(vpsUnits.length\n ? [\n {\n arrayCompleteness: 1,\n nalUnitType: HevcNalUnitType.VPS_NUT,\n nalUnits: vpsUnits,\n },\n ]\n : []),\n ...(spsUnits.length\n ? [\n {\n arrayCompleteness: 1,\n nalUnitType: HevcNalUnitType.SPS_NUT,\n nalUnits: spsUnits,\n },\n ]\n : []),\n ...(ppsUnits.length\n ? [\n {\n arrayCompleteness: 1,\n nalUnitType: HevcNalUnitType.PPS_NUT,\n nalUnits: ppsUnits,\n },\n ]\n : []),\n ...(seiUnits.length\n ? [\n {\n arrayCompleteness: 1,\n nalUnitType: extractNalUnitTypeForHevc(seiUnits[0]),\n nalUnits: seiUnits,\n },\n ]\n : []),\n ];\n const record = {\n configurationVersion: 1,\n generalProfileSpace: general_profile_space,\n generalTierFlag: general_tier_flag,\n generalProfileIdc: general_profile_idc,\n generalProfileCompatibilityFlags: general_profile_compatibility_flags,\n generalConstraintIndicatorFlags: general_constraint_indicator_flags,\n generalLevelIdc: general_level_idc,\n minSpatialSegmentationIdc: min_spatial_segmentation_idc,\n parallelismType,\n chromaFormatIdc: chroma_format_idc,\n bitDepthLumaMinus8: bit_depth_luma_minus8,\n bitDepthChromaMinus8: bit_depth_chroma_minus8,\n avgFrameRate: 0,\n constantFrameRate: 0,\n numTemporalLayers: sps_max_sub_layers_minus1 + 1,\n temporalIdNested: sps_temporal_id_nesting_flag,\n lengthSizeMinusOne: 3,\n arrays,\n };\n return record;\n }\n catch (error) {\n console.error('Error building HEVC Decoder Configuration Record:', error);\n return null;\n }\n};\nconst parseProfileTierLevel = (bitstream, maxNumSubLayersMinus1) => {\n const general_profile_space = bitstream.readBits(2);\n const general_tier_flag = bitstream.readBits(1);\n const general_profile_idc = bitstream.readBits(5);\n let general_profile_compatibility_flags = 0;\n for (let i = 0; i < 32; i++) {\n general_profile_compatibility_flags = (general_profile_compatibility_flags << 1) | bitstream.readBits(1);\n }\n const general_constraint_indicator_flags = new Uint8Array(6);\n for (let i = 0; i < 6; i++) {\n general_constraint_indicator_flags[i] = bitstream.readBits(8);\n }\n const general_level_idc = bitstream.readBits(8);\n const sub_layer_profile_present_flag = [];\n const sub_layer_level_present_flag = [];\n for (let i = 0; i < maxNumSubLayersMinus1; i++) {\n sub_layer_profile_present_flag.push(bitstream.readBits(1));\n sub_layer_level_present_flag.push(bitstream.readBits(1));\n }\n if (maxNumSubLayersMinus1 > 0) {\n for (let i = maxNumSubLayersMinus1; i < 8; i++) {\n bitstream.skipBits(2); // reserved_zero_2bits\n }\n }\n for (let i = 0; i < maxNumSubLayersMinus1; i++) {\n if (sub_layer_profile_present_flag[i])\n bitstream.skipBits(88);\n if (sub_layer_level_present_flag[i])\n bitstream.skipBits(8);\n }\n return {\n general_profile_space,\n general_tier_flag,\n general_profile_idc,\n general_profile_compatibility_flags,\n general_constraint_indicator_flags,\n general_level_idc,\n };\n};\nconst skipScalingListData = (bitstream) => {\n for (let sizeId = 0; sizeId < 4; sizeId++) {\n for (let matrixId = 0; matrixId < (sizeId === 3 ? 2 : 6); matrixId++) {\n const scaling_list_pred_mode_flag = bitstream.readBits(1);\n if (!scaling_list_pred_mode_flag) {\n readExpGolomb(bitstream); // scaling_list_pred_matrix_id_delta\n }\n else {\n const coefNum = Math.min(64, 1 << (4 + (sizeId << 1)));\n if (sizeId > 1) {\n readSignedExpGolomb(bitstream); // scaling_list_dc_coef_minus8\n }\n for (let i = 0; i < coefNum; i++) {\n readSignedExpGolomb(bitstream); // scaling_list_delta_coef\n }\n }\n }\n }\n};\nconst skipAllStRefPicSets = (bitstream, num_short_term_ref_pic_sets) => {\n const NumDeltaPocs = [];\n for (let stRpsIdx = 0; stRpsIdx < num_short_term_ref_pic_sets; stRpsIdx++) {\n NumDeltaPocs[stRpsIdx] = skipStRefPicSet(bitstream, stRpsIdx, num_short_term_ref_pic_sets, NumDeltaPocs);\n }\n};\nconst skipStRefPicSet = (bitstream, stRpsIdx, num_short_term_ref_pic_sets, NumDeltaPocs) => {\n let NumDeltaPocsThis = 0;\n let inter_ref_pic_set_prediction_flag = 0;\n let RefRpsIdx = 0;\n if (stRpsIdx !== 0) {\n inter_ref_pic_set_prediction_flag = bitstream.readBits(1);\n }\n if (inter_ref_pic_set_prediction_flag) {\n if (stRpsIdx === num_short_term_ref_pic_sets) {\n const delta_idx_minus1 = readExpGolomb(bitstream);\n RefRpsIdx = stRpsIdx - (delta_idx_minus1 + 1);\n }\n else {\n RefRpsIdx = stRpsIdx - 1;\n }\n bitstream.readBits(1); // delta_rps_sign\n readExpGolomb(bitstream); // abs_delta_rps_minus1\n // The number of iterations is NumDeltaPocs[RefRpsIdx] + 1\n const numDelta = NumDeltaPocs[RefRpsIdx] ?? 0;\n for (let j = 0; j <= numDelta; j++) {\n const used_by_curr_pic_flag = bitstream.readBits(1);\n if (!used_by_curr_pic_flag) {\n bitstream.readBits(1); // use_delta_flag\n }\n }\n NumDeltaPocsThis = NumDeltaPocs[RefRpsIdx];\n }\n else {\n const num_negative_pics = readExpGolomb(bitstream);\n const num_positive_pics = readExpGolomb(bitstream);\n for (let i = 0; i < num_negative_pics; i++) {\n readExpGolomb(bitstream); // delta_poc_s0_minus1[i]\n bitstream.readBits(1); // used_by_curr_pic_s0_flag[i]\n }\n for (let i = 0; i < num_positive_pics; i++) {\n readExpGolomb(bitstream); // delta_poc_s1_minus1[i]\n bitstream.readBits(1); // used_by_curr_pic_s1_flag[i]\n }\n NumDeltaPocsThis = num_negative_pics + num_positive_pics;\n }\n return NumDeltaPocsThis;\n};\nconst parseVuiForMinSpatialSegmentationIdc = (bitstream, sps_max_sub_layers_minus1) => {\n if (bitstream.readBits(1)) { // aspect_ratio_info_present_flag\n const aspect_ratio_idc = bitstream.readBits(8);\n if (aspect_ratio_idc === 255) {\n bitstream.readBits(16); // sar_width\n bitstream.readBits(16); // sar_height\n }\n }\n if (bitstream.readBits(1)) { // overscan_info_present_flag\n bitstream.readBits(1); // overscan_appropriate_flag\n }\n if (bitstream.readBits(1)) { // video_signal_type_present_flag\n bitstream.readBits(3); // video_format\n bitstream.readBits(1); // video_full_range_flag\n if (bitstream.readBits(1)) {\n bitstream.readBits(8); // colour_primaries\n bitstream.readBits(8); // transfer_characteristics\n bitstream.readBits(8); // matrix_coeffs\n }\n }\n if (bitstream.readBits(1)) { // chroma_loc_info_present_flag\n readExpGolomb(bitstream); // chroma_sample_loc_type_top_field\n readExpGolomb(bitstream); // chroma_sample_loc_type_bottom_field\n }\n bitstream.readBits(1); // neutral_chroma_indication_flag\n bitstream.readBits(1); // field_seq_flag\n bitstream.readBits(1); // frame_field_info_present_flag\n if (bitstream.readBits(1)) { // default_display_window_flag\n readExpGolomb(bitstream); // def_disp_win_left_offset\n readExpGolomb(bitstream); // def_disp_win_right_offset\n readExpGolomb(bitstream); // def_disp_win_top_offset\n readExpGolomb(bitstream); // def_disp_win_bottom_offset\n }\n if (bitstream.readBits(1)) { // vui_timing_info_present_flag\n bitstream.readBits(32); // vui_num_units_in_tick\n bitstream.readBits(32); // vui_time_scale\n if (bitstream.readBits(1)) { // vui_poc_proportional_to_timing_flag\n readExpGolomb(bitstream); // vui_num_ticks_poc_diff_one_minus1\n }\n if (bitstream.readBits(1)) {\n skipHrdParameters(bitstream, true, sps_max_sub_layers_minus1);\n }\n }\n if (bitstream.readBits(1)) { // bitstream_restriction_flag\n bitstream.readBits(1); // tiles_fixed_structure_flag\n bitstream.readBits(1); // motion_vectors_over_pic_boundaries_flag\n bitstream.readBits(1); // restricted_ref_pic_lists_flag\n const min_spatial_segmentation_idc = readExpGolomb(bitstream);\n // skip the rest\n readExpGolomb(bitstream); // max_bytes_per_pic_denom\n readExpGolomb(bitstream); // max_bits_per_min_cu_denom\n readExpGolomb(bitstream); // log2_max_mv_length_horizontal\n readExpGolomb(bitstream); // log2_max_mv_length_vertical\n return min_spatial_segmentation_idc;\n }\n return 0;\n};\nconst skipHrdParameters = (bitstream, commonInfPresentFlag, maxNumSubLayersMinus1) => {\n let nal_hrd_parameters_present_flag = false;\n let vcl_hrd_parameters_present_flag = false;\n let sub_pic_hrd_params_present_flag = false;\n if (commonInfPresentFlag) {\n nal_hrd_parameters_present_flag = bitstream.readBits(1) === 1;\n vcl_hrd_parameters_present_flag = bitstream.readBits(1) === 1;\n if (nal_hrd_parameters_present_flag || vcl_hrd_parameters_present_flag) {\n sub_pic_hrd_params_present_flag = bitstream.readBits(1) === 1;\n if (sub_pic_hrd_params_present_flag) {\n bitstream.readBits(8); // tick_divisor_minus2\n bitstream.readBits(5); // du_cpb_removal_delay_increment_length_minus1\n bitstream.readBits(1); // sub_pic_cpb_params_in_pic_timing_sei_flag\n bitstream.readBits(5); // dpb_output_delay_du_length_minus1\n }\n bitstream.readBits(4); // bit_rate_scale\n bitstream.readBits(4); // cpb_size_scale\n if (sub_pic_hrd_params_present_flag) {\n bitstream.readBits(4); // cpb_size_du_scale\n }\n bitstream.readBits(5); // initial_cpb_removal_delay_length_minus1\n bitstream.readBits(5); // au_cpb_removal_delay_length_minus1\n bitstream.readBits(5); // dpb_output_delay_length_minus1\n }\n }\n for (let i = 0; i <= maxNumSubLayersMinus1; i++) {\n const fixed_pic_rate_general_flag = bitstream.readBits(1) === 1;\n let fixed_pic_rate_within_cvs_flag = true; // Default assumption if general is true\n if (!fixed_pic_rate_general_flag) {\n fixed_pic_rate_within_cvs_flag = bitstream.readBits(1) === 1;\n }\n let low_delay_hrd_flag = false; // Default assumption\n if (fixed_pic_rate_within_cvs_flag) {\n readExpGolomb(bitstream); // elemental_duration_in_tc_minus1[i]\n }\n else {\n low_delay_hrd_flag = bitstream.readBits(1) === 1;\n }\n let CpbCnt = 1; // Default if low_delay is true\n if (!low_delay_hrd_flag) {\n const cpb_cnt_minus1 = readExpGolomb(bitstream); // cpb_cnt_minus1[i]\n CpbCnt = cpb_cnt_minus1 + 1;\n }\n if (nal_hrd_parameters_present_flag) {\n skipSubLayerHrdParameters(bitstream, CpbCnt, sub_pic_hrd_params_present_flag);\n }\n if (vcl_hrd_parameters_present_flag) {\n skipSubLayerHrdParameters(bitstream, CpbCnt, sub_pic_hrd_params_present_flag);\n }\n }\n};\nconst skipSubLayerHrdParameters = (bitstream, CpbCnt, sub_pic_hrd_params_present_flag) => {\n for (let i = 0; i < CpbCnt; i++) {\n readExpGolomb(bitstream); // bit_rate_value_minus1[i]\n readExpGolomb(bitstream); // cpb_size_value_minus1[i]\n if (sub_pic_hrd_params_present_flag) {\n readExpGolomb(bitstream); // cpb_size_du_value_minus1[i]\n readExpGolomb(bitstream); // bit_rate_du_value_minus1[i]\n }\n bitstream.readBits(1); // cbr_flag[i]\n }\n};\n/** Serializes an HevcDecoderConfigurationRecord into the format specified in Section 8.3.3.1 of ISO 14496-15. */\nexport const serializeHevcDecoderConfigurationRecord = (record) => {\n const bytes = [];\n bytes.push(record.configurationVersion);\n bytes.push(((record.generalProfileSpace & 0x3) << 6)\n | ((record.generalTierFlag & 0x1) << 5)\n | (record.generalProfileIdc & 0x1F));\n bytes.push((record.generalProfileCompatibilityFlags >>> 24) & 0xFF);\n bytes.push((record.generalProfileCompatibilityFlags >>> 16) & 0xFF);\n bytes.push((record.generalProfileCompatibilityFlags >>> 8) & 0xFF);\n bytes.push(record.generalProfileCompatibilityFlags & 0xFF);\n bytes.push(...record.generalConstraintIndicatorFlags);\n bytes.push(record.generalLevelIdc & 0xFF);\n bytes.push(0xF0 | ((record.minSpatialSegmentationIdc >> 8) & 0x0F)); // Reserved + high nibble\n bytes.push(record.minSpatialSegmentationIdc & 0xFF); // Low byte\n bytes.push(0xFC | (record.parallelismType & 0x03));\n bytes.push(0xFC | (record.chromaFormatIdc & 0x03));\n bytes.push(0xF8 | (record.bitDepthLumaMinus8 & 0x07));\n bytes.push(0xF8 | (record.bitDepthChromaMinus8 & 0x07));\n bytes.push((record.avgFrameRate >> 8) & 0xFF); // High byte\n bytes.push(record.avgFrameRate & 0xFF); // Low byte\n bytes.push(((record.constantFrameRate & 0x03) << 6)\n | ((record.numTemporalLayers & 0x07) << 3)\n | ((record.temporalIdNested & 0x01) << 2)\n | (record.lengthSizeMinusOne & 0x03));\n bytes.push(record.arrays.length & 0xFF);\n for (const arr of record.arrays) {\n bytes.push(((arr.arrayCompleteness & 0x01) << 7)\n | (0 << 6)\n | (arr.nalUnitType & 0x3F));\n bytes.push((arr.nalUnits.length >> 8) & 0xFF); // High byte\n bytes.push(arr.nalUnits.length & 0xFF); // Low byte\n for (const nal of arr.nalUnits) {\n bytes.push((nal.length >> 8) & 0xFF); // High byte\n bytes.push(nal.length & 0xFF); // Low byte\n for (let i = 0; i < nal.length; i++) {\n bytes.push(nal[i]);\n }\n }\n }\n return new Uint8Array(bytes);\n};\nexport const extractVp9CodecInfoFromPacket = (packet) => {\n // eslint-disable-next-line @stylistic/max-len\n // https://storage.googleapis.com/downloads.webmproject.org/docs/vp9/vp9-bitstream-specification-v0.7-20170222-draft.pdf\n // http://downloads.webmproject.org/docs/vp9/vp9-bitstream_superframe-and-uncompressed-header_v1.0.pdf\n const bitstream = new Bitstream(packet);\n // Frame marker (0b10)\n const frameMarker = bitstream.readBits(2);\n if (frameMarker !== 2) {\n return null;\n }\n // Profile\n const profileLowBit = bitstream.readBits(1);\n const profileHighBit = bitstream.readBits(1);\n const profile = (profileHighBit << 1) + profileLowBit;\n // Skip reserved bit for profile 3\n if (profile === 3) {\n bitstream.skipBits(1);\n }\n // show_existing_frame\n const showExistingFrame = bitstream.readBits(1);\n if (showExistingFrame === 1) {\n return null;\n }\n // frame_type (0 = key frame)\n const frameType = bitstream.readBits(1);\n if (frameType !== 0) {\n return null;\n }\n // Skip show_frame and error_resilient_mode\n bitstream.skipBits(2);\n // Sync code (0x498342)\n const syncCode = bitstream.readBits(24);\n if (syncCode !== 0x498342) {\n return null;\n }\n // Color config\n let bitDepth = 8;\n if (profile >= 2) {\n const tenOrTwelveBit = bitstream.readBits(1);\n bitDepth = tenOrTwelveBit ? 12 : 10;\n }\n // Color space\n const colorSpace = bitstream.readBits(3);\n let chromaSubsampling = 0;\n let videoFullRangeFlag = 0;\n if (colorSpace !== 7) { // 7 is CS_RGB\n const colorRange = bitstream.readBits(1);\n videoFullRangeFlag = colorRange;\n if (profile === 1 || profile === 3) {\n const subsamplingX = bitstream.readBits(1);\n const subsamplingY = bitstream.readBits(1);\n // 0 = 4:2:0 vertical\n // 1 = 4:2:0 colocated\n // 2 = 4:2:2\n // 3 = 4:4:4\n chromaSubsampling = !subsamplingX && !subsamplingY\n ? 3 // 0,0 = 4:4:4\n : subsamplingX && !subsamplingY\n ? 2 // 1,0 = 4:2:2\n : 1; // 1,1 = 4:2:0 colocated (default)\n // Skip reserved bit\n bitstream.skipBits(1);\n }\n else {\n // For profile 0 and 2, always 4:2:0\n chromaSubsampling = 1; // Using colocated as default\n }\n }\n else {\n // RGB is always 4:4:4\n chromaSubsampling = 3;\n videoFullRangeFlag = 1;\n }\n // Parse frame size\n const widthMinusOne = bitstream.readBits(16);\n const heightMinusOne = bitstream.readBits(16);\n const width = widthMinusOne + 1;\n const height = heightMinusOne + 1;\n // Calculate level based on dimensions\n const pictureSize = width * height;\n let level = last(VP9_LEVEL_TABLE).level; // Default to highest level\n for (const entry of VP9_LEVEL_TABLE) {\n if (pictureSize <= entry.maxPictureSize) {\n level = entry.level;\n break;\n }\n }\n // Map color_space to standard values\n const matrixCoefficients = colorSpace === 7\n ? 0\n : colorSpace === 2\n ? 1\n : colorSpace === 1\n ? 6\n : 2;\n const colourPrimaries = colorSpace === 2\n ? 1\n : colorSpace === 1\n ? 6\n : 2;\n const transferCharacteristics = colorSpace === 2\n ? 1\n : colorSpace === 1\n ? 6\n : 2;\n return {\n profile,\n level,\n bitDepth,\n chromaSubsampling,\n videoFullRangeFlag,\n colourPrimaries,\n transferCharacteristics,\n matrixCoefficients,\n };\n};\n/** Iterates over all OBUs in an AV1 packet bistream. */\nexport const iterateAv1PacketObus = function* (packet) {\n // https://aomediacodec.github.io/av1-spec/av1-spec.pdf\n const bitstream = new Bitstream(packet);\n const readLeb128 = () => {\n let value = 0;\n for (let i = 0; i < 8; i++) {\n const byte = bitstream.readAlignedByte();\n value |= ((byte & 0x7f) << (i * 7));\n if (!(byte & 0x80)) {\n break;\n }\n // Spec requirement\n if (i === 7 && (byte & 0x80)) {\n return null;\n }\n }\n // Spec requirement\n if (value >= 2 ** 32 - 1) {\n return null;\n }\n return value;\n };\n while (bitstream.getBitsLeft() >= 8) {\n // Parse OBU header\n bitstream.skipBits(1);\n const obuType = bitstream.readBits(4);\n const obuExtension = bitstream.readBits(1);\n const obuHasSizeField = bitstream.readBits(1);\n bitstream.skipBits(1);\n // Skip extension header if present\n if (obuExtension) {\n bitstream.skipBits(8);\n }\n // Read OBU size if present\n let obuSize;\n if (obuHasSizeField) {\n const obuSizeValue = readLeb128();\n if (obuSizeValue === null)\n return; // It was invalid\n obuSize = obuSizeValue;\n }\n else {\n // Calculate remaining bits and convert to bytes, rounding down\n obuSize = Math.floor(bitstream.getBitsLeft() / 8);\n }\n assert(bitstream.pos % 8 === 0);\n yield {\n type: obuType,\n data: packet.subarray(bitstream.pos / 8, bitstream.pos / 8 + obuSize),\n };\n // Move to next OBU\n bitstream.skipBits(obuSize * 8);\n }\n};\n/**\n * When AV1 codec information is not provided by the container, we can still try to extract the information by digging\n * into the AV1 bitstream.\n */\nexport const extractAv1CodecInfoFromPacket = (packet) => {\n // https://aomediacodec.github.io/av1-spec/av1-spec.pdf\n for (const { type, data } of iterateAv1PacketObus(packet)) {\n if (type !== 1) {\n continue; // 1 == OBU_SEQUENCE_HEADER\n }\n const bitstream = new Bitstream(data);\n // Read sequence header fields\n const seqProfile = bitstream.readBits(3);\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const stillPicture = bitstream.readBits(1);\n const reducedStillPictureHeader = bitstream.readBits(1);\n let seqLevel = 0;\n let seqTier = 0;\n let bufferDelayLengthMinus1 = 0;\n if (reducedStillPictureHeader) {\n seqLevel = bitstream.readBits(5);\n }\n else {\n // Parse timing_info_present_flag\n const timingInfoPresentFlag = bitstream.readBits(1);\n if (timingInfoPresentFlag) {\n // Skip timing info (num_units_in_display_tick, time_scale, equal_picture_interval)\n bitstream.skipBits(32); // num_units_in_display_tick\n bitstream.skipBits(32); // time_scale\n const equalPictureInterval = bitstream.readBits(1);\n if (equalPictureInterval) {\n // Skip num_ticks_per_picture_minus_1 (uvlc)\n // Since this is variable length, we'd need to implement uvlc reading\n // For now, we'll return null as this is rare\n return null;\n }\n }\n // Parse decoder_model_info_present_flag\n const decoderModelInfoPresentFlag = bitstream.readBits(1);\n if (decoderModelInfoPresentFlag) {\n // Store buffer_delay_length_minus_1 instead of just skipping\n bufferDelayLengthMinus1 = bitstream.readBits(5);\n bitstream.skipBits(32); // num_units_in_decoding_tick\n bitstream.skipBits(5); // buffer_removal_time_length_minus_1\n bitstream.skipBits(5); // frame_presentation_time_length_minus_1\n }\n // Parse operating_points_cnt_minus_1\n const operatingPointsCntMinus1 = bitstream.readBits(5);\n // For each operating point\n for (let i = 0; i <= operatingPointsCntMinus1; i++) {\n // operating_point_idc[i]\n bitstream.skipBits(12);\n // seq_level_idx[i]\n const seqLevelIdx = bitstream.readBits(5);\n if (i === 0) {\n seqLevel = seqLevelIdx;\n }\n if (seqLevelIdx > 7) {\n // seq_tier[i]\n const seqTierTemp = bitstream.readBits(1);\n if (i === 0) {\n seqTier = seqTierTemp;\n }\n }\n if (decoderModelInfoPresentFlag) {\n // decoder_model_present_for_this_op[i]\n const decoderModelPresentForThisOp = bitstream.readBits(1);\n if (decoderModelPresentForThisOp) {\n const n = bufferDelayLengthMinus1 + 1;\n bitstream.skipBits(n); // decoder_buffer_delay[op]\n bitstream.skipBits(n); // encoder_buffer_delay[op]\n bitstream.skipBits(1); // low_delay_mode_flag[op]\n }\n }\n // initial_display_delay_present_flag\n const initialDisplayDelayPresentFlag = bitstream.readBits(1);\n if (initialDisplayDelayPresentFlag) {\n // initial_display_delay_minus_1[i]\n bitstream.skipBits(4);\n }\n }\n }\n const highBitdepth = bitstream.readBits(1);\n let bitDepth = 8;\n if (seqProfile === 2 && highBitdepth) {\n const twelveBit = bitstream.readBits(1);\n bitDepth = twelveBit ? 12 : 10;\n }\n else if (seqProfile <= 2) {\n bitDepth = highBitdepth ? 10 : 8;\n }\n let monochrome = 0;\n if (seqProfile !== 1) {\n monochrome = bitstream.readBits(1);\n }\n let chromaSubsamplingX = 1;\n let chromaSubsamplingY = 1;\n let chromaSamplePosition = 0;\n if (!monochrome) {\n if (seqProfile === 0) {\n chromaSubsamplingX = 1;\n chromaSubsamplingY = 1;\n }\n else if (seqProfile === 1) {\n chromaSubsamplingX = 0;\n chromaSubsamplingY = 0;\n }\n else {\n if (bitDepth === 12) {\n chromaSubsamplingX = bitstream.readBits(1);\n if (chromaSubsamplingX) {\n chromaSubsamplingY = bitstream.readBits(1);\n }\n }\n }\n if (chromaSubsamplingX && chromaSubsamplingY) {\n chromaSamplePosition = bitstream.readBits(2);\n }\n }\n return {\n profile: seqProfile,\n level: seqLevel,\n tier: seqTier,\n bitDepth,\n monochrome,\n chromaSubsamplingX,\n chromaSubsamplingY,\n chromaSamplePosition,\n };\n }\n return null;\n};\nexport const parseOpusIdentificationHeader = (bytes) => {\n const view = toDataView(bytes);\n const outputChannelCount = view.getUint8(9);\n const preSkip = view.getUint16(10, true);\n const inputSampleRate = view.getUint32(12, true);\n const outputGain = view.getInt16(16, true);\n const channelMappingFamily = view.getUint8(18);\n let channelMappingTable = null;\n if (channelMappingFamily) {\n channelMappingTable = bytes.subarray(19, 19 + 2 + outputChannelCount);\n }\n return {\n outputChannelCount,\n preSkip,\n inputSampleRate,\n outputGain,\n channelMappingFamily,\n channelMappingTable,\n };\n};\n// From https://datatracker.ietf.org/doc/html/rfc6716, in 48 kHz samples\nconst OPUS_FRAME_DURATION_TABLE = [\n 480, 960, 1920, 2880,\n 480, 960, 1920, 2880,\n 480, 960, 1920, 2880,\n 480, 960,\n 480, 960,\n 120, 240, 480, 960,\n 120, 240, 480, 960,\n 120, 240, 480, 960,\n 120, 240, 480, 960,\n];\nexport const parseOpusTocByte = (packet) => {\n const config = packet[0] >> 3;\n return {\n durationInSamples: OPUS_FRAME_DURATION_TABLE[config],\n };\n};\n// Based on vorbis_parser.c from FFmpeg.\nexport const parseModesFromVorbisSetupPacket = (setupHeader) => {\n // Verify that this is a Setup header.\n if (setupHeader.length < 7) {\n throw new Error('Setup header is too short.');\n }\n if (setupHeader[0] !== 5) {\n throw new Error('Wrong packet type in Setup header.');\n }\n const signature = String.fromCharCode(...setupHeader.slice(1, 7));\n if (signature !== 'vorbis') {\n throw new Error('Invalid packet signature in Setup header.');\n }\n // Reverse the entire buffer.\n const bufSize = setupHeader.length;\n const revBuffer = new Uint8Array(bufSize);\n for (let i = 0; i < bufSize; i++) {\n revBuffer[i] = setupHeader[bufSize - 1 - i];\n }\n // Initialize a Bitstream on the reversed buffer.\n const bitstream = new Bitstream(revBuffer);\n // --- Find the framing bit.\n // In FFmpeg code, we scan until get_bits1() returns 1.\n let gotFramingBit = 0;\n while (bitstream.getBitsLeft() > 97) {\n if (bitstream.readBits(1) === 1) {\n gotFramingBit = bitstream.pos;\n break;\n }\n }\n if (gotFramingBit === 0) {\n throw new Error('Invalid Setup header: framing bit not found.');\n }\n // --- Search backwards for a valid mode header.\n // We try to \u201Cguess\u201D the number of modes by reading a fixed pattern.\n let modeCount = 0;\n let gotModeHeader = false;\n let lastModeCount = 0;\n while (bitstream.getBitsLeft() >= 97) {\n const tempPos = bitstream.pos;\n const a = bitstream.readBits(8);\n const b = bitstream.readBits(16);\n const c = bitstream.readBits(16);\n // If a > 63 or b or c nonzero, assume we\u2019ve gone too far.\n if (a > 63 || b !== 0 || c !== 0) {\n bitstream.pos = tempPos;\n break;\n }\n bitstream.skipBits(1);\n modeCount++;\n if (modeCount > 64) {\n break;\n }\n const bsClone = bitstream.clone();\n const candidate = bsClone.readBits(6) + 1;\n if (candidate === modeCount) {\n gotModeHeader = true;\n lastModeCount = modeCount;\n }\n }\n if (!gotModeHeader) {\n throw new Error('Invalid Setup header: mode header not found.');\n }\n if (lastModeCount > 63) {\n throw new Error(`Unsupported mode count: ${lastModeCount}.`);\n }\n const finalModeCount = lastModeCount;\n // --- Reinitialize the bitstream.\n bitstream.pos = 0;\n // Skip the bits up to the found framing bit.\n bitstream.skipBits(gotFramingBit);\n // --- Now read, for each mode (in reverse order), 40 bits then one bit.\n // That one bit is the mode blockflag.\n const modeBlockflags = Array(finalModeCount).fill(0);\n for (let i = finalModeCount - 1; i >= 0; i--) {\n bitstream.skipBits(40);\n modeBlockflags[i] = bitstream.readBits(1);\n }\n return { modeBlockflags };\n};\n/** Determines a packet's type (key or delta) by digging into the packet bitstream. */\nexport const determineVideoPacketType = async (videoTrack, packet) => {\n assert(videoTrack.codec);\n switch (videoTrack.codec) {\n case 'avc':\n {\n const decoderConfig = await videoTrack.getDecoderConfig();\n assert(decoderConfig);\n const nalUnits = extractAvcNalUnits(packet.data, decoderConfig);\n const isKeyframe = nalUnits.some(x => extractNalUnitTypeForAvc(x) === AvcNalUnitType.IDR);\n return isKeyframe ? 'key' : 'delta';\n }\n ;\n case 'hevc':\n {\n const decoderConfig = await videoTrack.getDecoderConfig();\n assert(decoderConfig);\n const nalUnits = extractHevcNalUnits(packet.data, decoderConfig);\n const isKeyframe = nalUnits.some((x) => {\n const type = extractNalUnitTypeForHevc(x);\n return HevcNalUnitType.BLA_W_LP <= type && type <= HevcNalUnitType.RSV_IRAP_VCL23;\n });\n return isKeyframe ? 'key' : 'delta';\n }\n ;\n case 'vp8':\n {\n // VP8, once again, by far the easiest to deal with.\n const frameType = packet.data[0] & 0b1;\n return frameType === 0 ? 'key' : 'delta';\n }\n ;\n case 'vp9':\n {\n const bitstream = new Bitstream(packet.data);\n if (bitstream.readBits(2) !== 2) {\n return null;\n }\n ;\n const profileLowBit = bitstream.readBits(1);\n const profileHighBit = bitstream.readBits(1);\n const profile = (profileHighBit << 1) + profileLowBit;\n // Skip reserved bit for profile 3\n if (profile === 3) {\n bitstream.skipBits(1);\n }\n const showExistingFrame = bitstream.readBits(1);\n if (showExistingFrame) {\n return null;\n }\n const frameType = bitstream.readBits(1);\n return frameType === 0 ? 'key' : 'delta';\n }\n ;\n case 'av1':\n {\n let reducedStillPictureHeader = false;\n for (const { type, data } of iterateAv1PacketObus(packet.data)) {\n if (type === 1) { // OBU_SEQUENCE_HEADER\n const bitstream = new Bitstream(data);\n bitstream.skipBits(4);\n reducedStillPictureHeader = !!bitstream.readBits(1);\n }\n else if (type === 3 // OBU_FRAME_HEADER\n || type === 6 // OBU_FRAME\n || type === 7 // OBU_REDUNDANT_FRAME_HEADER\n ) {\n if (reducedStillPictureHeader) {\n return 'key';\n }\n const bitstream = new Bitstream(data);\n const showExistingFrame = bitstream.readBits(1);\n if (showExistingFrame) {\n return null;\n }\n const frameType = bitstream.readBits(2);\n return frameType === 0 ? 'key' : 'delta';\n }\n }\n return null;\n }\n ;\n default:\n {\n assertNever(videoTrack.codec);\n assert(false);\n }\n ;\n }\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nexport const buildIsobmffMimeType = (info) => {\n const base = info.hasVideo\n ? 'video/'\n : info.hasAudio\n ? 'audio/'\n : 'application/';\n let string = base + (info.isQuickTime ? 'quicktime' : 'mp4');\n if (info.codecStrings.length > 0) {\n const uniqueCodecMimeTypes = [...new Set(info.codecStrings)];\n string += `; codecs=\"${uniqueCodecMimeTypes.join(', ')}\"`;\n }\n return string;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { assert, clamp, toDataView } from './misc.js';\nexport class Reader {\n constructor(source) {\n this.source = source;\n }\n requestSlice(start, length) {\n if (this.fileSize !== null && start + length > this.fileSize) {\n return null;\n }\n const end = start + length;\n const result = this.source._read(start, end);\n if (result instanceof Promise) {\n return result.then((x) => {\n if (!x) {\n return null;\n }\n return new FileSlice(x.bytes, x.view, x.offset, start, end);\n });\n }\n else {\n if (!result) {\n return null;\n }\n return new FileSlice(result.bytes, result.view, result.offset, start, end);\n }\n }\n requestSliceRange(start, minLength, maxLength) {\n if (this.fileSize !== null) {\n return this.requestSlice(start, clamp(this.fileSize - start, minLength, maxLength));\n }\n else {\n const promisedAttempt = this.requestSlice(start, maxLength);\n const handleAttempt = (attempt) => {\n if (attempt) {\n return attempt;\n }\n const handleFileSize = (fileSize) => {\n assert(fileSize !== null); // The slice couldn't fit, meaning we must know the file size now\n return this.requestSlice(start, clamp(fileSize - start, minLength, maxLength));\n };\n const promisedFileSize = this.source._retrieveSize();\n if (promisedFileSize instanceof Promise) {\n return promisedFileSize.then(handleFileSize);\n }\n else {\n return handleFileSize(promisedFileSize);\n }\n };\n if (promisedAttempt instanceof Promise) {\n return promisedAttempt.then(handleAttempt);\n }\n else {\n return handleAttempt(promisedAttempt);\n }\n }\n }\n}\nexport class FileSlice {\n constructor(bytes, view, offset, start, end) {\n this.bytes = bytes;\n this.view = view;\n this.offset = offset;\n this.start = start;\n this.end = end;\n this.bufferPos = start - offset;\n }\n static tempFromBytes(bytes) {\n return new FileSlice(bytes, toDataView(bytes), 0, 0, bytes.length);\n }\n get length() {\n return this.end - this.start;\n }\n get filePos() {\n return this.offset + this.bufferPos;\n }\n set filePos(value) {\n this.bufferPos = value - this.offset;\n }\n skip(byteCount) {\n this.bufferPos += byteCount;\n }\n slice(filePos, length = this.end - filePos) {\n if (filePos < this.start || filePos + length > this.end) {\n throw new RangeError('Slicing outside of original slice.');\n }\n return new FileSlice(this.bytes, this.view, this.offset, filePos, filePos + length);\n }\n}\nexport const readBytes = (slice, length) => {\n const bytes = slice.bytes.subarray(slice.bufferPos, slice.bufferPos + length);\n slice.bufferPos += length;\n return bytes;\n};\nexport const readU8 = (slice) => slice.view.getUint8(slice.bufferPos++);\nexport const readU16 = (slice, littleEndian) => {\n const value = slice.view.getUint16(slice.bufferPos, littleEndian);\n slice.bufferPos += 2;\n return value;\n};\nexport const readU16Be = (slice) => {\n const value = slice.view.getUint16(slice.bufferPos, false);\n slice.bufferPos += 2;\n return value;\n};\nexport const readU24Be = (slice) => {\n const high = readU16Be(slice);\n const low = readU8(slice);\n return high * 0x100 + low;\n};\nexport const readI16Be = (slice) => {\n const value = slice.view.getInt16(slice.bufferPos, false);\n slice.bufferPos += 2;\n return value;\n};\nexport const readU32 = (slice, littleEndian) => {\n const value = slice.view.getUint32(slice.bufferPos, littleEndian);\n slice.bufferPos += 4;\n return value;\n};\nexport const readU32Be = (slice) => {\n const value = slice.view.getUint32(slice.bufferPos, false);\n slice.bufferPos += 4;\n return value;\n};\nexport const readU32Le = (slice) => {\n const value = slice.view.getUint32(slice.bufferPos, true);\n slice.bufferPos += 4;\n return value;\n};\nexport const readI32Be = (slice) => {\n const value = slice.view.getInt32(slice.bufferPos, false);\n slice.bufferPos += 4;\n return value;\n};\nexport const readI32Le = (slice) => {\n const value = slice.view.getInt32(slice.bufferPos, true);\n slice.bufferPos += 4;\n return value;\n};\nexport const readU64 = (slice, littleEndian) => {\n let low;\n let high;\n if (littleEndian) {\n low = readU32(slice, true);\n high = readU32(slice, true);\n }\n else {\n high = readU32(slice, false);\n low = readU32(slice, false);\n }\n return high * 0x100000000 + low;\n};\nexport const readU64Be = (slice) => {\n const high = readU32Be(slice);\n const low = readU32Be(slice);\n return high * 0x100000000 + low;\n};\nexport const readI64Be = (slice) => {\n const high = readI32Be(slice);\n const low = readU32Be(slice);\n return high * 0x100000000 + low;\n};\nexport const readI64Le = (slice) => {\n const low = readU32Le(slice);\n const high = readI32Le(slice);\n return high * 0x100000000 + low;\n};\nexport const readF32Be = (slice) => {\n const value = slice.view.getFloat32(slice.bufferPos, false);\n slice.bufferPos += 4;\n return value;\n};\nexport const readF64Be = (slice) => {\n const value = slice.view.getFloat64(slice.bufferPos, false);\n slice.bufferPos += 8;\n return value;\n};\nexport const readAscii = (slice, length) => {\n if (slice.bufferPos + length > slice.bytes.length) {\n throw new RangeError('Reading past end of slice.');\n }\n let str = '';\n for (let i = 0; i < length; i++) {\n str += String.fromCharCode(slice.bytes[slice.bufferPos++]);\n }\n return str;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { RichImageData } from '../tags.js';\nimport { textDecoder } from '../misc.js';\nimport { readAscii, readBytes, readI32Be, readU16Be, readU32Be, readU64Be, readU8 } from '../reader.js';\nexport const MIN_BOX_HEADER_SIZE = 8;\nexport const MAX_BOX_HEADER_SIZE = 16;\nexport const readBoxHeader = (slice) => {\n let totalSize = readU32Be(slice);\n const name = readAscii(slice, 4);\n let headerSize = 8;\n const hasLargeSize = totalSize === 1;\n if (hasLargeSize) {\n totalSize = readU64Be(slice);\n headerSize = 16;\n }\n const contentSize = totalSize - headerSize;\n if (contentSize < 0) {\n return null; // Hardly a box is it\n }\n return { name, totalSize, headerSize, contentSize };\n};\nexport const readFixed_16_16 = (slice) => {\n return readI32Be(slice) / 0x10000;\n};\nexport const readFixed_2_30 = (slice) => {\n return readI32Be(slice) / 0x40000000;\n};\nexport const readIsomVariableInteger = (slice) => {\n let result = 0;\n for (let i = 0; i < 4; i++) {\n result <<= 7;\n const nextByte = readU8(slice);\n result |= nextByte & 0x7f;\n if ((nextByte & 0x80) === 0) {\n break;\n }\n }\n return result;\n};\nexport const readMetadataStringShort = (slice) => {\n const stringLength = readU16Be(slice);\n slice.skip(2); // Language\n return textDecoder.decode(readBytes(slice, stringLength));\n};\nexport const readDataBox = (slice) => {\n const header = readBoxHeader(slice);\n if (!header || header.name !== 'data') {\n return null;\n }\n const typeIndicator = readU32Be(slice);\n slice.skip(4); // Locale indicator\n const data = readBytes(slice, header.contentSize - 8);\n switch (typeIndicator) {\n case 1: return textDecoder.decode(data); // UTF-8\n case 2: return new TextDecoder('utf-16be').decode(data); // UTF-16-BE\n case 13: return new RichImageData(data, 'image/jpeg');\n case 14: return new RichImageData(data, 'image/png');\n case 27: return new RichImageData(data, 'image/bmp');\n default: return data;\n }\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { assertNever, textDecoder, textEncoder } from '../misc.js';\nimport { readBytes, readF32Be, readF64Be, readU8 } from '../reader.js';\n/** Wrapper around a number to be able to differentiate it in the writer. */\nexport class EBMLFloat32 {\n constructor(value) {\n this.value = value;\n }\n}\n/** Wrapper around a number to be able to differentiate it in the writer. */\nexport class EBMLFloat64 {\n constructor(value) {\n this.value = value;\n }\n}\n/** Wrapper around a number to be able to differentiate it in the writer. */\nexport class EBMLSignedInt {\n constructor(value) {\n this.value = value;\n }\n}\nexport class EBMLUnicodeString {\n constructor(value) {\n this.value = value;\n }\n}\n/** Defines some of the EBML IDs used by Matroska files. */\nexport var EBMLId;\n(function (EBMLId) {\n EBMLId[EBMLId[\"EBML\"] = 440786851] = \"EBML\";\n EBMLId[EBMLId[\"EBMLVersion\"] = 17030] = \"EBMLVersion\";\n EBMLId[EBMLId[\"EBMLReadVersion\"] = 17143] = \"EBMLReadVersion\";\n EBMLId[EBMLId[\"EBMLMaxIDLength\"] = 17138] = \"EBMLMaxIDLength\";\n EBMLId[EBMLId[\"EBMLMaxSizeLength\"] = 17139] = \"EBMLMaxSizeLength\";\n EBMLId[EBMLId[\"DocType\"] = 17026] = \"DocType\";\n EBMLId[EBMLId[\"DocTypeVersion\"] = 17031] = \"DocTypeVersion\";\n EBMLId[EBMLId[\"DocTypeReadVersion\"] = 17029] = \"DocTypeReadVersion\";\n EBMLId[EBMLId[\"Void\"] = 236] = \"Void\";\n EBMLId[EBMLId[\"Segment\"] = 408125543] = \"Segment\";\n EBMLId[EBMLId[\"SeekHead\"] = 290298740] = \"SeekHead\";\n EBMLId[EBMLId[\"Seek\"] = 19899] = \"Seek\";\n EBMLId[EBMLId[\"SeekID\"] = 21419] = \"SeekID\";\n EBMLId[EBMLId[\"SeekPosition\"] = 21420] = \"SeekPosition\";\n EBMLId[EBMLId[\"Duration\"] = 17545] = \"Duration\";\n EBMLId[EBMLId[\"Info\"] = 357149030] = \"Info\";\n EBMLId[EBMLId[\"TimestampScale\"] = 2807729] = \"TimestampScale\";\n EBMLId[EBMLId[\"MuxingApp\"] = 19840] = \"MuxingApp\";\n EBMLId[EBMLId[\"WritingApp\"] = 22337] = \"WritingApp\";\n EBMLId[EBMLId[\"Tracks\"] = 374648427] = \"Tracks\";\n EBMLId[EBMLId[\"TrackEntry\"] = 174] = \"TrackEntry\";\n EBMLId[EBMLId[\"TrackNumber\"] = 215] = \"TrackNumber\";\n EBMLId[EBMLId[\"TrackUID\"] = 29637] = \"TrackUID\";\n EBMLId[EBMLId[\"TrackType\"] = 131] = \"TrackType\";\n EBMLId[EBMLId[\"FlagEnabled\"] = 185] = \"FlagEnabled\";\n EBMLId[EBMLId[\"FlagDefault\"] = 136] = \"FlagDefault\";\n EBMLId[EBMLId[\"FlagForced\"] = 21930] = \"FlagForced\";\n EBMLId[EBMLId[\"FlagLacing\"] = 156] = \"FlagLacing\";\n EBMLId[EBMLId[\"Name\"] = 21358] = \"Name\";\n EBMLId[EBMLId[\"Language\"] = 2274716] = \"Language\";\n EBMLId[EBMLId[\"LanguageBCP47\"] = 2274717] = \"LanguageBCP47\";\n EBMLId[EBMLId[\"CodecID\"] = 134] = \"CodecID\";\n EBMLId[EBMLId[\"CodecPrivate\"] = 25506] = \"CodecPrivate\";\n EBMLId[EBMLId[\"CodecDelay\"] = 22186] = \"CodecDelay\";\n EBMLId[EBMLId[\"SeekPreRoll\"] = 22203] = \"SeekPreRoll\";\n EBMLId[EBMLId[\"DefaultDuration\"] = 2352003] = \"DefaultDuration\";\n EBMLId[EBMLId[\"Video\"] = 224] = \"Video\";\n EBMLId[EBMLId[\"PixelWidth\"] = 176] = \"PixelWidth\";\n EBMLId[EBMLId[\"PixelHeight\"] = 186] = \"PixelHeight\";\n EBMLId[EBMLId[\"Audio\"] = 225] = \"Audio\";\n EBMLId[EBMLId[\"SamplingFrequency\"] = 181] = \"SamplingFrequency\";\n EBMLId[EBMLId[\"Channels\"] = 159] = \"Channels\";\n EBMLId[EBMLId[\"BitDepth\"] = 25188] = \"BitDepth\";\n EBMLId[EBMLId[\"SimpleBlock\"] = 163] = \"SimpleBlock\";\n EBMLId[EBMLId[\"BlockGroup\"] = 160] = \"BlockGroup\";\n EBMLId[EBMLId[\"Block\"] = 161] = \"Block\";\n EBMLId[EBMLId[\"BlockAdditions\"] = 30113] = \"BlockAdditions\";\n EBMLId[EBMLId[\"BlockMore\"] = 166] = \"BlockMore\";\n EBMLId[EBMLId[\"BlockAdditional\"] = 165] = \"BlockAdditional\";\n EBMLId[EBMLId[\"BlockAddID\"] = 238] = \"BlockAddID\";\n EBMLId[EBMLId[\"BlockDuration\"] = 155] = \"BlockDuration\";\n EBMLId[EBMLId[\"ReferenceBlock\"] = 251] = \"ReferenceBlock\";\n EBMLId[EBMLId[\"Cluster\"] = 524531317] = \"Cluster\";\n EBMLId[EBMLId[\"Timestamp\"] = 231] = \"Timestamp\";\n EBMLId[EBMLId[\"Cues\"] = 475249515] = \"Cues\";\n EBMLId[EBMLId[\"CuePoint\"] = 187] = \"CuePoint\";\n EBMLId[EBMLId[\"CueTime\"] = 179] = \"CueTime\";\n EBMLId[EBMLId[\"CueTrackPositions\"] = 183] = \"CueTrackPositions\";\n EBMLId[EBMLId[\"CueTrack\"] = 247] = \"CueTrack\";\n EBMLId[EBMLId[\"CueClusterPosition\"] = 241] = \"CueClusterPosition\";\n EBMLId[EBMLId[\"Colour\"] = 21936] = \"Colour\";\n EBMLId[EBMLId[\"MatrixCoefficients\"] = 21937] = \"MatrixCoefficients\";\n EBMLId[EBMLId[\"TransferCharacteristics\"] = 21946] = \"TransferCharacteristics\";\n EBMLId[EBMLId[\"Primaries\"] = 21947] = \"Primaries\";\n EBMLId[EBMLId[\"Range\"] = 21945] = \"Range\";\n EBMLId[EBMLId[\"Projection\"] = 30320] = \"Projection\";\n EBMLId[EBMLId[\"ProjectionType\"] = 30321] = \"ProjectionType\";\n EBMLId[EBMLId[\"ProjectionPoseRoll\"] = 30325] = \"ProjectionPoseRoll\";\n EBMLId[EBMLId[\"Attachments\"] = 423732329] = \"Attachments\";\n EBMLId[EBMLId[\"AttachedFile\"] = 24999] = \"AttachedFile\";\n EBMLId[EBMLId[\"FileDescription\"] = 18046] = \"FileDescription\";\n EBMLId[EBMLId[\"FileName\"] = 18030] = \"FileName\";\n EBMLId[EBMLId[\"FileMediaType\"] = 18016] = \"FileMediaType\";\n EBMLId[EBMLId[\"FileData\"] = 18012] = \"FileData\";\n EBMLId[EBMLId[\"FileUID\"] = 18094] = \"FileUID\";\n EBMLId[EBMLId[\"Chapters\"] = 272869232] = \"Chapters\";\n EBMLId[EBMLId[\"Tags\"] = 307544935] = \"Tags\";\n EBMLId[EBMLId[\"Tag\"] = 29555] = \"Tag\";\n EBMLId[EBMLId[\"Targets\"] = 25536] = \"Targets\";\n EBMLId[EBMLId[\"TargetTypeValue\"] = 26826] = \"TargetTypeValue\";\n EBMLId[EBMLId[\"TargetType\"] = 25546] = \"TargetType\";\n EBMLId[EBMLId[\"TagTrackUID\"] = 25541] = \"TagTrackUID\";\n EBMLId[EBMLId[\"TagEditionUID\"] = 25545] = \"TagEditionUID\";\n EBMLId[EBMLId[\"TagChapterUID\"] = 25540] = \"TagChapterUID\";\n EBMLId[EBMLId[\"TagAttachmentUID\"] = 25542] = \"TagAttachmentUID\";\n EBMLId[EBMLId[\"SimpleTag\"] = 26568] = \"SimpleTag\";\n EBMLId[EBMLId[\"TagName\"] = 17827] = \"TagName\";\n EBMLId[EBMLId[\"TagLanguage\"] = 17530] = \"TagLanguage\";\n EBMLId[EBMLId[\"TagString\"] = 17543] = \"TagString\";\n EBMLId[EBMLId[\"TagBinary\"] = 17541] = \"TagBinary\";\n})(EBMLId || (EBMLId = {}));\nexport const LEVEL_0_EBML_IDS = [\n EBMLId.EBML,\n EBMLId.Segment,\n];\n// All the stuff that can appear in a segment, basically\nexport const LEVEL_1_EBML_IDS = [\n EBMLId.SeekHead,\n EBMLId.Info,\n EBMLId.Cluster,\n EBMLId.Tracks,\n EBMLId.Cues,\n EBMLId.Attachments,\n EBMLId.Chapters,\n EBMLId.Tags,\n];\nexport const LEVEL_0_AND_1_EBML_IDS = [\n ...LEVEL_0_EBML_IDS,\n ...LEVEL_1_EBML_IDS,\n];\nexport const measureUnsignedInt = (value) => {\n if (value < (1 << 8)) {\n return 1;\n }\n else if (value < (1 << 16)) {\n return 2;\n }\n else if (value < (1 << 24)) {\n return 3;\n }\n else if (value < 2 ** 32) {\n return 4;\n }\n else if (value < 2 ** 40) {\n return 5;\n }\n else {\n return 6;\n }\n};\nexport const measureSignedInt = (value) => {\n if (value >= -(1 << 6) && value < (1 << 6)) {\n return 1;\n }\n else if (value >= -(1 << 13) && value < (1 << 13)) {\n return 2;\n }\n else if (value >= -(1 << 20) && value < (1 << 20)) {\n return 3;\n }\n else if (value >= -(1 << 27) && value < (1 << 27)) {\n return 4;\n }\n else if (value >= -(2 ** 34) && value < 2 ** 34) {\n return 5;\n }\n else {\n return 6;\n }\n};\nexport const measureVarInt = (value) => {\n if (value < (1 << 7) - 1) {\n /** Top bit is set, leaving 7 bits to hold the integer, but we can't store\n * 127 because \"all bits set to one\" is a reserved value. Same thing for the\n * other cases below:\n */\n return 1;\n }\n else if (value < (1 << 14) - 1) {\n return 2;\n }\n else if (value < (1 << 21) - 1) {\n return 3;\n }\n else if (value < (1 << 28) - 1) {\n return 4;\n }\n else if (value < 2 ** 35 - 1) {\n return 5;\n }\n else if (value < 2 ** 42 - 1) {\n return 6;\n }\n else {\n throw new Error('EBML varint size not supported ' + value);\n }\n};\nexport class EBMLWriter {\n constructor(writer) {\n this.writer = writer;\n this.helper = new Uint8Array(8);\n this.helperView = new DataView(this.helper.buffer);\n /**\n * Stores the position from the start of the file to where EBML elements have been written. This is used to\n * rewrite/edit elements that were already added before, and to measure sizes of things.\n */\n this.offsets = new WeakMap();\n /** Same as offsets, but stores position where the element's data starts (after ID and size fields). */\n this.dataOffsets = new WeakMap();\n }\n writeByte(value) {\n this.helperView.setUint8(0, value);\n this.writer.write(this.helper.subarray(0, 1));\n }\n writeFloat32(value) {\n this.helperView.setFloat32(0, value, false);\n this.writer.write(this.helper.subarray(0, 4));\n }\n writeFloat64(value) {\n this.helperView.setFloat64(0, value, false);\n this.writer.write(this.helper);\n }\n writeUnsignedInt(value, width = measureUnsignedInt(value)) {\n let pos = 0;\n // Each case falls through:\n switch (width) {\n case 6:\n // Need to use division to access >32 bits of floating point var\n this.helperView.setUint8(pos++, (value / 2 ** 40) | 0);\n // eslint-disable-next-line no-fallthrough\n case 5:\n this.helperView.setUint8(pos++, (value / 2 ** 32) | 0);\n // eslint-disable-next-line no-fallthrough\n case 4:\n this.helperView.setUint8(pos++, value >> 24);\n // eslint-disable-next-line no-fallthrough\n case 3:\n this.helperView.setUint8(pos++, value >> 16);\n // eslint-disable-next-line no-fallthrough\n case 2:\n this.helperView.setUint8(pos++, value >> 8);\n // eslint-disable-next-line no-fallthrough\n case 1:\n this.helperView.setUint8(pos++, value);\n break;\n default:\n throw new Error('Bad unsigned int size ' + width);\n }\n this.writer.write(this.helper.subarray(0, pos));\n }\n writeSignedInt(value, width = measureSignedInt(value)) {\n if (value < 0) {\n // Two's complement stuff\n value += 2 ** (width * 8);\n }\n this.writeUnsignedInt(value, width);\n }\n writeVarInt(value, width = measureVarInt(value)) {\n let pos = 0;\n switch (width) {\n case 1:\n this.helperView.setUint8(pos++, (1 << 7) | value);\n break;\n case 2:\n this.helperView.setUint8(pos++, (1 << 6) | (value >> 8));\n this.helperView.setUint8(pos++, value);\n break;\n case 3:\n this.helperView.setUint8(pos++, (1 << 5) | (value >> 16));\n this.helperView.setUint8(pos++, value >> 8);\n this.helperView.setUint8(pos++, value);\n break;\n case 4:\n this.helperView.setUint8(pos++, (1 << 4) | (value >> 24));\n this.helperView.setUint8(pos++, value >> 16);\n this.helperView.setUint8(pos++, value >> 8);\n this.helperView.setUint8(pos++, value);\n break;\n case 5:\n /**\n * JavaScript converts its doubles to 32-bit integers for bitwise\n * operations, so we need to do a division by 2^32 instead of a\n * right-shift of 32 to retain those top 3 bits\n */\n this.helperView.setUint8(pos++, (1 << 3) | ((value / 2 ** 32) & 0x7));\n this.helperView.setUint8(pos++, value >> 24);\n this.helperView.setUint8(pos++, value >> 16);\n this.helperView.setUint8(pos++, value >> 8);\n this.helperView.setUint8(pos++, value);\n break;\n case 6:\n this.helperView.setUint8(pos++, (1 << 2) | ((value / 2 ** 40) & 0x3));\n this.helperView.setUint8(pos++, (value / 2 ** 32) | 0);\n this.helperView.setUint8(pos++, value >> 24);\n this.helperView.setUint8(pos++, value >> 16);\n this.helperView.setUint8(pos++, value >> 8);\n this.helperView.setUint8(pos++, value);\n break;\n default:\n throw new Error('Bad EBML varint size ' + width);\n }\n this.writer.write(this.helper.subarray(0, pos));\n }\n writeAsciiString(str) {\n this.writer.write(new Uint8Array(str.split('').map(x => x.charCodeAt(0))));\n }\n writeEBML(data) {\n if (data === null)\n return;\n if (data instanceof Uint8Array) {\n this.writer.write(data);\n }\n else if (Array.isArray(data)) {\n for (const elem of data) {\n this.writeEBML(elem);\n }\n }\n else {\n this.offsets.set(data, this.writer.getPos());\n this.writeUnsignedInt(data.id); // ID field\n if (Array.isArray(data.data)) {\n const sizePos = this.writer.getPos();\n const sizeSize = data.size === -1 ? 1 : (data.size ?? 4);\n if (data.size === -1) {\n // Write the reserved all-one-bits marker for unknown/unbounded size.\n this.writeByte(0xff);\n }\n else {\n this.writer.seek(this.writer.getPos() + sizeSize);\n }\n const startPos = this.writer.getPos();\n this.dataOffsets.set(data, startPos);\n this.writeEBML(data.data);\n if (data.size !== -1) {\n const size = this.writer.getPos() - startPos;\n const endPos = this.writer.getPos();\n this.writer.seek(sizePos);\n this.writeVarInt(size, sizeSize);\n this.writer.seek(endPos);\n }\n }\n else if (typeof data.data === 'number') {\n const size = data.size ?? measureUnsignedInt(data.data);\n this.writeVarInt(size);\n this.writeUnsignedInt(data.data, size);\n }\n else if (typeof data.data === 'string') {\n this.writeVarInt(data.data.length);\n this.writeAsciiString(data.data);\n }\n else if (data.data instanceof Uint8Array) {\n this.writeVarInt(data.data.byteLength, data.size);\n this.writer.write(data.data);\n }\n else if (data.data instanceof EBMLFloat32) {\n this.writeVarInt(4);\n this.writeFloat32(data.data.value);\n }\n else if (data.data instanceof EBMLFloat64) {\n this.writeVarInt(8);\n this.writeFloat64(data.data.value);\n }\n else if (data.data instanceof EBMLSignedInt) {\n const size = data.size ?? measureSignedInt(data.data.value);\n this.writeVarInt(size);\n this.writeSignedInt(data.data.value, size);\n }\n else if (data.data instanceof EBMLUnicodeString) {\n const bytes = textEncoder.encode(data.data.value);\n this.writeVarInt(bytes.length);\n this.writer.write(bytes);\n }\n else {\n assertNever(data.data);\n }\n }\n }\n}\nexport const MAX_VAR_INT_SIZE = 8;\nexport const MIN_HEADER_SIZE = 2; // 1-byte ID and 1-byte size\nexport const MAX_HEADER_SIZE = 2 * MAX_VAR_INT_SIZE; // 8-byte ID and 8-byte size\nexport const readVarIntSize = (slice) => {\n const firstByte = readU8(slice);\n slice.skip(-1);\n if (firstByte === 0) {\n return null; // Invalid VINT\n }\n let width = 1;\n let mask = 0x80;\n while ((firstByte & mask) === 0) {\n width++;\n mask >>= 1;\n }\n return width;\n};\nexport const readVarInt = (slice) => {\n // Read the first byte to determine the width of the variable-length integer\n const firstByte = readU8(slice);\n if (firstByte === 0) {\n return null; // Invalid VINT\n }\n // Find the position of VINT_MARKER, which determines the width\n let width = 1;\n let mask = 1 << 7;\n while ((firstByte & mask) === 0) {\n width++;\n mask >>= 1;\n }\n // First byte's value needs the marker bit cleared\n let value = firstByte & (mask - 1);\n // Read remaining bytes\n for (let i = 1; i < width; i++) {\n value *= 1 << 8;\n value += readU8(slice);\n }\n return value;\n};\nexport const readUnsignedInt = (slice, width) => {\n if (width < 1 || width > 8) {\n throw new Error('Bad unsigned int size ' + width);\n }\n let value = 0;\n // Read bytes from most significant to least significant\n for (let i = 0; i < width; i++) {\n value *= 1 << 8;\n value += readU8(slice);\n }\n return value;\n};\nexport const readSignedInt = (slice, width) => {\n let value = readUnsignedInt(slice, width);\n // If the highest bit is set, convert from two's complement\n if (value & (1 << (width * 8 - 1))) {\n value -= 2 ** (width * 8);\n }\n return value;\n};\nexport const readElementId = (slice) => {\n const size = readVarIntSize(slice);\n if (size === null) {\n return null;\n }\n const id = readUnsignedInt(slice, size);\n return id;\n};\nexport const readElementSize = (slice) => {\n let size = readU8(slice);\n if (size === 0xff) {\n size = null;\n }\n else {\n slice.skip(-1);\n size = readVarInt(slice);\n // In some (livestreamed) files, this is the value of the size field. While this technically is just a very\n // large number, it is intended to behave like the reserved size 0xFF, meaning the size is undefined. We\n // catch the number here. Note that it cannot be perfectly represented as a double, but the comparison works\n // nonetheless.\n // eslint-disable-next-line no-loss-of-precision\n if (size === 0x00ffffffffffffff) {\n size = null;\n }\n }\n return size;\n};\nexport const readElementHeader = (slice) => {\n const id = readElementId(slice);\n if (id === null) {\n return null;\n }\n const size = readElementSize(slice);\n return { id, size };\n};\nexport const readAsciiString = (slice, length) => {\n const bytes = readBytes(slice, length);\n // Actual string length might be shorter due to null terminators\n let strLength = 0;\n while (strLength < length && bytes[strLength] !== 0) {\n strLength += 1;\n }\n return String.fromCharCode(...bytes.subarray(0, strLength));\n};\nexport const readUnicodeString = (slice, length) => {\n const bytes = readBytes(slice, length);\n // Actual string length might be shorter due to null terminators\n let strLength = 0;\n while (strLength < length && bytes[strLength] !== 0) {\n strLength += 1;\n }\n return textDecoder.decode(bytes.subarray(0, strLength));\n};\nexport const readFloat = (slice, width) => {\n if (width === 0) {\n return 0;\n }\n if (width !== 4 && width !== 8) {\n throw new Error('Bad float size ' + width);\n }\n return width === 4 ? readF32Be(slice) : readF64Be(slice);\n};\n/** Returns the byte offset in the file of the next element with a matching ID. */\nexport const searchForNextElementId = async (reader, startPos, ids, until) => {\n const idsSet = new Set(ids);\n let currentPos = startPos;\n while (until === null || currentPos < until) {\n let slice = reader.requestSliceRange(currentPos, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const elementHeader = readElementHeader(slice);\n if (!elementHeader) {\n break;\n }\n if (idsSet.has(elementHeader.id)) {\n return { pos: currentPos, found: true };\n }\n assertDefinedSize(elementHeader.size);\n currentPos = slice.filePos + elementHeader.size;\n }\n return { pos: (until !== null && until > currentPos) ? until : currentPos, found: false };\n};\n/** Searches for the next occurrence of an element ID using a naive byte-wise search. */\nexport const resync = async (reader, startPos, ids, until) => {\n const CHUNK_SIZE = 2 ** 16; // So we don't need to grab thousands of slices\n const idsSet = new Set(ids);\n let currentPos = startPos;\n while (currentPos < until) {\n let slice = reader.requestSliceRange(currentPos, 0, Math.min(CHUNK_SIZE, until - currentPos));\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n if (slice.length < MAX_VAR_INT_SIZE)\n break;\n for (let i = 0; i < slice.length - MAX_VAR_INT_SIZE; i++) {\n slice.filePos = currentPos;\n const elementId = readElementId(slice);\n if (elementId !== null && idsSet.has(elementId)) {\n return currentPos;\n }\n currentPos++;\n }\n }\n return null;\n};\nexport const CODEC_STRING_MAP = {\n 'avc': 'V_MPEG4/ISO/AVC',\n 'hevc': 'V_MPEGH/ISO/HEVC',\n 'vp8': 'V_VP8',\n 'vp9': 'V_VP9',\n 'av1': 'V_AV1',\n 'aac': 'A_AAC',\n 'mp3': 'A_MPEG/L3',\n 'opus': 'A_OPUS',\n 'vorbis': 'A_VORBIS',\n 'flac': 'A_FLAC',\n 'pcm-u8': 'A_PCM/INT/LIT',\n 'pcm-s16': 'A_PCM/INT/LIT',\n 'pcm-s16be': 'A_PCM/INT/BIG',\n 'pcm-s24': 'A_PCM/INT/LIT',\n 'pcm-s24be': 'A_PCM/INT/BIG',\n 'pcm-s32': 'A_PCM/INT/LIT',\n 'pcm-s32be': 'A_PCM/INT/BIG',\n 'pcm-f32': 'A_PCM/FLOAT/IEEE',\n 'pcm-f64': 'A_PCM/FLOAT/IEEE',\n 'webvtt': 'S_TEXT/WEBVTT',\n};\nexport function assertDefinedSize(size) {\n if (size === null) {\n throw new Error('Undefined element size is used in a place where it is not supported.');\n }\n}\n;\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nexport const buildMatroskaMimeType = (info) => {\n const base = info.hasVideo\n ? 'video/'\n : info.hasAudio\n ? 'audio/'\n : 'application/';\n let string = base + (info.isWebM ? 'webm' : 'x-matroska');\n if (info.codecStrings.length > 0) {\n const uniqueCodecMimeTypes = [...new Set(info.codecStrings.filter(Boolean))];\n string += `; codecs=\"${uniqueCodecMimeTypes.join(', ')}\"`;\n }\n return string;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nexport const FRAME_HEADER_SIZE = 4;\n// These are in kbps:\nexport const MPEG_V1_BITRATES = {\n // Layer 3\n 1: [-1, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, -1],\n // Layer 2\n 2: [-1, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, -1],\n // Layer 1\n 3: [-1, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, -1],\n};\nexport const MPEG_V2_BITRATES = {\n // Layer 3\n 1: [-1, 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256, -1],\n // Layer 2\n 2: [-1, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1],\n // Layer 1\n 3: [-1, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160, -1],\n};\nexport const SAMPLING_RATES = {\n // MPEG Version 2.5\n 0: [11025, 12000, 8000, -1],\n // MPEG Version 2 (ISO/IEC 13818-3)\n 2: [22050, 24000, 16000, -1],\n // MPEG Version 1 (ISO/IEC 11172-3)\n 3: [44100, 48000, 32000, -1],\n};\n/** 'Xing' */\nexport const XING = 0x58696e67;\n/** 'Info' */\nexport const INFO = 0x496e666f;\nexport const computeMp3FrameSize = (layer, bitrate, sampleRate, padding) => {\n if (layer === 3) {\n // Layer 1\n return Math.floor((12 * bitrate / sampleRate + padding) * 4);\n }\n else {\n return Math.floor((144 * bitrate / sampleRate) + padding);\n }\n};\nexport const getXingOffset = (mpegVersionId, channel) => {\n return mpegVersionId === 3\n ? (channel === 3 ? 21 : 36)\n : (channel === 3 ? 13 : 21);\n};\nexport const readFrameHeader = (word, remainingBytes) => {\n const firstByte = word >>> 24;\n const secondByte = (word >>> 16) & 0xff;\n const thirdByte = (word >>> 8) & 0xff;\n const fourthByte = word & 0xff;\n if (firstByte !== 0xff && secondByte !== 0xff && thirdByte !== 0xff && fourthByte !== 0xff) {\n return {\n header: null,\n bytesAdvanced: 4,\n };\n }\n if (firstByte !== 0xff) {\n return { header: null, bytesAdvanced: 1 };\n }\n if ((secondByte & 0xe0) !== 0xe0) {\n return { header: null, bytesAdvanced: 1 };\n }\n const mpegVersionId = (secondByte >> 3) & 0x3;\n const layer = (secondByte >> 1) & 0x3;\n const bitrateIndex = (thirdByte >> 4) & 0xf;\n const frequencyIndex = (thirdByte >> 2) & 0x3;\n const padding = (thirdByte >> 1) & 0x1;\n const channel = (fourthByte >> 6) & 0x3;\n const modeExtension = (fourthByte >> 4) & 0x3;\n const copyright = (fourthByte >> 3) & 0x1;\n const original = (fourthByte >> 2) & 0x1;\n const emphasis = fourthByte & 0x3;\n const kilobitRate = mpegVersionId === 3\n ? MPEG_V1_BITRATES[layer]?.[bitrateIndex]\n : MPEG_V2_BITRATES[layer]?.[bitrateIndex];\n if (!kilobitRate || kilobitRate === -1) {\n return { header: null, bytesAdvanced: 1 };\n }\n const bitrate = kilobitRate * 1000;\n const sampleRate = SAMPLING_RATES[mpegVersionId]?.[frequencyIndex];\n if (!sampleRate || sampleRate === -1) {\n return { header: null, bytesAdvanced: 1 };\n }\n const frameLength = computeMp3FrameSize(layer, bitrate, sampleRate, padding);\n if (remainingBytes !== null && remainingBytes < frameLength) {\n // The frame doesn't fit into the rest of the file\n return { header: null, bytesAdvanced: 1 };\n }\n let audioSamplesInFrame;\n if (mpegVersionId === 3) {\n audioSamplesInFrame = layer === 3 ? 384 : 1152;\n }\n else {\n if (layer === 3) {\n audioSamplesInFrame = 384;\n }\n else if (layer === 2) {\n audioSamplesInFrame = 1152;\n }\n else {\n audioSamplesInFrame = 576;\n }\n }\n return {\n header: {\n totalSize: frameLength,\n mpegVersionId,\n layer,\n bitrate,\n frequencyIndex,\n sampleRate,\n channel,\n modeExtension,\n copyright,\n original,\n emphasis,\n audioSamplesInFrame,\n },\n bytesAdvanced: 1,\n };\n};\nexport const encodeSynchsafe = (unsynchsafed) => {\n let mask = 0x7f;\n let synchsafed = 0;\n let unsynchsafedRest = unsynchsafed;\n while ((mask ^ 0x7fffffff) !== 0) {\n synchsafed = unsynchsafedRest & ~mask;\n synchsafed <<= 1;\n synchsafed |= unsynchsafedRest & mask;\n mask = ((mask + 1) << 8) - 1;\n unsynchsafedRest = synchsafed;\n }\n return synchsafed;\n};\nexport const decodeSynchsafe = (synchsafed) => {\n let mask = 0x7f000000;\n let unsynchsafed = 0;\n while (mask !== 0) {\n unsynchsafed >>= 1;\n unsynchsafed |= synchsafed & mask;\n mask >>= 8;\n }\n return unsynchsafed;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { decodeSynchsafe, FRAME_HEADER_SIZE, readFrameHeader } from '../../shared/mp3-misc.js';\nimport { coalesceIndex, textDecoder } from '../misc.js';\nimport { readAscii, readBytes, readU32Be, readU8 } from '../reader.js';\nexport var Id3V2HeaderFlags;\n(function (Id3V2HeaderFlags) {\n Id3V2HeaderFlags[Id3V2HeaderFlags[\"Unsynchronisation\"] = 128] = \"Unsynchronisation\";\n Id3V2HeaderFlags[Id3V2HeaderFlags[\"ExtendedHeader\"] = 64] = \"ExtendedHeader\";\n Id3V2HeaderFlags[Id3V2HeaderFlags[\"ExperimentalIndicator\"] = 32] = \"ExperimentalIndicator\";\n Id3V2HeaderFlags[Id3V2HeaderFlags[\"Footer\"] = 16] = \"Footer\";\n})(Id3V2HeaderFlags || (Id3V2HeaderFlags = {}));\nexport var Id3V2TextEncoding;\n(function (Id3V2TextEncoding) {\n Id3V2TextEncoding[Id3V2TextEncoding[\"ISO_8859_1\"] = 0] = \"ISO_8859_1\";\n Id3V2TextEncoding[Id3V2TextEncoding[\"UTF_16_WITH_BOM\"] = 1] = \"UTF_16_WITH_BOM\";\n Id3V2TextEncoding[Id3V2TextEncoding[\"UTF_16_BE_NO_BOM\"] = 2] = \"UTF_16_BE_NO_BOM\";\n Id3V2TextEncoding[Id3V2TextEncoding[\"UTF_8\"] = 3] = \"UTF_8\";\n})(Id3V2TextEncoding || (Id3V2TextEncoding = {}));\nexport const ID3_V1_TAG_SIZE = 128;\nexport const ID3_V2_HEADER_SIZE = 10;\nexport const ID3_V1_GENRES = [\n 'Blues', 'Classic rock', 'Country', 'Dance', 'Disco', 'Funk', 'Grunge', 'Hip-hop', 'Jazz',\n 'Metal', 'New age', 'Oldies', 'Other', 'Pop', 'Rhythm and blues', 'Rap', 'Reggae', 'Rock',\n 'Techno', 'Industrial', 'Alternative', 'Ska', 'Death metal', 'Pranks', 'Soundtrack',\n 'Euro-techno', 'Ambient', 'Trip-hop', 'Vocal', 'Jazz & funk', 'Fusion', 'Trance', 'Classical',\n 'Instrumental', 'Acid', 'House', 'Game', 'Sound clip', 'Gospel', 'Noise', 'Alternative rock',\n 'Bass', 'Soul', 'Punk', 'Space', 'Meditative', 'Instrumental pop', 'Instrumental rock',\n 'Ethnic', 'Gothic', 'Darkwave', 'Techno-industrial', 'Electronic', 'Pop-folk', 'Eurodance',\n 'Dream', 'Southern rock', 'Comedy', 'Cult', 'Gangsta', 'Top 40', 'Christian rap', 'Pop/funk',\n 'Jungle music', 'Native US', 'Cabaret', 'New wave', 'Psychedelic', 'Rave', 'Showtunes',\n 'Trailer', 'Lo-fi', 'Tribal', 'Acid punk', 'Acid jazz', 'Polka', 'Retro', 'Musical',\n 'Rock \\'n\\' roll', 'Hard rock', 'Folk', 'Folk rock', 'National folk', 'Swing', 'Fast fusion',\n 'Bebop', 'Latin', 'Revival', 'Celtic', 'Bluegrass', 'Avantgarde', 'Gothic rock',\n 'Progressive rock', 'Psychedelic rock', 'Symphonic rock', 'Slow rock', 'Big band', 'Chorus',\n 'Easy listening', 'Acoustic', 'Humour', 'Speech', 'Chanson', 'Opera', 'Chamber music',\n 'Sonata', 'Symphony', 'Booty bass', 'Primus', 'Porn groove', 'Satire', 'Slow jam', 'Club',\n 'Tango', 'Samba', 'Folklore', 'Ballad', 'Power ballad', 'Rhythmic Soul', 'Freestyle', 'Duet',\n 'Punk rock', 'Drum solo', 'A cappella', 'Euro-house', 'Dance hall', 'Goa music', 'Drum & bass',\n 'Club-house', 'Hardcore techno', 'Terror', 'Indie', 'Britpop', 'Negerpunk', 'Polsk punk',\n 'Beat', 'Christian gangsta rap', 'Heavy metal', 'Black metal', 'Crossover',\n 'Contemporary Christian', 'Christian rock', 'Merengue', 'Salsa', 'Thrash metal', 'Anime',\n 'Jpop', 'Synthpop', 'Christmas', 'Art rock', 'Baroque', 'Bhangra', 'Big beat', 'Breakbeat',\n 'Chillout', 'Downtempo', 'Dub', 'EBM', 'Eclectic', 'Electro', 'Electroclash', 'Emo',\n 'Experimental', 'Garage', 'Global', 'IDM', 'Illbient', 'Industro-Goth', 'Jam Band',\n 'Krautrock', 'Leftfield', 'Lounge', 'Math rock', 'New romantic', 'Nu-breakz', 'Post-punk',\n 'Post-rock', 'Psytrance', 'Shoegaze', 'Space rock', 'Trop rock', 'World music', 'Neoclassical',\n 'Audiobook', 'Audio theatre', 'Neue Deutsche Welle', 'Podcast', 'Indie rock', 'G-Funk',\n 'Dubstep', 'Garage rock', 'Psybient',\n];\nexport const readNextFrameHeader = async (reader, startPos, until) => {\n let currentPos = startPos;\n while (until === null || currentPos < until) {\n let slice = reader.requestSlice(currentPos, FRAME_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const word = readU32Be(slice);\n const result = readFrameHeader(word, reader.fileSize !== null ? reader.fileSize - currentPos : null);\n if (result.header) {\n return { header: result.header, startPos: currentPos };\n }\n currentPos += result.bytesAdvanced;\n }\n return null;\n};\nexport const parseId3V1Tag = (slice, tags) => {\n const startPos = slice.filePos;\n tags.raw ??= {};\n tags.raw['TAG'] ??= readBytes(slice, ID3_V1_TAG_SIZE - 3); // Dump the whole tag into the raw metadata\n slice.filePos = startPos;\n const title = readId3V1String(slice, 30);\n if (title)\n tags.title ??= title;\n const artist = readId3V1String(slice, 30);\n if (artist)\n tags.artist ??= artist;\n const album = readId3V1String(slice, 30);\n if (album)\n tags.album ??= album;\n const yearText = readId3V1String(slice, 4);\n const year = Number.parseInt(yearText, 10);\n if (Number.isInteger(year) && year > 0) {\n tags.date ??= new Date(year, 0, 1);\n }\n const commentBytes = readBytes(slice, 30);\n let comment;\n // Check for the ID3v1.1 track number format:\n // The 29th byte (index 28) is a null terminator, and the 30th byte is the track number.\n if (commentBytes[28] === 0 && commentBytes[29] !== 0) {\n const trackNum = commentBytes[29];\n if (trackNum > 0) {\n tags.trackNumber ??= trackNum;\n }\n slice.skip(-30);\n comment = readId3V1String(slice, 28);\n slice.skip(2);\n }\n else {\n slice.skip(-30);\n comment = readId3V1String(slice, 30);\n }\n if (comment)\n tags.comment ??= comment;\n const genreIndex = readU8(slice);\n if (genreIndex < ID3_V1_GENRES.length) {\n tags.genre ??= ID3_V1_GENRES[genreIndex];\n }\n};\nexport const readId3V1String = (slice, length) => {\n const bytes = readBytes(slice, length);\n const endIndex = coalesceIndex(bytes.indexOf(0), bytes.length);\n const relevantBytes = bytes.subarray(0, endIndex);\n // Decode as ISO-8859-1\n let str = '';\n for (let i = 0; i < relevantBytes.length; i++) {\n str += String.fromCharCode(relevantBytes[i]);\n }\n return str.trimEnd(); // String also may be padded with spaces\n};\nexport const readId3V2Header = (slice) => {\n const startPos = slice.filePos;\n const tag = readAscii(slice, 3);\n const majorVersion = readU8(slice);\n const revision = readU8(slice);\n const flags = readU8(slice);\n const sizeRaw = readU32Be(slice);\n if (tag !== 'ID3' || majorVersion === 0xff || revision === 0xff || (sizeRaw & 0x80808080) !== 0) {\n slice.filePos = startPos;\n return null;\n }\n const size = decodeSynchsafe(sizeRaw);\n return { majorVersion, revision, flags, size };\n};\nexport const parseId3V2Tag = (slice, header, tags) => {\n // https://id3.org/id3v2.3.0\n if (![2, 3, 4].includes(header.majorVersion)) {\n console.warn(`Unsupported ID3v2 major version: ${header.majorVersion}`);\n return;\n }\n const bytes = readBytes(slice, header.size);\n const reader = new Id3V2Reader(header, bytes);\n if (header.flags & Id3V2HeaderFlags.Footer) {\n reader.removeFooter();\n }\n if ((header.flags & Id3V2HeaderFlags.Unsynchronisation) && header.majorVersion === 3) {\n reader.ununsynchronizeAll();\n }\n if (header.flags & Id3V2HeaderFlags.ExtendedHeader) {\n const extendedHeaderSize = reader.readU32();\n if (header.majorVersion === 3) {\n reader.pos += extendedHeaderSize; // The extended header size excludes itself\n }\n else {\n reader.pos += extendedHeaderSize - 4; // The extended header size includes itself\n }\n }\n while (reader.pos <= reader.bytes.length - reader.frameHeaderSize()) {\n const frame = reader.readId3V2Frame();\n if (!frame) {\n break;\n }\n const frameStartPos = reader.pos;\n const frameEndPos = reader.pos + frame.size;\n let frameEncrypted = false;\n let frameCompressed = false;\n let frameUnsynchronized = false;\n if (header.majorVersion === 3) {\n frameEncrypted = !!(frame.flags & (1 << 6));\n frameCompressed = !!(frame.flags & (1 << 7));\n }\n else if (header.majorVersion === 4) {\n frameEncrypted = !!(frame.flags & (1 << 2));\n frameCompressed = !!(frame.flags & (1 << 3));\n frameUnsynchronized = !!(frame.flags & (1 << 1))\n || !!(header.flags & Id3V2HeaderFlags.Unsynchronisation);\n }\n if (frameEncrypted) {\n console.warn(`Skipping encrypted ID3v2 frame ${frame.id}`);\n reader.pos = frameEndPos;\n continue;\n }\n if (frameCompressed) {\n console.warn(`Skipping compressed ID3v2 frame ${frame.id}`); // Maybe someday? Idk\n reader.pos = frameEndPos;\n continue;\n }\n if (frameUnsynchronized) {\n reader.ununsynchronizeRegion(reader.pos, frameEndPos);\n }\n tags.raw ??= {};\n if (frame.id[0] === 'T') {\n // It's a text frame, let's decode as text\n tags.raw[frame.id] ??= reader.readId3V2EncodingAndText(frameEndPos);\n }\n else {\n // For the others, let's just get the bytes\n tags.raw[frame.id] ??= reader.readBytes(frame.size);\n }\n reader.pos = frameStartPos;\n switch (frame.id) {\n case 'TIT2':\n case 'TT2':\n {\n tags.title ??= reader.readId3V2EncodingAndText(frameEndPos);\n }\n ;\n break;\n case 'TIT3':\n case 'TT3':\n {\n tags.description ??= reader.readId3V2EncodingAndText(frameEndPos);\n }\n ;\n break;\n case 'TPE1':\n case 'TP1':\n {\n tags.artist ??= reader.readId3V2EncodingAndText(frameEndPos);\n }\n ;\n break;\n case 'TALB':\n case 'TAL':\n {\n tags.album ??= reader.readId3V2EncodingAndText(frameEndPos);\n }\n ;\n break;\n case 'TPE2':\n case 'TP2':\n {\n tags.albumArtist ??= reader.readId3V2EncodingAndText(frameEndPos);\n }\n ;\n break;\n case 'TRCK':\n case 'TRK':\n {\n const trackText = reader.readId3V2EncodingAndText(frameEndPos);\n const parts = trackText.split('/');\n const trackNum = Number.parseInt(parts[0], 10);\n const tracksTotal = parts[1] && Number.parseInt(parts[1], 10);\n if (Number.isInteger(trackNum) && trackNum > 0) {\n tags.trackNumber ??= trackNum;\n }\n if (tracksTotal && Number.isInteger(tracksTotal) && tracksTotal > 0) {\n tags.tracksTotal ??= tracksTotal;\n }\n }\n ;\n break;\n case 'TPOS':\n case 'TPA':\n {\n const discText = reader.readId3V2EncodingAndText(frameEndPos);\n const parts = discText.split('/');\n const discNum = Number.parseInt(parts[0], 10);\n const discsTotal = parts[1] && Number.parseInt(parts[1], 10);\n if (Number.isInteger(discNum) && discNum > 0) {\n tags.discNumber ??= discNum;\n }\n if (discsTotal && Number.isInteger(discsTotal) && discsTotal > 0) {\n tags.discsTotal ??= discsTotal;\n }\n }\n ;\n break;\n case 'TCON':\n case 'TCO':\n {\n const genreText = reader.readId3V2EncodingAndText(frameEndPos);\n let match = /^\\((\\d+)\\)/.exec(genreText);\n if (match) {\n const genreNumber = Number.parseInt(match[1]);\n if (ID3_V1_GENRES[genreNumber] !== undefined) {\n tags.genre ??= ID3_V1_GENRES[genreNumber];\n break;\n }\n }\n match = /^\\d+$/.exec(genreText);\n if (match) {\n const genreNumber = Number.parseInt(match[0]);\n if (ID3_V1_GENRES[genreNumber] !== undefined) {\n tags.genre ??= ID3_V1_GENRES[genreNumber];\n break;\n }\n }\n tags.genre ??= genreText;\n }\n ;\n break;\n case 'TDRC':\n case 'TDAT':\n {\n const dateText = reader.readId3V2EncodingAndText(frameEndPos);\n const date = new Date(dateText);\n if (!Number.isNaN(date.getTime())) {\n tags.date ??= date;\n }\n }\n ;\n break;\n case 'TYER':\n case 'TYE':\n {\n const yearText = reader.readId3V2EncodingAndText(frameEndPos);\n const year = Number.parseInt(yearText, 10);\n if (Number.isInteger(year)) {\n tags.date ??= new Date(year, 0, 1);\n }\n }\n ;\n break;\n case 'USLT':\n case 'ULT':\n {\n const encoding = reader.readU8();\n reader.pos += 3; // Skip language\n reader.readId3V2Text(encoding, frameEndPos); // Short content description\n tags.lyrics ??= reader.readId3V2Text(encoding, frameEndPos);\n }\n ;\n break;\n case 'COMM':\n case 'COM':\n {\n const encoding = reader.readU8();\n reader.pos += 3; // Skip language\n reader.readId3V2Text(encoding, frameEndPos); // Short content description\n tags.comment ??= reader.readId3V2Text(encoding, frameEndPos);\n }\n ;\n break;\n case 'APIC':\n case 'PIC':\n {\n const encoding = reader.readId3V2TextEncoding();\n let mimeType;\n if (header.majorVersion === 2) {\n const imageFormat = reader.readAscii(3);\n mimeType = imageFormat === 'PNG'\n ? 'image/png'\n : imageFormat === 'JPG'\n ? 'image/jpeg'\n : 'image/*';\n }\n else {\n mimeType = reader.readId3V2Text(encoding, frameEndPos);\n }\n const pictureType = reader.readU8();\n const description = reader.readId3V2Text(encoding, frameEndPos).trimEnd(); // Trim ending spaces\n const imageDataSize = frameEndPos - reader.pos;\n if (imageDataSize >= 0) {\n const imageData = reader.readBytes(imageDataSize);\n if (!tags.images)\n tags.images = [];\n tags.images.push({\n data: imageData,\n mimeType,\n kind: pictureType === 3\n ? 'coverFront'\n : pictureType === 4\n ? 'coverBack'\n : 'unknown',\n description,\n });\n }\n }\n ;\n break;\n default:\n {\n reader.pos += frame.size;\n }\n ;\n break;\n }\n reader.pos = frameEndPos;\n }\n};\n// https://id3.org/id3v2.3.0\nexport class Id3V2Reader {\n constructor(header, bytes) {\n this.header = header;\n this.bytes = bytes;\n this.pos = 0;\n this.view = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n }\n frameHeaderSize() {\n return this.header.majorVersion === 2 ? 6 : 10;\n }\n ununsynchronizeAll() {\n const newBytes = [];\n for (let i = 0; i < this.bytes.length; i++) {\n const value1 = this.bytes[i];\n newBytes.push(value1);\n if (value1 === 0xff && i !== this.bytes.length - 1) {\n const value2 = this.bytes[i];\n if (value2 === 0x00) {\n i++;\n }\n }\n }\n this.bytes = new Uint8Array(newBytes);\n this.view = new DataView(this.bytes.buffer);\n }\n ununsynchronizeRegion(start, end) {\n const newBytes = [];\n for (let i = start; i < end; i++) {\n const value1 = this.bytes[i];\n newBytes.push(value1);\n if (value1 === 0xff && i !== end - 1) {\n const value2 = this.bytes[i + 1];\n if (value2 === 0x00) {\n i++;\n }\n }\n }\n const before = this.bytes.subarray(0, start);\n const after = this.bytes.subarray(end);\n this.bytes = new Uint8Array(before.length + newBytes.length + after.length);\n this.bytes.set(before, 0);\n this.bytes.set(newBytes, before.length);\n this.bytes.set(after, before.length + newBytes.length);\n this.view = new DataView(this.bytes.buffer);\n }\n removeFooter() {\n this.bytes = this.bytes.subarray(0, this.bytes.length - ID3_V2_HEADER_SIZE);\n this.view = new DataView(this.bytes.buffer);\n }\n readBytes(length) {\n const slice = this.bytes.subarray(this.pos, this.pos + length);\n this.pos += length;\n return slice;\n }\n readU8() {\n const value = this.view.getUint8(this.pos);\n this.pos += 1;\n return value;\n }\n readU16() {\n const value = this.view.getUint16(this.pos, false);\n this.pos += 2;\n return value;\n }\n readU24() {\n const high = this.view.getUint16(this.pos, false);\n const low = this.view.getUint8(this.pos + 1);\n this.pos += 3;\n return high * 0x100 + low;\n }\n readU32() {\n const value = this.view.getUint32(this.pos, false);\n this.pos += 4;\n return value;\n }\n readAscii(length) {\n let str = '';\n for (let i = 0; i < length; i++) {\n str += String.fromCharCode(this.view.getUint8(this.pos + i));\n }\n this.pos += length;\n return str;\n }\n readId3V2Frame() {\n if (this.header.majorVersion === 2) {\n const id = this.readAscii(3);\n if (id === '\\x00\\x00\\x00') {\n return null;\n }\n const size = this.readU24();\n return { id, size, flags: 0 };\n }\n else {\n const id = this.readAscii(4);\n if (id === '\\x00\\x00\\x00\\x00') {\n // We've landed in the padding section\n return null;\n }\n const sizeRaw = this.readU32();\n let size = this.header.majorVersion === 4\n ? decodeSynchsafe(sizeRaw)\n : sizeRaw;\n const flags = this.readU16();\n const headerEndPos = this.pos;\n // Some files may have incorrectly synchsafed/unsynchsafed sizes. To validate which interpretation is valid,\n // we validate a size by skipping ahead and seeing if we land at a valid frame header (or at the end of the\n // tag.\n const isSizeValid = (size) => {\n const nextPos = this.pos + size;\n if (nextPos > this.bytes.length) {\n return false;\n }\n if (nextPos <= this.bytes.length - this.frameHeaderSize()) {\n this.pos += size;\n const nextId = this.readAscii(4);\n if (nextId !== '\\x00\\x00\\x00\\x00' && !/[0-9A-Z]{4}/.test(nextId)) {\n return false;\n }\n }\n return true;\n };\n if (!isSizeValid(size)) {\n // Flip the synchsafing, and try if this one makes more sense\n const otherSize = this.header.majorVersion === 4\n ? sizeRaw\n : decodeSynchsafe(sizeRaw);\n if (isSizeValid(otherSize)) {\n size = otherSize;\n }\n }\n this.pos = headerEndPos;\n return { id, size, flags };\n }\n }\n readId3V2TextEncoding() {\n const number = this.readU8();\n if (number > 3) {\n throw new Error(`Unsupported text encoding: ${number}`);\n }\n return number;\n }\n readId3V2Text(encoding, until) {\n const startPos = this.pos;\n const data = this.readBytes(until);\n switch (encoding) {\n case Id3V2TextEncoding.ISO_8859_1: {\n let str = '';\n for (let i = 0; i < data.length; i++) {\n const value = data[i];\n if (value === 0) {\n this.pos = startPos + i + 1;\n break;\n }\n str += String.fromCharCode(value);\n }\n return str;\n }\n case Id3V2TextEncoding.UTF_16_WITH_BOM: {\n if (data[0] === 0xff && data[1] === 0xfe) {\n const decoder = new TextDecoder('utf-16le');\n const endIndex = coalesceIndex(data.findIndex((x, i) => x === 0 && data[i + 1] === 0 && i % 2 === 0), data.length);\n this.pos = startPos + Math.min(endIndex + 2, data.length);\n return decoder.decode(data.subarray(2, endIndex));\n }\n else if (data[0] === 0xfe && data[1] === 0xff) {\n const decoder = new TextDecoder('utf-16be');\n const endIndex = coalesceIndex(data.findIndex((x, i) => x === 0 && data[i + 1] === 0 && i % 2 === 0), data.length);\n this.pos = startPos + Math.min(endIndex + 2, data.length);\n return decoder.decode(data.subarray(2, endIndex));\n }\n else {\n // Treat it like UTF-8, some files do this\n const endIndex = coalesceIndex(data.findIndex(x => x === 0), data.length);\n this.pos = startPos + Math.min(endIndex + 1, data.length);\n return textDecoder.decode(data.subarray(0, endIndex));\n }\n }\n case Id3V2TextEncoding.UTF_16_BE_NO_BOM: {\n const decoder = new TextDecoder('utf-16be');\n const endIndex = coalesceIndex(data.findIndex((x, i) => x === 0 && data[i + 1] === 0 && i % 2 === 0), data.length);\n this.pos = startPos + Math.min(endIndex + 2, data.length);\n return decoder.decode(data.subarray(0, endIndex));\n }\n case Id3V2TextEncoding.UTF_8: {\n const endIndex = coalesceIndex(data.findIndex(x => x === 0), data.length);\n this.pos = startPos + Math.min(endIndex + 1, data.length);\n return textDecoder.decode(data.subarray(0, endIndex));\n }\n }\n }\n readId3V2EncodingAndText(until) {\n if (this.pos >= until) {\n return '';\n }\n const encoding = this.readId3V2TextEncoding();\n return this.readId3V2Text(encoding, until);\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { parseOpusTocByte } from '../codec-data.js';\nimport { assert, ilog, toDataView } from '../misc.js';\nexport const OGGS = 0x5367674f; // 'OggS'\nconst OGG_CRC_POLYNOMIAL = 0x04c11db7;\nconst OGG_CRC_TABLE = new Uint32Array(256);\nfor (let n = 0; n < 256; n++) {\n let crc = n << 24;\n for (let k = 0; k < 8; k++) {\n crc = (crc & 0x80000000)\n ? ((crc << 1) ^ OGG_CRC_POLYNOMIAL)\n : (crc << 1);\n }\n OGG_CRC_TABLE[n] = (crc >>> 0) & 0xffffffff;\n}\nexport const computeOggPageCrc = (bytes) => {\n const view = toDataView(bytes);\n const originalChecksum = view.getUint32(22, true);\n view.setUint32(22, 0, true); // Zero out checksum field\n let crc = 0;\n for (let i = 0; i < bytes.length; i++) {\n const byte = bytes[i];\n crc = ((crc << 8) ^ OGG_CRC_TABLE[(crc >>> 24) ^ byte]) >>> 0;\n }\n view.setUint32(22, originalChecksum, true); // Restore checksum field\n return crc;\n};\nexport const extractSampleMetadata = (data, codecInfo, vorbisLastBlocksize) => {\n let durationInSamples = 0;\n let currentBlocksize = null;\n if (data.length > 0) {\n // To know sample duration, we'll need to peak inside the packet\n if (codecInfo.codec === 'vorbis') {\n assert(codecInfo.vorbisInfo);\n const vorbisModeCount = codecInfo.vorbisInfo.modeBlockflags.length;\n const bitCount = ilog(vorbisModeCount - 1);\n const modeMask = ((1 << bitCount) - 1) << 1;\n const modeNumber = (data[0] & modeMask) >> 1;\n if (modeNumber >= codecInfo.vorbisInfo.modeBlockflags.length) {\n throw new Error('Invalid mode number.');\n }\n // In Vorbis, packet duration also depends on the blocksize of the previous packet\n let prevBlocksize = vorbisLastBlocksize;\n const blockflag = codecInfo.vorbisInfo.modeBlockflags[modeNumber];\n currentBlocksize = codecInfo.vorbisInfo.blocksizes[blockflag];\n if (blockflag === 1) {\n const prevMask = (modeMask | 0x1) + 1;\n const flag = data[0] & prevMask ? 1 : 0;\n prevBlocksize = codecInfo.vorbisInfo.blocksizes[flag];\n }\n durationInSamples = prevBlocksize !== null\n ? (prevBlocksize + currentBlocksize) >> 2\n : 0; // The first sample outputs no audio data and therefore has a duration of 0\n }\n else if (codecInfo.codec === 'opus') {\n const toc = parseOpusTocByte(data);\n durationInSamples = toc.durationInSamples;\n }\n }\n return {\n durationInSamples,\n vorbisBlockSize: currentBlocksize,\n };\n};\nexport const buildOggMimeType = (info) => {\n let string = 'audio/ogg';\n if (info.codecStrings) {\n const uniqueCodecMimeTypes = [...new Set(info.codecStrings)];\n string += `; codecs=\"${uniqueCodecMimeTypes.join(', ')}\"`;\n }\n return string;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { readI64Le, readU32Le, readU8 } from '../reader.js';\nimport { OGGS } from './ogg-misc.js';\nexport const MIN_PAGE_HEADER_SIZE = 27;\nexport const MAX_PAGE_HEADER_SIZE = 27 + 255;\nexport const MAX_PAGE_SIZE = MAX_PAGE_HEADER_SIZE + 255 * 255;\nexport const readPageHeader = (slice) => {\n const startPos = slice.filePos;\n const capturePattern = readU32Le(slice);\n if (capturePattern !== OGGS) {\n return null;\n }\n slice.skip(1); // Version\n const headerType = readU8(slice);\n const granulePosition = readI64Le(slice);\n const serialNumber = readU32Le(slice);\n const sequenceNumber = readU32Le(slice);\n const checksum = readU32Le(slice);\n const numberPageSegments = readU8(slice);\n const lacingValues = new Uint8Array(numberPageSegments);\n for (let i = 0; i < numberPageSegments; i++) {\n lacingValues[i] = readU8(slice);\n }\n const headerSize = 27 + numberPageSegments;\n const dataSize = lacingValues.reduce((a, b) => a + b, 0);\n const totalSize = headerSize + dataSize;\n return {\n headerStartPos: startPos,\n totalSize,\n dataStartPos: startPos + headerSize,\n dataSize,\n headerType,\n granulePosition,\n serialNumber,\n sequenceNumber,\n checksum,\n lacingValues,\n };\n};\nexport const findNextPageHeader = (slice, until) => {\n while (slice.filePos < until - (4 - 1)) { // Size of word minus 1\n const word = readU32Le(slice);\n const firstByte = word & 0xff;\n const secondByte = (word >>> 8) & 0xff;\n const thirdByte = (word >>> 16) & 0xff;\n const fourthByte = (word >>> 24) & 0xff;\n const O = 0x4f; // 'O'\n if (firstByte !== O && secondByte !== O && thirdByte !== O && fourthByte !== O) {\n continue;\n }\n slice.skip(-4);\n if (word === OGGS) {\n // We have found the capture pattern\n return true;\n }\n slice.skip(1);\n }\n return false;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nexport class Demuxer {\n constructor(input) {\n this.input = input;\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\n/**\n * Base class for custom video decoders. To add your own custom video decoder, extend this class, implement the\n * abstract methods and static `supports` method, and register the decoder using {@link registerDecoder}.\n * @group Custom coders\n * @public\n */\nexport class CustomVideoDecoder {\n /** Returns true if and only if the decoder can decode the given codec configuration. */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static supports(codec, config) {\n return false;\n }\n}\n/**\n * Base class for custom audio decoders. To add your own custom audio decoder, extend this class, implement the\n * abstract methods and static `supports` method, and register the decoder using {@link registerDecoder}.\n * @group Custom coders\n * @public\n */\nexport class CustomAudioDecoder {\n /** Returns true if and only if the decoder can decode the given codec configuration. */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static supports(codec, config) {\n return false;\n }\n}\n/**\n * Base class for custom video encoders. To add your own custom video encoder, extend this class, implement the\n * abstract methods and static `supports` method, and register the encoder using {@link registerEncoder}.\n * @group Custom coders\n * @public\n */\nexport class CustomVideoEncoder {\n /** Returns true if and only if the encoder can encode the given codec configuration. */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static supports(codec, config) {\n return false;\n }\n}\n/**\n * Base class for custom audio encoders. To add your own custom audio encoder, extend this class, implement the\n * abstract methods and static `supports` method, and register the encoder using {@link registerEncoder}.\n * @group Custom coders\n * @public\n */\nexport class CustomAudioEncoder {\n /** Returns true if and only if the encoder can encode the given codec configuration. */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static supports(codec, config) {\n return false;\n }\n}\nexport const customVideoDecoders = [];\nexport const customAudioDecoders = [];\nexport const customVideoEncoders = [];\nexport const customAudioEncoders = [];\n/**\n * Registers a custom video or audio decoder. Registered decoders will automatically be used for decoding whenever\n * possible.\n * @group Custom coders\n * @public\n */\nexport const registerDecoder = (decoder) => {\n if (decoder.prototype instanceof CustomVideoDecoder) {\n const casted = decoder;\n if (customVideoDecoders.includes(casted)) {\n console.warn('Video decoder already registered.');\n return;\n }\n customVideoDecoders.push(casted);\n }\n else if (decoder.prototype instanceof CustomAudioDecoder) {\n const casted = decoder;\n if (customAudioDecoders.includes(casted)) {\n console.warn('Audio decoder already registered.');\n return;\n }\n customAudioDecoders.push(casted);\n }\n else {\n throw new TypeError('Decoder must be a CustomVideoDecoder or CustomAudioDecoder.');\n }\n};\n/**\n * Registers a custom video or audio encoder. Registered encoders will automatically be used for encoding whenever\n * possible.\n * @group Custom coders\n * @public\n */\nexport const registerEncoder = (encoder) => {\n if (encoder.prototype instanceof CustomVideoEncoder) {\n const casted = encoder;\n if (customVideoEncoders.includes(casted)) {\n console.warn('Video encoder already registered.');\n return;\n }\n customVideoEncoders.push(casted);\n }\n else if (encoder.prototype instanceof CustomAudioEncoder) {\n const casted = encoder;\n if (customAudioEncoders.includes(casted)) {\n console.warn('Audio encoder already registered.');\n return;\n }\n customAudioEncoders.push(casted);\n }\n else {\n throw new TypeError('Encoder must be a CustomVideoEncoder or CustomAudioEncoder.');\n }\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { SECOND_TO_MICROSECOND_FACTOR } from './misc.js';\nexport const PLACEHOLDER_DATA = new Uint8Array(0);\n/**\n * Represents an encoded chunk of media. Mainly used as an expressive wrapper around WebCodecs API's\n * [`EncodedVideoChunk`](https://developer.mozilla.org/en-US/docs/Web/API/EncodedVideoChunk) and\n * [`EncodedAudioChunk`](https://developer.mozilla.org/en-US/docs/Web/API/EncodedAudioChunk), but can also be used\n * standalone.\n * @group Packets\n * @public\n */\nexport class EncodedPacket {\n /** Creates a new {@link EncodedPacket} from raw bytes and timing information. */\n constructor(\n /** The encoded data of this packet. */\n data, \n /** The type of this packet. */\n type, \n /**\n * The presentation timestamp of this packet in seconds. May be negative. Samples with negative end timestamps\n * should not be presented.\n */\n timestamp, \n /** The duration of this packet in seconds. */\n duration, \n /**\n * The sequence number indicates the decode order of the packets. Packet A must be decoded before packet B if A\n * has a lower sequence number than B. If two packets have the same sequence number, they are the same packet.\n * Otherwise, sequence numbers are arbitrary and are not guaranteed to have any meaning besides their relative\n * ordering. Negative sequence numbers mean the sequence number is undefined.\n */\n sequenceNumber = -1, byteLength) {\n this.data = data;\n this.type = type;\n this.timestamp = timestamp;\n this.duration = duration;\n this.sequenceNumber = sequenceNumber;\n if (data === PLACEHOLDER_DATA && byteLength === undefined) {\n throw new Error('Internal error: byteLength must be explicitly provided when constructing metadata-only packets.');\n }\n if (byteLength === undefined) {\n byteLength = data.byteLength;\n }\n if (!(data instanceof Uint8Array)) {\n throw new TypeError('data must be a Uint8Array.');\n }\n if (type !== 'key' && type !== 'delta') {\n throw new TypeError('type must be either \"key\" or \"delta\".');\n }\n if (!Number.isFinite(timestamp)) {\n throw new TypeError('timestamp must be a number.');\n }\n if (!Number.isFinite(duration) || duration < 0) {\n throw new TypeError('duration must be a non-negative number.');\n }\n if (!Number.isFinite(sequenceNumber)) {\n throw new TypeError('sequenceNumber must be a number.');\n }\n if (!Number.isInteger(byteLength) || byteLength < 0) {\n throw new TypeError('byteLength must be a non-negative integer.');\n }\n this.byteLength = byteLength;\n }\n /** If this packet is a metadata-only packet. Metadata-only packets don't contain their packet data. */\n get isMetadataOnly() {\n return this.data === PLACEHOLDER_DATA;\n }\n /** The timestamp of this packet in microseconds. */\n get microsecondTimestamp() {\n return Math.trunc(SECOND_TO_MICROSECOND_FACTOR * this.timestamp);\n }\n /** The duration of this packet in microseconds. */\n get microsecondDuration() {\n return Math.trunc(SECOND_TO_MICROSECOND_FACTOR * this.duration);\n }\n /** Converts this packet to an EncodedVideoChunk for use with the WebCodecs API. */\n toEncodedVideoChunk() {\n if (this.isMetadataOnly) {\n throw new TypeError('Metadata-only packets cannot be converted to a video chunk.');\n }\n if (typeof EncodedVideoChunk === 'undefined') {\n throw new Error('Your browser does not support EncodedVideoChunk.');\n }\n return new EncodedVideoChunk({\n data: this.data,\n type: this.type,\n timestamp: this.microsecondTimestamp,\n duration: this.microsecondDuration,\n });\n }\n /** Converts this packet to an EncodedAudioChunk for use with the WebCodecs API. */\n toEncodedAudioChunk() {\n if (this.isMetadataOnly) {\n throw new TypeError('Metadata-only packets cannot be converted to an audio chunk.');\n }\n if (typeof EncodedAudioChunk === 'undefined') {\n throw new Error('Your browser does not support EncodedAudioChunk.');\n }\n return new EncodedAudioChunk({\n data: this.data,\n type: this.type,\n timestamp: this.microsecondTimestamp,\n duration: this.microsecondDuration,\n });\n }\n /**\n * Creates an EncodedPacket from an EncodedVideoChunk or EncodedAudioChunk. This method is useful for converting\n * chunks from the WebCodecs API to EncodedPackets.\n */\n static fromEncodedChunk(chunk) {\n if (!(chunk instanceof EncodedVideoChunk || chunk instanceof EncodedAudioChunk)) {\n throw new TypeError('chunk must be an EncodedVideoChunk or EncodedAudioChunk.');\n }\n const data = new Uint8Array(chunk.byteLength);\n chunk.copyTo(data);\n return new EncodedPacket(data, chunk.type, chunk.timestamp / 1e6, (chunk.duration ?? 0) / 1e6);\n }\n /** Clones this packet while optionally updating timing information. */\n clone(options) {\n if (options !== undefined && (typeof options !== 'object' || options === null)) {\n throw new TypeError('options, when provided, must be an object.');\n }\n if (options?.timestamp !== undefined && !Number.isFinite(options.timestamp)) {\n throw new TypeError('options.timestamp, when provided, must be a number.');\n }\n if (options?.duration !== undefined && !Number.isFinite(options.duration)) {\n throw new TypeError('options.duration, when provided, must be a number.');\n }\n return new EncodedPacket(this.data, this.type, options?.timestamp ?? this.timestamp, options?.duration ?? this.duration, this.sequenceNumber, this.byteLength);\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { assert, clamp, isAllowSharedBufferSource, SECOND_TO_MICROSECOND_FACTOR, toDataView, toUint8Array, } from './misc.js';\n/**\n * Represents a raw, unencoded video sample (frame). Mainly used as an expressive wrapper around WebCodecs API's\n * [`VideoFrame`](https://developer.mozilla.org/en-US/docs/Web/API/VideoFrame), but can also be used standalone.\n * @group Samples\n * @public\n */\nexport class VideoSample {\n /** The width of the frame in pixels after rotation. */\n get displayWidth() {\n return this.rotation % 180 === 0 ? this.codedWidth : this.codedHeight;\n }\n /** The height of the frame in pixels after rotation. */\n get displayHeight() {\n return this.rotation % 180 === 0 ? this.codedHeight : this.codedWidth;\n }\n /** The presentation timestamp of the frame in microseconds. */\n get microsecondTimestamp() {\n return Math.trunc(SECOND_TO_MICROSECOND_FACTOR * this.timestamp);\n }\n /** The duration of the frame in microseconds. */\n get microsecondDuration() {\n return Math.trunc(SECOND_TO_MICROSECOND_FACTOR * this.duration);\n }\n constructor(data, init) {\n /** @internal */\n this._closed = false;\n if (data instanceof ArrayBuffer || ArrayBuffer.isView(data)) {\n if (!init || typeof init !== 'object') {\n throw new TypeError('init must be an object.');\n }\n if (!('format' in init) || typeof init.format !== 'string') {\n throw new TypeError('init.format must be a string.');\n }\n if (!Number.isInteger(init.codedWidth) || init.codedWidth <= 0) {\n throw new TypeError('init.codedWidth must be a positive integer.');\n }\n if (!Number.isInteger(init.codedHeight) || init.codedHeight <= 0) {\n throw new TypeError('init.codedHeight must be a positive integer.');\n }\n if (init.rotation !== undefined && ![0, 90, 180, 270].includes(init.rotation)) {\n throw new TypeError('init.rotation, when provided, must be 0, 90, 180, or 270.');\n }\n if (!Number.isFinite(init.timestamp)) {\n throw new TypeError('init.timestamp must be a number.');\n }\n if (init.duration !== undefined && (!Number.isFinite(init.duration) || init.duration < 0)) {\n throw new TypeError('init.duration, when provided, must be a non-negative number.');\n }\n this._data = toUint8Array(data).slice(); // Copy it\n this.format = init.format;\n this.codedWidth = init.codedWidth;\n this.codedHeight = init.codedHeight;\n this.rotation = init.rotation ?? 0;\n this.timestamp = init.timestamp;\n this.duration = init.duration ?? 0;\n this.colorSpace = new VideoColorSpace(init.colorSpace);\n }\n else if (typeof VideoFrame !== 'undefined' && data instanceof VideoFrame) {\n if (init?.rotation !== undefined && ![0, 90, 180, 270].includes(init.rotation)) {\n throw new TypeError('init.rotation, when provided, must be 0, 90, 180, or 270.');\n }\n if (init?.timestamp !== undefined && !Number.isFinite(init?.timestamp)) {\n throw new TypeError('init.timestamp, when provided, must be a number.');\n }\n if (init?.duration !== undefined && (!Number.isFinite(init.duration) || init.duration < 0)) {\n throw new TypeError('init.duration, when provided, must be a non-negative number.');\n }\n this._data = data;\n this.format = data.format;\n // Copying the display dimensions here, assuming no innate VideoFrame rotation\n this.codedWidth = data.displayWidth;\n this.codedHeight = data.displayHeight;\n // The VideoFrame's rotation is ignored here. It's still a new field, and I'm not sure of any application\n // where the browser makes use of it. If a case gets found, I'll add it.\n this.rotation = init?.rotation ?? 0;\n this.timestamp = init?.timestamp ?? data.timestamp / 1e6;\n this.duration = init?.duration ?? (data.duration ?? 0) / 1e6;\n this.colorSpace = data.colorSpace;\n }\n else if ((typeof HTMLImageElement !== 'undefined' && data instanceof HTMLImageElement)\n || (typeof SVGImageElement !== 'undefined' && data instanceof SVGImageElement)\n || (typeof ImageBitmap !== 'undefined' && data instanceof ImageBitmap)\n || (typeof HTMLVideoElement !== 'undefined' && data instanceof HTMLVideoElement)\n || (typeof HTMLCanvasElement !== 'undefined' && data instanceof HTMLCanvasElement)\n || (typeof OffscreenCanvas !== 'undefined' && data instanceof OffscreenCanvas)) {\n if (!init || typeof init !== 'object') {\n throw new TypeError('init must be an object.');\n }\n if (init.rotation !== undefined && ![0, 90, 180, 270].includes(init.rotation)) {\n throw new TypeError('init.rotation, when provided, must be 0, 90, 180, or 270.');\n }\n if (!Number.isFinite(init.timestamp)) {\n throw new TypeError('init.timestamp must be a number.');\n }\n if (init.duration !== undefined && (!Number.isFinite(init.duration) || init.duration < 0)) {\n throw new TypeError('init.duration, when provided, must be a non-negative number.');\n }\n if (typeof VideoFrame !== 'undefined') {\n return new VideoSample(new VideoFrame(data, {\n timestamp: Math.trunc(init.timestamp * SECOND_TO_MICROSECOND_FACTOR),\n duration: Math.trunc((init.duration ?? 0) * SECOND_TO_MICROSECOND_FACTOR),\n }), init);\n }\n let width = 0;\n let height = 0;\n // Determine the dimensions of the thing\n if ('naturalWidth' in data) {\n width = data.naturalWidth;\n height = data.naturalHeight;\n }\n else if ('videoWidth' in data) {\n width = data.videoWidth;\n height = data.videoHeight;\n }\n else if ('width' in data) {\n width = Number(data.width);\n height = Number(data.height);\n }\n if (!width || !height) {\n throw new TypeError('Could not determine dimensions.');\n }\n const canvas = new OffscreenCanvas(width, height);\n const context = canvas.getContext('2d', { alpha: false, willReadFrequently: true });\n assert(context);\n // Draw it to a canvas\n context.drawImage(data, 0, 0);\n this._data = canvas;\n this.format = 'RGBX';\n this.codedWidth = width;\n this.codedHeight = height;\n this.rotation = init.rotation ?? 0;\n this.timestamp = init.timestamp;\n this.duration = init.duration ?? 0;\n this.colorSpace = new VideoColorSpace({\n matrix: 'rgb',\n primaries: 'bt709',\n transfer: 'iec61966-2-1',\n fullRange: true,\n });\n }\n else {\n throw new TypeError('Invalid data type: Must be a BufferSource or CanvasImageSource.');\n }\n }\n /** Clones this video sample. */\n clone() {\n if (this._closed) {\n throw new Error('VideoSample is closed.');\n }\n assert(this._data !== null);\n if (isVideoFrame(this._data)) {\n return new VideoSample(this._data.clone(), {\n timestamp: this.timestamp,\n duration: this.duration,\n rotation: this.rotation,\n });\n }\n else if (this._data instanceof Uint8Array) {\n return new VideoSample(this._data.slice(), {\n format: this.format,\n codedWidth: this.codedWidth,\n codedHeight: this.codedHeight,\n timestamp: this.timestamp,\n duration: this.duration,\n colorSpace: this.colorSpace,\n rotation: this.rotation,\n });\n }\n else {\n return new VideoSample(this._data, {\n format: this.format,\n codedWidth: this.codedWidth,\n codedHeight: this.codedHeight,\n timestamp: this.timestamp,\n duration: this.duration,\n colorSpace: this.colorSpace,\n rotation: this.rotation,\n });\n }\n }\n /**\n * Closes this video sample, releasing held resources. Video samples should be closed as soon as they are not\n * needed anymore.\n */\n close() {\n if (this._closed) {\n return;\n }\n if (isVideoFrame(this._data)) {\n this._data.close();\n }\n else {\n this._data = null; // GC that shit\n }\n this._closed = true;\n }\n /** Returns the number of bytes required to hold this video sample's pixel data. */\n allocationSize() {\n if (this._closed) {\n throw new Error('VideoSample is closed.');\n }\n assert(this._data !== null);\n if (isVideoFrame(this._data)) {\n return this._data.allocationSize();\n }\n else if (this._data instanceof Uint8Array) {\n return this._data.byteLength;\n }\n else {\n return this.codedWidth * this.codedHeight * 4; // RGBX\n }\n }\n /** Copies this video sample's pixel data to an ArrayBuffer or ArrayBufferView. */\n async copyTo(destination) {\n if (!isAllowSharedBufferSource(destination)) {\n throw new TypeError('destination must be an ArrayBuffer or an ArrayBuffer view.');\n }\n if (this._closed) {\n throw new Error('VideoSample is closed.');\n }\n assert(this._data !== null);\n if (isVideoFrame(this._data)) {\n await this._data.copyTo(destination);\n }\n else if (this._data instanceof Uint8Array) {\n const dest = toUint8Array(destination);\n dest.set(this._data);\n }\n else {\n const canvas = this._data;\n const context = canvas.getContext('2d', { alpha: false });\n assert(context);\n const imageData = context.getImageData(0, 0, this.codedWidth, this.codedHeight);\n const dest = toUint8Array(destination);\n dest.set(imageData.data);\n }\n }\n /**\n * Converts this video sample to a VideoFrame for use with the WebCodecs API. The VideoFrame returned by this\n * method *must* be closed separately from this video sample.\n */\n toVideoFrame() {\n if (this._closed) {\n throw new Error('VideoSample is closed.');\n }\n assert(this._data !== null);\n if (isVideoFrame(this._data)) {\n return new VideoFrame(this._data, {\n timestamp: this.microsecondTimestamp,\n duration: this.microsecondDuration || undefined, // Drag 0 duration to undefined, glitches some codecs\n });\n }\n else if (this._data instanceof Uint8Array) {\n return new VideoFrame(this._data, {\n format: this.format,\n codedWidth: this.codedWidth,\n codedHeight: this.codedHeight,\n timestamp: this.microsecondTimestamp,\n duration: this.microsecondDuration,\n colorSpace: this.colorSpace,\n });\n }\n else {\n return new VideoFrame(this._data, {\n timestamp: this.microsecondTimestamp,\n duration: this.microsecondDuration,\n });\n }\n }\n draw(context, arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) {\n let sx = 0;\n let sy = 0;\n let sWidth = this.displayWidth;\n let sHeight = this.displayHeight;\n let dx = 0;\n let dy = 0;\n let dWidth = this.displayWidth;\n let dHeight = this.displayHeight;\n if (arg5 !== undefined) {\n sx = arg1;\n sy = arg2;\n sWidth = arg3;\n sHeight = arg4;\n dx = arg5;\n dy = arg6;\n if (arg7 !== undefined) {\n dWidth = arg7;\n dHeight = arg8;\n }\n else {\n dWidth = sWidth;\n dHeight = sHeight;\n }\n }\n else {\n dx = arg1;\n dy = arg2;\n if (arg3 !== undefined) {\n dWidth = arg3;\n dHeight = arg4;\n }\n }\n if (!((typeof CanvasRenderingContext2D !== 'undefined' && context instanceof CanvasRenderingContext2D)\n || (typeof OffscreenCanvasRenderingContext2D !== 'undefined'\n && context instanceof OffscreenCanvasRenderingContext2D))) {\n throw new TypeError('context must be a CanvasRenderingContext2D or OffscreenCanvasRenderingContext2D.');\n }\n if (!Number.isFinite(sx)) {\n throw new TypeError('sx must be a number.');\n }\n if (!Number.isFinite(sy)) {\n throw new TypeError('sy must be a number.');\n }\n if (!Number.isFinite(sWidth) || sWidth < 0) {\n throw new TypeError('sWidth must be a non-negative number.');\n }\n if (!Number.isFinite(sHeight) || sHeight < 0) {\n throw new TypeError('sHeight must be a non-negative number.');\n }\n if (!Number.isFinite(dx)) {\n throw new TypeError('dx must be a number.');\n }\n if (!Number.isFinite(dy)) {\n throw new TypeError('dy must be a number.');\n }\n if (!Number.isFinite(dWidth) || dWidth < 0) {\n throw new TypeError('dWidth must be a non-negative number.');\n }\n if (!Number.isFinite(dHeight) || dHeight < 0) {\n throw new TypeError('dHeight must be a non-negative number.');\n }\n if (this._closed) {\n throw new Error('VideoSample is closed.');\n }\n // The provided sx,sy,sWidth,sHeight refer to the final rotated image, but that's not actually how the image is\n // stored. Therefore, we must map these back onto the original, pre-rotation image.\n if (this.rotation === 90) {\n [sx, sy, sWidth, sHeight] = [\n sy,\n this.codedHeight - sx - sWidth,\n sHeight,\n sWidth,\n ];\n }\n else if (this.rotation === 180) {\n [sx, sy] = [\n this.codedWidth - sx - sWidth,\n this.codedHeight - sy - sHeight,\n ];\n }\n else if (this.rotation === 270) {\n [sx, sy, sWidth, sHeight] = [\n this.codedWidth - sy - sHeight,\n sx,\n sHeight,\n sWidth,\n ];\n }\n const source = this.toCanvasImageSource();\n context.save();\n const centerX = dx + dWidth / 2;\n const centerY = dy + dHeight / 2;\n context.translate(centerX, centerY);\n context.rotate(this.rotation * Math.PI / 180);\n const aspectRatioChange = this.rotation % 180 === 0 ? 1 : dWidth / dHeight;\n // Scale to compensate for aspect ratio changes when rotated\n context.scale(1 / aspectRatioChange, aspectRatioChange);\n context.drawImage(source, sx, sy, sWidth, sHeight, -dWidth / 2, -dHeight / 2, dWidth, dHeight);\n // Restore the previous transformation state\n context.restore();\n }\n /**\n * Draws the sample in the middle of the canvas corresponding to the context with the specified fit behavior.\n */\n drawWithFit(context, options) {\n const canvasWidth = context.canvas.width;\n const canvasHeight = context.canvas.height;\n const rotation = options.rotation ?? this.rotation;\n // These variables specify where the final sample will be drawn on the canvas\n let dx;\n let dy;\n let newWidth;\n let newHeight;\n if (options.fit === 'fill') {\n dx = 0;\n dy = 0;\n newWidth = canvasWidth;\n newHeight = canvasHeight;\n }\n else {\n const [sampleWidth, sampleHeight] = rotation % 180 === 0\n ? [this.codedWidth, this.codedHeight]\n : [this.codedHeight, this.codedWidth];\n const scale = options.fit === 'contain'\n ? Math.min(canvasWidth / sampleWidth, canvasHeight / sampleHeight)\n : Math.max(canvasWidth / sampleWidth, canvasHeight / sampleHeight);\n newWidth = sampleWidth * scale;\n newHeight = sampleHeight * scale;\n dx = (canvasWidth - newWidth) / 2;\n dy = (canvasHeight - newHeight) / 2;\n }\n const aspectRatioChange = rotation % 180 === 0 ? 1 : newWidth / newHeight;\n context.translate(canvasWidth / 2, canvasHeight / 2);\n context.rotate(rotation * Math.PI / 180);\n // This aspect ratio compensation is done so that we can draw the sample with the intended dimensions and\n // don't need to think about how those dimensions change after the rotation\n context.scale(1 / aspectRatioChange, aspectRatioChange);\n context.translate(-canvasWidth / 2, -canvasHeight / 2);\n // Important that we don't use .draw() here since that would take rotation into account, but we wanna handle it\n // ourselves here\n context.drawImage(this.toCanvasImageSource(), dx, dy, newWidth, newHeight);\n }\n /**\n * Converts this video sample to a\n * [`CanvasImageSource`](https://udn.realityripple.com/docs/Web/API/CanvasImageSource) for drawing to a canvas.\n *\n * You must use the value returned by this method immediately, as any VideoFrame created internally will\n * automatically be closed in the next microtask.\n */\n toCanvasImageSource() {\n if (this._closed) {\n throw new Error('VideoSample is closed.');\n }\n assert(this._data !== null);\n if (this._data instanceof Uint8Array) {\n // Requires VideoFrame to be defined\n const videoFrame = this.toVideoFrame();\n queueMicrotask(() => videoFrame.close()); // Let's automatically close the frame in the next microtask\n return videoFrame;\n }\n else {\n return this._data;\n }\n }\n /** Sets the rotation metadata of this video sample. */\n setRotation(newRotation) {\n if (![0, 90, 180, 270].includes(newRotation)) {\n throw new TypeError('newRotation must be 0, 90, 180, or 270.');\n }\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n this.rotation = newRotation;\n }\n /** Sets the presentation timestamp of this video sample, in seconds. */\n setTimestamp(newTimestamp) {\n if (!Number.isFinite(newTimestamp)) {\n throw new TypeError('newTimestamp must be a number.');\n }\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n this.timestamp = newTimestamp;\n }\n /** Sets the duration of this video sample, in seconds. */\n setDuration(newDuration) {\n if (!Number.isFinite(newDuration) || newDuration < 0) {\n throw new TypeError('newDuration must be a non-negative number.');\n }\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n this.duration = newDuration;\n }\n}\nconst isVideoFrame = (x) => {\n return typeof VideoFrame !== 'undefined' && x instanceof VideoFrame;\n};\nconst AUDIO_SAMPLE_FORMATS = new Set(['f32', 'f32-planar', 's16', 's16-planar', 's32', 's32-planar', 'u8', 'u8-planar']);\n/**\n * Represents a raw, unencoded audio sample. Mainly used as an expressive wrapper around WebCodecs API's\n * [`AudioData`](https://developer.mozilla.org/en-US/docs/Web/API/AudioData), but can also be used standalone.\n * @group Samples\n * @public\n */\nexport class AudioSample {\n /** The presentation timestamp of the sample in microseconds. */\n get microsecondTimestamp() {\n return Math.trunc(SECOND_TO_MICROSECOND_FACTOR * this.timestamp);\n }\n /** The duration of the sample in microseconds. */\n get microsecondDuration() {\n return Math.trunc(SECOND_TO_MICROSECOND_FACTOR * this.duration);\n }\n /**\n * Creates a new {@link AudioSample}, either from an existing\n * [`AudioData`](https://developer.mozilla.org/en-US/docs/Web/API/AudioData) or from raw bytes specified in\n * {@link AudioSampleInit}.\n */\n constructor(init) {\n /** @internal */\n this._closed = false;\n if (isAudioData(init)) {\n if (init.format === null) {\n throw new TypeError('AudioData with null format is not supported.');\n }\n this._data = init;\n this.format = init.format;\n this.sampleRate = init.sampleRate;\n this.numberOfFrames = init.numberOfFrames;\n this.numberOfChannels = init.numberOfChannels;\n this.timestamp = init.timestamp / 1e6;\n this.duration = init.numberOfFrames / init.sampleRate;\n }\n else {\n if (!init || typeof init !== 'object') {\n throw new TypeError('Invalid AudioDataInit: must be an object.');\n }\n if (!AUDIO_SAMPLE_FORMATS.has(init.format)) {\n throw new TypeError('Invalid AudioDataInit: invalid format.');\n }\n if (!Number.isFinite(init.sampleRate) || init.sampleRate <= 0) {\n throw new TypeError('Invalid AudioDataInit: sampleRate must be > 0.');\n }\n if (!Number.isInteger(init.numberOfChannels) || init.numberOfChannels === 0) {\n throw new TypeError('Invalid AudioDataInit: numberOfChannels must be an integer > 0.');\n }\n if (!Number.isFinite(init?.timestamp)) {\n throw new TypeError('init.timestamp must be a number.');\n }\n const numberOfFrames = init.data.byteLength / (getBytesPerSample(init.format) * init.numberOfChannels);\n if (!Number.isInteger(numberOfFrames)) {\n throw new TypeError('Invalid AudioDataInit: data size is not a multiple of frame size.');\n }\n this.format = init.format;\n this.sampleRate = init.sampleRate;\n this.numberOfFrames = numberOfFrames;\n this.numberOfChannels = init.numberOfChannels;\n this.timestamp = init.timestamp;\n this.duration = numberOfFrames / init.sampleRate;\n let dataBuffer;\n if (init.data instanceof ArrayBuffer) {\n dataBuffer = new Uint8Array(init.data);\n }\n else if (ArrayBuffer.isView(init.data)) {\n dataBuffer = new Uint8Array(init.data.buffer, init.data.byteOffset, init.data.byteLength);\n }\n else {\n throw new TypeError('Invalid AudioDataInit: data is not a BufferSource.');\n }\n const expectedSize = this.numberOfFrames * this.numberOfChannels * getBytesPerSample(this.format);\n if (dataBuffer.byteLength < expectedSize) {\n throw new TypeError('Invalid AudioDataInit: insufficient data size.');\n }\n this._data = dataBuffer;\n }\n }\n /** Returns the number of bytes required to hold the audio sample's data as specified by the given options. */\n allocationSize(options) {\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (!Number.isInteger(options.planeIndex) || options.planeIndex < 0) {\n throw new TypeError('planeIndex must be a non-negative integer.');\n }\n if (options.format !== undefined && !AUDIO_SAMPLE_FORMATS.has(options.format)) {\n throw new TypeError('Invalid format.');\n }\n if (options.frameOffset !== undefined && (!Number.isInteger(options.frameOffset) || options.frameOffset < 0)) {\n throw new TypeError('frameOffset must be a non-negative integer.');\n }\n if (options.frameCount !== undefined && (!Number.isInteger(options.frameCount) || options.frameCount < 0)) {\n throw new TypeError('frameCount must be a non-negative integer.');\n }\n if (this._closed) {\n throw new Error('AudioSample is closed.');\n }\n const destFormat = options.format ?? this.format;\n const frameOffset = options.frameOffset ?? 0;\n if (frameOffset >= this.numberOfFrames) {\n throw new RangeError('frameOffset out of range');\n }\n const copyFrameCount = options.frameCount !== undefined ? options.frameCount : (this.numberOfFrames - frameOffset);\n if (copyFrameCount > (this.numberOfFrames - frameOffset)) {\n throw new RangeError('frameCount out of range');\n }\n const bytesPerSample = getBytesPerSample(destFormat);\n const isPlanar = formatIsPlanar(destFormat);\n if (isPlanar && options.planeIndex >= this.numberOfChannels) {\n throw new RangeError('planeIndex out of range');\n }\n if (!isPlanar && options.planeIndex !== 0) {\n throw new RangeError('planeIndex out of range');\n }\n const elementCount = isPlanar ? copyFrameCount : copyFrameCount * this.numberOfChannels;\n return elementCount * bytesPerSample;\n }\n /** Copies the audio sample's data to an ArrayBuffer or ArrayBufferView as specified by the given options. */\n copyTo(destination, options) {\n if (!isAllowSharedBufferSource(destination)) {\n throw new TypeError('destination must be an ArrayBuffer or an ArrayBuffer view.');\n }\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (!Number.isInteger(options.planeIndex) || options.planeIndex < 0) {\n throw new TypeError('planeIndex must be a non-negative integer.');\n }\n if (options.format !== undefined && !AUDIO_SAMPLE_FORMATS.has(options.format)) {\n throw new TypeError('Invalid format.');\n }\n if (options.frameOffset !== undefined && (!Number.isInteger(options.frameOffset) || options.frameOffset < 0)) {\n throw new TypeError('frameOffset must be a non-negative integer.');\n }\n if (options.frameCount !== undefined && (!Number.isInteger(options.frameCount) || options.frameCount < 0)) {\n throw new TypeError('frameCount must be a non-negative integer.');\n }\n if (this._closed) {\n throw new Error('AudioSample is closed.');\n }\n const { planeIndex, format, frameCount: optFrameCount, frameOffset: optFrameOffset } = options;\n const destFormat = format ?? this.format;\n if (!destFormat)\n throw new Error('Destination format not determined');\n const numFrames = this.numberOfFrames;\n const numChannels = this.numberOfChannels;\n const frameOffset = optFrameOffset ?? 0;\n if (frameOffset >= numFrames) {\n throw new RangeError('frameOffset out of range');\n }\n const copyFrameCount = optFrameCount !== undefined ? optFrameCount : (numFrames - frameOffset);\n if (copyFrameCount > (numFrames - frameOffset)) {\n throw new RangeError('frameCount out of range');\n }\n const destBytesPerSample = getBytesPerSample(destFormat);\n const destIsPlanar = formatIsPlanar(destFormat);\n if (destIsPlanar && planeIndex >= numChannels) {\n throw new RangeError('planeIndex out of range');\n }\n if (!destIsPlanar && planeIndex !== 0) {\n throw new RangeError('planeIndex out of range');\n }\n const destElementCount = destIsPlanar ? copyFrameCount : copyFrameCount * numChannels;\n const requiredSize = destElementCount * destBytesPerSample;\n if (destination.byteLength < requiredSize) {\n throw new RangeError('Destination buffer is too small');\n }\n const destView = toDataView(destination);\n const writeFn = getWriteFunction(destFormat);\n if (isAudioData(this._data)) {\n if (destIsPlanar) {\n if (destFormat === 'f32-planar') {\n // Simple, since the browser must support f32-planar, we can just delegate here\n this._data.copyTo(destination, {\n planeIndex,\n frameOffset,\n frameCount: copyFrameCount,\n format: 'f32-planar',\n });\n }\n else {\n // Allocate temporary buffer for f32-planar data\n const tempBuffer = new ArrayBuffer(copyFrameCount * 4);\n const tempArray = new Float32Array(tempBuffer);\n this._data.copyTo(tempArray, {\n planeIndex,\n frameOffset,\n frameCount: copyFrameCount,\n format: 'f32-planar',\n });\n // Convert each f32 sample to destination format\n const tempView = new DataView(tempBuffer);\n for (let i = 0; i < copyFrameCount; i++) {\n const destOffset = i * destBytesPerSample;\n const sample = tempView.getFloat32(i * 4, true);\n writeFn(destView, destOffset, sample);\n }\n }\n }\n else {\n // Destination is interleaved.\n // Allocate a temporary Float32Array to hold one channel's worth of data.\n const numCh = numChannels;\n const temp = new Float32Array(copyFrameCount);\n for (let ch = 0; ch < numCh; ch++) {\n this._data.copyTo(temp, {\n planeIndex: ch,\n frameOffset,\n frameCount: copyFrameCount,\n format: 'f32-planar',\n });\n for (let i = 0; i < copyFrameCount; i++) {\n const destIndex = i * numCh + ch;\n const destOffset = destIndex * destBytesPerSample;\n writeFn(destView, destOffset, temp[i]);\n }\n }\n }\n }\n else {\n // Branch for Uint8Array data (non-AudioData)\n const uint8Data = this._data;\n const srcView = new DataView(uint8Data.buffer, uint8Data.byteOffset, uint8Data.byteLength);\n const srcFormat = this.format;\n const readFn = getReadFunction(srcFormat);\n const srcBytesPerSample = getBytesPerSample(srcFormat);\n const srcIsPlanar = formatIsPlanar(srcFormat);\n for (let i = 0; i < copyFrameCount; i++) {\n if (destIsPlanar) {\n const destOffset = i * destBytesPerSample;\n let srcOffset;\n if (srcIsPlanar) {\n srcOffset = (planeIndex * numFrames + (i + frameOffset)) * srcBytesPerSample;\n }\n else {\n srcOffset = (((i + frameOffset) * numChannels) + planeIndex) * srcBytesPerSample;\n }\n const normalized = readFn(srcView, srcOffset);\n writeFn(destView, destOffset, normalized);\n }\n else {\n for (let ch = 0; ch < numChannels; ch++) {\n const destIndex = i * numChannels + ch;\n const destOffset = destIndex * destBytesPerSample;\n let srcOffset;\n if (srcIsPlanar) {\n srcOffset = (ch * numFrames + (i + frameOffset)) * srcBytesPerSample;\n }\n else {\n srcOffset = (((i + frameOffset) * numChannels) + ch) * srcBytesPerSample;\n }\n const normalized = readFn(srcView, srcOffset);\n writeFn(destView, destOffset, normalized);\n }\n }\n }\n }\n }\n /** Clones this audio sample. */\n clone() {\n if (this._closed) {\n throw new Error('AudioSample is closed.');\n }\n if (isAudioData(this._data)) {\n const sample = new AudioSample(this._data.clone());\n sample.setTimestamp(this.timestamp); // Make sure the timestamp is precise (beyond microsecond accuracy)\n return sample;\n }\n else {\n return new AudioSample({\n format: this.format,\n sampleRate: this.sampleRate,\n numberOfFrames: this.numberOfFrames,\n numberOfChannels: this.numberOfChannels,\n timestamp: this.timestamp,\n data: this._data,\n });\n }\n }\n /**\n * Closes this audio sample, releasing held resources. Audio samples should be closed as soon as they are not\n * needed anymore.\n */\n close() {\n if (this._closed) {\n return;\n }\n if (isAudioData(this._data)) {\n this._data.close();\n }\n else {\n this._data = new Uint8Array(0);\n }\n this._closed = true;\n }\n /**\n * Converts this audio sample to an AudioData for use with the WebCodecs API. The AudioData returned by this\n * method *must* be closed separately from this audio sample.\n */\n toAudioData() {\n if (this._closed) {\n throw new Error('AudioSample is closed.');\n }\n if (isAudioData(this._data)) {\n if (this._data.timestamp === this.microsecondTimestamp) {\n // Timestamp matches, let's just return the data (but cloned)\n return this._data.clone();\n }\n else {\n // It's impossible to simply change an AudioData's timestamp, so we'll need to create a new one\n if (formatIsPlanar(this.format)) {\n const size = this.allocationSize({ planeIndex: 0, format: this.format });\n const data = new ArrayBuffer(size * this.numberOfChannels);\n // We gotta read out each plane individually\n for (let i = 0; i < this.numberOfChannels; i++) {\n this.copyTo(new Uint8Array(data, i * size, size), { planeIndex: i, format: this.format });\n }\n return new AudioData({\n format: this.format,\n sampleRate: this.sampleRate,\n numberOfFrames: this.numberOfFrames,\n numberOfChannels: this.numberOfChannels,\n timestamp: this.microsecondTimestamp,\n data,\n });\n }\n else {\n const data = new ArrayBuffer(this.allocationSize({ planeIndex: 0, format: this.format }));\n this.copyTo(data, { planeIndex: 0, format: this.format });\n return new AudioData({\n format: this.format,\n sampleRate: this.sampleRate,\n numberOfFrames: this.numberOfFrames,\n numberOfChannels: this.numberOfChannels,\n timestamp: this.microsecondTimestamp,\n data,\n });\n }\n }\n }\n else {\n return new AudioData({\n format: this.format,\n sampleRate: this.sampleRate,\n numberOfFrames: this.numberOfFrames,\n numberOfChannels: this.numberOfChannels,\n timestamp: this.microsecondTimestamp,\n data: this._data,\n });\n }\n }\n /** Convert this audio sample to an AudioBuffer for use with the Web Audio API. */\n toAudioBuffer() {\n if (this._closed) {\n throw new Error('AudioSample is closed.');\n }\n const audioBuffer = new AudioBuffer({\n numberOfChannels: this.numberOfChannels,\n length: this.numberOfFrames,\n sampleRate: this.sampleRate,\n });\n const dataBytes = new Float32Array(this.allocationSize({ planeIndex: 0, format: 'f32-planar' }) / 4);\n for (let i = 0; i < this.numberOfChannels; i++) {\n this.copyTo(dataBytes, { planeIndex: i, format: 'f32-planar' });\n audioBuffer.copyToChannel(dataBytes, i);\n }\n return audioBuffer;\n }\n /** Sets the presentation timestamp of this audio sample, in seconds. */\n setTimestamp(newTimestamp) {\n if (!Number.isFinite(newTimestamp)) {\n throw new TypeError('newTimestamp must be a number.');\n }\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n this.timestamp = newTimestamp;\n }\n /** @internal */\n static *_fromAudioBuffer(audioBuffer, timestamp) {\n if (!(audioBuffer instanceof AudioBuffer)) {\n throw new TypeError('audioBuffer must be an AudioBuffer.');\n }\n const MAX_FLOAT_COUNT = 48000 * 5; // 5 seconds of mono 48 kHz audio per sample\n const numberOfChannels = audioBuffer.numberOfChannels;\n const sampleRate = audioBuffer.sampleRate;\n const totalFrames = audioBuffer.length;\n const maxFramesPerChunk = Math.floor(MAX_FLOAT_COUNT / numberOfChannels);\n let currentRelativeFrame = 0;\n let remainingFrames = totalFrames;\n // Create AudioSamples in a chunked fashion so we don't create huge Float32Arrays\n while (remainingFrames > 0) {\n const framesToCopy = Math.min(maxFramesPerChunk, remainingFrames);\n const chunkData = new Float32Array(numberOfChannels * framesToCopy);\n for (let channel = 0; channel < numberOfChannels; channel++) {\n audioBuffer.copyFromChannel(chunkData.subarray(channel * framesToCopy, (channel + 1) * framesToCopy), channel, currentRelativeFrame);\n }\n yield new AudioSample({\n format: 'f32-planar',\n sampleRate,\n numberOfFrames: framesToCopy,\n numberOfChannels,\n timestamp: timestamp + currentRelativeFrame / sampleRate,\n data: chunkData,\n });\n currentRelativeFrame += framesToCopy;\n remainingFrames -= framesToCopy;\n }\n }\n /**\n * Creates AudioSamples from an AudioBuffer, starting at the given timestamp in seconds. Typically creates exactly\n * one sample, but may create multiple if the AudioBuffer is exceedingly large.\n */\n static fromAudioBuffer(audioBuffer, timestamp) {\n if (!(audioBuffer instanceof AudioBuffer)) {\n throw new TypeError('audioBuffer must be an AudioBuffer.');\n }\n const MAX_FLOAT_COUNT = 48000 * 5; // 5 seconds of mono 48 kHz audio per sample\n const numberOfChannels = audioBuffer.numberOfChannels;\n const sampleRate = audioBuffer.sampleRate;\n const totalFrames = audioBuffer.length;\n const maxFramesPerChunk = Math.floor(MAX_FLOAT_COUNT / numberOfChannels);\n let currentRelativeFrame = 0;\n let remainingFrames = totalFrames;\n const result = [];\n // Create AudioSamples in a chunked fashion so we don't create huge Float32Arrays\n while (remainingFrames > 0) {\n const framesToCopy = Math.min(maxFramesPerChunk, remainingFrames);\n const chunkData = new Float32Array(numberOfChannels * framesToCopy);\n for (let channel = 0; channel < numberOfChannels; channel++) {\n audioBuffer.copyFromChannel(chunkData.subarray(channel * framesToCopy, (channel + 1) * framesToCopy), channel, currentRelativeFrame);\n }\n const audioSample = new AudioSample({\n format: 'f32-planar',\n sampleRate,\n numberOfFrames: framesToCopy,\n numberOfChannels,\n timestamp: timestamp + currentRelativeFrame / sampleRate,\n data: chunkData,\n });\n result.push(audioSample);\n currentRelativeFrame += framesToCopy;\n remainingFrames -= framesToCopy;\n }\n return result;\n }\n}\nconst getBytesPerSample = (format) => {\n switch (format) {\n case 'u8':\n case 'u8-planar':\n return 1;\n case 's16':\n case 's16-planar':\n return 2;\n case 's32':\n case 's32-planar':\n return 4;\n case 'f32':\n case 'f32-planar':\n return 4;\n default:\n throw new Error('Unknown AudioSampleFormat');\n }\n};\nconst formatIsPlanar = (format) => {\n switch (format) {\n case 'u8-planar':\n case 's16-planar':\n case 's32-planar':\n case 'f32-planar':\n return true;\n default:\n return false;\n }\n};\nconst getReadFunction = (format) => {\n switch (format) {\n case 'u8':\n case 'u8-planar':\n return (view, offset) => (view.getUint8(offset) - 128) / 128;\n case 's16':\n case 's16-planar':\n return (view, offset) => view.getInt16(offset, true) / 32768;\n case 's32':\n case 's32-planar':\n return (view, offset) => view.getInt32(offset, true) / 2147483648;\n case 'f32':\n case 'f32-planar':\n return (view, offset) => view.getFloat32(offset, true);\n }\n};\nconst getWriteFunction = (format) => {\n switch (format) {\n case 'u8':\n case 'u8-planar':\n return (view, offset, value) => view.setUint8(offset, clamp((value + 1) * 127.5, 0, 255));\n case 's16':\n case 's16-planar':\n return (view, offset, value) => view.setInt16(offset, clamp(Math.round(value * 32767), -32768, 32767), true);\n case 's32':\n case 's32-planar':\n return (view, offset, value) => view.setInt32(offset, clamp(Math.round(value * 2147483647), -2147483648, 2147483647), true);\n case 'f32':\n case 'f32-planar':\n return (view, offset, value) => view.setFloat32(offset, value, true);\n }\n};\nconst isAudioData = (x) => {\n return typeof AudioData !== 'undefined' && x instanceof AudioData;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { parsePcmCodec, PCM_AUDIO_CODECS } from './codec.js';\nimport { extractHevcNalUnits, extractNalUnitTypeForHevc, HevcNalUnitType } from './codec-data.js';\nimport { customVideoDecoders, customAudioDecoders } from './custom-coder.js';\nimport { InputAudioTrack, InputTrack, InputVideoTrack } from './input-track.js';\nimport { assert, assertNever, CallSerializer, getInt24, getUint24, insertSorted, isSafari, last, mapAsyncGenerator, promiseWithResolvers, toAsyncIterator, toDataView, validateAnyIterable, } from './misc.js';\nimport { EncodedPacket } from './packet.js';\nimport { fromAlaw, fromUlaw } from './pcm.js';\nimport { AudioSample, VideoSample } from './sample.js';\nconst validatePacketRetrievalOptions = (options) => {\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (options.metadataOnly !== undefined && typeof options.metadataOnly !== 'boolean') {\n throw new TypeError('options.metadataOnly, when defined, must be a boolean.');\n }\n if (options.verifyKeyPackets !== undefined && typeof options.verifyKeyPackets !== 'boolean') {\n throw new TypeError('options.verifyKeyPackets, when defined, must be a boolean.');\n }\n if (options.verifyKeyPackets && options.metadataOnly) {\n throw new TypeError('options.verifyKeyPackets and options.metadataOnly cannot be enabled together.');\n }\n};\nconst validateTimestamp = (timestamp) => {\n if (typeof timestamp !== 'number' || Number.isNaN(timestamp)) {\n throw new TypeError('timestamp must be a number.'); // It can be non-finite, that's fine\n }\n};\nconst maybeFixPacketType = (track, promise, options) => {\n if (options.verifyKeyPackets) {\n return promise.then(async (packet) => {\n if (!packet || packet.type === 'delta') {\n return packet;\n }\n const determinedType = await track.determinePacketType(packet);\n if (determinedType) {\n // @ts-expect-error Technically readonly\n packet.type = determinedType;\n }\n return packet;\n });\n }\n else {\n return promise;\n }\n};\n/**\n * Sink for retrieving encoded packets from an input track.\n * @group Media sinks\n * @public\n */\nexport class EncodedPacketSink {\n /** Creates a new {@link EncodedPacketSink} for the given {@link InputTrack}. */\n constructor(track) {\n if (!(track instanceof InputTrack)) {\n throw new TypeError('track must be an InputTrack.');\n }\n this._track = track;\n }\n /**\n * Retrieves the track's first packet (in decode order), or null if it has no packets. The first packet is very\n * likely to be a key packet.\n */\n getFirstPacket(options = {}) {\n validatePacketRetrievalOptions(options);\n return maybeFixPacketType(this._track, this._track._backing.getFirstPacket(options), options);\n }\n /**\n * Retrieves the packet corresponding to the given timestamp, in seconds. More specifically, returns the last packet\n * (in presentation order) with a start timestamp less than or equal to the given timestamp. This method can be\n * used to retrieve a track's last packet using `getPacket(Infinity)`. The method returns null if the timestamp\n * is before the first packet in the track.\n *\n * @param timestamp - The timestamp used for retrieval, in seconds.\n */\n getPacket(timestamp, options = {}) {\n validateTimestamp(timestamp);\n validatePacketRetrievalOptions(options);\n return maybeFixPacketType(this._track, this._track._backing.getPacket(timestamp, options), options);\n }\n /**\n * Retrieves the packet following the given packet (in decode order), or null if the given packet is the\n * last packet.\n */\n getNextPacket(packet, options = {}) {\n if (!(packet instanceof EncodedPacket)) {\n throw new TypeError('packet must be an EncodedPacket.');\n }\n validatePacketRetrievalOptions(options);\n return maybeFixPacketType(this._track, this._track._backing.getNextPacket(packet, options), options);\n }\n /**\n * Retrieves the key packet corresponding to the given timestamp, in seconds. More specifically, returns the last\n * key packet (in presentation order) with a start timestamp less than or equal to the given timestamp. A key packet\n * is a packet that doesn't require previous packets to be decoded. This method can be used to retrieve a track's\n * last key packet using `getKeyPacket(Infinity)`. The method returns null if the timestamp is before the first\n * key packet in the track.\n *\n * To ensure that the returned packet is guaranteed to be a real key frame, enable `options.verifyKeyPackets`.\n *\n * @param timestamp - The timestamp used for retrieval, in seconds.\n */\n async getKeyPacket(timestamp, options = {}) {\n validateTimestamp(timestamp);\n validatePacketRetrievalOptions(options);\n if (!options.verifyKeyPackets) {\n return this._track._backing.getKeyPacket(timestamp, options);\n }\n const packet = await this._track._backing.getKeyPacket(timestamp, options);\n if (!packet || packet.type === 'delta') {\n return packet;\n }\n const determinedType = await this._track.determinePacketType(packet);\n if (determinedType === 'delta') {\n // Try returning the previous key packet (in hopes that it's actually a key packet)\n return this.getKeyPacket(packet.timestamp - 1 / this._track.timeResolution, options);\n }\n return packet;\n }\n /**\n * Retrieves the key packet following the given packet (in decode order), or null if the given packet is the last\n * key packet.\n *\n * To ensure that the returned packet is guaranteed to be a real key frame, enable `options.verifyKeyPackets`.\n */\n async getNextKeyPacket(packet, options = {}) {\n if (!(packet instanceof EncodedPacket)) {\n throw new TypeError('packet must be an EncodedPacket.');\n }\n validatePacketRetrievalOptions(options);\n if (!options.verifyKeyPackets) {\n return this._track._backing.getNextKeyPacket(packet, options);\n }\n const nextPacket = await this._track._backing.getNextKeyPacket(packet, options);\n if (!nextPacket || nextPacket.type === 'delta') {\n return nextPacket;\n }\n const determinedType = await this._track.determinePacketType(nextPacket);\n if (determinedType === 'delta') {\n // Try returning the next key packet (in hopes that it's actually a key packet)\n return this.getNextKeyPacket(nextPacket, options);\n }\n return nextPacket;\n }\n /**\n * Creates an async iterator that yields the packets in this track in decode order. To enable fast iteration, this\n * method will intelligently preload packets based on the speed of the consumer.\n *\n * @param startPacket - (optional) The packet from which iteration should begin. This packet will also be yielded.\n * @param endTimestamp - (optional) The timestamp at which iteration should end. This packet will _not_ be yielded.\n */\n packets(startPacket, endPacket, options = {}) {\n if (startPacket !== undefined && !(startPacket instanceof EncodedPacket)) {\n throw new TypeError('startPacket must be an EncodedPacket.');\n }\n if (startPacket !== undefined && startPacket.isMetadataOnly && !options?.metadataOnly) {\n throw new TypeError('startPacket can only be metadata-only if options.metadataOnly is enabled.');\n }\n if (endPacket !== undefined && !(endPacket instanceof EncodedPacket)) {\n throw new TypeError('endPacket must be an EncodedPacket.');\n }\n validatePacketRetrievalOptions(options);\n const packetQueue = [];\n let { promise: queueNotEmpty, resolve: onQueueNotEmpty } = promiseWithResolvers();\n let { promise: queueDequeue, resolve: onQueueDequeue } = promiseWithResolvers();\n let ended = false;\n let terminated = false;\n // This stores errors that are \"out of band\" in the sense that they didn't occur in the normal flow of this\n // method but instead in a different context. This error should not go unnoticed and must be bubbled up to\n // the consumer.\n let outOfBandError = null;\n const timestamps = [];\n // The queue should always be big enough to hold 1 second worth of packets\n const maxQueueSize = () => Math.max(2, timestamps.length);\n // The following is the \"pump\" process that keeps pumping packets into the queue\n (async () => {\n let packet = startPacket ?? await this.getFirstPacket(options);\n while (packet && !terminated) {\n if (endPacket && packet.sequenceNumber >= endPacket?.sequenceNumber) {\n break;\n }\n if (packetQueue.length > maxQueueSize()) {\n ({ promise: queueDequeue, resolve: onQueueDequeue } = promiseWithResolvers());\n await queueDequeue;\n continue;\n }\n packetQueue.push(packet);\n onQueueNotEmpty();\n ({ promise: queueNotEmpty, resolve: onQueueNotEmpty } = promiseWithResolvers());\n packet = await this.getNextPacket(packet, options);\n }\n ended = true;\n onQueueNotEmpty();\n })().catch((error) => {\n if (!outOfBandError) {\n outOfBandError = error;\n onQueueNotEmpty();\n }\n });\n return {\n async next() {\n while (true) {\n if (terminated) {\n return { value: undefined, done: true };\n }\n else if (outOfBandError) {\n throw outOfBandError;\n }\n else if (packetQueue.length > 0) {\n const value = packetQueue.shift();\n const now = performance.now();\n timestamps.push(now);\n while (timestamps.length > 0 && now - timestamps[0] >= 1000) {\n timestamps.shift();\n }\n onQueueDequeue();\n return { value, done: false };\n }\n else if (ended) {\n return { value: undefined, done: true };\n }\n else {\n await queueNotEmpty;\n }\n }\n },\n async return() {\n terminated = true;\n onQueueDequeue();\n onQueueNotEmpty();\n return { value: undefined, done: true };\n },\n async throw(error) {\n throw error;\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n };\n }\n}\nclass DecoderWrapper {\n constructor(onSample, onError) {\n this.onSample = onSample;\n this.onError = onError;\n }\n}\n/**\n * Base class for decoded media sample sinks.\n * @group Media sinks\n * @public\n */\nexport class BaseMediaSampleSink {\n /** @internal */\n mediaSamplesInRange(startTimestamp = 0, endTimestamp = Infinity) {\n validateTimestamp(startTimestamp);\n validateTimestamp(endTimestamp);\n const sampleQueue = [];\n let firstSampleQueued = false;\n let lastSample = null;\n let { promise: queueNotEmpty, resolve: onQueueNotEmpty } = promiseWithResolvers();\n let { promise: queueDequeue, resolve: onQueueDequeue } = promiseWithResolvers();\n let decoderIsFlushed = false;\n let ended = false;\n let terminated = false;\n // This stores errors that are \"out of band\" in the sense that they didn't occur in the normal flow of this\n // method but instead in a different context. This error should not go unnoticed and must be bubbled up to\n // the consumer.\n let outOfBandError = null;\n // The following is the \"pump\" process that keeps pumping packets into the decoder\n (async () => {\n const decoderError = new Error();\n const decoder = await this._createDecoder((sample) => {\n onQueueDequeue();\n if (sample.timestamp >= endTimestamp) {\n ended = true;\n }\n if (ended) {\n sample.close();\n return;\n }\n if (lastSample) {\n if (sample.timestamp > startTimestamp) {\n // We don't know ahead of time what the first first is. This is because the first first is the\n // last first whose timestamp is less than or equal to the start timestamp. Therefore we need to\n // wait for the first first after the start timestamp, and then we'll know that the previous\n // first was the first first.\n sampleQueue.push(lastSample);\n firstSampleQueued = true;\n }\n else {\n lastSample.close();\n }\n }\n if (sample.timestamp >= startTimestamp) {\n sampleQueue.push(sample);\n firstSampleQueued = true;\n }\n lastSample = firstSampleQueued ? null : sample;\n if (sampleQueue.length > 0) {\n onQueueNotEmpty();\n ({ promise: queueNotEmpty, resolve: onQueueNotEmpty } = promiseWithResolvers());\n }\n }, (error) => {\n if (!outOfBandError) {\n error.stack = decoderError.stack; // Provide a more useful stack trace\n outOfBandError = error;\n onQueueNotEmpty();\n }\n });\n const packetSink = this._createPacketSink();\n const keyPacket = await packetSink.getKeyPacket(startTimestamp, { verifyKeyPackets: true })\n ?? await packetSink.getFirstPacket();\n if (!keyPacket) {\n return;\n }\n let currentPacket = keyPacket;\n let endPacket = undefined;\n if (endTimestamp < Infinity) {\n // When an end timestamp is set, we cannot simply use that for the packet iterator due to out-of-order\n // frames (B-frames). Instead, we'll need to keep decoding packets until we get a frame that exceeds\n // this end time. However, we can still put a bound on it: Since key frames are by definition never\n // out of order, we can stop at the first key frame after the end timestamp.\n const packet = await packetSink.getPacket(endTimestamp);\n const keyPacket = !packet\n ? null\n : packet.type === 'key' && packet.timestamp === endTimestamp\n ? packet\n : await packetSink.getNextKeyPacket(packet, { verifyKeyPackets: true });\n if (keyPacket) {\n endPacket = keyPacket;\n }\n }\n const packets = packetSink.packets(keyPacket, endPacket);\n await packets.next(); // Skip the start packet as we already have it\n while (currentPacket && !ended) {\n const maxQueueSize = computeMaxQueueSize(sampleQueue.length);\n if (sampleQueue.length + decoder.getDecodeQueueSize() > maxQueueSize) {\n ({ promise: queueDequeue, resolve: onQueueDequeue } = promiseWithResolvers());\n await queueDequeue;\n continue;\n }\n decoder.decode(currentPacket);\n const packetResult = await packets.next();\n if (packetResult.done) {\n break;\n }\n currentPacket = packetResult.value;\n }\n await packets.return();\n if (!terminated)\n await decoder.flush();\n decoder.close();\n if (!firstSampleQueued && lastSample) {\n sampleQueue.push(lastSample);\n }\n decoderIsFlushed = true;\n onQueueNotEmpty(); // To unstuck the generator\n })().catch((error) => {\n if (!outOfBandError) {\n outOfBandError = error;\n onQueueNotEmpty();\n }\n });\n return {\n async next() {\n while (true) {\n if (terminated) {\n return { value: undefined, done: true };\n }\n else if (outOfBandError) {\n throw outOfBandError;\n }\n else if (sampleQueue.length > 0) {\n const value = sampleQueue.shift();\n onQueueDequeue();\n return { value, done: false };\n }\n else if (!decoderIsFlushed) {\n await queueNotEmpty;\n }\n else {\n return { value: undefined, done: true };\n }\n }\n },\n async return() {\n terminated = true;\n ended = true;\n onQueueDequeue();\n onQueueNotEmpty();\n lastSample?.close();\n for (const sample of sampleQueue) {\n sample.close();\n }\n return { value: undefined, done: true };\n },\n async throw(error) {\n throw error;\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n };\n }\n /** @internal */\n mediaSamplesAtTimestamps(timestamps) {\n validateAnyIterable(timestamps);\n const timestampIterator = toAsyncIterator(timestamps);\n const timestampsOfInterest = [];\n const sampleQueue = [];\n let { promise: queueNotEmpty, resolve: onQueueNotEmpty } = promiseWithResolvers();\n let { promise: queueDequeue, resolve: onQueueDequeue } = promiseWithResolvers();\n let decoderIsFlushed = false;\n let terminated = false;\n // This stores errors that are \"out of band\" in the sense that they didn't occur in the normal flow of this\n // method but instead in a different context. This error should not go unnoticed and must be bubbled up to\n // the consumer.\n let outOfBandError = null;\n const pushToQueue = (sample) => {\n sampleQueue.push(sample);\n onQueueNotEmpty();\n ({ promise: queueNotEmpty, resolve: onQueueNotEmpty } = promiseWithResolvers());\n };\n // The following is the \"pump\" process that keeps pumping packets into the decoder\n (async () => {\n const decoderError = new Error();\n const decoder = await this._createDecoder((sample) => {\n onQueueDequeue();\n if (terminated) {\n sample.close();\n return;\n }\n let sampleUses = 0;\n while (timestampsOfInterest.length > 0\n && sample.timestamp - timestampsOfInterest[0] > -1e-10 // Give it a little epsilon\n ) {\n sampleUses++;\n timestampsOfInterest.shift();\n }\n if (sampleUses > 0) {\n for (let i = 0; i < sampleUses; i++) {\n // Clone the sample if we need to emit it multiple times\n pushToQueue((i < sampleUses - 1 ? sample.clone() : sample));\n }\n }\n else {\n sample.close();\n }\n }, (error) => {\n if (!outOfBandError) {\n error.stack = decoderError.stack; // Provide a more useful stack trace\n outOfBandError = error;\n onQueueNotEmpty();\n }\n });\n const packetSink = this._createPacketSink();\n let lastPacket = null;\n let lastKeyPacket = null;\n // The end sequence number (inclusive) in the next batch of packets that will be decoded. The batch starts\n // at the last key frame and goes until this sequence number.\n let maxSequenceNumber = -1;\n const decodePackets = async () => {\n assert(lastKeyPacket);\n // Start at the current key packet\n let currentPacket = lastKeyPacket;\n decoder.decode(currentPacket);\n while (currentPacket.sequenceNumber < maxSequenceNumber) {\n const maxQueueSize = computeMaxQueueSize(sampleQueue.length);\n while (sampleQueue.length + decoder.getDecodeQueueSize() > maxQueueSize && !terminated) {\n ({ promise: queueDequeue, resolve: onQueueDequeue } = promiseWithResolvers());\n await queueDequeue;\n }\n if (terminated) {\n break;\n }\n const nextPacket = await packetSink.getNextPacket(currentPacket);\n assert(nextPacket);\n decoder.decode(nextPacket);\n currentPacket = nextPacket;\n }\n maxSequenceNumber = -1;\n };\n const flushDecoder = async () => {\n await decoder.flush();\n // We don't expect this list to have any elements in it anymore, but in case it does, let's emit\n // nulls for every remaining element, then clear it.\n for (let i = 0; i < timestampsOfInterest.length; i++) {\n pushToQueue(null);\n }\n timestampsOfInterest.length = 0;\n };\n for await (const timestamp of timestampIterator) {\n validateTimestamp(timestamp);\n if (terminated) {\n break;\n }\n const targetPacket = await packetSink.getPacket(timestamp);\n const keyPacket = targetPacket && await packetSink.getKeyPacket(timestamp, { verifyKeyPackets: true });\n if (!keyPacket) {\n if (maxSequenceNumber !== -1) {\n await decodePackets();\n await flushDecoder();\n }\n pushToQueue(null);\n lastPacket = null;\n continue;\n }\n // Check if the key packet has changed or if we're going back in time\n if (lastPacket\n && (keyPacket.sequenceNumber !== lastKeyPacket.sequenceNumber\n || targetPacket.timestamp < lastPacket.timestamp)) {\n await decodePackets();\n await flushDecoder(); // Always flush here, improves decoder compatibility\n }\n timestampsOfInterest.push(targetPacket.timestamp);\n maxSequenceNumber = Math.max(targetPacket.sequenceNumber, maxSequenceNumber);\n lastPacket = targetPacket;\n lastKeyPacket = keyPacket;\n }\n if (!terminated) {\n if (maxSequenceNumber !== -1) {\n // We still need to decode packets\n await decodePackets();\n }\n await flushDecoder();\n }\n decoder.close();\n decoderIsFlushed = true;\n onQueueNotEmpty(); // To unstuck the generator\n })().catch((error) => {\n if (!outOfBandError) {\n outOfBandError = error;\n onQueueNotEmpty();\n }\n });\n return {\n async next() {\n while (true) {\n if (terminated) {\n return { value: undefined, done: true };\n }\n else if (outOfBandError) {\n throw outOfBandError;\n }\n else if (sampleQueue.length > 0) {\n const value = sampleQueue.shift();\n assert(value !== undefined);\n onQueueDequeue();\n return { value, done: false };\n }\n else if (!decoderIsFlushed) {\n await queueNotEmpty;\n }\n else {\n return { value: undefined, done: true };\n }\n }\n },\n async return() {\n terminated = true;\n onQueueDequeue();\n onQueueNotEmpty();\n for (const sample of sampleQueue) {\n sample?.close();\n }\n return { value: undefined, done: true };\n },\n async throw(error) {\n throw error;\n },\n [Symbol.asyncIterator]() {\n return this;\n },\n };\n }\n}\nconst computeMaxQueueSize = (decodedSampleQueueSize) => {\n // If we have decoded samples lying around, limit the total queue size to a small value (decoded samples can use up\n // a lot of memory). If not, we're fine with a much bigger queue of encoded packets waiting to be decoded. In fact,\n // some decoders only start flushing out decoded chunks when the packet queue is large enough.\n return decodedSampleQueueSize === 0 ? 40 : 8;\n};\nclass VideoDecoderWrapper extends DecoderWrapper {\n constructor(onSample, onError, codec, decoderConfig, rotation, timeResolution) {\n super(onSample, onError);\n this.codec = codec;\n this.decoderConfig = decoderConfig;\n this.rotation = rotation;\n this.timeResolution = timeResolution;\n this.decoder = null;\n this.customDecoder = null;\n this.customDecoderCallSerializer = new CallSerializer();\n this.customDecoderQueueSize = 0;\n this.inputTimestamps = []; // Timestamps input into the decoder, sorted.\n this.sampleQueue = []; // Safari-specific thing, check usage.\n this.currentPacketIndex = 0;\n this.raslSkipped = false; // For HEVC stuff\n const MatchingCustomDecoder = customVideoDecoders.find(x => x.supports(codec, decoderConfig));\n if (MatchingCustomDecoder) {\n // @ts-expect-error \"Can't create instance of abstract class \uD83E\uDD13\"\n this.customDecoder = new MatchingCustomDecoder();\n // @ts-expect-error It's technically readonly\n this.customDecoder.codec = codec;\n // @ts-expect-error It's technically readonly\n this.customDecoder.config = decoderConfig;\n // @ts-expect-error It's technically readonly\n this.customDecoder.onSample = (sample) => {\n if (!(sample instanceof VideoSample)) {\n throw new TypeError('The argument passed to onSample must be a VideoSample.');\n }\n this.finalizeAndEmitSample(sample);\n };\n void this.customDecoderCallSerializer.call(() => this.customDecoder.init());\n }\n else {\n // Specific handler for the WebCodecs VideoDecoder to iron out browser differences\n const sampleHandler = (sample) => {\n if (isSafari()) {\n // For correct B-frame handling, we don't just hand over the frames directly but instead add them to\n // a queue, because we want to ensure frames are emitted in presentation order. We flush the queue\n // each time we receive a frame with a timestamp larger than the highest we've seen so far, as we\n // can sure that is not a B-frame. Typically, WebCodecs automatically guarantees that frames are\n // emitted in presentation order, but Safari doesn't always follow this rule.\n if (this.sampleQueue.length > 0 && (sample.timestamp >= last(this.sampleQueue).timestamp)) {\n for (const sample of this.sampleQueue) {\n this.finalizeAndEmitSample(sample);\n }\n this.sampleQueue.length = 0;\n }\n insertSorted(this.sampleQueue, sample, x => x.timestamp);\n }\n else {\n // Assign it the next earliest timestamp from the input. We do this because browsers, by spec, are\n // required to emit decoded frames in presentation order *while* retaining the timestamp of their\n // originating EncodedVideoChunk. For files with B-frames but no out-of-order timestamps (like a\n // missing ctts box, for example), this causes a mismatch. We therefore fix the timestamps and\n // ensure they are sorted by doing this.\n const timestamp = this.inputTimestamps.shift();\n // There's no way we'd have more decoded frames than encoded packets we passed in. Actually, the\n // correspondence should be 1:1.\n assert(timestamp !== undefined);\n sample.setTimestamp(timestamp);\n this.finalizeAndEmitSample(sample);\n }\n };\n this.decoder = new VideoDecoder({\n output: frame => sampleHandler(new VideoSample(frame)),\n error: onError,\n });\n this.decoder.configure(decoderConfig);\n }\n }\n finalizeAndEmitSample(sample) {\n // Round the timestamps to the time resolution\n sample.setTimestamp(Math.round(sample.timestamp * this.timeResolution) / this.timeResolution);\n sample.setDuration(Math.round(sample.duration * this.timeResolution) / this.timeResolution);\n sample.setRotation(this.rotation);\n this.onSample(sample);\n }\n getDecodeQueueSize() {\n if (this.customDecoder) {\n return this.customDecoderQueueSize;\n }\n else {\n assert(this.decoder);\n return this.decoder.decodeQueueSize;\n }\n }\n decode(packet) {\n if (this.codec === 'hevc' && this.currentPacketIndex > 0 && !this.raslSkipped) {\n // If we're using HEVC, we need to make sure to skip any RASL slices that follow a non-IDR key frame such as\n // CRA_NUT. This is because RASL slices cannot be decoded without data before the CRA_NUT. Browsers behave\n // differently here: Chromium drops the packets, Safari throws a decoder error. Either way, it's not good\n // and causes bugs upstream. So, let's take the dropping into our own hands.\n const nalUnits = extractHevcNalUnits(packet.data, this.decoderConfig);\n const hasRaslPicture = nalUnits.some((x) => {\n const type = extractNalUnitTypeForHevc(x);\n return type === HevcNalUnitType.RASL_N || type === HevcNalUnitType.RASL_R;\n });\n if (hasRaslPicture) {\n return; // Drop\n }\n this.raslSkipped = true;\n }\n this.currentPacketIndex++;\n if (this.customDecoder) {\n this.customDecoderQueueSize++;\n void this.customDecoderCallSerializer\n .call(() => this.customDecoder.decode(packet))\n .then(() => this.customDecoderQueueSize--);\n }\n else {\n assert(this.decoder);\n if (!isSafari()) {\n insertSorted(this.inputTimestamps, packet.timestamp, x => x);\n }\n this.decoder.decode(packet.toEncodedVideoChunk());\n }\n }\n async flush() {\n if (this.customDecoder) {\n await this.customDecoderCallSerializer.call(() => this.customDecoder.flush());\n }\n else {\n assert(this.decoder);\n await this.decoder.flush();\n }\n if (isSafari()) {\n for (const sample of this.sampleQueue) {\n this.finalizeAndEmitSample(sample);\n }\n this.sampleQueue.length = 0;\n }\n this.currentPacketIndex = 0;\n this.raslSkipped = false;\n }\n close() {\n if (this.customDecoder) {\n void this.customDecoderCallSerializer.call(() => this.customDecoder.close());\n }\n else {\n assert(this.decoder);\n this.decoder.close();\n }\n for (const sample of this.sampleQueue) {\n sample.close();\n }\n this.sampleQueue.length = 0;\n }\n}\n/**\n * A sink that retrieves decoded video samples (video frames) from a video track.\n * @group Media sinks\n * @public\n */\nexport class VideoSampleSink extends BaseMediaSampleSink {\n /** Creates a new {@link VideoSampleSink} for the given {@link InputVideoTrack}. */\n constructor(videoTrack) {\n if (!(videoTrack instanceof InputVideoTrack)) {\n throw new TypeError('videoTrack must be an InputVideoTrack.');\n }\n super();\n this._videoTrack = videoTrack;\n }\n /** @internal */\n async _createDecoder(onSample, onError) {\n if (!(await this._videoTrack.canDecode())) {\n throw new Error('This video track cannot be decoded by this browser. Make sure to check decodability before using'\n + ' a track.');\n }\n const codec = this._videoTrack.codec;\n const rotation = this._videoTrack.rotation;\n const decoderConfig = await this._videoTrack.getDecoderConfig();\n const timeResolution = this._videoTrack.timeResolution;\n assert(codec && decoderConfig);\n return new VideoDecoderWrapper(onSample, onError, codec, decoderConfig, rotation, timeResolution);\n }\n /** @internal */\n _createPacketSink() {\n return new EncodedPacketSink(this._videoTrack);\n }\n /**\n * Retrieves the video sample (frame) corresponding to the given timestamp, in seconds. More specifically, returns\n * the last video sample (in presentation order) with a start timestamp less than or equal to the given timestamp.\n * Returns null if the timestamp is before the track's first timestamp.\n *\n * @param timestamp - The timestamp used for retrieval, in seconds.\n */\n async getSample(timestamp) {\n validateTimestamp(timestamp);\n for await (const sample of this.mediaSamplesAtTimestamps([timestamp])) {\n return sample;\n }\n throw new Error('Internal error: Iterator returned nothing.');\n }\n /**\n * Creates an async iterator that yields the video samples (frames) of this track in presentation order. This method\n * will intelligently pre-decode a few frames ahead to enable fast iteration.\n *\n * @param startTimestamp - The timestamp in seconds at which to start yielding samples (inclusive).\n * @param endTimestamp - The timestamp in seconds at which to stop yielding samples (exclusive).\n */\n samples(startTimestamp = 0, endTimestamp = Infinity) {\n return this.mediaSamplesInRange(startTimestamp, endTimestamp);\n }\n /**\n * Creates an async iterator that yields a video sample (frame) for each timestamp in the argument. This method\n * uses an optimized decoding pipeline if these timestamps are monotonically sorted, decoding each packet at most\n * once, and is therefore more efficient than manually getting the sample for every timestamp. The iterator may\n * yield null if no frame is available for a given timestamp.\n *\n * @param timestamps - An iterable or async iterable of timestamps in seconds.\n */\n samplesAtTimestamps(timestamps) {\n return this.mediaSamplesAtTimestamps(timestamps);\n }\n}\n/**\n * A sink that renders video samples (frames) of the given video track to canvases. This is often more useful than\n * directly retrieving frames, as it comes with common preprocessing steps such as resizing or applying rotation\n * metadata.\n *\n * This sink will yield `HTMLCanvasElement`s when in a DOM context, and `OffscreenCanvas`es otherwise.\n *\n * @group Media sinks\n * @public\n */\nexport class CanvasSink {\n /** Creates a new {@link CanvasSink} for the given {@link InputVideoTrack}. */\n constructor(videoTrack, options = {}) {\n /** @internal */\n this._nextCanvasIndex = 0;\n if (!(videoTrack instanceof InputVideoTrack)) {\n throw new TypeError('videoTrack must be an InputVideoTrack.');\n }\n if (options && typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (options.width !== undefined && (!Number.isInteger(options.width) || options.width <= 0)) {\n throw new TypeError('options.width, when defined, must be a positive integer.');\n }\n if (options.height !== undefined && (!Number.isInteger(options.height) || options.height <= 0)) {\n throw new TypeError('options.height, when defined, must be a positive integer.');\n }\n if (options.fit !== undefined && !['fill', 'contain', 'cover'].includes(options.fit)) {\n throw new TypeError('options.fit, when provided, must be one of \"fill\", \"contain\", or \"cover\".');\n }\n if (options.width !== undefined\n && options.height !== undefined\n && options.fit === undefined) {\n throw new TypeError('When both options.width and options.height are provided, options.fit must also be provided.');\n }\n if (options.rotation !== undefined && ![0, 90, 180, 270].includes(options.rotation)) {\n throw new TypeError('options.rotation, when provided, must be 0, 90, 180 or 270.');\n }\n if (options.poolSize !== undefined\n && (typeof options.poolSize !== 'number' || !Number.isInteger(options.poolSize) || options.poolSize < 0)) {\n throw new TypeError('poolSize must be a non-negative integer.');\n }\n const rotation = options.rotation ?? videoTrack.rotation;\n let [width, height] = rotation % 180 === 0\n ? [videoTrack.codedWidth, videoTrack.codedHeight]\n : [videoTrack.codedHeight, videoTrack.codedWidth];\n const originalAspectRatio = width / height;\n // If width and height aren't defined together, deduce the missing value using the aspect ratio\n if (options.width !== undefined && options.height === undefined) {\n width = options.width;\n height = Math.round(width / originalAspectRatio);\n }\n else if (options.width === undefined && options.height !== undefined) {\n height = options.height;\n width = Math.round(height * originalAspectRatio);\n }\n else if (options.width !== undefined && options.height !== undefined) {\n width = options.width;\n height = options.height;\n }\n this._videoTrack = videoTrack;\n this._width = width;\n this._height = height;\n this._rotation = rotation;\n this._fit = options.fit ?? 'fill';\n this._videoSampleSink = new VideoSampleSink(videoTrack);\n this._canvasPool = Array.from({ length: options.poolSize ?? 0 }, () => null);\n }\n /** @internal */\n _videoSampleToWrappedCanvas(sample) {\n let canvas = this._canvasPool[this._nextCanvasIndex];\n let canvasIsNew = false;\n if (!canvas) {\n if (typeof document !== 'undefined') {\n // Prefer an HTMLCanvasElement\n canvas = document.createElement('canvas');\n canvas.width = this._width;\n canvas.height = this._height;\n }\n else {\n canvas = new OffscreenCanvas(this._width, this._height);\n }\n if (this._canvasPool.length > 0) {\n this._canvasPool[this._nextCanvasIndex] = canvas;\n }\n canvasIsNew = true;\n }\n if (this._canvasPool.length > 0) {\n this._nextCanvasIndex = (this._nextCanvasIndex + 1) % this._canvasPool.length;\n }\n const context = canvas.getContext('2d', { alpha: false });\n assert(context);\n context.resetTransform();\n if (!canvasIsNew) {\n context.clearRect(0, 0, this._width, this._height);\n }\n sample.drawWithFit(context, {\n fit: this._fit,\n rotation: this._rotation,\n });\n const result = {\n canvas,\n timestamp: sample.timestamp,\n duration: sample.duration,\n };\n sample.close();\n return result;\n }\n /**\n * Retrieves a canvas with the video frame corresponding to the given timestamp, in seconds. More specifically,\n * returns the last video frame (in presentation order) with a start timestamp less than or equal to the given\n * timestamp. Returns null if the timestamp is before the track's first timestamp.\n *\n * @param timestamp - The timestamp used for retrieval, in seconds.\n */\n async getCanvas(timestamp) {\n validateTimestamp(timestamp);\n const sample = await this._videoSampleSink.getSample(timestamp);\n return sample && this._videoSampleToWrappedCanvas(sample);\n }\n /**\n * Creates an async iterator that yields canvases with the video frames of this track in presentation order. This\n * method will intelligently pre-decode a few frames ahead to enable fast iteration.\n *\n * @param startTimestamp - The timestamp in seconds at which to start yielding canvases (inclusive).\n * @param endTimestamp - The timestamp in seconds at which to stop yielding canvases (exclusive).\n */\n canvases(startTimestamp = 0, endTimestamp = Infinity) {\n return mapAsyncGenerator(this._videoSampleSink.samples(startTimestamp, endTimestamp), sample => this._videoSampleToWrappedCanvas(sample));\n }\n /**\n * Creates an async iterator that yields a canvas for each timestamp in the argument. This method uses an optimized\n * decoding pipeline if these timestamps are monotonically sorted, decoding each packet at most once, and is\n * therefore more efficient than manually getting the canvas for every timestamp. The iterator may yield null if\n * no frame is available for a given timestamp.\n *\n * @param timestamps - An iterable or async iterable of timestamps in seconds.\n */\n canvasesAtTimestamps(timestamps) {\n return mapAsyncGenerator(this._videoSampleSink.samplesAtTimestamps(timestamps), sample => sample && this._videoSampleToWrappedCanvas(sample));\n }\n}\nclass AudioDecoderWrapper extends DecoderWrapper {\n constructor(onSample, onError, codec, decoderConfig) {\n super(onSample, onError);\n this.decoder = null;\n this.customDecoder = null;\n this.customDecoderCallSerializer = new CallSerializer();\n this.customDecoderQueueSize = 0;\n // Internal state to accumulate a precise current timestamp based on audio durations, not the (potentially\n // inaccurate) packet timestamps.\n this.currentTimestamp = null;\n const sampleHandler = (sample) => {\n if (this.currentTimestamp === null\n || Math.abs(sample.timestamp - this.currentTimestamp) >= sample.duration) {\n // We need to sync with the sample timestamp again\n this.currentTimestamp = sample.timestamp;\n }\n const preciseTimestamp = this.currentTimestamp;\n this.currentTimestamp += sample.duration;\n if (sample.numberOfFrames === 0) {\n // We skip zero-data (empty) AudioSamples. These are sometimes emitted, for example, by Firefox when it\n // decodes Vorbis (at the start).\n sample.close();\n return;\n }\n // Round the timestamp to the sample rate\n const sampleRate = decoderConfig.sampleRate;\n sample.setTimestamp(Math.round(preciseTimestamp * sampleRate) / sampleRate);\n onSample(sample);\n };\n const MatchingCustomDecoder = customAudioDecoders.find(x => x.supports(codec, decoderConfig));\n if (MatchingCustomDecoder) {\n // @ts-expect-error \"Can't create instance of abstract class \uD83E\uDD13\"\n this.customDecoder = new MatchingCustomDecoder();\n // @ts-expect-error It's technically readonly\n this.customDecoder.codec = codec;\n // @ts-expect-error It's technically readonly\n this.customDecoder.config = decoderConfig;\n // @ts-expect-error It's technically readonly\n this.customDecoder.onSample = (sample) => {\n if (!(sample instanceof AudioSample)) {\n throw new TypeError('The argument passed to onSample must be an AudioSample.');\n }\n sampleHandler(sample);\n };\n void this.customDecoderCallSerializer.call(() => this.customDecoder.init());\n }\n else {\n this.decoder = new AudioDecoder({\n output: data => sampleHandler(new AudioSample(data)),\n error: onError,\n });\n this.decoder.configure(decoderConfig);\n }\n }\n getDecodeQueueSize() {\n if (this.customDecoder) {\n return this.customDecoderQueueSize;\n }\n else {\n assert(this.decoder);\n return this.decoder.decodeQueueSize;\n }\n }\n decode(packet) {\n if (this.customDecoder) {\n this.customDecoderQueueSize++;\n void this.customDecoderCallSerializer\n .call(() => this.customDecoder.decode(packet))\n .then(() => this.customDecoderQueueSize--);\n }\n else {\n assert(this.decoder);\n this.decoder.decode(packet.toEncodedAudioChunk());\n }\n }\n flush() {\n if (this.customDecoder) {\n return this.customDecoderCallSerializer.call(() => this.customDecoder.flush());\n }\n else {\n assert(this.decoder);\n return this.decoder.flush();\n }\n }\n close() {\n if (this.customDecoder) {\n void this.customDecoderCallSerializer.call(() => this.customDecoder.close());\n }\n else {\n assert(this.decoder);\n this.decoder.close();\n }\n }\n}\n// There are a lot of PCM variants not natively supported by the browser and by AudioData. Therefore we need a simple\n// decoder that maps any input PCM format into a PCM format supported by the browser.\nclass PcmAudioDecoderWrapper extends DecoderWrapper {\n constructor(onSample, onError, decoderConfig) {\n super(onSample, onError);\n this.decoderConfig = decoderConfig;\n // Internal state to accumulate a precise current timestamp based on audio durations, not the (potentially\n // inaccurate) packet timestamps.\n this.currentTimestamp = null;\n assert(PCM_AUDIO_CODECS.includes(decoderConfig.codec));\n this.codec = decoderConfig.codec;\n const { dataType, sampleSize, littleEndian } = parsePcmCodec(this.codec);\n this.inputSampleSize = sampleSize;\n switch (sampleSize) {\n case 1:\n {\n if (dataType === 'unsigned') {\n this.readInputValue = (view, byteOffset) => view.getUint8(byteOffset) - 2 ** 7;\n }\n else if (dataType === 'signed') {\n this.readInputValue = (view, byteOffset) => view.getInt8(byteOffset);\n }\n else if (dataType === 'ulaw') {\n this.readInputValue = (view, byteOffset) => fromUlaw(view.getUint8(byteOffset));\n }\n else if (dataType === 'alaw') {\n this.readInputValue = (view, byteOffset) => fromAlaw(view.getUint8(byteOffset));\n }\n else {\n assert(false);\n }\n }\n ;\n break;\n case 2:\n {\n if (dataType === 'unsigned') {\n this.readInputValue = (view, byteOffset) => view.getUint16(byteOffset, littleEndian) - 2 ** 15;\n }\n else if (dataType === 'signed') {\n this.readInputValue = (view, byteOffset) => view.getInt16(byteOffset, littleEndian);\n }\n else {\n assert(false);\n }\n }\n ;\n break;\n case 3:\n {\n if (dataType === 'unsigned') {\n this.readInputValue = (view, byteOffset) => getUint24(view, byteOffset, littleEndian) - 2 ** 23;\n }\n else if (dataType === 'signed') {\n this.readInputValue = (view, byteOffset) => getInt24(view, byteOffset, littleEndian);\n }\n else {\n assert(false);\n }\n }\n ;\n break;\n case 4:\n {\n if (dataType === 'unsigned') {\n this.readInputValue = (view, byteOffset) => view.getUint32(byteOffset, littleEndian) - 2 ** 31;\n }\n else if (dataType === 'signed') {\n this.readInputValue = (view, byteOffset) => view.getInt32(byteOffset, littleEndian);\n }\n else if (dataType === 'float') {\n this.readInputValue = (view, byteOffset) => view.getFloat32(byteOffset, littleEndian);\n }\n else {\n assert(false);\n }\n }\n ;\n break;\n case 8:\n {\n if (dataType === 'float') {\n this.readInputValue = (view, byteOffset) => view.getFloat64(byteOffset, littleEndian);\n }\n else {\n assert(false);\n }\n }\n ;\n break;\n default:\n {\n assertNever(sampleSize);\n assert(false);\n }\n ;\n }\n switch (sampleSize) {\n case 1:\n {\n if (dataType === 'ulaw' || dataType === 'alaw') {\n this.outputSampleSize = 2;\n this.outputFormat = 's16';\n this.writeOutputValue = (view, byteOffset, value) => view.setInt16(byteOffset, value, true);\n }\n else {\n this.outputSampleSize = 1;\n this.outputFormat = 'u8';\n this.writeOutputValue = (view, byteOffset, value) => view.setUint8(byteOffset, value + 2 ** 7);\n }\n }\n ;\n break;\n case 2:\n {\n this.outputSampleSize = 2;\n this.outputFormat = 's16';\n this.writeOutputValue = (view, byteOffset, value) => view.setInt16(byteOffset, value, true);\n }\n ;\n break;\n case 3:\n {\n this.outputSampleSize = 4;\n this.outputFormat = 's32';\n // From https://www.w3.org/TR/webcodecs:\n // AudioData containing 24-bit samples SHOULD store those samples in s32 or f32. When samples are\n // stored in s32, each sample MUST be left-shifted by 8 bits.\n this.writeOutputValue = (view, byteOffset, value) => view.setInt32(byteOffset, value << 8, true);\n }\n ;\n break;\n case 4:\n {\n this.outputSampleSize = 4;\n if (dataType === 'float') {\n this.outputFormat = 'f32';\n this.writeOutputValue = (view, byteOffset, value) => view.setFloat32(byteOffset, value, true);\n }\n else {\n this.outputFormat = 's32';\n this.writeOutputValue = (view, byteOffset, value) => view.setInt32(byteOffset, value, true);\n }\n }\n ;\n break;\n case 8:\n {\n this.outputSampleSize = 4;\n this.outputFormat = 'f32';\n this.writeOutputValue = (view, byteOffset, value) => view.setFloat32(byteOffset, value, true);\n }\n ;\n break;\n default:\n {\n assertNever(sampleSize);\n assert(false);\n }\n ;\n }\n ;\n }\n getDecodeQueueSize() {\n return 0;\n }\n decode(packet) {\n const inputView = toDataView(packet.data);\n const numberOfFrames = packet.byteLength / this.decoderConfig.numberOfChannels / this.inputSampleSize;\n const outputBufferSize = numberOfFrames * this.decoderConfig.numberOfChannels * this.outputSampleSize;\n const outputBuffer = new ArrayBuffer(outputBufferSize);\n const outputView = new DataView(outputBuffer);\n for (let i = 0; i < numberOfFrames * this.decoderConfig.numberOfChannels; i++) {\n const inputIndex = i * this.inputSampleSize;\n const outputIndex = i * this.outputSampleSize;\n const value = this.readInputValue(inputView, inputIndex);\n this.writeOutputValue(outputView, outputIndex, value);\n }\n const preciseDuration = numberOfFrames / this.decoderConfig.sampleRate;\n if (this.currentTimestamp === null || Math.abs(packet.timestamp - this.currentTimestamp) >= preciseDuration) {\n // We need to sync with the packet timestamp again\n this.currentTimestamp = packet.timestamp;\n }\n const preciseTimestamp = this.currentTimestamp;\n this.currentTimestamp += preciseDuration;\n const audioSample = new AudioSample({\n format: this.outputFormat,\n data: outputBuffer,\n numberOfChannels: this.decoderConfig.numberOfChannels,\n sampleRate: this.decoderConfig.sampleRate,\n numberOfFrames,\n timestamp: preciseTimestamp,\n });\n this.onSample(audioSample);\n }\n async flush() {\n // Do nothing\n }\n close() {\n // Do nothing\n }\n}\n/**\n * Sink for retrieving decoded audio samples from an audio track.\n * @group Media sinks\n * @public\n */\nexport class AudioSampleSink extends BaseMediaSampleSink {\n /** Creates a new {@link AudioSampleSink} for the given {@link InputAudioTrack}. */\n constructor(audioTrack) {\n if (!(audioTrack instanceof InputAudioTrack)) {\n throw new TypeError('audioTrack must be an InputAudioTrack.');\n }\n super();\n this._audioTrack = audioTrack;\n }\n /** @internal */\n async _createDecoder(onSample, onError) {\n if (!(await this._audioTrack.canDecode())) {\n throw new Error('This audio track cannot be decoded by this browser. Make sure to check decodability before using'\n + ' a track.');\n }\n const codec = this._audioTrack.codec;\n const decoderConfig = await this._audioTrack.getDecoderConfig();\n assert(codec && decoderConfig);\n if (PCM_AUDIO_CODECS.includes(decoderConfig.codec)) {\n return new PcmAudioDecoderWrapper(onSample, onError, decoderConfig);\n }\n else {\n return new AudioDecoderWrapper(onSample, onError, codec, decoderConfig);\n }\n }\n /** @internal */\n _createPacketSink() {\n return new EncodedPacketSink(this._audioTrack);\n }\n /**\n * Retrieves the audio sample corresponding to the given timestamp, in seconds. More specifically, returns\n * the last audio sample (in presentation order) with a start timestamp less than or equal to the given timestamp.\n * Returns null if the timestamp is before the track's first timestamp.\n *\n * @param timestamp - The timestamp used for retrieval, in seconds.\n */\n async getSample(timestamp) {\n validateTimestamp(timestamp);\n for await (const sample of this.mediaSamplesAtTimestamps([timestamp])) {\n return sample;\n }\n throw new Error('Internal error: Iterator returned nothing.');\n }\n /**\n * Creates an async iterator that yields the audio samples of this track in presentation order. This method\n * will intelligently pre-decode a few samples ahead to enable fast iteration.\n *\n * @param startTimestamp - The timestamp in seconds at which to start yielding samples (inclusive).\n * @param endTimestamp - The timestamp in seconds at which to stop yielding samples (exclusive).\n */\n samples(startTimestamp = 0, endTimestamp = Infinity) {\n return this.mediaSamplesInRange(startTimestamp, endTimestamp);\n }\n /**\n * Creates an async iterator that yields an audio sample for each timestamp in the argument. This method\n * uses an optimized decoding pipeline if these timestamps are monotonically sorted, decoding each packet at most\n * once, and is therefore more efficient than manually getting the sample for every timestamp. The iterator may\n * yield null if no sample is available for a given timestamp.\n *\n * @param timestamps - An iterable or async iterable of timestamps in seconds.\n */\n samplesAtTimestamps(timestamps) {\n return this.mediaSamplesAtTimestamps(timestamps);\n }\n}\n/**\n * A sink that retrieves decoded audio samples from an audio track and converts them to `AudioBuffer` instances. This is\n * often more useful than directly retrieving audio samples, as audio buffers can be directly used with the\n * Web Audio API.\n * @group Media sinks\n * @public\n */\nexport class AudioBufferSink {\n /** Creates a new {@link AudioBufferSink} for the given {@link InputAudioTrack}. */\n constructor(audioTrack) {\n if (!(audioTrack instanceof InputAudioTrack)) {\n throw new TypeError('audioTrack must be an InputAudioTrack.');\n }\n this._audioSampleSink = new AudioSampleSink(audioTrack);\n }\n /** @internal */\n _audioSampleToWrappedArrayBuffer(sample) {\n return {\n buffer: sample.toAudioBuffer(),\n timestamp: sample.timestamp,\n duration: sample.duration,\n };\n }\n /**\n * Retrieves the audio buffer corresponding to the given timestamp, in seconds. More specifically, returns\n * the last audio buffer (in presentation order) with a start timestamp less than or equal to the given timestamp.\n * Returns null if the timestamp is before the track's first timestamp.\n *\n * @param timestamp - The timestamp used for retrieval, in seconds.\n */\n async getBuffer(timestamp) {\n validateTimestamp(timestamp);\n const data = await this._audioSampleSink.getSample(timestamp);\n return data && this._audioSampleToWrappedArrayBuffer(data);\n }\n /**\n * Creates an async iterator that yields audio buffers of this track in presentation order. This method\n * will intelligently pre-decode a few buffers ahead to enable fast iteration.\n *\n * @param startTimestamp - The timestamp in seconds at which to start yielding buffers (inclusive).\n * @param endTimestamp - The timestamp in seconds at which to stop yielding buffers (exclusive).\n */\n buffers(startTimestamp = 0, endTimestamp = Infinity) {\n return mapAsyncGenerator(this._audioSampleSink.samples(startTimestamp, endTimestamp), data => this._audioSampleToWrappedArrayBuffer(data));\n }\n /**\n * Creates an async iterator that yields an audio buffer for each timestamp in the argument. This method\n * uses an optimized decoding pipeline if these timestamps are monotonically sorted, decoding each packet at most\n * once, and is therefore more efficient than manually getting the buffer for every timestamp. The iterator may\n * yield null if no buffer is available for a given timestamp.\n *\n * @param timestamps - An iterable or async iterable of timestamps in seconds.\n */\n buffersAtTimestamps(timestamps) {\n return mapAsyncGenerator(this._audioSampleSink.samplesAtTimestamps(timestamps), data => data && this._audioSampleToWrappedArrayBuffer(data));\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { determineVideoPacketType } from './codec-data.js';\nimport { customAudioDecoders, customVideoDecoders } from './custom-coder.js';\nimport { EncodedPacketSink } from './media-sink.js';\nimport { assert } from './misc.js';\nimport { EncodedPacket } from './packet.js';\n/**\n * Represents a media track in an input file.\n * @group Input files & tracks\n * @public\n */\nexport class InputTrack {\n /** @internal */\n constructor(backing) {\n this._backing = backing;\n }\n /** Returns true if and only if this track is a video track. */\n isVideoTrack() {\n return this instanceof InputVideoTrack;\n }\n /** Returns true if and only if this track is an audio track. */\n isAudioTrack() {\n return this instanceof InputAudioTrack;\n }\n /** The unique ID of this track in the input file. */\n get id() {\n return this._backing.getId();\n }\n /**\n * The identifier of the codec used internally by the container. It is not homogenized by Mediabunny\n * and depends entirely on the container format.\n *\n * This field can be used to determine the codec of a track in case Mediabunny doesn't know that codec.\n *\n * - For ISOBMFF files, this field returns the name of the Sample Description Box (e.g. `'avc1'`).\n * - For Matroska files, this field returns the value of the `CodecID` element.\n * - For WAVE files, this field returns the value of the format tag in the `'fmt '` chunk.\n * - For ADTS files, this field contains the `MPEG-4 Audio Object Type`.\n * - In all other cases, this field is `null`.\n */\n get internalCodecId() {\n return this._backing.getInternalCodecId();\n }\n /**\n * The ISO 639-2/T language code for this track. If the language is unknown, this field is `'und'` (undetermined).\n */\n get languageCode() {\n return this._backing.getLanguageCode();\n }\n /** A user-defined name for this track. */\n get name() {\n return this._backing.getName();\n }\n /**\n * A positive number x such that all timestamps and durations of all packets of this track are\n * integer multiples of 1/x.\n */\n get timeResolution() {\n return this._backing.getTimeResolution();\n }\n /**\n * Returns the start timestamp of the first packet of this track, in seconds. While often near zero, this value\n * may be positive or even negative. A negative starting timestamp means the track's timing has been offset. Samples\n * with a negative timestamp should not be presented.\n */\n getFirstTimestamp() {\n return this._backing.getFirstTimestamp();\n }\n /** Returns the end timestamp of the last packet of this track, in seconds. */\n computeDuration() {\n return this._backing.computeDuration();\n }\n /**\n * Computes aggregate packet statistics for this track, such as average packet rate or bitrate.\n *\n * @param targetPacketCount - This optional parameter sets a target for how many packets this method must have\n * looked at before it can return early; this means, you can use it to aggregate only a subset (prefix) of all\n * packets. This is very useful for getting a great estimate of video frame rate without having to scan through the\n * entire file.\n */\n async computePacketStats(targetPacketCount = Infinity) {\n const sink = new EncodedPacketSink(this);\n let startTimestamp = Infinity;\n let endTimestamp = -Infinity;\n let packetCount = 0;\n let totalPacketBytes = 0;\n for await (const packet of sink.packets(undefined, undefined, { metadataOnly: true })) {\n if (packetCount >= targetPacketCount\n // This additional condition is needed to produce correct results with out-of-presentation-order packets\n && packet.timestamp >= endTimestamp) {\n break;\n }\n startTimestamp = Math.min(startTimestamp, packet.timestamp);\n endTimestamp = Math.max(endTimestamp, packet.timestamp + packet.duration);\n packetCount++;\n totalPacketBytes += packet.byteLength;\n }\n return {\n packetCount,\n averagePacketRate: packetCount\n ? Number((packetCount / (endTimestamp - startTimestamp)).toPrecision(16))\n : 0,\n averageBitrate: packetCount\n ? Number((8 * totalPacketBytes / (endTimestamp - startTimestamp)).toPrecision(16))\n : 0,\n };\n }\n}\n/**\n * Represents a video track in an input file.\n * @group Input files & tracks\n * @public\n */\nexport class InputVideoTrack extends InputTrack {\n /** @internal */\n constructor(backing) {\n super(backing);\n this._backing = backing;\n }\n get type() {\n return 'video';\n }\n get codec() {\n return this._backing.getCodec();\n }\n /** The width in pixels of the track's coded samples, before any transformations or rotations. */\n get codedWidth() {\n return this._backing.getCodedWidth();\n }\n /** The height in pixels of the track's coded samples, before any transformations or rotations. */\n get codedHeight() {\n return this._backing.getCodedHeight();\n }\n /** The angle in degrees by which the track's frames should be rotated (clockwise). */\n get rotation() {\n return this._backing.getRotation();\n }\n /** The width in pixels of the track's frames after rotation. */\n get displayWidth() {\n const rotation = this._backing.getRotation();\n return rotation % 180 === 0 ? this._backing.getCodedWidth() : this._backing.getCodedHeight();\n }\n /** The height in pixels of the track's frames after rotation. */\n get displayHeight() {\n const rotation = this._backing.getRotation();\n return rotation % 180 === 0 ? this._backing.getCodedHeight() : this._backing.getCodedWidth();\n }\n /** Returns the color space of the track's samples. */\n getColorSpace() {\n return this._backing.getColorSpace();\n }\n /** If this method returns true, the track's samples use a high dynamic range (HDR). */\n async hasHighDynamicRange() {\n const colorSpace = await this._backing.getColorSpace();\n return colorSpace.primaries === 'bt2020' || colorSpace.primaries === 'smpte432'\n || colorSpace.transfer === 'pg' || colorSpace.transfer === 'hlg'\n || colorSpace.matrix === 'bt2020-ncl';\n }\n /**\n * Returns the [decoder configuration](https://www.w3.org/TR/webcodecs/#video-decoder-config) for decoding the\n * track's packets using a [`VideoDecoder`](https://developer.mozilla.org/en-US/docs/Web/API/VideoDecoder). Returns\n * null if the track's codec is unknown.\n */\n getDecoderConfig() {\n return this._backing.getDecoderConfig();\n }\n async getCodecParameterString() {\n const decoderConfig = await this._backing.getDecoderConfig();\n return decoderConfig?.codec ?? null;\n }\n async canDecode() {\n try {\n const decoderConfig = await this._backing.getDecoderConfig();\n if (!decoderConfig) {\n return false;\n }\n const codec = this._backing.getCodec();\n assert(codec !== null);\n if (customVideoDecoders.some(x => x.supports(codec, decoderConfig))) {\n return true;\n }\n if (typeof VideoDecoder === 'undefined') {\n return false;\n }\n const support = await VideoDecoder.isConfigSupported(decoderConfig);\n return support.supported === true;\n }\n catch (error) {\n console.error('Error during decodability check:', error);\n return false;\n }\n }\n async determinePacketType(packet) {\n if (!(packet instanceof EncodedPacket)) {\n throw new TypeError('packet must be an EncodedPacket.');\n }\n if (packet.isMetadataOnly) {\n throw new TypeError('packet must not be metadata-only to determine its type.');\n }\n if (this.codec === null) {\n return null;\n }\n return determineVideoPacketType(this, packet);\n }\n}\n/**\n * Represents an audio track in an input file.\n * @group Input files & tracks\n * @public\n */\nexport class InputAudioTrack extends InputTrack {\n /** @internal */\n constructor(backing) {\n super(backing);\n this._backing = backing;\n }\n get type() {\n return 'audio';\n }\n get codec() {\n return this._backing.getCodec();\n }\n /** The number of audio channels in the track. */\n get numberOfChannels() {\n return this._backing.getNumberOfChannels();\n }\n /** The track's audio sample rate in hertz. */\n get sampleRate() {\n return this._backing.getSampleRate();\n }\n /**\n * Returns the [decoder configuration](https://www.w3.org/TR/webcodecs/#audio-decoder-config) for decoding the\n * track's packets using an [`AudioDecoder`](https://developer.mozilla.org/en-US/docs/Web/API/AudioDecoder). Returns\n * null if the track's codec is unknown.\n */\n getDecoderConfig() {\n return this._backing.getDecoderConfig();\n }\n async getCodecParameterString() {\n const decoderConfig = await this._backing.getDecoderConfig();\n return decoderConfig?.codec ?? null;\n }\n async canDecode() {\n try {\n const decoderConfig = await this._backing.getDecoderConfig();\n if (!decoderConfig) {\n return false;\n }\n const codec = this._backing.getCodec();\n assert(codec !== null);\n if (customAudioDecoders.some(x => x.supports(codec, decoderConfig))) {\n return true;\n }\n if (decoderConfig.codec.startsWith('pcm-')) {\n return true; // Since we decode it ourselves\n }\n else {\n if (typeof AudioDecoder === 'undefined') {\n return false;\n }\n const support = await AudioDecoder.isConfigSupported(decoderConfig);\n return support.supported === true;\n }\n }\n catch (error) {\n console.error('Error during decodability check:', error);\n return false;\n }\n }\n async determinePacketType(packet) {\n if (!(packet instanceof EncodedPacket)) {\n throw new TypeError('packet must be an EncodedPacket.');\n }\n if (this.codec === null) {\n return null;\n }\n return 'key'; // No audio codec with delta packets\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { Demuxer } from '../demuxer.js';\nimport { InputAudioTrack } from '../input-track.js';\nimport { assert, UNDETERMINED_LANGUAGE } from '../misc.js';\nimport { EncodedPacket, PLACEHOLDER_DATA } from '../packet.js';\nimport { readAscii, readBytes, readU16, readU32, readU64 } from '../reader.js';\nexport var WaveFormat;\n(function (WaveFormat) {\n WaveFormat[WaveFormat[\"PCM\"] = 1] = \"PCM\";\n WaveFormat[WaveFormat[\"IEEE_FLOAT\"] = 3] = \"IEEE_FLOAT\";\n WaveFormat[WaveFormat[\"ALAW\"] = 6] = \"ALAW\";\n WaveFormat[WaveFormat[\"MULAW\"] = 7] = \"MULAW\";\n WaveFormat[WaveFormat[\"EXTENSIBLE\"] = 65534] = \"EXTENSIBLE\";\n})(WaveFormat || (WaveFormat = {}));\nexport class WaveDemuxer extends Demuxer {\n constructor(input) {\n super(input);\n this.metadataPromise = null;\n this.dataStart = -1;\n this.dataSize = -1;\n this.audioInfo = null;\n this.tracks = [];\n this.lastKnownPacketIndex = 0;\n this.metadataTags = {};\n this.reader = input._reader;\n }\n async readMetadata() {\n return this.metadataPromise ??= (async () => {\n let slice = this.reader.requestSlice(0, 12);\n if (slice instanceof Promise)\n slice = await slice;\n assert(slice);\n const riffType = readAscii(slice, 4);\n const littleEndian = riffType !== 'RIFX';\n const isRf64 = riffType === 'RF64';\n const outerChunkSize = readU32(slice, littleEndian);\n let totalFileSize = isRf64\n ? this.reader.fileSize\n : Math.min(outerChunkSize + 8, this.reader.fileSize ?? Infinity);\n const format = readAscii(slice, 4);\n if (format !== 'WAVE') {\n throw new Error('Invalid WAVE file - wrong format');\n }\n let chunksRead = 0;\n let dataChunkSize = null;\n let currentPos = slice.filePos;\n while (totalFileSize === null || currentPos < totalFileSize) {\n let slice = this.reader.requestSlice(currentPos, 8);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const chunkId = readAscii(slice, 4);\n const chunkSize = readU32(slice, littleEndian);\n const startPos = slice.filePos;\n if (isRf64 && chunksRead === 0 && chunkId !== 'ds64') {\n throw new Error('Invalid RF64 file: First chunk must be \"ds64\".');\n }\n if (chunkId === 'fmt ') {\n await this.parseFmtChunk(startPos, chunkSize, littleEndian);\n }\n else if (chunkId === 'data') {\n dataChunkSize ??= chunkSize;\n this.dataStart = slice.filePos;\n this.dataSize = Math.min(dataChunkSize, (totalFileSize ?? Infinity) - this.dataStart);\n if (this.reader.fileSize === null) {\n break; // Stop once we hit the data chunk\n }\n }\n else if (chunkId === 'ds64') {\n // File and data chunk sizes are defined in here instead\n const riffChunkSize = readU64(slice, littleEndian);\n dataChunkSize = readU64(slice, littleEndian);\n totalFileSize = Math.min(riffChunkSize + 8, this.reader.fileSize ?? Infinity);\n }\n else if (chunkId === 'LIST') {\n await this.parseListChunk(startPos, chunkSize, littleEndian);\n }\n currentPos = startPos + chunkSize + (chunkSize & 1); // Handle padding\n chunksRead++;\n }\n if (!this.audioInfo) {\n throw new Error('Invalid WAVE file - missing \"fmt \" chunk');\n }\n if (this.dataStart === -1) {\n throw new Error('Invalid WAVE file - missing \"data\" chunk');\n }\n const blockSize = this.audioInfo.blockSizeInBytes;\n this.dataSize = Math.floor(this.dataSize / blockSize) * blockSize;\n this.tracks.push(new InputAudioTrack(new WaveAudioTrackBacking(this)));\n })();\n }\n async parseFmtChunk(startPos, size, littleEndian) {\n let slice = this.reader.requestSlice(startPos, size);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return; // File too short\n let formatTag = readU16(slice, littleEndian);\n const numChannels = readU16(slice, littleEndian);\n const sampleRate = readU32(slice, littleEndian);\n slice.skip(4); // Bytes per second\n const blockAlign = readU16(slice, littleEndian);\n let bitsPerSample;\n if (size === 14) { // Plain WAVEFORMAT\n bitsPerSample = 8;\n }\n else {\n bitsPerSample = readU16(slice, littleEndian);\n }\n // Handle WAVEFORMATEXTENSIBLE\n if (size >= 18 && formatTag !== 0x0165) {\n const cbSize = readU16(slice, littleEndian);\n const remainingSize = size - 18;\n const extensionSize = Math.min(remainingSize, cbSize);\n if (extensionSize >= 22 && formatTag === WaveFormat.EXTENSIBLE) {\n // Parse WAVEFORMATEXTENSIBLE\n slice.skip(2 + 4);\n const subFormat = readBytes(slice, 16);\n // Get actual format from subFormat GUID\n formatTag = subFormat[0] | (subFormat[1] << 8);\n }\n }\n if (formatTag === WaveFormat.MULAW || formatTag === WaveFormat.ALAW) {\n bitsPerSample = 8;\n }\n this.audioInfo = {\n format: formatTag,\n numberOfChannels: numChannels,\n sampleRate,\n sampleSizeInBytes: Math.ceil(bitsPerSample / 8),\n blockSizeInBytes: blockAlign,\n };\n }\n async parseListChunk(startPos, size, littleEndian) {\n let slice = this.reader.requestSlice(startPos, size);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return; // File too short\n const infoType = readAscii(slice, 4);\n if (infoType !== 'INFO' && infoType !== 'INF0') { // exiftool.org claims INF0 can happen\n return; // Not an INFO chunk\n }\n let currentPos = slice.filePos;\n while (currentPos <= startPos + size - 8) {\n slice.filePos = currentPos;\n const chunkName = readAscii(slice, 4);\n const chunkSize = readU32(slice, littleEndian);\n const bytes = readBytes(slice, chunkSize);\n let stringLength = 0;\n for (let i = 0; i < bytes.length; i++) {\n if (bytes[i] === 0) {\n break;\n }\n stringLength++;\n }\n const value = String.fromCharCode(...bytes.subarray(0, stringLength));\n this.metadataTags.raw ??= {};\n this.metadataTags.raw[chunkName] = value;\n switch (chunkName) {\n case 'INAM':\n case 'TITL':\n {\n this.metadataTags.title ??= value;\n }\n ;\n break;\n case 'TIT3':\n {\n this.metadataTags.description ??= value;\n }\n ;\n break;\n case 'IART':\n {\n this.metadataTags.artist ??= value;\n }\n ;\n break;\n case 'IPRD':\n {\n this.metadataTags.album ??= value;\n }\n ;\n break;\n case 'IPRT':\n case 'ITRK':\n case 'TRCK':\n {\n const parts = value.split('/');\n const trackNum = Number.parseInt(parts[0], 10);\n const tracksTotal = parts[1] && Number.parseInt(parts[1], 10);\n if (Number.isInteger(trackNum) && trackNum > 0) {\n this.metadataTags.trackNumber ??= trackNum;\n }\n if (tracksTotal && Number.isInteger(tracksTotal) && tracksTotal > 0) {\n this.metadataTags.tracksTotal ??= tracksTotal;\n }\n }\n ;\n break;\n case 'ICRD':\n case 'IDIT':\n {\n const date = new Date(value);\n if (!Number.isNaN(date.getTime())) {\n this.metadataTags.date ??= date;\n }\n }\n ;\n break;\n case 'YEAR':\n {\n const year = Number.parseInt(value, 10);\n if (Number.isInteger(year) && year > 0) {\n this.metadataTags.date ??= new Date(year, 0, 1);\n }\n }\n ;\n break;\n case 'IGNR':\n case 'GENR':\n {\n this.metadataTags.genre ??= value;\n }\n ;\n break;\n case 'ICMT':\n case 'CMNT':\n case 'COMM':\n {\n this.metadataTags.comment ??= value;\n }\n ;\n break;\n }\n currentPos += 8 + chunkSize + (chunkSize & 1); // Handle padding\n }\n }\n getCodec() {\n assert(this.audioInfo);\n if (this.audioInfo.format === WaveFormat.MULAW) {\n return 'ulaw';\n }\n if (this.audioInfo.format === WaveFormat.ALAW) {\n return 'alaw';\n }\n if (this.audioInfo.format === WaveFormat.PCM) {\n // All formats are little-endian\n if (this.audioInfo.sampleSizeInBytes === 1) {\n return 'pcm-u8';\n }\n else if (this.audioInfo.sampleSizeInBytes === 2) {\n return 'pcm-s16';\n }\n else if (this.audioInfo.sampleSizeInBytes === 3) {\n return 'pcm-s24';\n }\n else if (this.audioInfo.sampleSizeInBytes === 4) {\n return 'pcm-s32';\n }\n }\n if (this.audioInfo.format === WaveFormat.IEEE_FLOAT) {\n if (this.audioInfo.sampleSizeInBytes === 4) {\n return 'pcm-f32';\n }\n }\n return null;\n }\n async getMimeType() {\n return 'audio/wav';\n }\n async computeDuration() {\n await this.readMetadata();\n const track = this.tracks[0];\n assert(track);\n return track.computeDuration();\n }\n async getTracks() {\n await this.readMetadata();\n return this.tracks;\n }\n async getMetadataTags() {\n await this.readMetadata();\n return this.metadataTags;\n }\n}\nconst PACKET_SIZE_IN_FRAMES = 2048;\nclass WaveAudioTrackBacking {\n constructor(demuxer) {\n this.demuxer = demuxer;\n }\n getId() {\n return 1;\n }\n getCodec() {\n return this.demuxer.getCodec();\n }\n getInternalCodecId() {\n assert(this.demuxer.audioInfo);\n return this.demuxer.audioInfo.format;\n }\n async getDecoderConfig() {\n const codec = this.demuxer.getCodec();\n if (!codec) {\n return null;\n }\n assert(this.demuxer.audioInfo);\n return {\n codec,\n numberOfChannels: this.demuxer.audioInfo.numberOfChannels,\n sampleRate: this.demuxer.audioInfo.sampleRate,\n };\n }\n async computeDuration() {\n const lastPacket = await this.getPacket(Infinity, { metadataOnly: true });\n return (lastPacket?.timestamp ?? 0) + (lastPacket?.duration ?? 0);\n }\n getNumberOfChannels() {\n assert(this.demuxer.audioInfo);\n return this.demuxer.audioInfo.numberOfChannels;\n }\n getSampleRate() {\n assert(this.demuxer.audioInfo);\n return this.demuxer.audioInfo.sampleRate;\n }\n getTimeResolution() {\n assert(this.demuxer.audioInfo);\n return this.demuxer.audioInfo.sampleRate;\n }\n getName() {\n return null;\n }\n getLanguageCode() {\n return UNDETERMINED_LANGUAGE;\n }\n async getFirstTimestamp() {\n return 0;\n }\n async getPacketAtIndex(packetIndex, options) {\n assert(this.demuxer.audioInfo);\n const startOffset = packetIndex * PACKET_SIZE_IN_FRAMES * this.demuxer.audioInfo.blockSizeInBytes;\n if (startOffset >= this.demuxer.dataSize) {\n return null;\n }\n const sizeInBytes = Math.min(PACKET_SIZE_IN_FRAMES * this.demuxer.audioInfo.blockSizeInBytes, this.demuxer.dataSize - startOffset);\n if (this.demuxer.reader.fileSize === null) {\n // If the file size is unknown, we weren't able to cap the dataSize in the init logic and we instead have to\n // rely on the headers telling us how large the file is. But, these might be wrong, so let's check if the\n // requested slice actually exists.\n let slice = this.demuxer.reader.requestSlice(this.demuxer.dataStart + startOffset, sizeInBytes);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice) {\n return null;\n }\n }\n let data;\n if (options.metadataOnly) {\n data = PLACEHOLDER_DATA;\n }\n else {\n let slice = this.demuxer.reader.requestSlice(this.demuxer.dataStart + startOffset, sizeInBytes);\n if (slice instanceof Promise)\n slice = await slice;\n assert(slice);\n data = readBytes(slice, sizeInBytes);\n }\n const timestamp = packetIndex * PACKET_SIZE_IN_FRAMES / this.demuxer.audioInfo.sampleRate;\n const duration = sizeInBytes / this.demuxer.audioInfo.blockSizeInBytes / this.demuxer.audioInfo.sampleRate;\n this.demuxer.lastKnownPacketIndex = Math.max(packetIndex, timestamp);\n return new EncodedPacket(data, 'key', timestamp, duration, packetIndex, sizeInBytes);\n }\n getFirstPacket(options) {\n return this.getPacketAtIndex(0, options);\n }\n async getPacket(timestamp, options) {\n assert(this.demuxer.audioInfo);\n const packetIndex = Math.floor(Math.min(timestamp * this.demuxer.audioInfo.sampleRate / PACKET_SIZE_IN_FRAMES, (this.demuxer.dataSize - 1) / (PACKET_SIZE_IN_FRAMES * this.demuxer.audioInfo.blockSizeInBytes)));\n const packet = await this.getPacketAtIndex(packetIndex, options);\n if (packet) {\n return packet;\n }\n if (packetIndex === 0) {\n return null; // Empty data chunk\n }\n assert(this.demuxer.reader.fileSize === null);\n // The file is shorter than we thought, meaning the packet we were looking for doesn't exist. So, let's find\n // the last packet by doing a sequential scan, instead.\n let currentPacket = await this.getPacketAtIndex(this.demuxer.lastKnownPacketIndex, options);\n while (currentPacket) {\n const nextPacket = await this.getNextPacket(currentPacket, options);\n if (!nextPacket) {\n break;\n }\n currentPacket = nextPacket;\n }\n return currentPacket;\n }\n getNextPacket(packet, options) {\n assert(this.demuxer.audioInfo);\n const packetIndex = Math.round(packet.timestamp * this.demuxer.audioInfo.sampleRate / PACKET_SIZE_IN_FRAMES);\n return this.getPacketAtIndex(packetIndex + 1, options);\n }\n getKeyPacket(timestamp, options) {\n return this.getPacket(timestamp, options);\n }\n getNextKeyPacket(packet, options) {\n return this.getNextPacket(packet, options);\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { assert, binarySearchLessOrEqual, closedIntervalsOverlap, mergeObjectsDeeply, promiseWithResolvers, retriedFetch, toDataView, toUint8Array, } from './misc.js';\n/**\n * The source base class, representing a resource from which bytes can be read.\n * @group Input sources\n * @public\n */\nexport class Source {\n constructor() {\n /** @internal */\n this._sizePromise = null;\n /** Called each time data is retrieved from the source. Will be called with the retrieved range (end exclusive). */\n this.onread = null;\n }\n /**\n * Resolves with the total size of the file in bytes. This function is memoized, meaning only the first call\n * will retrieve the size.\n *\n * Returns null if the source is unsized.\n */\n async getSizeOrNull() {\n return this._sizePromise ??= Promise.resolve(this._retrieveSize());\n }\n /**\n * Resolves with the total size of the file in bytes. This function is memoized, meaning only the first call\n * will retrieve the size.\n *\n * Throws an error if the source is unsized.\n */\n async getSize() {\n const result = await this.getSizeOrNull();\n if (result === null) {\n throw new Error('Cannot determine the size of an unsized source.');\n }\n return result;\n }\n}\n/**\n * A source backed by an ArrayBuffer or ArrayBufferView, with the entire file held in memory.\n * @group Input sources\n * @public\n */\nexport class BufferSource extends Source {\n /** Creates a new {@link BufferSource} backed the specified `ArrayBuffer` or `ArrayBufferView`. */\n constructor(buffer) {\n if (!(buffer instanceof ArrayBuffer) && !ArrayBuffer.isView(buffer)) {\n throw new TypeError('buffer must be an ArrayBuffer or ArrayBufferView.');\n }\n super();\n /** @internal */\n this._onreadCalled = false;\n this._bytes = toUint8Array(buffer);\n this._view = toDataView(buffer);\n }\n /** @internal */\n _retrieveSize() {\n return this._bytes.byteLength;\n }\n /** @internal */\n _read() {\n if (!this._onreadCalled) {\n // We just say the first read retrives all bytes from the source (which, I mean, it does)\n this.onread?.(0, this._bytes.byteLength);\n this._onreadCalled = true;\n }\n return {\n bytes: this._bytes,\n view: this._view,\n offset: 0,\n };\n }\n /** @internal */\n get _supportsRandomAccess() {\n return true;\n }\n}\n/**\n * A source backed by a [`Blob`](https://developer.mozilla.org/en-US/docs/Web/API/Blob). Since a\n * [`File`](https://developer.mozilla.org/en-US/docs/Web/API/File) is also a `Blob`, this is the source to use when\n * reading files off the disk.\n * @group Input sources\n * @public\n */\nexport class BlobSource extends Source {\n /**\n * Creates a new {@link BlobSource} backed by the specified\n * [`Blob`](https://developer.mozilla.org/en-US/docs/Web/API/Blob).\n */\n constructor(blob, options = {}) {\n if (!(blob instanceof Blob)) {\n throw new TypeError('blob must be a Blob.');\n }\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (options.maxCacheSize !== undefined\n && (!Number.isInteger(options.maxCacheSize) || options.maxCacheSize < 0)) {\n throw new TypeError('options.maxCacheSize, when provided, must be a non-negative integer.');\n }\n super();\n /** @internal */\n this._readers = new WeakMap();\n this._blob = blob;\n this._orchestrator = new ReadOrchestrator({\n maxCacheSize: options.maxCacheSize ?? (8 * 2 ** 20 /* 8 MiB */),\n maxWorkerCount: 4,\n runWorker: this._runWorker.bind(this),\n prefetchProfile: PREFETCH_PROFILES.fileSystem,\n });\n }\n /** @internal */\n _retrieveSize() {\n const size = this._blob.size;\n this._orchestrator.fileSize = size;\n return size;\n }\n /** @internal */\n _read(start, end) {\n return this._orchestrator.read(start, end);\n }\n /** @internal */\n async _runWorker(worker) {\n let reader = this._readers.get(worker);\n if (!reader) {\n // Get a reader of the blob starting at the required offset, and then keep it around\n reader = this._blob.slice(worker.currentPos).stream().getReader();\n this._readers.set(worker, reader);\n }\n while (worker.currentPos < worker.targetPos && !worker.aborted) {\n const { done, value } = await reader.read();\n if (done) {\n this._orchestrator.forgetWorker(worker);\n if (worker.currentPos < worker.targetPos) { // I think this `if` should always hit?\n throw new Error('Blob reader stopped unexpectedly before all requested data was read.');\n }\n break;\n }\n this.onread?.(worker.currentPos, worker.currentPos + value.length);\n this._orchestrator.supplyWorkerData(worker, value);\n }\n worker.running = false;\n }\n /** @internal */\n get _supportsRandomAccess() {\n return true;\n }\n}\nconst URL_SOURCE_MIN_LOAD_AMOUNT = 0.5 * 2 ** 20; // 0.5 MiB\n/**\n * A source backed by a URL. This is useful for reading data from the network. Requests will be made using an optimized\n * reading and prefetching pattern to minimize request count and latency.\n * @group Input sources\n * @public\n */\nexport class UrlSource extends Source {\n /** Creates a new {@link UrlSource} backed by the resource at the specified URL. */\n constructor(url, options = {}) {\n if (typeof url !== 'string' && !(url instanceof URL)) {\n throw new TypeError('url must be a string or URL.');\n }\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (options.requestInit !== undefined && (!options.requestInit || typeof options.requestInit !== 'object')) {\n throw new TypeError('options.requestInit, when provided, must be an object.');\n }\n if (options.getRetryDelay !== undefined && typeof options.getRetryDelay !== 'function') {\n throw new TypeError('options.getRetryDelay, when provided, must be a function.');\n }\n if (options.maxCacheSize !== undefined\n && (!Number.isInteger(options.maxCacheSize) || options.maxCacheSize < 0)) {\n throw new TypeError('options.maxCacheSize, when provided, must be a non-negative integer.');\n }\n super();\n /** @internal */\n this._existingResponses = new WeakMap();\n this._url = url instanceof URL\n ? url\n : new URL(url, typeof location !== 'undefined' ? location.href : undefined);\n this._options = options;\n this._getRetryDelay = options.getRetryDelay ?? (previousAttempts => Math.min(2 ** (previousAttempts - 2), 8));\n this._orchestrator = new ReadOrchestrator({\n maxCacheSize: options.maxCacheSize ?? (64 * 2 ** 20 /* 64 MiB */),\n // Most files in the real-world have a single sequential access pattern, but having two in parallel can\n // also happen\n maxWorkerCount: 2,\n runWorker: this._runWorker.bind(this),\n prefetchProfile: PREFETCH_PROFILES.network,\n });\n }\n /** @internal */\n async _retrieveSize() {\n // Retrieving the resource size for UrlSource is optimized: Almost always (= always), the first bytes we have to\n // read are the start of the file. This means it's smart to combine size fetching with fetching the start of the\n // file. We additionally use this step to probe if the server supports range requests, killing three birds with\n // one stone.\n const abortController = new AbortController();\n const response = await retriedFetch(this._url, mergeObjectsDeeply(this._options.requestInit ?? {}, {\n headers: {\n // We could also send a non-range request to request the same bytes (all of them), but doing it like\n // this is an easy way to check if the server supports range requests in the first place\n Range: 'bytes=0-',\n },\n signal: abortController.signal,\n }), this._getRetryDelay);\n if (!response.ok) {\n throw new Error(`Error fetching ${this._url}: ${response.status} ${response.statusText}`);\n }\n let worker;\n let fileSize;\n if (response.status === 206) {\n fileSize = this._getPartialLengthFromRangeResponse(response);\n worker = this._orchestrator.createWorker(0, Math.min(fileSize, URL_SOURCE_MIN_LOAD_AMOUNT));\n }\n else {\n // Server probably returned a 200.\n const contentLength = response.headers.get('Content-Length');\n if (contentLength) {\n fileSize = Number(contentLength);\n worker = this._orchestrator.createWorker(0, fileSize);\n this._orchestrator.options.maxCacheSize = Infinity; // \uD83E\uDD37\n console.warn('HTTP server did not respond with 206 Partial Content, meaning the entire remote resource now has'\n + ' to be downloaded. For efficient media file streaming across a network, please make sure your'\n + ' server supports range requests.');\n }\n else {\n throw new Error(`HTTP response (status ${response.status}) must surface Content-Length header.`);\n }\n }\n this._orchestrator.fileSize = fileSize;\n this._existingResponses.set(worker, { response, abortController });\n this._orchestrator.runWorker(worker);\n return fileSize;\n }\n /** @internal */\n _read(start, end) {\n return this._orchestrator.read(start, end);\n }\n /** @internal */\n async _runWorker(worker) {\n // The outer loop is for resuming a request if it dies mid-response\n while (!worker.aborted) {\n const existing = this._existingResponses.get(worker);\n this._existingResponses.delete(worker);\n let abortController = existing?.abortController;\n let response = existing?.response;\n if (!abortController) {\n abortController = new AbortController();\n response = await retriedFetch(this._url, mergeObjectsDeeply(this._options.requestInit ?? {}, {\n headers: {\n Range: `bytes=${worker.currentPos}-`,\n },\n signal: abortController.signal,\n }), this._getRetryDelay);\n }\n assert(response);\n if (!response.ok) {\n throw new Error(`Error fetching ${this._url}: ${response.status} ${response.statusText}`);\n }\n if (worker.currentPos > 0 && response.status !== 206) {\n throw new Error('HTTP server did not respond with 206 Partial Content to a range request. To enable efficient media'\n + ' file streaming across a network, please make sure your server supports range requests.');\n }\n const length = this._getPartialLengthFromRangeResponse(response);\n const required = worker.targetPos - worker.currentPos;\n if (length < required) {\n throw new Error(`HTTP response unexpectedly too short: Needed at least ${required} bytes, got only ${length}.`);\n }\n if (!response.body) {\n throw new Error('Missing HTTP response body.');\n }\n const reader = response.body.getReader();\n while (true) {\n let readResult;\n try {\n readResult = await reader.read();\n }\n catch (error) {\n const retryDelayInSeconds = this._getRetryDelay(1);\n if (retryDelayInSeconds !== null) {\n console.error('Error while reading response stream. Attempting to resume.', error);\n await new Promise(resolve => setTimeout(resolve, 1000 * retryDelayInSeconds));\n break;\n }\n else {\n throw error;\n }\n }\n const { done, value } = readResult;\n if (done) {\n this._orchestrator.forgetWorker(worker);\n if (worker.currentPos < worker.targetPos) {\n throw new Error('Response stream reader stopped unexpectedly before all requested data was read.');\n }\n worker.running = false;\n return;\n }\n this.onread?.(worker.currentPos, worker.currentPos + value.length);\n this._orchestrator.supplyWorkerData(worker, value);\n if (worker.currentPos >= worker.targetPos || worker.aborted) {\n abortController.abort();\n worker.running = false;\n return;\n }\n }\n }\n worker.running = false;\n // The previous UrlSource had logic for circumventing https://issues.chromium.org/issues/436025873; I haven't\n // been able to observe this bug with the new UrlSource (maybe because we're using response streaming), so the\n // logic for that has vanished for now. Leaving a comment here if this becomes relevant again.\n }\n /** @internal */\n _getPartialLengthFromRangeResponse(response) {\n const contentRange = response.headers.get('Content-Range');\n if (contentRange) {\n const match = /\\/(\\d+)/.exec(contentRange);\n if (match) {\n return Number(match[1]);\n }\n else {\n throw new Error(`Invalid Content-Range header: ${contentRange}`);\n }\n }\n else {\n const contentLength = response.headers.get('Content-Length');\n if (contentLength) {\n return Number(contentLength);\n }\n else {\n throw new Error('Partial HTTP response (status 206) must surface either Content-Range or'\n + ' Content-Length header.');\n }\n }\n }\n /** @internal */\n get _supportsRandomAccess() {\n return true;\n }\n}\n/**\n * A source backed by a path to a file. Intended for server-side usage in Node, Bun, or Deno.\n * @group Input sources\n * @public\n */\nexport class FilePathSource extends Source {\n /** Creates a new {@link FilePathSource} backed by the file at the specified file path. */\n constructor(filePath, options = {}) {\n if (typeof filePath !== 'string') {\n throw new TypeError('filePath must be a string.');\n }\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (options.maxCacheSize !== undefined\n && (!Number.isInteger(options.maxCacheSize) || options.maxCacheSize < 0)) {\n throw new TypeError('options.maxCacheSize, when provided, must be a non-negative integer.');\n }\n super();\n let fileHandle = null;\n // Let's back this source with a StreamSource, makes the implementation very simple\n this._streamSource = new StreamSource({\n getSize: async () => {\n const FS_MODULE_NAME = 'node:fs/promises';\n const fs = await import(/* @vite-ignore */ FS_MODULE_NAME);\n fileHandle = await fs.open(filePath, 'r');\n const stats = await fileHandle.stat();\n return stats.size;\n },\n read: async (start, end) => {\n assert(fileHandle);\n const buffer = Buffer.alloc(end - start);\n await fileHandle.read(buffer, 0, end - start, start);\n return buffer;\n },\n maxCacheSize: options.maxCacheSize,\n prefetchProfile: 'fileSystem',\n });\n }\n /** @internal */\n _read(start, end) {\n return this._streamSource._read(start, end);\n }\n /** @internal */\n _retrieveSize() {\n return this._streamSource._retrieveSize();\n }\n /** @internal */\n get _supportsRandomAccess() {\n return true;\n }\n}\n/**\n * A general-purpose, callback-driven source that can get its data from anywhere.\n * @group Input sources\n * @public\n */\nexport class StreamSource extends Source {\n /** Creates a new {@link StreamSource} whose behavior is specified by `options`. */\n constructor(options) {\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (typeof options.read !== 'function') {\n throw new TypeError('options.read must be a function.');\n }\n if (typeof options.getSize !== 'function') {\n throw new TypeError('options.getSize must be a function.');\n }\n if (options.maxCacheSize !== undefined\n && (!Number.isInteger(options.maxCacheSize) || options.maxCacheSize < 0)) {\n throw new TypeError('options.maxCacheSize, when provided, must be a non-negative integer.');\n }\n if (options.prefetchProfile && !['none', 'fileSystem', 'network'].includes(options.prefetchProfile)) {\n throw new TypeError('options.prefetchProfile, when provided, must be one of \\'none\\', \\'fileSystem\\' or \\'network\\'.');\n }\n super();\n this._options = options;\n this._orchestrator = new ReadOrchestrator({\n maxCacheSize: options.maxCacheSize ?? (8 * 2 ** 20 /* 8 MiB */),\n maxWorkerCount: 2, // Fixed for now, *should* be fine\n prefetchProfile: PREFETCH_PROFILES[options.prefetchProfile ?? 'none'],\n runWorker: this._runWorker.bind(this),\n });\n }\n /** @internal */\n _retrieveSize() {\n const result = this._options.getSize();\n if (result instanceof Promise) {\n return result.then((size) => {\n if (!Number.isInteger(size) || size < 0) {\n throw new TypeError('options.getSize must return or resolve to a non-negative integer.');\n }\n this._orchestrator.fileSize = size;\n return size;\n });\n }\n else {\n if (!Number.isInteger(result) || result < 0) {\n throw new TypeError('options.getSize must return or resolve to a non-negative integer.');\n }\n this._orchestrator.fileSize = result;\n return result;\n }\n }\n /** @internal */\n _read(start, end) {\n return this._orchestrator.read(start, end);\n }\n /** @internal */\n async _runWorker(worker) {\n while (worker.currentPos < worker.targetPos && !worker.aborted) {\n const originalCurrentPos = worker.currentPos;\n const originalTargetPos = worker.targetPos;\n let data = this._options.read(worker.currentPos, originalTargetPos);\n if (data instanceof Promise)\n data = await data;\n if (data instanceof Uint8Array) {\n if (data.length !== originalTargetPos - worker.currentPos) {\n // Yes, we're that strict\n throw new Error(`options.read returned a Uint8Array with unexpected length: Requested ${originalTargetPos - worker.currentPos} bytes, but got ${data.length}.`);\n }\n this.onread?.(worker.currentPos, worker.currentPos + data.length);\n this._orchestrator.supplyWorkerData(worker, data);\n }\n else if (data instanceof ReadableStream) {\n const reader = data.getReader();\n while (true) {\n const { done, value } = await reader.read();\n if (done) {\n if (worker.currentPos < originalTargetPos) {\n // Yes, we're *that* strict\n throw new Error(`ReadableStream returned by options.read ended before supplying enough data.`\n + ` Requested ${originalTargetPos - originalCurrentPos} bytes, but got ${worker.currentPos - originalCurrentPos}`);\n }\n break;\n }\n if (!(value instanceof Uint8Array)) {\n throw new TypeError('ReadableStream returned by options.read must yield Uint8Array chunks.');\n }\n this.onread?.(worker.currentPos, worker.currentPos + value.length);\n this._orchestrator.supplyWorkerData(worker, value);\n if (worker.currentPos >= originalTargetPos || worker.aborted) {\n break;\n }\n }\n }\n else {\n throw new TypeError('options.read must return or resolve to a Uint8Array or a ReadableStream.');\n }\n }\n worker.running = false;\n }\n /** @internal */\n get _supportsRandomAccess() {\n return true;\n }\n}\n/**\n * A source backed by a [`ReadableStream`](https://developer.mozilla.org/en-US/docs/Web/API/ReadableStream) of\n * `Uint8Array`, representing an append-only byte stream of unknown length. This is the source to use for incrementally\n * streaming in input files that are still being constructed and whose size we don't yet know, like for example the\n * output chunks of [MediaRecorder](https://developer.mozilla.org/en-US/docs/Web/API/MediaRecorder).\n *\n * This source is *unsized*, meaning calls to `.getSize()` will throw and readers are more limited due to the\n * lack of random file access. You should only use this source with sequential access patterns, such as reading all\n * packets from start to end. This source does not work well with random access patterns unless you increase its\n * max cache size.\n *\n * @group Input sources\n * @public\n */\nexport class ReadableStreamSource extends Source {\n /** Creates a new {@link ReadableStreamSource} backed by the specified `ReadableStream<Uint8Array>`. */\n constructor(stream, options = {}) {\n if (!(stream instanceof ReadableStream)) {\n throw new TypeError('stream must be a ReadableStream.');\n }\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (options.maxCacheSize !== undefined\n && (!Number.isInteger(options.maxCacheSize) || options.maxCacheSize < 0)) {\n throw new TypeError('options.maxCacheSize, when provided, must be a non-negative integer.');\n }\n super();\n /** @internal */\n this._reader = null;\n /** @internal */\n this._cache = [];\n /** @internal */\n this._pendingSlices = [];\n /** @internal */\n this._currentIndex = 0;\n /** @internal */\n this._targetIndex = 0;\n /** @internal */\n this._maxRequestedIndex = 0;\n /** @internal */\n this._endIndex = null;\n /** @internal */\n this._pulling = false;\n this._stream = stream;\n this._maxCacheSize = options.maxCacheSize ?? (16 * 2 ** 20 /* 16 MiB */);\n }\n /** @internal */\n _retrieveSize() {\n return this._endIndex; // Starts out as null, meaning this source is unsized\n }\n /** @internal */\n _read(start, end) {\n if (this._endIndex !== null && end > this._endIndex) {\n return null;\n }\n this._maxRequestedIndex = Math.max(this._maxRequestedIndex, end);\n const cacheStartIndex = binarySearchLessOrEqual(this._cache, start, x => x.start);\n const cacheStartEntry = cacheStartIndex !== -1 ? this._cache[cacheStartIndex] : null;\n if (cacheStartEntry && cacheStartEntry.start <= start && end <= cacheStartEntry.end) {\n // The request can be satisfied with a single cache entry\n return {\n bytes: cacheStartEntry.bytes,\n view: cacheStartEntry.view,\n offset: cacheStartEntry.start,\n };\n }\n let lastEnd = start;\n const bytes = new Uint8Array(end - start);\n if (cacheStartIndex !== -1) {\n // Walk over the cache to see if we can satisfy the request using multiple cache entries\n for (let i = cacheStartIndex; i < this._cache.length; i++) {\n const cacheEntry = this._cache[i];\n if (cacheEntry.start >= end) {\n break;\n }\n const cappedStart = Math.max(start, cacheEntry.start);\n if (cappedStart > lastEnd) {\n // We're too far behind\n this._throwDueToCacheMiss();\n }\n const cappedEnd = Math.min(end, cacheEntry.end);\n if (cappedStart < cappedEnd) {\n bytes.set(cacheEntry.bytes.subarray(cappedStart - cacheEntry.start, cappedEnd - cacheEntry.start), cappedStart - start);\n lastEnd = cappedEnd;\n }\n }\n }\n if (lastEnd === end) {\n return {\n bytes,\n view: toDataView(bytes),\n offset: start,\n };\n }\n // We need to pull more data\n if (this._currentIndex > lastEnd) {\n // We're too far behind\n this._throwDueToCacheMiss();\n }\n const { promise, resolve, reject } = promiseWithResolvers();\n this._pendingSlices.push({\n start,\n end,\n bytes,\n resolve,\n reject,\n });\n this._targetIndex = Math.max(this._targetIndex, end);\n // Start pulling from the stream if we're not already doing it\n if (!this._pulling) {\n this._pulling = true;\n void this._pull()\n .catch((error) => {\n this._pulling = false;\n if (this._pendingSlices.length > 0) {\n this._pendingSlices.forEach(x => x.reject(error)); // Make sure to propagate any errors\n this._pendingSlices.length = 0;\n }\n else {\n throw error; // So it doesn't get swallowed\n }\n });\n }\n return promise;\n }\n /** @internal */\n _throwDueToCacheMiss() {\n throw new Error('Read is before the cached region. With ReadableStreamSource, you must access the data more'\n + ' sequentially or increase the size of its cache.');\n }\n /** @internal */\n async _pull() {\n this._reader ??= this._stream.getReader();\n // This is the loop that keeps pulling data from the stream until a target index is reached, filling requests\n // in the process\n while (this._currentIndex < this._targetIndex) {\n const { done, value } = await this._reader.read();\n if (done) {\n for (const pendingSlice of this._pendingSlices) {\n pendingSlice.resolve(null);\n }\n this._pendingSlices.length = 0;\n this._endIndex = this._currentIndex; // We know how long the file is now!\n break;\n }\n const startIndex = this._currentIndex;\n const endIndex = this._currentIndex + value.byteLength;\n // Fill the pending slices with the data\n for (let i = 0; i < this._pendingSlices.length; i++) {\n const pendingSlice = this._pendingSlices[i];\n const cappedStart = Math.max(startIndex, pendingSlice.start);\n const cappedEnd = Math.min(endIndex, pendingSlice.end);\n if (cappedStart < cappedEnd) {\n pendingSlice.bytes.set(value.subarray(cappedStart - startIndex, cappedEnd - startIndex), cappedStart - pendingSlice.start);\n if (cappedEnd === pendingSlice.end) {\n // Pending slice fully filled\n pendingSlice.resolve({\n bytes: pendingSlice.bytes,\n view: toDataView(pendingSlice.bytes),\n offset: pendingSlice.start,\n });\n this._pendingSlices.splice(i, 1);\n i--;\n }\n }\n }\n this._cache.push({\n start: startIndex,\n end: endIndex,\n bytes: value,\n view: toDataView(value),\n age: 0, // Unused\n });\n // Do cache eviction, based on the distance from the last-requested index. It's important that we do it like\n // this and not based on where the reader is at, because if the reader is fast, we'll unnecessarily evict\n // data that we still might need.\n while (this._cache.length > 0) {\n const firstEntry = this._cache[0];\n const distance = this._maxRequestedIndex - firstEntry.end;\n if (distance <= this._maxCacheSize) {\n break;\n }\n this._cache.shift();\n }\n this._currentIndex += value.byteLength;\n }\n this._pulling = false;\n }\n /** @internal */\n get _supportsRandomAccess() {\n return false;\n }\n}\nconst PREFETCH_PROFILES = {\n none: (start, end) => ({ start, end }),\n fileSystem: (start, end) => {\n const padding = 2 ** 16;\n start = Math.floor((start - padding) / padding) * padding;\n end = Math.ceil((end + padding) / padding) * padding;\n return { start, end };\n },\n network: (start, end, workers) => {\n // Add a slight bit of start padding because backwards reading is painful\n const paddingStart = 2 ** 16;\n start = Math.max(0, Math.floor((start - paddingStart) / paddingStart) * paddingStart);\n // Remote resources have extreme latency (relatively speaking), so the benefit from intelligent\n // prefetching is great. The network prefetch strategy is as follows: When we notice\n // successive reads to a worker's read region, we prefetch more data at the end of that region,\n // growing exponentially (up to a cap). This performs well for real-world use cases: Either we read a\n // small part of the file once and then never need it again, in which case the requested about of data\n // is small. Or, we're repeatedly doing a sequential access pattern (common in media files), in which\n // case we can become more and more confident to prefetch more and more data.\n for (const worker of workers) {\n const maxExtensionAmount = 8 * 2 ** 20; // 8 MiB\n // When the read region cross the threshold point, we trigger a prefetch. This point is typically\n // in the middle of the worker's read region, or a fixed offset from the end if the region has grown\n // really large.\n const thresholdPoint = Math.max((worker.startPos + worker.targetPos) / 2, worker.targetPos - maxExtensionAmount);\n if (closedIntervalsOverlap(start, end, thresholdPoint, worker.targetPos)) {\n const size = worker.targetPos - worker.startPos;\n // If we extend by maxExtensionAmount\n const a = Math.ceil((size + 1) / maxExtensionAmount) * maxExtensionAmount;\n // If we extend to the next power of 2\n const b = 2 ** Math.ceil(Math.log2(size + 1));\n const extent = Math.min(b, a);\n end = Math.max(end, worker.startPos + extent);\n }\n }\n end = Math.max(end, start + URL_SOURCE_MIN_LOAD_AMOUNT);\n return {\n start,\n end,\n };\n },\n};\n/**\n * Godclass for orchestrating complex, cached read operations. The reading model is as follows: Any reading task is\n * delegated to a *worker*, which is a sequential reader positioned somewhere along the file. All workers run in\n * parallel and can be stopped and resumed in their forward movement. When read requests come in, this orchestrator will\n * first try to satisfy the request with only the cached data. If this isn't possible, workers are spun up for all\n * missing parts (or existing workers are repurposed), and these workers will then fill the holes in the data as they\n * march along the file.\n */\nclass ReadOrchestrator {\n constructor(options) {\n this.options = options;\n this.fileSize = null;\n this.nextAge = 0; // Used for LRU eviction of both cache entries and workers\n this.workers = [];\n this.cache = [];\n this.currentCacheSize = 0;\n }\n read(innerStart, innerEnd) {\n assert(this.fileSize !== null);\n const prefetchRange = this.options.prefetchProfile(innerStart, innerEnd, this.workers);\n const outerStart = Math.max(prefetchRange.start, 0);\n const outerEnd = Math.min(prefetchRange.end, this.fileSize);\n assert(outerStart <= innerStart && innerEnd <= outerEnd);\n let result = null;\n const innerCacheStartIndex = binarySearchLessOrEqual(this.cache, innerStart, x => x.start);\n const innerStartEntry = innerCacheStartIndex !== -1 ? this.cache[innerCacheStartIndex] : null;\n // See if the read request can be satisfied by a single cache entry\n if (innerStartEntry && innerStartEntry.start <= innerStart && innerEnd <= innerStartEntry.end) {\n innerStartEntry.age = this.nextAge++;\n result = {\n bytes: innerStartEntry.bytes,\n view: innerStartEntry.view,\n offset: innerStartEntry.start,\n };\n // Can't return yet though, still need to check if the prefetch range might lie outside the cached area\n }\n const outerCacheStartIndex = binarySearchLessOrEqual(this.cache, outerStart, x => x.start);\n const bytes = result ? null : new Uint8Array(innerEnd - innerStart);\n let contiguousBytesWriteEnd = 0; // Used to track if the cache is able to completely cover the bytes\n let lastEnd = outerStart;\n // The \"holes\" in the cache (the parts we need to load)\n const outerHoles = [];\n // Loop over the cache and build up the list of holes\n if (outerCacheStartIndex !== -1) {\n for (let i = outerCacheStartIndex; i < this.cache.length; i++) {\n const entry = this.cache[i];\n if (entry.start >= outerEnd) {\n break;\n }\n if (entry.end <= outerStart) {\n continue;\n }\n const cappedOuterStart = Math.max(outerStart, entry.start);\n const cappedOuterEnd = Math.min(outerEnd, entry.end);\n assert(cappedOuterStart <= cappedOuterEnd);\n if (lastEnd < cappedOuterStart) {\n outerHoles.push({ start: lastEnd, end: cappedOuterStart });\n }\n lastEnd = cappedOuterEnd;\n if (bytes) {\n const cappedInnerStart = Math.max(innerStart, entry.start);\n const cappedInnerEnd = Math.min(innerEnd, entry.end);\n if (cappedInnerStart < cappedInnerEnd) {\n const relativeOffset = cappedInnerStart - innerStart;\n // Fill the relevant section of the bytes with the cached data\n bytes.set(entry.bytes.subarray(cappedInnerStart - entry.start, cappedInnerEnd - entry.start), relativeOffset);\n if (relativeOffset === contiguousBytesWriteEnd) {\n contiguousBytesWriteEnd = cappedInnerEnd - innerStart;\n }\n }\n }\n entry.age = this.nextAge++;\n }\n if (lastEnd < outerEnd) {\n outerHoles.push({ start: lastEnd, end: outerEnd });\n }\n }\n else {\n outerHoles.push({ start: outerStart, end: outerEnd });\n }\n if (bytes && contiguousBytesWriteEnd >= bytes.length) {\n // Multiple cache entries were able to completely cover the requested bytes!\n result = {\n bytes,\n view: toDataView(bytes),\n offset: innerStart,\n };\n }\n if (outerHoles.length === 0) {\n assert(result);\n return result;\n }\n // We need to read more data, so now we're in async land\n const { promise, resolve, reject } = promiseWithResolvers();\n const innerHoles = [];\n for (const outerHole of outerHoles) {\n const cappedStart = Math.max(innerStart, outerHole.start);\n const cappedEnd = Math.min(innerEnd, outerHole.end);\n if (cappedStart === outerHole.start && cappedEnd === outerHole.end) {\n innerHoles.push(outerHole); // Can reuse without allocating a new object\n }\n else if (cappedStart < cappedEnd) {\n innerHoles.push({ start: cappedStart, end: cappedEnd });\n }\n }\n // Fire off workers to take care of patching the holes\n for (const outerHole of outerHoles) {\n const pendingSlice = bytes && {\n start: innerStart,\n bytes,\n holes: innerHoles,\n resolve,\n reject,\n };\n let workerFound = false;\n for (const worker of this.workers) {\n // A small tolerance in the case that the requested region is *just* after the target position of an\n // existing worker. In that case, it's probably more efficient to repurpose that worker than to spawn\n // another one so close to it\n const gapTolerance = 2 ** 17;\n // This check also implies worker.currentPos <= outerHole.start, a critical condition\n if (closedIntervalsOverlap(outerHole.start - gapTolerance, outerHole.start, worker.currentPos, worker.targetPos)) {\n worker.targetPos = Math.max(worker.targetPos, outerHole.end); // Update the worker's target position\n workerFound = true;\n if (pendingSlice && !worker.pendingSlices.includes(pendingSlice)) {\n worker.pendingSlices.push(pendingSlice);\n }\n if (!worker.running) {\n // Kick it off if it's idle\n this.runWorker(worker);\n }\n break;\n }\n }\n if (!workerFound) {\n // We need to spawn a new worker\n const newWorker = this.createWorker(outerHole.start, outerHole.end);\n if (pendingSlice) {\n newWorker.pendingSlices = [pendingSlice];\n }\n this.runWorker(newWorker);\n }\n }\n if (!result) {\n assert(bytes);\n result = promise.then(bytes => ({\n bytes,\n view: toDataView(bytes),\n offset: innerStart,\n }));\n }\n else {\n // The requested region was satisfied by the cache, but the entire prefetch region was not\n }\n return result;\n }\n createWorker(startPos, targetPos) {\n const worker = {\n startPos,\n currentPos: startPos,\n targetPos,\n running: false,\n aborted: false,\n pendingSlices: [],\n age: this.nextAge++,\n };\n this.workers.push(worker);\n // LRU eviction of the other workers\n while (this.workers.length > this.options.maxWorkerCount) {\n let oldestIndex = 0;\n let oldestWorker = this.workers[0];\n for (let i = 1; i < this.workers.length; i++) {\n const worker = this.workers[i];\n if (worker.age < oldestWorker.age) {\n oldestIndex = i;\n oldestWorker = worker;\n }\n }\n if (oldestWorker.running && oldestWorker.pendingSlices.length > 0) {\n break;\n }\n oldestWorker.aborted = true;\n this.workers.splice(oldestIndex, 1);\n }\n return worker;\n }\n runWorker(worker) {\n assert(!worker.running);\n assert(worker.currentPos < worker.targetPos);\n worker.running = true;\n worker.age = this.nextAge++;\n void this.options.runWorker(worker)\n .catch((error) => {\n worker.running = false;\n if (worker.pendingSlices.length > 0) {\n worker.pendingSlices.forEach(x => x.reject(error)); // Make sure to propagate any errors\n worker.pendingSlices.length = 0;\n }\n else {\n throw error; // So it doesn't get swallowed\n }\n });\n }\n /** Called by a worker when it has read some data. */\n supplyWorkerData(worker, bytes) {\n const start = worker.currentPos;\n const end = start + bytes.length;\n this.insertIntoCache({\n start,\n end,\n bytes,\n view: toDataView(bytes),\n age: this.nextAge++,\n });\n worker.currentPos += bytes.length;\n worker.targetPos = Math.max(worker.targetPos, worker.currentPos); // In case it overshoots\n // Now, let's see if we can use the read bytes to fill any pending slice\n for (let i = 0; i < worker.pendingSlices.length; i++) {\n const pendingSlice = worker.pendingSlices[i];\n const clampedStart = Math.max(start, pendingSlice.start);\n const clampedEnd = Math.min(end, pendingSlice.start + pendingSlice.bytes.length);\n if (clampedStart < clampedEnd) {\n pendingSlice.bytes.set(bytes.subarray(clampedStart - start, clampedEnd - start), clampedStart - pendingSlice.start);\n }\n for (let j = 0; j < pendingSlice.holes.length; j++) {\n // The hole is intentionally not modified here if the read section starts somewhere in the middle of\n // the hole. We don't need to do \"hole splitting\", since the workers are spawned *by* the holes,\n // meaning there's always a worker which will consume the hole left to right.\n const hole = pendingSlice.holes[j];\n if (start <= hole.start && end > hole.start) {\n hole.start = end;\n }\n if (hole.end <= hole.start) {\n pendingSlice.holes.splice(j, 1);\n j--;\n }\n }\n if (pendingSlice.holes.length === 0) {\n // The slice has been fulfilled, everything has been read. Let's resolve the promise\n pendingSlice.resolve(pendingSlice.bytes);\n worker.pendingSlices.splice(i, 1);\n i--;\n }\n }\n // Remove other idle workers if we \"ate\" into their territory\n for (let i = 0; i < this.workers.length; i++) {\n const otherWorker = this.workers[i];\n if (worker === otherWorker || otherWorker.running) {\n continue;\n }\n if (closedIntervalsOverlap(start, end, otherWorker.currentPos, otherWorker.targetPos)) {\n this.workers.splice(i, 1);\n i--;\n }\n }\n }\n forgetWorker(worker) {\n const index = this.workers.indexOf(worker);\n assert(index !== -1);\n this.workers.splice(index, 1);\n }\n insertIntoCache(entry) {\n if (this.options.maxCacheSize === 0) {\n return; // No caching\n }\n let insertionIndex = binarySearchLessOrEqual(this.cache, entry.start, x => x.start) + 1;\n if (insertionIndex > 0) {\n const previous = this.cache[insertionIndex - 1];\n if (previous.end >= entry.end) {\n // Previous entry swallows the one to be inserted; we don't need to do anything\n return;\n }\n if (previous.end > entry.start) {\n // Partial overlap with the previous entry, let's join\n const joined = new Uint8Array(entry.end - previous.start);\n joined.set(previous.bytes, 0);\n joined.set(entry.bytes, entry.start - previous.start);\n this.currentCacheSize += entry.end - previous.end;\n previous.bytes = joined;\n previous.view = toDataView(joined);\n previous.end = entry.end;\n // Do the rest of the logic with the previous entry instead\n insertionIndex--;\n entry = previous;\n }\n else {\n this.cache.splice(insertionIndex, 0, entry);\n this.currentCacheSize += entry.bytes.length;\n }\n }\n else {\n this.cache.splice(insertionIndex, 0, entry);\n this.currentCacheSize += entry.bytes.length;\n }\n for (let i = insertionIndex + 1; i < this.cache.length; i++) {\n const next = this.cache[i];\n if (entry.end <= next.start) {\n // Even if they touch, we don't wanna merge them, no need\n break;\n }\n if (entry.end >= next.end) {\n // The inserted entry completely swallows the next entry\n this.cache.splice(i, 1);\n this.currentCacheSize -= next.bytes.length;\n i--;\n continue;\n }\n // Partial overlap, let's join\n const joined = new Uint8Array(next.end - entry.start);\n joined.set(entry.bytes, 0);\n joined.set(next.bytes, next.start - entry.start);\n this.currentCacheSize -= entry.end - next.start; // Subtract the overlap\n entry.bytes = joined;\n entry.view = toDataView(joined);\n entry.end = next.end;\n this.cache.splice(i, 1);\n break; // After the join case, we're done: the next entry cannot possibly overlap with the inserted one.\n }\n // LRU eviction of cache entries\n while (this.currentCacheSize > this.options.maxCacheSize) {\n let oldestIndex = 0;\n let oldestEntry = this.cache[0];\n for (let i = 1; i < this.cache.length; i++) {\n const entry = this.cache[i];\n if (entry.age < oldestEntry.age) {\n oldestIndex = i;\n oldestEntry = entry;\n }\n }\n if (this.currentCacheSize - oldestEntry.bytes.length <= this.options.maxCacheSize) {\n // Don't evict if it would shrink the cache below the max size\n break;\n }\n this.cache.splice(oldestIndex, 1);\n this.currentCacheSize -= oldestEntry.bytes.length;\n }\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { extractAudioCodecString, extractVideoCodecString, parseAacAudioSpecificConfig, parsePcmCodec, PCM_AUDIO_CODECS, } from '../codec.js';\nimport { extractAv1CodecInfoFromPacket, extractVp9CodecInfoFromPacket, } from '../codec-data.js';\nimport { Demuxer } from '../demuxer.js';\nimport { InputAudioTrack, InputVideoTrack, } from '../input-track.js';\nimport { assert, AsyncMutex, binarySearchExact, binarySearchLessOrEqual, Bitstream, COLOR_PRIMARIES_MAP_INVERSE, findLastIndex, insertSorted, isIso639Dash2LanguageCode, last, MATRIX_COEFFICIENTS_MAP_INVERSE, normalizeRotation, roundToMultiple, roundToPrecision, textDecoder, TRANSFER_CHARACTERISTICS_MAP_INVERSE, UNDETERMINED_LANGUAGE, toDataView, } from '../misc.js';\nimport { EncodedPacket, PLACEHOLDER_DATA } from '../packet.js';\nimport { buildIsobmffMimeType } from './isobmff-misc.js';\nimport { MAX_BOX_HEADER_SIZE, MIN_BOX_HEADER_SIZE, readBoxHeader, readDataBox, readFixed_16_16, readFixed_2_30, readIsomVariableInteger, readMetadataStringShort, } from './isobmff-reader.js';\nimport { readBytes, readF64Be, readI16Be, readI32Be, readI64Be, readU16Be, readU24Be, readU32Be, readU64Be, readU8, readAscii, } from '../reader.js';\nimport { RichImageData } from '../tags.js';\n// https://exiftool.org/TagNames/QuickTime.html\nconst UDTA_STRING_KEYS = new Set([\n '@day', '@mak', '@mod', '@swr', '@xyz', 'CAME', 'CNCV', 'CNFV', 'CNMN', 'FIRM', 'FOV\\0', 'GoPr', 'LENS', 'PXMN',\n 'SIGM', 'SNum', 'TAGS', 'albm', 'albr', 'angl', 'auth', 'ccid', 'cdis', 'clfn', 'clid', 'clsf', 'cmid', 'cmnm',\n 'coll', 'cprt', 'cver', 'cvru', 'date', 'dscp', 'fsid', 'gnre', 'hinv', 'icnu', 'info', 'infu', 'kgtt', 'loci',\n 'lrcu', 'mcvr', 'name', 'perf', 'pmcc', 'reel', 'rtng', 'scen', 'shot', 'slno', 'thmb', 'titl', 'tnam', 'urat',\n 'uuid', 'vndr', 'yrrc', '\u00A9ART', '\u00A9TIM', '\u00A9TSC', '\u00A9TSZ', '\u00A9alb', '\u00A9arg', '\u00A9ark', '\u00A9cmt', '\u00A9cok', '\u00A9com', '\u00A9cpy',\n '\u00A9day', '\u00A9dir', '\u00A9ed1', '\u00A9ed2', '\u00A9ed3', '\u00A9ed4', '\u00A9ed5', '\u00A9ed6', '\u00A9ed7', '\u00A9ed8', '\u00A9ed9', '\u00A9enc', '\u00A9fmt', '\u00A9fpt',\n '\u00A9frl', '\u00A9fyw', '\u00A9gen', '\u00A9gpt', '\u00A9grl', '\u00A9grp', '\u00A9gyw', '\u00A9inf', '\u00A9isr', '\u00A9lab', '\u00A9lal', '\u00A9lyr', '\u00A9mak', '\u00A9mal',\n '\u00A9mdl', '\u00A9mod', '\u00A9nam', '\u00A9pdk', '\u00A9phg', '\u00A9prd', '\u00A9prf', '\u00A9prk', '\u00A9prl', '\u00A9req', '\u00A9snk', '\u00A9snm', '\u00A9src', '\u00A9swf',\n '\u00A9swk', '\u00A9swr', '\u00A9too', '\u00A9trk', '\u00A9wrt', '\u00A9xsp', '\u00A9xyz', '\u00A9ysp', '\u00A9zsp',\n]);\nexport class IsobmffDemuxer extends Demuxer {\n constructor(input) {\n super(input);\n this.moovSlice = null;\n this.currentTrack = null;\n this.tracks = [];\n this.metadataPromise = null;\n this.movieTimescale = -1;\n this.movieDurationInTimescale = -1;\n this.isQuickTime = false;\n this.metadataTags = {};\n this.currentMetadataKeys = null;\n this.isFragmented = false;\n this.fragmentTrackDefaults = [];\n this.fragments = [];\n this.currentFragment = null;\n this.fragmentLookupMutex = new AsyncMutex();\n this.reader = input._reader;\n }\n async computeDuration() {\n const tracks = await this.getTracks();\n const trackDurations = await Promise.all(tracks.map(x => x.computeDuration()));\n return Math.max(0, ...trackDurations);\n }\n async getTracks() {\n await this.readMetadata();\n return this.tracks.map(track => track.inputTrack);\n }\n async getMimeType() {\n await this.readMetadata();\n const codecStrings = await Promise.all(this.tracks.map(x => x.inputTrack.getCodecParameterString()));\n return buildIsobmffMimeType({\n isQuickTime: this.isQuickTime,\n hasVideo: this.tracks.some(x => x.info?.type === 'video'),\n hasAudio: this.tracks.some(x => x.info?.type === 'audio'),\n codecStrings: codecStrings.filter(Boolean),\n });\n }\n async getMetadataTags() {\n await this.readMetadata();\n return this.metadataTags;\n }\n readMetadata() {\n return this.metadataPromise ??= (async () => {\n let currentPos = 0;\n while (true) {\n let slice = this.reader.requestSliceRange(currentPos, MIN_BOX_HEADER_SIZE, MAX_BOX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const startPos = currentPos;\n const boxInfo = readBoxHeader(slice);\n if (!boxInfo) {\n break;\n }\n if (boxInfo.name === 'ftyp') {\n const majorBrand = readAscii(slice, 4);\n this.isQuickTime = majorBrand === 'qt ';\n }\n else if (boxInfo.name === 'moov') {\n // Found moov, load it\n let moovSlice = this.reader.requestSlice(slice.filePos, boxInfo.contentSize);\n if (moovSlice instanceof Promise)\n moovSlice = await moovSlice;\n if (!moovSlice)\n break;\n this.moovSlice = moovSlice;\n this.readContiguousBoxes(this.moovSlice);\n for (const track of this.tracks) {\n // Modify the edit list offset based on the previous segment durations. They are in different\n // timescales, so we first convert to seconds and then into the track timescale.\n const previousSegmentDurationsInSeconds = track.editListPreviousSegmentDurations / this.movieTimescale;\n track.editListOffset -= Math.round(previousSegmentDurationsInSeconds * track.timescale);\n }\n break;\n }\n currentPos = startPos + boxInfo.totalSize;\n }\n if (this.isFragmented && this.reader.fileSize !== null) {\n // The last 4 bytes may contain the size of the mfra box at the end of the file\n let lastWordSlice = this.reader.requestSlice(this.reader.fileSize - 4, 4);\n if (lastWordSlice instanceof Promise)\n lastWordSlice = await lastWordSlice;\n assert(lastWordSlice);\n const lastWord = readU32Be(lastWordSlice);\n const potentialMfraPos = this.reader.fileSize - lastWord;\n if (potentialMfraPos >= 0 && potentialMfraPos <= this.reader.fileSize - MAX_BOX_HEADER_SIZE) {\n let mfraHeaderSlice = this.reader.requestSliceRange(potentialMfraPos, MIN_BOX_HEADER_SIZE, MAX_BOX_HEADER_SIZE);\n if (mfraHeaderSlice instanceof Promise)\n mfraHeaderSlice = await mfraHeaderSlice;\n if (mfraHeaderSlice) {\n const boxInfo = readBoxHeader(mfraHeaderSlice);\n if (boxInfo && boxInfo.name === 'mfra') {\n // We found the mfra box, allowing for much better random access. Let's parse it.\n let mfraSlice = this.reader.requestSlice(mfraHeaderSlice.filePos, boxInfo.contentSize);\n if (mfraSlice instanceof Promise)\n mfraSlice = await mfraSlice;\n if (mfraSlice) {\n this.readContiguousBoxes(mfraSlice);\n }\n }\n }\n }\n }\n })();\n }\n getSampleTableForTrack(internalTrack) {\n if (internalTrack.sampleTable) {\n return internalTrack.sampleTable;\n }\n const sampleTable = {\n sampleTimingEntries: [],\n sampleCompositionTimeOffsets: [],\n sampleSizes: [],\n keySampleIndices: null,\n chunkOffsets: [],\n sampleToChunk: [],\n presentationTimestamps: null,\n presentationTimestampIndexMap: null,\n };\n internalTrack.sampleTable = sampleTable;\n assert(this.moovSlice);\n const stblContainerSlice = this.moovSlice.slice(internalTrack.sampleTableByteOffset);\n this.currentTrack = internalTrack;\n this.traverseBox(stblContainerSlice);\n this.currentTrack = null;\n const isPcmCodec = internalTrack.info?.type === 'audio'\n && internalTrack.info.codec\n && PCM_AUDIO_CODECS.includes(internalTrack.info.codec);\n if (isPcmCodec && sampleTable.sampleCompositionTimeOffsets.length === 0) {\n // If the audio has PCM samples, the way the samples are defined in the sample table is somewhat\n // suboptimal: Each individual audio sample is its own sample, meaning we can have 48000 samples per second.\n // Because we treat each sample as its own atomic unit that can be decoded, this would lead to a huge\n // amount of very short samples for PCM audio. So instead, we make a transformation: If the audio is in PCM,\n // we say that each chunk (that normally holds many samples) now is one big sample. We can this because\n // the samples in the chunk are contiguous and the format is PCM, so the entire chunk as one thing still\n // encodes valid audio information.\n assert(internalTrack.info?.type === 'audio');\n const pcmInfo = parsePcmCodec(internalTrack.info.codec);\n const newSampleTimingEntries = [];\n const newSampleSizes = [];\n for (let i = 0; i < sampleTable.sampleToChunk.length; i++) {\n const chunkEntry = sampleTable.sampleToChunk[i];\n const nextEntry = sampleTable.sampleToChunk[i + 1];\n const chunkCount = (nextEntry ? nextEntry.startChunkIndex : sampleTable.chunkOffsets.length)\n - chunkEntry.startChunkIndex;\n for (let j = 0; j < chunkCount; j++) {\n const startSampleIndex = chunkEntry.startSampleIndex + j * chunkEntry.samplesPerChunk;\n const endSampleIndex = startSampleIndex + chunkEntry.samplesPerChunk; // Exclusive, outside of chunk\n const startTimingEntryIndex = binarySearchLessOrEqual(sampleTable.sampleTimingEntries, startSampleIndex, x => x.startIndex);\n const startTimingEntry = sampleTable.sampleTimingEntries[startTimingEntryIndex];\n const endTimingEntryIndex = binarySearchLessOrEqual(sampleTable.sampleTimingEntries, endSampleIndex, x => x.startIndex);\n const endTimingEntry = sampleTable.sampleTimingEntries[endTimingEntryIndex];\n const firstSampleTimestamp = startTimingEntry.startDecodeTimestamp\n + (startSampleIndex - startTimingEntry.startIndex) * startTimingEntry.delta;\n const lastSampleTimestamp = endTimingEntry.startDecodeTimestamp\n + (endSampleIndex - endTimingEntry.startIndex) * endTimingEntry.delta;\n const delta = lastSampleTimestamp - firstSampleTimestamp;\n const lastSampleTimingEntry = last(newSampleTimingEntries);\n if (lastSampleTimingEntry && lastSampleTimingEntry.delta === delta) {\n lastSampleTimingEntry.count++;\n }\n else {\n // One sample for the entire chunk\n newSampleTimingEntries.push({\n startIndex: chunkEntry.startChunkIndex + j,\n startDecodeTimestamp: firstSampleTimestamp,\n count: 1,\n delta,\n });\n }\n // Instead of determining the chunk's size by looping over the samples sizes in the sample table, we\n // can directly compute it as we know how many PCM frames are in this chunk, and the size of each\n // PCM frame. This also improves compatibility with some files which fail to write proper sample\n // size values into their sample tables in the PCM case.\n const chunkSize = chunkEntry.samplesPerChunk\n * pcmInfo.sampleSize\n * internalTrack.info.numberOfChannels;\n newSampleSizes.push(chunkSize);\n }\n chunkEntry.startSampleIndex = chunkEntry.startChunkIndex;\n chunkEntry.samplesPerChunk = 1;\n }\n sampleTable.sampleTimingEntries = newSampleTimingEntries;\n sampleTable.sampleSizes = newSampleSizes;\n }\n if (sampleTable.sampleCompositionTimeOffsets.length > 0) {\n // If composition time offsets are defined, we must build a list of all presentation timestamps and then\n // sort them\n sampleTable.presentationTimestamps = [];\n for (const entry of sampleTable.sampleTimingEntries) {\n for (let i = 0; i < entry.count; i++) {\n sampleTable.presentationTimestamps.push({\n presentationTimestamp: entry.startDecodeTimestamp + i * entry.delta,\n sampleIndex: entry.startIndex + i,\n });\n }\n }\n for (const entry of sampleTable.sampleCompositionTimeOffsets) {\n for (let i = 0; i < entry.count; i++) {\n const sampleIndex = entry.startIndex + i;\n const sample = sampleTable.presentationTimestamps[sampleIndex];\n if (!sample) {\n continue;\n }\n sample.presentationTimestamp += entry.offset;\n }\n }\n sampleTable.presentationTimestamps.sort((a, b) => a.presentationTimestamp - b.presentationTimestamp);\n sampleTable.presentationTimestampIndexMap = Array(sampleTable.presentationTimestamps.length).fill(-1);\n for (let i = 0; i < sampleTable.presentationTimestamps.length; i++) {\n sampleTable.presentationTimestampIndexMap[sampleTable.presentationTimestamps[i].sampleIndex] = i;\n }\n }\n else {\n // If they're not defined, we can simply use the decode timestamps as presentation timestamps\n }\n return sampleTable;\n }\n async readFragment(startPos) {\n let headerSlice = this.reader.requestSliceRange(startPos, MIN_BOX_HEADER_SIZE, MAX_BOX_HEADER_SIZE);\n if (headerSlice instanceof Promise)\n headerSlice = await headerSlice;\n assert(headerSlice);\n const moofBoxInfo = readBoxHeader(headerSlice);\n assert(moofBoxInfo?.name === 'moof');\n let entireSlice = this.reader.requestSlice(startPos, moofBoxInfo.totalSize);\n if (entireSlice instanceof Promise)\n entireSlice = await entireSlice;\n assert(entireSlice);\n this.traverseBox(entireSlice);\n const index = binarySearchExact(this.fragments, startPos, x => x.moofOffset);\n assert(index !== -1);\n const fragment = this.fragments[index];\n assert(fragment.moofOffset === startPos);\n // It may be that some tracks don't define the base decode time, i.e. when the fragment begins. This means the\n // only other option is to sum up the duration of all previous fragments.\n for (const [trackId, trackData] of fragment.trackData) {\n if (trackData.startTimestampIsFinal) {\n continue;\n }\n const internalTrack = this.tracks.find(x => x.id === trackId);\n let currentPos = 0;\n let currentFragment = null;\n let lastFragment = null;\n const index = binarySearchLessOrEqual(internalTrack.fragments, startPos - 1, x => x.moofOffset);\n if (index !== -1) {\n // Instead of starting at the start of the file, let's start at the previous fragment instead (which\n // already has final timestamps).\n currentFragment = internalTrack.fragments[index];\n lastFragment = currentFragment;\n currentPos = currentFragment.moofOffset + currentFragment.moofSize;\n }\n let nextFragmentIsFirstFragment = currentPos === 0;\n while (currentPos <= startPos - MIN_BOX_HEADER_SIZE) {\n if (currentFragment?.nextFragment) {\n currentFragment = currentFragment.nextFragment;\n currentPos = currentFragment.moofOffset + currentFragment.moofSize;\n }\n else {\n let slice = this.reader.requestSliceRange(currentPos, MIN_BOX_HEADER_SIZE, MAX_BOX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const boxStartPos = currentPos;\n const boxInfo = readBoxHeader(slice);\n if (!boxInfo) {\n break;\n }\n if (boxInfo.name === 'moof') {\n const index = binarySearchExact(this.fragments, boxStartPos, x => x.moofOffset);\n let fragment;\n if (index === -1) {\n fragment = await this.readFragment(boxStartPos); // Recursive call\n }\n else {\n // We already know this fragment\n fragment = this.fragments[index];\n }\n // Even if we already know the fragment, we might not yet know its predecessor; always do this\n if (currentFragment)\n currentFragment.nextFragment = fragment;\n currentFragment = fragment;\n if (nextFragmentIsFirstFragment) {\n fragment.isKnownToBeFirstFragment = true;\n nextFragmentIsFirstFragment = false;\n }\n }\n currentPos = boxStartPos + boxInfo.totalSize;\n }\n if (currentFragment && currentFragment.trackData.has(trackId)) {\n lastFragment = currentFragment;\n }\n }\n if (lastFragment) {\n const otherTrackData = lastFragment.trackData.get(trackId);\n assert(otherTrackData.startTimestampIsFinal);\n offsetFragmentTrackDataByTimestamp(trackData, otherTrackData.endTimestamp);\n }\n trackData.startTimestampIsFinal = true;\n }\n return fragment;\n }\n readContiguousBoxes(slice) {\n const startIndex = slice.filePos;\n while (slice.filePos - startIndex <= slice.length - MIN_BOX_HEADER_SIZE) {\n const foundBox = this.traverseBox(slice);\n if (!foundBox) {\n break;\n }\n }\n }\n // eslint-disable-next-line @stylistic/generator-star-spacing\n *iterateContiguousBoxes(slice) {\n const startIndex = slice.filePos;\n while (slice.filePos - startIndex <= slice.length - MIN_BOX_HEADER_SIZE) {\n const startPos = slice.filePos;\n const boxInfo = readBoxHeader(slice);\n if (!boxInfo) {\n break;\n }\n yield { boxInfo, slice };\n slice.filePos = startPos + boxInfo.totalSize;\n }\n }\n traverseBox(slice) {\n const startPos = slice.filePos;\n const boxInfo = readBoxHeader(slice);\n if (!boxInfo) {\n return false;\n }\n const contentStartPos = slice.filePos;\n const boxEndPos = startPos + boxInfo.totalSize;\n switch (boxInfo.name) {\n case 'mdia':\n case 'minf':\n case 'dinf':\n case 'mfra':\n case 'edts':\n {\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n }\n ;\n break;\n case 'mvhd':\n {\n const version = readU8(slice);\n slice.skip(3); // Flags\n if (version === 1) {\n slice.skip(8 + 8);\n this.movieTimescale = readU32Be(slice);\n this.movieDurationInTimescale = readU64Be(slice);\n }\n else {\n slice.skip(4 + 4);\n this.movieTimescale = readU32Be(slice);\n this.movieDurationInTimescale = readU32Be(slice);\n }\n }\n ;\n break;\n case 'trak':\n {\n const track = {\n id: -1,\n demuxer: this,\n inputTrack: null,\n info: null,\n timescale: -1,\n durationInMovieTimescale: -1,\n durationInMediaTimescale: -1,\n rotation: 0,\n internalCodecId: null,\n name: null,\n languageCode: UNDETERMINED_LANGUAGE,\n sampleTableByteOffset: -1,\n sampleTable: null,\n fragmentLookupTable: null,\n currentFragmentState: null,\n fragments: [],\n fragmentsWithKeyFrame: [],\n editListPreviousSegmentDurations: 0,\n editListOffset: 0,\n };\n this.currentTrack = track;\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n if (track.id !== -1 && track.timescale !== -1 && track.info !== null) {\n if (track.info.type === 'video' && track.info.width !== -1) {\n const videoTrack = track;\n track.inputTrack = new InputVideoTrack(new IsobmffVideoTrackBacking(videoTrack));\n this.tracks.push(track);\n }\n else if (track.info.type === 'audio' && track.info.numberOfChannels !== -1) {\n const audioTrack = track;\n track.inputTrack = new InputAudioTrack(new IsobmffAudioTrackBacking(audioTrack));\n this.tracks.push(track);\n }\n }\n this.currentTrack = null;\n }\n ;\n break;\n case 'tkhd':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n const version = readU8(slice);\n const flags = readU24Be(slice);\n const trackEnabled = (flags & 0x1) !== 0;\n if (!trackEnabled) {\n break;\n }\n // Skip over creation & modification time to reach the track ID\n if (version === 0) {\n slice.skip(8);\n track.id = readU32Be(slice);\n slice.skip(4);\n track.durationInMovieTimescale = readU32Be(slice);\n }\n else if (version === 1) {\n slice.skip(16);\n track.id = readU32Be(slice);\n slice.skip(4);\n track.durationInMovieTimescale = readU64Be(slice);\n }\n else {\n throw new Error(`Incorrect track header version ${version}.`);\n }\n slice.skip(2 * 4 + 2 + 2 + 2 + 2);\n const matrix = [\n readFixed_16_16(slice),\n readFixed_16_16(slice),\n readFixed_2_30(slice),\n readFixed_16_16(slice),\n readFixed_16_16(slice),\n readFixed_2_30(slice),\n readFixed_16_16(slice),\n readFixed_16_16(slice),\n readFixed_2_30(slice),\n ];\n const rotation = normalizeRotation(roundToMultiple(extractRotationFromMatrix(matrix), 90));\n assert(rotation === 0 || rotation === 90 || rotation === 180 || rotation === 270);\n track.rotation = rotation;\n }\n ;\n break;\n case 'elst':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n const version = readU8(slice);\n slice.skip(3); // Flags\n let relevantEntryFound = false;\n let previousSegmentDurations = 0;\n const entryCount = readU32Be(slice);\n for (let i = 0; i < entryCount; i++) {\n const segmentDuration = version === 1\n ? readU64Be(slice)\n : readU32Be(slice);\n const mediaTime = version === 1\n ? readI64Be(slice)\n : readI32Be(slice);\n const mediaRate = readFixed_16_16(slice);\n if (segmentDuration === 0) {\n // Don't care\n continue;\n }\n if (relevantEntryFound) {\n console.warn('Unsupported edit list: multiple edits are not currently supported. Only using first edit.');\n break;\n }\n if (mediaTime === -1) {\n previousSegmentDurations += segmentDuration;\n continue;\n }\n if (mediaRate !== 1) {\n console.warn('Unsupported edit list entry: media rate must be 1.');\n break;\n }\n track.editListPreviousSegmentDurations = previousSegmentDurations;\n track.editListOffset = mediaTime;\n relevantEntryFound = true;\n }\n }\n ;\n break;\n case 'mdhd':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n const version = readU8(slice);\n slice.skip(3); // Flags\n if (version === 0) {\n slice.skip(8);\n track.timescale = readU32Be(slice);\n track.durationInMediaTimescale = readU32Be(slice);\n }\n else if (version === 1) {\n slice.skip(16);\n track.timescale = readU32Be(slice);\n track.durationInMediaTimescale = readU64Be(slice);\n }\n let language = readU16Be(slice);\n if (language > 0) {\n track.languageCode = '';\n for (let i = 0; i < 3; i++) {\n track.languageCode = String.fromCharCode(0x60 + (language & 0b11111)) + track.languageCode;\n language >>= 5;\n }\n if (!isIso639Dash2LanguageCode(track.languageCode)) {\n // Sometimes the bytes are garbage\n track.languageCode = UNDETERMINED_LANGUAGE;\n }\n }\n }\n ;\n break;\n case 'hdlr':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n slice.skip(8); // Version + flags + pre-defined\n const handlerType = readAscii(slice, 4);\n if (handlerType === 'vide') {\n track.info = {\n type: 'video',\n width: -1,\n height: -1,\n codec: null,\n codecDescription: null,\n colorSpace: null,\n avcCodecInfo: null,\n hevcCodecInfo: null,\n vp9CodecInfo: null,\n av1CodecInfo: null,\n };\n }\n else if (handlerType === 'soun') {\n track.info = {\n type: 'audio',\n numberOfChannels: -1,\n sampleRate: -1,\n codec: null,\n codecDescription: null,\n aacCodecInfo: null,\n };\n }\n }\n ;\n break;\n case 'stbl':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n track.sampleTableByteOffset = startPos;\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n }\n ;\n break;\n case 'stsd':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (track.info === null || track.sampleTable) {\n break;\n }\n const stsdVersion = readU8(slice);\n slice.skip(3); // Flags\n const entries = readU32Be(slice);\n for (let i = 0; i < entries; i++) {\n const sampleBoxStartPos = slice.filePos;\n const sampleBoxInfo = readBoxHeader(slice);\n if (!sampleBoxInfo) {\n break;\n }\n track.internalCodecId = sampleBoxInfo.name;\n const lowercaseBoxName = sampleBoxInfo.name.toLowerCase();\n if (track.info.type === 'video') {\n if (lowercaseBoxName === 'avc1') {\n track.info.codec = 'avc';\n }\n else if (lowercaseBoxName === 'hvc1' || lowercaseBoxName === 'hev1') {\n track.info.codec = 'hevc';\n }\n else if (lowercaseBoxName === 'vp08') {\n track.info.codec = 'vp8';\n }\n else if (lowercaseBoxName === 'vp09') {\n track.info.codec = 'vp9';\n }\n else if (lowercaseBoxName === 'av01') {\n track.info.codec = 'av1';\n }\n else {\n console.warn(`Unsupported video codec (sample entry type '${sampleBoxInfo.name}').`);\n }\n slice.skip(6 * 1 + 2 + 2 + 2 + 3 * 4);\n track.info.width = readU16Be(slice);\n track.info.height = readU16Be(slice);\n slice.skip(4 + 4 + 4 + 2 + 32 + 2 + 2);\n this.readContiguousBoxes(slice.slice(slice.filePos, (sampleBoxStartPos + sampleBoxInfo.totalSize) - slice.filePos));\n }\n else {\n if (lowercaseBoxName === 'mp4a') {\n // We don't know the codec yet (might be AAC, might be MP3), need to read the esds box\n }\n else if (lowercaseBoxName === 'opus') {\n track.info.codec = 'opus';\n }\n else if (lowercaseBoxName === 'flac') {\n track.info.codec = 'flac';\n }\n else if (lowercaseBoxName === 'twos'\n || lowercaseBoxName === 'sowt'\n || lowercaseBoxName === 'raw '\n || lowercaseBoxName === 'in24'\n || lowercaseBoxName === 'in32'\n || lowercaseBoxName === 'fl32'\n || lowercaseBoxName === 'fl64'\n || lowercaseBoxName === 'lpcm'\n || lowercaseBoxName === 'ipcm' // ISO/IEC 23003-5\n || lowercaseBoxName === 'fpcm' // \"\n ) {\n // It's PCM\n // developer.apple.com/documentation/quicktime-file-format/sound_sample_descriptions/\n }\n else if (lowercaseBoxName === 'ulaw') {\n track.info.codec = 'ulaw';\n }\n else if (lowercaseBoxName === 'alaw') {\n track.info.codec = 'alaw';\n }\n else {\n console.warn(`Unsupported audio codec (sample entry type '${sampleBoxInfo.name}').`);\n }\n slice.skip(6 * 1 + 2);\n const version = readU16Be(slice);\n slice.skip(3 * 2);\n let channelCount = readU16Be(slice);\n let sampleSize = readU16Be(slice);\n slice.skip(2 * 2);\n // Can't use fixed16_16 as that's signed\n let sampleRate = readU32Be(slice) / 0x10000;\n if (stsdVersion === 0 && version > 0) {\n // Additional QuickTime fields\n if (version === 1) {\n slice.skip(4);\n sampleSize = 8 * readU32Be(slice);\n slice.skip(2 * 4);\n }\n else if (version === 2) {\n slice.skip(4);\n sampleRate = readF64Be(slice);\n channelCount = readU32Be(slice);\n slice.skip(4); // Always 0x7f000000\n sampleSize = readU32Be(slice);\n const flags = readU32Be(slice);\n slice.skip(2 * 4);\n if (lowercaseBoxName === 'lpcm') {\n const bytesPerSample = (sampleSize + 7) >> 3;\n const isFloat = Boolean(flags & 1);\n const isBigEndian = Boolean(flags & 2);\n const sFlags = flags & 4 ? -1 : 0; // I guess it means \"signed flags\" or something?\n if (sampleSize > 0 && sampleSize <= 64) {\n if (isFloat) {\n if (sampleSize === 32) {\n track.info.codec = isBigEndian ? 'pcm-f32be' : 'pcm-f32';\n }\n }\n else {\n if (sFlags & (1 << (bytesPerSample - 1))) {\n if (bytesPerSample === 1) {\n track.info.codec = 'pcm-s8';\n }\n else if (bytesPerSample === 2) {\n track.info.codec = isBigEndian ? 'pcm-s16be' : 'pcm-s16';\n }\n else if (bytesPerSample === 3) {\n track.info.codec = isBigEndian ? 'pcm-s24be' : 'pcm-s24';\n }\n else if (bytesPerSample === 4) {\n track.info.codec = isBigEndian ? 'pcm-s32be' : 'pcm-s32';\n }\n }\n else {\n if (bytesPerSample === 1) {\n track.info.codec = 'pcm-u8';\n }\n }\n }\n }\n if (track.info.codec === null) {\n console.warn('Unsupported PCM format.');\n }\n }\n }\n }\n track.info.numberOfChannels = channelCount;\n track.info.sampleRate = sampleRate;\n // PCM codec assignments\n if (lowercaseBoxName === 'twos') {\n if (sampleSize === 8) {\n track.info.codec = 'pcm-s8';\n }\n else if (sampleSize === 16) {\n track.info.codec = 'pcm-s16be';\n }\n else {\n console.warn(`Unsupported sample size ${sampleSize} for codec 'twos'.`);\n track.info.codec = null;\n }\n }\n else if (lowercaseBoxName === 'sowt') {\n if (sampleSize === 8) {\n track.info.codec = 'pcm-s8';\n }\n else if (sampleSize === 16) {\n track.info.codec = 'pcm-s16';\n }\n else {\n console.warn(`Unsupported sample size ${sampleSize} for codec 'sowt'.`);\n track.info.codec = null;\n }\n }\n else if (lowercaseBoxName === 'raw ') {\n track.info.codec = 'pcm-u8';\n }\n else if (lowercaseBoxName === 'in24') {\n track.info.codec = 'pcm-s24be';\n }\n else if (lowercaseBoxName === 'in32') {\n track.info.codec = 'pcm-s32be';\n }\n else if (lowercaseBoxName === 'fl32') {\n track.info.codec = 'pcm-f32be';\n }\n else if (lowercaseBoxName === 'fl64') {\n track.info.codec = 'pcm-f64be';\n }\n else if (lowercaseBoxName === 'ipcm') {\n track.info.codec = 'pcm-s16be'; // Placeholder, will be adjusted by the pcmC box\n }\n else if (lowercaseBoxName === 'fpcm') {\n track.info.codec = 'pcm-f32be'; // Placeholder, will be adjusted by the pcmC box\n }\n this.readContiguousBoxes(slice.slice(slice.filePos, (sampleBoxStartPos + sampleBoxInfo.totalSize) - slice.filePos));\n }\n }\n }\n ;\n break;\n case 'avcC':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info);\n track.info.codecDescription = readBytes(slice, boxInfo.contentSize);\n }\n ;\n break;\n case 'hvcC':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info);\n track.info.codecDescription = readBytes(slice, boxInfo.contentSize);\n }\n ;\n break;\n case 'vpcC':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'video');\n slice.skip(4); // Version + flags\n const profile = readU8(slice);\n const level = readU8(slice);\n const thirdByte = readU8(slice);\n const bitDepth = thirdByte >> 4;\n const chromaSubsampling = (thirdByte >> 1) & 0b111;\n const videoFullRangeFlag = thirdByte & 1;\n const colourPrimaries = readU8(slice);\n const transferCharacteristics = readU8(slice);\n const matrixCoefficients = readU8(slice);\n track.info.vp9CodecInfo = {\n profile,\n level,\n bitDepth,\n chromaSubsampling,\n videoFullRangeFlag,\n colourPrimaries,\n transferCharacteristics,\n matrixCoefficients,\n };\n }\n ;\n break;\n case 'av1C':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'video');\n slice.skip(1); // Marker + version\n const secondByte = readU8(slice);\n const profile = secondByte >> 5;\n const level = secondByte & 0b11111;\n const thirdByte = readU8(slice);\n const tier = thirdByte >> 7;\n const highBitDepth = (thirdByte >> 6) & 1;\n const twelveBit = (thirdByte >> 5) & 1;\n const monochrome = (thirdByte >> 4) & 1;\n const chromaSubsamplingX = (thirdByte >> 3) & 1;\n const chromaSubsamplingY = (thirdByte >> 2) & 1;\n const chromaSamplePosition = thirdByte & 0b11;\n // Logic from https://aomediacodec.github.io/av1-spec/av1-spec.pdf\n const bitDepth = profile === 2 && highBitDepth ? (twelveBit ? 12 : 10) : (highBitDepth ? 10 : 8);\n track.info.av1CodecInfo = {\n profile,\n level,\n tier,\n bitDepth,\n monochrome,\n chromaSubsamplingX,\n chromaSubsamplingY,\n chromaSamplePosition,\n };\n }\n ;\n break;\n case 'colr':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'video');\n const colourType = readAscii(slice, 4);\n if (colourType !== 'nclx') {\n break;\n }\n const colourPrimaries = readU16Be(slice);\n const transferCharacteristics = readU16Be(slice);\n const matrixCoefficients = readU16Be(slice);\n const fullRangeFlag = Boolean(readU8(slice) & 0x80);\n track.info.colorSpace = {\n primaries: COLOR_PRIMARIES_MAP_INVERSE[colourPrimaries],\n transfer: TRANSFER_CHARACTERISTICS_MAP_INVERSE[transferCharacteristics],\n matrix: MATRIX_COEFFICIENTS_MAP_INVERSE[matrixCoefficients],\n fullRange: fullRangeFlag,\n };\n }\n ;\n break;\n case 'wave':\n {\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n }\n ;\n break;\n case 'esds':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'audio');\n slice.skip(4); // Version + flags\n const tag = readU8(slice);\n assert(tag === 0x03); // ES Descriptor\n readIsomVariableInteger(slice); // Length\n slice.skip(2); // ES ID\n const mixed = readU8(slice);\n const streamDependenceFlag = (mixed & 0x80) !== 0;\n const urlFlag = (mixed & 0x40) !== 0;\n const ocrStreamFlag = (mixed & 0x20) !== 0;\n if (streamDependenceFlag) {\n slice.skip(2);\n }\n if (urlFlag) {\n const urlLength = readU8(slice);\n slice.skip(urlLength);\n }\n if (ocrStreamFlag) {\n slice.skip(2);\n }\n const decoderConfigTag = readU8(slice);\n assert(decoderConfigTag === 0x04); // DecoderConfigDescriptor\n const decoderConfigDescriptorLength = readIsomVariableInteger(slice); // Length\n const payloadStart = slice.filePos;\n const objectTypeIndication = readU8(slice);\n if (objectTypeIndication === 0x40 || objectTypeIndication === 0x67) {\n track.info.codec = 'aac';\n track.info.aacCodecInfo = { isMpeg2: objectTypeIndication === 0x67 };\n }\n else if (objectTypeIndication === 0x69 || objectTypeIndication === 0x6b) {\n track.info.codec = 'mp3';\n }\n else if (objectTypeIndication === 0xdd) {\n track.info.codec = 'vorbis'; // \"nonstandard, gpac uses it\" - FFmpeg\n }\n else {\n console.warn(`Unsupported audio codec (objectTypeIndication ${objectTypeIndication}) - discarding track.`);\n }\n slice.skip(1 + 3 + 4 + 4);\n if (decoderConfigDescriptorLength > slice.filePos - payloadStart) {\n // There's a DecoderSpecificInfo at the end, let's read it\n const decoderSpecificInfoTag = readU8(slice);\n assert(decoderSpecificInfoTag === 0x05); // DecoderSpecificInfo\n const decoderSpecificInfoLength = readIsomVariableInteger(slice);\n track.info.codecDescription = readBytes(slice, decoderSpecificInfoLength);\n if (track.info.codec === 'aac') {\n // Let's try to deduce more accurate values directly from the AudioSpecificConfig:\n const audioSpecificConfig = parseAacAudioSpecificConfig(track.info.codecDescription);\n if (audioSpecificConfig.numberOfChannels !== null) {\n track.info.numberOfChannels = audioSpecificConfig.numberOfChannels;\n }\n if (audioSpecificConfig.sampleRate !== null) {\n track.info.sampleRate = audioSpecificConfig.sampleRate;\n }\n }\n }\n }\n ;\n break;\n case 'enda':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'audio');\n const littleEndian = readU16Be(slice) & 0xff; // 0xff is from FFmpeg\n if (littleEndian) {\n if (track.info.codec === 'pcm-s16be') {\n track.info.codec = 'pcm-s16';\n }\n else if (track.info.codec === 'pcm-s24be') {\n track.info.codec = 'pcm-s24';\n }\n else if (track.info.codec === 'pcm-s32be') {\n track.info.codec = 'pcm-s32';\n }\n else if (track.info.codec === 'pcm-f32be') {\n track.info.codec = 'pcm-f32';\n }\n else if (track.info.codec === 'pcm-f64be') {\n track.info.codec = 'pcm-f64';\n }\n }\n }\n ;\n break;\n case 'pcmC':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'audio');\n slice.skip(1 + 3); // Version + flags\n // ISO/IEC 23003-5\n const formatFlags = readU8(slice);\n const isLittleEndian = Boolean(formatFlags & 0x01);\n const pcmSampleSize = readU8(slice);\n if (track.info.codec === 'pcm-s16be') {\n // ipcm\n if (isLittleEndian) {\n if (pcmSampleSize === 16) {\n track.info.codec = 'pcm-s16';\n }\n else if (pcmSampleSize === 24) {\n track.info.codec = 'pcm-s24';\n }\n else if (pcmSampleSize === 32) {\n track.info.codec = 'pcm-s32';\n }\n else {\n console.warn(`Invalid ipcm sample size ${pcmSampleSize}.`);\n track.info.codec = null;\n }\n }\n else {\n if (pcmSampleSize === 16) {\n track.info.codec = 'pcm-s16be';\n }\n else if (pcmSampleSize === 24) {\n track.info.codec = 'pcm-s24be';\n }\n else if (pcmSampleSize === 32) {\n track.info.codec = 'pcm-s32be';\n }\n else {\n console.warn(`Invalid ipcm sample size ${pcmSampleSize}.`);\n track.info.codec = null;\n }\n }\n }\n else if (track.info.codec === 'pcm-f32be') {\n // fpcm\n if (isLittleEndian) {\n if (pcmSampleSize === 32) {\n track.info.codec = 'pcm-f32';\n }\n else if (pcmSampleSize === 64) {\n track.info.codec = 'pcm-f64';\n }\n else {\n console.warn(`Invalid fpcm sample size ${pcmSampleSize}.`);\n track.info.codec = null;\n }\n }\n else {\n if (pcmSampleSize === 32) {\n track.info.codec = 'pcm-f32be';\n }\n else if (pcmSampleSize === 64) {\n track.info.codec = 'pcm-f64be';\n }\n else {\n console.warn(`Invalid fpcm sample size ${pcmSampleSize}.`);\n track.info.codec = null;\n }\n }\n }\n break;\n }\n ;\n case 'dOps':\n { // Used for Opus audio\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'audio');\n slice.skip(1); // Version\n // https://www.opus-codec.org/docs/opus_in_isobmff.html\n const outputChannelCount = readU8(slice);\n const preSkip = readU16Be(slice);\n const inputSampleRate = readU32Be(slice);\n const outputGain = readI16Be(slice);\n const channelMappingFamily = readU8(slice);\n let channelMappingTable;\n if (channelMappingFamily !== 0) {\n channelMappingTable = readBytes(slice, 2 + outputChannelCount);\n }\n else {\n channelMappingTable = new Uint8Array(0);\n }\n // https://datatracker.ietf.org/doc/html/draft-ietf-codec-oggopus-06\n const description = new Uint8Array(8 + 1 + 1 + 2 + 4 + 2 + 1 + channelMappingTable.byteLength);\n const view = new DataView(description.buffer);\n view.setUint32(0, 0x4f707573, false); // 'Opus'\n view.setUint32(4, 0x48656164, false); // 'Head'\n view.setUint8(8, 1); // Version\n view.setUint8(9, outputChannelCount);\n view.setUint16(10, preSkip, true);\n view.setUint32(12, inputSampleRate, true);\n view.setInt16(16, outputGain, true);\n view.setUint8(18, channelMappingFamily);\n description.set(channelMappingTable, 19);\n track.info.codecDescription = description;\n track.info.numberOfChannels = outputChannelCount;\n track.info.sampleRate = inputSampleRate;\n }\n ;\n break;\n case 'dfLa':\n { // Used for FLAC audio\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.info?.type === 'audio');\n slice.skip(4); // Version + flags\n // https://datatracker.ietf.org/doc/rfc9639/\n const BLOCK_TYPE_MASK = 0x7f;\n const LAST_METADATA_BLOCK_FLAG_MASK = 0x80;\n const startPos = slice.filePos;\n while (slice.filePos < boxEndPos) {\n const flagAndType = readU8(slice);\n const metadataBlockLength = readU24Be(slice);\n const type = flagAndType & BLOCK_TYPE_MASK;\n // It's a STREAMINFO block; let's extract the actual sample rate and channel count\n if (type === 0) {\n slice.skip(10);\n // Extract sample rate and channel count\n const word = readU32Be(slice);\n const sampleRate = word >>> 12;\n const numberOfChannels = ((word >> 9) & 0b111) + 1;\n track.info.sampleRate = sampleRate;\n track.info.numberOfChannels = numberOfChannels;\n slice.skip(20);\n }\n else {\n // Simply skip ahead to the next block\n slice.skip(metadataBlockLength);\n }\n if (flagAndType & LAST_METADATA_BLOCK_FLAG_MASK) {\n break;\n }\n }\n const endPos = slice.filePos;\n slice.filePos = startPos;\n const bytes = readBytes(slice, endPos - startPos);\n const description = new Uint8Array(4 + bytes.byteLength);\n const view = new DataView(description.buffer);\n view.setUint32(0, 0x664c6143, false); // 'fLaC'\n description.set(bytes, 4);\n // Set the codec description to be 'fLaC' + all metadata blocks\n track.info.codecDescription = description;\n }\n ;\n break;\n case 'stts':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4); // Version + flags\n const entryCount = readU32Be(slice);\n let currentIndex = 0;\n let currentTimestamp = 0;\n for (let i = 0; i < entryCount; i++) {\n const sampleCount = readU32Be(slice);\n const sampleDelta = readU32Be(slice);\n track.sampleTable.sampleTimingEntries.push({\n startIndex: currentIndex,\n startDecodeTimestamp: currentTimestamp,\n count: sampleCount,\n delta: sampleDelta,\n });\n currentIndex += sampleCount;\n currentTimestamp += sampleCount * sampleDelta;\n }\n }\n ;\n break;\n case 'ctts':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(1 + 3); // Version + flags\n const entryCount = readU32Be(slice);\n let sampleIndex = 0;\n for (let i = 0; i < entryCount; i++) {\n const sampleCount = readU32Be(slice);\n const sampleOffset = readI32Be(slice);\n track.sampleTable.sampleCompositionTimeOffsets.push({\n startIndex: sampleIndex,\n count: sampleCount,\n offset: sampleOffset,\n });\n sampleIndex += sampleCount;\n }\n }\n ;\n break;\n case 'stsz':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4); // Version + flags\n const sampleSize = readU32Be(slice);\n const sampleCount = readU32Be(slice);\n if (sampleSize === 0) {\n for (let i = 0; i < sampleCount; i++) {\n const sampleSize = readU32Be(slice);\n track.sampleTable.sampleSizes.push(sampleSize);\n }\n }\n else {\n track.sampleTable.sampleSizes.push(sampleSize);\n }\n }\n ;\n break;\n case 'stz2':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4); // Version + flags\n slice.skip(3); // Reserved\n const fieldSize = readU8(slice); // in bits\n const sampleCount = readU32Be(slice);\n const bytes = readBytes(slice, Math.ceil(sampleCount * fieldSize / 8));\n const bitstream = new Bitstream(bytes);\n for (let i = 0; i < sampleCount; i++) {\n const sampleSize = bitstream.readBits(fieldSize);\n track.sampleTable.sampleSizes.push(sampleSize);\n }\n }\n ;\n break;\n case 'stss':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4); // Version + flags\n track.sampleTable.keySampleIndices = [];\n const entryCount = readU32Be(slice);\n for (let i = 0; i < entryCount; i++) {\n const sampleIndex = readU32Be(slice) - 1; // Convert to 0-indexed\n track.sampleTable.keySampleIndices.push(sampleIndex);\n }\n if (track.sampleTable.keySampleIndices[0] !== 0) {\n // Some files don't mark the first sample a key sample, which is basically almost always incorrect.\n // Here, we correct for that mistake:\n track.sampleTable.keySampleIndices.unshift(0);\n }\n }\n ;\n break;\n case 'stsc':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4);\n const entryCount = readU32Be(slice);\n for (let i = 0; i < entryCount; i++) {\n const startChunkIndex = readU32Be(slice) - 1; // Convert to 0-indexed\n const samplesPerChunk = readU32Be(slice);\n const sampleDescriptionIndex = readU32Be(slice);\n track.sampleTable.sampleToChunk.push({\n startSampleIndex: -1,\n startChunkIndex,\n samplesPerChunk,\n sampleDescriptionIndex,\n });\n }\n let startSampleIndex = 0;\n for (let i = 0; i < track.sampleTable.sampleToChunk.length; i++) {\n track.sampleTable.sampleToChunk[i].startSampleIndex = startSampleIndex;\n if (i < track.sampleTable.sampleToChunk.length - 1) {\n const nextChunk = track.sampleTable.sampleToChunk[i + 1];\n const chunkCount = nextChunk.startChunkIndex\n - track.sampleTable.sampleToChunk[i].startChunkIndex;\n startSampleIndex += chunkCount * track.sampleTable.sampleToChunk[i].samplesPerChunk;\n }\n }\n }\n ;\n break;\n case 'stco':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4); // Version + flags\n const entryCount = readU32Be(slice);\n for (let i = 0; i < entryCount; i++) {\n const chunkOffset = readU32Be(slice);\n track.sampleTable.chunkOffsets.push(chunkOffset);\n }\n }\n ;\n break;\n case 'co64':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n if (!track.sampleTable) {\n break;\n }\n slice.skip(4); // Version + flags\n const entryCount = readU32Be(slice);\n for (let i = 0; i < entryCount; i++) {\n const chunkOffset = readU64Be(slice);\n track.sampleTable.chunkOffsets.push(chunkOffset);\n }\n }\n ;\n break;\n case 'mvex':\n {\n this.isFragmented = true;\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n }\n ;\n break;\n case 'mehd':\n {\n const version = readU8(slice);\n slice.skip(3); // Flags\n const fragmentDuration = version === 1 ? readU64Be(slice) : readU32Be(slice);\n this.movieDurationInTimescale = fragmentDuration;\n }\n ;\n break;\n case 'trex':\n {\n slice.skip(4); // Version + flags\n const trackId = readU32Be(slice);\n const defaultSampleDescriptionIndex = readU32Be(slice);\n const defaultSampleDuration = readU32Be(slice);\n const defaultSampleSize = readU32Be(slice);\n const defaultSampleFlags = readU32Be(slice);\n // We store these separately rather than in the tracks since the tracks may not exist yet\n this.fragmentTrackDefaults.push({\n trackId,\n defaultSampleDescriptionIndex,\n defaultSampleDuration,\n defaultSampleSize,\n defaultSampleFlags,\n });\n }\n ;\n break;\n case 'tfra':\n {\n const version = readU8(slice);\n slice.skip(3); // Flags\n const trackId = readU32Be(slice);\n const track = this.tracks.find(x => x.id === trackId);\n if (!track) {\n break;\n }\n track.fragmentLookupTable = [];\n const word = readU32Be(slice);\n const lengthSizeOfTrafNum = (word & 0b110000) >> 4;\n const lengthSizeOfTrunNum = (word & 0b001100) >> 2;\n const lengthSizeOfSampleNum = word & 0b000011;\n const functions = [readU8, readU16Be, readU24Be, readU32Be];\n const readTrafNum = functions[lengthSizeOfTrafNum];\n const readTrunNum = functions[lengthSizeOfTrunNum];\n const readSampleNum = functions[lengthSizeOfSampleNum];\n const numberOfEntries = readU32Be(slice);\n for (let i = 0; i < numberOfEntries; i++) {\n const time = version === 1 ? readU64Be(slice) : readU32Be(slice);\n const moofOffset = version === 1 ? readU64Be(slice) : readU32Be(slice);\n readTrafNum(slice);\n readTrunNum(slice);\n readSampleNum(slice);\n track.fragmentLookupTable.push({\n timestamp: time,\n moofOffset,\n });\n }\n }\n ;\n break;\n case 'moof':\n {\n this.currentFragment = {\n moofOffset: startPos,\n moofSize: boxInfo.totalSize,\n implicitBaseDataOffset: startPos,\n trackData: new Map(),\n dataStart: Infinity,\n dataEnd: 0,\n nextFragment: null,\n isKnownToBeFirstFragment: false,\n };\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n insertSorted(this.fragments, this.currentFragment, x => x.moofOffset);\n // Compute the byte range of the sample data in this fragment, so we can load the whole fragment at once\n for (const [, trackData] of this.currentFragment.trackData) {\n const firstSample = trackData.samples[0];\n const lastSample = last(trackData.samples);\n this.currentFragment.dataStart = Math.min(this.currentFragment.dataStart, firstSample.byteOffset);\n this.currentFragment.dataEnd = Math.max(this.currentFragment.dataEnd, lastSample.byteOffset + lastSample.byteSize);\n }\n this.currentFragment = null;\n }\n ;\n break;\n case 'traf':\n {\n assert(this.currentFragment);\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n // It is possible that there is no current track, for example when we don't care about the track\n // referenced in the track fragment header.\n if (this.currentTrack) {\n const trackData = this.currentFragment.trackData.get(this.currentTrack.id);\n if (trackData) {\n // We know there is sample data for this track in this fragment, so let's add it to the\n // track's fragments:\n insertSorted(this.currentTrack.fragments, this.currentFragment, x => x.moofOffset);\n const hasKeyFrame = trackData.firstKeyFrameTimestamp !== null;\n if (hasKeyFrame) {\n insertSorted(this.currentTrack.fragmentsWithKeyFrame, this.currentFragment, x => x.moofOffset);\n }\n const { currentFragmentState } = this.currentTrack;\n assert(currentFragmentState);\n if (currentFragmentState.startTimestamp !== null) {\n offsetFragmentTrackDataByTimestamp(trackData, currentFragmentState.startTimestamp);\n trackData.startTimestampIsFinal = true;\n }\n }\n this.currentTrack.currentFragmentState = null;\n this.currentTrack = null;\n }\n }\n ;\n break;\n case 'tfhd':\n {\n assert(this.currentFragment);\n slice.skip(1); // Version\n const flags = readU24Be(slice);\n const baseDataOffsetPresent = Boolean(flags & 0x000001);\n const sampleDescriptionIndexPresent = Boolean(flags & 0x000002);\n const defaultSampleDurationPresent = Boolean(flags & 0x000008);\n const defaultSampleSizePresent = Boolean(flags & 0x000010);\n const defaultSampleFlagsPresent = Boolean(flags & 0x000020);\n const durationIsEmpty = Boolean(flags & 0x010000);\n const defaultBaseIsMoof = Boolean(flags & 0x020000);\n const trackId = readU32Be(slice);\n const track = this.tracks.find(x => x.id === trackId);\n if (!track) {\n // We don't care about this track\n break;\n }\n const defaults = this.fragmentTrackDefaults.find(x => x.trackId === trackId);\n this.currentTrack = track;\n track.currentFragmentState = {\n baseDataOffset: this.currentFragment.implicitBaseDataOffset,\n sampleDescriptionIndex: defaults?.defaultSampleDescriptionIndex ?? null,\n defaultSampleDuration: defaults?.defaultSampleDuration ?? null,\n defaultSampleSize: defaults?.defaultSampleSize ?? null,\n defaultSampleFlags: defaults?.defaultSampleFlags ?? null,\n startTimestamp: null,\n };\n if (baseDataOffsetPresent) {\n track.currentFragmentState.baseDataOffset = readU64Be(slice);\n }\n else if (defaultBaseIsMoof) {\n track.currentFragmentState.baseDataOffset = this.currentFragment.moofOffset;\n }\n if (sampleDescriptionIndexPresent) {\n track.currentFragmentState.sampleDescriptionIndex = readU32Be(slice);\n }\n if (defaultSampleDurationPresent) {\n track.currentFragmentState.defaultSampleDuration = readU32Be(slice);\n }\n if (defaultSampleSizePresent) {\n track.currentFragmentState.defaultSampleSize = readU32Be(slice);\n }\n if (defaultSampleFlagsPresent) {\n track.currentFragmentState.defaultSampleFlags = readU32Be(slice);\n }\n if (durationIsEmpty) {\n track.currentFragmentState.defaultSampleDuration = 0;\n }\n }\n ;\n break;\n case 'tfdt':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(track.currentFragmentState);\n const version = readU8(slice);\n slice.skip(3); // Flags\n const baseMediaDecodeTime = version === 0 ? readU32Be(slice) : readU64Be(slice);\n track.currentFragmentState.startTimestamp = baseMediaDecodeTime;\n }\n ;\n break;\n case 'trun':\n {\n const track = this.currentTrack;\n if (!track) {\n break;\n }\n assert(this.currentFragment);\n assert(track.currentFragmentState);\n if (this.currentFragment.trackData.has(track.id)) {\n console.warn('Can\\'t have two trun boxes for the same track in one fragment. Ignoring...');\n break;\n }\n const version = readU8(slice);\n const flags = readU24Be(slice);\n const dataOffsetPresent = Boolean(flags & 0x000001);\n const firstSampleFlagsPresent = Boolean(flags & 0x000004);\n const sampleDurationPresent = Boolean(flags & 0x000100);\n const sampleSizePresent = Boolean(flags & 0x000200);\n const sampleFlagsPresent = Boolean(flags & 0x000400);\n const sampleCompositionTimeOffsetsPresent = Boolean(flags & 0x000800);\n const sampleCount = readU32Be(slice);\n let dataOffset = track.currentFragmentState.baseDataOffset;\n if (dataOffsetPresent) {\n dataOffset += readI32Be(slice);\n }\n let firstSampleFlags = null;\n if (firstSampleFlagsPresent) {\n firstSampleFlags = readU32Be(slice);\n }\n let currentOffset = dataOffset;\n if (sampleCount === 0) {\n // Don't associate the fragment with the track if it has no samples, this simplifies other code\n this.currentFragment.implicitBaseDataOffset = currentOffset;\n break;\n }\n let currentTimestamp = 0;\n const trackData = {\n startTimestamp: 0,\n endTimestamp: 0,\n firstKeyFrameTimestamp: null,\n samples: [],\n presentationTimestamps: [],\n startTimestampIsFinal: false,\n };\n this.currentFragment.trackData.set(track.id, trackData);\n for (let i = 0; i < sampleCount; i++) {\n let sampleDuration;\n if (sampleDurationPresent) {\n sampleDuration = readU32Be(slice);\n }\n else {\n assert(track.currentFragmentState.defaultSampleDuration !== null);\n sampleDuration = track.currentFragmentState.defaultSampleDuration;\n }\n let sampleSize;\n if (sampleSizePresent) {\n sampleSize = readU32Be(slice);\n }\n else {\n assert(track.currentFragmentState.defaultSampleSize !== null);\n sampleSize = track.currentFragmentState.defaultSampleSize;\n }\n let sampleFlags;\n if (sampleFlagsPresent) {\n sampleFlags = readU32Be(slice);\n }\n else {\n assert(track.currentFragmentState.defaultSampleFlags !== null);\n sampleFlags = track.currentFragmentState.defaultSampleFlags;\n }\n if (i === 0 && firstSampleFlags !== null) {\n sampleFlags = firstSampleFlags;\n }\n let sampleCompositionTimeOffset = 0;\n if (sampleCompositionTimeOffsetsPresent) {\n if (version === 0) {\n sampleCompositionTimeOffset = readU32Be(slice);\n }\n else {\n sampleCompositionTimeOffset = readI32Be(slice);\n }\n }\n const isKeyFrame = !(sampleFlags & 0x00010000);\n trackData.samples.push({\n presentationTimestamp: currentTimestamp + sampleCompositionTimeOffset,\n duration: sampleDuration,\n byteOffset: currentOffset,\n byteSize: sampleSize,\n isKeyFrame,\n });\n currentOffset += sampleSize;\n currentTimestamp += sampleDuration;\n }\n trackData.presentationTimestamps = trackData.samples\n .map((x, i) => ({ presentationTimestamp: x.presentationTimestamp, sampleIndex: i }))\n .sort((a, b) => a.presentationTimestamp - b.presentationTimestamp);\n for (let i = 0; i < trackData.presentationTimestamps.length; i++) {\n const currentEntry = trackData.presentationTimestamps[i];\n const currentSample = trackData.samples[currentEntry.sampleIndex];\n if (trackData.firstKeyFrameTimestamp === null && currentSample.isKeyFrame) {\n trackData.firstKeyFrameTimestamp = currentSample.presentationTimestamp;\n }\n if (i < trackData.presentationTimestamps.length - 1) {\n // Update sample durations based on presentation order\n const nextEntry = trackData.presentationTimestamps[i + 1];\n currentSample.duration = nextEntry.presentationTimestamp - currentEntry.presentationTimestamp;\n }\n }\n const firstSample = trackData.samples[trackData.presentationTimestamps[0].sampleIndex];\n const lastSample = trackData.samples[last(trackData.presentationTimestamps).sampleIndex];\n trackData.startTimestamp = firstSample.presentationTimestamp;\n trackData.endTimestamp = lastSample.presentationTimestamp + lastSample.duration;\n this.currentFragment.implicitBaseDataOffset = currentOffset;\n }\n ;\n break;\n // Metadata section\n // https://exiftool.org/TagNames/QuickTime.html\n // https://mp4workshop.com/about\n case 'udta':\n { // Contains either movie metadata or track metadata\n const iterator = this.iterateContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n for (const { boxInfo, slice } of iterator) {\n if (boxInfo.name !== 'meta' && !this.currentTrack) {\n const startPos = slice.filePos;\n this.metadataTags.raw ??= {};\n if (UDTA_STRING_KEYS.has(boxInfo.name)) {\n this.metadataTags.raw[boxInfo.name] ??= readMetadataStringShort(slice);\n }\n else {\n this.metadataTags.raw[boxInfo.name] ??= readBytes(slice, boxInfo.contentSize);\n }\n slice.filePos = startPos;\n }\n switch (boxInfo.name) {\n case 'meta':\n {\n slice.skip(-boxInfo.headerSize);\n this.traverseBox(slice);\n }\n ;\n break;\n case '\u00A9nam':\n case 'name':\n {\n if (this.currentTrack) {\n this.currentTrack.name = textDecoder.decode(readBytes(slice, boxInfo.contentSize));\n }\n else {\n this.metadataTags.title ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case '\u00A9des':\n {\n if (!this.currentTrack) {\n this.metadataTags.description ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case '\u00A9ART':\n {\n if (!this.currentTrack) {\n this.metadataTags.artist ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case '\u00A9alb':\n {\n if (!this.currentTrack) {\n this.metadataTags.album ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case 'albr':\n {\n if (!this.currentTrack) {\n this.metadataTags.albumArtist ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case '\u00A9gen':\n {\n if (!this.currentTrack) {\n this.metadataTags.genre ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case '\u00A9day':\n {\n if (!this.currentTrack) {\n const date = new Date(readMetadataStringShort(slice));\n if (!Number.isNaN(date.getTime())) {\n this.metadataTags.date ??= date;\n }\n }\n }\n ;\n break;\n case '\u00A9cmt':\n {\n if (!this.currentTrack) {\n this.metadataTags.comment ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n case '\u00A9lyr':\n {\n if (!this.currentTrack) {\n this.metadataTags.lyrics ??= readMetadataStringShort(slice);\n }\n }\n ;\n break;\n }\n }\n }\n ;\n break;\n case 'meta':\n {\n if (this.currentTrack) {\n break; // Only care about movie-level metadata for now\n }\n // The 'meta' box comes in two flavors, one with flags/version and one without. To know which is which,\n // let's read the next 4 bytes, which are either the version or the size of the first subbox.\n const word = readU32Be(slice);\n const isQuickTime = word !== 0;\n this.currentMetadataKeys = new Map();\n if (isQuickTime) {\n this.readContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n }\n else {\n this.readContiguousBoxes(slice.slice(contentStartPos + 4, boxInfo.contentSize - 4));\n }\n this.currentMetadataKeys = null;\n }\n ;\n break;\n case 'keys':\n {\n if (!this.currentMetadataKeys) {\n break;\n }\n slice.skip(4); // Version + flags\n const entryCount = readU32Be(slice);\n for (let i = 0; i < entryCount; i++) {\n const keySize = readU32Be(slice);\n slice.skip(4); // Key namespace\n const keyName = textDecoder.decode(readBytes(slice, keySize - 8));\n this.currentMetadataKeys.set(i + 1, keyName);\n }\n }\n ;\n break;\n case 'ilst':\n {\n if (!this.currentMetadataKeys) {\n break;\n }\n const iterator = this.iterateContiguousBoxes(slice.slice(contentStartPos, boxInfo.contentSize));\n for (const { boxInfo, slice } of iterator) {\n let metadataKey = boxInfo.name;\n // Interpret the box name as a u32be\n const nameAsNumber = (metadataKey.charCodeAt(0) << 24)\n + (metadataKey.charCodeAt(1) << 16)\n + (metadataKey.charCodeAt(2) << 8)\n + metadataKey.charCodeAt(3);\n if (this.currentMetadataKeys.has(nameAsNumber)) {\n // An entry exists for this number\n metadataKey = this.currentMetadataKeys.get(nameAsNumber);\n }\n const data = readDataBox(slice);\n this.metadataTags.raw ??= {};\n this.metadataTags.raw[metadataKey] ??= data;\n switch (metadataKey) {\n case '\u00A9nam':\n case 'titl':\n case 'com.apple.quicktime.title':\n case 'title':\n {\n if (typeof data === 'string') {\n this.metadataTags.title ??= data;\n }\n }\n ;\n break;\n case '\u00A9des':\n case 'desc':\n case 'dscp':\n case 'com.apple.quicktime.description':\n case 'description':\n {\n if (typeof data === 'string') {\n this.metadataTags.description ??= data;\n }\n }\n ;\n break;\n case '\u00A9ART':\n case 'com.apple.quicktime.artist':\n case 'artist':\n {\n if (typeof data === 'string') {\n this.metadataTags.artist ??= data;\n }\n }\n ;\n break;\n case '\u00A9alb':\n case 'albm':\n case 'com.apple.quicktime.album':\n case 'album':\n {\n if (typeof data === 'string') {\n this.metadataTags.album ??= data;\n }\n }\n ;\n break;\n case 'aART':\n case 'album_artist':\n {\n if (typeof data === 'string') {\n this.metadataTags.albumArtist ??= data;\n }\n }\n ;\n break;\n case '\u00A9cmt':\n case 'com.apple.quicktime.comment':\n case 'comment':\n {\n if (typeof data === 'string') {\n this.metadataTags.comment ??= data;\n }\n }\n ;\n break;\n case '\u00A9gen':\n case 'gnre':\n case 'com.apple.quicktime.genre':\n case 'genre':\n {\n if (typeof data === 'string') {\n this.metadataTags.genre ??= data;\n }\n }\n ;\n break;\n case '\u00A9lyr':\n case 'lyrics':\n {\n if (typeof data === 'string') {\n this.metadataTags.lyrics ??= data;\n }\n }\n ;\n break;\n case '\u00A9day':\n case 'rldt':\n case 'com.apple.quicktime.creationdate':\n case 'date':\n {\n if (typeof data === 'string') {\n const date = new Date(data);\n if (!Number.isNaN(date.getTime())) {\n this.metadataTags.date ??= date;\n }\n }\n }\n ;\n break;\n case 'covr':\n case 'com.apple.quicktime.artwork':\n {\n if (data instanceof RichImageData) {\n this.metadataTags.images ??= [];\n this.metadataTags.images.push({\n data: data.data,\n kind: 'coverFront',\n mimeType: data.mimeType,\n });\n }\n else if (data instanceof Uint8Array) {\n this.metadataTags.images ??= [];\n this.metadataTags.images.push({\n data,\n kind: 'coverFront',\n mimeType: 'image/*',\n });\n }\n }\n ;\n break;\n case 'trkn':\n {\n if (data instanceof Uint8Array) {\n const view = toDataView(data);\n const trackNumber = view.getUint16(2, false);\n const tracksTotal = view.getUint16(4, false);\n if (trackNumber > 0) {\n this.metadataTags.trackNumber ??= trackNumber;\n }\n if (tracksTotal > 0) {\n this.metadataTags.tracksTotal ??= tracksTotal;\n }\n }\n }\n ;\n break;\n case 'disc':\n case 'disk':\n {\n if (data instanceof Uint8Array) {\n const view = toDataView(data);\n const discNumber = view.getUint16(2, false);\n const discNumberMax = view.getUint16(4, false);\n if (discNumber > 0) {\n this.metadataTags.discNumber ??= discNumber;\n }\n if (discNumberMax > 0) {\n this.metadataTags.discsTotal ??= discNumberMax;\n }\n }\n }\n ;\n break;\n }\n }\n }\n ;\n break;\n }\n slice.filePos = boxEndPos;\n return true;\n }\n}\nclass IsobmffTrackBacking {\n constructor(internalTrack) {\n this.internalTrack = internalTrack;\n this.packetToSampleIndex = new WeakMap();\n this.packetToFragmentLocation = new WeakMap();\n }\n getId() {\n return this.internalTrack.id;\n }\n getCodec() {\n throw new Error('Not implemented on base class.');\n }\n getInternalCodecId() {\n return this.internalTrack.internalCodecId;\n }\n getName() {\n return this.internalTrack.name;\n }\n getLanguageCode() {\n return this.internalTrack.languageCode;\n }\n getTimeResolution() {\n return this.internalTrack.timescale;\n }\n async computeDuration() {\n const lastPacket = await this.getPacket(Infinity, { metadataOnly: true });\n return (lastPacket?.timestamp ?? 0) + (lastPacket?.duration ?? 0);\n }\n async getFirstTimestamp() {\n const firstPacket = await this.getFirstPacket({ metadataOnly: true });\n return firstPacket?.timestamp ?? 0;\n }\n async getFirstPacket(options) {\n const regularPacket = await this.fetchPacketForSampleIndex(0, options);\n if (regularPacket || !this.internalTrack.demuxer.isFragmented) {\n // If there's a non-fragmented packet, always prefer that\n return regularPacket;\n }\n return this.performFragmentedLookup(() => {\n const startFragment = this.internalTrack.demuxer.fragments[0] ?? null;\n if (startFragment?.isKnownToBeFirstFragment) {\n // Walk from the very first fragment in the file until we find one with our track in it\n let currentFragment = startFragment;\n while (currentFragment) {\n const trackData = currentFragment.trackData.get(this.internalTrack.id);\n if (trackData) {\n return {\n fragmentIndex: binarySearchExact(this.internalTrack.fragments, currentFragment.moofOffset, x => x.moofOffset),\n sampleIndex: 0,\n correctSampleFound: true,\n };\n }\n currentFragment = currentFragment.nextFragment;\n }\n }\n return {\n fragmentIndex: -1,\n sampleIndex: -1,\n correctSampleFound: false,\n };\n }, -Infinity, // Use -Infinity as a search timestamp to avoid using the lookup entries\n Infinity, options);\n }\n mapTimestampIntoTimescale(timestamp) {\n // Do a little rounding to catch cases where the result is very close to an integer. If it is, it's likely\n // that the number was originally an integer divided by the timescale. For stability, it's best\n // to return the integer in this case.\n return roundToPrecision(timestamp * this.internalTrack.timescale, 14) + this.internalTrack.editListOffset;\n }\n async getPacket(timestamp, options) {\n const timestampInTimescale = this.mapTimestampIntoTimescale(timestamp);\n const sampleTable = this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack);\n const sampleIndex = getSampleIndexForTimestamp(sampleTable, timestampInTimescale);\n const regularPacket = await this.fetchPacketForSampleIndex(sampleIndex, options);\n if (!sampleTableIsEmpty(sampleTable) || !this.internalTrack.demuxer.isFragmented) {\n // Prefer the non-fragmented packet\n return regularPacket;\n }\n return this.performFragmentedLookup(() => this.findSampleInFragmentsForTimestamp(timestampInTimescale), timestampInTimescale, timestampInTimescale, options);\n }\n async getNextPacket(packet, options) {\n const regularSampleIndex = this.packetToSampleIndex.get(packet);\n if (regularSampleIndex !== undefined) {\n // Prefer the non-fragmented packet\n return this.fetchPacketForSampleIndex(regularSampleIndex + 1, options);\n }\n const locationInFragment = this.packetToFragmentLocation.get(packet);\n if (locationInFragment === undefined) {\n throw new Error('Packet was not created from this track.');\n }\n const trackData = locationInFragment.fragment.trackData.get(this.internalTrack.id);\n const fragmentIndex = binarySearchExact(this.internalTrack.fragments, locationInFragment.fragment.moofOffset, x => x.moofOffset);\n assert(fragmentIndex !== -1);\n return this.performFragmentedLookup(() => {\n if (locationInFragment.sampleIndex + 1 < trackData.samples.length) {\n // We can simply take the next sample in the fragment\n return {\n fragmentIndex,\n sampleIndex: locationInFragment.sampleIndex + 1,\n correctSampleFound: true,\n };\n }\n else {\n // Walk the list of fragments until we find the next fragment for this track\n let currentFragment = locationInFragment.fragment;\n while (currentFragment.nextFragment) {\n currentFragment = currentFragment.nextFragment;\n const trackData = currentFragment.trackData.get(this.internalTrack.id);\n if (trackData) {\n const fragmentIndex = binarySearchExact(this.internalTrack.fragments, currentFragment.moofOffset, x => x.moofOffset);\n assert(fragmentIndex !== -1);\n return {\n fragmentIndex,\n sampleIndex: 0,\n correctSampleFound: true,\n };\n }\n }\n return {\n fragmentIndex,\n sampleIndex: -1,\n correctSampleFound: false,\n };\n }\n }, -Infinity, // Use -Infinity as a search timestamp to avoid using the lookup entries\n Infinity, options);\n }\n async getKeyPacket(timestamp, options) {\n const timestampInTimescale = this.mapTimestampIntoTimescale(timestamp);\n const sampleTable = this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack);\n const sampleIndex = getSampleIndexForTimestamp(sampleTable, timestampInTimescale);\n const keyFrameSampleIndex = sampleIndex === -1\n ? -1\n : getRelevantKeyframeIndexForSample(sampleTable, sampleIndex);\n const regularPacket = await this.fetchPacketForSampleIndex(keyFrameSampleIndex, options);\n if (!sampleTableIsEmpty(sampleTable) || !this.internalTrack.demuxer.isFragmented) {\n // Prefer the non-fragmented packet\n return regularPacket;\n }\n return this.performFragmentedLookup(() => this.findKeySampleInFragmentsForTimestamp(timestampInTimescale), timestampInTimescale, timestampInTimescale, options);\n }\n async getNextKeyPacket(packet, options) {\n const regularSampleIndex = this.packetToSampleIndex.get(packet);\n if (regularSampleIndex !== undefined) {\n // Prefer the non-fragmented packet\n const sampleTable = this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack);\n const nextKeyFrameSampleIndex = getNextKeyframeIndexForSample(sampleTable, regularSampleIndex);\n return this.fetchPacketForSampleIndex(nextKeyFrameSampleIndex, options);\n }\n const locationInFragment = this.packetToFragmentLocation.get(packet);\n if (locationInFragment === undefined) {\n throw new Error('Packet was not created from this track.');\n }\n const trackData = locationInFragment.fragment.trackData.get(this.internalTrack.id);\n const fragmentIndex = binarySearchExact(this.internalTrack.fragments, locationInFragment.fragment.moofOffset, x => x.moofOffset);\n assert(fragmentIndex !== -1);\n return this.performFragmentedLookup(() => {\n const nextKeyFrameIndex = trackData.samples.findIndex((x, i) => x.isKeyFrame && i > locationInFragment.sampleIndex);\n if (nextKeyFrameIndex !== -1) {\n // We can simply take the next key frame in the fragment\n return {\n fragmentIndex,\n sampleIndex: nextKeyFrameIndex,\n correctSampleFound: true,\n };\n }\n else {\n // Walk the list of fragments until we find the next fragment for this track with a key frame\n let currentFragment = locationInFragment.fragment;\n while (currentFragment.nextFragment) {\n currentFragment = currentFragment.nextFragment;\n const trackData = currentFragment.trackData.get(this.internalTrack.id);\n if (trackData && trackData.firstKeyFrameTimestamp !== null) {\n const fragmentIndex = binarySearchExact(this.internalTrack.fragments, currentFragment.moofOffset, x => x.moofOffset);\n assert(fragmentIndex !== -1);\n const keyFrameIndex = trackData.samples.findIndex(x => x.isKeyFrame);\n assert(keyFrameIndex !== -1); // There must be one\n return {\n fragmentIndex,\n sampleIndex: keyFrameIndex,\n correctSampleFound: true,\n };\n }\n }\n return {\n fragmentIndex,\n sampleIndex: -1,\n correctSampleFound: false,\n };\n }\n }, -Infinity, // Use -Infinity as a search timestamp to avoid using the lookup entries\n Infinity, options);\n }\n async fetchPacketForSampleIndex(sampleIndex, options) {\n if (sampleIndex === -1) {\n return null;\n }\n const sampleTable = this.internalTrack.demuxer.getSampleTableForTrack(this.internalTrack);\n const sampleInfo = getSampleInfo(sampleTable, sampleIndex);\n if (!sampleInfo) {\n return null;\n }\n let data;\n if (options.metadataOnly) {\n data = PLACEHOLDER_DATA;\n }\n else {\n let slice = this.internalTrack.demuxer.reader.requestSlice(sampleInfo.sampleOffset, sampleInfo.sampleSize);\n if (slice instanceof Promise)\n slice = await slice;\n assert(slice);\n data = readBytes(slice, sampleInfo.sampleSize);\n }\n const timestamp = (sampleInfo.presentationTimestamp - this.internalTrack.editListOffset)\n / this.internalTrack.timescale;\n const duration = sampleInfo.duration / this.internalTrack.timescale;\n const packet = new EncodedPacket(data, sampleInfo.isKeyFrame ? 'key' : 'delta', timestamp, duration, sampleIndex, sampleInfo.sampleSize);\n this.packetToSampleIndex.set(packet, sampleIndex);\n return packet;\n }\n async fetchPacketInFragment(fragment, sampleIndex, options) {\n if (sampleIndex === -1) {\n return null;\n }\n const trackData = fragment.trackData.get(this.internalTrack.id);\n const fragmentSample = trackData.samples[sampleIndex];\n assert(fragmentSample);\n let data;\n if (options.metadataOnly) {\n data = PLACEHOLDER_DATA;\n }\n else {\n let slice = this.internalTrack.demuxer.reader.requestSlice(fragmentSample.byteOffset, fragmentSample.byteSize);\n if (slice instanceof Promise)\n slice = await slice;\n assert(slice);\n data = readBytes(slice, fragmentSample.byteSize);\n }\n const timestamp = (fragmentSample.presentationTimestamp - this.internalTrack.editListOffset)\n / this.internalTrack.timescale;\n const duration = fragmentSample.duration / this.internalTrack.timescale;\n const packet = new EncodedPacket(data, fragmentSample.isKeyFrame ? 'key' : 'delta', timestamp, duration, fragment.moofOffset + sampleIndex, fragmentSample.byteSize);\n this.packetToFragmentLocation.set(packet, { fragment, sampleIndex });\n return packet;\n }\n findSampleInFragmentsForTimestamp(timestampInTimescale) {\n const fragmentIndex = binarySearchLessOrEqual(\n // This array is technically not sorted by start timestamp, but for any reasonable file, it basically is.\n this.internalTrack.fragments, timestampInTimescale, x => x.trackData.get(this.internalTrack.id).startTimestamp);\n let sampleIndex = -1;\n let correctSampleFound = false;\n if (fragmentIndex !== -1) {\n const fragment = this.internalTrack.fragments[fragmentIndex];\n const trackData = fragment.trackData.get(this.internalTrack.id);\n const index = binarySearchLessOrEqual(trackData.presentationTimestamps, timestampInTimescale, x => x.presentationTimestamp);\n assert(index !== -1);\n sampleIndex = trackData.presentationTimestamps[index].sampleIndex;\n correctSampleFound = timestampInTimescale < trackData.endTimestamp;\n }\n return { fragmentIndex, sampleIndex, correctSampleFound };\n }\n findKeySampleInFragmentsForTimestamp(timestampInTimescale) {\n const indexInKeyFrameFragments = binarySearchLessOrEqual(\n // This array is technically not sorted by start timestamp, but for any reasonable file, it basically is.\n this.internalTrack.fragmentsWithKeyFrame, timestampInTimescale, x => x.trackData.get(this.internalTrack.id).startTimestamp);\n let fragmentIndex = -1;\n let sampleIndex = -1;\n let correctSampleFound = false;\n if (indexInKeyFrameFragments !== -1) {\n const fragment = this.internalTrack.fragmentsWithKeyFrame[indexInKeyFrameFragments];\n // Now, let's find the actual index of the fragment in the list of ALL fragments, not just key frame ones\n fragmentIndex = binarySearchExact(this.internalTrack.fragments, fragment.moofOffset, x => x.moofOffset);\n assert(fragmentIndex !== -1);\n const trackData = fragment.trackData.get(this.internalTrack.id);\n const index = findLastIndex(trackData.presentationTimestamps, (x) => {\n const sample = trackData.samples[x.sampleIndex];\n return sample.isKeyFrame && x.presentationTimestamp <= timestampInTimescale;\n });\n assert(index !== -1); // It's a key frame fragment, so there must be a key frame\n const entry = trackData.presentationTimestamps[index];\n sampleIndex = entry.sampleIndex;\n correctSampleFound = timestampInTimescale < trackData.endTimestamp;\n }\n return { fragmentIndex, sampleIndex, correctSampleFound };\n }\n /** Looks for a packet in the fragments while trying to load as few fragments as possible to retrieve it. */\n async performFragmentedLookup(\n // This function returns the best-matching sample that is currently loaded. Based on this information, we know\n // which fragments we need to load to find the actual match.\n getBestMatch, \n // The timestamp with which we can search the lookup table\n searchTimestamp, \n // The timestamp for which we know the correct sample will not come after it\n latestTimestamp, options) {\n const demuxer = this.internalTrack.demuxer;\n const release = await demuxer.fragmentLookupMutex.acquire(); // The algorithm requires exclusivity\n try {\n const { fragmentIndex, sampleIndex, correctSampleFound } = getBestMatch();\n if (correctSampleFound) {\n // The correct sample already exists, easy path.\n const fragment = this.internalTrack.fragments[fragmentIndex];\n return this.fetchPacketInFragment(fragment, sampleIndex, options);\n }\n let prevFragment = null;\n let bestFragmentIndex = fragmentIndex;\n let bestSampleIndex = sampleIndex;\n // Search for a lookup entry; this way, we won't need to start searching from the start of the file\n // but can jump right into the correct fragment (or at least nearby).\n const lookupEntryIndex = this.internalTrack.fragmentLookupTable\n ? binarySearchLessOrEqual(this.internalTrack.fragmentLookupTable, searchTimestamp, x => x.timestamp)\n : -1;\n const lookupEntry = lookupEntryIndex !== -1\n ? this.internalTrack.fragmentLookupTable[lookupEntryIndex]\n : null;\n let currentPos;\n let nextFragmentIsFirstFragment = false;\n if (fragmentIndex === -1) {\n currentPos = lookupEntry?.moofOffset ?? 0;\n nextFragmentIsFirstFragment = currentPos === 0;\n }\n else {\n const fragment = this.internalTrack.fragments[fragmentIndex];\n if (!lookupEntry || fragment.moofOffset >= lookupEntry.moofOffset) {\n currentPos = fragment.moofOffset + fragment.moofSize;\n prevFragment = fragment;\n }\n else {\n // Use the lookup entry\n currentPos = lookupEntry.moofOffset;\n }\n }\n while (true) {\n if (prevFragment) {\n const trackData = prevFragment.trackData.get(this.internalTrack.id);\n if (trackData && trackData.startTimestamp > latestTimestamp) {\n // We're already past the upper bound, no need to keep searching\n break;\n }\n if (prevFragment.nextFragment) {\n // Skip ahead quickly without needing to read the file again\n currentPos = prevFragment.nextFragment.moofOffset + prevFragment.nextFragment.moofSize;\n prevFragment = prevFragment.nextFragment;\n continue;\n }\n }\n // Load the header\n let slice = demuxer.reader.requestSliceRange(currentPos, MIN_BOX_HEADER_SIZE, MAX_BOX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const startPos = currentPos;\n const boxInfo = readBoxHeader(slice);\n if (!boxInfo) {\n break;\n }\n if (boxInfo.name === 'moof') {\n const index = binarySearchExact(demuxer.fragments, startPos, x => x.moofOffset);\n let fragment;\n if (index === -1) {\n // This is the first time we've seen this fragment\n fragment = await demuxer.readFragment(startPos);\n }\n else {\n // We already know this fragment\n fragment = demuxer.fragments[index];\n }\n // Even if we already know the fragment, we might not yet know its predecessor, so always do this\n if (prevFragment)\n prevFragment.nextFragment = fragment;\n prevFragment = fragment;\n if (nextFragmentIsFirstFragment) {\n fragment.isKnownToBeFirstFragment = true;\n nextFragmentIsFirstFragment = false;\n }\n const { fragmentIndex, sampleIndex, correctSampleFound } = getBestMatch();\n if (correctSampleFound) {\n const fragment = this.internalTrack.fragments[fragmentIndex];\n return this.fetchPacketInFragment(fragment, sampleIndex, options);\n }\n if (fragmentIndex !== -1) {\n bestFragmentIndex = fragmentIndex;\n bestSampleIndex = sampleIndex;\n }\n }\n currentPos = startPos + boxInfo.totalSize;\n }\n const bestFragment = bestFragmentIndex !== -1 ? this.internalTrack.fragments[bestFragmentIndex] : null;\n // Catch faulty lookup table entries\n if (lookupEntry && (!bestFragment || bestFragment.moofOffset < lookupEntry.moofOffset)) {\n // The lookup table entry lied to us! We found a lookup entry but no fragment there that satisfied\n // the match. In this case, let's search again but using the lookup entry before that.\n const previousLookupEntry = this.internalTrack.fragmentLookupTable[lookupEntryIndex - 1];\n const newSearchTimestamp = previousLookupEntry?.timestamp ?? -Infinity;\n return this.performFragmentedLookup(getBestMatch, newSearchTimestamp, latestTimestamp, options);\n }\n if (bestFragment) {\n // If we finished looping but didn't find a perfect match, still return the best match we found\n return this.fetchPacketInFragment(bestFragment, bestSampleIndex, options);\n }\n return null;\n }\n finally {\n release();\n }\n }\n}\nclass IsobmffVideoTrackBacking extends IsobmffTrackBacking {\n constructor(internalTrack) {\n super(internalTrack);\n this.decoderConfigPromise = null;\n this.internalTrack = internalTrack;\n }\n getCodec() {\n return this.internalTrack.info.codec;\n }\n getCodedWidth() {\n return this.internalTrack.info.width;\n }\n getCodedHeight() {\n return this.internalTrack.info.height;\n }\n getRotation() {\n return this.internalTrack.rotation;\n }\n async getColorSpace() {\n return {\n primaries: this.internalTrack.info.colorSpace?.primaries,\n transfer: this.internalTrack.info.colorSpace?.transfer,\n matrix: this.internalTrack.info.colorSpace?.matrix,\n fullRange: this.internalTrack.info.colorSpace?.fullRange,\n };\n }\n async getDecoderConfig() {\n if (!this.internalTrack.info.codec) {\n return null;\n }\n return this.decoderConfigPromise ??= (async () => {\n if (this.internalTrack.info.codec === 'vp9' && !this.internalTrack.info.vp9CodecInfo) {\n const firstPacket = await this.getFirstPacket({});\n this.internalTrack.info.vp9CodecInfo = firstPacket && extractVp9CodecInfoFromPacket(firstPacket.data);\n }\n else if (this.internalTrack.info.codec === 'av1' && !this.internalTrack.info.av1CodecInfo) {\n const firstPacket = await this.getFirstPacket({});\n this.internalTrack.info.av1CodecInfo = firstPacket && extractAv1CodecInfoFromPacket(firstPacket.data);\n }\n return {\n codec: extractVideoCodecString(this.internalTrack.info),\n codedWidth: this.internalTrack.info.width,\n codedHeight: this.internalTrack.info.height,\n description: this.internalTrack.info.codecDescription ?? undefined,\n colorSpace: this.internalTrack.info.colorSpace ?? undefined,\n };\n })();\n }\n}\nclass IsobmffAudioTrackBacking extends IsobmffTrackBacking {\n constructor(internalTrack) {\n super(internalTrack);\n this.decoderConfig = null;\n this.internalTrack = internalTrack;\n }\n getCodec() {\n return this.internalTrack.info.codec;\n }\n getNumberOfChannels() {\n return this.internalTrack.info.numberOfChannels;\n }\n getSampleRate() {\n return this.internalTrack.info.sampleRate;\n }\n async getDecoderConfig() {\n if (!this.internalTrack.info.codec) {\n return null;\n }\n return this.decoderConfig ??= {\n codec: extractAudioCodecString(this.internalTrack.info),\n numberOfChannels: this.internalTrack.info.numberOfChannels,\n sampleRate: this.internalTrack.info.sampleRate,\n description: this.internalTrack.info.codecDescription ?? undefined,\n };\n }\n}\nconst getSampleIndexForTimestamp = (sampleTable, timescaleUnits) => {\n if (sampleTable.presentationTimestamps) {\n const index = binarySearchLessOrEqual(sampleTable.presentationTimestamps, timescaleUnits, x => x.presentationTimestamp);\n if (index === -1) {\n return -1;\n }\n return sampleTable.presentationTimestamps[index].sampleIndex;\n }\n else {\n const index = binarySearchLessOrEqual(sampleTable.sampleTimingEntries, timescaleUnits, x => x.startDecodeTimestamp);\n if (index === -1) {\n return -1;\n }\n const entry = sampleTable.sampleTimingEntries[index];\n return entry.startIndex\n + Math.min(Math.floor((timescaleUnits - entry.startDecodeTimestamp) / entry.delta), entry.count - 1);\n }\n};\nconst getSampleInfo = (sampleTable, sampleIndex) => {\n const timingEntryIndex = binarySearchLessOrEqual(sampleTable.sampleTimingEntries, sampleIndex, x => x.startIndex);\n const timingEntry = sampleTable.sampleTimingEntries[timingEntryIndex];\n if (!timingEntry || timingEntry.startIndex + timingEntry.count <= sampleIndex) {\n return null;\n }\n const decodeTimestamp = timingEntry.startDecodeTimestamp\n + (sampleIndex - timingEntry.startIndex) * timingEntry.delta;\n let presentationTimestamp = decodeTimestamp;\n const offsetEntryIndex = binarySearchLessOrEqual(sampleTable.sampleCompositionTimeOffsets, sampleIndex, x => x.startIndex);\n const offsetEntry = sampleTable.sampleCompositionTimeOffsets[offsetEntryIndex];\n if (offsetEntry && sampleIndex - offsetEntry.startIndex < offsetEntry.count) {\n presentationTimestamp += offsetEntry.offset;\n }\n const sampleSize = sampleTable.sampleSizes[Math.min(sampleIndex, sampleTable.sampleSizes.length - 1)];\n const chunkEntryIndex = binarySearchLessOrEqual(sampleTable.sampleToChunk, sampleIndex, x => x.startSampleIndex);\n const chunkEntry = sampleTable.sampleToChunk[chunkEntryIndex];\n assert(chunkEntry);\n const chunkIndex = chunkEntry.startChunkIndex\n + Math.floor((sampleIndex - chunkEntry.startSampleIndex) / chunkEntry.samplesPerChunk);\n const chunkOffset = sampleTable.chunkOffsets[chunkIndex];\n const startSampleIndexOfChunk = chunkEntry.startSampleIndex\n + (chunkIndex - chunkEntry.startChunkIndex) * chunkEntry.samplesPerChunk;\n let chunkSize = 0;\n let sampleOffset = chunkOffset;\n if (sampleTable.sampleSizes.length === 1) {\n sampleOffset += sampleSize * (sampleIndex - startSampleIndexOfChunk);\n chunkSize += sampleSize * chunkEntry.samplesPerChunk;\n }\n else {\n for (let i = startSampleIndexOfChunk; i < startSampleIndexOfChunk + chunkEntry.samplesPerChunk; i++) {\n const sampleSize = sampleTable.sampleSizes[i];\n if (i < sampleIndex) {\n sampleOffset += sampleSize;\n }\n chunkSize += sampleSize;\n }\n }\n let duration = timingEntry.delta;\n if (sampleTable.presentationTimestamps) {\n // In order to accurately compute the duration, we need to take the duration to the next sample in presentation\n // order, not in decode order\n const presentationIndex = sampleTable.presentationTimestampIndexMap[sampleIndex];\n assert(presentationIndex !== undefined);\n if (presentationIndex < sampleTable.presentationTimestamps.length - 1) {\n const nextEntry = sampleTable.presentationTimestamps[presentationIndex + 1];\n const nextPresentationTimestamp = nextEntry.presentationTimestamp;\n duration = nextPresentationTimestamp - presentationTimestamp;\n }\n }\n return {\n presentationTimestamp,\n duration,\n sampleOffset,\n sampleSize,\n chunkOffset,\n chunkSize,\n isKeyFrame: sampleTable.keySampleIndices\n ? binarySearchExact(sampleTable.keySampleIndices, sampleIndex, x => x) !== -1\n : true,\n };\n};\nconst getRelevantKeyframeIndexForSample = (sampleTable, sampleIndex) => {\n if (!sampleTable.keySampleIndices) {\n return sampleIndex;\n }\n const index = binarySearchLessOrEqual(sampleTable.keySampleIndices, sampleIndex, x => x);\n return sampleTable.keySampleIndices[index] ?? -1;\n};\nconst getNextKeyframeIndexForSample = (sampleTable, sampleIndex) => {\n if (!sampleTable.keySampleIndices) {\n return sampleIndex + 1;\n }\n const index = binarySearchLessOrEqual(sampleTable.keySampleIndices, sampleIndex, x => x);\n return sampleTable.keySampleIndices[index + 1] ?? -1;\n};\nconst offsetFragmentTrackDataByTimestamp = (trackData, timestamp) => {\n trackData.startTimestamp += timestamp;\n trackData.endTimestamp += timestamp;\n for (const sample of trackData.samples) {\n sample.presentationTimestamp += timestamp;\n }\n for (const entry of trackData.presentationTimestamps) {\n entry.presentationTimestamp += timestamp;\n }\n};\n/** Extracts the rotation component from a transformation matrix, in degrees. */\nconst extractRotationFromMatrix = (matrix) => {\n const [m11, , , m21] = matrix;\n const scaleX = Math.hypot(m11, m21);\n const cosTheta = m11 / scaleX;\n const sinTheta = m21 / scaleX;\n // Invert the rotation because matrices are post-multiplied in ISOBMFF\n const result = -Math.atan2(sinTheta, cosTheta) * (180 / Math.PI);\n if (!Number.isFinite(result)) {\n // Can happen if the entire matrix is 0, for example\n return 0;\n }\n return result;\n};\nconst sampleTableIsEmpty = (sampleTable) => {\n return sampleTable.sampleSizes.length === 0;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { extractAv1CodecInfoFromPacket, extractAvcDecoderConfigurationRecord, extractHevcDecoderConfigurationRecord, extractVp9CodecInfoFromPacket, } from '../codec-data.js';\nimport { extractAudioCodecString, extractVideoCodecString, } from '../codec.js';\nimport { Demuxer } from '../demuxer.js';\nimport { InputAudioTrack, InputVideoTrack, } from '../input-track.js';\nimport { assert, AsyncMutex, binarySearchExact, binarySearchLessOrEqual, COLOR_PRIMARIES_MAP_INVERSE, findLastIndex, insertSorted, isIso639Dash2LanguageCode, last, MATRIX_COEFFICIENTS_MAP_INVERSE, normalizeRotation, roundToPrecision, TRANSFER_CHARACTERISTICS_MAP_INVERSE, UNDETERMINED_LANGUAGE, } from '../misc.js';\nimport { EncodedPacket, PLACEHOLDER_DATA } from '../packet.js';\nimport { assertDefinedSize, CODEC_STRING_MAP, EBMLId, LEVEL_0_AND_1_EBML_IDS, LEVEL_1_EBML_IDS, MAX_HEADER_SIZE, MIN_HEADER_SIZE, readAsciiString, readUnicodeString, readElementHeader, readElementId, readFloat, readSignedInt, readUnsignedInt, readVarInt, resync, searchForNextElementId, } from './ebml.js';\nimport { buildMatroskaMimeType } from './matroska-misc.js';\nimport { FileSlice, readBytes, readI16Be, readU8 } from '../reader.js';\nvar BlockLacing;\n(function (BlockLacing) {\n BlockLacing[BlockLacing[\"None\"] = 0] = \"None\";\n BlockLacing[BlockLacing[\"Xiph\"] = 1] = \"Xiph\";\n BlockLacing[BlockLacing[\"FixedSize\"] = 2] = \"FixedSize\";\n BlockLacing[BlockLacing[\"Ebml\"] = 3] = \"Ebml\";\n})(BlockLacing || (BlockLacing = {}));\nconst METADATA_ELEMENTS = [\n { id: EBMLId.SeekHead, flag: 'seekHeadSeen' },\n { id: EBMLId.Info, flag: 'infoSeen' },\n { id: EBMLId.Tracks, flag: 'tracksSeen' },\n { id: EBMLId.Cues, flag: 'cuesSeen' },\n];\nconst MAX_RESYNC_LENGTH = 10 * 2 ** 20; // 10 MiB\nexport class MatroskaDemuxer extends Demuxer {\n constructor(input) {\n super(input);\n this.readMetadataPromise = null;\n this.segments = [];\n this.currentSegment = null;\n this.currentTrack = null;\n this.currentCluster = null;\n this.currentBlock = null;\n this.currentCueTime = null;\n this.currentTagTargetIsMovie = true;\n this.currentSimpleTagName = null;\n this.currentAttachedFile = null;\n this.isWebM = false;\n this.reader = input._reader;\n }\n async computeDuration() {\n const tracks = await this.getTracks();\n const trackDurations = await Promise.all(tracks.map(x => x.computeDuration()));\n return Math.max(0, ...trackDurations);\n }\n async getTracks() {\n await this.readMetadata();\n return this.segments.flatMap(segment => segment.tracks.map(track => track.inputTrack));\n }\n async getMimeType() {\n await this.readMetadata();\n const tracks = await this.getTracks();\n const codecStrings = await Promise.all(tracks.map(x => x.getCodecParameterString()));\n return buildMatroskaMimeType({\n isWebM: this.isWebM,\n hasVideo: this.segments.some(segment => segment.tracks.some(x => x.info?.type === 'video')),\n hasAudio: this.segments.some(segment => segment.tracks.some(x => x.info?.type === 'audio')),\n codecStrings: codecStrings.filter(Boolean),\n });\n }\n async getMetadataTags() {\n await this.readMetadata();\n // Load metadata tags from each segment lazily (only once)\n for (const segment of this.segments) {\n if (!segment.metadataTagsCollected) {\n if (this.reader.fileSize !== null) {\n await this.loadSegmentMetadata(segment);\n }\n else {\n // The seeking would be too crazy, let's not\n }\n segment.metadataTagsCollected = true;\n }\n }\n // This is kinda handwavy, and how we handle multiple segments isn't suuuuper well-defined anyway; so we just\n // shallow-merge metadata tags from all (usually just one) segments.\n let metadataTags = {};\n for (const segment of this.segments) {\n metadataTags = { ...metadataTags, ...segment.metadataTags };\n }\n return metadataTags;\n }\n readMetadata() {\n return this.readMetadataPromise ??= (async () => {\n let currentPos = 0;\n // Loop over all top-level elements in the file\n while (true) {\n let slice = this.reader.requestSliceRange(currentPos, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const header = readElementHeader(slice);\n if (!header) {\n break; // Zero padding at the end of the file triggers this, for example\n }\n const id = header.id;\n let size = header.size;\n const dataStartPos = slice.filePos;\n if (id === EBMLId.EBML) {\n assertDefinedSize(size);\n let slice = this.reader.requestSlice(dataStartPos, size);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n this.readContiguousElements(slice);\n }\n else if (id === EBMLId.Segment) { // Segment found!\n await this.readSegment(dataStartPos, size);\n if (size === null) {\n // Segment sizes can be undefined (common in livestreamed files), so assume this is the last\n // and only segment\n break;\n }\n if (this.reader.fileSize === null) {\n break; // Stop at the first segment\n }\n }\n else if (id === EBMLId.Cluster) {\n if (this.reader.fileSize === null) {\n break; // Shouldn't be reached anyway, since we stop at the first segment\n }\n // Clusters are not a top-level element in Matroska, but some files contain a Segment whose size\n // doesn't contain any of the clusters that follow it. In the case, we apply the following logic: if\n // we find a top-level cluster, attribute it to the previous segment.\n if (size === null) {\n // Just in case this is one of those weird sizeless clusters, let's do our best and still try to\n // determine its size.\n const nextElementPos = await searchForNextElementId(this.reader, dataStartPos, LEVEL_0_AND_1_EBML_IDS, this.reader.fileSize);\n size = nextElementPos.pos - dataStartPos;\n }\n const lastSegment = last(this.segments);\n if (lastSegment) {\n // Extend the previous segment's size\n lastSegment.elementEndPos = dataStartPos + size;\n }\n }\n assertDefinedSize(size);\n currentPos = dataStartPos + size;\n }\n })();\n }\n async readSegment(segmentDataStart, dataSize) {\n this.currentSegment = {\n seekHeadSeen: false,\n infoSeen: false,\n tracksSeen: false,\n cuesSeen: false,\n tagsSeen: false,\n attachmentsSeen: false,\n timestampScale: -1,\n timestampFactor: -1,\n duration: -1,\n seekEntries: [],\n tracks: [],\n cuePoints: [],\n dataStartPos: segmentDataStart,\n elementEndPos: dataSize === null\n ? null // Assume it goes until the end of the file\n : segmentDataStart + dataSize,\n clusterSeekStartPos: segmentDataStart,\n clusters: [],\n clusterLookupMutex: new AsyncMutex(),\n metadataTags: {},\n metadataTagsCollected: false,\n };\n this.segments.push(this.currentSegment);\n let currentPos = segmentDataStart;\n while (this.currentSegment.elementEndPos === null || currentPos < this.currentSegment.elementEndPos) {\n let slice = this.reader.requestSliceRange(currentPos, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const elementStartPos = currentPos;\n const header = readElementHeader(slice);\n if (!header || (!LEVEL_1_EBML_IDS.includes(header.id) && header.id !== EBMLId.Void)) {\n // Potential junk. Let's try to resync\n const nextPos = await resync(this.reader, elementStartPos, LEVEL_1_EBML_IDS, Math.min(this.currentSegment.elementEndPos ?? Infinity, elementStartPos + MAX_RESYNC_LENGTH));\n if (nextPos) {\n currentPos = nextPos;\n continue;\n }\n else {\n break; // Resync failed\n }\n }\n const { id, size } = header;\n const dataStartPos = slice.filePos;\n const metadataElementIndex = METADATA_ELEMENTS.findIndex(x => x.id === id);\n if (metadataElementIndex !== -1) {\n const field = METADATA_ELEMENTS[metadataElementIndex].flag;\n this.currentSegment[field] = true;\n assertDefinedSize(size);\n let slice = this.reader.requestSlice(dataStartPos, size);\n if (slice instanceof Promise)\n slice = await slice;\n if (slice) {\n this.readContiguousElements(slice);\n }\n }\n else if (id === EBMLId.Tags || id === EBMLId.Attachments) {\n // Metadata found at the beginning of the segment, great, let's parse it\n if (id === EBMLId.Tags) {\n this.currentSegment.tagsSeen = true;\n }\n else {\n this.currentSegment.attachmentsSeen = true;\n }\n assertDefinedSize(size);\n let slice = this.reader.requestSlice(dataStartPos, size);\n if (slice instanceof Promise)\n slice = await slice;\n if (slice) {\n this.readContiguousElements(slice);\n }\n }\n else if (id === EBMLId.Cluster) {\n this.currentSegment.clusterSeekStartPos = elementStartPos;\n break; // Stop at the first cluster\n }\n if (size === null) {\n break;\n }\n else {\n currentPos = dataStartPos + size;\n }\n }\n // Sort the seek entries by file position so reading them exhibits a sequential pattern\n this.currentSegment.seekEntries.sort((a, b) => a.segmentPosition - b.segmentPosition);\n if (this.reader.fileSize !== null) {\n // Use the seek head to read missing metadata elements\n for (const seekEntry of this.currentSegment.seekEntries) {\n const target = METADATA_ELEMENTS.find(x => x.id === seekEntry.id);\n if (!target) {\n continue;\n }\n if (this.currentSegment[target.flag])\n continue;\n let slice = this.reader.requestSliceRange(segmentDataStart + seekEntry.segmentPosition, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n continue;\n const header = readElementHeader(slice);\n if (!header)\n continue;\n const { id, size } = header;\n if (id !== target.id)\n continue;\n assertDefinedSize(size);\n this.currentSegment[target.flag] = true;\n let dataSlice = this.reader.requestSlice(slice.filePos, size);\n if (dataSlice instanceof Promise)\n dataSlice = await dataSlice;\n if (!dataSlice)\n continue;\n this.readContiguousElements(dataSlice);\n }\n }\n if (this.currentSegment.timestampScale === -1) {\n // TimestampScale element is missing. Technically an invalid file, but let's default to the typical value,\n // which is 1e6.\n this.currentSegment.timestampScale = 1e6;\n this.currentSegment.timestampFactor = 1e9 / 1e6;\n }\n // Put default tracks first\n this.currentSegment.tracks.sort((a, b) => Number(b.isDefault) - Number(a.isDefault));\n // Sort cue points by cluster position (required for the next algorithm)\n this.currentSegment.cuePoints.sort((a, b) => a.clusterPosition - b.clusterPosition);\n // Now, let's distribute the cue points to each track. Ideally, each track has their own cue point, but some\n // Matroska files may only specify cue points for a single track. In this case, we still wanna use those cue\n // points for all tracks.\n const allTrackIds = this.currentSegment.tracks.map(x => x.id);\n const remainingTrackIds = new Set();\n let lastClusterPosition = null;\n let lastCuePoint = null;\n for (const cuePoint of this.currentSegment.cuePoints) {\n if (cuePoint.clusterPosition !== lastClusterPosition) {\n for (const id of remainingTrackIds) {\n // These tracks didn't receive a cue point for the last cluster, so let's give them one\n assert(lastCuePoint);\n const track = this.currentSegment.tracks.find(x => x.id === id);\n track.cuePoints.push(lastCuePoint);\n }\n for (const id of allTrackIds) {\n remainingTrackIds.add(id);\n }\n }\n lastCuePoint = cuePoint;\n if (!remainingTrackIds.has(cuePoint.trackId)) {\n continue;\n }\n const track = this.currentSegment.tracks.find(x => x.id === cuePoint.trackId);\n track.cuePoints.push(cuePoint);\n remainingTrackIds.delete(cuePoint.trackId);\n lastClusterPosition = cuePoint.clusterPosition;\n }\n for (const id of remainingTrackIds) {\n assert(lastCuePoint);\n const track = this.currentSegment.tracks.find(x => x.id === id);\n track.cuePoints.push(lastCuePoint);\n }\n for (const track of this.currentSegment.tracks) {\n // Sort cue points by time\n track.cuePoints.sort((a, b) => a.time - b.time);\n }\n this.currentSegment = null;\n }\n async readCluster(startPos, segment) {\n let headerSlice = this.reader.requestSliceRange(startPos, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (headerSlice instanceof Promise)\n headerSlice = await headerSlice;\n assert(headerSlice);\n const elementStartPos = startPos;\n const elementHeader = readElementHeader(headerSlice);\n assert(elementHeader);\n const id = elementHeader.id;\n let size = elementHeader.size;\n const dataStartPos = headerSlice.filePos;\n if (size === null) {\n // The cluster's size is undefined (can happen in livestreamed files). We'd still like to know the size of\n // it, so we have no other choice but to iterate over the EBML structure until we find an element at level\n // 0 or 1, indicating the end of the cluster (all elements inside the cluster are at level 2).\n const nextElementPos = await searchForNextElementId(this.reader, dataStartPos, LEVEL_0_AND_1_EBML_IDS, segment.elementEndPos);\n size = nextElementPos.pos - dataStartPos;\n }\n assert(id === EBMLId.Cluster);\n // Load the entire cluster\n let dataSlice = this.reader.requestSlice(dataStartPos, size);\n if (dataSlice instanceof Promise)\n dataSlice = await dataSlice;\n const cluster = {\n elementStartPos,\n elementEndPos: dataStartPos + size,\n dataStartPos,\n timestamp: -1,\n trackData: new Map(),\n nextCluster: null,\n isKnownToBeFirstCluster: false,\n };\n this.currentCluster = cluster;\n if (dataSlice) {\n this.readContiguousElements(dataSlice);\n }\n for (const [trackId, trackData] of cluster.trackData) {\n const track = segment.tracks.find(x => x.id === trackId) ?? null;\n // This must hold, as track datas only get created if a block for that track is encountered\n assert(trackData.blocks.length > 0);\n let blockReferencesExist = false;\n let hasLacedBlocks = false;\n for (let i = 0; i < trackData.blocks.length; i++) {\n const block = trackData.blocks[i];\n block.timestamp += cluster.timestamp;\n blockReferencesExist ||= block.referencedTimestamps.length > 0;\n hasLacedBlocks ||= block.lacing !== BlockLacing.None;\n }\n if (blockReferencesExist) {\n trackData.blocks = sortBlocksByReferences(trackData.blocks);\n }\n trackData.presentationTimestamps = trackData.blocks\n .map((block, i) => ({ timestamp: block.timestamp, blockIndex: i }))\n .sort((a, b) => a.timestamp - b.timestamp);\n for (let i = 0; i < trackData.presentationTimestamps.length; i++) {\n const currentEntry = trackData.presentationTimestamps[i];\n const currentBlock = trackData.blocks[currentEntry.blockIndex];\n if (trackData.firstKeyFrameTimestamp === null && currentBlock.isKeyFrame) {\n trackData.firstKeyFrameTimestamp = currentBlock.timestamp;\n }\n if (i < trackData.presentationTimestamps.length - 1) {\n // Update block durations based on presentation order\n const nextEntry = trackData.presentationTimestamps[i + 1];\n currentBlock.duration = nextEntry.timestamp - currentBlock.timestamp;\n }\n else if (currentBlock.duration === 0) {\n if (track?.defaultDuration != null) {\n if (currentBlock.lacing === BlockLacing.None) {\n currentBlock.duration = track.defaultDuration;\n }\n else {\n // Handled by the lace resolution code\n }\n }\n }\n }\n if (hasLacedBlocks) {\n // Perform lace resolution. Here, we expand each laced block into multiple blocks where each contains\n // one frame of the lace. We do this after determining block timestamps so we can properly distribute\n // the block's duration across the laced frames.\n this.expandLacedBlocks(trackData.blocks, track);\n // Recompute since blocks have changed\n trackData.presentationTimestamps = trackData.blocks\n .map((block, i) => ({ timestamp: block.timestamp, blockIndex: i }))\n .sort((a, b) => a.timestamp - b.timestamp);\n }\n const firstBlock = trackData.blocks[trackData.presentationTimestamps[0].blockIndex];\n const lastBlock = trackData.blocks[last(trackData.presentationTimestamps).blockIndex];\n trackData.startTimestamp = firstBlock.timestamp;\n trackData.endTimestamp = lastBlock.timestamp + lastBlock.duration;\n if (track) {\n insertSorted(track.clusters, cluster, x => x.elementStartPos);\n const hasKeyFrame = trackData.firstKeyFrameTimestamp !== null;\n if (hasKeyFrame) {\n insertSorted(track.clustersWithKeyFrame, cluster, x => x.elementStartPos);\n }\n }\n }\n insertSorted(segment.clusters, cluster, x => x.elementStartPos);\n this.currentCluster = null;\n return cluster;\n }\n getTrackDataInCluster(cluster, trackNumber) {\n let trackData = cluster.trackData.get(trackNumber);\n if (!trackData) {\n trackData = {\n startTimestamp: 0,\n endTimestamp: 0,\n firstKeyFrameTimestamp: null,\n blocks: [],\n presentationTimestamps: [],\n };\n cluster.trackData.set(trackNumber, trackData);\n }\n return trackData;\n }\n expandLacedBlocks(blocks, track) {\n // https://www.matroska.org/technical/notes.html#block-lacing\n for (let blockIndex = 0; blockIndex < blocks.length; blockIndex++) {\n const originalBlock = blocks[blockIndex];\n if (originalBlock.lacing === BlockLacing.None) {\n continue;\n }\n const slice = FileSlice.tempFromBytes(originalBlock.data);\n const frameSizes = [];\n const frameCount = readU8(slice) + 1;\n switch (originalBlock.lacing) {\n case BlockLacing.Xiph:\n {\n let totalUsedSize = 0;\n // Xiph lacing, just like in Ogg\n for (let i = 0; i < frameCount - 1; i++) {\n let frameSize = 0;\n while (slice.bufferPos < slice.length) {\n const value = readU8(slice);\n frameSize += value;\n if (value < 255) {\n frameSizes.push(frameSize);\n totalUsedSize += frameSize;\n break;\n }\n }\n }\n // Compute the last frame's size from whatever's left\n frameSizes.push(slice.length - (slice.bufferPos + totalUsedSize));\n }\n ;\n break;\n case BlockLacing.FixedSize:\n {\n // Fixed size lacing: all frames have same size\n const totalDataSize = slice.length - 1; // Minus the frame count byte\n const frameSize = Math.floor(totalDataSize / frameCount);\n for (let i = 0; i < frameCount; i++) {\n frameSizes.push(frameSize);\n }\n }\n ;\n break;\n case BlockLacing.Ebml:\n {\n // EBML lacing: first size absolute, subsequent ones are coded as signed differences from the last\n const firstResult = readVarInt(slice);\n assert(firstResult !== null); // Assume it's not an invalid VINT\n let currentSize = firstResult;\n frameSizes.push(currentSize);\n let totalUsedSize = currentSize;\n for (let i = 1; i < frameCount - 1; i++) {\n const startPos = slice.bufferPos;\n const diffResult = readVarInt(slice);\n assert(diffResult !== null);\n const unsignedDiff = diffResult;\n const width = slice.bufferPos - startPos;\n const bias = (1 << (width * 7 - 1)) - 1; // Typo-corrected version of 2^((7*n)-1)^-1\n const diff = unsignedDiff - bias;\n currentSize += diff;\n frameSizes.push(currentSize);\n totalUsedSize += currentSize;\n }\n // Compute the last frame's size from whatever's left\n frameSizes.push(slice.length - (slice.bufferPos + totalUsedSize));\n }\n ;\n break;\n default: assert(false);\n }\n assert(frameSizes.length === frameCount);\n blocks.splice(blockIndex, 1); // Remove the original block\n // Now, let's insert each frame as its own block\n for (let i = 0; i < frameCount; i++) {\n const frameSize = frameSizes[i];\n const frameData = readBytes(slice, frameSize);\n const blockDuration = originalBlock.duration || (frameCount * (track?.defaultDuration ?? 0));\n // Distribute timestamps evenly across the block duration\n const frameTimestamp = originalBlock.timestamp + (blockDuration * i / frameCount);\n const frameDuration = blockDuration / frameCount;\n blocks.splice(blockIndex + i, 0, {\n timestamp: frameTimestamp,\n duration: frameDuration,\n isKeyFrame: originalBlock.isKeyFrame,\n referencedTimestamps: originalBlock.referencedTimestamps,\n data: frameData,\n lacing: BlockLacing.None,\n });\n }\n blockIndex += frameCount; // Skip the blocks we just added\n blockIndex--;\n }\n }\n async loadSegmentMetadata(segment) {\n for (const seekEntry of segment.seekEntries) {\n if (seekEntry.id === EBMLId.Tags && !segment.tagsSeen) {\n // We need to load the tags\n }\n else if (seekEntry.id === EBMLId.Attachments && !segment.attachmentsSeen) {\n // We need to load the attachments\n }\n else {\n continue;\n }\n let slice = this.reader.requestSliceRange(segment.dataStartPos + seekEntry.segmentPosition, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n continue;\n const header = readElementHeader(slice);\n if (!header || header.id !== seekEntry.id)\n continue;\n const { size } = header;\n assertDefinedSize(size);\n assert(!this.currentSegment);\n this.currentSegment = segment;\n let dataSlice = this.reader.requestSlice(slice.filePos, size);\n if (dataSlice instanceof Promise)\n dataSlice = await dataSlice;\n if (dataSlice) {\n this.readContiguousElements(dataSlice);\n }\n this.currentSegment = null;\n // Mark as seen\n if (seekEntry.id === EBMLId.Tags) {\n segment.tagsSeen = true;\n }\n else if (seekEntry.id === EBMLId.Attachments) {\n segment.attachmentsSeen = true;\n }\n }\n }\n readContiguousElements(slice) {\n const startIndex = slice.filePos;\n while (slice.filePos - startIndex <= slice.length - MIN_HEADER_SIZE) {\n const foundElement = this.traverseElement(slice);\n if (!foundElement) {\n break;\n }\n }\n }\n traverseElement(slice) {\n const header = readElementHeader(slice);\n if (!header) {\n return false;\n }\n const { id, size } = header;\n const dataStartPos = slice.filePos;\n assertDefinedSize(size);\n switch (id) {\n case EBMLId.DocType:\n {\n this.isWebM = readAsciiString(slice, size) === 'webm';\n }\n ;\n break;\n case EBMLId.Seek:\n {\n if (!this.currentSegment)\n break;\n const seekEntry = { id: -1, segmentPosition: -1 };\n this.currentSegment.seekEntries.push(seekEntry);\n this.readContiguousElements(slice.slice(dataStartPos, size));\n if (seekEntry.id === -1 || seekEntry.segmentPosition === -1) {\n this.currentSegment.seekEntries.pop();\n }\n }\n ;\n break;\n case EBMLId.SeekID:\n {\n const lastSeekEntry = this.currentSegment?.seekEntries[this.currentSegment.seekEntries.length - 1];\n if (!lastSeekEntry)\n break;\n lastSeekEntry.id = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.SeekPosition:\n {\n const lastSeekEntry = this.currentSegment?.seekEntries[this.currentSegment.seekEntries.length - 1];\n if (!lastSeekEntry)\n break;\n lastSeekEntry.segmentPosition = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.TimestampScale:\n {\n if (!this.currentSegment)\n break;\n this.currentSegment.timestampScale = readUnsignedInt(slice, size);\n this.currentSegment.timestampFactor = 1e9 / this.currentSegment.timestampScale;\n }\n ;\n break;\n case EBMLId.Duration:\n {\n if (!this.currentSegment)\n break;\n this.currentSegment.duration = readFloat(slice, size);\n }\n ;\n break;\n case EBMLId.TrackEntry:\n {\n if (!this.currentSegment)\n break;\n this.currentTrack = {\n id: -1,\n segment: this.currentSegment,\n demuxer: this,\n clusters: [],\n clustersWithKeyFrame: [],\n cuePoints: [],\n isDefault: false,\n inputTrack: null,\n codecId: null,\n codecPrivate: null,\n defaultDuration: null,\n name: null,\n languageCode: UNDETERMINED_LANGUAGE,\n info: null,\n };\n this.readContiguousElements(slice.slice(dataStartPos, size));\n if (this.currentTrack\n && this.currentTrack.id !== -1\n && this.currentTrack.codecId\n && this.currentTrack.info) {\n const slashIndex = this.currentTrack.codecId.indexOf('/');\n const codecIdWithoutSuffix = slashIndex === -1\n ? this.currentTrack.codecId\n : this.currentTrack.codecId.slice(0, slashIndex);\n if (this.currentTrack.info.type === 'video'\n && this.currentTrack.info.width !== -1\n && this.currentTrack.info.height !== -1) {\n if (this.currentTrack.codecId === CODEC_STRING_MAP.avc) {\n this.currentTrack.info.codec = 'avc';\n this.currentTrack.info.codecDescription = this.currentTrack.codecPrivate;\n }\n else if (this.currentTrack.codecId === CODEC_STRING_MAP.hevc) {\n this.currentTrack.info.codec = 'hevc';\n this.currentTrack.info.codecDescription = this.currentTrack.codecPrivate;\n }\n else if (codecIdWithoutSuffix === CODEC_STRING_MAP.vp8) {\n this.currentTrack.info.codec = 'vp8';\n }\n else if (codecIdWithoutSuffix === CODEC_STRING_MAP.vp9) {\n this.currentTrack.info.codec = 'vp9';\n }\n else if (codecIdWithoutSuffix === CODEC_STRING_MAP.av1) {\n this.currentTrack.info.codec = 'av1';\n }\n const videoTrack = this.currentTrack;\n const inputTrack = new InputVideoTrack(new MatroskaVideoTrackBacking(videoTrack));\n this.currentTrack.inputTrack = inputTrack;\n this.currentSegment.tracks.push(this.currentTrack);\n }\n else if (this.currentTrack.info.type === 'audio'\n && this.currentTrack.info.numberOfChannels !== -1\n && this.currentTrack.info.sampleRate !== -1) {\n if (codecIdWithoutSuffix === CODEC_STRING_MAP.aac) {\n this.currentTrack.info.codec = 'aac';\n this.currentTrack.info.aacCodecInfo = {\n isMpeg2: this.currentTrack.codecId.includes('MPEG2'),\n };\n this.currentTrack.info.codecDescription = this.currentTrack.codecPrivate;\n }\n else if (this.currentTrack.codecId === CODEC_STRING_MAP.mp3) {\n this.currentTrack.info.codec = 'mp3';\n }\n else if (codecIdWithoutSuffix === CODEC_STRING_MAP.opus) {\n this.currentTrack.info.codec = 'opus';\n this.currentTrack.info.codecDescription = this.currentTrack.codecPrivate;\n }\n else if (codecIdWithoutSuffix === CODEC_STRING_MAP.vorbis) {\n this.currentTrack.info.codec = 'vorbis';\n this.currentTrack.info.codecDescription = this.currentTrack.codecPrivate;\n }\n else if (codecIdWithoutSuffix === CODEC_STRING_MAP.flac) {\n this.currentTrack.info.codec = 'flac';\n this.currentTrack.info.codecDescription = this.currentTrack.codecPrivate;\n }\n else if (this.currentTrack.codecId === 'A_PCM/INT/LIT') {\n if (this.currentTrack.info.bitDepth === 8) {\n this.currentTrack.info.codec = 'pcm-u8';\n }\n else if (this.currentTrack.info.bitDepth === 16) {\n this.currentTrack.info.codec = 'pcm-s16';\n }\n else if (this.currentTrack.info.bitDepth === 24) {\n this.currentTrack.info.codec = 'pcm-s24';\n }\n else if (this.currentTrack.info.bitDepth === 32) {\n this.currentTrack.info.codec = 'pcm-s32';\n }\n }\n else if (this.currentTrack.codecId === 'A_PCM/INT/BIG') {\n if (this.currentTrack.info.bitDepth === 8) {\n this.currentTrack.info.codec = 'pcm-u8';\n }\n else if (this.currentTrack.info.bitDepth === 16) {\n this.currentTrack.info.codec = 'pcm-s16be';\n }\n else if (this.currentTrack.info.bitDepth === 24) {\n this.currentTrack.info.codec = 'pcm-s24be';\n }\n else if (this.currentTrack.info.bitDepth === 32) {\n this.currentTrack.info.codec = 'pcm-s32be';\n }\n }\n else if (this.currentTrack.codecId === 'A_PCM/FLOAT/IEEE') {\n if (this.currentTrack.info.bitDepth === 32) {\n this.currentTrack.info.codec = 'pcm-f32';\n }\n else if (this.currentTrack.info.bitDepth === 64) {\n this.currentTrack.info.codec = 'pcm-f64';\n }\n }\n const audioTrack = this.currentTrack;\n const inputTrack = new InputAudioTrack(new MatroskaAudioTrackBacking(audioTrack));\n this.currentTrack.inputTrack = inputTrack;\n this.currentSegment.tracks.push(this.currentTrack);\n }\n }\n this.currentTrack = null;\n }\n ;\n break;\n case EBMLId.TrackNumber:\n {\n if (!this.currentTrack)\n break;\n this.currentTrack.id = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.TrackType:\n {\n if (!this.currentTrack)\n break;\n const type = readUnsignedInt(slice, size);\n if (type === 1) {\n this.currentTrack.info = {\n type: 'video',\n width: -1,\n height: -1,\n rotation: 0,\n codec: null,\n codecDescription: null,\n colorSpace: null,\n };\n }\n else if (type === 2) {\n this.currentTrack.info = {\n type: 'audio',\n numberOfChannels: -1,\n sampleRate: -1,\n bitDepth: -1,\n codec: null,\n codecDescription: null,\n aacCodecInfo: null,\n };\n }\n }\n ;\n break;\n case EBMLId.FlagEnabled:\n {\n if (!this.currentTrack)\n break;\n const enabled = readUnsignedInt(slice, size);\n if (!enabled) {\n this.currentSegment.tracks.pop();\n this.currentTrack = null;\n }\n }\n ;\n break;\n case EBMLId.FlagDefault:\n {\n if (!this.currentTrack)\n break;\n this.currentTrack.isDefault = !!readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.CodecID:\n {\n if (!this.currentTrack)\n break;\n this.currentTrack.codecId = readAsciiString(slice, size);\n }\n ;\n break;\n case EBMLId.CodecPrivate:\n {\n if (!this.currentTrack)\n break;\n this.currentTrack.codecPrivate = readBytes(slice, size);\n }\n ;\n break;\n case EBMLId.DefaultDuration:\n {\n if (!this.currentTrack)\n break;\n this.currentTrack.defaultDuration\n = this.currentTrack.segment.timestampFactor * readUnsignedInt(slice, size) / 1e9;\n }\n ;\n break;\n case EBMLId.Name:\n {\n if (!this.currentTrack)\n break;\n this.currentTrack.name = readUnicodeString(slice, size);\n }\n ;\n break;\n case EBMLId.Language:\n {\n if (!this.currentTrack)\n break;\n if (this.currentTrack.languageCode !== UNDETERMINED_LANGUAGE) {\n // LanguageBCP47 was present, which takes precedence\n break;\n }\n this.currentTrack.languageCode = readAsciiString(slice, size);\n if (!isIso639Dash2LanguageCode(this.currentTrack.languageCode)) {\n this.currentTrack.languageCode = UNDETERMINED_LANGUAGE;\n }\n }\n ;\n break;\n case EBMLId.LanguageBCP47:\n {\n if (!this.currentTrack)\n break;\n const bcp47 = readAsciiString(slice, size);\n const languageSubtag = bcp47.split('-')[0];\n if (languageSubtag) {\n // Technically invalid, for now: The language subtag might be a language code from ISO 639-1,\n // ISO 639-2, ISO 639-3, ISO 639-5 or some other thing (source: Wikipedia). But, `languageCode` is\n // documented as ISO 639-2. Changing the definition would be a breaking change. This will get\n // cleaned up in the future by defining languageCode to be BCP 47 instead.\n this.currentTrack.languageCode = languageSubtag;\n }\n else {\n this.currentTrack.languageCode = UNDETERMINED_LANGUAGE;\n }\n }\n ;\n break;\n case EBMLId.Video:\n {\n if (this.currentTrack?.info?.type !== 'video')\n break;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.PixelWidth:\n {\n if (this.currentTrack?.info?.type !== 'video')\n break;\n this.currentTrack.info.width = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.PixelHeight:\n {\n if (this.currentTrack?.info?.type !== 'video')\n break;\n this.currentTrack.info.height = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.Colour:\n {\n if (this.currentTrack?.info?.type !== 'video')\n break;\n this.currentTrack.info.colorSpace = {};\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.MatrixCoefficients:\n {\n if (this.currentTrack?.info?.type !== 'video' || !this.currentTrack.info.colorSpace)\n break;\n const matrixCoefficients = readUnsignedInt(slice, size);\n const mapped = MATRIX_COEFFICIENTS_MAP_INVERSE[matrixCoefficients] ?? null;\n this.currentTrack.info.colorSpace.matrix = mapped;\n }\n ;\n break;\n case EBMLId.Range:\n {\n if (this.currentTrack?.info?.type !== 'video' || !this.currentTrack.info.colorSpace)\n break;\n this.currentTrack.info.colorSpace.fullRange = readUnsignedInt(slice, size) === 2;\n }\n ;\n break;\n case EBMLId.TransferCharacteristics:\n {\n if (this.currentTrack?.info?.type !== 'video' || !this.currentTrack.info.colorSpace)\n break;\n const transferCharacteristics = readUnsignedInt(slice, size);\n const mapped = TRANSFER_CHARACTERISTICS_MAP_INVERSE[transferCharacteristics] ?? null;\n this.currentTrack.info.colorSpace.transfer = mapped;\n }\n ;\n break;\n case EBMLId.Primaries:\n {\n if (this.currentTrack?.info?.type !== 'video' || !this.currentTrack.info.colorSpace)\n break;\n const primaries = readUnsignedInt(slice, size);\n const mapped = COLOR_PRIMARIES_MAP_INVERSE[primaries] ?? null;\n this.currentTrack.info.colorSpace.primaries = mapped;\n }\n ;\n break;\n case EBMLId.Projection:\n {\n if (this.currentTrack?.info?.type !== 'video')\n break;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.ProjectionPoseRoll:\n {\n if (this.currentTrack?.info?.type !== 'video')\n break;\n const rotation = readFloat(slice, size);\n const flippedRotation = -rotation; // Convert counter-clockwise to clockwise\n try {\n this.currentTrack.info.rotation = normalizeRotation(flippedRotation);\n }\n catch {\n // It wasn't a valid rotation\n }\n }\n ;\n break;\n case EBMLId.Audio:\n {\n if (this.currentTrack?.info?.type !== 'audio')\n break;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.SamplingFrequency:\n {\n if (this.currentTrack?.info?.type !== 'audio')\n break;\n this.currentTrack.info.sampleRate = readFloat(slice, size);\n }\n ;\n break;\n case EBMLId.Channels:\n {\n if (this.currentTrack?.info?.type !== 'audio')\n break;\n this.currentTrack.info.numberOfChannels = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.BitDepth:\n {\n if (this.currentTrack?.info?.type !== 'audio')\n break;\n this.currentTrack.info.bitDepth = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.CuePoint:\n {\n if (!this.currentSegment)\n break;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n this.currentCueTime = null;\n }\n ;\n break;\n case EBMLId.CueTime:\n {\n this.currentCueTime = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.CueTrackPositions:\n {\n if (this.currentCueTime === null)\n break;\n assert(this.currentSegment);\n const cuePoint = { time: this.currentCueTime, trackId: -1, clusterPosition: -1 };\n this.currentSegment.cuePoints.push(cuePoint);\n this.readContiguousElements(slice.slice(dataStartPos, size));\n if (cuePoint.trackId === -1 || cuePoint.clusterPosition === -1) {\n this.currentSegment.cuePoints.pop();\n }\n }\n ;\n break;\n case EBMLId.CueTrack:\n {\n const lastCuePoint = this.currentSegment?.cuePoints[this.currentSegment.cuePoints.length - 1];\n if (!lastCuePoint)\n break;\n lastCuePoint.trackId = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.CueClusterPosition:\n {\n const lastCuePoint = this.currentSegment?.cuePoints[this.currentSegment.cuePoints.length - 1];\n if (!lastCuePoint)\n break;\n assert(this.currentSegment);\n lastCuePoint.clusterPosition = this.currentSegment.dataStartPos + readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.Timestamp:\n {\n if (!this.currentCluster)\n break;\n this.currentCluster.timestamp = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.SimpleBlock:\n {\n if (!this.currentCluster)\n break;\n const trackNumber = readVarInt(slice);\n if (trackNumber === null)\n break;\n const relativeTimestamp = readI16Be(slice);\n const flags = readU8(slice);\n const isKeyFrame = !!(flags & 0x80);\n const lacing = (flags >> 1) & 0x3; // If the block is laced, we'll expand it later\n const trackData = this.getTrackDataInCluster(this.currentCluster, trackNumber);\n trackData.blocks.push({\n timestamp: relativeTimestamp, // We'll add the cluster's timestamp to this later\n duration: 0, // Will set later\n isKeyFrame,\n referencedTimestamps: [],\n data: readBytes(slice, size - (slice.filePos - dataStartPos)),\n lacing,\n });\n }\n ;\n break;\n case EBMLId.BlockGroup:\n {\n if (!this.currentCluster)\n break;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n if (this.currentBlock) {\n for (let i = 0; i < this.currentBlock.referencedTimestamps.length; i++) {\n this.currentBlock.referencedTimestamps[i] += this.currentBlock.timestamp;\n }\n this.currentBlock = null;\n }\n }\n ;\n break;\n case EBMLId.Block:\n {\n if (!this.currentCluster)\n break;\n const trackNumber = readVarInt(slice);\n if (trackNumber === null)\n break;\n const relativeTimestamp = readI16Be(slice);\n const flags = readU8(slice);\n const lacing = (flags >> 1) & 0x3; // If the block is laced, we'll expand it later\n const trackData = this.getTrackDataInCluster(this.currentCluster, trackNumber);\n this.currentBlock = {\n timestamp: relativeTimestamp, // We'll add the cluster's timestamp to this later\n duration: 0, // Will set later\n isKeyFrame: true,\n referencedTimestamps: [],\n data: readBytes(slice, size - (slice.filePos - dataStartPos)),\n lacing,\n };\n trackData.blocks.push(this.currentBlock);\n }\n ;\n break;\n case EBMLId.BlockDuration:\n {\n if (!this.currentBlock)\n break;\n this.currentBlock.duration = readUnsignedInt(slice, size);\n }\n ;\n break;\n case EBMLId.ReferenceBlock:\n {\n if (!this.currentBlock)\n break;\n this.currentBlock.isKeyFrame = false;\n const relativeTimestamp = readSignedInt(slice, size);\n // We'll offset this by the block's timestamp later\n this.currentBlock.referencedTimestamps.push(relativeTimestamp);\n }\n ;\n break;\n case EBMLId.Tag:\n {\n this.currentTagTargetIsMovie = true;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.Targets:\n {\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.TargetTypeValue:\n {\n const targetTypeValue = readUnsignedInt(slice, size);\n if (targetTypeValue !== 50) {\n this.currentTagTargetIsMovie = false;\n }\n }\n ;\n break;\n case EBMLId.TagTrackUID:\n case EBMLId.TagEditionUID:\n case EBMLId.TagChapterUID:\n case EBMLId.TagAttachmentUID:\n {\n this.currentTagTargetIsMovie = false;\n }\n ;\n break;\n case EBMLId.SimpleTag:\n {\n if (!this.currentTagTargetIsMovie)\n break;\n this.currentSimpleTagName = null;\n this.readContiguousElements(slice.slice(dataStartPos, size));\n }\n ;\n break;\n case EBMLId.TagName:\n {\n this.currentSimpleTagName = readUnicodeString(slice, size);\n }\n ;\n break;\n case EBMLId.TagString:\n {\n if (!this.currentSimpleTagName)\n break;\n const value = readUnicodeString(slice, size);\n this.processTagValue(this.currentSimpleTagName, value);\n }\n ;\n break;\n case EBMLId.TagBinary:\n {\n if (!this.currentSimpleTagName)\n break;\n const value = readBytes(slice, size);\n this.processTagValue(this.currentSimpleTagName, value);\n }\n ;\n break;\n case EBMLId.AttachedFile:\n {\n if (!this.currentSegment)\n break;\n this.currentAttachedFile = {\n fileName: null,\n fileMediaType: null,\n fileData: null,\n fileDescription: null,\n };\n this.readContiguousElements(slice.slice(dataStartPos, size));\n // Only process image attachments\n if (this.currentAttachedFile.fileMediaType?.startsWith('image/') && this.currentAttachedFile.fileData) {\n const fileName = this.currentAttachedFile.fileName;\n let kind = 'unknown';\n if (fileName) {\n const lowerName = fileName.toLowerCase();\n if (lowerName.startsWith('cover.')) {\n kind = 'coverFront';\n }\n else if (lowerName.startsWith('back.')) {\n kind = 'coverBack';\n }\n }\n this.currentSegment.metadataTags.images ??= [];\n this.currentSegment.metadataTags.images.push({\n data: this.currentAttachedFile.fileData,\n mimeType: this.currentAttachedFile.fileMediaType,\n kind,\n name: this.currentAttachedFile.fileName ?? undefined,\n description: this.currentAttachedFile.fileDescription ?? undefined,\n });\n }\n this.currentAttachedFile = null;\n }\n ;\n break;\n case EBMLId.FileName:\n {\n if (!this.currentAttachedFile)\n break;\n this.currentAttachedFile.fileName = readUnicodeString(slice, size);\n }\n ;\n break;\n case EBMLId.FileMediaType:\n {\n if (!this.currentAttachedFile)\n break;\n this.currentAttachedFile.fileMediaType = readAsciiString(slice, size);\n }\n ;\n break;\n case EBMLId.FileData:\n {\n if (!this.currentAttachedFile)\n break;\n this.currentAttachedFile.fileData = readBytes(slice, size);\n }\n ;\n break;\n case EBMLId.FileDescription:\n {\n if (!this.currentAttachedFile)\n break;\n this.currentAttachedFile.fileDescription = readUnicodeString(slice, size);\n }\n ;\n break;\n }\n slice.filePos = dataStartPos + size;\n return true;\n }\n processTagValue(name, value) {\n if (!this.currentSegment?.metadataTags)\n return;\n const metadataTags = this.currentSegment.metadataTags;\n metadataTags.raw ??= {};\n metadataTags.raw[name] ??= value;\n if (typeof value === 'string') {\n switch (name.toLowerCase()) {\n case 'title':\n {\n metadataTags.title ??= value;\n }\n ;\n break;\n case 'description':\n {\n metadataTags.description ??= value;\n }\n ;\n break;\n case 'artist':\n {\n metadataTags.artist ??= value;\n }\n ;\n break;\n case 'album':\n {\n metadataTags.album ??= value;\n }\n ;\n break;\n case 'album_artist':\n {\n metadataTags.albumArtist ??= value;\n }\n ;\n break;\n case 'genre':\n {\n metadataTags.genre ??= value;\n }\n ;\n break;\n case 'comment':\n {\n metadataTags.comment ??= value;\n }\n ;\n break;\n case 'lyrics':\n {\n metadataTags.lyrics ??= value;\n }\n ;\n break;\n case 'date':\n {\n const date = new Date(value);\n if (!Number.isNaN(date.getTime())) {\n metadataTags.date ??= date;\n }\n }\n ;\n break;\n case 'track_number':\n case 'part_number':\n {\n const parts = value.split('/');\n const trackNum = Number.parseInt(parts[0], 10);\n const tracksTotal = parts[1] && Number.parseInt(parts[1], 10);\n if (Number.isInteger(trackNum) && trackNum > 0) {\n metadataTags.trackNumber ??= trackNum;\n }\n if (tracksTotal && Number.isInteger(tracksTotal) && tracksTotal > 0) {\n metadataTags.tracksTotal ??= tracksTotal;\n }\n }\n ;\n break;\n case 'disc_number':\n case 'disc':\n {\n const discParts = value.split('/');\n const discNum = Number.parseInt(discParts[0], 10);\n const discsTotal = discParts[1] && Number.parseInt(discParts[1], 10);\n if (Number.isInteger(discNum) && discNum > 0) {\n metadataTags.discNumber ??= discNum;\n }\n if (discsTotal && Number.isInteger(discsTotal) && discsTotal > 0) {\n metadataTags.discsTotal ??= discsTotal;\n }\n }\n ;\n break;\n }\n }\n }\n}\nclass MatroskaTrackBacking {\n constructor(internalTrack) {\n this.internalTrack = internalTrack;\n this.packetToClusterLocation = new WeakMap();\n }\n getId() {\n return this.internalTrack.id;\n }\n getCodec() {\n throw new Error('Not implemented on base class.');\n }\n getInternalCodecId() {\n return this.internalTrack.codecId;\n }\n async computeDuration() {\n const lastPacket = await this.getPacket(Infinity, { metadataOnly: true });\n return (lastPacket?.timestamp ?? 0) + (lastPacket?.duration ?? 0);\n }\n getName() {\n return this.internalTrack.name;\n }\n getLanguageCode() {\n return this.internalTrack.languageCode;\n }\n async getFirstTimestamp() {\n const firstPacket = await this.getFirstPacket({ metadataOnly: true });\n return firstPacket?.timestamp ?? 0;\n }\n getTimeResolution() {\n return this.internalTrack.segment.timestampFactor;\n }\n async getFirstPacket(options) {\n return this.performClusterLookup(() => {\n const startCluster = this.internalTrack.segment.clusters[0] ?? null;\n if (startCluster?.isKnownToBeFirstCluster) {\n // Walk from the very first cluster in the file until we find one with our track in it\n let currentCluster = startCluster;\n while (currentCluster) {\n const trackData = currentCluster.trackData.get(this.internalTrack.id);\n if (trackData) {\n return {\n clusterIndex: binarySearchExact(this.internalTrack.clusters, currentCluster.elementStartPos, x => x.elementStartPos),\n blockIndex: 0,\n correctBlockFound: true,\n };\n }\n currentCluster = currentCluster.nextCluster;\n }\n }\n return {\n clusterIndex: -1,\n blockIndex: -1,\n correctBlockFound: false,\n };\n }, -Infinity, // Use -Infinity as a search timestamp to avoid using the cues\n Infinity, options);\n }\n intoTimescale(timestamp) {\n // Do a little rounding to catch cases where the result is very close to an integer. If it is, it's likely\n // that the number was originally an integer divided by the timescale. For stability, it's best\n // to return the integer in this case.\n return roundToPrecision(timestamp * this.internalTrack.segment.timestampFactor, 14);\n }\n async getPacket(timestamp, options) {\n const timestampInTimescale = this.intoTimescale(timestamp);\n return this.performClusterLookup(() => this.findBlockInClustersForTimestamp(timestampInTimescale), timestampInTimescale, timestampInTimescale, options);\n }\n async getNextPacket(packet, options) {\n const locationInCluster = this.packetToClusterLocation.get(packet);\n if (locationInCluster === undefined) {\n throw new Error('Packet was not created from this track.');\n }\n const trackData = locationInCluster.cluster.trackData.get(this.internalTrack.id);\n const clusterIndex = binarySearchExact(this.internalTrack.clusters, locationInCluster.cluster.elementStartPos, x => x.elementStartPos);\n assert(clusterIndex !== -1);\n return this.performClusterLookup(() => {\n if (locationInCluster.blockIndex + 1 < trackData.blocks.length) {\n // We can simply take the next block in the cluster\n return {\n clusterIndex,\n blockIndex: locationInCluster.blockIndex + 1,\n correctBlockFound: true,\n };\n }\n else {\n // Walk the list of clusters until we find the next cluster for this track\n let currentCluster = locationInCluster.cluster;\n while (currentCluster.nextCluster) {\n currentCluster = currentCluster.nextCluster;\n const trackData = currentCluster.trackData.get(this.internalTrack.id);\n if (trackData) {\n const clusterIndex = binarySearchExact(this.internalTrack.clusters, currentCluster.elementStartPos, x => x.elementStartPos);\n assert(clusterIndex !== -1);\n return {\n clusterIndex,\n blockIndex: 0,\n correctBlockFound: true,\n };\n }\n }\n return {\n clusterIndex,\n blockIndex: -1,\n correctBlockFound: false,\n };\n }\n }, -Infinity, // Use -Infinity as a search timestamp to avoid using the cues\n Infinity, options);\n }\n async getKeyPacket(timestamp, options) {\n const timestampInTimescale = this.intoTimescale(timestamp);\n return this.performClusterLookup(() => this.findKeyBlockInClustersForTimestamp(timestampInTimescale), timestampInTimescale, timestampInTimescale, options);\n }\n async getNextKeyPacket(packet, options) {\n const locationInCluster = this.packetToClusterLocation.get(packet);\n if (locationInCluster === undefined) {\n throw new Error('Packet was not created from this track.');\n }\n const trackData = locationInCluster.cluster.trackData.get(this.internalTrack.id);\n const clusterIndex = binarySearchExact(this.internalTrack.clusters, locationInCluster.cluster.elementStartPos, x => x.elementStartPos);\n assert(clusterIndex !== -1);\n return this.performClusterLookup(() => {\n const nextKeyFrameIndex = trackData.blocks.findIndex((x, i) => x.isKeyFrame && i > locationInCluster.blockIndex);\n if (nextKeyFrameIndex !== -1) {\n // We can simply take the next key frame in the cluster\n return {\n clusterIndex,\n blockIndex: nextKeyFrameIndex,\n correctBlockFound: true,\n };\n }\n else {\n // Walk the list of clusters until we find the next cluster for this track with a key frame\n let currentCluster = locationInCluster.cluster;\n while (currentCluster.nextCluster) {\n currentCluster = currentCluster.nextCluster;\n const trackData = currentCluster.trackData.get(this.internalTrack.id);\n if (trackData && trackData.firstKeyFrameTimestamp !== null) {\n const clusterIndex = binarySearchExact(this.internalTrack.clusters, currentCluster.elementStartPos, x => x.elementStartPos);\n assert(clusterIndex !== -1);\n const keyFrameIndex = trackData.blocks.findIndex(x => x.isKeyFrame);\n assert(keyFrameIndex !== -1); // There must be one\n return {\n clusterIndex,\n blockIndex: keyFrameIndex,\n correctBlockFound: true,\n };\n }\n }\n return {\n clusterIndex,\n blockIndex: -1,\n correctBlockFound: false,\n };\n }\n }, -Infinity, // Use -Infinity as a search timestamp to avoid using the cues\n Infinity, options);\n }\n async fetchPacketInCluster(cluster, blockIndex, options) {\n if (blockIndex === -1) {\n return null;\n }\n const trackData = cluster.trackData.get(this.internalTrack.id);\n const block = trackData.blocks[blockIndex];\n assert(block);\n const data = options.metadataOnly ? PLACEHOLDER_DATA : block.data;\n const timestamp = block.timestamp / this.internalTrack.segment.timestampFactor;\n const duration = block.duration / this.internalTrack.segment.timestampFactor;\n const packet = new EncodedPacket(data, block.isKeyFrame ? 'key' : 'delta', timestamp, duration, cluster.dataStartPos + blockIndex, block.data.byteLength);\n this.packetToClusterLocation.set(packet, { cluster, blockIndex });\n return packet;\n }\n findBlockInClustersForTimestamp(timestampInTimescale) {\n const clusterIndex = binarySearchLessOrEqual(\n // This array is technically not sorted by start timestamp, but for any reasonable file, it basically is.\n this.internalTrack.clusters, timestampInTimescale, x => x.trackData.get(this.internalTrack.id).startTimestamp);\n let blockIndex = -1;\n let correctBlockFound = false;\n if (clusterIndex !== -1) {\n const cluster = this.internalTrack.clusters[clusterIndex];\n const trackData = cluster.trackData.get(this.internalTrack.id);\n const index = binarySearchLessOrEqual(trackData.presentationTimestamps, timestampInTimescale, x => x.timestamp);\n assert(index !== -1);\n blockIndex = trackData.presentationTimestamps[index].blockIndex;\n correctBlockFound = timestampInTimescale < trackData.endTimestamp;\n }\n return { clusterIndex, blockIndex, correctBlockFound };\n }\n findKeyBlockInClustersForTimestamp(timestampInTimescale) {\n const indexInKeyFrameClusters = binarySearchLessOrEqual(\n // This array is technically not sorted by start timestamp, but for any reasonable file, it basically is.\n this.internalTrack.clustersWithKeyFrame, timestampInTimescale, x => x.trackData.get(this.internalTrack.id).firstKeyFrameTimestamp);\n let clusterIndex = -1;\n let blockIndex = -1;\n let correctBlockFound = false;\n if (indexInKeyFrameClusters !== -1) {\n const cluster = this.internalTrack.clustersWithKeyFrame[indexInKeyFrameClusters];\n // Now, let's find the actual index of the cluster in the list of ALL clusters, not just key frame ones\n clusterIndex = binarySearchExact(this.internalTrack.clusters, cluster.elementStartPos, x => x.elementStartPos);\n assert(clusterIndex !== -1);\n const trackData = cluster.trackData.get(this.internalTrack.id);\n const index = findLastIndex(trackData.presentationTimestamps, (x) => {\n const block = trackData.blocks[x.blockIndex];\n return block.isKeyFrame && x.timestamp <= timestampInTimescale;\n });\n assert(index !== -1); // It's a key frame cluster, so there must be a key frame\n const entry = trackData.presentationTimestamps[index];\n blockIndex = entry.blockIndex;\n correctBlockFound = timestampInTimescale < trackData.endTimestamp;\n }\n return { clusterIndex, blockIndex, correctBlockFound };\n }\n /** Looks for a packet in the clusters while trying to load as few clusters as possible to retrieve it. */\n async performClusterLookup(\n // This function returns the best-matching block that is currently loaded. Based on this information, we know\n // which clusters we need to load to find the actual match.\n getBestMatch, \n // The timestamp with which we can search the lookup table\n searchTimestamp, \n // The timestamp for which we know the correct block will not come after it\n latestTimestamp, options) {\n const { demuxer, segment } = this.internalTrack;\n const release = await segment.clusterLookupMutex.acquire(); // The algorithm requires exclusivity\n try {\n const { clusterIndex, blockIndex, correctBlockFound } = getBestMatch();\n if (correctBlockFound) {\n // The correct block already exists, easy path.\n const cluster = this.internalTrack.clusters[clusterIndex];\n return this.fetchPacketInCluster(cluster, blockIndex, options);\n }\n let prevCluster = null;\n let bestClusterIndex = clusterIndex;\n let bestBlockIndex = blockIndex;\n // Search for a cue point; this way, we won't need to start searching from the start of the file\n // but can jump right into the correct cluster (or at least nearby).\n const cuePointIndex = binarySearchLessOrEqual(this.internalTrack.cuePoints, searchTimestamp, x => x.time);\n const cuePoint = cuePointIndex !== -1 ? this.internalTrack.cuePoints[cuePointIndex] : null;\n let currentPos;\n let nextClusterIsFirstCluster = false;\n if (clusterIndex === -1) {\n currentPos = cuePoint?.clusterPosition ?? segment.clusterSeekStartPos;\n nextClusterIsFirstCluster = currentPos === segment.clusterSeekStartPos;\n }\n else {\n const cluster = this.internalTrack.clusters[clusterIndex];\n if (!cuePoint || cluster.elementStartPos >= cuePoint.clusterPosition) {\n currentPos = cluster.elementEndPos;\n prevCluster = cluster;\n }\n else {\n // Use the lookup entry\n currentPos = cuePoint.clusterPosition;\n }\n }\n while (segment.elementEndPos === null || currentPos <= segment.elementEndPos - MIN_HEADER_SIZE) {\n if (prevCluster) {\n const trackData = prevCluster.trackData.get(this.internalTrack.id);\n if (trackData && trackData.startTimestamp > latestTimestamp) {\n // We're already past the upper bound, no need to keep searching\n break;\n }\n if (prevCluster.nextCluster) {\n // Skip ahead quickly without needing to read the file again\n currentPos = prevCluster.nextCluster.elementEndPos;\n prevCluster = prevCluster.nextCluster;\n continue;\n }\n }\n // Load the header\n let slice = demuxer.reader.requestSliceRange(currentPos, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const elementStartPos = currentPos;\n const elementHeader = readElementHeader(slice);\n if (!elementHeader\n || (!LEVEL_1_EBML_IDS.includes(elementHeader.id) && elementHeader.id !== EBMLId.Void)) {\n // There's an element here that shouldn't be here. Might be garbage. In this case, let's\n // try and resync to the next valid element.\n const nextPos = await resync(demuxer.reader, elementStartPos, LEVEL_1_EBML_IDS, Math.min(segment.elementEndPos ?? Infinity, elementStartPos + MAX_RESYNC_LENGTH));\n if (nextPos) {\n currentPos = nextPos;\n continue;\n }\n else {\n break; // Resync failed\n }\n }\n const id = elementHeader.id;\n let size = elementHeader.size;\n const dataStartPos = slice.filePos;\n if (id === EBMLId.Cluster) {\n const index = binarySearchExact(segment.clusters, elementStartPos, x => x.elementStartPos);\n let cluster;\n if (index === -1) {\n // This is the first time we've seen this cluster\n cluster = await demuxer.readCluster(elementStartPos, segment);\n }\n else {\n // We already know this cluster\n cluster = segment.clusters[index];\n }\n // Even if we already know the cluster, we might not yet know its predecessor, so always do this\n if (prevCluster)\n prevCluster.nextCluster = cluster;\n prevCluster = cluster;\n if (nextClusterIsFirstCluster) {\n cluster.isKnownToBeFirstCluster = true;\n nextClusterIsFirstCluster = false;\n }\n const { clusterIndex, blockIndex, correctBlockFound } = getBestMatch();\n if (correctBlockFound) {\n const cluster = this.internalTrack.clusters[clusterIndex];\n return this.fetchPacketInCluster(cluster, blockIndex, options);\n }\n if (clusterIndex !== -1) {\n bestClusterIndex = clusterIndex;\n bestBlockIndex = blockIndex;\n }\n }\n if (size === null) {\n // Undefined element size (can happen in livestreamed files). In this case, we need to do some\n // searching to determine the actual size of the element.\n if (id === EBMLId.Cluster) {\n // The cluster should have already computed its length, we can just copy that result\n assert(prevCluster);\n size = prevCluster.elementEndPos - dataStartPos;\n }\n else {\n // Search for the next element at level 0 or 1\n const nextElementPos = await searchForNextElementId(demuxer.reader, dataStartPos, LEVEL_0_AND_1_EBML_IDS, segment.elementEndPos);\n size = nextElementPos.pos - dataStartPos;\n }\n const endPos = dataStartPos + size;\n if (segment.elementEndPos !== null && endPos > segment.elementEndPos - MIN_HEADER_SIZE) {\n // No more elements fit in this segment\n break;\n }\n else {\n // Check the next element. If it's a new segment, we know this segment ends here. The new\n // segment is just ignored, since we're likely in a livestreamed file and thus only care about\n // the first segment.\n let slice = demuxer.reader.requestSliceRange(endPos, MIN_HEADER_SIZE, MAX_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const elementId = readElementId(slice);\n if (elementId === EBMLId.Segment) {\n segment.elementEndPos = endPos;\n break;\n }\n }\n }\n currentPos = dataStartPos + size;\n }\n const bestCluster = bestClusterIndex !== -1 ? this.internalTrack.clusters[bestClusterIndex] : null;\n // Catch faulty cue points\n if (cuePoint && (!bestCluster || bestCluster.elementStartPos < cuePoint.clusterPosition)) {\n // The cue point lied to us! We found a cue point but no cluster there that satisfied the match. In this\n // case, let's search again but using the cue point before that.\n const previousCuePoint = this.internalTrack.cuePoints[cuePointIndex - 1];\n const newSearchTimestamp = previousCuePoint?.time ?? -Infinity;\n return this.performClusterLookup(getBestMatch, newSearchTimestamp, latestTimestamp, options);\n }\n if (bestCluster) {\n // If we finished looping but didn't find a perfect match, still return the best match we found\n return this.fetchPacketInCluster(bestCluster, bestBlockIndex, options);\n }\n return null;\n }\n finally {\n release();\n }\n }\n}\nclass MatroskaVideoTrackBacking extends MatroskaTrackBacking {\n constructor(internalTrack) {\n super(internalTrack);\n this.decoderConfigPromise = null;\n this.internalTrack = internalTrack;\n }\n getCodec() {\n return this.internalTrack.info.codec;\n }\n getCodedWidth() {\n return this.internalTrack.info.width;\n }\n getCodedHeight() {\n return this.internalTrack.info.height;\n }\n getRotation() {\n return this.internalTrack.info.rotation;\n }\n async getColorSpace() {\n return {\n primaries: this.internalTrack.info.colorSpace?.primaries,\n transfer: this.internalTrack.info.colorSpace?.transfer,\n matrix: this.internalTrack.info.colorSpace?.matrix,\n fullRange: this.internalTrack.info.colorSpace?.fullRange,\n };\n }\n async getDecoderConfig() {\n if (!this.internalTrack.info.codec) {\n return null;\n }\n return this.decoderConfigPromise ??= (async () => {\n let firstPacket = null;\n const needsPacketForAdditionalInfo = this.internalTrack.info.codec === 'vp9'\n || this.internalTrack.info.codec === 'av1'\n // Packets are in Annex B format:\n || (this.internalTrack.info.codec === 'avc' && !this.internalTrack.info.codecDescription)\n // Packets are in Annex B format:\n || (this.internalTrack.info.codec === 'hevc' && !this.internalTrack.info.codecDescription);\n if (needsPacketForAdditionalInfo) {\n firstPacket = await this.getFirstPacket({});\n }\n return {\n codec: extractVideoCodecString({\n width: this.internalTrack.info.width,\n height: this.internalTrack.info.height,\n codec: this.internalTrack.info.codec,\n codecDescription: this.internalTrack.info.codecDescription,\n colorSpace: this.internalTrack.info.colorSpace,\n avcCodecInfo: this.internalTrack.info.codec === 'avc' && firstPacket\n ? extractAvcDecoderConfigurationRecord(firstPacket.data)\n : null,\n hevcCodecInfo: this.internalTrack.info.codec === 'hevc' && firstPacket\n ? extractHevcDecoderConfigurationRecord(firstPacket.data)\n : null,\n vp9CodecInfo: this.internalTrack.info.codec === 'vp9' && firstPacket\n ? extractVp9CodecInfoFromPacket(firstPacket.data)\n : null,\n av1CodecInfo: this.internalTrack.info.codec === 'av1' && firstPacket\n ? extractAv1CodecInfoFromPacket(firstPacket.data)\n : null,\n }),\n codedWidth: this.internalTrack.info.width,\n codedHeight: this.internalTrack.info.height,\n description: this.internalTrack.info.codecDescription ?? undefined,\n colorSpace: this.internalTrack.info.colorSpace ?? undefined,\n };\n })();\n }\n}\nclass MatroskaAudioTrackBacking extends MatroskaTrackBacking {\n constructor(internalTrack) {\n super(internalTrack);\n this.decoderConfig = null;\n this.internalTrack = internalTrack;\n }\n getCodec() {\n return this.internalTrack.info.codec;\n }\n getNumberOfChannels() {\n return this.internalTrack.info.numberOfChannels;\n }\n getSampleRate() {\n return this.internalTrack.info.sampleRate;\n }\n async getDecoderConfig() {\n if (!this.internalTrack.info.codec) {\n return null;\n }\n return this.decoderConfig ??= {\n codec: extractAudioCodecString({\n codec: this.internalTrack.info.codec,\n codecDescription: this.internalTrack.info.codecDescription,\n aacCodecInfo: this.internalTrack.info.aacCodecInfo,\n }),\n numberOfChannels: this.internalTrack.info.numberOfChannels,\n sampleRate: this.internalTrack.info.sampleRate,\n description: this.internalTrack.info.codecDescription ?? undefined,\n };\n }\n}\n/** Sorts blocks such that referenced blocks come before the blocks that reference them. */\nconst sortBlocksByReferences = (blocks) => {\n const timestampToBlock = new Map();\n for (let i = 0; i < blocks.length; i++) {\n const block = blocks[i];\n timestampToBlock.set(block.timestamp, block);\n }\n const processedBlocks = new Set();\n const result = [];\n const processBlock = (block) => {\n if (processedBlocks.has(block)) {\n return;\n }\n // Marking the block as processed here already; prevents this algorithm from dying on cycles\n processedBlocks.add(block);\n for (let j = 0; j < block.referencedTimestamps.length; j++) {\n const timestamp = block.referencedTimestamps[j];\n const otherBlock = timestampToBlock.get(timestamp);\n if (!otherBlock) {\n continue;\n }\n processBlock(otherBlock);\n }\n result.push(block);\n };\n for (let i = 0; i < blocks.length; i++) {\n processBlock(blocks[i]);\n }\n return result;\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { Demuxer } from '../demuxer.js';\nimport { InputAudioTrack } from '../input-track.js';\nimport { assert, AsyncMutex, binarySearchExact, binarySearchLessOrEqual, UNDETERMINED_LANGUAGE } from '../misc.js';\nimport { EncodedPacket, PLACEHOLDER_DATA } from '../packet.js';\nimport { getXingOffset, INFO, XING } from '../../shared/mp3-misc.js';\nimport { ID3_V1_TAG_SIZE, ID3_V2_HEADER_SIZE, parseId3V1Tag, parseId3V2Tag, readId3V2Header, readNextFrameHeader, } from './mp3-reader.js';\nimport { readAscii, readBytes, readU32Be } from '../reader.js';\nexport class Mp3Demuxer extends Demuxer {\n constructor(input) {\n super(input);\n this.metadataPromise = null;\n this.firstFrameHeader = null;\n this.loadedSamples = []; // All samples from the start of the file to lastLoadedPos\n this.metadataTags = null;\n this.tracks = [];\n this.readingMutex = new AsyncMutex();\n this.lastSampleLoaded = false;\n this.lastLoadedPos = 0;\n this.nextTimestampInSamples = 0;\n this.reader = input._reader;\n }\n async readMetadata() {\n return this.metadataPromise ??= (async () => {\n // Keep loading until we find the first frame header\n while (!this.firstFrameHeader && !this.lastSampleLoaded) {\n await this.advanceReader();\n }\n if (!this.firstFrameHeader) {\n throw new Error('No valid MP3 frame found.');\n }\n this.tracks = [new InputAudioTrack(new Mp3AudioTrackBacking(this))];\n })();\n }\n async advanceReader() {\n if (this.lastLoadedPos === 0) {\n // Let's skip all ID3v2 tags at the start of the file\n while (true) {\n let slice = this.reader.requestSlice(this.lastLoadedPos, ID3_V2_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice) {\n this.lastSampleLoaded = true;\n return;\n }\n const id3V2Header = readId3V2Header(slice);\n if (!id3V2Header) {\n break;\n }\n this.lastLoadedPos = slice.filePos + id3V2Header.size;\n }\n }\n const result = await readNextFrameHeader(this.reader, this.lastLoadedPos, this.reader.fileSize);\n if (!result) {\n this.lastSampleLoaded = true;\n return;\n }\n const header = result.header;\n this.lastLoadedPos = result.startPos + header.totalSize - 1; // -1 in case the frame is 1 byte too short\n const xingOffset = getXingOffset(header.mpegVersionId, header.channel);\n let slice = this.reader.requestSlice(result.startPos + xingOffset, 4);\n if (slice instanceof Promise)\n slice = await slice;\n if (slice) {\n const word = readU32Be(slice);\n const isXing = word === XING || word === INFO;\n if (isXing) {\n // There's no actual audio data in this frame, so let's skip it\n return;\n }\n }\n if (!this.firstFrameHeader) {\n this.firstFrameHeader = header;\n }\n const sampleDuration = header.audioSamplesInFrame / header.sampleRate;\n const sample = {\n timestamp: this.nextTimestampInSamples / header.sampleRate,\n duration: sampleDuration,\n dataStart: result.startPos,\n dataSize: header.totalSize,\n };\n this.loadedSamples.push(sample);\n this.nextTimestampInSamples += header.audioSamplesInFrame;\n return;\n }\n async getMimeType() {\n return 'audio/mpeg';\n }\n async getTracks() {\n await this.readMetadata();\n return this.tracks;\n }\n async computeDuration() {\n await this.readMetadata();\n const track = this.tracks[0];\n assert(track);\n return track.computeDuration();\n }\n async getMetadataTags() {\n const release = await this.readingMutex.acquire();\n try {\n await this.readMetadata();\n if (this.metadataTags) {\n return this.metadataTags;\n }\n this.metadataTags = {};\n let currentPos = 0;\n let id3V2HeaderFound = false;\n while (true) {\n let headerSlice = this.reader.requestSlice(currentPos, ID3_V2_HEADER_SIZE);\n if (headerSlice instanceof Promise)\n headerSlice = await headerSlice;\n if (!headerSlice)\n break;\n const id3V2Header = readId3V2Header(headerSlice);\n if (!id3V2Header) {\n break;\n }\n id3V2HeaderFound = true;\n let contentSlice = this.reader.requestSlice(headerSlice.filePos, id3V2Header.size);\n if (contentSlice instanceof Promise)\n contentSlice = await contentSlice;\n if (!contentSlice)\n break;\n parseId3V2Tag(contentSlice, id3V2Header, this.metadataTags);\n currentPos = headerSlice.filePos + id3V2Header.size;\n }\n if (!id3V2HeaderFound && this.reader.fileSize !== null && this.reader.fileSize >= ID3_V1_TAG_SIZE) {\n // Try reading an ID3v1 tag at the end of the file\n let slice = this.reader.requestSlice(this.reader.fileSize - ID3_V1_TAG_SIZE, ID3_V1_TAG_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n assert(slice);\n const tag = readAscii(slice, 3);\n if (tag === 'TAG') {\n parseId3V1Tag(slice, this.metadataTags);\n }\n }\n return this.metadataTags;\n }\n finally {\n release();\n }\n }\n}\nclass Mp3AudioTrackBacking {\n constructor(demuxer) {\n this.demuxer = demuxer;\n }\n getId() {\n return 1;\n }\n async getFirstTimestamp() {\n return 0;\n }\n getTimeResolution() {\n assert(this.demuxer.firstFrameHeader);\n return this.demuxer.firstFrameHeader.sampleRate / this.demuxer.firstFrameHeader.audioSamplesInFrame;\n }\n async computeDuration() {\n const lastPacket = await this.getPacket(Infinity, { metadataOnly: true });\n return (lastPacket?.timestamp ?? 0) + (lastPacket?.duration ?? 0);\n }\n getName() {\n return null;\n }\n getLanguageCode() {\n return UNDETERMINED_LANGUAGE;\n }\n getCodec() {\n return 'mp3';\n }\n getInternalCodecId() {\n return null;\n }\n getNumberOfChannels() {\n assert(this.demuxer.firstFrameHeader);\n return this.demuxer.firstFrameHeader.channel === 3 ? 1 : 2;\n }\n getSampleRate() {\n assert(this.demuxer.firstFrameHeader);\n return this.demuxer.firstFrameHeader.sampleRate;\n }\n async getDecoderConfig() {\n assert(this.demuxer.firstFrameHeader);\n return {\n codec: 'mp3',\n numberOfChannels: this.demuxer.firstFrameHeader.channel === 3 ? 1 : 2,\n sampleRate: this.demuxer.firstFrameHeader.sampleRate,\n };\n }\n async getPacketAtIndex(sampleIndex, options) {\n if (sampleIndex === -1) {\n return null;\n }\n const rawSample = this.demuxer.loadedSamples[sampleIndex];\n if (!rawSample) {\n return null;\n }\n let data;\n if (options.metadataOnly) {\n data = PLACEHOLDER_DATA;\n }\n else {\n let slice = this.demuxer.reader.requestSlice(rawSample.dataStart, rawSample.dataSize);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice) {\n return null; // Data didn't fit into the rest of the file\n }\n data = readBytes(slice, rawSample.dataSize);\n }\n return new EncodedPacket(data, 'key', rawSample.timestamp, rawSample.duration, sampleIndex, rawSample.dataSize);\n }\n getFirstPacket(options) {\n return this.getPacketAtIndex(0, options);\n }\n async getNextPacket(packet, options) {\n const release = await this.demuxer.readingMutex.acquire();\n try {\n const sampleIndex = binarySearchExact(this.demuxer.loadedSamples, packet.timestamp, x => x.timestamp);\n if (sampleIndex === -1) {\n throw new Error('Packet was not created from this track.');\n }\n const nextIndex = sampleIndex + 1;\n // Ensure the next sample exists\n while (nextIndex >= this.demuxer.loadedSamples.length\n && !this.demuxer.lastSampleLoaded) {\n await this.demuxer.advanceReader();\n }\n return this.getPacketAtIndex(nextIndex, options);\n }\n finally {\n release();\n }\n }\n async getPacket(timestamp, options) {\n const release = await this.demuxer.readingMutex.acquire();\n try {\n while (true) {\n const index = binarySearchLessOrEqual(this.demuxer.loadedSamples, timestamp, x => x.timestamp);\n if (index === -1 && this.demuxer.loadedSamples.length > 0) {\n // We're before the first sample\n return null;\n }\n if (this.demuxer.lastSampleLoaded) {\n // All data is loaded, return what we found\n return this.getPacketAtIndex(index, options);\n }\n if (index >= 0 && index + 1 < this.demuxer.loadedSamples.length) {\n // The next packet also exists, we're done\n return this.getPacketAtIndex(index, options);\n }\n // Otherwise, keep loading data\n await this.demuxer.advanceReader();\n }\n }\n finally {\n release();\n }\n }\n getKeyPacket(timestamp, options) {\n return this.getPacket(timestamp, options);\n }\n getNextKeyPacket(packet, options) {\n return this.getNextPacket(packet, options);\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { OPUS_INTERNAL_SAMPLE_RATE } from '../codec.js';\nimport { parseModesFromVorbisSetupPacket, parseOpusIdentificationHeader } from '../codec-data.js';\nimport { Demuxer } from '../demuxer.js';\nimport { InputAudioTrack } from '../input-track.js';\nimport { assert, AsyncMutex, base64ToBytes, binarySearchLessOrEqual, findLast, last, roundToPrecision, textDecoder, toDataView, UNDETERMINED_LANGUAGE, } from '../misc.js';\nimport { EncodedPacket, PLACEHOLDER_DATA } from '../packet.js';\nimport { readBytes } from '../reader.js';\nimport { buildOggMimeType, computeOggPageCrc, extractSampleMetadata } from './ogg-misc.js';\nimport { findNextPageHeader, MAX_PAGE_HEADER_SIZE, MAX_PAGE_SIZE, MIN_PAGE_HEADER_SIZE, readPageHeader, } from './ogg-reader.js';\nexport class OggDemuxer extends Demuxer {\n constructor(input) {\n super(input);\n this.metadataPromise = null;\n this.bitstreams = [];\n this.tracks = [];\n this.metadataTags = {};\n this.reader = input._reader;\n }\n async readMetadata() {\n return this.metadataPromise ??= (async () => {\n let currentPos = 0;\n while (true) {\n let slice = this.reader.requestSliceRange(currentPos, MIN_PAGE_HEADER_SIZE, MAX_PAGE_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const page = readPageHeader(slice);\n if (!page) {\n break;\n }\n const isBos = !!(page.headerType & 0x02);\n if (!isBos) {\n // All bos pages for all bitstreams are required to be at the start, so if the page is not bos then\n // we know we've seen all bitstreams (minus chaining)\n break;\n }\n this.bitstreams.push({\n serialNumber: page.serialNumber,\n bosPage: page,\n description: null,\n numberOfChannels: -1,\n sampleRate: -1,\n codecInfo: {\n codec: null,\n vorbisInfo: null,\n opusInfo: null,\n },\n lastMetadataPacket: null,\n });\n currentPos = page.headerStartPos + page.totalSize;\n }\n for (const bitstream of this.bitstreams) {\n const firstPacket = await this.readPacket(bitstream.bosPage, 0);\n if (!firstPacket) {\n continue;\n }\n if (\n // Check for Vorbis\n firstPacket.data.byteLength >= 7\n && firstPacket.data[0] === 0x01 // Packet type 1 = identification header\n && firstPacket.data[1] === 0x76 // 'v'\n && firstPacket.data[2] === 0x6f // 'o'\n && firstPacket.data[3] === 0x72 // 'r'\n && firstPacket.data[4] === 0x62 // 'b'\n && firstPacket.data[5] === 0x69 // 'i'\n && firstPacket.data[6] === 0x73 // 's'\n ) {\n await this.readVorbisMetadata(firstPacket, bitstream);\n }\n else if (\n // Check for Opus\n firstPacket.data.byteLength >= 8\n && firstPacket.data[0] === 0x4f // 'O'\n && firstPacket.data[1] === 0x70 // 'p'\n && firstPacket.data[2] === 0x75 // 'u'\n && firstPacket.data[3] === 0x73 // 's'\n && firstPacket.data[4] === 0x48 // 'H'\n && firstPacket.data[5] === 0x65 // 'e'\n && firstPacket.data[6] === 0x61 // 'a'\n && firstPacket.data[7] === 0x64 // 'd'\n ) {\n await this.readOpusMetadata(firstPacket, bitstream);\n }\n if (bitstream.codecInfo.codec !== null) {\n this.tracks.push(new InputAudioTrack(new OggAudioTrackBacking(bitstream, this)));\n }\n }\n })();\n }\n async readVorbisMetadata(firstPacket, bitstream) {\n let nextPacketPosition = await this.findNextPacketStart(firstPacket);\n if (!nextPacketPosition) {\n return;\n }\n const secondPacket = await this.readPacket(nextPacketPosition.startPage, nextPacketPosition.startSegmentIndex);\n if (!secondPacket) {\n return;\n }\n nextPacketPosition = await this.findNextPacketStart(secondPacket);\n if (!nextPacketPosition) {\n return;\n }\n const thirdPacket = await this.readPacket(nextPacketPosition.startPage, nextPacketPosition.startSegmentIndex);\n if (!thirdPacket) {\n return;\n }\n if (secondPacket.data[0] !== 0x03 || thirdPacket.data[0] !== 0x05) {\n return;\n }\n const lacingValues = [];\n const addBytesToSegmentTable = (bytes) => {\n while (true) {\n lacingValues.push(Math.min(255, bytes));\n if (bytes < 255) {\n break;\n }\n bytes -= 255;\n }\n };\n addBytesToSegmentTable(firstPacket.data.length);\n addBytesToSegmentTable(secondPacket.data.length);\n // We don't add the last packet to the segment table, as it is assumed to be whatever bytes remain\n const description = new Uint8Array(1 + lacingValues.length\n + firstPacket.data.length + secondPacket.data.length + thirdPacket.data.length);\n description[0] = lacingValues.length;\n description.set(lacingValues, 1);\n description.set(firstPacket.data, 1 + lacingValues.length);\n description.set(secondPacket.data, 1 + lacingValues.length + firstPacket.data.length);\n description.set(thirdPacket.data, 1 + lacingValues.length + firstPacket.data.length + secondPacket.data.length);\n bitstream.codecInfo.codec = 'vorbis';\n bitstream.description = description;\n bitstream.lastMetadataPacket = thirdPacket;\n const view = toDataView(firstPacket.data);\n bitstream.numberOfChannels = view.getUint8(11);\n bitstream.sampleRate = view.getUint32(12, true);\n const blockSizeByte = view.getUint8(28);\n bitstream.codecInfo.vorbisInfo = {\n blocksizes: [\n 1 << (blockSizeByte & 0xf),\n 1 << (blockSizeByte >> 4),\n ],\n modeBlockflags: parseModesFromVorbisSetupPacket(thirdPacket.data).modeBlockflags,\n };\n this.readVorbisComments(secondPacket.data.subarray(7)); // Skip header type and 'vorbis'\n }\n async readOpusMetadata(firstPacket, bitstream) {\n // From https://datatracker.ietf.org/doc/html/rfc7845#section-5:\n // \"An Ogg Opus logical stream contains exactly two mandatory header packets: an identification header and a\n // comment header.\"\n const nextPacketPosition = await this.findNextPacketStart(firstPacket);\n if (!nextPacketPosition) {\n return;\n }\n const secondPacket = await this.readPacket(nextPacketPosition.startPage, nextPacketPosition.startSegmentIndex);\n if (!secondPacket) {\n return;\n }\n bitstream.codecInfo.codec = 'opus';\n bitstream.description = firstPacket.data;\n bitstream.lastMetadataPacket = secondPacket;\n const header = parseOpusIdentificationHeader(firstPacket.data);\n bitstream.numberOfChannels = header.outputChannelCount;\n bitstream.sampleRate = header.inputSampleRate;\n bitstream.codecInfo.opusInfo = {\n preSkip: header.preSkip,\n };\n this.readVorbisComments(secondPacket.data.subarray(8)); // Skip 'OpusTags'\n }\n readVorbisComments(bytes) {\n // https://datatracker.ietf.org/doc/html/rfc7845#section-5.2\n const commentView = toDataView(bytes);\n let commentPos = 0;\n const vendorStringLength = commentView.getUint32(commentPos, true);\n commentPos += 4;\n const vendorString = textDecoder.decode(bytes.subarray(commentPos, commentPos + vendorStringLength));\n commentPos += vendorStringLength;\n if (vendorStringLength > 0) {\n // Expose the vendor string in the raw metadata\n this.metadataTags.raw ??= {};\n this.metadataTags.raw['vendor'] ??= vendorString;\n }\n const listLength = commentView.getUint32(commentPos, true);\n commentPos += 4;\n // Loop over all metadata tags\n for (let i = 0; i < listLength; i++) {\n const stringLength = commentView.getUint32(commentPos, true);\n commentPos += 4;\n const string = textDecoder.decode(bytes.subarray(commentPos, commentPos + stringLength));\n commentPos += stringLength;\n const separatorIndex = string.indexOf('=');\n if (separatorIndex === -1) {\n continue;\n }\n const key = string.slice(0, separatorIndex).toUpperCase();\n const value = string.slice(separatorIndex + 1);\n this.metadataTags.raw ??= {};\n this.metadataTags.raw[key] ??= value;\n switch (key) {\n case 'TITLE':\n {\n this.metadataTags.title ??= value;\n }\n ;\n break;\n case 'DESCRIPTION':\n {\n this.metadataTags.description ??= value;\n }\n ;\n break;\n case 'ARTIST':\n {\n this.metadataTags.artist ??= value;\n }\n ;\n break;\n case 'ALBUM':\n {\n this.metadataTags.album ??= value;\n }\n ;\n break;\n case 'ALBUMARTIST':\n {\n this.metadataTags.albumArtist ??= value;\n }\n ;\n break;\n case 'COMMENT':\n {\n this.metadataTags.comment ??= value;\n }\n ;\n break;\n case 'LYRICS':\n {\n this.metadataTags.lyrics ??= value;\n }\n ;\n break;\n case 'TRACKNUMBER':\n {\n const parts = value.split('/');\n const trackNum = Number.parseInt(parts[0], 10);\n const tracksTotal = parts[1] && Number.parseInt(parts[1], 10);\n if (Number.isInteger(trackNum) && trackNum > 0) {\n this.metadataTags.trackNumber ??= trackNum;\n }\n if (tracksTotal && Number.isInteger(tracksTotal) && tracksTotal > 0) {\n this.metadataTags.tracksTotal ??= tracksTotal;\n }\n }\n ;\n break;\n case 'TRACKTOTAL':\n {\n const tracksTotal = Number.parseInt(value, 10);\n if (Number.isInteger(tracksTotal) && tracksTotal > 0) {\n this.metadataTags.tracksTotal ??= tracksTotal;\n }\n }\n ;\n break;\n case 'DISCNUMBER':\n {\n const parts = value.split('/');\n const discNum = Number.parseInt(parts[0], 10);\n const discsTotal = parts[1] && Number.parseInt(parts[1], 10);\n if (Number.isInteger(discNum) && discNum > 0) {\n this.metadataTags.discNumber ??= discNum;\n }\n if (discsTotal && Number.isInteger(discsTotal) && discsTotal > 0) {\n this.metadataTags.discsTotal ??= discsTotal;\n }\n }\n ;\n break;\n case 'DISCTOTAL':\n {\n const discsTotal = Number.parseInt(value, 10);\n if (Number.isInteger(discsTotal) && discsTotal > 0) {\n this.metadataTags.discsTotal ??= discsTotal;\n }\n }\n ;\n break;\n case 'DATE':\n {\n const date = new Date(value);\n if (!Number.isNaN(date.getTime())) {\n this.metadataTags.date ??= date;\n }\n }\n ;\n break;\n case 'GENRE':\n {\n this.metadataTags.genre ??= value;\n }\n ;\n break;\n case 'METADATA_BLOCK_PICTURE':\n {\n // https://datatracker.ietf.org/doc/rfc9639/ Section 8.8\n const decoded = base64ToBytes(value);\n const view = toDataView(decoded);\n const pictureType = view.getUint32(0, false);\n const mediaTypeLength = view.getUint32(4, false);\n const mediaType = String.fromCharCode(...decoded.subarray(8, 8 + mediaTypeLength)); // ASCII\n const descriptionLength = view.getUint32(8 + mediaTypeLength, false);\n const description = textDecoder.decode(decoded.subarray(12 + mediaTypeLength, 12 + mediaTypeLength + descriptionLength));\n const dataLength = view.getUint32(mediaTypeLength + descriptionLength + 28);\n const data = decoded.subarray(mediaTypeLength + descriptionLength + 32, mediaTypeLength + descriptionLength + 32 + dataLength);\n this.metadataTags.images ??= [];\n this.metadataTags.images.push({\n data,\n mimeType: mediaType,\n kind: pictureType === 3 ? 'coverFront' : pictureType === 4 ? 'coverBack' : 'unknown',\n name: undefined,\n description: description || undefined,\n });\n }\n ;\n break;\n }\n }\n }\n async readPacket(startPage, startSegmentIndex) {\n assert(startSegmentIndex < startPage.lacingValues.length);\n let startDataOffset = 0;\n for (let i = 0; i < startSegmentIndex; i++) {\n startDataOffset += startPage.lacingValues[i];\n }\n let currentPage = startPage;\n let currentDataOffset = startDataOffset;\n let currentSegmentIndex = startSegmentIndex;\n const chunks = [];\n outer: while (true) {\n // Load the entire page data\n let pageSlice = this.reader.requestSlice(currentPage.dataStartPos, currentPage.dataSize);\n if (pageSlice instanceof Promise)\n pageSlice = await pageSlice;\n assert(pageSlice);\n const pageData = readBytes(pageSlice, currentPage.dataSize);\n while (true) {\n if (currentSegmentIndex === currentPage.lacingValues.length) {\n chunks.push(pageData.subarray(startDataOffset, currentDataOffset));\n break;\n }\n const lacingValue = currentPage.lacingValues[currentSegmentIndex];\n currentDataOffset += lacingValue;\n if (lacingValue < 255) {\n chunks.push(pageData.subarray(startDataOffset, currentDataOffset));\n break outer;\n }\n currentSegmentIndex++;\n }\n // The packet extends to the next page; let's find it\n let currentPos = currentPage.headerStartPos + currentPage.totalSize;\n while (true) {\n let headerSlice = this.reader.requestSliceRange(currentPos, MIN_PAGE_HEADER_SIZE, MAX_PAGE_HEADER_SIZE);\n if (headerSlice instanceof Promise)\n headerSlice = await headerSlice;\n if (!headerSlice) {\n return null;\n }\n const nextPage = readPageHeader(headerSlice);\n if (!nextPage) {\n return null;\n }\n currentPage = nextPage;\n if (currentPage.serialNumber === startPage.serialNumber) {\n break;\n }\n currentPos = currentPage.headerStartPos + currentPage.totalSize;\n }\n startDataOffset = 0;\n currentDataOffset = 0;\n currentSegmentIndex = 0;\n }\n const totalPacketSize = chunks.reduce((sum, chunk) => sum + chunk.length, 0);\n const packetData = new Uint8Array(totalPacketSize);\n let offset = 0;\n for (let i = 0; i < chunks.length; i++) {\n const chunk = chunks[i];\n packetData.set(chunk, offset);\n offset += chunk.length;\n }\n return {\n data: packetData,\n endPage: currentPage,\n endSegmentIndex: currentSegmentIndex,\n };\n }\n async findNextPacketStart(lastPacket) {\n // If there's another segment in the same page, return it\n if (lastPacket.endSegmentIndex < lastPacket.endPage.lacingValues.length - 1) {\n return { startPage: lastPacket.endPage, startSegmentIndex: lastPacket.endSegmentIndex + 1 };\n }\n const isEos = !!(lastPacket.endPage.headerType & 0x04);\n if (isEos) {\n // The page is marked as the last page of the logical bitstream, so we won't find anything beyond it\n return null;\n }\n // Otherwise, search for the next page belonging to the same bitstream\n let currentPos = lastPacket.endPage.headerStartPos + lastPacket.endPage.totalSize;\n while (true) {\n let slice = this.reader.requestSliceRange(currentPos, MIN_PAGE_HEADER_SIZE, MAX_PAGE_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice) {\n return null;\n }\n const nextPage = readPageHeader(slice);\n if (!nextPage) {\n return null;\n }\n if (nextPage.serialNumber === lastPacket.endPage.serialNumber) {\n return { startPage: nextPage, startSegmentIndex: 0 };\n }\n currentPos = nextPage.headerStartPos + nextPage.totalSize;\n }\n }\n async getMimeType() {\n await this.readMetadata();\n const codecStrings = await Promise.all(this.tracks.map(x => x.getCodecParameterString()));\n return buildOggMimeType({\n codecStrings: codecStrings.filter(Boolean),\n });\n }\n async getTracks() {\n await this.readMetadata();\n return this.tracks;\n }\n async computeDuration() {\n const tracks = await this.getTracks();\n const trackDurations = await Promise.all(tracks.map(x => x.computeDuration()));\n return Math.max(0, ...trackDurations);\n }\n async getMetadataTags() {\n await this.readMetadata();\n return this.metadataTags;\n }\n}\nclass OggAudioTrackBacking {\n constructor(bitstream, demuxer) {\n this.bitstream = bitstream;\n this.demuxer = demuxer;\n this.encodedPacketToMetadata = new WeakMap();\n this.sequentialScanCache = [];\n this.sequentialScanMutex = new AsyncMutex();\n // Opus always uses a fixed sample rate for its internal calculations, even if the actual rate is different\n this.internalSampleRate = bitstream.codecInfo.codec === 'opus'\n ? OPUS_INTERNAL_SAMPLE_RATE\n : bitstream.sampleRate;\n }\n getId() {\n return this.bitstream.serialNumber;\n }\n getNumberOfChannels() {\n return this.bitstream.numberOfChannels;\n }\n getSampleRate() {\n return this.bitstream.sampleRate;\n }\n getTimeResolution() {\n return this.bitstream.sampleRate;\n }\n getCodec() {\n return this.bitstream.codecInfo.codec;\n }\n getInternalCodecId() {\n return null;\n }\n async getDecoderConfig() {\n assert(this.bitstream.codecInfo.codec);\n return {\n codec: this.bitstream.codecInfo.codec,\n numberOfChannels: this.bitstream.numberOfChannels,\n sampleRate: this.bitstream.sampleRate,\n description: this.bitstream.description ?? undefined,\n };\n }\n getName() {\n return null;\n }\n getLanguageCode() {\n return UNDETERMINED_LANGUAGE;\n }\n async getFirstTimestamp() {\n return 0;\n }\n async computeDuration() {\n const lastPacket = await this.getPacket(Infinity, { metadataOnly: true });\n return (lastPacket?.timestamp ?? 0) + (lastPacket?.duration ?? 0);\n }\n granulePositionToTimestampInSamples(granulePosition) {\n if (this.bitstream.codecInfo.codec === 'opus') {\n assert(this.bitstream.codecInfo.opusInfo);\n return granulePosition - this.bitstream.codecInfo.opusInfo.preSkip;\n }\n return granulePosition;\n }\n createEncodedPacketFromOggPacket(packet, additional, options) {\n if (!packet) {\n return null;\n }\n const { durationInSamples, vorbisBlockSize } = extractSampleMetadata(packet.data, this.bitstream.codecInfo, additional.vorbisLastBlocksize);\n const encodedPacket = new EncodedPacket(options.metadataOnly ? PLACEHOLDER_DATA : packet.data, 'key', Math.max(0, additional.timestampInSamples) / this.internalSampleRate, durationInSamples / this.internalSampleRate, packet.endPage.headerStartPos + packet.endSegmentIndex, packet.data.byteLength);\n this.encodedPacketToMetadata.set(encodedPacket, {\n packet,\n timestampInSamples: additional.timestampInSamples,\n durationInSamples,\n vorbisLastBlockSize: additional.vorbisLastBlocksize,\n vorbisBlockSize,\n });\n return encodedPacket;\n }\n async getFirstPacket(options) {\n assert(this.bitstream.lastMetadataPacket);\n const packetPosition = await this.demuxer.findNextPacketStart(this.bitstream.lastMetadataPacket);\n if (!packetPosition) {\n return null;\n }\n let timestampInSamples = 0;\n if (this.bitstream.codecInfo.codec === 'opus') {\n assert(this.bitstream.codecInfo.opusInfo);\n timestampInSamples -= this.bitstream.codecInfo.opusInfo.preSkip;\n }\n const packet = await this.demuxer.readPacket(packetPosition.startPage, packetPosition.startSegmentIndex);\n return this.createEncodedPacketFromOggPacket(packet, {\n timestampInSamples,\n vorbisLastBlocksize: null,\n }, options);\n }\n async getNextPacket(prevPacket, options) {\n const prevMetadata = this.encodedPacketToMetadata.get(prevPacket);\n if (!prevMetadata) {\n throw new Error('Packet was not created from this track.');\n }\n const packetPosition = await this.demuxer.findNextPacketStart(prevMetadata.packet);\n if (!packetPosition) {\n return null;\n }\n const timestampInSamples = prevMetadata.timestampInSamples + prevMetadata.durationInSamples;\n const packet = await this.demuxer.readPacket(packetPosition.startPage, packetPosition.startSegmentIndex);\n return this.createEncodedPacketFromOggPacket(packet, {\n timestampInSamples,\n vorbisLastBlocksize: prevMetadata.vorbisBlockSize,\n }, options);\n }\n async getPacket(timestamp, options) {\n if (this.demuxer.reader.fileSize === null) {\n // No file size known, can't do binary search, but fall back to sequential algo instead\n return this.getPacketSequential(timestamp, options);\n }\n const timestampInSamples = roundToPrecision(timestamp * this.internalSampleRate, 14);\n if (timestampInSamples === 0) {\n // Fast path for timestamp 0 - avoids binary search when playing back from the start\n return this.getFirstPacket(options);\n }\n if (timestampInSamples < 0) {\n // There's nothing here\n return null;\n }\n assert(this.bitstream.lastMetadataPacket);\n const startPosition = await this.demuxer.findNextPacketStart(this.bitstream.lastMetadataPacket);\n if (!startPosition) {\n return null;\n }\n let lowPage = startPosition.startPage;\n let high = this.demuxer.reader.fileSize;\n const lowPages = [lowPage];\n // First, let's perform a binary serach (bisection search) on the file to find the approximate page where\n // we'll find the packet. We want to find a page whose end packet position is less than or equal to the\n // packet position we're searching for.\n // Outer loop: Does the binary serach\n outer: while (lowPage.headerStartPos + lowPage.totalSize < high) {\n const low = lowPage.headerStartPos;\n const mid = Math.floor((low + high) / 2);\n let searchStartPos = mid;\n // Inner loop: Does a linear forward scan if the page cannot be found immediately\n while (true) {\n const until = Math.min(searchStartPos + MAX_PAGE_SIZE, high - MIN_PAGE_HEADER_SIZE);\n let searchSlice = this.demuxer.reader.requestSlice(searchStartPos, until - searchStartPos);\n if (searchSlice instanceof Promise)\n searchSlice = await searchSlice;\n assert(searchSlice);\n const found = findNextPageHeader(searchSlice, until);\n if (!found) {\n high = mid + MIN_PAGE_HEADER_SIZE;\n continue outer;\n }\n let headerSlice = this.demuxer.reader.requestSliceRange(searchSlice.filePos, MIN_PAGE_HEADER_SIZE, MAX_PAGE_HEADER_SIZE);\n if (headerSlice instanceof Promise)\n headerSlice = await headerSlice;\n assert(headerSlice);\n const page = readPageHeader(headerSlice);\n assert(page);\n let pageValid = false;\n if (page.serialNumber === this.bitstream.serialNumber) {\n // Serial numbers are basically random numbers, and the chance of finding a fake page with\n // matching serial number is astronomically low, so we can be pretty sure this page is legit.\n pageValid = true;\n }\n else {\n let pageSlice = this.demuxer.reader.requestSlice(page.headerStartPos, page.totalSize);\n if (pageSlice instanceof Promise)\n pageSlice = await pageSlice;\n assert(pageSlice);\n // Validate the page by checking checksum\n const bytes = readBytes(pageSlice, page.totalSize);\n const crc = computeOggPageCrc(bytes);\n pageValid = crc === page.checksum;\n }\n if (!pageValid) {\n // Keep searching for a valid page\n searchStartPos = page.headerStartPos + 4; // 'OggS' is 4 bytes\n continue;\n }\n if (pageValid && page.serialNumber !== this.bitstream.serialNumber) {\n // Page is valid but from a different bitstream, so keep searching forward until we find one\n // belonging to the our bitstream\n searchStartPos = page.headerStartPos + page.totalSize;\n continue;\n }\n const isContinuationPage = page.granulePosition === -1;\n if (isContinuationPage) {\n // No packet ends on this page - keep looking\n searchStartPos = page.headerStartPos + page.totalSize;\n continue;\n }\n // The page is valid and belongs to our bitstream; let's check its granule position to see where we\n // need to take the bisection search.\n if (this.granulePositionToTimestampInSamples(page.granulePosition) > timestampInSamples) {\n high = page.headerStartPos;\n }\n else {\n lowPage = page;\n lowPages.push(page);\n }\n continue outer;\n }\n }\n // Now we have the last page with a packet position <= the packet position we're looking for, but there\n // might be multiple pages with the packet position, in which case we actually need to find the first of\n // such pages. We'll do this in two steps: First, let's find the latest page we know with an earlier packet\n // position, and then linear scan ourselves forward until we find the correct page.\n let lowerPage = startPosition.startPage;\n for (const otherLowPage of lowPages) {\n if (otherLowPage.granulePosition === lowPage.granulePosition) {\n break;\n }\n if (!lowerPage || otherLowPage.headerStartPos > lowerPage.headerStartPos) {\n lowerPage = otherLowPage;\n }\n }\n let currentPage = lowerPage;\n // Keep track of the pages we traversed, we need these later for backwards seeking\n const previousPages = [currentPage];\n while (true) {\n // This loop must terminate as we'll eventually reach lowPage\n if (currentPage.serialNumber === this.bitstream.serialNumber\n && currentPage.granulePosition === lowPage.granulePosition) {\n break;\n }\n const nextPos = currentPage.headerStartPos + currentPage.totalSize;\n let slice = this.demuxer.reader.requestSliceRange(nextPos, MIN_PAGE_HEADER_SIZE, MAX_PAGE_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n assert(slice);\n const nextPage = readPageHeader(slice);\n assert(nextPage);\n currentPage = nextPage;\n if (currentPage.serialNumber === this.bitstream.serialNumber) {\n previousPages.push(currentPage);\n }\n }\n assert(currentPage.granulePosition !== -1);\n let currentSegmentIndex = null;\n let currentTimestampInSamples;\n let currentTimestampIsCorrect;\n // These indicate the end position of the packet that the granule position belongs to\n let endPage = currentPage;\n let endSegmentIndex = 0;\n if (currentPage.headerStartPos === startPosition.startPage.headerStartPos) {\n currentTimestampInSamples = this.granulePositionToTimestampInSamples(0);\n currentTimestampIsCorrect = true;\n currentSegmentIndex = 0;\n }\n else {\n currentTimestampInSamples = 0; // Placeholder value! We'll refine it once we can\n currentTimestampIsCorrect = false;\n // Find the segment index of the next packet\n for (let i = currentPage.lacingValues.length - 1; i >= 0; i--) {\n const value = currentPage.lacingValues[i];\n if (value < 255) {\n // We know the last packet ended at i, so the next one starts at i + 1\n currentSegmentIndex = i + 1;\n break;\n }\n }\n // This must hold: Since this page has a granule position set, that means there must be a packet that\n // ends in this page.\n if (currentSegmentIndex === null) {\n throw new Error('Invalid page with granule position: no packets end on this page.');\n }\n endSegmentIndex = currentSegmentIndex - 1;\n const pseudopacket = {\n data: PLACEHOLDER_DATA,\n endPage,\n endSegmentIndex,\n };\n const nextPosition = await this.demuxer.findNextPacketStart(pseudopacket);\n if (nextPosition) {\n // Let's rewind a single step (packet) - this previous packet ensures that we'll correctly compute\n // the duration for the packet we're looking for.\n const endPosition = findPreviousPacketEndPosition(previousPages, currentPage, currentSegmentIndex);\n assert(endPosition);\n const startPosition = findPacketStartPosition(previousPages, endPosition.page, endPosition.segmentIndex);\n if (startPosition) {\n currentPage = startPosition.page;\n currentSegmentIndex = startPosition.segmentIndex;\n }\n }\n else {\n // There is no next position, which means we're looking for the last packet in the bitstream. The\n // granule position on the last page tends to be fucky, so let's instead start the search on the\n // page before that. So let's loop until we find a packet that ends in a previous page.\n while (true) {\n const endPosition = findPreviousPacketEndPosition(previousPages, currentPage, currentSegmentIndex);\n if (!endPosition) {\n break;\n }\n const startPosition = findPacketStartPosition(previousPages, endPosition.page, endPosition.segmentIndex);\n if (!startPosition) {\n break;\n }\n currentPage = startPosition.page;\n currentSegmentIndex = startPosition.segmentIndex;\n if (endPosition.page.headerStartPos !== endPage.headerStartPos) {\n endPage = endPosition.page;\n endSegmentIndex = endPosition.segmentIndex;\n break;\n }\n }\n }\n }\n let lastEncodedPacket = null;\n let lastEncodedPacketMetadata = null;\n // Alright, now it's time for the final, granular seek: We keep iterating over packets until we've found the\n // one with the correct timestamp - i.e., the last one with a timestamp <= the timestamp we're looking for.\n while (currentPage !== null) {\n assert(currentSegmentIndex !== null);\n const packet = await this.demuxer.readPacket(currentPage, currentSegmentIndex);\n if (!packet) {\n break;\n }\n // We might need to skip the packet if it's a metadata one\n const skipPacket = currentPage.headerStartPos === startPosition.startPage.headerStartPos\n && currentSegmentIndex < startPosition.startSegmentIndex;\n if (!skipPacket) {\n let encodedPacket = this.createEncodedPacketFromOggPacket(packet, {\n timestampInSamples: currentTimestampInSamples,\n vorbisLastBlocksize: lastEncodedPacketMetadata?.vorbisBlockSize ?? null,\n }, options);\n assert(encodedPacket);\n let encodedPacketMetadata = this.encodedPacketToMetadata.get(encodedPacket);\n assert(encodedPacketMetadata);\n if (!currentTimestampIsCorrect\n && packet.endPage.headerStartPos === endPage.headerStartPos\n && packet.endSegmentIndex === endSegmentIndex) {\n // We know this packet end timestamp can be derived from the page's granule position\n currentTimestampInSamples = this.granulePositionToTimestampInSamples(currentPage.granulePosition);\n currentTimestampIsCorrect = true;\n // Let's backpatch the packet we just created with the correct timestamp\n encodedPacket = this.createEncodedPacketFromOggPacket(packet, {\n timestampInSamples: currentTimestampInSamples - encodedPacketMetadata.durationInSamples,\n vorbisLastBlocksize: lastEncodedPacketMetadata?.vorbisBlockSize ?? null,\n }, options);\n assert(encodedPacket);\n encodedPacketMetadata = this.encodedPacketToMetadata.get(encodedPacket);\n assert(encodedPacketMetadata);\n }\n else {\n currentTimestampInSamples += encodedPacketMetadata.durationInSamples;\n }\n lastEncodedPacket = encodedPacket;\n lastEncodedPacketMetadata = encodedPacketMetadata;\n if (currentTimestampIsCorrect\n && (\n // Next timestamp will be too late\n Math.max(currentTimestampInSamples, 0) > timestampInSamples\n // This timestamp already matches\n || Math.max(encodedPacketMetadata.timestampInSamples, 0) === timestampInSamples)) {\n break;\n }\n }\n const nextPosition = await this.demuxer.findNextPacketStart(packet);\n if (!nextPosition) {\n break;\n }\n currentPage = nextPosition.startPage;\n currentSegmentIndex = nextPosition.startSegmentIndex;\n }\n return lastEncodedPacket;\n }\n // A slower but simpler and sequential algorithm for finding a packet in a file\n async getPacketSequential(timestamp, options) {\n const release = await this.sequentialScanMutex.acquire(); // Requires exclusivity because we write to a cache\n try {\n const timestampInSamples = roundToPrecision(timestamp * this.internalSampleRate, 14);\n timestamp = timestampInSamples / this.internalSampleRate;\n const index = binarySearchLessOrEqual(this.sequentialScanCache, timestampInSamples, x => x.timestampInSamples);\n let currentPacket;\n if (index !== -1) {\n // We don't need to start from the beginning, we can start at a previous scan point\n const cacheEntry = this.sequentialScanCache[index];\n currentPacket = this.createEncodedPacketFromOggPacket(cacheEntry.packet, {\n timestampInSamples: cacheEntry.timestampInSamples,\n vorbisLastBlocksize: cacheEntry.vorbisLastBlockSize,\n }, options);\n }\n else {\n currentPacket = await this.getFirstPacket(options);\n }\n let i = 0;\n while (currentPacket && currentPacket.timestamp < timestamp) {\n const nextPacket = await this.getNextPacket(currentPacket, options);\n if (!nextPacket || nextPacket.timestamp > timestamp) {\n break;\n }\n currentPacket = nextPacket;\n i++;\n if (i === 100) {\n // Add \"checkpoints\" every once in a while to speed up subsequent random accesses\n i = 0;\n const metadata = this.encodedPacketToMetadata.get(currentPacket);\n assert(metadata);\n if (this.sequentialScanCache.length > 0) {\n // If we reach this case, we must be at the end of the cache\n assert(last(this.sequentialScanCache).timestampInSamples <= metadata.timestampInSamples);\n }\n this.sequentialScanCache.push(metadata);\n }\n }\n return currentPacket;\n }\n finally {\n release();\n }\n }\n getKeyPacket(timestamp, options) {\n return this.getPacket(timestamp, options);\n }\n getNextKeyPacket(packet, options) {\n return this.getNextPacket(packet, options);\n }\n}\n/** Finds the start position of a packet given its end position. */\nconst findPacketStartPosition = (pageList, endPage, endSegmentIndex) => {\n let page = endPage;\n let segmentIndex = endSegmentIndex;\n outer: while (true) {\n segmentIndex--;\n for (segmentIndex; segmentIndex >= 0; segmentIndex--) {\n const lacingValue = page.lacingValues[segmentIndex];\n if (lacingValue < 255) {\n segmentIndex++; // We know the last packet starts here\n break outer;\n }\n }\n assert(segmentIndex === -1);\n const pageStartsWithFreshPacket = !(page.headerType & 0x01);\n if (pageStartsWithFreshPacket) {\n // Fast exit: We know we don't need to look in the previous page\n segmentIndex = 0;\n break;\n }\n const previousPage = findLast(pageList, x => x.headerStartPos < page.headerStartPos);\n if (!previousPage) {\n return null;\n }\n page = previousPage;\n segmentIndex = page.lacingValues.length;\n }\n assert(segmentIndex !== -1);\n if (segmentIndex === page.lacingValues.length) {\n // Wrap back around to the first segment of the next page\n const nextPage = pageList[pageList.indexOf(page) + 1];\n assert(nextPage);\n page = nextPage;\n segmentIndex = 0;\n }\n return { page, segmentIndex };\n};\n/** Finds the end position of a packet given the start position of the following packet. */\nconst findPreviousPacketEndPosition = (pageList, startPage, startSegmentIndex) => {\n if (startSegmentIndex > 0) {\n // Easy\n return { page: startPage, segmentIndex: startSegmentIndex - 1 };\n }\n const previousPage = findLast(pageList, x => x.headerStartPos < startPage.headerStartPos);\n if (!previousPage) {\n return null;\n }\n return { page: previousPage, segmentIndex: previousPage.lacingValues.length - 1 };\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { Bitstream } from '../misc.js';\nimport { readBytes } from '../reader.js';\nexport const MIN_FRAME_HEADER_SIZE = 7;\nexport const MAX_FRAME_HEADER_SIZE = 9;\nexport const readFrameHeader = (slice) => {\n // https://wiki.multimedia.cx/index.php/ADTS (last visited: 2025/08/17)\n const startPos = slice.filePos;\n const bytes = readBytes(slice, 9); // 9 with CRC, 7 without CRC\n const bitstream = new Bitstream(bytes);\n const syncword = bitstream.readBits(12);\n if (syncword !== 0b1111_11111111) {\n return null;\n }\n bitstream.skipBits(1); // MPEG version\n const layer = bitstream.readBits(2);\n if (layer !== 0) {\n return null;\n }\n const protectionAbsence = bitstream.readBits(1);\n const objectType = bitstream.readBits(2) + 1;\n const samplingFrequencyIndex = bitstream.readBits(4);\n if (samplingFrequencyIndex === 15) {\n return null;\n }\n bitstream.skipBits(1); // Private bit\n const channelConfiguration = bitstream.readBits(3);\n if (channelConfiguration === 0) {\n throw new Error('ADTS frames with channel configuration 0 are not supported.');\n }\n bitstream.skipBits(1); // Originality\n bitstream.skipBits(1); // Home\n bitstream.skipBits(1); // Copyright ID bit\n bitstream.skipBits(1); // Copyright ID start\n const frameLength = bitstream.readBits(13);\n bitstream.skipBits(11); // Buffer fullness\n const numberOfAacFrames = bitstream.readBits(2) + 1;\n if (numberOfAacFrames !== 1) {\n throw new Error('ADTS frames with more than one AAC frame are not supported.');\n }\n let crcCheck = null;\n if (protectionAbsence === 1) { // No CRC\n slice.filePos -= 2;\n }\n else { // CRC\n crcCheck = bitstream.readBits(16);\n }\n return {\n objectType,\n samplingFrequencyIndex,\n channelConfiguration,\n frameLength,\n numberOfAacFrames,\n crcCheck,\n startPos,\n };\n};\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { aacChannelMap, aacFrequencyTable } from '../codec.js';\nimport { Demuxer } from '../demuxer.js';\nimport { InputAudioTrack } from '../input-track.js';\nimport { assert, AsyncMutex, binarySearchExact, binarySearchLessOrEqual, Bitstream, UNDETERMINED_LANGUAGE, } from '../misc.js';\nimport { EncodedPacket, PLACEHOLDER_DATA } from '../packet.js';\nimport { readBytes } from '../reader.js';\nimport { MAX_FRAME_HEADER_SIZE, MIN_FRAME_HEADER_SIZE, readFrameHeader } from './adts-reader.js';\nconst SAMPLES_PER_AAC_FRAME = 1024;\nexport class AdtsDemuxer extends Demuxer {\n constructor(input) {\n super(input);\n this.metadataPromise = null;\n this.firstFrameHeader = null;\n this.loadedSamples = [];\n this.tracks = [];\n this.readingMutex = new AsyncMutex();\n this.lastSampleLoaded = false;\n this.lastLoadedPos = 0;\n this.nextTimestampInSamples = 0;\n this.reader = input._reader;\n }\n async readMetadata() {\n return this.metadataPromise ??= (async () => {\n // Keep loading until we find the first frame header\n while (!this.firstFrameHeader && !this.lastSampleLoaded) {\n await this.advanceReader();\n }\n // There has to be a frame if this demuxer got selected\n assert(this.firstFrameHeader);\n // Create the single audio track\n this.tracks = [new InputAudioTrack(new AdtsAudioTrackBacking(this))];\n })();\n }\n async advanceReader() {\n let slice = this.reader.requestSliceRange(this.lastLoadedPos, MIN_FRAME_HEADER_SIZE, MAX_FRAME_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice) {\n this.lastSampleLoaded = true;\n return;\n }\n const header = readFrameHeader(slice);\n if (!header) {\n this.lastSampleLoaded = true;\n return;\n }\n if (this.reader.fileSize !== null && header.startPos + header.frameLength > this.reader.fileSize) {\n // Frame doesn't fit in the rest of the file\n this.lastSampleLoaded = true;\n return;\n }\n if (!this.firstFrameHeader) {\n this.firstFrameHeader = header;\n }\n const sampleRate = aacFrequencyTable[header.samplingFrequencyIndex];\n assert(sampleRate !== undefined);\n const sampleDuration = SAMPLES_PER_AAC_FRAME / sampleRate;\n const headerSize = header.crcCheck ? MAX_FRAME_HEADER_SIZE : MIN_FRAME_HEADER_SIZE;\n const sample = {\n timestamp: this.nextTimestampInSamples / sampleRate,\n duration: sampleDuration,\n dataStart: header.startPos + headerSize,\n dataSize: header.frameLength - headerSize,\n };\n this.loadedSamples.push(sample);\n this.nextTimestampInSamples += SAMPLES_PER_AAC_FRAME;\n this.lastLoadedPos = header.startPos + header.frameLength;\n }\n async getMimeType() {\n return 'audio/aac';\n }\n async getTracks() {\n await this.readMetadata();\n return this.tracks;\n }\n async computeDuration() {\n await this.readMetadata();\n const track = this.tracks[0];\n assert(track);\n return track.computeDuration();\n }\n async getMetadataTags() {\n return {}; // No tags in this one\n }\n}\nclass AdtsAudioTrackBacking {\n constructor(demuxer) {\n this.demuxer = demuxer;\n }\n getId() {\n return 1;\n }\n async getFirstTimestamp() {\n return 0;\n }\n getTimeResolution() {\n const sampleRate = this.getSampleRate();\n return sampleRate / SAMPLES_PER_AAC_FRAME;\n }\n async computeDuration() {\n const lastPacket = await this.getPacket(Infinity, { metadataOnly: true });\n return (lastPacket?.timestamp ?? 0) + (lastPacket?.duration ?? 0);\n }\n getName() {\n return null;\n }\n getLanguageCode() {\n return UNDETERMINED_LANGUAGE;\n }\n getCodec() {\n return 'aac';\n }\n getInternalCodecId() {\n assert(this.demuxer.firstFrameHeader);\n return this.demuxer.firstFrameHeader.objectType;\n }\n getNumberOfChannels() {\n assert(this.demuxer.firstFrameHeader);\n const numberOfChannels = aacChannelMap[this.demuxer.firstFrameHeader.channelConfiguration];\n assert(numberOfChannels !== undefined);\n return numberOfChannels;\n }\n getSampleRate() {\n assert(this.demuxer.firstFrameHeader);\n const sampleRate = aacFrequencyTable[this.demuxer.firstFrameHeader.samplingFrequencyIndex];\n assert(sampleRate !== undefined);\n return sampleRate;\n }\n async getDecoderConfig() {\n assert(this.demuxer.firstFrameHeader);\n const bytes = new Uint8Array(3); // 19 bits max\n const bitstream = new Bitstream(bytes);\n const { objectType, samplingFrequencyIndex, channelConfiguration } = this.demuxer.firstFrameHeader;\n if (objectType > 31) {\n bitstream.writeBits(5, 31);\n bitstream.writeBits(6, objectType - 32);\n }\n else {\n bitstream.writeBits(5, objectType);\n }\n bitstream.writeBits(4, samplingFrequencyIndex); // samplingFrequencyIndex === 15 is forbidden\n bitstream.writeBits(4, channelConfiguration);\n return {\n codec: `mp4a.40.${this.demuxer.firstFrameHeader.objectType}`,\n numberOfChannels: this.getNumberOfChannels(),\n sampleRate: this.getSampleRate(),\n description: bytes.subarray(0, Math.ceil((bitstream.pos - 1) / 8)),\n };\n }\n async getPacketAtIndex(sampleIndex, options) {\n if (sampleIndex === -1) {\n return null;\n }\n const rawSample = this.demuxer.loadedSamples[sampleIndex];\n if (!rawSample) {\n return null;\n }\n let data;\n if (options.metadataOnly) {\n data = PLACEHOLDER_DATA;\n }\n else {\n let slice = this.demuxer.reader.requestSlice(rawSample.dataStart, rawSample.dataSize);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice) {\n return null; // Data didn't fit into the rest of the file\n }\n data = readBytes(slice, rawSample.dataSize);\n }\n return new EncodedPacket(data, 'key', rawSample.timestamp, rawSample.duration, sampleIndex, rawSample.dataSize);\n }\n getFirstPacket(options) {\n return this.getPacketAtIndex(0, options);\n }\n async getNextPacket(packet, options) {\n const release = await this.demuxer.readingMutex.acquire();\n try {\n const sampleIndex = binarySearchExact(this.demuxer.loadedSamples, packet.timestamp, x => x.timestamp);\n if (sampleIndex === -1) {\n throw new Error('Packet was not created from this track.');\n }\n const nextIndex = sampleIndex + 1;\n // Ensure the next sample exists\n while (nextIndex >= this.demuxer.loadedSamples.length\n && !this.demuxer.lastSampleLoaded) {\n await this.demuxer.advanceReader();\n }\n return this.getPacketAtIndex(nextIndex, options);\n }\n finally {\n release();\n }\n }\n async getPacket(timestamp, options) {\n const release = await this.demuxer.readingMutex.acquire();\n try {\n while (true) {\n const index = binarySearchLessOrEqual(this.demuxer.loadedSamples, timestamp, x => x.timestamp);\n if (index === -1 && this.demuxer.loadedSamples.length > 0) {\n // We're before the first sample\n return null;\n }\n if (this.demuxer.lastSampleLoaded) {\n // All data is loaded, return what we found\n return this.getPacketAtIndex(index, options);\n }\n if (index >= 0 && index + 1 < this.demuxer.loadedSamples.length) {\n // The next packet also exists, we're done\n return this.getPacketAtIndex(index, options);\n }\n // Otherwise, keep loading data\n await this.demuxer.advanceReader();\n }\n }\n finally {\n release();\n }\n }\n getKeyPacket(timestamp, options) {\n return this.getPacket(timestamp, options);\n }\n getNextKeyPacket(packet, options) {\n return this.getNextPacket(packet, options);\n }\n}\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { IsobmffDemuxer } from './isobmff/isobmff-demuxer.js';\nimport { EBMLId, MAX_HEADER_SIZE, MIN_HEADER_SIZE, readAsciiString, readElementHeader, readElementSize, readUnsignedInt, readVarIntSize, } from './matroska/ebml.js';\nimport { MatroskaDemuxer } from './matroska/matroska-demuxer.js';\nimport { Mp3Demuxer } from './mp3/mp3-demuxer.js';\nimport { FRAME_HEADER_SIZE } from '../shared/mp3-misc.js';\nimport { ID3_V2_HEADER_SIZE, readId3V2Header, readNextFrameHeader } from './mp3/mp3-reader.js';\nimport { OggDemuxer } from './ogg/ogg-demuxer.js';\nimport { WaveDemuxer } from './wave/wave-demuxer.js';\nimport { MAX_FRAME_HEADER_SIZE, MIN_FRAME_HEADER_SIZE, readFrameHeader } from './adts/adts-reader.js';\nimport { AdtsDemuxer } from './adts/adts-demuxer.js';\nimport { readAscii } from './reader.js';\n/**\n * Base class representing an input media file format.\n * @group Input formats\n * @public\n */\nexport class InputFormat {\n}\n/**\n * Format representing files compatible with the ISO base media file format (ISOBMFF), like MP4 or MOV files.\n * @group Input formats\n * @public\n */\nexport class IsobmffInputFormat extends InputFormat {\n /** @internal */\n async _getMajorBrand(input) {\n let slice = input._reader.requestSlice(0, 12);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return null;\n slice.skip(4);\n const fourCc = readAscii(slice, 4);\n if (fourCc !== 'ftyp') {\n return null;\n }\n return readAscii(slice, 4);\n }\n /** @internal */\n _createDemuxer(input) {\n return new IsobmffDemuxer(input);\n }\n}\n/**\n * MPEG-4 Part 14 (MP4) file format.\n *\n * Do not instantiate this class; use the {@link MP4} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class Mp4InputFormat extends IsobmffInputFormat {\n /** @internal */\n async _canReadInput(input) {\n const majorBrand = await this._getMajorBrand(input);\n return !!majorBrand && majorBrand !== 'qt ';\n }\n get name() {\n return 'MP4';\n }\n get mimeType() {\n return 'video/mp4';\n }\n}\n/**\n * QuickTime File Format (QTFF), often called MOV.\n *\n * Do not instantiate this class; use the {@link QTFF} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class QuickTimeInputFormat extends IsobmffInputFormat {\n /** @internal */\n async _canReadInput(input) {\n const majorBrand = await this._getMajorBrand(input);\n return majorBrand === 'qt ';\n }\n get name() {\n return 'QuickTime File Format';\n }\n get mimeType() {\n return 'video/quicktime';\n }\n}\n/**\n * Matroska file format.\n *\n * Do not instantiate this class; use the {@link MATROSKA} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class MatroskaInputFormat extends InputFormat {\n /** @internal */\n async isSupportedEBMLOfDocType(input, desiredDocType) {\n let headerSlice = input._reader.requestSlice(0, MAX_HEADER_SIZE);\n if (headerSlice instanceof Promise)\n headerSlice = await headerSlice;\n if (!headerSlice)\n return false;\n const varIntSize = readVarIntSize(headerSlice);\n if (varIntSize === null) {\n return false;\n }\n if (varIntSize < 1 || varIntSize > 8) {\n return false;\n }\n const id = readUnsignedInt(headerSlice, varIntSize);\n if (id !== EBMLId.EBML) {\n return false;\n }\n const dataSize = readElementSize(headerSlice);\n if (dataSize === null) {\n return false; // Miss me with that shit\n }\n let dataSlice = input._reader.requestSlice(headerSlice.filePos, dataSize);\n if (dataSlice instanceof Promise)\n dataSlice = await dataSlice;\n if (!dataSlice)\n return false;\n const startPos = headerSlice.filePos;\n while (dataSlice.filePos <= startPos + dataSize - MIN_HEADER_SIZE) {\n const header = readElementHeader(dataSlice);\n if (!header)\n break;\n const { id, size } = header;\n const dataStartPos = dataSlice.filePos;\n if (size === null)\n return false;\n switch (id) {\n case EBMLId.EBMLVersion:\n {\n const ebmlVersion = readUnsignedInt(dataSlice, size);\n if (ebmlVersion !== 1) {\n return false;\n }\n }\n ;\n break;\n case EBMLId.EBMLReadVersion:\n {\n const ebmlReadVersion = readUnsignedInt(dataSlice, size);\n if (ebmlReadVersion !== 1) {\n return false;\n }\n }\n ;\n break;\n case EBMLId.DocType:\n {\n const docType = readAsciiString(dataSlice, size);\n if (docType !== desiredDocType) {\n return false;\n }\n }\n ;\n break;\n case EBMLId.DocTypeVersion:\n {\n const docTypeVersion = readUnsignedInt(dataSlice, size);\n if (docTypeVersion > 4) { // Support up to Matroska v4\n return false;\n }\n }\n ;\n break;\n }\n dataSlice.filePos = dataStartPos + size;\n }\n return true;\n }\n /** @internal */\n _canReadInput(input) {\n return this.isSupportedEBMLOfDocType(input, 'matroska');\n }\n /** @internal */\n _createDemuxer(input) {\n return new MatroskaDemuxer(input);\n }\n get name() {\n return 'Matroska';\n }\n get mimeType() {\n return 'video/x-matroska';\n }\n}\n/**\n * WebM file format, based on Matroska.\n *\n * Do not instantiate this class; use the {@link WEBM} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class WebMInputFormat extends MatroskaInputFormat {\n /** @internal */\n _canReadInput(input) {\n return this.isSupportedEBMLOfDocType(input, 'webm');\n }\n get name() {\n return 'WebM';\n }\n get mimeType() {\n return 'video/webm';\n }\n}\n/**\n * MP3 file format.\n *\n * Do not instantiate this class; use the {@link MP3} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class Mp3InputFormat extends InputFormat {\n /** @internal */\n async _canReadInput(input) {\n let slice = input._reader.requestSlice(0, 10);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return false;\n let currentPos = 0;\n let id3V2HeaderFound = false;\n while (true) {\n let slice = input._reader.requestSlice(currentPos, ID3_V2_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n break;\n const id3V2Header = readId3V2Header(slice);\n if (!id3V2Header) {\n break;\n }\n id3V2HeaderFound = true;\n currentPos = slice.filePos + id3V2Header.size;\n }\n const firstResult = await readNextFrameHeader(input._reader, currentPos, currentPos + 4096);\n if (!firstResult) {\n return false;\n }\n if (id3V2HeaderFound) {\n // If there was an ID3v2 tag at the start, we can be pretty sure this is MP3 by now\n return true;\n }\n currentPos = firstResult.startPos += firstResult.header.totalSize;\n // Fine, we found one frame header, but we're still not entirely sure this is MP3. Let's check if we can find\n // another header right after it:\n const secondResult = await readNextFrameHeader(input._reader, currentPos, currentPos + FRAME_HEADER_SIZE);\n if (!secondResult) {\n return false;\n }\n const firstHeader = firstResult.header;\n const secondHeader = secondResult.header;\n // In a well-formed MP3 file, we'd expect these two frames to share some similarities:\n if (firstHeader.channel !== secondHeader.channel || firstHeader.sampleRate !== secondHeader.sampleRate) {\n return false;\n }\n // We have found two matching consecutive MP3 frames, a strong indicator that this is an MP3 file\n return true;\n }\n /** @internal */\n _createDemuxer(input) {\n return new Mp3Demuxer(input);\n }\n get name() {\n return 'MP3';\n }\n get mimeType() {\n return 'audio/mpeg';\n }\n}\n/**\n * WAVE file format, based on RIFF.\n *\n * Do not instantiate this class; use the {@link WAVE} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class WaveInputFormat extends InputFormat {\n /** @internal */\n async _canReadInput(input) {\n let slice = input._reader.requestSlice(0, 12);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return false;\n const riffType = readAscii(slice, 4);\n if (riffType !== 'RIFF' && riffType !== 'RIFX' && riffType !== 'RF64') {\n return false;\n }\n slice.skip(4);\n const format = readAscii(slice, 4);\n return format === 'WAVE';\n }\n /** @internal */\n _createDemuxer(input) {\n return new WaveDemuxer(input);\n }\n get name() {\n return 'WAVE';\n }\n get mimeType() {\n return 'audio/wav';\n }\n}\n/**\n * Ogg file format.\n *\n * Do not instantiate this class; use the {@link OGG} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class OggInputFormat extends InputFormat {\n /** @internal */\n async _canReadInput(input) {\n let slice = input._reader.requestSlice(0, 4);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return false;\n return readAscii(slice, 4) === 'OggS';\n }\n /** @internal */\n _createDemuxer(input) {\n return new OggDemuxer(input);\n }\n get name() {\n return 'Ogg';\n }\n get mimeType() {\n return 'application/ogg';\n }\n}\n/**\n * ADTS file format.\n *\n * Do not instantiate this class; use the {@link ADTS} singleton instead.\n *\n * @group Input formats\n * @public\n */\nexport class AdtsInputFormat extends InputFormat {\n /** @internal */\n async _canReadInput(input) {\n let slice = input._reader.requestSliceRange(0, MIN_FRAME_HEADER_SIZE, MAX_FRAME_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return false;\n const firstHeader = readFrameHeader(slice);\n if (!firstHeader) {\n return false;\n }\n slice = input._reader.requestSliceRange(firstHeader.frameLength, MIN_FRAME_HEADER_SIZE, MAX_FRAME_HEADER_SIZE);\n if (slice instanceof Promise)\n slice = await slice;\n if (!slice)\n return false;\n const secondHeader = readFrameHeader(slice);\n if (!secondHeader) {\n return false;\n }\n return firstHeader.objectType === secondHeader.objectType\n && firstHeader.samplingFrequencyIndex === secondHeader.samplingFrequencyIndex\n && firstHeader.channelConfiguration === secondHeader.channelConfiguration;\n }\n /** @internal */\n _createDemuxer(input) {\n return new AdtsDemuxer(input);\n }\n get name() {\n return 'ADTS';\n }\n get mimeType() {\n return 'audio/aac';\n }\n}\n/**\n * MP4 input format singleton.\n * @group Input formats\n * @public\n */\nexport const MP4 = new Mp4InputFormat();\n/**\n * QuickTime File Format input format singleton.\n * @group Input formats\n * @public\n */\nexport const QTFF = new QuickTimeInputFormat();\n/**\n * Matroska input format singleton.\n * @group Input formats\n * @public\n */\nexport const MATROSKA = new MatroskaInputFormat();\n/**\n * WebM input format singleton.\n * @group Input formats\n * @public\n */\nexport const WEBM = new WebMInputFormat();\n/**\n * MP3 input format singleton.\n * @group Input formats\n * @public\n */\nexport const MP3 = new Mp3InputFormat();\n/**\n * WAVE input format singleton.\n * @group Input formats\n * @public\n */\nexport const WAVE = new WaveInputFormat();\n/**\n * Ogg input format singleton.\n * @group Input formats\n * @public\n */\nexport const OGG = new OggInputFormat();\n/**\n * ADTS input format singleton.\n * @group Input formats\n * @public\n */\nexport const ADTS = new AdtsInputFormat();\n/**\n * List of all input format singletons. If you don't need to support all input formats, you should specify the\n * formats individually for better tree shaking.\n * @group Input formats\n * @public\n */\nexport const ALL_FORMATS = [MP4, QTFF, MATROSKA, WEBM, WAVE, OGG, MP3, ADTS];\n", "/*!\n * Copyright (c) 2025-present, Vanilagy and contributors\n *\n * This Source Code Form is subject to the terms of the Mozilla Public\n * License, v. 2.0. If a copy of the MPL was not distributed with this\n * file, You can obtain one at https://mozilla.org/MPL/2.0/.\n */\nimport { InputFormat } from './input-format.js';\nimport { assert } from './misc.js';\nimport { Reader } from './reader.js';\nimport { Source } from './source.js';\n/**\n * Represents an input media file. This is the root object from which all media read operations start.\n * @group Input files & tracks\n * @public\n */\nexport class Input {\n /**\n * Creates a new input file from the specified options. No reading operations will be performed until methods are\n * called on this instance.\n */\n constructor(options) {\n /** @internal */\n this._demuxerPromise = null;\n /** @internal */\n this._format = null;\n if (!options || typeof options !== 'object') {\n throw new TypeError('options must be an object.');\n }\n if (!Array.isArray(options.formats) || options.formats.some(x => !(x instanceof InputFormat))) {\n throw new TypeError('options.formats must be an array of InputFormat.');\n }\n if (!(options.source instanceof Source)) {\n throw new TypeError('options.source must be a Source.');\n }\n this._formats = options.formats;\n this._source = options.source;\n this._reader = new Reader(options.source);\n }\n /** @internal */\n _getDemuxer() {\n return this._demuxerPromise ??= (async () => {\n this._reader.fileSize = await this._source.getSizeOrNull();\n for (const format of this._formats) {\n const canRead = await format._canReadInput(this);\n if (canRead) {\n this._format = format;\n return format._createDemuxer(this);\n }\n }\n throw new Error('Input has an unsupported or unrecognizable format.');\n })();\n }\n /**\n * Returns the source from which this input file reads its data. This is the same source that was passed to the\n * constructor.\n */\n get source() {\n return this._source;\n }\n /**\n * Returns the format of the input file. You can compare this result directly to the {@link InputFormat} singletons\n * or use `instanceof` checks for subset-aware logic (for example, `format instanceof MatroskaInputFormat` is true\n * for both MKV and WebM).\n */\n async getFormat() {\n await this._getDemuxer();\n assert(this._format);\n return this._format;\n }\n /**\n * Computes the duration of the input file, in seconds. More precisely, returns the largest end timestamp among\n * all tracks.\n */\n async computeDuration() {\n const demuxer = await this._getDemuxer();\n return demuxer.computeDuration();\n }\n /** Returns the list of all tracks of this input file. */\n async getTracks() {\n const demuxer = await this._getDemuxer();\n return demuxer.getTracks();\n }\n /** Returns the list of all video tracks of this input file. */\n async getVideoTracks() {\n const tracks = await this.getTracks();\n return tracks.filter(x => x.isVideoTrack());\n }\n /** Returns the list of all audio tracks of this input file. */\n async getAudioTracks() {\n const tracks = await this.getTracks();\n return tracks.filter(x => x.isAudioTrack());\n }\n /** Returns the primary video track of this input file, or null if there are no video tracks. */\n async getPrimaryVideoTrack() {\n const tracks = await this.getTracks();\n return tracks.find(x => x.isVideoTrack()) ?? null;\n }\n /** Returns the primary audio track of this input file, or null if there are no audio tracks. */\n async getPrimaryAudioTrack() {\n const tracks = await this.getTracks();\n return tracks.find(x => x.isAudioTrack()) ?? null;\n }\n /** Returns the full MIME type of this input file, including track codecs. */\n async getMimeType() {\n const demuxer = await this._getDemuxer();\n return demuxer.getMimeType();\n }\n /** Returns descriptive metadata tags about the media file, such as title, author, date, or cover art. */\n async getMetadataTags() {\n const demuxer = await this._getDemuxer();\n return demuxer.getMetadataTags();\n }\n}\n", "import {WebMediaInfo} from \"web-demuxer\"\n\ntype Events =\n\t| {type: \"config\", config: {audio: AudioDecoderConfig, video: VideoDecoderConfig}}\n\t| {type: \"info\", data: WebMediaInfo}\n\t| {type: \"encoderQueueSize\", size: number}\n\ntype Handler = (event: Events) => void\n\nexport class Machina {\n\tcount = 0\n\n\t#handlers = new Map<number, Handler>()\n\n\tregister(id: number, handler: Handler) {\n\t\tthis.#handlers.set(id, handler)\n\t}\n\n\tunregister(id: number) {\n\t\tthis.#handlers.delete(id)\n\t}\n\n\tdispatch(id: number, event: Events) {\n\t\tthis.#handlers.get(id)?.(event)\n\t}\n}\n\n", "\nimport {Comrade} from \"@e280/comrade\"\nimport {Machina} from \"../parts/machina.js\"\nimport {DriverSchematic} from \"./schematic.js\"\n\nexport const setupDriverHost = (machina: Machina) => (\n\tComrade.host<DriverSchematic>(_shell => ({\n\t\tasync world() {\n\t\t\tmachina.count++\n\t\t},\n\t}))\n)\n\n", "import {BlobSource, UrlSource} from \"mediabunny\"\nimport {DecoderSource} from \"../fns/schematic.js\"\n\n// only streamable sources\nexport async function loadDecoderSource(source: DecoderSource): Promise<UrlSource | BlobSource> {\n\tif(source instanceof Blob) {\n\t\treturn new BlobSource(source)\n\t} else {\n\t\treturn new UrlSource(source)\n\t}\n}\n\n", "import {Comrade, tune, Thread} from \"@e280/comrade\"\nimport {ALL_FORMATS, Input, type StreamTargetChunk} from \"mediabunny\"\n\nimport {Machina} from \"./parts/machina.js\"\nimport {setupDriverHost} from \"./fns/host.js\"\nimport {loadDecoderSource} from \"./utils/load-decoder-source.js\"\nimport {DecoderInput, DriverSchematic, Composition, EncoderInput, DecoderSource} from \"./fns/schematic.js\"\n\nexport type DriverOptions = {\n\tworkerUrl: URL | string\n}\n\nexport class Driver {\n\tstatic async setup(options: DriverOptions) {\n\t\tconst machina = new Machina()\n\t\tconst thread = await Comrade.thread<DriverSchematic>({\n\t\t\tlabel: \"OmnitoolDriver\",\n\t\t\tworkerUrl: options.workerUrl,\n\t\t\tsetupHost: setupDriverHost(machina),\n\t\t})\n\t\treturn new this(machina, thread)\n\t}\n\n\tconstructor(\n\t\tpublic machina: Machina,\n\t\tpublic thread: Thread<DriverSchematic>\n\t) {}\n\n\tasync hello() {\n\t\treturn this.thread.work.hello()\n\t}\n\n\tasync getAudioDuration(source: DecoderSource) {\n\t\tconst input = new Input({\n\t\t\tsource: await loadDecoderSource(source),\n\t\t\tformats: ALL_FORMATS\n\t\t})\n\n\t\tconst audioTrack = await input.getPrimaryAudioTrack()\n\t\treturn await audioTrack?.computeDuration()\n\t}\n\n\tasync getVideoDuration(source: DecoderSource) {\n\t\tconst input = new Input({\n\t\t\tsource: await loadDecoderSource(source),\n\t\t\tformats: ALL_FORMATS\n\t\t})\n\n\t\tconst videoTrack = await input.getPrimaryVideoTrack()\n\t\treturn await videoTrack?.computeDuration()\n\t}\n\n\tdecodeVideo(input: DecoderInput) {\n\t\tlet lastFrame: VideoFrame | null = null\n\t\tconst videoTransform = new TransformStream<VideoFrame, VideoFrame>({\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tconst frame = await input.onFrame?.(chunk) ?? chunk\n\t\t\t\t// below code is to prevent mem leaks and hardware accelerated decoder stall\n\t\t\t\tlastFrame?.close()\n\t\t\t\tcontroller.enqueue(frame)\n\t\t\t\tlastFrame = frame\n\t\t\t}\n\t\t})\n\t\tthis.thread.work.decodeVideo[tune]({transfer: [videoTransform.writable]})({\n\t\t\tsource: input.source,\n\t\t\tvideo: videoTransform.writable,\n\t\t\tstart: input.start,\n\t\t\tend: input.end\n\t\t})\n\t\treturn videoTransform.readable\n\t}\n\n\tdecodeAudio(input: DecoderInput) {\n\t\tconst audioTransform = new TransformStream<AudioData, AudioData>()\n\t\tthis.thread.work.decodeAudio[tune]({transfer: [audioTransform.writable]})({\n\t\t\tsource: input.source,\n\t\t\taudio: audioTransform.writable,\n\t\t\tstart: input.start,\n\t\t\tend: input.end\n\t\t})\n\t\treturn audioTransform.readable\n\t}\n\n\tasync encode({video, audio, config}: EncoderInput) {\n\t\tconst handle = await window.showSaveFilePicker()\n\t\tconst writable = await handle.createWritable()\n\t\t// making bridge because file picker writable is not transferable\n\t\tconst bridge = new WritableStream<StreamTargetChunk>({\n\t\t\tasync write(chunk) {\n\t\t\t\tawait writable.write(chunk)\n\t\t\t},\n\t\t\tasync close() {\n\t\t\t\tawait writable.close()\n\t\t\t}\n\t\t})\n\t\treturn await this.thread.work.encode[tune]({transfer: [audio ?? [], video ?? [], bridge]})({video, audio, config, bridge})\n\t}\n\n\tasync composite(\n\t\tcomposition: Composition,\n\t) {\n\t\tconst transfer = this.#collectTransferablesFromComposition(composition)\n\t\treturn await this.thread.work.composite[tune]({transfer})(composition)\n\t}\n\n\t#collectTransferablesFromComposition(composition: Composition) {\n\t\tconst transferables: Transferable[] = []\n\n\t\tconst visit = (node: Composition) => {\n\t\t\tif (Array.isArray(node)) {\n\t\t\t\tfor (const child of node)\n\t\t\t\t\tvisit(child)\n\t\t\t}\n\t\t\telse if (node && typeof node === 'object' && 'kind' in node) {\n\t\t\t\tif (node.kind === 'image' && node.frame instanceof VideoFrame)\n\t\t\t\t\ttransferables.push(node.frame)\n\t\t\t}\n\t\t}\n\n\t\tvisit(composition)\n\t\treturn transferables\n\t}\n}\n\n", "import {Driver} from \"./driver/driver.js\"\n\nconst workerUrl = new URL(\"../driver/driver.worker.bundle.min.js\", import.meta.url)\n\nexport const context = {\n\tdriver: Driver.setup({workerUrl})\n}\n", "function t(t,e,i,s){return new(i||(i=Promise))((function(n,r){function o(t){try{h(s.next(t))}catch(t){r(t)}}function a(t){try{h(s.throw(t))}catch(t){r(t)}}function h(t){var e;t.done?n(t.value):(e=t.value,e instanceof i?e:new i((function(t){t(e)}))).then(o,a)}h((s=s.apply(t,e||[])).next())}))}\"function\"==typeof SuppressedError&&SuppressedError;class e{constructor(){this.listeners={}}on(t,e,i){if(this.listeners[t]||(this.listeners[t]=new Set),this.listeners[t].add(e),null==i?void 0:i.once){const i=()=>{this.un(t,i),this.un(t,e)};return this.on(t,i),i}return()=>this.un(t,e)}un(t,e){var i;null===(i=this.listeners[t])||void 0===i||i.delete(e)}once(t,e){return this.on(t,e,{once:!0})}unAll(){this.listeners={}}emit(t,...e){this.listeners[t]&&this.listeners[t].forEach((t=>t(...e)))}}const i={decode:function(e,i){return t(this,void 0,void 0,(function*(){const t=new AudioContext({sampleRate:i});return t.decodeAudioData(e).finally((()=>t.close()))}))},createBuffer:function(t,e){return\"number\"==typeof t[0]&&(t=[t]),function(t){const e=t[0];if(e.some((t=>t>1||t<-1))){const i=e.length;let s=0;for(let t=0;t<i;t++){const i=Math.abs(e[t]);i>s&&(s=i)}for(const e of t)for(let t=0;t<i;t++)e[t]/=s}}(t),{duration:e,length:t[0].length,sampleRate:t[0].length/e,numberOfChannels:t.length,getChannelData:e=>null==t?void 0:t[e],copyFromChannel:AudioBuffer.prototype.copyFromChannel,copyToChannel:AudioBuffer.prototype.copyToChannel}}};function s(t,e){const i=e.xmlns?document.createElementNS(e.xmlns,t):document.createElement(t);for(const[t,n]of Object.entries(e))if(\"children\"===t&&n)for(const[t,e]of Object.entries(n))e instanceof Node?i.appendChild(e):\"string\"==typeof e?i.appendChild(document.createTextNode(e)):i.appendChild(s(t,e));else\"style\"===t?Object.assign(i.style,n):\"textContent\"===t?i.textContent=n:i.setAttribute(t,n.toString());return i}function n(t,e,i){const n=s(t,e||{});return null==i||i.appendChild(n),n}var r=Object.freeze({__proto__:null,createElement:n,default:n});const o={fetchBlob:function(e,i,s){return t(this,void 0,void 0,(function*(){const n=yield fetch(e,s);if(n.status>=400)throw new Error(`Failed to fetch ${e}: ${n.status} (${n.statusText})`);return function(e,i){t(this,void 0,void 0,(function*(){if(!e.body||!e.headers)return;const s=e.body.getReader(),n=Number(e.headers.get(\"Content-Length\"))||0;let r=0;const o=e=>t(this,void 0,void 0,(function*(){r+=(null==e?void 0:e.length)||0;const t=Math.round(r/n*100);i(t)})),a=()=>t(this,void 0,void 0,(function*(){let t;try{t=yield s.read()}catch(t){return}t.done||(o(t.value),yield a())}));a()}))}(n.clone(),i),n.blob()}))}};class a extends e{constructor(t){super(),this.isExternalMedia=!1,t.media?(this.media=t.media,this.isExternalMedia=!0):this.media=document.createElement(\"audio\"),t.mediaControls&&(this.media.controls=!0),t.autoplay&&(this.media.autoplay=!0),null!=t.playbackRate&&this.onMediaEvent(\"canplay\",(()=>{null!=t.playbackRate&&(this.media.playbackRate=t.playbackRate)}),{once:!0})}onMediaEvent(t,e,i){return this.media.addEventListener(t,e,i),()=>this.media.removeEventListener(t,e,i)}getSrc(){return this.media.currentSrc||this.media.src||\"\"}revokeSrc(){const t=this.getSrc();t.startsWith(\"blob:\")&&URL.revokeObjectURL(t)}canPlayType(t){return\"\"!==this.media.canPlayType(t)}setSrc(t,e){const i=this.getSrc();if(t&&i===t)return;this.revokeSrc();const s=e instanceof Blob&&(this.canPlayType(e.type)||!t)?URL.createObjectURL(e):t;if(i&&this.media.removeAttribute(\"src\"),s||t)try{this.media.src=s}catch(e){this.media.src=t}}destroy(){this.isExternalMedia||(this.media.pause(),this.media.remove(),this.revokeSrc(),this.media.removeAttribute(\"src\"),this.media.load())}setMediaElement(t){this.media=t}play(){return t(this,void 0,void 0,(function*(){return this.media.play()}))}pause(){this.media.pause()}isPlaying(){return!this.media.paused&&!this.media.ended}setTime(t){this.media.currentTime=Math.max(0,Math.min(t,this.getDuration()))}getDuration(){return this.media.duration}getCurrentTime(){return this.media.currentTime}getVolume(){return this.media.volume}setVolume(t){this.media.volume=t}getMuted(){return this.media.muted}setMuted(t){this.media.muted=t}getPlaybackRate(){return this.media.playbackRate}isSeeking(){return this.media.seeking}setPlaybackRate(t,e){null!=e&&(this.media.preservesPitch=e),this.media.playbackRate=t}getMediaElement(){return this.media}setSinkId(t){return this.media.setSinkId(t)}}class h extends e{constructor(t,e){super(),this.timeouts=[],this.isScrollable=!1,this.audioData=null,this.resizeObserver=null,this.lastContainerWidth=0,this.isDragging=!1,this.subscriptions=[],this.unsubscribeOnScroll=[],this.subscriptions=[],this.options=t;const i=this.parentFromOptionsContainer(t.container);this.parent=i;const[s,n]=this.initHtml();i.appendChild(s),this.container=s,this.scrollContainer=n.querySelector(\".scroll\"),this.wrapper=n.querySelector(\".wrapper\"),this.canvasWrapper=n.querySelector(\".canvases\"),this.progressWrapper=n.querySelector(\".progress\"),this.cursor=n.querySelector(\".cursor\"),e&&n.appendChild(e),this.initEvents()}parentFromOptionsContainer(t){let e;if(\"string\"==typeof t?e=document.querySelector(t):t instanceof HTMLElement&&(e=t),!e)throw new Error(\"Container not found\");return e}initEvents(){const t=t=>{const e=this.wrapper.getBoundingClientRect(),i=t.clientX-e.left,s=t.clientY-e.top;return[i/e.width,s/e.height]};if(this.wrapper.addEventListener(\"click\",(e=>{const[i,s]=t(e);this.emit(\"click\",i,s)})),this.wrapper.addEventListener(\"dblclick\",(e=>{const[i,s]=t(e);this.emit(\"dblclick\",i,s)})),!0!==this.options.dragToSeek&&\"object\"!=typeof this.options.dragToSeek||this.initDrag(),this.scrollContainer.addEventListener(\"scroll\",(()=>{const{scrollLeft:t,scrollWidth:e,clientWidth:i}=this.scrollContainer,s=t/e,n=(t+i)/e;this.emit(\"scroll\",s,n,t,t+i)})),\"function\"==typeof ResizeObserver){const t=this.createDelay(100);this.resizeObserver=new ResizeObserver((()=>{t().then((()=>this.onContainerResize())).catch((()=>{}))})),this.resizeObserver.observe(this.scrollContainer)}}onContainerResize(){const t=this.parent.clientWidth;t===this.lastContainerWidth&&\"auto\"!==this.options.height||(this.lastContainerWidth=t,this.reRender())}initDrag(){this.subscriptions.push(function(t,e,i,s,n=3,r=0,o=100){if(!t)return()=>{};const a=matchMedia(\"(pointer: coarse)\").matches;let h=()=>{};const l=l=>{if(l.button!==r)return;l.preventDefault(),l.stopPropagation();let d=l.clientX,c=l.clientY,u=!1;const p=Date.now(),m=s=>{if(s.preventDefault(),s.stopPropagation(),a&&Date.now()-p<o)return;const r=s.clientX,h=s.clientY,l=r-d,m=h-c;if(u||Math.abs(l)>n||Math.abs(m)>n){const s=t.getBoundingClientRect(),{left:n,top:o}=s;u||(null==i||i(d-n,c-o),u=!0),e(l,m,r-n,h-o),d=r,c=h}},f=e=>{if(u){const i=e.clientX,n=e.clientY,r=t.getBoundingClientRect(),{left:o,top:a}=r;null==s||s(i-o,n-a)}h()},g=t=>{t.relatedTarget&&t.relatedTarget!==document.documentElement||f(t)},v=t=>{u&&(t.stopPropagation(),t.preventDefault())},b=t=>{u&&t.preventDefault()};document.addEventListener(\"pointermove\",m),document.addEventListener(\"pointerup\",f),document.addEventListener(\"pointerout\",g),document.addEventListener(\"pointercancel\",g),document.addEventListener(\"touchmove\",b,{passive:!1}),document.addEventListener(\"click\",v,{capture:!0}),h=()=>{document.removeEventListener(\"pointermove\",m),document.removeEventListener(\"pointerup\",f),document.removeEventListener(\"pointerout\",g),document.removeEventListener(\"pointercancel\",g),document.removeEventListener(\"touchmove\",b),setTimeout((()=>{document.removeEventListener(\"click\",v,{capture:!0})}),10)}};return t.addEventListener(\"pointerdown\",l),()=>{h(),t.removeEventListener(\"pointerdown\",l)}}(this.wrapper,((t,e,i)=>{this.emit(\"drag\",Math.max(0,Math.min(1,i/this.wrapper.getBoundingClientRect().width)))}),(t=>{this.isDragging=!0,this.emit(\"dragstart\",Math.max(0,Math.min(1,t/this.wrapper.getBoundingClientRect().width)))}),(t=>{this.isDragging=!1,this.emit(\"dragend\",Math.max(0,Math.min(1,t/this.wrapper.getBoundingClientRect().width)))})))}getHeight(t,e){var i;const s=(null===(i=this.audioData)||void 0===i?void 0:i.numberOfChannels)||1;if(null==t)return 128;if(!isNaN(Number(t)))return Number(t);if(\"auto\"===t){const t=this.parent.clientHeight||128;return(null==e?void 0:e.every((t=>!t.overlay)))?t/s:t}return 128}initHtml(){const t=document.createElement(\"div\"),e=t.attachShadow({mode:\"open\"}),i=this.options.cspNonce&&\"string\"==typeof this.options.cspNonce?this.options.cspNonce.replace(/\"/g,\"\"):\"\";return e.innerHTML=`\\n <style${i?` nonce=\"${i}\"`:\"\"}>\\n :host {\\n user-select: none;\\n min-width: 1px;\\n }\\n :host audio {\\n display: block;\\n width: 100%;\\n }\\n :host .scroll {\\n overflow-x: auto;\\n overflow-y: hidden;\\n width: 100%;\\n position: relative;\\n }\\n :host .noScrollbar {\\n scrollbar-color: transparent;\\n scrollbar-width: none;\\n }\\n :host .noScrollbar::-webkit-scrollbar {\\n display: none;\\n -webkit-appearance: none;\\n }\\n :host .wrapper {\\n position: relative;\\n overflow: visible;\\n z-index: 2;\\n }\\n :host .canvases {\\n min-height: ${this.getHeight(this.options.height,this.options.splitChannels)}px;\\n }\\n :host .canvases > div {\\n position: relative;\\n }\\n :host canvas {\\n display: block;\\n position: absolute;\\n top: 0;\\n image-rendering: pixelated;\\n }\\n :host .progress {\\n pointer-events: none;\\n position: absolute;\\n z-index: 2;\\n top: 0;\\n left: 0;\\n width: 0;\\n height: 100%;\\n overflow: hidden;\\n }\\n :host .progress > div {\\n position: relative;\\n }\\n :host .cursor {\\n pointer-events: none;\\n position: absolute;\\n z-index: 5;\\n top: 0;\\n left: 0;\\n height: 100%;\\n border-radius: 2px;\\n }\\n </style>\\n\\n <div class=\"scroll\" part=\"scroll\">\\n <div class=\"wrapper\" part=\"wrapper\">\\n <div class=\"canvases\" part=\"canvases\"></div>\\n <div class=\"progress\" part=\"progress\"></div>\\n <div class=\"cursor\" part=\"cursor\"></div>\\n </div>\\n </div>\\n `,[t,e]}setOptions(t){if(this.options.container!==t.container){const e=this.parentFromOptionsContainer(t.container);e.appendChild(this.container),this.parent=e}!0!==t.dragToSeek&&\"object\"!=typeof this.options.dragToSeek||this.initDrag(),this.options=t,this.reRender()}getWrapper(){return this.wrapper}getWidth(){return this.scrollContainer.clientWidth}getScroll(){return this.scrollContainer.scrollLeft}setScroll(t){this.scrollContainer.scrollLeft=t}setScrollPercentage(t){const{scrollWidth:e}=this.scrollContainer,i=e*t;this.setScroll(i)}destroy(){var t,e;this.subscriptions.forEach((t=>t())),this.container.remove(),null===(t=this.resizeObserver)||void 0===t||t.disconnect(),null===(e=this.unsubscribeOnScroll)||void 0===e||e.forEach((t=>t())),this.unsubscribeOnScroll=[]}createDelay(t=10){let e,i;const s=()=>{e&&clearTimeout(e),i&&i()};return this.timeouts.push(s),()=>new Promise(((n,r)=>{s(),i=r,e=setTimeout((()=>{e=void 0,i=void 0,n()}),t)}))}convertColorValues(t){if(!Array.isArray(t))return t||\"\";if(t.length<2)return t[0]||\"\";const e=document.createElement(\"canvas\"),i=e.getContext(\"2d\"),s=e.height*(window.devicePixelRatio||1),n=i.createLinearGradient(0,0,0,s),r=1/(t.length-1);return t.forEach(((t,e)=>{const i=e*r;n.addColorStop(i,t)})),n}getPixelRatio(){return Math.max(1,window.devicePixelRatio||1)}renderBarWaveform(t,e,i,s){const n=t[0],r=t[1]||t[0],o=n.length,{width:a,height:h}=i.canvas,l=h/2,d=this.getPixelRatio(),c=e.barWidth?e.barWidth*d:1,u=e.barGap?e.barGap*d:e.barWidth?c/2:0,p=e.barRadius||0,m=a/(c+u)/o,f=p&&\"roundRect\"in i?\"roundRect\":\"rect\";i.beginPath();let g=0,v=0,b=0;for(let t=0;t<=o;t++){const o=Math.round(t*m);if(o>g){const t=Math.round(v*l*s),n=t+Math.round(b*l*s)||1;let r=l-t;\"top\"===e.barAlign?r=0:\"bottom\"===e.barAlign&&(r=h-n),i[f](g*(c+u),r,c,n,p),g=o,v=0,b=0}const a=Math.abs(n[t]||0),d=Math.abs(r[t]||0);a>v&&(v=a),d>b&&(b=d)}i.fill(),i.closePath()}renderLineWaveform(t,e,i,s){const n=e=>{const n=t[e]||t[0],r=n.length,{height:o}=i.canvas,a=o/2,h=i.canvas.width/r;i.moveTo(0,a);let l=0,d=0;for(let t=0;t<=r;t++){const r=Math.round(t*h);if(r>l){const t=a+(Math.round(d*a*s)||1)*(0===e?-1:1);i.lineTo(l,t),l=r,d=0}const o=Math.abs(n[t]||0);o>d&&(d=o)}i.lineTo(l,a)};i.beginPath(),n(0),n(1),i.fill(),i.closePath()}renderWaveform(t,e,i){if(i.fillStyle=this.convertColorValues(e.waveColor),e.renderFunction)return void e.renderFunction(t,i);let s=e.barHeight||1;if(e.normalize){const e=Array.from(t[0]).reduce(((t,e)=>Math.max(t,Math.abs(e))),0);s=e?1/e:1}e.barWidth||e.barGap||e.barAlign?this.renderBarWaveform(t,e,i,s):this.renderLineWaveform(t,e,i,s)}renderSingleCanvas(t,e,i,s,n,r,o){const a=this.getPixelRatio(),h=document.createElement(\"canvas\");h.width=Math.round(i*a),h.height=Math.round(s*a),h.style.width=`${i}px`,h.style.height=`${s}px`,h.style.left=`${Math.round(n)}px`,r.appendChild(h);const l=h.getContext(\"2d\");if(this.renderWaveform(t,e,l),h.width>0&&h.height>0){const t=h.cloneNode(),i=t.getContext(\"2d\");i.drawImage(h,0,0),i.globalCompositeOperation=\"source-in\",i.fillStyle=this.convertColorValues(e.progressColor),i.fillRect(0,0,h.width,h.height),o.appendChild(t)}}renderMultiCanvas(t,e,i,s,n,r){const o=this.getPixelRatio(),{clientWidth:a}=this.scrollContainer,l=i/o;let d=Math.min(h.MAX_CANVAS_WIDTH,a,l),c={};if(e.barWidth||e.barGap){const t=e.barWidth||.5,i=t+(e.barGap||t/2);d%i!=0&&(d=Math.floor(d/i)*i)}if(0===d)return;const u=i=>{if(i<0||i>=p)return;if(c[i])return;c[i]=!0;const o=i*d;let a=Math.min(l-o,d);if(e.barWidth||e.barGap){const t=e.barWidth||.5,i=t+(e.barGap||t/2);a=Math.floor(a/i)*i}if(a<=0)return;const h=t.map((t=>{const e=Math.floor(o/l*t.length),i=Math.floor((o+a)/l*t.length);return t.slice(e,i)}));this.renderSingleCanvas(h,e,a,s,o,n,r)},p=Math.ceil(l/d);if(!this.isScrollable){for(let t=0;t<p;t++)u(t);return}const m=this.scrollContainer.scrollLeft/l,f=Math.floor(m*p);if(u(f-1),u(f),u(f+1),p>1){const t=this.on(\"scroll\",(()=>{const{scrollLeft:t}=this.scrollContainer,e=Math.floor(t/l*p);Object.keys(c).length>h.MAX_NODES&&(n.innerHTML=\"\",r.innerHTML=\"\",c={}),u(e-1),u(e),u(e+1)}));this.unsubscribeOnScroll.push(t)}}renderChannel(t,e,i,s){var{overlay:n}=e,r=function(t,e){var i={};for(var s in t)Object.prototype.hasOwnProperty.call(t,s)&&e.indexOf(s)<0&&(i[s]=t[s]);if(null!=t&&\"function\"==typeof Object.getOwnPropertySymbols){var n=0;for(s=Object.getOwnPropertySymbols(t);n<s.length;n++)e.indexOf(s[n])<0&&Object.prototype.propertyIsEnumerable.call(t,s[n])&&(i[s[n]]=t[s[n]])}return i}(e,[\"overlay\"]);const o=document.createElement(\"div\"),a=this.getHeight(r.height,r.splitChannels);o.style.height=`${a}px`,n&&s>0&&(o.style.marginTop=`-${a}px`),this.canvasWrapper.style.minHeight=`${a}px`,this.canvasWrapper.appendChild(o);const h=o.cloneNode();this.progressWrapper.appendChild(h),this.renderMultiCanvas(t,r,i,a,o,h)}render(e){return t(this,void 0,void 0,(function*(){var t;this.timeouts.forEach((t=>t())),this.timeouts=[],this.canvasWrapper.innerHTML=\"\",this.progressWrapper.innerHTML=\"\",null!=this.options.width&&(this.scrollContainer.style.width=\"number\"==typeof this.options.width?`${this.options.width}px`:this.options.width);const i=this.getPixelRatio(),s=this.scrollContainer.clientWidth,n=Math.ceil(e.duration*(this.options.minPxPerSec||0));this.isScrollable=n>s;const r=this.options.fillParent&&!this.isScrollable,o=(r?s:n)*i;if(this.wrapper.style.width=r?\"100%\":`${n}px`,this.scrollContainer.style.overflowX=this.isScrollable?\"auto\":\"hidden\",this.scrollContainer.classList.toggle(\"noScrollbar\",!!this.options.hideScrollbar),this.cursor.style.backgroundColor=`${this.options.cursorColor||this.options.progressColor}`,this.cursor.style.width=`${this.options.cursorWidth}px`,this.audioData=e,this.emit(\"render\"),this.options.splitChannels)for(let i=0;i<e.numberOfChannels;i++){const s=Object.assign(Object.assign({},this.options),null===(t=this.options.splitChannels)||void 0===t?void 0:t[i]);this.renderChannel([e.getChannelData(i)],s,o,i)}else{const t=[e.getChannelData(0)];e.numberOfChannels>1&&t.push(e.getChannelData(1)),this.renderChannel(t,this.options,o,0)}Promise.resolve().then((()=>this.emit(\"rendered\")))}))}reRender(){if(this.unsubscribeOnScroll.forEach((t=>t())),this.unsubscribeOnScroll=[],!this.audioData)return;const{scrollWidth:t}=this.scrollContainer,{right:e}=this.progressWrapper.getBoundingClientRect();if(this.render(this.audioData),this.isScrollable&&t!==this.scrollContainer.scrollWidth){const{right:t}=this.progressWrapper.getBoundingClientRect();let i=t-e;i*=2,i=i<0?Math.floor(i):Math.ceil(i),i/=2,this.scrollContainer.scrollLeft+=i}}zoom(t){this.options.minPxPerSec=t,this.reRender()}scrollIntoView(t,e=!1){const{scrollLeft:i,scrollWidth:s,clientWidth:n}=this.scrollContainer,r=t*s,o=i,a=i+n,h=n/2;if(this.isDragging){const t=30;r+t>a?this.scrollContainer.scrollLeft+=t:r-t<o&&(this.scrollContainer.scrollLeft-=t)}else{(r<o||r>a)&&(this.scrollContainer.scrollLeft=r-(this.options.autoCenter?h:0));const t=r-i-h;e&&this.options.autoCenter&&t>0&&(this.scrollContainer.scrollLeft+=Math.min(t,10))}{const t=this.scrollContainer.scrollLeft,e=t/s,i=(t+n)/s;this.emit(\"scroll\",e,i,t,t+n)}}renderProgress(t,e){if(isNaN(t))return;const i=100*t;this.canvasWrapper.style.clipPath=`polygon(${i}% 0%, 100% 0%, 100% 100%, ${i}% 100%)`,this.progressWrapper.style.width=`${i}%`,this.cursor.style.left=`${i}%`,this.cursor.style.transform=`translateX(-${100===Math.round(i)?this.options.cursorWidth:0}px)`,this.isScrollable&&this.options.autoScroll&&this.scrollIntoView(t,e)}exportImage(e,i,s){return t(this,void 0,void 0,(function*(){const t=this.canvasWrapper.querySelectorAll(\"canvas\");if(!t.length)throw new Error(\"No waveform data\");if(\"dataURL\"===s){const s=Array.from(t).map((t=>t.toDataURL(e,i)));return Promise.resolve(s)}return Promise.all(Array.from(t).map((t=>new Promise(((s,n)=>{t.toBlob((t=>{t?s(t):n(new Error(\"Could not export image\"))}),e,i)})))))}))}}h.MAX_CANVAS_WIDTH=8e3,h.MAX_NODES=10;class l extends e{constructor(){super(...arguments),this.unsubscribe=()=>{}}start(){this.unsubscribe=this.on(\"tick\",(()=>{requestAnimationFrame((()=>{this.emit(\"tick\")}))})),this.emit(\"tick\")}stop(){this.unsubscribe()}destroy(){this.unsubscribe()}}class d extends e{constructor(t=new AudioContext){super(),this.bufferNode=null,this.playStartTime=0,this.playedDuration=0,this._muted=!1,this._playbackRate=1,this._duration=void 0,this.buffer=null,this.currentSrc=\"\",this.paused=!0,this.crossOrigin=null,this.seeking=!1,this.autoplay=!1,this.addEventListener=this.on,this.removeEventListener=this.un,this.audioContext=t,this.gainNode=this.audioContext.createGain(),this.gainNode.connect(this.audioContext.destination)}load(){return t(this,void 0,void 0,(function*(){}))}get src(){return this.currentSrc}set src(t){if(this.currentSrc=t,this._duration=void 0,!t)return this.buffer=null,void this.emit(\"emptied\");fetch(t).then((e=>{if(e.status>=400)throw new Error(`Failed to fetch ${t}: ${e.status} (${e.statusText})`);return e.arrayBuffer()})).then((e=>this.currentSrc!==t?null:this.audioContext.decodeAudioData(e))).then((e=>{this.currentSrc===t&&(this.buffer=e,this.emit(\"loadedmetadata\"),this.emit(\"canplay\"),this.autoplay&&this.play())}))}_play(){var t;if(!this.paused)return;this.paused=!1,null===(t=this.bufferNode)||void 0===t||t.disconnect(),this.bufferNode=this.audioContext.createBufferSource(),this.buffer&&(this.bufferNode.buffer=this.buffer),this.bufferNode.playbackRate.value=this._playbackRate,this.bufferNode.connect(this.gainNode);let e=this.playedDuration*this._playbackRate;(e>=this.duration||e<0)&&(e=0,this.playedDuration=0),this.bufferNode.start(this.audioContext.currentTime,e),this.playStartTime=this.audioContext.currentTime,this.bufferNode.onended=()=>{this.currentTime>=this.duration&&(this.pause(),this.emit(\"ended\"))}}_pause(){var t;this.paused=!0,null===(t=this.bufferNode)||void 0===t||t.stop(),this.playedDuration+=this.audioContext.currentTime-this.playStartTime}play(){return t(this,void 0,void 0,(function*(){this.paused&&(this._play(),this.emit(\"play\"))}))}pause(){this.paused||(this._pause(),this.emit(\"pause\"))}stopAt(t){const e=t-this.currentTime,i=this.bufferNode;null==i||i.stop(this.audioContext.currentTime+e),null==i||i.addEventListener(\"ended\",(()=>{i===this.bufferNode&&(this.bufferNode=null,this.pause())}),{once:!0})}setSinkId(e){return t(this,void 0,void 0,(function*(){return this.audioContext.setSinkId(e)}))}get playbackRate(){return this._playbackRate}set playbackRate(t){this._playbackRate=t,this.bufferNode&&(this.bufferNode.playbackRate.value=t)}get currentTime(){return(this.paused?this.playedDuration:this.playedDuration+(this.audioContext.currentTime-this.playStartTime))*this._playbackRate}set currentTime(t){const e=!this.paused;e&&this._pause(),this.playedDuration=t/this._playbackRate,e&&this._play(),this.emit(\"seeking\"),this.emit(\"timeupdate\")}get duration(){var t,e;return null!==(t=this._duration)&&void 0!==t?t:(null===(e=this.buffer)||void 0===e?void 0:e.duration)||0}set duration(t){this._duration=t}get volume(){return this.gainNode.gain.value}set volume(t){this.gainNode.gain.value=t,this.emit(\"volumechange\")}get muted(){return this._muted}set muted(t){this._muted!==t&&(this._muted=t,this._muted?this.gainNode.disconnect():this.gainNode.connect(this.audioContext.destination))}canPlayType(t){return/^(audio|video)\\//.test(t)}getGainNode(){return this.gainNode}getChannelData(){const t=[];if(!this.buffer)return t;const e=this.buffer.numberOfChannels;for(let i=0;i<e;i++)t.push(this.buffer.getChannelData(i));return t}}const c={waveColor:\"#999\",progressColor:\"#555\",cursorWidth:1,minPxPerSec:0,fillParent:!0,interact:!0,dragToSeek:!1,autoScroll:!0,autoCenter:!0,sampleRate:8e3};class u extends a{static create(t){return new u(t)}constructor(t){const e=t.media||(\"WebAudio\"===t.backend?new d:void 0);super({media:e,mediaControls:t.mediaControls,autoplay:t.autoplay,playbackRate:t.audioRate}),this.plugins=[],this.decodedData=null,this.stopAtPosition=null,this.subscriptions=[],this.mediaSubscriptions=[],this.abortController=null,this.options=Object.assign({},c,t),this.timer=new l;const i=e?void 0:this.getMediaElement();this.renderer=new h(this.options,i),this.initPlayerEvents(),this.initRendererEvents(),this.initTimerEvents(),this.initPlugins();const s=this.options.url||this.getSrc()||\"\";Promise.resolve().then((()=>{this.emit(\"init\");const{peaks:t,duration:e}=this.options;(s||t&&e)&&this.load(s,t,e).catch((()=>null))}))}updateProgress(t=this.getCurrentTime()){return this.renderer.renderProgress(t/this.getDuration(),this.isPlaying()),t}initTimerEvents(){this.subscriptions.push(this.timer.on(\"tick\",(()=>{if(!this.isSeeking()){const t=this.updateProgress();this.emit(\"timeupdate\",t),this.emit(\"audioprocess\",t),null!=this.stopAtPosition&&this.isPlaying()&&t>=this.stopAtPosition&&this.pause()}})))}initPlayerEvents(){this.isPlaying()&&(this.emit(\"play\"),this.timer.start()),this.mediaSubscriptions.push(this.onMediaEvent(\"timeupdate\",(()=>{const t=this.updateProgress();this.emit(\"timeupdate\",t)})),this.onMediaEvent(\"play\",(()=>{this.emit(\"play\"),this.timer.start()})),this.onMediaEvent(\"pause\",(()=>{this.emit(\"pause\"),this.timer.stop(),this.stopAtPosition=null})),this.onMediaEvent(\"emptied\",(()=>{this.timer.stop(),this.stopAtPosition=null})),this.onMediaEvent(\"ended\",(()=>{this.emit(\"timeupdate\",this.getDuration()),this.emit(\"finish\"),this.stopAtPosition=null})),this.onMediaEvent(\"seeking\",(()=>{this.emit(\"seeking\",this.getCurrentTime())})),this.onMediaEvent(\"error\",(()=>{var t;this.emit(\"error\",null!==(t=this.getMediaElement().error)&&void 0!==t?t:new Error(\"Media error\")),this.stopAtPosition=null})))}initRendererEvents(){this.subscriptions.push(this.renderer.on(\"click\",((t,e)=>{this.options.interact&&(this.seekTo(t),this.emit(\"interaction\",t*this.getDuration()),this.emit(\"click\",t,e))})),this.renderer.on(\"dblclick\",((t,e)=>{this.emit(\"dblclick\",t,e)})),this.renderer.on(\"scroll\",((t,e,i,s)=>{const n=this.getDuration();this.emit(\"scroll\",t*n,e*n,i,s)})),this.renderer.on(\"render\",(()=>{this.emit(\"redraw\")})),this.renderer.on(\"rendered\",(()=>{this.emit(\"redrawcomplete\")})),this.renderer.on(\"dragstart\",(t=>{this.emit(\"dragstart\",t)})),this.renderer.on(\"dragend\",(t=>{this.emit(\"dragend\",t)})));{let t;this.subscriptions.push(this.renderer.on(\"drag\",(e=>{if(!this.options.interact)return;let i;this.renderer.renderProgress(e),clearTimeout(t),this.isPlaying()?i=0:!0===this.options.dragToSeek?i=200:\"object\"==typeof this.options.dragToSeek&&void 0!==this.options.dragToSeek&&(i=this.options.dragToSeek.debounceTime),t=setTimeout((()=>{this.seekTo(e)}),i),this.emit(\"interaction\",e*this.getDuration()),this.emit(\"drag\",e)})))}}initPlugins(){var t;(null===(t=this.options.plugins)||void 0===t?void 0:t.length)&&this.options.plugins.forEach((t=>{this.registerPlugin(t)}))}unsubscribePlayerEvents(){this.mediaSubscriptions.forEach((t=>t())),this.mediaSubscriptions=[]}setOptions(t){this.options=Object.assign({},this.options,t),t.duration&&!t.peaks&&(this.decodedData=i.createBuffer(this.exportPeaks(),t.duration)),t.peaks&&t.duration&&(this.decodedData=i.createBuffer(t.peaks,t.duration)),this.renderer.setOptions(this.options),t.audioRate&&this.setPlaybackRate(t.audioRate),null!=t.mediaControls&&(this.getMediaElement().controls=t.mediaControls)}registerPlugin(t){if(this.plugins.includes(t))return t;t._init(this),this.plugins.push(t);const e=t.once(\"destroy\",(()=>{this.plugins=this.plugins.filter((e=>e!==t)),this.subscriptions=this.subscriptions.filter((t=>t!==e))}));return this.subscriptions.push(e),t}unregisterPlugin(t){this.plugins=this.plugins.filter((e=>e!==t)),t.destroy()}getWrapper(){return this.renderer.getWrapper()}getWidth(){return this.renderer.getWidth()}getScroll(){return this.renderer.getScroll()}setScroll(t){return this.renderer.setScroll(t)}setScrollTime(t){const e=t/this.getDuration();this.renderer.setScrollPercentage(e)}getActivePlugins(){return this.plugins}loadAudio(e,s,n,r){return t(this,void 0,void 0,(function*(){var t;if(this.emit(\"load\",e),!this.options.media&&this.isPlaying()&&this.pause(),this.decodedData=null,this.stopAtPosition=null,!s&&!n){const i=this.options.fetchParams||{};window.AbortController&&!i.signal&&(this.abortController=new AbortController,i.signal=null===(t=this.abortController)||void 0===t?void 0:t.signal);const n=t=>this.emit(\"loading\",t);s=yield o.fetchBlob(e,n,i);const r=this.options.blobMimeType;r&&(s=new Blob([s],{type:r}))}this.setSrc(e,s);const a=yield new Promise((t=>{const e=r||this.getDuration();e?t(e):this.mediaSubscriptions.push(this.onMediaEvent(\"loadedmetadata\",(()=>t(this.getDuration())),{once:!0}))}));if(!e&&!s){const t=this.getMediaElement();t instanceof d&&(t.duration=a)}if(n)this.decodedData=i.createBuffer(n,a||0);else if(s){const t=yield s.arrayBuffer();this.decodedData=yield i.decode(t,this.options.sampleRate)}this.decodedData&&(this.emit(\"decode\",this.getDuration()),this.renderer.render(this.decodedData)),this.emit(\"ready\",this.getDuration())}))}load(e,i,s){return t(this,void 0,void 0,(function*(){try{return yield this.loadAudio(e,void 0,i,s)}catch(t){throw this.emit(\"error\",t),t}}))}loadBlob(e,i,s){return t(this,void 0,void 0,(function*(){try{return yield this.loadAudio(\"\",e,i,s)}catch(t){throw this.emit(\"error\",t),t}}))}zoom(t){if(!this.decodedData)throw new Error(\"No audio loaded\");this.renderer.zoom(t),this.emit(\"zoom\",t)}getDecodedData(){return this.decodedData}exportPeaks({channels:t=2,maxLength:e=8e3,precision:i=1e4}={}){if(!this.decodedData)throw new Error(\"The audio has not been decoded yet\");const s=Math.min(t,this.decodedData.numberOfChannels),n=[];for(let t=0;t<s;t++){const s=this.decodedData.getChannelData(t),r=[],o=s.length/e;for(let t=0;t<e;t++){const e=s.slice(Math.floor(t*o),Math.ceil((t+1)*o));let n=0;for(let t=0;t<e.length;t++){const i=e[t];Math.abs(i)>Math.abs(n)&&(n=i)}r.push(Math.round(n*i)/i)}n.push(r)}return n}getDuration(){let t=super.getDuration()||0;return 0!==t&&t!==1/0||!this.decodedData||(t=this.decodedData.duration),t}toggleInteraction(t){this.options.interact=t}setTime(t){this.stopAtPosition=null,super.setTime(t),this.updateProgress(t),this.emit(\"timeupdate\",t)}seekTo(t){const e=this.getDuration()*t;this.setTime(e)}play(e,i){const s=Object.create(null,{play:{get:()=>super.play}});return t(this,void 0,void 0,(function*(){null!=e&&this.setTime(e);const t=yield s.play.call(this);return null!=i&&(this.media instanceof d?this.media.stopAt(i):this.stopAtPosition=i),t}))}playPause(){return t(this,void 0,void 0,(function*(){return this.isPlaying()?this.pause():this.play()}))}stop(){this.pause(),this.setTime(0)}skip(t){this.setTime(this.getCurrentTime()+t)}empty(){this.load(\"\",[[0]],.001)}setMediaElement(t){this.unsubscribePlayerEvents(),super.setMediaElement(t),this.initPlayerEvents()}exportImage(){return t(this,arguments,void 0,(function*(t=\"image/png\",e=1,i=\"dataURL\"){return this.renderer.exportImage(t,e,i)}))}destroy(){var t;this.emit(\"destroy\"),null===(t=this.abortController)||void 0===t||t.abort(),this.plugins.forEach((t=>t.destroy())),this.subscriptions.forEach((t=>t())),this.unsubscribePlayerEvents(),this.timer.destroy(),this.renderer.destroy(),super.destroy()}}u.BasePlugin=class extends e{constructor(t){super(),this.subscriptions=[],this.isDestroyed=!1,this.options=t}onInit(){}_init(t){this.isDestroyed&&(this.subscriptions=[],this.isDestroyed=!1),this.wavesurfer=t,this.onInit()}destroy(){this.emit(\"destroy\"),this.subscriptions.forEach((t=>t())),this.subscriptions=[],this.isDestroyed=!0,this.wavesurfer=void 0}},u.dom=r;export{u as default};\n", "import WaveSurfer from \"wavesurfer.js\"\n\nimport {context} from \"../../context.js\"\nimport {DecoderSource} from \"../../driver/fns/schematic.js\"\n\nexport class Waveform {\n\twavesurfer: WaveSurfer\n\n\tconstructor(peaks: number[], container: HTMLElement, duration: number) {\n\t\tthis.wavesurfer = WaveSurfer.create({\n \t\tcontainer,\n \t\twaveColor: 'rgb(200, 0, 200)',\n \t\tprogressColor: 'rgb(100, 0, 100)',\n \t\tbarWidth: 10,\n \t\tbarRadius: 10,\n \t\tbarGap: 2,\n \t\tpeaks: [peaks],\n \t\tduration\n\t\t})\n\t}\n\n\tstatic async init(source: DecoderSource, container: HTMLElement) {\n\t\tconst driver = await context.driver\n\t\tconst reader = driver.decodeAudio({source}).getReader()\n\n\t\tconst peaks: number[] = []\n\t\tlet buffer: number[] = []\n\t\tconst samplesPerPeak = 1024\n\t\tconst duration = await driver.getAudioDuration(source)\n\n\t\twhile (true) {\n\t\t\tconst {done, value: audioData} = await reader.read()\n\t\t\tif (done) break\n\n\t\t\tconst frames = audioData.numberOfFrames\n\t\t\tconst plane = new Float32Array(frames)\n\t\t\taudioData.copyTo(plane, {planeIndex: 0}) // Use left channel only\n\n\t\t\tfor (let i = 0; i < plane.length; i++) {\n\t\t\t\tbuffer.push(plane[i])\n\t\t\t\tif (buffer.length >= samplesPerPeak) {\n\t\t\t\t\tconst chunk = buffer.splice(0, samplesPerPeak)\n\t\t\t\t\tconst min = Math.min(...chunk)\n\t\t\t\t\tconst max = Math.max(...chunk)\n\t\t\t\t\tpeaks.push(min, max)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\taudioData.close()\n\t\t}\n\n\t\treturn new Waveform(peaks, container, duration ?? 0)\n\t}\n\n\t// set zoom(value: number) {\n\t// \tthis.wavesurfer.zoom(value)\n\t// }\n\n\tset width(value: number) {\n\t\tthis.wavesurfer.setOptions({width: value})\n\t}\n}\n", "import {Waveform} from \"../../timeline/parts/waveform.js\"\n\nexport async function waveformTest() {\n\tconst container = document.querySelector(\".waveform-demo\") as HTMLElement\n\tconst widthSlider = document.querySelector(\".width\") as HTMLInputElement\n\tconst waveform = await Waveform.init(\"/assets/temp/gl.mp4\", container)\n\n\twidthSlider.addEventListener(\"change\", () => {\n\t\tconst width = +widthSlider.value\n\t\twaveform.width = width\n\t})\n}\n", "import {\n\tALL_FORMATS,\n\tCanvasSink,\n\tCanvasSinkOptions,\n\tInput,\n\tInputVideoTrack,\n\tWrappedCanvas,\n} from \"mediabunny\"\n\nimport {DecoderSource} from '../../driver/fns/schematic.js'\nimport {loadDecoderSource} from '../../driver/utils/load-decoder-source.js'\n\nexport class Filmstrip {\n\t#sink: CanvasSink\n\t#cache: Map<number, WrappedCanvas> = new Map()\n\t#activeRange: TimeRange = [0, 0]\n\n\tprivate constructor(\n\t\tprivate videoTrack: InputVideoTrack,\n\t\tprivate options: Required<FilmstripOptions>\n\t) {\n\t\tthis.#sink = new CanvasSink(videoTrack, options.canvasSinkOptions)\n\t}\n\n\tstatic async init(source: DecoderSource, options: FilmstripOptions) {\n\t\tconst input = new Input({\n\t\t\tformats: ALL_FORMATS,\n\t\t\tsource: await loadDecoderSource(source)\n\t\t})\n\t\tconst videoTrack = await input.getPrimaryVideoTrack()\n\t\tif(videoTrack)\n\t\t\treturn new Filmstrip(\n\t\t\t\tvideoTrack, {\n\t\t\t\t\tfrequency: options.frequency ?? 1,\n\t\t\t\t\tcanvasSinkOptions: options.canvasSinkOptions ?? {width: 80, height: 50, fit: \"fill\"},\n\t\t\t\t\tonChange: options.onChange\n\t\t\t})\n\t\telse throw new Error(\"Source has no video track\")\n\t}\n\n\t/**\n \t* Sets the frequency (granularity) of filmstrip thumbnails.\n \t* Changing this triggers a filmstrip refresh after any ongoing update finishes.\n \t* @param value - The new frequency in seconds.\n \t*/\n\tset frequency(value: number) {\n\t\tif(value !== this.options.frequency) {\n\t\t\tthis.options.frequency = value\n\t\t\tthis.#update()\n\t\t}\n\t}\n\n\tget frequency() {\n\t\treturn this.options.frequency\n\t}\n\n\t#computeActiveRange([start, end]: TimeRange): TimeRange {\n\t\tconst tileSize = end - start\n\t\treturn [start - tileSize, end + tileSize]\n\t}\n\n\tasync #generateTiles() {\n\t\tconst [rangeStart, rangeEnd] = this.#activeRange\n\t\tconst neededTimestamps = new Set<number>()\n\n\t\t// duration should be computed but with trim etc also\n\t\tconst duration = await this.videoTrack.computeDuration()\n\t\tfor (\n\t\t\tlet timestamp = rangeStart;\n\t\t\ttimestamp <= rangeEnd;\n\t\t\ttimestamp += this.options.frequency\n\t\t) {\n\t\t\t// Clamp to valid time range\n\t\t\tif (timestamp >= 0 && timestamp <= duration)\n\t\t\t\tneededTimestamps.add(+timestamp.toFixed(3))\n\t\t}\n\n\t\tconst missingTimestamps = [...neededTimestamps]\n\t\t\t.filter(t => !this.#cache.has(t))\n\n\t\tlet i = 0\n\t\tfor await (const canvas of this.#sink.canvasesAtTimestamps(missingTimestamps)) {\n\t\t\tif(canvas) {\n\t\t\t\tconst requestedTime = missingTimestamps[i++]\n\t\t\t\tthis.#cache.set(requestedTime, canvas)\n\t\t\t}\n\t\t}\n\n\t\t// Dispose canvases outside the new range\n\t\tfor (const key of this.#cache.keys()) {\n\t\t\tif (!neededTimestamps.has(key)) {\n\t\t\t\tthis.#cache.delete(key)\n\t\t\t}\n\t\t}\n\n\t\tconst tiles = [...this.#cache.entries()]\n\t\t\t.map(([time, canvas]) => ({time, canvas}))\n\t\tthis.options.onChange(tiles)\n\t}\n\n\t/**\n \t* Updates the visible time range for the filmstrip.\n \t*\n \t* Triggers a thumbnails update, with extended margins to preload\n \t* thumbnails slightly outside the visible range.\n \t* @param visibleRange - The current timeline viewport as a [start, end] tuple in seconds.\n \t*/\n\tset range(visibleRange: TimeRange) {\n\t\tconst newRange = this.#computeActiveRange(visibleRange)\n\t\t// Avoid redundant updates\n\t\tif (\n\t\t\tthis.#activeRange[0] === newRange[0] &&\n\t\t\tthis.#activeRange[1] === newRange[1]\n\t\t)\n\t\t\treturn\n\n\t\tthis.#activeRange = newRange\n\t\tthis.#update()\n\t}\n\n\t#updating: Promise<void> | null = null\n\t#shouldRunAgain = false\n\n\tasync #update() {\n\t\t// Perform update immediately. If multiple updates are requested while updating,\n\t\t// only the latest one will run after the current finishes (skips intermediate ones).\n\t\tif(this.#updating) {\n\t\t\tthis.#shouldRunAgain = true\n\t\t\treturn\n\t\t}\n\n\t\tthis.#updating = this.#generateTiles()\n\t\tawait this.#updating\n\t\tthis.#updating = null\n\n\t\tif(this.#shouldRunAgain) {\n\t\t\tthis.#shouldRunAgain = false\n\t\t\tawait this.#update()\n\t\t}\n\t}\n\t/**\n \t* Returns the cached thumbnail (if any) for a given timestamp.\n \t* @param time - The timestamp to retrieve the canvas for.\n \t*/\n\tgetThumbnail(time: number) {\n\t\treturn this.#cache.get(time)\n\t}\n}\n\ntype TimeRange = [number, number]\n\ninterface FilmstripOptions {\n\tfrequency?: number\n\tcanvasSinkOptions?: CanvasSinkOptions\n\tonChange: (tiles: {\n\t\ttime: number\n\t\tcanvas: WrappedCanvas\n\t}[]) => void\n}\n", "import {Filmstrip} from \"../../timeline/parts/filmstrip.js\"\n\nexport async function filmstripTest(file: File) {\n\tconst rangeSlider = document.querySelector(\".range\") as HTMLInputElement\n\tconst rangeView = document.querySelector(\".range-view\")!\n\tconst rangeSizeSlider = document.querySelector(\".range-size\")! as HTMLInputElement\n\tconst frequencySlider = document.querySelector(\".frequency\")! as HTMLInputElement\n\tconst frequencyView = document.querySelector(\".frequency-view\")!\n\tconst container = document.querySelector(\"#filmstrip\")!\n\tconst FPS_10 = 1000/10 / 1000\n\tlet rangeSize = 0.5\n\tconst filmstrip = await Filmstrip.init(\n\t\t\tfile,\n\t\t\t{\n\t\t\t\tonChange(tiles) {\n\t\t\t\t\t// Sort by time (optional, for clean ordering)\n\t\t\t\t\tconst sorted = tiles.sort((a, b) => a.time - b.time)\n\t\t\t\t\t// Clear previous thumbnails\n\t\t\t\t\tcontainer.replaceChildren(\n\t\t\t\t\t\t...sorted.map(({ time, canvas }) => createLabeledCanvas(time, canvas.canvas as HTMLCanvasElement))\n\t\t\t\t\t)\n\t\t\t\t},\n\t\t\t\tfrequency: FPS_10,\n\t\t\t\tcanvasSinkOptions: {\n\t\t\t\t\twidth: 80,\n\t\t\t\t\theight: 50,\n\t\t\t\t\tfit: \"fill\"\n\t\t\t\t}\n\t\t\t}\n\t\t)\n\trangeSizeSlider.addEventListener(\"change\", () => {\n\t\trangeSize = +rangeSizeSlider.value\n\t\tconst [start, end] = [+rangeSlider.value, +rangeSlider.value+rangeSize]\n\t\tfilmstrip.range = [start, end]\n\t\trangeView.textContent = `visible time range: [${start}, ${end}]`\n\t})\n\trangeSlider.addEventListener(\"change\", () => {\n\t\tconst [start, end] = [+rangeSlider.value, +rangeSlider.value+rangeSize]\n\t\tfilmstrip.range = [start, end]\n\t\trangeView.textContent = `visible time range: [${start}, ${end}]`\n\t})\n\tfrequencySlider.addEventListener(\"change\", () => {\n\t\tfilmstrip.frequency = 1000/+frequencySlider.value/1000\n\t\tfrequencyView.textContent = `frame every ${filmstrip.frequency.toFixed(3)} second (${frequencySlider.value} frames per second)`\n\t})\n\tfilmstrip.range = [10, 10.5]\n}\n\nfunction createLabeledCanvas(time: number, canvas: HTMLCanvasElement) {\n\tconst wrapper = document.createElement('div')\n\twrapper.style.position = 'relative'\n\twrapper.style.display = 'inline-block'\n\twrapper.style.marginRight = '4px'\n\twrapper.appendChild(canvas)\n\tconst label = document.createElement('div')\n\tlabel.textContent = `${time.toFixed(2)}s`\n\tlabel.style.position = 'absolute'\n\tlabel.style.top = '2px'\n\tlabel.style.right = '4px'\n\tlabel.style.fontSize = '10px'\n\tlabel.style.color = 'white'\n\tlabel.style.background = 'rgba(0,0,0,0.6)'\n\tlabel.style.padding = '2px 4px'\n\tlabel.style.borderRadius = '4px'\n\tlabel.style.pointerEvents = 'none'\n\twrapper.appendChild(label)\n\treturn wrapper\n}\n", "\nimport {Driver} from \"../../../../driver/driver.js\"\n\nexport async function prepAudio(driver: Driver, source: Blob) {\n\tconst arrayBuffer = await source.arrayBuffer()\n\tconst audioCTX = new AudioContext({sampleRate: 16000})\n\tconst audioData = await audioCTX.decodeAudioData(arrayBuffer)\n\tlet audio: Float32Array\n\tif (audioData.numberOfChannels === 2) {\n\t\tconst SCALING_FACTOR = Math.sqrt(2)\n\t\tconst left = audioData.getChannelData(0)\n\t\tconst right = audioData.getChannelData(1)\n\t\taudio = new Float32Array(left.length)\n\t\tfor (let i = 0; i < audioData.length; ++i) {\n\t\t\taudio[i] = (SCALING_FACTOR * (left[i] + right[i])) / 2\n\t\t}\n\t} else {\n\t\taudio = audioData.getChannelData(0)\n\t}\n\tconst duration = await driver.getAudioDuration(source)\n\treturn {audio, duration}\n}\n\n", "\nimport {Comrade} from \"@e280/comrade\"\nimport {coalesce, queue, sub} from \"@e280/stz\"\n\nimport {prepAudio} from \"./parts/prep-audio.js\"\nimport {TranscriberOptions, TranscriberSchematic, TranscriptionOptions, TranscriptionReport} from \"./types.js\"\n\nexport async function makeTranscriber({driver, spec, workerUrl, onLoading}: TranscriberOptions) {\n\tconst onReport = sub<[report: TranscriptionReport]>()\n\tconst onTranscription = sub<[transcription: string]>()\n\n\tconst thread = await Comrade.thread<TranscriberSchematic>({\n\t\tlabel: \"OmnitoolSpeechTranscriber\",\n\t\tworkerUrl,\n\t\tsetupHost: () => ({\n\t\t\tloading: async loading => onLoading(loading),\n\t\t\tdeliverReport: async report => onReport.pub(report),\n\t\t\tdeliverTranscription: async transcription => onTranscription.pub(transcription),\n\t\t}),\n\t})\n\n\tawait thread.work.prepare(spec)\n\n\treturn {\n\t\ttranscribe: queue(async(info: TranscriptionOptions) => {\n\t\t\tconst {source, language} = info\n\t\t\tconst {audio, duration} = await prepAudio(driver, source)\n\n\t\t\tconst detachCallbacks = coalesce(\n\t\t\t\tonReport(info.onReport),\n\t\t\t\tonTranscription(info.onTranscription),\n\t\t\t)\n\n\t\t\tconst result = await thread.work.transcribe({\n\t\t\t\tduration,\n\t\t\t\tlanguage,\n\t\t\t\taudio: audio.buffer,\n\t\t\t})\n\n\t\t\tdetachCallbacks()\n\t\t\treturn result\n\t\t}),\n\t\tdispose: thread.terminate()\n\t}\n}\n\n", "import {Driver} from \"../../driver/driver.js\"\nimport {makeTranscriber} from \"../../features/speech/transcribe/transcriber.js\"\n\nexport async function transcriberTest(driver: Driver) {\n\tconst transcriber = await makeTranscriber({\n\t\tdriver,\n\t\tspec: {\n\t\t\tmodel: \"onnx-community/whisper-tiny_timestamped\",\n\t\t\tdevice: \"webgpu\",\n\t\t\tstrideLength: 5,\n\t\t\tchunkLength: 30,\n\t\t\tdtype: \"fp32\"\n\t\t},\n\t\tworkerUrl: new URL(\"/features/speech/transcribe/worker.bundle.min.js\", import.meta.url),\n\t\tonLoading({progress, total}) {\n\t \tconsole.log(progress, total, \"total\")\n\t\t},\n\t})\n\treturn {\n\t\ttranscribe: async (file: File) => {\n\t\t\tconst result = await transcriber.transcribe({\n\t\t\t\tsource: file,\n\t\t\t\tlanguage: \"english\",\n\t\t\t\tonReport(report) {\n\t \t\t\tconsole.log(\"report\", report)\n\t\t\t\t},\n\t\t\t\tonTranscription(transcription) {\n\t \t\t\tconsole.log(\"transcript\", transcription)\n\t\t\t\t}\n\t\t\t})\n\t\t\tconsole.log(result, \"transcript result\")\n\t\t}\n\t}\n}\n", "import {Driver} from \"../../driver/driver.js\"\nimport {DecoderSource} from \"../../driver/fns/schematic.js\"\n\nexport function setupTranscodeTest(driver: Driver, source: DecoderSource) {\n\tconst dimensions = {width: 1920, height: 1080}\n\n\tconst canvas = document.createElement(\"canvas\")\n\tcanvas.width = dimensions.width\n\tcanvas.height = dimensions.height\n\tconst ctx = canvas.getContext(\"2d\")\n\n\tasync function run() {\n\t\tconst video = driver.decodeVideo({\n\t\t\tsource,\n\t\t\tasync onFrame(frame) {\n\t\t\t\tconst composed = await driver.composite([\n\t\t\t\t\t{\n\t\t\t\t\t\tkind: \"image\",\n\t\t\t\t\t\tframe\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tkind: \"text\",\n\t\t\t\t\t\tcontent: \"omnitool\",\n\t\t\t\t\t\tfontSize: 50,\n\t\t\t\t\t\tcolor: \"green\"\n\t\t\t\t\t}\n\t\t\t\t])\n\t\t\t\tframe.close()\n\t\t\t\tctx?.drawImage(composed, 0, 0)\n\t\t\t\treturn composed\n\t\t\t}\n\t\t})\n\t\tconst audio = driver.decodeAudio({source})\n\n\t\tawait driver.encode({\n\t\t\tvideo,\n\t\t\taudio,\n\t\t\tconfig: {\n\t\t\t\taudio: {codec: \"opus\", bitrate: 128000},\n\t\t\t\tvideo: {codec: \"vp9\", bitrate: 1000000}\n\t\t\t}\n\t\t})\n\t}\n\n\treturn {canvas, run}\n}\n", "\nimport {context} from \"../context.js\"\nimport {waveformTest} from \"./routines/waveform-test.js\"\nimport {filmstripTest} from \"./routines/filmstrip-test.js\"\nimport {transcriberTest} from \"./routines/transcriber-test.js\"\nimport {setupTranscodeTest} from \"./routines/transcode-test.js\"\n\nconst driver = await context.driver\nconst results = document.querySelector(\".results\")!\n\nconst fetchButton = document.querySelector(\".fetch\")\nconst importButton = document.querySelector(\".import\") as HTMLButtonElement\n\nfetchButton?.addEventListener(\"click\", startDemoFetch)\nimportButton?.addEventListener(\"click\", startDemoImport)\n\nwaveformTest()\nconst transcriber = await transcriberTest(driver)\n\n// hello world test\n{\n\tawait driver.thread.work.hello()\n\tif (driver.machina.count === 1) console.log(\"\u2705 driver works\")\n\telse console.error(\"\u274C FAIL driver call didn't work\")\n}\n\n// transcoding tests\nasync function startDemoImport()\n{\n\tconst [fileHandle] = await window.showOpenFilePicker()\n\tconst file = await fileHandle.getFile()\n\tconst transcode = setupTranscodeTest(driver, file)\n\tawait filmstripTest(file)\n\trun(transcode, fileHandle.name)\n\tawait transcriber.transcribe(file)\n}\n\nasync function startDemoFetch()\n{\n\n\t// which videos to run tests on\n\tconst videos = [\n\t\t\"/assets/temp/gl.mp4\",\n\t]\n\n\t// running each test in sequence\n\tfor (const url of videos) {\n\t\tconst transcode = setupTranscodeTest(driver, \"/assets/temp/gl.mp4\")\n\t\trun(transcode, url)\n\t}\n}\n\nasync function run(transcode: ReturnType<typeof setupTranscodeTest>, label: string) {\n\t// create result div\n\tconst div = document.createElement(\"div\")\n\tresults.append(div)\n\n\t// add video label\n\tconst p = document.createElement(\"p\")\n\tp.textContent = label\n\tdiv.append(p)\n\n\t// add the canvas to dom\n\tdiv.append(transcode.canvas)\n\n\t// run the test\n\tawait transcode.run()\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["bindTap", "tap", "ctx", "o", "basicTheme", "colors", "autoTheme", "basicTheme", "codes", "colorFns", "s", "uncolor", "mix", "hex", "rgb", "bgRgb", "fn", "bigint", "r", "g", "b", "c", "code", "codes", "colorless", "codes", "key", "s", "colorFns", "colorful", "codes", "key", "code", "s", "colorFns", "isDeno", "isNode", "isColorSupported", "autoColors", "isColorSupported", "colorful", "colorless", "errorsShaper", "colors", "theme", "palette", "errstring", "error", "stack", "processErrors", "item", "processAll", "items", "combineShapers", "shapers", "context", "items", "shaper", "defaultTimestampOptions", "timestampShaper", "options", "colors", "theme", "opts", "palette", "date", "year", "month", "day", "calendar", "hour", "minute", "second", "milliseconds", "clock", "stamp", "items", "autoShaper", "combineShapers", "errorsShaper", "timestampShaper", "denoWriter", "line", "nodeWriter", "line", "consoleWriter", "line", "autoWriter", "isDeno", "denoWriter", "isNode", "nodeWriter", "consoleWriter", "voidWriter", "noneShaper", "items", "Logger", "_Logger", "autoWriter", "voidWriter", "denoWriter", "nodeWriter", "consoleWriter", "autoColors", "colorful", "colorless", "autoTheme", "basicTheme", "autoShaper", "noneShaper", "errorsShaper", "timestampShaper", "items", "writer", "colors", "theme", "shapers", "combineShapers", "LoggerTap", "Logger", "request", "context", "g", "#context", "error", "meta", "label", "remote", "cRemote", "cLocal", "#meta", "headers", "ErrorTap", "LoggerTap", "Bytes", "a", "b", "i", "count", "Hex", "bytes", "byte", "string", "i", "byteCount", "Bytes", "base", "characters", "Base58", "bytes", "intVal", "Hex", "encoded", "remainder", "byte", "string", "char", "index", "hex", "leadingZeroes", "decoded", "count", "Bytes", "BaseX", "lexicon", "char", "i", "s", "bitsPerChar", "bitBuffer", "bitCount", "output", "val", "num", "base", "negative", "out", "bytes", "byte", "index", "n", "value", "count", "Bytes", "Base64", "bytes", "string", "char", "count", "Bytes", "Txt", "bytes", "string", "is", "x", "DeadlineError", "milliseconds", "deadline", "fn", "resolve", "reject", "id", "defer", "resolve", "reject", "promise", "res", "rej", "entangle", "outside", "drill", "object", "path", "current", "key", "is", "ob", "o", "transform", "obMap", "predicate", "obFilter", "key", "value", "xub", "set", "sub", "fn", "pub", "next", "promise", "resolve", "defer", "unsubscribe", "a", "clear", "pub", "listener", "fn", "xub", "Trash", "#fns", "fns", "x", "fn", "JsonRpc", "getId", "request", "ExposedError", "RemoteError", "execute", "tap", "request", "action", "id", "JsonRpc", "result", "error", "ExposedError", "makeEndpoint", "options", "tap", "ErrorTap", "request", "path", "fn", "drill", "action", "execute", "tune", "query", "notify", "settings", "remoteProxy", "executor", "recurse", "path", "currentSettings", "_", "_this", "args", "target", "key", "value", "makeRemote", "options", "endpoint", "tap", "ErrorTap", "id", "remoteProxy", "path", "params", "settings", "notify", "transfer", "base", "request", "response", "RemoteError", "makeMock", "options", "makeRemote", "makeEndpoint", "Conduit", "pub", "origin", "a", "b", "disposers", "data", "fn", "onMessage", "channel", "fn", "makeRemoteEndpoint", "waiter", "sendRequest", "request", "transfer", "done", "defer", "response", "interpretIncoming", "json", "requests", "responses", "item", "handleIncomingRequests", "localEndpoint", "r", "PostableConduit", "Conduit", "#trash", "Trash", "channel", "m", "transfer", "onMessage", "e", "MessengerMeta", "remote", "defaults", "ResponseWaiter", "timeout", "id", "method", "deferred", "defer", "deadline", "error", "DeadlineError", "response", "pend", "RemoteError", "Messenger", "#waiter", "#trash", "Trash", "options", "conduit", "tap", "ResponseWaiter", "defaults", "makeRemoteEndpoint", "makeRemote", "bindTap", "m", "incoming", "meta", "MessengerMeta", "rpc", "requests", "responses", "interpretIncoming", "response", "fns", "endpoint", "makeEndpoint", "outgoing", "handleIncomingRequests", "shells", "meta", "t", "defaultTap", "ErrorTap", "worker", "compat", "setupWork", "options", "tap", "defaultTap", "messenger", "Messenger", "PostableConduit", "m", "shells", "Bytes", "a", "b", "i", "count", "Hex", "bytes", "byte", "string", "i", "byteCount", "Bytes", "base", "characters", "Base58", "bytes", "intVal", "Hex", "encoded", "remainder", "byte", "string", "char", "index", "hex", "leadingZeroes", "decoded", "count", "Bytes", "BaseX", "lexicon", "char", "i", "s", "bitsPerChar", "bitBuffer", "bitCount", "output", "val", "num", "base", "negative", "out", "bytes", "byte", "index", "n", "value", "count", "Bytes", "Base64", "bytes", "string", "char", "count", "Bytes", "Txt", "bytes", "string", "is", "x", "queue", "fn", "last", "args", "job", "current", "coalesce", "fns", "a", "fn", "defer", "resolve", "reject", "promise", "res", "rej", "entangle", "outside", "ob", "o", "transform", "obMap", "predicate", "obFilter", "key", "value", "xub", "set", "sub", "fn", "pub", "next", "promise", "resolve", "defer", "unsubscribe", "a", "clear", "listener", "Thread", "worker", "messenger", "compat", "options", "tap", "defaultTap", "label", "readyprom", "defer", "infra", "Messenger", "PostableConduit", "m", "shells", "Cluster", "compat", "options", "workerCount", "threads", "_", "index", "Thread", "#available", "#tasks", "tap", "defaultTap", "remoteEndpoint", "request", "special", "#scheduleTask", "defer", "makeRemote", "t", "thread", "task", "#distributeTasks", "callprom", "setupComrade", "compat", "options", "Thread", "Cluster", "setupWork", "worker", "fn", "setupHost", "tap", "defaultTap", "hostShell", "shells", "workShell", "makeMock", "setupBrowserCompat", "count", "url", "name", "compat", "setupBrowserCompat", "Comrade", "setupComrade", "assert", "x", "normalizeRotation", "rotation", "mappedRotation", "last", "arr", "Bitstream", "_Bitstream", "bytes", "byteOffset", "byteIndex", "byte", "bitIndex", "bit", "n", "result", "i", "value", "end", "clone", "readExpGolomb", "bitstream", "leadingZeroBits", "readSignedExpGolomb", "codeNum", "toUint8Array", "source", "toDataView", "textDecoder", "textEncoder", "invertObject", "object", "key", "value", "COLOR_PRIMARIES_MAP", "COLOR_PRIMARIES_MAP_INVERSE", "TRANSFER_CHARACTERISTICS_MAP", "TRANSFER_CHARACTERISTICS_MAP_INVERSE", "MATRIX_COEFFICIENTS_MAP", "MATRIX_COEFFICIENTS_MAP_INVERSE", "isAllowSharedBufferSource", "x", "AsyncMutex", "resolver", "nextPromise", "resolve", "currentPromiseAlias", "bytesToHexString", "bytes", "reverseBitsU32", "binarySearchExact", "arr", "key", "valueGetter", "low", "high", "ans", "mid", "midVal", "binarySearchLessOrEqual", "insertSorted", "item", "insertionIndex", "promiseWithResolvers", "reject", "res", "rej", "findLast", "arr", "predicate", "i", "findLastIndex", "toAsyncIterator", "source", "validateAnyIterable", "iterable", "assertNever", "x", "mapAsyncGenerator", "generator", "map", "result", "error", "clamp", "value", "min", "max", "UNDETERMINED_LANGUAGE", "roundToPrecision", "digits", "factor", "roundToMultiple", "multiple", "ilog", "x", "ret", "ISO_639_2_REGEX", "isIso639Dash2LanguageCode", "SECOND_TO_MICROSECOND_FACTOR", "mergeObjectsDeeply", "a", "b", "key", "retriedFetch", "url", "requestInit", "getRetryDelay", "attempts", "retryDelayInSeconds", "resolve", "CallSerializer", "fn", "isSafariCache", "isSafari", "result", "coalesceIndex", "a", "b", "closedIntervalsOverlap", "startA", "endA", "startB", "endB", "base64ToBytes", "base64", "decoded", "bytes", "i", "RichImageData", "data", "mimeType", "PCM_AUDIO_CODECS", "NON_PCM_AUDIO_CODECS", "AUDIO_CODECS", "VP9_LEVEL_TABLE", "VP9_DEFAULT_SUFFIX", "AV1_DEFAULT_SUFFIX", "extractVideoCodecString", "trackInfo", "codec", "codecDescription", "colorSpace", "avcCodecInfo", "hevcCodecInfo", "vp9CodecInfo", "av1CodecInfo", "bytes", "bytesToHexString", "generalProfileSpace", "generalProfileIdc", "compatibilityFlags", "generalTierFlag", "generalLevelIdc", "constraintFlags", "reverseBitsU32", "view", "toDataView", "profileByte", "i", "codecString", "x", "pictureSize", "level", "last", "VP9_LEVEL_TABLE", "entry", "profile", "bitDepth", "chromaSubsampling", "colourPrimaries", "transferCharacteristics", "matrixCoefficients", "videoFullRangeFlag", "string", "VP9_DEFAULT_SUFFIX", "tier", "monochrome", "colorPrimaries", "COLOR_PRIMARIES_MAP", "TRANSFER_CHARACTERISTICS_MAP", "MATRIX_COEFFICIENTS_MAP", "AV1_DEFAULT_SUFFIX", "extractAudioCodecString", "trackInfo", "codec", "codecDescription", "aacCodecInfo", "parseAacAudioSpecificConfig", "PCM_AUDIO_CODECS", "aacFrequencyTable", "aacChannelMap", "bytes", "bitstream", "Bitstream", "objectType", "frequencyIndex", "sampleRate", "channelConfiguration", "numberOfChannels", "OPUS_INTERNAL_SAMPLE_RATE", "PCM_CODEC_REGEX", "parsePcmCodec", "assert", "match", "dataType", "sampleSize", "littleEndian", "silentValue", "AvcNalUnitType", "HevcNalUnitType", "findNalUnitsInAnnexB", "packetData", "nalUnits", "i", "startCodePos", "startCodeLength", "j", "nalData", "findNalUnitsInLengthPrefixed", "lengthSize", "offset", "dataView", "nalUnitLength", "assertNever", "assert", "nalUnit", "removeEmulationPreventionBytes", "data", "result", "len", "extractAvcNalUnits", "packetData", "decoderConfig", "lengthSize", "toUint8Array", "findNalUnitsInLengthPrefixed", "findNalUnitsInAnnexB", "extractNalUnitTypeForAvc", "data", "extractAvcDecoderConfigurationRecord", "nalUnits", "spsUnits", "unit", "AvcNalUnitType", "ppsUnits", "spsExtUnits", "spsData", "bitstream", "Bitstream", "removeEmulationPreventionBytes", "profile_idc", "constraint_flags", "level_idc", "record", "readExpGolomb", "chroma_format_idc", "bit_depth_luma_minus8", "bit_depth_chroma_minus8", "error", "extractHevcNalUnits", "packetData", "decoderConfig", "lengthSize", "toUint8Array", "findNalUnitsInLengthPrefixed", "findNalUnitsInAnnexB", "extractNalUnitTypeForHevc", "data", "extractHevcDecoderConfigurationRecord", "nalUnits", "vpsUnits", "unit", "HevcNalUnitType", "spsUnits", "ppsUnits", "seiUnits", "sps", "bitstream", "Bitstream", "removeEmulationPreventionBytes", "sps_max_sub_layers_minus1", "sps_temporal_id_nesting_flag", "general_profile_space", "general_tier_flag", "general_profile_idc", "general_profile_compatibility_flags", "general_constraint_indicator_flags", "general_level_idc", "parseProfileTierLevel", "readExpGolomb", "chroma_format_idc", "bit_depth_luma_minus8", "bit_depth_chroma_minus8", "maxNum", "i", "skipScalingListData", "num_short_term_ref_pic_sets", "skipAllStRefPicSets", "num_long_term_ref_pics_sps", "min_spatial_segmentation_idc", "parseVuiForMinSpatialSegmentationIdc", "parallelismType", "pps", "ppsBitstream", "readSignedExpGolomb", "tiles_enabled_flag", "entropy_coding_sync_enabled_flag", "arrays", "error", "maxNumSubLayersMinus1", "sub_layer_profile_present_flag", "sub_layer_level_present_flag", "sizeId", "matrixId", "coefNum", "NumDeltaPocs", "stRpsIdx", "skipStRefPicSet", "NumDeltaPocsThis", "inter_ref_pic_set_prediction_flag", "RefRpsIdx", "delta_idx_minus1", "numDelta", "j", "num_negative_pics", "num_positive_pics", "skipHrdParameters", "commonInfPresentFlag", "nal_hrd_parameters_present_flag", "vcl_hrd_parameters_present_flag", "sub_pic_hrd_params_present_flag", "fixed_pic_rate_general_flag", "fixed_pic_rate_within_cvs_flag", "low_delay_hrd_flag", "CpbCnt", "skipSubLayerHrdParameters", "extractVp9CodecInfoFromPacket", "packet", "bitstream", "Bitstream", "profileLowBit", "profile", "bitDepth", "colorSpace", "chromaSubsampling", "videoFullRangeFlag", "subsamplingX", "subsamplingY", "widthMinusOne", "heightMinusOne", "width", "height", "pictureSize", "level", "last", "VP9_LEVEL_TABLE", "entry", "iterateAv1PacketObus", "readLeb128", "value", "i", "byte", "obuType", "obuExtension", "obuHasSizeField", "obuSize", "obuSizeValue", "assert", "extractAv1CodecInfoFromPacket", "type", "data", "seqProfile", "stillPicture", "reducedStillPictureHeader", "seqLevel", "seqTier", "bufferDelayLengthMinus1", "decoderModelInfoPresentFlag", "operatingPointsCntMinus1", "seqLevelIdx", "seqTierTemp", "n", "highBitdepth", "monochrome", "chromaSubsamplingX", "chromaSubsamplingY", "chromaSamplePosition", "parseOpusIdentificationHeader", "bytes", "view", "toDataView", "outputChannelCount", "preSkip", "inputSampleRate", "outputGain", "channelMappingFamily", "channelMappingTable", "OPUS_FRAME_DURATION_TABLE", "parseOpusTocByte", "config", "parseModesFromVorbisSetupPacket", "setupHeader", "bufSize", "revBuffer", "gotFramingBit", "modeCount", "gotModeHeader", "lastModeCount", "tempPos", "a", "b", "c", "finalModeCount", "modeBlockflags", "determineVideoPacketType", "videoTrack", "decoderConfig", "extractAvcNalUnits", "x", "extractNalUnitTypeForAvc", "AvcNalUnitType", "extractHevcNalUnits", "extractNalUnitTypeForHevc", "HevcNalUnitType", "assertNever", "buildIsobmffMimeType", "info", "string", "uniqueCodecMimeTypes", "Reader", "source", "start", "length", "end", "result", "x", "FileSlice", "minLength", "maxLength", "clamp", "promisedAttempt", "handleAttempt", "attempt", "handleFileSize", "fileSize", "assert", "promisedFileSize", "_FileSlice", "bytes", "view", "offset", "toDataView", "value", "byteCount", "filePos", "readBytes", "slice", "readU8", "readU16", "littleEndian", "readU16Be", "readU24Be", "high", "low", "readI16Be", "readU32", "readU32Be", "readU32Le", "readI32Be", "readI32Le", "readU64", "readU64Be", "readI64Be", "readI64Le", "readF32Be", "readF64Be", "readAscii", "str", "i", "MIN_BOX_HEADER_SIZE", "MAX_BOX_HEADER_SIZE", "readBoxHeader", "slice", "totalSize", "readU32Be", "name", "readAscii", "headerSize", "readU64Be", "contentSize", "readFixed_16_16", "readI32Be", "readFixed_2_30", "readIsomVariableInteger", "result", "i", "nextByte", "readU8", "readMetadataStringShort", "stringLength", "readU16Be", "textDecoder", "readBytes", "readDataBox", "header", "typeIndicator", "data", "RichImageData", "EBMLId", "LEVEL_0_EBML_IDS", "LEVEL_1_EBML_IDS", "LEVEL_0_AND_1_EBML_IDS", "MAX_VAR_INT_SIZE", "MIN_HEADER_SIZE", "MAX_HEADER_SIZE", "readVarIntSize", "slice", "firstByte", "readU8", "width", "mask", "readVarInt", "value", "i", "readUnsignedInt", "readSignedInt", "readElementId", "size", "readElementSize", "readElementHeader", "id", "readAsciiString", "length", "bytes", "readBytes", "strLength", "readUnicodeString", "textDecoder", "readFloat", "readF32Be", "readF64Be", "searchForNextElementId", "reader", "startPos", "ids", "until", "idsSet", "currentPos", "elementHeader", "assertDefinedSize", "resync", "elementId", "CODEC_STRING_MAP", "buildMatroskaMimeType", "info", "string", "uniqueCodecMimeTypes", "MPEG_V1_BITRATES", "MPEG_V2_BITRATES", "SAMPLING_RATES", "XING", "INFO", "computeMp3FrameSize", "layer", "bitrate", "sampleRate", "padding", "getXingOffset", "mpegVersionId", "channel", "readFrameHeader", "word", "remainingBytes", "firstByte", "secondByte", "thirdByte", "fourthByte", "bitrateIndex", "frequencyIndex", "modeExtension", "copyright", "original", "emphasis", "kilobitRate", "frameLength", "audioSamplesInFrame", "decodeSynchsafe", "synchsafed", "mask", "unsynchsafed", "Id3V2HeaderFlags", "Id3V2TextEncoding", "ID3_V1_TAG_SIZE", "ID3_V2_HEADER_SIZE", "ID3_V1_GENRES", "readNextFrameHeader", "reader", "startPos", "until", "currentPos", "slice", "word", "readU32Be", "result", "readFrameHeader", "parseId3V1Tag", "tags", "readBytes", "title", "readId3V1String", "artist", "album", "yearText", "year", "commentBytes", "comment", "trackNum", "genreIndex", "readU8", "length", "bytes", "endIndex", "coalesceIndex", "relevantBytes", "str", "readId3V2Header", "tag", "readAscii", "majorVersion", "revision", "flags", "sizeRaw", "size", "decodeSynchsafe", "parseId3V2Tag", "header", "Id3V2Reader", "extendedHeaderSize", "frame", "frameStartPos", "frameEndPos", "frameEncrypted", "frameCompressed", "frameUnsynchronized", "parts", "tracksTotal", "discNum", "discsTotal", "genreText", "match", "genreNumber", "dateText", "date", "encoding", "mimeType", "imageFormat", "pictureType", "description", "imageDataSize", "imageData", "newBytes", "i", "value1", "start", "end", "before", "after", "value", "high", "low", "id", "headerEndPos", "isSizeValid", "nextPos", "nextId", "otherSize", "number", "data", "decoder", "x", "textDecoder", "OGGS", "OGG_CRC_POLYNOMIAL", "OGG_CRC_TABLE", "n", "crc", "k", "computeOggPageCrc", "bytes", "view", "toDataView", "originalChecksum", "i", "byte", "extractSampleMetadata", "data", "codecInfo", "vorbisLastBlocksize", "durationInSamples", "currentBlocksize", "assert", "vorbisModeCount", "modeMask", "ilog", "modeNumber", "prevBlocksize", "blockflag", "prevMask", "flag", "parseOpusTocByte", "buildOggMimeType", "info", "string", "uniqueCodecMimeTypes", "MIN_PAGE_HEADER_SIZE", "MAX_PAGE_HEADER_SIZE", "MAX_PAGE_SIZE", "readPageHeader", "slice", "startPos", "readU32Le", "OGGS", "headerType", "readU8", "granulePosition", "readI64Le", "serialNumber", "sequenceNumber", "checksum", "numberPageSegments", "lacingValues", "i", "headerSize", "dataSize", "a", "b", "totalSize", "findNextPageHeader", "until", "word", "firstByte", "secondByte", "thirdByte", "fourthByte", "O", "Demuxer", "input", "customVideoDecoders", "customAudioDecoders", "PLACEHOLDER_DATA", "EncodedPacket", "_EncodedPacket", "data", "type", "timestamp", "duration", "sequenceNumber", "byteLength", "SECOND_TO_MICROSECOND_FACTOR", "chunk", "options", "VideoSample", "_VideoSample", "SECOND_TO_MICROSECOND_FACTOR", "data", "init", "toUint8Array", "width", "height", "canvas", "context", "assert", "isVideoFrame", "destination", "isAllowSharedBufferSource", "imageData", "arg1", "arg2", "arg3", "arg4", "arg5", "arg6", "arg7", "arg8", "sx", "sy", "sWidth", "sHeight", "dx", "dy", "dWidth", "dHeight", "source", "centerX", "centerY", "aspectRatioChange", "options", "canvasWidth", "canvasHeight", "rotation", "newWidth", "newHeight", "sampleWidth", "sampleHeight", "scale", "videoFrame", "newRotation", "newTimestamp", "newDuration", "x", "validatePacketRetrievalOptions", "options", "validateTimestamp", "timestamp", "maybeFixPacketType", "track", "promise", "packet", "determinedType", "EncodedPacketSink", "InputTrack", "EncodedPacket", "nextPacket", "startPacket", "endPacket", "packetQueue", "queueNotEmpty", "onQueueNotEmpty", "promiseWithResolvers", "queueDequeue", "onQueueDequeue", "ended", "terminated", "outOfBandError", "timestamps", "maxQueueSize", "error", "value", "now", "DecoderWrapper", "onSample", "onError", "BaseMediaSampleSink", "startTimestamp", "endTimestamp", "sampleQueue", "firstSampleQueued", "lastSample", "decoderIsFlushed", "decoderError", "decoder", "sample", "packetSink", "keyPacket", "currentPacket", "packets", "computeMaxQueueSize", "packetResult", "validateAnyIterable", "timestampIterator", "toAsyncIterator", "timestampsOfInterest", "pushToQueue", "sampleUses", "i", "lastPacket", "lastKeyPacket", "maxSequenceNumber", "decodePackets", "assert", "flushDecoder", "targetPacket", "decodedSampleQueueSize", "VideoDecoderWrapper", "codec", "decoderConfig", "rotation", "timeResolution", "CallSerializer", "MatchingCustomDecoder", "customVideoDecoders", "x", "VideoSample", "sampleHandler", "isSafari", "last", "insertSorted", "frame", "extractHevcNalUnits", "type", "extractNalUnitTypeForHevc", "HevcNalUnitType", "VideoSampleSink", "videoTrack", "InputVideoTrack", "CanvasSink", "width", "height", "originalAspectRatio", "canvas", "canvasIsNew", "context", "result", "mapAsyncGenerator", "InputTrack", "backing", "InputVideoTrack", "InputAudioTrack", "targetPacketCount", "sink", "EncodedPacketSink", "startTimestamp", "endTimestamp", "packetCount", "totalPacketBytes", "packet", "colorSpace", "decoderConfig", "codec", "assert", "customVideoDecoders", "x", "error", "EncodedPacket", "determineVideoPacketType", "customAudioDecoders", "WaveFormat", "WaveDemuxer", "Demuxer", "input", "slice", "assert", "riffType", "readAscii", "littleEndian", "isRf64", "outerChunkSize", "readU32", "totalFileSize", "chunksRead", "dataChunkSize", "currentPos", "chunkId", "chunkSize", "startPos", "riffChunkSize", "readU64", "blockSize", "InputAudioTrack", "WaveAudioTrackBacking", "size", "formatTag", "readU16", "numChannels", "sampleRate", "blockAlign", "bitsPerSample", "cbSize", "remainingSize", "subFormat", "readBytes", "infoType", "chunkName", "bytes", "stringLength", "i", "value", "parts", "trackNum", "tracksTotal", "date", "year", "track", "PACKET_SIZE_IN_FRAMES", "demuxer", "codec", "lastPacket", "UNDETERMINED_LANGUAGE", "packetIndex", "options", "startOffset", "sizeInBytes", "data", "PLACEHOLDER_DATA", "timestamp", "duration", "EncodedPacket", "packet", "currentPacket", "nextPacket", "Source", "result", "BlobSource", "Source", "blob", "options", "ReadOrchestrator", "PREFETCH_PROFILES", "size", "start", "end", "worker", "reader", "done", "value", "URL_SOURCE_MIN_LOAD_AMOUNT", "UrlSource", "url", "previousAttempts", "abortController", "response", "retriedFetch", "mergeObjectsDeeply", "fileSize", "contentLength", "existing", "assert", "length", "required", "readResult", "error", "retryDelayInSeconds", "resolve", "contentRange", "match", "PREFETCH_PROFILES", "start", "end", "workers", "worker", "thresholdPoint", "closedIntervalsOverlap", "size", "a", "b", "extent", "URL_SOURCE_MIN_LOAD_AMOUNT", "ReadOrchestrator", "options", "innerStart", "innerEnd", "assert", "prefetchRange", "outerStart", "outerEnd", "result", "innerCacheStartIndex", "binarySearchLessOrEqual", "x", "innerStartEntry", "outerCacheStartIndex", "bytes", "contiguousBytesWriteEnd", "lastEnd", "outerHoles", "i", "entry", "cappedOuterStart", "cappedOuterEnd", "cappedInnerStart", "cappedInnerEnd", "relativeOffset", "toDataView", "promise", "resolve", "reject", "promiseWithResolvers", "innerHoles", "outerHole", "cappedStart", "cappedEnd", "pendingSlice", "workerFound", "newWorker", "startPos", "targetPos", "oldestIndex", "oldestWorker", "error", "clampedStart", "clampedEnd", "j", "hole", "otherWorker", "index", "insertionIndex", "previous", "joined", "next", "oldestEntry", "UDTA_STRING_KEYS", "IsobmffDemuxer", "Demuxer", "input", "AsyncMutex", "tracks", "trackDurations", "x", "track", "codecStrings", "buildIsobmffMimeType", "currentPos", "slice", "MIN_BOX_HEADER_SIZE", "MAX_BOX_HEADER_SIZE", "startPos", "boxInfo", "readBoxHeader", "majorBrand", "readAscii", "moovSlice", "previousSegmentDurationsInSeconds", "lastWordSlice", "assert", "lastWord", "readU32Be", "potentialMfraPos", "mfraHeaderSlice", "mfraSlice", "internalTrack", "sampleTable", "stblContainerSlice", "PCM_AUDIO_CODECS", "pcmInfo", "parsePcmCodec", "newSampleTimingEntries", "newSampleSizes", "i", "chunkEntry", "nextEntry", "chunkCount", "j", "startSampleIndex", "endSampleIndex", "startTimingEntryIndex", "binarySearchLessOrEqual", "startTimingEntry", "endTimingEntryIndex", "endTimingEntry", "firstSampleTimestamp", "delta", "lastSampleTimingEntry", "last", "chunkSize", "entry", "sampleIndex", "sample", "b", "headerSlice", "moofBoxInfo", "entireSlice", "index", "binarySearchExact", "fragment", "trackId", "trackData", "currentFragment", "lastFragment", "nextFragmentIsFirstFragment", "boxStartPos", "otherTrackData", "offsetFragmentTrackDataByTimestamp", "startIndex", "contentStartPos", "boxEndPos", "version", "readU8", "readU64Be", "UNDETERMINED_LANGUAGE", "videoTrack", "InputVideoTrack", "IsobmffVideoTrackBacking", "audioTrack", "InputAudioTrack", "IsobmffAudioTrackBacking", "readU24Be", "matrix", "readFixed_16_16", "readFixed_2_30", "rotation", "normalizeRotation", "roundToMultiple", "extractRotationFromMatrix", "relevantEntryFound", "previousSegmentDurations", "entryCount", "segmentDuration", "mediaTime", "readI64Be", "readI32Be", "mediaRate", "language", "readU16Be", "isIso639Dash2LanguageCode", "handlerType", "stsdVersion", "entries", "sampleBoxStartPos", "sampleBoxInfo", "lowercaseBoxName", "channelCount", "sampleSize", "sampleRate", "readF64Be", "flags", "bytesPerSample", "isFloat", "isBigEndian", "sFlags", "readBytes", "profile", "level", "thirdByte", "bitDepth", "chromaSubsampling", "videoFullRangeFlag", "colourPrimaries", "transferCharacteristics", "matrixCoefficients", "secondByte", "tier", "highBitDepth", "twelveBit", "monochrome", "chromaSubsamplingX", "chromaSubsamplingY", "chromaSamplePosition", "fullRangeFlag", "COLOR_PRIMARIES_MAP_INVERSE", "TRANSFER_CHARACTERISTICS_MAP_INVERSE", "MATRIX_COEFFICIENTS_MAP_INVERSE", "tag", "readIsomVariableInteger", "mixed", "streamDependenceFlag", "urlFlag", "ocrStreamFlag", "urlLength", "decoderConfigTag", "decoderConfigDescriptorLength", "payloadStart", "objectTypeIndication", "decoderSpecificInfoTag", "decoderSpecificInfoLength", "audioSpecificConfig", "parseAacAudioSpecificConfig", "isLittleEndian", "pcmSampleSize", "outputChannelCount", "preSkip", "inputSampleRate", "outputGain", "readI16Be", "channelMappingFamily", "channelMappingTable", "description", "view", "BLOCK_TYPE_MASK", "LAST_METADATA_BLOCK_FLAG_MASK", "flagAndType", "metadataBlockLength", "word", "numberOfChannels", "endPos", "bytes", "currentIndex", "currentTimestamp", "sampleCount", "sampleDelta", "sampleOffset", "fieldSize", "bitstream", "Bitstream", "startChunkIndex", "samplesPerChunk", "sampleDescriptionIndex", "chunkOffset", "fragmentDuration", "defaultSampleDescriptionIndex", "defaultSampleDuration", "defaultSampleSize", "defaultSampleFlags", "lengthSizeOfTrafNum", "lengthSizeOfTrunNum", "lengthSizeOfSampleNum", "functions", "readTrafNum", "readTrunNum", "readSampleNum", "numberOfEntries", "time", "moofOffset", "insertSorted", "firstSample", "lastSample", "currentFragmentState", "baseDataOffsetPresent", "sampleDescriptionIndexPresent", "defaultSampleDurationPresent", "defaultSampleSizePresent", "defaultSampleFlagsPresent", "durationIsEmpty", "defaultBaseIsMoof", "defaults", "baseMediaDecodeTime", "dataOffsetPresent", "firstSampleFlagsPresent", "sampleDurationPresent", "sampleSizePresent", "sampleFlagsPresent", "sampleCompositionTimeOffsetsPresent", "dataOffset", "firstSampleFlags", "currentOffset", "sampleDuration", "sampleFlags", "sampleCompositionTimeOffset", "isKeyFrame", "a", "currentEntry", "currentSample", "iterator", "readMetadataStringShort", "textDecoder", "date", "isQuickTime", "keySize", "keyName", "metadataKey", "nameAsNumber", "data", "readDataBox", "RichImageData", "toDataView", "trackNumber", "tracksTotal", "discNumber", "discNumberMax", "IsobmffTrackBacking", "lastPacket", "options", "regularPacket", "startFragment", "timestamp", "roundToPrecision", "timestampInTimescale", "getSampleIndexForTimestamp", "sampleTableIsEmpty", "packet", "regularSampleIndex", "locationInFragment", "fragmentIndex", "keyFrameSampleIndex", "getRelevantKeyframeIndexForSample", "nextKeyFrameSampleIndex", "getNextKeyframeIndexForSample", "nextKeyFrameIndex", "keyFrameIndex", "sampleInfo", "getSampleInfo", "PLACEHOLDER_DATA", "duration", "EncodedPacket", "fragmentSample", "correctSampleFound", "indexInKeyFrameFragments", "findLastIndex", "getBestMatch", "searchTimestamp", "latestTimestamp", "demuxer", "release", "prevFragment", "bestFragmentIndex", "bestSampleIndex", "lookupEntryIndex", "lookupEntry", "bestFragment", "newSearchTimestamp", "firstPacket", "extractVp9CodecInfoFromPacket", "extractAv1CodecInfoFromPacket", "extractVideoCodecString", "extractAudioCodecString", "timescaleUnits", "timingEntryIndex", "timingEntry", "presentationTimestamp", "offsetEntryIndex", "offsetEntry", "chunkEntryIndex", "chunkIndex", "startSampleIndexOfChunk", "presentationIndex", "m11", "m21", "scaleX", "cosTheta", "sinTheta", "result", "BlockLacing", "METADATA_ELEMENTS", "EBMLId", "MAX_RESYNC_LENGTH", "MatroskaDemuxer", "Demuxer", "input", "tracks", "trackDurations", "x", "segment", "track", "codecStrings", "buildMatroskaMimeType", "metadataTags", "currentPos", "slice", "MIN_HEADER_SIZE", "MAX_HEADER_SIZE", "header", "readElementHeader", "id", "size", "dataStartPos", "assertDefinedSize", "searchForNextElementId", "LEVEL_0_AND_1_EBML_IDS", "lastSegment", "last", "segmentDataStart", "dataSize", "AsyncMutex", "elementStartPos", "LEVEL_1_EBML_IDS", "nextPos", "resync", "metadataElementIndex", "field", "a", "b", "seekEntry", "target", "dataSlice", "allTrackIds", "remainingTrackIds", "lastClusterPosition", "lastCuePoint", "cuePoint", "assert", "startPos", "headerSlice", "elementHeader", "cluster", "trackId", "trackData", "blockReferencesExist", "hasLacedBlocks", "i", "block", "sortBlocksByReferences", "currentEntry", "currentBlock", "nextEntry", "firstBlock", "lastBlock", "insertSorted", "trackNumber", "blocks", "blockIndex", "originalBlock", "FileSlice", "frameSizes", "frameCount", "readU8", "totalUsedSize", "frameSize", "value", "totalDataSize", "firstResult", "readVarInt", "currentSize", "diffResult", "unsignedDiff", "bias", "diff", "frameData", "readBytes", "blockDuration", "frameTimestamp", "frameDuration", "startIndex", "readAsciiString", "lastSeekEntry", "readUnsignedInt", "readFloat", "UNDETERMINED_LANGUAGE", "slashIndex", "codecIdWithoutSuffix", "CODEC_STRING_MAP", "videoTrack", "inputTrack", "InputVideoTrack", "MatroskaVideoTrackBacking", "audioTrack", "InputAudioTrack", "MatroskaAudioTrackBacking", "type", "readUnicodeString", "isIso639Dash2LanguageCode", "languageSubtag", "matrixCoefficients", "mapped", "MATRIX_COEFFICIENTS_MAP_INVERSE", "transferCharacteristics", "TRANSFER_CHARACTERISTICS_MAP_INVERSE", "primaries", "COLOR_PRIMARIES_MAP_INVERSE", "flippedRotation", "normalizeRotation", "relativeTimestamp", "readI16Be", "flags", "isKeyFrame", "lacing", "readSignedInt", "fileName", "kind", "lowerName", "name", "date", "parts", "trackNum", "tracksTotal", "discParts", "discNum", "discsTotal", "MatroskaTrackBacking", "internalTrack", "lastPacket", "options", "startCluster", "currentCluster", "binarySearchExact", "timestamp", "roundToPrecision", "timestampInTimescale", "packet", "locationInCluster", "clusterIndex", "nextKeyFrameIndex", "keyFrameIndex", "data", "PLACEHOLDER_DATA", "duration", "EncodedPacket", "binarySearchLessOrEqual", "correctBlockFound", "index", "indexInKeyFrameClusters", "findLastIndex", "getBestMatch", "searchTimestamp", "latestTimestamp", "demuxer", "release", "prevCluster", "bestClusterIndex", "bestBlockIndex", "cuePointIndex", "nextClusterIsFirstCluster", "endPos", "readElementId", "bestCluster", "newSearchTimestamp", "firstPacket", "extractVideoCodecString", "extractAvcDecoderConfigurationRecord", "extractHevcDecoderConfigurationRecord", "extractVp9CodecInfoFromPacket", "extractAv1CodecInfoFromPacket", "extractAudioCodecString", "timestampToBlock", "processedBlocks", "result", "processBlock", "j", "otherBlock", "Mp3Demuxer", "Demuxer", "input", "AsyncMutex", "InputAudioTrack", "Mp3AudioTrackBacking", "slice", "ID3_V2_HEADER_SIZE", "id3V2Header", "readId3V2Header", "result", "readNextFrameHeader", "header", "xingOffset", "getXingOffset", "word", "readU32Be", "XING", "INFO", "sampleDuration", "sample", "track", "assert", "release", "currentPos", "id3V2HeaderFound", "headerSlice", "contentSlice", "parseId3V2Tag", "ID3_V1_TAG_SIZE", "readAscii", "parseId3V1Tag", "demuxer", "lastPacket", "UNDETERMINED_LANGUAGE", "sampleIndex", "options", "rawSample", "data", "PLACEHOLDER_DATA", "readBytes", "EncodedPacket", "packet", "binarySearchExact", "x", "nextIndex", "timestamp", "index", "binarySearchLessOrEqual", "OggDemuxer", "Demuxer", "input", "currentPos", "slice", "MIN_PAGE_HEADER_SIZE", "MAX_PAGE_HEADER_SIZE", "page", "readPageHeader", "bitstream", "firstPacket", "InputAudioTrack", "OggAudioTrackBacking", "nextPacketPosition", "secondPacket", "thirdPacket", "lacingValues", "addBytesToSegmentTable", "bytes", "description", "view", "toDataView", "blockSizeByte", "parseModesFromVorbisSetupPacket", "header", "parseOpusIdentificationHeader", "commentView", "commentPos", "vendorStringLength", "vendorString", "textDecoder", "listLength", "i", "stringLength", "string", "separatorIndex", "key", "value", "parts", "trackNum", "tracksTotal", "discNum", "discsTotal", "date", "decoded", "base64ToBytes", "pictureType", "mediaTypeLength", "mediaType", "descriptionLength", "dataLength", "data", "startPage", "startSegmentIndex", "assert", "startDataOffset", "currentPage", "currentDataOffset", "currentSegmentIndex", "chunks", "outer", "pageSlice", "pageData", "readBytes", "lacingValue", "headerSlice", "nextPage", "totalPacketSize", "sum", "chunk", "packetData", "offset", "lastPacket", "codecStrings", "x", "buildOggMimeType", "tracks", "trackDurations", "demuxer", "AsyncMutex", "OPUS_INTERNAL_SAMPLE_RATE", "UNDETERMINED_LANGUAGE", "granulePosition", "packet", "additional", "options", "durationInSamples", "vorbisBlockSize", "extractSampleMetadata", "encodedPacket", "EncodedPacket", "PLACEHOLDER_DATA", "packetPosition", "timestampInSamples", "prevPacket", "prevMetadata", "timestamp", "roundToPrecision", "startPosition", "lowPage", "high", "lowPages", "low", "mid", "searchStartPos", "until", "MAX_PAGE_SIZE", "searchSlice", "findNextPageHeader", "pageValid", "computeOggPageCrc", "lowerPage", "otherLowPage", "previousPages", "nextPos", "currentTimestampInSamples", "currentTimestampIsCorrect", "endPage", "endSegmentIndex", "pseudopacket", "endPosition", "findPreviousPacketEndPosition", "findPacketStartPosition", "lastEncodedPacket", "lastEncodedPacketMetadata", "encodedPacketMetadata", "nextPosition", "release", "index", "binarySearchLessOrEqual", "currentPacket", "cacheEntry", "nextPacket", "metadata", "last", "pageList", "segmentIndex", "previousPage", "findLast", "MIN_FRAME_HEADER_SIZE", "MAX_FRAME_HEADER_SIZE", "readFrameHeader", "slice", "startPos", "bytes", "readBytes", "bitstream", "Bitstream", "protectionAbsence", "objectType", "samplingFrequencyIndex", "channelConfiguration", "frameLength", "numberOfAacFrames", "crcCheck", "SAMPLES_PER_AAC_FRAME", "AdtsDemuxer", "Demuxer", "input", "AsyncMutex", "assert", "InputAudioTrack", "AdtsAudioTrackBacking", "slice", "MIN_FRAME_HEADER_SIZE", "MAX_FRAME_HEADER_SIZE", "header", "readFrameHeader", "sampleRate", "aacFrequencyTable", "sampleDuration", "headerSize", "sample", "track", "demuxer", "lastPacket", "UNDETERMINED_LANGUAGE", "numberOfChannels", "aacChannelMap", "bytes", "bitstream", "Bitstream", "objectType", "samplingFrequencyIndex", "channelConfiguration", "sampleIndex", "options", "rawSample", "data", "PLACEHOLDER_DATA", "readBytes", "EncodedPacket", "packet", "release", "binarySearchExact", "x", "nextIndex", "timestamp", "index", "binarySearchLessOrEqual", "InputFormat", "IsobmffInputFormat", "input", "slice", "readAscii", "IsobmffDemuxer", "Mp4InputFormat", "majorBrand", "QuickTimeInputFormat", "MatroskaInputFormat", "desiredDocType", "headerSlice", "MAX_HEADER_SIZE", "varIntSize", "readVarIntSize", "readUnsignedInt", "EBMLId", "dataSize", "readElementSize", "dataSlice", "startPos", "MIN_HEADER_SIZE", "header", "readElementHeader", "id", "size", "dataStartPos", "readAsciiString", "MatroskaDemuxer", "WebMInputFormat", "Mp3InputFormat", "currentPos", "id3V2HeaderFound", "ID3_V2_HEADER_SIZE", "id3V2Header", "readId3V2Header", "firstResult", "readNextFrameHeader", "secondResult", "firstHeader", "secondHeader", "Mp3Demuxer", "WaveInputFormat", "riffType", "WaveDemuxer", "OggInputFormat", "OggDemuxer", "AdtsInputFormat", "MIN_FRAME_HEADER_SIZE", "MAX_FRAME_HEADER_SIZE", "readFrameHeader", "AdtsDemuxer", "MP4", "QTFF", "MATROSKA", "WEBM", "MP3", "WAVE", "OGG", "ADTS", "ALL_FORMATS", "Input", "options", "x", "InputFormat", "Source", "Reader", "format", "assert", "Machina", "#handlers", "id", "handler", "event", "setupDriverHost", "machina", "Comrade", "_shell", "loadDecoderSource", "source", "BlobSource", "UrlSource", "Driver", "options", "machina", "Machina", "thread", "Comrade", "setupDriverHost", "source", "Input", "loadDecoderSource", "ALL_FORMATS", "input", "lastFrame", "videoTransform", "chunk", "controller", "frame", "tune", "audioTransform", "video", "audio", "config", "writable", "bridge", "composition", "transfer", "#collectTransferablesFromComposition", "transferables", "visit", "node", "child", "workerUrl", "context", "Driver", "t", "i", "s", "n", "r", "o", "h", "a", "e", "e", "t", "i", "s", "n", "r", "o", "a", "h", "_h", "l", "d", "c", "u", "p", "m", "f", "g", "v", "b", "_u", "Waveform", "_Waveform", "peaks", "container", "duration", "u", "source", "driver", "context", "reader", "buffer", "samplesPerPeak", "done", "audioData", "frames", "plane", "i", "chunk", "min", "max", "value", "waveformTest", "container", "widthSlider", "waveform", "Waveform", "width", "Filmstrip", "_Filmstrip", "#sink", "#cache", "#activeRange", "videoTrack", "options", "CanvasSink", "source", "Input", "ALL_FORMATS", "loadDecoderSource", "value", "#update", "#computeActiveRange", "start", "end", "tileSize", "#generateTiles", "rangeStart", "rangeEnd", "neededTimestamps", "duration", "timestamp", "missingTimestamps", "t", "canvas", "requestedTime", "key", "tiles", "time", "visibleRange", "newRange", "#updating", "#shouldRunAgain", "filmstripTest", "file", "rangeSlider", "rangeView", "rangeSizeSlider", "frequencySlider", "frequencyView", "container", "FPS_10", "rangeSize", "filmstrip", "Filmstrip", "tiles", "sorted", "a", "b", "time", "canvas", "createLabeledCanvas", "start", "end", "wrapper", "label", "prepAudio", "driver", "source", "arrayBuffer", "audioData", "audio", "SCALING_FACTOR", "left", "right", "i", "duration", "makeTranscriber", "driver", "spec", "workerUrl", "onLoading", "onReport", "sub", "onTranscription", "thread", "Comrade", "loading", "report", "transcription", "queue", "info", "source", "language", "audio", "duration", "prepAudio", "detachCallbacks", "coalesce", "result", "transcriberTest", "driver", "transcriber", "makeTranscriber", "progress", "total", "file", "result", "report", "transcription", "setupTranscodeTest", "driver", "source", "dimensions", "canvas", "ctx", "run", "video", "frame", "composed", "audio", "driver", "context", "results", "fetchButton", "importButton", "startDemoFetch", "startDemoImport", "waveformTest", "transcriber", "transcriberTest", "fileHandle", "file", "transcode", "setupTranscodeTest", "filmstripTest", "run", "videos", "url", "label", "div", "p"]
|
|
7
|
+
}
|