Compare commits

..

No commits in common. "255d79affbf432e062f768f5700df1776be6a73c" and "be3556e23efc0517d5f47b85314522398ae2a2e2" have entirely different histories.

3 changed files with 1 additions and 30 deletions

View File

@ -25,6 +25,4 @@ type IException interface {
ToError() error
// IsCode 是否为指定code
IsCode(code any) bool
// GetStack 获取调用堆栈
GetStack() string
}

View File

@ -82,7 +82,7 @@ var (
// messageWithCode 自动在message文案后追加状态码
messageWithCode = true
// defaultSuccessCode 默认代表成功的状态码
defaultSuccessCode any = 0
defaultSuccessCode any
// defaultLanguage 默认的语言
defaultLanguage = "zh"
)

View File

@ -10,9 +10,6 @@ package exception
import (
"errors"
"fmt"
"runtime"
"strconv"
"strings"
)
// Exception 异常接口的具体实现
@ -24,17 +21,12 @@ type Exception struct {
code any
message string
data map[string]any
stack string
}
func (e *Exception) Error() string {
return e.Message()
}
func (e *Exception) GetStack() string {
return e.stack
}
func (e *Exception) Code() any {
return e.code
}
@ -91,29 +83,10 @@ func New(code any, data map[string]any, defaultMessage ...string) IException {
// 保证数据结构的一致性, 同时避免后续使用出现空指针
data = map[string]any{}
}
pcs := make([]uintptr, 128)
n := runtime.Callers(2, pcs)
frames := runtime.CallersFrames(pcs[:n])
var sb strings.Builder
for {
frame, more := frames.Next()
sb.WriteString(frame.Function)
sb.WriteByte('\n')
sb.WriteByte('\t')
sb.WriteString(frame.File)
sb.WriteByte(':')
sb.WriteString(strconv.Itoa(frame.Line))
sb.WriteByte('\n')
if !more {
break
}
}
return &Exception{
code: code,
message: GetMessage(code, defaultMessage...),
data: data,
stack: sb.String(),
}
}