diff options
author | Drew DeVault <sir@cmpwn.com> | 2019-06-26 20:50:27 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-06-26 20:50:54 -0400 |
commit | 91a75cd98b705bd5e6689b154ecaca0e7c81630e (patch) | |
tree | 85fd35605953bad88f9ad2b3a5875f5490b59f09 /commands | |
parent | ccf5c02c3815efbe3b2e495cbc6eaca9f017aefd (diff) |
Implement :search, :next-result, :prev-result
Diffstat (limited to 'commands')
-rw-r--r-- | commands/account/next-result.go | 41 | ||||
-rw-r--r-- | commands/account/search.go | 54 |
2 files changed, 95 insertions, 0 deletions
diff --git a/commands/account/next-result.go b/commands/account/next-result.go new file mode 100644 index 0000000..d89de56 --- /dev/null +++ b/commands/account/next-result.go @@ -0,0 +1,41 @@ +package account + +import ( + "errors" + "fmt" + + "git.sr.ht/~sircmpwn/aerc/widgets" +) + +func init() { + register("next-result", NextPrevResult) + register("prev-result", NextPrevResult) +} + +func nextPrevResultUsage(cmd string) error { + return errors.New(fmt.Sprintf("Usage: %s [<n>[%%]]", cmd)) +} + +func NextPrevResult(aerc *widgets.Aerc, args []string) error { + if len(args) > 1 { + return nextPrevResultUsage(args[0]) + } + acct := aerc.SelectedAccount() + if acct == nil { + return errors.New("No account selected") + } + if args[0] == "prev-result" { + store := acct.Store() + if store != nil { + store.PrevResult() + } + acct.Messages().Scroll() + } else { + store := acct.Store() + if store != nil { + store.NextResult() + } + acct.Messages().Scroll() + } + return nil +} diff --git a/commands/account/search.go b/commands/account/search.go new file mode 100644 index 0000000..513ad43 --- /dev/null +++ b/commands/account/search.go @@ -0,0 +1,54 @@ +package account + +import ( + "errors" + + "git.sr.ht/~sircmpwn/getopt" + "github.com/emersion/go-imap" + + "git.sr.ht/~sircmpwn/aerc/widgets" +) + +func init() { + register("search", SearchFilter) + //register("filter", SearchFilter) // TODO +} + +func SearchFilter(aerc *widgets.Aerc, args []string) error { + var ( + criteria *imap.SearchCriteria = imap.NewSearchCriteria() + ) + + opts, optind, err := getopt.Getopts(args, "ruH:") + if err != nil { + return err + } + for _, opt := range opts { + switch opt.Option { + case 'r': + criteria.WithFlags = append(criteria.WithFlags, imap.SeenFlag) + case 'u': + criteria.WithoutFlags = append(criteria.WithoutFlags, imap.SeenFlag) + case 'H': + // TODO + } + } + for _, arg := range args[optind:] { + criteria.Header.Add("Subject", arg) + } + + acct := aerc.SelectedAccount() + if acct == nil { + return errors.New("No account selected") + } + store := acct.Store() + aerc.SetStatus("Searching...") + store.Search(criteria, func(uids []uint32) { + aerc.SetStatus("Search complete.") + acct.Logger().Printf("Search results: %v", uids) + store.ApplySearch(uids) + // TODO: Remove when stores have multiple OnUpdate handlers + acct.Messages().Scroll() + }) + return nil +} |