diff options
author | Jeffas <dev@jeffas.io> | 2019-07-23 19:41:15 +0100 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-07-25 18:12:08 -0400 |
commit | ee5b537d538baf38450a2ae655dee53a49aa9824 (patch) | |
tree | f1b60a518f870198f7a9477f80816f23b8ab588a | |
parent | 454151922558f2e82cc7f7d935d74940afa0107b (diff) |
Fix :close on terminal panic
Executing :close on a terminal would panic due to it already having been
removed.
This is also related to the fact that removing a tab doesn't check for
whether it actually found a tab to remove or not.
-rw-r--r-- | commands/terminal/close.go | 1 | ||||
-rw-r--r-- | lib/ui/tab.go | 5 |
2 files changed, 5 insertions, 1 deletions
diff --git a/commands/terminal/close.go b/commands/terminal/close.go index 35c4799..8256e67 100644 --- a/commands/terminal/close.go +++ b/commands/terminal/close.go @@ -26,6 +26,5 @@ func (_ Close) Execute(aerc *widgets.Aerc, args []string) error { } term, _ := aerc.SelectedTab().(*widgets.Terminal) term.Close(nil) - aerc.RemoveTab(term) return nil } diff --git a/lib/ui/tab.go b/lib/ui/tab.go index a9b24a9..6ee5575 100644 --- a/lib/ui/tab.go +++ b/lib/ui/tab.go @@ -57,13 +57,18 @@ func (tabs *Tabs) invalidateChild(d Drawable) { } func (tabs *Tabs) Remove(content Drawable) { + match := false for i, tab := range tabs.Tabs { if tab.Content == content { tabs.Tabs = append(tabs.Tabs[:i], tabs.Tabs[i+1:]...) tabs.removeHistory(i) + match = true break } } + if !match { + return + } index, ok := tabs.popHistory() if ok { tabs.Select(index) |