apply_patch-Tool
Dateiänderungen mit einem strukturierten Patch-Format anwenden. Ideal für Multi-Datei-
oder Multi-Hunk-Bearbeitungen, bei denen ein einzelner edit-Aufruf fragil wäre.
Das Tool akzeptiert einen einzelnen input-String, der eine oder mehrere Dateioperationen umschließt:
*** 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
Parameter
input(erforderlich): Vollständiger Patch-Inhalt einschließlich*** Begin Patchund*** End Patch.
Hinweise
- Patch-Pfade unterstützen relative Pfade (vom Workspace-Verzeichnis) und absolute Pfade.
tools.exec.applyPatch.workspaceOnlyist standardmäßigtrue(auf Workspace beschränkt). Setze es nur auffalse, wenn du bewusst möchtest, dassapply_patchaußerhalb des Workspace-Verzeichnisses schreibt/löscht.- Verwende
*** Move to:innerhalb eines*** Update File:-Hunks, um Dateien umzubenennen. *** End of Filemarkiert ein reines EOF-Insert, wenn nötig.- Experimentell und standardmäßig deaktiviert. Aktivierung mit
tools.exec.applyPatch.enabled. - Nur für OpenAI (einschließlich OpenAI Codex). Optional per Modell einschränkbar über
tools.exec.applyPatch.allowModels. - Konfiguration befindet sich ausschließlich unter
tools.exec.
Beispiel
{
"tool": "apply_patch",
"input": "*** Begin Patch\n*** Update File: src/index.ts\n@@\n-const foo = 1\n+const foo = 2\n*** End Patch"
}