Documentation ¶
Index ¶
- Variables
- func Call(fn func() error)
- func ErrorEqual(err1, err2 error) bool
- func ErrorNotEqual(err1, err2 error) bool
- func Log(err error)
- func MustNil(err error, closeFuns ...func())
- type ErrClass
- func (ec ErrClass) EqualClass(err error) bool
- func (ec ErrClass) New(code ErrCode, message string) *Error
- func (ec ErrClass) NewStd(code ErrCode) *Error
- func (ec ErrClass) NotEqualClass(err error) bool
- func (ec ErrClass) String() string
- func (ec ErrClass) Synthesize(code ErrCode, message string) *Error
- type ErrCode
- type Error
- func (e *Error) Class() ErrClass
- func (e *Error) Code() ErrCode
- func (e *Error) Equal(err error) bool
- func (e *Error) Error() string
- func (e *Error) FastGen(format string, args ...interface{}) error
- func (e *Error) FastGenByArgs(args ...interface{}) error
- func (e *Error) GenWithStack(format string, args ...interface{}) error
- func (e *Error) GenWithStackByArgs(args ...interface{}) error
- func (e *Error) Location() (file string, line int)
- func (e *Error) MarshalJSON() ([]byte, error)
- func (e *Error) NotEqual(err error) bool
- func (e *Error) ToSQLError() *mysql.SQLError
- func (e *Error) UnmarshalJSON(data []byte) error
Constants ¶
This section is empty.
Variables ¶
var ( ClassAutoid = RegisterErrorClass(1, "autoid") ClassDDL = RegisterErrorClass(2, "ddl") ClassDomain = RegisterErrorClass(3, "domain") ClassEvaluator = RegisterErrorClass(4, "evaluator") ClassExecutor = RegisterErrorClass(5, "executor") ClassExpression = RegisterErrorClass(6, "expression") ClassAdmin = RegisterErrorClass(7, "admin") ClassKV = RegisterErrorClass(8, "kv") ClassMeta = RegisterErrorClass(9, "meta") ClassOptimizer = RegisterErrorClass(10, "planner") ClassParser = RegisterErrorClass(11, "parser") ClassPerfSchema = RegisterErrorClass(12, "perfschema") ClassPrivilege = RegisterErrorClass(13, "privilege") ClassSchema = RegisterErrorClass(14, "schema") ClassServer = RegisterErrorClass(15, "server") ClassStructure = RegisterErrorClass(16, "structure") ClassVariable = RegisterErrorClass(17, "variable") ClassXEval = RegisterErrorClass(18, "xeval") ClassTable = RegisterErrorClass(19, "table") ClassTypes = RegisterErrorClass(20, "types") ClassGlobal = RegisterErrorClass(21, "global") ClassMockTikv = RegisterErrorClass(22, "mocktikv") ClassJSON = RegisterErrorClass(23, "json") ClassTiKV = RegisterErrorClass(24, "tikv") ClassSession = RegisterErrorClass(25, "session") ClassPlugin = RegisterErrorClass(26, "plugin") ClassUtil = RegisterErrorClass(27, "util") )
Error classes.
var ( // ErrClassToMySQLCodes is the map of ErrClass to code-set. ErrClassToMySQLCodes = make(map[ErrClass]map[ErrCode]struct{}) ErrCritical = ClassGlobal.New(CodeExecResultIsEmpty, "critical error %v") ErrResultUndetermined = ClassGlobal.New(CodeResultUndetermined, "execution result undetermined") )
Functions ¶
func ErrorEqual ¶
ErrorEqual returns a boolean indicating whether err1 is equal to err2.
func ErrorNotEqual ¶
ErrorNotEqual returns a boolean indicating whether err1 isn't equal to err2.
Types ¶
type ErrClass ¶
type ErrClass int
ErrClass represents a class of errors.
func RegisterErrorClass ¶
RegisterErrorClass registers new error class for terror.
func (ErrClass) EqualClass ¶
EqualClass returns true if err is *Error with the same class.
func (ErrClass) New ¶
New defines an *Error with an error code and an error message. Usually used to create base *Error. Attention: this method is not goroutine-safe and usually be used in global variable initializer
func (ErrClass) NewStd ¶
NewStd calls New using the standard message for the error code Attention: this method is not goroutine-safe and usually be used in global variable initializer
func (ErrClass) NotEqualClass ¶
NotEqualClass returns true if err is not *Error with the same class.
type ErrCode ¶
type ErrCode int
ErrCode represents a specific error type in a error class. Same error code can be used in different error classes.
const ( // CodeUnknown is for errors of unknown reason. CodeUnknown ErrCode = -1 // CodeExecResultIsEmpty indicates execution result is empty. CodeExecResultIsEmpty ErrCode = 3 // CodeMissConnectionID indicates connection id is missing. CodeMissConnectionID ErrCode = 1 // CodeResultUndetermined indicates the sql execution result is undetermined. CodeResultUndetermined ErrCode = 2 )
type Error ¶
type Error struct {
// contains filtered or unexported fields
}
Error implements error interface and adds integer Class and Code, so errors with different message can be compared.
func (*Error) FastGen ¶
FastGen generates a new *Error with the same class and code, and a new formatted message. This will not call runtime.Caller to get file and line.
func (*Error) FastGenByArgs ¶
FastGen generates a new *Error with the same class and code, and a new arguments. This will not call runtime.Caller to get file and line.
func (*Error) GenWithStack ¶
GenWithStack generates a new *Error with the same class and code, and a new formatted message.
func (*Error) GenWithStackByArgs ¶
GenWithStackByArgs generates a new *Error with the same class and code, and new arguments.
func (*Error) Location ¶
Location returns the location where the error is created, implements juju/errors locationer interface.
func (*Error) MarshalJSON ¶
MarshalJSON implements json.Marshaler interface.
func (*Error) ToSQLError ¶
ToSQLError convert Error to mysql.SQLError.
func (*Error) UnmarshalJSON ¶
UnmarshalJSON implements json.Unmarshaler interface.