2017-02-08 04:01:22 -05:00
|
|
|
// Package errors is a drop-in replacement for Golang lib 'errors'.
|
2016-12-04 03:10:47 -05:00
|
|
|
package errors
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2016-12-15 05:05:32 -05:00
|
|
|
|
2016-12-04 03:10:47 -05:00
|
|
|
"v2ray.com/core/common/serial"
|
|
|
|
)
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
type hasInnerError interface {
|
|
|
|
// Inner returns the underlying error of this one.
|
2016-12-04 03:10:47 -05:00
|
|
|
Inner() error
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// Error is an error object with underlying error.
|
2016-12-04 03:10:47 -05:00
|
|
|
type Error struct {
|
|
|
|
message string
|
|
|
|
inner error
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// Error implements error.Error().
|
2016-12-04 03:10:47 -05:00
|
|
|
func (v *Error) Error() string {
|
|
|
|
return v.message
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// Inner implements hasInnerError.Inner()
|
2016-12-04 03:10:47 -05:00
|
|
|
func (v *Error) Inner() error {
|
|
|
|
if v.inner == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return v.inner
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// New returns a new error object with message formed from given arguments.
|
2016-12-04 03:10:47 -05:00
|
|
|
func New(msg ...interface{}) error {
|
|
|
|
return &Error{
|
2017-01-17 04:22:09 -05:00
|
|
|
message: serial.Concat(msg...),
|
2016-12-04 03:10:47 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// Base returns an ErrorBuilder based on the given error.
|
2016-12-04 03:10:47 -05:00
|
|
|
func Base(err error) ErrorBuilder {
|
|
|
|
return ErrorBuilder{
|
|
|
|
error: err,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-15 05:05:32 -05:00
|
|
|
func Format(format string, values ...interface{}) error {
|
|
|
|
return New(fmt.Sprintf(format, values...))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Cause returns the root cause of this error.
|
2016-12-04 03:10:47 -05:00
|
|
|
func Cause(err error) error {
|
|
|
|
if err == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
for {
|
2017-02-08 04:01:22 -05:00
|
|
|
inner, ok := err.(hasInnerError)
|
2016-12-04 03:10:47 -05:00
|
|
|
if !ok {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if inner.Inner() == nil {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
err = inner.Inner()
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
type ErrorBuilder struct {
|
|
|
|
error
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// Message returns an error object with given message and base error.
|
2016-12-04 03:10:47 -05:00
|
|
|
func (v ErrorBuilder) Message(msg ...interface{}) error {
|
|
|
|
if v.error == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return &Error{
|
2017-01-29 02:20:47 -05:00
|
|
|
message: serial.Concat(msg...) + " > " + v.error.Error(),
|
2016-12-04 03:10:47 -05:00
|
|
|
inner: v.error,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:01:22 -05:00
|
|
|
// Format returns an errors object with given message format and base error.
|
2016-12-04 03:10:47 -05:00
|
|
|
func (v ErrorBuilder) Format(format string, values ...interface{}) error {
|
|
|
|
if v.error == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return &Error{
|
|
|
|
message: fmt.Sprintf(format, values...) + " > " + v.error.Error(),
|
|
|
|
inner: v.error,
|
|
|
|
}
|
|
|
|
}
|