@remotion/media-parser 4.0.213 → 4.0.215

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.
Files changed (98) hide show
  1. package/dist/boxes/webm/ebml.d.ts +1 -1
  2. package/dist/boxes/webm/make-header.js +2 -2
  3. package/dist/boxes/webm/segments/block-simple-block-flags.d.ts +1 -1
  4. package/dist/esm/from-node.mjs +3 -3
  5. package/dist/esm/index.mjs +51 -51
  6. package/dist/readers/from-fetch.js +2 -2
  7. package/dist/truthy.js +1 -2
  8. package/package.json +3 -3
  9. package/dist/av1-codec-string.d.ts +0 -3
  10. package/dist/av1-codec-string.js +0 -91
  11. package/dist/boxes/iso-base-media/ftype.d.ts +0 -9
  12. package/dist/boxes/iso-base-media/ftype.js +0 -31
  13. package/dist/boxes/iso-base-media/stsd/avcc-hvcc.d.ts +0 -20
  14. package/dist/boxes/iso-base-media/stsd/avcc-hvcc.js +0 -73
  15. package/dist/boxes/iso-base-media/stts/stts.d.ts +0 -15
  16. package/dist/boxes/iso-base-media/stts/stts.js +0 -35
  17. package/dist/boxes/webm/bitstream/av1/bitstream-frame-header.d.ts +0 -14
  18. package/dist/boxes/webm/bitstream/av1/bitstream-frame-header.js +0 -67
  19. package/dist/boxes/webm/bitstream/av1/bitstream-frame.d.ts +0 -11
  20. package/dist/boxes/webm/bitstream/av1/bitstream-frame.js +0 -14
  21. package/dist/boxes/webm/bitstream/av1/chroma-sample-position.d.ts +0 -6
  22. package/dist/boxes/webm/bitstream/av1/chroma-sample-position.js +0 -9
  23. package/dist/boxes/webm/bitstream/av1/color-config.d.ts +0 -16
  24. package/dist/boxes/webm/bitstream/av1/color-config.js +0 -103
  25. package/dist/boxes/webm/bitstream/av1/color-primaries.d.ts +0 -14
  26. package/dist/boxes/webm/bitstream/av1/color-primaries.js +0 -17
  27. package/dist/boxes/webm/bitstream/av1/decoder-model-info.d.ts +0 -9
  28. package/dist/boxes/webm/bitstream/av1/decoder-model-info.js +0 -17
  29. package/dist/boxes/webm/bitstream/av1/frame.d.ts +0 -0
  30. package/dist/boxes/webm/bitstream/av1/frame.js +0 -1
  31. package/dist/boxes/webm/bitstream/av1/header-segment.d.ts +0 -51
  32. package/dist/boxes/webm/bitstream/av1/header-segment.js +0 -183
  33. package/dist/boxes/webm/bitstream/av1/matrix-coefficients.d.ts +0 -17
  34. package/dist/boxes/webm/bitstream/av1/matrix-coefficients.js +0 -20
  35. package/dist/boxes/webm/bitstream/av1/operating-parameters-info.d.ts +0 -10
  36. package/dist/boxes/webm/bitstream/av1/operating-parameters-info.js +0 -15
  37. package/dist/boxes/webm/bitstream/av1/temporal-point-info.d.ts +0 -5
  38. package/dist/boxes/webm/bitstream/av1/temporal-point-info.js +0 -8
  39. package/dist/boxes/webm/bitstream/av1/timing-info.d.ts +0 -8
  40. package/dist/boxes/webm/bitstream/av1/timing-info.js +0 -20
  41. package/dist/boxes/webm/bitstream/av1/transfer-characteristics.d.ts +0 -21
  42. package/dist/boxes/webm/bitstream/av1/transfer-characteristics.js +0 -24
  43. package/dist/boxes/webm/bitstream/av1/uvlc.d.ts +0 -2
  44. package/dist/boxes/webm/bitstream/av1/uvlc.js +0 -20
  45. package/dist/boxes/webm/bitstream/av1.d.ts +0 -20
  46. package/dist/boxes/webm/bitstream/av1.js +0 -118
  47. package/dist/boxes/webm/bitstream/h264/get-h264-descriptor.d.ts +0 -0
  48. package/dist/boxes/webm/bitstream/h264/get-h264-descriptor.js +0 -1
  49. package/dist/boxes/webm/get-track.d.ts +0 -6
  50. package/dist/boxes/webm/get-track.js +0 -184
  51. package/dist/boxes/webm/segments/duration.d.ts +0 -6
  52. package/dist/boxes/webm/segments/duration.js +0 -19
  53. package/dist/boxes/webm/segments/info.d.ts +0 -9
  54. package/dist/boxes/webm/segments/info.js +0 -22
  55. package/dist/boxes/webm/segments/main.d.ts +0 -5
  56. package/dist/boxes/webm/segments/main.js +0 -2
  57. package/dist/boxes/webm/segments/muxing.d.ts +0 -6
  58. package/dist/boxes/webm/segments/muxing.js +0 -11
  59. package/dist/boxes/webm/segments/seek-head.d.ts +0 -9
  60. package/dist/boxes/webm/segments/seek-head.js +0 -22
  61. package/dist/boxes/webm/segments/seek-position.d.ts +0 -6
  62. package/dist/boxes/webm/segments/seek-position.js +0 -11
  63. package/dist/boxes/webm/segments/seek.d.ts +0 -13
  64. package/dist/boxes/webm/segments/seek.js +0 -35
  65. package/dist/boxes/webm/segments/timestamp-scale.d.ts +0 -6
  66. package/dist/boxes/webm/segments/timestamp-scale.js +0 -11
  67. package/dist/boxes/webm/segments/tracks.d.ts +0 -8
  68. package/dist/boxes/webm/segments/tracks.js +0 -21
  69. package/dist/boxes/webm/segments/unknown.d.ts +0 -6
  70. package/dist/boxes/webm/segments/unknown.js +0 -11
  71. package/dist/boxes/webm/segments/void.d.ts +0 -6
  72. package/dist/boxes/webm/segments/void.js +0 -11
  73. package/dist/boxes/webm/segments/writing.d.ts +0 -6
  74. package/dist/boxes/webm/segments/writing.js +0 -11
  75. package/dist/boxes/webm/tracks.d.ts +0 -8
  76. package/dist/boxes/webm/tracks.js +0 -21
  77. package/dist/combine-uint8array.d.ts +0 -1
  78. package/dist/combine-uint8array.js +0 -13
  79. package/dist/create/cues.d.ts +0 -0
  80. package/dist/create/cues.js +0 -1
  81. package/dist/from-fetch.d.ts +0 -2
  82. package/dist/from-fetch.js +0 -64
  83. package/dist/from-node.d.ts +0 -2
  84. package/dist/from-node.js +0 -40
  85. package/dist/from-web-file.d.ts +0 -2
  86. package/dist/from-web-file.js +0 -39
  87. package/dist/from-web.d.ts +0 -2
  88. package/dist/from-web.js +0 -45
  89. package/dist/get-video-metadata.d.ts +0 -2
  90. package/dist/get-video-metadata.js +0 -44
  91. package/dist/read-and-increment-offset.d.ts +0 -28
  92. package/dist/read-and-increment-offset.js +0 -177
  93. package/dist/reader.d.ts +0 -11
  94. package/dist/reader.js +0 -2
  95. package/dist/traversal.d.ts +0 -65
  96. package/dist/traversal.js +0 -368
  97. package/dist/understand-vorbis.d.ts +0 -1
  98. package/dist/understand-vorbis.js +0 -12
