source: code/trunk/vendor/golang.org/x/xerrors/frame.go@ 823

Last change on this file since 823 was 822, checked in by yakumo.izuru, 22 months ago

Prefer immortal.run over runit and rc.d, use vendored modules
for convenience.

Signed-off-by: Izuru Yakumo <yakumo.izuru@…>

File size: 1.5 KB
Line 
1// Copyright 2018 The Go Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style
3// license that can be found in the LICENSE file.
4
5package xerrors
6
7import (
8 "runtime"
9)
10
11// A Frame contains part of a call stack.
12type Frame struct {
13 // Make room for three PCs: the one we were asked for, what it called,
14 // and possibly a PC for skipPleaseUseCallersFrames. See:
15 // https://go.googlesource.com/go/+/032678e0fb/src/runtime/extern.go#169
16 frames [3]uintptr
17}
18
19// Caller returns a Frame that describes a frame on the caller's stack.
20// The argument skip is the number of frames to skip over.
21// Caller(0) returns the frame for the caller of Caller.
22func Caller(skip int) Frame {
23 var s Frame
24 runtime.Callers(skip+1, s.frames[:])
25 return s
26}
27
28// location reports the file, line, and function of a frame.
29//
30// The returned function may be "" even if file and line are not.
31func (f Frame) location() (function, file string, line int) {
32 frames := runtime.CallersFrames(f.frames[:])
33 if _, ok := frames.Next(); !ok {
34 return "", "", 0
35 }
36 fr, ok := frames.Next()
37 if !ok {
38 return "", "", 0
39 }
40 return fr.Function, fr.File, fr.Line
41}
42
43// Format prints the stack as error detail.
44// It should be called from an error's Format implementation
45// after printing any other error detail.
46func (f Frame) Format(p Printer) {
47 if p.Detail() {
48 function, file, line := f.location()
49 if function != "" {
50 p.Printf("%s\n ", function)
51 }
52 if file != "" {
53 p.Printf("%s:%d\n", file, line)
54 }
55 }
56}
Note: See TracBrowser for help on using the repository browser.