cleanup/modernize (should be no behavior change)

This commit is contained in:
Eric House 2018-03-01 08:13:38 -08:00
parent 2c153d1b9e
commit de01c1aadb
2 changed files with 40 additions and 59 deletions

View file

@ -1686,15 +1686,7 @@ static XP_S16
commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles, commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
XWStreamCtxt* stream, WordNotifierInfo* wni, XP_Bool useStack ) XWStreamCtxt* stream, WordNotifierInfo* wni, XP_Bool useStack )
{ {
XP_U16 ii;
PlayerCtxt* player;
PendingTile* pt;
XP_S16 score = -1; XP_S16 score = -1;
XP_Bool isHorizontal;
const Tile* newTilesP;
XP_U16 nTiles;
nTiles = newTiles->nTiles;
#ifdef DEBUG #ifdef DEBUG
XP_ASSERT( getCurrentMoveScoreIfLegal( model, turn, (XWStreamCtxt*)NULL, XP_ASSERT( getCurrentMoveScoreIfLegal( model, turn, (XWStreamCtxt*)NULL,
@ -1706,10 +1698,11 @@ commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
clearLastMoveInfo( model ); clearLastMoveInfo( model );
player = &model->players[turn]; PlayerCtxt* player = &model->players[turn];
if ( useStack ) { if ( useStack ) {
MoveInfo moveInfo = {0}; MoveInfo moveInfo = {0};
XP_Bool isHorizontal;
#ifdef DEBUG #ifdef DEBUG
XP_Bool inLine = XP_Bool inLine =
#endif #endif
@ -1720,19 +1713,16 @@ commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
stack_addMove( model->vol.stack, turn, &moveInfo, newTiles ); stack_addMove( model->vol.stack, turn, &moveInfo, newTiles );
} }
for ( ii = 0, pt=player->pendingTiles; ii < player->nPending; /* Where's it removed from tray? Need to assert there! */
++ii, ++pt ) { for ( int ii = 0; ii < player->nPending; ++ii ) {
XP_U16 col, row; const PendingTile* pt = &player->pendingTiles[ii];
CellTile tile; XP_U16 col = pt->col;
XP_U16 val; XP_U16 row = pt->row;
CellTile tile = getModelTileRaw( model, col, row );
col = pt->col;
row = pt->row;
tile = getModelTileRaw( model, col, row );
XP_ASSERT( (tile & TILE_PENDING_BIT) != 0 ); XP_ASSERT( (tile & TILE_PENDING_BIT) != 0 );
val = tile & TILE_VALUE_MASK; XP_U16 val = tile & TILE_VALUE_MASK;
if ( val > 1 ) { /* somebody else is using this square too! */ if ( val > 1 ) { /* somebody else is using this square too! */
putBackOtherPlayersTiles( model, turn, col, row ); putBackOtherPlayersTiles( model, turn, col, row );
} }
@ -1753,17 +1743,18 @@ commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
player->score += score; player->score += score;
/* Why is this next loop necessary? */ /* Why is this next loop necessary? */
for ( ii = 0; ii < model->nPlayers; ++ii ) { for ( int ii = 0; ii < model->nPlayers; ++ii ) {
invalidateScore( model, ii ); invalidateScore( model, ii );
} }
player->nPending = 0; player->nPending = 0;
player->nUndone = 0; player->nUndone = 0;
newTilesP = newTiles->tiles; /* Move new tiles into tray */
while ( nTiles-- ) { for ( int ii = newTiles->nTiles - 1; ii >= 0; --ii ) {
model_addPlayerTile( model, turn, -1, *newTilesP++ ); model_addPlayerTile( model, turn, -1, newTiles->tiles[ii] );
} }
return score; return score;
} /* commitTurn */ } /* commitTurn */
@ -2064,14 +2055,12 @@ static void
printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry, printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry,
void* p_closure ) void* p_closure )
{ {
XWStreamCtxt* stream; if ( entry->moveType != ASSIGN_TYPE ) {
const XP_UCHAR* format; const XP_UCHAR* format;
XP_UCHAR buf[64]; XP_UCHAR buf[64];
XP_UCHAR traybuf[MAX_TRAY_TILES+1]; XP_UCHAR traybuf[MAX_TRAY_TILES+1];
MovePrintClosure* closure = (MovePrintClosure*)p_closure; MovePrintClosure* closure = (MovePrintClosure*)p_closure;
XWStreamCtxt* stream = closure->stream;
if ( entry->moveType != ASSIGN_TYPE ) {
stream = closure->stream;
XP_SNPRINTF( buf, sizeof(buf), (XP_UCHAR*)"%d:%d ", ++closure->nPrinted, XP_SNPRINTF( buf, sizeof(buf), (XP_UCHAR*)"%d:%d ", ++closure->nPrinted,
entry->playerNum+1 ); entry->playerNum+1 );
@ -2134,19 +2123,18 @@ printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN),
const StackEntry* entry, XP_S16 XP_UNUSED(score), const StackEntry* entry, XP_S16 XP_UNUSED(score),
void* p_closure ) void* p_closure )
{ {
if ( entry->moveType != ASSIGN_TYPE ) {
MovePrintClosure* closure = (MovePrintClosure*)p_closure; MovePrintClosure* closure = (MovePrintClosure*)p_closure;
XWStreamCtxt* stream = closure->stream; XWStreamCtxt* stream = closure->stream;
DictionaryCtxt* dict = closure->dict; DictionaryCtxt* dict = closure->dict;
const XP_UCHAR* format; const XP_UCHAR* format;
XP_U16 nTiles; XP_U16 nTiles;
XP_S16 totalScore;
XP_UCHAR buf[100]; XP_UCHAR buf[100];
XP_UCHAR traybuf1[MAX_TRAY_TILES+1]; XP_UCHAR traybuf1[MAX_TRAY_TILES+1];
XP_UCHAR traybuf2[MAX_TRAY_TILES+1]; XP_UCHAR traybuf2[MAX_TRAY_TILES+1];
const MoveInfo* mi; const MoveInfo* mi;
XP_S16 totalScore = model_getPlayerScore( model, entry->playerNum );
if ( entry->moveType != ASSIGN_TYPE ) {
totalScore = model_getPlayerScore( model, entry->playerNum );
switch( entry->moveType ) { switch( entry->moveType ) {
case TRADE_TYPE: case TRADE_TYPE:

View file

@ -1833,10 +1833,7 @@ fetchTiles( ServerCtxt* server, XP_U16 playerNum, XP_U16 nToFetch,
{ {
XP_Bool ask; XP_Bool ask;
XP_U16 nSoFar = resultTiles->nTiles; XP_U16 nSoFar = resultTiles->nTiles;
XP_U16 nLeft;
PoolContext* pool = server->pool; PoolContext* pool = server->pool;
TrayTileSet oneTile;
PickInfo pi;
const XP_UCHAR* curTray[MAX_TRAY_TILES]; const XP_UCHAR* curTray[MAX_TRAY_TILES];
#ifdef FEATURE_TRAY_EDIT #ifdef FEATURE_TRAY_EDIT
DictionaryCtxt* dict = model_getDictionary( server->vol.model ); DictionaryCtxt* dict = model_getDictionary( server->vol.model );
@ -1850,22 +1847,22 @@ fetchTiles( ServerCtxt* server, XP_U16 playerNum, XP_U16 nToFetch,
ask = XP_FALSE; ask = XP_FALSE;
#endif #endif
nLeft = pool_getNTilesLeft( pool ); XP_U16 nLeft = pool_getNTilesLeft( pool );
if ( nLeft < nToFetch ) { if ( nLeft < nToFetch ) {
nToFetch = nLeft; nToFetch = nLeft;
} }
oneTile.nTiles = 1; TrayTileSet oneTile = {.nTiles = 1};
PickInfo pi = { .nTotal = nToFetch,
pi.nTotal = nToFetch; .thisPick = 0,
pi.thisPick = 0; .curTiles = curTray,
pi.curTiles = curTray; };
curTrayAsTexts( server, playerNum, tradedTiles, &pi.nCurTiles, curTray ); curTrayAsTexts( server, playerNum, tradedTiles, &pi.nCurTiles, curTray );
#ifdef FEATURE_TRAY_EDIT /* good compiler would note ask==0, but... */ #ifdef FEATURE_TRAY_EDIT /* good compiler would note ask==0, but... */
/* First ask until cancelled */ /* First ask until cancelled */
for ( ; ask && nSoFar < nToFetch; ) { while ( ask && nSoFar < nToFetch ) {
const XP_UCHAR* texts[MAX_UNIQUE_TILES]; const XP_UCHAR* texts[MAX_UNIQUE_TILES];
Tile tiles[MAX_UNIQUE_TILES]; Tile tiles[MAX_UNIQUE_TILES];
XP_S16 chosen; XP_S16 chosen;
@ -1902,12 +1899,7 @@ fetchTiles( ServerCtxt* server, XP_U16 playerNum, XP_U16 nToFetch,
/* Then fetch the rest without asking */ /* Then fetch the rest without asking */
if ( nSoFar < nToFetch ) { if ( nSoFar < nToFetch ) {
XP_U8 nLeft = nToFetch - nSoFar; XP_U8 nLeft = nToFetch - nSoFar;
Tile tiles[MAX_TRAY_TILES]; pool_requestTiles( pool, &resultTiles->tiles[nSoFar], &nLeft );
pool_requestTiles( pool, tiles, &nLeft );
XP_MEMCPY( &resultTiles->tiles[nSoFar], tiles,
nLeft * sizeof(resultTiles->tiles[0]) );
nSoFar += nLeft; nSoFar += nLeft;
} }
@ -2463,8 +2455,9 @@ server_commitMove( ServerCtxt* server, TrayTileSet* newTilesP )
if client, send to server. */ if client, send to server. */
XP_ASSERT( turn >= 0 ); XP_ASSERT( turn >= 0 );
nTilesMoved = model_getCurrentMoveCount( model, turn );
pool_removeTiles( server->pool, &newTiles ); pool_removeTiles( server->pool, &newTiles );
nTilesMoved = model_getCurrentMoveCount( model, turn );
fetchTiles( server, turn, nTilesMoved, NULL, &newTiles ); fetchTiles( server, turn, nTilesMoved, NULL, &newTiles );
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY