Skip to content

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 更可靠——让你的"龙虾"干活更精准。