mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-07 05:24:46 +01:00
detect when no moves found that meet criteria to fix (I think) crash
when iterating from highest to lowest move using prevMove.
This commit is contained in:
parent
4425ff838c
commit
5725f36db8
1 changed files with 22 additions and 11 deletions
|
@ -361,7 +361,7 @@ chooseMove( EngineCtxt* engine, PossibleMove** move )
|
||||||
|
|
||||||
*move = chosen; /* set either way */
|
*move = chosen; /* set either way */
|
||||||
|
|
||||||
result = chosen->score > 0;
|
result = (NULL != chosen) && (chosen->score > 0);
|
||||||
|
|
||||||
if ( !result ) {
|
if ( !result ) {
|
||||||
engine_reset( engine );
|
engine_reset( engine );
|
||||||
|
@ -1143,9 +1143,11 @@ saveMoveIfQualifies( EngineCtxt* engine, PossibleMove* posmove )
|
||||||
/* we're not interested if we've seen this */
|
/* we're not interested if we've seen this */
|
||||||
cmpVal = CMPMOVES( posmove, &engine->miData.lastSeenMove );
|
cmpVal = CMPMOVES( posmove, &engine->miData.lastSeenMove );
|
||||||
if ( !usePrev && cmpVal >= 0 ) {
|
if ( !usePrev && cmpVal >= 0 ) {
|
||||||
XP_LOGF( "%s: dropping: too high", __func__ );
|
XP_LOGF( "%s: dropping %d: higher than %d", __func__,
|
||||||
|
posmove->score, engine->miData.lastSeenMove.score );
|
||||||
} else if ( usePrev && cmpVal <= 0 ) {
|
} else if ( usePrev && cmpVal <= 0 ) {
|
||||||
XP_LOGF( "%s: dropping: too low", __func__ );
|
XP_LOGF( "%s: dropping %d: lower than %d", __func__,
|
||||||
|
posmove->score, engine->miData.lastSeenMove.score );
|
||||||
} else {
|
} else {
|
||||||
XP_S16 ii;
|
XP_S16 ii;
|
||||||
/* terminate i at 1 because mostest starts at 0 */
|
/* terminate i at 1 because mostest starts at 0 */
|
||||||
|
@ -1216,10 +1218,13 @@ set_search_limits( EngineCtxt* engine )
|
||||||
/* If we're going to be searching backwards we want our highest cached
|
/* If we're going to be searching backwards we want our highest cached
|
||||||
move as the limit; otherwise the lowest */
|
move as the limit; otherwise the lowest */
|
||||||
if ( 0 < engine->miData.nInMoveCache ) {
|
if ( 0 < engine->miData.nInMoveCache ) {
|
||||||
XP_U16 srcIndx = engine->usePrev? NUM_SAVED_ENGINE_MOVES-1 : 0;
|
XP_U16 srcIndx = engine->usePrev
|
||||||
|
? NUM_SAVED_ENGINE_MOVES-1 : engine->miData.bottom;
|
||||||
XP_MEMCPY( &engine->miData.lastSeenMove,
|
XP_MEMCPY( &engine->miData.lastSeenMove,
|
||||||
&engine->miData.savedMoves[srcIndx],
|
&engine->miData.savedMoves[srcIndx],
|
||||||
sizeof(engine->miData.lastSeenMove) );
|
sizeof(engine->miData.lastSeenMove) );
|
||||||
|
XP_LOGF( "%s: saved limit move with score: %d", __func__,
|
||||||
|
engine->miData.lastSeenMove.score );
|
||||||
//engine->miData.lowestSavedScore = 0;
|
//engine->miData.lowestSavedScore = 0;
|
||||||
} else {
|
} else {
|
||||||
/* we're doing this for first time */
|
/* we're doing this for first time */
|
||||||
|
@ -1256,14 +1261,20 @@ init_move_cache( EngineCtxt* engine )
|
||||||
static PossibleMove*
|
static PossibleMove*
|
||||||
next_from_cache( EngineCtxt* engine )
|
next_from_cache( EngineCtxt* engine )
|
||||||
{
|
{
|
||||||
|
PossibleMove* move;
|
||||||
|
if ( move_cache_empty( engine ) ) {
|
||||||
|
move = NULL;
|
||||||
|
} else {
|
||||||
if ( engine->usePrev ) {
|
if ( engine->usePrev ) {
|
||||||
++engine->miData.curCacheIndex;
|
++engine->miData.curCacheIndex;
|
||||||
} else {
|
} else {
|
||||||
--engine->miData.curCacheIndex;
|
--engine->miData.curCacheIndex;
|
||||||
}
|
}
|
||||||
|
move = &engine->miData.savedMoves[engine->miData.curCacheIndex];
|
||||||
XP_LOGF( "%s: curCacheIndex now %d", __func__,
|
XP_LOGF( "%s: curCacheIndex now %d", __func__,
|
||||||
engine->miData.curCacheIndex );
|
engine->miData.curCacheIndex );
|
||||||
return &engine->miData.savedMoves[engine->miData.curCacheIndex];
|
}
|
||||||
|
return move;
|
||||||
}
|
}
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
|
@ -1323,7 +1334,7 @@ scoreQualifies( EngineCtxt* engine, XP_U16 score )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
XP_LOGF( "%s(%d)->%d", __func__, score, qualifies );
|
//XP_LOGF( "%s(%d)->%d", __func__, score, qualifies );
|
||||||
return qualifies;
|
return qualifies;
|
||||||
} /* scoreQualifies */
|
} /* scoreQualifies */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue