39 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
[](https://godoc.org/github.com/go-stack/stack)
 | 
						|
[](https://goreportcard.com/report/go-stack/stack)
 | 
						|
[](https://travis-ci.org/go-stack/stack)
 | 
						|
[](https://coveralls.io/github/go-stack/stack?branch=master)
 | 
						|
 | 
						|
# 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](http://semver.org/) 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.
 | 
						|
 | 
						|
```go
 | 
						|
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.
 |