Fix VAEDecode -> Preview not being executed first.

This commit is contained in:
comfyanonymous 2024-08-17 04:08:54 -04:00
parent cd5017c1c9
commit 858d51f91a

View File

@ -176,19 +176,35 @@ class ExecutionList(TopologicalSort):
"current_inputs": [] "current_inputs": []
} }
return None, error_details, ex return None, error_details, ex
next_node = available[0]
self.staged_node_id = self.ux_friendly_pick_node(available)
return self.staged_node_id, None, None
def ux_friendly_pick_node(self, node_list):
# If an output node is available, do that first. # If an output node is available, do that first.
# Technically this has no effect on the overall length of execution, but it feels better as a user # Technically this has no effect on the overall length of execution, but it feels better as a user
# for a PreviewImage to display a result as soon as it can # for a PreviewImage to display a result as soon as it can
# Some other heuristics could probably be used here to improve the UX further. # Some other heuristics could probably be used here to improve the UX further.
for node_id in available: def is_output(node_id):
class_type = self.dynprompt.get_node(node_id)["class_type"] class_type = self.dynprompt.get_node(node_id)["class_type"]
class_def = nodes.NODE_CLASS_MAPPINGS[class_type] class_def = nodes.NODE_CLASS_MAPPINGS[class_type]
if hasattr(class_def, 'OUTPUT_NODE') and class_def.OUTPUT_NODE == True: if hasattr(class_def, 'OUTPUT_NODE') and class_def.OUTPUT_NODE == True:
next_node = node_id return True
break return False
self.staged_node_id = next_node
return self.staged_node_id, None, None for node_id in node_list:
if is_output(node_id):
return node_id
#This should handle the VAEDecode -> preview case
for node_id in node_list:
for blocked_node_id in self.blocking[node_id]:
if is_output(blocked_node_id):
return node_id
#Do we want to look deeper?
return node_list[0]
def unstage_node_execution(self): def unstage_node_execution(self):
assert self.staged_node_id is not None assert self.staged_node_id is not None