Compare commits

...

2 Commits

Author SHA1 Message Date
Deleted user
aee8a67905
Merge 84ccbf171e into e1b3fa242c 2024-07-28 01:28:27 +09:00
kikuyan
84ccbf171e [postprocessor/ffmpeg] Allow embedding subtitles in m4a 2021-08-17 13:57:10 +09:00
2 changed files with 4 additions and 4 deletions

View File

@ -821,7 +821,7 @@ def parseOpts(overrideArguments=None):
postproc.add_option(
'--embed-subs',
action='store_true', dest='embedsubtitles', default=False,
help='Embed subtitles in the video (only for mp4, webm and mkv videos)')
help='Embed subtitles in the video or audio (only for mp4, m4a, webm and mkv files)')
postproc.add_option(
'--embed-thumbnail',
action='store_true', dest='embedthumbnail', default=False,

View File

@ -370,8 +370,8 @@ class FFmpegVideoConvertorPP(FFmpegPostProcessor):
class FFmpegEmbedSubtitlePP(FFmpegPostProcessor):
def run(self, information):
if information['ext'] not in ('mp4', 'webm', 'mkv'):
self._downloader.to_screen('[ffmpeg] Subtitles can only be embedded in mp4, webm or mkv files')
if information['ext'] not in ('mp4', 'm4a', 'webm', 'mkv'):
self._downloader.to_screen('[ffmpeg] Subtitles can only be embedded in mp4, m4a, webm or mkv files')
return [], information
subtitles = information.get('requested_subtitles')
if not subtitles:
@ -410,7 +410,7 @@ class FFmpegEmbedSubtitlePP(FFmpegPostProcessor):
# https://trac.ffmpeg.org/ticket/6016)
'-map', '-0:d',
]
if information['ext'] == 'mp4':
if information['ext'] in ('mp4', 'm4a'):
opts += ['-c:s', 'mov_text']
for (i, lang) in enumerate(sub_langs):
opts.extend(['-map', '%d:0' % (i + 1)])