Add an extractor for common mistakes (#4610)
authorPhilipp Hagemeister <phihag@phihag.de>
Thu, 1 Jan 2015 21:34:58 +0000 (22:34 +0100)
committerPhilipp Hagemeister <phihag@phihag.de>
Thu, 1 Jan 2015 21:34:58 +0000 (22:34 +0100)
youtube_dl/extractor/__init__.py
youtube_dl/extractor/commonmistakes.py [new file with mode: 0644]

index 6c5827f88dfe313c64513ba0acf7d70874620113..a95de54cbfd15ddcaab4f24d7ffb4cd378638e7d 100644 (file)
@@ -71,6 +71,7 @@ from .cnn import (
 from .collegehumor import CollegeHumorIE
 from .comedycentral import ComedyCentralIE, ComedyCentralShowsIE
 from .comcarcoff import ComCarCoffIE
+from .commonmistakes import CommonMistakesIE
 from .condenast import CondeNastIE
 from .cracked import CrackedIE
 from .criterion import CriterionIE
diff --git a/youtube_dl/extractor/commonmistakes.py b/youtube_dl/extractor/commonmistakes.py
new file mode 100644 (file)
index 0000000..75c0690
--- /dev/null
@@ -0,0 +1,29 @@
+from __future__ import unicode_literals
+
+from .common import InfoExtractor
+from ..utils import ExtractorError
+
+
+class CommonMistakesIE(InfoExtractor):
+    IE_DESC = False  # Do not list
+    _VALID_URL = r'''(?x)
+        (?:url|URL)
+    '''
+
+    _TESTS = [{
+        'url': 'url',
+        'only_matching': True,
+    }, {
+        'url': 'URL',
+        'only_matching': True,
+    }]
+
+    def _real_extract(self, url):
+        msg = (
+            'You\'ve asked youtube-dl to download the URL "%s". '
+            'That doesn\'t make any sense. '
+            'Simply remove the parameter in your command or configuration.'
+        ) % url
+        if self._downloader.params.get('verbose'):
+            msg += ' Add -v to the command line to see what arguments and configuration youtube-dl got.'
+        raise ExtractorError(msg, expected=True)