-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstacktrace.go
More file actions
77 lines (73 loc) · 1.56 KB
/
stacktrace.go
File metadata and controls
77 lines (73 loc) · 1.56 KB
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 errors
import (
"github.com/valyala/bytebufferpool"
"runtime"
"strconv"
"strings"
"unsafe"
)
func newStacktrace(skip int) Stacktrace {
pc, file, line, ok := runtime.Caller(skip)
if !ok {
return Stacktrace{
Fn: "unknown",
File: "unknown",
Line: 0,
}
}
if strings.IndexByte(file, '/') == 0 || strings.IndexByte(file, ':') == 1 {
idx := strings.Index(file, "/src/")
if idx > 0 {
file = file[idx+5:]
} else {
idx = strings.Index(file, "/pkg/mod/")
if idx > 0 {
file = file[idx+9:]
}
}
}
fn := runtime.FuncForPC(pc)
return Stacktrace{
Fn: fn.Name(),
File: file,
Line: line,
}
}
type Stacktrace struct {
Fn string `json:"fn" avro:"fn"`
File string `json:"file" avro:"file"`
Line int `json:"line" avro:"line"`
}
func (s Stacktrace) MarshalJSON() (p []byte, err error) {
buf := bytebufferpool.Get()
_, _ = buf.Write(lb)
// fn
_, _ = buf.Write(dqm)
_, _ = buf.Write(fnIdent)
_, _ = buf.Write(dqm)
_, _ = buf.Write(colon)
_, _ = buf.Write(dqm)
_, _ = buf.WriteString(s.Fn)
_, _ = buf.Write(dqm)
_, _ = buf.Write(comma)
// file
_, _ = buf.Write(dqm)
_, _ = buf.Write(fileIdent)
_, _ = buf.Write(dqm)
_, _ = buf.Write(colon)
_, _ = buf.Write(dqm)
_, _ = buf.WriteString(s.File)
_, _ = buf.Write(dqm)
_, _ = buf.Write(comma)
// lind
_, _ = buf.Write(dqm)
_, _ = buf.Write(lineIdent)
_, _ = buf.Write(dqm)
_, _ = buf.Write(colon)
_, _ = buf.WriteString(strconv.Itoa(s.Line))
_, _ = buf.Write(rb)
ss := buf.String()
p = unsafe.Slice(unsafe.StringData(ss), len(ss))
bytebufferpool.Put(buf)
return
}