diff options
author | Philipp Hagemeister <phihag@phihag.de> | 2014-01-03 13:06:22 +0100 |
---|---|---|
committer | Philipp Hagemeister <phihag@phihag.de> | 2014-01-03 13:06:22 +0100 |
commit | cc14dfb8ecb73be9905f5adab2d7f1f92d435e2f (patch) | |
tree | 2cc586185347a134c7f955e00161802605a4de3f | |
parent | 9887c9b2d62258645de73aa69f18bfff5f540174 (diff) | |
parent | 1e923b0d2991c5d7425a38338e1487c7a431b9e1 (diff) |
Merge remote-tracking branch 'dstftw/macgamestore'
-rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
-rw-r--r-- | youtube_dl/extractor/macgamestore.py | 40 |
2 files changed, 41 insertions, 0 deletions
diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index 9c1374373..31bbda46f 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -102,6 +102,7 @@ from .kickstarter import KickStarterIE from .keek import KeekIE from .liveleak import LiveLeakIE from .livestream import LivestreamIE, LivestreamOriginalIE +from .macgamestore import MacGameStoreIE from .mdr import MDRIE from .metacafe import MetacafeIE from .metacritic import MetacriticIE diff --git a/youtube_dl/extractor/macgamestore.py b/youtube_dl/extractor/macgamestore.py new file mode 100644 index 000000000..4541f6d66 --- /dev/null +++ b/youtube_dl/extractor/macgamestore.py @@ -0,0 +1,40 @@ +import re + +from .common import InfoExtractor +from ..utils import ExtractorError + + +class MacGameStoreIE(InfoExtractor): + IE_NAME = u'macgamestore' + IE_DESC = u'MacGameStore trailers' + _VALID_URL = r'https?://www\.macgamestore\.com/mediaviewer\.php\?trailer=(?P<id>\d+)' + + _TEST = { + u'url': u'http://www.macgamestore.com/mediaviewer.php?trailer=2450', + u'file': u'2450.m4v', + u'md5': u'8649b8ea684b6666b4c5be736ecddc61', + u'info_dict': { + u'title': u'Crow', + } + } + + def _real_extract(self, url): + mobj = re.match(self._VALID_URL, url) + video_id = mobj.group('id') + + webpage = self._download_webpage(url, video_id, u'Downloading trailer page') + + if re.search(r'>Missing Media<', webpage) is not None: + raise ExtractorError(u'Trailer %s does not exist' % video_id, expected=True) + + mobj = re.search(r'<title>MacGameStore: (?P<title>.*?) Trailer</title>', webpage) + video_title = mobj.group('title') + + mobj = re.search(r'(?s)<div\s+id="video-player".*?href="(?P<video>[^"]+)"\s*>', webpage) + video_url = mobj.group('video') + + return { + 'id': video_id, + 'url': video_url, + 'title': video_title + }
\ No newline at end of file |