@remotion/media-parser 4.0.231 → 4.0.232

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 (95) hide show
  1. package/dist/add-avc-profile-to-track.d.ts +3 -0
  2. package/dist/add-avc-profile-to-track.js +35 -0
  3. package/dist/add-new-matroska-tracks.d.ts +6 -1
  4. package/dist/add-new-matroska-tracks.js +16 -1
  5. package/dist/boxes/avc/parse-avc.d.ts +18 -0
  6. package/dist/boxes/avc/parse-avc.js +96 -0
  7. package/dist/boxes/iso-base-media/make-track.js +3 -3
  8. package/dist/boxes/iso-base-media/mdat/mdat.d.ts +2 -2
  9. package/dist/boxes/iso-base-media/mdat/mdat.js +5 -2
  10. package/dist/boxes/iso-base-media/moov/moov.js +2 -2
  11. package/dist/boxes/iso-base-media/process-box.d.ts +5 -5
  12. package/dist/boxes/iso-base-media/process-box.js +38 -37
  13. package/dist/boxes/iso-base-media/stsd/mebx.js +2 -2
  14. package/dist/boxes/iso-base-media/stsd/samples.d.ts +2 -2
  15. package/dist/boxes/iso-base-media/stsd/samples.js +9 -9
  16. package/dist/boxes/iso-base-media/trak/trak.js +2 -2
  17. package/dist/boxes/iso-base-media/traversal.d.ts +1 -1
  18. package/dist/boxes/riff/expect-riff-box.d.ts +16 -0
  19. package/dist/boxes/riff/expect-riff-box.js +49 -0
  20. package/dist/boxes/riff/get-tracks-from-avi.d.ts +21 -0
  21. package/dist/boxes/riff/get-tracks-from-avi.js +108 -0
  22. package/dist/boxes/riff/is-movi.d.ts +2 -0
  23. package/dist/boxes/riff/is-movi.js +12 -0
  24. package/dist/boxes/riff/parse-avih.d.ts +6 -0
  25. package/dist/boxes/riff/parse-avih.js +32 -0
  26. package/dist/boxes/riff/parse-box.d.ts +13 -0
  27. package/dist/boxes/riff/parse-box.js +113 -0
  28. package/dist/boxes/riff/parse-fmt-box.d.ts +7 -0
  29. package/dist/boxes/riff/parse-fmt-box.js +33 -0
  30. package/dist/boxes/riff/parse-list-box.d.ts +8 -0
  31. package/dist/boxes/riff/parse-list-box.js +30 -0
  32. package/dist/boxes/riff/parse-movi.d.ts +17 -0
  33. package/dist/boxes/riff/parse-movi.js +122 -0
  34. package/dist/boxes/riff/parse-riff-box.d.ts +10 -0
  35. package/dist/boxes/riff/parse-riff-box.js +33 -0
  36. package/dist/boxes/riff/parse-strf.d.ts +7 -0
  37. package/dist/boxes/riff/parse-strf.js +67 -0
  38. package/dist/boxes/riff/parse-strh.d.ts +6 -0
  39. package/dist/boxes/riff/parse-strh.js +46 -0
  40. package/dist/boxes/riff/riff-box.d.ts +81 -0
  41. package/dist/boxes/riff/riff-box.js +2 -0
  42. package/dist/boxes/riff/strf.d.ts +7 -0
  43. package/dist/boxes/riff/strf.js +67 -0
  44. package/dist/boxes/riff/timescale.d.ts +1 -0
  45. package/dist/boxes/riff/timescale.js +4 -0
  46. package/dist/boxes/riff/traversal.d.ts +8 -0
  47. package/dist/boxes/riff/traversal.js +36 -0
  48. package/dist/boxes/webm/parse-ebml.js +2 -2
  49. package/dist/boxes/webm/parse-webm-header.d.ts +2 -2
  50. package/dist/boxes/webm/parse-webm-header.js +7 -7
  51. package/dist/boxes/webm/traversal.d.ts +2 -2
  52. package/dist/buffer-iterator.d.ts +6 -1
  53. package/dist/buffer-iterator.js +24 -5
  54. package/dist/create/iso-base-media/create-iso-base-media.js +0 -4
  55. package/dist/create/matroska/create-matroska-media.js +0 -4
  56. package/dist/create/media-fn.d.ts +0 -1
  57. package/dist/create/mp3/create-mp3.d.ts +2 -0
  58. package/dist/create/mp3/create-mp3.js +49 -0
  59. package/dist/create/wav/create-wav.d.ts +2 -0
  60. package/dist/create/wav/create-wav.js +108 -0
  61. package/dist/emit-available-info.d.ts +2 -2
  62. package/dist/emit-available-info.js +6 -4
  63. package/dist/esm/from-node.mjs +2 -1
  64. package/dist/esm/index.mjs +1487 -431
  65. package/dist/get-audio-codec.d.ts +3 -3
  66. package/dist/get-audio-codec.js +2 -2
  67. package/dist/get-container.d.ts +3 -3
  68. package/dist/get-container.js +9 -7
  69. package/dist/get-dimensions.d.ts +3 -3
  70. package/dist/get-duration.d.ts +3 -3
  71. package/dist/get-duration.js +32 -14
  72. package/dist/get-fps.d.ts +3 -3
  73. package/dist/get-fps.js +31 -4
  74. package/dist/get-tracks.d.ts +4 -7
  75. package/dist/get-tracks.js +55 -27
  76. package/dist/get-video-codec.d.ts +5 -4
  77. package/dist/get-video-codec.js +38 -10
  78. package/dist/has-all-info.d.ts +2 -2
  79. package/dist/has-all-info.js +4 -4
  80. package/dist/index.d.ts +1 -0
  81. package/dist/index.js +2 -0
  82. package/dist/options.d.ts +9 -9
  83. package/dist/parse-media.js +2 -0
  84. package/dist/parse-result.d.ts +20 -6
  85. package/dist/parse-video.d.ts +2 -2
  86. package/dist/parse-video.js +5 -16
  87. package/dist/parser-context.d.ts +1 -0
  88. package/dist/parser-state.d.ts +11 -0
  89. package/dist/parser-state.js +30 -0
  90. package/dist/readers/from-node.js +2 -1
  91. package/dist/register-track.d.ts +13 -0
  92. package/dist/register-track.js +25 -0
  93. package/dist/version.d.ts +1 -1
  94. package/dist/version.js +1 -1
  95. package/package.json +3 -3
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createWav = void 0;
4
+ const log_1 = require("../../log");
5
+ const numberTo32BiIntLittleEndian = (num) => {
6
+ return new Uint8Array([
7
+ num & 0xff,
8
+ (num >> 8) & 0xff,
9
+ (num >> 16) & 0xff,
10
+ (num >> 24) & 0xff,
11
+ ]);
12
+ };
13
+ const numberTo16BitLittleEndian = (num) => {
14
+ return new Uint8Array([num & 0xff, (num >> 8) & 0xff]);
15
+ };
16
+ const BIT_DEPTH = 16;
17
+ const BYTES_PER_SAMPLE = BIT_DEPTH / 8;
18
+ const createWav = async ({ filename, logLevel, onBytesProgress, onMillisecondsProgress, writer, }) => {
19
+ const w = await writer.createContent({ filename, mimeType: 'audio/wav' });
20
+ await w.write(new Uint8Array([0x52, 0x49, 0x46, 0x46])); // "RIFF"
21
+ const sizePosition = w.getWrittenByteCount();
22
+ await w.write(new Uint8Array([0x00, 0x00, 0x00, 0x00])); // Remaining size
23
+ await w.write(new Uint8Array([0x57, 0x41, 0x56, 0x45])); // "WAVE"
24
+ await w.write(new Uint8Array([0x66, 0x6d, 0x74, 0x20])); // "fmt "
25
+ await w.write(new Uint8Array([0x10, 0x00, 0x00, 0x00])); // fmt chunk size = 16
26
+ await w.write(new Uint8Array([0x01, 0x00])); // Audio format (PCM) = 1, set 3 if float32 would be true
27
+ const channelNumPosition = w.getWrittenByteCount();
28
+ await w.write(new Uint8Array([0x01, 0x00])); // Number of channels = 1
29
+ const sampleRatePosition = w.getWrittenByteCount();
30
+ await w.write(new Uint8Array([0x0, 0x0, 0x00, 0x00])); // Sample rate
31
+ const byteRatePosition = w.getWrittenByteCount();
32
+ await w.write(new Uint8Array([0x0, 0x0, 0x00, 0x00])); // Byte rate
33
+ const blockAlignPosition = w.getWrittenByteCount();
34
+ await w.write(new Uint8Array([0x00, 0x00])); // Block align
35
+ await w.write(numberTo16BitLittleEndian(BIT_DEPTH)); // Bits per sample
36
+ await w.write(new Uint8Array([0x64, 0x61, 0x74, 0x61])); // "data"
37
+ const dataSizePosition = w.getWrittenByteCount();
38
+ await w.write(new Uint8Array([0x00, 0x00, 0x00, 0x00])); // Remaining size
39
+ const operationProm = { current: Promise.resolve() };
40
+ const updateSize = async () => {
41
+ const size = w.getWrittenByteCount() - sizePosition - 4;
42
+ await w.updateDataAt(sizePosition, numberTo32BiIntLittleEndian(size));
43
+ const dataSize = w.getWrittenByteCount() - dataSizePosition - 4;
44
+ await w.updateDataAt(dataSizePosition, numberTo32BiIntLittleEndian(dataSize));
45
+ };
46
+ const updateChannelNum = async (numberOfChannels) => {
47
+ await w.updateDataAt(channelNumPosition, new Uint8Array([numberOfChannels, 0x00]));
48
+ };
49
+ const updateSampleRate = async (sampleRate) => {
50
+ await w.updateDataAt(sampleRatePosition, numberTo32BiIntLittleEndian(sampleRate));
51
+ };
52
+ const updateByteRate = async ({ sampleRate, numberOfChannels, }) => {
53
+ await w.updateDataAt(byteRatePosition, numberTo32BiIntLittleEndian(sampleRate * numberOfChannels + BYTES_PER_SAMPLE));
54
+ };
55
+ const updateBlockAlign = async (numberOfChannels) => {
56
+ await w.updateDataAt(blockAlignPosition, new Uint8Array(numberTo16BitLittleEndian(numberOfChannels * BYTES_PER_SAMPLE)));
57
+ };
58
+ const addSample = async (chunk) => {
59
+ var _a;
60
+ log_1.Log.verbose(logLevel, 'Adding sample', chunk);
61
+ await w.write(chunk.data);
62
+ onMillisecondsProgress((chunk.timestamp + ((_a = chunk.duration) !== null && _a !== void 0 ? _a : 0)) / 1000);
63
+ onBytesProgress(w.getWrittenByteCount());
64
+ };
65
+ const waitForFinishPromises = [];
66
+ return {
67
+ save: () => {
68
+ return w.save();
69
+ },
70
+ remove: () => {
71
+ return w.remove();
72
+ },
73
+ addSample: ({ chunk, trackNumber }) => {
74
+ if (trackNumber !== 1) {
75
+ throw new Error('Only one track supported for WAV');
76
+ }
77
+ operationProm.current = operationProm.current.then(() => addSample(chunk));
78
+ return operationProm.current;
79
+ },
80
+ updateTrackSampleRate: () => {
81
+ throw new Error('updateTrackSampleRate() not implemented for WAV encoder');
82
+ },
83
+ addWaitForFinishPromise: (promise) => {
84
+ waitForFinishPromises.push(promise);
85
+ },
86
+ async waitForFinish() {
87
+ log_1.Log.verbose(logLevel, 'All write operations queued. Waiting for finish...');
88
+ await Promise.all(waitForFinishPromises.map((p) => p()));
89
+ await operationProm.current;
90
+ await updateSize();
91
+ await w.waitForFinish();
92
+ },
93
+ addTrack: async (track) => {
94
+ if (track.type !== 'audio') {
95
+ throw new Error('Only audio tracks supported for WAV');
96
+ }
97
+ await updateChannelNum(track.numberOfChannels);
98
+ await updateSampleRate(track.sampleRate);
99
+ await updateByteRate({
100
+ sampleRate: track.sampleRate,
101
+ numberOfChannels: track.numberOfChannels,
102
+ });
103
+ await updateBlockAlign(track.numberOfChannels);
104
+ return Promise.resolve({ trackNumber: 1 });
105
+ },
106
+ };
107
+ };
108
+ exports.createWav = createWav;
@@ -1,9 +1,9 @@
1
1
  import type { AllParseMediaFields, Options, ParseMediaCallbacks, ParseMediaFields, ParseMediaResult } from './options';
