When using frontier models to edit your codebase, you’re paying premium rates for both valuable changes and unchanged sections alike.Instant apply is about the separation of concerns — use heavyweight models for new sections of code, and use a lightweight model to merge the new into the old.Using relace-apply-3 running at 10k+ tok/s, this method is over 3x faster and cheaper than rewriting files from scratch.We explain how we train/inference the model to achieve these speeds in our blog post.
Add instructions for formatting edits somewhere in the system prompt for your LLM of choice. See our edit tool definition if you’re building an agent.
- Abbreviate sections of the code in your response that will remain the same by replacing those sections with a comment like "// ... rest of code ...", "// ... keep existing code ...", "// ... code remains the same". - Be precise with the location of these comments within your edit snippet. A less intelligent model will use the context clues you provide to accurately merge your edit snippet. - If applicable, it can help to include some concise information about the specific code segments you wish to retain "// ... keep calculateTotalFunction ... ". - If you plan on deleting a section, you must provide the context to delete it. Some options: 1. If the initial code is ```code \n Block 1 \n Block 2 \n Block 3 \n code```, and you want to remove Block 2, you would output ```// ... keep existing code ... \n Block 1 \n Block 3 \n // ... rest of code ...```. 2. If the initial code is ```code \n Block \n code```, and you want to remove Block, you can also specify ```// ... keep existing code ... \n // remove Block \n // ... rest of code ...```. - You must use the comment format applicable to the specific code provided to express these truncations. - Preserve the indentation and code structure of exactly how you believe the final code will look (do not output lines that will not be in the final code after they are merged). - Be as length efficient as possible without omitting key context.
2
Merge with Instant Apply
Pass the abbreviated edit snippet along with the initial code to the Instant Apply endpoint.