mods to track just the main word when scoring a turn

This commit is contained in:
ehouse 2004-04-30 08:32:11 +00:00
parent 6f8c09ed54
commit 0db24688b3

View file

@ -45,7 +45,8 @@ static XP_S16 checkScoreMove( ModelCtxt* model, XP_S16 turn,
/* WordNotifierInfo* notifyInfo ); */ /* WordNotifierInfo* notifyInfo ); */
static XP_U16 scoreWord( ModelCtxt* model, MoveInfo* movei, static XP_U16 scoreWord( ModelCtxt* model, MoveInfo* movei,
EngineCtxt* engine, XWStreamCtxt* stream, EngineCtxt* engine, XWStreamCtxt* stream,
XP_Bool silent, WordNotifierInfo* notifyInfo ); XP_Bool silent, WordNotifierInfo* notifyInfo,
XP_UCHAR* mainWord );
/* for formatting when caller wants an explanation of the score. These live /* for formatting when caller wants an explanation of the score. These live
in separate function called only when stream != NULL so that they'll have in separate function called only when stream != NULL so that they'll have
@ -53,20 +54,20 @@ static XP_U16 scoreWord( ModelCtxt* model, MoveInfo* movei,
scoring */ scoring */
typedef struct WordScoreFormatter { typedef struct WordScoreFormatter {
DictionaryCtxt* dict; DictionaryCtxt* dict;
XWStreamCtxt* stream;
XP_UCHAR fullBuf[80]; XP_UCHAR fullBuf[80];
XP_UCHAR wordBuf[MAX_ROWS+1];
XP_U16 bufLen, nTiles; XP_U16 bufLen, nTiles;
XP_Bool firstPass; XP_Bool firstPass;
} WordScoreFormatter; } WordScoreFormatter;
static void wordScoreFormatterInit( WordScoreFormatter* fmtr, static void wordScoreFormatterInit( WordScoreFormatter* fmtr,
XWStreamCtxt* stream,
DictionaryCtxt* dict ); DictionaryCtxt* dict );
static void wordScoreFormatterAddTile( WordScoreFormatter* fmtr, Tile tile, static void wordScoreFormatterAddTile( WordScoreFormatter* fmtr, Tile tile,
XP_U16 tileMultiplier, XP_U16 tileMultiplier,
XP_Bool isBlank ); XP_Bool isBlank );
static void wordScoreFormatterFinish( WordScoreFormatter* fmtr, Tile* word ); static void wordScoreFormatterFinish( WordScoreFormatter* fmtr, Tile* word,
XWStreamCtxt* stream, XP_UCHAR* mainWord );
static void formatWordScore( XWStreamCtxt* stream, XP_U16 wordScore, static void formatWordScore( XWStreamCtxt* stream, XP_U16 wordScore,
XP_U16 moveMultiplier ); XP_U16 moveMultiplier );
static void formatSummary( XWStreamCtxt* stream, ModelCtxt* model, static void formatSummary( XWStreamCtxt* stream, ModelCtxt* model,
@ -105,7 +106,7 @@ adjustScoreForUndone( ModelCtxt* model, MoveInfo* mi, XP_U16 turn )
} else { } else {
moveScore = figureMoveScore( model, mi, (EngineCtxt*)NULL, moveScore = figureMoveScore( model, mi, (EngineCtxt*)NULL,
(XWStreamCtxt*)NULL, XP_TRUE, (XWStreamCtxt*)NULL, XP_TRUE,
(WordNotifierInfo*)NULL ); (WordNotifierInfo*)NULL, NULL );
} }
player->score -= moveScore; player->score -= moveScore;
player->curMoveScore = 0; player->curMoveScore = 0;
@ -240,7 +241,7 @@ checkScoreMove( ModelCtxt* model, XP_S16 turn, EngineCtxt* engine,
if ( isLegalMove( model, &moveInfo, silent ) ) { if ( isLegalMove( model, &moveInfo, silent ) ) {
score = figureMoveScore( model, &moveInfo, engine, stream, score = figureMoveScore( model, &moveInfo, engine, stream,
silent, notifyInfo ); silent, notifyInfo, NULL );
} }
} else if ( !silent ) { /* tiles out of line */ } else if ( !silent ) { /* tiles out of line */
util_userError( model->vol.util, ERR_TILES_NOT_IN_LINE ); util_userError( model->vol.util, ERR_TILES_NOT_IN_LINE );
@ -444,7 +445,8 @@ isLegalMove( ModelCtxt* model, MoveInfo* mInfo, XP_Bool silent )
XP_U16 XP_U16
figureMoveScore( ModelCtxt* model, MoveInfo* moveInfo, EngineCtxt* engine, figureMoveScore( ModelCtxt* model, MoveInfo* moveInfo, EngineCtxt* engine,
XWStreamCtxt* stream, XP_Bool silent, XWStreamCtxt* stream, XP_Bool silent,
WordNotifierInfo* notifyInfo ) WordNotifierInfo* notifyInfo,
XP_UCHAR* mainWord )
{ {
XP_U16 col, row; XP_U16 col, row;
XP_U16* incr; XP_U16* incr;
@ -473,7 +475,7 @@ figureMoveScore( ModelCtxt* model, MoveInfo* moveInfo, EngineCtxt* engine,
} }
oneScore = scoreWord( model, moveInfo, (EngineCtxt*)NULL, stream, oneScore = scoreWord( model, moveInfo, (EngineCtxt*)NULL, stream,
silent, notifyInfo ); silent, notifyInfo, mainWord );
if ( !!stream ) { if ( !!stream ) {
formatWordScore( stream, oneScore, moveMultiplier ); formatWordScore( stream, oneScore, moveMultiplier );
} }
@ -491,7 +493,7 @@ figureMoveScore( ModelCtxt* model, MoveInfo* moveInfo, EngineCtxt* engine,
tmpMI.tiles[0].tile = tiles->tile; tmpMI.tiles[0].tile = tiles->tile;
oneScore = scoreWord( model, &tmpMI, engine, stream, silent, oneScore = scoreWord( model, &tmpMI, engine, stream, silent,
notifyInfo ); notifyInfo, NULL );
if ( !!stream ) { if ( !!stream ) {
formatWordScore( stream, oneScore, multipliers[i] ); formatWordScore( stream, oneScore, multipliers[i] );
} }
@ -551,7 +553,8 @@ scoreWord( ModelCtxt* model, MoveInfo* movei, /* new tiles */
EngineCtxt* engine,/* for crosswise caching */ EngineCtxt* engine,/* for crosswise caching */
XWStreamCtxt* stream, XWStreamCtxt* stream,
XP_Bool silent, /* report error via dialog */ XP_Bool silent, /* report error via dialog */
WordNotifierInfo* notifyInfo ) WordNotifierInfo* notifyInfo,
XP_UCHAR* mainWord )
{ {
XP_U16 tileMultiplier; XP_U16 tileMultiplier;
XP_U16 restScore, scoreFromCache; XP_U16 restScore, scoreFromCache;
@ -566,8 +569,8 @@ scoreWord( ModelCtxt* model, MoveInfo* movei, /* new tiles */
DictionaryCtxt* dict = model->vol.dict; DictionaryCtxt* dict = model->vol.dict;
WordScoreFormatter fmtr; WordScoreFormatter fmtr;
if ( !!stream ) { if ( !!stream || !!mainWord ) {
wordScoreFormatterInit( &fmtr, stream, dict ); wordScoreFormatterInit( &fmtr, dict );
} }
if ( movei->isHorizontal ) { if ( movei->isHorizontal ) {
@ -645,7 +648,7 @@ scoreWord( ModelCtxt* model, MoveInfo* movei, /* new tiles */
*curTile++ = tile; /* save in case we're checking phonies */ *curTile++ = tile; /* save in case we're checking phonies */
if ( !!stream ) { if ( !!stream || !!mainWord ) {
wordScoreFormatterAddTile( &fmtr, tile, tileMultiplier, wordScoreFormatterAddTile( &fmtr, tile, tileMultiplier,
isBlank ); isBlank );
} }
@ -673,8 +676,8 @@ scoreWord( ModelCtxt* model, MoveInfo* movei, /* new tiles */
} }
} }
if ( !!stream ) { if ( !!stream || !!mainWord ) {
wordScoreFormatterFinish( &fmtr, checkWordBuf ); wordScoreFormatterFinish( &fmtr, checkWordBuf, stream, mainWord );
} }
#ifdef DEBUG #ifdef DEBUG
@ -734,15 +737,11 @@ find_end( ModelCtxt* model, XP_U16 col, XP_U16 row, XP_Bool isHorizontal )
} /* find_end */ } /* find_end */
static void static void
wordScoreFormatterInit( WordScoreFormatter* fmtr, XWStreamCtxt* stream, wordScoreFormatterInit( WordScoreFormatter* fmtr, DictionaryCtxt* dict )
DictionaryCtxt* dict )
{ {
XP_ASSERT( !!stream ); XP_MEMSET( fmtr, 0, sizeof(*fmtr) );
fmtr->stream = stream;
fmtr->dict = dict;
fmtr->bufLen = 0; fmtr->dict = dict;
fmtr->nTiles = 0;
fmtr->firstPass = XP_TRUE; fmtr->firstPass = XP_TRUE;
} /* initWordScoreFormatter */ } /* initWordScoreFormatter */
@ -759,9 +758,12 @@ wordScoreFormatterAddTile( WordScoreFormatter* fmtr, Tile tile,
++fmtr->nTiles; ++fmtr->nTiles;
dict_tilesToString( fmtr->dict, &tile, 1, buf ); dict_tilesToString( fmtr->dict, &tile, 1, buf );
XP_ASSERT( XP_STRLEN(fmtr->wordBuf) + XP_STRLEN(buf) < sizeof(fmtr->wordBuf) );
XP_STRCAT( fmtr->wordBuf, buf );
if ( isBlank ) { if ( isBlank ) {
tile = dict_getBlankTile( fmtr->dict ); tile = dict_getBlankTile( fmtr->dict );
} }
tileScore = dict_getTileValue( fmtr->dict, tile ); tileScore = dict_getTileValue( fmtr->dict, tile );
if ( fmtr->firstPass ) { if ( fmtr->firstPass ) {
@ -783,15 +785,23 @@ wordScoreFormatterAddTile( WordScoreFormatter* fmtr, Tile tile,
} /* wordScoreFormatterAddTile */ } /* wordScoreFormatterAddTile */
static void static void
wordScoreFormatterFinish( WordScoreFormatter* fmtr, Tile* word ) wordScoreFormatterFinish( WordScoreFormatter* fmtr, Tile* word, XWStreamCtxt* stream,
XP_UCHAR* mainWord )
{ {
XP_UCHAR buf[(MAX_ROWS*2)+1]; XP_UCHAR buf[(MAX_ROWS*2)+1];
XP_U16 len = dict_tilesToString( fmtr->dict, word, fmtr->nTiles, buf ); XP_U16 len = dict_tilesToString( fmtr->dict, word, fmtr->nTiles, buf );
stream_putBytes( fmtr->stream, buf, len ); if ( !!stream ) {
stream_putBytes( stream, buf, len );
stream_putBytes( stream, fmtr->fullBuf, fmtr->bufLen );
stream_putU8( stream, ']' );
}
if ( !!mainWord ) {
XP_MEMCPY( mainWord, fmtr->wordBuf, XP_STRLEN(fmtr->wordBuf) + 1 );
}
stream_putBytes( fmtr->stream, fmtr->fullBuf, fmtr->bufLen );
stream_putU8( fmtr->stream, ']' );
} /* wordScoreFormatterFinish */ } /* wordScoreFormatterFinish */
static void static void