|
|
@ -15,7 +15,7 @@ class BaseWorkflow(BaseStructure):
|
|
|
|
task_pool (list): A list to store tasks.
|
|
|
|
task_pool (list): A list to store tasks.
|
|
|
|
|
|
|
|
|
|
|
|
Methods:
|
|
|
|
Methods:
|
|
|
|
add(task: Task = None, tasks: List[Task] = None, *args, **kwargs):
|
|
|
|
add(task: Task = None, tasks: List[Task] = None, *args, **kwargs):
|
|
|
|
Adds a task or a list of tasks to the task pool.
|
|
|
|
Adds a task or a list of tasks to the task pool.
|
|
|
|
run():
|
|
|
|
run():
|
|
|
|
Abstract method to run the workflow.
|
|
|
|
Abstract method to run the workflow.
|
|
|
@ -24,8 +24,14 @@ class BaseWorkflow(BaseStructure):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super().__init__(*args, **kwargs)
|
|
|
|
super().__init__(*args, **kwargs)
|
|
|
|
self.task_pool = []
|
|
|
|
self.task_pool = []
|
|
|
|
|
|
|
|
|
|
|
|
def add(self, task: Task = None, tasks: List[Task] = None, *args, **kwargs):
|
|
|
|
def add(
|
|
|
|
|
|
|
|
self,
|
|
|
|
|
|
|
|
task: Task = None,
|
|
|
|
|
|
|
|
tasks: List[Task] = None,
|
|
|
|
|
|
|
|
*args,
|
|
|
|
|
|
|
|
**kwargs,
|
|
|
|
|
|
|
|
):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
Adds a task or a list of tasks to the task pool.
|
|
|
|
Adds a task or a list of tasks to the task pool.
|
|
|
|
|
|
|
|
|
|
|
@ -41,21 +47,23 @@ class BaseWorkflow(BaseStructure):
|
|
|
|
elif tasks:
|
|
|
|
elif tasks:
|
|
|
|
self.task_pool.extend(tasks)
|
|
|
|
self.task_pool.extend(tasks)
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
raise ValueError("You must provide a task or a list of tasks")
|
|
|
|
raise ValueError(
|
|
|
|
|
|
|
|
"You must provide a task or a list of tasks"
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
def run(self):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
Abstract method to run the workflow.
|
|
|
|
Abstract method to run the workflow.
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
raise NotImplementedError("You must implement this method")
|
|
|
|
raise NotImplementedError("You must implement this method")
|
|
|
|
|
|
|
|
|
|
|
|
def __sequential_loop(self):
|
|
|
|
def __sequential_loop(self):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
Abstract method for the sequential loop.
|
|
|
|
Abstract method for the sequential loop.
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
# raise NotImplementedError("You must implement this method")
|
|
|
|
# raise NotImplementedError("You must implement this method")
|
|
|
|
pass
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
def __log(self, message: str):
|
|
|
|
def __log(self, message: str):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
Logs a message if verbose mode is enabled.
|
|
|
|
Logs a message if verbose mode is enabled.
|
|
|
@ -65,13 +73,13 @@ class BaseWorkflow(BaseStructure):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
if self.verbose:
|
|
|
|
if self.verbose:
|
|
|
|
print(message)
|
|
|
|
print(message)
|
|
|
|
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
def __str__(self):
|
|
|
|
return f"Workflow with {len(self.task_pool)} tasks"
|
|
|
|
return f"Workflow with {len(self.task_pool)} tasks"
|
|
|
|
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
def __repr__(self):
|
|
|
|
return f"Workflow with {len(self.task_pool)} tasks"
|
|
|
|
return f"Workflow with {len(self.task_pool)} tasks"
|
|
|
|
|
|
|
|
|
|
|
|
def reset(self) -> None:
|
|
|
|
def reset(self) -> None:
|
|
|
|
"""Resets the workflow by clearing the results of each task."""
|
|
|
|
"""Resets the workflow by clearing the results of each task."""
|
|
|
|
try:
|
|
|
|
try:
|
|
|
@ -193,7 +201,6 @@ class BaseWorkflow(BaseStructure):
|
|
|
|
),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def save_workflow_state(
|
|
|
|
def save_workflow_state(
|
|
|
|
self,
|
|
|
|
self,
|
|
|
|
filepath: Optional[str] = "sequential_workflow_state.json",
|
|
|
|
filepath: Optional[str] = "sequential_workflow_state.json",
|
|
|
@ -240,7 +247,7 @@ class BaseWorkflow(BaseStructure):
|
|
|
|
"red",
|
|
|
|
"red",
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def add_objective_to_workflow(self, task: str, **kwargs) -> None:
|
|
|
|
def add_objective_to_workflow(self, task: str, **kwargs) -> None:
|
|
|
|
"""Adds an objective to the workflow."""
|
|
|
|
"""Adds an objective to the workflow."""
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|