| 123456789101112131415161718192021222324252627282930313233 |
- from dataclasses import dataclass, field
- from opendevin.controller.state.task import RootTask
- from opendevin.events.action import (
- Action,
- MessageAction,
- )
- from opendevin.events.observation import (
- CmdOutputObservation,
- Observation,
- )
- @dataclass
- class State:
- root_task: RootTask = field(default_factory=RootTask)
- iteration: int = 0
- max_iterations: int = 100
- # number of characters we have sent to and received from LLM so far for current task
- num_of_chars: int = 0
- background_commands_obs: list[CmdOutputObservation] = field(default_factory=list)
- history: list[tuple[Action, Observation]] = field(default_factory=list)
- updated_info: list[tuple[Action, Observation]] = field(default_factory=list)
- inputs: dict = field(default_factory=dict)
- outputs: dict = field(default_factory=dict)
- def get_current_user_intent(self):
- # TODO: this is used to understand the user's main goal, but it's possible
- # the latest message is an interruption. We should look for a space where
- # the agent goes to FINISHED, and then look for the next user message.
- for action, obs in reversed(self.history):
- if isinstance(action, MessageAction) and action.source == 'user':
- return action.content
|