@remotion/media-parser 4.0.249 → 4.0.251
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/dist/add-avc-profile-to-track.js +2 -2
- package/dist/buffer-iterator.d.ts +3 -5
- package/dist/buffer-iterator.js +66 -50
- package/dist/containers/aac/parse-aac.d.ts +3 -0
- package/dist/containers/aac/parse-aac.js +83 -0
- package/dist/containers/aac/types.d.ts +4 -0
- package/dist/{boxes → containers}/avc/key.d.ts +1 -1
- package/dist/containers/flac/get-block-size.d.ts +2 -0
- package/dist/containers/flac/get-block-size.js +26 -0
- package/dist/containers/flac/get-channel-count.d.ts +2 -0
- package/dist/containers/flac/get-channel-count.js +36 -0
- package/dist/containers/flac/get-duration-from-flac.d.ts +2 -0
- package/dist/containers/flac/get-duration-from-flac.js +15 -0
- package/dist/containers/flac/get-metadata-from-flac.d.ts +2 -0
- package/dist/containers/flac/get-metadata-from-flac.js +11 -0
- package/dist/containers/flac/get-sample-rate.d.ts +3 -0
- package/dist/containers/flac/get-sample-rate.js +60 -0
- package/dist/containers/flac/parse-flac-frame.d.ts +15 -0
- package/dist/containers/flac/parse-flac-frame.js +175 -0
- package/dist/{boxes/riff/parse-box.d.ts → containers/flac/parse-flac.d.ts} +1 -3
- package/dist/containers/flac/parse-flac.js +54 -0
- package/dist/{boxes/mp3/parse-mpeg-header.d.ts → containers/flac/parse-header.d.ts} +4 -3
- package/dist/containers/flac/parse-header.js +10 -0
- package/dist/{boxes/mp3/parse-mp3.d.ts → containers/flac/parse-metadata.d.ts} +4 -4
- package/dist/containers/flac/parse-metadata.js +24 -0
- package/dist/{boxes/webm/parse-webm-header.d.ts → containers/flac/parse-streaminfo.d.ts} +2 -4
- package/dist/containers/flac/parse-streaminfo.js +53 -0
- package/dist/containers/flac/parse-unknown-block.d.ts +8 -0
- package/dist/containers/flac/parse-unknown-block.js +11 -0
- package/dist/containers/flac/types.d.ts +26 -0
- package/dist/containers/iso-base-media/base-media-box.d.ts +40 -0
- package/dist/containers/iso-base-media/get-children.d.ts +6 -0
- package/dist/containers/iso-base-media/get-children.js +21 -0
- package/dist/{boxes → containers}/iso-base-media/get-sample-positions-from-track.d.ts +1 -1
- package/dist/containers/iso-base-media/mdat/mdat.d.ts +2 -0
- package/dist/containers/iso-base-media/mdat/mdat.js +91 -0
- package/dist/containers/iso-base-media/moov/moov.d.ts +12 -0
- package/dist/containers/iso-base-media/moov/moov.js +17 -0
- package/dist/containers/iso-base-media/parse-boxes.d.ts +3 -0
- package/dist/containers/iso-base-media/parse-boxes.js +40 -0
- package/dist/containers/iso-base-media/process-box.d.ts +3 -0
- package/dist/{boxes → containers}/iso-base-media/process-box.js +49 -147
- package/dist/{boxes → containers}/iso-base-media/stsd/mebx.d.ts +1 -6
- package/dist/containers/iso-base-media/stsd/mebx.js +22 -0
- package/dist/{boxes → containers}/iso-base-media/stsd/samples.d.ts +6 -16
- package/dist/{boxes → containers}/iso-base-media/stsd/samples.js +26 -71
- package/dist/{boxes → containers}/iso-base-media/stsd/stsd.d.ts +1 -6
- package/dist/{boxes → containers}/iso-base-media/stsd/stsd.js +3 -6
- package/dist/containers/iso-base-media/trak/trak.d.ts +12 -0
- package/dist/containers/iso-base-media/trak/trak.js +17 -0
- package/dist/{boxes → containers}/iso-base-media/traversal.d.ts +2 -3
- package/dist/{boxes → containers}/iso-base-media/traversal.js +1 -12
- package/dist/containers/iso-base-media/void-box.js +2 -0
- package/dist/containers/mp3/get-tracks-from-mp3.d.ts +4 -0
- package/dist/{boxes → containers}/mp3/get-tracks-from-mp3.js +6 -6
- package/dist/containers/mp3/id3.d.ts +4 -0
- package/dist/{boxes → containers}/mp3/id3.js +8 -5
- package/dist/containers/mp3/parse-mp3.d.ts +3 -0
- package/dist/{boxes → containers}/mp3/parse-mp3.js +4 -20
- package/dist/containers/mp3/parse-mpeg-header.d.ts +4 -0
- package/dist/{boxes → containers}/mp3/parse-mpeg-header.js +2 -1
- package/dist/containers/riff/expect-riff-box.d.ts +7 -0
- package/dist/containers/riff/expect-riff-box.js +72 -0
- package/dist/containers/riff/get-duration.d.ts +3 -0
- package/dist/containers/riff/get-duration.js +33 -0
- package/dist/{boxes → containers}/riff/get-tracks-from-avi.d.ts +2 -3
- package/dist/{boxes → containers}/riff/get-tracks-from-avi.js +6 -10
- package/dist/containers/riff/parse-list-box.d.ts +6 -0
- package/dist/containers/riff/parse-list-box.js +29 -0
- package/dist/containers/riff/parse-movi.d.ts +11 -0
- package/dist/{boxes → containers}/riff/parse-movi.js +37 -57
- package/dist/containers/riff/parse-riff-body.d.ts +3 -0
- package/dist/containers/riff/parse-riff-body.js +22 -0
- package/dist/containers/riff/parse-riff-box.d.ts +7 -0
- package/dist/{boxes → containers}/riff/parse-riff-box.js +3 -10
- package/dist/containers/riff/parse-riff-header.d.ts +3 -0
- package/dist/containers/riff/parse-riff-header.js +23 -0
- package/dist/containers/riff/parse-riff.d.ts +3 -0
- package/dist/containers/riff/parse-riff.js +12 -0
- package/dist/containers/riff/parse-strf.d.ts +7 -0
- package/dist/{boxes → containers}/riff/parse-strf.js +4 -8
- package/dist/{boxes → containers}/riff/parse-strh.js +11 -0
- package/dist/containers/riff/parse-video-section.d.ts +2 -0
- package/dist/containers/riff/parse-video-section.js +19 -0
- package/dist/{boxes → containers}/riff/riff-box.d.ts +8 -14
- package/dist/containers/riff/riff-box.js +2 -0
- package/dist/{boxes → containers}/riff/traversal.d.ts +1 -3
- package/dist/{boxes → containers}/riff/traversal.js +1 -6
- package/dist/containers/transport-stream/boxes.js +2 -0
- package/dist/containers/transport-stream/get-tracks.d.ts +4 -0
- package/dist/{boxes → containers}/transport-stream/get-tracks.js +4 -3
- package/dist/containers/transport-stream/parse-packet.d.ts +5 -0
- package/dist/{boxes → containers}/transport-stream/parse-packet.js +4 -5
- package/dist/containers/transport-stream/parse-stream-packet.d.ts +9 -0
- package/dist/{boxes → containers}/transport-stream/parse-stream-packet.js +11 -12
- package/dist/containers/transport-stream/parse-transport-stream.d.ts +3 -0
- package/dist/{boxes → containers}/transport-stream/parse-transport-stream.js +8 -37
- package/dist/{boxes → containers}/transport-stream/process-stream-buffers.d.ts +1 -2
- package/dist/{boxes → containers}/transport-stream/process-stream-buffers.js +3 -3
- package/dist/containers/wav/get-duration-from-wav.d.ts +3 -0
- package/dist/containers/wav/get-duration-from-wav.js +29 -0
- package/dist/containers/wav/get-metadata-from-wav.d.ts +3 -0
- package/dist/containers/wav/get-metadata-from-wav.js +11 -0
- package/dist/containers/wav/parse-data.d.ts +5 -0
- package/dist/containers/wav/parse-data.js +25 -0
- package/dist/containers/wav/parse-fmt.d.ts +5 -0
- package/dist/containers/wav/parse-fmt.js +56 -0
- package/dist/containers/wav/parse-header.d.ts +5 -0
- package/dist/containers/wav/parse-header.js +17 -0
- package/dist/containers/wav/parse-id3.d.ts +5 -0
- package/dist/containers/wav/parse-id3.js +17 -0
- package/dist/containers/wav/parse-list.d.ts +5 -0
- package/dist/containers/wav/parse-list.js +32 -0
- package/dist/containers/wav/parse-video-section.d.ts +5 -0
- package/dist/containers/wav/parse-video-section.js +37 -0
- package/dist/containers/wav/parse-wav.d.ts +3 -0
- package/dist/containers/wav/parse-wav.js +36 -0
- package/dist/containers/wav/types.d.ts +30 -0
- package/dist/containers/wav/types.js +2 -0
- package/dist/{boxes → containers}/webm/parse-ebml.d.ts +1 -2
- package/dist/{boxes → containers}/webm/parse-ebml.js +6 -2
- package/dist/containers/webm/parse-webm-header.d.ts +3 -0
- package/dist/containers/webm/parse-webm-header.js +53 -0
- package/dist/containers/webm/segments.d.ts +9 -0
- package/dist/containers/webm/segments.js +80 -0
- package/dist/emit-available-info.d.ts +1 -3
- package/dist/emit-available-info.js +86 -76
- package/dist/errors.d.ts +1 -1
- package/dist/esm/from-node.mjs +8 -9
- package/dist/esm/index.mjs +4951 -4693
- package/dist/file-types/detect-file-type.d.ts +5 -1
- package/dist/file-types/detect-file-type.js +10 -3
- package/dist/file-types/index.js +3 -0
- package/dist/get-audio-codec.d.ts +4 -5
- package/dist/get-audio-codec.js +5 -5
- package/dist/get-container.d.ts +2 -2
- package/dist/get-container.js +10 -1
- package/dist/get-dimensions.d.ts +2 -3
- package/dist/get-dimensions.js +14 -10
- package/dist/get-duration.d.ts +5 -5
- package/dist/get-duration.js +29 -27
- package/dist/get-fields-from-callbacks.js +4 -0
- package/dist/get-fps.d.ts +1 -1
- package/dist/get-fps.js +12 -4
- package/dist/get-is-hdr.d.ts +2 -3
- package/dist/get-is-hdr.js +4 -4
- package/dist/get-keyframes.d.ts +1 -1
- package/dist/get-keyframes.js +4 -3
- package/dist/get-number-of-audio-channels.d.ts +3 -0
- package/dist/get-number-of-audio-channels.js +14 -0
- package/dist/get-sample-aspect-ratio.d.ts +8 -8
- package/dist/get-sample-aspect-ratio.js +1 -1
- package/dist/get-sample-positions-from-lpcm.d.ts +1 -1
- package/dist/get-sample-positions-from-lpcm.js +1 -1
- package/dist/get-sample-positions.d.ts +6 -6
- package/dist/get-sample-rate.d.ts +3 -0
- package/dist/get-sample-rate.js +14 -0
- package/dist/get-tracks.d.ts +9 -8
- package/dist/get-tracks.js +36 -22
- package/dist/get-video-codec.d.ts +3 -4
- package/dist/get-video-codec.js +6 -6
- package/dist/has-all-info.js +26 -15
- package/dist/index.d.ts +145 -41
- package/dist/index.js +8 -8
- package/dist/init-video.d.ts +7 -0
- package/dist/init-video.js +114 -0
- package/dist/is-audio-structure.d.ts +2 -0
- package/dist/is-audio-structure.js +31 -0
- package/dist/metadata/get-metadata.js +16 -1
- package/dist/metadata/metadata-from-iso.d.ts +2 -1
- package/dist/metadata/metadata-from-iso.js +1 -1
- package/dist/metadata/metadata-from-matroska.js +1 -1
- package/dist/metadata/metadata-from-riff.d.ts +1 -1
- package/dist/options.d.ts +64 -38
- package/dist/parse-media.js +125 -43
- package/dist/parse-result.d.ts +8 -61
- package/dist/perform-seek.d.ts +13 -0
- package/dist/perform-seek.js +29 -0
- package/dist/readers/from-node.js +7 -8
- package/dist/readers/reader.d.ts +1 -1
- package/dist/register-track.d.ts +3 -3
- package/dist/run-parse-iteration.d.ts +8 -0
- package/dist/run-parse-iteration.js +48 -0
- package/dist/samples-from-moof.js +1 -1
- package/dist/state/aac-state.d.ts +13 -0
- package/dist/state/aac-state.js +17 -0
- package/dist/state/can-skip-tracks.d.ts +8 -1
- package/dist/state/can-skip-tracks.js +42 -27
- package/dist/state/emitted-fields.js +4 -0
- package/dist/state/flac-state.d.ts +4 -0
- package/dist/state/flac-state.js +13 -0
- package/dist/state/has-tracks-section.d.ts +2 -1
- package/dist/state/has-tracks-section.js +4 -1
- package/dist/state/iso-base-media/cached-sample-positions.d.ts +15 -0
- package/dist/state/iso-base-media/cached-sample-positions.js +42 -0
- package/dist/state/iso-base-media/iso-state.d.ts +8 -0
- package/dist/state/iso-base-media/iso-state.js +15 -0
- package/dist/{may-skip-video-data → state}/may-skip-video-data.d.ts +1 -1
- package/dist/{may-skip-video-data → state}/may-skip-video-data.js +6 -2
- package/dist/{may-skip-video-data → state}/need-samples-for-fields.js +4 -0
- package/dist/state/parser-state.d.ts +131 -17
- package/dist/state/parser-state.js +18 -5
- package/dist/state/sample-callbacks.d.ts +6 -2
- package/dist/state/sample-callbacks.js +5 -2
- package/dist/state/slow-duration-fps.d.ts +2 -0
- package/dist/state/slow-duration-fps.js +18 -0
- package/dist/state/transport-stream.d.ts +8 -0
- package/dist/state/transport-stream.js +11 -0
- package/dist/state/video-section.d.ts +16 -0
- package/dist/state/video-section.js +37 -0
- package/dist/state/webm.d.ts +17 -2
- package/dist/state/webm.js +33 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/dist/webcodec-sample-types.d.ts +3 -3
- package/package.json +3 -3
- package/test.json +663 -0
- package/dist/boxes/iso-base-media/get-children.d.ts +0 -14
- package/dist/boxes/iso-base-media/get-children.js +0 -39
- package/dist/boxes/iso-base-media/mdat/mdat.d.ts +0 -26
- package/dist/boxes/iso-base-media/mdat/mdat.js +0 -141
- package/dist/boxes/iso-base-media/moov/moov.d.ts +0 -19
- package/dist/boxes/iso-base-media/moov/moov.js +0 -27
- package/dist/boxes/iso-base-media/parse-boxes.d.ts +0 -15
- package/dist/boxes/iso-base-media/parse-boxes.js +0 -129
- package/dist/boxes/iso-base-media/parse-mdat-partially.d.ts +0 -12
- package/dist/boxes/iso-base-media/parse-mdat-partially.js +0 -33
- package/dist/boxes/iso-base-media/process-box.d.ts +0 -15
- package/dist/boxes/iso-base-media/stsd/mebx.js +0 -32
- package/dist/boxes/iso-base-media/trak/trak.d.ts +0 -19
- package/dist/boxes/iso-base-media/trak/trak.js +0 -27
- package/dist/boxes/mp3/get-tracks-from-mp3.d.ts +0 -4
- package/dist/boxes/mp3/id3-v2.d.ts +0 -0
- package/dist/boxes/mp3/id3-v2.js +0 -1
- package/dist/boxes/mp3/id3.d.ts +0 -8
- package/dist/boxes/riff/continue-after-riff-result.d.ts +0 -13
- package/dist/boxes/riff/continue-after-riff-result.js +0 -34
- package/dist/boxes/riff/expect-riff-box.d.ts +0 -19
- package/dist/boxes/riff/expect-riff-box.js +0 -50
- package/dist/boxes/riff/parse-box.js +0 -35
- package/dist/boxes/riff/parse-fmt-box.d.ts +0 -7
- package/dist/boxes/riff/parse-fmt-box.js +0 -33
- package/dist/boxes/riff/parse-list-box.d.ts +0 -10
- package/dist/boxes/riff/parse-list-box.js +0 -31
- package/dist/boxes/riff/parse-movi.d.ts +0 -17
- package/dist/boxes/riff/parse-riff-body.d.ts +0 -11
- package/dist/boxes/riff/parse-riff-body.js +0 -105
- package/dist/boxes/riff/parse-riff-box.d.ts +0 -12
- package/dist/boxes/riff/parse-strf.d.ts +0 -7
- package/dist/boxes/transport-stream/get-tracks.d.ts +0 -5
- package/dist/boxes/transport-stream/parse-packet.d.ts +0 -13
- package/dist/boxes/transport-stream/parse-stream-packet.d.ts +0 -15
- package/dist/boxes/transport-stream/parse-transport-stream.d.ts +0 -13
- package/dist/boxes/webm/parse-webm-header.js +0 -37
- package/dist/boxes/webm/segments/parse-children.d.ts +0 -23
- package/dist/boxes/webm/segments/parse-children.js +0 -144
- package/dist/boxes/webm/segments.d.ts +0 -15
- package/dist/boxes/webm/segments.js +0 -161
- package/dist/continue-mdat-routine.d.ts +0 -17
- package/dist/continue-mdat-routine.js +0 -92
- package/dist/parse-video.d.ts +0 -28
- package/dist/parse-video.js +0 -130
- /package/dist/{boxes/iso-base-media/base-type.js → containers/aac/types.js} +0 -0
- /package/dist/{boxes → containers}/avc/codec-string.d.ts +0 -0
- /package/dist/{boxes → containers}/avc/codec-string.js +0 -0
- /package/dist/{boxes → containers}/avc/color.d.ts +0 -0
- /package/dist/{boxes → containers}/avc/color.js +0 -0
- /package/dist/{boxes → containers}/avc/create-sps-pps-data.d.ts +0 -0
- /package/dist/{boxes → containers}/avc/create-sps-pps-data.js +0 -0
- /package/dist/{boxes → containers}/avc/interpret-sps.d.ts +0 -0
- /package/dist/{boxes → containers}/avc/interpret-sps.js +0 -0
- /package/dist/{boxes → containers}/avc/key.js +0 -0
- /package/dist/{boxes → containers}/avc/parse-avc.d.ts +0 -0
- /package/dist/{boxes → containers}/avc/parse-avc.js +0 -0
- /package/dist/{boxes → containers}/avc/sps-and-pps.d.ts +0 -0
- /package/dist/{boxes → containers}/avc/sps-and-pps.js +0 -0
- /package/dist/{boxes/iso-base-media/void-box.js → containers/flac/types.js} +0 -0
- /package/dist/{boxes/riff/riff-box.js → containers/iso-base-media/base-media-box.js} +0 -0
- /package/dist/{boxes → containers}/iso-base-media/base-type.d.ts +0 -0
- /package/dist/{boxes/transport-stream/boxes.js → containers/iso-base-media/base-type.js} +0 -0
- /package/dist/{boxes → containers}/iso-base-media/esds/decoder-specific-config.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/esds/decoder-specific-config.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/esds/esds-descriptors.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/esds/esds-descriptors.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/esds/esds.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/esds/esds.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/ftyp.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/ftyp.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-actual-number-of-channels.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-actual-number-of-channels.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-keyframes.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-keyframes.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-sample-positions-from-track.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-video-codec-from-iso-track.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/get-video-codec-from-iso-track.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/make-track.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/make-track.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/mdhd.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/mdhd.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/meta/hdlr.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/meta/hdlr.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/meta/ilst.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/meta/ilst.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/mvhd.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/mvhd.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/parse-icc-profile.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/parse-icc-profile.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/av1c.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/av1c.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/avcc.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/avcc.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/colr.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/colr.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/ctts.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/ctts.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/hvcc.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/hvcc.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/keys.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/keys.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/pasp.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/pasp.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stco.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stco.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stsc.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stsc.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stss.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stss.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stsz.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stsz.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stts.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/stsd/stts.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/tfdt.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/tfdt.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/tfhd.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/tfhd.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/tkhd.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/tkhd.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/to-date.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/to-date.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/trun.d.ts +0 -0
- /package/dist/{boxes → containers}/iso-base-media/trun.js +0 -0
- /package/dist/{boxes → containers}/iso-base-media/void-box.d.ts +0 -0
- /package/dist/{boxes → containers}/mp3/get-duration.d.ts +0 -0
- /package/dist/{boxes → containers}/mp3/get-duration.js +0 -0
- /package/dist/{boxes → containers}/mp3/get-frame-length.d.ts +0 -0
- /package/dist/{boxes → containers}/mp3/get-frame-length.js +0 -0
- /package/dist/{boxes → containers}/mp3/get-metadata-from-mp3.d.ts +0 -0
- /package/dist/{boxes → containers}/mp3/get-metadata-from-mp3.js +0 -0
- /package/dist/{boxes → containers}/mp3/id3-v1.d.ts +0 -0
- /package/dist/{boxes → containers}/mp3/id3-v1.js +0 -0
- /package/dist/{boxes → containers}/mp3/samples-per-mpeg-file.d.ts +0 -0
- /package/dist/{boxes → containers}/mp3/samples-per-mpeg-file.js +0 -0
- /package/dist/{boxes → containers}/riff/is-movi.d.ts +0 -0
- /package/dist/{boxes → containers}/riff/is-movi.js +0 -0
- /package/dist/{boxes → containers}/riff/parse-avih.d.ts +0 -0
- /package/dist/{boxes → containers}/riff/parse-avih.js +0 -0
- /package/dist/{boxes → containers}/riff/parse-isft.d.ts +0 -0
- /package/dist/{boxes → containers}/riff/parse-isft.js +0 -0
- /package/dist/{boxes → containers}/riff/parse-strh.d.ts +0 -0
- /package/dist/{boxes → containers}/riff/timescale.d.ts +0 -0
- /package/dist/{boxes → containers}/riff/timescale.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/adts-header.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/adts-header.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/boxes.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/discard-rest-of-packet.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/discard-rest-of-packet.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/find-separator.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/find-separator.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/handle-aac-packet.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/handle-aac-packet.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/handle-avc-packet.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/handle-avc-packet.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/next-pes-header-store.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/next-pes-header-store.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/parse-pat.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/parse-pat.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/parse-pes.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/parse-pes.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/parse-pmt.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/parse-pmt.js +0 -0
- /package/dist/{boxes → containers}/transport-stream/traversal.d.ts +0 -0
- /package/dist/{boxes → containers}/transport-stream/traversal.js +0 -0
- /package/dist/{boxes → containers}/webm/allowed-partial-segments.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/allowed-partial-segments.js +0 -0
- /package/dist/{boxes → containers}/webm/av1-codec-private.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/av1-codec-private.js +0 -0
- /package/dist/{boxes → containers}/webm/color.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/color.js +0 -0
- /package/dist/{boxes → containers}/webm/description.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/description.js +0 -0
- /package/dist/{boxes → containers}/webm/get-ready-tracks.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/get-ready-tracks.js +0 -0
- /package/dist/{boxes → containers}/webm/get-sample-from-block.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/get-sample-from-block.js +0 -0
- /package/dist/{boxes → containers}/webm/make-track.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/make-track.js +0 -0
- /package/dist/{boxes → containers}/webm/segments/all-segments.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/segments/all-segments.js +0 -0
- /package/dist/{boxes → containers}/webm/segments/block-simple-block-flags.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/segments/block-simple-block-flags.js +0 -0
- /package/dist/{boxes → containers}/webm/segments/track-entry.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/segments/track-entry.js +0 -0
- /package/dist/{boxes → containers}/webm/traversal.d.ts +0 -0
- /package/dist/{boxes → containers}/webm/traversal.js +0 -0
- /package/dist/{may-skip-video-data → state}/need-samples-for-fields.d.ts +0 -0
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.expectRiffBox = void 0;
|
|
4
|
-
const is_movi_1 = require("./is-movi");
|
|
5
|
-
const parse_movi_1 = require("./parse-movi");
|
|
6
|
-
const parse_riff_box_1 = require("./parse-riff-box");
|
|
7
|
-
const expectRiffBox = async ({ iterator, state, structure, fields, }) => {
|
|
8
|
-
// Need at least 16 bytes to read LIST,size,movi,size
|
|
9
|
-
if (iterator.bytesRemaining() < 16) {
|
|
10
|
-
return {
|
|
11
|
-
type: 'incomplete',
|
|
12
|
-
continueParsing() {
|
|
13
|
-
return (0, exports.expectRiffBox)({ structure, iterator, state, fields });
|
|
14
|
-
},
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
const ckId = iterator.getByteString(4, false);
|
|
18
|
-
const ckSize = iterator.getUint32Le();
|
|
19
|
-
if ((0, is_movi_1.isMoviAtom)(iterator, ckId)) {
|
|
20
|
-
iterator.discard(4);
|
|
21
|
-
return (0, parse_movi_1.parseMovi)({
|
|
22
|
-
iterator,
|
|
23
|
-
maxOffset: ckSize + iterator.counter.getOffset() - 4,
|
|
24
|
-
state,
|
|
25
|
-
structure,
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
if (iterator.bytesRemaining() < ckSize) {
|
|
29
|
-
iterator.counter.decrement(8);
|
|
30
|
-
return {
|
|
31
|
-
type: 'incomplete',
|
|
32
|
-
continueParsing: () => {
|
|
33
|
-
return (0, exports.expectRiffBox)({ structure, iterator, state, fields });
|
|
34
|
-
},
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
return {
|
|
38
|
-
type: 'complete',
|
|
39
|
-
box: await (0, parse_riff_box_1.parseRiffBox)({
|
|
40
|
-
id: ckId,
|
|
41
|
-
iterator,
|
|
42
|
-
size: ckSize,
|
|
43
|
-
boxes: structure.boxes,
|
|
44
|
-
state,
|
|
45
|
-
fields,
|
|
46
|
-
}),
|
|
47
|
-
skipTo: null,
|
|
48
|
-
};
|
|
49
|
-
};
|
|
50
|
-
exports.expectRiffBox = expectRiffBox;
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseRiff = void 0;
|
|
4
|
-
const has_all_info_1 = require("../../has-all-info");
|
|
5
|
-
const parse_riff_body_1 = require("./parse-riff-body");
|
|
6
|
-
const parseRiff = ({ iterator, state, fields, }) => {
|
|
7
|
-
const riff = iterator.getByteString(4, false);
|
|
8
|
-
if (riff !== 'RIFF') {
|
|
9
|
-
throw new Error('Not a RIFF file');
|
|
10
|
-
}
|
|
11
|
-
const structure = state.structure.getStructure();
|
|
12
|
-
if (structure.type !== 'riff') {
|
|
13
|
-
throw new Error('Structure is not a RIFF structure');
|
|
14
|
-
}
|
|
15
|
-
const size = iterator.getUint32Le();
|
|
16
|
-
const fileType = iterator.getByteString(4, false);
|
|
17
|
-
if (fileType !== 'WAVE' && fileType !== 'AVI') {
|
|
18
|
-
throw new Error(`File type ${fileType} not supported`);
|
|
19
|
-
}
|
|
20
|
-
structure.boxes.push({ type: 'riff-header', fileSize: size, fileType });
|
|
21
|
-
if ((0, has_all_info_1.hasAllInfo)({ fields, state })) {
|
|
22
|
-
return Promise.resolve({
|
|
23
|
-
status: 'done',
|
|
24
|
-
segments: structure,
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
return (0, parse_riff_body_1.parseRiffBody)({
|
|
28
|
-
iterator,
|
|
29
|
-
maxOffset: Infinity,
|
|
30
|
-
state,
|
|
31
|
-
structure,
|
|
32
|
-
fields,
|
|
33
|
-
});
|
|
34
|
-
};
|
|
35
|
-
exports.parseRiff = parseRiff;
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseFmtBox = void 0;
|
|
4
|
-
const parseFmtBox = ({ iterator, boxes, size, }) => {
|
|
5
|
-
const box = iterator.startBox(size);
|
|
6
|
-
const header = boxes.find((b) => b.type === 'riff-header');
|
|
7
|
-
if (!header) {
|
|
8
|
-
throw new Error('Expected RIFF header');
|
|
9
|
-
}
|
|
10
|
-
if (header.fileType !== 'WAVE') {
|
|
11
|
-
throw new Error('Only supporting WAVE type');
|
|
12
|
-
}
|
|
13
|
-
const wFormatTag = iterator.getUint16Le();
|
|
14
|
-
if (wFormatTag !== 1) {
|
|
15
|
-
throw new Error('Expected wFormatTag to be 1, only supporting this');
|
|
16
|
-
}
|
|
17
|
-
const numberOfChannels = iterator.getUint16Le();
|
|
18
|
-
const sampleRate = iterator.getUint32Le();
|
|
19
|
-
const byteRate = iterator.getUint32Le();
|
|
20
|
-
const blockAlign = iterator.getUint16Le();
|
|
21
|
-
const bitsPerSample = iterator.getUint16Le();
|
|
22
|
-
box.expectNoMoreBytes();
|
|
23
|
-
return {
|
|
24
|
-
type: 'wave-format-box',
|
|
25
|
-
formatTag: wFormatTag,
|
|
26
|
-
numberOfChannels,
|
|
27
|
-
sampleRate,
|
|
28
|
-
blockAlign,
|
|
29
|
-
byteRate,
|
|
30
|
-
bitsPerSample,
|
|
31
|
-
};
|
|
32
|
-
};
|
|
33
|
-
exports.parseFmtBox = parseFmtBox;
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { Options, ParseMediaFields } from '../../options';
|
|
3
|
-
import type { ParserState } from '../../state/parser-state';
|
|
4
|
-
import type { RiffBox } from './riff-box';
|
|
5
|
-
export declare const parseListBox: ({ iterator, size, state, fields, }: {
|
|
6
|
-
iterator: BufferIterator;
|
|
7
|
-
size: number;
|
|
8
|
-
state: ParserState;
|
|
9
|
-
fields: Options<ParseMediaFields>;
|
|
10
|
-
}) => Promise<RiffBox>;
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseListBox = void 0;
|
|
4
|
-
const parse_riff_body_1 = require("./parse-riff-body");
|
|
5
|
-
const parseListBox = async ({ iterator, size, state, fields, }) => {
|
|
6
|
-
const counter = iterator.counter.getOffset();
|
|
7
|
-
const listType = iterator.getByteString(4, false);
|
|
8
|
-
if (listType === 'movi') {
|
|
9
|
-
throw new Error('should not be handled here');
|
|
10
|
-
}
|
|
11
|
-
const structure = {
|
|
12
|
-
type: 'riff',
|
|
13
|
-
boxes: [],
|
|
14
|
-
};
|
|
15
|
-
const result = await (0, parse_riff_body_1.parseRiffBody)({
|
|
16
|
-
structure,
|
|
17
|
-
iterator,
|
|
18
|
-
maxOffset: counter + size,
|
|
19
|
-
state,
|
|
20
|
-
fields,
|
|
21
|
-
});
|
|
22
|
-
if (result.status === 'incomplete') {
|
|
23
|
-
throw new Error(`Should only parse complete boxes (${listType})`);
|
|
24
|
-
}
|
|
25
|
-
return {
|
|
26
|
-
type: 'list-box',
|
|
27
|
-
listType,
|
|
28
|
-
children: structure.boxes,
|
|
29
|
-
};
|
|
30
|
-
};
|
|
31
|
-
exports.parseListBox = parseListBox;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { RiffStructure } from '../../parse-result';
|
|
3
|
-
import type { ParserState } from '../../state/parser-state';
|
|
4
|
-
import type { RiffResult } from './expect-riff-box';
|
|
5
|
-
export declare const handleChunk: ({ iterator, state, structure, ckId, ckSize, }: {
|
|
6
|
-
iterator: BufferIterator;
|
|
7
|
-
state: ParserState;
|
|
8
|
-
structure: RiffStructure;
|
|
9
|
-
ckId: string;
|
|
10
|
-
ckSize: number;
|
|
11
|
-
}) => Promise<void>;
|
|
12
|
-
export declare const parseMovi: ({ iterator, maxOffset, state, structure, }: {
|
|
13
|
-
iterator: BufferIterator;
|
|
14
|
-
maxOffset: number;
|
|
15
|
-
state: ParserState;
|
|
16
|
-
structure: RiffStructure;
|
|
17
|
-
}) => Promise<RiffResult>;
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { Options, ParseMediaFields } from '../../options';
|
|
3
|
-
import type { ParseResult, RiffStructure } from '../../parse-result';
|
|
4
|
-
import type { ParserState } from '../../state/parser-state';
|
|
5
|
-
export declare const parseRiffBody: ({ iterator, structure, maxOffset, state, fields, }: {
|
|
6
|
-
iterator: BufferIterator;
|
|
7
|
-
structure: RiffStructure;
|
|
8
|
-
maxOffset: number;
|
|
9
|
-
state: ParserState;
|
|
10
|
-
fields: Options<ParseMediaFields>;
|
|
11
|
-
}) => Promise<ParseResult>;
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseRiffBody = void 0;
|
|
4
|
-
const get_tracks_1 = require("../../get-tracks");
|
|
5
|
-
const has_all_info_1 = require("../../has-all-info");
|
|
6
|
-
const register_track_1 = require("../../register-track");
|
|
7
|
-
const continue_after_riff_result_1 = require("./continue-after-riff-result");
|
|
8
|
-
const expect_riff_box_1 = require("./expect-riff-box");
|
|
9
|
-
const get_tracks_from_avi_1 = require("./get-tracks-from-avi");
|
|
10
|
-
const traversal_1 = require("./traversal");
|
|
11
|
-
const parseRiffBody = async ({ iterator, structure, maxOffset, state, fields, }) => {
|
|
12
|
-
while (iterator.bytesRemaining() > 0 &&
|
|
13
|
-
iterator.counter.getOffset() < maxOffset &&
|
|
14
|
-
!(0, has_all_info_1.hasAllInfo)({ fields, state })) {
|
|
15
|
-
const result = await (0, expect_riff_box_1.expectRiffBox)({
|
|
16
|
-
iterator,
|
|
17
|
-
state,
|
|
18
|
-
structure,
|
|
19
|
-
fields,
|
|
20
|
-
});
|
|
21
|
-
if (result.type === 'complete' && result.skipTo !== null) {
|
|
22
|
-
return {
|
|
23
|
-
status: 'incomplete',
|
|
24
|
-
skipTo: result.skipTo,
|
|
25
|
-
continueParsing() {
|
|
26
|
-
return Promise.resolve((0, continue_after_riff_result_1.continueAfterRiffBoxResult)({
|
|
27
|
-
iterator,
|
|
28
|
-
maxOffset,
|
|
29
|
-
state,
|
|
30
|
-
result,
|
|
31
|
-
structure,
|
|
32
|
-
fields,
|
|
33
|
-
}));
|
|
34
|
-
},
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
if (result.type === 'incomplete') {
|
|
38
|
-
return {
|
|
39
|
-
status: 'incomplete',
|
|
40
|
-
async continueParsing() {
|
|
41
|
-
return Promise.resolve((0, continue_after_riff_result_1.continueAfterRiffBoxResult)({
|
|
42
|
-
iterator,
|
|
43
|
-
maxOffset,
|
|
44
|
-
state,
|
|
45
|
-
result: await result.continueParsing(),
|
|
46
|
-
structure,
|
|
47
|
-
fields,
|
|
48
|
-
}));
|
|
49
|
-
},
|
|
50
|
-
skipTo: null,
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
if (result.box === null) {
|
|
54
|
-
continue;
|
|
55
|
-
}
|
|
56
|
-
structure.boxes.push(result.box);
|
|
57
|
-
// When parsing an AVI
|
|
58
|
-
if (result.box.type === 'list-box' && result.box.listType === 'hdrl') {
|
|
59
|
-
const tracks = (0, get_tracks_1.getTracks)(structure, state);
|
|
60
|
-
if (!tracks.videoTracks.some((t) => t.codec === get_tracks_from_avi_1.TO_BE_OVERRIDDEN_LATER)) {
|
|
61
|
-
state.callbacks.tracks.setIsDone();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
// When parsing a WAV
|
|
65
|
-
if (result.box.type === 'wave-format-box') {
|
|
66
|
-
state.callbacks.tracks.setIsDone();
|
|
67
|
-
}
|
|
68
|
-
if (result.box.type === 'strf-box-video' ||
|
|
69
|
-
result.box.type === 'strf-box-audio') {
|
|
70
|
-
const strh = (0, traversal_1.getStrhBox)(structure.boxes);
|
|
71
|
-
const strf = (0, traversal_1.getStrfBox)(structure.boxes);
|
|
72
|
-
if (!strh || !strf) {
|
|
73
|
-
throw new Error('strh or strf box missing');
|
|
74
|
-
}
|
|
75
|
-
if (strf.type === 'strf-box-audio' && state.onAudioTrack) {
|
|
76
|
-
const audioTrack = (0, get_tracks_from_avi_1.makeAviAudioTrack)({
|
|
77
|
-
index: state.riff.getNextTrackIndex(),
|
|
78
|
-
strf,
|
|
79
|
-
});
|
|
80
|
-
await (0, register_track_1.registerTrack)({
|
|
81
|
-
state,
|
|
82
|
-
track: audioTrack,
|
|
83
|
-
container: 'avi',
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
if (state.onVideoTrack && strf.type === 'strf-box-video') {
|
|
87
|
-
const videoTrack = (0, get_tracks_from_avi_1.makeAviVideoTrack)({
|
|
88
|
-
strh,
|
|
89
|
-
index: state.riff.getNextTrackIndex(),
|
|
90
|
-
strf,
|
|
91
|
-
});
|
|
92
|
-
(0, register_track_1.registerVideoTrackWhenProfileIsAvailable)({
|
|
93
|
-
state,
|
|
94
|
-
track: videoTrack,
|
|
95
|
-
container: 'avi',
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
state.riff.incrementNextTrackIndex();
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
return {
|
|
102
|
-
status: 'done',
|
|
103
|
-
};
|
|
104
|
-
};
|
|
105
|
-
exports.parseRiffBody = parseRiffBody;
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { Options, ParseMediaFields } from '../../options';
|
|
3
|
-
import type { ParserState } from '../../state/parser-state';
|
|
4
|
-
import type { RiffBox } from './riff-box';
|
|
5
|
-
export declare const parseRiffBox: ({ iterator, size, id, boxes, state, fields, }: {
|
|
6
|
-
iterator: BufferIterator;
|
|
7
|
-
size: number;
|
|
8
|
-
id: string;
|
|
9
|
-
boxes: RiffBox[];
|
|
10
|
-
state: ParserState;
|
|
11
|
-
fields: Options<ParseMediaFields>;
|
|
12
|
-
}) => Promise<RiffBox>;
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import type { TransportStreamStructure } from '../../parse-result';
|
|
2
|
-
import type { ParserState } from '../../state/parser-state';
|
|
3
|
-
import type { AllTracks } from '../riff/get-tracks-from-avi';
|
|
4
|
-
export declare const getTracksFromTransportStream: (structure: TransportStreamStructure, parserState: ParserState) => AllTracks;
|
|
5
|
-
export declare const hasAllTracksFromTransportStream: (structure: TransportStreamStructure, parserState: ParserState) => boolean;
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { TransportStreamStructure } from '../../parse-result';
|
|
3
|
-
import type { ParserState } from '../../state/parser-state';
|
|
4
|
-
import type { TransportStreamBox } from './boxes';
|
|
5
|
-
import type { NextPesHeaderStore } from './next-pes-header-store';
|
|
6
|
-
import { type StreamBufferMap } from './process-stream-buffers';
|
|
7
|
-
export declare const parsePacket: ({ iterator, structure, streamBuffers, parserState, nextPesHeaderStore, }: {
|
|
8
|
-
iterator: BufferIterator;
|
|
9
|
-
structure: TransportStreamStructure;
|
|
10
|
-
streamBuffers: StreamBufferMap;
|
|
11
|
-
parserState: ParserState;
|
|
12
|
-
nextPesHeaderStore: NextPesHeaderStore;
|
|
13
|
-
}) => Promise<TransportStreamBox | null>;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { TransportStreamStructure } from '../../parse-result';
|
|
3
|
-
import type { ParserState } from '../../state/parser-state';
|
|
4
|
-
import type { PacketPes } from './parse-pes';
|
|
5
|
-
import type { TransportStreamEntry } from './parse-pmt';
|
|
6
|
-
import { type StreamBufferMap } from './process-stream-buffers';
|
|
7
|
-
export declare const parseStream: ({ iterator, transportStreamEntry, streamBuffers, state, programId, structure, nextPesHeader, }: {
|
|
8
|
-
iterator: BufferIterator;
|
|
9
|
-
transportStreamEntry: TransportStreamEntry;
|
|
10
|
-
streamBuffers: StreamBufferMap;
|
|
11
|
-
state: ParserState;
|
|
12
|
-
programId: number;
|
|
13
|
-
structure: TransportStreamStructure;
|
|
14
|
-
nextPesHeader: PacketPes;
|
|
15
|
-
}) => Promise<void>;
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { Options, ParseMediaFields } from '../../options';
|
|
3
|
-
import type { ParseResult } from '../../parse-result';
|
|
4
|
-
import type { ParserState } from '../../state/parser-state';
|
|
5
|
-
import type { NextPesHeaderStore } from './next-pes-header-store';
|
|
6
|
-
import { type StreamBufferMap } from './process-stream-buffers';
|
|
7
|
-
export declare const parseTransportStream: ({ iterator, state, streamBuffers, fields, nextPesHeaderStore, }: {
|
|
8
|
-
iterator: BufferIterator;
|
|
9
|
-
state: ParserState;
|
|
10
|
-
streamBuffers: StreamBufferMap;
|
|
11
|
-
fields: Options<ParseMediaFields>;
|
|
12
|
-
nextPesHeaderStore: NextPesHeaderStore;
|
|
13
|
-
}) => Promise<ParseResult>;
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseWebm = void 0;
|
|
4
|
-
const parse_children_1 = require("./segments/parse-children");
|
|
5
|
-
const continueAfterMatroskaResult = (result, structure) => {
|
|
6
|
-
if (result.status === 'done') {
|
|
7
|
-
return {
|
|
8
|
-
status: 'done',
|
|
9
|
-
};
|
|
10
|
-
}
|
|
11
|
-
return {
|
|
12
|
-
status: 'incomplete',
|
|
13
|
-
continueParsing: async () => {
|
|
14
|
-
const newResult = await result.continueParsing();
|
|
15
|
-
return continueAfterMatroskaResult(newResult, structure);
|
|
16
|
-
},
|
|
17
|
-
skipTo: null,
|
|
18
|
-
};
|
|
19
|
-
};
|
|
20
|
-
// Parsing according to https://darkcoding.net/software/reading-mediarecorders-webm-opus-output/
|
|
21
|
-
const parseWebm = async ({ counter, state, fields, }) => {
|
|
22
|
-
const structure = state.structure.getStructure();
|
|
23
|
-
if (structure.type !== 'matroska') {
|
|
24
|
-
throw new Error('Invalid structure type');
|
|
25
|
-
}
|
|
26
|
-
const results = await (0, parse_children_1.expectChildren)({
|
|
27
|
-
iterator: counter,
|
|
28
|
-
length: Infinity,
|
|
29
|
-
children: structure.boxes,
|
|
30
|
-
state,
|
|
31
|
-
startOffset: counter.counter.getOffset(),
|
|
32
|
-
fields,
|
|
33
|
-
topLevelStructure: structure,
|
|
34
|
-
});
|
|
35
|
-
return continueAfterMatroskaResult(results, structure);
|
|
36
|
-
};
|
|
37
|
-
exports.parseWebm = parseWebm;
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../../buffer-iterator';
|
|
2
|
-
import type { Options, ParseMediaFields } from '../../../options';
|
|
3
|
-
import type { ExpectSegmentParseResult, MatroskaParseResult, MatroskaStructure } from '../../../parse-result';
|
|
4
|
-
import type { ParserState } from '../../../state/parser-state';
|
|
5
|
-
import type { MatroskaSegment } from '../segments';
|
|
6
|
-
import type { PossibleEbml } from './all-segments';
|
|
7
|
-
export declare const expectAndProcessSegment: ({ iterator, state, offset, children, fields, topLevelStructure, }: {
|
|
8
|
-
iterator: BufferIterator;
|
|
9
|
-
state: ParserState;
|
|
10
|
-
offset: number;
|
|
11
|
-
children: PossibleEbml[];
|
|
12
|
-
fields: Options<ParseMediaFields>;
|
|
13
|
-
topLevelStructure: MatroskaStructure;
|
|
14
|
-
}) => Promise<ExpectSegmentParseResult>;
|
|
15
|
-
export declare const expectChildren: ({ iterator, length, children, state, startOffset, fields, topLevelStructure, }: {
|
|
16
|
-
iterator: BufferIterator;
|
|
17
|
-
length: number;
|
|
18
|
-
children: MatroskaSegment[];
|
|
19
|
-
state: ParserState;
|
|
20
|
-
startOffset: number;
|
|
21
|
-
fields: Options<ParseMediaFields>;
|
|
22
|
-
topLevelStructure: MatroskaStructure;
|
|
23
|
-
}) => Promise<MatroskaParseResult>;
|
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.expectChildren = exports.expectAndProcessSegment = void 0;
|
|
4
|
-
const has_all_info_1 = require("../../../has-all-info");
|
|
5
|
-
const segments_1 = require("../segments");
|
|
6
|
-
const processParseResult = ({ parseResult, children, state, fields, topLevelStructure, }) => {
|
|
7
|
-
if (parseResult.segment && !children.includes(parseResult.segment)) {
|
|
8
|
-
children.push(parseResult.segment);
|
|
9
|
-
if ((0, has_all_info_1.hasAllInfo)({ fields, state })) {
|
|
10
|
-
return {
|
|
11
|
-
status: 'done',
|
|
12
|
-
segment: parseResult.segment,
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
if (parseResult.segment.type === 'Tracks') {
|
|
16
|
-
state.callbacks.tracks.setIsDone();
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
if (parseResult.status === 'incomplete') {
|
|
20
|
-
// No need to decrement because expectSegment already does it
|
|
21
|
-
return {
|
|
22
|
-
status: 'incomplete',
|
|
23
|
-
segment: parseResult.segment,
|
|
24
|
-
continueParsing: async () => {
|
|
25
|
-
const newParseResult = await parseResult.continueParsing();
|
|
26
|
-
return processParseResult({
|
|
27
|
-
children,
|
|
28
|
-
parseResult: newParseResult,
|
|
29
|
-
state,
|
|
30
|
-
fields,
|
|
31
|
-
topLevelStructure,
|
|
32
|
-
});
|
|
33
|
-
},
|
|
34
|
-
};
|
|
35
|
-
}
|
|
36
|
-
return {
|
|
37
|
-
status: 'done',
|
|
38
|
-
segment: parseResult.segment,
|
|
39
|
-
};
|
|
40
|
-
};
|
|
41
|
-
const expectAndProcessSegment = async ({ iterator, state, offset, children, fields, topLevelStructure, }) => {
|
|
42
|
-
const segment = await (0, segments_1.expectSegment)({
|
|
43
|
-
iterator,
|
|
44
|
-
state,
|
|
45
|
-
offset,
|
|
46
|
-
children,
|
|
47
|
-
fields,
|
|
48
|
-
topLevelStructure,
|
|
49
|
-
});
|
|
50
|
-
return processParseResult({
|
|
51
|
-
children,
|
|
52
|
-
parseResult: segment,
|
|
53
|
-
state,
|
|
54
|
-
fields,
|
|
55
|
-
topLevelStructure,
|
|
56
|
-
});
|
|
57
|
-
};
|
|
58
|
-
exports.expectAndProcessSegment = expectAndProcessSegment;
|
|
59
|
-
const continueAfterSegmentResult = async ({ result, length, children, state, iterator, startOffset, fields, topLevelStructure, }) => {
|
|
60
|
-
if (result.status === 'done') {
|
|
61
|
-
throw new Error('Should not continue after done');
|
|
62
|
-
}
|
|
63
|
-
const segmentResult = await result.continueParsing();
|
|
64
|
-
if (segmentResult.status === 'done') {
|
|
65
|
-
return {
|
|
66
|
-
status: 'incomplete',
|
|
67
|
-
continueParsing: () => {
|
|
68
|
-
// eslint-disable-next-line @typescript-eslint/no-use-before-define
|
|
69
|
-
return (0, exports.expectChildren)({
|
|
70
|
-
children,
|
|
71
|
-
iterator,
|
|
72
|
-
length,
|
|
73
|
-
state,
|
|
74
|
-
startOffset,
|
|
75
|
-
fields,
|
|
76
|
-
topLevelStructure,
|
|
77
|
-
});
|
|
78
|
-
},
|
|
79
|
-
skipTo: null,
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
return {
|
|
83
|
-
status: 'incomplete',
|
|
84
|
-
continueParsing: () => {
|
|
85
|
-
return continueAfterSegmentResult({
|
|
86
|
-
result: segmentResult,
|
|
87
|
-
children,
|
|
88
|
-
iterator,
|
|
89
|
-
length,
|
|
90
|
-
state,
|
|
91
|
-
startOffset,
|
|
92
|
-
fields,
|
|
93
|
-
topLevelStructure,
|
|
94
|
-
});
|
|
95
|
-
},
|
|
96
|
-
skipTo: null,
|
|
97
|
-
};
|
|
98
|
-
};
|
|
99
|
-
const expectChildren = async ({ iterator, length, children, state, startOffset, fields, topLevelStructure, }) => {
|
|
100
|
-
while (iterator.counter.getOffset() < startOffset + length) {
|
|
101
|
-
if (iterator.bytesRemaining() === 0) {
|
|
102
|
-
break;
|
|
103
|
-
}
|
|
104
|
-
const currentOffset = iterator.counter.getOffset();
|
|
105
|
-
const child = await (0, exports.expectAndProcessSegment)({
|
|
106
|
-
iterator,
|
|
107
|
-
state,
|
|
108
|
-
offset: currentOffset,
|
|
109
|
-
children,
|
|
110
|
-
fields,
|
|
111
|
-
topLevelStructure,
|
|
112
|
-
});
|
|
113
|
-
if ((0, has_all_info_1.hasAllInfo)({
|
|
114
|
-
fields,
|
|
115
|
-
state,
|
|
116
|
-
})) {
|
|
117
|
-
return {
|
|
118
|
-
status: 'done',
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
if (child.status === 'incomplete') {
|
|
122
|
-
return {
|
|
123
|
-
status: 'incomplete',
|
|
124
|
-
continueParsing: () => {
|
|
125
|
-
return continueAfterSegmentResult({
|
|
126
|
-
result: child,
|
|
127
|
-
children,
|
|
128
|
-
iterator,
|
|
129
|
-
length: length - (currentOffset - startOffset),
|
|
130
|
-
state,
|
|
131
|
-
startOffset: currentOffset,
|
|
132
|
-
fields,
|
|
133
|
-
topLevelStructure,
|
|
134
|
-
});
|
|
135
|
-
},
|
|
136
|
-
skipTo: null,
|
|
137
|
-
};
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
return {
|
|
141
|
-
status: 'done',
|
|
142
|
-
};
|
|
143
|
-
};
|
|
144
|
-
exports.expectChildren = expectChildren;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import type { BufferIterator } from '../../buffer-iterator';
|
|
2
|
-
import type { Options, ParseMediaFields } from '../../options';
|
|
3
|
-
import type { ExpectSegmentParseResult, MatroskaStructure } from '../../parse-result';
|
|
4
|
-
import type { ParserState } from '../../state/parser-state';
|
|
5
|
-
import { type PossibleEbml, type TrackEntry } from './segments/all-segments';
|
|
6
|
-
export type MatroskaSegment = PossibleEbml;
|
|
7
|
-
export type OnTrackEntrySegment = (trackEntry: TrackEntry) => void;
|
|
8
|
-
export declare const expectSegment: ({ iterator, state, offset, children, fields, topLevelStructure, }: {
|
|
9
|
-
iterator: BufferIterator;
|
|
10
|
-
state: ParserState;
|
|
11
|
-
offset: number;
|
|
12
|
-
children: PossibleEbml[];
|
|
13
|
-
fields: Options<ParseMediaFields>;
|
|
14
|
-
topLevelStructure: MatroskaStructure;
|
|
15
|
-
}) => Promise<ExpectSegmentParseResult>;
|