implement 'parent-directory' option (#551)

This commit is contained in:
Mike Fährmann 2020-01-29 18:32:37 +01:00
parent ae07f92f7e
commit 56f1c96168
No known key found for this signature in database
GPG Key ID: 5680CA389D365A88
5 changed files with 31 additions and 7 deletions

View File

@ -108,6 +108,17 @@ Description Directory path used as the base for all download destinations.
=========== =====
extractor.*.parent-directory
----------------------------
=========== =====
Type ``bool``
Default ``false``
Description Use an extractor's current target directory as
`base-directory <extractor.*.base-directory_>`__
for any spawned child extractors.
=========== =====
extractor.*.path-restrict
-------------------------
=========== =====

View File

@ -39,6 +39,7 @@ class Extractor():
self._cookiefile = None
self._cookiejar = self.session.cookies
self._parentdir = ""
self._retries = self.config("retries", 4)
self._timeout = self.config("timeout", 30)
self._verify = self.config("verify", True)

View File

@ -31,6 +31,7 @@ class RedditExtractor(Extractor):
match_subreddit = RedditSubredditExtractor.pattern.match
match_user = RedditUserExtractor.pattern.match
parentdir = self.config("parent-directory")
submissions = self.submissions()
visited = set()
depth = 0
@ -56,6 +57,8 @@ class RedditExtractor(Extractor):
yield Message.Url, "ytdl:" + url, submission
elif not submission["is_self"]:
urls.append((url, submission))
elif parentdir:
yield Message.Directory, comments[0]
if self.api.comments:
if submission:

View File

@ -182,7 +182,14 @@ class DownloadJob(Job):
self.downloaders = {}
self.postprocessors = None
self.out = output.select()
self.visited = parent.visited if parent else set()
if parent:
self.visited = parent.visited
pfmt = parent.pathfmt
if pfmt and parent.extractor.config("parent-directory"):
self.extractor._parentdir = pfmt.directory
else:
self.visited = set()
def handle_url(self, url, kwdict, fallback=None):
"""Download the resource specified in 'url'"""

View File

@ -627,6 +627,8 @@ class PathFormat():
self.delete = False
self.path = self.realpath = self.temppath = ""
basedir = extractor._parentdir
if not basedir:
basedir = expand_path(
extractor.config("base-directory", (".", "gallery-dl")))
if os.altsep and os.altsep in basedir: