diff options
author | pukkandan <pukkandan@gmail.com> | 2020-11-13 02:40:51 +0530 |
---|---|---|
committer | pukkandan <pukkandan@gmail.com> | 2020-11-13 02:44:47 +0530 |
commit | 9a68de12179c92b578fd00e16ff3ca63aab94c94 (patch) | |
tree | 4afe37ebf97243a9273dbc3c49c723c36c63a199 | |
parent | d052b9a112fb7ae749a829dceba6e3289663a303 (diff) | |
download | hypervideo-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.py | 12 |
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 |