diff options
Diffstat (limited to 'youtube_dl/FileDownloader.py')
| -rw-r--r-- | youtube_dl/FileDownloader.py | 49 | 
1 files changed, 40 insertions, 9 deletions
| diff --git a/youtube_dl/FileDownloader.py b/youtube_dl/FileDownloader.py index 8d21a79d5..5087b4cc8 100644 --- a/youtube_dl/FileDownloader.py +++ b/youtube_dl/FileDownloader.py @@ -78,7 +78,11 @@ class FileDownloader(object):      updatetime:        Use the Last-modified header to set output file timestamps.      writedescription:  Write the video description to a .description file      writeinfojson:     Write the video description to a .info.json file -    writesubtitles:    Write the video subtitles to a .srt file +    writesubtitles:    Write the video subtitles to a file +    onlysubtitles:     Downloads only the subtitles of the video +    allsubtitles:      Downloads all the subtitles of the video +    listsubtitles:     Lists all available subtitles for the video +    subtitlesformat:   Subtitle format [sbv/srt] (default=srt)      subtitleslang:     Language of the subtitles to download      test:              Download only first bytes to test the downloader.      keepvideo:         Keep the video file after post-processing @@ -313,9 +317,9 @@ class FileDownloader(object):          """ Report that the description file is being written """          self.to_screen(u'[info] Writing video description to: ' + descfn) -    def report_writesubtitles(self, srtfn): +    def report_writesubtitles(self, sub_filename):          """ Report that the subtitles file is being written """ -        self.to_screen(u'[info] Writing video subtitles to: ' + srtfn) +        self.to_screen(u'[info] Writing video subtitles to: ' + sub_filename)      def report_writeinfojson(self, infofn):          """ Report that the metadata file has been written """ @@ -384,8 +388,11 @@ class FileDownloader(object):              filename = self.params['outtmpl'] % template_dict              return filename -        except (ValueError, KeyError) as err: -            self.report_error(u'invalid system charset or erroneous output template') +        except KeyError as err: +            self.trouble(u'ERROR: Erroneous output template') +            return None +        except ValueError as err: +            self.trouble(u'ERROR: Insufficient system charset ' + repr(preferredencoding()))              return None      def _match_entry(self, info_dict): @@ -465,14 +472,35 @@ class FileDownloader(object):          if self.params.get('writesubtitles', False) and 'subtitles' in info_dict and info_dict['subtitles']:              # subtitles download errors are already managed as troubles in relevant IE              # that way it will silently go on when used with unsupporting IE +            subtitle = info_dict['subtitles'][0] +            (sub_error, sub_lang, sub) = subtitle +            sub_format = self.params.get('subtitlesformat')              try: -                srtfn = filename.rsplit('.', 1)[0] + u'.srt' -                self.report_writesubtitles(srtfn) -                with io.open(encodeFilename(srtfn), 'w', encoding='utf-8') as srtfile: -                    srtfile.write(info_dict['subtitles']) +                sub_filename = filename.rsplit('.', 1)[0] + u'.' + sub_lang + u'.' + sub_format +                self.report_writesubtitles(sub_filename) +                with io.open(encodeFilename(sub_filename), 'w', encoding='utf-8') as subfile: +                    subfile.write(sub)              except (OSError, IOError):                  self.report_error(u'Cannot write subtitles file ' + descfn)                  return +            if self.params.get('onlysubtitles', False): +                return  + +        if self.params.get('allsubtitles', False) and 'subtitles' in info_dict and info_dict['subtitles']: +            subtitles = info_dict['subtitles'] +            sub_format = self.params.get('subtitlesformat') +            for subtitle in subtitles: +                (sub_error, sub_lang, sub) = subtitle +                try: +                    sub_filename = filename.rsplit('.', 1)[0] + u'.' + sub_lang + u'.' + sub_format +                    self.report_writesubtitles(sub_filename) +                    with io.open(encodeFilename(sub_filename), 'w', encoding='utf-8') as subfile: +                            subfile.write(sub) +                except (OSError, IOError): +                    self.trouble(u'ERROR: Cannot write subtitles file ' + descfn) +                    return +            if self.params.get('onlysubtitles', False): +                return           if self.params.get('writeinfojson', False):              infofn = filename + u'.info.json' @@ -532,6 +560,9 @@ class FileDownloader(object):                  except ExtractorError as de: # An error we somewhat expected                      self.trouble(u'ERROR: ' + compat_str(de), de.format_traceback())                      break +                except MaxDownloadsReached: +                    self.to_screen(u'[info] Maximum number of downloaded files reached.') +                    raise                  except Exception as e:                      if self.params.get('ignoreerrors', False):                          self.report_error(u'' + compat_str(e), tb=compat_str(traceback.format_exc())) | 
