From af3520b4be195c68dc4f5d5a0eca65fb7818884e Mon Sep 17 00:00:00 2001 From: Mohamad mehdi Kharatizadeh Date: Wed, 9 Jan 2019 02:08:22 +0100 Subject: [PATCH] use runtime.Frame instead of program counters after braking change to github.com/pkg/errors (#75) --- sentry.go | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/sentry.go b/sentry.go index 2a5c388..59661f8 100644 --- a/sentry.go +++ b/sentry.go @@ -3,7 +3,6 @@ package logrus_sentry import ( "encoding/json" "fmt" - "runtime" "sync" "time" @@ -114,7 +113,7 @@ func NewWithClientSentryHook(client *raven.Client, levels []logrus.Level) (*Sent StacktraceConfiguration: StackTraceConfiguration{ Enable: false, Level: logrus.ErrorLevel, - Skip: 5, + Skip: 6, Context: 0, InAppPrefixes: nil, SendExceptionType: true, @@ -310,11 +309,9 @@ func (hook *SentryHook) convertStackTrace(st errors.StackTrace) *raven.Stacktrac stConfig := &hook.StacktraceConfiguration stFrames := []errors.Frame(st) frames := make([]*raven.StacktraceFrame, 0, len(stFrames)) - for i := range stFrames { - pc := uintptr(stFrames[i]) - fn := runtime.FuncForPC(pc) - file, line := fn.FileLine(pc) - frame := raven.NewStacktraceFrame(pc, fn.Name(), file, line, stConfig.Context, stConfig.InAppPrefixes) + for _, stFrame := range stFrames { + frame := raven.NewStacktraceFrame(stFrame.PC, stFrame.Func.Name(), stFrame.File, stFrame.Line, + stConfig.Context, stConfig.InAppPrefixes) if frame != nil { frames = append(frames, frame) }