diff options
author | 2018-11-11 15:32:48 -0800 | |
---|---|---|
committer | 2018-11-11 15:32:48 -0800 | |
commit | 487852f07eb191ef56967b7b7d7f01537a55eabd (patch) | |
tree | 0c5194c4371392128917a0860ac7a6b00f7784a2 /worker/pool.go | |
parent | ca45765c46de3b00c3b22936c885b57c37186e3d (diff) |
Replace daemon and scheduler package with service package
Diffstat (limited to 'worker/pool.go')
-rw-r--r-- | worker/pool.go | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/worker/pool.go b/worker/pool.go new file mode 100644 index 0000000..909e815 --- /dev/null +++ b/worker/pool.go @@ -0,0 +1,36 @@ +// Copyright 2018 Frédéric Guillot. All rights reserved. +// Use of this source code is governed by the Apache 2.0 +// license that can be found in the LICENSE file. + +package worker // import "miniflux.app/worker" + +import ( + "miniflux.app/model" + "miniflux.app/reader/feed" +) + +// Pool handles a pool of workers. +type Pool struct { + queue chan model.Job +} + +// Push send a list of jobs to the queue. +func (p *Pool) Push(jobs model.JobList) { + for _, job := range jobs { + p.queue <- job + } +} + +// NewPool creates a pool of background workers. +func NewPool(feedHandler *feed.Handler, nbWorkers int) *Pool { + workerPool := &Pool{ + queue: make(chan model.Job), + } + + for i := 0; i < nbWorkers; i++ { + worker := &Worker{id: i, feedHandler: feedHandler} + go worker.Run(workerPool.queue) + } + + return workerPool +} |