1
0
Fork 0
forked from External/ergo

Merge remote-tracking branch 'slingmann/recovery'

This commit is contained in:
Daniel Oaks 2017-10-29 04:37:57 +00:00
commit c6b6a25906
5 changed files with 37 additions and 8 deletions

View file

@ -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()
}
//