apply_patch Tool

Wende Dateiänderungen mit einem strukturierten Patch-Format an. Das ist ideal für Multi-File- oder Multi-Hunk-Änderungen, bei denen ein einzelner edit-Aufruf zu fehleranfällig wäre.

Das Tool akzeptiert einen einzelnen input-String, der eine oder mehrere Dateioperationen umfasst:

*** 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 inklusive *** Begin Patch und *** End Patch.

Hinweise

  • Pfade werden relativ zum Workspace-Root aufgelöst.
  • Nutze *** Move to: innerhalb eines *** Update File:-Hunks, um Dateien umzubenennen.
  • *** End of File markiert ein EOF-only-Insert, wenn nötig.
  • Experimentell und standardmäßig deaktiviert. Aktiviere es mit tools.exec.applyPatch.enabled.
  • Nur für OpenAI (inklusive OpenAI Codex). Optional kannst du es per Model einschränken via tools.exec.applyPatch.allowModels.
  • Die Config liegt nur 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"
}