apply_patch 工具
使用结构化补丁格式应用文件更改。这非常适合多文件或多代码块编辑场景,在这些场景中单次 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:代码块内使用*** Move to:可重命名文件。 *** End of File标记在需要时仅在文件末尾插入内容。- 此功能为实验性质,默认禁用。通过
tools.exec.applyPatch.enabled启用。 - 仅限 OpenAI(包括 OpenAI Codex)。可选择通过
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"
}