From 8bc3ccb9017b04aafccafa294f219ced5b41a372 Mon Sep 17 00:00:00 2001 From: Kevin Kuehler Date: Mon, 28 Oct 2019 12:07:07 -0700 Subject: Add manual threading to the pipeline Signed-off-by: Kevin Kuehler --- lib/msgstore.go | 13 +++++++++++-- widgets/account.go | 4 ++++ worker/imap/open.go | 17 +++++++++++++++++ worker/imap/worker.go | 2 ++ worker/types/messages.go | 9 +++++++++ 5 files changed, 43 insertions(+), 2 deletions(-) diff --git a/lib/msgstore.go b/lib/msgstore.go index ccde2c2..bc55255 100644 --- a/lib/msgstore.go +++ b/lib/msgstore.go @@ -171,6 +171,15 @@ func (store *MessageStore) Update(msg types.WorkerMessage) { case *types.DirectoryInfo: store.DirInfo = *msg.Info if store.thread { + store.worker.PostAction(&types.FetchNativeThreadSupport{}, nil) + } else { + store.worker.PostAction(&types.FetchDirectoryContents{ + SortCriteria: store.defaultSortCriteria, + }, nil) + } + update = true + case *types.NativeThreadSupport: + if msg.HasSupport { store.worker.PostAction(&types.FetchDirectoryThreaded{ SortCriteria: store.defaultSortCriteria, }, nil) @@ -178,8 +187,8 @@ func (store *MessageStore) Update(msg types.WorkerMessage) { store.worker.PostAction(&types.FetchDirectoryContents{ SortCriteria: store.defaultSortCriteria, }, nil) + update = true } - update = true case *types.DirectoryThreaded: var ( uids []uint32 @@ -190,7 +199,7 @@ func (store *MessageStore) Update(msg types.WorkerMessage) { msg.ThreadRoot.Traverse(false, func(t *types.Thread) bool { uid := t.Uid uids = append([]uint32{uid}, uids...) - flattened = append([]*types.Thread{t}, flattened...) + flattened = append(flattened, t) if msg, ok := store.Messages[uid]; ok { newMap[uid] = msg } else { diff --git a/widgets/account.go b/widgets/account.go index ebc321d..d3f94cc 100644 --- a/widgets/account.go +++ b/widgets/account.go @@ -239,6 +239,10 @@ func (acct *AccountView) onMessage(msg types.WorkerMessage) { if store, ok := acct.dirlist.SelectedMsgStore(); ok { store.Update(msg) } + case *types.NativeThreadSupport: + if store, ok := acct.dirlist.SelectedMsgStore(); ok { + store.Update(msg) + } case *types.DirectoryThreaded: if store, ok := acct.dirlist.SelectedMsgStore(); ok { store.Update(msg) diff --git a/worker/imap/open.go b/worker/imap/open.go index 1152887..c7a479a 100644 --- a/worker/imap/open.go +++ b/worker/imap/open.go @@ -50,6 +50,23 @@ func (imapw *IMAPWorker) handleFetchDirectoryContents( } } +func (imapw *IMAPWorker) handleNativeThreadSupport( + msg *types.FetchNativeThreadSupport) { + hasSupport, err := imapw.client.tc.SupportThread() + if err != nil { + imapw.worker.PostMessage(&types.Error{ + Message: types.RespondTo(msg), + Error: err, + }, nil) + } else { + imapw.worker.PostMessage(&types.NativeThreadSupport{ + Message: types.RespondTo(msg), + HasSupport: hasSupport, + }, nil) + imapw.worker.PostMessage(&types.Done{types.RespondTo(msg)}, nil) + } +} + func (imapw *IMAPWorker) handleDirectoryThreaded( msg *types.FetchDirectoryThreaded) { imapw.worker.Logger.Printf("Fetching threaded UID list") diff --git a/worker/imap/worker.go b/worker/imap/worker.go index 1ba3774..ed1ad9e 100644 --- a/worker/imap/worker.go +++ b/worker/imap/worker.go @@ -165,6 +165,8 @@ func (w *IMAPWorker) handleMessage(msg types.WorkerMessage) error { w.handleFetchDirectoryContents(msg) case *types.FetchDirectoryThreaded: w.handleDirectoryThreaded(msg) + case *types.FetchNativeThreadSupport: + w.handleNativeThreadSupport(msg) case *types.CreateDirectory: w.handleCreateDirectory(msg) case *types.FetchMessageHeaders: diff --git a/worker/types/messages.go b/worker/types/messages.go index d5f2484..2cde38f 100644 --- a/worker/types/messages.go +++ b/worker/types/messages.go @@ -81,6 +81,10 @@ type FetchDirectoryContents struct { SortCriteria []*SortCriterion } +type FetchNativeThreadSupport struct { + Message +} + type FetchDirectoryThreaded struct { Message SortCriteria []*SortCriterion @@ -157,6 +161,11 @@ type DirectoryContents struct { Uids []uint32 } +type NativeThreadSupport struct { + Message + HasSupport bool +} + type DirectoryThreaded struct { Message ThreadRoot *Thread -- cgit v1.2.3