mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-06-28 11:32:22 +00:00
feat(cli): note background delegate_task dispatch in _on_tool_complete
A top-level delegate_task dispatches in the background and re-enters as a fresh turn when done. Print a one-line dispatch-time note — no spinner, nothing to poll — so the idle prompt doesn't read as "nothing happened."
This commit is contained in:
parent
7f02f30b76
commit
985350dd85
2 changed files with 84 additions and 0 deletions
15
cli.py
15
cli.py
|
|
@ -10499,6 +10499,21 @@ class HermesCLI(CLIAgentSetupMixin, CLICommandsMixin):
|
|||
|
||||
def _on_tool_complete(self, tool_call_id: str, function_name: str, function_args: dict, function_result: str):
|
||||
"""Render file edits with inline diff after write-capable tools complete."""
|
||||
# A top-level delegate_task dispatches in the background and re-enters as
|
||||
# a fresh turn when done. Say so once — no spinner, nothing to poll — so
|
||||
# the idle prompt doesn't read as "nothing happened" (⛓ tracks the work).
|
||||
if function_name == "delegate_task":
|
||||
try:
|
||||
parsed = json.loads(function_result) if isinstance(function_result, str) else (function_result or {})
|
||||
except Exception:
|
||||
parsed = {}
|
||||
if isinstance(parsed, dict) and parsed.get("status") == "dispatched" and parsed.get("mode") == "background":
|
||||
n = parsed.get("count") or 1
|
||||
noun, tail = ("task", "it finishes") if n == 1 else (f"{n} tasks", "they finish")
|
||||
try:
|
||||
_cprint(f"\033[2m\u21a9 Background {noun} running — I'll resume when {tail}. Keep chatting.\033[0m")
|
||||
except Exception:
|
||||
pass
|
||||
snapshot = self._pending_edit_snapshots.pop(tool_call_id, None)
|
||||
try:
|
||||
from agent.display import render_edit_diff_with_delta
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue