mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
Merge branch 'relay_proxy' of ssh://xwords.git.sourceforge.net/gitroot/xwords/xwords into relay_proxy
This commit is contained in:
commit
24fae0f53b
3 changed files with 22 additions and 15 deletions
|
@ -1236,10 +1236,6 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
|
||||||
|| comms->r.myHostID == srcID );
|
|| comms->r.myHostID == srcID );
|
||||||
comms->r.myHostID = srcID;
|
comms->r.myHostID = srcID;
|
||||||
XP_LOGF( "set hostid: %x", comms->r.myHostID );
|
XP_LOGF( "set hostid: %x", comms->r.myHostID );
|
||||||
cookieID = stream_getU16( stream );
|
|
||||||
XP_ASSERT( cookieID == comms->r.cookieID );
|
|
||||||
// comms->r.cookieID = stream_getU16( stream );
|
|
||||||
XP_LOGF( "set cookieID = %d", comms->r.cookieID );
|
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
{
|
{
|
||||||
|
|
|
@ -1097,7 +1097,7 @@ main( int argc, char** argv )
|
||||||
} else if ( conType == COMMS_CONN_RELAY ) {
|
} else if ( conType == COMMS_CONN_RELAY ) {
|
||||||
mainParams.connInfo.relay.relayName = hostName;
|
mainParams.connInfo.relay.relayName = hostName;
|
||||||
if ( NULL == portNum ) {
|
if ( NULL == portNum ) {
|
||||||
portNum = "10999";
|
portNum = "10997";
|
||||||
}
|
}
|
||||||
mainParams.connInfo.relay.defaultSendPort = atoi( portNum );
|
mainParams.connInfo.relay.defaultSendPort = atoi( portNum );
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1036,7 +1036,6 @@ void
|
||||||
CookieRef::sendAllHere( bool initial )
|
CookieRef::sendAllHere( bool initial )
|
||||||
{
|
{
|
||||||
unsigned char buf[1 + 1 /* hostID */
|
unsigned char buf[1 + 1 /* hostID */
|
||||||
+ sizeof(CookieID)
|
|
||||||
+ 1 + MAX_CONNNAME_LEN];
|
+ 1 + MAX_CONNNAME_LEN];
|
||||||
|
|
||||||
unsigned char* bufp = buf;
|
unsigned char* bufp = buf;
|
||||||
|
@ -1045,8 +1044,6 @@ CookieRef::sendAllHere( bool initial )
|
||||||
*bufp++ = initial? XWRELAY_ALLHERE : XWRELAY_ALLBACK;
|
*bufp++ = initial? XWRELAY_ALLHERE : XWRELAY_ALLBACK;
|
||||||
idLoc = bufp++; /* space for hostId, remembering address */
|
idLoc = bufp++; /* space for hostId, remembering address */
|
||||||
|
|
||||||
putNetShort( &bufp, GetCookieID() );
|
|
||||||
|
|
||||||
const char* connName = ConnName();
|
const char* connName = ConnName();
|
||||||
assert( !!connName && connName[0] );
|
assert( !!connName && connName[0] );
|
||||||
int len = strlen( connName );
|
int len = strlen( connName );
|
||||||
|
@ -1056,13 +1053,27 @@ CookieRef::sendAllHere( bool initial )
|
||||||
bufp += len;
|
bufp += len;
|
||||||
|
|
||||||
ASSERT_LOCKED();
|
ASSERT_LOCKED();
|
||||||
vector<HostRec>::iterator iter = m_sockets.begin();
|
|
||||||
while ( iter != m_sockets.end() ) {
|
/* Assuming destIds in range 1 .. nSought, for each find if it's here and
|
||||||
logf( XW_LOGINFO, "%s: sending to hostid %d", __func__,
|
if it is try sending to it. If fail, or it's not here, store the
|
||||||
iter->m_hostID );
|
message for it. Would be better if could look up rather than run
|
||||||
*idLoc = iter->m_hostID; /* write in this target's hostId */
|
through the vector each time. */
|
||||||
send_with_length( iter->m_socket, buf, bufp-buf, true );
|
HostID dest;
|
||||||
++iter;
|
for ( dest = 1; dest <= m_nPlayersHere; ++dest ) {
|
||||||
|
bool sent = false;
|
||||||
|
*idLoc = dest; /* write in this target's hostId */
|
||||||
|
vector<HostRec>::iterator iter;
|
||||||
|
for ( iter = m_sockets.begin(); iter != m_sockets.end(); ++iter ) {
|
||||||
|
if ( iter->m_hostID == dest ) {
|
||||||
|
sent = send_with_length( iter->m_socket, buf, bufp-buf,
|
||||||
|
true );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !sent ) {
|
||||||
|
store_message( dest, buf, bufp-buf );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} /* sendAllHere */
|
} /* sendAllHere */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue