(job jobFn)
| 49 | } |
| 50 | |
| 51 | func (p *WorkerPool) Add(job jobFn) { |
| 52 | p.semC <- struct{}{} |
| 53 | p.wg.Add(1) |
| 54 | go func(ctx context.Context, wg *sync.WaitGroup, semC <-chan struct{}, errC chan<- error) { |
| 55 | defer func() { |
| 56 | <-semC |
| 57 | wg.Done() |
| 58 | }() |
| 59 | if err := job(ctx); err != nil { |
| 60 | slog.Error("Worker error", slogs.Error, err) |
| 61 | errC <- err |
| 62 | } |
| 63 | }(p.ctx, &p.wg, p.semC, p.errC) |
| 64 | } |
| 65 | |
| 66 | func (p *WorkerPool) Drain() []error { |
| 67 | if p.cancelFn != nil { |