This repository has been archived by the owner on Sep 13, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
errors.go
94 lines (79 loc) · 2.77 KB
/
errors.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/*
Copyright 2019 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package errors
import (
stderrors "errors"
pkgerrors "github.com/pkg/errors"
)
// New returns an error with the supplied message.
// New also records the stack trace at the point it was called.
func New(message string) error {
return pkgerrors.New(message)
}
// NewWithoutStack is like new but does NOT wrap with a stack
// This is useful for exported errors
func NewWithoutStack(message string) error {
return stderrors.New(message)
}
// Errorf formats according to a format specifier and returns the string as a
// value that satisfies error. Errorf also records the stack trace at the
// point it was called.
func Errorf(format string, args ...interface{}) error {
return pkgerrors.Errorf(format, args...)
}
// Wrap returns an error annotating err with a stack trace at the point Wrap
// is called, and the supplied message. If err is nil, Wrap returns nil.
func Wrap(err error, message string) error {
return pkgerrors.Wrap(err, message)
}
// Wrapf returns an error annotating err with a stack trace at the point Wrapf
// is called, and the format specifier. If err is nil, Wrapf returns nil.
func Wrapf(err error, format string, args ...interface{}) error {
return pkgerrors.Wrapf(err, format, args...)
}
// WithStack annotates err with a stack trace at the point WithStack was called.
// If err is nil, WithStack returns nil.
func WithStack(err error) error {
return pkgerrors.WithStack(err)
}
// Causer is an interface to github.com/pkg/errors error's Cause() wrapping
type Causer interface {
// Cause returns the underlying error
Cause() error
}
// StackTracer is an interface to github.com/pkg/errors error's StackTrace()
type StackTracer interface {
// StackTrace returns the StackTrace ...
// TODO: return our own type instead?
// https://github.com/pkg/errors#roadmap
StackTrace() pkgerrors.StackTrace
}
// StackTrace returns the deepest StackTrace in a Cause chain
// https://github.com/pkg/errors/issues/173
func StackTrace(err error) pkgerrors.StackTrace {
var stackErr error
for {
if _, ok := err.(StackTracer); ok {
stackErr = err
}
if causerErr, ok := err.(Causer); ok {
err = causerErr.Cause()
} else {
break
}
}
if stackErr != nil {
return stackErr.(StackTracer).StackTrace()
}
return nil
}