2
- import type { ParseResult } from './parse-result';
2
+ import type { ParseResult, Structure } from './parse-result';
3
3
  import type { ParserState } from './parser-state';
4
4
  export declare const emitAvailableInfo: ({ hasInfo, parseResult, moreFields, state, returnValue, contentLength, name, }: {
5
5
  hasInfo: Record<keyof Options<ParseMediaFields>, boolean>;
6
- parseResult: ParseResult | null;
6
+ parseResult: ParseResult<Structure> | null;
7
7
  moreFields: ParseMediaCallbacks<AllParseMediaFields>;
8
8
  state: ParserState;
9
9
  returnValue: ParseMediaResult<AllParseMediaFields>;
@@ -12,10 +12,12 @@ const emitAvailableInfo = ({ hasInfo, parseResult, moreFields, state, returnValu
12
12
  var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13
13
  const keys = Object.keys(hasInfo);
14
14
  for (const key of keys) {
15
- if (key === 'boxes') {
16
- if (parseResult && hasInfo.boxes && returnValue.boxes === undefined) {
17
- (_a = moreFields.onBoxes) === null || _a === void 0 ? void 0 : _a.call(moreFields, parseResult.segments);
18
- returnValue.boxes = parseResult.segments;
15
+ if (key === 'structure') {
16
+ if (parseResult &&
17
+ hasInfo.structure &&
18
+ returnValue.structure === undefined) {
19
+ (_a = moreFields.onStructure) === null || _a === void 0 ? void 0 : _a.call(moreFields, parseResult.segments);
20
+ returnValue.structure = parseResult.segments;
19
21
  }
20
22
  continue;
21
23
  }
@@ -1,6 +1,7 @@
1
1
  // src/readers/from-node.ts
2
2
  import { createReadStream } from "fs";
3
3
  import { stat } from "node:fs/promises";
4
+ import { sep } from "path";
4
5
  import { Readable } from "stream";
5
6
  var nodeReader = {
6
7
  read: async (src, range, signal) => {
@@ -32,7 +33,7 @@ var nodeReader = {
32
33
  }
33
34
  },
34
35
  contentLength: stats.size,
35
- name: src.split("/").pop(),
36
+ name: src.split(sep).pop(),
36
37
  supportsContentRange: true
37
38
  };
38
39
  },