diff options
author | Drew DeVault <sir@cmpwn.com> | 2019-03-14 23:41:25 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-03-14 23:41:25 -0400 |
commit | 24daef89e0fc6056c3ff7b94880ed12b4ec3eaa6 (patch) | |
tree | 82bffc5ee8ec795d07833734929907db0f659f85 /commands | |
parent | 4c8feb9aa54ddb162558482905c4723e2743e657 (diff) |
Implement :{next,prev}-message
Diffstat (limited to 'commands')
-rw-r--r-- | commands/next-folder.go | 6 | ||||
-rw-r--r-- | commands/next-message.go | 43 |
2 files changed, 46 insertions, 3 deletions
diff --git a/commands/next-folder.go b/commands/next-folder.go index ed11615..dce8907 100644 --- a/commands/next-folder.go +++ b/commands/next-folder.go @@ -13,13 +13,13 @@ func init() { Register("prev-folder", NextPrevFolder) } -func usage(cmd string) error { +func nextPrevFolderUsage(cmd string) error { return errors.New(fmt.Sprintf("Usage: %s [n]", cmd)) } func NextPrevFolder(aerc *widgets.Aerc, args []string) error { if len(args) > 2 { - return usage(args[0]) + return nextPrevFolderUsage(args[0]) } var ( n int = 1 @@ -28,7 +28,7 @@ func NextPrevFolder(aerc *widgets.Aerc, args []string) error { if len(args) > 1 { n, err = strconv.Atoi(args[1]) if err != nil { - return usage(args[0]) + return nextPrevFolderUsage(args[0]) } } acct := aerc.SelectedAccount() diff --git a/commands/next-message.go b/commands/next-message.go new file mode 100644 index 0000000..86cd678 --- /dev/null +++ b/commands/next-message.go @@ -0,0 +1,43 @@ +package commands + +import ( + "errors" + "fmt" + "strconv" + + "git.sr.ht/~sircmpwn/aerc2/widgets" +) + +func init() { + Register("next-message", NextPrevMessage) + Register("prev-message", NextPrevMessage) +} + +func nextPrevMessageUsage(cmd string) error { + return errors.New(fmt.Sprintf("Usage: %s [n]", cmd)) +} + +func NextPrevMessage(aerc *widgets.Aerc, args []string) error { + if len(args) > 2 { + return nextPrevMessageUsage(args[0]) + } + var ( + n int = 1 + err error + ) + if len(args) > 1 { + n, err = strconv.Atoi(args[1]) + if err != nil { + return nextPrevMessageUsage(args[0]) + } + } + acct := aerc.SelectedAccount() + for ; n > 0; n-- { + if args[0] == "prev-message" { + acct.Messages().Prev() + } else { + acct.Messages().Next() + } + } + return nil +} |