mirror of
https://github.com/kemko/icecast-ripper.git
synced 2026-01-01 15:55:42 +03:00
Bumps [github.com/spf13/viper](https://github.com/spf13/viper) from 1.20.1 to 1.21.0. - [Release notes](https://github.com/spf13/viper/releases) - [Commits](https://github.com/spf13/viper/compare/v1.20.1...v1.21.0) --- updated-dependencies: - dependency-name: github.com/spf13/viper dependency-version: 1.21.0 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
86 lines
2.8 KiB
Go
86 lines
2.8 KiB
Go
package pool
|
|
|
|
import (
|
|
"context"
|
|
)
|
|
|
|
// ResultContextPool is a pool that runs tasks that take a context and return a
|
|
// result. The context passed to the task will be canceled if any of the tasks
|
|
// return an error, which makes its functionality different than just capturing
|
|
// a context with the task closure.
|
|
//
|
|
// The configuration methods (With*) will panic if they are used after calling
|
|
// Go() for the first time.
|
|
type ResultContextPool[T any] struct {
|
|
contextPool ContextPool
|
|
agg resultAggregator[T]
|
|
collectErrored bool
|
|
}
|
|
|
|
// Go submits a task to the pool. If all goroutines in the pool
|
|
// are busy, a call to Go() will block until the task can be started.
|
|
func (p *ResultContextPool[T]) Go(f func(context.Context) (T, error)) {
|
|
idx := p.agg.nextIndex()
|
|
p.contextPool.Go(func(ctx context.Context) error {
|
|
res, err := f(ctx)
|
|
p.agg.save(idx, res, err != nil)
|
|
return err
|
|
})
|
|
}
|
|
|
|
// Wait cleans up all spawned goroutines, propagates any panics, and
|
|
// returns an error if any of the tasks errored.
|
|
func (p *ResultContextPool[T]) Wait() ([]T, error) {
|
|
err := p.contextPool.Wait()
|
|
results := p.agg.collect(p.collectErrored)
|
|
p.agg = resultAggregator[T]{}
|
|
return results, err
|
|
}
|
|
|
|
// WithCollectErrored configures the pool to still collect the result of a task
|
|
// even if the task returned an error. By default, the result of tasks that errored
|
|
// are ignored and only the error is collected.
|
|
func (p *ResultContextPool[T]) WithCollectErrored() *ResultContextPool[T] {
|
|
p.panicIfInitialized()
|
|
p.collectErrored = true
|
|
return p
|
|
}
|
|
|
|
// WithFirstError configures the pool to only return the first error
|
|
// returned by a task. By default, Wait() will return a combined error.
|
|
func (p *ResultContextPool[T]) WithFirstError() *ResultContextPool[T] {
|
|
p.panicIfInitialized()
|
|
p.contextPool.WithFirstError()
|
|
return p
|
|
}
|
|
|
|
// WithCancelOnError configures the pool to cancel its context as soon as
|
|
// any task returns an error. By default, the pool's context is not
|
|
// canceled until the parent context is canceled.
|
|
func (p *ResultContextPool[T]) WithCancelOnError() *ResultContextPool[T] {
|
|
p.panicIfInitialized()
|
|
p.contextPool.WithCancelOnError()
|
|
return p
|
|
}
|
|
|
|
// WithFailFast is an alias for the combination of WithFirstError and
|
|
// WithCancelOnError. By default, the errors from all tasks are returned and
|
|
// the pool's context is not canceled until the parent context is canceled.
|
|
func (p *ResultContextPool[T]) WithFailFast() *ResultContextPool[T] {
|
|
p.panicIfInitialized()
|
|
p.contextPool.WithFailFast()
|
|
return p
|
|
}
|
|
|
|
// WithMaxGoroutines limits the number of goroutines in a pool.
|
|
// Defaults to unlimited. Panics if n < 1.
|
|
func (p *ResultContextPool[T]) WithMaxGoroutines(n int) *ResultContextPool[T] {
|
|
p.panicIfInitialized()
|
|
p.contextPool.WithMaxGoroutines(n)
|
|
return p
|
|
}
|
|
|
|
func (p *ResultContextPool[T]) panicIfInitialized() {
|
|
p.contextPool.panicIfInitialized()
|
|
}
|