mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-03 23:04:08 +01:00
cleanup/modernize (should be no behavior change)
This commit is contained in:
parent
2c153d1b9e
commit
de01c1aadb
2 changed files with 40 additions and 59 deletions
|
@ -1686,15 +1686,7 @@ static XP_S16
|
|||
commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
|
||||
XWStreamCtxt* stream, WordNotifierInfo* wni, XP_Bool useStack )
|
||||
{
|
||||
XP_U16 ii;
|
||||
PlayerCtxt* player;
|
||||
PendingTile* pt;
|
||||
XP_S16 score = -1;
|
||||
XP_Bool isHorizontal;
|
||||
const Tile* newTilesP;
|
||||
XP_U16 nTiles;
|
||||
|
||||
nTiles = newTiles->nTiles;
|
||||
|
||||
#ifdef DEBUG
|
||||
XP_ASSERT( getCurrentMoveScoreIfLegal( model, turn, (XWStreamCtxt*)NULL,
|
||||
|
@ -1706,10 +1698,11 @@ commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
|
|||
|
||||
clearLastMoveInfo( model );
|
||||
|
||||
player = &model->players[turn];
|
||||
PlayerCtxt* player = &model->players[turn];
|
||||
|
||||
if ( useStack ) {
|
||||
MoveInfo moveInfo = {0};
|
||||
XP_Bool isHorizontal;
|
||||
#ifdef DEBUG
|
||||
XP_Bool inLine =
|
||||
#endif
|
||||
|
@ -1720,19 +1713,16 @@ commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
|
|||
stack_addMove( model->vol.stack, turn, &moveInfo, newTiles );
|
||||
}
|
||||
|
||||
for ( ii = 0, pt=player->pendingTiles; ii < player->nPending;
|
||||
++ii, ++pt ) {
|
||||
XP_U16 col, row;
|
||||
CellTile tile;
|
||||
XP_U16 val;
|
||||
|
||||
col = pt->col;
|
||||
row = pt->row;
|
||||
tile = getModelTileRaw( model, col, row );
|
||||
/* Where's it removed from tray? Need to assert there! */
|
||||
for ( int ii = 0; ii < player->nPending; ++ii ) {
|
||||
const PendingTile* pt = &player->pendingTiles[ii];
|
||||
XP_U16 col = pt->col;
|
||||
XP_U16 row = pt->row;
|
||||
CellTile tile = getModelTileRaw( model, col, row );
|
||||
|
||||
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! */
|
||||
putBackOtherPlayersTiles( model, turn, col, row );
|
||||
}
|
||||
|
@ -1753,17 +1743,18 @@ commitTurn( ModelCtxt* model, XP_S16 turn, const TrayTileSet* newTiles,
|
|||
player->score += score;
|
||||
|
||||
/* Why is this next loop necessary? */
|
||||
for ( ii = 0; ii < model->nPlayers; ++ii ) {
|
||||
for ( int ii = 0; ii < model->nPlayers; ++ii ) {
|
||||
invalidateScore( model, ii );
|
||||
}
|
||||
|
||||
player->nPending = 0;
|
||||
player->nUndone = 0;
|
||||
|
||||
newTilesP = newTiles->tiles;
|
||||
while ( nTiles-- ) {
|
||||
model_addPlayerTile( model, turn, -1, *newTilesP++ );
|
||||
/* Move new tiles into tray */
|
||||
for ( int ii = newTiles->nTiles - 1; ii >= 0; --ii ) {
|
||||
model_addPlayerTile( model, turn, -1, newTiles->tiles[ii] );
|
||||
}
|
||||
|
||||
return score;
|
||||
} /* commitTurn */
|
||||
|
||||
|
@ -2064,14 +2055,12 @@ static void
|
|||
printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry,
|
||||
void* p_closure )
|
||||
{
|
||||
XWStreamCtxt* stream;
|
||||
if ( entry->moveType != ASSIGN_TYPE ) {
|
||||
const XP_UCHAR* format;
|
||||
XP_UCHAR buf[64];
|
||||
XP_UCHAR traybuf[MAX_TRAY_TILES+1];
|
||||
MovePrintClosure* closure = (MovePrintClosure*)p_closure;
|
||||
|
||||
if ( entry->moveType != ASSIGN_TYPE ) {
|
||||
stream = closure->stream;
|
||||
XWStreamCtxt* stream = closure->stream;
|
||||
|
||||
XP_SNPRINTF( buf, sizeof(buf), (XP_UCHAR*)"%d:%d ", ++closure->nPrinted,
|
||||
entry->playerNum+1 );
|
||||
|
@ -2134,19 +2123,18 @@ printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN),
|
|||
const StackEntry* entry, XP_S16 XP_UNUSED(score),
|
||||
void* p_closure )
|
||||
{
|
||||
if ( entry->moveType != ASSIGN_TYPE ) {
|
||||
MovePrintClosure* closure = (MovePrintClosure*)p_closure;
|
||||
XWStreamCtxt* stream = closure->stream;
|
||||
DictionaryCtxt* dict = closure->dict;
|
||||
const XP_UCHAR* format;
|
||||
XP_U16 nTiles;
|
||||
XP_S16 totalScore;
|
||||
|
||||
XP_UCHAR buf[100];
|
||||
XP_UCHAR traybuf1[MAX_TRAY_TILES+1];
|
||||
XP_UCHAR traybuf2[MAX_TRAY_TILES+1];
|
||||
const MoveInfo* mi;
|
||||
|
||||
if ( entry->moveType != ASSIGN_TYPE ) {
|
||||
totalScore = model_getPlayerScore( model, entry->playerNum );
|
||||
XP_S16 totalScore = model_getPlayerScore( model, entry->playerNum );
|
||||
|
||||
switch( entry->moveType ) {
|
||||
case TRADE_TYPE:
|
||||
|
|
|
@ -1833,10 +1833,7 @@ fetchTiles( ServerCtxt* server, XP_U16 playerNum, XP_U16 nToFetch,
|
|||
{
|
||||
XP_Bool ask;
|
||||
XP_U16 nSoFar = resultTiles->nTiles;
|
||||
XP_U16 nLeft;
|
||||
PoolContext* pool = server->pool;
|
||||
TrayTileSet oneTile;
|
||||
PickInfo pi;
|
||||
const XP_UCHAR* curTray[MAX_TRAY_TILES];
|
||||
#ifdef FEATURE_TRAY_EDIT
|
||||
DictionaryCtxt* dict = model_getDictionary( server->vol.model );
|
||||
|
@ -1850,22 +1847,22 @@ fetchTiles( ServerCtxt* server, XP_U16 playerNum, XP_U16 nToFetch,
|
|||
ask = XP_FALSE;
|
||||
#endif
|
||||
|
||||
nLeft = pool_getNTilesLeft( pool );
|
||||
XP_U16 nLeft = pool_getNTilesLeft( pool );
|
||||
if ( nLeft < nToFetch ) {
|
||||
nToFetch = nLeft;
|
||||
}
|
||||
|
||||
oneTile.nTiles = 1;
|
||||
|
||||
pi.nTotal = nToFetch;
|
||||
pi.thisPick = 0;
|
||||
pi.curTiles = curTray;
|
||||
TrayTileSet oneTile = {.nTiles = 1};
|
||||
PickInfo pi = { .nTotal = nToFetch,
|
||||
.thisPick = 0,
|
||||
.curTiles = curTray,
|
||||
};
|
||||
|
||||
curTrayAsTexts( server, playerNum, tradedTiles, &pi.nCurTiles, curTray );
|
||||
|
||||
#ifdef FEATURE_TRAY_EDIT /* good compiler would note ask==0, but... */
|
||||
/* First ask until cancelled */
|
||||
for ( ; ask && nSoFar < nToFetch; ) {
|
||||
while ( ask && nSoFar < nToFetch ) {
|
||||
const XP_UCHAR* texts[MAX_UNIQUE_TILES];
|
||||
Tile tiles[MAX_UNIQUE_TILES];
|
||||
XP_S16 chosen;
|
||||
|
@ -1902,12 +1899,7 @@ fetchTiles( ServerCtxt* server, XP_U16 playerNum, XP_U16 nToFetch,
|
|||
/* Then fetch the rest without asking */
|
||||
if ( nSoFar < nToFetch ) {
|
||||
XP_U8 nLeft = nToFetch - nSoFar;
|
||||
Tile tiles[MAX_TRAY_TILES];
|
||||
|
||||
pool_requestTiles( pool, tiles, &nLeft );
|
||||
|
||||
XP_MEMCPY( &resultTiles->tiles[nSoFar], tiles,
|
||||
nLeft * sizeof(resultTiles->tiles[0]) );
|
||||
pool_requestTiles( pool, &resultTiles->tiles[nSoFar], &nLeft );
|
||||
nSoFar += nLeft;
|
||||
}
|
||||
|
||||
|
@ -2463,8 +2455,9 @@ server_commitMove( ServerCtxt* server, TrayTileSet* newTilesP )
|
|||
if client, send to server. */
|
||||
XP_ASSERT( turn >= 0 );
|
||||
|
||||
nTilesMoved = model_getCurrentMoveCount( model, turn );
|
||||
pool_removeTiles( server->pool, &newTiles );
|
||||
|
||||
nTilesMoved = model_getCurrentMoveCount( model, turn );
|
||||
fetchTiles( server, turn, nTilesMoved, NULL, &newTiles );
|
||||
|
||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||
|
|
Loading…
Reference in a new issue