package errors
import "k8s.io/apimachinery/pkg/util/errors"
Package errors implements various utility functions and types around errors.
Index ¶
- Variables
- func FilterOut(err error, fns ...Matcher) error
- func Reduce(err error) error
- type Aggregate
- func AggregateGoroutines(funcs ...func() error) Aggregate
- func CreateAggregateFromMessageCountMap(m MessageCountMap) Aggregate
- func Flatten(agg Aggregate) Aggregate
- func NewAggregate(errlist []error) Aggregate
- type Matcher
- type MessageCountMap
Variables ¶
ErrPreconditionViolated is returned when the precondition is violated
Functions ¶
func FilterOut ¶
FilterOut removes all errors that match any of the matchers from the input error. If the input is a singular error, only that error is tested. If the input implements the Aggregate interface, the list of errors will be processed recursively.
This can be used, for example, to remove known-OK errors (such as io.EOF or os.PathNotFound) from a list of errors.
func Reduce ¶
Reduce will return err or nil, if err is an Aggregate and only has one item, the first item in the aggregate.
Types ¶
type Aggregate ¶
Aggregate represents an object that contains multiple errors, but does not necessarily have singular semantic meaning. The aggregate can be used with `errors.Is()` to check for the occurrence of a specific error type. Errors.As() is not supported, because the caller presumably cares about a specific error of potentially multiple that match the given type.
func AggregateGoroutines ¶
AggregateGoroutines runs the provided functions in parallel, stuffing all non-nil errors into the returned Aggregate. Returns nil if all the functions complete successfully.
func CreateAggregateFromMessageCountMap ¶
func CreateAggregateFromMessageCountMap(m MessageCountMap) Aggregate
CreateAggregateFromMessageCountMap converts MessageCountMap Aggregate
func Flatten ¶
Flatten takes an Aggregate, which may hold other Aggregates in arbitrary nesting, and flattens them all into a single Aggregate, recursively.
func NewAggregate ¶
NewAggregate converts a slice of errors into an Aggregate interface, which is itself an implementation of the error interface. If the slice is empty, this returns nil. It will check if any of the element of input error list is nil, to avoid nil pointer panic when call Error().
type Matcher ¶
Matcher is used to match errors. Returns true if the error matches.
type MessageCountMap ¶
MessageCountMap contains occurrence for each error message.
Source Files ¶
doc.go errors.go
- Version
- v0.33.0 (latest)
- Published
- Apr 11, 2025
- Platform
- linux/amd64
- Imports
- 3 packages
- Last checked
- 3 hours ago –
Tools for package owners.