|
|
@ -636,9 +636,9 @@ void CliGkConn::AutoPing () { |
|
|
|
void CliGkConn::StopAutoPing () { |
|
|
|
void CliGkConn::StopAutoPing () { |
|
|
|
critsect.Enter(); |
|
|
|
critsect.Enter(); |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (AsyncTimer * timer = pingTimer) { |
|
|
|
if (pingTimer) { |
|
|
|
|
|
|
|
AsyncTimerDeleteCallback(pingTimer, CliGkConnTimerDestroyed); |
|
|
|
pingTimer = nil; |
|
|
|
pingTimer = nil; |
|
|
|
AsyncTimerDeleteCallback(timer, CliGkConnTimerDestroyed); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
critsect.Leave(); |
|
|
|
critsect.Leave(); |
|
|
@ -646,30 +646,18 @@ void CliGkConn::StopAutoPing () { |
|
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
//============================================================================
|
|
|
|
void CliGkConn::TimerPing () { |
|
|
|
void CliGkConn::TimerPing () { |
|
|
|
|
|
|
|
// Send a ping request
|
|
|
|
#if 0 |
|
|
|
pingSendTimeMs = GetNonZeroTimeMs(); |
|
|
|
// if the time difference between when we last sent a ping and when we last
|
|
|
|
|
|
|
|
// heard from the server is >= 3x the ping interval, the socket is stale.
|
|
|
|
|
|
|
|
if (pingSendTimeMs && abs(int(pingSendTimeMs - lastHeardTimeMs)) >= kPingTimeoutMs) { |
|
|
|
|
|
|
|
// ping timed out, disconnect the socket
|
|
|
|
|
|
|
|
AsyncSocketDisconnect(sock, true); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
// Send a ping request
|
|
|
|
|
|
|
|
pingSendTimeMs = GetNonZeroTimeMs(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
const uintptr_t msg[] = { |
|
|
|
kCli2GateKeeper_PingRequest, |
|
|
|
kCli2GateKeeper_PingRequest, |
|
|
|
pingSendTimeMs, |
|
|
|
pingSendTimeMs, |
|
|
|
0, // not a transaction
|
|
|
|
0, // not a transaction
|
|
|
|
0, // no payload
|
|
|
|
0, // no payload
|
|
|
|
nil |
|
|
|
nil |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
//Send(msg, arrsize(msg));
|
|
|
|
Send(msg, arrsize(msg)); |
|
|
|
}
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
//============================================================================
|
|
|
|