diff options
Diffstat (limited to 'youtube_dl/extractor/common.py')
| -rw-r--r-- | youtube_dl/extractor/common.py | 16 | 
1 files changed, 13 insertions, 3 deletions
| diff --git a/youtube_dl/extractor/common.py b/youtube_dl/extractor/common.py index 08b8ad37c..79f6d199b 100644 --- a/youtube_dl/extractor/common.py +++ b/youtube_dl/extractor/common.py @@ -391,6 +391,16 @@ class InfoExtractor(object):              if blocked_iframe:                  msg += ' Visit %s for more details' % blocked_iframe              raise ExtractorError(msg, expected=True) +        if '<title>The URL you requested has been blocked</title>' in content[:512]: +            msg = ( +                'Access to this webpage has been blocked by Indian censorship. ' +                'Use a VPN or proxy server (with --proxy) to route around it.') +            block_msg = self._html_search_regex( +                r'</h1><p>(.*?)</p>', +                content, 'block message', default=None) +            if block_msg: +                msg += ' (Message: "%s")' % block_msg.replace('\n', ' ') +            raise ExtractorError(msg, expected=True)          return content @@ -798,8 +808,8 @@ class InfoExtractor(object):              media_nodes = manifest.findall('{http://ns.adobe.com/f4m/2.0}media')          for i, media_el in enumerate(media_nodes):              if manifest_version == '2.0': -                manifest_url = ('/'.join(manifest_url.split('/')[:-1]) + '/' -                                + (media_el.attrib.get('href') or media_el.attrib.get('url'))) +                manifest_url = ('/'.join(manifest_url.split('/')[:-1]) + '/' + +                                (media_el.attrib.get('href') or media_el.attrib.get('url')))              tbr = int_or_none(media_el.attrib.get('bitrate'))              formats.append({                  'format_id': '-'.join(filter(None, [f4m_id, 'f4m-%d' % (i if tbr is None else tbr)])), @@ -823,7 +833,7 @@ class InfoExtractor(object):              'url': m3u8_url,              'ext': ext,              'protocol': 'm3u8', -            'preference': -1, +            'preference': preference - 1 if preference else -1,              'resolution': 'multiple',              'format_note': 'Quality selection URL',          }] | 
