VOOZH about

URL: https://developers.openai.com/api/docs/guides/tools-apply-patch

⇱ Apply Patch | OpenAI API


Search the API docs

Primary navigation

Evaluation

Legacy APIs

The apply_patch tool lets GPT-5.1 create, update, and delete files in your codebase using structured diffs. Instead of just suggesting edits, the model emits patch operations that your application applies and then reports back on, enabling iterative, multi-step code editing workflows.

When to use

Some common scenarios where you would use apply_patch:

  • Multi-file refactors – Rename symbols, extract helpers, or reorganize modules across many files at once.
  • Bug fixes – Have the model both diagnose issues and emit precise patches.
  • Tests & docs generation – Create new test files, fixtures, and documentation alongside code changes.
  • Migrations & mechanical edits – Apply repetitive, structured updates (API migrations, type annotations, formatting fixes, etc.).

If you can describe your repo and desired change in text, apply_patch can usually generate the corresponding diffs.

Use apply patch tool with Responses API

At a high level, using apply_patch with the Responses API looks like this:

  1. Call the Responses API with the apply_patch tool
    • Provide the model with context about available files (or a summary) in your input, or give the model tools for exploring your file system.
    • Enable the tool with tools=[{"type": "apply_patch"}].
  2. Let the model return one or more patch operations
    • The Response output includes one or more apply_patch_call objects.
    • Each call describes a single file operation: create, update, or delete.
  3. Apply patches in your environment
    • Run a patch harness or script that:
      • Interprets the operation diff for each apply_patch_call.
      • Applies the patch to your working directory or repo.
      • Records whether each patch succeeded and any logs or error messages.
  4. Report patch results back to the model
    • Call the Responses API again, either with previous_response_id or by passing back your conversation items into input.
    • Include an apply_patch_call_output event for each call_id, with a status and optional output string.
    • Keep tools=[{"type": "apply_patch"}] so the model can continue editing if needed.
  5. Let the model continue or explain changes
    • The model may issue more apply_patch_call operations, or
    • Provide a human-facing explanation of what it changed and why.

Example: Renaming a function with Apply Patch Tool

Step 1: Ask the model to plan and emit patches

Example apply_patch_call object

Step 2: Apply the patch and send results back

If a patch fails (for example, file not found), set status: "failed" and include a helpful output string so the model can recover:

Apply patch operations

Operation TypePurposePayload
create_fileCreate a new file at path.diff is a V4A diff representing the full file contents.
update_fileModify an existing file at path.diff is a V4A diff with additions, deletions, or replacements.
delete_fileRemove a file at path.No diff; delete the file entirely.

Your patch harness is responsible for interpreting the V4A diff format and applying changes. For reference implementations, see the Python Agents SDK or TypeScript Agents SDK code.

Implementing the patch harness

When using the apply_patch tool, you don’t provide an input schema; the model knows how to construct operation objects. Your job is to:

  1. Parse operations from the Response
    • Scan the Response for items with type: "apply_patch_call".
    • For each call, inspect operation.type, operation.path, and any potential diff.
  2. Apply file operations
    • For create_file and update_file, apply the V4A diff to the file system or in-memory workspace.
    • For delete_file, remove the file at path.
    • Record whether each operation succeeded and any logs or error messages.
  3. Return apply_patch_call_output events
    • For each call_id, emit exactly one apply_patch_call_output event with:
      • status: "completed" if the operation was applied successfully.
      • status: "failed" if you encountered an error (include a short human-readable output string).

Safety and robustness

  • Path validation: Prevent directory traversal and restrict edits to allowed directories.
  • Backups: Consider backing up files (or working in a scratch copy) before applying patches.
  • Error handling: Always return a failed status with an informative output string when patches cannot be applied.
  • Atomicity: Decide whether you want “all-or-nothing” semantics (rollback if any patch fails) or per-file success/failure.

Use the apply patch tool with the Agents SDK

Alternatively, you can use the Agents SDK to use the apply patch tool. You’ll still have to implement the harness that handles the actual file operations but you can use the applyDiff function to handle the diff processing.

You can find full working examples on GitHub.

Apply patch tool example - TypeScript

Example of how to use the apply patch tool with the Agents SDK in TypeScript

Apply patch tool example - Python

Example of how to use the apply patch tool with the Agents SDK in Python

Handling common errors

Use status: "failed" plus a clear output message to help the model recover.

File not found
Patch conflict

The model can then adjust future diffs (for example, by re-reading a file in your prompt or simplifying a change) based on these error messages.

Best practices

  • Give clear file context
    • When you call the Responses API, include either an inline snapshot of your files (as in the example), or give the model tools for exploring your filesystem (like the shell tool).
  • Consider using with the shell tool
    • When used in conjunction with the shell tool, the model can explore file system directories, read files, and grep for keywords, enabling agentic file discovery and editing.
  • Encourage small, focused diffs
    • In your system instructions, nudge the model toward minimal, targeted edits rather than huge rewrites.
  • Make sure changes apply cleanly
    • After a series of patches, run your tests or linters and share failures back in the next input so the model can fix them.

Usage notes

API AvailabilitySupported models
GPT-5.5
GPT-5.4
GPT-5.2
GPT-5.1

Loading docs agent...