From c693db5b1a00f6f6c32bcdb4d5a276efd1c7f6a5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mike=20F=C3=A4hrmann?= Date: Wed, 12 May 2021 02:22:28 +0200 Subject: [PATCH] add '"skip": "terminate"' option Stops not only the current extractor/job, but all parent extractors/jobs as well. --- CHANGELOG.md | 2 ++ docs/configuration.rst | 8 ++++++-- gallery_dl/__init__.py | 2 ++ gallery_dl/exception.py | 8 +++++++- gallery_dl/job.py | 4 ++++ gallery_dl/version.py | 2 +- 6 files changed, 22 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 05ec91c3430..e45783bd0cc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,7 @@ # Changelog +## Unreleased + ## 1.17.4 - 2021-05-07 ### Additions - [gelbooru] add extractor for `/redirect.php` URLs ([#1530](https://github.com/mikf/gallery-dl/issues/1530)) diff --git a/docs/configuration.rst b/docs/configuration.rst index 0cd00db52e0..e2f1032e453 100644 --- a/docs/configuration.rst +++ b/docs/configuration.rst @@ -226,10 +226,14 @@ Description * ``true``: Skip downloads * ``false``: Overwrite already existing files - * ``"abort"``: Abort the current extractor run - * ``"abort:N"``: Skip downloads and abort extractor run + * ``"abort"``: Stop the current extractor run + * ``"abort:N"``: Skip downloads and stop the current extractor run after ``N`` consecutive skips + * ``"terminate"``: Stop the current extractor run, including parent extractors + * ``"terminate:N"``: Skip downloads and stop the current extractor run, + including parent extractors, after ``N`` consecutive skips + * ``"exit"``: Exit the program altogether * ``"exit:N"``: Skip downloads and exit the program after ``N`` consecutive skips diff --git a/gallery_dl/__init__.py b/gallery_dl/__init__.py index 7d64c91e085..8154afc7ec9 100644 --- a/gallery_dl/__init__.py +++ b/gallery_dl/__init__.py @@ -249,6 +249,8 @@ def main(): retval |= jobtype(url.value).run() else: retval |= jobtype(url).run() + except exception.TerminateExtraction: + pass except exception.NoExtractorError: log.error("No suitable extractor found for '%s'", url) retval |= 64 diff --git a/gallery_dl/exception.py b/gallery_dl/exception.py index f553d419fb8..0433dc9728d 100644 --- a/gallery_dl/exception.py +++ b/gallery_dl/exception.py @@ -1,6 +1,6 @@ # -*- coding: utf-8 -*- -# Copyright 2015-2019 Mike Fährmann +# Copyright 2015-2021 Mike Fährmann # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License version 2 as @@ -23,6 +23,7 @@ +-- FilterError +-- NoExtractorError +-- StopExtraction + +-- TerminateExtraction """ @@ -109,3 +110,8 @@ def __init__(self, message=None, *args): GalleryDLException.__init__(self) self.message = message % args if args else message self.code = 1 if message else 0 + + +class TerminateExtraction(GalleryDLException): + """Terminate data extraction""" + code = 0 diff --git a/gallery_dl/job.py b/gallery_dl/job.py index 00688d45b86..64d2979830b 100644 --- a/gallery_dl/job.py +++ b/gallery_dl/job.py @@ -80,6 +80,8 @@ def run(self): if exc.message: log.error(exc.message) self.status |= exc.code + except exception.TerminateExtraction: + raise except exception.GalleryDLException as exc: log.error("%s: %s", exc.__class__.__name__, exc) self.status |= exc.code @@ -400,6 +402,8 @@ def initialize(self, kwdict=None): skip, _, smax = skip.partition(":") if skip == "abort": self._skipexc = exception.StopExtraction + elif skip == "terminate": + self._skipexc = exception.TerminateExtraction elif skip == "exit": self._skipexc = sys.exit self._skipcnt = 0 diff --git a/gallery_dl/version.py b/gallery_dl/version.py index 031c4ebf73c..07403811ece 100644 --- a/gallery_dl/version.py +++ b/gallery_dl/version.py @@ -6,4 +6,4 @@ # it under the terms of the GNU General Public License version 2 as # published by the Free Software Foundation. -__version__ = "1.17.4" +__version__ = "1.17.5-dev"