Add move-tab command
This commit is contained in:
parent
2e381fa42d
commit
68f179021d
4 changed files with 108 additions and 0 deletions
commands
51
commands/move-tab.go
Normal file
51
commands/move-tab.go
Normal file
|
@ -0,0 +1,51 @@
|
|||
package commands
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"git.sr.ht/~sircmpwn/aerc/widgets"
|
||||
)
|
||||
|
||||
type MoveTab struct{}
|
||||
|
||||
func init() {
|
||||
register(MoveTab{})
|
||||
}
|
||||
|
||||
func (MoveTab) Aliases() []string {
|
||||
return []string{"move-tab"}
|
||||
}
|
||||
|
||||
func (MoveTab) Complete(aerc *widgets.Aerc, args []string) []string {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (MoveTab) Execute(aerc *widgets.Aerc, args []string) error {
|
||||
if len(args) == 1 {
|
||||
return fmt.Errorf("Usage: %s [+|-]<index>", args[0])
|
||||
}
|
||||
|
||||
joinedArgs := strings.Join(args[1:], "")
|
||||
|
||||
n, err := strconv.Atoi(joinedArgs)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to parse index argument: %v", err)
|
||||
}
|
||||
|
||||
i := aerc.SelectedTabIndex()
|
||||
l := aerc.NumTabs()
|
||||
|
||||
if strings.HasPrefix(joinedArgs, "+") {
|
||||
i = (i + n) % l
|
||||
} else if strings.HasPrefix(joinedArgs, "-") {
|
||||
i = (((i + n) % l) + l) % l
|
||||
} else {
|
||||
i = n
|
||||
}
|
||||
|
||||
aerc.MoveTab(i)
|
||||
|
||||
return nil
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue