|
||
---|---|---|
.. | ||
.codecov.yml | ||
.editorconfig | ||
.gitignore | ||
.golangci.yml | ||
LICENSE | ||
Makefile | ||
README.md | ||
adaptor.go | ||
doc.go | ||
errors.go | ||
format.go | ||
frame.go | ||
go.coverage.sh | ||
go.test.sh | ||
into.go | ||
join_go120.go | ||
must.go | ||
noerrtrace.go | ||
trace.go | ||
wrap.go |
README.md
errors
data:image/s3,"s3://crabby-images/d36a2/d36a24c1fe59f21052e8b3f40712b5f95276df08" alt="codecov"
Fork of xerrors with explicit Wrap instead of %w
.
Clear is better than clever.
go get github.com/go-faster/errors
errors.Wrap(err, "message")
Why
- Using
Wrap
is the most explicit way to wrap errors - Wrapping with
fmt.Errorf("foo: %w", err)
is implicit, redundant and error-prone - Parsing
"foo: %w"
is implicit, redundant and slow - The pkg/errors and xerrors are not maintainted
- The cockroachdb/errors is too big
- The
errors
has no caller stack trace
Don't need traces?
Call errors.DisableTrace
or use build tag noerrtrace
.
Additional features
Into
Generic type assertion for errors.
// Into finds the first error in err's chain that matches target type T, and if so, returns it.
//
// Into is type-safe alternative to As.
func Into[T error](err error) (val T, ok bool)
if pathError, ok := errors.Into[*os.PathError](err); ok {
fmt.Println("Failed at path:", pathError.Path)
}
Must
Must is a generic helper, like template.Must, that wraps a call to a function returning (T, error) and panics if the error is non-nil.
func Must[T any](val T, err error) T
License
BSD-3-Clause, same as Go sources