mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-01-18 03:56:52 +02:00
ef690d07ef
Co-authored-by: Carlos Alexandro Becker <caarlos0@users.noreply.github.com>
76 lines
2.1 KiB
Go
76 lines
2.1 KiB
Go
// Package pipe provides generic errors for pipes to use.
|
|
package pipe
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"strings"
|
|
)
|
|
|
|
// ErrSnapshotEnabled happens when goreleaser is running in snapshot mode.
|
|
// It usually means that publishing and maybe some validations were skipped.
|
|
var ErrSnapshotEnabled = Skip("disabled during snapshot mode")
|
|
|
|
// ErrSkipPublishEnabled happens if --skip-publish is set.
|
|
// It means that the part of a Piper that publishes its artifacts was not run.
|
|
var ErrSkipPublishEnabled = Skip("publishing is disabled")
|
|
|
|
// ErrSkipAnnounceEnabled happens if --skip-announce is set.
|
|
var ErrSkipAnnounceEnabled = Skip("announcing is disabled")
|
|
|
|
// ErrSkipSignEnabled happens if --skip-sign is set.
|
|
// It means that the part of a Piper that signs some things was not run.
|
|
var ErrSkipSignEnabled = Skip("artifact signing is disabled")
|
|
|
|
// ErrSkipValidateEnabled happens if --skip-validate is set.
|
|
// It means that the part of a Piper that validates some things was not run.
|
|
var ErrSkipValidateEnabled = Skip("validation is disabled")
|
|
|
|
// IsSkip returns true if the error is an ErrSkip.
|
|
func IsSkip(err error) bool {
|
|
return errors.As(err, &ErrSkip{})
|
|
}
|
|
|
|
// ErrSkip occurs when a pipe is skipped for some reason.
|
|
type ErrSkip struct {
|
|
reason string
|
|
}
|
|
|
|
// Error implements the error interface. returns the reason the pipe was skipped.
|
|
func (e ErrSkip) Error() string {
|
|
return e.reason
|
|
}
|
|
|
|
// Skip skips this pipe with the given reason.
|
|
func Skip(reason string) ErrSkip {
|
|
return ErrSkip{reason: reason}
|
|
}
|
|
|
|
// Skipf skips this pipe with the given reason.
|
|
func Skipf(format string, a ...any) ErrSkip {
|
|
return Skip(fmt.Sprintf(format, a...))
|
|
}
|
|
|
|
// SkipMemento remembers previous skip errors so you can return them all at once later.
|
|
type SkipMemento struct {
|
|
skips []string
|
|
}
|
|
|
|
// Remember a skip.
|
|
func (e *SkipMemento) Remember(err error) {
|
|
for _, skip := range e.skips {
|
|
if skip == err.Error() {
|
|
return
|
|
}
|
|
}
|
|
e.skips = append(e.skips, err.Error())
|
|
}
|
|
|
|
// Evaluate return a skip error with all previous skips, or nil if none happened.
|
|
func (e *SkipMemento) Evaluate() error {
|
|
if len(e.skips) == 0 {
|
|
return nil
|
|
}
|
|
return Skip(strings.Join(e.skips, ", "))
|
|
}
|