aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkayb94 <30302445+kayb94@users.noreply.github.com>2017-09-22 22:49:48 +0000
committerSergey M <dstftw@gmail.com>2017-09-23 05:49:48 +0700
commit9ce1ac404648142139f8b231c674d434ad4f9ffe (patch)
treec5e9d57084dd1fd848ce000b4bd7b3378117833b
parent095774e59130c999ed8ce132f80a7164c5ee39a7 (diff)
[generic] Fix support for multiple HTML5 videos on one page (closes #14080)
-rw-r--r--youtube_dl/extractor/generic.py22
1 files changed, 19 insertions, 3 deletions
diff --git a/youtube_dl/extractor/generic.py b/youtube_dl/extractor/generic.py
index b83c18380..7d0edf09c 100644
--- a/youtube_dl/extractor/generic.py
+++ b/youtube_dl/extractor/generic.py
@@ -1879,6 +1879,15 @@ class GenericIE(InfoExtractor):
'title': 'Building A Business Online: Principal Chairs Q & A',
},
},
+ {
+ # multiple HTML5 videos on one page
+ 'url': 'https://www.paragon-software.com/home/rk-free/keyscenarios.html',
+ 'info_dict': {
+ 'id': 'keyscenarios',
+ 'title': 'Rescue Kit 14 Free Edition - Getting started',
+ },
+ 'playlist_count': 4,
+ }
# {
# # TODO: find another test
# # http://schema.org/VideoObject
@@ -2849,13 +2858,20 @@ class GenericIE(InfoExtractor):
# Look for HTML5 media
entries = self._parse_html5_media_entries(url, webpage, video_id, m3u8_id='hls')
if entries:
- for entry in entries:
- entry.update({
+ if len(entries) == 1:
+ entries[0].update({
'id': video_id,
'title': video_title,
})
+ else:
+ for num, entry in enumerate(entries, start=1):
+ entry.update({
+ 'id': '%s-%s' % (video_id, num),
+ 'title': '%s (%d)' % (video_title, num),
+ })
+ for entry in entries:
self._sort_formats(entry['formats'])
- return self.playlist_result(entries)
+ return self.playlist_result(entries, video_id, video_title)
jwplayer_data = self._find_jwplayer_data(
webpage, video_id, transform_source=js_to_json)