summaryrefslogtreecommitdiff
path: root/extension/src/diffs.ts
diff options
context:
space:
mode:
Diffstat (limited to 'extension/src/diffs.ts')
-rw-r--r--extension/src/diffs.ts16
1 files changed, 14 insertions, 2 deletions
diff --git a/extension/src/diffs.ts b/extension/src/diffs.ts
index 4fce744c..52a54046 100644
--- a/extension/src/diffs.ts
+++ b/extension/src/diffs.ts
@@ -38,7 +38,12 @@ class DiffManager {
originalFilepath: string,
newFilepath: string,
newContent: string
- ): vscode.TextEditor {
+ ): vscode.TextEditor | undefined {
+ // If the file doesn't yet exist, don't open the diff editor
+ if (!fs.existsSync(newFilepath)) {
+ return undefined;
+ }
+
const rightUri = vscode.Uri.parse(newFilepath);
const leftUri = vscode.Uri.file(originalFilepath);
const title = "Continue Diff";
@@ -73,6 +78,12 @@ class DiffManager {
originalFilepath,
newFilepath,
};
+ this.diffs.set(newFilepath, diffInfo);
+ }
+
+ // Open the editor if it hasn't been opened yet
+ const diffInfo = this.diffs.get(newFilepath);
+ if (diffInfo && !diffInfo?.editor) {
diffInfo.editor = this.openDiffEditor(
originalFilepath,
newFilepath,
@@ -80,6 +91,7 @@ class DiffManager {
);
this.diffs.set(newFilepath, diffInfo);
}
+
return newFilepath;
}
@@ -89,7 +101,7 @@ class DiffManager {
vscode.window.showTextDocument(diffInfo.editor.document);
vscode.commands.executeCommand("workbench.action.closeActiveEditor");
}
- this.diffs.delete(diffInfo.newFilepath);
+ // this.diffs.delete(diffInfo.newFilepath);
fs.unlinkSync(diffInfo.newFilepath);
}