mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-28 07:58:08 +01:00
get rid of states and code for checking numbers of players -- since
any number is allowed now.
This commit is contained in:
parent
3bdfda6548
commit
ed52582ea4
4 changed files with 3 additions and 62 deletions
|
@ -495,10 +495,6 @@ CookieRef::handleEvents()
|
||||||
|
|
||||||
switch( takeAction ) {
|
switch( takeAction ) {
|
||||||
|
|
||||||
case XWA_CHKCOUNTS:
|
|
||||||
checkCounts( &evt );
|
|
||||||
break;
|
|
||||||
|
|
||||||
case XWA_SEND_1ST_RSP:
|
case XWA_SEND_1ST_RSP:
|
||||||
case XWA_SEND_1ST_RERSP:
|
case XWA_SEND_1ST_RERSP:
|
||||||
setAllConnectedTimer();
|
setAllConnectedTimer();
|
||||||
|
@ -626,8 +622,8 @@ print_sockets( const char* caller, vector<HostRec>& sockets )
|
||||||
logf( XW_LOGINFO, " %s from %s", __func__, caller );
|
logf( XW_LOGINFO, " %s from %s", __func__, caller );
|
||||||
vector<HostRec>::iterator iter;
|
vector<HostRec>::iterator iter;
|
||||||
for ( iter = sockets.begin(); iter != sockets.end(); ++iter ) {
|
for ( iter = sockets.begin(); iter != sockets.end(); ++iter ) {
|
||||||
logf( XW_LOGINFO, "isHost: %d; nPlayersH: %d; seed=%.4X; socket: %d",
|
logf( XW_LOGINFO, "nPSought: %d; nPHere: %d; seed=%.4X; socket: %d",
|
||||||
iter->m_nPlayersS > 0, iter->m_nPlayersH, iter->m_seed,
|
iter->m_nPlayersS, iter->m_nPlayersH, iter->m_seed,
|
||||||
iter->m_socket );
|
iter->m_socket );
|
||||||
}
|
}
|
||||||
} /* print_sockets */
|
} /* print_sockets */
|
||||||
|
@ -866,41 +862,6 @@ CookieRef::reducePlayerCounts( int socket )
|
||||||
}
|
}
|
||||||
} /* reducePlayerCounts */
|
} /* reducePlayerCounts */
|
||||||
|
|
||||||
/* Determine if adding this device to the game would give us too many
|
|
||||||
players. */
|
|
||||||
void
|
|
||||||
CookieRef::checkCounts( const CRefEvent* evt )
|
|
||||||
{
|
|
||||||
int nPlayersH = evt->u.con.nPlayersH;
|
|
||||||
int nPlayersS = evt->u.con.nPlayersS;
|
|
||||||
HostID hid = evt->u.con.srcID;
|
|
||||||
bool success;
|
|
||||||
|
|
||||||
logf( XW_LOGVERBOSE1, "%s: hid:%d; nPlayersS:%d; nPlayersH:%d; "
|
|
||||||
"m_nPlayersSought:%d; m_nPlayersHere:%d", __func__,
|
|
||||||
hid, nPlayersS, nPlayersH, m_nPlayersSought, m_nPlayersHere );
|
|
||||||
|
|
||||||
/* increasePlayerCounts() is where we actually increase the numbers. Is
|
|
||||||
that right? */
|
|
||||||
|
|
||||||
if ( hid == HOST_ID_SERVER ) {
|
|
||||||
success = m_nPlayersSought == 0;
|
|
||||||
} else {
|
|
||||||
success = (m_nPlayersSought == 0) /* if no server present yet */
|
|
||||||
|| (m_nPlayersSought >= m_nPlayersHere + nPlayersH);
|
|
||||||
}
|
|
||||||
logf( XW_LOGVERBOSE1, "success = %d", success );
|
|
||||||
|
|
||||||
CRefEvent newevt;
|
|
||||||
if ( success ) {
|
|
||||||
newevt = *evt; /* this is a gross hack!!! */
|
|
||||||
newevt.type = XWE_OKTOSEND;
|
|
||||||
} else {
|
|
||||||
newevt.type = XWE_COUNTSBAD;
|
|
||||||
}
|
|
||||||
m_eventQueue.push_back( newevt );
|
|
||||||
} /* checkCounts */
|
|
||||||
|
|
||||||
void
|
void
|
||||||
CookieRef::setAllConnectedTimer()
|
CookieRef::setAllConnectedTimer()
|
||||||
{
|
{
|
||||||
|
|
|
@ -188,7 +188,6 @@ class CookieRef {
|
||||||
void populate( vector<HostRec> hosts );
|
void populate( vector<HostRec> hosts );
|
||||||
void increasePlayerCounts( const CRefEvent* evt );
|
void increasePlayerCounts( const CRefEvent* evt );
|
||||||
void reducePlayerCounts( int socket );
|
void reducePlayerCounts( int socket );
|
||||||
void checkCounts( const CRefEvent* evt );
|
|
||||||
|
|
||||||
void setAllConnectedTimer();
|
void setAllConnectedTimer();
|
||||||
void cancelAllConnectedTimer();
|
void cancelAllConnectedTimer();
|
||||||
|
|
|
@ -63,17 +63,7 @@ typedef struct StateTable {
|
||||||
|
|
||||||
StateTable g_stateTable[] = {
|
StateTable g_stateTable[] = {
|
||||||
|
|
||||||
{ XWS_INITED, XWE_CONNECTMSG, XWA_CHKCOUNTS, XWS_CHKCOUNTS_INIT },
|
{ XWS_INITED, XWE_CONNECTMSG, XWA_SEND_1ST_RSP, XWS_CHK_ALLHERE },
|
||||||
{ XWS_CHKCOUNTS_INIT, XWE_OKTOSEND, XWA_SEND_1ST_RSP, XWS_CHK_ALLHERE },
|
|
||||||
{ XWS_CHKCOUNTS_INIT, XWE_COUNTSBAD, XWA_REJECT, XWS_INITED },
|
|
||||||
{ XWS_CONNECTING, XWE_CONNECTMSG, XWA_CHKCOUNTS, XWS_CHKCOUNTS },
|
|
||||||
{ XWS_CHKCOUNTS, XWE_OKTOSEND, XWA_SEND_1ST_RSP, XWS_CHK_ALLHERE },
|
|
||||||
{ XWS_CHKCOUNTS, XWE_COUNTSBAD, XWA_REJECT, XWS_CONNECTING },
|
|
||||||
|
|
||||||
{ XWS_MISSING, XWE_CONNECTMSG, XWA_CHKCOUNTS, XWS_CHKCOUNTS_MISS },
|
|
||||||
{ XWS_CHKCOUNTS_MISS, XWE_OKTOSEND, XWA_SEND_1ST_RSP, XWS_CHK_ALLHERE_2 },
|
|
||||||
{ XWS_CHKCOUNTS_MISS, XWE_COUNTSBAD, XWA_REJECT, XWS_MISSING },
|
|
||||||
|
|
||||||
|
|
||||||
{ XWS_CONNECTING, XWE_CONNECTMSG, XWA_SEND_RSP, XWS_CHK_ALLHERE },
|
{ XWS_CONNECTING, XWE_CONNECTMSG, XWA_SEND_RSP, XWS_CHK_ALLHERE },
|
||||||
{ XWS_CHK_ALLHERE, XWE_ALLHERE, XWA_SENDALLHERE, XWS_ALLCONND },
|
{ XWS_CHK_ALLHERE, XWE_ALLHERE, XWA_SENDALLHERE, XWS_ALLCONND },
|
||||||
|
@ -179,8 +169,6 @@ stateString( XW_RELAY_STATE state )
|
||||||
CASESTR(XWS_CHK_ALLHERE);
|
CASESTR(XWS_CHK_ALLHERE);
|
||||||
CASESTR(XWS_CHK_ALLHERE_2);
|
CASESTR(XWS_CHK_ALLHERE_2);
|
||||||
CASESTR(XWS_CHKCOUNTS_INIT);
|
CASESTR(XWS_CHKCOUNTS_INIT);
|
||||||
CASESTR(XWS_CHKCOUNTS_MISS);
|
|
||||||
CASESTR(XWS_CHKCOUNTS);
|
|
||||||
CASESTR(XWS_CLONED);
|
CASESTR(XWS_CLONED);
|
||||||
default:
|
default:
|
||||||
assert(0);
|
assert(0);
|
||||||
|
@ -213,8 +201,6 @@ eventString( XW_RELAY_EVENT evt )
|
||||||
CASESTR(XWE_NOTIFYDISCON);
|
CASESTR(XWE_NOTIFYDISCON);
|
||||||
CASESTR(XWE_ALLHERE);
|
CASESTR(XWE_ALLHERE);
|
||||||
CASESTR(XWE_SOMEMISSING);
|
CASESTR(XWE_SOMEMISSING);
|
||||||
CASESTR(XWE_OKTOSEND);
|
|
||||||
CASESTR(XWE_COUNTSBAD);
|
|
||||||
CASESTR(XWE_SHUTDOWN);
|
CASESTR(XWE_SHUTDOWN);
|
||||||
CASESTR(XWE_CLONECHKMSG);
|
CASESTR(XWE_CLONECHKMSG);
|
||||||
default:
|
default:
|
||||||
|
@ -231,7 +217,6 @@ actString( XW_RELAY_ACTION act )
|
||||||
CASESTR(XWA_NONE);
|
CASESTR(XWA_NONE);
|
||||||
CASESTR(XWA_SEND_1ST_RSP);
|
CASESTR(XWA_SEND_1ST_RSP);
|
||||||
CASESTR(XWA_SEND_1ST_RERSP);
|
CASESTR(XWA_SEND_1ST_RERSP);
|
||||||
CASESTR(XWA_CHKCOUNTS);
|
|
||||||
CASESTR(XWA_REJECT);
|
CASESTR(XWA_REJECT);
|
||||||
CASESTR(XWA_SEND_RSP);
|
CASESTR(XWA_SEND_RSP);
|
||||||
CASESTR(XWA_SEND_RERSP);
|
CASESTR(XWA_SEND_RERSP);
|
||||||
|
|
|
@ -33,7 +33,6 @@ enum {
|
||||||
actually: 1-device game. */
|
actually: 1-device game. */
|
||||||
|
|
||||||
,XWS_CHKCOUNTS_MISS /* from the missing state */
|
,XWS_CHKCOUNTS_MISS /* from the missing state */
|
||||||
,XWS_CHKCOUNTS /* check from any other state */
|
|
||||||
|
|
||||||
,XWS_CLONED /* just got duplicated */
|
,XWS_CLONED /* just got duplicated */
|
||||||
|
|
||||||
|
@ -84,7 +83,6 @@ typedef enum {
|
||||||
XWE_NONE
|
XWE_NONE
|
||||||
|
|
||||||
,XWE_OKTOSEND
|
,XWE_OKTOSEND
|
||||||
,XWE_COUNTSBAD
|
|
||||||
|
|
||||||
,XWE_ALLHERE /* notify that all expected players are arrived */
|
,XWE_ALLHERE /* notify that all expected players are arrived */
|
||||||
,XWE_SOMEMISSING /* notify that some expected players are still missing */
|
,XWE_SOMEMISSING /* notify that some expected players are still missing */
|
||||||
|
@ -126,8 +124,6 @@ typedef enum {
|
||||||
,XWA_SEND_1ST_RSP
|
,XWA_SEND_1ST_RSP
|
||||||
,XWA_SEND_1ST_RERSP
|
,XWA_SEND_1ST_RERSP
|
||||||
|
|
||||||
,XWA_CHKCOUNTS
|
|
||||||
|
|
||||||
,XWA_REJECT
|
,XWA_REJECT
|
||||||
|
|
||||||
,XWA_SEND_RSP /* Send a connection response */
|
,XWA_SEND_RSP /* Send a connection response */
|
||||||
|
|
Loading…
Add table
Reference in a new issue