fix infinite loop when attempting to undo tile assignment. The ideal

fix would allow the undo, but this is much less risky.
This commit is contained in:
ehouse 2004-05-14 08:55:13 +00:00
parent a0be6e027a
commit 36bbf2d254

View file

@ -534,8 +534,13 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
XP_Bool success = XP_TRUE; XP_Bool success = XP_TRUE;
XP_S16 moveSought = *moveNumP; XP_S16 moveSought = *moveNumP;
XP_U16 nMovesUndone; XP_U16 nMovesUndone;
XP_U16 nStackEntries;
if ( stack_getNEntries( stack ) < nMovesSought ) { nStackEntries = stack_getNEntries( stack );
if ( nStackEntries < nMovesSought ) {
return XP_FALSE;
} else if ( nStackEntries <= model->nPlayers ) {
util_userError( model->vol.util, ERR_CANT_UNDO_TILEASSIGN );
return XP_FALSE; return XP_FALSE;
} }
@ -578,6 +583,7 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
/* nothing to do, since nothing happened */ /* nothing to do, since nothing happened */
} else { } else {
XP_ASSERT( entry.moveType == ASSIGN_TYPE );
success = XP_FALSE; success = XP_FALSE;
break; break;
} }
@ -616,6 +622,8 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
notifyBoardListeners( model, entry.playerNum, col, row, XP_FALSE ); notifyBoardListeners( model, entry.playerNum, col, row, XP_FALSE );
} }
break; break;
} else if ( entry.moveType == ASSIGN_TYPE ) {
break;
} }
} }