From 0c73e982fa596da07f23b377621ab894a9e64884 Mon Sep 17 00:00:00 2001 From: Unit 193 Date: Sun, 10 Nov 2019 22:14:10 -0500 Subject: New upstream version 1.11.1 --- gallery_dl/postprocessor/exec.py | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) (limited to 'gallery_dl/postprocessor/exec.py') diff --git a/gallery_dl/postprocessor/exec.py b/gallery_dl/postprocessor/exec.py index 19a9b87..0a56281 100644 --- a/gallery_dl/postprocessor/exec.py +++ b/gallery_dl/postprocessor/exec.py @@ -26,17 +26,26 @@ class ExecPP(PostProcessor): def __init__(self, pathfmt, options): PostProcessor.__init__(self) args = options["command"] + final = options.get("final", False) if isinstance(args, str): + if final: + self._format = self._format_args_directory + else: + self._format = self._format_args_path if "{}" not in args: args += " {}" self.args = args self.shell = True - self._format = self._format_args_string else: + self._format = self._format_args_list self.args = [util.Formatter(arg) for arg in args] self.shell = False - self._format = self._format_args_list + + if final: + self.run_after = PostProcessor.run_after + else: + self.run_final = PostProcessor.run_final if options.get("async", False): self._exec = self._exec_async @@ -44,9 +53,16 @@ class ExecPP(PostProcessor): def run_after(self, pathfmt): self._exec(self._format(pathfmt)) - def _format_args_string(self, pathfmt): + def run_final(self, pathfmt, status): + if status == 0: + self._exec(self._format(pathfmt)) + + def _format_args_path(self, pathfmt): return self.args.replace("{}", quote(pathfmt.realpath)) + def _format_args_directory(self, pathfmt): + return self.args.replace("{}", quote(pathfmt.realdirectory)) + def _format_args_list(self, pathfmt): kwdict = pathfmt.kwdict kwdict["_directory"] = pathfmt.realdirectory -- cgit v1.2.3