mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-07 05:24:46 +01:00
add debug-only field tracking place in iterator
This commit is contained in:
parent
0f7d924a8e
commit
e9ec30206d
1 changed files with 30 additions and 28 deletions
|
@ -107,9 +107,13 @@ typedef struct _Indexer {
|
||||||
|
|
||||||
struct DictIter {
|
struct DictIter {
|
||||||
XP_U16 nEdges;
|
XP_U16 nEdges;
|
||||||
|
#ifdef DEBUG
|
||||||
|
/* Current string: useful when stepping in gdb */
|
||||||
|
XP_UCHAR curWord[32];
|
||||||
|
#endif
|
||||||
struct {
|
struct {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
XP_UCHAR face[8];
|
XP_U16 faceLen;
|
||||||
#endif
|
#endif
|
||||||
array_edge* edge;
|
array_edge* edge;
|
||||||
PatMatch match;
|
PatMatch match;
|
||||||
|
@ -624,15 +628,6 @@ struct _IPattern {
|
||||||
} DIPattern;
|
} DIPattern;
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
static void
|
|
||||||
formatCurWord( const DictIter* iter, XP_UCHAR* buf, XP_U16 bufLen )
|
|
||||||
{
|
|
||||||
int index = 0;
|
|
||||||
for ( int ii = 0; ii < iter->nEdges; ++ii ) {
|
|
||||||
index += XP_SNPRINTF( buf +index, bufLen - index, "%s", iter->stack[ii].face );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* static void */
|
/* static void */
|
||||||
/* logCurWord( const DictIter* iter, const XP_UCHAR* note ) */
|
/* logCurWord( const DictIter* iter, const XP_UCHAR* note ) */
|
||||||
/* { */
|
/* { */
|
||||||
|
@ -1014,17 +1009,14 @@ patMatchFinished( const DictIter* iter, XP_Bool log )
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if ( log ) {
|
if ( log ) {
|
||||||
XP_UCHAR word[32];
|
|
||||||
formatCurWord( iter, word, VSIZE(word) );
|
|
||||||
|
|
||||||
if ( result ) {
|
if ( result ) {
|
||||||
XP_UCHAR elemBuf[64];
|
XP_UCHAR elemBuf[64];
|
||||||
PrintState prs = { .iter = iter, .buf = elemBuf, .bufLen = VSIZE(elemBuf), };
|
PrintState prs = { .iter = iter, .buf = elemBuf, .bufLen = VSIZE(elemBuf), };
|
||||||
formatElem( &prs, params.elem );
|
formatElem( &prs, params.elem );
|
||||||
XP_LOGFF( "for word %s: => %s (matched elem %d: %s)", word, boolToStr(result),
|
XP_LOGFF( "for word %s: => %s (matched elem %d: %s)", iter->curWord, boolToStr(result),
|
||||||
params.patElemIndx, elemBuf );
|
params.patElemIndx, elemBuf );
|
||||||
} else {
|
} else {
|
||||||
XP_LOGFF( "for word %s: => %s", word, boolToStr(result) );
|
XP_LOGFF( "for word %s: => %s", iter->curWord, boolToStr(result) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -1084,9 +1076,12 @@ pushEdge( DictIter* iter, array_edge* edge, PatMatch* match )
|
||||||
iter->stack[nEdges].match = *match;
|
iter->stack[nEdges].match = *match;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if ( !!edge ) { /* Will fail when called from di_stringMatches() */
|
if ( !!edge ) { /* Will fail when called from di_stringMatches() */
|
||||||
|
// XP_LOGFF( "before: %s", iter->curWord );
|
||||||
Tile tile = EDGETILE( iter->dict, edge );
|
Tile tile = EDGETILE( iter->dict, edge );
|
||||||
const XP_UCHAR* face = dict_getTileString( iter->dict, tile );
|
const XP_UCHAR* face = dict_getTileString( iter->dict, tile );
|
||||||
XP_STRNCPY( iter->stack[nEdges].face, face, VSIZE(iter->stack[nEdges].face) );
|
iter->stack[nEdges].faceLen = XP_STRLEN( face );
|
||||||
|
XP_STRCAT( iter->curWord, face );
|
||||||
|
// XP_LOGFF( "after: %s", iter->curWord );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return ++iter->nEdges;
|
return ++iter->nEdges;
|
||||||
|
@ -1096,6 +1091,14 @@ static array_edge*
|
||||||
popEdge( DictIter* iter )
|
popEdge( DictIter* iter )
|
||||||
{
|
{
|
||||||
XP_ASSERT( 0 < iter->nEdges );
|
XP_ASSERT( 0 < iter->nEdges );
|
||||||
|
#ifdef DEBUG
|
||||||
|
// XP_LOGFF( "before: %s", iter->curWord );
|
||||||
|
XP_U16 curLen = XP_STRLEN( iter->curWord );
|
||||||
|
XP_U16 popLen = iter->stack[iter->nEdges-1].faceLen;
|
||||||
|
XP_ASSERT( curLen >= popLen );
|
||||||
|
iter->curWord[curLen-popLen] = '\0';
|
||||||
|
// XP_LOGFF( "after: %s", iter->curWord );
|
||||||
|
#endif
|
||||||
return iter->stack[--iter->nEdges].edge;
|
return iter->stack[--iter->nEdges].edge;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1145,9 +1148,7 @@ nextWord( DictIter* iter, XP_Bool log )
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if ( log ) {
|
if ( log ) {
|
||||||
if ( success ) {
|
if ( success ) {
|
||||||
XP_UCHAR buf[32] = {0};
|
XP_LOGFF( "word found: %s", iter->curWord );
|
||||||
formatCurWord( iter, buf, VSIZE( buf ) );
|
|
||||||
XP_LOGFF( "word found: %s", buf );
|
|
||||||
} else {
|
} else {
|
||||||
XP_LOGFF( "NOTHING FOUND" );
|
XP_LOGFF( "NOTHING FOUND" );
|
||||||
}
|
}
|
||||||
|
@ -1228,19 +1229,11 @@ prevWord( DictIter* iter, XP_Bool log )
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if ( log ) {
|
if ( log ) {
|
||||||
if ( success ) {
|
if ( success ) {
|
||||||
XP_UCHAR buf[32] = {0};
|
XP_LOGFF( "word found: %s", iter->curWord );
|
||||||
formatCurWord( iter, buf, VSIZE( buf ) );
|
|
||||||
XP_LOGFF( "word found: %s", buf );
|
|
||||||
} else {
|
} else {
|
||||||
XP_LOGFF( "NOTHING FOUND" );
|
XP_LOGFF( "NOTHING FOUND" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if ( log && success ) { */
|
|
||||||
/* XP_UCHAR buf[32] = {0}; */
|
|
||||||
/* formatCurWord( iter, buf, VSIZE( buf ) ); */
|
|
||||||
/* XP_LOGFF( "word found: %s", buf ); */
|
|
||||||
/* } */
|
|
||||||
#endif
|
#endif
|
||||||
XP_ASSERT( (iter->min <= iter->nEdges && iter->nEdges <= iter->max) || !success );
|
XP_ASSERT( (iter->min <= iter->nEdges && iter->nEdges <= iter->max) || !success );
|
||||||
return success;
|
return success;
|
||||||
|
@ -1253,6 +1246,9 @@ findStartsWithTiles( DictIter* iter, const Tile* tiles, XP_U16 nTiles )
|
||||||
const DictionaryCtxt* dict = iter->dict;
|
const DictionaryCtxt* dict = iter->dict;
|
||||||
array_edge* edge = dict_getTopEdge( dict );
|
array_edge* edge = dict_getTopEdge( dict );
|
||||||
iter->nEdges = 0;
|
iter->nEdges = 0;
|
||||||
|
#ifdef DEBUG
|
||||||
|
iter->curWord[0] = '\0';
|
||||||
|
#endif
|
||||||
|
|
||||||
while ( nTiles > 0 ) {
|
while ( nTiles > 0 ) {
|
||||||
Tile tile = *tiles++;
|
Tile tile = *tiles++;
|
||||||
|
@ -1932,6 +1928,12 @@ di_wordToString( const DictIter* iter, XP_UCHAR* buf, XP_U16 buflen,
|
||||||
{
|
{
|
||||||
ASSERT_INITED( iter );
|
ASSERT_INITED( iter );
|
||||||
iterToString( iter, buf, buflen, delim );
|
iterToString( iter, buf, buflen, delim );
|
||||||
|
#ifdef DEBUG
|
||||||
|
// If there's no delim, debug string should be same
|
||||||
|
if ( !delim || '\0' != *delim ) {
|
||||||
|
XP_ASSERT( 0 == XP_STRCMP( buf, iter->curWord ) );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
DictPosition
|
DictPosition
|
||||||
|
|
Loading…
Reference in a new issue