feat: 增强系统提示词 — 对齐官方工具使用指南

添加 'Using your tools' 段落(匹配官方 Claude Code):
- 专用工具优先于 Bash(FileRead/FileEdit/Glob/Grep)
- WebSearch/WebFetch 主动使用指令:遇到实时信息需求时
  必须使用 WebSearch,不要说无法获取实时信息
- 并行工具调用指导
- TodoWrite 任务管理指导

解决 AI 不主动使用 WebSearch 工具的问题

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
pull/1/head
abel533 1 month ago
parent 54c3cb41a9
commit 43e62fb8fc
  1. 30
      src/main/java/com/claudecode/context/SystemPromptBuilder.java

@ -72,6 +72,36 @@ public class SystemPromptBuilder {
sb.append(BashTool.getShellHint());
sb.append("\n");
// 工具使用指南(对齐官方 Claude Code 的 "Using your tools" 段落)
sb.append("""
# Using your tools
- Do NOT use the Bash tool to run commands when a relevant dedicated tool is provided. \
Using dedicated tools allows the user to better understand and review your work. \
This is CRITICAL to assisting the user:
- To read files use FileRead instead of cat, head, tail, or sed
- To edit files use FileEdit instead of sed or awk
- To create files use FileWrite instead of cat with heredoc or echo redirection
- To search for files use Glob instead of find or ls
- To search the content of files, use Grep instead of grep or rg
- Reserve using the Bash exclusively for system commands and terminal operations \
that require shell execution. If you are unsure and there is a relevant dedicated tool, \
default to using the dedicated tool and only fallback on using the Bash tool for these \
if it is absolutely necessary.
- When the user asks about current events, real-time information, weather, news, or anything \
that requires up-to-date data beyond your knowledge cutoff, you MUST use the WebSearch tool \
to find the answer. Do NOT say you cannot access real-time information you have WebSearch \
and WebFetch tools available. Use them proactively.
- Use WebFetch to retrieve and analyze specific web pages when you have a URL.
- You can call multiple tools in a single response. If you intend to call multiple tools \
and there are no dependencies between them, make all independent tool calls in parallel. \
Maximize use of parallel tool calls where possible to increase efficiency. However, if \
some tool calls depend on previous calls to inform dependent values, do NOT call these \
tools in parallel and instead call them sequentially.
- Break down and manage your work with the TodoWrite tool. These tools are helpful for \
planning your work and helping the user track your progress.
""");
// 行为准则
sb.append("""
# Guidelines

Loading…
Cancel
Save