Documentation ¶
Index ¶
- Variables
- func As(err error, target interface{}) bool
- func Catch(err *error, handler func(err error, fr *Frame))
- func ErrorCallerf(skip int, format string, args ...interface{}) error
- func Errorf(format string, args ...interface{}) error
- func Is(err, target error) bool
- func Join(errs ...error) error
- func New(s string) error
- func Opaque(err error) error
- func Try(err error)
- func Try1[T1 any](v1 T1, err error) T1
- func Try2[T1, T2 any](v1 T1, v2 T2, err error) (T1, T2)
- func Try3[T1, T2, T3 any](v1 T1, v2 T2, v3 T3, err error) (T1, T2, T3)
- func Try4[T1, T2, T3, T4 any](v1 T1, v2 T2, v3 T3, v4 T4, err error) (T1, T2, T3, T4)
- func Try5[T1, T2, T3, T4, T5 any](v1 T1, v2 T2, v3 T3, v4 T4, v5 T5, err error) (T1, T2, T3, T4, T5)
- func Unwrap(err error) error
- func Wrap(err error, skip int) error
- type ErrorList
- func (e *ErrorList) As(target interface{}) bool
- func (e *ErrorList) Err() error
- func (e *ErrorList) Error() string
- func (e *ErrorList) ErrorCallerf(skip int, format string, args ...interface{})
- func (e *ErrorList) Errorf(format string, args ...interface{})
- func (e *ErrorList) Errors() []error
- func (e *ErrorList) Is(target error) bool
- func (e *ErrorList) PushCallerIf(err error, skip int) bool
- func (e *ErrorList) PushIf(err error) bool
- func (e *ErrorList) Reset()
- func (e *ErrorList) Safe()
- func (e *ErrorList) Unwrap() error
- type Formatter
- type Frame
- type Framer
- type Group
- type HasAs
- type HasIs
- type JSONError
- func (e *JSONError) Error() string
- func (e *JSONError) Format(s fmt.State, v rune)
- func (e *JSONError) FormatError(p Printer) (next error)
- func (e *JSONError) Frame() *Frame
- func (e *JSONError) Is(target error) bool
- func (e *JSONError) MarshalJSON() ([]byte, error)
- func (e *JSONError) Unwrap() error
- type Printer
- type String
- type Wrapper
Examples ¶
Constants ¶
This section is empty.
Variables ¶
var ( AlwaysWithCaller = true WrappedErrorTextIncludesFrameInfo = false )
var CatchAll func(err error, fr *Frame)
Functions ¶
func ErrorCallerf ¶
Types ¶
type ErrorList ¶
type ErrorList struct {
// contains filtered or unexported fields
}
func NewSafeList ¶
func (*ErrorList) As ¶
As implements errors.As by checking if target is ErrorList, otherwise will go through each error.
func (*ErrorList) ErrorCallerf ¶
type Frame ¶
A Frame contains part of a call stack. Copied from xerrors
func Caller ¶
Caller returns a Frame that describes a frame on the caller's stack. The argument skip is the number of frames to skip over. Caller(0) returns the frame for the caller of Caller.
func (*Frame) Format ¶
Format prints the stack as error detail. It should be called from an error's Format implementation after printing any other error detail.
type Group ¶
type Group struct {
// contains filtered or unexported fields
}
A Group is a collection of goroutines working on subtasks that are part of the same overall task.
A zero Group is valid and does not cancel on error.
Example (JustErrors) ¶
JustErrors illustrates the use of a Group in place of a sync.WaitGroup to simplify goroutine counting and error handling. This example is derived from the sync.WaitGroup example at https://golang.org/pkg/sync/#example_WaitGroup.
g := new(Group) urls := []string{ "http://www.golang.org/", "http://www.google.com/", "http://www.somestupidname.com/", } for _, url := range urls { // Launch a goroutine to fetch the URL. url := url // https://golang.org/doc/faq#closures_and_goroutines g.Go(func() error { // Fetch the URL. resp, err := http.Get(url) if err == nil { resp.Body.Close() } return err }) } // Wait for all HTTP fetches to complete. if err := g.Wait(); err == nil { fmt.Println("Successfully fetched all URLs.") }
Output:
Example (Parallel) ¶
Parallel illustrates the use of a Group for synchronizing a simple parallel task: the "Google Search 2.0" function from https://talks.golang.org/2012/concurrency.slide#46, augmented with a Context and error-handling.
Google := func(ctx context.Context, query string) ([]Result, error) { g, ctx := GroupWithContext(ctx) searches := []Search{Web, Image, Video} results := make([]Result, len(searches)) for i, search := range searches { i, search := i, search // https://golang.org/doc/faq#closures_and_goroutines g.Go(func() error { result, err := search(ctx, query) if err == nil { results[i] = result } return err }) } if err := g.Wait(); err != nil { return nil, err } return results, nil } results, err := Google(context.Background(), "golang") if err != nil { fmt.Fprintln(os.Stderr, err) return } for _, result := range results { fmt.Println(result) }
Output: web result for "golang" image result for "golang" video result for "golang"
func GroupWithContext ¶
WithContext returns a new Group and an associated Context derived from ctx.
The derived Context is canceled the first time a function passed to Go returns a non-nil error or the first time Wait returns, whichever occurs first.
func (*Group) Go ¶
Go calls the given function in a new goroutine. It blocks until the new goroutine can be added without the number of active goroutines in the group exceeding the configured limit.
The first call to return a non-nil error cancels the group; its error will be returned by Wait.
func (*Group) SetLimit ¶
SetLimit limits the number of active goroutines in this group to at most n. A negative value indicates no limit.
Any subsequent call to the Go method will block until it can add an active goroutine without exceeding the configured limit.
The limit must not be modified while any goroutines in the group are active.
func (*Group) TryGo ¶
TryGo calls the given function in a new goroutine only if the number of active goroutines in the group is currently below the configured limit.
The return value reports whether the goroutine was started.
type HasAs ¶
type HasAs interface {
As(interface{}) bool
}
HasAs is a handy interface to check if an error implements As
type JSONError ¶
type JSONError struct { Err string `json:"error,omitempty"` Func string `json:"func,omitempty"` File string `json:"file,omitempty"` Line int `json:"line,omitempty"` // contains filtered or unexported fields }