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 /lib | |
parent | ccf5c02c3815efbe3b2e495cbc6eaca9f017aefd (diff) | |
download | aerc-91a75cd98b705bd5e6689b154ecaca0e7c81630e.tar.gz |
Implement :search, :next-result, :prev-result
Diffstat (limited to 'lib')
-rw-r--r-- | lib/msgstore.go | 50 |
1 files changed, 49 insertions, 1 deletions
diff --git a/lib/msgstore.go b/lib/msgstore.go index a81f9ad3..45a9fb67 100644 --- a/lib/msgstore.go +++ b/lib/msgstore.go @@ -21,6 +21,10 @@ type MessageStore struct { bodyCallbacks map[uint32][]func(io.Reader) headerCallbacks map[uint32][]func(*types.MessageInfo) + // Search/filter results + results []uint32 + resultIndex int + // Map of uids we've asked the worker to fetch onUpdate func(store *MessageStore) // TODO: multiple onUpdate handlers pendingBodies map[uint32]interface{} @@ -107,7 +111,6 @@ func (store *MessageStore) FetchBodyPart( } func merge(to *types.MessageInfo, from *types.MessageInfo) { - if from.BodyStructure != nil { to.BodyStructure = from.BodyStructure } @@ -320,3 +323,48 @@ func (store *MessageStore) Next() { func (store *MessageStore) Prev() { store.nextPrev(-1) } + +func (store *MessageStore) Search(c *imap.SearchCriteria, cb func([]uint32)) { + store.worker.PostAction(&types.SearchDirectory{ + Criteria: c, + }, func(msg types.WorkerMessage) { + switch msg := msg.(type) { + case *types.SearchResults: + cb(msg.Uids) + } + }) +} + +func (store *MessageStore) ApplySearch(results []uint32) { + store.results = results + store.resultIndex = -1 + store.NextResult() +} + +func (store *MessageStore) nextPrevResult(delta int) { + if len(store.results) == 0 { + return + } + store.resultIndex += delta + if store.resultIndex >= len(store.results) { + store.resultIndex = 0 + } + if store.resultIndex < 0 { + store.resultIndex = len(store.results) - 1 + } + for i, uid := range store.Uids { + if store.results[len(store.results)-store.resultIndex-1] == uid { + store.Select(len(store.Uids) - i - 1) + break + } + } + store.update() +} + +func (store *MessageStore) NextResult() { + store.nextPrevResult(1) +} + +func (store *MessageStore) PrevResult() { + store.nextPrevResult(-1) +} |