mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-27 07:58:49 +01:00
generate XWRELAY_OTHERCONNECT message
This commit is contained in:
parent
481febe807
commit
8e672b18bb
2 changed files with 40 additions and 20 deletions
|
@ -265,10 +265,10 @@ CookieRef::pushReconnectEvent( int socket, HostID srcID )
|
|||
{
|
||||
CRefEvent evt;
|
||||
evt.type = XW_EVENT_RECONNECTMSG;
|
||||
evt.u.recon.socket = socket;
|
||||
evt.u.recon.srcID = srcID;
|
||||
evt.u.con.socket = socket;
|
||||
evt.u.con.srcID = srcID;
|
||||
m_eventQueue.push_back( evt );
|
||||
} /* pushConnectEvent */
|
||||
} /* pushReconnectEvent */
|
||||
|
||||
void
|
||||
CookieRef::pushHeartbeatEvent( HostID id, int socket )
|
||||
|
@ -382,8 +382,12 @@ CookieRef::handleEvents()
|
|||
switch( takeAction ) {
|
||||
case XW_ACTION_SEND_1ST_RSP:
|
||||
setAllConnectedTimer();
|
||||
/* fallthru */
|
||||
sendResponse( &evt );
|
||||
break;
|
||||
|
||||
case XW_ACTION_SENDRSP:
|
||||
notifyOthers( evt.u.con.socket, XWRELAY_OTHERCONNECT,
|
||||
XWRELAY_ERROR_NONE );
|
||||
sendResponse( &evt );
|
||||
break;
|
||||
|
||||
|
@ -403,7 +407,8 @@ CookieRef::handleEvents()
|
|||
disconnectSockets( 0, XWRELAY_ERROR_TIMEOUT );
|
||||
break;
|
||||
case XW_ACTION_HEARTDISCONNECT:
|
||||
notifyOthers( evt.u.heart.socket, XWRELAY_ERROR_HEART_OTHER );
|
||||
notifyOthers( evt.u.heart.socket, XWRELAY_DISCONNECT_OTHER,
|
||||
XWRELAY_ERROR_HEART_OTHER );
|
||||
disconnectSockets( evt.u.heart.socket,
|
||||
XWRELAY_ERROR_HEART_YOU );
|
||||
break;
|
||||
|
@ -551,7 +556,32 @@ CookieRef::checkFromServer( const CRefEvent* evt )
|
|||
}
|
||||
|
||||
void
|
||||
CookieRef::notifyOthers( int socket, XWREASON why )
|
||||
CookieRef::send_msg( int socket, HostID id, XWRelayMsg msg, XWREASON why )
|
||||
{
|
||||
unsigned char buf[10];
|
||||
short tmp;
|
||||
int len = 0;
|
||||
buf[len++] = msg;
|
||||
|
||||
switch ( msg ) {
|
||||
case XWRELAY_DISCONNECT_OTHER:
|
||||
buf[len++] = why;
|
||||
tmp = htons( id );
|
||||
memcpy( &buf[len], &tmp, 2 );
|
||||
len += 2;
|
||||
break;
|
||||
case XWRELAY_OTHERCONNECT:
|
||||
break;
|
||||
default:
|
||||
logf( "not handling message %d", msg );
|
||||
assert(0);
|
||||
}
|
||||
|
||||
send_with_length( socket, buf, sizeof(buf) );
|
||||
} /* send_msg */
|
||||
|
||||
void
|
||||
CookieRef::notifyOthers( int socket, XWRelayMsg msg, XWREASON why )
|
||||
{
|
||||
assert( socket != 0 );
|
||||
|
||||
|
@ -561,15 +591,7 @@ CookieRef::notifyOthers( int socket, XWREASON why )
|
|||
while ( iter != m_hostSockets.end() ) {
|
||||
int other = iter->second.m_socket;
|
||||
if ( other != socket ) {
|
||||
unsigned char buf[4];
|
||||
buf[0] = XWRELAY_DISCONNECT_OTHER;
|
||||
buf[1] = why;
|
||||
|
||||
HostID id = iter->first;
|
||||
short tmp = htons( id );
|
||||
memcpy( &buf[2], &tmp, 2 );
|
||||
|
||||
send_with_length( other, buf, sizeof(buf) );
|
||||
send_msg( other, iter->first, msg, why );
|
||||
}
|
||||
++iter;
|
||||
}
|
||||
|
|
|
@ -101,10 +101,6 @@ class CookieRef {
|
|||
int socket;
|
||||
HostID srcID;
|
||||
} con;
|
||||
struct {
|
||||
int socket;
|
||||
HostID srcID;
|
||||
} recon;
|
||||
struct {
|
||||
HostID id;
|
||||
int socket;
|
||||
|
@ -128,6 +124,8 @@ class CookieRef {
|
|||
} CRefEvent;
|
||||
|
||||
void send_with_length( int socket, unsigned char* buf, int bufLen );
|
||||
void send_msg( int socket, HostID id, XWRelayMsg msg, XWREASON why );
|
||||
|
||||
void RecordSent( int nBytes, int socket ) {
|
||||
m_totalSent += nBytes;
|
||||
}
|
||||
|
@ -157,7 +155,7 @@ class CookieRef {
|
|||
void forward( const CRefEvent* evt );
|
||||
void checkDest( const CRefEvent* evt );
|
||||
void checkFromServer( const CRefEvent* evt );
|
||||
void notifyOthers( int socket, XWREASON why );
|
||||
void notifyOthers( int socket, XWRelayMsg msg, XWREASON why );
|
||||
|
||||
void disconnectSockets( int socket, XWREASON why );
|
||||
void noteHeartbeat(const CRefEvent* evt);
|
||||
|
|
Loading…
Add table
Reference in a new issue