Documentation ¶
Overview ¶
Package gerror provides simple functions to manipulate errors.
Very note that, this package is quite a base package, which should not import extra packages except standard packages, to avoid cycle imports.
Index ¶
- Constants
- func Cause(err error) error
- func Code(err error) int
- func Current(err error) error
- func New(text string) error
- func NewCode(code int, text string) error
- func NewCodeSkip(code, skip int, text string) error
- func NewCodeSkipf(code, skip int, format string, args ...interface{}) error
- func NewCodef(code int, format string, args ...interface{}) error
- func NewOption(option Option) error
- func NewSkip(skip int, text string) error
- func NewSkipf(skip int, format string, args ...interface{}) error
- func Newf(format string, args ...interface{}) error
- func Next(err error) error
- func Stack(err error) string
- func Wrap(err error, text string) error
- func WrapCode(code int, err error, text string) error
- func WrapCodeSkip(code, skip int, err error, text string) error
- func WrapCodeSkipf(code, skip int, err error, format string, args ...interface{}) error
- func WrapCodef(code int, err error, format string, args ...interface{}) error
- func WrapSkip(skip int, err error, text string) error
- func WrapSkipf(skip int, err error, format string, args ...interface{}) error
- func Wrapf(err error, format string, args ...interface{}) error
- type Error
- type Option
Examples ¶
Constants ¶
const ( CodeNil = -1 // No error code specified. CodeOk = 0 // It is OK. CodeInternalError = 50 + iota // An error occurred internally. CodeValidationFailed // Data validation failed. CodeDbOperationError // Database operation error. CodeInvalidParameter // The given parameter for current operation is invalid. CodeMissingParameter // Parameter for current operation is missing. CodeInvalidOperation // The function cannot be used like this. CodeInvalidConfiguration // The configuration is invalid for current operation. CodeMissingConfiguration // The configuration is missing for current operation. CodeNotImplemented // The operation is not implemented yet. CodeNotSupported // The operation is not supported yet. CodeOperationFailed // I tried, but I cannot give you what you want. CodeNotAuthorized // Not Authorized. CodeSecurityReason // Security Reason. CodeServerBusy // Server is busy, please try again later. CodeUnknown // Unknown error. CodeResourceNotExist // Resource does not exist. CodeBusinessValidationFailed = 300 + iota // Business validation failed. )
Variables ¶
This section is empty.
Functions ¶
func Code ¶ added in v1.14.6
Code returns the error code of current error. It returns -1 if it has no error code or it does not implements interface Code.
func Current ¶ added in v1.14.0
Current creates and returns the current level error. It returns nil if current level error is nil.
func NewCode ¶ added in v1.14.6
NewCode creates and returns an error that has error code and given text.
Example ¶
package main import ( "fmt" "github.com/gogf/gf/errors/gerror" ) func main() { err := gerror.NewCode(10000, "My Error") fmt.Println(err.Error()) fmt.Println(gerror.Code(err)) }
Output: My Error 10000
func NewCodeSkip ¶ added in v1.14.6
NewCodeSkip creates and returns an error which has error code and is formatted from given text. The parameter <skip> specifies the stack callers skipped amount.
func NewCodeSkipf ¶ added in v1.14.6
NewCodeSkipf returns an error that has error code and formats as the given format and args. The parameter <skip> specifies the stack callers skipped amount.
func NewCodef ¶ added in v1.14.6
NewCodef returns an error that has error code and formats as the given format and args.
Example ¶
package main import ( "fmt" "github.com/gogf/gf/errors/gerror" ) func main() { err := gerror.NewCodef(10000, "It's %s", "My Error") fmt.Println(err.Error()) fmt.Println(gerror.Code(err)) }
Output: It's My Error 10000
func NewOption ¶ added in v1.16.5
NewOption creates and returns an error with Option. It is the senior usage for creating error, which is often used internally in framework.
func NewSkip ¶ added in v1.12.3
NewSkip creates and returns an error which is formatted from given text. The parameter <skip> specifies the stack callers skipped amount.
func NewSkipf ¶ added in v1.14.6
NewSkipf returns an error that formats as the given format and args. The parameter <skip> specifies the stack callers skipped amount.
func Next ¶ added in v1.14.0
Next returns the next level error. It returns nil if current level error or the next level error is nil.
func Stack ¶
Stack returns the stack callers as string. It returns the error string directly if the <err> does not support stacks.
func WrapCode ¶ added in v1.14.6
WrapCode wraps error with code and text. It returns nil if given err is nil.
Example ¶
package main import ( "errors" "fmt" "github.com/gogf/gf/errors/gerror" ) func main() { err1 := errors.New("permission denied") err2 := gerror.WrapCode(10000, err1, "Custom Error") fmt.Println(err2.Error()) fmt.Println(gerror.Code(err2)) }
Output: Custom Error: permission denied 10000
func WrapCodeSkip ¶ added in v1.15.0
WrapCodeSkip wraps error with code and text. It returns nil if given err is nil. The parameter <skip> specifies the stack callers skipped amount.
func WrapCodeSkipf ¶ added in v1.15.0
WrapCodeSkipf wraps error with code and text that is formatted with given format and args. It returns nil if given err is nil. The parameter <skip> specifies the stack callers skipped amount.
func WrapCodef ¶ added in v1.14.6
WrapCodef wraps error with code and format specifier. It returns nil if given <err> is nil.
Example ¶
package main import ( "errors" "fmt" "github.com/gogf/gf/errors/gerror" ) func main() { err1 := errors.New("permission denied") err2 := gerror.WrapCodef(10000, err1, "It's %s", "Custom Error") fmt.Println(err2.Error()) fmt.Println(gerror.Code(err2)) }
Output: It's Custom Error: permission denied 10000
func WrapSkip ¶ added in v1.15.0
WrapSkip wraps error with text. It returns nil if given err is nil. The parameter <skip> specifies the stack callers skipped amount.
Types ¶
type Error ¶
type Error struct {
// contains filtered or unexported fields
}
Error is custom error for additional features.
func (*Error) Code ¶ added in v1.14.6
Code returns the error code. It returns -1 if it has no error code.
func (*Error) Current ¶ added in v1.14.0
Current creates and returns the current level error. It returns nil if current level error is nil.
func (*Error) Format ¶
Format formats the frame according to the fmt.Formatter interface.
%v, %s : Print all the error string; %-v, %-s : Print current level error string; %+s : Print full stack error list; %+v : Print the error string and full stack error list;
func (*Error) MarshalJSON ¶ added in v1.15.2
MarshalJSON implements the interface MarshalJSON for json.Marshal. Note that do not use pointer as its receiver here.