merge master && fix both modify

This commit is contained in:
白茶清欢 2025-05-10 19:35:05 +08:00
commit 255d79affb
3 changed files with 30 additions and 1 deletions

View File

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

View File

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

View File

@ -10,6 +10,9 @@ package exception
import ( import (
"errors" "errors"
"fmt" "fmt"
"runtime"
"strconv"
"strings"
) )
// Exception 异常接口的具体实现 // Exception 异常接口的具体实现
@ -21,12 +24,17 @@ type Exception struct {
code any code any
message string message string
data map[string]any data map[string]any
stack string
} }
func (e *Exception) Error() string { func (e *Exception) Error() string {
return e.Message() return e.Message()
} }
func (e *Exception) GetStack() string {
return e.stack
}
func (e *Exception) Code() any { func (e *Exception) Code() any {
return e.code return e.code
} }
@ -83,10 +91,29 @@ func New(code any, data map[string]any, defaultMessage ...string) IException {
// 保证数据结构的一致性, 同时避免后续使用出现空指针 // 保证数据结构的一致性, 同时避免后续使用出现空指针
data = map[string]any{} 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{ return &Exception{
code: code, code: code,
message: GetMessage(code, defaultMessage...), message: GetMessage(code, defaultMessage...),
data: data, data: data,
stack: sb.String(),
} }
} }