ipld-eth-server/vendor/github.com/go-stack/stack
Matt K 293dd2e848 Add vendor dir (#16) (#4)
* Add vendor dir so builds dont require dep

* Pin specific version go-eth version
2018-01-29 13:44:18 -06:00
..
.travis.yml Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00
format_test.go Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00
LICENSE.md Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00
README.md Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00
stack_test.go Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00
stack-go19_test.go Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00
stack.go Add vendor dir (#16) (#4) 2018-01-29 13:44:18 -06:00

GoDoc Go Report Card TravisCI Coverage Status

stack

Package stack implements utilities to capture, manipulate, and format call stacks. It provides a simpler API than package runtime.

The implementation takes care of the minutia and special cases of interpreting the program counter (pc) values returned by runtime.Callers.

Versioning

Package stack publishes releases via semver compatible Git tags prefixed with a single 'v'. The master branch always contains the latest release. The develop branch contains unreleased commits.

Formatting

Package stack's types implement fmt.Formatter, which provides a simple and flexible way to declaratively configure formatting when used with logging or error tracking packages.

func DoTheThing() {
    c := stack.Caller(0)
    log.Print(c)          // "source.go:10"
    log.Printf("%+v", c)  // "pkg/path/source.go:10"
    log.Printf("%n", c)   // "DoTheThing"

    s := stack.Trace().TrimRuntime()
    log.Print(s)          // "[source.go:15 caller.go:42 main.go:14]"
}

See the docs for all of the supported formatting options.