1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2026-04-30 20:19:47 +02:00
Files
goreleaser/internal/middleware/errhandler/error.go
T

58 lines
1.3 KiB
Go
Raw Normal View History

package errhandler
2019-01-22 01:56:16 -02:00
import (
2022-06-21 21:11:15 -03:00
"github.com/caarlos0/log"
"github.com/goreleaser/goreleaser/internal/middleware"
2019-01-22 01:56:16 -02:00
"github.com/goreleaser/goreleaser/internal/pipe"
"github.com/goreleaser/goreleaser/pkg/context"
"github.com/hashicorp/go-multierror"
2019-01-22 01:56:16 -02:00
)
// Handle handles an action error, ignoring and logging pipe skipped
2019-01-22 01:56:16 -02:00
// errors.
func Handle(action middleware.Action) middleware.Action {
2019-01-22 01:56:16 -02:00
return func(ctx *context.Context) error {
2021-04-19 09:31:57 -03:00
err := action(ctx)
2019-01-22 01:56:16 -02:00
if err == nil {
return nil
}
if pipe.IsSkip(err) {
log.WithField("reason", err.Error()).Warn("pipe skipped")
2019-01-22 01:56:16 -02:00
return nil
}
return err
}
}
// Memo is a handler that memorizes errors, so you can grab them all in the end
// instead of returning each of them.
type Memo struct {
err error
}
// Error returns the underlying error.
func (m *Memo) Error() error {
return m.err
}
// Wrap the given action, memorizing its errors.
// The resulting action will always return a nil error.
func (m *Memo) Wrap(action middleware.Action) middleware.Action {
return func(ctx *context.Context) error {
err := action(ctx)
if err == nil {
return nil
}
2023-06-20 09:33:59 -03:00
m.Memorize(err)
return nil
}
}
2023-06-20 09:33:59 -03:00
func (m *Memo) Memorize(err error) {
if pipe.IsSkip(err) {
log.WithField("reason", err.Error()).Warn("pipe skipped")
return
}
m.err = multierror.Append(m.err, err)
}