From e9baa265e9a62f86e8824f933209699870cb31dd Mon Sep 17 00:00:00 2001 From: Sergio Date: Thu, 3 Oct 2024 15:02:32 +0200 Subject: [PATCH] prompt to retry with force --- src/commands/git/branch.ts | 22 +++++++++++++++++++--- src/messages.ts | 2 +- 2 files changed, 20 insertions(+), 4 deletions(-) diff --git a/src/commands/git/branch.ts b/src/commands/git/branch.ts index ee90a642c3bb5..d24abfa24dd30 100644 --- a/src/commands/git/branch.ts +++ b/src/commands/git/branch.ts @@ -1,6 +1,6 @@ import { QuickInputButtons } from 'vscode'; import type { Container } from '../../container'; -import { BranchError } from '../../git/errors'; +import { BranchError, BranchErrorReason } from '../../git/errors'; import type { GitBranchReference, GitReference } from '../../git/models/reference'; import { getNameWithoutRemote, @@ -11,7 +11,7 @@ import { import { Repository } from '../../git/models/repository'; import type { GitWorktree } from '../../git/models/worktree'; import { getWorktreesByBranch } from '../../git/models/worktree'; -import { showGenericErrorMessage } from '../../messages'; +import { showGenericErrorMessage, showGitBranchNotFullyMergedPrompt } from '../../messages'; import type { QuickPickItemOfT } from '../../quickpicks/items/common'; import { createQuickPickSeparator } from '../../quickpicks/items/common'; import type { FlagsQuickPickItem } from '../../quickpicks/items/flags'; @@ -540,7 +540,23 @@ export class BranchGitCommand extends QuickCommand { } catch (ex) { // TODO likely need some better error handling here Logger.error(ex); - return showGenericErrorMessage(ex); + if (ex instanceof BranchError && ex.reason === BranchErrorReason.BranchNotFullyMerged) { + const shouldRetryWithForce = await showGitBranchNotFullyMergedPrompt(ref.name); + if (shouldRetryWithForce) { + try { + await state.repo.git.deleteBranch(ref, { + force: true, + remote: state.flags.includes('--remotes'), + }); + } catch (ex) { + Logger.error(ex); + await showGenericErrorMessage(ex); + } + } + continue; + } + + await showGenericErrorMessage(ex); } } } diff --git a/src/messages.ts b/src/messages.ts index 26f9cbfa15076..b943bfd4017e5 100644 --- a/src/messages.ts +++ b/src/messages.ts @@ -137,7 +137,7 @@ export function showGitVersionUnsupportedErrorMessage( ); } -export async function showGitBranchNotFullyMergedPrompt(branchName: string): Promise { +export async function showGitBranchNotFullyMergedPrompt(branchName: string): Promise { const confirm = { title: 'Retry with --force flag' }; const result = await showMessage( 'warn',