@@ -1,8 +0,0 @@
1
- import type { BufferIterator } from '../../../../buffer-iterator';
2
- export type TimingInfo = {
3
- num_units_in_display_tick: number;
4
- time_scale: number;
5
- equal_picture_interval: boolean;
6
- num_ticks_per_picture_minus_1: number;
7
- };
8
- export declare const getTimingInfo: (stream: BufferIterator) => TimingInfo;
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getTimingInfo = void 0;
4
- const uvlc_1 = require("./uvlc");
5
- const getTimingInfo = (stream) => {
6
- const num_units_in_display_tick = stream.getBits(32);
7
- const time_scale = stream.getBits(32);
8
- const equal_picture_interval = Boolean(stream.getBits(1));
9
- let num_ticks_per_picture_minus_1 = 0;
10
- if (equal_picture_interval) {
11
- num_ticks_per_picture_minus_1 = (0, uvlc_1.uvlc)(stream);
12
- }
13
- return {
14
- num_units_in_display_tick,
15
- time_scale,
16
- equal_picture_interval,
17
- num_ticks_per_picture_minus_1,
18
- };
19
- };
20
- exports.getTimingInfo = getTimingInfo;
@@ -1,21 +0,0 @@
1
- export declare const transferCharacteristics: {
2
- TC_RESERVED_0: number;
3
- TC_BT_709: number;
4
- TC_UNSPECIFIED: number;
5
- TC_RESERVED_3: number;
6
- TC_BT_470_M: number;
7
- TC_BT_470_B_G: number;
8
- TC_BT_601: number;
9
- TC_SMPTE_240: number;
10
- TC_LINEAR: number;
11
- TC_LOG_100: number;
12
- TC_LOG_100_SQRT10: number;
13
- TC_IEC_61966: number;
14
- TC_BT_1361: number;
15
- TC_SRGB: number;
16
- TC_BT_2020_10_BIT: number;
17
- TC_BT_2020_12_BIT: number;
18
- TC_SMPTE_2084: number;
19
- TC_SMPTE_428: number;
20
- TC_HLG: number;
21
- };
@@ -1,24 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.transferCharacteristics = void 0;
4
- exports.transferCharacteristics = {
5
- TC_RESERVED_0: 0,
6
- TC_BT_709: 1,
7
- TC_UNSPECIFIED: 2,
8
- TC_RESERVED_3: 3,
9
- TC_BT_470_M: 4,
10
- TC_BT_470_B_G: 5,
11
- TC_BT_601: 6,
12
- TC_SMPTE_240: 7,
13
- TC_LINEAR: 8,
14
- TC_LOG_100: 9,
15
- TC_LOG_100_SQRT10: 10,
16
- TC_IEC_61966: 11,
17
- TC_BT_1361: 12,
18
- TC_SRGB: 13,
19
- TC_BT_2020_10_BIT: 14,
20
- TC_BT_2020_12_BIT: 15,
21
- TC_SMPTE_2084: 16,
22
- TC_SMPTE_428: 17,
23
- TC_HLG: 18,
24
- };
@@ -1,2 +0,0 @@
1
- import type { BufferIterator } from '../../../../buffer-iterator';
2
- export declare const uvlc: (stream: BufferIterator) => number;
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.uvlc = void 0;
4
- const uvlc = (stream) => {
5
- let leadingZeroBits = 0;
6
- // eslint-disable-next-line no-constant-condition
7
- while (true) {
8
- const done = stream.getBits(1);
9
- if (done) {
10
- break;
11
- }
12
- leadingZeroBits++;
13
- }
14
- if (leadingZeroBits >= 32) {
15
- return (1 << 32) - 1;
16
- }
17
- const value = stream.getBits(leadingZeroBits);
18
- return value + (1 << leadingZeroBits) - 1;
19
- };
20
- exports.uvlc = uvlc;
@@ -1,20 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- import type { ParserContext } from '../../../parser-context';
3
- import type { VideoSample } from '../../../webcodec-sample-types';
4
- import { type Av1BitstreamHeaderSegment } from './av1/header-segment';
5
- type Av1BitstreamUimplementedSegment = {
6
- type: 'av1-bitstream-unimplemented';
7
- };
8
- export type Av1BitstreamSegment = Av1BitstreamHeaderSegment | Av1BitstreamUimplementedSegment;
9
- export declare const av1Bitstream: ({ stream, length, onVideoSample, trackNumber, context, timecode, }: {
10
- stream: BufferIterator;
11
- length: number;
12
- onVideoSample: (trackId: number, sample: VideoSample) => void;
13
- trackNumber: number;
14
- context: ParserContext;
15
- timecode: number;
16
- }) => {
17
- discarded: boolean;
18
- segment: Av1BitstreamSegment;
19
- };
20
- export {};
@@ -1,118 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.av1Bitstream = void 0;
4
- const combine_uint8array_1 = require("../../../combine-uint8array");
5
- const bitstream_frame_1 = require("./av1/bitstream-frame");
6
- const header_segment_1 = require("./av1/header-segment");
7
- const av1Bitstream = ({ stream, length, onVideoSample, trackNumber, context, timecode, }) => {
8
- var _a, _b;
9
- const address = stream.counter.getOffset();
10
- stream.startReadingBits();
11
- // log this to understand:
12
- // (firstByte.toString(2).padStart(8, '0'));
13
- // get bit 0
14
- const obuForbiddenBit = stream.getBits(1);
15
- if (obuForbiddenBit) {
16
- throw new Error('obuForbiddenBit is not 0');
17
- }
18
- // get bits 1-3
19
- const obuType = stream.getBits(4);
20
- // get bit 4
21
- const obuExtensionFlag = stream.getBits(1);
22
- // get bit 5
23
- const obuHasSizeField = stream.getBits(1);
24
- // reserved bit
25
- stream.getBits(1);
26
- let size = null;
27
- if (obuExtensionFlag) {
28
- // extension
29
- stream.getBits(6);
30
- }
31
- if (obuHasSizeField) {
32
- // size
33
- size = stream.leb128();
34
- }
35
- /*
36
- console.log(
37
- address.toString(16),
38
- firstByte.toString(2).padStart(8, '0'),
39
- obuForbiddenBit,
40
- obuType,
41
- obuExtensionFlag,
42
- obuHasSizeField,
43
- reservedBit,
44
- size,
45
- );
46
- */
47
- const bytesReadSoFar = stream.counter.getOffset() - address;
48
- const segment = obuType === 1
49
- ? (0, header_segment_1.parseAv1BitstreamHeaderSegment)(stream)
50
- : {
51
- type: 'av1-bitstream-unimplemented',
52
- };
53
- if (obuType === 6) {
54
- const head = context.parserState.getAv1BitstreamHeaderSegment();
55
- if (!head) {
56
- throw new Error('Expected header segment');
57
- }
58
- const header = (0, bitstream_frame_1.parseAv1Frame)({
59
- stream,
60
- headerSegment: head.segment,
61
- });
62
- const bytesAdvanced = stream.counter.getOffset() - address;
63
- stream.counter.decrement(bytesAdvanced);
64
- if (size === null) {
65
- throw new Error('Expected size in OBU');
66
- }
67
- const clusterTimestamp = context.parserState.getClusterTimestamp();
68
- if (clusterTimestamp === null) {
69
- throw new Error('Expected cluster timestamp');
70
- }
71
- const toSlice = size + bytesReadSoFar;
72
- const frame = stream.getSlice(toSlice);
73
- let extraBytes = null;
74
- if (!context.parserState.getIsFirstAv1FrameRead()) {
75
- context.parserState.setIsFirstAv1FrameRead();
76
- extraBytes =
77
- (_b = (_a = context.parserState.getAv1BitstreamHeaderSegment()) === null || _a === void 0 ? void 0 : _a.header) !== null && _b !== void 0 ? _b : null;
78
- if (!extraBytes) {
79
- throw new Error('Expected extra bytes');
80
- }
81
- }
82
- onVideoSample(trackNumber, {
83
- data: (0, combine_uint8array_1.combineUint8Arrays)(extraBytes, frame),
84
- timestamp: timecode + clusterTimestamp,
85
- duration: undefined,
86
- trackId: trackNumber,
87
- cts: null,
88
- dts: null,
89
- type: header.header.frameType === 'key' ? 'key' : 'delta',
90
- });
91
- stream.stopReadingBits();
92
- return {
93
- discarded: true,
94
- segment,
95
- };
96
- }
97
- stream.stopReadingBits();
98
- if (size === null) {
99
- return {
100
- discarded: false,
101
- segment,
102
- };
103
- }
104
- const end = stream.counter.getOffset();
105
- const remaining = (size === null ? length : size + bytesReadSoFar) - (end - address);
106
- if (remaining > 0) {
107
- stream.discard(remaining);
108
- }
109
- const remainingNow = length - (stream.counter.getOffset() - address);
110
- if (remainingNow > 0 && remainingNow <= 2) {
111
- throw new Error('remainingNow > 0 && remainingNow <= 2');
112
- }
113
- return {
114
- discarded: Boolean(size),
115
- segment,
116
- };
117
- };
118
- exports.av1Bitstream = av1Bitstream;
@@ -1 +0,0 @@
1
- "use strict";
@@ -1,6 +0,0 @@
1
- import type { AudioTrack, VideoTrack } from '../../get-tracks';
2
- import type { TrackEntry } from './segments/all-segments';
3
- export declare const getTrack: ({ timescale, track, }: {
4
- timescale: number;
5
- track: TrackEntry;
6
- }) => VideoTrack | AudioTrack | null;
@@ -1,184 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getTrack = void 0;
4
- const buffer_iterator_1 = require("../../buffer-iterator");
5
- const make_hvc1_codec_strings_1 = require("../../make-hvc1-codec-strings");
6
- const traversal_1 = require("../../traversal");
7
- const av1_codec_private_1 = require("./av1-codec-private");
8
- const description_1 = require("./description");
9
- const track_entry_1 = require("./segments/track-entry");
10
- const getDescription = (track) => {
11
- const codec = (0, traversal_1.getCodecSegment)(track);
12
- if (!codec) {
13
- return undefined;
14
- }
15
- if (codec.value === 'V_MPEG4/ISO/AVC' || codec.value === 'V_MPEGH/ISO/HEVC') {
16
- const priv = (0, traversal_1.getPrivateData)(track);
17
- if (priv) {
18
- return priv;
19
- }
20
- }
21
- return undefined;
22
- };
23
- const getMatroskaVideoCodecString = ({ track, codecSegment: codec, }) => {
24
- if (codec.value === 'V_VP8') {
25
- return 'vp8';
26
- }
27
- if (codec.value === 'V_VP9') {
28
- const priv = (0, traversal_1.getPrivateData)(track);
29
- if (priv) {
30
- throw new Error('@remotion/media-parser cannot handle the private data for VP9. Do you have an example file you could send so we can implement it?');
31
- }
32
- return 'vp09.00.10.08';
33
- }
34
- if (codec.value === 'V_MPEG4/ISO/AVC') {
35
- const priv = (0, traversal_1.getPrivateData)(track);
36
- if (priv) {
37
- return `avc1.${priv[1].toString(16).padStart(2, '0')}${priv[2].toString(16).padStart(2, '0')}${priv[3].toString(16).padStart(2, '0')}`;
38
- }
39
- throw new Error('Could not find a CodecPrivate field in TrackEntry');
40
- }
41
- if (codec.value === 'V_AV1') {
42
- const priv = (0, traversal_1.getPrivateData)(track);
43
- if (!priv) {
44
- throw new Error('Expected private data in AV1 track');
45
- }
46
- return (0, av1_codec_private_1.parseAv1PrivateData)(priv, null);
47
- }
48
- if (codec.value === 'V_MPEGH/ISO/HEVC') {
49
- const priv = (0, traversal_1.getPrivateData)(track);
50
- const iterator = (0, buffer_iterator_1.getArrayBufferIterator)(priv, priv.length);
51
- return 'hvc1.' + (0, make_hvc1_codec_strings_1.getHvc1CodecString)(iterator);
52
- }
53
- throw new Error(`Unknown codec: ${codec.value}`);
54
- };
55
- const getMatroskaAudioCodecString = (track) => {
56
- const codec = (0, traversal_1.getCodecSegment)(track);
57
- if (!codec) {
58
- throw new Error('Expected codec segment');
59
- }
60
- if (codec.value === 'A_OPUS') {
61
- return 'opus';
62
- }
63
- if (codec.value === 'A_VORBIS') {
64
- return 'vorbis';
65
- }
66
- if (codec.value === 'A_PCM/INT/LIT') {
67
- // https://github.com/ietf-wg-cellar/matroska-specification/issues/142#issuecomment-330004950
68
- // Audio samples MUST be considered as signed values, except if the audio bit depth is 8 which MUST be interpreted as unsigned values.
69
- const bitDepth = (0, traversal_1.getBitDepth)(track);
70
- if (bitDepth === null) {
71
- throw new Error('Expected bit depth');
72
- }
73
- if (bitDepth === 8) {
74
- return 'pcm-u8';
75
- }
76
- return 'pcm-s' + bitDepth;
77
- }
78
- if (codec.value === 'A_AAC') {
79
- const priv = (0, traversal_1.getPrivateData)(track);
80
- const iterator = (0, buffer_iterator_1.getArrayBufferIterator)(priv, priv.length);
81
- iterator.startReadingBits();
82
- /**
83
- * ChatGPT
84
- * ▪ The first 5 bits represent the AOT.
85
- ▪ Common values:
86
- ◦ 1 for AAC Main
87
- ◦ 2 for AAC LC (Low Complexity)
88
- ◦ 3 for AAC SSR (Scalable Sample Rate)
89
- ◦ 4 for AAC LTP (Long Term Prediction)
90
- ◦ 5 for SBR (Spectral Band Replication)
91
- ◦ 29 for HE-AAC (which uses SBR with AAC LC)
92
- */
93
- /**
94
- * Fully qualified codec:
95
- * This codec has multiple possible codec strings:
96
- "mp4a.40.2" — MPEG-4 AAC LC
97
- "mp4a.40.02" — MPEG-4 AAC LC, leading 0 for Aud-OTI compatibility
98
- "mp4a.40.5" — MPEG-4 HE-AAC v1 (AAC LC + SBR)
99
- "mp4a.40.05" — MPEG-4 HE-AAC v1 (AAC LC + SBR), leading 0 for Aud-OTI compatibility
100
- "mp4a.40.29" — MPEG-4 HE-AAC v2 (AAC LC + SBR + PS)
101
- "mp4a.67" — MPEG-2 AAC LC
102
- */
103
- const profile = iterator.getBits(5);
104
- iterator.stopReadingBits();
105
- iterator.destroy();
106
- return `mp4a.40.${profile.toString().padStart(2, '0')}`;
107
- }
108
- if (codec.value === 'A_MPEG/L3') {
109
- return 'mp3';
110
- }
111
- throw new Error(`Unknown codec: ${codec.value}`);
112
- };
113
- const getTrack = ({ timescale, track, }) => {
114
- const trackType = (0, traversal_1.getTrackTypeSegment)(track);
115
- if (!trackType) {
116
- throw new Error('Expected track type segment');
117
- }
118
- const trackId = (0, traversal_1.getTrackId)(track);
119
- if ((0, track_entry_1.trackTypeToString)(trackType.value.value) === 'video') {
120
- const width = (0, traversal_1.getWidthSegment)(track);
121
- if (width === null) {
122
- throw new Error('Expected width segment');
123
- }
124
- const height = (0, traversal_1.getHeightSegment)(track);
125
- if (height === null) {
126
- throw new Error('Expected height segment');
127
- }
128
- const displayHeight = (0, traversal_1.getDisplayHeightSegment)(track);
129
- const displayWidth = (0, traversal_1.getDisplayWidthSegment)(track);
130
- const codec = (0, traversal_1.getCodecSegment)(track);
131
- if (!codec) {
132
- return null;
133
- }
134
- const codecString = getMatroskaVideoCodecString({
135
- track,
136
- codecSegment: codec,
137
- });
138
- if (!codecString) {
139
- return null;
140
- }
141
- return {
142
- type: 'video',
143
- trackId,
144
- codec: codecString,
145
- description: getDescription(track),
146
- height: displayHeight ? displayHeight.value.value : height.value.value,
147
- width: displayWidth ? displayWidth.value.value : width.value.value,
148
- sampleAspectRatio: {
149
- numerator: 1,
150
- denominator: 1,
151
- },
152
- timescale,
153
- codedHeight: height.value.value,
154
- codedWidth: width.value.value,
155
- displayAspectHeight: displayHeight
156
- ? displayHeight.value.value
157
- : height.value.value,
158
- displayAspectWidth: displayWidth
159
- ? displayWidth.value.value
160
- : width.value.value,
161
- rotation: 0,
162
- trakBox: null,
163
- };
164
- }
165
- if ((0, track_entry_1.trackTypeToString)(trackType.value.value) === 'audio') {
166
- const sampleRate = (0, traversal_1.getSampleRate)(track);
167
- const numberOfChannels = (0, traversal_1.getNumberOfChannels)(track);
168
- if (sampleRate === null) {
169
- throw new Error('Could not find sample rate or number of channels');
170
- }
171
- return {
172
- type: 'audio',
173
- trackId,
174
- codec: getMatroskaAudioCodecString(track),
175
- timescale,
176
- numberOfChannels,
177
- sampleRate,
178
- description: (0, description_1.getAudioDescription)(track),
179
- trakBox: null,
180
- };
181
- }
182
- return null;
183
- };
184
- exports.getTrack = getTrack;
@@ -1,6 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- export type DurationSegment = {
3
- type: 'duration-segment';
4
- duration: number;
5
- };
6
- export declare const parseDurationSegment: (iterator: BufferIterator, length: number) => DurationSegment;
@@ -1,19 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseDurationSegment = void 0;
4
- const parseDurationSegment = (iterator, length) => {
5
- if (length === 8) {
6
- return {
7
- type: 'duration-segment',
8
- duration: iterator.getFloat64(),
9
- };
10
- }
11
- if (length === 4) {
12
- return {
13
- type: 'duration-segment',
14
- duration: iterator.getFloat32(),
15
- };
16
- }
17
- throw new Error('Expected duration segment to be 4 or 8 bytes, but it is ' + length);
18
- };
19
- exports.parseDurationSegment = parseDurationSegment;
@@ -1,9 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- import type { ParserContext } from '../../../parser-context';
3
- import type { MatroskaSegment } from '../segments';
4
- export type InfoSegment = {
5
- type: 'info-segment';
6
- length: number;
7
- children: MatroskaSegment[];
8
- };
9
- export declare const parseInfoSegment: (iterator: BufferIterator, length: number, parserContext: ParserContext) => Promise<InfoSegment>;
@@ -1,22 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseInfoSegment = void 0;
4
- const parse_children_1 = require("./parse-children");
5
- const parseInfoSegment = async (iterator, length, parserContext) => {
6
- const children = await (0, parse_children_1.expectChildren)({
7
- iterator,
8
- length,
9
- initialChildren: [],
10
- wrap: null,
11
- parserContext,
12
- });
13
- if (children.status === 'incomplete') {
14
- throw new Error('Incomplete children');
15
- }
16
- return {
17
- type: 'info-segment',
18
- length,
19
- children: children.segments,
20
- };
21
- };
22
- exports.parseInfoSegment = parseInfoSegment;
@@ -1,5 +0,0 @@
1
- import { type MatroskaSegment } from '../segments';
2
- export type MainSegment = {
3
- type: 'main-segment';
4
- children: MatroskaSegment[];
5
- };
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,6 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- export type MuxingAppSegment = {
3
- type: 'muxing-app-segment';
4
- value: string;
5
- };
6
- export declare const parseMuxingSegment: (iterator: BufferIterator, length: number) => MuxingAppSegment;
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseMuxingSegment = void 0;
4
- const parseMuxingSegment = (iterator, length) => {
5
- const value = iterator.getByteString(length);
6
- return {
7
- type: 'muxing-app-segment',
8
- value,
9
- };
10
- };
11
- exports.parseMuxingSegment = parseMuxingSegment;
@@ -1,9 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- import type { ParserContext } from '../../../parser-context';
3
- import { type MatroskaSegment } from '../segments';
4
- export type SeekHeadSegment = {
5
- type: 'seek-head-segment';
6
- children: MatroskaSegment[];
7
- length: number;
8
- };
9
- export declare const parseSeekHeadSegment: (iterator: BufferIterator, length: number, parserContext: ParserContext) => Promise<SeekHeadSegment>;
@@ -1,22 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseSeekHeadSegment = void 0;
4
- const parse_children_1 = require("./parse-children");
5
- const parseSeekHeadSegment = async (iterator, length, parserContext) => {
6
- const children = await (0, parse_children_1.expectChildren)({
7
- iterator,
8
- length,
9
- initialChildren: [],
10
- wrap: null,
11
- parserContext,
12
- });
13
- if (children.status === 'incomplete') {
14
- throw new Error('Incomplete children');
15
- }
16
- return {
17
- type: 'seek-head-segment',
18
- length,
19
- children: children.segments,
20
- };
21
- };
22
- exports.parseSeekHeadSegment = parseSeekHeadSegment;
@@ -1,6 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- export type SeekPositionSegment = {
3
- type: 'seek-position-segment';
4
- seekPosition: number;
5
- };
6
- export declare const parseSeekPositionSegment: (iterator: BufferIterator, length: number) => SeekPositionSegment;
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseSeekPositionSegment = void 0;
4
- const parseSeekPositionSegment = (iterator, length) => {
5
- const seekPosition = iterator.getUint(length);
6
- return {
7
- type: 'seek-position-segment',
8
- seekPosition,
9
- };
10
- };
11
- exports.parseSeekPositionSegment = parseSeekPositionSegment;
@@ -1,13 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- import type { ParserContext } from '../../../parser-context';
3
- import type { MatroskaSegment } from '../segments';
4
- export type SeekSegment = {
5
- type: 'seek-segment';
6
- children: MatroskaSegment[];
7
- };
8
- export declare const parseSeekSegment: (iterator: BufferIterator, length: number, parserContext: ParserContext) => Promise<SeekSegment>;
9
- export type SeekIdSegment = {
10
- type: 'seek-id-segment';
11
- seekId: string;
12
- };
13
- export declare const parseSeekIdSegment: (iterator: BufferIterator, length: number) => SeekIdSegment;
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseSeekIdSegment = exports.parseSeekSegment = void 0;
4
- const parse_children_1 = require("./parse-children");
5
- const parseSeekSegment = async (iterator, length, parserContext) => {
6
- const children = await (0, parse_children_1.expectChildren)({
7
- iterator,
8
- length,
9
- initialChildren: [],
10
- wrap: null,
11
- parserContext,
12
- });
13
- if (children.status === 'incomplete') {
14
- throw new Error('Incomplete children');
15
- }
16
- return {
17
- type: 'seek-segment',
18
- children: children.segments,
19
- };
20
- };
21
- exports.parseSeekSegment = parseSeekSegment;
22
- const parseSeekIdSegment = (iterator, length) => {
23
- const seekId = '0x' +
24
- [...iterator.getSlice(length)]
25
- .map((b) => b.toString(16).padStart(2, '0'))
26
- .join('');
27
- if (seekId === null) {
28
- throw new Error('Not enough bytes to parse seek id');
29
- }
30
- return {
31
- type: 'seek-id-segment',
32
- seekId,
33
- };
34
- };
35
- exports.parseSeekIdSegment = parseSeekIdSegment;
@@ -1,6 +0,0 @@
1
- import type { BufferIterator } from '../../../buffer-iterator';
2
- export type TimestampScaleSegment = {
3
- type: 'timestamp-scale-segment';
4
- timestampScale: number;
5
- };
6
- export declare const parseTimestampScaleSegment: (iterator: BufferIterator) => TimestampScaleSegment;
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parseTimestampScaleSegment = void 0;
4
- const parseTimestampScaleSegment = (iterator) => {
5
- const timestampScale = iterator.getUint(3);
6
- return {
7
- type: 'timestamp-scale-segment',
8
- timestampScale,
9
- };
10
- };
11
- exports.parseTimestampScaleSegment = parseTimestampScaleSegment;