diff options
Diffstat (limited to 'youtube_dl/InfoExtractors.py')
| -rwxr-xr-x | youtube_dl/InfoExtractors.py | 47 | 
1 files changed, 33 insertions, 14 deletions
| diff --git a/youtube_dl/InfoExtractors.py b/youtube_dl/InfoExtractors.py index 835428f32..dd4a776e4 100755 --- a/youtube_dl/InfoExtractors.py +++ b/youtube_dl/InfoExtractors.py @@ -134,6 +134,24 @@ class InfoExtractor(object):              encoding = 'utf-8'          webpage_bytes = urlh.read()          return webpage_bytes.decode(encoding, 'replace') +         +    #Methods for following #608 +    #They set the correct value of the '_type' key +    def video_result(self, video_info): +        """Returns a video""" +        video_info['_type'] = 'video' +        return video_info +    def url_result(self, url, ie=None): +        """Returns a url that points to a page that should be processed""" +        #TODO: ie should be the class used for getting the info +        video_info = {'_type': 'url', +                      'url': url} +        return video_info +    def playlist_result(self, entries): +        """Returns a playlist""" +        video_info = {'_type': 'playlist', +                      'entries': entries} +        return video_info  class YoutubeIE(InfoExtractor): @@ -1331,7 +1349,7 @@ class GenericIE(InfoExtractor):          self._downloader.to_screen(u'[redirect] Following redirect to %s' % new_url)      def _test_redirect(self, url): -        """Check if it is a redirect, like url shorteners, in case restart chain.""" +        """Check if it is a redirect, like url shorteners, in case return the new url."""          class HeadRequest(compat_urllib_request.Request):              def get_method(self):                  return "HEAD" @@ -1382,11 +1400,11 @@ class GenericIE(InfoExtractor):              return False          self.report_following_redirect(new_url) -        self._downloader.download([new_url]) -        return True +        return new_url      def _real_extract(self, url): -        if self._test_redirect(url): return +        new_url = self._test_redirect(url) +        if new_url: return [self.url_result(new_url)]          video_id = url.split('/')[-1]          try: @@ -1789,9 +1807,8 @@ class YoutubePlaylistIE(InfoExtractor):          else:              self._downloader.to_screen(u'[youtube] PL %s: Found %i videos, downloading %i' % (playlist_id, total, len(videos))) -        for video in videos: -            self._downloader.download([video]) -        return +        url_results = [self.url_result(url) for url in videos] +        return [self.playlist_result(url_results)]  class YoutubeChannelIE(InfoExtractor): @@ -1841,9 +1858,9 @@ class YoutubeChannelIE(InfoExtractor):          self._downloader.to_screen(u'[youtube] Channel %s: Found %i videos' % (channel_id, len(video_ids))) -        for id in video_ids: -            self._downloader.download(['http://www.youtube.com/watch?v=%s' % id]) -        return +        urls = ['http://www.youtube.com/watch?v=%s' % id for id in video_ids] +        url_entries = [self.url_result(url) for url in urls] +        return [self.playlist_result(url_entries)]  class YoutubeUserIE(InfoExtractor): @@ -1925,8 +1942,9 @@ class YoutubeUserIE(InfoExtractor):          self._downloader.to_screen(u"[youtube] user %s: Collected %d video ids (downloading %d of them)" %                  (username, all_ids_count, len(video_ids))) -        for video_id in video_ids: -            self._downloader.download(['http://www.youtube.com/watch?v=%s' % video_id]) +        urls = ['http://www.youtube.com/watch?v=%s' % video_id for video_id in video_ids] +        url_results = [self.url_result(url) for url in urls] +        return [self.playlist_result(url_results)]  class BlipTVUserIE(InfoExtractor): @@ -2016,8 +2034,9 @@ class BlipTVUserIE(InfoExtractor):          self._downloader.to_screen(u"[%s] user %s: Collected %d video ids (downloading %d of them)" %                  (self.IE_NAME, username, all_ids_count, len(video_ids))) -        for video_id in video_ids: -            self._downloader.download([u'http://blip.tv/'+video_id]) +        urls = [u'http://blip.tv/%s' % video_id for video_id in video_ids] +        url_entries = [self.url_result(url) for url in urls] +        return [self.playlist_result(url_entries)]  class DepositFilesIE(InfoExtractor): | 
