aboutsummaryrefslogtreecommitdiff
path: root/modules/scripts.py
diff options
context:
space:
mode:
authorAUTOMATIC1111 <16777216c@gmail.com>2022-11-04 11:07:05 +0300
committerGitHub <noreply@github.com>2022-11-04 11:07:05 +0300
commitc250d2a08f9c379e3f46de30d975b86376a22aec (patch)
tree159b69093e4a08e47326ca6af9e473b3551d34da /modules/scripts.py
parent1b9faaa1c304cd75080d1453a5cb26b02bbdb541 (diff)
parentde64146ad2fc2030a4cd3545676f9e18c93b8b18 (diff)
Merge pull request #4182 from macrosoft/process_one
Process one
Diffstat (limited to 'modules/scripts.py')
-rw-r--r--modules/scripts.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/modules/scripts.py b/modules/scripts.py
index 28ce07f4..75e47cd2 100644
--- a/modules/scripts.py
+++ b/modules/scripts.py
@@ -73,6 +73,13 @@ class Script:
pass
+ def process_one(self, p, n, *args):
+ """
+ Same as process(), but called for every iteration
+ """
+
+ pass
+
def postprocess(self, p, processed, *args):
"""
This function is called after processing ends for AlwaysVisible scripts.
@@ -296,6 +303,15 @@ class ScriptRunner:
print(f"Error running process: {script.filename}", file=sys.stderr)
print(traceback.format_exc(), file=sys.stderr)
+ def process_one(self, p, n):
+ for script in self.alwayson_scripts:
+ try:
+ script_args = p.script_args[script.args_from:script.args_to]
+ script.process_one(p, n, *script_args)
+ except Exception:
+ print(f"Error running process_one: {script.filename}", file=sys.stderr)
+ print(traceback.format_exc(), file=sys.stderr)
+
def postprocess(self, p, processed):
for script in self.alwayson_scripts:
try: