mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-22 07:28:16 +01:00
cleanup; add debugging info for state changes
This commit is contained in:
parent
5e184841d2
commit
c0f3adcfc4
1 changed files with 69 additions and 33 deletions
102
common/server.c
102
common/server.c
|
@ -140,6 +140,43 @@ static void tellMoveWasLegal( ServerCtxt* server );
|
||||||
|
|
||||||
#define PICK_NEXT -1
|
#define PICK_NEXT -1
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
static char*
|
||||||
|
getStateStr( XW_State st )
|
||||||
|
{
|
||||||
|
# define CASESTR(c) case c: return #c
|
||||||
|
switch( st ) {
|
||||||
|
CASESTR(XWSTATE_NONE);
|
||||||
|
CASESTR(XWSTATE_BEGIN);
|
||||||
|
CASESTR(XWSTATE_POOL_INITED);
|
||||||
|
CASESTR(XWSTATE_NEED_SHOWSCORE);
|
||||||
|
CASESTR(XWSTATE_WAITING_ALL_REG);
|
||||||
|
CASESTR(XWSTATE_RECEIVED_ALL_REG);
|
||||||
|
CASESTR(XWSTATE_NEEDSEND_BADWORD_INFO);
|
||||||
|
CASESTR(XWSTATE_MOVE_CONFIRM_WAIT);
|
||||||
|
CASESTR(XWSTATE_MOVE_CONFIRM_MUSTSEND);
|
||||||
|
CASESTR(XWSTATE_NEEDSEND_ENDGAME);
|
||||||
|
CASESTR(XWSTATE_INTURN);
|
||||||
|
CASESTR(XWSTATE_GAMEOVER);
|
||||||
|
default:
|
||||||
|
return "unknown";
|
||||||
|
}
|
||||||
|
# undef CASESTR
|
||||||
|
}
|
||||||
|
static void
|
||||||
|
logNewState( XW_State old, XW_State newst )
|
||||||
|
{
|
||||||
|
char* oldStr = getStateStr(old);
|
||||||
|
char* newStr = getStateStr(newst);
|
||||||
|
XP_LOGF( "state transition %s => %s", oldStr, newStr );
|
||||||
|
}
|
||||||
|
# define SETSTATE( s, st ) { XW_State old = (s)->nv.gameState; \
|
||||||
|
(s)->nv.gameState = (st); \
|
||||||
|
logNewState(old, st); }
|
||||||
|
#else
|
||||||
|
# define SETSTATE( s, st ) (s)->nv.gameState = (st)
|
||||||
|
#endif
|
||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -154,9 +191,9 @@ initServer( ServerCtxt* server )
|
||||||
server->nv.currentTurn = -1; /* game isn't under way yet */
|
server->nv.currentTurn = -1; /* game isn't under way yet */
|
||||||
|
|
||||||
if ( server->vol.gi->serverRole == SERVER_ISCLIENT ) {
|
if ( server->vol.gi->serverRole == SERVER_ISCLIENT ) {
|
||||||
server->nv.gameState = XWSTATE_NONE;
|
SETSTATE( server, XWSTATE_NONE );
|
||||||
} else {
|
} else {
|
||||||
server->nv.gameState = XWSTATE_BEGIN;
|
SETSTATE( server, XWSTATE_BEGIN );
|
||||||
}
|
}
|
||||||
|
|
||||||
lp = gi->players;
|
lp = gi->players;
|
||||||
|
@ -462,7 +499,7 @@ handleRegistrationMsg( ServerCtxt* server, XWStreamCtxt* stream )
|
||||||
|
|
||||||
if ( server->nv.pendingRegistrations == 0 ) {
|
if ( server->nv.pendingRegistrations == 0 ) {
|
||||||
assignTilesToAll( server );
|
assignTilesToAll( server );
|
||||||
server->nv.gameState = XWSTATE_RECEIVED_ALL_REG;
|
SETSTATE( server, XWSTATE_RECEIVED_ALL_REG );
|
||||||
}
|
}
|
||||||
return XP_TRUE;
|
return XP_TRUE;
|
||||||
} /* handleRegistrationMsg */
|
} /* handleRegistrationMsg */
|
||||||
|
@ -710,7 +747,7 @@ showPrevScore( ServerCtxt* server )
|
||||||
(void)util_userQuery( util, QUERY_ROBOT_MOVE, stream );
|
(void)util_userQuery( util, QUERY_ROBOT_MOVE, stream );
|
||||||
stream_destroy( stream );
|
stream_destroy( stream );
|
||||||
|
|
||||||
server->nv.gameState = server->vol.stateAfterShow;
|
SETSTATE( server, server->vol.stateAfterShow );
|
||||||
} /* showPrevScore */
|
} /* showPrevScore */
|
||||||
|
|
||||||
XP_Bool
|
XP_Bool
|
||||||
|
@ -728,7 +765,7 @@ server_do( ServerCtxt* server )
|
||||||
case XWSTATE_BEGIN:
|
case XWSTATE_BEGIN:
|
||||||
if ( server->nv.pendingRegistrations == 0 ) { /* all players on device */
|
if ( server->nv.pendingRegistrations == 0 ) { /* all players on device */
|
||||||
assignTilesToAll( server );
|
assignTilesToAll( server );
|
||||||
server->nv.gameState = XWSTATE_INTURN;
|
SETSTATE( server, XWSTATE_INTURN );
|
||||||
server->nv.currentTurn = 0;
|
server->nv.currentTurn = 0;
|
||||||
moreToDo = XP_TRUE;
|
moreToDo = XP_TRUE;
|
||||||
}
|
}
|
||||||
|
@ -748,7 +785,7 @@ server_do( ServerCtxt* server )
|
||||||
case XWSTATE_RECEIVED_ALL_REG:
|
case XWSTATE_RECEIVED_ALL_REG:
|
||||||
server_sendInitialMessage( server );
|
server_sendInitialMessage( server );
|
||||||
/* PENDING isn't INTURN_OFFDEVICE possible too? Or just INTURN? */
|
/* PENDING isn't INTURN_OFFDEVICE possible too? Or just INTURN? */
|
||||||
server->nv.gameState = XWSTATE_INTURN;
|
SETSTATE( server, XWSTATE_INTURN );
|
||||||
server->nv.currentTurn = 0;
|
server->nv.currentTurn = 0;
|
||||||
moreToDo = XP_TRUE;
|
moreToDo = XP_TRUE;
|
||||||
break;
|
break;
|
||||||
|
@ -831,7 +868,7 @@ findFirstPending( ServerCtxt* server, ServerPlayer** playerP )
|
||||||
return lp;
|
return lp;
|
||||||
} /* findFirstPending */
|
} /* findFirstPending */
|
||||||
|
|
||||||
void
|
static void
|
||||||
registerRemotePlayer( ServerCtxt* server, XWStreamCtxt* stream )
|
registerRemotePlayer( ServerCtxt* server, XWStreamCtxt* stream )
|
||||||
{
|
{
|
||||||
XP_S8 deviceIndex;
|
XP_S8 deviceIndex;
|
||||||
|
@ -992,7 +1029,7 @@ client_readInitialMessage( ServerCtxt* server, XWStreamCtxt* stream )
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( gi->players->isLocal ) {
|
if ( gi->players->isLocal ) {
|
||||||
server->nv.gameState = XWSTATE_INTURN;
|
SETSTATE( server, XWSTATE_INTURN );
|
||||||
}
|
}
|
||||||
server->nv.currentTurn = 0;
|
server->nv.currentTurn = 0;
|
||||||
|
|
||||||
|
@ -1494,8 +1531,7 @@ nextTurn( ServerCtxt* server, XP_S16 nxtTurn )
|
||||||
obscure bug.*/
|
obscure bug.*/
|
||||||
server->nv.nPassesInRow = 0;
|
server->nv.nPassesInRow = 0;
|
||||||
}
|
}
|
||||||
|
SETSTATE( server, XWSTATE_INTURN ); /* unless game over */
|
||||||
server->nv.gameState = XWSTATE_INTURN; /* unless game over */
|
|
||||||
|
|
||||||
if ( playerTilesLeft > 0
|
if ( playerTilesLeft > 0
|
||||||
&& (server->nv.nPassesInRow / nPlayers < MAX_PASSES) ) {
|
&& (server->nv.nPassesInRow / nPlayers < MAX_PASSES) ) {
|
||||||
|
@ -1508,7 +1544,7 @@ nextTurn( ServerCtxt* server, XP_S16 nxtTurn )
|
||||||
should I wait for the server to deduce this and send out a message.
|
should I wait for the server to deduce this and send out a message.
|
||||||
I think so. */
|
I think so. */
|
||||||
if ( server->vol.gi->serverRole != SERVER_ISCLIENT ) {
|
if ( server->vol.gi->serverRole != SERVER_ISCLIENT ) {
|
||||||
server->nv.gameState = XWSTATE_NEEDSEND_ENDGAME;
|
SETSTATE( server, XWSTATE_NEEDSEND_ENDGAME );
|
||||||
moreToDo = XP_TRUE;
|
moreToDo = XP_TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1517,7 +1553,7 @@ nextTurn( ServerCtxt* server, XP_S16 nxtTurn )
|
||||||
server->vol.showPrevMove = XP_FALSE;
|
server->vol.showPrevMove = XP_FALSE;
|
||||||
if ( server->nv.showRobotScores ) {
|
if ( server->nv.showRobotScores ) {
|
||||||
server->vol.stateAfterShow = server->nv.gameState;
|
server->vol.stateAfterShow = server->nv.gameState;
|
||||||
server->nv.gameState = XWSTATE_NEED_SHOWSCORE;
|
SETSTATE( server, XWSTATE_NEED_SHOWSCORE );
|
||||||
moreToDo = XP_TRUE;
|
moreToDo = XP_TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1752,12 +1788,12 @@ reflectMoveAndInform( ServerCtxt* server, XWStreamCtxt* stream )
|
||||||
|
|
||||||
if ( (gi->phoniesAction == PHONIES_DISALLOW) && (nTilesMoved > 0) ) {
|
if ( (gi->phoniesAction == PHONIES_DISALLOW) && (nTilesMoved > 0) ) {
|
||||||
server->lastMoveSource = sourceClientIndex;
|
server->lastMoveSource = sourceClientIndex;
|
||||||
server->nv.gameState = XWSTATE_MOVE_CONFIRM_MUSTSEND;
|
SETSTATE( server, XWSTATE_MOVE_CONFIRM_MUSTSEND );
|
||||||
doRequest = XP_TRUE;
|
doRequest = XP_TRUE;
|
||||||
} else if ( nTilesLeft > 0 ) {
|
} else if ( nTilesLeft > 0 ) {
|
||||||
nextTurn( server, PICK_NEXT );
|
nextTurn( server, PICK_NEXT );
|
||||||
} else {
|
} else {
|
||||||
server->nv.gameState = XWSTATE_NEEDSEND_ENDGAME;
|
SETSTATE(server, XWSTATE_NEEDSEND_ENDGAME );
|
||||||
doRequest = XP_TRUE;
|
doRequest = XP_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1771,7 +1807,7 @@ reflectMoveAndInform( ServerCtxt* server, XWStreamCtxt* stream )
|
||||||
can't send a message now since we're burried in a message handler.
|
can't send a message now since we're burried in a message handler.
|
||||||
(Palm, at least, won't manage.) So set up state to tell that
|
(Palm, at least, won't manage.) So set up state to tell that
|
||||||
client again in a minute. */
|
client again in a minute. */
|
||||||
server->nv.gameState = XWSTATE_NEEDSEND_BADWORD_INFO;
|
SETSTATE( server, XWSTATE_NEEDSEND_BADWORD_INFO );
|
||||||
server->lastMoveSource = sourceClientIndex;
|
server->lastMoveSource = sourceClientIndex;
|
||||||
doRequest = XP_TRUE;
|
doRequest = XP_TRUE;
|
||||||
}
|
}
|
||||||
|
@ -1894,7 +1930,7 @@ server_commitMove( ServerCtxt* server )
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
if (isClient && (gi->phoniesAction == PHONIES_DISALLOW)
|
if (isClient && (gi->phoniesAction == PHONIES_DISALLOW)
|
||||||
&& nTilesMoved > 0 ) {
|
&& nTilesMoved > 0 ) {
|
||||||
server->nv.gameState = XWSTATE_MOVE_CONFIRM_WAIT;
|
SETSTATE( server, XWSTATE_MOVE_CONFIRM_WAIT );
|
||||||
} else {
|
} else {
|
||||||
nextTurn( server, PICK_NEXT );
|
nextTurn( server, PICK_NEXT );
|
||||||
}
|
}
|
||||||
|
@ -1967,7 +2003,7 @@ server_getGameIsOver( ServerCtxt* server )
|
||||||
static void
|
static void
|
||||||
doEndGame( ServerCtxt* server )
|
doEndGame( ServerCtxt* server )
|
||||||
{
|
{
|
||||||
server->nv.gameState = XWSTATE_GAMEOVER;
|
SETSTATE( server, XWSTATE_GAMEOVER );
|
||||||
server->nv.currentTurn = -1;
|
server->nv.currentTurn = -1;
|
||||||
|
|
||||||
(*server->vol.gameOverListener)( server->vol.gameOverData );
|
(*server->vol.gameOverListener)( server->vol.gameOverData );
|
||||||
|
@ -2178,12 +2214,12 @@ server_handleUndo( ServerCtxt* server )
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
XP_Bool
|
XP_Bool
|
||||||
server_receiveMessage( ServerCtxt* server, XWStreamCtxt* incomming )
|
server_receiveMessage( ServerCtxt* server, XWStreamCtxt* incoming )
|
||||||
{
|
{
|
||||||
XW_Proto code;
|
XW_Proto code;
|
||||||
XP_Bool accepted = XP_FALSE;
|
XP_Bool accepted = XP_FALSE;
|
||||||
|
|
||||||
code = (XW_Proto)stream_getBits( incomming, XWPROTO_NBITS );
|
code = (XW_Proto)stream_getBits( incoming, XWPROTO_NBITS );
|
||||||
|
|
||||||
printCode("Receiving", code);
|
printCode("Receiving", code);
|
||||||
|
|
||||||
|
@ -2192,42 +2228,42 @@ server_receiveMessage( ServerCtxt* server, XWStreamCtxt* incomming )
|
||||||
once the game's in progress and communication's been
|
once the game's in progress and communication's been
|
||||||
established. */
|
established. */
|
||||||
XP_STATUSF( "somebody's registering!!!" );
|
XP_STATUSF( "somebody's registering!!!" );
|
||||||
accepted = handleRegistrationMsg( server, incomming );
|
accepted = handleRegistrationMsg( server, incoming );
|
||||||
|
|
||||||
} else if ( code == XWPROTO_CLIENT_SETUP ) {
|
} else if ( code == XWPROTO_CLIENT_SETUP ) {
|
||||||
|
|
||||||
XP_STATUSF( "client got XWPROTO_CLIENT_SETUP" );
|
XP_STATUSF( "client got XWPROTO_CLIENT_SETUP" );
|
||||||
XP_ASSERT( server->vol.gi->serverRole == SERVER_ISCLIENT );
|
XP_ASSERT( server->vol.gi->serverRole == SERVER_ISCLIENT );
|
||||||
accepted = client_readInitialMessage( server, incomming );
|
accepted = client_readInitialMessage( server, incoming );
|
||||||
|
|
||||||
} else if ( readStreamHeader( server, incomming ) ) {
|
} else if ( readStreamHeader( server, incoming ) ) {
|
||||||
|
|
||||||
switch( code ) {
|
switch( code ) {
|
||||||
/* case XWPROTO_MOVEMADE_INFO: */
|
/* case XWPROTO_MOVEMADE_INFO: */
|
||||||
/* accepted = client_reflectMoveMade( server, incomming ); */
|
/* accepted = client_reflectMoveMade( server, incoming ); */
|
||||||
/* if ( accepted ) { */
|
/* if ( accepted ) { */
|
||||||
/* nextTurn( server ); */
|
/* nextTurn( server ); */
|
||||||
/* } */
|
/* } */
|
||||||
/* break; */
|
/* break; */
|
||||||
/* case XWPROTO_TRADEMADE_INFO: */
|
/* case XWPROTO_TRADEMADE_INFO: */
|
||||||
/* accepted = client_reflectTradeMade( server, incomming ); */
|
/* accepted = client_reflectTradeMade( server, incoming ); */
|
||||||
/* if ( accepted ) { */
|
/* if ( accepted ) { */
|
||||||
/* nextTurn( server ); */
|
/* nextTurn( server ); */
|
||||||
/* } */
|
/* } */
|
||||||
/* break; */
|
/* break; */
|
||||||
/* case XWPROTO_CLIENT_MOVE_INFO: */
|
/* case XWPROTO_CLIENT_MOVE_INFO: */
|
||||||
/* accepted = handleClientMoved( server, incomming ); */
|
/* accepted = handleClientMoved( server, incoming ); */
|
||||||
/* break; */
|
/* break; */
|
||||||
/* case XWPROTO_CLIENT_TRADE_INFO: */
|
/* case XWPROTO_CLIENT_TRADE_INFO: */
|
||||||
/* accepted = handleClientTraded( server, incomming ); */
|
/* accepted = handleClientTraded( server, incoming ); */
|
||||||
/* break; */
|
/* break; */
|
||||||
|
|
||||||
case XWPROTO_MOVEMADE_INFO_CLIENT: /* client is reporting a move */
|
case XWPROTO_MOVEMADE_INFO_CLIENT: /* client is reporting a move */
|
||||||
accepted = reflectMoveAndInform( server, incomming );
|
accepted = reflectMoveAndInform( server, incoming );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case XWPROTO_MOVEMADE_INFO_SERVER: /* server telling me about a move */
|
case XWPROTO_MOVEMADE_INFO_SERVER: /* server telling me about a move */
|
||||||
accepted = reflectMove( server, incomming );
|
accepted = reflectMove( server, incoming );
|
||||||
if ( accepted ) {
|
if ( accepted ) {
|
||||||
nextTurn( server, PICK_NEXT );
|
nextTurn( server, PICK_NEXT );
|
||||||
}
|
}
|
||||||
|
@ -2235,19 +2271,19 @@ server_receiveMessage( ServerCtxt* server, XWStreamCtxt* incomming )
|
||||||
|
|
||||||
case XWPROTO_UNDO_INFO_CLIENT:
|
case XWPROTO_UNDO_INFO_CLIENT:
|
||||||
case XWPROTO_UNDO_INFO_SERVER:
|
case XWPROTO_UNDO_INFO_SERVER:
|
||||||
accepted = reflectUndos( server, incomming, code );
|
accepted = reflectUndos( server, incoming, code );
|
||||||
/* nextTurn is called by reflectUndos */
|
/* nextTurn is called by reflectUndos */
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case XWPROTO_BADWORD_INFO:
|
case XWPROTO_BADWORD_INFO:
|
||||||
accepted = handleIllegalWord( server, incomming );
|
accepted = handleIllegalWord( server, incoming );
|
||||||
if ( accepted && server->nv.gameState != XWSTATE_GAMEOVER ) {
|
if ( accepted && server->nv.gameState != XWSTATE_GAMEOVER ) {
|
||||||
nextTurn( server, PICK_NEXT );
|
nextTurn( server, PICK_NEXT );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case XWPROTO_MOVE_CONFIRM:
|
case XWPROTO_MOVE_CONFIRM:
|
||||||
accepted = handleMoveOk( server, incomming );
|
accepted = handleMoveOk( server, incoming );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case XWPROTO_CLIENT_REQ_END_GAME:
|
case XWPROTO_CLIENT_REQ_END_GAME:
|
||||||
|
@ -2259,12 +2295,12 @@ server_receiveMessage( ServerCtxt* server, XWStreamCtxt* incomming )
|
||||||
accepted = XP_TRUE;
|
accepted = XP_TRUE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
XP_WARNF( "Unknown code on incomming message: %d\n", code );
|
XP_WARNF( "Unknown code on incoming message: %d\n", code );
|
||||||
break;
|
break;
|
||||||
} /* switch */
|
} /* switch */
|
||||||
}
|
}
|
||||||
|
|
||||||
stream_close( incomming );
|
stream_close( incoming );
|
||||||
return accepted;
|
return accepted;
|
||||||
} /* server_receiveMessage */
|
} /* server_receiveMessage */
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue