diff options
author | Jesse Duffield <jessedduffield@gmail.com> | 2018-10-24 09:24:16 +1100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-24 09:24:16 +1100 |
commit | c6da4c8a47a45a96beb2de4fbe5b98cfb87446b4 (patch) | |
tree | f0af2140c32532d23a84d4adcd79217ccca1bd6b /pkg/gui/branches_panel.go | |
parent | 3b6b68a2a1541fe26b39cba676b039f72142a28b (diff) | |
parent | 467775fc1ca1630ca5c1b4bdb2bc87d53c4e72c6 (diff) |
Merge pull request #301 from rozuur/masterv0.5
Initial version of delete named branch added
Diffstat (limited to 'pkg/gui/branches_panel.go')
-rw-r--r-- | pkg/gui/branches_panel.go | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/pkg/gui/branches_panel.go b/pkg/gui/branches_panel.go index 11a4a0ebb..dbf4b007a 100644 --- a/pkg/gui/branches_panel.go +++ b/pkg/gui/branches_panel.go @@ -87,6 +87,10 @@ func (gui *Gui) deleteBranch(g *gocui.Gui, v *gocui.View, force bool) error { if checkedOutBranch.Name == selectedBranch.Name { return gui.createErrorPanel(g, gui.Tr.SLocalize("CantDeleteCheckOutBranch")) } + return gui.deleteNamedBranch(g, v, selectedBranch, force) +} + +func (gui *Gui) deleteNamedBranch(g *gocui.Gui, v *gocui.View, selectedBranch *commands.Branch, force bool) error { title := gui.Tr.SLocalize("DeleteBranch") var messageId string if force { @@ -102,7 +106,12 @@ func (gui *Gui) deleteBranch(g *gocui.Gui, v *gocui.View, force bool) error { ) return gui.createConfirmationPanel(g, v, title, message, func(g *gocui.Gui, v *gocui.View) error { if err := gui.GitCommand.DeleteBranch(selectedBranch.Name, force); err != nil { - return gui.createErrorPanel(g, err.Error()) + errMessage := err.Error() + if !force && strings.Contains(errMessage, "is not fully merged") { + return gui.deleteNamedBranch(g, v, selectedBranch, true) + } else { + return gui.createErrorPanel(g, errMessage) + } } return gui.refreshSidePanels(g) }, nil) |