From 494bd674a98bc9f2889acad0fda3ff4c77c641b5 Mon Sep 17 00:00:00 2001 From: Tobias Wölfel Date: Fri, 24 Jul 2020 10:36:19 +0200 Subject: Add flag based search options Provide search and filter with the option to specify more flag based conditions. Use '-x ' to search for messages with a flag (seen, answered, flagged) and '-X ' to search for messages without a flag. --- worker/maildir/search.go | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) (limited to 'worker/maildir/search.go') diff --git a/worker/maildir/search.go b/worker/maildir/search.go index f658c02..005f6fa 100644 --- a/worker/maildir/search.go +++ b/worker/maildir/search.go @@ -29,7 +29,7 @@ func newSearchCriteria() *searchCriteria { func parseSearch(args []string) (*searchCriteria, error) { criteria := newSearchCriteria() - opts, optind, err := getopt.Getopts(args, "rubat:H:f:c:") + opts, optind, err := getopt.Getopts(args, "rux:X:bat:H:f:c:") if err != nil { return nil, err } @@ -41,6 +41,10 @@ func parseSearch(args []string) (*searchCriteria, error) { criteria.WithFlags = append(criteria.WithFlags, maildir.FlagSeen) case 'u': criteria.WithoutFlags = append(criteria.WithoutFlags, maildir.FlagSeen) + case 'x': + criteria.WithFlags = append(criteria.WithFlags, getParsedFlag(opt.Value)) + case 'X': + criteria.WithoutFlags = append(criteria.WithoutFlags, getParsedFlag(opt.Value)) case 'H': // TODO case 'f': @@ -67,6 +71,19 @@ func parseSearch(args []string) (*searchCriteria, error) { return criteria, nil } +func getParsedFlag(name string) maildir.Flag { + var f maildir.Flag + switch strings.ToLower(name) { + case "seen": + f = maildir.FlagSeen + case "answered": + f = maildir.FlagReplied + case "flagged": + f = maildir.FlagFlagged + } + return f +} + func (w *Worker) search(criteria *searchCriteria) ([]uint32, error) { requiredParts := getRequiredParts(criteria) w.worker.Logger.Printf("Required parts bitmask for search: %b", requiredParts) -- cgit 1.4.1-2-gfad0