mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-09 11:42:45 +01:00
eliminate quitMutex
This commit is contained in:
parent
b0649cb5d3
commit
545e8d71db
@ -70,7 +70,6 @@ type Client struct {
|
|||||||
proxiedIP string // actual remote IP if using the PROXY protocol
|
proxiedIP string // actual remote IP if using the PROXY protocol
|
||||||
quitMessage string
|
quitMessage string
|
||||||
quitMessageSent bool
|
quitMessageSent bool
|
||||||
quitMutex sync.Mutex
|
|
||||||
quitTimer *time.Timer
|
quitTimer *time.Timer
|
||||||
rawHostname string
|
rawHostname string
|
||||||
realname string
|
realname string
|
||||||
@ -505,9 +504,18 @@ func (client *Client) RplISupport() {
|
|||||||
|
|
||||||
// Quit sends the given quit message to the client (but does not destroy them).
|
// Quit sends the given quit message to the client (but does not destroy them).
|
||||||
func (client *Client) Quit(message string) {
|
func (client *Client) Quit(message string) {
|
||||||
client.quitMutex.Lock()
|
client.stateMutex.Lock()
|
||||||
defer client.quitMutex.Unlock()
|
alreadyQuit := client.quitMessageSent
|
||||||
if !client.quitMessageSent {
|
if !alreadyQuit {
|
||||||
|
client.quitMessageSent = true
|
||||||
|
client.quitMessage = message
|
||||||
|
}
|
||||||
|
client.stateMutex.Unlock()
|
||||||
|
|
||||||
|
if alreadyQuit {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
quitMsg := ircmsg.MakeMessage(nil, client.nickMaskString, "QUIT", message)
|
quitMsg := ircmsg.MakeMessage(nil, client.nickMaskString, "QUIT", message)
|
||||||
quitLine, _ := quitMsg.Line()
|
quitLine, _ := quitMsg.Line()
|
||||||
|
|
||||||
@ -515,9 +523,6 @@ func (client *Client) Quit(message string) {
|
|||||||
errorLine, _ := errorMsg.Line()
|
errorLine, _ := errorMsg.Line()
|
||||||
|
|
||||||
client.socket.SetFinalData(quitLine + errorLine)
|
client.socket.SetFinalData(quitLine + errorLine)
|
||||||
client.quitMessageSent = true
|
|
||||||
client.quitMessage = message
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// destroy gets rid of a client, removes them from server lists etc.
|
// destroy gets rid of a client, removes them from server lists etc.
|
||||||
|
Loading…
Reference in New Issue
Block a user