diff options
| -rw-r--r-- | youtube_dl/__init__.py | 2 | ||||
| -rw-r--r-- | youtube_dl/extractor/kickstarter.py | 37 | 
2 files changed, 31 insertions, 8 deletions
| diff --git a/youtube_dl/__init__.py b/youtube_dl/__init__.py index 0e7b9ddaf..c6a5b2b5b 100644 --- a/youtube_dl/__init__.py +++ b/youtube_dl/__init__.py @@ -633,7 +633,7 @@ def _real_main(argv=None):              if desc is False:                  continue              if hasattr(ie, 'SEARCH_KEY'): -                _SEARCHES = (u'cute kittens', u'slithering pythons', u'falling cat', u'angry poodle', u'purple fish', u'running tortoise') +                _SEARCHES = (u'cute kittens', u'slithering pythons', u'falling cat', u'angry poodle', u'purple fish', u'running tortoise', u'sleeping bunny')                  _COUNTS = (u'', u'5', u'10', u'all')                  desc += u' (Example: "%s%s:%s" )' % (ie.SEARCH_KEY, random.choice(_COUNTS), random.choice(_SEARCHES))              compat_print(desc) diff --git a/youtube_dl/extractor/kickstarter.py b/youtube_dl/extractor/kickstarter.py index 961dd1aa6..56a76380c 100644 --- a/youtube_dl/extractor/kickstarter.py +++ b/youtube_dl/extractor/kickstarter.py @@ -8,7 +8,7 @@ from .common import InfoExtractor  class KickStarterIE(InfoExtractor):      _VALID_URL = r'https?://www\.kickstarter\.com/projects/(?P<id>[^/]*)/.*' -    _TEST = { +    _TESTS = [{          'url': 'https://www.kickstarter.com/projects/1404461844/intersection-the-story-of-josh-grant?ref=home_location',          'md5': 'c81addca81327ffa66c642b5d8b08cab',          'info_dict': { @@ -18,22 +18,45 @@ class KickStarterIE(InfoExtractor):              'description': 'A unique motocross documentary that examines the '                  'life and mind of one of sports most elite athletes: Josh Grant.',          }, -    } +    }, { +        'note': 'Embedded video (not using the native kickstarter video service)', +        'url': 'https://www.kickstarter.com/projects/597507018/pebble-e-paper-watch-for-iphone-and-android/posts/659178', +        'playlist': [ +            { +                'info_dict': { +                    'id': '78704821', +                    'ext': 'mp4', +                    'uploader_id': 'pebble', +                    'uploader': 'Pebble Technology', +                    'title': 'Pebble iOS Notifications', +                } +            } +        ], +    }]      def _real_extract(self, url):          m = re.match(self._VALID_URL, url)          video_id = m.group('id')          webpage = self._download_webpage(url, video_id) -        video_url = self._search_regex(r'data-video-url="(.*?)"', -            webpage, 'video URL') -        video_title = self._html_search_regex(r'<title>(.*?)</title>', -            webpage, 'title').rpartition('— Kickstarter')[0].strip() +        title = self._html_search_regex( +            r'<title>\s*(.*?)(?:\s*— Kickstarter)?\s*</title>', +            webpage, 'title') +        video_url = self._search_regex( +            r'data-video-url="(.*?)"', +            webpage, 'video URL', default=None) +        if video_url is None:  # No native kickstarter, look for embedded videos +            return { +                '_type': 'url_transparent', +                'ie_key': 'Generic', +                'url': url, +                'title': title, +            }          return {              'id': video_id,              'url': video_url, -            'title': video_title, +            'title': title,              'description': self._og_search_description(webpage),              'thumbnail': self._og_search_thumbnail(webpage),          } | 
