forked from External/ergo
Merge remote-tracking branch 'slingmann/recovery'
This commit is contained in:
commit
c6b6a25906
5 changed files with 37 additions and 8 deletions
|
|
@ -197,6 +197,20 @@ func (client *Client) run() {
|
|||
var line string
|
||||
var msg ircmsg.IrcMessage
|
||||
|
||||
defer func() {
|
||||
if r := recover(); r != nil {
|
||||
client.server.logger.Error("internal",
|
||||
fmt.Sprintf("Client caused panic: %v\n%s", r, debug.Stack()))
|
||||
if client.server.RecoverFromErrors() {
|
||||
client.server.logger.Error("internal", "Disconnecting client and attempting to recover")
|
||||
} else {
|
||||
panic(r)
|
||||
}
|
||||
}
|
||||
// ensure client connection gets closed
|
||||
client.destroy()
|
||||
}()
|
||||
|
||||
client.idletimer = NewIdleTimer(client)
|
||||
client.idletimer.Start()
|
||||
|
||||
|
|
@ -238,9 +252,6 @@ func (client *Client) run() {
|
|||
break
|
||||
}
|
||||
}
|
||||
|
||||
// ensure client connection gets closed
|
||||
client.destroy()
|
||||
}
|
||||
|
||||
//
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue