aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpukkandan <pukkandan@gmail.com>2020-11-13 02:40:51 +0530
committerpukkandan <pukkandan@gmail.com>2020-11-13 02:44:47 +0530
commit9a68de12179c92b578fd00e16ff3ca63aab94c94 (patch)
tree4afe37ebf97243a9273dbc3c49c723c36c63a199
parentd052b9a112fb7ae749a829dceba6e3289663a303 (diff)
downloadhypervideo-pre-9a68de12179c92b578fd00e16ff3ca63aab94c94.tar.lz
hypervideo-pre-9a68de12179c92b578fd00e16ff3ca63aab94c94.tar.xz
hypervideo-pre-9a68de12179c92b578fd00e16ff3ca63aab94c94.zip
Pre-check video IDs in the archive before downloading
-rw-r--r--youtube_dlc/YoutubeDL.py12
1 files changed, 11 insertions, 1 deletions
diff --git a/youtube_dlc/YoutubeDL.py b/youtube_dlc/YoutubeDL.py
index dd55ba0f2..373e83715 100644
--- a/youtube_dlc/YoutubeDL.py
+++ b/youtube_dlc/YoutubeDL.py
@@ -821,12 +821,22 @@ class YoutubeDL(object):
if not ie.suitable(url):
continue
- ie = self.get_info_extractor(ie.ie_key())
+ ie_key = ie.ie_key()
+ ie = self.get_info_extractor(ie_key)
if not ie.working():
self.report_warning('The program functionality for this site has been marked as broken, '
'and will probably not work.')
try:
+ try:
+ temp_id = ie.extract_id(url) if callable(getattr(ie, 'extract_id', None)) else ie._match_id(url)
+ except AssertionError:
+ temp_id = None
+ if temp_id is not None and self.in_download_archive({'id': temp_id, 'ie_key': ie_key}):
+ self.to_screen("[download] [%s] %s has already been recorded in archive" % (
+ ie_key, temp_id))
+ break
+
ie_result = ie.extract(url)
if ie_result is None: # Finished already (backwards compatibility; listformats and friends should be moved here)
break