Revert "add close command at global level"
This reverts commit f0a0c5aa73
.
This commit is contained in:
parent
f0a0c5aa73
commit
4fc6fee734
6 changed files with 100 additions and 72 deletions
|
@ -1,59 +0,0 @@
|
|||
package commands
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
|
||||
"git.sr.ht/~sircmpwn/aerc/widgets"
|
||||
)
|
||||
|
||||
type Close struct{}
|
||||
|
||||
func init() {
|
||||
register(Close{})
|
||||
}
|
||||
|
||||
func (_ Close) Aliases() []string {
|
||||
return []string{"close", "abort"}
|
||||
}
|
||||
|
||||
func (_ Close) Complete(aerc *widgets.Aerc, args []string) []string {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (_ Close) Execute(aerc *widgets.Aerc, args []string) error {
|
||||
if len(args) > 2 {
|
||||
return errors.New("Usage: close [tab name]")
|
||||
} else if len(args) == 1 {
|
||||
return CloseTab(aerc, aerc.SelectedTabName())
|
||||
} else {
|
||||
tabname := args[1]
|
||||
for _, tab := range aerc.TabNames() {
|
||||
if tab == tabname {
|
||||
return CloseTab(aerc, tabname)
|
||||
}
|
||||
}
|
||||
return errors.New(fmt.Sprintf("Tab %s not found", tabname))
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func CloseTab(aerc *widgets.Aerc, tabname string) error {
|
||||
curTabIndex := aerc.SelectedTabIndex()
|
||||
aerc.SelectTab(tabname)
|
||||
switch tab := aerc.SelectedTab().(type) {
|
||||
default:
|
||||
aerc.RemoveTab(tab)
|
||||
return nil
|
||||
case *widgets.Terminal:
|
||||
tab.Close(nil)
|
||||
return nil
|
||||
case *widgets.Composer:
|
||||
aerc.RemoveTab(tab)
|
||||
tab.Close()
|
||||
return nil
|
||||
case *widgets.AccountView:
|
||||
aerc.SelectTabIndex(curTabIndex)
|
||||
return errors.New("Cannot close account tab")
|
||||
}
|
||||
}
|
33
commands/compose/abort.go
Normal file
33
commands/compose/abort.go
Normal file
|
@ -0,0 +1,33 @@
|
|||
package compose
|
||||
|
||||
import (
|
||||
"errors"
|
||||
|
||||
"git.sr.ht/~sircmpwn/aerc/widgets"
|
||||
)
|
||||
|
||||
type Abort struct{}
|
||||
|
||||
func init() {
|
||||
register(Abort{})
|
||||
}
|
||||
|
||||
func (_ Abort) Aliases() []string {
|
||||
return []string{"abort"}
|
||||
}
|
||||
|
||||
func (_ Abort) Complete(aerc *widgets.Aerc, args []string) []string {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (_ Abort) Execute(aerc *widgets.Aerc, args []string) error {
|
||||
if len(args) != 1 {
|
||||
return errors.New("Usage: abort")
|
||||
}
|
||||
composer, _ := aerc.SelectedTab().(*widgets.Composer)
|
||||
|
||||
aerc.RemoveTab(composer)
|
||||
composer.Close()
|
||||
|
||||
return nil
|
||||
}
|
30
commands/msgview/close.go
Normal file
30
commands/msgview/close.go
Normal file
|
@ -0,0 +1,30 @@
|
|||
package msgview
|
||||
|
||||
import (
|
||||
"errors"
|
||||
|
||||
"git.sr.ht/~sircmpwn/aerc/widgets"
|
||||
)
|
||||
|
||||
type Close struct{}
|
||||
|
||||
func init() {
|
||||
register(Close{})
|
||||
}
|
||||
|
||||
func (_ Close) Aliases() []string {
|
||||
return []string{"close"}
|
||||
}
|
||||
|
||||
func (_ Close) Complete(aerc *widgets.Aerc, args []string) []string {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (_ Close) Execute(aerc *widgets.Aerc, args []string) error {
|
||||
if len(args) != 1 {
|
||||
return errors.New("Usage: close")
|
||||
}
|
||||
mv, _ := aerc.SelectedTab().(*widgets.MessageViewer)
|
||||
aerc.RemoveTab(mv)
|
||||
return nil
|
||||
}
|
30
commands/terminal/close.go
Normal file
30
commands/terminal/close.go
Normal file
|
@ -0,0 +1,30 @@
|
|||
package terminal
|
||||
|
||||
import (
|
||||
"errors"
|
||||
|
||||
"git.sr.ht/~sircmpwn/aerc/widgets"
|
||||
)
|
||||
|
||||
type Close struct{}
|
||||
|
||||
func init() {
|
||||
register(Close{})
|
||||
}
|
||||
|
||||
func (_ Close) Aliases() []string {
|
||||
return []string{"close"}
|
||||
}
|
||||
|
||||
func (_ Close) Complete(aerc *widgets.Aerc, args []string) []string {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (_ Close) Execute(aerc *widgets.Aerc, args []string) error {
|
||||
if len(args) != 1 {
|
||||
return errors.New("Usage: close")
|
||||
}
|
||||
term, _ := aerc.SelectedTab().(*widgets.Terminal)
|
||||
term.Close(nil)
|
||||
return nil
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue