Register worker in init.
This allows backends which can't always be compiled due to missing dependencies (say libnotmuch) to be compiled conditionally with buildflags.
This commit is contained in:
parent
66a9052f0f
commit
6fed04bb9f
5 changed files with 53 additions and 20 deletions
27
worker/handlers/register.go
Normal file
27
worker/handlers/register.go
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
package handlers
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
||||||
|
)
|
||||||
|
|
||||||
|
type FactoryFunc func(*types.Worker) (types.Backend, error)
|
||||||
|
|
||||||
|
var workerFactories map[string]FactoryFunc = make(map[string]FactoryFunc)
|
||||||
|
|
||||||
|
func RegisterWorkerFactory(scheme string, factory FactoryFunc) {
|
||||||
|
workerFactories[scheme] = factory
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetHandlerForScheme(scheme string, worker *types.Worker) (types.Backend, error) {
|
||||||
|
factory, ok := workerFactories[scheme]
|
||||||
|
if !ok {
|
||||||
|
return nil, fmt.Errorf("Unknown backend %s", scheme)
|
||||||
|
}
|
||||||
|
backend, err := factory(worker)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return backend, nil
|
||||||
|
}
|
|
@ -13,9 +13,15 @@ import (
|
||||||
|
|
||||||
"git.sr.ht/~sircmpwn/aerc/lib"
|
"git.sr.ht/~sircmpwn/aerc/lib"
|
||||||
"git.sr.ht/~sircmpwn/aerc/models"
|
"git.sr.ht/~sircmpwn/aerc/models"
|
||||||
|
"git.sr.ht/~sircmpwn/aerc/worker/handlers"
|
||||||
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
handlers.RegisterWorkerFactory("imap", NewIMAPWorker)
|
||||||
|
handlers.RegisterWorkerFactory("imaps", NewIMAPWorker)
|
||||||
|
}
|
||||||
|
|
||||||
var errUnsupported = fmt.Errorf("unsupported command")
|
var errUnsupported = fmt.Errorf("unsupported command")
|
||||||
|
|
||||||
type imapClient struct {
|
type imapClient struct {
|
||||||
|
@ -43,12 +49,12 @@ type IMAPWorker struct {
|
||||||
seqMap []uint32
|
seqMap []uint32
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewIMAPWorker(worker *types.Worker) *IMAPWorker {
|
func NewIMAPWorker(worker *types.Worker) (types.Backend, error) {
|
||||||
return &IMAPWorker{
|
return &IMAPWorker{
|
||||||
idleDone: make(chan error),
|
idleDone: make(chan error),
|
||||||
updates: make(chan client.Update, 50),
|
updates: make(chan client.Update, 50),
|
||||||
worker: worker,
|
worker: worker,
|
||||||
}
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *IMAPWorker) handleMessage(msg types.WorkerMessage) error {
|
func (w *IMAPWorker) handleMessage(msg types.WorkerMessage) error {
|
||||||
|
|
|
@ -11,9 +11,14 @@ import (
|
||||||
"github.com/fsnotify/fsnotify"
|
"github.com/fsnotify/fsnotify"
|
||||||
|
|
||||||
"git.sr.ht/~sircmpwn/aerc/models"
|
"git.sr.ht/~sircmpwn/aerc/models"
|
||||||
|
"git.sr.ht/~sircmpwn/aerc/worker/handlers"
|
||||||
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
handlers.RegisterWorkerFactory("maildir", NewWorker)
|
||||||
|
}
|
||||||
|
|
||||||
var errUnsupported = fmt.Errorf("unsupported command")
|
var errUnsupported = fmt.Errorf("unsupported command")
|
||||||
|
|
||||||
// A Worker handles interfacing between aerc's UI and a group of maildirs.
|
// A Worker handles interfacing between aerc's UI and a group of maildirs.
|
||||||
|
@ -25,7 +30,7 @@ type Worker struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewWorker creates a new maildir worker with the provided worker.
|
// NewWorker creates a new maildir worker with the provided worker.
|
||||||
func NewWorker(worker *types.Worker) (*Worker, error) {
|
func NewWorker(worker *types.Worker) (types.Backend, error) {
|
||||||
watch, err := fsnotify.NewWatcher()
|
watch, err := fsnotify.NewWatcher()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("could not create file system watcher: %v", err)
|
return nil, fmt.Errorf("could not create file system watcher: %v", err)
|
||||||
|
|
|
@ -1,14 +1,13 @@
|
||||||
package worker
|
package worker
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"git.sr.ht/~sircmpwn/aerc/worker/imap"
|
|
||||||
"git.sr.ht/~sircmpwn/aerc/worker/maildir"
|
|
||||||
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
|
||||||
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"net/url"
|
"net/url"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
"git.sr.ht/~sircmpwn/aerc/worker/handlers"
|
||||||
|
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Guesses the appropriate worker type based on the given source string
|
// Guesses the appropriate worker type based on the given source string
|
||||||
|
@ -23,19 +22,10 @@ func NewWorker(source string, logger *log.Logger) (*types.Worker, error) {
|
||||||
scheme = scheme[:strings.IndexRune(scheme, '+')]
|
scheme = scheme[:strings.IndexRune(scheme, '+')]
|
||||||
fmt.Println(scheme)
|
fmt.Println(scheme)
|
||||||
}
|
}
|
||||||
switch scheme {
|
backend, err := handlers.GetHandlerForScheme(scheme, worker)
|
||||||
case "imap":
|
if err != nil {
|
||||||
fallthrough
|
return nil, err
|
||||||
case "imaps":
|
|
||||||
worker.Backend = imap.NewIMAPWorker(worker)
|
|
||||||
case "maildir":
|
|
||||||
if w, err := maildir.NewWorker(worker); err != nil {
|
|
||||||
return nil, fmt.Errorf("could not create maildir worker: %v", err)
|
|
||||||
} else {
|
|
||||||
worker.Backend = w
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
return nil, fmt.Errorf("Unknown backend %s", u.Scheme)
|
|
||||||
}
|
}
|
||||||
|
worker.Backend = backend
|
||||||
return worker, nil
|
return worker, nil
|
||||||
}
|
}
|
||||||
|
|
5
worker/worker_enabled.go
Normal file
5
worker/worker_enabled.go
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
package worker
|
||||||
|
|
||||||
|
// the following workers are always enabled
|
||||||
|
import _ "git.sr.ht/~sircmpwn/aerc/worker/imap"
|
||||||
|
import _ "git.sr.ht/~sircmpwn/aerc/worker/maildir"
|
Loading…
Reference in a new issue