From 68f179021d304d6edf939ecf5fc7d0d073b16152 Mon Sep 17 00:00:00 2001 From: Jeffas Date: Mon, 2 Mar 2020 19:54:42 +0000 Subject: Add move-tab command --- commands/move-tab.go | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 commands/move-tab.go (limited to 'commands/move-tab.go') diff --git a/commands/move-tab.go b/commands/move-tab.go new file mode 100644 index 00000000..9f0293c7 --- /dev/null +++ b/commands/move-tab.go @@ -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 [+|-]", 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 +} -- cgit