@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.
- package/dist/add-avc-profile-to-track.d.ts +3 -0
- package/dist/add-avc-profile-to-track.js +35 -0
- package/dist/add-new-matroska-tracks.d.ts +6 -1
- package/dist/add-new-matroska-tracks.js +16 -1
- package/dist/boxes/avc/parse-avc.d.ts +18 -0
- package/dist/boxes/avc/parse-avc.js +96 -0
- package/dist/boxes/iso-base-media/make-track.js +3 -3
- package/dist/boxes/iso-base-media/mdat/mdat.d.ts +2 -2
- package/dist/boxes/iso-base-media/mdat/mdat.js +5 -2
- package/dist/boxes/iso-base-media/moov/moov.js +2 -2
- package/dist/boxes/iso-base-media/process-box.d.ts +5 -5
- package/dist/boxes/iso-base-media/process-box.js +38 -37
- package/dist/boxes/iso-base-media/stsd/mebx.js +2 -2
- package/dist/boxes/iso-base-media/stsd/samples.d.ts +2 -2
- package/dist/boxes/iso-base-media/stsd/samples.js +9 -9
- package/dist/boxes/iso-base-media/trak/trak.js +2 -2
- package/dist/boxes/iso-base-media/traversal.d.ts +1 -1
- package/dist/boxes/riff/expect-riff-box.d.ts +16 -0
- package/dist/boxes/riff/expect-riff-box.js +49 -0
- package/dist/boxes/riff/get-tracks-from-avi.d.ts +21 -0
- package/dist/boxes/riff/get-tracks-from-avi.js +108 -0
- package/dist/boxes/riff/is-movi.d.ts +2 -0
- package/dist/boxes/riff/is-movi.js +12 -0
- package/dist/boxes/riff/parse-avih.d.ts +6 -0
- package/dist/boxes/riff/parse-avih.js +32 -0
- package/dist/boxes/riff/parse-box.d.ts +13 -0
- package/dist/boxes/riff/parse-box.js +113 -0
- package/dist/boxes/riff/parse-fmt-box.d.ts +7 -0
- package/dist/boxes/riff/parse-fmt-box.js +33 -0
- package/dist/boxes/riff/parse-list-box.d.ts +8 -0
- package/dist/boxes/riff/parse-list-box.js +30 -0
- package/dist/boxes/riff/parse-movi.d.ts +17 -0
- package/dist/boxes/riff/parse-movi.js +122 -0
- package/dist/boxes/riff/parse-riff-box.d.ts +10 -0
- package/dist/boxes/riff/parse-riff-box.js +33 -0
- package/dist/boxes/riff/parse-strf.d.ts +7 -0
- package/dist/boxes/riff/parse-strf.js +67 -0
- package/dist/boxes/riff/parse-strh.d.ts +6 -0
- package/dist/boxes/riff/parse-strh.js +46 -0
- package/dist/boxes/riff/riff-box.d.ts +81 -0
- package/dist/boxes/riff/riff-box.js +2 -0
- package/dist/boxes/riff/strf.d.ts +7 -0
- package/dist/boxes/riff/strf.js +67 -0
- package/dist/boxes/riff/timescale.d.ts +1 -0
- package/dist/boxes/riff/timescale.js +4 -0
- package/dist/boxes/riff/traversal.d.ts +8 -0
- package/dist/boxes/riff/traversal.js +36 -0
- package/dist/boxes/webm/parse-ebml.js +2 -2
- package/dist/boxes/webm/parse-webm-header.d.ts +2 -2
- package/dist/boxes/webm/parse-webm-header.js +7 -7
- package/dist/boxes/webm/traversal.d.ts +2 -2
- package/dist/buffer-iterator.d.ts +6 -1
- package/dist/buffer-iterator.js +24 -5
- package/dist/create/iso-base-media/create-iso-base-media.js +0 -4
- package/dist/create/matroska/create-matroska-media.js +0 -4
- package/dist/create/media-fn.d.ts +0 -1
- package/dist/create/mp3/create-mp3.d.ts +2 -0
- package/dist/create/mp3/create-mp3.js +49 -0
- package/dist/create/wav/create-wav.d.ts +2 -0
- package/dist/create/wav/create-wav.js +108 -0
- package/dist/emit-available-info.d.ts +2 -2
- package/dist/emit-available-info.js +6 -4
- package/dist/esm/from-node.mjs +2 -1
- package/dist/esm/index.mjs +1487 -431
- package/dist/get-audio-codec.d.ts +3 -3
- package/dist/get-audio-codec.js +2 -2
- package/dist/get-container.d.ts +3 -3
- package/dist/get-container.js +9 -7
- package/dist/get-dimensions.d.ts +3 -3
- package/dist/get-duration.d.ts +3 -3
- package/dist/get-duration.js +32 -14
- package/dist/get-fps.d.ts +3 -3
- package/dist/get-fps.js +31 -4
- package/dist/get-tracks.d.ts +4 -7
- package/dist/get-tracks.js +55 -27
- package/dist/get-video-codec.d.ts +5 -4
- package/dist/get-video-codec.js +38 -10
- package/dist/has-all-info.d.ts +2 -2
- package/dist/has-all-info.js +4 -4
- package/dist/index.d.ts +1 -0
- package/dist/index.js +2 -0
- package/dist/options.d.ts +9 -9
- package/dist/parse-media.js +2 -0
- package/dist/parse-result.d.ts +20 -6
- package/dist/parse-video.d.ts +2 -2
- package/dist/parse-video.js +5 -16
- package/dist/parser-context.d.ts +1 -0
- package/dist/parser-state.d.ts +11 -0
- package/dist/parser-state.js +30 -0
- package/dist/readers/from-node.js +2 -1
- package/dist/register-track.d.ts +13 -0
- package/dist/register-track.js +25 -0
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- 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 === '
|
|
16
|
-
if (parseResult &&
|
|
17
|
-
|
|
18
|
-
returnValue.
|
|
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
|
}
|
package/dist/esm/from-node.mjs
CHANGED
|
@@ -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(
|
|
36
|
+
name: src.split(sep).pop(),
|
|
36
37
|
supportsContentRange: true
|
|
37
38
|
};
|
|
38
39
|
},
|