diff options
-rw-r--r-- | pool.go | 3 | ||||
-rw-r--r-- | static_pool.go | 34 |
2 files changed, 20 insertions, 17 deletions
@@ -19,6 +19,9 @@ type Pool interface { // Workers returns worker list associated with the pool. Workers() (workers []*Worker) + // DestroyWorker destroys workers and removes it from the pool. + DestroyWorker(w *Worker) + // Destroy all underlying workers (but let them to complete the task). Destroy() } diff --git a/static_pool.go b/static_pool.go index 3d036946..2ac6a593 100644 --- a/static_pool.go +++ b/static_pool.go @@ -130,23 +130,6 @@ func (p *StaticPool) Exec(rqs *Payload) (rsp *Payload, err error) { return rsp, nil } -// Destroy all underlying workers (but let them to complete the task). -func (p *StaticPool) Destroy() { - p.tasks.Wait() - - var wg sync.WaitGroup - for _, w := range p.Workers() { - wg.Add(1) - go func(w *Worker) { - defer wg.Done() - - p.DestroyWorker(w) - }(w) - } - - wg.Wait() -} - // DestroyWorker destroys workers and removes it from the pool. func (p *StaticPool) DestroyWorker(w *Worker) { p.throw(EventDestruct, w, nil) @@ -174,6 +157,23 @@ func (p *StaticPool) DestroyWorker(w *Worker) { } } +// Destroy all underlying workers (but let them to complete the task). +func (p *StaticPool) Destroy() { + p.tasks.Wait() + + var wg sync.WaitGroup + for _, w := range p.Workers() { + wg.Add(1) + go func(w *Worker) { + defer wg.Done() + + p.DestroyWorker(w) + }(w) + } + + wg.Wait() +} + // finds free worker in a given time interval or creates new if allowed. func (p *StaticPool) allocateWorker() (w *Worker, err error) { select { |