mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
add model_recentPassCountOk
This commit is contained in:
parent
912f53178b
commit
26cd5c2d88
2 changed files with 42 additions and 0 deletions
|
@ -34,6 +34,8 @@ extern "C" {
|
||||||
|
|
||||||
#define mEND 0x6d454e44
|
#define mEND 0x6d454e44
|
||||||
|
|
||||||
|
#define MAX_PASSES 2 /* how many times can all players pass? */
|
||||||
|
|
||||||
/****************************** prototypes ******************************/
|
/****************************** prototypes ******************************/
|
||||||
typedef void (*MovePrintFuncPre)(ModelCtxt*, XP_U16, StackEntry*, void*);
|
typedef void (*MovePrintFuncPre)(ModelCtxt*, XP_U16, StackEntry*, void*);
|
||||||
typedef void (*MovePrintFuncPost)(ModelCtxt*, XP_U16, StackEntry*, XP_S16,
|
typedef void (*MovePrintFuncPost)(ModelCtxt*, XP_U16, StackEntry*, XP_S16,
|
||||||
|
@ -64,6 +66,7 @@ static void buildModelFromStack( ModelCtxt* model, StackCtxt* stack,
|
||||||
static void setPendingCounts( ModelCtxt* model, XP_S16 turn );
|
static void setPendingCounts( ModelCtxt* model, XP_S16 turn );
|
||||||
static void loadPlayerCtxt( XWStreamCtxt* stream, PlayerCtxt* pc );
|
static void loadPlayerCtxt( XWStreamCtxt* stream, PlayerCtxt* pc );
|
||||||
static void writePlayerCtxt( XWStreamCtxt* stream, PlayerCtxt* pc );
|
static void writePlayerCtxt( XWStreamCtxt* stream, PlayerCtxt* pc );
|
||||||
|
static XP_U16 model_getRecentPassCount( ModelCtxt* model );
|
||||||
|
|
||||||
|
|
||||||
/*****************************************************************************
|
/*****************************************************************************
|
||||||
|
@ -1620,6 +1623,42 @@ scoreLastMove( ModelCtxt* model, MoveInfo* moveInfo, XP_U16 howMany,
|
||||||
}
|
}
|
||||||
} /* scoreLastMove */
|
} /* scoreLastMove */
|
||||||
|
|
||||||
|
static XP_U16
|
||||||
|
model_getRecentPassCount( ModelCtxt* model )
|
||||||
|
{
|
||||||
|
StackCtxt* stack = model->vol.stack;
|
||||||
|
XP_U16 nPasses = 0;
|
||||||
|
XP_S16 nEntries, which;
|
||||||
|
StackEntry entry;
|
||||||
|
|
||||||
|
XP_ASSERT( !!stack );
|
||||||
|
|
||||||
|
nEntries = stack_getNEntries( stack );
|
||||||
|
for ( which = nEntries - 1; which >= 0; --which ) {
|
||||||
|
if ( stack_getNthEntry( stack, which, &entry ) ) {
|
||||||
|
if ( entry.moveType == MOVE_TYPE
|
||||||
|
&& entry.u.move.moveInfo.nTiles == 0 ) {
|
||||||
|
++nPasses;
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
XP_LOGF( "model_getRecentPassCount=>%d", nPasses );
|
||||||
|
return nPasses;
|
||||||
|
} /* model_getRecentPassCount */
|
||||||
|
|
||||||
|
XP_Bool
|
||||||
|
model_recentPassCountOk( ModelCtxt* model )
|
||||||
|
{
|
||||||
|
XP_U16 count = model_getRecentPassCount( model );
|
||||||
|
XP_U16 okCount = model->nPlayers * MAX_PASSES;
|
||||||
|
XP_ASSERT( count <= okCount ); /* should never be more than 1 over */
|
||||||
|
return count < okCount;
|
||||||
|
}
|
||||||
|
|
||||||
XP_Bool
|
XP_Bool
|
||||||
model_getPlayersLastScore( ModelCtxt* model, XP_S16 player,
|
model_getPlayersLastScore( ModelCtxt* model, XP_S16 player,
|
||||||
XP_UCHAR* expl, XP_U16* explLen )
|
XP_UCHAR* expl, XP_U16* explLen )
|
||||||
|
|
|
@ -215,6 +215,9 @@ XP_S16 model_getPlayerScore( ModelCtxt* model, XP_S16 player );
|
||||||
XP_Bool model_getPlayersLastScore( ModelCtxt* model, XP_S16 player,
|
XP_Bool model_getPlayersLastScore( ModelCtxt* model, XP_S16 player,
|
||||||
XP_UCHAR* expl, XP_U16* explLen );
|
XP_UCHAR* expl, XP_U16* explLen );
|
||||||
|
|
||||||
|
/* Have there been too many passes (so game should end)? */
|
||||||
|
XP_Bool model_recentPassCountOk( ModelCtxt* model );
|
||||||
|
|
||||||
XP_Bool model_checkMoveLegal( ModelCtxt* model, XP_S16 player,
|
XP_Bool model_checkMoveLegal( ModelCtxt* model, XP_S16 player,
|
||||||
XWStreamCtxt* stream,
|
XWStreamCtxt* stream,
|
||||||
WordNotifierInfo* notifyInfo );
|
WordNotifierInfo* notifyInfo );
|
||||||
|
|
Loading…
Reference in a new issue