-
Notifications
You must be signed in to change notification settings - Fork 51
Closed
Description
Decouple Shell Process Tracking from backgroundTools
Description
Currently, the backgroundTools
tracker is used to track shell processes, browser sessions, and agents in a single implementation. This creates unnecessary coupling between these different types of tools. This issue proposes to refactor the shell process tracking into its own dedicated tracker.
Proposed Changes
- Create a new
ShellTracker
class inpackages/agent/src/tools/system/shellTracker.ts
that will be responsible for tracking shell processes - Move shell-specific tracking logic from
backgroundTools.ts
to this new class - Implement a new
listShells
tool that uses the dedicatedShellTracker
- Update
shellStart.ts
andshellMessage.ts
to use the new tracker instead ofbackgroundTools
- Remove shell-related code from
backgroundTools.ts
Technical Details
- The new
ShellTracker
should maintain a registry of shell processes similar to howprocessStates
works now - It should provide methods for registering, updating, and retrieving shell processes
- The
listShells
tool should have similar filtering capabilities aslistBackgroundTools
but focused only on shell processes - The implementation should maintain backward compatibility where possible
Benefits
- Reduced coupling between different tool types
- More focused and maintainable code
- Easier to extend or modify shell-specific functionality
- Clearer separation of concerns
Acceptance Criteria
-
ShellTracker
class is implemented -
listShells
tool is implemented -
shellStart
andshellMessage
are updated to use the new tracker - Shell-specific code is removed from
backgroundTools.ts
- All tests pass
- Documentation is updated
Metadata
Metadata
Assignees
Labels
No labels