diff options
| author | Philipp Hagemeister <phihag@phihag.de> | 2013-01-01 20:27:53 +0100 | 
|---|---|---|
| committer | Philipp Hagemeister <phihag@phihag.de> | 2013-01-01 20:27:53 +0100 | 
| commit | 1c256f7047051bf351ed5aedb95d8e705685a06b (patch) | |
| tree | e507b073c6cb78f91e81f1b7bff86b8d8c8dbd94 | |
| parent | a34dd63bebf2140d7df7082c49857fc3b6dc410e (diff) | |
ExtractorError for errors during extraction
| -rw-r--r-- | youtube_dl/FileDownloader.py | 22 | ||||
| -rwxr-xr-x | youtube_dl/InfoExtractors.py | 3 | ||||
| -rw-r--r-- | youtube_dl/utils.py | 11 | 
3 files changed, 29 insertions, 7 deletions
| diff --git a/youtube_dl/FileDownloader.py b/youtube_dl/FileDownloader.py index ebc2552df..756fc72ec 100644 --- a/youtube_dl/FileDownloader.py +++ b/youtube_dl/FileDownloader.py @@ -210,7 +210,7 @@ class FileDownloader(object):          """Checks if the output template is fixed."""          return (re.search(u'(?u)%\\(.+?\\)s', self.params['outtmpl']) is None) -    def trouble(self, message=None): +    def trouble(self, message=None, tb=None):          """Determine action to take when a download problem appears.          Depending on if the downloader has been configured to ignore @@ -220,7 +220,9 @@ class FileDownloader(object):          if message is not None:              self.to_stderr(message)          if self.params.get('verbose'): -            self.to_stderr(u''.join(traceback.format_list(traceback.extract_stack()))) +            if tb is None: +                tb = u''.join(traceback.format_list(traceback.extract_stack())) +            self.to_stderr(tb)          if not self.params.get('ignoreerrors', False):              raise DownloadError(message)          self._download_retcode = 1 @@ -485,14 +487,24 @@ class FileDownloader(object):                  # Warn if the _WORKING attribute is False                  if not ie.working(): -                    self.trouble(u'WARNING: the program functionality for this site has been marked as broken, ' -                                 u'and will probably not work. If you want to go on, use the -i option.') +                    self.to_stderr(u'WARNING: the program functionality for this site has been marked as broken, ' +                                   u'and will probably not work. If you want to go on, use the -i option.')                  # Suitable InfoExtractor found                  suitable_found = True                  # Extract information from URL and process it -                videos = ie.extract(url) +                try: +                    videos = ie.extract(url) +                except ExtractorError as de: # An error we somewhat expected +                    self.trouble(u'ERROR: ' + compat_str(de), compat_str(u''.join(traceback.format_tb(de.traceback)))) +                    break +                except Exception as e: +                    if self.params.get('ignoreerrors', False): +                        self.trouble(u'ERROR: ' + compat_str(e), tb=compat_str(traceback.format_exc())) +                        break +                    else: +                        raise                  if len(videos or []) > 1 and self.fixed_template():                      raise SameFileError(self.params['outtmpl']) diff --git a/youtube_dl/InfoExtractors.py b/youtube_dl/InfoExtractors.py index 18326e294..0c101e704 100755 --- a/youtube_dl/InfoExtractors.py +++ b/youtube_dl/InfoExtractors.py @@ -3808,8 +3808,7 @@ class UstreamIE(InfoExtractor):              webpage_bytes = urlh.read()              webpage = webpage_bytes.decode('utf-8', 'ignore')          except (compat_urllib_error.URLError, compat_http_client.HTTPException, socket.error) as err: -            self._downloader.trouble(u'ERROR: unable to download webpage: %s' % compat_str(err)) -            return +            raise ExtractorError(u'unable to download webpage: %s' % compat_str(err))          m = re.search(r'data-title="(?P<title>.+)"',webpage)          title = m.group('title')          m = re.search(r'<a class="state" data-content-type="channel" data-content-id="(?P<uploader>\d+)"',webpage) diff --git a/youtube_dl/utils.py b/youtube_dl/utils.py index e9336bcdd..91e180326 100644 --- a/youtube_dl/utils.py +++ b/youtube_dl/utils.py @@ -410,6 +410,17 @@ def encodeFilename(s):      else:          return s.encode(sys.getfilesystemencoding(), 'ignore') + +class ExtractorError(Exception): +    """Error during info extraction.""" +    def __init__(self, msg, tb=None): +        """ tb is the original traceback (so that it can be printed out) """ +        super(ExtractorError, self).__init__(msg) +        if tb is None: +            tb = sys.exc_info()[2] +        self.traceback = tb + +  class DownloadError(Exception):      """Download Error exception. | 
