No Description

Conrad Irwin f104a1a5b4 Go modules opt-in 5 years ago
.travis.yml c9f81afe77 Add Travis config file for continuous integration. 7 years ago
LICENSE.MIT a25f26c222 Import library from bugsnag-go 11 years ago
README.md 722bdf0b8f Add travis build status badge to README. 7 years ago
cover.out a25f26c222 Import library from bugsnag-go 11 years ago
error.go 18bd882d94 Wrapping returns nil rather than Error(<nil>). 7 years ago
error_test.go 331a2a9283 optimize SourceLine 5 years ago
go.mod f104a1a5b4 Go modules opt-in 5 years ago
parse_panic.go a25f26c222 Import library from bugsnag-go 11 years ago
parse_panic_test.go a25f26c222 Import library from bugsnag-go 11 years ago
stackframe.go 331a2a9283 optimize SourceLine 5 years ago

README.md

go-errors/errors

Build Status

Package errors adds stacktrace support to errors in go.

This is particularly useful when you want to understand the state of execution when an error was returned unexpectedly.

It provides the type *Error which implements the standard golang error interface, so you can use this library interchangably with code that is expecting a normal error return.

Usage

Full documentation is available on godoc, but here's a simple example:

package crashy

import "github.com/go-errors/errors"

var Crashed = errors.Errorf("oh dear")

func Crash() error {
    return errors.New(Crashed)
}

This can be called as follows:

package main

import (
    "crashy"
    "fmt"
    "github.com/go-errors/errors"
)

func main() {
    err := crashy.Crash()
    if err != nil {
        if errors.Is(err, crashy.Crashed) {
            fmt.Println(err.(*errors.Error).ErrorStack())
        } else {
            panic(err)
        }
    }
}

Meta-fu

This package was original written to allow reporting to Bugsnag from bugsnag-go, but after I found similar packages by Facebook and Dropbox, it was moved to one canonical location so everyone can benefit.

This package is licensed under the MIT license, see LICENSE.MIT for details.