diff options
Diffstat (limited to 'youtube_dl/extractor')
| -rw-r--r-- | youtube_dl/extractor/metacafe.py | 20 | 
1 files changed, 12 insertions, 8 deletions
diff --git a/youtube_dl/extractor/metacafe.py b/youtube_dl/extractor/metacafe.py index 6436c05a3..96a4f1018 100644 --- a/youtube_dl/extractor/metacafe.py +++ b/youtube_dl/extractor/metacafe.py @@ -134,6 +134,7 @@ class MetacafeIE(InfoExtractor):          # Extract URL, uploader and title from webpage          self.report_extraction(video_id) +        video_url = None          mobj = re.search(r'(?m)&mediaURL=([^&]+)', webpage)          if mobj is not None:              mediaURL = compat_urllib_parse.unquote(mobj.group(1)) @@ -146,16 +147,17 @@ class MetacafeIE(InfoExtractor):              else:                  gdaKey = mobj.group(1)                  video_url = '%s?__gda__=%s' % (mediaURL, gdaKey) -        else: +        if video_url is None:              mobj = re.search(r'<video src="([^"]+)"', webpage)              if mobj:                  video_url = mobj.group(1)                  video_ext = 'mp4' -            else: -                mobj = re.search(r' name="flashvars" value="(.*?)"', webpage) -                if mobj is None: -                    raise ExtractorError('Unable to extract media URL') -                vardict = compat_parse_qs(mobj.group(1)) +        if video_url is None: +            flashvars = self._search_regex( +                r' name="flashvars" value="(.*?)"', webpage, 'flashvars', +                default=None) +            if flashvars: +                vardict = compat_parse_qs(flashvars)                  if 'mediaData' not in vardict:                      raise ExtractorError('Unable to extract media URL')                  mobj = re.search( @@ -166,7 +168,9 @@ class MetacafeIE(InfoExtractor):                  video_url = '%s?__gda__=%s' % (mediaURL, mobj.group('key'))                  video_ext = determine_ext(video_url) -        video_title = self._html_search_regex(r'(?im)<title>(.*) - Video</title>', webpage, 'title') + +        video_title = self._html_search_regex( +            r'(?im)<title>(.*) - Video</title>', webpage, 'title')          description = self._og_search_description(webpage)          thumbnail = self._og_search_thumbnail(webpage)          video_uploader = self._html_search_regex( @@ -184,7 +188,7 @@ class MetacafeIE(InfoExtractor):              'description': description,              'uploader': video_uploader,              'title': video_title, -            'thumbnail':thumbnail, +            'thumbnail': thumbnail,              'ext': video_ext,              'age_limit': age_limit,          }  | 
