From d8c600ce53e20bae5db17142857012f549fa474e Mon Sep 17 00:00:00 2001 From: Eric Amodio Date: Mon, 18 May 2020 02:38:35 -0400 Subject: [PATCH] Ensure right-side diff --- src/commands/diffWithPrevious.ts | 14 ++++++++++++-- src/commands/diffWithWorking.ts | 9 +++++++-- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/src/commands/diffWithPrevious.ts b/src/commands/diffWithPrevious.ts index 489e68e..4340736 100644 --- a/src/commands/diffWithPrevious.ts +++ b/src/commands/diffWithPrevious.ts @@ -24,10 +24,15 @@ export class DiffWithPreviousCommand extends ActiveEditorCommand { protected preExecute(context: CommandContext, args?: DiffWithPreviousCommandArgs) { if (context.command === Commands.DiffWithPreviousInDiffRight) { args = { ...args }; - args.inDiffRightEditor = true; + + // Ensure we are on the right side -- context.uri is always the right-side uri, so ensure the editor matches, otherwise we are on the left + if (context.editor?.document.uri.toString() === context.uri?.toString()) { + args.inDiffRightEditor = true; + } } - return this.execute(context.editor, context.uri, args); + // Always pass the editor.uri (if we have one), so we are correct for a split diff + return this.execute(context.editor, context.editor?.document.uri ?? context.uri, args); } async execute(editor?: TextEditor, uri?: Uri, args?: DiffWithPreviousCommandArgs) { @@ -63,6 +68,11 @@ export class DiffWithPreviousCommand extends ActiveEditorCommand { gitUri = await GitUri.fromUri(uri); } + // If we are in the right diff editor, we can't really trust the line number + // if (args.inDiffRightEditor && args.line !== 0) { + // // TODO@eamodio figure out how to tell where the line moved in the previous commit (if at all) + // } + try { const diffUris = await Container.git.getPreviousDiffUris( gitUri.repoPath!, diff --git a/src/commands/diffWithWorking.ts b/src/commands/diffWithWorking.ts index f59383d..81ba607 100644 --- a/src/commands/diffWithWorking.ts +++ b/src/commands/diffWithWorking.ts @@ -22,10 +22,15 @@ export class DiffWithWorkingCommand extends ActiveEditorCommand { protected preExecute(context: CommandContext, args?: DiffWithWorkingCommandArgs) { if (context.command === Commands.DiffWithWorkingInDiffRight) { args = { ...args }; - args.inDiffRightEditor = true; + + // Ensure we are on the right side -- context.uri is always the right-side uri, so ensure the editor matches, otherwise we are on the left + if (context.editor?.document.uri.toString() === context.uri?.toString()) { + args.inDiffRightEditor = true; + } } - return this.execute(context.editor, context.uri, args); + // Always pass the editor.uri (if we have one), so we are correct for a split diff + return this.execute(context.editor, context.editor?.document.uri ?? context.uri, args); } async execute(editor?: TextEditor, uri?: Uri, args?: DiffWithWorkingCommandArgs): Promise {