FFmpegEmbedSubtitlePP: don't fail if the video doesn't have an audio stream (fixes...
authorJaime Marquínez Ferrándiz <jaime.marquinez.ferrandiz@gmail.com>
Fri, 16 Jan 2015 12:29:01 +0000 (13:29 +0100)
committerJaime Marquínez Ferrándiz <jaime.marquinez.ferrandiz@gmail.com>
Fri, 16 Jan 2015 12:29:01 +0000 (13:29 +0100)
Instead of specifying which streams ffmpeg must copy, we tell it to copy all.

youtube_dl/postprocessor/ffmpeg.py

index 26b99e43c33bd4bcebea171a9df71969273a1cc8..a752777780605a0e8ccd060f35feba2ba15aad2e 100644 (file)
@@ -475,7 +475,13 @@ class FFmpegEmbedSubtitlePP(FFmpegPostProcessor):
         filename = information['filepath']
         input_files = [filename] + [subtitles_filename(filename, lang, self._subformat) for lang in sub_langs]
 
-        opts = ['-map', '0:0', '-map', '0:1', '-c:v', 'copy', '-c:a', 'copy']
+        opts = [
+            '-map', '0',
+            '-c', 'copy',
+            # Don't copy the existing subtitles, we may be running the
+            # postprocessor a second time
+            '-map', '-0:s',
+        ]
         for (i, lang) in enumerate(sub_langs):
             opts.extend(['-map', '%d:0' % (i + 1), '-c:s:%d' % i, 'mov_text'])
             lang_code = self._conver_lang_code(lang)