merge master && fix both modify

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

View File

@@ -10,6 +10,9 @@ package exception
import (
"errors"
"fmt"
"runtime"
"strconv"
"strings"
)
// Exception 异常接口的具体实现
@@ -21,12 +24,17 @@ 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
}
@@ -83,10 +91,29 @@ 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(),
}
}