Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ztrue/tracerr
Golang errors with stack trace and source fragments.
https://github.com/ztrue/tracerr
debug error-handling errors errors-log go golang source-map stacktrace
Last synced: 3 days ago
JSON representation
Golang errors with stack trace and source fragments.
- Host: GitHub
- URL: https://github.com/ztrue/tracerr
- Owner: ztrue
- License: mit
- Created: 2019-02-06T18:57:46.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-05-29T03:24:53.000Z (8 months ago)
- Last Synced: 2024-07-31T20:51:25.689Z (5 months ago)
- Topics: debug, error-handling, errors, errors-log, go, golang, source-map, stacktrace
- Language: Go
- Homepage:
- Size: 705 KB
- Stars: 956
- Watchers: 12
- Forks: 41
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go - tracerr - Golang errors with stack trace and source fragments. (Error Handling / Search and Analytic Databases)
- awesome-golang-repositories - tracerr
- awesome-go-extra - tracerr - 02-06T18:57:46Z|2019-03-15T03:57:28Z| (Error Handling / Advanced Console UIs)
- awesome-go - tracerr - Golang errors with stack trace and source fragments. Stars:`1.0K`. (Error Handling / Search and Analytic Databases)
README
# Golang Errors with Stack Trace and Source Fragments
[![GoDoc](https://godoc.org/github.com/ztrue/tracerr?status.svg)](https://godoc.org/github.com/ztrue/tracerr)
[![Report](https://goreportcard.com/badge/github.com/ztrue/tracerr)](https://goreportcard.com/report/github.com/ztrue/tracerr)
[![Coverage Status](https://coveralls.io/repos/github/ztrue/tracerr/badge.svg?branch=master)](https://coveralls.io/github/ztrue/tracerr?branch=master)Tired of uninformative error output? Probably this will be more convenient:
![Output](output.png)
## Example
```go
package mainimport (
"io/ioutil""github.com/ztrue/tracerr"
)func main() {
if err := read(); err != nil {
tracerr.PrintSourceColor(err)
}
}func read() error {
return readNonExistent()
}func readNonExistent() error {
_, err := ioutil.ReadFile("/tmp/non_existent_file")
// Add stack trace to existing error, no matter if it's nil.
return tracerr.Wrap(err)
}
```Find more executable examples in [examples](examples) dir.
## How to Use
### Import
```go
import "github.com/ztrue/tracerr"
```### Create New Error
```go
err := tracerr.New("some error")
```Or:
```go
err := tracerr.Errorf("some error %d", num)
```### Add Stack Trace to Existing Error
> If `err` is `nil` then it still be `nil` with no stack trace added.
```go
err = tracerr.Wrap(err)
```### Print Error and Stack Trace
> Stack trace will be printed only if `err` is of type `tracerr.Error`, otherwise just error text will be shown.
This will print error message and stack trace if any:
```go
tracerr.Print(err)
```This will add source code:
```go
tracerr.PrintSource(err)
```It's able to set up number of lines of code to display for each frame, which is `6` by default:
```go
tracerr.PrintSource(err, 9)
```Or to set up number of lines before and after traced line:
```go
tracerr.PrintSource(err, 5, 2)
```The same, but with color, which is much more useful:
```go
tracerr.PrintSourceColor(err)
``````go
tracerr.PrintSourceColor(err, 9)
``````go
tracerr.PrintSourceColor(err, 5, 2)
```### Save Output to Variable
It's also able to save output to variable instead of printing it, which works the same way:
```go
text := tracerr.Sprint(err)
``````go
text := tracerr.SprintSource(err)
``````go
text := tracerr.SprintSource(err, 9)
``````go
text := tracerr.SprintSource(err, 5, 2)
```### Get Stack Trace
> Stack trace will be empty if `err` is not an instance of `tracerr.Error`.
```go
frames := tracerr.StackTrace(err)
```Or if `err` is of type `tracerr.Error`:
```go
frames := err.StackTrace()
```### Get Original Error
> Unwrapped error will be `nil` if `err` is `nil` and will be the same error if `err` is not an instance of `tracerr.Error`.
```go
err = tracerr.Unwrap(err)
```Or if `err` is of type `tracerr.Error`:
```go
err = err.Unwrap()
```## Performance
Stack trace causes a performance overhead, depending on a stack trace depth. This can be insignificant in a number of situations (such as HTTP request handling), however, avoid of adding a stack trace for really hot spots where a high number of errors created frequently, this can be inefficient.
> Benchmarks done on a MacBook Pro 2015 with go 1.11.
Benchmarks for creating a new error with a stack trace of different depth:
```
BenchmarkNew/5 200000 5646 ns/op 976 B/op 4 allocs/op
BenchmarkNew/10 200000 11565 ns/op 976 B/op 4 allocs/op
BenchmarkNew/20 50000 25629 ns/op 976 B/op 4 allocs/op
BenchmarkNew/40 20000 65833 ns/op 2768 B/op 5 allocs/op
```