Appearance
apply_patch 工具
使用结构化补丁格式应用文件变更。适合多文件或多 hunk 编辑,在这类场景下单次 edit 调用容易出错。
该工具接受一个包含一个或多个文件操作的 input 字符串:
*** Begin Patch
*** Add File: path/to/file.txt
+line 1
+line 2
*** Update File: src/app.ts
@@
-old line
+new line
*** Delete File: obsolete.txt
*** End Patch参数
input(必填):完整的补丁内容,包含*** Begin Patch和*** End Patch。
注意事项
- 补丁路径支持相对路径(从工作区目录算起)和绝对路径。
tools.exec.applyPatch.workspaceOnly默认为true(仅限工作区内)。只有在你明确希望apply_patch在工作区目录之外写入/删除时,才将其设为false。- 在
*** Update File:hunk 中使用*** Move to:可以重命名文件。 *** End of File在需要仅 EOF 插入时使用。- OpenAI 和 OpenAI Codex 模型默认可用。设置
tools.exec.applyPatch.enabled: false可禁用。 - 可通过
tools.exec.applyPatch.allowModels按模型限制使用。 - 配置仅在
tools.exec下。
示例
json
{
"tool": "apply_patch",
"input": "*** Begin Patch\n*** Update File: src/index.ts\n@@\n-const foo = 1\n+const foo = 2\n*** End Patch"
}提示: 当你需要在多个文件里一次性修改时,
apply_patch比逐个调用edit更可靠——让你的"龙虾"干活更精准。