mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
fix infinite loop looking for last not-undone move to highlight.
This commit is contained in:
parent
d0e11a6080
commit
676f049479
1 changed files with 11 additions and 9 deletions
|
@ -540,7 +540,6 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
|
||||||
if ( nStackEntries < nMovesSought ) {
|
if ( nStackEntries < nMovesSought ) {
|
||||||
return XP_FALSE;
|
return XP_FALSE;
|
||||||
} else if ( nStackEntries <= model->nPlayers ) {
|
} else if ( nStackEntries <= model->nPlayers ) {
|
||||||
util_userError( model->vol.util, ERR_CANT_UNDO_TILEASSIGN );
|
|
||||||
return XP_FALSE;
|
return XP_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -590,13 +589,13 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If there's still a move on top of the stack, highlight its tiles since
|
/* Find the first MOVE still on the stack and highlight its tiles since
|
||||||
they're now the most recent move. */
|
they're now the most recent move. Trades and lost turns ignored. */
|
||||||
|
nStackEntries = stack_getNEntries( stack );
|
||||||
for ( ; ; ) {
|
for ( ; ; ) {
|
||||||
StackEntry entry;
|
StackEntry entry;
|
||||||
XP_U16 movesLeft = stack_getNEntries( stack );
|
if ( nStackEntries == 0 ||
|
||||||
if ( movesLeft == 0 ||
|
!stack_getNthEntry( stack, nStackEntries - 1, &entry ) ) {
|
||||||
!stack_getNthEntry( stack, movesLeft - 1, &entry ) ) {
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if ( entry.moveType == MOVE_TYPE ) {
|
if ( entry.moveType == MOVE_TYPE ) {
|
||||||
|
@ -617,13 +616,16 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
|
||||||
|
|
||||||
*varies = entry.u.move.moveInfo.tiles[nTiles].varCoord;
|
*varies = entry.u.move.moveInfo.tiles[nTiles].varCoord;
|
||||||
tile = getModelTileRaw( model, col, row );
|
tile = getModelTileRaw( model, col, row );
|
||||||
setModelTileRaw( model, col, row, (CellTile)(tile | PREV_MOVE_BIT) );
|
setModelTileRaw( model, col, row,
|
||||||
|
(CellTile)(tile | PREV_MOVE_BIT) );
|
||||||
notifyBoardListeners( model, entry.playerNum, col, row, XP_FALSE );
|
notifyBoardListeners( model, entry.playerNum, col, row,
|
||||||
|
XP_FALSE );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
} else if ( entry.moveType == ASSIGN_TYPE ) {
|
} else if ( entry.moveType == ASSIGN_TYPE ) {
|
||||||
break;
|
break;
|
||||||
|
} else {
|
||||||
|
--nStackEntries; /* look at the next one */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue