From 487852f07eb191ef56967b7b7d7f01537a55eabd Mon Sep 17 00:00:00 2001 From: Frédéric Guillot Date: Sun, 11 Nov 2018 15:32:48 -0800 Subject: Replace daemon and scheduler package with service package --- worker/pool.go | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 worker/pool.go (limited to 'worker/pool.go') 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 +} -- cgit v1.2.3