mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-23 21:51:30 +01:00
42 lines
987 B
Go
42 lines
987 B
Go
// Copyright 2024, Command Line Inc.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package panichandler
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
"runtime/debug"
|
|
)
|
|
|
|
// to log NumPanics into the local telemetry system
|
|
// gets around import cycles
|
|
var PanicTelemetryHandler func()
|
|
|
|
func PanicHandlerNoTelemetry(debugStr string, recoverVal any) {
|
|
if recoverVal == nil {
|
|
return
|
|
}
|
|
log.Printf("[panic] in %s: %v\n", debugStr, recoverVal)
|
|
debug.PrintStack()
|
|
}
|
|
|
|
// returns an error (wrapping the panic) if a panic occurred
|
|
func PanicHandler(debugStr string, recoverVal any) error {
|
|
if recoverVal == nil {
|
|
return nil
|
|
}
|
|
log.Printf("[panic] in %s: %v\n", debugStr, recoverVal)
|
|
debug.PrintStack()
|
|
if PanicTelemetryHandler != nil {
|
|
go func() {
|
|
defer PanicHandlerNoTelemetry("PanicTelemetryHandler", recover())
|
|
PanicTelemetryHandler()
|
|
}()
|
|
}
|
|
if err, ok := recoverVal.(error); ok {
|
|
return fmt.Errorf("panic in %s: %w", debugStr, err)
|
|
}
|
|
return fmt.Errorf("panic in %s: %v", debugStr, recoverVal)
|
|
}
|