mirror of
https://github.com/imgproxy/imgproxy.git
synced 2025-01-08 10:45:04 +02:00
Better stacktrace in errors
This commit is contained in:
parent
cc5ee1923a
commit
b104c5c973
31
errors.go
31
errors.go
@ -11,12 +11,26 @@ type imgproxyError struct {
|
||||
Message string
|
||||
PublicMessage string
|
||||
Unexpected bool
|
||||
|
||||
stack []uintptr
|
||||
}
|
||||
|
||||
func (e *imgproxyError) Error() string {
|
||||
return e.Message
|
||||
}
|
||||
|
||||
func (e *imgproxyError) ErrorWithStack() string {
|
||||
if e.stack == nil {
|
||||
return e.Message
|
||||
}
|
||||
|
||||
return fmt.Sprintf("%s\n%s", e.Message, formatStack(e.stack))
|
||||
}
|
||||
|
||||
func (e *imgproxyError) StackTrace() []uintptr {
|
||||
return e.stack
|
||||
}
|
||||
|
||||
func newError(status int, msg string, pub string) *imgproxyError {
|
||||
return &imgproxyError{
|
||||
StatusCode: status,
|
||||
@ -28,18 +42,23 @@ func newError(status int, msg string, pub string) *imgproxyError {
|
||||
func newUnexpectedError(msg string, skip int) *imgproxyError {
|
||||
return &imgproxyError{
|
||||
StatusCode: 500,
|
||||
Message: fmt.Sprintf("Unexpected error: %s\n%s", msg, stacktrace(skip+3)),
|
||||
Message: msg,
|
||||
PublicMessage: "Internal error",
|
||||
Unexpected: true,
|
||||
|
||||
stack: callers(skip + 3),
|
||||
}
|
||||
}
|
||||
|
||||
func stacktrace(skip int) string {
|
||||
callers := make([]uintptr, 10)
|
||||
n := runtime.Callers(skip, callers)
|
||||
func callers(skip int) []uintptr {
|
||||
stack := make([]uintptr, 10)
|
||||
n := runtime.Callers(skip, stack)
|
||||
return stack[:n]
|
||||
}
|
||||
|
||||
lines := make([]string, n)
|
||||
for i, pc := range callers[:n] {
|
||||
func formatStack(stack []uintptr) string {
|
||||
lines := make([]string, len(stack))
|
||||
for i, pc := range stack {
|
||||
f := runtime.FuncForPC(pc)
|
||||
file, line := f.FileLine(pc)
|
||||
lines[i] = fmt.Sprintf("%s:%d %s", file, line, f.Name())
|
||||
|
Loading…
Reference in New Issue
Block a user