Files
picoclaw/.ralph/progress.txt
yinwm b573d61a58 feat: US-005 - Update AgentLoop tool result processing logic
- Modify runLLMIteration to return lastToolResult for later decisions
- Send tool.ForUser content to user immediately when Silent=false
- Use tool.ForLLM for LLM context
- Implement Silent flag check to suppress user messages
- Add lastToolResult tracking for async callback support (US-008)

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-12 19:34:32 +08:00

87 lines
4.4 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# Ralph Progress: tool-result-refactor
# Branch: ralph/tool-result-refactor
## Overview
Tool 返回值结构化重构 - 将 Tool 接口返回值从 (string, error) 改为结构化 ToolResult支持异步任务删除字符串匹配黑魔法
## Progress
### Completed (4/21)
- US-001: Add ToolResult struct and helper functions
- US-002: Modify Tool interface to return *ToolResult
- US-004: Delete isToolConfirmationMessage function (already removed in commit 488e7a9)
- US-005: Update AgentLoop tool result processing logic
### In Progress
### Blocked
### Pending
| ID | Title | Status | Notes |
|----|-------|--------|-------|
| US-003 | Modify ToolRegistry to process ToolResult | Pending | registry.go already updated |
| US-004 | Delete isToolConfirmationMessage function | Completed | Already removed in commit 488e7a9 |
| US-005 | Update AgentLoop tool result processing logic | Completed | No test files in pkg/agent yet |
| US-006 | Add AsyncCallback type and AsyncTool interface | Pending | |
| US-007 | Heartbeat async task execution support | Pending | |
| US-008 | Inject callback into async tools in AgentLoop | Pending | |
| US-009 | State save atomicity - SetLastChannel | Pending | |
| US-010 | Update RecordLastChannel to use atomic save | Pending | |
| US-011 | Refactor MessageTool to use ToolResult | Completed | |
| US-012 | Refactor ShellTool to use ToolResult | Completed | |
| US-013 | Refactor FilesystemTool to use ToolResult | Completed | |
| US-014 | Refactor WebTool to use ToolResult | Completed | |
| US-015 | Refactor EditTool to use ToolResult | Completed | |
| US-016 | Refactor CronTool to use ToolResult | Pending | |
| US-017 | Refactor SpawnTool to use AsyncTool and callbacks | Pending | |
| US-018 | Refactor SubagentTool to use ToolResult | Pending | |
| US-019 | Enable heartbeat by default in config | Pending | |
| US-020 | Move heartbeat log to memory directory | Pending | |
| US-021 | Heartbeat calls ExecuteHeartbeatWithTools | Pending | |
---
## [2026-02-12] - US-002
- What was implemented:
- 修复了所有剩余 Tool 实现的 Execute 方法返回值类型:
- `shell.go`: ExecTool 成功时返回 UserResultForUser=命令输出),失败时返回 ErrorResult
- `spawn.go`: SpawnTool 成功返回 NewToolResult失败返回 ErrorResult
- `web.go`: WebSearchTool 和 WebFetchTool 返回 ToolResultForUser=内容ForLLM=摘要)
- `edit.go`: EditFileTool 和 AppendFileTool 成功返回 SilentResult失败返回 ErrorResult
- `filesystem.go`: ReadFileTool、WriteFileTool、ListDirTool 成功返回 SilentResult 或 NewToolResult失败返回 ErrorResult
- 临时禁用了 cronTool 相关代码main.go等待 US-016 完成
- Files changed:
- `pkg/tools/shell.go`
- `pkg/tools/spawn.go`
- `pkg/tools/web.go`
- `pkg/tools/edit.go`
- `pkg/tools/filesystem.go`
- `cmd/picoclaw/main.go`
- **Learnings for future iterations:**
- **Patterns discovered:** 代码重构需要分步骤进行。先修改接口签名,再修改实现,最后处理调用方。
- **Gotchas encountered:** 临时禁用的代码(如 cronTool需要同时注释掉所有相关的启动/停止调用,否则会编译失败。
- **Useful context:** `cron.go` 已被临时禁用(包含注释说明),将在 US-016 中恢复。main.go 中的 cronTool 相关代码也已用注释标记为临时禁用。
---
## [2026-02-12] - US-005
- What was implemented:
- 修改 `runLLMIteration` 返回值,增加 `lastToolResult *tools.ToolResult` 参数
- 在工具执行循环中,立即发送非 Silent 的 ForUser 内容给用户
- 使用 `toolResult.ForLLM` 发送内容给 LLM
- 实现了 Silent 标志检查:`if !toolResult.Silent && toolResult.ForUser != ""`
- 记录最后执行的工具结果用于后续决策
- Files changed:
- `pkg/agent/loop.go`
- **Learnings for future iterations:**
- **Patterns discovered:** 工具结果的处理需要区分两个目的地LLM (ForLLM) 和用户 (ForUser)。用户消息应该在工具执行后立即发送,而不是等待 LLM 的最终响应。
- **Gotchas encountered:** 编辑大文件时要小心不要引入重复代码。我之前编辑时没有完整替换代码块,导致有重复的代码段。
- **Useful context:** `opts.SendResponse` 参数控制是否发送响应给用户。当工具设置了 `ForUser` 时,即使 Silent=false也只有在 `SendResponse=true` 时才会发送。
---