stop using thread->env mapping for util callbacks

This commit is contained in:
Eric House 2020-04-26 11:28:18 -07:00
parent eb9ef738e4
commit 88335d38f2
41 changed files with 1340 additions and 1289 deletions

View file

@ -33,7 +33,6 @@
typedef struct _AndDUtil { typedef struct _AndDUtil {
XW_DUtilCtxt dutil; XW_DUtilCtxt dutil;
EnvThreadInfo* ti;
JNIUtilCtxt* jniutil; JNIUtilCtxt* jniutil;
jobject jdutil; /* global ref to object implementing XW_DUtilCtxt */ jobject jdutil; /* global ref to object implementing XW_DUtilCtxt */
XP_UCHAR* userStrings[N_AND_USER_STRINGS]; XP_UCHAR* userStrings[N_AND_USER_STRINGS];
@ -50,14 +49,14 @@ typedef struct _TimerStorage {
typedef struct _AndUtil { typedef struct _AndUtil {
XW_UtilCtxt util; XW_UtilCtxt util;
EnvThreadInfo* ti;
jobject jutil; /* global ref to object implementing XW_UtilCtxt */ jobject jutil; /* global ref to object implementing XW_UtilCtxt */
TimerStorage timerStorage[NUM_TIMERS_PLUS_ONE]; TimerStorage timerStorage[NUM_TIMERS_PLUS_ONE];
} AndUtil; } AndUtil;
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static XWStreamCtxt* static XWStreamCtxt*
and_util_makeStreamFromAddr( XW_UtilCtxt* uc, XP_PlayerAddr channelNo ) and_util_makeStreamFromAddr( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_PlayerAddr channelNo )
{ {
#ifdef DEBUG #ifdef DEBUG
AndUtil* util = (AndUtil*)uc; AndUtil* util = (AndUtil*)uc;
@ -73,7 +72,7 @@ and_util_makeStreamFromAddr( XW_UtilCtxt* uc, XP_PlayerAddr channelNo )
#define UTIL_CBK_HEADER(nam,sig) \ #define UTIL_CBK_HEADER(nam,sig) \
AndUtil* util = (AndUtil*)uc; \ AndUtil* util = (AndUtil*)uc; \
JNIEnv* env = ENVFORME( util->ti ); \ JNIEnv* env = xwe; \
if ( NULL != util->jutil ) { \ if ( NULL != util->jutil ) { \
jmethodID mid = getMethodID( env, util->jutil, nam, sig ) jmethodID mid = getMethodID( env, util->jutil, nam, sig )
@ -85,13 +84,14 @@ and_util_makeStreamFromAddr( XW_UtilCtxt* uc, XP_PlayerAddr channelNo )
#define DUTIL_CBK_HEADER(nam,sig) \ #define DUTIL_CBK_HEADER(nam,sig) \
AndDUtil* dutil = (AndDUtil*)duc; \ AndDUtil* dutil = (AndDUtil*)duc; \
JNIEnv* env = ENVFORME( dutil->ti ); \ JNIEnv* env = xwe; \
if ( NULL != dutil->jdutil ) { \ if ( NULL != dutil->jdutil ) { \
jmethodID mid = getMethodID( env, dutil->jdutil, nam, sig ) jmethodID mid = getMethodID( env, dutil->jdutil, nam, sig )
#define DUTIL_CBK_TAIL() UTIL_CBK_TAIL() #define DUTIL_CBK_TAIL() UTIL_CBK_TAIL()
static XWBonusType and_util_getSquareBonus( XW_UtilCtxt* XP_UNUSED(uc), static XWBonusType and_util_getSquareBonus( XW_UtilCtxt* XP_UNUSED(uc),
XWEnv XP_UNUSED(xwe),
XP_U16 boardSize, XP_U16 boardSize,
XP_U16 col, XP_U16 row ) XP_U16 col, XP_U16 row )
{ {
@ -119,7 +119,7 @@ static XWBonusType and_util_getSquareBonus( XW_UtilCtxt* XP_UNUSED(uc),
} }
static void static void
and_util_userError( XW_UtilCtxt* uc, UtilErrID id ) and_util_userError( XW_UtilCtxt* uc, XWEnv xwe, UtilErrID id )
{ {
UTIL_CBK_HEADER( "userError", "(I)V" ); UTIL_CBK_HEADER( "userError", "(I)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, id ); (*env)->CallVoidMethod( env, util->jutil, mid, id );
@ -132,7 +132,7 @@ and_util_userError( XW_UtilCtxt* uc, UtilErrID id )
} }
static void static void
and_util_notifyMove( XW_UtilCtxt* uc, XWStreamCtxt* stream ) and_util_notifyMove( XW_UtilCtxt* uc, XWEnv xwe, XWStreamCtxt* stream )
{ {
UTIL_CBK_HEADER("notifyMove", "(Ljava/lang/String;)V" ); UTIL_CBK_HEADER("notifyMove", "(Ljava/lang/String;)V" );
@ -146,7 +146,7 @@ and_util_notifyMove( XW_UtilCtxt* uc, XWStreamCtxt* stream )
} }
static void static void
and_util_notifyTrade( XW_UtilCtxt* uc, const XP_UCHAR** tiles, XP_U16 nTiles ) and_util_notifyTrade( XW_UtilCtxt* uc, XWEnv xwe, const XP_UCHAR** tiles, XP_U16 nTiles )
{ {
UTIL_CBK_HEADER("notifyTrade", "([Ljava/lang/String;)V" ); UTIL_CBK_HEADER("notifyTrade", "([Ljava/lang/String;)V" );
jobjectArray jtiles = makeStringArray( env, nTiles, tiles ); jobjectArray jtiles = makeStringArray( env, nTiles, tiles );
@ -156,7 +156,7 @@ and_util_notifyTrade( XW_UtilCtxt* uc, const XP_UCHAR** tiles, XP_U16 nTiles )
} }
static void static void
and_util_notifyPickTileBlank( XW_UtilCtxt* uc, XP_U16 playerNum, and_util_notifyPickTileBlank( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 playerNum,
XP_U16 col, XP_U16 row, XP_U16 col, XP_U16 row,
const XP_UCHAR** tileFaces, XP_U16 nTiles ) const XP_UCHAR** tileFaces, XP_U16 nTiles )
{ {
@ -171,7 +171,7 @@ and_util_notifyPickTileBlank( XW_UtilCtxt* uc, XP_U16 playerNum,
} }
static void static void
and_util_informNeedPickTiles( XW_UtilCtxt* uc, XP_Bool isInitial, and_util_informNeedPickTiles( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool isInitial,
XP_U16 player, XP_U16 nToPick, XP_U16 player, XP_U16 nToPick,
XP_U16 nFaces, const XP_UCHAR** faces, XP_U16 nFaces, const XP_UCHAR** faces,
const XP_U16* counts ) const XP_U16* counts )
@ -189,7 +189,7 @@ and_util_informNeedPickTiles( XW_UtilCtxt* uc, XP_Bool isInitial,
} /* and_util_informNeedPickTiles */ } /* and_util_informNeedPickTiles */
static void static void
and_util_informNeedPassword( XW_UtilCtxt* uc, XP_U16 player, and_util_informNeedPassword( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 player,
const XP_UCHAR* name ) const XP_UCHAR* name )
{ {
UTIL_CBK_HEADER("informNeedPassword", "(ILjava/lang/String;)V" ); UTIL_CBK_HEADER("informNeedPassword", "(ILjava/lang/String;)V" );
@ -201,13 +201,14 @@ and_util_informNeedPassword( XW_UtilCtxt* uc, XP_U16 player,
} }
static void static void
and_util_trayHiddenChange(XW_UtilCtxt* uc, XW_TrayVisState newState, and_util_trayHiddenChange(XW_UtilCtxt* uc, XWEnv xwe,
XW_TrayVisState newState,
XP_U16 nVisibleRows ) XP_U16 nVisibleRows )
{ {
} }
static void static void
and_util_yOffsetChange(XW_UtilCtxt* uc, XP_U16 maxOffset, and_util_yOffsetChange(XW_UtilCtxt* uc, XWEnv xwe, XP_U16 maxOffset,
XP_U16 oldOffset, XP_U16 newOffset ) XP_U16 oldOffset, XP_U16 newOffset )
{ {
#if 0 #if 0
@ -223,7 +224,7 @@ and_util_yOffsetChange(XW_UtilCtxt* uc, XP_U16 maxOffset,
#ifdef XWFEATURE_TURNCHANGENOTIFY #ifdef XWFEATURE_TURNCHANGENOTIFY
static void static void
and_util_turnChanged( XW_UtilCtxt* uc, XP_S16 turn ) and_util_turnChanged( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 turn )
{ {
UTIL_CBK_HEADER( "turnChanged", "(I)V" ); UTIL_CBK_HEADER( "turnChanged", "(I)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, turn ); (*env)->CallVoidMethod( env, util->jutil, mid, turn );
@ -232,7 +233,7 @@ and_util_turnChanged( XW_UtilCtxt* uc, XP_S16 turn )
#endif #endif
static void static void
and_util_informMove( XW_UtilCtxt* uc, XP_S16 turn, XWStreamCtxt* expl, and_util_informMove( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 turn, XWStreamCtxt* expl,
XWStreamCtxt* words ) XWStreamCtxt* words )
{ {
UTIL_CBK_HEADER( "informMove", "(ILjava/lang/String;Ljava/lang/String;)V" ); UTIL_CBK_HEADER( "informMove", "(ILjava/lang/String;Ljava/lang/String;)V" );
@ -244,7 +245,7 @@ and_util_informMove( XW_UtilCtxt* uc, XP_S16 turn, XWStreamCtxt* expl,
} }
static void static void
and_util_notifyDupStatus( XW_UtilCtxt* uc, XP_Bool amHost, const XP_UCHAR* msg ) and_util_notifyDupStatus( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool amHost, const XP_UCHAR* msg )
{ {
UTIL_CBK_HEADER( "notifyDupStatus", "(ZLjava/lang/String;)V" ); UTIL_CBK_HEADER( "notifyDupStatus", "(ZLjava/lang/String;)V" );
jstring jmsg = (*env)->NewStringUTF( env, msg ); jstring jmsg = (*env)->NewStringUTF( env, msg );
@ -254,7 +255,7 @@ and_util_notifyDupStatus( XW_UtilCtxt* uc, XP_Bool amHost, const XP_UCHAR* msg )
} }
static void static void
and_util_informUndo( XW_UtilCtxt* uc ) and_util_informUndo( XW_UtilCtxt* uc, XWEnv xwe )
{ {
UTIL_CBK_HEADER( "informUndo", "()V" ); UTIL_CBK_HEADER( "informUndo", "()V" );
(*env)->CallVoidMethod( env, util->jutil, mid ); (*env)->CallVoidMethod( env, util->jutil, mid );
@ -262,7 +263,7 @@ and_util_informUndo( XW_UtilCtxt* uc )
} }
static void static void
and_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode lang, and_util_informNetDict( XW_UtilCtxt* uc, XWEnv xwe, XP_LangCode lang,
const XP_UCHAR* oldName, const XP_UCHAR* oldName,
const XP_UCHAR* newName, const XP_UCHAR* newSum, const XP_UCHAR* newName, const XP_UCHAR* newSum,
XWPhoniesChoice phoniesAction ) XWPhoniesChoice phoniesAction )
@ -285,7 +286,7 @@ and_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode lang,
} }
static void static void
and_util_notifyGameOver( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(quitter) ) and_util_notifyGameOver( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 XP_UNUSED(quitter) )
{ {
UTIL_CBK_HEADER( "notifyGameOver", "()V" ); UTIL_CBK_HEADER( "notifyGameOver", "()V" );
(*env)->CallVoidMethod( env, util->jutil, mid ); (*env)->CallVoidMethod( env, util->jutil, mid );
@ -302,7 +303,7 @@ and_util_hiliteCell( XW_UtilCtxt* uc, XP_U16 col, XP_U16 row )
#endif #endif
static XP_Bool static XP_Bool
and_util_engineProgressCallback( XW_UtilCtxt* uc ) and_util_engineProgressCallback( XW_UtilCtxt* uc, XWEnv xwe )
{ {
XP_Bool result = XP_FALSE; XP_Bool result = XP_FALSE;
UTIL_CBK_HEADER("engineProgressCallback","()Z" ); UTIL_CBK_HEADER("engineProgressCallback","()Z" );
@ -333,7 +334,7 @@ utilTimerFired( XW_UtilCtxt* uc, XWEnv xwe, XWTimerReason why, int handle )
} }
static void static void
and_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 when, and_util_setTimer( XW_UtilCtxt* uc, XWEnv xwe, XWTimerReason why, XP_U16 when,
XWTimerProc proc, void* closure ) XWTimerProc proc, void* closure )
{ {
UTIL_CBK_HEADER("setTimer", "(III)V" ); UTIL_CBK_HEADER("setTimer", "(III)V" );
@ -348,7 +349,7 @@ and_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 when,
} }
static void static void
and_util_clearTimer( XW_UtilCtxt* uc, XWTimerReason why ) and_util_clearTimer( XW_UtilCtxt* uc, XWEnv xwe, XWTimerReason why )
{ {
UTIL_CBK_HEADER("clearTimer", "(I)V" ); UTIL_CBK_HEADER("clearTimer", "(I)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, why ); (*env)->CallVoidMethod( env, util->jutil, mid, why );
@ -357,7 +358,7 @@ and_util_clearTimer( XW_UtilCtxt* uc, XWTimerReason why )
static void static void
and_util_requestTime( XW_UtilCtxt* uc ) and_util_requestTime( XW_UtilCtxt* uc, XWEnv xwe )
{ {
UTIL_CBK_HEADER("requestTime", "()V" ); UTIL_CBK_HEADER("requestTime", "()V" );
(*env)->CallVoidMethod( env, util->jutil, mid ); (*env)->CallVoidMethod( env, util->jutil, mid );
@ -365,20 +366,16 @@ and_util_requestTime( XW_UtilCtxt* uc )
} }
static XP_Bool static XP_Bool
and_util_altKeyDown( XW_UtilCtxt* uc ) and_util_altKeyDown( XW_UtilCtxt* uc, XWEnv xwe )
{ {
LOG_FUNC(); LOG_FUNC();
return XP_FALSE; return XP_FALSE;
} }
XP_U32 XP_U32
and_dutil_getCurSeconds( XW_DUtilCtxt* duc ) and_dutil_getCurSeconds( XW_DUtilCtxt* XP_UNUSED(duc), XWEnv xwe )
{ {
AndDUtil* anddutil = (AndDUtil*)duc; XP_U32 curSeconds = getCurSeconds( xwe );
XP_U32 curSeconds = getCurSeconds( ENVFORME( anddutil->ti ) );
/* struct timeval tv; */
/* gettimeofday( &tv, NULL ); */
/* XP_LOGF( "%s: %d vs %d", __func__, (int)tv.tv_sec, (int)curSeconds ); */
return curSeconds; return curSeconds;
} }
@ -397,7 +394,7 @@ and_util_makeEmptyDict( XW_UtilCtxt* uc, XWEnv xwe )
} }
static const XP_UCHAR* static const XP_UCHAR*
and_dutil_getUserString( XW_DUtilCtxt* duc, XP_U16 stringCode ) and_dutil_getUserString( XW_DUtilCtxt* duc, XWEnv xwe, XP_U16 stringCode )
{ {
XP_UCHAR* result = ""; XP_UCHAR* result = "";
DUTIL_CBK_HEADER("getUserString", "(I)Ljava/lang/String;" ); DUTIL_CBK_HEADER("getUserString", "(I)Ljava/lang/String;" );
@ -426,7 +423,8 @@ and_dutil_getUserString( XW_DUtilCtxt* duc, XP_U16 stringCode )
} }
static const XP_UCHAR* static const XP_UCHAR*
and_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XP_U16 stringCode, XP_U16 quantity ) and_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XWEnv xwe,
XP_U16 stringCode, XP_U16 quantity )
{ {
XP_UCHAR* result = ""; XP_UCHAR* result = "";
DUTIL_CBK_HEADER("getUserQuantityString", "(II)Ljava/lang/String;" ); DUTIL_CBK_HEADER("getUserQuantityString", "(II)Ljava/lang/String;" );
@ -473,7 +471,7 @@ and_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XP_U16 stringCode, XP_U16 qu
} }
static void static void
and_dutil_storePtr( XW_DUtilCtxt* duc, const XP_UCHAR* key, and_dutil_storePtr( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
const void* data, XP_U16 len ) const void* data, XP_U16 len )
{ {
DUTIL_CBK_HEADER( "store", "(Ljava/lang/String;[B)V" ); DUTIL_CBK_HEADER( "store", "(Ljava/lang/String;[B)V" );
@ -489,17 +487,17 @@ and_dutil_storePtr( XW_DUtilCtxt* duc, const XP_UCHAR* key,
} }
static void static void
and_dutil_storeStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, and_dutil_storeStream( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
XWStreamCtxt* stream ) XWStreamCtxt* stream )
{ {
const void* ptr = stream_getPtr( stream ); const void* ptr = stream_getPtr( stream );
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
and_dutil_storePtr( duc, key, ptr, len ); and_dutil_storePtr( duc, xwe, key, ptr, len );
} }
static jbyteArray static jbyteArray
loadToByteArray( XW_DUtilCtxt* duc, const XP_UCHAR* key ) loadToByteArray( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key )
{ {
jbyteArray result = NULL; jbyteArray result = NULL;
DUTIL_CBK_HEADER( "load", "(Ljava/lang/String;)[B"); DUTIL_CBK_HEADER( "load", "(Ljava/lang/String;)[B");
@ -512,12 +510,11 @@ loadToByteArray( XW_DUtilCtxt* duc, const XP_UCHAR* key )
} }
static void static void
and_dutil_loadPtr( XW_DUtilCtxt* duc, const XP_UCHAR* key, and_dutil_loadPtr( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
void* data, XP_U16* lenp ) void* data, XP_U16* lenp )
{ {
AndDUtil* dutil = (AndDUtil*)duc; JNIEnv* env = xwe;
JNIEnv* env = ENVFORME( dutil->ti ); jbyteArray jvalue = loadToByteArray( duc, env, key );
jbyteArray jvalue = loadToByteArray( duc, key );
if ( jvalue != NULL ) { if ( jvalue != NULL ) {
jsize len = (*env)->GetArrayLength( env, jvalue ); jsize len = (*env)->GetArrayLength( env, jvalue );
if ( len <= *lenp ) { if ( len <= *lenp ) {
@ -531,11 +528,11 @@ and_dutil_loadPtr( XW_DUtilCtxt* duc, const XP_UCHAR* key,
} }
static void static void
and_dutil_loadStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, XWStreamCtxt* stream ) and_dutil_loadStream( XW_DUtilCtxt* duc, XWEnv xwe,
const XP_UCHAR* key, XWStreamCtxt* stream )
{ {
AndDUtil* dutil = (AndDUtil*)duc; JNIEnv* env = xwe;
JNIEnv* env = ENVFORME( dutil->ti ); jbyteArray jvalue = loadToByteArray( duc, xwe, key );
jbyteArray jvalue = loadToByteArray( duc, key );
if ( jvalue != NULL ) { if ( jvalue != NULL ) {
jbyte* jelems = (*env)->GetByteArrayElements( env, jvalue, NULL ); jbyte* jelems = (*env)->GetByteArrayElements( env, jvalue, NULL );
jsize len = (*env)->GetArrayLength( env, jvalue ); jsize len = (*env)->GetArrayLength( env, jvalue );
@ -546,7 +543,7 @@ and_dutil_loadStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, XWStreamCtxt* stre
} }
static void static void
and_util_notifyIllegalWords( XW_UtilCtxt* uc, BadWordInfo* bwi, and_util_notifyIllegalWords( XW_UtilCtxt* uc, XWEnv xwe, BadWordInfo* bwi,
XP_U16 turn, XP_Bool turnLost ) XP_U16 turn, XP_Bool turnLost )
{ {
UTIL_CBK_HEADER("notifyIllegalWords", UTIL_CBK_HEADER("notifyIllegalWords",
@ -566,7 +563,7 @@ and_util_notifyIllegalWords( XW_UtilCtxt* uc, BadWordInfo* bwi,
#ifdef XWFEATURE_CHAT #ifdef XWFEATURE_CHAT
static void static void
and_util_showChat( XW_UtilCtxt* uc, const XP_UCHAR* msg, XP_S16 from, XP_U32 timestamp ) and_util_showChat( XW_UtilCtxt* uc, XWEnv xwe, const XP_UCHAR* msg, XP_S16 from, XP_U32 timestamp )
{ {
UTIL_CBK_HEADER( "showChat", "(Ljava/lang/String;ILjava/lang/String;I)V" ); UTIL_CBK_HEADER( "showChat", "(Ljava/lang/String;ILjava/lang/String;I)V" );
jstring jname = NULL; jstring jname = NULL;
@ -584,7 +581,7 @@ and_util_showChat( XW_UtilCtxt* uc, const XP_UCHAR* msg, XP_S16 from, XP_U32 tim
#endif #endif
static void static void
and_util_remSelected(XW_UtilCtxt* uc) and_util_remSelected( XW_UtilCtxt* uc, XWEnv xwe )
{ {
UTIL_CBK_HEADER("remSelected", "()V" ); UTIL_CBK_HEADER("remSelected", "()V" );
(*env)->CallVoidMethod( env, util->jutil, mid ); (*env)->CallVoidMethod( env, util->jutil, mid );
@ -592,7 +589,7 @@ and_util_remSelected(XW_UtilCtxt* uc)
} }
static void static void
and_util_timerSelected( XW_UtilCtxt* uc, XP_Bool inDuplicateMode, XP_Bool canPause ) and_util_timerSelected( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool inDuplicateMode, XP_Bool canPause )
{ {
UTIL_CBK_HEADER("timerSelected", "(ZZ)V" ); UTIL_CBK_HEADER("timerSelected", "(ZZ)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, inDuplicateMode, canPause ); (*env)->CallVoidMethod( env, util->jutil, mid, inDuplicateMode, canPause );
@ -600,7 +597,7 @@ and_util_timerSelected( XW_UtilCtxt* uc, XP_Bool inDuplicateMode, XP_Bool canPau
} }
static void static void
and_util_formatPauseHistory( XW_UtilCtxt* uc, XWStreamCtxt* stream, and_util_formatPauseHistory( XW_UtilCtxt* uc, XWEnv xwe, XWStreamCtxt* stream,
DupPauseType typ, XP_S16 turn, DupPauseType typ, XP_S16 turn,
XP_U32 secsPrev, XP_U32 secsCur, XP_U32 secsPrev, XP_U32 secsCur,
const XP_UCHAR* msg ) const XP_UCHAR* msg )
@ -621,7 +618,7 @@ and_util_formatPauseHistory( XW_UtilCtxt* uc, XWStreamCtxt* stream,
#ifndef XWFEATURE_MINIWIN #ifndef XWFEATURE_MINIWIN
static void static void
and_util_bonusSquareHeld( XW_UtilCtxt* uc, XWBonusType bonus ) and_util_bonusSquareHeld( XW_UtilCtxt* uc, XWEnv xwe, XWBonusType bonus )
{ {
UTIL_CBK_HEADER( "bonusSquareHeld", "(I)V" ); UTIL_CBK_HEADER( "bonusSquareHeld", "(I)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, bonus ); (*env)->CallVoidMethod( env, util->jutil, mid, bonus );
@ -629,7 +626,7 @@ and_util_bonusSquareHeld( XW_UtilCtxt* uc, XWBonusType bonus )
} }
static void static void
and_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player ) and_util_playerScoreHeld( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 player )
{ {
UTIL_CBK_HEADER( "playerScoreHeld", "(I)V" ); UTIL_CBK_HEADER( "playerScoreHeld", "(I)V" );
(*env)->CallVoidMethod( env, util->jutil, mid, player ); (*env)->CallVoidMethod( env, util->jutil, mid, player );
@ -639,7 +636,7 @@ and_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player )
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
static XP_Bool static XP_Bool
and_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, const XP_UCHAR* p1, and_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* p1,
const XP_UCHAR* p2 ) const XP_UCHAR* p2 )
{ {
XP_Bool same = 0 == strcmp( p1, p2 ); XP_Bool same = 0 == strcmp( p1, p2 );
@ -658,7 +655,7 @@ and_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, const XP_UCHAR* p1,
#ifdef XWFEATURE_BOARDWORDS #ifdef XWFEATURE_BOARDWORDS
static void static void
and_util_cellSquareHeld( XW_UtilCtxt* uc, XWStreamCtxt* words ) and_util_cellSquareHeld( XW_UtilCtxt* uc, XWEnv xwe, XWStreamCtxt* words )
{ {
if ( NULL != words ) { if ( NULL != words ) {
UTIL_CBK_HEADER( "cellSquareHeld", "(Ljava/lang/String;)V" ); UTIL_CBK_HEADER( "cellSquareHeld", "(Ljava/lang/String;)V" );
@ -673,7 +670,7 @@ and_util_cellSquareHeld( XW_UtilCtxt* uc, XWStreamCtxt* words )
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static void static void
and_util_informMissing( XW_UtilCtxt* uc, XP_Bool isServer, and_util_informMissing( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool isServer,
const CommsAddrRec* addr, XP_U16 nDevs, XP_U16 nMissing) const CommsAddrRec* addr, XP_U16 nDevs, XP_U16 nMissing)
{ {
UTIL_CBK_HEADER( "informMissing", UTIL_CBK_HEADER( "informMissing",
@ -689,14 +686,15 @@ and_util_informMissing( XW_UtilCtxt* uc, XP_Bool isServer,
} }
static void static void
and_util_addrChange( XW_UtilCtxt* uc, const CommsAddrRec* oldAddr, and_util_addrChange( XW_UtilCtxt* uc, XWEnv xwe,
const CommsAddrRec* oldAddr,
const CommsAddrRec* newAddr ) const CommsAddrRec* newAddr )
{ {
// LOG_FUNC(); // LOG_FUNC();
} }
static void static void
and_util_setIsServer( XW_UtilCtxt* uc, XP_Bool isServer ) and_util_setIsServer( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool isServer )
{ {
/* Change both the C and Java structs, which need to stay in sync */ /* Change both the C and Java structs, which need to stay in sync */
uc->gameInfo->serverRole = isServer? SERVER_ISSERVER : SERVER_ISCLIENT; uc->gameInfo->serverRole = isServer? SERVER_ISSERVER : SERVER_ISCLIENT;
@ -706,7 +704,7 @@ and_util_setIsServer( XW_UtilCtxt* uc, XP_Bool isServer )
} }
static void static void
and_util_informWordsBlocked( XW_UtilCtxt* uc, XP_U16 nBadWords, and_util_informWordsBlocked( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 nBadWords,
XWStreamCtxt* words, const XP_UCHAR* dict ) XWStreamCtxt* words, const XP_UCHAR* dict )
{ {
UTIL_CBK_HEADER( "informWordsBlocked", "(ILjava/lang/String;Ljava/lang/String;)V" ); UTIL_CBK_HEADER( "informWordsBlocked", "(ILjava/lang/String;Ljava/lang/String;)V" );
@ -719,7 +717,7 @@ and_util_informWordsBlocked( XW_UtilCtxt* uc, XP_U16 nBadWords,
#ifdef XWFEATURE_DEVID #ifdef XWFEATURE_DEVID
static const XP_UCHAR* static const XP_UCHAR*
and_dutil_getDevID( XW_DUtilCtxt* duc, DevIDType* typ ) and_dutil_getDevID( XW_DUtilCtxt* duc, XWEnv xwe, DevIDType* typ )
{ {
const XP_UCHAR* result = NULL; const XP_UCHAR* result = NULL;
*typ = ID_TYPE_NONE; *typ = ID_TYPE_NONE;
@ -752,7 +750,7 @@ and_dutil_getDevID( XW_DUtilCtxt* duc, DevIDType* typ )
} }
static void static void
and_dutil_deviceRegistered( XW_DUtilCtxt* duc, DevIDType typ, and_dutil_deviceRegistered( XW_DUtilCtxt* duc, XWEnv xwe, DevIDType typ,
const XP_UCHAR* idRelay ) const XP_UCHAR* idRelay )
{ {
DUTIL_CBK_HEADER( "deviceRegistered", DUTIL_CBK_HEADER( "deviceRegistered",
@ -797,7 +795,7 @@ and_util_engineStopping( XW_UtilCtxt* uc )
#endif #endif
static XW_DUtilCtxt* static XW_DUtilCtxt*
and_util_getDevUtilCtxt( XW_UtilCtxt* uc ) and_util_getDevUtilCtxt( XW_UtilCtxt* uc, XWEnv xwe )
{ {
AndGameGlobals* globals = (AndGameGlobals*)uc->closure; AndGameGlobals* globals = (AndGameGlobals*)uc->closure;
XP_ASSERT( !!globals->dutil ); XP_ASSERT( !!globals->dutil );
@ -806,10 +804,10 @@ and_util_getDevUtilCtxt( XW_UtilCtxt* uc )
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
static XP_UCHAR* static XP_UCHAR*
and_dutil_md5sum( XW_DUtilCtxt* duc, const XP_U8* ptr, XP_U16 len ) and_dutil_md5sum( XW_DUtilCtxt* duc, XWEnv xwe, const XP_U8* ptr, XP_U16 len )
{ {
AndDUtil* dutil = (AndDUtil*)duc; AndDUtil* dutil = (AndDUtil*)duc;
JNIEnv* env = ENVFORME( dutil->ti ); JNIEnv* env = xwe;
struct JNIUtilCtxt* jniutil = dutil->jniutil; struct JNIUtilCtxt* jniutil = dutil->jniutil;
jstring jsum = and_util_getMD5SumForBytes( jniutil, env, ptr, len ); jstring jsum = and_util_getMD5SumForBytes( jniutil, env, ptr, len );
XP_UCHAR* result = getStringCopy( MPPARM(duc->mpool) env, jsum ); XP_UCHAR* result = getStringCopy( MPPARM(duc->mpool) env, jsum );
@ -819,7 +817,7 @@ and_dutil_md5sum( XW_DUtilCtxt* duc, const XP_U8* ptr, XP_U16 len )
#endif #endif
static void static void
and_dutil_notifyPause( XW_DUtilCtxt* duc, XP_U32 gameID, DupPauseType pauseTyp, and_dutil_notifyPause( XW_DUtilCtxt* duc, XWEnv xwe, XP_U32 gameID, DupPauseType pauseTyp,
XP_U16 pauser, const XP_UCHAR* name, XP_U16 pauser, const XP_UCHAR* name,
const XP_UCHAR* msg ) const XP_UCHAR* msg )
{ {
@ -833,7 +831,7 @@ and_dutil_notifyPause( XW_DUtilCtxt* duc, XP_U32 gameID, DupPauseType pauseTyp,
} }
static void static void
and_dutil_onDupTimerChanged( XW_DUtilCtxt* duc, XP_U32 gameID, and_dutil_onDupTimerChanged( XW_DUtilCtxt* duc, XWEnv xwe, XP_U32 gameID,
XP_U32 oldVal, XP_U32 newVal ) XP_U32 oldVal, XP_U32 newVal )
{ {
DUTIL_CBK_HEADER( "onDupTimerChanged", "(III)V" ); DUTIL_CBK_HEADER( "onDupTimerChanged", "(III)V" );
@ -842,13 +840,11 @@ and_dutil_onDupTimerChanged( XW_DUtilCtxt* duc, XP_U32 gameID,
} }
XW_UtilCtxt* XW_UtilCtxt*
makeUtil( MPFORMAL EnvThreadInfo* ti, jobject jutil, CurGameInfo* gi, makeUtil( MPFORMAL JNIEnv* env, jobject jutil, CurGameInfo* gi,
AndGameGlobals* closure ) AndGameGlobals* closure )
{ {
AndUtil* util = (AndUtil*)XP_CALLOC( mpool, sizeof(*util) ); AndUtil* util = (AndUtil*)XP_CALLOC( mpool, sizeof(*util) );
UtilVtable* vtable = (UtilVtable*)XP_CALLOC( mpool, sizeof(*vtable) ); UtilVtable* vtable = (UtilVtable*)XP_CALLOC( mpool, sizeof(*vtable) );
util->ti = ti;
JNIEnv* env = ENVFORME( util->ti );
if ( NULL != jutil ) { if ( NULL != jutil ) {
util->jutil = (*env)->NewGlobalRef( env, jutil ); util->jutil = (*env)->NewGlobalRef( env, jutil );
} }
@ -927,10 +923,9 @@ makeUtil( MPFORMAL EnvThreadInfo* ti, jobject jutil, CurGameInfo* gi,
} /* makeUtil */ } /* makeUtil */
void void
destroyUtil( XW_UtilCtxt** utilc ) destroyUtil( XW_UtilCtxt** utilc, JNIEnv* env )
{ {
AndUtil* util = (AndUtil*)*utilc; AndUtil* util = (AndUtil*)*utilc;
JNIEnv* env = ENVFORME( util->ti );
if ( NULL != util->jutil ) { if ( NULL != util->jutil ) {
(*env)->DeleteGlobalRef( env, util->jutil ); (*env)->DeleteGlobalRef( env, util->jutil );
@ -941,17 +936,15 @@ destroyUtil( XW_UtilCtxt** utilc )
} }
XW_DUtilCtxt* XW_DUtilCtxt*
makeDUtil( MPFORMAL EnvThreadInfo* ti, jobject jdutil, VTableMgr* vtMgr, makeDUtil( MPFORMAL JNIEnv* env, jobject jdutil, VTableMgr* vtMgr,
JNIUtilCtxt* jniutil, void* closure ) JNIUtilCtxt* jniutil, void* closure )
{ {
AndDUtil* dutil = (AndDUtil*)XP_CALLOC( mpool, sizeof(*dutil) ); AndDUtil* dutil = (AndDUtil*)XP_CALLOC( mpool, sizeof(*dutil) );
dutil->ti = ti;
dutil->jniutil = jniutil; dutil->jniutil = jniutil;
dutil->dutil.closure = closure; dutil->dutil.closure = closure;
dutil->dutil.vtMgr = vtMgr; dutil->dutil.vtMgr = vtMgr;
if ( NULL != jdutil ) { if ( NULL != jdutil ) {
JNIEnv* env = ENVFORME( ti );
dutil->jdutil = (*env)->NewGlobalRef( env, jdutil ); dutil->jdutil = (*env)->NewGlobalRef( env, jdutil );
} }
@ -986,10 +979,9 @@ makeDUtil( MPFORMAL EnvThreadInfo* ti, jobject jdutil, VTableMgr* vtMgr,
} }
void void
destroyDUtil( XW_DUtilCtxt** dutilp ) destroyDUtil( XW_DUtilCtxt** dutilp, JNIEnv* env )
{ {
AndDUtil* dutil = (AndDUtil*)*dutilp; AndDUtil* dutil = (AndDUtil*)*dutilp;
JNIEnv* env = ENVFORME( dutil->ti );
if ( NULL != dutil->jdutil ) { if ( NULL != dutil->jdutil ) {
(*env)->DeleteGlobalRef( env, dutil->jdutil ); (*env)->DeleteGlobalRef( env, dutil->jdutil );
} }

View file

@ -29,14 +29,14 @@
#include "andglobals.h" #include "andglobals.h"
#include "jniutlswrapper.h" #include "jniutlswrapper.h"
XW_DUtilCtxt* makeDUtil( MPFORMAL EnvThreadInfo* ti, jobject j_dutil, XW_DUtilCtxt* makeDUtil( MPFORMAL JNIEnv* env, jobject j_dutil,
VTableMgr* vtMgr, JNIUtilCtxt* jniutil, VTableMgr* vtMgr, JNIUtilCtxt* jniutil,
void* closure ); void* closure );
void destroyDUtil( XW_DUtilCtxt** dutilp ); void destroyDUtil( XW_DUtilCtxt** dutilp, JNIEnv* env );
XW_UtilCtxt* makeUtil( MPFORMAL EnvThreadInfo* ti, jobject j_util, XW_UtilCtxt* makeUtil( MPFORMAL JNIEnv* env, jobject j_util,
CurGameInfo* gi, AndGameGlobals* globals ); CurGameInfo* gi, AndGameGlobals* globals );
void destroyUtil( XW_UtilCtxt** util ); void destroyUtil( XW_UtilCtxt** util, JNIEnv* env );
bool utilTimerFired( XW_UtilCtxt* util, XWEnv xwe, XWTimerReason why, int handle ); bool utilTimerFired( XW_UtilCtxt* util, XWEnv xwe, XWTimerReason why, int handle );

View file

@ -359,10 +359,10 @@ Java_org_eehouse_android_xw4_jni_XwJNI_initGlobals
map_init( MPPARM(mpool) &globalState->ti, env ); map_init( MPPARM(mpool) &globalState->ti, env );
globalState->jniutil = makeJNIUtil( MPPARM(mpool) env, &globalState->ti, jniu ); globalState->jniutil = makeJNIUtil( MPPARM(mpool) env, &globalState->ti, jniu );
globalState->vtMgr = make_vtablemgr( MPPARM_NOCOMMA(mpool) ); globalState->vtMgr = make_vtablemgr( MPPARM_NOCOMMA(mpool) );
globalState->dutil = makeDUtil( MPPARM(mpool) &globalState->ti, jdutil, globalState->dutil = makeDUtil( MPPARM(mpool) env, jdutil,
globalState->vtMgr, globalState->jniutil, NULL ); globalState->vtMgr, globalState->jniutil, NULL );
globalState->dictMgr = dmgr_make( MPPARM_NOCOMMA( mpool ) ); globalState->dictMgr = dmgr_make( MPPARM_NOCOMMA( mpool ) );
globalState->smsProto = smsproto_init( MPPARM( mpool ) globalState->dutil ); globalState->smsProto = smsproto_init( MPPARM( mpool ) env, globalState->dutil );
MPASSIGN( globalState->mpool, mpool ); MPASSIGN( globalState->mpool, mpool );
setGlobalState( globalState ); setGlobalState( globalState );
// LOG_RETURNF( "%p", globalState ); // LOG_RETURNF( "%p", globalState );
@ -384,7 +384,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_cleanGlobals
smsproto_free( globalState->smsProto ); smsproto_free( globalState->smsProto );
vtmgr_destroy( MPPARM(mpool) globalState->vtMgr ); vtmgr_destroy( MPPARM(mpool) globalState->vtMgr );
dmgr_destroy( globalState->dictMgr, env ); dmgr_destroy( globalState->dictMgr, env );
destroyDUtil( &globalState->dutil ); destroyDUtil( &globalState->dutil, env );
destroyJNIUtil( env, &globalState->jniutil ); destroyJNIUtil( env, &globalState->jniutil );
map_destroy( &globalState->ti ); map_destroy( &globalState->ti );
XP_FREE( mpool, globalState ); XP_FREE( mpool, globalState );
@ -899,7 +899,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_smsproto_1prepOutbound
const char* toPhone = (*env)->GetStringUTFChars( env, jToPhone, NULL ); const char* toPhone = (*env)->GetStringUTFChars( env, jToPhone, NULL );
XP_U16 waitSecs; XP_U16 waitSecs;
SMSMsgArray* arr = smsproto_prepOutbound( globalState->smsProto, cmd, SMSMsgArray* arr = smsproto_prepOutbound( globalState->smsProto, env, cmd,
jGameID, (const XP_U8*)data, len, jGameID, (const XP_U8*)data, len,
toPhone, jPort, XP_FALSE, toPhone, jPort, XP_FALSE,
&waitSecs ); &waitSecs );
@ -933,7 +933,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_smsproto_1prepInbound
jbyte* data = (*env)->GetByteArrayElements( env, jData, NULL ); jbyte* data = (*env)->GetByteArrayElements( env, jData, NULL );
const char* fromPhone = (*env)->GetStringUTFChars( env, jFromPhone, NULL ); const char* fromPhone = (*env)->GetStringUTFChars( env, jFromPhone, NULL );
SMSMsgArray* arr = smsproto_prepInbound( globalState->smsProto, fromPhone, SMSMsgArray* arr = smsproto_prepInbound( globalState->smsProto, env, fromPhone,
jWantPort, (XP_U8*)data, len ); jWantPort, (XP_U8*)data, len );
if ( !!arr ) { if ( !!arr ) {
result = msgArrayToJMsgArray( env, arr ); result = msgArrayToJMsgArray( env, arr );
@ -1013,10 +1013,9 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1makeNewGame
jobject j_procs ) jobject j_procs )
{ {
XWJNI_START_GLOBALS(); XWJNI_START_GLOBALS();
EnvThreadInfo* ti = &state->globalJNI->ti;
CurGameInfo* gi = makeGI( MPPARM(mpool) env, j_gi ); CurGameInfo* gi = makeGI( MPPARM(mpool) env, j_gi );
globals->gi = gi; globals->gi = gi;
globals->util = makeUtil( MPPARM(mpool) ti, j_util, gi, globals->util = makeUtil( MPPARM(mpool) env, j_util, gi,
globals ); globals );
globals->jniutil = state->globalJNI->jniutil; globals->jniutil = state->globalJNI->jniutil;
DrawCtx* dctx = NULL; DrawCtx* dctx = NULL;
@ -1066,7 +1065,7 @@ JNIEXPORT void JNICALL Java_org_eehouse_android_xw4_jni_XwJNI_game_1dispose
destroyDraw( &globals->dctx, env ); destroyDraw( &globals->dctx, env );
destroyXportProcs( &globals->xportProcs, env ); destroyXportProcs( &globals->xportProcs, env );
destroyUtil( &globals->util ); destroyUtil( &globals->util, env );
vtmgr_destroy( MPPARM(mpool) globals->vtMgr ); vtmgr_destroy( MPPARM(mpool) globals->vtMgr );
MAP_REMOVE( &state->globalJNI->ti, env ); MAP_REMOVE( &state->globalJNI->ti, env );
@ -1084,10 +1083,9 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1makeFromStream
DictionaryCtxt* dict; DictionaryCtxt* dict;
PlayerDicts dicts; PlayerDicts dicts;
XWJNI_START_GLOBALS(); XWJNI_START_GLOBALS();
EnvThreadInfo* ti = &state->globalJNI->ti;
globals->gi = (CurGameInfo*)XP_CALLOC( mpool, sizeof(*globals->gi) ); globals->gi = (CurGameInfo*)XP_CALLOC( mpool, sizeof(*globals->gi) );
globals->util = makeUtil( MPPARM(mpool) ti, jutil, globals->gi, globals); globals->util = makeUtil( MPPARM(mpool) env, jutil, globals->gi, globals);
globals->jniutil = state->globalJNI->jniutil; globals->jniutil = state->globalJNI->jniutil;
makeDicts( MPPARM(state->globalJNI->mpool) env, state->globalJNI->dictMgr, makeDicts( MPPARM(state->globalJNI->mpool) env, state->globalJNI->dictMgr,
globals->jniutil, &dict, &dicts, jdictNames, jdicts, jpaths, globals->jniutil, &dict, &dicts, jdictNames, jdicts, jpaths,
@ -1221,7 +1219,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1figureLayout
CurGameInfo* gi = makeGI( MPPARM(mpool) env, jgi ); CurGameInfo* gi = makeGI( MPPARM(mpool) env, jgi );
BoardDims dims; BoardDims dims;
board_figureLayout( state->game.board, gi, left, top, width, height, board_figureLayout( state->game.board, env, gi, left, top, width, height,
115, scorePct, trayPct, scoreWidth, 115, scorePct, trayPct, scoreWidth,
fontWidth, fontHt, squareTiles, fontWidth, fontHt, squareTiles,
((!!jdims) ? &dims : NULL) ); ((!!jdims) ? &dims : NULL) );
@ -1241,7 +1239,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1applyLayout
XWJNI_START(); XWJNI_START();
BoardDims dims; BoardDims dims;
dimsJToC( env, &dims, jdims ); dimsJToC( env, &dims, jdims );
board_applyLayout( state->game.board, &dims ); board_applyLayout( state->game.board, env, &dims );
XWJNI_END(); XWJNI_END();
} }
@ -1288,7 +1286,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1zoom
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
XP_Bool canInOut[2]; XP_Bool canInOut[2];
result = board_zoom( state->game.board, zoomBy, canInOut ); result = board_zoom( state->game.board, env, zoomBy, canInOut );
jboolean canZoom[2] = { canInOut[0], canInOut[1] }; jboolean canZoom[2] = { canInOut[0], canInOut[1] };
setBoolArray( env, jCanZoom, VSIZE(canZoom), canZoom ); setBoolArray( env, jCanZoom, VSIZE(canZoom), canZoom );
XWJNI_END(); XWJNI_END();
@ -1328,7 +1326,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1handlePenDown
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
XP_Bool bb; /* drop this for now */ XP_Bool bb; /* drop this for now */
result = board_handlePenDown( state->game.board, xx, yy, &bb ); result = board_handlePenDown( state->game.board, env, xx, yy, &bb );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1339,7 +1337,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1handlePenMove
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_handlePenMove( state->game.board, xx, yy ); result = board_handlePenMove( state->game.board, env, xx, yy );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1373,7 +1371,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1juggleTray
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_juggleTray( state->game.board ); result = board_juggleTray( state->game.board, env );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1407,7 +1405,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1passwordProvided
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
const char* passwd = (*env)->GetStringUTFChars( env, jpasswd, NULL ); const char* passwd = (*env)->GetStringUTFChars( env, jpasswd, NULL );
result = board_passwordProvided( state->game.board, player, passwd ); result = board_passwordProvided( state->game.board, env, player, passwd );
(*env)->ReleaseStringUTFChars( env, jpasswd, passwd ); (*env)->ReleaseStringUTFChars( env, jpasswd, passwd );
XWJNI_END(); XWJNI_END();
return result; return result;
@ -1419,7 +1417,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1hideTray
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_hideTray( state->game.board ); result = board_hideTray( state->game.board, env);
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1430,7 +1428,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1showTray
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_showTray( state->game.board ); result = board_showTray( state->game.board, env );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1441,7 +1439,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1beginTrade
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_beginTrade( state->game.board ); result = board_beginTrade( state->game.board, env );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1518,7 +1516,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1replaceTiles
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_replaceTiles( state->game.board ); result = board_replaceTiles( state->game.board, env );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1529,7 +1527,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1redoReplacedTiles
{ {
jboolean result; jboolean result;
XWJNI_START(); XWJNI_START();
result = board_redoReplacedTiles( state->game.board ); result = board_redoReplacedTiles( state->game.board, env );
XWJNI_END(); XWJNI_END();
return result; return result;
} }
@ -1571,7 +1569,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_server_1tilesPicked
XWJNI_START(); XWJNI_START();
TrayTileSet newTiles; TrayTileSet newTiles;
tilesArrayToTileSet( env, jNewTiles, &newTiles ); tilesArrayToTileSet( env, jNewTiles, &newTiles );
server_tilesPicked( state->game.server, player, &newTiles ); server_tilesPicked( state->game.server, env, player, &newTiles );
XWJNI_END(); XWJNI_END();
} }
@ -1637,7 +1635,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1formatRemainingTiles
XWJNI_START_GLOBALS(); XWJNI_START_GLOBALS();
XWStreamCtxt* stream = mem_stream_make( MPPARM(mpool) globals->vtMgr, XWStreamCtxt* stream = mem_stream_make( MPPARM(mpool) globals->vtMgr,
NULL, 0, NULL ); NULL, 0, NULL );
board_formatRemainingTiles( state->game.board, stream ); board_formatRemainingTiles( state->game.board, env, stream );
result = streamToJString( env, stream ); result = streamToJString( env, stream );
stream_destroy( stream, env ); stream_destroy( stream, env );
@ -1652,7 +1650,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_server_1formatDictCounts
jstring result; jstring result;
XWJNI_START_GLOBALS(); XWJNI_START_GLOBALS();
XWStreamCtxt* stream = and_empty_stream( MPPARM(mpool) globals ); XWStreamCtxt* stream = and_empty_stream( MPPARM(mpool) globals );
server_formatDictCounts( state->game.server, stream, nCols, XP_FALSE ); server_formatDictCounts( state->game.server, env, stream, nCols, XP_FALSE );
result = streamToJString( env, stream ); result = streamToJString( env, stream );
stream_destroy( stream, env ); stream_destroy( stream, env );
XWJNI_END(); XWJNI_END();
@ -1738,7 +1736,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_server_1writeFinalScores
jstring result; jstring result;
XWJNI_START_GLOBALS(); XWJNI_START_GLOBALS();
XWStreamCtxt* stream = and_empty_stream( MPPARM(mpool) globals ); XWStreamCtxt* stream = and_empty_stream( MPPARM(mpool) globals );
server_writeFinalScores( state->game.server, stream ); server_writeFinalScores( state->game.server, env, stream );
result = streamToJString( env, stream ); result = streamToJString( env, stream );
stream_destroy( stream, env ); stream_destroy( stream, env );
XWJNI_END(); XWJNI_END();
@ -2078,7 +2076,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1getState
{ {
XWJNI_START(); XWJNI_START();
GameStateInfo info; GameStateInfo info;
game_getState( &state->game, &info ); game_getState( &state->game, env, &info );
setInts( env, jgsi, (void*)&info, AANDS(gsi_ints) ); setInts( env, jgsi, (void*)&info, AANDS(gsi_ints) );
setBools( env, jgsi, (void*)&info, AANDS(gsi_bools) ); setBools( env, jgsi, (void*)&info, AANDS(gsi_bools) );

File diff suppressed because it is too large Load diff

View file

@ -59,21 +59,21 @@ typedef enum {
/* typedef struct BoardCtxt BoardCtxt; */ /* typedef struct BoardCtxt BoardCtxt; */
BoardCtxt* board_make( MPFORMAL ModelCtxt* model, ServerCtxt* server, BoardCtxt* board_make( MPFORMAL XWEnv xwe, ModelCtxt* model, ServerCtxt* server,
DrawCtx* draw, XW_UtilCtxt* util ); DrawCtx* draw, XW_UtilCtxt* util );
BoardCtxt* board_makeFromStream( MPFORMAL XWStreamCtxt* stream, BoardCtxt* board_makeFromStream( MPFORMAL XWEnv xwe, XWStreamCtxt* stream,
ModelCtxt* model, ServerCtxt* server, ModelCtxt* model, ServerCtxt* server,
DrawCtx* draw, XW_UtilCtxt* util, DrawCtx* draw, XW_UtilCtxt* util,
XP_U16 nPlayers ); XP_U16 nPlayers );
void board_setCallbacks( BoardCtxt* board ); void board_setCallbacks( BoardCtxt* board, XWEnv xwe );
void board_setDraw( BoardCtxt* board, XWEnv xwe, DrawCtx* draw ); void board_setDraw( BoardCtxt* board, XWEnv xwe, DrawCtx* draw );
DrawCtx* board_getDraw( const BoardCtxt* board ); DrawCtx* board_getDraw( const BoardCtxt* board );
void board_destroy( BoardCtxt* board, XP_Bool ownsUtil ); void board_destroy( BoardCtxt* board, XWEnv xwe, XP_Bool ownsUtil );
void board_writeToStream( const BoardCtxt* board, XWStreamCtxt* stream ); void board_writeToStream( const BoardCtxt* board, XWStreamCtxt* stream );
void board_reset( BoardCtxt* board ); void board_reset( BoardCtxt* board, XWEnv xwe );
void board_drawSnapshot( const BoardCtxt* board, XWEnv xwe, DrawCtx* dctx, void board_drawSnapshot( const BoardCtxt* board, XWEnv xwe, DrawCtx* dctx,
XP_U16 width, XP_U16 height ); XP_U16 width, XP_U16 height );
@ -100,28 +100,29 @@ typedef struct _BoardDims {
XP_U16 timerWidth; XP_U16 timerWidth;
} BoardDims; } BoardDims;
void board_figureLayout( BoardCtxt* board, const CurGameInfo* gi, XP_U16 bLeft, void board_figureLayout( BoardCtxt* board, XWEnv xwe, const CurGameInfo* gi,
XP_U16 bTop, XP_U16 bWidth, XP_U16 bHeight, XP_U16 bLeft, XP_U16 bTop, XP_U16 bWidth, XP_U16 bHeight,
XP_U16 colPctMax, XP_U16 scorePct, XP_U16 trayPct, XP_U16 colPctMax, XP_U16 scorePct, XP_U16 trayPct,
XP_U16 scoreWidth, XP_U16 fontWidth, XP_U16 fontHt, XP_U16 scoreWidth, XP_U16 fontWidth, XP_U16 fontHt,
XP_Bool squareTiles, /* out */ BoardDims* dimsp ); XP_Bool squareTiles, /* out */ BoardDims* dimsp );
void board_applyLayout( BoardCtxt* board, const BoardDims* dims ); void board_applyLayout( BoardCtxt* board, XWEnv xwe, const BoardDims* dims );
#endif #endif
/* These four aren't needed if COMMON_LAYOUT defined */ /* These four aren't needed if COMMON_LAYOUT defined */
void board_setPos( BoardCtxt* board, XP_U16 left, XP_U16 top, void board_setPos( BoardCtxt* board, XWEnv xwe, XP_U16 left, XP_U16 top,
XP_U16 width, XP_U16 height, XP_U16 maxCellSize, XP_U16 width, XP_U16 height, XP_U16 maxCellSize,
XP_Bool leftHanded ); XP_Bool leftHanded );
void board_setScoreboardLoc( BoardCtxt* board, void board_setScoreboardLoc( BoardCtxt* board,
XP_U16 scoreLeft, XP_U16 scoreTop, XP_U16 scoreLeft, XP_U16 scoreTop,
XP_U16 scoreWidth, XP_U16 scoreHeight, XP_U16 scoreWidth, XP_U16 scoreHeight,
XP_Bool divideHorizontally ); XP_Bool divideHorizontally );
void board_setTrayLoc( BoardCtxt* board, XP_U16 trayLeft, XP_U16 trayTop, void board_setTrayLoc( BoardCtxt* board, XWEnv xwe,
XP_U16 trayLeft, XP_U16 trayTop,
XP_U16 trayWidth, XP_U16 trayHeight ); XP_U16 trayWidth, XP_U16 trayHeight );
/* Vertical scroll support; offset is in rows, not pixels */ /* Vertical scroll support; offset is in rows, not pixels */
XP_Bool board_setYOffset( BoardCtxt* board, XP_U16 newOffset ); XP_Bool board_setYOffset( BoardCtxt* board, XWEnv xwe, XP_U16 newOffset );
XP_U16 board_getYOffset( const BoardCtxt* board ); XP_U16 board_getYOffset( const BoardCtxt* board );
XP_Bool board_curTurnSelected( const BoardCtxt* board ); XP_Bool board_curTurnSelected( const BoardCtxt* board );
@ -130,13 +131,13 @@ void board_pause( BoardCtxt* board, XWEnv xwe, const XP_UCHAR* msg );
void board_unpause( BoardCtxt* board, XWEnv xwe, const XP_UCHAR* msg ); void board_unpause( BoardCtxt* board, XWEnv xwe, const XP_UCHAR* msg );
XP_Bool board_canShuffle( const BoardCtxt* board ); XP_Bool board_canShuffle( const BoardCtxt* board );
XP_Bool board_canHideRack( const BoardCtxt* board ); XP_Bool board_canHideRack( const BoardCtxt* board );
XP_Bool board_canTrade( BoardCtxt* board ); XP_Bool board_canTrade( BoardCtxt* board, XWEnv xwe );
XP_Bool board_canTogglePending( const BoardCtxt* board ); XP_Bool board_canTogglePending( const BoardCtxt* board );
XP_Bool board_canHint( const BoardCtxt* board ); XP_Bool board_canHint( const BoardCtxt* board );
void board_sendChat( const BoardCtxt* board, XWEnv xwe, const XP_UCHAR* msg ); void board_sendChat( const BoardCtxt* board, XWEnv xwe, const XP_UCHAR* msg );
/* zoomBy: >0: zoom in; < 0: zoom out; 0: query only */ /* zoomBy: >0: zoom in; < 0: zoom out; 0: query only */
XP_Bool board_zoom( BoardCtxt* board, XP_S16 zoomBy, XP_Bool* canInOut ); XP_Bool board_zoom( BoardCtxt* board, XWEnv xwe, XP_S16 zoomBy, XP_Bool* canInOut );
void board_invalAll( BoardCtxt* board ); void board_invalAll( BoardCtxt* board );
void board_invalRect( BoardCtxt* board, XP_Rect* rect ); void board_invalRect( BoardCtxt* board, XP_Rect* rect );
@ -152,13 +153,13 @@ XP_Bool board_flip( BoardCtxt* board );
XP_Bool board_inTrade( const BoardCtxt* board, XP_Bool* anySelected ); XP_Bool board_inTrade( const BoardCtxt* board, XP_Bool* anySelected );
XP_Bool board_get_showValues( const BoardCtxt* board ); XP_Bool board_get_showValues( const BoardCtxt* board );
XP_Bool board_toggle_showValues( BoardCtxt* board ); XP_Bool board_toggle_showValues( BoardCtxt* board );
XP_Bool board_replaceTiles( BoardCtxt* board ); XP_Bool board_replaceTiles( BoardCtxt* board, XWEnv xwe );
XP_Bool board_redoReplacedTiles( BoardCtxt* board ); XP_Bool board_redoReplacedTiles( BoardCtxt* board, XWEnv xwe );
XP_U16 board_getSelPlayer(const BoardCtxt* board ); XP_U16 board_getSelPlayer(const BoardCtxt* board );
XP_Bool board_passwordProvided( BoardCtxt* board, XP_U16 player, const XP_Bool board_passwordProvided( BoardCtxt* board, XWEnv xwe,
XP_UCHAR* pass ); XP_U16 player, const XP_UCHAR* pass );
XP_Bool board_requestHint( BoardCtxt* board, XWEnv xwe, XP_Bool board_requestHint( BoardCtxt* board, XWEnv xwe,
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
@ -179,15 +180,16 @@ void board_resetEngine( BoardCtxt* board );
XP_Bool board_commitTurn( BoardCtxt* board, XWEnv xwe, XP_Bool phoniesConfirmed, XP_Bool board_commitTurn( BoardCtxt* board, XWEnv xwe, XP_Bool phoniesConfirmed,
XP_Bool turnConfirmed, TrayTileSet* newTiles ); XP_Bool turnConfirmed, TrayTileSet* newTiles );
void board_pushTimerSave( BoardCtxt* board ); void board_pushTimerSave( BoardCtxt* board, XWEnv xwe );
void board_popTimerSave( BoardCtxt* board ); void board_popTimerSave( BoardCtxt* board, XWEnv xwe );
void board_formatRemainingTiles( BoardCtxt* board, XWStreamCtxt* stream ); void board_formatRemainingTiles( BoardCtxt* board, XWEnv xwe,
XWStreamCtxt* stream );
#ifdef POINTER_SUPPORT #ifdef POINTER_SUPPORT
XP_Bool board_handlePenDown( BoardCtxt* board, XP_U16 x, XP_U16 y, XP_Bool board_handlePenDown( BoardCtxt* board, XWEnv xwe, XP_U16 xx,
XP_Bool* handled ); XP_U16 yy, XP_Bool* handled );
XP_Bool board_handlePenMove( BoardCtxt* board, XP_U16 x, XP_U16 y ); XP_Bool board_handlePenMove( BoardCtxt* board, XWEnv xwe, XP_U16 x, XP_U16 y );
XP_Bool board_handlePenUp( BoardCtxt* board, XWEnv xwe, XP_U16 x, XP_U16 y ); XP_Bool board_handlePenUp( BoardCtxt* board, XWEnv xwe, XP_U16 x, XP_U16 y );
XP_Bool board_containsPt( const BoardCtxt* board, XP_U16 xx, XP_U16 yy ); XP_Bool board_containsPt( const BoardCtxt* board, XP_U16 xx, XP_U16 yy );
#endif #endif
@ -196,10 +198,10 @@ XP_Bool board_containsPt( const BoardCtxt* board, XP_U16 xx, XP_U16 yy );
XP_Bool board_handleKey( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled ); XP_Bool board_handleKey( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled );
XP_Bool board_handleKeyUp( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled ); XP_Bool board_handleKeyUp( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled );
XP_Bool board_handleKeyDown( BoardCtxt* board, XP_Key key, XP_Bool* handled ); XP_Bool board_handleKeyDown( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled );
XP_Bool board_handleKeyRepeat( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled ); XP_Bool board_handleKeyRepeat( BoardCtxt* board, XWEnv xwe, XP_Key key, XP_Bool* handled );
# ifdef KEYBOARD_NAV # ifdef KEYBOARD_NAV
XP_Bool board_focusChanged( BoardCtxt* board, BoardObjectType typ, XP_Bool board_focusChanged( BoardCtxt* board, XWEnv xwe, BoardObjectType typ,
XP_Bool gained ); XP_Bool gained );
# endif # endif
#endif #endif
@ -207,13 +209,13 @@ XP_Bool board_focusChanged( BoardCtxt* board, BoardObjectType typ,
/******************** Tray methods ********************/ /******************** Tray methods ********************/
#define NO_TILES ((TileBit)0) #define NO_TILES ((TileBit)0)
XP_Bool board_hideTray( BoardCtxt* board ); XP_Bool board_hideTray( BoardCtxt* board, XWEnv xwe );
XP_Bool board_showTray( BoardCtxt* board ); XP_Bool board_showTray( BoardCtxt* board, XWEnv xwe );
XW_TrayVisState board_getTrayVisState( const BoardCtxt* board ); XW_TrayVisState board_getTrayVisState( const BoardCtxt* board );
void board_invalTrayTiles( BoardCtxt* board, TileBit what ); void board_invalTrayTiles( BoardCtxt* board, TileBit what );
XP_Bool board_juggleTray( BoardCtxt* board ); XP_Bool board_juggleTray( BoardCtxt* board, XWEnv xwe );
XP_Bool board_beginTrade( BoardCtxt* board ); XP_Bool board_beginTrade( BoardCtxt* board, XWEnv xwe );
XP_Bool board_endTrade( BoardCtxt* board ); XP_Bool board_endTrade( BoardCtxt* board );
#if defined FOR_GREMLINS #if defined FOR_GREMLINS

View file

@ -339,7 +339,7 @@ drawBoard( BoardCtxt* board, XWEnv xwe )
XWBonusType bonus; XWBonusType bonus;
HintAtts hintAtts; HintAtts hintAtts;
CellFlags flags = CELL_NONE; CellFlags flags = CELL_NONE;
bonus = model_getSquareBonus( model, col, row ); bonus = model_getSquareBonus( model, xwe, col, row );
hintAtts = figureHintAtts( board, col, row ); hintAtts = figureHintAtts( board, col, row );
#ifdef KEYBOARD_NAV #ifdef KEYBOARD_NAV
if ( cellFocused( board, col, row ) ) { if ( cellFocused( board, col, row ) ) {
@ -368,7 +368,8 @@ drawBoard( BoardCtxt* board, XWEnv xwe )
} /* drawBoard */ } /* drawBoard */
static XP_Bool static XP_Bool
drawCell( BoardCtxt* board, XWEnv xwe, const XP_U16 col, const XP_U16 row, XP_Bool skipBlanks ) drawCell( BoardCtxt* board, XWEnv xwe, const XP_U16 col,
const XP_U16 row, XP_Bool skipBlanks )
{ {
XP_Bool success = XP_TRUE; XP_Bool success = XP_TRUE;
XP_Rect cellRect = {0}; XP_Rect cellRect = {0};
@ -443,7 +444,7 @@ drawCell( BoardCtxt* board, XWEnv xwe, const XP_U16 col, const XP_U16 row, XP_Bo
textP = dict_getTileString( dict, tile ); textP = dict_getTileString( dict, tile );
} }
} }
bonus = model_getSquareBonus( model, col, row ); bonus = model_getSquareBonus( model, xwe, col, row );
hintAtts = figureHintAtts( board, col, row ); hintAtts = figureHintAtts( board, col, row );
if ( (col==board->star_row) && (row==board->star_row) ) { if ( (col==board->star_row) && (row==board->star_row) ) {

View file

@ -245,15 +245,15 @@ struct BoardCtxt {
/* tray-related functions */ /* tray-related functions */
XP_Bool handlePenUpTray( BoardCtxt* board, XWEnv xwe, XP_U16 x, XP_U16 y ); XP_Bool handlePenUpTray( BoardCtxt* board, XWEnv xwe, XP_U16 x, XP_U16 y );
void drawTray( BoardCtxt* board, XWEnv xwe ); void drawTray( BoardCtxt* board, XWEnv xwe );
XP_Bool moveTileToArrowLoc( BoardCtxt* board, XP_U8 index ); XP_Bool moveTileToArrowLoc( BoardCtxt* board, XWEnv xwe, XP_U8 index );
XP_U16 indexForBits( XP_U8 bits ); XP_U16 indexForBits( XP_U8 bits );
XP_Bool rectContainsPt( const XP_Rect* rect1, XP_S16 x, XP_S16 y ); XP_Bool rectContainsPt( const XP_Rect* rect1, XP_S16 x, XP_S16 y );
XP_Bool checkRevealTray( BoardCtxt* board ); XP_Bool checkRevealTray( BoardCtxt* board, XWEnv xwe );
void figureTrayTileRect( BoardCtxt* board, XP_U16 index, XP_Rect* rect ); void figureTrayTileRect( BoardCtxt* board, XP_U16 index, XP_Rect* rect );
XP_Bool rectsIntersect( const XP_Rect* rect1, const XP_Rect* rect2 ); XP_Bool rectsIntersect( const XP_Rect* rect1, const XP_Rect* rect2 );
XP_S16 pointToTileIndex( BoardCtxt* board, XP_U16 x, XP_U16 y, XP_S16 pointToTileIndex( BoardCtxt* board, XP_U16 x, XP_U16 y,
XP_Bool* onDividerP ); XP_Bool* onDividerP );
void board_selectPlayer( BoardCtxt* board, XP_U16 newPlayer, XP_Bool canPeek ); void board_selectPlayer( BoardCtxt* board, XWEnv xwe, XP_U16 newPlayer, XP_Bool canPeek );
void flipIf( const BoardCtxt* board, XP_U16 col, XP_U16 row, void flipIf( const BoardCtxt* board, XP_U16 col, XP_U16 row,
XP_U16* fCol, XP_U16* fRow ); XP_U16* fCol, XP_U16* fRow );
XP_Bool pointOnSomething( const BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool pointOnSomething( const BoardCtxt* board, XP_U16 xx, XP_U16 yy,
@ -264,9 +264,9 @@ XP_Bool cellOccupied( const BoardCtxt* board, XP_U16 col, XP_U16 row,
XP_Bool inclPending ); XP_Bool inclPending );
XP_Bool holdsPendingTile( BoardCtxt* board, XP_U16 pencol, XP_U16 penrow ); XP_Bool holdsPendingTile( BoardCtxt* board, XP_U16 pencol, XP_U16 penrow );
XP_Bool moveTileToBoard( BoardCtxt* board, XP_U16 col, XP_U16 row, XP_Bool moveTileToBoard( BoardCtxt* board, XWEnv xwe, XP_U16 col, XP_U16 row,
XP_U16 tileIndex, Tile blankFace ); XP_U16 tileIndex, Tile blankFace );
XP_Bool board_replaceNTiles( BoardCtxt* board, XP_U16 nTiles ); XP_Bool board_replaceNTiles( BoardCtxt* board, XWEnv xwe, XP_U16 nTiles );
void invalTilesUnderRect( BoardCtxt* board, const XP_Rect* rect ); void invalTilesUnderRect( BoardCtxt* board, const XP_Rect* rect );
void invalCellRegion( BoardCtxt* board, XP_U16 colA, XP_U16 rowA, XP_U16 colB, void invalCellRegion( BoardCtxt* board, XP_U16 colA, XP_U16 rowA, XP_U16 colB,
@ -312,11 +312,10 @@ const XP_UCHAR* getTileDrawInfo( const BoardCtxt* board, Tile tile,
XP_S16* value ); XP_S16* value );
XP_Bool dividerMoved( BoardCtxt* board, XP_U8 newLoc ); XP_Bool dividerMoved( BoardCtxt* board, XP_U8 newLoc );
XP_Bool scrollIntoView( BoardCtxt* board, XP_U16 col, XP_U16 row ); XP_Bool scrollIntoView( BoardCtxt* board, XWEnv xwe, XP_U16 col, XP_U16 row );
XP_Bool onBorderCanScroll( const BoardCtxt* board, SDIndex indx, XP_U16 row, XP_Bool onBorderCanScroll( const BoardCtxt* board, SDIndex indx, XP_U16 row, XP_S16* change );
XP_S16* change );
XP_Bool adjustXOffset( BoardCtxt* board, XP_S16 moveBy ); XP_Bool adjustXOffset( BoardCtxt* board, XP_S16 moveBy );
XP_Bool adjustYOffset( BoardCtxt* board, XP_S16 moveBy ); XP_Bool adjustYOffset( BoardCtxt* board, XWEnv xwe, XP_S16 moveBy );
XP_Bool rectContainsRect( const XP_Rect* rect1, const XP_Rect* rect2 ); XP_Bool rectContainsRect( const XP_Rect* rect1, const XP_Rect* rect2 );

View file

@ -193,10 +193,11 @@ static AddressRecord* rememberChannelAddress( CommsCtxt* comms, XWEnv xwe,
static void augmentChannelAddr( AddressRecord* rec, const CommsAddrRec* addr, static void augmentChannelAddr( AddressRecord* rec, const CommsAddrRec* addr,
XWHostID hostID ); XWHostID hostID );
static void augmentAddr( CommsAddrRec* dest, const CommsAddrRec* src ); static void augmentAddr( CommsAddrRec* dest, const CommsAddrRec* src );
static XP_Bool channelToAddress( CommsCtxt* comms, XP_PlayerAddr channelNo, static XP_Bool channelToAddress( CommsCtxt* comms, XWEnv xwe, XP_PlayerAddr channelNo,
const CommsAddrRec** addr ); const CommsAddrRec** addr );
static AddressRecord* getRecordFor( CommsCtxt* comms, const CommsAddrRec* addr, static AddressRecord* getRecordFor( CommsCtxt* comms, XWEnv xwe,
XP_PlayerAddr channelNo, XP_Bool maskChnl ); const CommsAddrRec* addr, XP_PlayerAddr channelNo,
XP_Bool maskChnl );
static XP_S16 sendMsg( CommsCtxt* comms, XWEnv xwe, MsgQueueElem* elem, static XP_S16 sendMsg( CommsCtxt* comms, XWEnv xwe, MsgQueueElem* elem,
CommsConnType filter ); CommsConnType filter );
static MsgQueueElem* addToQueue( CommsCtxt* comms, XWEnv xwe, MsgQueueElem* newMsgElem ); static MsgQueueElem* addToQueue( CommsCtxt* comms, XWEnv xwe, MsgQueueElem* newMsgElem );
@ -218,11 +219,11 @@ static XP_Bool send_via_relay( CommsCtxt* comms, XWEnv xwe, XWRELAY_Cmd cmd,
static XP_Bool sendNoConn( CommsCtxt* comms, XWEnv xwe, static XP_Bool sendNoConn( CommsCtxt* comms, XWEnv xwe,
const MsgQueueElem* elem, XWHostID destID ); const MsgQueueElem* elem, XWHostID destID );
static XWHostID getDestID( CommsCtxt* comms, XWEnv xwe, XP_PlayerAddr channelNo ); static XWHostID getDestID( CommsCtxt* comms, XWEnv xwe, XP_PlayerAddr channelNo );
static void set_reset_timer( CommsCtxt* comms ); static void set_reset_timer( CommsCtxt* comms, XWEnv xwe );
# ifdef XWFEATURE_DEVID # ifdef XWFEATURE_DEVID
static void putDevID( const CommsCtxt* comms, XWStreamCtxt* stream ); static void putDevID( const CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream );
# else # else
# define putDevID( comms, stream ) # define putDevID( comms, xwe, stream )
# endif # endif
# ifdef DEBUG # ifdef DEBUG
static const char* relayCmdToStr( XWRELAY_Cmd cmd ); static const char* relayCmdToStr( XWRELAY_Cmd cmd );
@ -378,9 +379,9 @@ comms_make( MPFORMAL XWEnv xwe, XW_UtilCtxt* util, XP_Bool isServer,
comms->xportFlags = comms->procs.flags; comms->xportFlags = comms->procs.flags;
#endif #endif
} }
comms->dutil = util_getDevUtilCtxt( util ); comms->dutil = util_getDevUtilCtxt( util, xwe );
comms->util = util; comms->util = util;
comms->dutil = util_getDevUtilCtxt( util ); comms->dutil = util_getDevUtilCtxt( util, xwe );
#ifdef XWFEATURE_RELAY #ifdef XWFEATURE_RELAY
init_relay( comms, xwe, nPlayersHere, nPlayersTotal ); init_relay( comms, xwe, nPlayersHere, nPlayersTotal );
@ -516,7 +517,7 @@ p_comms_resetTimer( void* closure, XWEnv xwe, XWTimerReason XP_UNUSED_DBG(why) )
setHeartbeatTimer( comms ); /* in case we killed it with this setHeartbeatTimer( comms ); /* in case we killed it with this
one.... */ one.... */
} else { } else {
set_reset_timer( comms ); set_reset_timer( comms, xwe );
} }
} }
@ -524,12 +525,12 @@ p_comms_resetTimer( void* closure, XWEnv xwe, XWTimerReason XP_UNUSED_DBG(why) )
} /* p_comms_resetTimer */ } /* p_comms_resetTimer */
static void static void
set_reset_timer( CommsCtxt* comms ) set_reset_timer( CommsCtxt* comms, XWEnv xwe )
{ {
/* This timer is allowed to overwrite a heartbeat timer, but not /* This timer is allowed to overwrite a heartbeat timer, but not
vice-versa. Make sure we can restart it. */ vice-versa. Make sure we can restart it. */
comms->hbTimerPending = XP_FALSE; comms->hbTimerPending = XP_FALSE;
util_setTimer( comms->util, TIMER_COMMS, 15, util_setTimer( comms->util, xwe, TIMER_COMMS, 15,
p_comms_resetTimer, comms ); p_comms_resetTimer, comms );
comms->reconTimerPending = XP_TRUE; comms->reconTimerPending = XP_TRUE;
} /* set_reset_timer */ } /* set_reset_timer */
@ -543,26 +544,26 @@ comms_transportFailed( CommsCtxt* comms, XWEnv xwe, CommsConnType failed )
&& comms->rr.relayState != COMMS_RELAYSTATE_DENIED ) { && comms->rr.relayState != COMMS_RELAYSTATE_DENIED ) {
relayDisconnect( comms, xwe ); relayDisconnect( comms, xwe );
set_reset_timer( comms ); set_reset_timer( comms, xwe );
} }
LOG_RETURN_VOID(); LOG_RETURN_VOID();
} }
#endif /* XWFEATURE_RELAY */ #endif /* XWFEATURE_RELAY */
void void
comms_destroy( CommsCtxt* comms ) comms_destroy( CommsCtxt* comms, XWEnv xwe )
{ {
/* did I call comms_stop()? */ /* did I call comms_stop()? */
XP_ASSERT( ! addr_hasType( &comms->addr, COMMS_CONN_RELAY ) XP_ASSERT( ! addr_hasType( &comms->addr, COMMS_CONN_RELAY )
|| COMMS_RELAYSTATE_UNCONNECTED == comms->rr.relayState ); || COMMS_RELAYSTATE_UNCONNECTED == comms->rr.relayState );
CommsAddrRec aNew = {0}; CommsAddrRec aNew = {0};
util_addrChange( comms->util, &comms->addr, &aNew ); util_addrChange( comms->util, xwe, &comms->addr, &aNew );
cleanupInternal( comms ); cleanupInternal( comms );
cleanupAddrRecs( comms ); cleanupAddrRecs( comms );
util_clearTimer( comms->util, TIMER_COMMS ); util_clearTimer( comms->util, xwe, TIMER_COMMS );
XP_FREE( comms->mpool, comms ); XP_FREE( comms->mpool, comms );
} /* comms_destroy */ } /* comms_destroy */
@ -733,7 +734,7 @@ comms_makeFromStream( MPFORMAL XWEnv xwe, XWStreamCtxt* stream, XW_UtilCtxt* uti
msg->msg = (XP_U8*)XP_MALLOC( mpool, msg->len ); msg->msg = (XP_U8*)XP_MALLOC( mpool, msg->len );
stream_getBytes( stream, msg->msg, msg->len ); stream_getBytes( stream, msg->msg, msg->len );
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
msg->checksum = dutil_md5sum( comms->dutil, msg->msg, msg->len ); msg->checksum = dutil_md5sum( comms->dutil, xwe, msg->msg, msg->len );
#endif #endif
msg->next = (MsgQueueElem*)NULL; msg->next = (MsgQueueElem*)NULL;
*prevsQueueNext = comms->msgQueueTail = msg; *prevsQueueNext = comms->msgQueueTail = msg;
@ -808,7 +809,7 @@ sendConnect( CommsCtxt* comms, XWEnv xwe, XP_Bool breakExisting )
set_relay_state( comms, xwe, COMMS_RELAYSTATE_UNCONNECTED ); set_relay_state( comms, xwe, COMMS_RELAYSTATE_UNCONNECTED );
if ( !relayConnect( comms, xwe ) ) { if ( !relayConnect( comms, xwe ) ) {
XP_LOGF( "%s: relayConnect failed", __func__ ); XP_LOGF( "%s: relayConnect failed", __func__ );
set_reset_timer( comms ); set_reset_timer( comms, xwe );
} }
} }
break; break;
@ -1008,7 +1009,7 @@ comms_augmentHostAddr( CommsCtxt* comms, XWEnv xwe, const CommsAddrRec* addr )
CommsAddrRec tmp = comms->addr; CommsAddrRec tmp = comms->addr;
augmentAddr( &tmp, addr ); augmentAddr( &tmp, addr );
util_addrChange( comms->util, &comms->addr, &tmp ); util_addrChange( comms->util, xwe, &comms->addr, &tmp );
comms->addr = tmp; comms->addr = tmp;
logAddr( comms, xwe, &comms->addr, "after" ); logAddr( comms, xwe, &comms->addr, "after" );
@ -1123,7 +1124,8 @@ comms_getInitialAddr( CommsAddrRec* addr
} /* comms_getInitialAddr */ } /* comms_getInitialAddr */
XP_Bool XP_Bool
comms_checkAddr( DeviceRole role, const CommsAddrRec* addr, XW_UtilCtxt* util ) comms_checkAddr( XWEnv xwe, DeviceRole role, const CommsAddrRec* addr,
XW_UtilCtxt* util )
{ {
XP_Bool ok = XP_TRUE; XP_Bool ok = XP_TRUE;
/* make sure the user's given us enough information to make a connection */ /* make sure the user's given us enough information to make a connection */
@ -1133,7 +1135,7 @@ comms_checkAddr( DeviceRole role, const CommsAddrRec* addr, XW_UtilCtxt* util )
if ( !XP_MEMCMP( &empty, &addr->u.bt.btAddr, sizeof(empty) ) ) { if ( !XP_MEMCMP( &empty, &addr->u.bt.btAddr, sizeof(empty) ) ) {
ok = XP_FALSE; ok = XP_FALSE;
if ( !!util ) { if ( !!util ) {
util_userError( util, STR_NEED_BT_HOST_ADDR ); util_userError( util, xwe, STR_NEED_BT_HOST_ADDR );
} }
} }
} }
@ -1217,7 +1219,7 @@ makeElemWithID( CommsCtxt* comms, XWEnv xwe, MsgID msgID, AddressRecord* rec,
} }
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
newMsgElem->checksum = dutil_md5sum( comms->dutil, newMsgElem->msg, newMsgElem->checksum = dutil_md5sum( comms->dutil, xwe, newMsgElem->msg,
newMsgElem->len ); newMsgElem->len );
#endif #endif
return newMsgElem; return newMsgElem;
@ -1249,7 +1251,7 @@ comms_send( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream )
XP_PlayerAddr channelNo = stream_getAddress( stream ); XP_PlayerAddr channelNo = stream_getAddress( stream );
CNO_FMT( cbuf, channelNo ); CNO_FMT( cbuf, channelNo );
XP_LOGF( "%s: %s", __func__, cbuf ); XP_LOGF( "%s: %s", __func__, cbuf );
AddressRecord* rec = getRecordFor( comms, NULL, channelNo, XP_FALSE ); AddressRecord* rec = getRecordFor( comms, xwe, NULL, channelNo, XP_FALSE );
MsgID msgID = (!!rec)? ++rec->nextMsgID : 0; MsgID msgID = (!!rec)? ++rec->nextMsgID : 0;
MsgQueueElem* elem; MsgQueueElem* elem;
@ -1386,7 +1388,7 @@ removeFromQueue( CommsCtxt* comms, XWEnv xwe, XP_PlayerAddr channelNo, MsgID msg
XP_LOGF( "%s(channelNo=%d): remove msgs <= " XP_LD " for %s (queueLen: %d)", XP_LOGF( "%s(channelNo=%d): remove msgs <= " XP_LD " for %s (queueLen: %d)",
__func__, channelNo, msgID, cbuf, comms->queueLen ); __func__, channelNo, msgID, cbuf, comms->queueLen );
if ((channelNo == 0) || !!getRecordFor( comms, NULL, channelNo, XP_FALSE)) { if ((channelNo == 0) || !!getRecordFor( comms, xwe, NULL, channelNo, XP_FALSE)) {
MsgQueueElem* elem = comms->msgQueueHead; MsgQueueElem* elem = comms->msgQueueHead;
MsgQueueElem* next; MsgQueueElem* next;
@ -1466,7 +1468,7 @@ sendMsg( CommsCtxt* comms, XWEnv xwe, MsgQueueElem* elem, const CommsConnType fi
CommsAddrRec addr; CommsAddrRec addr;
const CommsAddrRec* addrP; const CommsAddrRec* addrP;
(void)channelToAddress( comms, channelNo, &addrP ); (void)channelToAddress( comms, xwe, channelNo, &addrP );
if ( NULL == addrP ) { if ( NULL == addrP ) {
XP_LOGF( TAGFMT() "no addr for channel so using comms'", TAGPRMS ); XP_LOGF( TAGFMT() "no addr for channel so using comms'", TAGPRMS );
comms_getAddr( comms, &addr ); comms_getAddr( comms, &addr );
@ -1576,7 +1578,7 @@ resendImpl( CommsCtxt* comms, XWEnv xwe, CommsConnType filter, XP_Bool force,
XP_Bool success = XP_TRUE; XP_Bool success = XP_TRUE;
XP_ASSERT( !!comms ); XP_ASSERT( !!comms );
XP_U32 now = dutil_getCurSeconds( comms->dutil ); XP_U32 now = dutil_getCurSeconds( comms->dutil, xwe );
if ( !force && (now < comms->nextResend) ) { if ( !force && (now < comms->nextResend) ) {
XP_LOGF( "%s: aborting: %d seconds left in backoff", __func__, XP_LOGF( "%s: aborting: %d seconds left in backoff", __func__,
comms->nextResend - now ); comms->nextResend - now );
@ -1725,7 +1727,7 @@ got_connect_cmd( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream,
if ( isServer != comms->isServer ) { if ( isServer != comms->isServer ) {
XP_LOGF( "%s: becoming%s a server", __func__, isServer ? "" : " NOT" ); XP_LOGF( "%s: becoming%s a server", __func__, isServer ? "" : " NOT" );
comms->isServer = isServer; comms->isServer = isServer;
util_setIsServer( comms->util, comms->isServer ); util_setIsServer( comms->util, xwe, comms->isServer );
reset_internal( comms, xwe, isServer, comms->rr.nPlayersHere, reset_internal( comms, xwe, isServer, comms->rr.nPlayersHere,
comms->rr.nPlayersTotal, XP_FALSE ); comms->rr.nPlayersTotal, XP_FALSE );
@ -1766,7 +1768,7 @@ got_connect_cmd( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream,
} }
if ( ID_TYPE_NONE == typ /* error case */ if ( ID_TYPE_NONE == typ /* error case */
|| '\0' != devID[0] ) /* new info case */ { || '\0' != devID[0] ) /* new info case */ {
dutil_deviceRegistered( comms->dutil, typ, devID ); dutil_deviceRegistered( comms->dutil, xwe, typ, devID );
} }
#endif #endif
@ -1904,7 +1906,7 @@ relayPreProcess( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream, XWHostID* se
} else { } else {
set_relay_state( comms, xwe, COMMS_RELAYSTATE_RECONNECTED ); set_relay_state( comms, xwe, COMMS_RELAYSTATE_RECONNECTED );
/* we will eventually want to tell the user which player's gone */ /* we will eventually want to tell the user which player's gone */
util_userError( comms->util, ERR_RELAY_BASE + relayErr ); util_userError( comms->util, xwe, ERR_RELAY_BASE + relayErr );
} }
} }
break; break;
@ -1912,7 +1914,7 @@ relayPreProcess( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream, XWHostID* se
case XWRELAY_DISCONNECT_YOU: /* Close socket for this? */ case XWRELAY_DISCONNECT_YOU: /* Close socket for this? */
relayErr = stream_getU8( stream ); relayErr = stream_getU8( stream );
set_relay_state( comms, xwe, COMMS_RELAYSTATE_UNCONNECTED ); set_relay_state( comms, xwe, COMMS_RELAYSTATE_UNCONNECTED );
util_userError( comms->util, ERR_RELAY_BASE + relayErr ); util_userError( comms->util, xwe, ERR_RELAY_BASE + relayErr );
break; break;
case XWRELAY_MSG_STATUS: case XWRELAY_MSG_STATUS:
@ -1928,7 +1930,7 @@ relayPreProcess( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream, XWHostID* se
if ( XWRELAY_ERROR_NORECONN == relayErr ) { if ( XWRELAY_ERROR_NORECONN == relayErr ) {
init_relay( comms, xwe, comms->rr.nPlayersHere, comms->rr.nPlayersTotal ); init_relay( comms, xwe, comms->rr.nPlayersHere, comms->rr.nPlayersTotal );
} else { } else {
util_userError( comms->util, ERR_RELAY_BASE + relayErr ); util_userError( comms->util, xwe, ERR_RELAY_BASE + relayErr );
/* requires action, not just notification */ /* requires action, not just notification */
(*comms->procs.rerror)( xwe, comms->procs.closure, relayErr ); (*comms->procs.rerror)( xwe, comms->procs.closure, relayErr );
} }
@ -1949,7 +1951,7 @@ relayPreProcess( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream, XWHostID* se
static void static void
noteHBReceived( CommsCtxt* comms/* , const CommsAddrRec* addr */ ) noteHBReceived( CommsCtxt* comms/* , const CommsAddrRec* addr */ )
{ {
comms->lastMsgRcvdTime = dutil_getCurSeconds( comms->dutil ); comms->lastMsgRcvdTime = dutil_getCurSeconds( comms->dutil, xwe );
setHeartbeatTimer( comms ); setHeartbeatTimer( comms );
} }
#else #else
@ -2028,7 +2030,7 @@ preProcess( CommsCtxt* comms, XWEnv xwe, const CommsAddrRec* useAddr,
} /* preProcess */ } /* preProcess */
static AddressRecord* static AddressRecord*
getRecordFor( CommsCtxt* comms, const CommsAddrRec* addr, getRecordFor( CommsCtxt* comms, XWEnv xwe, const CommsAddrRec* addr,
const XP_PlayerAddr channelNo, XP_Bool maskChannel ) const XP_PlayerAddr channelNo, XP_Bool maskChannel )
{ {
LOG_FUNC(); LOG_FUNC();
@ -2083,8 +2085,8 @@ getRecordFor( CommsCtxt* comms, const CommsAddrRec* addr,
case COMMS_CONN_SMS: case COMMS_CONN_SMS:
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
{ {
XW_DUtilCtxt* duc = util_getDevUtilCtxt( comms->util ); XW_DUtilCtxt* duc = util_getDevUtilCtxt( comms->util, xwe );
if ( dutil_phoneNumbersSame( duc, addr->u.sms.phone, if ( dutil_phoneNumbersSame( duc, xwe, addr->u.sms.phone,
rec->addr.u.sms.phone ) rec->addr.u.sms.phone )
&& addr->u.sms.port == rec->addr.u.sms.port ) { && addr->u.sms.port == rec->addr.u.sms.port ) {
matched = XP_TRUE; matched = XP_TRUE;
@ -2163,7 +2165,7 @@ validateInitialMessage( CommsCtxt* comms, XWEnv xwe,
} else if ( comms->doHeartbeat ) { } else if ( comms->doHeartbeat ) {
XP_Bool addRec = XP_FALSE; XP_Bool addRec = XP_FALSE;
/* This (with mask) is untested!!! */ /* This (with mask) is untested!!! */
rec = getRecordFor( comms, addr, *channelNo, XP_TRUE ); rec = getRecordFor( comms, xwe, addr, *channelNo, XP_TRUE );
if ( hasPayload ) { if ( hasPayload ) {
if ( rec ) { if ( rec ) {
@ -2201,7 +2203,7 @@ validateInitialMessage( CommsCtxt* comms, XWEnv xwe,
} else { } else {
CNO_FMT( cbuf, *channelNo ); CNO_FMT( cbuf, *channelNo );
XP_LOGF( TAGFMT() "looking at %s", TAGPRMS, cbuf ); XP_LOGF( TAGFMT() "looking at %s", TAGPRMS, cbuf );
rec = getRecordFor( comms, addr, *channelNo, XP_TRUE ); rec = getRecordFor( comms, xwe, addr, *channelNo, XP_TRUE );
if ( !!rec ) { if ( !!rec ) {
augmentChannelAddr( rec, addr, senderID ); augmentChannelAddr( rec, addr, senderID );
/* reject: we've already seen init message on channel */ /* reject: we've already seen init message on channel */
@ -2274,7 +2276,7 @@ validateChannelMessage( CommsCtxt* comms, XWEnv xwe, const CommsAddrRec* addr,
AddressRecord* rec; AddressRecord* rec;
LOG_FUNC(); LOG_FUNC();
rec = getRecordFor( comms, NULL, channelNo, XP_FALSE ); rec = getRecordFor( comms, xwe, NULL, channelNo, XP_FALSE );
if ( !!rec ) { if ( !!rec ) {
removeFromQueue( comms, xwe, channelNo, lastMsgRcd ); removeFromQueue( comms, xwe, channelNo, lastMsgRcd );
@ -2345,7 +2347,7 @@ comms_checkIncomingStream( CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream,
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
// stream_getPtr pts at base, but sum excludes relay header // stream_getPtr pts at base, but sum excludes relay header
const XP_U8* ptr = initialLen - len + stream_getPtr( stream ); const XP_U8* ptr = initialLen - len + stream_getPtr( stream );
XP_UCHAR* sum = dutil_md5sum( comms->dutil, ptr, len ); XP_UCHAR* sum = dutil_md5sum( comms->dutil, xwe, ptr, len );
XP_LOGF( TAGFMT() "got message of len %d with sum %s", XP_LOGF( TAGFMT() "got message of len %d with sum %s",
TAGPRMS, len, sum ); TAGPRMS, len, sum );
XP_FREE( comms->mpool, sum ); XP_FREE( comms->mpool, sum );
@ -2452,7 +2454,7 @@ comms_msgProcessed( CommsCtxt* comms, XWEnv xwe,
XP_LOGFF( "msg rejected; NOT upping lastMsgRcd to %d", state->msgID ); XP_LOGFF( "msg rejected; NOT upping lastMsgRcd to %d", state->msgID );
#endif #endif
} else { } else {
AddressRecord* rec = getRecordFor( comms, NULL, state->channelNo, XP_TRUE ); AddressRecord* rec = getRecordFor( comms, xwe, NULL, state->channelNo, XP_TRUE );
XP_ASSERT( !!rec ); XP_ASSERT( !!rec );
if ( !!rec && rec->lastMsgRcd < state->msgID ) { if ( !!rec && rec->lastMsgRcd < state->msgID ) {
#ifdef LOG_COMMS_MSGNOS #ifdef LOG_COMMS_MSGNOS
@ -2567,7 +2569,7 @@ heartbeat_checks( CommsCtxt* comms )
do { do {
if ( comms->lastMsgRcvdTime > 0 ) { if ( comms->lastMsgRcvdTime > 0 ) {
XP_U32 now = dutil_getCurSeconds( comms->dutil ); XP_U32 now = dutil_getCurSeconds( comms->dutil, xwe );
XP_U32 tooLongAgo = now - (HB_INTERVAL * 2); XP_U32 tooLongAgo = now - (HB_INTERVAL * 2);
if ( comms->lastMsgRcvdTime < tooLongAgo ) { if ( comms->lastMsgRcvdTime < tooLongAgo ) {
XP_LOGF( "%s: calling reset proc; last was %ld secs too long " XP_LOGF( "%s: calling reset proc; last was %ld secs too long "
@ -2641,7 +2643,7 @@ setHeartbeatTimer( CommsCtxt* comms )
} }
#endif #endif
if ( when != 0 ) { if ( when != 0 ) {
util_setTimer( comms->util, TIMER_COMMS, when, util_setTimer( comms->util, xwe, TIMER_COMMS, when,
p_comms_timerFired, comms ); p_comms_timerFired, comms );
comms->hbTimerPending = XP_TRUE; comms->hbTimerPending = XP_TRUE;
} }
@ -2735,7 +2737,7 @@ rememberChannelAddress( CommsCtxt* comms, XWEnv xwe, XP_PlayerAddr channelNo,
logAddr( comms, xwe, addr, __func__ ); logAddr( comms, xwe, addr, __func__ );
AddressRecord* rec = NULL; AddressRecord* rec = NULL;
rec = getRecordFor( comms, NULL, channelNo, XP_FALSE ); rec = getRecordFor( comms, xwe, NULL, channelNo, XP_FALSE );
if ( !rec ) { if ( !rec ) {
/* not found; add a new entry */ /* not found; add a new entry */
rec = (AddressRecord*)XP_CALLOC( comms->mpool, sizeof(*rec) ); rec = (AddressRecord*)XP_CALLOC( comms->mpool, sizeof(*rec) );
@ -2911,10 +2913,10 @@ augmentAddr( CommsAddrRec* destAddr, const CommsAddrRec* srcAddr )
} }
static XP_Bool static XP_Bool
channelToAddress( CommsCtxt* comms, XP_PlayerAddr channelNo, channelToAddress( CommsCtxt* comms, XWEnv xwe, XP_PlayerAddr channelNo,
const CommsAddrRec** addr ) const CommsAddrRec** addr )
{ {
AddressRecord* recs = getRecordFor( comms, NULL, channelNo, XP_FALSE ); AddressRecord* recs = getRecordFor( comms, xwe, NULL, channelNo, XP_FALSE );
XP_Bool found = !!recs; XP_Bool found = !!recs;
*addr = found? &recs->addr : NULL; *addr = found? &recs->addr : NULL;
return found; return found;
@ -3119,7 +3121,7 @@ relay_msg_to_stream( CommsCtxt* comms, XWEnv xwe, XWRELAY_Cmd cmd, XWHostID dest
stream_putU8( stream, comms->rr.nPlayersTotal ); stream_putU8( stream, comms->rr.nPlayersTotal );
stream_putU16( stream, comms_getChannelSeed(comms) ); stream_putU16( stream, comms_getChannelSeed(comms) );
stream_putU8( stream, comms->util->gameInfo->dictLang ); stream_putU8( stream, comms->util->gameInfo->dictLang );
putDevID( comms, stream ); putDevID( comms, xwe, stream );
stream_putU8( stream, comms->forceChannel ); /* "clientIndx" on relay */ stream_putU8( stream, comms->forceChannel ); /* "clientIndx" on relay */
set_relay_state( comms, xwe, COMMS_RELAYSTATE_CONNECT_PENDING ); set_relay_state( comms, xwe, COMMS_RELAYSTATE_CONNECT_PENDING );
@ -3143,7 +3145,7 @@ relay_msg_to_stream( CommsCtxt* comms, XWEnv xwe, XWRELAY_Cmd cmd, XWHostID dest
stream_putU16( stream, comms_getChannelSeed(comms) ); stream_putU16( stream, comms_getChannelSeed(comms) );
stream_putU8( stream, comms->util->gameInfo->dictLang ); stream_putU8( stream, comms->util->gameInfo->dictLang );
stringToStream( stream, comms->rr.connName ); stringToStream( stream, comms->rr.connName );
putDevID( comms, stream ); putDevID( comms, xwe, stream );
set_relay_state( comms, xwe, COMMS_RELAYSTATE_CONNECT_PENDING ); set_relay_state( comms, xwe, COMMS_RELAYSTATE_CONNECT_PENDING );
break; break;
@ -3259,7 +3261,7 @@ relayConnect( CommsCtxt* comms, XWEnv xwe )
comms_getAddr( comms, &addr ); comms_getAddr( comms, &addr );
DevIDType ignored; /* but should it be? */ DevIDType ignored; /* but should it be? */
(*comms->procs.requestJoin)( comms->procs.closure, (*comms->procs.requestJoin)( comms->procs.closure,
util_getDevID( comms->util, &ignored ), util_getDevID( comms->util, xwe, &ignored ),
addr.u.ip_relay.invite, /* room */ addr.u.ip_relay.invite, /* room */
comms->rr.nPlayersHere, comms->rr.nPlayersHere,
comms->rr.nPlayersTotal, comms->rr.nPlayersTotal,
@ -3292,7 +3294,7 @@ send_via_bt_or_ip( CommsCtxt* comms, XWEnv xwe, BTIPMsgType msgTyp, XP_PlayerAdd
buf = XP_MALLOC( comms->mpool, dlen + 1 ); buf = XP_MALLOC( comms->mpool, dlen + 1 );
if ( !!buf ) { if ( !!buf ) {
const CommsAddrRec* addr; const CommsAddrRec* addr;
(void)channelToAddress( comms, channelNo, &addr ); (void)channelToAddress( comms, xwe, channelNo, &addr );
buf[0] = msgTyp; buf[0] = msgTyp;
if ( dlen > 0 ) { if ( dlen > 0 ) {
@ -3327,11 +3329,11 @@ relayDisconnect( CommsCtxt* comms, XWEnv xwe )
#ifdef XWFEATURE_DEVID #ifdef XWFEATURE_DEVID
static void static void
putDevID( const CommsCtxt* comms, XWStreamCtxt* stream ) putDevID( const CommsCtxt* comms, XWEnv xwe, XWStreamCtxt* stream )
{ {
# if XWRELAY_PROTO_VERSION >= XWRELAY_PROTO_VERSION_CLIENTID # if XWRELAY_PROTO_VERSION >= XWRELAY_PROTO_VERSION_CLIENTID
DevIDType typ; DevIDType typ;
const XP_UCHAR* devID = dutil_getDevID( comms->dutil, &typ ); const XP_UCHAR* devID = dutil_getDevID( comms->dutil, xwe, &typ );
XP_ASSERT( ID_TYPE_NONE <= typ && typ < ID_TYPE_NTYPES ); XP_ASSERT( ID_TYPE_NONE <= typ && typ < ID_TYPE_NTYPES );
stream_putU8( stream, typ ); stream_putU8( stream, typ );
if ( ID_TYPE_NONE != typ ) { if ( ID_TYPE_NONE != typ ) {

View file

@ -192,7 +192,7 @@ void comms_reset( CommsCtxt* comms, XWEnv xwe, XP_Bool isServer,
void comms_resetSame( CommsCtxt* comms, XWEnv xwe ); void comms_resetSame( CommsCtxt* comms, XWEnv xwe );
void comms_transportFailed( CommsCtxt* comms, XWEnv xwe, CommsConnType failed ); void comms_transportFailed( CommsCtxt* comms, XWEnv xwe, CommsConnType failed );
void comms_destroy( CommsCtxt* comms ); void comms_destroy( CommsCtxt* comms, XWEnv xwe );
void comms_setConnID( CommsCtxt* comms, XP_U32 connID ); void comms_setConnID( CommsCtxt* comms, XP_U32 connID );
@ -203,7 +203,7 @@ void comms_getInitialAddr( CommsAddrRec* addr
, XP_U16 relayPort , XP_U16 relayPort
#endif #endif
); );
XP_Bool comms_checkAddr( DeviceRole role, const CommsAddrRec* addr, XP_Bool comms_checkAddr( XWEnv xwe, DeviceRole role, const CommsAddrRec* addr,
XW_UtilCtxt* util ); XW_UtilCtxt* util );
void comms_getAddr( const CommsCtxt* comms, CommsAddrRec* addr ); void comms_getAddr( const CommsCtxt* comms, CommsAddrRec* addr );

View file

@ -39,13 +39,13 @@ mkStream( XW_DUtilCtxt* dutil )
} }
static DevCtxt* static DevCtxt*
load( XW_DUtilCtxt* dutil ) load( XW_DUtilCtxt* dutil, XWEnv xwe )
{ {
LOG_FUNC(); LOG_FUNC();
DevCtxt* state = (DevCtxt*)dutil->devCtxt; DevCtxt* state = (DevCtxt*)dutil->devCtxt;
if ( NULL == state ) { if ( NULL == state ) {
XWStreamCtxt* stream = mkStream( dutil ); XWStreamCtxt* stream = mkStream( dutil );
dutil_loadStream( dutil, KEY_DEVSTATE, stream ); dutil_loadStream( dutil, xwe, KEY_DEVSTATE, stream );
state = XP_CALLOC( dutil->mpool, sizeof(*state) ); state = XP_CALLOC( dutil->mpool, sizeof(*state) );
dutil->devCtxt = state; dutil->devCtxt = state;
@ -64,13 +64,13 @@ load( XW_DUtilCtxt* dutil )
} }
void void
device_store( XW_DUtilCtxt* dutil ) device_store( XW_DUtilCtxt* dutil, XWEnv xwe )
{ {
LOG_FUNC(); LOG_FUNC();
DevCtxt* state = load( dutil ); DevCtxt* state = load( dutil, xwe );
XWStreamCtxt* stream = mkStream( dutil ); XWStreamCtxt* stream = mkStream( dutil );
stream_putU16( stream, state->devCount ); stream_putU16( stream, state->devCount );
dutil_storeStream( dutil, KEY_DEVSTATE, stream ); dutil_storeStream( dutil, xwe, KEY_DEVSTATE, stream );
stream_destroy( stream, NULL ); stream_destroy( stream, NULL );
XP_FREEP( dutil->mpool, &dutil->devCtxt ); XP_FREEP( dutil->mpool, &dutil->devCtxt );

View file

@ -25,9 +25,9 @@
// void device_load( XW_DUtilCtxt dctxt ); // void device_load( XW_DUtilCtxt dctxt );
# ifdef XWFEATURE_DEVICE # ifdef XWFEATURE_DEVICE
void device_store( XW_DUtilCtxt* dctxt ); void device_store( XW_DUtilCtxt* dctxt, XWEnv xwe );
# else # else
# define device_store(dctxt) # define device_store(dctxt, xwe)
# endif # endif
#endif #endif

View file

@ -30,8 +30,8 @@ extern "C" {
# define SCROLL_DRAG_THRESHHOLD 1 # define SCROLL_DRAG_THRESHHOLD 1
#endif #endif
static XP_Bool dragDropContinueImpl( BoardCtxt* board, XP_U16 xx, XP_U16 yy, static XP_Bool dragDropContinueImpl( BoardCtxt* board, XWEnv xwe, XP_U16 xx,
BoardObjectType* onWhichP ); XP_U16 yy, BoardObjectType* onWhichP );
static void invalDragObjRange( BoardCtxt* board, const DragObjInfo* from, static void invalDragObjRange( BoardCtxt* board, const DragObjInfo* from,
const DragObjInfo* to ); const DragObjInfo* to );
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
@ -49,7 +49,7 @@ static void crosshairs_clear( BoardCtxt* board );
# define crosshairs_clear( board ) # define crosshairs_clear( board )
#endif #endif
static void startScrollTimerIf( BoardCtxt* board ); static void startScrollTimerIf( BoardCtxt* board, XWEnv xwe );
XP_Bool XP_Bool
dragDropInProgress( const BoardCtxt* board ) dragDropInProgress( const BoardCtxt* board )
@ -84,7 +84,7 @@ clearDS( DragState* ds )
} }
static XP_Bool static XP_Bool
ddStartBoard( BoardCtxt* board, XP_U16 xx, XP_U16 yy ) ddStartBoard( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy )
{ {
DragState* ds = &board->dragState; DragState* ds = &board->dragState;
XP_Bool trayVisible; XP_Bool trayVisible;
@ -128,7 +128,7 @@ ddStartBoard( BoardCtxt* board, XP_U16 xx, XP_U16 yy )
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
} else if ( !board->gi->hintsNotAllowed && board->gi->allowHintRect } else if ( !board->gi->hintsNotAllowed && board->gi->allowHintRect
&& trayVisible ) { && trayVisible ) {
if ( !util_altKeyDown(board->util) ) { if ( !util_altKeyDown(board->util, xwe) ) {
ds->dtype = DT_HINTRGN; ds->dtype = DT_HINTRGN;
} else if ( canScroll ) { } else if ( canScroll ) {
ds->dtype = DT_BOARD; ds->dtype = DT_BOARD;
@ -185,7 +185,7 @@ ddStartTray( BoardCtxt* board, XP_U16 x, XP_U16 y )
* tray. * tray.
*/ */
XP_Bool XP_Bool
dragDropStart( BoardCtxt* board, BoardObjectType obj, XP_U16 x, XP_U16 y ) dragDropStart( BoardCtxt* board, XWEnv xwe, BoardObjectType obj, XP_U16 xx, XP_U16 yy )
{ {
XP_Bool result = XP_FALSE; XP_Bool result = XP_FALSE;
DragState* ds = &board->dragState; DragState* ds = &board->dragState;
@ -197,9 +197,9 @@ dragDropStart( BoardCtxt* board, BoardObjectType obj, XP_U16 x, XP_U16 y )
ds->start.obj = obj; ds->start.obj = obj;
if ( OBJ_BOARD == obj ) { if ( OBJ_BOARD == obj ) {
result = ddStartBoard( board, x, y ); result = ddStartBoard( board, xwe, xx, yy );
} else if ( OBJ_TRAY == obj ) { } else if ( OBJ_TRAY == obj ) {
result = ddStartTray( board, x, y ); result = ddStartTray( board, xx, yy );
} else { } else {
XP_ASSERT(0); XP_ASSERT(0);
} }
@ -207,7 +207,7 @@ dragDropStart( BoardCtxt* board, BoardObjectType obj, XP_U16 x, XP_U16 y )
if ( result ) { if ( result ) {
ds->cur = ds->start; ds->cur = ds->start;
invalDragObj( board, &ds->start ); invalDragObj( board, &ds->start );
startScrollTimerIf( board ); startScrollTimerIf( board, xwe );
} }
return result; return result;
@ -229,22 +229,22 @@ dragDropStart( BoardCtxt* board, BoardObjectType obj, XP_U16 x, XP_U16 y )
* just change it every time we can. * just change it every time we can.
*/ */
XP_Bool XP_Bool
dragDropContinue( BoardCtxt* board, XP_U16 xx, XP_U16 yy ) dragDropContinue( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy )
{ {
XP_ASSERT( dragDropInProgress(board) ); XP_ASSERT( dragDropInProgress(board) );
return dragDropContinueImpl( board, xx, yy, NULL ); return dragDropContinueImpl( board, xwe, xx, yy, NULL );
} }
XP_Bool XP_Bool
dragDropEnd( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool* draggedP ) dragDropEnd( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy, XP_Bool* draggedP )
{ {
DragState* ds = &board->dragState; DragState* ds = &board->dragState;
BoardObjectType newObj; BoardObjectType newObj;
XP_ASSERT( dragDropInProgress(board) ); XP_ASSERT( dragDropInProgress(board) );
(void)dragDropContinueImpl( board, xx, yy, &newObj ); (void)dragDropContinueImpl( board, xwe, xx, yy, &newObj );
if ( !!draggedP ) { if ( !!draggedP ) {
*draggedP = ds->didMove; *draggedP = ds->didMove;
} }
@ -282,7 +282,7 @@ dragDropEnd( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool* draggedP )
if ( newObj == OBJ_TRAY ) { if ( newObj == OBJ_TRAY ) {
if ( ds->start.obj == OBJ_BOARD ) { /* board->tray is pending */ if ( ds->start.obj == OBJ_BOARD ) { /* board->tray is pending */
model_moveBoardToTray( board->model, board->selPlayer, model_moveBoardToTray( board->model, xwe, board->selPlayer,
mod_startc, mod_startr, mod_startc, mod_startr,
ds->cur.u.tray.index ); ds->cur.u.tray.index );
} else { } else {
@ -295,14 +295,14 @@ dragDropEnd( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool* draggedP )
ds->cur.u.board.row, XP_TRUE ) ) { ds->cur.u.board.row, XP_TRUE ) ) {
if ( ds->start.obj == OBJ_TRAY ) { if ( ds->start.obj == OBJ_TRAY ) {
/* moveTileToBoard flips its inputs */ /* moveTileToBoard flips its inputs */
(void)moveTileToBoard( board, ds->cur.u.board.col, (void)moveTileToBoard( board, xwe, ds->cur.u.board.col,
ds->cur.u.board.row, ds->cur.u.board.row,
ds->start.u.tray.index, EMPTY_TILE ); ds->start.u.tray.index, EMPTY_TILE );
} else if ( ds->start.obj == OBJ_BOARD ) { } else if ( ds->start.obj == OBJ_BOARD ) {
XP_U16 mod_curc, mod_curr; XP_U16 mod_curc, mod_curr;
flipIf( board, ds->cur.u.board.col, ds->cur.u.board.row, flipIf( board, ds->cur.u.board.col, ds->cur.u.board.row,
&mod_curc, &mod_curr ); &mod_curc, &mod_curr );
if ( model_moveTileOnBoard( board->model, board->selPlayer, if ( model_moveTileOnBoard( board->model, xwe, board->selPlayer,
mod_startc, mod_startr, mod_curc, mod_startc, mod_startr, mod_curc,
mod_curr ) ) { mod_curr ) ) {
/* inval points tile in case score changed */ /* inval points tile in case score changed */
@ -329,7 +329,7 @@ dragDropEnd( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool* draggedP )
#ifdef XWFEATURE_RAISETILE #ifdef XWFEATURE_RAISETILE
XP_Bool XP_Bool
dragDropSetAdd( BoardCtxt* board ) dragDropSetAdd( BoardCtxt* board, XWEnv xwe )
{ {
DragState* ds = &board->dragState; DragState* ds = &board->dragState;
XP_Bool draw; XP_Bool draw;
@ -338,7 +338,7 @@ dragDropSetAdd( BoardCtxt* board )
if ( draw ) { if ( draw ) {
if ( draw ) { if ( draw ) {
ds->yyAdd = (board->trayBounds.height * 2) / 3; ds->yyAdd = (board->trayBounds.height * 2) / 3;
draw = dragDropContinueImpl( board, board->penDownX, draw = dragDropContinueImpl( board, xwe, board->penDownX,
board->penDownY, NULL ); board->penDownY, NULL );
} }
} }
@ -474,7 +474,7 @@ invalHintRectDiffs( BoardCtxt* board, const DragObjInfo* cur,
#endif #endif
static XP_Bool static XP_Bool
dragDropContinueImpl( BoardCtxt* board, XP_U16 xx, XP_U16 yy, dragDropContinueImpl( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy,
BoardObjectType* onWhichP ) BoardObjectType* onWhichP )
{ {
XP_Bool moving = XP_FALSE; XP_Bool moving = XP_FALSE;
@ -532,7 +532,7 @@ dragDropContinueImpl( BoardCtxt* board, XP_U16 xx, XP_U16 yy,
ds->cellChanged = XP_TRUE; ds->cellChanged = XP_TRUE;
} }
diff /= SCROLL_DRAG_THRESHHOLD; diff /= SCROLL_DRAG_THRESHHOLD;
moving = adjustYOffset( board, diff ) || moving; moving = adjustYOffset( board, xwe, diff ) || moving;
} }
} else if ( ds->dtype == DT_TILE ) { } else if ( ds->dtype == DT_TILE ) {
if ( newInfo.obj == OBJ_BOARD ) { if ( newInfo.obj == OBJ_BOARD ) {
@ -572,7 +572,7 @@ dragDropContinueImpl( BoardCtxt* board, XP_U16 xx, XP_U16 yy,
} }
XP_MEMCPY( &ds->cur, &newInfo, sizeof(ds->cur) ); XP_MEMCPY( &ds->cur, &newInfo, sizeof(ds->cur) );
startScrollTimerIf( board ); startScrollTimerIf( board, xwe );
} }
} else { } else {
XP_ASSERT( 0 ); XP_ASSERT( 0 );
@ -651,10 +651,10 @@ scrollTimerProc( void* closure, XWEnv xwe, XWTimerReason XP_UNUSED_DBG(why) )
if ( 0 != changeY ) { if ( 0 != changeY ) {
ds->cur.u.board.row += (changeY >0 ? 1 : -1); ds->cur.u.board.row += (changeY >0 ? 1 : -1);
} }
if ( scrollIntoView( board, ds->cur.u.board.col, if ( scrollIntoView( board, xwe, ds->cur.u.board.col,
ds->cur.u.board.row ) ) { ds->cur.u.board.row ) ) {
board_draw( board, xwe ); /* may fail, e.g. on wince */ board_draw( board, xwe ); /* may fail, e.g. on wince */
startScrollTimerIf( board ); startScrollTimerIf( board, xwe );
draw = XP_TRUE; draw = XP_TRUE;
} }
} }
@ -663,7 +663,7 @@ scrollTimerProc( void* closure, XWEnv xwe, XWTimerReason XP_UNUSED_DBG(why) )
} /* scrollTimerProc */ } /* scrollTimerProc */
static void static void
startScrollTimerIf( BoardCtxt* board ) startScrollTimerIf( BoardCtxt* board, XWEnv xwe )
{ {
DragState* ds = &board->dragState; DragState* ds = &board->dragState;
@ -672,7 +672,7 @@ startScrollTimerIf( BoardCtxt* board )
if ( onBorderCanScroll( board, SCROLL_H, ds->cur.u.board.col, &ignore ) if ( onBorderCanScroll( board, SCROLL_H, ds->cur.u.board.col, &ignore )
|| onBorderCanScroll( board, SCROLL_V, ds->cur.u.board.row, || onBorderCanScroll( board, SCROLL_V, ds->cur.u.board.row,
&ignore ) ) { &ignore ) ) {
util_setTimer( board->util, TIMER_PENDOWN, 0, util_setTimer( board->util, xwe, TIMER_PENDOWN, 0,
scrollTimerProc, (void*) board ); scrollTimerProc, (void*) board );
ds->scrollTimerSet = XP_TRUE; ds->scrollTimerSet = XP_TRUE;
} else { } else {

View file

@ -31,10 +31,11 @@ extern "C" {
XP_Bool dragDropInProgress( const BoardCtxt* board ); XP_Bool dragDropInProgress( const BoardCtxt* board );
XP_Bool dragDropHasMoved( const BoardCtxt* board ); XP_Bool dragDropHasMoved( const BoardCtxt* board );
XP_Bool dragDropStart( BoardCtxt* board, BoardObjectType obj, XP_Bool dragDropStart( BoardCtxt* board, XWEnv xwe, BoardObjectType obj,
XP_U16 xx, XP_U16 yy ); XP_U16 xx, XP_U16 yy );
XP_Bool dragDropContinue( BoardCtxt* board, XP_U16 xx, XP_U16 yy ); XP_Bool dragDropContinue( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy );
XP_Bool dragDropEnd( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool* dragged ); XP_Bool dragDropEnd( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy,
XP_Bool* dragged );
#ifdef XWFEATURE_RAISETILE #ifdef XWFEATURE_RAISETILE
XP_Bool dragDropSetAdd( BoardCtxt* board ); XP_Bool dragDropSetAdd( BoardCtxt* board );

View file

@ -32,40 +32,41 @@ typedef enum { UNPAUSED,
} DupPauseType; } DupPauseType;
typedef struct _DUtilVtable { typedef struct _DUtilVtable {
XP_U32 (*m_dutil_getCurSeconds)( XW_DUtilCtxt* duc ); XP_U32 (*m_dutil_getCurSeconds)( XW_DUtilCtxt* duc, XWEnv xwe );
const XP_UCHAR* (*m_dutil_getUserString)( XW_DUtilCtxt* duc, const XP_UCHAR* (*m_dutil_getUserString)( XW_DUtilCtxt* duc, XWEnv xwe,
XP_U16 stringCode ); XP_U16 stringCode );
const XP_UCHAR* (*m_dutil_getUserQuantityString)( XW_DUtilCtxt* duc, const XP_UCHAR* (*m_dutil_getUserQuantityString)( XW_DUtilCtxt* duc,
XWEnv xwe,
XP_U16 stringCode, XP_U16 stringCode,
XP_U16 quantity ); XP_U16 quantity );
void (*m_dutil_storeStream)( XW_DUtilCtxt* duc, const XP_UCHAR* key, void (*m_dutil_storeStream)( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
XWStreamCtxt* data ); XWStreamCtxt* data );
/* Pass in an empty stream, and it'll be returned full */ /* Pass in an empty stream, and it'll be returned full */
void (*m_dutil_loadStream)( XW_DUtilCtxt* duc, const XP_UCHAR* key, void (*m_dutil_loadStream)( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
XWStreamCtxt* inOut ); XWStreamCtxt* inOut );
void (*m_dutil_storePtr)( XW_DUtilCtxt* duc, const XP_UCHAR* key, void (*m_dutil_storePtr)( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
const void* data, XP_U16 len ); const void* data, XP_U16 len );
void (*m_dutil_loadPtr)( XW_DUtilCtxt* duc, const XP_UCHAR* key, void (*m_dutil_loadPtr)( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
void* data, XP_U16* lenp ); void* data, XP_U16* lenp );
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
XP_Bool (*m_dutil_phoneNumbersSame)( XW_DUtilCtxt* uc, const XP_UCHAR* p1, XP_Bool (*m_dutil_phoneNumbersSame)( XW_DUtilCtxt* uc, XWEnv xwe, const XP_UCHAR* p1,
const XP_UCHAR* p2 ); const XP_UCHAR* p2 );
#endif #endif
#ifdef XWFEATURE_DEVID #ifdef XWFEATURE_DEVID
const XP_UCHAR* (*m_dutil_getDevID)( XW_DUtilCtxt* duc, DevIDType* typ ); const XP_UCHAR* (*m_dutil_getDevID)( XW_DUtilCtxt* duc, XWEnv xwe, DevIDType* typ );
void (*m_dutil_deviceRegistered)( XW_DUtilCtxt* duc, DevIDType typ, void (*m_dutil_deviceRegistered)( XW_DUtilCtxt* duc, XWEnv xwe, DevIDType typ,
const XP_UCHAR* idRelay ); const XP_UCHAR* idRelay );
#endif #endif
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
XP_UCHAR* (*m_dutil_md5sum)( XW_DUtilCtxt* duc, const XP_U8* ptr, XP_U16 len ); XP_UCHAR* (*m_dutil_md5sum)( XW_DUtilCtxt* duc, XWEnv xwe, const XP_U8* ptr, XP_U16 len );
#endif #endif
void (*m_dutil_notifyPause)( XW_DUtilCtxt* duc, XP_U32 gameID, void (*m_dutil_notifyPause)( XW_DUtilCtxt* duc, XWEnv xwe, XP_U32 gameID,
DupPauseType pauseTyp, XP_U16 pauser, DupPauseType pauseTyp, XP_U16 pauser,
const XP_UCHAR* name, const XP_UCHAR* msg ); const XP_UCHAR* name, const XP_UCHAR* msg );
void (*m_dutil_onDupTimerChanged)( XW_DUtilCtxt* duc, XP_U32 gameID, void (*m_dutil_onDupTimerChanged)( XW_DUtilCtxt* duc, XWEnv xwe, XP_U32 gameID,
XP_U32 oldVal, XP_U32 newVal ); XP_U32 oldVal, XP_U32 newVal );
} DUtilVtable; } DUtilVtable;
@ -80,41 +81,42 @@ struct XW_DUtilCtxt {
/* This one cheats: direct access */ /* This one cheats: direct access */
#define dutil_getVTManager(duc) (duc)->vtMgr #define dutil_getVTManager(duc) (duc)->vtMgr
#define dutil_getCurSeconds(duc) \ #define dutil_getCurSeconds(duc, e) \
(duc)->vtable.m_dutil_getCurSeconds((duc)) (duc)->vtable.m_dutil_getCurSeconds((duc), (e))
#define dutil_getUserString( duc, c ) \ #define dutil_getUserString( duc, e, c ) \
(duc)->vtable.m_dutil_getUserString((duc),(c)) (duc)->vtable.m_dutil_getUserString((duc),(e), (c))
#define dutil_getUserQuantityString( duc, c, q ) \ #define dutil_getUserQuantityString( duc, e, c, q ) \
(duc)->vtable.m_dutil_getUserQuantityString((duc),(c),(q)) (duc)->vtable.m_dutil_getUserQuantityString((duc),(e), (c),(q))
#define dutil_storeStream(duc, k, s) \ #define dutil_storeStream(duc, e,k, s) \
(duc)->vtable.m_dutil_storeStream((duc), (k), (s)); (duc)->vtable.m_dutil_storeStream((duc), (e), (k), (s));
#define dutil_storePtr(duc, k, p, l) \ #define dutil_storePtr(duc, e, k, p, l) \
(duc)->vtable.m_dutil_storePtr((duc), (k), (p), (l)); (duc)->vtable.m_dutil_storePtr((duc), (e), (k), (p), (l));
#define dutil_loadStream(duc, k, s) \ #define dutil_loadStream(duc, e, k, s) \
(duc)->vtable.m_dutil_loadStream((duc), (k), (s)); (duc)->vtable.m_dutil_loadStream((duc), (e), (k), (s));
#define dutil_loadPtr(duc, k, p, l) \ #define dutil_loadPtr(duc, e, k, p, l) \
(duc)->vtable.m_dutil_loadPtr((duc), (k), (p), (l)); (duc)->vtable.m_dutil_loadPtr((duc), (e), (k), (p), (l));
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
# define dutil_phoneNumbersSame(duc,p1,p2) \ # define dutil_phoneNumbersSame(duc,e,p1,p2) \
(duc)->vtable.m_dutil_phoneNumbersSame( (duc), (p1), (p2) ) (duc)->vtable.m_dutil_phoneNumbersSame( (duc), (e), (p1), (p2) )
#endif #endif
#ifdef XWFEATURE_DEVID #ifdef XWFEATURE_DEVID
# define dutil_getDevID( duc, t ) \ # define dutil_getDevID( duc, e, t ) \
(duc)->vtable.m_dutil_getDevID((duc),(t)) (duc)->vtable.m_dutil_getDevID((duc), (e),(t))
# define dutil_deviceRegistered( duc, typ, id ) \ # define dutil_deviceRegistered( duc, e, typ, id ) \
(duc)->vtable.m_dutil_deviceRegistered( (duc), (typ), (id) ) (duc)->vtable.m_dutil_deviceRegistered( (duc), (e), (typ), (id) )
#endif #endif
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
# define dutil_md5sum( duc, p, l ) (duc)->vtable.m_dutil_md5sum((duc), (p), (l)) # define dutil_md5sum( duc, e, p, l ) \
(duc)->vtable.m_dutil_md5sum((duc), (e), (p), (l))
#endif #endif
#define dutil_notifyPause( duc, id, ip, p, n, m ) \ #define dutil_notifyPause( duc, e, id, ip, p, n, m ) \
(duc)->vtable.m_dutil_notifyPause( (duc), (id), (ip), (p), (n), (m) ) (duc)->vtable.m_dutil_notifyPause( (duc), (e), (id), (ip), (p), (n), (m) )
#define dutil_onDupTimerChanged(duc, id, ov, nv) \ #define dutil_onDupTimerChanged(duc, e, id, ov, nv) \
(duc)->vtable.m_dutil_onDupTimerChanged( (duc), (id), (ov), (nv)) (duc)->vtable.m_dutil_onDupTimerChanged( (duc), (e), (id), (ov), (nv))
#endif #endif

View file

@ -123,30 +123,30 @@ struct EngineCtxt {
MPSLOT MPSLOT
}; /* EngineCtxt */ }; /* EngineCtxt */
static void findMovesOneRow( EngineCtxt* engine ); static void findMovesOneRow( EngineCtxt* engine, XWEnv xwe );
static Tile localGetBoardTile( EngineCtxt* engine, XP_U16 col, static Tile localGetBoardTile( EngineCtxt* engine, XP_U16 col,
XP_U16 row, XP_Bool substBlank ); XP_U16 row, XP_Bool substBlank );
static void findMovesForAnchor( EngineCtxt* engine, XP_S16* prevAnchor, static void findMovesForAnchor( EngineCtxt* engine, XWEnv xwe,
XP_U16 col, XP_U16 row ) ; XP_S16* prevAnchor, XP_U16 col, XP_U16 row ) ;
static void figureCrosschecks( EngineCtxt* engine, XP_U16 col, static void figureCrosschecks( EngineCtxt* engine, XP_U16 col,
XP_U16 row, XP_U16* scoreP, XP_U16 row, XP_U16* scoreP,
Crosscheck* check ); Crosscheck* check );
static XP_Bool isAnchorSquare( EngineCtxt* engine, XP_U16 col, XP_U16 row ); static XP_Bool isAnchorSquare( EngineCtxt* engine, XP_U16 col, XP_U16 row );
static array_edge* edge_from_tile( const DictionaryCtxt* dict, static array_edge* edge_from_tile( const DictionaryCtxt* dict,
array_edge* from, Tile tile ); array_edge* from, Tile tile );
static void leftPart( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength, static void leftPart( EngineCtxt* engine, XWEnv xwe, Tile* tiles, XP_U16 tileLength,
array_edge* edge, XP_U16 limit, XP_U16 firstCol, array_edge* edge, XP_U16 limit, XP_U16 firstCol,
XP_U16 anchorCol, XP_U16 row ); XP_U16 anchorCol, XP_U16 row );
static void extendRight( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength, static void extendRight( EngineCtxt* engine, XWEnv xwe, Tile* tiles, XP_U16 tileLength,
array_edge* edge, XP_Bool accepting, array_edge* edge, XP_Bool accepting,
XP_U16 firstCol, XP_U16 col, XP_U16 row ); XP_U16 firstCol, XP_U16 col, XP_U16 row );
static array_edge* consumeFromLeft( EngineCtxt* engine, array_edge* edge, static array_edge* consumeFromLeft( EngineCtxt* engine, array_edge* edge,
short col, short row ); short col, short row );
static XP_Bool rack_remove( EngineCtxt* engine, Tile tile, XP_Bool* isBlank ); static XP_Bool rack_remove( EngineCtxt* engine, Tile tile, XP_Bool* isBlank );
static void rack_replace( EngineCtxt* engine, Tile tile, XP_Bool isBlank ); static void rack_replace( EngineCtxt* engine, Tile tile, XP_Bool isBlank );
static void considerMove( EngineCtxt* engine, Tile* tiles, short tileLength, static void considerMove( EngineCtxt* engine, XWEnv xwe, Tile* tiles, short tileLength,
short firstCol, short lastRow ); short firstCol, short lastRow );
static void considerScoreWordHasBlanks( EngineCtxt* engine, XP_U16 blanksLeft, static void considerScoreWordHasBlanks( EngineCtxt* engine, XWEnv xwe, XP_U16 blanksLeft,
PossibleMove* posmove, PossibleMove* posmove,
XP_U16 lastRow, XP_U16 lastRow,
BlankTuple* usedBlanks, BlankTuple* usedBlanks,
@ -170,8 +170,8 @@ static XP_S16 cmpMoves( PossibleMove* m1, PossibleMove* m2 );
/* #define CROSSCHECK_CONTAINS(chk,tile) (((chk) & (1L<<(tile))) != 0) */ /* #define CROSSCHECK_CONTAINS(chk,tile) (((chk) & (1L<<(tile))) != 0) */
#define CROSSCHECK_CONTAINS(chk,tile) checkIsSet( (chk), (tile) ) #define CROSSCHECK_CONTAINS(chk,tile) checkIsSet( (chk), (tile) )
#define HILITE_CELL( engine, col, row ) \ #define HILITE_CELL( engine, xwe, col, row ) \
util_hiliteCell( (engine)->util, (col), (row) ) util_hiliteCell( (engine)->util, (xwe), (col), (row) )
/* not implemented yet */ /* not implemented yet */
XP_U16 XP_U16
@ -377,7 +377,7 @@ normalizeIQ( EngineCtxt* engine, XP_U16 iq )
* filled in in *newMove. * filled in in *newMove.
*/ */
XP_Bool XP_Bool
engine_findMove( EngineCtxt* engine, const ModelCtxt* model, engine_findMove( EngineCtxt* engine, XWEnv xwe, const ModelCtxt* model,
XP_S16 turn, XP_Bool includePending, XP_Bool skipCallback, XP_S16 turn, XP_Bool includePending, XP_Bool skipCallback,
const Tile* tiles, const XP_U16 nTiles, XP_Bool usePrev, const Tile* tiles, const XP_U16 nTiles, XP_Bool usePrev,
#ifdef XWFEATURE_BONUSALL #ifdef XWFEATURE_BONUSALL
@ -410,7 +410,7 @@ engine_findMove( EngineCtxt* engine, const ModelCtxt* model,
XP_U16 nTilesMin = engine->nTilesMinUser; XP_U16 nTilesMin = engine->nTilesMinUser;
XP_U16 nTilesMax = engine->nTilesMaxUser; XP_U16 nTilesMax = engine->nTilesMaxUser;
if ( util_getTraySearchLimits( engine->util, if ( util_getTraySearchLimits( engine->util, xwe,
&nTilesMin, &nTilesMax ) ) { &nTilesMin, &nTilesMax ) ) {
engine->tileLimitsKnown = XP_TRUE; engine->tileLimitsKnown = XP_TRUE;
engine->nTilesMinUser = nTilesMin; engine->nTilesMinUser = nTilesMin;
@ -454,7 +454,7 @@ engine_findMove( EngineCtxt* engine, const ModelCtxt* model,
&& initTray( engine, tiles, nTiles ); && initTray( engine, tiles, nTiles );
if ( canMove ) { if ( canMove ) {
util_engineStarting( engine->util, util_engineStarting( engine->util, xwe,
engine->rack[engine->blankTile] ); engine->rack[engine->blankTile] );
normalizeIQ( engine, robotIQ ); normalizeIQ( engine, robotIQ );
@ -503,7 +503,7 @@ engine_findMove( EngineCtxt* engine, const ModelCtxt* model,
if ( engine->isFirstMove && (engine->curRow != star_row)) { if ( engine->isFirstMove && (engine->curRow != star_row)) {
continue; continue;
} }
findMovesOneRow( engine ); findMovesOneRow( engine, xwe );
if ( engine->returnNOW ) { if ( engine->returnNOW ) {
goto outer; goto outer;
} }
@ -540,7 +540,7 @@ engine_findMove( EngineCtxt* engine, const ModelCtxt* model,
XP_ASSERT( result ); XP_ASSERT( result );
} }
util_engineStopping( engine->util ); util_engineStopping( engine->util, xwe );
} else { } else {
/* set up a PASS. I suspect the caller should be deciding how to /* set up a PASS. I suspect the caller should be deciding how to
handle this case itself, but this doesn't preclude its doing handle this case itself, but this doesn't preclude its doing
@ -573,7 +573,7 @@ engine_findMove( EngineCtxt* engine, const ModelCtxt* model,
} /* engine_findMove */ } /* engine_findMove */
static void static void
findMovesOneRow( EngineCtxt* engine ) findMovesOneRow( EngineCtxt* engine, XWEnv xwe )
{ {
XP_U16 lastCol = engine->numCols - 1; XP_U16 lastCol = engine->numCols - 1;
XP_U16 col, row = engine->curRow; XP_U16 col, row = engine->curRow;
@ -614,7 +614,7 @@ findMovesOneRow( EngineCtxt* engine )
for ( col = firstSearchCol; col <= lastSearchCol && !engine->returnNOW; for ( col = firstSearchCol; col <= lastSearchCol && !engine->returnNOW;
++col ) { ++col ) {
if ( isAnchorSquare( engine, col, row ) ) { if ( isAnchorSquare( engine, col, row ) ) {
findMovesForAnchor( engine, &prevAnchor, col, row ); findMovesForAnchor( engine, xwe, &prevAnchor, col, row );
} }
} }
} /* findMovesOneRow */ } /* findMovesOneRow */
@ -824,7 +824,7 @@ isAnchorSquare( EngineCtxt* engine, XP_U16 col, XP_U16 row )
#ifdef XWFEATURE_HILITECELL #ifdef XWFEATURE_HILITECELL
static void static void
hiliteForAnchor( EngineCtxt* engine, XP_U16 col, XP_U16 row ) hiliteForAnchor( EngineCtxt* engine, XWEnv xwe, XP_U16 col, XP_U16 row )
{ {
if ( !engine->searchHorizontal ) { if ( !engine->searchHorizontal ) {
XP_U16 tmp = col; XP_U16 tmp = col;
@ -832,16 +832,16 @@ hiliteForAnchor( EngineCtxt* engine, XP_U16 col, XP_U16 row )
row = tmp; row = tmp;
} }
if ( !HILITE_CELL( engine, col, row ) ) { if ( !HILITE_CELL( engine, xwe, col, row ) ) {
engine->returnNOW = XP_TRUE; engine->returnNOW = XP_TRUE;
} }
} /* hiliteForAnchor */ } /* hiliteForAnchor */
#else #else
# define hiliteForAnchor( engine, col, row ) # define hiliteForAnchor( engine, xwe, col, row )
#endif #endif
static void static void
findMovesForAnchor( EngineCtxt* engine, XP_S16* prevAnchor, findMovesForAnchor( EngineCtxt* engine, XWEnv xwe, XP_S16* prevAnchor,
XP_U16 col, XP_U16 row ) XP_U16 col, XP_U16 row )
{ {
XP_S16 limit; XP_S16 limit;
@ -849,7 +849,7 @@ findMovesForAnchor( EngineCtxt* engine, XP_S16* prevAnchor,
array_edge* topEdge; array_edge* topEdge;
Tile tiles[MAX_ROWS]; Tile tiles[MAX_ROWS];
hiliteForAnchor( engine, col, row ); hiliteForAnchor( engine, xwe, col, row );
if ( engine->returnNOW ) { if ( engine->returnNOW ) {
/* time to bail */ /* time to bail */
@ -865,13 +865,13 @@ findMovesForAnchor( EngineCtxt* engine, XP_S16* prevAnchor,
edge = topEdge; edge = topEdge;
} else if ( localGetBoardTile( engine, col-1, row, XP_FALSE ) } else if ( localGetBoardTile( engine, col-1, row, XP_FALSE )
== EMPTY_TILE ) { == EMPTY_TILE ) {
leftPart( engine, tiles, 0, topEdge, limit, col, col, row ); leftPart( engine, xwe, tiles, 0, topEdge, limit, col, col, row );
goto done; goto done;
} else { } else {
edge = consumeFromLeft( engine, topEdge, col, row ); edge = consumeFromLeft( engine, topEdge, col, row );
} }
DEBUG_ASSIGN(engine->curLimit, 0); DEBUG_ASSIGN(engine->curLimit, 0);
extendRight( engine, tiles, 0, edge, extendRight( engine, xwe, tiles, 0, edge,
XP_FALSE, // can't accept without the anchor square XP_FALSE, // can't accept without the anchor square
col-limit, col, row ); col-limit, col, row );
@ -913,13 +913,13 @@ consumeFromLeft( EngineCtxt* engine, array_edge* edge, short col, short row )
} /* consumeFromLeft */ } /* consumeFromLeft */
static void static void
leftPart( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength, leftPart( EngineCtxt* engine, XWEnv xwe, Tile* tiles, XP_U16 tileLength,
array_edge* edge, XP_U16 limit, XP_U16 firstCol, array_edge* edge, XP_U16 limit, XP_U16 firstCol,
XP_U16 anchorCol, XP_U16 row ) XP_U16 anchorCol, XP_U16 row )
{ {
DEBUG_ASSIGN( engine->curLimit, tileLength ); DEBUG_ASSIGN( engine->curLimit, tileLength );
extendRight( engine, tiles, tileLength, edge, XP_FALSE, firstCol, extendRight( engine, xwe, tiles, tileLength, edge, XP_FALSE, firstCol,
anchorCol, row ); anchorCol, row );
if ( !engine->returnNOW ) { if ( !engine->returnNOW ) {
if ( (limit > 0) && (edge != NULL) ) { if ( (limit > 0) && (edge != NULL) ) {
@ -930,7 +930,7 @@ leftPart( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength,
Tile tile = EDGETILE( engine->dict, edge ); Tile tile = EDGETILE( engine->dict, edge );
if ( rack_remove( engine, tile, &isBlank ) ) { if ( rack_remove( engine, tile, &isBlank ) ) {
tiles[tileLength] = tile; tiles[tileLength] = tile;
leftPart( engine, tiles, tileLength+1, leftPart( engine, xwe, tiles, tileLength+1,
dict_follow( engine->dict, edge ), dict_follow( engine->dict, edge ),
limit-1, firstCol-1, anchorCol, row ); limit-1, firstCol-1, anchorCol, row );
rack_replace( engine, tile, isBlank ); rack_replace( engine, tile, isBlank );
@ -947,7 +947,7 @@ leftPart( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength,
} /* leftPart */ } /* leftPart */
static void static void
extendRight( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength, extendRight( EngineCtxt* engine, XWEnv xwe, Tile* tiles, XP_U16 tileLength,
array_edge* edge, XP_Bool accepting, array_edge* edge, XP_Bool accepting,
XP_U16 firstCol, XP_U16 col, XP_U16 row ) XP_U16 firstCol, XP_U16 col, XP_U16 row )
{ {
@ -989,7 +989,7 @@ extendRight( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength,
XP_Bool isBlank; XP_Bool isBlank;
if ( rack_remove( engine, tile, &isBlank ) ) { if ( rack_remove( engine, tile, &isBlank ) ) {
tiles[tileLength] = tile; tiles[tileLength] = tile;
extendRight( engine, tiles, tileLength+1, extendRight( engine, xwe, tiles, tileLength+1,
edge_from_tile( dict, edge, tile ), edge_from_tile( dict, edge, tile ),
ISACCEPTING( dict, edge ), firstCol, ISACCEPTING( dict, edge ), firstCol,
col+1, row ); col+1, row );
@ -1009,7 +1009,7 @@ extendRight( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength,
} else if ( (edge = dict_edge_with_tile( dict, edge, tile ) ) != NULL ) { } else if ( (edge = dict_edge_with_tile( dict, edge, tile ) ) != NULL ) {
accepting = ISACCEPTING( dict, edge ); accepting = ISACCEPTING( dict, edge );
extendRight( engine, tiles, tileLength, dict_follow(dict, edge), extendRight( engine, xwe, tiles, tileLength, dict_follow(dict, edge),
accepting, firstCol, col+1, row ); accepting, firstCol, col+1, row );
goto no_check; /* don't do the check at the end */ goto no_check; /* don't do the check at the end */
} else { } else {
@ -1021,7 +1021,7 @@ extendRight( EngineCtxt* engine, Tile* tiles, XP_U16 tileLength,
&& tileLength >= engine->nTilesMin && tileLength >= engine->nTilesMin
#endif #endif
) { ) {
considerMove( engine, tiles, tileLength, firstCol, row ); considerMove( engine, xwe, tiles, tileLength, firstCol, row );
} }
no_check: no_check:
return; return;
@ -1065,14 +1065,15 @@ rack_replace( EngineCtxt* engine, Tile tile, XP_Bool isBlank )
} /* rack_replace */ } /* rack_replace */
static void static void
considerMove( EngineCtxt* engine, Tile* tiles, XP_S16 tileLength, considerMove( EngineCtxt* engine, XWEnv xwe, Tile* tiles, XP_S16 tileLength,
XP_S16 firstCol, XP_S16 lastRow ) XP_S16 firstCol, XP_S16 lastRow )
{ {
PossibleMove posmove; PossibleMove posmove;
short col; short col;
BlankTuple blankTuples[MAX_NUM_BLANKS]; BlankTuple blankTuples[MAX_NUM_BLANKS];
if ( !engine->skipProgressCallback && !util_engineProgressCallback( engine->util ) ) { if ( !engine->skipProgressCallback
&& !util_engineProgressCallback( engine->util, xwe ) ) {
engine->returnNOW = XP_TRUE; engine->returnNOW = XP_TRUE;
} else { } else {
@ -1098,7 +1099,7 @@ considerMove( EngineCtxt* engine, Tile* tiles, XP_S16 tileLength,
posmove.moveInfo.isHorizontal = engine->searchHorizontal; posmove.moveInfo.isHorizontal = engine->searchHorizontal;
posmove.moveInfo.commonCoord = (XP_U8)lastRow; posmove.moveInfo.commonCoord = (XP_U8)lastRow;
considerScoreWordHasBlanks( engine, engine->blankCount, &posmove, considerScoreWordHasBlanks( engine, xwe, engine->blankCount, &posmove,
lastRow, blankTuples, 0 ); lastRow, blankTuples, 0 );
} }
} /* considerMove */ } /* considerMove */
@ -1113,7 +1114,7 @@ countWords( const WNParams* wnp, void* closure )
} }
static void static void
considerScoreWordHasBlanks( EngineCtxt* engine, XP_U16 blanksLeft, considerScoreWordHasBlanks( EngineCtxt* engine, XWEnv xwe, XP_U16 blanksLeft,
PossibleMove* posmove, PossibleMove* posmove,
XP_U16 lastRow, BlankTuple* usedBlanks, XP_U16 lastRow, BlankTuple* usedBlanks,
XP_U16 usedBlanksCount ) XP_U16 usedBlanksCount )
@ -1137,7 +1138,7 @@ considerScoreWordHasBlanks( EngineCtxt* engine, XP_U16 blanksLeft,
wiip = &wii; wiip = &wii;
} }
XP_U16 score = figureMoveScore( engine->model, engine->turn, XP_U16 score = figureMoveScore( engine->model, xwe, engine->turn,
&posmove->moveInfo, &posmove->moveInfo,
engine, (XWStreamCtxt*)NULL, wiip ); engine, (XWStreamCtxt*)NULL, wiip );
@ -1179,7 +1180,7 @@ considerScoreWordHasBlanks( EngineCtxt* engine, XP_U16 blanksLeft,
posmove->moveInfo.tiles[ii].tile |= TILE_BLANK_BIT; posmove->moveInfo.tiles[ii].tile |= TILE_BLANK_BIT;
bt->col = ii; bt->col = ii;
bt->tile = bTile; bt->tile = bTile;
considerScoreWordHasBlanks( engine, blanksLeft, considerScoreWordHasBlanks( engine, xwe, blanksLeft,
posmove, lastRow, posmove, lastRow,
usedBlanks, usedBlanks,
usedBlanksCount ); usedBlanksCount );

View file

@ -48,7 +48,7 @@ void engine_init( EngineCtxt* ctxt );
void engine_reset( EngineCtxt* ctxt ); void engine_reset( EngineCtxt* ctxt );
void engine_destroy( EngineCtxt* ctxt ); void engine_destroy( EngineCtxt* ctxt );
XP_Bool engine_findMove( EngineCtxt* ctxt, const ModelCtxt* model, XP_S16 turn, XP_Bool engine_findMove( EngineCtxt* ctxt, XWEnv xwe, const ModelCtxt* model, XP_S16 turn,
/* includePending: include pending tiles as part of words */ /* includePending: include pending tiles as part of words */
XP_Bool includePending, XP_Bool includePending,
/* skipCallback: skip the callback that lets client cancel */ /* skipCallback: skip the callback that lets client cancel */

View file

@ -75,24 +75,24 @@ checkServerRole( CurGameInfo* gi, XP_U16* nPlayersHere,
} /* checkServerRole */ } /* checkServerRole */
static XP_U32 static XP_U32
makeGameID( XW_UtilCtxt* util ) makeGameID( XW_UtilCtxt* util, XWEnv xwe )
{ {
XP_U32 gameID = 0; XP_U32 gameID = 0;
assertUtilOK( util ); assertUtilOK( util );
while ( 0 == gameID ) { while ( 0 == gameID ) {
gameID = dutil_getCurSeconds( util_getDevUtilCtxt( util ) ); gameID = dutil_getCurSeconds( util_getDevUtilCtxt( util, xwe ), xwe );
} }
return gameID; return gameID;
} }
static void static void
timerChangeListener( void* data, const XP_U32 gameID, timerChangeListener( XWEnv xwe, void* data, const XP_U32 gameID,
XP_S32 oldVal, XP_S32 newVal ) XP_S32 oldVal, XP_S32 newVal )
{ {
XWGame* game = (XWGame*)data; XWGame* game = (XWGame*)data;
XP_ASSERT( game->util->gameInfo->gameID == gameID ); XP_ASSERT( game->util->gameInfo->gameID == gameID );
XP_LOGF( "%s(oldVal=%d, newVal=%d, id=%d)", __func__, oldVal, newVal, gameID ); XP_LOGF( "%s(oldVal=%d, newVal=%d, id=%d)", __func__, oldVal, newVal, gameID );
dutil_onDupTimerChanged( util_getDevUtilCtxt( game->util ), dutil_onDupTimerChanged( util_getDevUtilCtxt( game->util, xwe ), xwe,
gameID, oldVal, newVal ); gameID, oldVal, newVal );
} }
@ -121,7 +121,7 @@ game_makeNewGame( MPFORMAL XWEnv xwe, XWGame* game, CurGameInfo* gi,
assertUtilOK( util ); assertUtilOK( util );
if ( 0 == gi->gameID ) { if ( 0 == gi->gameID ) {
gi->gameID = makeGameID( util ); gi->gameID = makeGameID( util, xwe );
} }
game->util = util; game->util = util;
@ -143,16 +143,16 @@ game_makeNewGame( MPFORMAL XWEnv xwe, XWGame* game, CurGameInfo* gi,
game->comms = (CommsCtxt*)NULL; game->comms = (CommsCtxt*)NULL;
} }
#endif #endif
game->server = server_make( MPPARM(mpool) game->model, game->server = server_make( MPPARM(mpool) xwe, game->model,
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
game->comms, game->comms,
#else #else
(CommsCtxt*)NULL, (CommsCtxt*)NULL,
#endif #endif
util ); util );
game->board = board_make( MPPARM(mpool) game->model, game->server, game->board = board_make( MPPARM(mpool) xwe, game->model, game->server,
NULL, util ); NULL, util );
board_setCallbacks( game->board ); board_setCallbacks( game->board, xwe );
board_setDraw( game->board, xwe, draw ); board_setDraw( game->board, xwe, draw );
setListeners( game, cp ); setListeners( game, cp );
@ -170,7 +170,7 @@ game_reset( MPFORMAL XWGame* game, XWEnv xwe, CurGameInfo* gi, XW_UtilCtxt* util
XP_ASSERT( !!game->model ); XP_ASSERT( !!game->model );
XP_ASSERT( !!gi ); XP_ASSERT( !!gi );
gi->gameID = makeGameID( util ); gi->gameID = makeGameID( util, xwe );
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
XP_U16 nPlayersHere = 0; XP_U16 nPlayersHere = 0;
@ -179,7 +179,7 @@ game_reset( MPFORMAL XWGame* game, XWEnv xwe, CurGameInfo* gi, XW_UtilCtxt* util
if ( !!game->comms ) { if ( !!game->comms ) {
if ( gi->serverRole == SERVER_STANDALONE ) { if ( gi->serverRole == SERVER_STANDALONE ) {
comms_destroy( game->comms ); comms_destroy( game->comms, xwe );
game->comms = NULL; game->comms = NULL;
} else { } else {
comms_reset( game->comms, xwe, gi->serverRole != SERVER_ISCLIENT, comms_reset( game->comms, xwe, gi->serverRole != SERVER_ISCLIENT,
@ -209,7 +209,7 @@ game_reset( MPFORMAL XWGame* game, XWEnv xwe, CurGameInfo* gi, XW_UtilCtxt* util
NULL NULL
#endif #endif
); );
board_reset( game->board ); board_reset( game->board, xwe );
for ( ii = 0; ii < gi->nPlayers; ++ii ) { for ( ii = 0; ii < gi->nPlayers; ++ii ) {
gi->players[ii].secondsUsed = 0; gi->players[ii].secondsUsed = 0;
@ -287,11 +287,11 @@ game_makeFromStream( MPFORMAL XWEnv xwe, XWStreamCtxt* stream, XWGame* game,
game->model = model_makeFromStream( MPPARM(mpool) xwe, stream, dict, game->model = model_makeFromStream( MPPARM(mpool) xwe, stream, dict,
dicts, util ); dicts, util );
game->server = server_makeFromStream( MPPARM(mpool) stream, game->server = server_makeFromStream( MPPARM(mpool) xwe, stream,
game->model, game->comms, game->model, game->comms,
util, gi->nPlayers ); util, gi->nPlayers );
game->board = board_makeFromStream( MPPARM(mpool) stream, game->board = board_makeFromStream( MPPARM(mpool) xwe, stream,
game->model, game->server, game->model, game->server,
NULL, util, gi->nPlayers ); NULL, util, gi->nPlayers );
setListeners( game, cp ); setListeners( game, cp );
@ -387,7 +387,7 @@ game_receiveMessage( XWGame* game, XWEnv xwe, XWStreamCtxt* stream,
} }
void void
game_getState( const XWGame* game, GameStateInfo* gsi ) game_getState( const XWGame* game, XWEnv xwe, GameStateInfo* gsi )
{ {
const ServerCtxt* server = game->server; const ServerCtxt* server = game->server;
BoardCtxt* board = game->board; BoardCtxt* board = game->board;
@ -403,7 +403,7 @@ game_getState( const XWGame* game, GameStateInfo* gsi )
gsi->canChat = !!game->comms && comms_canChat( game->comms ); gsi->canChat = !!game->comms && comms_canChat( game->comms );
gsi->canShuffle = board_canShuffle( board ); gsi->canShuffle = board_canShuffle( board );
gsi->canHideRack = board_canHideRack( board ); gsi->canHideRack = board_canHideRack( board );
gsi->canTrade = board_canTrade( board ); gsi->canTrade = board_canTrade( board, xwe );
gsi->nPendingMessages = !!game->comms ? gsi->nPendingMessages = !!game->comms ?
comms_countPendingPackets(game->comms) : 0; comms_countPendingPackets(game->comms) : 0;
@ -423,14 +423,14 @@ game_dispose( XWGame* game, XWEnv xwe )
{ {
/* The board should be reused!!! PENDING(ehouse) */ /* The board should be reused!!! PENDING(ehouse) */
if ( !!game->board ) { if ( !!game->board ) {
board_destroy( game->board, XP_TRUE ); board_destroy( game->board, xwe, XP_TRUE );
game->board = NULL; game->board = NULL;
} }
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
if ( !!game->comms ) { if ( !!game->comms ) {
comms_stop( game->comms, xwe ); comms_stop( game->comms, xwe );
comms_destroy( game->comms ); comms_destroy( game->comms, xwe );
game->comms = NULL; game->comms = NULL;
} }
#endif #endif

View file

@ -92,7 +92,7 @@ XP_Bool game_receiveMessage( XWGame* game, XWEnv xwe, XWStreamCtxt* stream,
void game_dispose( XWGame* game, XWEnv xwe ); void game_dispose( XWGame* game, XWEnv xwe );
void game_getState( const XWGame* game, GameStateInfo* gsi ); void game_getState( const XWGame* game, XWEnv xwe, GameStateInfo* gsi );
XP_Bool game_getIsServer( const XWGame* game ); XP_Bool game_getIsServer( const XWGame* game );
void gi_initPlayerInfo( MPFORMAL CurGameInfo* gi, void gi_initPlayerInfo( MPFORMAL CurGameInfo* gi,

View file

@ -38,15 +38,15 @@ extern "C" {
#define MAX_PASSES 2 /* how many times can all players pass? */ #define MAX_PASSES 2 /* how many times can all players pass? */
/****************************** prototypes ******************************/ /****************************** prototypes ******************************/
typedef void (*MovePrintFuncPre)(ModelCtxt*, XP_U16, const StackEntry*, void*); typedef void (*MovePrintFuncPre)(ModelCtxt*, XWEnv, XP_U16, const StackEntry*, void*);
typedef void (*MovePrintFuncPost)(ModelCtxt*, XP_U16, const StackEntry*, typedef void (*MovePrintFuncPost)(ModelCtxt*, XWEnv, XP_U16, const StackEntry*,
XP_S16, void*); XP_S16, void*);
static void incrPendingTileCountAt( ModelCtxt* model, XP_U16 col, static void incrPendingTileCountAt( ModelCtxt* model, XP_U16 col,
XP_U16 row ); XP_U16 row );
static void decrPendingTileCountAt( ModelCtxt* model, XP_U16 col, static void decrPendingTileCountAt( ModelCtxt* model, XP_U16 col,
XP_U16 row ); XP_U16 row );
static void notifyBoardListeners( ModelCtxt* model, XP_U16 turn, static void notifyBoardListeners( ModelCtxt* model, XWEnv xwe, XP_U16 turn,
XP_U16 col, XP_U16 row, XP_Bool added ); XP_U16 col, XP_U16 row, XP_Bool added );
static void notifyTrayListeners( ModelCtxt* model, XP_U16 turn, static void notifyTrayListeners( ModelCtxt* model, XP_U16 turn,
XP_S16 index1, XP_S16 index2 ); XP_S16 index1, XP_S16 index2 );
@ -83,7 +83,7 @@ typedef struct _DiffTurnState {
XP_S16 lastPlayerNum; XP_S16 lastPlayerNum;
XP_S16 lastMoveNum; XP_S16 lastMoveNum;
} DiffTurnState; } DiffTurnState;
static void assertDiffTurn( ModelCtxt* model, XP_U16 turn, static void assertDiffTurn( ModelCtxt* model, XWEnv xwe, XP_U16 turn,
const StackEntry* entry, void* closure); const StackEntry* entry, void* closure);
#endif #endif
@ -100,7 +100,7 @@ model_make( MPFORMAL XWEnv xwe, DictionaryCtxt* dict, const PlayerDicts* dicts,
MPASSIGN(result->vol.mpool, mpool); MPASSIGN(result->vol.mpool, mpool);
result->vol.util = util; result->vol.util = util;
result->vol.dutil = util_getDevUtilCtxt( util ); result->vol.dutil = util_getDevUtilCtxt( util, xwe );
result->vol.wni.proc = recordWord; result->vol.wni.proc = recordWord;
result->vol.wni.closure = &result->vol.rwi; result->vol.wni.closure = &result->vol.rwi;
@ -328,7 +328,7 @@ model_hashMatches( const ModelCtxt* model, const XP_U32 hash )
} }
XP_Bool XP_Bool
model_popToHash( ModelCtxt* model, const XP_U32 hash, PoolContext* pool ) model_popToHash( ModelCtxt* model, XWEnv xwe, const XP_U32 hash, PoolContext* pool )
{ {
LOG_FUNC(); LOG_FUNC();
XP_U16 nPopped = 0; XP_U16 nPopped = 0;
@ -366,7 +366,7 @@ model_popToHash( ModelCtxt* model, const XP_U32 hash, PoolContext* pool )
#ifdef DEBUG #ifdef DEBUG
XP_Bool success = XP_Bool success =
#endif #endif
model_undoLatestMoves( model, pool, foundAt, NULL, NULL ); model_undoLatestMoves( model, xwe, pool, foundAt, NULL, NULL );
XP_ASSERT( success ); XP_ASSERT( success );
} }
/* Assert not needed for long */ /* Assert not needed for long */
@ -405,7 +405,7 @@ model_setSquareBonuses( ModelCtxt* model, XWBonusType* bonuses, XP_U16 nBonuses
#endif #endif
XWBonusType XWBonusType
model_getSquareBonus( const ModelCtxt* model, XP_U16 col, XP_U16 row ) model_getSquareBonus( const ModelCtxt* model, XWEnv xwe, XP_U16 col, XP_U16 row )
{ {
XWBonusType result = BONUS_NONE; XWBonusType result = BONUS_NONE;
#ifdef STREAM_VERS_BIGBOARD #ifdef STREAM_VERS_BIGBOARD
@ -437,7 +437,8 @@ model_getSquareBonus( const ModelCtxt* model, XP_U16 col, XP_U16 row )
} }
#endif #endif
} else { } else {
result = util_getSquareBonus( model->vol.util, model_numRows(model), result = util_getSquareBonus( model->vol.util, xwe,
model_numRows(model),
col, row ); col, row );
} }
return result; return result;
@ -448,7 +449,7 @@ makeAndCommit( ModelCtxt* model, XWEnv xwe, XP_U16 turn, const MoveInfo* mi,
const TrayTileSet* tiles, XWStreamCtxt* stream, const TrayTileSet* tiles, XWStreamCtxt* stream,
XP_Bool useStack, WordNotifierInfo* wni ) XP_Bool useStack, WordNotifierInfo* wni )
{ {
model_makeTurnFromMoveInfo( model, turn, mi ); model_makeTurnFromMoveInfo( model, xwe, turn, mi );
XP_U16 moveScore = commitTurn( model, xwe, turn, tiles, XP_U16 moveScore = commitTurn( model, xwe, turn, tiles,
stream, wni, useStack ); stream, wni, useStack );
return moveScore; return moveScore;
@ -464,13 +465,13 @@ dupe_adjustScores( ModelCtxt* model, XP_Bool add, XP_U16 nScores, const XP_U16*
} }
void void
model_cloneDupeTrays( ModelCtxt* model ) model_cloneDupeTrays( ModelCtxt* model, XWEnv xwe )
{ {
XP_ASSERT( model->vol.gi->inDuplicateMode ); XP_ASSERT( model->vol.gi->inDuplicateMode );
XP_U16 nTiles = model->players[DUP_PLAYER].trayTiles.nTiles; XP_U16 nTiles = model->players[DUP_PLAYER].trayTiles.nTiles;
for ( XP_U16 ii = 0; ii < model->nPlayers; ++ii ) { for ( XP_U16 ii = 0; ii < model->nPlayers; ++ii ) {
if ( ii != DUP_PLAYER ) { if ( ii != DUP_PLAYER ) {
model_resetCurrentTurn( model, ii ); model_resetCurrentTurn( model, xwe, ii );
model->players[ii].trayTiles = model->players[DUP_PLAYER].trayTiles; model->players[ii].trayTiles = model->players[DUP_PLAYER].trayTiles;
notifyTrayListeners( model, ii, 0, nTiles ); notifyTrayListeners( model, ii, 0, nTiles );
} }
@ -485,7 +486,7 @@ modelAddEntry( ModelCtxt* model, XWEnv xwe, XP_U16 indx, const StackEntry* entry
{ {
XP_S16 moveScore = 0; /* keep compiler happy */ XP_S16 moveScore = 0; /* keep compiler happy */
if ( !!mpf_pre ) { if ( !!mpf_pre ) {
(*mpf_pre)( model, indx, entry, closure ); (*mpf_pre)( model, xwe, indx, entry, closure );
} }
switch ( entry->moveType ) { switch ( entry->moveType ) {
@ -496,7 +497,7 @@ modelAddEntry( ModelCtxt* model, XWEnv xwe, XP_U16 indx, const StackEntry* entry
XP_ASSERT( DUP_PLAYER == entry->playerNum ); XP_ASSERT( DUP_PLAYER == entry->playerNum );
dupe_adjustScores( model, XP_TRUE, entry->u.move.dup.nScores, dupe_adjustScores( model, XP_TRUE, entry->u.move.dup.nScores,
entry->u.move.dup.scores ); entry->u.move.dup.scores );
model_cloneDupeTrays( model ); model_cloneDupeTrays( model, xwe );
} }
break; break;
case TRADE_TYPE: case TRADE_TYPE:
@ -504,24 +505,24 @@ modelAddEntry( ModelCtxt* model, XWEnv xwe, XP_U16 indx, const StackEntry* entry
&entry->u.trade.newTiles ); &entry->u.trade.newTiles );
if ( model->vol.gi->inDuplicateMode ) { if ( model->vol.gi->inDuplicateMode ) {
XP_ASSERT( DUP_PLAYER == entry->playerNum ); XP_ASSERT( DUP_PLAYER == entry->playerNum );
model_cloneDupeTrays( model ); model_cloneDupeTrays( model, xwe );
} }
break; break;
case ASSIGN_TYPE: case ASSIGN_TYPE:
model_addNewTiles( model, entry->playerNum, &entry->u.assign.tiles ); model_addNewTiles( model, entry->playerNum, &entry->u.assign.tiles );
if ( model->vol.gi->inDuplicateMode ) { if ( model->vol.gi->inDuplicateMode ) {
XP_ASSERT( DUP_PLAYER == entry->playerNum ); XP_ASSERT( DUP_PLAYER == entry->playerNum );
model_cloneDupeTrays( model ); model_cloneDupeTrays( model, xwe );
} }
break; break;
case PHONY_TYPE: /* nothing to add */ case PHONY_TYPE: /* nothing to add */
model_makeTurnFromMoveInfo( model, entry->playerNum, model_makeTurnFromMoveInfo( model, xwe, entry->playerNum,
&entry->u.phony.moveInfo); &entry->u.phony.moveInfo);
/* do something here to cause it to print */ /* do something here to cause it to print */
(void)getCurrentMoveScoreIfLegal( model, xwe, entry->playerNum, stream, (void)getCurrentMoveScoreIfLegal( model, xwe, entry->playerNum, stream,
wni, &moveScore ); wni, &moveScore );
moveScore = 0; moveScore = 0;
model_resetCurrentTurn( model, entry->playerNum ); model_resetCurrentTurn( model, xwe, entry->playerNum );
break; break;
case PAUSE_TYPE: case PAUSE_TYPE:
@ -532,7 +533,7 @@ modelAddEntry( ModelCtxt* model, XWEnv xwe, XP_U16 indx, const StackEntry* entry
} }
if ( !!mpf_post ) { if ( !!mpf_post ) {
(*mpf_post)( model, indx, entry, moveScore, closure ); (*mpf_post)( model, xwe, indx, entry, moveScore, closure );
} }
} /* modelAddEntry */ } /* modelAddEntry */
@ -747,7 +748,7 @@ model_listPlacedBlanks( ModelCtxt* model, XP_U16 turn,
} /* model_listPlacedBlanks */ } /* model_listPlacedBlanks */
void void
model_foreachPrevCell( ModelCtxt* model, BoardListener bl, void* closure ) model_foreachPrevCell( ModelCtxt* model, XWEnv xwe, BoardListener bl, void* closure )
{ {
XP_U16 col, row; XP_U16 col, row;
@ -755,41 +756,41 @@ model_foreachPrevCell( ModelCtxt* model, BoardListener bl, void* closure )
for ( row = 0; row < model->nRows; ++row) { for ( row = 0; row < model->nRows; ++row) {
CellTile tile = getModelTileRaw( model, col, row ); CellTile tile = getModelTileRaw( model, col, row );
if ( (tile & PREV_MOVE_BIT) != 0 ) { if ( (tile & PREV_MOVE_BIT) != 0 ) {
(*bl)( closure, (XP_U16)CELL_OWNER(tile), col, row, XP_FALSE ); (*bl)( xwe, closure, (XP_U16)CELL_OWNER(tile), col, row, XP_FALSE );
} }
} }
} }
} /* model_foreachPrevCell */ } /* model_foreachPrevCell */
static void static void
clearAndNotify( void* closure, XP_U16 XP_UNUSED(turn), XP_U16 col, XP_U16 row, clearAndNotify( XWEnv xwe, void* closure, XP_U16 XP_UNUSED(turn),
XP_Bool XP_UNUSED(added) ) XP_U16 col, XP_U16 row, XP_Bool XP_UNUSED(added) )
{ {
ModelCtxt* model = (ModelCtxt*)closure; ModelCtxt* model = (ModelCtxt*)closure;
CellTile tile = getModelTileRaw( model, col, row ); CellTile tile = getModelTileRaw( model, col, row );
setModelTileRaw( model, col, row, (CellTile)(tile & ~PREV_MOVE_BIT) ); setModelTileRaw( model, col, row, (CellTile)(tile & ~PREV_MOVE_BIT) );
notifyBoardListeners( model, (XP_U16)CELL_OWNER(tile), col, row, notifyBoardListeners( model, xwe, (XP_U16)CELL_OWNER(tile), col, row,
XP_FALSE ); XP_FALSE );
} /* clearAndNotify */ } /* clearAndNotify */
static void static void
clearLastMoveInfo( ModelCtxt* model ) clearLastMoveInfo( ModelCtxt* model, XWEnv xwe )
{ {
model_foreachPrevCell( model, clearAndNotify, model ); model_foreachPrevCell( model, xwe, clearAndNotify, model );
} /* clearLastMoveInfo */ } /* clearLastMoveInfo */
static void static void
invalLastMove( ModelCtxt* model ) invalLastMove( ModelCtxt* model, XWEnv xwe )
{ {
if ( !!model->vol.boardListenerFunc ) { if ( !!model->vol.boardListenerFunc ) {
model_foreachPrevCell( model, model->vol.boardListenerFunc, model_foreachPrevCell( model, xwe, model->vol.boardListenerFunc,
model->vol.boardListenerData ); model->vol.boardListenerData );
} }
} /* invalLastMove */ } /* invalLastMove */
void void
model_foreachPendingCell( ModelCtxt* model, XP_S16 turn, model_foreachPendingCell( ModelCtxt* model, XWEnv xwe, XP_S16 turn,
BoardListener bl, void* closure ) BoardListener bl, void* closure )
{ {
PendingTile* pt; PendingTile* pt;
@ -801,7 +802,7 @@ model_foreachPendingCell( ModelCtxt* model, XP_S16 turn,
count = player->nPending; count = player->nPending;
for ( pt = player->pendingTiles; count--; ++pt ) { for ( pt = player->pendingTiles; count--; ++pt ) {
(*bl)( closure, turn, pt->col, pt->row, XP_FALSE ); (*bl)( xwe, closure, turn, pt->col, pt->row, XP_FALSE );
} }
} /* model_foreachPendingCell */ } /* model_foreachPendingCell */
@ -837,7 +838,7 @@ getModelTileRaw( const ModelCtxt* model, XP_U16 col, XP_U16 row )
} /* getModelTileRaw */ } /* getModelTileRaw */
static void static void
undoFromMove( ModelCtxt* model, XP_U16 turn, Tile blankTile, MoveRec* move ) undoFromMove( ModelCtxt* model, XWEnv xwe, XP_U16 turn, Tile blankTile, MoveRec* move )
{ {
const MoveInfo* mi = &move->moveInfo; const MoveInfo* mi = &move->moveInfo;
@ -852,7 +853,7 @@ undoFromMove( ModelCtxt* model, XP_U16 turn, Tile blankTile, MoveRec* move )
*other = tinfo->varCoord; *other = tinfo->varCoord;
setModelTileRaw( model, col, row, EMPTY_TILE ); setModelTileRaw( model, col, row, EMPTY_TILE );
notifyBoardListeners( model, turn, col, row, XP_FALSE ); notifyBoardListeners( model, xwe, turn, col, row, XP_FALSE );
--model->vol.nTilesOnBoard; --model->vol.nTilesOnBoard;
if ( IS_BLANK(tile) ) { if ( IS_BLANK(tile) ) {
@ -864,7 +865,7 @@ undoFromMove( ModelCtxt* model, XP_U16 turn, Tile blankTile, MoveRec* move )
if ( model->vol.gi->inDuplicateMode ) { if ( model->vol.gi->inDuplicateMode ) {
dupe_adjustScores( model, XP_FALSE, move->dup.nScores, move->dup.scores ); dupe_adjustScores( model, XP_FALSE, move->dup.nScores, move->dup.scores );
} else { } else {
adjustScoreForUndone( model, mi, turn ); adjustScoreForUndone( model, xwe, mi, turn );
} }
} /* undoFromMove */ } /* undoFromMove */
@ -894,7 +895,8 @@ replaceNewTiles( ModelCtxt* model, PoolContext* pool, XP_U16 turn,
/* Turn the most recent move into a phony. /* Turn the most recent move into a phony.
*/ */
void void
model_rejectPreviousMove( ModelCtxt* model, PoolContext* pool, XP_U16* turn ) model_rejectPreviousMove( ModelCtxt* model, XWEnv xwe,
PoolContext* pool, XP_U16* turn )
{ {
StackCtxt* stack = model->vol.stack; StackCtxt* stack = model->vol.stack;
StackEntry entry; StackEntry entry;
@ -903,11 +905,11 @@ model_rejectPreviousMove( ModelCtxt* model, PoolContext* pool, XP_U16* turn )
stack_popEntry( stack, &entry ); stack_popEntry( stack, &entry );
XP_ASSERT( entry.moveType == MOVE_TYPE ); XP_ASSERT( entry.moveType == MOVE_TYPE );
model_resetCurrentTurn( model, entry.playerNum ); model_resetCurrentTurn( model, xwe, entry.playerNum );
replaceNewTiles( model, pool, entry.playerNum, &entry.u.move.newTiles ); replaceNewTiles( model, pool, entry.playerNum, &entry.u.move.newTiles );
XP_ASSERT( !model->vol.gi->inDuplicateMode ); XP_ASSERT( !model->vol.gi->inDuplicateMode );
undoFromMove( model, entry.playerNum, blankTile, &entry.u.move ); undoFromMove( model, xwe, entry.playerNum, blankTile, &entry.u.move );
stack_addPhony( stack, entry.playerNum, &entry.u.phony.moveInfo ); stack_addPhony( stack, entry.playerNum, &entry.u.phony.moveInfo );
@ -931,7 +933,7 @@ model_canUndo( const ModelCtxt* model )
* indicated by *moveNumP, if >= 0). * indicated by *moveNumP, if >= 0).
*/ */
XP_Bool XP_Bool
model_undoLatestMoves( ModelCtxt* model, PoolContext* pool, model_undoLatestMoves( ModelCtxt* model, XWEnv xwe, PoolContext* pool,
XP_U16 nMovesSought, XP_U16* turnP, XP_S16* moveNumP ) XP_U16 nMovesSought, XP_U16* turnP, XP_S16* moveNumP )
{ {
XP_ASSERT( 0 < nMovesSought ); /* this case isn't handled correctly */ XP_ASSERT( 0 < nMovesSought ); /* this case isn't handled correctly */
@ -968,19 +970,19 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
++nMovesUndone; ++nMovesUndone;
turn = entry.playerNum; turn = entry.playerNum;
model_resetCurrentTurn( model, turn ); model_resetCurrentTurn( model, xwe, turn );
if ( entry.moveType == MOVE_TYPE ) { if ( entry.moveType == MOVE_TYPE ) {
/* get the tiles out of player's tray and back into the /* get the tiles out of player's tray and back into the
pool */ pool */
replaceNewTiles( model, pool, turn, &entry.u.move.newTiles ); replaceNewTiles( model, pool, turn, &entry.u.move.newTiles );
undoFromMove( model, turn, blankTile, &entry.u.move ); undoFromMove( model, xwe, turn, blankTile, &entry.u.move );
model_sortTiles( model, turn ); model_sortTiles( model, turn );
if ( model->vol.gi->inDuplicateMode ) { if ( model->vol.gi->inDuplicateMode ) {
XP_ASSERT( DUP_PLAYER == turn ); XP_ASSERT( DUP_PLAYER == turn );
model_cloneDupeTrays( model ); model_cloneDupeTrays( model, xwe );
} }
} else if ( entry.moveType == TRADE_TYPE ) { } else if ( entry.moveType == TRADE_TYPE ) {
replaceNewTiles( model, pool, turn, replaceNewTiles( model, pool, turn,
@ -1040,7 +1042,7 @@ model_undoLatestMoves( ModelCtxt* model, PoolContext* pool,
tile = getModelTileRaw( model, col, row ); tile = getModelTileRaw( model, col, row );
setModelTileRaw( model, col, row, setModelTileRaw( model, col, row,
(CellTile)(tile | PREV_MOVE_BIT) ); (CellTile)(tile | PREV_MOVE_BIT) );
notifyBoardListeners( model, entry.playerNum, col, row, notifyBoardListeners( model, xwe, entry.playerNum, col, row,
XP_FALSE ); XP_FALSE );
} }
break; break;
@ -1171,7 +1173,7 @@ model_currentMoveToStream( ModelCtxt* model, XP_S16 turn,
* board. * board.
*/ */
XP_Bool XP_Bool
model_makeTurnFromStream( ModelCtxt* model, XP_U16 playerNum, model_makeTurnFromStream( ModelCtxt* model, XWEnv xwe, XP_U16 playerNum,
XWStreamCtxt* stream ) XWStreamCtxt* stream )
{ {
Tile blank = dict_getBlankTile( model_getDictionary(model) ); Tile blank = dict_getBlankTile( model_getDictionary(model) );
@ -1183,7 +1185,7 @@ model_makeTurnFromStream( ModelCtxt* model, XP_U16 playerNum,
#endif #endif
; ;
model_resetCurrentTurn( model, playerNum ); model_resetCurrentTurn( model, xwe, playerNum );
XP_U16 numTiles = (XP_U16)stream_getBits( stream, NTILES_NBITS ); XP_U16 numTiles = (XP_U16)stream_getBits( stream, NTILES_NBITS );
XP_LOGF( "%s: numTiles=%d", __func__, numTiles ); XP_LOGF( "%s: numTiles=%d", __func__, numTiles );
@ -1229,7 +1231,7 @@ model_makeTurnFromStream( ModelCtxt* model, XP_U16 playerNum,
model_addPlayerTile( model, playerNum, -1, moveTiles[ii] ); model_addPlayerTile( model, playerNum, -1, moveTiles[ii] );
} }
model_moveTrayToBoard( model, playerNum, cols[ii], rows[ii], foundAt, model_moveTrayToBoard( model, xwe, playerNum, cols[ii], rows[ii], foundAt,
tileFaces[ii] ); tileFaces[ii] );
} }
} }
@ -1275,7 +1277,7 @@ reverseTiles( MoveInfo* move )
#endif #endif
void void
model_makeTurnFromMoveInfo( ModelCtxt* model, XP_U16 playerNum, model_makeTurnFromMoveInfo( ModelCtxt* model, XWEnv xwe, XP_U16 playerNum,
const MoveInfo* newMove ) const MoveInfo* newMove )
{ {
XP_U16 col, row, ii; XP_U16 col, row, ii;
@ -1300,7 +1302,7 @@ model_makeTurnFromMoveInfo( ModelCtxt* model, XP_U16 playerNum,
XP_ASSERT( tileIndex >= 0 ); XP_ASSERT( tileIndex >= 0 );
*other = tinfo->varCoord; *other = tinfo->varCoord;
model_moveTrayToBoard( model, (XP_S16)playerNum, col, row, tileIndex, model_moveTrayToBoard( model, xwe, (XP_S16)playerNum, col, row, tileIndex,
(Tile)(tinfo->tile & TILE_VALUE_MASK) ); (Tile)(tinfo->tile & TILE_VALUE_MASK) );
} }
} /* model_makeTurnFromMoveInfo */ } /* model_makeTurnFromMoveInfo */
@ -1502,7 +1504,7 @@ model_packTilesUtil( ModelCtxt* model, PoolContext* pool,
/* setup async query for blank value, but while at it return a reasonable /* setup async query for blank value, but while at it return a reasonable
default. */ default. */
Tile Tile
model_askBlankTile( ModelCtxt* model, XP_U16 turn, XP_U16 col, XP_U16 row ) model_askBlankTile( ModelCtxt* model, XWEnv xwe, XP_U16 turn, XP_U16 col, XP_U16 row )
{ {
XP_U16 nUsed = MAX_UNIQUE_TILES; XP_U16 nUsed = MAX_UNIQUE_TILES;
const XP_UCHAR* tfaces[MAX_UNIQUE_TILES]; const XP_UCHAR* tfaces[MAX_UNIQUE_TILES];
@ -1511,13 +1513,13 @@ model_askBlankTile( ModelCtxt* model, XP_U16 turn, XP_U16 col, XP_U16 row )
model_packTilesUtil( model, NULL, XP_FALSE, model_packTilesUtil( model, NULL, XP_FALSE,
&nUsed, tfaces, tiles ); &nUsed, tfaces, tiles );
util_notifyPickTileBlank( model->vol.util, turn, col, row, util_notifyPickTileBlank( model->vol.util, xwe, turn, col, row,
tfaces, nUsed ); tfaces, nUsed );
return tiles[0]; return tiles[0];
} /* model_askBlankTile */ } /* model_askBlankTile */
void void
model_moveTrayToBoard( ModelCtxt* model, XP_S16 turn, XP_U16 col, XP_U16 row, model_moveTrayToBoard( ModelCtxt* model, XWEnv xwe, XP_S16 turn, XP_U16 col, XP_U16 row,
XP_S16 tileIndex, Tile blankFace ) XP_S16 tileIndex, Tile blankFace )
{ {
PlayerCtxt* player; PlayerCtxt* player;
@ -1531,7 +1533,7 @@ model_moveTrayToBoard( ModelCtxt* model, XP_S16 turn, XP_U16 col, XP_U16 row,
} else { } else {
XP_ASSERT( turn >= 0 ); XP_ASSERT( turn >= 0 );
tile = TILE_BLANK_BIT tile = TILE_BLANK_BIT
| model_askBlankTile( model, (XP_U16)turn, col, row ); | model_askBlankTile( model, xwe, (XP_U16)turn, col, row );
} }
tile |= TILE_BLANK_BIT; tile |= TILE_BLANK_BIT;
} }
@ -1539,7 +1541,7 @@ model_moveTrayToBoard( ModelCtxt* model, XP_S16 turn, XP_U16 col, XP_U16 row,
player = &model->players[turn]; player = &model->players[turn];
if ( player->nPending == 0 ) { if ( player->nPending == 0 ) {
invalLastMove( model ); invalLastMove( model, xwe );
} }
player->nUndone = 0; player->nUndone = 0;
@ -1553,7 +1555,7 @@ model_moveTrayToBoard( ModelCtxt* model, XP_S16 turn, XP_U16 col, XP_U16 row,
invalidateScore( model, turn ); invalidateScore( model, turn );
incrPendingTileCountAt( model, col, row ); incrPendingTileCountAt( model, col, row );
notifyBoardListeners( model, turn, col, row, XP_TRUE ); notifyBoardListeners( model, xwe, turn, col, row, XP_TRUE );
} /* model_moveTrayToBoard */ } /* model_moveTrayToBoard */
XP_Bool XP_Bool
@ -1586,7 +1588,7 @@ model_setBlankValue( ModelCtxt* model, XP_U16 turn,
} }
XP_Bool XP_Bool
model_redoPendingTiles( ModelCtxt* model, XP_S16 turn ) model_redoPendingTiles( ModelCtxt* model, XWEnv xwe, XP_S16 turn )
{ {
XP_U16 actualCnt = 0; XP_U16 actualCnt = 0;
PlayerCtxt* player; PlayerCtxt* player;
@ -1618,7 +1620,7 @@ model_redoPendingTiles( ModelCtxt* model, XP_S16 turn )
if ( !model_getTile( model, pt->col, pt->row, XP_FALSE, turn, if ( !model_getTile( model, pt->col, pt->row, XP_FALSE, turn,
NULL, NULL, NULL, NULL ) ) { NULL, NULL, NULL, NULL ) ) {
model_moveTrayToBoard( model, turn, pt->col, pt->row, model_moveTrayToBoard( model, xwe, turn, pt->col, pt->row,
foundAt, pt->tile & ~TILE_BLANK_BIT ); foundAt, pt->tile & ~TILE_BLANK_BIT );
++actualCnt; ++actualCnt;
} }
@ -1628,7 +1630,7 @@ model_redoPendingTiles( ModelCtxt* model, XP_S16 turn )
} }
void void
model_moveBoardToTray( ModelCtxt* model, XP_S16 turn, model_moveBoardToTray( ModelCtxt* model, XWEnv xwe, XP_S16 turn,
XP_U16 col, XP_U16 row, XP_U16 trayOffset ) XP_U16 col, XP_U16 row, XP_U16 trayOffset )
{ {
XP_S16 index; XP_S16 index;
@ -1652,7 +1654,7 @@ model_moveBoardToTray( ModelCtxt* model, XP_S16 turn,
if ( index < player->nPending ) { if ( index < player->nPending ) {
PendingTile tmpPending; PendingTile tmpPending;
decrPendingTileCountAt( model, col, row ); decrPendingTileCountAt( model, col, row );
notifyBoardListeners( model, turn, col, row, XP_FALSE ); notifyBoardListeners( model, xwe, turn, col, row, XP_FALSE );
tile = pt->tile; tile = pt->tile;
if ( (tile & TILE_BLANK_BIT) != 0 ) { if ( (tile & TILE_BLANK_BIT) != 0 ) {
@ -1672,7 +1674,7 @@ model_moveBoardToTray( ModelCtxt* model, XP_S16 turn,
//XP_LOGF( "%s: nUndone(%d): %d", __func__, turn, player->nUndone ); //XP_LOGF( "%s: nUndone(%d): %d", __func__, turn, player->nUndone );
if ( player->nPending == 0 ) { if ( player->nPending == 0 ) {
invalLastMove( model ); invalLastMove( model, xwe );
} }
invalidateScore( model, turn ); invalidateScore( model, turn );
@ -1680,7 +1682,7 @@ model_moveBoardToTray( ModelCtxt* model, XP_S16 turn,
} /* model_moveBoardToTray */ } /* model_moveBoardToTray */
XP_Bool XP_Bool
model_moveTileOnBoard( ModelCtxt* model, XP_S16 turn, XP_U16 colCur, model_moveTileOnBoard( ModelCtxt* model, XWEnv xwe, XP_S16 turn, XP_U16 colCur,
XP_U16 rowCur, XP_U16 colNew, XP_U16 rowNew ) XP_U16 rowCur, XP_U16 colNew, XP_U16 rowNew )
{ {
XP_Bool found = XP_FALSE; XP_Bool found = XP_FALSE;
@ -1703,7 +1705,7 @@ model_moveTileOnBoard( ModelCtxt* model, XP_S16 turn, XP_U16 colCur,
pt->col = colNew; pt->col = colNew;
pt->row = rowNew; pt->row = rowNew;
if ( isBlank ) { if ( isBlank ) {
(void)model_askBlankTile( model, turn, colNew, rowNew ); (void)model_askBlankTile( model, xwe, turn, colNew, rowNew );
} }
decrPendingTileCountAt( model, colCur, rowCur ); decrPendingTileCountAt( model, colCur, rowCur );
@ -1718,7 +1720,7 @@ model_moveTileOnBoard( ModelCtxt* model, XP_S16 turn, XP_U16 colCur,
} /* model_moveTileOnBoard */ } /* model_moveTileOnBoard */
void void
model_resetCurrentTurn( ModelCtxt* model, XP_S16 whose ) model_resetCurrentTurn( ModelCtxt* model, XWEnv xwe, XP_S16 whose )
{ {
PlayerCtxt* player; PlayerCtxt* player;
@ -1726,7 +1728,7 @@ model_resetCurrentTurn( ModelCtxt* model, XP_S16 whose )
player = &model->players[whose]; player = &model->players[whose];
while ( player->nPending > 0 ) { while ( player->nPending > 0 ) {
model_moveBoardToTray( model, whose, model_moveBoardToTray( model, xwe, whose,
player->pendingTiles[0].col, player->pendingTiles[0].col,
player->pendingTiles[0].row, player->pendingTiles[0].row,
-1 ); -1 );
@ -1819,7 +1821,7 @@ decrPendingTileCountAt( ModelCtxt* model, XP_U16 col, XP_U16 row )
} /* decrPendingTileCountAt */ } /* decrPendingTileCountAt */
static void static void
putBackOtherPlayersTiles( ModelCtxt* model, XP_U16 notMyTurn, putBackOtherPlayersTiles( ModelCtxt* model, XWEnv xwe, XP_U16 notMyTurn,
XP_U16 col, XP_U16 row ) XP_U16 col, XP_U16 row )
{ {
XP_U16 turn; XP_U16 turn;
@ -1828,7 +1830,7 @@ putBackOtherPlayersTiles( ModelCtxt* model, XP_U16 notMyTurn,
if ( turn == notMyTurn ) { if ( turn == notMyTurn ) {
continue; continue;
} }
model_moveBoardToTray( model, turn, col, row, -1 ); model_moveBoardToTray( model, xwe, turn, col, row, -1 );
} }
} /* putBackOtherPlayersTiles */ } /* putBackOtherPlayersTiles */
@ -1858,7 +1860,7 @@ commitTurn( ModelCtxt* model, XWEnv xwe, XP_S16 turn, const TrayTileSet* newTile
XP_ASSERT( turn >= 0 && turn < MAX_NUM_PLAYERS); XP_ASSERT( turn >= 0 && turn < MAX_NUM_PLAYERS);
clearLastMoveInfo( model ); clearLastMoveInfo( model, xwe );
PlayerCtxt* player = &model->players[turn]; PlayerCtxt* player = &model->players[turn];
@ -1886,7 +1888,7 @@ commitTurn( ModelCtxt* model, XWEnv xwe, XP_S16 turn, const TrayTileSet* newTile
XP_U16 val = tile & TILE_VALUE_MASK; XP_U16 val = tile & TILE_VALUE_MASK;
if ( val > 1 ) { /* somebody else is using this square too! */ if ( val > 1 ) { /* somebody else is using this square too! */
putBackOtherPlayersTiles( model, turn, col, row ); putBackOtherPlayersTiles( model, xwe, turn, col, row );
} }
tile = pt->tile; tile = pt->tile;
@ -1895,7 +1897,7 @@ commitTurn( ModelCtxt* model, XWEnv xwe, XP_S16 turn, const TrayTileSet* newTile
setModelTileRaw( model, col, row, tile ); setModelTileRaw( model, col, row, tile );
notifyBoardListeners( model, turn, col, row, XP_FALSE ); notifyBoardListeners( model, xwe, turn, col, row, XP_FALSE );
++model->vol.nTilesOnBoard; ++model->vol.nTilesOnBoard;
} }
@ -1930,8 +1932,8 @@ void
model_commitDupeTurn( ModelCtxt* model, XWEnv xwe, const MoveInfo* moveInfo, model_commitDupeTurn( ModelCtxt* model, XWEnv xwe, const MoveInfo* moveInfo,
XP_U16 nScores, XP_U16* scores, TrayTileSet* newTiles ) XP_U16 nScores, XP_U16* scores, TrayTileSet* newTiles )
{ {
model_resetCurrentTurn( model, DUP_PLAYER ); model_resetCurrentTurn( model, xwe, DUP_PLAYER );
model_makeTurnFromMoveInfo( model, DUP_PLAYER, moveInfo ); model_makeTurnFromMoveInfo( model, xwe, DUP_PLAYER, moveInfo );
(void)commitTurn( model, xwe, DUP_PLAYER, newTiles, NULL, NULL, XP_FALSE ); (void)commitTurn( model, xwe, DUP_PLAYER, newTiles, NULL, NULL, XP_FALSE );
dupe_adjustScores( model, XP_TRUE, nScores, scores ); dupe_adjustScores( model, XP_TRUE, nScores, scores );
invalidateScores( model ); invalidateScores( model );
@ -1947,10 +1949,10 @@ model_commitDupeTrade( ModelCtxt* model, const TrayTileSet* oldTiles,
} }
void void
model_noteDupePause( ModelCtxt* model, DupPauseType typ, XP_S16 turn, model_noteDupePause( ModelCtxt* model, XWEnv xwe, DupPauseType typ, XP_S16 turn,
const XP_UCHAR* msg ) const XP_UCHAR* msg )
{ {
XP_U32 when = dutil_getCurSeconds( model->vol.dutil ); XP_U32 when = dutil_getCurSeconds( model->vol.dutil, xwe );
stack_addPause( model->vol.stack, typ, turn, when, msg ); stack_addPause( model->vol.stack, typ, turn, when, msg );
} }
@ -2119,10 +2121,10 @@ model_getNextTurn( const ModelCtxt* model )
} }
void void
model_assignDupeTiles( ModelCtxt* model, const TrayTileSet* tiles ) model_assignDupeTiles( ModelCtxt* model, XWEnv xwe, const TrayTileSet* tiles )
{ {
model_assignPlayerTiles( model, DUP_PLAYER, tiles ); model_assignPlayerTiles( model, DUP_PLAYER, tiles );
model_cloneDupeTrays( model ); model_cloneDupeTrays( model, xwe );
} }
void void
@ -2196,12 +2198,12 @@ model_setDictListener( ModelCtxt* model, DictListener dl, void* data )
} /* model_setDictListener */ } /* model_setDictListener */
static void static void
notifyBoardListeners( ModelCtxt* model, XP_U16 turn, XP_U16 col, XP_U16 row, notifyBoardListeners( ModelCtxt* model, XWEnv xwe, XP_U16 turn, XP_U16 col,
XP_Bool added ) XP_U16 row, XP_Bool added )
{ {
if ( model->vol.boardListenerFunc != NULL ) { if ( model->vol.boardListenerFunc != NULL ) {
(*model->vol.boardListenerFunc)( model->vol.boardListenerData, turn, (*model->vol.boardListenerFunc)( xwe, model->vol.boardListenerData,
col, row, added ); turn, col, row, added );
} }
} /* notifyBoardListeners */ } /* notifyBoardListeners */
@ -2258,8 +2260,8 @@ typedef struct MovePrintClosure {
} MovePrintClosure; } MovePrintClosure;
static void static void
printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry, printMovePre( ModelCtxt* model, XWEnv xwe, XP_U16 XP_UNUSED(moveN),
void* p_closure ) const StackEntry* entry, void* p_closure )
{ {
if ( entry->moveType != ASSIGN_TYPE ) { if ( entry->moveType != ASSIGN_TYPE ) {
const XP_UCHAR* format; const XP_UCHAR* format;
@ -2293,13 +2295,13 @@ printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry
} }
if ( isPass ) { if ( isPass ) {
format = dutil_getUserString( model->vol.dutil, STR_PASS ); format = dutil_getUserString( model->vol.dutil, xwe, STR_PASS );
XP_SNPRINTF( buf, VSIZE(buf), "%s", format ); XP_SNPRINTF( buf, VSIZE(buf), "%s", format );
} else { } else {
if ( isHorizontal ) { if ( isHorizontal ) {
format = dutil_getUserString( model->vol.dutil, STRS_MOVE_ACROSS ); format = dutil_getUserString( model->vol.dutil, xwe, STRS_MOVE_ACROSS );
} else { } else {
format = dutil_getUserString( model->vol.dutil, STRS_MOVE_DOWN ); format = dutil_getUserString( model->vol.dutil, xwe, STRS_MOVE_DOWN );
} }
row = mi->commonCoord; row = mi->commonCoord;
@ -2316,7 +2318,7 @@ printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry
printString( stream, (XP_UCHAR*)buf ); printString( stream, (XP_UCHAR*)buf );
if ( !closure->keepHidden ) { if ( !closure->keepHidden ) {
format = dutil_getUserString( model->vol.dutil, STRS_TRAY_AT_START ); format = dutil_getUserString( model->vol.dutil, xwe, STRS_TRAY_AT_START );
formatTray( model_getPlayerTiles( model, entry->playerNum ), formatTray( model_getPlayerTiles( model, entry->playerNum ),
closure->dict, (XP_UCHAR*)traybuf, sizeof(traybuf), closure->dict, (XP_UCHAR*)traybuf, sizeof(traybuf),
XP_FALSE ); XP_FALSE );
@ -2330,7 +2332,7 @@ printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry
} /* printMovePre */ } /* printMovePre */
static void static void
printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), printMovePost( ModelCtxt* model, XWEnv xwe, XP_U16 XP_UNUSED(moveN),
const StackEntry* entry, XP_S16 XP_UNUSED(score), const StackEntry* entry, XP_S16 XP_UNUSED(score),
void* p_closure ) void* p_closure )
{ {
@ -2355,14 +2357,14 @@ printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN),
formatTray( (const TrayTileSet*) &entry->u.trade.newTiles, formatTray( (const TrayTileSet*) &entry->u.trade.newTiles,
dict, traybuf2, sizeof(traybuf2), closure->keepHidden ); dict, traybuf2, sizeof(traybuf2), closure->keepHidden );
format = dutil_getUserString( model->vol.dutil, STRSS_TRADED_FOR ); format = dutil_getUserString( model->vol.dutil, xwe, STRSS_TRADED_FOR );
XP_SNPRINTF( buf, sizeof(buf), format, traybuf1, traybuf2 ); XP_SNPRINTF( buf, sizeof(buf), format, traybuf1, traybuf2 );
printString( stream, buf ); printString( stream, buf );
addCR = XP_TRUE; addCR = XP_TRUE;
break; break;
case PHONY_TYPE: case PHONY_TYPE:
format = dutil_getUserString( model->vol.dutil, STR_PHONY_REJECTED ); format = dutil_getUserString( model->vol.dutil, xwe, STR_PHONY_REJECTED );
printString( stream, format ); printString( stream, format );
/* FALLTHRU */ /* FALLTHRU */
case MOVE_TYPE: case MOVE_TYPE:
@ -2377,7 +2379,7 @@ printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN),
printString( stream, buf ); printString( stream, buf );
} }
format = dutil_getUserString( model->vol.dutil, STRD_CUMULATIVE_SCORE ); format = dutil_getUserString( model->vol.dutil, xwe, STRD_CUMULATIVE_SCORE );
XP_SNPRINTF( buf, sizeof(buf), format, totalScore ); XP_SNPRINTF( buf, sizeof(buf), format, totalScore );
printString( stream, buf ); printString( stream, buf );
@ -2392,7 +2394,7 @@ printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN),
if ( entry->moveType == PHONY_TYPE ) { if ( entry->moveType == PHONY_TYPE ) {
/* printString( stream, (XP_UCHAR*)"phony rejected " ); */ /* printString( stream, (XP_UCHAR*)"phony rejected " ); */
} else if ( !closure->keepHidden ) { } else if ( !closure->keepHidden ) {
format = dutil_getUserString( model->vol.dutil, STRS_NEW_TILES ); format = dutil_getUserString( model->vol.dutil, xwe, STRS_NEW_TILES );
XP_SNPRINTF( buf, sizeof(buf), format, XP_SNPRINTF( buf, sizeof(buf), format,
formatTray( &entry->u.move.newTiles, dict, formatTray( &entry->u.move.newTiles, dict,
traybuf1, sizeof(traybuf1), traybuf1, sizeof(traybuf1),
@ -2404,7 +2406,7 @@ printMovePost( ModelCtxt* model, XP_U16 XP_UNUSED(moveN),
break; break;
case PAUSE_TYPE: case PAUSE_TYPE:
util_formatPauseHistory( model->vol.util, stream, entry->u.pause.pauseType, util_formatPauseHistory( model->vol.util, xwe, stream, entry->u.pause.pauseType,
entry->playerNum, closure->lastPauseWhen, entry->playerNum, closure->lastPauseWhen,
entry->u.pause.when, entry->u.pause.msg ); entry->u.pause.when, entry->u.pause.msg );
closure->lastPauseWhen = entry->u.pause.when; closure->lastPauseWhen = entry->u.pause.when;
@ -2472,7 +2474,7 @@ model_writeGameHistory( ModelCtxt* model, XWEnv xwe, XWStreamCtxt* stream,
if ( gameOver ) { if ( gameOver ) {
/* if the game's over, it shouldn't matter which model I pass to this /* if the game's over, it shouldn't matter which model I pass to this
method */ method */
server_writeFinalScores( server, stream ); server_writeFinalScores( server, xwe, stream );
} }
} /* model_writeGameHistory */ } /* model_writeGameHistory */
@ -2503,7 +2505,7 @@ scoreLastMove( ModelCtxt* model, XWEnv xwe, MoveInfo* moveInfo, XP_U16 howMany,
copyStack( model, xwe, tmpModel->vol.stack, model->vol.stack ); copyStack( model, xwe, tmpModel->vol.stack, model->vol.stack );
if ( !model_undoLatestMoves( tmpModel, NULL, howMany, &turn, if ( !model_undoLatestMoves( tmpModel, xwe, NULL, howMany, &turn,
&moveNum ) ) { &moveNum ) ) {
XP_ASSERT( 0 ); XP_ASSERT( 0 );
} }
@ -2511,7 +2513,7 @@ scoreLastMove( ModelCtxt* model, XWEnv xwe, MoveInfo* moveInfo, XP_U16 howMany,
data.word[0] = '\0'; data.word[0] = '\0';
notifyInfo.proc = getFirstWord; notifyInfo.proc = getFirstWord;
notifyInfo.closure = &data; notifyInfo.closure = &data;
score = figureMoveScore( tmpModel, turn, moveInfo, (EngineCtxt*)NULL, score = figureMoveScore( tmpModel, xwe, turn, moveInfo, (EngineCtxt*)NULL,
(XWStreamCtxt*)NULL, &notifyInfo ); (XWStreamCtxt*)NULL, &notifyInfo );
model_destroy( tmpModel, xwe ); model_destroy( tmpModel, xwe );
@ -2626,7 +2628,7 @@ model_listWordsThrough( ModelCtxt* model, XWEnv xwe, XP_U16 col, XP_U16 row,
if ( tilesInLine( model, turn, &isHorizontal ) ) { if ( tilesInLine( model, turn, &isHorizontal ) ) {
MoveInfo moveInfo = {0}; MoveInfo moveInfo = {0};
normalizeMoves( model, turn, isHorizontal, &moveInfo ); normalizeMoves( model, turn, isHorizontal, &moveInfo );
model_makeTurnFromMoveInfo( tmpModel, turn, &moveInfo ); model_makeTurnFromMoveInfo( tmpModel, xwe, turn, &moveInfo );
/* Might not be a legal move. If isn't, don't add it! */ /* Might not be a legal move. If isn't, don't add it! */
if ( getCurrentMoveScoreIfLegal( tmpModel, xwe, turn, (XWStreamCtxt*)NULL, if ( getCurrentMoveScoreIfLegal( tmpModel, xwe, turn, (XWStreamCtxt*)NULL,
@ -2634,7 +2636,7 @@ model_listWordsThrough( ModelCtxt* model, XWEnv xwe, XP_U16 col, XP_U16 row,
TrayTileSet newTiles = {.nTiles = 0}; TrayTileSet newTiles = {.nTiles = 0};
commitTurn( tmpModel, xwe, turn, &newTiles, NULL, NULL, XP_TRUE ); commitTurn( tmpModel, xwe, turn, &newTiles, NULL, NULL, XP_TRUE );
} else { } else {
model_resetCurrentTurn( tmpModel, turn ); model_resetCurrentTurn( tmpModel, xwe, turn );
} }
} }
@ -2644,7 +2646,7 @@ model_listWordsThrough( ModelCtxt* model, XWEnv xwe, XP_U16 col, XP_U16 row,
XP_U16 nEntriesAfter; XP_U16 nEntriesAfter;
/* Loop until we undo the move that placed the tile. */ /* Loop until we undo the move that placed the tile. */
while ( model_undoLatestMoves( tmpModel, NULL, 1, NULL, NULL ) ) { while ( model_undoLatestMoves( tmpModel, xwe, NULL, 1, NULL, NULL ) ) {
if ( 0 != (TILE_EMPTY_BIT & getModelTileRaw( tmpModel, col, row ) ) ) { if ( 0 != (TILE_EMPTY_BIT & getModelTileRaw( tmpModel, col, row ) ) ) {
break; break;
} }
@ -2852,8 +2854,9 @@ setContains( const TrayTileSet* tiles, Tile tile )
#ifdef DEBUG #ifdef DEBUG
static void static void
assertDiffTurn( ModelCtxt* model, XP_U16 XP_UNUSED(turn), assertDiffTurn( ModelCtxt* model, XWEnv XP_UNUSED(xwe),
const StackEntry* entry, void* closure ) XP_U16 XP_UNUSED(turn), const StackEntry* entry,
void* closure )
{ {
if ( 1 < model->nPlayers && ! model->vol.gi->inDuplicateMode ) { if ( 1 < model->nPlayers && ! model->vol.gi->inDuplicateMode ) {
DiffTurnState* state = (DiffTurnState*)closure; DiffTurnState* state = (DiffTurnState*)closure;

View file

@ -122,7 +122,7 @@ void model_setSize( ModelCtxt* model, XP_U16 boardSize );
void model_destroy( ModelCtxt* model, XWEnv xwe ); void model_destroy( ModelCtxt* model, XWEnv xwe );
XP_U32 model_getHash( const ModelCtxt* model ); XP_U32 model_getHash( const ModelCtxt* model );
XP_Bool model_hashMatches( const ModelCtxt* model, XP_U32 hash ); XP_Bool model_hashMatches( const ModelCtxt* model, XP_U32 hash );
XP_Bool model_popToHash( ModelCtxt* model, const XP_U32 hash, XP_Bool model_popToHash( ModelCtxt* model, XWEnv xwe, const XP_U32 hash,
PoolContext* pool ); PoolContext* pool );
void model_setNPlayers( ModelCtxt* model, XP_U16 numPlayers ); void model_setNPlayers( ModelCtxt* model, XP_U16 numPlayers );
@ -147,7 +147,7 @@ void model_addNewTiles( ModelCtxt* model, XP_S16 turn,
const TrayTileSet* tiles ); const TrayTileSet* tiles );
void model_assignPlayerTiles( ModelCtxt* model, XP_S16 turn, void model_assignPlayerTiles( ModelCtxt* model, XP_S16 turn,
const TrayTileSet* tiles ); const TrayTileSet* tiles );
void model_assignDupeTiles( ModelCtxt* model, const TrayTileSet* tiles ); void model_assignDupeTiles( ModelCtxt* model, XWEnv xwe, const TrayTileSet* tiles );
Tile model_getPlayerTile( const ModelCtxt* model, XP_S16 turn, XP_S16 index ); Tile model_getPlayerTile( const ModelCtxt* model, XP_S16 turn, XP_S16 index );
@ -172,13 +172,14 @@ void model_printTrays( const ModelCtxt* model );
void model_sortTiles( ModelCtxt* model, XP_S16 turn ); void model_sortTiles( ModelCtxt* model, XP_S16 turn );
XP_U16 model_getNumTilesInTray( ModelCtxt* model, XP_S16 turn ); XP_U16 model_getNumTilesInTray( ModelCtxt* model, XP_S16 turn );
XP_U16 model_getNumTilesTotal( ModelCtxt* model, XP_S16 turn ); XP_U16 model_getNumTilesTotal( ModelCtxt* model, XP_S16 turn );
void model_moveBoardToTray( ModelCtxt* model, XP_S16 turn, void model_moveBoardToTray( ModelCtxt* model, XWEnv xwe, XP_S16 turn,
XP_U16 col, XP_U16 row, XP_U16 trayOffset ); XP_U16 col, XP_U16 row, XP_U16 trayOffset );
void model_moveTrayToBoard( ModelCtxt* model, XP_S16 turn, XP_U16 col, void model_moveTrayToBoard( ModelCtxt* model, XWEnv xwe, XP_S16 turn, XP_U16 col,
XP_U16 row, XP_S16 tileIndex, Tile blankFace ); XP_U16 row, XP_S16 tileIndex, Tile blankFace );
XP_Bool model_moveTileOnBoard( ModelCtxt* model, XP_S16 turn, XP_U16 colCur, XP_Bool model_moveTileOnBoard( ModelCtxt* model, XWEnv xwe, XP_S16 turn,
XP_U16 rowCur, XP_U16 colNew, XP_U16 rowNew ); XP_U16 colCur, XP_U16 rowCur, XP_U16 colNew,
XP_Bool model_redoPendingTiles( ModelCtxt* model, XP_S16 turn ); XP_U16 rowNew );
XP_Bool model_redoPendingTiles( ModelCtxt* model, XWEnv xwe, XP_S16 turn );
XP_Bool model_setBlankValue( ModelCtxt* model, XP_U16 XP_UNUSED(player), XP_Bool model_setBlankValue( ModelCtxt* model, XP_U16 XP_UNUSED(player),
XP_U16 col, XP_U16 row, XP_U16 tileIndex ); XP_U16 col, XP_U16 row, XP_U16 tileIndex );
@ -210,20 +211,20 @@ void model_commitDupeTurn( ModelCtxt* model, XWEnv xwe,
TrayTileSet* newTiles ); TrayTileSet* newTiles );
void model_commitDupeTrade( ModelCtxt* model, const TrayTileSet* oldTiles, void model_commitDupeTrade( ModelCtxt* model, const TrayTileSet* oldTiles,
const TrayTileSet* newTiles ); const TrayTileSet* newTiles );
void model_noteDupePause( ModelCtxt* model, DupPauseType typ, XP_S16 turn, void model_noteDupePause( ModelCtxt* model, XWEnv xwe, DupPauseType typ,
const XP_UCHAR* msg ); XP_S16 turn, const XP_UCHAR* msg );
void model_cloneDupeTrays( ModelCtxt* model ); void model_cloneDupeTrays( ModelCtxt* model, XWEnv xwe );
void model_commitRejectedPhony( ModelCtxt* model, XP_S16 player ); void model_commitRejectedPhony( ModelCtxt* model, XP_S16 player );
void model_makeTileTrade( ModelCtxt* model, XP_S16 player, void model_makeTileTrade( ModelCtxt* model, XP_S16 player,
const TrayTileSet* oldTiles, const TrayTileSet* oldTiles,
const TrayTileSet* newTiles ); const TrayTileSet* newTiles );
XP_Bool model_canUndo( const ModelCtxt* model ); XP_Bool model_canUndo( const ModelCtxt* model );
XP_Bool model_undoLatestMoves( ModelCtxt* model, PoolContext* pool, XP_Bool model_undoLatestMoves( ModelCtxt* model, XWEnv xwe, PoolContext* pool,
XP_U16 nMovesSought, XP_U16* turn, XP_U16 nMovesSought, XP_U16* turn,
XP_S16* moveNum ); XP_S16* moveNum );
void model_rejectPreviousMove( ModelCtxt* model, PoolContext* pool, void model_rejectPreviousMove( ModelCtxt* model, XWEnv xwe,
XP_U16* turn ); PoolContext* pool, XP_U16* turn );
void model_trayToStream( ModelCtxt* model, XP_S16 turn, void model_trayToStream( ModelCtxt* model, XP_S16 turn,
XWStreamCtxt* stream ); XWStreamCtxt* stream );
@ -231,9 +232,9 @@ void model_currentMoveToStream( ModelCtxt* model, XP_S16 turn,
XWStreamCtxt* stream ); XWStreamCtxt* stream );
void model_currentMoveToMoveInfo( ModelCtxt* model, XP_S16 turn, void model_currentMoveToMoveInfo( ModelCtxt* model, XP_S16 turn,
MoveInfo* moveInfo ); MoveInfo* moveInfo );
XP_Bool model_makeTurnFromStream( ModelCtxt* model, XP_U16 playerNum, XP_Bool model_makeTurnFromStream( ModelCtxt* model, XWEnv xwe, XP_U16 playerNum,
XWStreamCtxt* stream ); XWStreamCtxt* stream );
void model_makeTurnFromMoveInfo( ModelCtxt* model, XP_U16 playerNum, void model_makeTurnFromMoveInfo( ModelCtxt* model, XWEnv xwe, XP_U16 playerNum,
const MoveInfo* newMove ); const MoveInfo* newMove );
#ifdef DEBUG #ifdef DEBUG
@ -245,7 +246,7 @@ void model_dumpSelf( const ModelCtxt* model, const XP_UCHAR* msg );
# define model_dumpSelf( model, msg ) # define model_dumpSelf( model, msg )
#endif #endif
void model_resetCurrentTurn( ModelCtxt* model, XP_S16 turn ); void model_resetCurrentTurn( ModelCtxt* model, XWEnv xwe, XP_S16 turn );
XP_S16 model_getNMoves( const ModelCtxt* model ); XP_S16 model_getNMoves( const ModelCtxt* model );
/* Are there two or more tiles visible */ /* Are there two or more tiles visible */
@ -256,7 +257,7 @@ XP_Bool model_canShuffle( const ModelCtxt* model, XP_U16 turn,
XP_Bool model_canTogglePending( const ModelCtxt* model, XP_U16 turn ); XP_Bool model_canTogglePending( const ModelCtxt* model, XP_U16 turn );
/********************* notification ********************/ /********************* notification ********************/
typedef void (*BoardListener)(void* data, XP_U16 turn, XP_U16 col, typedef void (*BoardListener)( XWEnv xwe, void* data, XP_U16 turn, XP_U16 col,
XP_U16 row, XP_Bool added ); XP_U16 row, XP_Bool added );
void model_setBoardListener( ModelCtxt* model, BoardListener bl, void model_setBoardListener( ModelCtxt* model, BoardListener bl,
void* data ); void* data );
@ -269,9 +270,9 @@ typedef void (*DictListener)( void* data, XWEnv xwe, XP_S16 playerNum,
const DictionaryCtxt* newDict ); const DictionaryCtxt* newDict );
void model_setDictListener( ModelCtxt* model, DictListener dl, void model_setDictListener( ModelCtxt* model, DictListener dl,
void* data ); void* data );
void model_foreachPendingCell( ModelCtxt* model, XP_S16 turn, void model_foreachPendingCell( ModelCtxt* model, XWEnv xwe, XP_S16 turn,
BoardListener bl, void* data ); BoardListener bl, void* data );
void model_foreachPrevCell( ModelCtxt* model, BoardListener bl, void* data ); void model_foreachPrevCell( ModelCtxt* model, XWEnv xwe, BoardListener bl, void* data );
void model_writeGameHistory( ModelCtxt* model, XWEnv xwe, XWStreamCtxt* stream, void model_writeGameHistory( ModelCtxt* model, XWEnv xwe, XWStreamCtxt* stream,
ServerCtxt* server, /* for player names */ ServerCtxt* server, /* for player names */
@ -317,7 +318,7 @@ XP_Bool model_listWordsThrough( ModelCtxt* model, XWEnv xwe, XP_U16 col,
XP_Bool model_recentPassCountOk( ModelCtxt* model ); XP_Bool model_recentPassCountOk( ModelCtxt* model );
XWBonusType model_getSquareBonus( const ModelCtxt* model, XWBonusType model_getSquareBonus( const ModelCtxt* model,
XP_U16 col, XP_U16 row ); XWEnv xwe, XP_U16 col, XP_U16 row );
#ifdef STREAM_VERS_BIGBOARD #ifdef STREAM_VERS_BIGBOARD
void model_setSquareBonuses( ModelCtxt* model, XWBonusType* bonuses, void model_setSquareBonuses( ModelCtxt* model, XWBonusType* bonuses,
XP_U16 nBonuses ); XP_U16 nBonuses );
@ -332,7 +333,7 @@ void model_figureFinalScores( ModelCtxt* model, ScoresArray* scores,
ScoresArray* tilePenalties ); ScoresArray* tilePenalties );
/* figureMoveScore is meant only for the engine's use */ /* figureMoveScore is meant only for the engine's use */
XP_U16 figureMoveScore( const ModelCtxt* model, XP_U16 turn, XP_U16 figureMoveScore( const ModelCtxt* model, XWEnv xwe, XP_U16 turn,
const MoveInfo* mvInfo, EngineCtxt* engine, const MoveInfo* mvInfo, EngineCtxt* engine,
XWStreamCtxt* stream, WordNotifierInfo* notifyInfo ); XWStreamCtxt* stream, WordNotifierInfo* notifyInfo );
@ -352,7 +353,8 @@ void model_packTilesUtil( ModelCtxt* model, PoolContext* pool,
XP_U16* nUsed, const XP_UCHAR** texts, XP_U16* nUsed, const XP_UCHAR** texts,
Tile* tiles ); Tile* tiles );
Tile model_askBlankTile( ModelCtxt* model, XP_U16 turn, XP_U16 col, XP_U16 row); Tile model_askBlankTile( ModelCtxt* model, XWEnv xwe, XP_U16 turn,
XP_U16 col, XP_U16 row);
XP_S16 model_getNextTurn( const ModelCtxt* model ); XP_S16 model_getNextTurn( const ModelCtxt* model );

View file

@ -93,7 +93,8 @@ XP_Bool tilesInLine( ModelCtxt* model, XP_S16 turn, XP_Bool* isHorizontal );
void normalizeMoves( const ModelCtxt* model, XP_S16 turn, void normalizeMoves( const ModelCtxt* model, XP_S16 turn,
XP_Bool isHorizontal, MoveInfo* moveInfo ); XP_Bool isHorizontal, MoveInfo* moveInfo );
void normalizeMI( MoveInfo* moveInfoOut, const MoveInfo* moveInfoIn ); void normalizeMI( MoveInfo* moveInfoOut, const MoveInfo* moveInfoIn );
void adjustScoreForUndone( ModelCtxt* model, const MoveInfo* mi, XP_U16 turn ); void adjustScoreForUndone( ModelCtxt* model, XWEnv xwe, const MoveInfo* mi,
XP_U16 turn );
#ifdef CPLUS #ifdef CPLUS
} }
#endif #endif

View file

@ -32,8 +32,9 @@ extern "C" {
#define IMPOSSIBLY_LOW_PENALTY (-20*MAX_TRAY_TILES) #define IMPOSSIBLY_LOW_PENALTY (-20*MAX_TRAY_TILES)
/****************************** prototypes ******************************/ /****************************** prototypes ******************************/
static XP_Bool isLegalMove( ModelCtxt* model, MoveInfo* moves, XP_Bool silent ); static XP_Bool isLegalMove( ModelCtxt* model, XWEnv xwe, MoveInfo* moves,
static XP_U16 word_multiplier( const ModelCtxt* model, XP_Bool silent );
static XP_U16 word_multiplier( const ModelCtxt* model, XWEnv xwe,
XP_U16 col, XP_U16 row ); XP_U16 col, XP_U16 row );
static XP_U16 find_end( const ModelCtxt* model, XP_U16 col, XP_U16 row, static XP_U16 find_end( const ModelCtxt* model, XP_U16 col, XP_U16 row,
XP_Bool isHorizontal ); XP_Bool isHorizontal );
@ -42,7 +43,7 @@ static XP_U16 find_start( const ModelCtxt* model, XP_U16 col, XP_U16 row,
static XP_S16 checkScoreMove( ModelCtxt* model, XWEnv xwe, XP_S16 turn, static XP_S16 checkScoreMove( ModelCtxt* model, XWEnv xwe, XP_S16 turn,
EngineCtxt* engine, XWStreamCtxt* stream, EngineCtxt* engine, XWStreamCtxt* stream,
XP_Bool silent, WordNotifierInfo* notifyInfo ); XP_Bool silent, WordNotifierInfo* notifyInfo );
static XP_U16 scoreWord( const ModelCtxt* model, XP_U16 turn, static XP_U16 scoreWord( const ModelCtxt* model, XWEnv xwe, XP_U16 turn,
const MoveInfo* movei, EngineCtxt* engine, const MoveInfo* movei, EngineCtxt* engine,
XWStreamCtxt* stream, WordNotifierInfo* notifyInfo ); XWStreamCtxt* stream, WordNotifierInfo* notifyInfo );
@ -68,7 +69,7 @@ static void wordScoreFormatterFinish( WordScoreFormatter* fmtr, Tile* word,
XWStreamCtxt* stream ); XWStreamCtxt* stream );
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, const ModelCtxt* model, static void formatSummary( XWStreamCtxt* stream, XWEnv xwe, const ModelCtxt* model,
XP_U16 score ); XP_U16 score );
@ -95,7 +96,7 @@ scoreCurrentMove( ModelCtxt* model, XWEnv xwe, XP_S16 turn, XWStreamCtxt* stream
} /* scoreCurrentMove */ } /* scoreCurrentMove */
void void
adjustScoreForUndone( ModelCtxt* model, const MoveInfo* mi, XP_U16 turn ) adjustScoreForUndone( ModelCtxt* model, XWEnv xwe, const MoveInfo* mi, XP_U16 turn )
{ {
XP_U16 moveScore; XP_U16 moveScore;
PlayerCtxt* player = &model->players[turn]; PlayerCtxt* player = &model->players[turn];
@ -103,7 +104,7 @@ adjustScoreForUndone( ModelCtxt* model, const MoveInfo* mi, XP_U16 turn )
if ( mi->nTiles == 0 ) { if ( mi->nTiles == 0 ) {
moveScore = 0; moveScore = 0;
} else { } else {
moveScore = figureMoveScore( model, turn, mi, (EngineCtxt*)NULL, moveScore = figureMoveScore( model, xwe, turn, mi, (EngineCtxt*)NULL,
(XWStreamCtxt*)NULL, (XWStreamCtxt*)NULL,
(WordNotifierInfo*)NULL ); (WordNotifierInfo*)NULL );
} }
@ -265,18 +266,18 @@ checkScoreMove( ModelCtxt* model, XWEnv xwe, XP_S16 turn, EngineCtxt* engine,
score = 0; score = 0;
if ( !!stream ) { if ( !!stream ) {
formatSummary( stream, model, 0 ); formatSummary( stream, xwe, model, 0 );
} }
} else if ( !tilesInLine( model, turn, &isHorizontal ) ) { } else if ( !tilesInLine( model, turn, &isHorizontal ) ) {
if ( !silent ) { /* tiles out of line */ if ( !silent ) { /* tiles out of line */
util_userError( model->vol.util, ERR_TILES_NOT_IN_LINE ); util_userError( model->vol.util, xwe, ERR_TILES_NOT_IN_LINE );
} }
} else { } else {
MoveInfo moveInfo; MoveInfo moveInfo;
normalizeMoves( model, turn, isHorizontal, &moveInfo ); normalizeMoves( model, turn, isHorizontal, &moveInfo );
if ( isLegalMove( model, &moveInfo, silent ) ) { if ( isLegalMove( model, xwe, &moveInfo, silent ) ) {
/* If I'm testing for blocking, I need to chain my test onto any /* If I'm testing for blocking, I need to chain my test onto any
existing WordNotifierInfo. blockCheck() does that. */ existing WordNotifierInfo. blockCheck() does that. */
XP_Bool checkDict = PHONIES_BLOCK == model->vol.gi->phoniesAction; XP_Bool checkDict = PHONIES_BLOCK == model->vol.gi->phoniesAction;
@ -292,13 +293,13 @@ checkScoreMove( ModelCtxt* model, XWEnv xwe, XP_S16 turn, EngineCtxt* engine,
notifyInfo = &blockWNI; notifyInfo = &blockWNI;
} }
XP_S16 tmpScore = figureMoveScore( model, turn, &moveInfo, XP_S16 tmpScore = figureMoveScore( model, xwe, turn, &moveInfo,
engine, stream, notifyInfo ); engine, stream, notifyInfo );
if ( checkDict && 0 < bcs.nBadWords ) { if ( checkDict && 0 < bcs.nBadWords ) {
if ( !silent ) { if ( !silent ) {
XP_ASSERT( !!bcs.stream ); XP_ASSERT( !!bcs.stream );
DictionaryCtxt* dict = model_getPlayerDict( model, turn ); DictionaryCtxt* dict = model_getPlayerDict( model, turn );
util_informWordsBlocked( model->vol.util, bcs.nBadWords, util_informWordsBlocked( model->vol.util, xwe, bcs.nBadWords,
bcs.stream, dict_getName( dict ) ); bcs.stream, dict_getName( dict ) );
stream_destroy( bcs.stream, xwe ); stream_destroy( bcs.stream, xwe );
} }
@ -415,7 +416,7 @@ modelIsEmptyAt( const ModelCtxt* model, XP_U16 col, XP_U16 row )
* handles dragging the tiles, will have taken care of that. * handles dragging the tiles, will have taken care of that.
****************************************************************************/ ****************************************************************************/
static XP_Bool static XP_Bool
isLegalMove( ModelCtxt* model, MoveInfo* mInfo, XP_Bool silent ) isLegalMove( ModelCtxt* model, XWEnv xwe, MoveInfo* mInfo, XP_Bool silent )
{ {
XP_Bool result = XP_TRUE; XP_Bool result = XP_TRUE;
XP_S16 high, low; XP_S16 high, low;
@ -453,7 +454,7 @@ isLegalMove( ModelCtxt* model, MoveInfo* mInfo, XP_Bool silent )
++newTile; ++newTile;
} else if ( modelIsEmptyAt( model, col, row ) ) { } else if ( modelIsEmptyAt( model, col, row ) ) {
if ( !silent ) { if ( !silent ) {
util_userError( model->vol.util, ERR_NO_EMPTIES_IN_TURN ); util_userError( model->vol.util, xwe, ERR_NO_EMPTIES_IN_TURN );
} }
result = XP_FALSE; result = XP_FALSE;
goto exit; goto exit;
@ -507,14 +508,14 @@ isLegalMove( ModelCtxt* model, MoveInfo* mInfo, XP_Bool silent )
goto exit; goto exit;
} else { } else {
if ( !silent ) { if ( !silent ) {
util_userError(model->vol.util, ERR_TWO_TILES_FIRST_MOVE); util_userError(model->vol.util, xwe, ERR_TWO_TILES_FIRST_MOVE);
} }
result = XP_FALSE; result = XP_FALSE;
goto exit; goto exit;
} }
} else { } else {
if ( !silent ) { if ( !silent ) {
util_userError( model->vol.util, ERR_TILES_MUST_CONTACT ); util_userError( model->vol.util, xwe, ERR_TILES_MUST_CONTACT );
} }
result = XP_FALSE; result = XP_FALSE;
goto exit; goto exit;
@ -526,7 +527,7 @@ isLegalMove( ModelCtxt* model, MoveInfo* mInfo, XP_Bool silent )
} /* isLegalMove */ } /* isLegalMove */
XP_U16 XP_U16
figureMoveScore( const ModelCtxt* model, XP_U16 turn, const MoveInfo* moveInfo, figureMoveScore( const ModelCtxt* model, XWEnv xwe, XP_U16 turn, const MoveInfo* moveInfo,
EngineCtxt* engine, XWStreamCtxt* stream, EngineCtxt* engine, XWStreamCtxt* stream,
WordNotifierInfo* notifyInfo ) WordNotifierInfo* notifyInfo )
{ {
@ -553,11 +554,12 @@ figureMoveScore( const ModelCtxt* model, XP_U16 turn, const MoveInfo* moveInfo,
for ( ii = 0; ii < nTiles; ++ii ) { for ( ii = 0; ii < nTiles; ++ii ) {
*incr = moveInfo->tiles[ii].varCoord; *incr = moveInfo->tiles[ii].varCoord;
moveMultiplier *= multipliers[ii] = word_multiplier( model, col, row ); moveMultiplier *= multipliers[ii] =
word_multiplier( model, xwe, col, row );
} }
oneScore = scoreWord( model, turn, moveInfo, (EngineCtxt*)NULL, stream, oneScore = scoreWord( model, xwe, turn, moveInfo, (EngineCtxt*)NULL,
notifyInfo ); stream, notifyInfo );
if ( !!stream ) { if ( !!stream ) {
formatWordScore( stream, oneScore, moveMultiplier ); formatWordScore( stream, oneScore, moveMultiplier );
} }
@ -574,7 +576,7 @@ figureMoveScore( const ModelCtxt* model, XP_U16 turn, const MoveInfo* moveInfo,
tmpMI.commonCoord = tiles->varCoord; tmpMI.commonCoord = tiles->varCoord;
tmpMI.tiles[0].tile = tiles->tile; tmpMI.tiles[0].tile = tiles->tile;
oneScore = scoreWord( model, turn, &tmpMI, engine, stream, notifyInfo ); oneScore = scoreWord( model, xwe, turn, &tmpMI, engine, stream, notifyInfo );
if ( !!stream ) { if ( !!stream ) {
formatWordScore( stream, oneScore, multipliers[ii] ); formatWordScore( stream, oneScore, multipliers[ii] );
} }
@ -588,22 +590,22 @@ figureMoveScore( const ModelCtxt* model, XP_U16 turn, const MoveInfo* moveInfo,
if ( !!stream ) { if ( !!stream ) {
const XP_UCHAR* bstr = dutil_getUserString( model->vol.dutil, const XP_UCHAR* bstr = dutil_getUserString( model->vol.dutil,
STR_BONUS_ALL ); xwe, STR_BONUS_ALL );
stream_catString( stream, bstr ); stream_catString( stream, bstr );
} }
} }
if ( !!stream ) { if ( !!stream ) {
formatSummary( stream, model, score ); formatSummary( stream, xwe, model, score );
} }
return score; return score;
} /* figureMoveScore */ } /* figureMoveScore */
static XP_U16 static XP_U16
word_multiplier( const ModelCtxt* model, XP_U16 col, XP_U16 row ) word_multiplier( const ModelCtxt* model, XWEnv xwe, XP_U16 col, XP_U16 row )
{ {
XWBonusType bonus = model_getSquareBonus( model, col, row ); XWBonusType bonus = model_getSquareBonus( model, xwe, col, row );
switch ( bonus ) { switch ( bonus ) {
case BONUS_DOUBLE_WORD: case BONUS_DOUBLE_WORD:
return 2; return 2;
@ -615,9 +617,9 @@ word_multiplier( const ModelCtxt* model, XP_U16 col, XP_U16 row )
} /* word_multiplier */ } /* word_multiplier */
static XP_U16 static XP_U16
tile_multiplier( const ModelCtxt* model, XP_U16 col, XP_U16 row ) tile_multiplier( const ModelCtxt* model, XWEnv xwe, XP_U16 col, XP_U16 row )
{ {
XWBonusType bonus = model_getSquareBonus( model, col, row ); XWBonusType bonus = model_getSquareBonus( model, xwe, col, row );
switch ( bonus ) { switch ( bonus ) {
case BONUS_DOUBLE_LETTER: case BONUS_DOUBLE_LETTER:
return 2; return 2;
@ -629,7 +631,7 @@ tile_multiplier( const ModelCtxt* model, XP_U16 col, XP_U16 row )
} /* tile_multiplier */ } /* tile_multiplier */
static XP_U16 static XP_U16
scoreWord( const ModelCtxt* model, XP_U16 turn, scoreWord( const ModelCtxt* model, XWEnv xwe, XP_U16 turn,
const MoveInfo* movei, /* new tiles */ const MoveInfo* movei, /* new tiles */
EngineCtxt* engine,/* for crosswise caching */ EngineCtxt* engine,/* for crosswise caching */
XWStreamCtxt* stream, XWStreamCtxt* stream,
@ -678,7 +680,7 @@ scoreWord( const ModelCtxt* model, XP_U16 turn,
thisTileValue = dict_getTileValue( dict, tile ); thisTileValue = dict_getTileValue( dict, tile );
XP_ASSERT( *incr == tiles[0].varCoord ); XP_ASSERT( *incr == tiles[0].varCoord );
thisTileValue *= tile_multiplier( model, col, row ); thisTileValue *= tile_multiplier( model, xwe, col, row );
XP_ASSERT( engine == NULL || nTiles == 1 ); XP_ASSERT( engine == NULL || nTiles == 1 );
@ -714,7 +716,7 @@ scoreWord( const ModelCtxt* model, XP_U16 turn,
* mode, as the blank won't be known there. (Assert will * mode, as the blank won't be known there. (Assert will
* fail.) */ * fail.) */
tileMultiplier = tile_multiplier( model, col, row ); tileMultiplier = tile_multiplier( model, xwe, col, row );
++tiles; ++tiles;
--nTiles; --nTiles;
} else { /* placed on the board before this move */ } else { /* placed on the board before this move */
@ -919,11 +921,12 @@ formatWordScore( XWStreamCtxt* stream, XP_U16 wordScore,
} /* formatWordScore */ } /* formatWordScore */
static void static void
formatSummary( XWStreamCtxt* stream, const ModelCtxt* model, XP_U16 score ) formatSummary( XWStreamCtxt* stream, XWEnv xwe,
const ModelCtxt* model, XP_U16 score )
{ {
XP_UCHAR buf[60]; XP_UCHAR buf[60];
XP_SNPRINTF( buf, sizeof(buf), XP_SNPRINTF( buf, sizeof(buf),
dutil_getUserString(model->vol.dutil, STRD_TURN_SCORE), dutil_getUserString(model->vol.dutil, xwe, STRD_TURN_SCORE),
score ); score );
XP_ASSERT( XP_STRLEN(buf) < sizeof(buf) ); XP_ASSERT( XP_STRLEN(buf) < sizeof(buf) );
stream_catString( stream, buf ); stream_catString( stream, buf );

View file

@ -62,16 +62,16 @@ static void enableOne( NewGameCtx* ngc, XP_U16 player, NewGameColumn col,
XP_TriEnable enable, XP_Bool force ); XP_TriEnable enable, XP_Bool force );
static void adjustAllRows( NewGameCtx* ngc, XP_Bool force ); static void adjustAllRows( NewGameCtx* ngc, XP_Bool force );
static void adjustOneRow( NewGameCtx* ngc, XP_U16 player, XP_Bool force ); static void adjustOneRow( NewGameCtx* ngc, XP_U16 player, XP_Bool force );
static void setRoleStrings( NewGameCtx* ngc ); static void setRoleStrings( NewGameCtx* ngc, XWEnv xwe );
static void considerEnable( NewGameCtx* ngc ); static void considerEnable( NewGameCtx* ngc );
static void storePlayer( NewGameCtx* ngc, XP_U16 player, LocalPlayer* lp ); static void storePlayer( NewGameCtx* ngc, XP_U16 player, LocalPlayer* lp );
static void loadPlayer( NewGameCtx* ngc, XP_U16 player, static void loadPlayer( NewGameCtx* ngc, XP_U16 player,
const LocalPlayer* lp ); const LocalPlayer* lp );
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static XP_Bool changeRole( NewGameCtx* ngc, DeviceRole role ); static XP_Bool changeRole( NewGameCtx* ngc, XWEnv xwe, DeviceRole role );
static XP_Bool checkConsistent( NewGameCtx* ngc, XP_Bool warnUser ); static XP_Bool checkConsistent( NewGameCtx* ngc, XWEnv xwe, XP_Bool warnUser );
#else #else
# define checkConsistent( ngc, warnUser ) XP_TRUE # define checkConsistent( ngc, xwe, warnUser ) XP_TRUE
#endif #endif
NewGameCtx* NewGameCtx*
@ -105,7 +105,7 @@ newg_destroy( NewGameCtx* ngc )
} /* newg_destroy */ } /* newg_destroy */
void void
newg_load( NewGameCtx* ngc, const CurGameInfo* gi ) newg_load( NewGameCtx* ngc, XWEnv xwe, const CurGameInfo* gi )
{ {
void* closure = ngc->closure; void* closure = ngc->closure;
NGValue value; NGValue value;
@ -164,7 +164,7 @@ newg_load( NewGameCtx* ngc, const CurGameInfo* gi )
value.ng_u16 = ngc->timerSeconds; value.ng_u16 = ngc->timerSeconds;
(*ngc->setAttrProc)( closure, NG_ATTR_TIMER, value ); (*ngc->setAttrProc)( closure, NG_ATTR_TIMER, value );
setRoleStrings( ngc ); setRoleStrings( ngc, xwe );
considerEnable( ngc ); considerEnable( ngc );
/* Load local players first */ /* Load local players first */
@ -227,10 +227,10 @@ cpToLP( NGValue value, const void* cbClosure )
} /* cpToLP */ } /* cpToLP */
XP_Bool XP_Bool
newg_store( NewGameCtx* ngc, CurGameInfo* gi, newg_store( NewGameCtx* ngc, XWEnv xwe, CurGameInfo* gi,
XP_Bool XP_UNUSED_STANDALONE(warn) ) XP_Bool XP_UNUSED_STANDALONE(warn) )
{ {
XP_Bool consistent = checkConsistent( ngc, warn ); XP_Bool consistent = checkConsistent( ngc, xwe, warn );
if ( consistent ) { if ( consistent ) {
XP_Bool makeLocal = XP_FALSE; XP_Bool makeLocal = XP_FALSE;
@ -268,7 +268,8 @@ newg_colChanged( NewGameCtx* ngc, XP_U16 player )
} }
void void
newg_attrChanged( NewGameCtx* ngc, NewGameAttr attr, NGValue value ) newg_attrChanged( NewGameCtx* ngc, XWEnv xwe,
NewGameAttr attr, NGValue value )
{ {
XP_Bool changed = XP_FALSE; XP_Bool changed = XP_FALSE;
switch ( attr ) { switch ( attr ) {
@ -281,7 +282,7 @@ newg_attrChanged( NewGameCtx* ngc, NewGameAttr attr, NGValue value )
break; break;
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
case NG_ATTR_ROLE: case NG_ATTR_ROLE:
changed = changeRole( ngc, value.ng_role ); changed = changeRole( ngc, xwe, value.ng_role );
break; break;
#endif #endif
case NG_ATTR_TIMER: case NG_ATTR_TIMER:
@ -373,7 +374,7 @@ newg_juggle( NewGameCtx* ngc )
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static XP_Bool static XP_Bool
checkConsistent( NewGameCtx* ngc, XP_Bool warnUser ) checkConsistent( NewGameCtx* ngc, XWEnv xwe, XP_Bool warnUser )
{ {
XP_Bool consistent; XP_Bool consistent;
XP_U16 ii; XP_U16 ii;
@ -390,7 +391,7 @@ checkConsistent( NewGameCtx* ngc, XP_Bool warnUser )
} }
} }
if ( !consistent && warnUser ) { if ( !consistent && warnUser ) {
util_userError( ngc->util, ERR_REG_SERVER_SANS_REMOTE ); util_userError( ngc->util, xwe, ERR_REG_SERVER_SANS_REMOTE );
} }
/* Add other consistency checks, and error messages, here. */ /* Add other consistency checks, and error messages, here. */
@ -511,7 +512,7 @@ adjustOneRow( NewGameCtx* ngc, XP_U16 player, XP_Bool force )
*/ */
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static XP_Bool static XP_Bool
changeRole( NewGameCtx* ngc, DeviceRole newRole ) changeRole( NewGameCtx* ngc, XWEnv xwe, DeviceRole newRole )
{ {
DeviceRole oldRole = ngc->role; DeviceRole oldRole = ngc->role;
XP_Bool changing = oldRole != newRole; XP_Bool changing = oldRole != newRole;
@ -529,14 +530,14 @@ changeRole( NewGameCtx* ngc, DeviceRole newRole )
} }
} }
ngc->role = newRole; ngc->role = newRole;
setRoleStrings( ngc ); setRoleStrings( ngc, xwe );
} }
return changing; return changing;
} }
#endif #endif
static void static void
setRoleStrings( NewGameCtx* ngc ) setRoleStrings( NewGameCtx* ngc, XWEnv xwe )
{ {
XP_U16 strID; XP_U16 strID;
NGValue value; NGValue value;
@ -561,7 +562,8 @@ setRoleStrings( NewGameCtx* ngc )
strID = STR_TOTALPLAYERS; strID = STR_TOTALPLAYERS;
} }
value.ng_cp = dutil_getUserString( util_getDevUtilCtxt(ngc->util), strID ); value.ng_cp = dutil_getUserString( util_getDevUtilCtxt(ngc->util, xwe),
xwe, strID );
(*ngc->setAttrProc)( closure, NG_ATTR_NPLAYHEADER, value ); (*ngc->setAttrProc)( closure, NG_ATTR_NPLAYHEADER, value );
} /* setRoleStrings */ } /* setRoleStrings */

View file

@ -101,11 +101,11 @@ NewGameCtx* newg_make( MPFORMAL XP_Bool isNewGame,
void* closure ); void* closure );
void newg_destroy( NewGameCtx* ngc ); void newg_destroy( NewGameCtx* ngc );
void newg_load( NewGameCtx* ngc, const CurGameInfo* gi ); void newg_load( NewGameCtx* ngc, XWEnv xwe, const CurGameInfo* gi );
XP_Bool newg_store( NewGameCtx* ngc, CurGameInfo* gi, XP_Bool warn ); XP_Bool newg_store( NewGameCtx* ngc, XWEnv xwe, CurGameInfo* gi, XP_Bool warn );
void newg_colChanged( NewGameCtx* ngc, XP_U16 player ); void newg_colChanged( NewGameCtx* ngc, XP_U16 player );
void newg_attrChanged( NewGameCtx* ngc, NewGameAttr attr, void newg_attrChanged( NewGameCtx* ngc, XWEnv xwe, NewGameAttr attr,
NGValue value ); NGValue value );
/** newg_juggle: Return XP_TRUE if a juggle happened, XP_FALSE if randomness /** newg_juggle: Return XP_TRUE if a juggle happened, XP_FALSE if randomness

View file

@ -267,7 +267,7 @@ drawScoreBoard( BoardCtxt* board, XWEnv xwe )
dp->dsi.isRemote = !lp->isLocal; dp->dsi.isRemote = !lp->isLocal;
XP_ASSERT( !isMissing || dp->dsi.isRemote ); XP_ASSERT( !isMissing || dp->dsi.isRemote );
if ( dp->dsi.isRemote && isMissing ) { if ( dp->dsi.isRemote && isMissing ) {
dp->dsi.name = dutil_getUserString( board->dutil, STR_PENDING_PLAYER ); dp->dsi.name = dutil_getUserString( board->dutil, xwe, STR_PENDING_PLAYER );
} else { } else {
dp->dsi.name = emptyStringIfNull( lp->name ); dp->dsi.name = emptyStringIfNull( lp->name );
} }
@ -351,7 +351,7 @@ void
drawTimer( const BoardCtxt* board, XWEnv xwe ) drawTimer( const BoardCtxt* board, XWEnv xwe )
{ {
if ( !!board->draw && board->gi->timerEnabled ) { if ( !!board->draw && board->gi->timerEnabled ) {
XP_S16 secondsLeft = server_getTimerSeconds( board->server, XP_S16 secondsLeft = server_getTimerSeconds( board->server, xwe,
board->selPlayer ); board->selPlayer );
XP_Bool turnDone = board->gi->inDuplicateMode XP_Bool turnDone = board->gi->inDuplicateMode
? server_dupTurnDone( board->server, board->selPlayer ) ? server_dupTurnDone( board->server, board->selPlayer )
@ -409,20 +409,20 @@ figureScoreRectTapped( const BoardCtxt* board, XP_U16 xx, XP_U16 yy )
*/ */
#if defined POINTER_SUPPORT || defined KEYBOARD_NAV #if defined POINTER_SUPPORT || defined KEYBOARD_NAV
XP_Bool XP_Bool
handlePenUpScore( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool altDown ) handlePenUpScore( BoardCtxt* board, XWEnv xwe, XP_U16 xx, XP_U16 yy, XP_Bool altDown )
{ {
XP_Bool result = XP_TRUE; XP_Bool result = XP_TRUE;
XP_S16 rectNum = figureScoreRectTapped( board, xx, yy ); XP_S16 rectNum = figureScoreRectTapped( board, xx, yy );
if ( rectNum == CURSOR_LOC_REM ) { if ( rectNum == CURSOR_LOC_REM ) {
util_remSelected( board->util ); util_remSelected( board->util, xwe );
} else if ( --rectNum >= 0 ) { } else if ( --rectNum >= 0 ) {
XP_Bool canSwitch = board->gameOver || board->allowPeek; XP_Bool canSwitch = board->gameOver || board->allowPeek;
if ( altDown || !canSwitch ) { if ( altDown || !canSwitch ) {
penTimerFiredScore( board ); penTimerFiredScore( board, xwe );
} else { } else {
board_selectPlayer( board, rectNum, XP_TRUE ); board_selectPlayer( board, xwe, rectNum, XP_TRUE );
} }
} else { } else {
result = XP_FALSE; result = XP_FALSE;
@ -432,7 +432,7 @@ handlePenUpScore( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool altDown )
#endif #endif
void void
penTimerFiredScore( const BoardCtxt* board ) penTimerFiredScore( const BoardCtxt* board, XWEnv xwe )
{ {
XP_S16 scoreIndex = figureScoreRectTapped( board, board->penDownX, XP_S16 scoreIndex = figureScoreRectTapped( board, board->penDownX,
board->penDownY ); board->penDownY );
@ -459,7 +459,7 @@ penTimerFiredScore( const BoardCtxt* board )
} }
text = buf; text = buf;
#else #else
util_playerScoreHeld( board->util, player ); util_playerScoreHeld( board->util, xwe, player );
#endif #endif
} }

View file

@ -25,10 +25,11 @@
void drawScoreBoard( BoardCtxt* board, XWEnv xwe ); void drawScoreBoard( BoardCtxt* board, XWEnv xwe );
XP_S16 figureScoreRectTapped( const BoardCtxt* board, XP_U16 x, XP_U16 y ); XP_S16 figureScoreRectTapped( const BoardCtxt* board, XP_U16 x, XP_U16 y );
void drawTimer( const BoardCtxt* board, XWEnv xwe ); void drawTimer( const BoardCtxt* board, XWEnv xwe );
void penTimerFiredScore( const BoardCtxt* board ); void penTimerFiredScore( const BoardCtxt* board, XWEnv xwe );
#if defined POINTER_SUPPORT || defined KEYBOARD_NAV #if defined POINTER_SUPPORT || defined KEYBOARD_NAV
XP_Bool handlePenUpScore( BoardCtxt* board, XP_U16 xx, XP_U16 yy, XP_Bool altDown ); XP_Bool handlePenUpScore( BoardCtxt* board, XWEnv xwe, XP_U16 xx,
XP_U16 yy, XP_Bool altDown );
#endif #endif

File diff suppressed because it is too large Load diff

View file

@ -30,10 +30,10 @@
extern "C" { extern "C" {
#endif #endif
ServerCtxt* server_make( MPFORMAL ModelCtxt* model, CommsCtxt* comms, ServerCtxt* server_make( MPFORMAL XWEnv xwe, ModelCtxt* model, CommsCtxt* comms,
XW_UtilCtxt* util ); XW_UtilCtxt* util );
ServerCtxt* server_makeFromStream( MPFORMAL XWStreamCtxt* stream, ServerCtxt* server_makeFromStream( MPFORMAL XWEnv xwe, XWStreamCtxt* stream,
ModelCtxt* model, CommsCtxt* comms, ModelCtxt* model, CommsCtxt* comms,
XW_UtilCtxt* util, XP_U16 nPlayers ); XW_UtilCtxt* util, XP_U16 nPlayers );
@ -44,16 +44,16 @@ void server_destroy( ServerCtxt* server, XWEnv xwe );
void server_prefsChanged( ServerCtxt* server, const CommonPrefs* cp ); void server_prefsChanged( ServerCtxt* server, const CommonPrefs* cp );
typedef void (*TurnChangeListener)( void* data ); typedef void (*TurnChangeListener)( XWEnv xwe, void* data );
void server_setTurnChangeListener( ServerCtxt* server, TurnChangeListener tl, void server_setTurnChangeListener( ServerCtxt* server, TurnChangeListener tl,
void* data ); void* data );
typedef void (*TimerChangeListener)( void* data, XP_U32 gameID, typedef void (*TimerChangeListener)( XWEnv xwe, void* data, XP_U32 gameID,
XP_S32 oldVal, XP_S32 newVal ); XP_S32 oldVal, XP_S32 newVal );
void server_setTimerChangeListener( ServerCtxt* server, TimerChangeListener tl, void server_setTimerChangeListener( ServerCtxt* server, TimerChangeListener tl,
void* data ); void* data );
typedef void (*GameOverListener)( void* data, XP_S16 quitter ); typedef void (*GameOverListener)( XWEnv xwe, void* data, XP_S16 quitter );
void server_setGameOverListener( ServerCtxt* server, GameOverListener gol, void server_setGameOverListener( ServerCtxt* server, GameOverListener gol,
void* data ); void* data );
@ -78,7 +78,7 @@ XP_S16 server_getCurrentTurn( const ServerCtxt* server, XP_Bool* isLocal );
XP_Bool server_isPlayersTurn( const ServerCtxt* server, XP_U16 turn ); XP_Bool server_isPlayersTurn( const ServerCtxt* server, XP_U16 turn );
XP_Bool server_getGameIsOver( const ServerCtxt* server ); XP_Bool server_getGameIsOver( const ServerCtxt* server );
XP_S32 server_getDupTimerExpires( const ServerCtxt* server ); XP_S32 server_getDupTimerExpires( const ServerCtxt* server );
XP_S16 server_getTimerSeconds( const ServerCtxt* server, XP_U16 turn ); XP_S16 server_getTimerSeconds( const ServerCtxt* server, XWEnv xwe, XP_U16 turn );
XP_Bool server_dupTurnDone( const ServerCtxt* server, XP_U16 turn ); XP_Bool server_dupTurnDone( const ServerCtxt* server, XP_U16 turn );
XP_Bool server_canPause( const ServerCtxt* server ); XP_Bool server_canPause( const ServerCtxt* server );
XP_Bool server_canUnpause( const ServerCtxt* server ); XP_Bool server_canUnpause( const ServerCtxt* server );
@ -91,9 +91,9 @@ XP_U32 server_getLastMoveTime( const ServerCtxt* server );
/* Signed in case no dictionary available */ /* Signed in case no dictionary available */
XP_S16 server_countTilesInPool( ServerCtxt* server ); XP_S16 server_countTilesInPool( ServerCtxt* server );
XP_Bool server_askPickTiles( ServerCtxt* server, XP_U16 player, XP_Bool server_askPickTiles( ServerCtxt* server, XWEnv xwe, XP_U16 player,
TrayTileSet* newTiles, XP_U16 nToPick ); TrayTileSet* newTiles, XP_U16 nToPick );
void server_tilesPicked( ServerCtxt* server, XP_U16 player, void server_tilesPicked( ServerCtxt* server, XWEnv xwe, XP_U16 player,
const TrayTileSet* newTiles ); const TrayTileSet* newTiles );
XP_U16 server_getPendingRegs( const ServerCtxt* server ); XP_U16 server_getPendingRegs( const ServerCtxt* server );
@ -124,12 +124,12 @@ void server_sendChat( ServerCtxt* server, XWEnv xwe,
const XP_UCHAR* msg, XP_S16 from ); const XP_UCHAR* msg, XP_S16 from );
#endif #endif
void server_formatDictCounts( ServerCtxt* server, XWStreamCtxt* stream, void server_formatDictCounts( ServerCtxt* server, XWEnv xwe, XWStreamCtxt* stream,
XP_U16 nCols, XP_Bool allFaces ); XP_U16 nCols, XP_Bool allFaces );
void server_formatRemainingTiles( ServerCtxt* server, XWStreamCtxt* stream, void server_formatRemainingTiles( ServerCtxt* server, XWEnv xwe,
XP_S16 player ); XWStreamCtxt* stream, XP_S16 player );
void server_writeFinalScores( ServerCtxt* server, XWStreamCtxt* stream ); void server_writeFinalScores( ServerCtxt* server, XWEnv xwe, XWStreamCtxt* stream );
#ifdef XWFEATURE_BONUSALL #ifdef XWFEATURE_BONUSALL
XP_U16 server_figureFinishBonus( const ServerCtxt* server, XP_U16 turn ); XP_U16 server_figureFinishBonus( const ServerCtxt* server, XP_U16 turn );

View file

@ -87,10 +87,11 @@ struct SMSProto {
#define KEY_PARTIALS PERSIST_KEY("partials") #define KEY_PARTIALS PERSIST_KEY("partials")
#define KEY_NEXTID PERSIST_KEY("nextID") #define KEY_NEXTID PERSIST_KEY("nextID")
static int nextMsgID( SMSProto* state ); static int nextMsgID( SMSProto* state, XWEnv xwe );
static XWStreamCtxt* mkStream( SMSProto* state ); static XWStreamCtxt* mkStream( SMSProto* state );
static void destroyStream( XWStreamCtxt* stream ); static void destroyStream( XWStreamCtxt* stream );
static SMSMsgArray* toNetMsgs( SMSProto* state, ToPhoneRec* rec, XP_Bool forceOld ); static SMSMsgArray* toNetMsgs( SMSProto* state, XWEnv xwe, ToPhoneRec* rec,
XP_Bool forceOld );
static ToPhoneRec* getForPhone( SMSProto* state, const XP_UCHAR* phone, static ToPhoneRec* getForPhone( SMSProto* state, const XP_UCHAR* phone,
XP_Bool create ); XP_Bool create );
static void addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd, static void addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd,
@ -101,8 +102,8 @@ static void addMessage( SMSProto* state, const XP_UCHAR* fromPhone, int msgID,
static SMSMsgArray* completeMsgs( SMSProto* state, SMSMsgArray* arr, static SMSMsgArray* completeMsgs( SMSProto* state, SMSMsgArray* arr,
const XP_UCHAR* fromPhone, XP_U16 wantPort, const XP_UCHAR* fromPhone, XP_U16 wantPort,
int msgID ); int msgID );
static void savePartials( SMSProto* state ); static void savePartials( SMSProto* state, XWEnv xwe );
static void restorePartials( SMSProto* state ); static void restorePartials( SMSProto* state, XWEnv xwe );
static void rmFromPhoneRec( SMSProto* state, int fromPhoneIndex ); static void rmFromPhoneRec( SMSProto* state, int fromPhoneIndex );
static void freeMsgIDRec( SMSProto* state, MsgIDRec* rec, int fromPhoneIndex, static void freeMsgIDRec( SMSProto* state, MsgIDRec* rec, int fromPhoneIndex,
int msgIDIndex ); int msgIDIndex );
@ -110,13 +111,14 @@ static void freeForPhone( SMSProto* state, const XP_UCHAR* phone );
static void freeMsg( SMSProto* state, MsgRec** msg ); static void freeMsg( SMSProto* state, MsgRec** msg );
static void freeRec( SMSProto* state, ToPhoneRec* rec ); static void freeRec( SMSProto* state, ToPhoneRec* rec );
#ifdef DEBUG #ifdef DEBUG
static void logResult( const SMSProto* state, const SMSMsgArray* result, const char* caller ); static void logResult( const SMSProto* state, XWEnv xwe,
const SMSMsgArray* result, const char* caller );
#else #else
# define logResult( state, result, caller ) # define logResult( state, result, caller )
#endif #endif
SMSProto* SMSProto*
smsproto_init( MPFORMAL XW_DUtilCtxt* dutil ) smsproto_init( MPFORMAL XWEnv xwe, XW_DUtilCtxt* dutil )
{ {
SMSProto* state = (SMSProto*)XP_CALLOC( mpool, sizeof(*state) ); SMSProto* state = (SMSProto*)XP_CALLOC( mpool, sizeof(*state) );
pthread_mutex_init( &state->mutex, NULL ); pthread_mutex_init( &state->mutex, NULL );
@ -124,10 +126,10 @@ smsproto_init( MPFORMAL XW_DUtilCtxt* dutil )
MPASSIGN( state->mpool, mpool ); MPASSIGN( state->mpool, mpool );
XP_U16 siz = sizeof(state->nNextID); XP_U16 siz = sizeof(state->nNextID);
dutil_loadPtr( state->dutil, KEY_NEXTID, &state->nNextID, &siz ); dutil_loadPtr( state->dutil, xwe, KEY_NEXTID, &state->nNextID, &siz );
XP_LOGF( "%s(): loaded nextMsgID: %d", __func__, state->nNextID ); XP_LOGF( "%s(): loaded nextMsgID: %d", __func__, state->nNextID );
restorePartials( state ); restorePartials( state, xwe );
return state; return state;
} }
@ -212,7 +214,7 @@ headerFromStream( XWStreamCtxt* stream, SMS_CMD* cmd, XP_U16* port, XP_U32* game
* UtilCtxt around. * UtilCtxt around.
*/ */
SMSMsgArray* SMSMsgArray*
smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, XP_U32 gameID, smsproto_prepOutbound( SMSProto* state, XWEnv xwe, SMS_CMD cmd, XP_U32 gameID,
const void* buf, XP_U16 buflen, const XP_UCHAR* toPhone, const void* buf, XP_U16 buflen, const XP_UCHAR* toPhone,
int toPort, XP_Bool forceOld, XP_U16* waitSecsP ) int toPort, XP_Bool forceOld, XP_U16* waitSecsP )
{ {
@ -221,7 +223,7 @@ smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, XP_U32 gameID,
pthread_mutex_lock( &state->mutex ); pthread_mutex_lock( &state->mutex );
#ifdef DEBUG #ifdef DEBUG
XP_UCHAR* checksum = dutil_md5sum( state->dutil, buf, buflen ); XP_UCHAR* checksum = dutil_md5sum( state->dutil, xwe, buf, buflen );
XP_LOGFF( "(cmd=%d, gameID=%d): len=%d, sum=%s, toPhone=%s", cmd, XP_LOGFF( "(cmd=%d, gameID=%d): len=%d, sum=%s, toPhone=%s", cmd,
gameID, buflen, checksum, toPhone ); gameID, buflen, checksum, toPhone );
XP_FREEP( state->mpool, &checksum ); XP_FREEP( state->mpool, &checksum );
@ -230,7 +232,7 @@ smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, XP_U32 gameID,
ToPhoneRec* rec = getForPhone( state, toPhone, cmd != NONE ); ToPhoneRec* rec = getForPhone( state, toPhone, cmd != NONE );
/* First, add the new message (if present) to the array */ /* First, add the new message (if present) to the array */
XP_U32 nowSeconds = dutil_getCurSeconds( state->dutil ); XP_U32 nowSeconds = dutil_getCurSeconds( state->dutil, xwe );
if ( cmd != NONE && 0 < buflen ) { if ( cmd != NONE && 0 < buflen ) {
addToOutRec( state, rec, cmd, toPort, gameID, buf, buflen, nowSeconds ); addToOutRec( state, rec, cmd, toPort, gameID, buf, buflen, nowSeconds );
} }
@ -245,7 +247,7 @@ smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, XP_U32 gameID,
} }
if ( doSend ) { if ( doSend ) {
result = toNetMsgs( state, rec, forceOld ); result = toNetMsgs( state, xwe, rec, forceOld );
freeForPhone( state, toPhone ); freeForPhone( state, toPhone );
} }
@ -259,7 +261,7 @@ smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, XP_U32 gameID,
!!result ? result->nMsgs : 0, *waitSecsP ); !!result ? result->nMsgs : 0, *waitSecsP );
pthread_mutex_unlock( &state->mutex ); pthread_mutex_unlock( &state->mutex );
logResult( state, result, __func__ ); logResult( state, xwe, result, __func__ );
return result; return result;
} /* smsproto_prepOutbound */ } /* smsproto_prepOutbound */
@ -296,13 +298,13 @@ appendNetMsg( SMSProto* XP_UNUSED_DBG(state), SMSMsgArray* arr, SMSMsgNet* msg )
} }
SMSMsgArray* SMSMsgArray*
smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone, smsproto_prepInbound( SMSProto* state, XWEnv xwe, const XP_UCHAR* fromPhone,
XP_U16 wantPort, const XP_U8* data, XP_U16 len ) XP_U16 wantPort, const XP_U8* data, XP_U16 len )
{ {
XP_LOGFF( "len=%d, fromPhone=%s", len, fromPhone ); XP_LOGFF( "len=%d, fromPhone=%s", len, fromPhone );
#ifdef DEBUG #ifdef DEBUG
XP_UCHAR* checksum = dutil_md5sum( state->dutil, data, len ); XP_UCHAR* checksum = dutil_md5sum( state->dutil, xwe, data, len );
XP_LOGFF( "(fromPhone=%s, len=%d); sum=%s", fromPhone, len, checksum ); XP_LOGFF( "(fromPhone=%s, len=%d); sum=%s", fromPhone, len, checksum );
XP_FREEP( state->mpool, &checksum ); XP_FREEP( state->mpool, &checksum );
#endif #endif
@ -327,7 +329,7 @@ smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
stream_getBytes( stream, buf, len ); stream_getBytes( stream, buf, len );
addMessage( state, fromPhone, msgID, indx, count, buf, len ); addMessage( state, fromPhone, msgID, indx, count, buf, len );
result = completeMsgs( state, result, fromPhone, wantPort, msgID ); result = completeMsgs( state, result, fromPhone, wantPort, msgID );
savePartials( state ); savePartials( state, xwe );
} }
} }
break; break;
@ -376,7 +378,7 @@ smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
destroyStream( stream ); destroyStream( stream );
XP_LOGFF( "=> %p (len=%d)", result, (!!result) ? result->nMsgs : 0 ); XP_LOGFF( "=> %p (len=%d)", result, (!!result) ? result->nMsgs : 0 );
logResult( state, result, __func__ ); logResult( state, xwe, result, __func__ );
pthread_mutex_unlock( &state->mutex ); pthread_mutex_unlock( &state->mutex );
return result; return result;
@ -412,7 +414,8 @@ smsproto_freeMsgArray( SMSProto* state, SMSMsgArray* arr )
#ifdef DEBUG #ifdef DEBUG
static void static void
logResult( const SMSProto* state, const SMSMsgArray* result, const char* caller ) logResult( const SMSProto* state, XWEnv xwe, const SMSMsgArray* result,
const char* caller )
{ {
if ( !!result ) { if ( !!result ) {
for ( int ii = 0; ii < result->nMsgs; ++ii ) { for ( int ii = 0; ii < result->nMsgs; ++ii ) {
@ -435,7 +438,7 @@ logResult( const SMSProto* state, const SMSMsgArray* result, const char* caller
XP_ASSERT(0); XP_ASSERT(0);
} }
XP_ASSERT( 0 < len ); XP_ASSERT( 0 < len );
XP_UCHAR* checksum = dutil_md5sum( state->dutil, data, len ); XP_UCHAR* checksum = dutil_md5sum( state->dutil, xwe, data, len );
XP_LOGFF( "%s() => datum[%d] sum: %s, len: %d", caller, ii, checksum, len ); XP_LOGFF( "%s() => datum[%d] sum: %s, len: %d", caller, ii, checksum, len );
XP_FREEP( state->mpool, &checksum ); XP_FREEP( state->mpool, &checksum );
} }
@ -670,7 +673,7 @@ freeMsgIDRec( SMSProto* state, MsgIDRec* XP_UNUSED_DBG(rec), int fromPhoneIndex,
} }
static void static void
savePartials( SMSProto* state ) savePartials( SMSProto* state, XWEnv xwe )
{ {
XWStreamCtxt* stream = mkStream( state ); XWStreamCtxt* stream = mkStream( state );
stream_putU8( stream, PARTIALS_FORMAT ); stream_putU8( stream, PARTIALS_FORMAT );
@ -698,7 +701,7 @@ savePartials( SMSProto* state )
if ( state->lastStoredSize == 2 && newSize == 2 ) { if ( state->lastStoredSize == 2 && newSize == 2 ) {
XP_LOGFF( "not storing empty again" ); XP_LOGFF( "not storing empty again" );
} else { } else {
dutil_storeStream( state->dutil, KEY_PARTIALS, stream ); dutil_storeStream( state->dutil, xwe, KEY_PARTIALS, stream );
state->lastStoredSize = newSize; state->lastStoredSize = newSize;
} }
@ -708,11 +711,11 @@ savePartials( SMSProto* state )
} /* savePartials */ } /* savePartials */
static void static void
restorePartials( SMSProto* state ) restorePartials( SMSProto* state, XWEnv xwe )
{ {
XWStreamCtxt* stream = mkStream( state ); XWStreamCtxt* stream = mkStream( state );
dutil_loadStream( state->dutil, KEY_PARTIALS, stream ); dutil_loadStream( state->dutil, xwe, KEY_PARTIALS, stream );
if ( stream_getSize( stream ) >= 1 if ( stream_getSize( stream ) >= 1
&& PARTIALS_FORMAT == stream_getU8( stream ) ) { && PARTIALS_FORMAT == stream_getU8( stream ) ) {
int nFromPhones = stream_getU8( stream ); int nFromPhones = stream_getU8( stream );
@ -795,7 +798,7 @@ completeMsgs( SMSProto* state, SMSMsgArray* arr, const XP_UCHAR* fromPhone,
} }
static SMSMsgArray* static SMSMsgArray*
toNetMsgs( SMSProto* state, ToPhoneRec* rec, XP_Bool forceOld ) toNetMsgs( SMSProto* state, XWEnv xwe, ToPhoneRec* rec, XP_Bool forceOld )
{ {
SMSMsgArray* result = NULL; SMSMsgArray* result = NULL;
@ -831,14 +834,14 @@ toNetMsgs( SMSProto* state, ToPhoneRec* rec, XP_Bool forceOld )
for ( int jj = ii; jj < last; ++jj ) { for ( int jj = ii; jj < last; ++jj ) {
const SMSMsgNet* msg = &rec->msgs[jj]->msgNet; const SMSMsgNet* msg = &rec->msgs[jj]->msgNet;
newMsg.data[indx++] = msg->len; newMsg.data[indx++] = msg->len;
newMsg.data[indx++] = nextMsgID( state ); newMsg.data[indx++] = nextMsgID( state, xwe );
XP_MEMCPY( &newMsg.data[indx], msg->data, msg->len ); /* bad! */ XP_MEMCPY( &newMsg.data[indx], msg->data, msg->len ); /* bad! */
indx += msg->len; indx += msg->len;
} }
result = appendNetMsg( state, result, &newMsg ); result = appendNetMsg( state, result, &newMsg );
ii = last; ii = last;
} else { } else {
int msgID = nextMsgID( state ); int msgID = nextMsgID( state, xwe );
const SMSMsgNet* msg = &rec->msgs[ii]->msgNet; const SMSMsgNet* msg = &rec->msgs[ii]->msgNet;
XP_U8* nextStart = msg->data; XP_U8* nextStart = msg->data;
XP_U16 lenLeft = msg->len; XP_U16 lenLeft = msg->len;
@ -870,10 +873,10 @@ toNetMsgs( SMSProto* state, ToPhoneRec* rec, XP_Bool forceOld )
} /* toMsgs */ } /* toMsgs */
static int static int
nextMsgID( SMSProto* state ) nextMsgID( SMSProto* state, XWEnv xwe )
{ {
int result = ++state->nNextID % 0x000000FF; int result = ++state->nNextID % 0x000000FF;
dutil_storePtr( state->dutil, KEY_NEXTID, &state->nNextID, dutil_storePtr( state->dutil, xwe, KEY_NEXTID, &state->nNextID,
sizeof(state->nNextID) ); sizeof(state->nNextID) );
LOG_RETURNF( "%d", result ); LOG_RETURNF( "%d", result );
return result; return result;
@ -895,10 +898,10 @@ destroyStream( XWStreamCtxt* stream )
#ifdef DEBUG #ifdef DEBUG
void void
smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil ) smsproto_runTests( MPFORMAL XWEnv xwe, XW_DUtilCtxt* dutil )
{ {
LOG_FUNC(); LOG_FUNC();
SMSProto* state = smsproto_init( mpool, dutil ); SMSProto* state = smsproto_init( mpool, xwe, dutil );
const int smallSiz = 20; const int smallSiz = 20;
const char* phones[] = {"1234", "3456", "5467", "9877"}; const char* phones[] = {"1234", "3456", "5467", "9877"};
@ -923,10 +926,10 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
XP_U16 waitSecs; XP_U16 waitSecs;
if ( firstTime ) { if ( firstTime ) {
XP_U16 len = (ii + 1) * 30; XP_U16 len = (ii + 1) * 30;
arrs[ii] = smsproto_prepOutbound( state, DATA, gameID, buf, len, phones[ii], arrs[ii] = smsproto_prepOutbound( state, xwe, DATA, gameID, buf, len, phones[ii],
port, forceOld, &waitSecs ); port, forceOld, &waitSecs );
} else if ( NULL == arrs[ii]) { } else if ( NULL == arrs[ii]) {
arrs[ii] = smsproto_prepOutbound( state, DATA, gameID, NULL, 0, phones[ii], arrs[ii] = smsproto_prepOutbound( state, xwe, DATA, gameID, NULL, 0, phones[ii],
port, forceOld, &waitSecs ); port, forceOld, &waitSecs );
} else { } else {
continue; continue;
@ -946,7 +949,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
if (!!arrs[ii] && indx < arrs[ii]->nMsgs) { if (!!arrs[ii] && indx < arrs[ii]->nMsgs) {
XP_ASSERT( arrs[ii]->format == FORMAT_NET ); XP_ASSERT( arrs[ii]->format == FORMAT_NET );
haveOne = XP_TRUE; haveOne = XP_TRUE;
SMSMsgArray* outArr = smsproto_prepInbound( state, phones[ii], port, SMSMsgArray* outArr = smsproto_prepInbound( state, xwe, phones[ii], port,
arrs[ii]->u.msgsNet[indx].data, arrs[ii]->u.msgsNet[indx].data,
arrs[ii]->u.msgsNet[indx].len ); arrs[ii]->u.msgsNet[indx].len );
if ( !!outArr ) { if ( !!outArr ) {
@ -972,7 +975,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
/* Now let's send a bunch of small messages that should get combined */ /* Now let's send a bunch of small messages that should get combined */
for ( int nUsed = 0; ; ++nUsed ) { for ( int nUsed = 0; ; ++nUsed ) {
XP_U16 waitSecs; XP_U16 waitSecs;
SMSMsgArray* sendArr = smsproto_prepOutbound( state, DATA, gameID, &buf[nUsed], SMSMsgArray* sendArr = smsproto_prepOutbound( state, xwe, DATA, gameID, &buf[nUsed],
smallSiz, phones[0], port, smallSiz, phones[0], port,
XP_FALSE, &waitSecs ); XP_FALSE, &waitSecs );
if ( sendArr == NULL ) { if ( sendArr == NULL ) {
@ -984,7 +987,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
XP_ASSERT( sendArr->format == FORMAT_NET ); XP_ASSERT( sendArr->format == FORMAT_NET );
int totalBack = 0; int totalBack = 0;
for ( int jj = 0; jj < sendArr->nMsgs; ++jj ) { for ( int jj = 0; jj < sendArr->nMsgs; ++jj ) {
SMSMsgArray* recvArr = smsproto_prepInbound( state, phones[0], port, SMSMsgArray* recvArr = smsproto_prepInbound( state, xwe, phones[0], port,
sendArr->u.msgsNet[jj].data, sendArr->u.msgsNet[jj].data,
sendArr->u.msgsNet[jj].len ); sendArr->u.msgsNet[jj].len );
@ -1013,21 +1016,21 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
/* Now let's add a too-long message and unpack only the first part. Make /* Now let's add a too-long message and unpack only the first part. Make
sure it's cleaned up correctly */ sure it's cleaned up correctly */
XP_U16 waitSecs; XP_U16 waitSecs;
SMSMsgArray* arr = smsproto_prepOutbound( state, DATA, gameID, buf, 200, "33333", SMSMsgArray* arr = smsproto_prepOutbound( state, xwe, DATA, gameID, buf, 200, "33333",
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
XP_ASSERT( !!arr && arr->nMsgs > 1 ); XP_ASSERT( !!arr && arr->nMsgs > 1 );
/* add only part 1 */ /* add only part 1 */
SMSMsgArray* out = smsproto_prepInbound( state, "33333", port, arr->u.msgsNet[0].data, SMSMsgArray* out = smsproto_prepInbound( state, xwe, "33333", port, arr->u.msgsNet[0].data,
arr->u.msgsNet[0].len ); arr->u.msgsNet[0].len );
XP_ASSERT( !out ); XP_ASSERT( !out );
smsproto_freeMsgArray( state, arr ); smsproto_freeMsgArray( state, arr );
/* Try the no-buffer messages */ /* Try the no-buffer messages */
XP_LOGF( "%s(): trying DEATH", __func__ ); XP_LOGF( "%s(): trying DEATH", __func__ );
arr = smsproto_prepOutbound( state, DEATH, gameID, NULL, 0, "33333", arr = smsproto_prepOutbound( state, xwe, DEATH, gameID, NULL, 0, "33333",
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
XP_ASSERT( arr->format == FORMAT_NET ); XP_ASSERT( arr->format == FORMAT_NET );
out = smsproto_prepInbound( state, "33333", port, out = smsproto_prepInbound( state, xwe, "33333", port,
arr->u.msgsNet[0].data, arr->u.msgsNet[0].data,
arr->u.msgsNet[0].len ); arr->u.msgsNet[0].len );
XP_ASSERT( out->format == FORMAT_LOC ); XP_ASSERT( out->format == FORMAT_LOC );
@ -1038,10 +1041,10 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
XP_LOGF( "%s(): DEATH checked out", __func__ ); XP_LOGF( "%s(): DEATH checked out", __func__ );
/* Test port mismatch */ /* Test port mismatch */
arr = smsproto_prepOutbound( state, DEATH, gameID, NULL, 0, "33333", arr = smsproto_prepOutbound( state, xwe, DEATH, gameID, NULL, 0, "33333",
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
XP_ASSERT( arr->format == FORMAT_NET ); XP_ASSERT( arr->format == FORMAT_NET );
out = smsproto_prepInbound( state, "33333", port + 1, out = smsproto_prepInbound( state, xwe, "33333", port + 1,
arr->u.msgsNet[0].data, arr->u.msgsNet[0].data,
arr->u.msgsNet[0].len ); arr->u.msgsNet[0].len );
XP_ASSERT( out == NULL ); XP_ASSERT( out == NULL );
@ -1050,10 +1053,10 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
/* now a message that's unpacked across multiple sessions to test store/load */ /* now a message that's unpacked across multiple sessions to test store/load */
XP_LOGF( "%s(): testing store/restore", __func__ ); XP_LOGF( "%s(): testing store/restore", __func__ );
arr = smsproto_prepOutbound( state, DATA, gameID, (XP_U8*)buf, 200, "33333", arr = smsproto_prepOutbound( state, xwe, DATA, gameID, (XP_U8*)buf, 200, "33333",
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
for ( int ii = 0; ii < arr->nMsgs; ++ii ) { for ( int ii = 0; ii < arr->nMsgs; ++ii ) {
SMSMsgArray* out = smsproto_prepInbound( state, "33333", port, SMSMsgArray* out = smsproto_prepInbound( state, xwe, "33333", port,
arr->u.msgsNet[ii].data, arr->u.msgsNet[ii].data,
arr->u.msgsNet[ii].len ); arr->u.msgsNet[ii].len );
if ( !!out ) { if ( !!out ) {
@ -1066,7 +1069,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
break; break;
} }
smsproto_free( state ); /* give it a chance to store state */ smsproto_free( state ); /* give it a chance to store state */
state = smsproto_init( mpool, dutil ); state = smsproto_init( mpool, xwe, dutil );
} }
/* Really bad to pass a different state than was created with, but now /* Really bad to pass a different state than was created with, but now

View file

@ -78,7 +78,7 @@ typedef struct _SMSMsgArray {
} u; } u;
} SMSMsgArray; } SMSMsgArray;
struct SMSProto* smsproto_init( MPFORMAL XW_DUtilCtxt* dutil ); struct SMSProto* smsproto_init( MPFORMAL XWEnv xwe, XW_DUtilCtxt* dutil );
void smsproto_free( SMSProto* state ); void smsproto_free( SMSProto* state );
@ -90,20 +90,20 @@ void smsproto_free( SMSProto* state );
* freeMsgArray() or there will be leakage. * freeMsgArray() or there will be leakage.
*/ */
SMSMsgArray* smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, SMSMsgArray* smsproto_prepOutbound( SMSProto* state, XWEnv xwe, SMS_CMD cmd,
XP_U32 gameID, const void* buf, XP_U16 buflen, XP_U32 gameID, const void* buf, XP_U16 buflen,
const XP_UCHAR* toPhone, int port, const XP_UCHAR* toPhone, int port,
XP_Bool forceOld, XP_U16* waitSecs ); XP_Bool forceOld, XP_U16* waitSecs );
/* When a message is received, pass it in for reassambly. Non-null return /* When a message is received, pass it in for reassambly. Non-null return
means one or more messages is ready for consumption. */ means one or more messages is ready for consumption. */
SMSMsgArray* smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone, SMSMsgArray* smsproto_prepInbound( SMSProto* state, XWEnv xwe, const XP_UCHAR* fromPhone,
XP_U16 wantPort, const XP_U8* data, XP_U16 len ); XP_U16 wantPort, const XP_U8* data, XP_U16 len );
void smsproto_freeMsgArray( SMSProto* state, SMSMsgArray* arr ); void smsproto_freeMsgArray( SMSProto* state, SMSMsgArray* arr );
# ifdef DEBUG # ifdef DEBUG
void smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil ); void smsproto_runTests( MPFORMAL XWEnv xwe, XW_DUtilCtxt* dutil );
# else # else
# define smsproto_runTests( p1, p2 ) # define smsproto_runTests( p1, p2 )
# endif # endif

View file

@ -432,7 +432,7 @@ handleActionInTray( BoardCtxt* board, XWEnv xwe, XP_S16 index, XP_Bool onDivider
result = handleTrayDuringTrade( board, index ); result = handleTrayDuringTrade( board, index );
} }
} else if ( index >= 0 ) { } else if ( index >= 0 ) {
result = moveTileToArrowLoc( board, (XP_U8)index ); result = moveTileToArrowLoc( board, xwe, (XP_U8)index );
#ifndef DISABLE_TILE_SEL #ifndef DISABLE_TILE_SEL
if ( !result ) { if ( !result ) {
TileBit newBits = 1 << index; TileBit newBits = 1 << index;
@ -468,7 +468,7 @@ handleActionInTray( BoardCtxt* board, XWEnv xwe, XP_S16 index, XP_Bool onDivider
#elif defined XWFEATURE_TRAYUNDO_ONE #elif defined XWFEATURE_TRAYUNDO_ONE
} else if ( index < 0 ) { /* other empty area */ } else if ( index < 0 ) { /* other empty area */
/* it better be true */ /* it better be true */
(void)board_replaceNTiles( board, 1 ); (void)board_replaceNTiles( board, xwe, 1 );
result = XP_TRUE; result = XP_TRUE;
#endif #endif
} }
@ -561,12 +561,12 @@ invalTrayTilesBetween( BoardCtxt* board, XP_U16 tileIndex1,
} /* invalTrayTilesBetween */ } /* invalTrayTilesBetween */
XP_Bool XP_Bool
board_juggleTray( BoardCtxt* board ) board_juggleTray( BoardCtxt* board, XWEnv xwe )
{ {
XP_Bool result = XP_FALSE; XP_Bool result = XP_FALSE;
const XP_S16 turn = board->selPlayer; const XP_S16 turn = board->selPlayer;
if ( checkRevealTray( board ) ) { if ( checkRevealTray( board, xwe ) ) {
XP_S16 nTiles; XP_S16 nTiles;
XP_U16 dividerLoc = getDividerLoc( board ); XP_U16 dividerLoc = getDividerLoc( board );
ModelCtxt* model = board->model; ModelCtxt* model = board->model;

View file

@ -86,113 +86,113 @@ typedef XP_Bool (*XWTimerProc)( void* closure, XWEnv xwe, XWTimerReason why );
typedef struct UtilVtable { typedef struct UtilVtable {
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
XWStreamCtxt* (*m_util_makeStreamFromAddr )(XW_UtilCtxt* uc, XWStreamCtxt* (*m_util_makeStreamFromAddr )(XW_UtilCtxt* uc, XWEnv xwe,
XP_PlayerAddr channelNo ); XP_PlayerAddr channelNo );
#endif #endif
XWBonusType (*m_util_getSquareBonus)( XW_UtilCtxt* uc, XP_U16 boardSize, XWBonusType (*m_util_getSquareBonus)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 boardSize,
XP_U16 col, XP_U16 row ); XP_U16 col, XP_U16 row );
void (*m_util_userError)( XW_UtilCtxt* uc, UtilErrID id ); void (*m_util_userError)( XW_UtilCtxt* uc, XWEnv xwe, UtilErrID id );
void (*m_util_notifyMove)( XW_UtilCtxt* uc, XWStreamCtxt* stream ); void (*m_util_notifyMove)( XW_UtilCtxt* uc, XWEnv xwe, XWStreamCtxt* stream );
void (*m_util_notifyTrade)( XW_UtilCtxt* uc, const XP_UCHAR** tiles, void (*m_util_notifyTrade)( XW_UtilCtxt* uc, XWEnv xwe, const XP_UCHAR** tiles,
XP_U16 nTiles ); XP_U16 nTiles );
void (*m_util_notifyPickTileBlank)( XW_UtilCtxt* uc, XP_U16 playerNum, void (*m_util_notifyPickTileBlank)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 playerNum,
XP_U16 col, XP_U16 row, XP_U16 col, XP_U16 row,
const XP_UCHAR** tileFaces, const XP_UCHAR** tileFaces,
XP_U16 nTiles ); XP_U16 nTiles );
void (*m_util_informNeedPickTiles)( XW_UtilCtxt* uc, XP_Bool isInitial, void (*m_util_informNeedPickTiles)( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool isInitial,
XP_U16 player, XP_U16 nToPick, XP_U16 player, XP_U16 nToPick,
XP_U16 nFaces, const XP_UCHAR** faces, XP_U16 nFaces, const XP_UCHAR** faces,
const XP_U16* counts ); const XP_U16* counts );
void (*m_util_informNeedPassword)( XW_UtilCtxt* uc, XP_U16 playerNum, void (*m_util_informNeedPassword)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 playerNum,
const XP_UCHAR* name ); const XP_UCHAR* name );
void (*m_util_trayHiddenChange)(XW_UtilCtxt* uc, void (*m_util_trayHiddenChange)(XW_UtilCtxt* uc, XWEnv xwe,
XW_TrayVisState newState, XW_TrayVisState newState,
XP_U16 nVisibleRows ); XP_U16 nVisibleRows );
void (*m_util_yOffsetChange)(XW_UtilCtxt* uc, XP_U16 maxOffset, void (*m_util_yOffsetChange)(XW_UtilCtxt* uc, XWEnv xwe, XP_U16 maxOffset,
XP_U16 oldOffset, XP_U16 newOffset ); XP_U16 oldOffset, XP_U16 newOffset );
#ifdef XWFEATURE_TURNCHANGENOTIFY #ifdef XWFEATURE_TURNCHANGENOTIFY
void (*m_util_turnChanged)(XW_UtilCtxt* uc, XP_S16 newTurn); void (*m_util_turnChanged)(XW_UtilCtxt* uc, XWEnv xwe, XP_S16 newTurn);
#endif #endif
void (*m_util_notifyDupStatus)( XW_UtilCtxt* uc, XP_Bool amHost, void (*m_util_notifyDupStatus)( XW_UtilCtxt* uc, XWEnv xwe, XP_Bool amHost,
const XP_UCHAR* msg ); const XP_UCHAR* msg );
void (*m_util_informMove)( XW_UtilCtxt* uc, XP_S16 turn, void (*m_util_informMove)( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 turn,
XWStreamCtxt* expl, XWStreamCtxt* words ); XWStreamCtxt* expl, XWStreamCtxt* words );
void (*m_util_informUndo)( XW_UtilCtxt* uc ); void (*m_util_informUndo)( XW_UtilCtxt* uc, XWEnv xwe );
void (*m_util_informNetDict)( XW_UtilCtxt* uc, XP_LangCode lang, void (*m_util_informNetDict)( XW_UtilCtxt* uc, XWEnv xwe, XP_LangCode lang,
const XP_UCHAR* oldName, const XP_UCHAR* oldName,
const XP_UCHAR* newName, const XP_UCHAR* newName,
const XP_UCHAR* newSum, const XP_UCHAR* newSum,
XWPhoniesChoice phoniesAction ); XWPhoniesChoice phoniesAction );
void (*m_util_notifyGameOver)( XW_UtilCtxt* uc, XP_S16 quitter ); void (*m_util_notifyGameOver)( XW_UtilCtxt* uc, XWEnv xwe, XP_S16 quitter );
#ifdef XWFEATURE_HILITECELL #ifdef XWFEATURE_HILITECELL
XP_Bool (*m_util_hiliteCell)( XW_UtilCtxt* uc, XP_U16 col, XP_U16 row ); XP_Bool (*m_util_hiliteCell)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 col, XP_U16 row );
#endif #endif
XP_Bool (*m_util_engineProgressCallback)( XW_UtilCtxt* uc ); XP_Bool (*m_util_engineProgressCallback)( XW_UtilCtxt* uc, XWEnv xwe );
void (*m_util_setTimer)( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 when, void (*m_util_setTimer)( XW_UtilCtxt* uc, XWEnv xwe, XWTimerReason why, XP_U16 when,
XWTimerProc proc, void* closure ); XWTimerProc proc, void* closure );
void (*m_util_clearTimer)( XW_UtilCtxt* uc, XWTimerReason why ); void (*m_util_clearTimer)( XW_UtilCtxt* uc, XWEnv xwe, XWTimerReason why );
void (*m_util_requestTime)( XW_UtilCtxt* uc ); void (*m_util_requestTime)( XW_UtilCtxt* uc, XWEnv xwe );
XP_Bool (*m_util_altKeyDown)( XW_UtilCtxt* uc ); XP_Bool (*m_util_altKeyDown)( XW_UtilCtxt* uc, XWEnv xwe );
DictionaryCtxt* (*m_util_makeEmptyDict)( XW_UtilCtxt* uc, XWEnv xwe ); DictionaryCtxt* (*m_util_makeEmptyDict)( XW_UtilCtxt* uc, XWEnv xwe );
void (*m_util_notifyIllegalWords)( XW_UtilCtxt* uc, BadWordInfo* bwi, void (*m_util_notifyIllegalWords)( XW_UtilCtxt* uc, XWEnv xwe, BadWordInfo* bwi,
XP_U16 turn, XP_Bool turnLost ); XP_U16 turn, XP_Bool turnLost );
void (*m_util_remSelected)(XW_UtilCtxt* uc); void (*m_util_remSelected)(XW_UtilCtxt* uc, XWEnv xwe);
void (*m_util_timerSelected)(XW_UtilCtxt* uc, XP_Bool inDuplicateMode, void (*m_util_timerSelected)(XW_UtilCtxt* uc, XWEnv xwe, XP_Bool inDuplicateMode,
XP_Bool canPause); XP_Bool canPause);
void (*m_util_formatPauseHistory)( XW_UtilCtxt* uc, XWStreamCtxt* stream, void (*m_util_formatPauseHistory)( XW_UtilCtxt* uc, XWEnv xwe, XWStreamCtxt* stream,
DupPauseType typ, XP_S16 turn, DupPauseType typ, XP_S16 turn,
XP_U32 secsPrev, XP_U32 secsCur, XP_U32 secsPrev, XP_U32 secsCur,
const XP_UCHAR* msg ); const XP_UCHAR* msg );
#ifndef XWFEATURE_MINIWIN #ifndef XWFEATURE_MINIWIN
void (*m_util_bonusSquareHeld)( XW_UtilCtxt* uc, XWBonusType bonus ); void (*m_util_bonusSquareHeld)( XW_UtilCtxt* uc, XWEnv xwe, XWBonusType bonus );
void (*m_util_playerScoreHeld)( XW_UtilCtxt* uc, XP_U16 player ); void (*m_util_playerScoreHeld)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 player );
#endif #endif
#ifdef XWFEATURE_BOARDWORDS #ifdef XWFEATURE_BOARDWORDS
void (*m_util_cellSquareHeld)( XW_UtilCtxt* uc, XWStreamCtxt* words ); void (*m_util_cellSquareHeld)( XW_UtilCtxt* uc, XWEnv xwe, XWStreamCtxt* words );
#endif #endif
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
void (*m_util_informMissing)(XW_UtilCtxt* uc, XP_Bool isServer, void (*m_util_informMissing)(XW_UtilCtxt* uc, XWEnv xwe, XP_Bool isServer,
const CommsAddrRec* addr, XP_U16 nDevs, const CommsAddrRec* addr, XP_U16 nDevs,
XP_U16 nMissing ); XP_U16 nMissing );
void (*m_util_addrChange)( XW_UtilCtxt* uc, const CommsAddrRec* oldAddr, void (*m_util_addrChange)( XW_UtilCtxt* uc, XWEnv xwe, const CommsAddrRec* oldAddr,
const CommsAddrRec* newAddr ); const CommsAddrRec* newAddr );
void (*m_util_setIsServer)(XW_UtilCtxt* uc, XP_Bool isServer ); void (*m_util_setIsServer)(XW_UtilCtxt* uc, XWEnv xwe, XP_Bool isServer );
#endif #endif
void (*m_util_informWordsBlocked)( XW_UtilCtxt* uc, XP_U16 nBadWords, void (*m_util_informWordsBlocked)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 nBadWords,
XWStreamCtxt* words, const XP_UCHAR* dictName ); XWStreamCtxt* words, const XP_UCHAR* dictName );
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
XP_Bool (*m_util_getTraySearchLimits)(XW_UtilCtxt* uc, XP_Bool (*m_util_getTraySearchLimits)(XW_UtilCtxt* uc, XWEnv xwe,
XP_U16* min, XP_U16* max ); XP_U16* min, XP_U16* max );
#endif #endif
#ifdef XWFEATURE_CHAT #ifdef XWFEATURE_CHAT
void (*m_util_showChat)( XW_UtilCtxt* uc, const XP_UCHAR* const msg, void (*m_util_showChat)( XW_UtilCtxt* uc, XWEnv xwe, const XP_UCHAR* const msg,
XP_S16 from, XP_U32 timestamp ); XP_S16 from, XP_U32 timestamp );
#endif #endif
#ifdef SHOW_PROGRESS #ifdef SHOW_PROGRESS
void (*m_util_engineStarting)( XW_UtilCtxt* uc, XP_U16 nBlanks ); void (*m_util_engineStarting)( XW_UtilCtxt* uc, XWEnv xwe, XP_U16 nBlanks );
void (*m_util_engineStopping)( XW_UtilCtxt* uc ); void (*m_util_engineStopping)( XW_UtilCtxt* uc, XWEnv xwe );
#endif #endif
XW_DUtilCtxt* (*m_util_getDevUtilCtxt)( XW_UtilCtxt* uc ); XW_DUtilCtxt* (*m_util_getDevUtilCtxt)( XW_UtilCtxt* uc, XWEnv xwe );
} UtilVtable; } UtilVtable;
@ -206,135 +206,135 @@ struct XW_UtilCtxt {
MPSLOT MPSLOT
}; };
#define util_makeStreamFromAddr(uc,a) \ #define util_makeStreamFromAddr(uc,e,a) \
(uc)->vtable->m_util_makeStreamFromAddr((uc),(a)) (uc)->vtable->m_util_makeStreamFromAddr((uc), (e),(a))
#define util_getSquareBonus(uc,b,c,r) \ #define util_getSquareBonus(uc,e,b,c,r) \
(uc)->vtable->m_util_getSquareBonus((uc),(b),(c),(r)) (uc)->vtable->m_util_getSquareBonus((uc), (e),(b),(c),(r))
#define util_userError(uc,err) \ #define util_userError(uc,e,err) \
(uc)->vtable->m_util_userError((uc),(err)) (uc)->vtable->m_util_userError((uc),(e),(err))
#define util_notifyMove(uc, str) \ #define util_notifyMove(uc,e, str) \
(uc)->vtable->m_util_notifyMove((uc), (str)) (uc)->vtable->m_util_notifyMove((uc), (e), (str))
#define util_notifyTrade(uc, tx, nt) \ #define util_notifyTrade(uc,e, tx, nt) \
(uc)->vtable->m_util_notifyTrade((uc), (tx), (nt)) (uc)->vtable->m_util_notifyTrade((uc), (e), (tx), (nt))
#define util_notifyPickTileBlank( uc, c, r, n, tx, nt ) \ #define util_notifyPickTileBlank( uc,e, c, r, n, tx, nt ) \
(uc)->vtable->m_util_notifyPickTileBlank( (uc), (c), (r), (n), (tx), (nt) ) (uc)->vtable->m_util_notifyPickTileBlank( (uc), (e), (c), (r), (n), (tx), (nt) )
#define util_informNeedPickTiles( uc, ii, pl, np, nt, fc, cn ) \ #define util_informNeedPickTiles( uc,e, ii, pl, np, nt, fc, cn ) \
(uc)->vtable->m_util_informNeedPickTiles( (uc), (ii), (pl), (np), (nt), (fc), (cn) ) (uc)->vtable->m_util_informNeedPickTiles( (uc), (e), (ii), (pl), (np), (nt), (fc), (cn) )
#define util_informNeedPassword( uc, pn, n ) \ #define util_informNeedPassword( uc,e, pn, n ) \
(uc)->vtable->m_util_informNeedPassword( (uc), (pn), (n) ) (uc)->vtable->m_util_informNeedPassword( (uc), (e), (pn), (n) )
#define util_trayHiddenChange( uc, b, n ) \ #define util_trayHiddenChange( uc,e, b, n ) \
(uc)->vtable->m_util_trayHiddenChange((uc), (b), (n)) (uc)->vtable->m_util_trayHiddenChange((uc), (e), (b), (n))
#define util_yOffsetChange( uc, m, o, n ) \ #define util_yOffsetChange( uc,e, m, o, n ) \
(uc)->vtable->m_util_yOffsetChange((uc), (m), (o), (n) ) (uc)->vtable->m_util_yOffsetChange((uc), (e), (m), (o), (n) )
#ifdef XWFEATURE_TURNCHANGENOTIFY #ifdef XWFEATURE_TURNCHANGENOTIFY
# define util_turnChanged( uc, t ) \ # define util_turnChanged( uc,e, t ) \
(uc)->vtable->m_util_turnChanged( (uc), (t) ) (uc)->vtable->m_util_turnChanged( (uc), (e), (t) )
#else #else
# define util_turnChanged( uc, t ) # define util_turnChanged( uc,e, t )
#endif #endif
#define util_notifyDupStatus(uc, h, m) \ #define util_notifyDupStatus(uc,e, h, m) \
(uc)->vtable->m_util_notifyDupStatus( (uc), (h), (m) ) (uc)->vtable->m_util_notifyDupStatus( (uc), (e), (h), (m) )
#define util_informMove(uc,t,e,w) \ #define util_informMove(uc,e,t,ex,w) \
(uc)->vtable->m_util_informMove( (uc), (t), (e), (w)) (uc)->vtable->m_util_informMove( (uc), (e), (t), (ex), (w))
#define util_informUndo(uc) \ #define util_informUndo(uc,e) \
(uc)->vtable->m_util_informUndo( (uc)) (uc)->vtable->m_util_informUndo( (uc), (e))
#define util_informNetDict(uc, cd, on, nn, ns, pa ) \ #define util_informNetDict(uc,e, cd, on, nn, ns, pa ) \
(uc)->vtable->m_util_informNetDict( (uc), (cd), (on), (nn), (ns), \ (uc)->vtable->m_util_informNetDict( (uc), (e), (cd), (on), (nn), (ns), \
(pa) ) (pa) )
#define util_notifyGameOver( uc, q ) \ #define util_notifyGameOver( uc,e, q ) \
(uc)->vtable->m_util_notifyGameOver((uc), (q)) (uc)->vtable->m_util_notifyGameOver((uc), (e), (q))
#ifdef XWFEATURE_HILITECELL #ifdef XWFEATURE_HILITECELL
# define util_hiliteCell( uc, c, r ) \ # define util_hiliteCell( uc,e, c, r ) \
(uc)->vtable->m_util_hiliteCell((uc), (c), (r)) (uc)->vtable->m_util_hiliteCell((uc), (e), (c), (r))
#endif #endif
#define util_engineProgressCallback( uc ) \ #define util_engineProgressCallback( uc,e ) \
(uc)->vtable->m_util_engineProgressCallback((uc)) (uc)->vtable->m_util_engineProgressCallback((uc), (e))
#define util_setTimer( uc, why, when, proc, clos ) \ #define util_setTimer( uc,e, why, when, proc, clos ) \
(uc)->vtable->m_util_setTimer((uc),(why),(when),(proc),(clos)) (uc)->vtable->m_util_setTimer((uc), (e),(why),(when),(proc),(clos))
#define util_clearTimer( uc, why ) \ #define util_clearTimer( uc,e, why ) \
(uc)->vtable->m_util_clearTimer((uc),(why)) (uc)->vtable->m_util_clearTimer((uc), (e),(why))
#define util_requestTime( uc ) \ #define util_requestTime( uc,e ) \
(uc)->vtable->m_util_requestTime((uc)) (uc)->vtable->m_util_requestTime((uc), (e))
#define util_altKeyDown( uc ) \ #define util_altKeyDown( uc,e ) \
(uc)->vtable->m_util_altKeyDown((uc)) (uc)->vtable->m_util_altKeyDown((uc),(e))
#define util_makeEmptyDict( uc, xwe ) \ #define util_makeEmptyDict( uc, e ) \
(uc)->vtable->m_util_makeEmptyDict((uc), (xwe)) (uc)->vtable->m_util_makeEmptyDict((uc), (e))
#define util_notifyIllegalWords( uc, w, p, b ) \ #define util_notifyIllegalWords( uc,e, w, p, b ) \
(uc)->vtable->m_util_notifyIllegalWords((uc),(w),(p),(b)) (uc)->vtable->m_util_notifyIllegalWords((uc), (e),(w),(p),(b))
#define util_remSelected( uc ) \ #define util_remSelected( uc,e ) \
(uc)->vtable->m_util_remSelected((uc)) (uc)->vtable->m_util_remSelected((uc), (e))
#define util_timerSelected( uc, dm, cp ) \ #define util_timerSelected( uc,e, dm, cp ) \
(uc)->vtable->m_util_timerSelected((uc), (dm), (cp)) (uc)->vtable->m_util_timerSelected((uc), (e), (dm), (cp))
#define util_formatPauseHistory( uc, s, typ, turn, secsPrev, secsCur, msg ) \ #define util_formatPauseHistory( uc,e, s, typ, turn, secsPrev, secsCur, msg ) \
(uc)->vtable->m_util_formatPauseHistory( (uc), (s), (typ), (turn), \ (uc)->vtable->m_util_formatPauseHistory( (uc), (e), (s), (typ), (turn), \
(secsPrev), (secsCur), (msg) ) (secsPrev), (secsCur), (msg) )
#ifndef XWFEATURE_MINIWIN #ifndef XWFEATURE_MINIWIN
# define util_bonusSquareHeld( uc, b ) \ # define util_bonusSquareHeld( uc,e, b ) \
(uc)->vtable->m_util_bonusSquareHeld( (uc), (b) ) (uc)->vtable->m_util_bonusSquareHeld( (uc), (e), (b) )
# define util_playerScoreHeld( uc, player ) \ # define util_playerScoreHeld( uc,e, player ) \
(uc)->vtable->m_util_playerScoreHeld( (uc), (player) ) (uc)->vtable->m_util_playerScoreHeld( (uc), (e), (player) )
#endif #endif
#ifdef XWFEATURE_BOARDWORDS #ifdef XWFEATURE_BOARDWORDS
#define util_cellSquareHeld(uc, s) \ #define util_cellSquareHeld(uc,e, s) \
(uc)->vtable->m_util_cellSquareHeld( (uc), (s) ) (uc)->vtable->m_util_cellSquareHeld( (uc), (e), (s) )
#endif #endif
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
# define util_informMissing( uc, is, ct, nd, nm ) \ # define util_informMissing( uc,e, is, ct, nd, nm ) \
(uc)->vtable->m_util_informMissing((uc), (is), (ct), (nd), (nm) ) (uc)->vtable->m_util_informMissing((uc), (e), (is), (ct), (nd), (nm) )
# define util_addrChange( uc, addro, addrn ) \ # define util_addrChange( uc,e, addro, addrn ) \
(uc)->vtable->m_util_addrChange((uc), (addro), (addrn)) (uc)->vtable->m_util_addrChange((uc), (e), (addro), (addrn))
# define util_setIsServer( uc, is ) \ # define util_setIsServer( uc,e, is ) \
(uc)->vtable->m_util_setIsServer((uc), (is)) (uc)->vtable->m_util_setIsServer((uc), (e), (is))
# else # else
# define util_addrChange( uc, addro, addrn ) # define util_addrChange( uc,e, addro, addrn )
#endif #endif
#define util_informWordsBlocked(uc, c, w, d) \ #define util_informWordsBlocked(uc,e, c, w, d) \
(uc)->vtable->m_util_informWordsBlocked( (uc), (c), (w), (d) ) (uc)->vtable->m_util_informWordsBlocked( (uc), (e), (c), (w), (d) )
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
#define util_getTraySearchLimits(uc,min,max) \ #define util_getTraySearchLimits(uc,e,min,max) \
(uc)->vtable->m_util_getTraySearchLimits((uc), (min), (max)) (uc)->vtable->m_util_getTraySearchLimits((uc), (e), (min), (max))
#endif #endif
#ifdef XWFEATURE_CHAT #ifdef XWFEATURE_CHAT
# define util_showChat( uc, m, f, ts ) (uc)->vtable->m_util_showChat((uc),(m),(f), (ts)) # define util_showChat( uc,e, m, f, ts ) (uc)->vtable->m_util_showChat((uc), (e),(m),(f), (ts))
#endif #endif
# ifdef SHOW_PROGRESS # ifdef SHOW_PROGRESS
# define util_engineStarting( uc, nb ) \ # define util_engineStarting( uc,e, nb ) \
(uc)->vtable->m_util_engineStarting((uc),(nb)) (uc)->vtable->m_util_engineStarting((uc), (e),(nb))
# define util_engineStopping( uc ) \ # define util_engineStopping( uc,e ) \
(uc)->vtable->m_util_engineStopping((uc)) (uc)->vtable->m_util_engineStopping((uc), (e))
# else # else
# define util_engineStarting( uc, nb ) # define util_engineStarting( uc,e, nb )
# define util_engineStopping( uc ) # define util_engineStopping( uc,e )
# endif # endif
# define util_getDevUtilCtxt(uc) \ # define util_getDevUtilCtxt(uc,e) \
(uc)->vtable->m_util_getDevUtilCtxt( (uc) ) (uc)->vtable->m_util_getDevUtilCtxt( (uc), (e) )
#endif #endif

View file

@ -558,13 +558,13 @@ setupBoard( CursesBoardGlobals* bGlobals )
XP_U16 fontWidth, fontHt; XP_U16 fontWidth, fontHt;
getFromDict( cGlobals, &fontWidth, &fontHt ); getFromDict( cGlobals, &fontWidth, &fontHt );
BoardDims dims; BoardDims dims;
board_figureLayout( board, cGlobals->gi, board_figureLayout( board, NULL_XWE, cGlobals->gi,
0, 0, width, height, 100, 0, 0, width, height, 100,
150, 200, /* percents */ 150, 200, /* percents */
width*75/100, width*75/100,
fontWidth, fontHt, fontWidth, fontHt,
XP_FALSE, &dims ); XP_FALSE, &dims );
board_applyLayout( board, &dims ); board_applyLayout( board, NULL_XWE, &dims );
XP_LOGF( "%s(): calling board_draw()", __func__ ); XP_LOGF( "%s(): calling board_draw()", __func__ );
board_invalAll( board ); board_invalAll( board );
board_draw( board, NULL_XWE ); board_draw( board, NULL_XWE );
@ -710,7 +710,7 @@ cursesUserError( CursesBoardGlobals* bGlobals, const char* format, ... )
} /* cursesUserError */ } /* cursesUserError */
static void static void
curses_util_notifyPickTileBlank( XW_UtilCtxt* uc, XP_U16 playerNum, curses_util_notifyPickTileBlank( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 playerNum,
XP_U16 XP_UNUSED(col), XP_U16 XP_UNUSED(row), XP_U16 XP_UNUSED(col), XP_U16 XP_UNUSED(row),
const XP_UCHAR** texts, XP_U16 nTiles ) const XP_UCHAR** texts, XP_U16 nTiles )
{ {
@ -728,6 +728,7 @@ curses_util_notifyPickTileBlank( XW_UtilCtxt* uc, XP_U16 playerNum,
static void static void
curses_util_informNeedPickTiles( XW_UtilCtxt* XP_UNUSED(uc), curses_util_informNeedPickTiles( XW_UtilCtxt* XP_UNUSED(uc),
XWEnv XP_UNUSED(xwe),
XP_Bool XP_UNUSED(isInitial), XP_Bool XP_UNUSED(isInitial),
XP_U16 XP_UNUSED(player), XP_U16 XP_UNUSED(player),
XP_U16 XP_UNUSED(nToPick), XP_U16 XP_UNUSED(nToPick),
@ -750,7 +751,7 @@ curses_util_informNeedPickTiles( XW_UtilCtxt* XP_UNUSED(uc),
} }
static void static void
curses_util_userError( XW_UtilCtxt* uc, UtilErrID id ) curses_util_userError( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), UtilErrID id )
{ {
CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure;
XP_Bool silent; XP_Bool silent;
@ -784,6 +785,7 @@ ask_move( gpointer data )
static void static void
curses_util_informNeedPassword( XW_UtilCtxt* XP_UNUSED(uc), curses_util_informNeedPassword( XW_UtilCtxt* XP_UNUSED(uc),
XWEnv XP_UNUSED(xwe),
XP_U16 XP_UNUSED_DBG(playerNum), XP_U16 XP_UNUSED_DBG(playerNum),
const XP_UCHAR* XP_UNUSED_DBG(name) ) const XP_UCHAR* XP_UNUSED_DBG(name) )
{ {
@ -792,7 +794,8 @@ curses_util_informNeedPassword( XW_UtilCtxt* XP_UNUSED(uc),
} /* curses_util_askPassword */ } /* curses_util_askPassword */
static void static void
curses_util_yOffsetChange( XW_UtilCtxt* uc, XP_U16 XP_UNUSED(maxOffset), curses_util_yOffsetChange( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_U16 XP_UNUSED(maxOffset),
XP_U16 oldOffset, XP_U16 newOffset ) XP_U16 oldOffset, XP_U16 newOffset )
{ {
if ( 0 != newOffset ) { if ( 0 != newOffset ) {
@ -806,7 +809,8 @@ curses_util_yOffsetChange( XW_UtilCtxt* uc, XP_U16 XP_UNUSED(maxOffset),
#ifdef XWFEATURE_TURNCHANGENOTIFY #ifdef XWFEATURE_TURNCHANGENOTIFY
static void static void
curses_util_turnChanged( XW_UtilCtxt* uc, XP_S16 XP_UNUSED_DBG(newTurn) ) curses_util_turnChanged( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_S16 XP_UNUSED_DBG(newTurn) )
{ {
XP_LOGF( "%s(newTurn=%d)", __func__, newTurn ); XP_LOGF( "%s(newTurn=%d)", __func__, newTurn );
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure;
@ -815,7 +819,7 @@ curses_util_turnChanged( XW_UtilCtxt* uc, XP_S16 XP_UNUSED_DBG(newTurn) )
#endif #endif
static void static void
curses_util_notifyIllegalWords( XW_UtilCtxt* uc, BadWordInfo* bwi, curses_util_notifyIllegalWords( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), BadWordInfo* bwi,
XP_U16 player, XP_Bool turnLost ) XP_U16 player, XP_Bool turnLost )
{ {
gchar* strs = g_strjoinv( "\", \"", (gchar**)bwi->words ); gchar* strs = g_strjoinv( "\", \"", (gchar**)bwi->words );
@ -834,7 +838,7 @@ curses_util_notifyIllegalWords( XW_UtilCtxt* uc, BadWordInfo* bwi,
/* this needs to change!!! */ /* this needs to change!!! */
static void static void
curses_util_notifyMove( XW_UtilCtxt* uc, XWStreamCtxt* stream ) curses_util_notifyMove( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XWStreamCtxt* stream )
{ {
CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
@ -864,7 +868,8 @@ ask_trade( gpointer data )
} }
static void static void
curses_util_notifyTrade( XW_UtilCtxt* uc, const XP_UCHAR** tiles, XP_U16 nTiles ) curses_util_notifyTrade( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
const XP_UCHAR** tiles, XP_U16 nTiles )
{ {
CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure;
formatConfirmTrade( &globals->cGlobals, tiles, nTiles ); formatConfirmTrade( &globals->cGlobals, tiles, nTiles );
@ -872,7 +877,7 @@ curses_util_notifyTrade( XW_UtilCtxt* uc, const XP_UCHAR** tiles, XP_U16 nTiles
} }
static void static void
curses_util_trayHiddenChange( XW_UtilCtxt* XP_UNUSED(uc), curses_util_trayHiddenChange( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe),
XW_TrayVisState XP_UNUSED(state), XW_TrayVisState XP_UNUSED(state),
XP_U16 XP_UNUSED(nVisibleRows) ) XP_U16 XP_UNUSED(nVisibleRows) )
{ {
@ -888,7 +893,7 @@ cursesShowFinalScores( CursesBoardGlobals* bGlobals )
CommonGlobals* cGlobals = &bGlobals->cGlobals; CommonGlobals* cGlobals = &bGlobals->cGlobals;
stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool) stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool)
cGlobals->params->vtMgr ); cGlobals->params->vtMgr );
server_writeFinalScores( cGlobals->game.server, stream ); server_writeFinalScores( cGlobals->game.server, NULL_XWE, stream );
text = strFromStream( stream ); text = strFromStream( stream );
@ -899,8 +904,9 @@ cursesShowFinalScores( CursesBoardGlobals* bGlobals )
} /* cursesShowFinalScores */ } /* cursesShowFinalScores */
static void static void
curses_util_informMove( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(turn), curses_util_informMove( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XWStreamCtxt* expl, XWStreamCtxt* XP_UNUSED(words)) XP_S16 XP_UNUSED(turn), XWStreamCtxt* expl,
XWStreamCtxt* XP_UNUSED(words))
{ {
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure;
if ( !!bGlobals->boardWin ) { if ( !!bGlobals->boardWin ) {
@ -911,7 +917,7 @@ curses_util_informMove( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(turn),
} }
static void static void
curses_util_notifyDupStatus( XW_UtilCtxt* uc, curses_util_notifyDupStatus( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_Bool XP_UNUSED(amHost), XP_Bool XP_UNUSED(amHost),
const XP_UCHAR* msg ) const XP_UCHAR* msg )
{ {
@ -922,7 +928,7 @@ curses_util_notifyDupStatus( XW_UtilCtxt* uc,
} }
static void static void
curses_util_informUndo( XW_UtilCtxt* uc ) curses_util_informUndo( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure;
if ( !!bGlobals->boardWin ) { if ( !!bGlobals->boardWin ) {
@ -931,7 +937,7 @@ curses_util_informUndo( XW_UtilCtxt* uc )
} }
static void static void
curses_util_notifyGameOver( XW_UtilCtxt* uc, XP_S16 quitter ) curses_util_notifyGameOver( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_S16 quitter )
{ {
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure;
CommonGlobals* cGlobals = &bGlobals->cGlobals; CommonGlobals* cGlobals = &bGlobals->cGlobals;
@ -957,7 +963,8 @@ curses_util_notifyGameOver( XW_UtilCtxt* uc, XP_S16 quitter )
} /* curses_util_notifyGameOver */ } /* curses_util_notifyGameOver */
static void static void
curses_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode XP_UNUSED(lang), curses_util_informNetDict( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_LangCode XP_UNUSED(lang),
const XP_UCHAR* XP_UNUSED_DBG(oldName), const XP_UCHAR* XP_UNUSED_DBG(oldName),
const XP_UCHAR* XP_UNUSED_DBG(newName), const XP_UCHAR* XP_UNUSED_DBG(newName),
const XP_UCHAR* XP_UNUSED_DBG(newSum), const XP_UCHAR* XP_UNUSED_DBG(newSum),
@ -970,7 +977,7 @@ curses_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode XP_UNUSED(lang),
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
static XP_Bool static XP_Bool
curses_util_getTraySearchLimits( XW_UtilCtxt* XP_UNUSED(uc), curses_util_getTraySearchLimits( XW_UtilCtxt* XP_UNUSED(uc),XWEnv XP_UNUSED(xwe),
XP_U16* XP_UNUSED(min), XP_U16* XP_UNUSED(max) ) XP_U16* XP_UNUSED(min), XP_U16* XP_UNUSED(max) )
{ {
XP_ASSERT(0); XP_ASSERT(0);
@ -981,7 +988,7 @@ curses_util_getTraySearchLimits( XW_UtilCtxt* XP_UNUSED(uc),
#ifdef XWFEATURE_HILITECELL #ifdef XWFEATURE_HILITECELL
static XP_Bool static XP_Bool
curses_util_hiliteCell( XW_UtilCtxt* uc, curses_util_hiliteCell( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_U16 XP_UNUSED(col), XP_U16 XP_UNUSED(row) ) XP_U16 XP_UNUSED(col), XP_U16 XP_UNUSED(row) )
{ {
CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure;
@ -993,19 +1000,19 @@ curses_util_hiliteCell( XW_UtilCtxt* uc,
#endif #endif
static XP_Bool static XP_Bool
curses_util_engineProgressCallback( XW_UtilCtxt* XP_UNUSED(uc) ) curses_util_engineProgressCallback( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe) )
{ {
return XP_TRUE; return XP_TRUE;
} /* curses_util_engineProgressCallback */ } /* curses_util_engineProgressCallback */
static XP_Bool static XP_Bool
curses_util_altKeyDown( XW_UtilCtxt* XP_UNUSED(uc) ) curses_util_altKeyDown( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe) )
{ {
return XP_FALSE; return XP_FALSE;
} }
static void static void
curses_util_remSelected( XW_UtilCtxt* uc ) curses_util_remSelected( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure;
CommonGlobals* cGlobals = (CommonGlobals*)uc->closure; CommonGlobals* cGlobals = (CommonGlobals*)uc->closure;
@ -1014,7 +1021,7 @@ curses_util_remSelected( XW_UtilCtxt* uc )
stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool) stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool)
cGlobals->params->vtMgr ); cGlobals->params->vtMgr );
board_formatRemainingTiles( cGlobals->game.board, stream ); board_formatRemainingTiles( cGlobals->game.board, NULL_XWE, stream );
text = strFromStream( stream ); text = strFromStream( stream );
@ -1024,7 +1031,7 @@ curses_util_remSelected( XW_UtilCtxt* uc )
} }
static void static void
curses_util_timerSelected( XW_UtilCtxt* XP_UNUSED(uc), curses_util_timerSelected( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe),
XP_Bool XP_UNUSED_DBG(inDuplicateMode), XP_Bool XP_UNUSED_DBG(inDuplicateMode),
XP_Bool XP_UNUSED_DBG(canPause) ) XP_Bool XP_UNUSED_DBG(canPause) )
{ {
@ -1033,7 +1040,8 @@ curses_util_timerSelected( XW_UtilCtxt* XP_UNUSED(uc),
} }
static void static void
curses_util_bonusSquareHeld( XW_UtilCtxt* uc, XWBonusType bonus ) curses_util_bonusSquareHeld( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XWBonusType bonus )
{ {
LOG_FUNC(); LOG_FUNC();
XP_USE( uc ); XP_USE( uc );
@ -1041,7 +1049,7 @@ curses_util_bonusSquareHeld( XW_UtilCtxt* uc, XWBonusType bonus )
} }
static void static void
curses_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player ) curses_util_playerScoreHeld( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 player )
{ {
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)uc->closure;
LastMoveInfo lmi; LastMoveInfo lmi;
@ -1055,7 +1063,8 @@ curses_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player )
#ifdef XWFEATURE_BOARDWORDS #ifdef XWFEATURE_BOARDWORDS
static void static void
curses_util_cellSquareHeld( XW_UtilCtxt* uc, XWStreamCtxt* words ) curses_util_cellSquareHeld( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XWStreamCtxt* words )
{ {
XP_USE( uc ); XP_USE( uc );
catOnClose( words, NULL_XWE, NULL ); catOnClose( words, NULL_XWE, NULL );
@ -1064,7 +1073,7 @@ curses_util_cellSquareHeld( XW_UtilCtxt* uc, XWStreamCtxt* words )
#endif #endif
static void static void
curses_util_informWordsBlocked( XW_UtilCtxt* XP_UNUSED(uc), curses_util_informWordsBlocked( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe),
XP_U16 XP_UNUSED_DBG(nBadWords), XP_U16 XP_UNUSED_DBG(nBadWords),
XWStreamCtxt* XP_UNUSED(words), XWStreamCtxt* XP_UNUSED(words),
const XP_UCHAR* XP_UNUSED_DBG(dictName) ) const XP_UCHAR* XP_UNUSED_DBG(dictName) )
@ -1074,7 +1083,8 @@ curses_util_informWordsBlocked( XW_UtilCtxt* XP_UNUSED(uc),
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static XWStreamCtxt* static XWStreamCtxt*
curses_util_makeStreamFromAddr(XW_UtilCtxt* uc, XP_PlayerAddr channelNo ) curses_util_makeStreamFromAddr(XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_PlayerAddr channelNo )
{ {
CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure; CursesBoardGlobals* globals = (CursesBoardGlobals*)uc->closure;
LaunchParams* params = globals->cGlobals.params; LaunchParams* params = globals->cGlobals.params;
@ -1088,7 +1098,7 @@ curses_util_makeStreamFromAddr(XW_UtilCtxt* uc, XP_PlayerAddr channelNo )
#ifdef XWFEATURE_CHAT #ifdef XWFEATURE_CHAT
static void static void
curses_util_showChat( XW_UtilCtxt* uc, curses_util_showChat( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
const XP_UCHAR* const XP_UNUSED_DBG(msg), const XP_UCHAR* const XP_UNUSED_DBG(msg),
XP_S16 XP_UNUSED_DBG(from), XP_U32 XP_UNUSED(timestamp) ) XP_S16 XP_UNUSED_DBG(from), XP_U32 XP_UNUSED(timestamp) )
{ {
@ -1205,7 +1215,7 @@ static bool
handleReplace( void* closure, int XP_UNUSED(key) ) handleReplace( void* closure, int XP_UNUSED(key) )
{ {
CommonGlobals* cGlobals = &((CursesBoardGlobals*)closure)->cGlobals; CommonGlobals* cGlobals = &((CursesBoardGlobals*)closure)->cGlobals;
if ( board_replaceTiles( cGlobals->game.board ) ) { if ( board_replaceTiles( cGlobals->game.board, NULL_XWE ) ) {
board_draw( cGlobals->game.board, NULL_XWE ); board_draw( cGlobals->game.board, NULL_XWE );
} }
return XP_TRUE; return XP_TRUE;
@ -1295,7 +1305,7 @@ static bool
handleJuggle( void* closure, int XP_UNUSED(key) ) handleJuggle( void* closure, int XP_UNUSED(key) )
{ {
CommonGlobals* cGlobals = &((CursesBoardGlobals*)closure)->cGlobals; CommonGlobals* cGlobals = &((CursesBoardGlobals*)closure)->cGlobals;
if ( board_juggleTray( cGlobals->game.board ) ) { if ( board_juggleTray( cGlobals->game.board, NULL_XWE ) ) {
board_draw( cGlobals->game.board, NULL_XWE ); board_draw( cGlobals->game.board, NULL_XWE );
} }
return XP_TRUE; return XP_TRUE;
@ -1309,8 +1319,8 @@ handleHide( void* closure, int XP_UNUSED(key) )
board_getTrayVisState( cGlobals->game.board ); board_getTrayVisState( cGlobals->game.board );
bool draw = curState == TRAY_REVEALED bool draw = curState == TRAY_REVEALED
? board_hideTray( cGlobals->game.board ) ? board_hideTray( cGlobals->game.board, NULL_XWE )
: board_showTray( cGlobals->game.board ); : board_showTray( cGlobals->game.board, NULL_XWE );
if ( draw ) { if ( draw ) {
board_draw( cGlobals->game.board, NULL_XWE ); board_draw( cGlobals->game.board, NULL_XWE );
} }
@ -1323,7 +1333,7 @@ static void
checkAssignFocus( BoardCtxt* board ) checkAssignFocus( BoardCtxt* board )
{ {
if ( OBJ_NONE == board_getFocusOwner(board) ) { if ( OBJ_NONE == board_getFocusOwner(board) ) {
board_focusChanged( board, OBJ_BOARD, XP_TRUE ); board_focusChanged( board, NULL_XWE, OBJ_BOARD, XP_TRUE );
} }
} }
@ -1476,7 +1486,8 @@ handleShowVals( void* closure, int XP_UNUSED(key) )
XWStreamCtxt* stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool) XWStreamCtxt* stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool)
cGlobals->params->vtMgr ); cGlobals->params->vtMgr );
server_formatDictCounts( bGlobals->cGlobals.game.server, stream, 5, XP_FALSE ); server_formatDictCounts( bGlobals->cGlobals.game.server, NULL_XWE,
stream, 5, XP_FALSE );
const XP_U8* data = stream_getPtr( stream ); const XP_U8* data = stream_getPtr( stream );
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
XP_UCHAR buf[len + 1]; XP_UCHAR buf[len + 1];

View file

@ -1535,7 +1535,7 @@ cursesmain( XP_Bool XP_UNUSED(isServer), LaunchParams* params )
endwin(); endwin();
device_store( params->dutil ); device_store( params->dutil, NULL_XWE );
if ( params->useUdp ) { if ( params->useUdp ) {
relaycon_cleanup( params ); relaycon_cleanup( params );

View file

@ -142,7 +142,7 @@ button_press_event( GtkWidget* XP_UNUSED(widget), GdkEventButton *event,
if ( !globals->mouseDown ) { if ( !globals->mouseDown ) {
globals->mouseDown = XP_TRUE; globals->mouseDown = XP_TRUE;
redraw = board_handlePenDown( globals->cGlobals.game.board, redraw = board_handlePenDown( globals->cGlobals.game.board, NULL_XWE,
event->x, event->y, &handled ); event->x, event->y, &handled );
if ( redraw ) { if ( redraw ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
@ -161,8 +161,8 @@ motion_notify_event( GtkWidget* XP_UNUSED(widget), GdkEventMotion *event,
gtkSetAltState( globals, event->state ); gtkSetAltState( globals, event->state );
if ( globals->mouseDown ) { if ( globals->mouseDown ) {
handled = board_handlePenMove( globals->cGlobals.game.board, event->x, handled = board_handlePenMove( globals->cGlobals.game.board,
event->y ); NULL_XWE, event->x, event->y );
if ( handled ) { if ( handled ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
disenable_buttons( globals ); disenable_buttons( globals );
@ -264,7 +264,7 @@ key_press_event( GtkWidget* XP_UNUSED(widget), GdkEventKey* event,
board_handleKeyRepeat( globals->cGlobals.game.board, NULL_XWE, board_handleKeyRepeat( globals->cGlobals.game.board, NULL_XWE,
xpkey, &handled ) xpkey, &handled )
: board_handleKeyDown( globals->cGlobals.game.board, : board_handleKeyDown( globals->cGlobals.game.board,
xpkey, &handled ); NULL_XWE, xpkey, &handled );
if ( draw ) { if ( draw ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
} }
@ -622,16 +622,16 @@ configure_event( GtkWidget* widget, GdkEventConfigure* XP_UNUSED(event),
XP_ASSERT( !cGlobals->params->verticalScore ); /* not supported */ XP_ASSERT( !cGlobals->params->verticalScore ); /* not supported */
BoardDims dims; BoardDims dims;
board_figureLayout( board, cGlobals->gi, board_figureLayout( board, NULL_XWE, cGlobals->gi,
GTK_BOARD_LEFT, GTK_HOR_SCORE_TOP, bdWidth, bdHeight, GTK_BOARD_LEFT, GTK_HOR_SCORE_TOP, bdWidth, bdHeight,
110, 150, 200, bdWidth-25, 16, 16, XP_FALSE, &dims ); 110, 150, 200, bdWidth-25, 16, 16, XP_FALSE, &dims );
board_applyLayout( board, &dims ); board_applyLayout( board, NULL_XWE, &dims );
setCtrlsForTray( globals ); setCtrlsForTray( globals );
board_invalAll( board ); board_invalAll( board );
XP_Bool inOut[2]; XP_Bool inOut[2];
board_zoom( board, 0, inOut ); board_zoom( board, NULL_XWE, 0, inOut );
setZoomButtons( globals, inOut ); setZoomButtons( globals, inOut );
return TRUE; return TRUE;
@ -743,7 +743,8 @@ tile_values_impl( GtkGameGlobals* globals, bool full )
globals, globals,
CHANNEL_NONE, CHANNEL_NONE,
catOnClose ); catOnClose );
server_formatDictCounts( cGlobals->game.server, stream, 5, full ); server_formatDictCounts( cGlobals->game.server, NULL_XWE,
stream, 5, full );
stream_putU8( stream, '\n' ); stream_putU8( stream, '\n' );
stream_destroy( stream, NULL_XWE ); stream_destroy( stream, NULL_XWE );
} }
@ -1134,7 +1135,7 @@ disenable_buttons( GtkGameGlobals* globals )
} }
GameStateInfo gsi; GameStateInfo gsi;
game_getState( &globals->cGlobals.game, &gsi ); game_getState( &globals->cGlobals.game, NULL_XWE, &gsi );
XP_Bool canFlip = 1 < board_visTileCount( globals->cGlobals.game.board ); XP_Bool canFlip = 1 < board_visTileCount( globals->cGlobals.game.board );
gtk_widget_set_sensitive( globals->flip_button, canFlip ); gtk_widget_set_sensitive( globals->flip_button, canFlip );
@ -1232,7 +1233,7 @@ handle_colors_button( GtkWidget* XP_UNUSED(widget),
static void static void
handle_juggle_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals ) handle_juggle_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
{ {
if ( board_juggleTray( globals->cGlobals.game.board ) ) { if ( board_juggleTray( globals->cGlobals.game.board, NULL_XWE ) ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
} }
} /* handle_juggle_button */ } /* handle_juggle_button */
@ -1256,7 +1257,8 @@ handle_toggle_undo( GtkWidget* XP_UNUSED(widget),
GtkGameGlobals* globals ) GtkGameGlobals* globals )
{ {
BoardCtxt* board = globals->cGlobals.game.board; BoardCtxt* board = globals->cGlobals.game.board;
if ( board_redoReplacedTiles( board ) || board_replaceTiles( board ) ) { if ( board_redoReplacedTiles( board, NULL_XWE )
|| board_replaceTiles( board, NULL_XWE ) ) {
board_draw( board, NULL_XWE ); board_draw( board, NULL_XWE );
} }
} }
@ -1264,7 +1266,7 @@ handle_toggle_undo( GtkWidget* XP_UNUSED(widget),
static void static void
handle_trade_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals ) handle_trade_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
{ {
if ( board_beginTrade( globals->cGlobals.game.board ) ) { if ( board_beginTrade( globals->cGlobals.game.board, NULL_XWE ) ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
disenable_buttons( globals ); disenable_buttons( globals );
} }
@ -1291,7 +1293,7 @@ static void
handle_zoomin_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals ) handle_zoomin_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
{ {
XP_Bool inOut[2]; XP_Bool inOut[2];
if ( board_zoom( globals->cGlobals.game.board, 1, inOut ) ) { if ( board_zoom( globals->cGlobals.game.board, NULL_XWE, 1, inOut ) ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
setZoomButtons( globals, inOut ); setZoomButtons( globals, inOut );
} }
@ -1301,7 +1303,7 @@ static void
handle_zoomout_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals ) handle_zoomout_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
{ {
XP_Bool inOut[2]; XP_Bool inOut[2];
if ( board_zoom( globals->cGlobals.game.board, -1, inOut ) ) { if ( board_zoom( globals->cGlobals.game.board, NULL_XWE, -1, inOut ) ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
setZoomButtons( globals, inOut ); setZoomButtons( globals, inOut );
} }
@ -1343,7 +1345,7 @@ scroll_value_changed( GtkAdjustment *adj, GtkGameGlobals* globals )
/* && newValueF <= globals->cGlobals.params->nHidden ); */ /* && newValueF <= globals->cGlobals.params->nHidden ); */
newValue = (XP_U16)newValueF; newValue = (XP_U16)newValueF;
if ( board_setYOffset( globals->cGlobals.game.board, newValue ) ) { if ( board_setYOffset( globals->cGlobals.game.board, NULL_XWE, newValue ) ) {
board_draw( globals->cGlobals.game.board, NULL_XWE ); board_draw( globals->cGlobals.game.board, NULL_XWE );
} }
} /* scroll_value_changed */ } /* scroll_value_changed */
@ -1374,9 +1376,9 @@ handle_hide_button( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
board = globals->cGlobals.game.board; board = globals->cGlobals.game.board;
if ( TRAY_REVEALED == board_getTrayVisState( board ) ) { if ( TRAY_REVEALED == board_getTrayVisState( board ) ) {
draw = board_hideTray( board ); draw = board_hideTray( board, NULL_XWE );
} else { } else {
draw = board_showTray( board ); draw = board_showTray( board, NULL_XWE );
} }
if ( draw ) { if ( draw ) {
board_draw( board, NULL_XWE ); board_draw( board, NULL_XWE );
@ -1533,7 +1535,8 @@ ask_blank( gpointer data )
return 0; return 0;
} }
static void static void
gtk_util_notifyPickTileBlank( XW_UtilCtxt* uc, XP_U16 playerNum, XP_U16 col, gtk_util_notifyPickTileBlank( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_U16 playerNum, XP_U16 col,
XP_U16 row, const XP_UCHAR** texts, XP_U16 nTiles ) XP_U16 row, const XP_UCHAR** texts, XP_U16 nTiles )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1587,8 +1590,8 @@ ask_tiles( gpointer data )
BoardCtxt* board = cGlobals->game.board; BoardCtxt* board = cGlobals->game.board;
XP_Bool draw = XP_TRUE; XP_Bool draw = XP_TRUE;
if ( cGlobals->pickIsInitial ) { if ( cGlobals->pickIsInitial ) {
server_tilesPicked( cGlobals->game.server, cGlobals->selPlayer, server_tilesPicked( cGlobals->game.server, NULL_XWE,
&newTiles ); cGlobals->selPlayer, &newTiles );
} else { } else {
draw = board_commitTurn( cGlobals->game.board, NULL_XWE, draw = board_commitTurn( cGlobals->game.board, NULL_XWE,
XP_TRUE, XP_TRUE, &newTiles ); XP_TRUE, XP_TRUE, &newTiles );
@ -1602,8 +1605,8 @@ ask_tiles( gpointer data )
} }
static void static void
gtk_util_informNeedPickTiles( XW_UtilCtxt* uc, XP_Bool isInitial, gtk_util_informNeedPickTiles( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_U16 player, XP_U16 nToPick, XP_Bool isInitial, XP_U16 player, XP_U16 nToPick,
XP_U16 nFaces, const XP_UCHAR** faces, XP_U16 nFaces, const XP_UCHAR** faces,
const XP_U16* counts ) const XP_U16* counts )
{ {
@ -1631,7 +1634,7 @@ ask_password( gpointer data )
XP_U16 len = VSIZE(buf); XP_U16 len = VSIZE(buf);
if ( gtkpasswdask( cGlobals->askPassName, buf, &len ) ) { if ( gtkpasswdask( cGlobals->askPassName, buf, &len ) ) {
BoardCtxt* board = cGlobals->game.board; BoardCtxt* board = cGlobals->game.board;
if ( board_passwordProvided( board, cGlobals->selPlayer, buf ) ) { if ( board_passwordProvided( board, NULL_XWE, cGlobals->selPlayer, buf ) ) {
board_draw( board, NULL_XWE ); board_draw( board, NULL_XWE );
} }
} }
@ -1639,7 +1642,8 @@ ask_password( gpointer data )
} }
static void static void
gtk_util_informNeedPassword( XW_UtilCtxt* uc, XP_U16 player, const XP_UCHAR* name ) gtk_util_informNeedPassword( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_U16 player, const XP_UCHAR* name )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
@ -1676,7 +1680,8 @@ setCtrlsForTray( GtkGameGlobals* XP_UNUSED(globals) )
} /* setCtrlsForTray */ } /* setCtrlsForTray */
static void static void
gtk_util_trayHiddenChange( XW_UtilCtxt* uc, XW_TrayVisState XP_UNUSED(state), gtk_util_trayHiddenChange( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XW_TrayVisState XP_UNUSED(state),
XP_U16 XP_UNUSED(nVisibleRows) ) XP_U16 XP_UNUSED(nVisibleRows) )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1684,7 +1689,7 @@ gtk_util_trayHiddenChange( XW_UtilCtxt* uc, XW_TrayVisState XP_UNUSED(state),
} /* gtk_util_trayHiddenChange */ } /* gtk_util_trayHiddenChange */
static void static void
gtk_util_yOffsetChange( XW_UtilCtxt* uc, XP_U16 maxOffset, gtk_util_yOffsetChange( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 maxOffset,
XP_U16 XP_UNUSED(oldOffset), XP_U16 XP_UNUSED(oldOffset),
XP_U16 newOffset ) XP_U16 newOffset )
{ {
@ -1700,7 +1705,7 @@ gtk_util_yOffsetChange( XW_UtilCtxt* uc, XP_U16 maxOffset,
#ifdef XWFEATURE_TURNCHANGENOTIFY #ifdef XWFEATURE_TURNCHANGENOTIFY
static void static void
gtk_util_turnChanged( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(newTurn) ) gtk_util_turnChanged( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_S16 XP_UNUSED(newTurn) )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
linuxSaveGame( &globals->cGlobals ); linuxSaveGame( &globals->cGlobals );
@ -1716,7 +1721,7 @@ gtkShowFinalScores( const GtkGameGlobals* globals, XP_Bool ignoreTimeout )
stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool) stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool)
cGlobals->params->vtMgr ); cGlobals->params->vtMgr );
server_writeFinalScores( cGlobals->game.server, stream ); server_writeFinalScores( cGlobals->game.server, NULL_XWE, stream );
text = strFromStream( stream ); text = strFromStream( stream );
stream_destroy( stream, NULL_XWE ); stream_destroy( stream, NULL_XWE );
@ -1738,7 +1743,7 @@ gtkShowFinalScores( const GtkGameGlobals* globals, XP_Bool ignoreTimeout )
} /* gtkShowFinalScores */ } /* gtkShowFinalScores */
static void static void
gtk_util_notifyDupStatus( XW_UtilCtxt* uc, XP_Bool XP_UNUSED(amHost), gtk_util_notifyDupStatus( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_Bool XP_UNUSED(amHost),
const XP_UCHAR* msg ) const XP_UCHAR* msg )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1746,7 +1751,7 @@ gtk_util_notifyDupStatus( XW_UtilCtxt* uc, XP_Bool XP_UNUSED(amHost),
} }
static void static void
gtk_util_informMove( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(turn), gtk_util_informMove( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_S16 XP_UNUSED(turn),
XWStreamCtxt* expl, XWStreamCtxt* words ) XWStreamCtxt* expl, XWStreamCtxt* words )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1756,7 +1761,7 @@ gtk_util_informMove( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(turn),
} }
static void static void
gtk_util_informUndo( XW_UtilCtxt* uc ) gtk_util_informUndo( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
(void)gtkask_timeout( globals->window, "Remote player undid a move", (void)gtkask_timeout( globals->window, "Remote player undid a move",
@ -1764,7 +1769,7 @@ gtk_util_informUndo( XW_UtilCtxt* uc )
} }
static void static void
gtk_util_notifyGameOver( XW_UtilCtxt* uc, XP_S16 quitter ) gtk_util_notifyGameOver( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_S16 quitter )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
@ -1787,7 +1792,8 @@ gtk_util_notifyGameOver( XW_UtilCtxt* uc, XP_S16 quitter )
} /* gtk_util_notifyGameOver */ } /* gtk_util_notifyGameOver */
static void static void
gtk_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode XP_UNUSED(lang), gtk_util_informNetDict( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
XP_LangCode XP_UNUSED(lang),
const XP_UCHAR* oldName, const XP_UCHAR* oldName,
const XP_UCHAR* newName, const XP_UCHAR* newSum, const XP_UCHAR* newName, const XP_UCHAR* newSum,
XWPhoniesChoice phoniesAction ) XWPhoniesChoice phoniesAction )
@ -1812,7 +1818,7 @@ gtk_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode XP_UNUSED(lang),
#ifdef XWFEATURE_HILITECELL #ifdef XWFEATURE_HILITECELL
static XP_Bool static XP_Bool
gtk_util_hiliteCell( XW_UtilCtxt* uc, XP_U16 col, XP_U16 row ) gtk_util_hiliteCell( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 col, XP_U16 row )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
#ifndef DONT_ABORT_ENGINE #ifndef DONT_ABORT_ENGINE
@ -1837,14 +1843,14 @@ gtk_util_hiliteCell( XW_UtilCtxt* uc, XP_U16 col, XP_U16 row )
#endif #endif
static XP_Bool static XP_Bool
gtk_util_altKeyDown( XW_UtilCtxt* uc ) gtk_util_altKeyDown( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
return globals->altKeyDown; return globals->altKeyDown;
} }
static XP_Bool static XP_Bool
gtk_util_engineProgressCallback( XW_UtilCtxt* XP_UNUSED(uc) ) gtk_util_engineProgressCallback( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe) )
{ {
#ifdef DONT_ABORT_ENGINE #ifdef DONT_ABORT_ENGINE
return XP_TRUE; /* keep going */ return XP_TRUE; /* keep going */
@ -1871,7 +1877,8 @@ ask_bad_words( gpointer data )
} }
static void static void
gtk_util_notifyIllegalWords( XW_UtilCtxt* uc, BadWordInfo* bwi, XP_U16 player, gtk_util_notifyIllegalWords( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
BadWordInfo* bwi, XP_U16 player,
XP_Bool turnLost ) XP_Bool turnLost )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1901,7 +1908,7 @@ gtk_util_notifyIllegalWords( XW_UtilCtxt* uc, BadWordInfo* bwi, XP_U16 player,
} /* gtk_util_notifyIllegalWords */ } /* gtk_util_notifyIllegalWords */
static void static void
gtk_util_remSelected( XW_UtilCtxt* uc ) gtk_util_remSelected( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
XWStreamCtxt* stream; XWStreamCtxt* stream;
@ -1909,7 +1916,7 @@ gtk_util_remSelected( XW_UtilCtxt* uc )
stream = mem_stream_make_raw( MEMPOOL stream = mem_stream_make_raw( MEMPOOL
globals->cGlobals.params->vtMgr ); globals->cGlobals.params->vtMgr );
board_formatRemainingTiles( globals->cGlobals.game.board, stream ); board_formatRemainingTiles( globals->cGlobals.game.board, NULL_XWE, stream );
text = strFromStream( stream ); text = strFromStream( stream );
stream_destroy( stream, NULL_XWE ); stream_destroy( stream, NULL_XWE );
@ -1918,7 +1925,7 @@ gtk_util_remSelected( XW_UtilCtxt* uc )
} }
static void static void
gtk_util_timerSelected( XW_UtilCtxt* uc, XP_Bool inDuplicateMode, gtk_util_timerSelected( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_Bool inDuplicateMode,
XP_Bool canPause ) XP_Bool canPause )
{ {
if ( inDuplicateMode ) { if ( inDuplicateMode ) {
@ -1933,7 +1940,7 @@ gtk_util_timerSelected( XW_UtilCtxt* uc, XP_Bool inDuplicateMode,
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static XWStreamCtxt* static XWStreamCtxt*
gtk_util_makeStreamFromAddr(XW_UtilCtxt* uc, XP_PlayerAddr channelNo ) gtk_util_makeStreamFromAddr(XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_PlayerAddr channelNo )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1946,7 +1953,8 @@ gtk_util_makeStreamFromAddr(XW_UtilCtxt* uc, XP_PlayerAddr channelNo )
#ifdef XWFEATURE_CHAT #ifdef XWFEATURE_CHAT
static void static void
gtk_util_showChat( XW_UtilCtxt* uc, const XP_UCHAR* const msg, XP_S16 from, gtk_util_showChat( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
const XP_UCHAR* const msg, XP_S16 from,
XP_U32 timestamp ) XP_U32 timestamp )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
@ -1963,7 +1971,7 @@ gtk_util_showChat( XW_UtilCtxt* uc, const XP_UCHAR* const msg, XP_S16 from,
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
static XP_Bool static XP_Bool
gtk_util_getTraySearchLimits( XW_UtilCtxt* XP_UNUSED(uc), gtk_util_getTraySearchLimits( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe),
XP_U16* XP_UNUSED(min), XP_U16* max ) XP_U16* XP_UNUSED(min), XP_U16* max )
{ {
*max = askNTiles( MAX_TRAY_TILES, *max ); *max = askNTiles( MAX_TRAY_TILES, *max );
@ -1973,7 +1981,7 @@ gtk_util_getTraySearchLimits( XW_UtilCtxt* XP_UNUSED(uc),
#ifndef XWFEATURE_MINIWIN #ifndef XWFEATURE_MINIWIN
static void static void
gtk_util_bonusSquareHeld( XW_UtilCtxt* uc, XWBonusType bonus ) gtk_util_bonusSquareHeld( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XWBonusType bonus )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
gchar* msg = g_strdup_printf( "bonusSquareHeld(bonus=%d)", bonus ); gchar* msg = g_strdup_printf( "bonusSquareHeld(bonus=%d)", bonus );
@ -1982,7 +1990,7 @@ gtk_util_bonusSquareHeld( XW_UtilCtxt* uc, XWBonusType bonus )
} }
static void static void
gtk_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player ) gtk_util_playerScoreHeld( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 player )
{ {
LOG_FUNC(); LOG_FUNC();
@ -2000,7 +2008,7 @@ gtk_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player )
#ifdef XWFEATURE_BOARDWORDS #ifdef XWFEATURE_BOARDWORDS
static void static void
gtk_util_cellSquareHeld( XW_UtilCtxt* uc, XWStreamCtxt* words ) gtk_util_cellSquareHeld( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XWStreamCtxt* words )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
const XP_U8* bytes = stream_getPtr( words ); const XP_U8* bytes = stream_getPtr( words );
@ -2012,7 +2020,7 @@ gtk_util_cellSquareHeld( XW_UtilCtxt* uc, XWStreamCtxt* words )
#endif #endif
static void static void
gtk_util_informWordsBlocked( XW_UtilCtxt* uc, XP_U16 nBadWords, gtk_util_informWordsBlocked( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 nBadWords,
XWStreamCtxt* words, const XP_UCHAR* dict ) XWStreamCtxt* words, const XP_UCHAR* dict )
{ {
XP_U16 len = stream_getSize( words ); XP_U16 len = stream_getSize( words );
@ -2026,7 +2034,7 @@ gtk_util_informWordsBlocked( XW_UtilCtxt* uc, XP_U16 nBadWords,
} }
static void static void
gtk_util_userError( XW_UtilCtxt* uc, UtilErrID id ) gtk_util_userError( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), UtilErrID id )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
XP_Bool silent; XP_Bool silent;
@ -2055,7 +2063,7 @@ ask_move( gpointer data )
} }
static void static void
gtk_util_notifyMove( XW_UtilCtxt* uc, XWStreamCtxt* stream ) gtk_util_notifyMove( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XWStreamCtxt* stream )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
@ -2086,7 +2094,8 @@ ask_trade( gpointer data )
} }
static void static void
gtk_util_notifyTrade( XW_UtilCtxt* uc, const XP_UCHAR** tiles, XP_U16 nTiles ) gtk_util_notifyTrade( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
const XP_UCHAR** tiles, XP_U16 nTiles )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
formatConfirmTrade( &globals->cGlobals, tiles, nTiles ); formatConfirmTrade( &globals->cGlobals, tiles, nTiles );

View file

@ -922,7 +922,7 @@ gtkmain( LaunchParams* params )
if ( params->runSMSTest ) { if ( params->runSMSTest ) {
CommonGlobals cGlobals = {.params = params }; CommonGlobals cGlobals = {.params = params };
setupUtil( &cGlobals ); setupUtil( &cGlobals );
smsproto_runTests( params->mpool, cGlobals.params->dutil ); smsproto_runTests( params->mpool, NULL_XWE, cGlobals.params->dutil );
linux_util_vt_destroy( cGlobals.util ); linux_util_vt_destroy( cGlobals.util );
free( cGlobals.util ); free( cGlobals.util );
} }
@ -933,7 +933,7 @@ gtkmain( LaunchParams* params )
} }
gtk_main(); gtk_main();
device_store( params->dutil ); device_store( params->dutil, NULL_XWE );
/* closeGamesDB( params->pDb ); */ /* closeGamesDB( params->pDb ); */
/* params->pDb = NULL; */ /* params->pDb = NULL; */
relaycon_cleanup( params ); relaycon_cleanup( params );

View file

@ -71,7 +71,7 @@ nplayers_menu_changed( GtkComboBox* combo, GtkNewGameState* state )
gint index = gtk_combo_box_get_active( GTK_COMBO_BOX(combo) ); gint index = gtk_combo_box_get_active( GTK_COMBO_BOX(combo) );
if ( index >= 0 ) { if ( index >= 0 ) {
NGValue value = { .ng_u16 = index + 1 }; NGValue value = { .ng_u16 = index + 1 };
newg_attrChanged( state->newGameCtxt, NG_ATTR_NPLAYERS, value ); newg_attrChanged( state->newGameCtxt, NULL_XWE, NG_ATTR_NPLAYERS, value );
} }
} /* nplayers_menu_changed */ } /* nplayers_menu_changed */
@ -88,7 +88,7 @@ role_combo_changed( GtkComboBox* combo, gpointer gp )
value.ng_role = role; value.ng_role = role;
if ( state->isNewGame ) { if ( state->isNewGame ) {
newg_attrChanged( state->newGameCtxt, NG_ATTR_ROLE, value ); newg_attrChanged( state->newGameCtxt, NULL_XWE, NG_ATTR_ROLE, value );
} else if ( state->loaded ) { } else if ( state->loaded ) {
/* put it back */ /* put it back */
gtk_combo_box_set_active( GTK_COMBO_BOX(combo), state->role ); gtk_combo_box_set_active( GTK_COMBO_BOX(combo), state->role );
@ -243,7 +243,7 @@ on_timer_changed( GtkEditable *editable, gpointer data )
XP_ASSERT( GTK_ENTRY(state->timerField) == GTK_ENTRY(editable) ); XP_ASSERT( GTK_ENTRY(state->timerField) == GTK_ENTRY(editable) );
gchar* text = gtk_editable_get_chars( editable, 0, -1 ); gchar* text = gtk_editable_get_chars( editable, 0, -1 );
NGValue value = { .ng_u16 = atoi(text) }; NGValue value = { .ng_u16 = atoi(text) };
newg_attrChanged( state->newGameCtxt, NG_ATTR_TIMER, value ); newg_attrChanged( state->newGameCtxt, NULL_XWE, NG_ATTR_TIMER, value );
} }
static void static void
@ -264,7 +264,7 @@ static void
handle_duplicate_toggled( GtkWidget* item, GtkNewGameState* state ) handle_duplicate_toggled( GtkWidget* item, GtkNewGameState* state )
{ {
NGValue value = { .ng_bool = gtk_toggle_button_get_active( GTK_TOGGLE_BUTTON(item) ) }; NGValue value = { .ng_bool = gtk_toggle_button_get_active( GTK_TOGGLE_BUTTON(item) ) };
newg_attrChanged( state->newGameCtxt, NG_ATTR_DUPLICATE, value ); newg_attrChanged( state->newGameCtxt, NULL_XWE, NG_ATTR_DUPLICATE, value );
} }
static void static void
@ -703,12 +703,12 @@ gtkNewGameDialog( GtkGameGlobals* globals, CurGameInfo* gi, CommsAddrRec* addr,
dialog = makeNewGameDialog( &state ); dialog = makeNewGameDialog( &state );
newg_load( state.newGameCtxt, gi ); newg_load( state.newGameCtxt, NULL_XWE, gi );
state.loaded = XP_TRUE; state.loaded = XP_TRUE;
gtk_main(); gtk_main();
if ( !state.cancelled && !state.revert ) { if ( !state.cancelled && !state.revert ) {
if ( newg_store( state.newGameCtxt, gi, XP_TRUE ) ) { if ( newg_store( state.newGameCtxt, NULL_XWE, gi, XP_TRUE ) ) {
gi->boardSize = state.nCols; gi->boardSize = state.nCols;
replaceStringIfDifferent( globals->cGlobals.util->mpool, replaceStringIfDifferent( globals->cGlobals.util->mpool,
&gi->dictName, state.dict ); &gi->dictName, state.dict );

View file

@ -25,40 +25,41 @@
#include "gamesdb.h" #include "gamesdb.h"
#include "LocalizedStrIncludes.h" #include "LocalizedStrIncludes.h"
static XP_U32 linux_dutil_getCurSeconds( XW_DUtilCtxt* duc ); static XP_U32 linux_dutil_getCurSeconds( XW_DUtilCtxt* duc, XWEnv xwe );
static const XP_UCHAR* linux_dutil_getUserString( XW_DUtilCtxt* duc, XP_U16 code ); static const XP_UCHAR* linux_dutil_getUserString( XW_DUtilCtxt* duc, XWEnv xwe, XP_U16 code );
static const XP_UCHAR* linux_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XP_U16 code, static const XP_UCHAR* linux_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XWEnv xwe, XP_U16 code,
XP_U16 quantity ); XP_U16 quantity );
static void linux_dutil_storeStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, static void linux_dutil_storeStream( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
XWStreamCtxt* data ); XWStreamCtxt* data );
static void linux_dutil_loadStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, static void linux_dutil_loadStream( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
XWStreamCtxt* inOut ); XWStreamCtxt* inOut );
static void linux_dutil_storePtr( XW_DUtilCtxt* duc, const XP_UCHAR* key, static void linux_dutil_storePtr( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
const void* data, XP_U16 len ); const void* data, XP_U16 len );
static void linux_dutil_loadPtr( XW_DUtilCtxt* duc, const XP_UCHAR* key, static void linux_dutil_loadPtr( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
void* data, XP_U16* lenp ); void* data, XP_U16* lenp );
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
static XP_Bool linux_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, static XP_Bool linux_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, XWEnv xwe,
const XP_UCHAR* p1, const XP_UCHAR* p1,
const XP_UCHAR* p2 ); const XP_UCHAR* p2 );
#endif #endif
#ifdef XWFEATURE_DEVID #ifdef XWFEATURE_DEVID
static const XP_UCHAR* linux_dutil_getDevID( XW_DUtilCtxt* duc, DevIDType* typ ); static const XP_UCHAR* linux_dutil_getDevID( XW_DUtilCtxt* duc, XWEnv xwe, DevIDType* typ );
static void linux_dutil_deviceRegistered( XW_DUtilCtxt* duc, DevIDType typ, static void linux_dutil_deviceRegistered( XW_DUtilCtxt* duc, XWEnv xwe, DevIDType typ,
const XP_UCHAR* idRelay ); const XP_UCHAR* idRelay );
#endif #endif
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
static XP_UCHAR* linux_dutil_md5sum( XW_DUtilCtxt* duc, const XP_U8* ptr, static XP_UCHAR* linux_dutil_md5sum( XW_DUtilCtxt* duc, XWEnv xwe, const XP_U8* ptr,
XP_U16 len ); XP_U16 len );
#endif #endif
static void static void
linux_dutil_notifyPause( XW_DUtilCtxt* XP_UNUSED(duc), XP_U32 XP_UNUSED_DBG(gameID), linux_dutil_notifyPause( XW_DUtilCtxt* XP_UNUSED(duc), XWEnv XP_UNUSED(xwe),
XP_U32 XP_UNUSED_DBG(gameID),
DupPauseType XP_UNUSED_DBG(pauseTyp), DupPauseType XP_UNUSED_DBG(pauseTyp),
XP_U16 XP_UNUSED_DBG(pauser), XP_U16 XP_UNUSED_DBG(pauser),
const XP_UCHAR* XP_UNUSED_DBG(name), const XP_UCHAR* XP_UNUSED_DBG(name),
@ -69,7 +70,7 @@ linux_dutil_notifyPause( XW_DUtilCtxt* XP_UNUSED(duc), XP_U32 XP_UNUSED_DBG(game
} }
static void static void
linux_dutil_onDupTimerChanged( XW_DUtilCtxt* XP_UNUSED(duc), linux_dutil_onDupTimerChanged( XW_DUtilCtxt* XP_UNUSED(duc), XWEnv XP_UNUSED(xwe),
XP_U32 XP_UNUSED_DBG(gameID), XP_U32 XP_UNUSED_DBG(gameID),
XP_U32 XP_UNUSED_DBG(oldVal), XP_U32 XP_UNUSED_DBG(oldVal),
XP_U32 XP_UNUSED_DBG(newVal) ) XP_U32 XP_UNUSED_DBG(newVal) )
@ -125,13 +126,14 @@ void dutils_free( XW_DUtilCtxt** XP_UNUSED_DBG(ducp) )
} }
static XP_U32 static XP_U32
linux_dutil_getCurSeconds( XW_DUtilCtxt* XP_UNUSED(duc) ) linux_dutil_getCurSeconds( XW_DUtilCtxt* XP_UNUSED(duc), XWEnv XP_UNUSED(xwe) )
{ {
return linux_getCurSeconds(); return linux_getCurSeconds();
} }
static const XP_UCHAR* static const XP_UCHAR*
linux_dutil_getUserString( XW_DUtilCtxt* XP_UNUSED(uc), XP_U16 code ) linux_dutil_getUserString( XW_DUtilCtxt* XP_UNUSED(uc),
XWEnv XP_UNUSED(xwe), XP_U16 code )
{ {
switch( code ) { switch( code ) {
case STRD_REMAINING_TILES_ADD: case STRD_REMAINING_TILES_ADD:
@ -216,29 +218,30 @@ linux_dutil_getUserString( XW_DUtilCtxt* XP_UNUSED(uc), XP_U16 code )
} /* linux_dutil_getUserString */ } /* linux_dutil_getUserString */
static const XP_UCHAR* static const XP_UCHAR*
linux_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XP_U16 code, linux_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XWEnv xwe, XP_U16 code,
XP_U16 XP_UNUSED(quantity) ) XP_U16 XP_UNUSED(quantity) )
{ {
return linux_dutil_getUserString( duc, code ); return linux_dutil_getUserString( duc, xwe, code );
} }
static void static void
linux_dutil_storeStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, XWStreamCtxt* stream ) linux_dutil_storeStream( XW_DUtilCtxt* duc, XWEnv xwe,
const XP_UCHAR* key, XWStreamCtxt* stream )
{ {
const void* ptr = stream_getPtr( stream ); const void* ptr = stream_getPtr( stream );
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
linux_dutil_storePtr( duc, key, ptr, len ); linux_dutil_storePtr( duc, xwe, key, ptr, len );
} }
static void static void
linux_dutil_loadStream( XW_DUtilCtxt* duc, const XP_UCHAR* key, linux_dutil_loadStream( XW_DUtilCtxt* duc, XWEnv xwe, const XP_UCHAR* key,
XWStreamCtxt* stream ) XWStreamCtxt* stream )
{ {
XP_U16 len = 0; XP_U16 len = 0;
linux_dutil_loadPtr( duc, key, NULL, &len ); linux_dutil_loadPtr( duc, xwe, key, NULL, &len );
if ( 0 < len ) { if ( 0 < len ) {
XP_U8 buf[len]; XP_U8 buf[len];
linux_dutil_loadPtr( duc, key, buf, &len ); linux_dutil_loadPtr( duc, xwe, key, buf, &len );
stream_putBytes( stream, buf, len ); stream_putBytes( stream, buf, len );
} }
@ -247,7 +250,7 @@ linux_dutil_loadStream( XW_DUtilCtxt* duc, const XP_UCHAR* key,
} }
static void static void
linux_dutil_storePtr( XW_DUtilCtxt* duc, const XP_UCHAR* key, linux_dutil_storePtr( XW_DUtilCtxt* duc, XWEnv XP_UNUSED(xwe), const XP_UCHAR* key,
const void* data, const XP_U16 len ) const void* data, const XP_U16 len )
{ {
LaunchParams* params = (LaunchParams*)duc->closure; LaunchParams* params = (LaunchParams*)duc->closure;
@ -259,7 +262,7 @@ linux_dutil_storePtr( XW_DUtilCtxt* duc, const XP_UCHAR* key,
} }
static void static void
linux_dutil_loadPtr( XW_DUtilCtxt* duc, const XP_UCHAR* key, linux_dutil_loadPtr( XW_DUtilCtxt* duc, XWEnv XP_UNUSED(xwe), const XP_UCHAR* key,
void* data, XP_U16* lenp ) void* data, XP_U16* lenp )
{ {
LaunchParams* params = (LaunchParams*)duc->closure; LaunchParams* params = (LaunchParams*)duc->closure;
@ -294,8 +297,8 @@ linux_dutil_loadPtr( XW_DUtilCtxt* duc, const XP_UCHAR* key,
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
static XP_Bool static XP_Bool
linux_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, const XP_UCHAR* p1, linux_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, XWEnv XP_UNUSED(xwe),
const XP_UCHAR* p2 ) const XP_UCHAR* p1, const XP_UCHAR* p2 )
{ {
LOG_FUNC(); LOG_FUNC();
XP_USE( duc ); XP_USE( duc );
@ -307,14 +310,14 @@ linux_dutil_phoneNumbersSame( XW_DUtilCtxt* duc, const XP_UCHAR* p1,
#ifdef XWFEATURE_DEVID #ifdef XWFEATURE_DEVID
static const XP_UCHAR* static const XP_UCHAR*
linux_dutil_getDevID( XW_DUtilCtxt* duc, DevIDType* typ ) linux_dutil_getDevID( XW_DUtilCtxt* duc, XWEnv XP_UNUSED(xwe), DevIDType* typ )
{ {
LaunchParams* params = (LaunchParams*)duc->closure; LaunchParams* params = (LaunchParams*)duc->closure;
return linux_getDevID( params, typ ); return linux_getDevID( params, typ );
} }
static void static void
linux_dutil_deviceRegistered( XW_DUtilCtxt* duc, DevIDType typ, linux_dutil_deviceRegistered( XW_DUtilCtxt* duc, XWEnv XP_UNUSED(xwe), DevIDType typ,
const XP_UCHAR* idRelay ) const XP_UCHAR* idRelay )
{ {
/* Script discon_ok2.sh is grepping for these strings in logs, so don't /* Script discon_ok2.sh is grepping for these strings in logs, so don't
@ -340,7 +343,8 @@ linux_dutil_deviceRegistered( XW_DUtilCtxt* duc, DevIDType typ,
#ifdef COMMS_CHECKSUM #ifdef COMMS_CHECKSUM
static XP_UCHAR* static XP_UCHAR*
linux_dutil_md5sum( XW_DUtilCtxt* duc, const XP_U8* ptr, XP_U16 len ) linux_dutil_md5sum( XW_DUtilCtxt* duc, XWEnv XP_UNUSED(xwe),
const XP_U8* ptr, XP_U16 len )
{ {
gchar* sum = g_compute_checksum_for_data( G_CHECKSUM_MD5, ptr, len ); gchar* sum = g_compute_checksum_for_data( G_CHECKSUM_MD5, ptr, len );
XP_U16 sumlen = 1 + strlen( sum ); XP_U16 sumlen = 1 + strlen( sum );

View file

@ -433,7 +433,7 @@ gameGotBuf( CommonGlobals* cGlobals, XP_Bool hasDraw, const XP_U8* buf,
before giving the server another shot. So just call the idle before giving the server another shot. So just call the idle
proc. */ proc. */
if ( hasDraw && redraw ) { if ( hasDraw && redraw ) {
util_requestTime( cGlobals->util ); util_requestTime( cGlobals->util, NULL_XWE );
} else { } else {
for ( int ii = 0; ii < 4; ++ii ) { for ( int ii = 0; ii < 4; ++ii ) {
redraw = server_do( game->server, NULL_XWE ) || redraw; redraw = server_do( game->server, NULL_XWE ) || redraw;
@ -547,7 +547,7 @@ catFinalScores( const CommonGlobals* cGlobals, XP_S16 quitter )
cGlobals->gi->players[quitter].name ); cGlobals->gi->players[quitter].name );
stream_catString( stream, buf ); stream_catString( stream, buf );
} }
server_writeFinalScores( cGlobals->game.server, stream ); server_writeFinalScores( cGlobals->game.server, NULL_XWE, stream );
stream_putU8( stream, '\n' ); stream_putU8( stream, '\n' );
stream_destroy( stream, NULL_XWE ); stream_destroy( stream, NULL_XWE );
} /* printFinalScores */ } /* printFinalScores */
@ -1142,7 +1142,7 @@ linShiftFocus( CommonGlobals* cGlobals, XP_Key key, const BoardObjectType* order
curIndex %= 3; curIndex %= 3;
nxt = order[curIndex]; nxt = order[curIndex];
handled = board_focusChanged( board, nxt, XP_TRUE ); handled = board_focusChanged( board, NULL_XWE, nxt, XP_TRUE );
if ( !!nxtP ) { if ( !!nxtP ) {
*nxtP = nxt; *nxtP = nxt;
@ -1442,7 +1442,7 @@ linux_relay_ioproc( GIOChannel* source, GIOCondition condition, gpointer data )
that on the screen before giving the server another that on the screen before giving the server another
shot. So just call the idle proc. */ shot. So just call the idle proc. */
if ( redraw ) { if ( redraw ) {
util_requestTime( cGlobals->util ); util_requestTime( cGlobals->util, NULL_XWE );
} }
} }
} }
@ -1730,7 +1730,7 @@ streamClosed( XWStreamCtxt* stream, XP_PlayerAddr addr, void* closure )
} /* streamClosed */ } /* streamClosed */
static XWStreamCtxt* static XWStreamCtxt*
linux_util_makeStreamFromAddr( XW_UtilCtxt* uctx, XP_U16 channelNo ) linux_util_makeStreamFromAddr( XW_UtilCtxt* uctx, XWEnv XP_UNUSED(xwe), XP_U16 channelNo )
{ {
#if 1 #if 1
/* XWStreamCtxt* stream = linux_mem_stream_make( uctx->closure, channelNo, */ /* XWStreamCtxt* stream = linux_mem_stream_make( uctx->closure, channelNo, */
@ -1773,7 +1773,7 @@ linuxFireTimer( CommonGlobals* cGlobals, XWTimerReason why )
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
static void static void
linux_util_informMissing( XW_UtilCtxt* XP_UNUSED(uc), linux_util_informMissing( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe),
XP_Bool XP_UNUSED_DBG(isServer), XP_Bool XP_UNUSED_DBG(isServer),
const CommsAddrRec* XP_UNUSED_DBG(addr), const CommsAddrRec* XP_UNUSED_DBG(addr),
XP_U16 XP_UNUSED_DBG(nDevs), XP_U16 XP_UNUSED_DBG(nDevs),
@ -1784,7 +1784,7 @@ linux_util_informMissing( XW_UtilCtxt* XP_UNUSED(uc),
} }
static void static void
linux_util_addrChange( XW_UtilCtxt* uc, linux_util_addrChange( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),
const CommsAddrRec* XP_UNUSED(oldAddr), const CommsAddrRec* XP_UNUSED(oldAddr),
const CommsAddrRec* newAddr ) const CommsAddrRec* newAddr )
{ {
@ -1835,7 +1835,7 @@ changeRolesIdle( gpointer data )
} }
static void static void
linux_util_setIsServer( XW_UtilCtxt* uc, XP_Bool isServer ) linux_util_setIsServer( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe),XP_Bool isServer )
{ {
XP_LOGF( "%s(isServer=%d)", __func__, isServer ); XP_LOGF( "%s(isServer=%d)", __func__, isServer );
CommonGlobals* cGlobals = (CommonGlobals*)uc->closure; CommonGlobals* cGlobals = (CommonGlobals*)uc->closure;
@ -2207,7 +2207,8 @@ listDicts( const LaunchParams *params )
} }
static void static void
linux_util_formatPauseHistory( XW_UtilCtxt* XP_UNUSED(uc), XWStreamCtxt* stream, linux_util_formatPauseHistory( XW_UtilCtxt* XP_UNUSED(uc), XWEnv XP_UNUSED(xwe),
XWStreamCtxt* stream,
DupPauseType typ, XP_S16 turn, DupPauseType typ, XP_S16 turn,
XP_U32 whenPrev, XP_U32 whenCur, const XP_UCHAR* msg ) XP_U32 whenPrev, XP_U32 whenCur, const XP_UCHAR* msg )
{ {
@ -2310,7 +2311,7 @@ slowrob_timer_func( gpointer data )
#endif #endif
static void static void
linux_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why, linux_util_setTimer( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XWTimerReason why,
XP_U16 XP_UNUSED_STANDALONE(when), XP_U16 XP_UNUSED_STANDALONE(when),
XWTimerProc proc, void* closure ) XWTimerProc proc, void* closure )
{ {
@ -2360,7 +2361,7 @@ linux_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why,
} /* linux_util_setTimer */ } /* linux_util_setTimer */
static void static void
linux_util_clearTimer( XW_UtilCtxt* uc, XWTimerReason why ) linux_util_clearTimer( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XWTimerReason why )
{ {
CommonGlobals* cGlobals = (CommonGlobals*)uc->closure; CommonGlobals* cGlobals = (CommonGlobals*)uc->closure;
cGlobals->timerInfo[why].proc = NULL; cGlobals->timerInfo[why].proc = NULL;
@ -2387,7 +2388,7 @@ idle_func( gpointer data )
} /* idle_func */ } /* idle_func */
static void static void
linux_util_requestTime( XW_UtilCtxt* uc ) linux_util_requestTime( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
CommonGlobals* cGlobals = (CommonGlobals*)uc->closure; CommonGlobals* cGlobals = (CommonGlobals*)uc->closure;
cGlobals->idleID = g_idle_add( idle_func, cGlobals ); cGlobals->idleID = g_idle_add( idle_func, cGlobals );

View file

@ -246,7 +246,8 @@ parseAndDispatch( LaunchParams* params, uint8_t* buf, int len,
{ {
LinSMSData* storage = getStorage( params ); LinSMSData* storage = getStorage( params );
const XP_UCHAR* fromPhone = addr->u.sms.phone; const XP_UCHAR* fromPhone = addr->u.sms.phone;
SMSMsgArray* arr = smsproto_prepInbound( storage->protoState, fromPhone, SMSMsgArray* arr =
smsproto_prepInbound( storage->protoState, NULL_XWE, fromPhone,
storage->myPort, buf, len ); storage->myPort, buf, len );
if ( NULL != arr ) { if ( NULL != arr ) {
XP_ASSERT( arr->format == FORMAT_LOC ); XP_ASSERT( arr->format == FORMAT_LOC );
@ -286,7 +287,7 @@ linux_sms_init( LaunchParams* params, const gchar* myPhone, XP_U16 myPort,
storage->myPort = myPort; storage->myPort = myPort;
storage->procs = procs; storage->procs = procs;
storage->procClosure = procClosure; storage->procClosure = procClosure;
storage->protoState = smsproto_init( MPPARM(params->mpool) params->dutil ); storage->protoState = smsproto_init( MPPARM(params->mpool) NULL_XWE, params->dutil );
formatQueuePath( myPhone, myPort, storage->myQueue, sizeof(storage->myQueue) ); formatQueuePath( myPhone, myPort, storage->myQueue, sizeof(storage->myQueue) );
XP_LOGFF( " my queue: %s", storage->myQueue ); XP_LOGFF( " my queue: %s", storage->myQueue );
@ -317,7 +318,7 @@ linux_sms_invite( LaunchParams* params, const NetLaunchInfo* nli,
XP_U16 waitSecs; XP_U16 waitSecs;
const XP_Bool forceOld = XP_TRUE; /* Send NOW in case test app kills us */ const XP_Bool forceOld = XP_TRUE; /* Send NOW in case test app kills us */
SMSMsgArray* arr SMSMsgArray* arr
= smsproto_prepOutbound( storage->protoState, INVITE, nli->gameID, ptr, = smsproto_prepOutbound( storage->protoState, NULL_XWE, INVITE, nli->gameID, ptr,
len, toPhone, toPort, forceOld, &waitSecs ); len, toPhone, toPort, forceOld, &waitSecs );
XP_ASSERT( !!arr || !forceOld ); XP_ASSERT( !!arr || !forceOld );
sendOrRetry( params, arr, INVITE, waitSecs, toPhone, toPort, sendOrRetry( params, arr, INVITE, waitSecs, toPhone, toPort,
@ -332,7 +333,7 @@ linux_sms_send( LaunchParams* params, const XP_U8* buf,
{ {
LinSMSData* storage = getStorage( params ); LinSMSData* storage = getStorage( params );
XP_U16 waitSecs; XP_U16 waitSecs;
SMSMsgArray* arr = smsproto_prepOutbound( storage->protoState, DATA, gameID, SMSMsgArray* arr = smsproto_prepOutbound( storage->protoState, NULL_XWE, DATA, gameID,
buf, buflen, phone, port, buf, buflen, phone, port,
XP_TRUE, &waitSecs ); XP_TRUE, &waitSecs );
sendOrRetry( params, arr, DATA, waitSecs, phone, port, gameID, msgNo ); sendOrRetry( params, arr, DATA, waitSecs, phone, port, gameID, msgNo );
@ -382,7 +383,8 @@ retrySend( gpointer data )
RetryClosure* closure = (RetryClosure*)data; RetryClosure* closure = (RetryClosure*)data;
LinSMSData* storage = getStorage( closure->params ); LinSMSData* storage = getStorage( closure->params );
XP_U16 waitSecs; XP_U16 waitSecs;
SMSMsgArray* arr = smsproto_prepOutbound( storage->protoState, closure->cmd, SMSMsgArray* arr = smsproto_prepOutbound( storage->protoState, NULL_XWE,
closure->cmd,
closure->gameID, NULL, 0, closure->gameID, NULL, 0,
closure->phone, closure->port, closure->phone, closure->port,
XP_TRUE, &waitSecs ); XP_TRUE, &waitSecs );

View file

@ -239,7 +239,7 @@ parseBonusFile( XP_U16 nCols, const char* bonusFile )
} }
static XWBonusType static XWBonusType
linux_util_getSquareBonus( XW_UtilCtxt* uc, XP_U16 nCols, linux_util_getSquareBonus( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe), XP_U16 nCols,
XP_U16 col, XP_U16 row ) XP_U16 col, XP_U16 row )
{ {
static XWBonusType* parsedFile = NULL; static XWBonusType* parsedFile = NULL;
@ -278,7 +278,7 @@ linux_util_getSquareBonus( XW_UtilCtxt* uc, XP_U16 nCols,
} /* linux_util_getSquareBonus */ } /* linux_util_getSquareBonus */
static XW_DUtilCtxt* static XW_DUtilCtxt*
linux_util_getDevUtilCtxt( XW_UtilCtxt* uc ) linux_util_getDevUtilCtxt( XW_UtilCtxt* uc, XWEnv XP_UNUSED(xwe) )
{ {
CommonGlobals* cGlobals = (CommonGlobals*)uc->closure; CommonGlobals* cGlobals = (CommonGlobals*)uc->closure;
return cGlobals->params->dutil; return cGlobals->params->dutil;