From dc96b9fb418af3ddf4cbe6ac06aa1b6d5a54ccd8 Mon Sep 17 00:00:00 2001 From: "jeanchristophe.mqt@gmail.com" Date: Fri, 10 Jan 2025 20:47:03 +0100 Subject: [PATCH] Corrected dispositions build --- .../1.0.0/index.js | 72 +++++++++---------- .../1.0.0/index.ts | 70 +++++++++--------- 2 files changed, 68 insertions(+), 74 deletions(-) diff --git a/FlowPlugins/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.js b/FlowPlugins/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.js index 107ef1cc7..bdfcff6f7 100644 --- a/FlowPlugins/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.js +++ b/FlowPlugins/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.js @@ -1,4 +1,13 @@ "use strict"; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; Object.defineProperty(exports, "__esModule", { value: true }); exports.plugin = exports.details = void 0; var flowUtils_1 = require("../../../../FlowHelpers/1.0.0/interfaces/flowUtils"); @@ -77,40 +86,26 @@ var details = function () { return ({ ], }); }; exports.details = details; -var addDisposition = function (disposition, dispositionToAdd) { return (dispositionToAdd.length > 0 - ? "".concat(disposition).concat(disposition.length > 0 ? '+' : '').concat(dispositionToAdd) - : disposition); }; -var getFFMPEGDisposition = function (stream, isDefault) { - if (!stream.disposition) - return '0'; - var disposition = addDisposition(isDefault ? 'default' : '', Object.entries(stream.disposition) - .filter(function (_a) { - var value = _a[0]; - return value === '1'; - }) - .map(function (_a) { - var key = _a[0]; - return key; - }) - .join('+')); - return disposition.length > 0 ? disposition : '0'; +var getFFMPEGDisposition = function (args, isDefault, dispositions) { + if (!dispositions) + return isDefault ? 'default' : '0'; + args.jobLog("previous disposition ".concat(JSON.stringify(dispositions))); + var previousDispositions = Object.entries(dispositions) + .reduce(function (acc, _a) { + var key = _a[0], value = _a[1]; + if (key !== 'default' && value === 1) { + acc.push(key); + } + return acc; + }, []); + var ffmpegDisposition = __spreadArray([ + isDefault ? 'default' : '' + ], previousDispositions, true).filter(Boolean) + .join('+') + || '0'; + args.jobLog("ffmpegDisposition ".concat(ffmpegDisposition)); + return ffmpegDisposition; }; -// addDisposition(disposition, stream.disposition.dub === 1 ? 'dub' : ''); -// addDisposition(disposition, stream.disposition.original === 1 ? 'original' : ''); -// addDisposition(disposition, stream.disposition.comment === 1 ? 'comment' : ''); -// addDisposition(disposition, stream.disposition.lyrics === 1 ? 'lyrics' : ''); -// addDisposition(disposition, stream.disposition.karaoke === 1 ? 'karaoke' : ''); -// addDisposition(disposition, stream.disposition.forced === 1 ? 'forced' : ''); -// addDisposition(disposition, stream.disposition.hearing_impaired === 1 ? 'hearing_impaired' : ''); -// addDisposition(disposition, stream.disposition.visual_impaired === 1 ? 'visual_impaired' : ''); -// addDisposition(disposition, stream.disposition.clean_effects === 1 ? 'clean_effects' : ''); -// addDisposition(disposition, stream.disposition.attached_pic === 1 ? 'attached_pic' : ''); -// addDisposition(disposition, stream.disposition.timed_thumbnails === 1 ? 'timed_thumbnails' : ''); -// addDisposition(disposition, stream.disposition.captions === 1 ? 'captions' : ''); -// addDisposition(disposition, stream.disposition.descriptions === 1 ? 'descriptions' : ''); -// addDisposition(disposition, stream.disposition.metadata === 1 ? 'metadata' : ''); -// addDisposition(disposition, stream.disposition.dependent === 1 ? 'dependent' : ''); -// addDisposition(disposition, stream.disposition.still_image === 1 ? 'still_image' : ''); // eslint-disable-next-line @typescript-eslint/no-unused-vars var plugin = function (args) { var _a, _b, _c, _d; @@ -135,21 +130,18 @@ var plugin = function (args) { args.jobLog("Channels ".concat(channels, " determined has being the highest match")); } streams.forEach(function (stream, index) { - var _a, _b, _c, _d, _e; + var _a, _b, _c; if (stream.codec_type === 'audio') { + var dispositions = stream.disposition; if (((_b = (_a = stream.tags) === null || _a === void 0 ? void 0 : _a.language) !== null && _b !== void 0 ? _b : '') === languageCode && ((_c = stream.channels) !== null && _c !== void 0 ? _c : 0) === channels && !defaultSet) { args.jobLog("Setting stream ".concat(index, " (language ").concat(languageCode, ", channels ").concat(channels, ") has default")); - var disposition = getFFMPEGDisposition(stream, true); - args.jobLog("Original ".concat(JSON.stringify((_d = stream.disposition) !== null && _d !== void 0 ? _d : {}), "; new ").concat(disposition)); - stream.outputArgs.push("-c:".concat(index), 'copy', "-disposition:".concat(index), disposition); + stream.outputArgs.push("-c:".concat(index), 'copy', "-disposition:".concat(index), getFFMPEGDisposition(args, true, dispositions)); defaultSet = true; } else { - var disposition = getFFMPEGDisposition(stream, false); - args.jobLog("Original ".concat(JSON.stringify((_e = stream.disposition) !== null && _e !== void 0 ? _e : {}), "}; new ").concat(disposition)); - stream.outputArgs.push("-c:".concat(index), 'copy', "-disposition:".concat(index), disposition); + stream.outputArgs.push("-c:".concat(index), 'copy', "-disposition:".concat(index), getFFMPEGDisposition(args, false, dispositions)); } } }); diff --git a/FlowPluginsTs/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.ts b/FlowPluginsTs/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.ts index 534ca5467..4bdeedb27 100644 --- a/FlowPluginsTs/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.ts +++ b/FlowPluginsTs/CommunityFlowPlugins/ffmpegCommand/ffmpegCommandSetDefaultAudioStream/1.0.0/index.ts @@ -103,38 +103,33 @@ interface IStreamDisposition { disposition?: IDisposition } -const addDisposition = (disposition: string, dispositionToAdd: string): string => (dispositionToAdd.length > 0 - ? `${disposition}${disposition.length > 0 ? '+' : ''}${dispositionToAdd}` - : disposition); +const getFFMPEGDisposition = ( + args: IpluginInputArgs, + isDefault: boolean, + dispositions?: IDisposition, +): string => { + if (!dispositions) return isDefault ? 'default' : '0'; + args.jobLog(`previous disposition ${JSON.stringify(dispositions)}`); -const getFFMPEGDisposition = (stream: IStreamDisposition, isDefault: boolean): string => { - if (!stream.disposition) return '0'; + const previousDispositions = Object.entries(dispositions) + .reduce((acc, [key, value]) => { + if (key !== 'default' && value === 1) { + acc.push(key); + } + return acc; + }, [] as string[]); - const disposition = addDisposition( + const ffmpegDisposition = [ isDefault ? 'default' : '', - Object.entries(stream.disposition) - .filter(([value]) => value === '1') - .map(([key]) => key) - .join('+'), - ); - return disposition.length > 0 ? disposition : '0'; + ...previousDispositions, + ] + .filter(Boolean) + .join('+') + || '0'; + args.jobLog(`ffmpegDisposition ${ffmpegDisposition}`); + + return ffmpegDisposition; }; -// addDisposition(disposition, stream.disposition.dub === 1 ? 'dub' : ''); -// addDisposition(disposition, stream.disposition.original === 1 ? 'original' : ''); -// addDisposition(disposition, stream.disposition.comment === 1 ? 'comment' : ''); -// addDisposition(disposition, stream.disposition.lyrics === 1 ? 'lyrics' : ''); -// addDisposition(disposition, stream.disposition.karaoke === 1 ? 'karaoke' : ''); -// addDisposition(disposition, stream.disposition.forced === 1 ? 'forced' : ''); -// addDisposition(disposition, stream.disposition.hearing_impaired === 1 ? 'hearing_impaired' : ''); -// addDisposition(disposition, stream.disposition.visual_impaired === 1 ? 'visual_impaired' : ''); -// addDisposition(disposition, stream.disposition.clean_effects === 1 ? 'clean_effects' : ''); -// addDisposition(disposition, stream.disposition.attached_pic === 1 ? 'attached_pic' : ''); -// addDisposition(disposition, stream.disposition.timed_thumbnails === 1 ? 'timed_thumbnails' : ''); -// addDisposition(disposition, stream.disposition.captions === 1 ? 'captions' : ''); -// addDisposition(disposition, stream.disposition.descriptions === 1 ? 'descriptions' : ''); -// addDisposition(disposition, stream.disposition.metadata === 1 ? 'metadata' : ''); -// addDisposition(disposition, stream.disposition.dependent === 1 ? 'dependent' : ''); -// addDisposition(disposition, stream.disposition.still_image === 1 ? 'still_image' : ''); // eslint-disable-next-line @typescript-eslint/no-unused-vars const plugin = (args: IpluginInputArgs): IpluginOutputArgs => { @@ -170,18 +165,25 @@ const plugin = (args: IpluginInputArgs): IpluginOutputArgs => { streams.forEach((stream, index) => { if (stream.codec_type === 'audio') { + const dispositions = (stream as IStreamDisposition).disposition; if ((stream.tags?.language ?? '') === languageCode && (stream.channels ?? 0) === channels && !defaultSet) { args.jobLog(`Setting stream ${index} (language ${languageCode}, channels ${channels}) has default`); - const disposition = getFFMPEGDisposition(stream as IStreamDisposition, true); - args.jobLog(`Original ${JSON.stringify(stream.disposition ?? {})}; new ${disposition}`); - stream.outputArgs.push(`-c:${index}`, 'copy', `-disposition:${index}`, disposition); + stream.outputArgs.push( + `-c:${index}`, + 'copy', + `-disposition:${index}`, + getFFMPEGDisposition(args, true, dispositions), + ); defaultSet = true; } else { - const disposition = getFFMPEGDisposition(stream as IStreamDisposition, false); - args.jobLog(`Original ${JSON.stringify(stream.disposition ?? {})}}; new ${disposition}`); - stream.outputArgs.push(`-c:${index}`, 'copy', `-disposition:${index}`, disposition); + stream.outputArgs.push( + `-c:${index}`, + 'copy', + `-disposition:${index}`, + getFFMPEGDisposition(args, false, dispositions), + ); } } });