-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbugsnag.go
77 lines (63 loc) · 1.94 KB
/
bugsnag.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
package spcontext
import (
"runtime"
"strings"
bugsnagerrors "github.com/bugsnag/bugsnag-go/v2/errors"
"github.com/pkg/errors"
)
// BugsnagLogger wraps the given Context inside a bugsnag friendly logger.
type BugsnagLogger struct {
Ctx Context
}
// Printf logs the message with info level.
func (l *BugsnagLogger) Printf(format string, v ...interface{}) {
l.Ctx.Infof(format, v...)
}
type stackTracer interface {
error
StackTrace() errors.StackTrace
}
// errorWithStackFrames satisfies bugsnag.ErrorWithStackFrames for a github.com/pkg/errors error.
type errorWithStackFrames struct {
err stackTracer
}
// Cause returns initial error, provides compatibility for pkg/errors chains.
func (w *errorWithStackFrames) Cause() error { return w.err }
// Unwrap returns initial error, provides compatibility for Go 1.13 error chains.
func (w *errorWithStackFrames) Unwrap() error { return w.err }
func (e *errorWithStackFrames) Error() string {
return e.err.Error()
}
func (e *errorWithStackFrames) StackFrames() []bugsnagerrors.StackFrame {
stackTrace := e.err.StackTrace()
out := make([]bugsnagerrors.StackFrame, len(stackTrace))
for i, frame := range stackTrace {
pc := uintptr(frame) - 1
fn := runtime.FuncForPC(pc)
file, line := fn.FileLine(pc)
name := fn.Name()
var pkg string
var fnName string
if pkgDivider := strings.LastIndex(name, "/"); pkgDivider != -1 {
pkg = name[:pkgDivider]
fnName = name[pkgDivider+1:]
if fnDivider := strings.LastIndex(fnName, "."); fnDivider != -1 {
fnName = fnName[fnDivider+1:]
}
} else if pkgDivider := strings.Index(name, "."); pkgDivider != -1 {
pkg = name[:pkgDivider]
fnName = name[pkgDivider+1:]
if fnDivider := strings.LastIndex(fnName, "."); fnDivider != -1 {
fnName = fnName[fnDivider+1:]
}
}
out[i] = bugsnagerrors.StackFrame{
File: file,
LineNumber: line,
Name: fnName,
Package: pkg,
ProgramCounter: pc,
}
}
return out
}