Turbo edits v2 (#1653)
Fixes #1222 #1646 TODOs - [x] description? - [x] collect errors across all files for turbo edits - [x] be forgiving around whitespaces - [x] write e2e tests - [x] do more manual testing across different models <!-- CURSOR_SUMMARY --> --- > [!NOTE] > Adds Turbo Edits v2 search-replace flow with settings/UI selector, parser/renderer, dry-run validation + fallback, proposal integration, and comprehensive tests; updates licensing. > > - **Engine/Processing**: > - Add `dyad-search-replace` end-to-end: parsing (`getDyadSearchReplaceTags`), markdown rendering (`DyadSearchReplace`), and application (`applySearchReplace`) with dry-run validation and fallback to `dyad-write`. > - Inject Turbo Edits v2 system prompt; toggle via `isTurboEditsV2Enabled`; disable classic lazy edits when v2 is on. > - Include search-replace edits in proposals and full-response processing. > - **Settings/UI**: > - Introduce `proLazyEditsMode` (`off`|`v1`|`v2`) and helper selectors; update `ProModeSelector` with Turbo Edits and Smart Context selectors (`data-testid`s). > - **LLM/token flow**: > - Construct system prompt conditionally; update token counting and chat stream to validate and repair search-replace responses. > - **Tests**: > - Add unit tests for search-replace processor; e2e tests for Turbo Edits v2 and options; fixtures and snapshots. > - **Licensing/Docs**: > - Add `src/pro/LICENSE` (FSL 1.1 ALv2 future), update root `LICENSE` and README license section. > - **Tooling**: > - Update `.prettierignore`; enhance test helpers (selectors, path normalization, snapshot filtering). > > <sup>Written by [Cursor Bugbot](https://cursor.com/dashboard?tab=bugbot) for commit 7aefa02bfae2fe22a25c7d87f3c4c326f820f1e6. This will update automatically on new commits. Configure [here](https://cursor.com/dashboard?tab=bugbot).</sup> <!-- /CURSOR_SUMMARY -->
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
import path from "node:path";
|
||||
import fs from "node:fs";
|
||||
import log from "electron-log";
|
||||
import { TURBO_EDITS_V2_SYSTEM_PROMPT } from "../pro/main/prompts/turbo_edits_v2_prompt";
|
||||
|
||||
const logger = log.scope("system_prompt");
|
||||
|
||||
@@ -505,24 +506,36 @@ When tools are not used, simply state: **"Ok, looks like I don't need any tools,
|
||||
export const constructSystemPrompt = ({
|
||||
aiRules,
|
||||
chatMode = "build",
|
||||
enableTurboEditsV2,
|
||||
}: {
|
||||
aiRules: string | undefined;
|
||||
chatMode?: "build" | "ask" | "agent";
|
||||
enableTurboEditsV2: boolean;
|
||||
}) => {
|
||||
const systemPrompt = getSystemPromptForChatMode(chatMode);
|
||||
const systemPrompt = getSystemPromptForChatMode({
|
||||
chatMode,
|
||||
enableTurboEditsV2,
|
||||
});
|
||||
return systemPrompt.replace("[[AI_RULES]]", aiRules ?? DEFAULT_AI_RULES);
|
||||
};
|
||||
|
||||
export const getSystemPromptForChatMode = (
|
||||
chatMode: "build" | "ask" | "agent",
|
||||
) => {
|
||||
export const getSystemPromptForChatMode = ({
|
||||
chatMode,
|
||||
enableTurboEditsV2,
|
||||
}: {
|
||||
chatMode: "build" | "ask" | "agent";
|
||||
enableTurboEditsV2: boolean;
|
||||
}) => {
|
||||
if (chatMode === "agent") {
|
||||
return AGENT_MODE_SYSTEM_PROMPT;
|
||||
}
|
||||
if (chatMode === "ask") {
|
||||
return ASK_MODE_SYSTEM_PROMPT;
|
||||
}
|
||||
return BUILD_SYSTEM_PROMPT;
|
||||
return (
|
||||
BUILD_SYSTEM_PROMPT +
|
||||
(enableTurboEditsV2 ? TURBO_EDITS_V2_SYSTEM_PROMPT : "")
|
||||
);
|
||||
};
|
||||
|
||||
export const readAiRules = async (dyadAppPath: string) => {
|
||||
|
||||
Reference in New Issue
Block a user