1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-18 03:56:52 +02:00
goreleaser/internal/pipe/pipe.go
Ville Skyttä ef690d07ef
style: spelling and grammar fixes (#4069)
Co-authored-by: Carlos Alexandro Becker <caarlos0@users.noreply.github.com>
2023-06-05 13:08:57 -03:00

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, ", "))
}