Revert "toward compiling with gcc8"

This reverts commit d293517e7c.
This commit is contained in:
Eric House 2019-01-29 09:05:54 -08:00
parent d293517e7c
commit 15a2897112
34 changed files with 155 additions and 182 deletions

View file

@ -232,8 +232,7 @@ static void
splitFaces_via_java( JNIEnv* env, AndDictionaryCtxt* ctxt, const XP_U8* ptr, splitFaces_via_java( JNIEnv* env, AndDictionaryCtxt* ctxt, const XP_U8* ptr,
int nFaceBytes, int nFaces, XP_Bool isUTF8 ) int nFaceBytes, int nFaces, XP_Bool isUTF8 )
{ {
const size_t facesBufSize = nFaces*16; XP_UCHAR facesBuf[nFaces*16]; /* seems a reasonable upper bound... */
XP_UCHAR facesBuf[facesBufSize]; /* seems a reasonable upper bound... */
int indx = 0; int indx = 0;
int offsets[nFaces]; int offsets[nFaces];
int nBytes; int nBytes;
@ -268,7 +267,7 @@ splitFaces_via_java( JNIEnv* env, AndDictionaryCtxt* ctxt, const XP_U8* ptr,
} }
deleteLocalRef( env, jstrs ); deleteLocalRef( env, jstrs );
XP_ASSERT( indx < facesBufSize ); XP_ASSERT( indx < VSIZE(facesBuf) );
} }
deleteLocalRef( env, jstrarr ); deleteLocalRef( env, jstrarr );
@ -573,7 +572,7 @@ makeDicts( MPFORMAL JNIEnv *env, DictMgrCtxt* dictMgr, JNIUtilCtxt* jniutil,
jsize len = (*env)->GetArrayLength( env, jdicts ); jsize len = (*env)->GetArrayLength( env, jdicts );
XP_ASSERT( len == (*env)->GetArrayLength( env, jnames ) ); XP_ASSERT( len == (*env)->GetArrayLength( env, jnames ) );
for ( int ii = 0; ii <= MAX_NUM_PLAYERS; ++ii ) { for ( int ii = 0; ii <= VSIZE(dicts->dicts); ++ii ) {
DictionaryCtxt* dict = NULL; DictionaryCtxt* dict = NULL;
if ( ii < len ) { if ( ii < len ) {
jobject jdict = (*env)->GetObjectArrayElement( env, jdicts, ii ); jobject jdict = (*env)->GetObjectArrayElement( env, jdicts, ii );
@ -591,7 +590,7 @@ makeDicts( MPFORMAL JNIEnv *env, DictMgrCtxt* dictMgr, JNIUtilCtxt* jniutil,
if ( 0 == ii ) { if ( 0 == ii ) {
*dictp = dict; *dictp = dict;
} else { } else {
XP_ASSERT( ii-1 < MAX_NUM_PLAYERS ); XP_ASSERT( ii-1 < VSIZE( dicts->dicts ) );
dicts->dicts[ii-1] = dict; dicts->dicts[ii-1] = dict;
} }
} }

View file

@ -576,9 +576,9 @@ getJAddrRec( JNIEnv* env, CommsAddrRec* addr, jobject jaddr )
case COMMS_CONN_RELAY: case COMMS_CONN_RELAY:
addr->u.ip_relay.port = getInt( env, jaddr, "ip_relay_port" ); addr->u.ip_relay.port = getInt( env, jaddr, "ip_relay_port" );
getString( env, jaddr, "ip_relay_hostName", addr->u.ip_relay.hostName, getString( env, jaddr, "ip_relay_hostName", addr->u.ip_relay.hostName,
MAX_HOSTNAME_LEN + 1 ); VSIZE(addr->u.ip_relay.hostName) );
getString( env, jaddr, "ip_relay_invite", addr->u.ip_relay.invite, getString( env, jaddr, "ip_relay_invite", addr->u.ip_relay.invite,
MAX_INVITE_LEN + 1 ); VSIZE(addr->u.ip_relay.invite) );
addr->u.ip_relay.seeksPublicRoom = addr->u.ip_relay.seeksPublicRoom =
getBool( env, jaddr, "ip_relay_seeksPublicRoom" ); getBool( env, jaddr, "ip_relay_seeksPublicRoom" );
addr->u.ip_relay.advertiseRoom = addr->u.ip_relay.advertiseRoom =
@ -587,19 +587,19 @@ getJAddrRec( JNIEnv* env, CommsAddrRec* addr, jobject jaddr )
break; break;
case COMMS_CONN_SMS: case COMMS_CONN_SMS:
getString( env, jaddr, "sms_phone", addr->u.sms.phone, getString( env, jaddr, "sms_phone", addr->u.sms.phone,
MAX_PHONE_LEN + 1 ); VSIZE(addr->u.sms.phone) );
// XP_LOGF( "%s: got SMS; phone=%s", __func__, addr->u.sms.phone ); // XP_LOGF( "%s: got SMS; phone=%s", __func__, addr->u.sms.phone );
addr->u.sms.port = getInt( env, jaddr, "sms_port" ); addr->u.sms.port = getInt( env, jaddr, "sms_port" );
break; break;
case COMMS_CONN_BT: case COMMS_CONN_BT:
getString( env, jaddr, "bt_hostName", addr->u.bt.hostName, getString( env, jaddr, "bt_hostName", addr->u.bt.hostName,
MAX_HOSTNAME_LEN + 1 ); VSIZE(addr->u.bt.hostName) );
getString( env, jaddr, "bt_btAddr", addr->u.bt.btAddr.chars, getString( env, jaddr, "bt_btAddr", addr->u.bt.btAddr.chars,
MAX_BTADDR_STR_LEN ); VSIZE(addr->u.bt.btAddr.chars) );
break; break;
case COMMS_CONN_P2P: case COMMS_CONN_P2P:
getString( env, jaddr, "p2p_addr", addr->u.p2p.mac_addr, getString( env, jaddr, "p2p_addr", addr->u.p2p.mac_addr,
MAX_P2P_MAC_LEN + 1 ); VSIZE(addr->u.p2p.mac_addr) );
break; break;
default: default:
XP_ASSERT(0); XP_ASSERT(0);

View file

@ -323,7 +323,7 @@ and_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 when,
{ {
UTIL_CBK_HEADER("setTimer", "(III)V" ); UTIL_CBK_HEADER("setTimer", "(III)V" );
XP_ASSERT( why < NUM_TIMERS_PLUS_ONE ); XP_ASSERT( why < VSIZE(util->timerStorage) );
TimerStorage* storage = &util->timerStorage[why]; TimerStorage* storage = &util->timerStorage[why];
storage->proc = proc; storage->proc = proc;
storage->closure = closure; storage->closure = closure;
@ -388,7 +388,7 @@ and_dutil_getUserString( XW_DUtilCtxt* duc, 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;" );
int index = stringCode - 1; /* see LocalizedStrIncludes.h */ int index = stringCode - 1; /* see LocalizedStrIncludes.h */
XP_ASSERT( index < N_AND_USER_STRINGS ); XP_ASSERT( index < VSIZE( dutil->userStrings ) );
XP_ASSERT( 0 == (dutil->userStringsBits & (1 << index)) ); XP_ASSERT( 0 == (dutil->userStringsBits & (1 << index)) );
@ -417,7 +417,7 @@ and_dutil_getUserQuantityString( XW_DUtilCtxt* duc, XP_U16 stringCode, XP_U16 qu
XP_UCHAR* result = ""; XP_UCHAR* result = "";
DUTIL_CBK_HEADER("getUserQuantityString", "(II)Ljava/lang/String;" ); DUTIL_CBK_HEADER("getUserQuantityString", "(II)Ljava/lang/String;" );
int index = stringCode - 1; /* see LocalizedStrIncludes.h */ int index = stringCode - 1; /* see LocalizedStrIncludes.h */
XP_ASSERT( index < N_AND_USER_STRINGS ); XP_ASSERT( index < VSIZE( dutil->userStrings ) );
XP_UCHAR** ptrs; XP_UCHAR** ptrs;
dutil->userStringsBits |= 1 << index; dutil->userStringsBits |= 1 << index;
@ -908,7 +908,7 @@ destroyDUtil( XW_DUtilCtxt** dutilp )
(*env)->DeleteGlobalRef( env, dutil->jdutil ); (*env)->DeleteGlobalRef( env, dutil->jdutil );
} }
for ( int ii = 0; ii < N_AND_USER_STRINGS; ++ii ) { for ( int ii = 0; ii < VSIZE(dutil->userStrings); ++ii ) {
XP_UCHAR* ptr = dutil->userStrings[ii]; XP_UCHAR* ptr = dutil->userStrings[ii];
if ( NULL != ptr ) { if ( NULL != ptr ) {
if ( 0 == (dutil->userStringsBits & (1 << ii)) ) { if ( 0 == (dutil->userStringsBits & (1 << ii)) ) {

View file

@ -329,8 +329,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_cleanGlobals
} }
} }
#define GI_INTS_SIZE 6 static const SetInfo gi_ints[] = {
static const SetInfo gi_ints[GI_INTS_SIZE] = {
ARR_MEMBER( CurGameInfo, nPlayers ) ARR_MEMBER( CurGameInfo, nPlayers )
,ARR_MEMBER( CurGameInfo, gameSeconds ) ,ARR_MEMBER( CurGameInfo, gameSeconds )
,ARR_MEMBER( CurGameInfo, boardSize ) ,ARR_MEMBER( CurGameInfo, boardSize )
@ -339,16 +338,14 @@ static const SetInfo gi_ints[GI_INTS_SIZE] = {
,ARR_MEMBER( CurGameInfo, forceChannel ) ,ARR_MEMBER( CurGameInfo, forceChannel )
}; };
#define GI_BOOLS_SIZE 4 static const SetInfo gi_bools[] = {
static const SetInfo gi_bools[GI_BOOLS_SIZE] = {
ARR_MEMBER( CurGameInfo, hintsNotAllowed ) ARR_MEMBER( CurGameInfo, hintsNotAllowed )
,ARR_MEMBER( CurGameInfo, timerEnabled ) ,ARR_MEMBER( CurGameInfo, timerEnabled )
,ARR_MEMBER( CurGameInfo, allowPickTiles ) ,ARR_MEMBER( CurGameInfo, allowPickTiles )
,ARR_MEMBER( CurGameInfo, allowHintRect ) ,ARR_MEMBER( CurGameInfo, allowHintRect )
}; };
#define PL_INTS_SIZE 2 static const SetInfo pl_ints[] = {
static const SetInfo pl_ints[PL_INTS_SIZE] = {
ARR_MEMBER( LocalPlayer, robotIQ ) ARR_MEMBER( LocalPlayer, robotIQ )
,ARR_MEMBER( LocalPlayer, secondsUsed ) ,ARR_MEMBER( LocalPlayer, secondsUsed )
}; };
@ -357,10 +354,10 @@ static CurGameInfo*
makeGI( MPFORMAL JNIEnv* env, jobject jgi ) makeGI( MPFORMAL JNIEnv* env, jobject jgi )
{ {
CurGameInfo* gi = (CurGameInfo*)XP_CALLOC( mpool, sizeof(*gi) ); CurGameInfo* gi = (CurGameInfo*)XP_CALLOC( mpool, sizeof(*gi) );
VDECL( XP_UCHAR, buf, 256 ); /* in case needs whole path */ XP_UCHAR buf[256]; /* in case needs whole path */
getInts( env, (void*)gi, jgi, gi_ints, GI_INTS_SIZE ); getInts( env, (void*)gi, jgi, gi_ints, VSIZE(gi_ints) );
getBools( env, (void*)gi, jgi, gi_bools, GI_BOOLS_SIZE ); getBools( env, (void*)gi, jgi, gi_bools, VSIZE(gi_bools) );
/* Unlike on other platforms, gi is created without a call to /* Unlike on other platforms, gi is created without a call to
game_makeNewGame, which sets gameID. So check here if it's still unset game_makeNewGame, which sets gameID. So check here if it's still unset
@ -393,7 +390,7 @@ makeGI( MPFORMAL JNIEnv* env, jobject jgi )
jobject jlp = (*env)->GetObjectArrayElement( env, jplayers, ii ); jobject jlp = (*env)->GetObjectArrayElement( env, jplayers, ii );
XP_ASSERT( !!jlp ); XP_ASSERT( !!jlp );
getInts( env, (void*)lp, jlp, pl_ints, PL_INTS_SIZE ); getInts( env, (void*)lp, jlp, pl_ints, VSIZE(pl_ints) );
lp->isLocal = getBool( env, jlp, "isLocal" ); lp->isLocal = getBool( env, jlp, "isLocal" );
@ -414,8 +411,7 @@ makeGI( MPFORMAL JNIEnv* env, jobject jgi )
return gi; return gi;
} /* makeGI */ } /* makeGI */
#define NLI_INTS_SIZE 7 static const SetInfo nli_ints[] = {
static const SetInfo nli_ints[NLI_INTS_SIZE] = {
ARR_MEMBER( NetLaunchInfo, _conTypes ), ARR_MEMBER( NetLaunchInfo, _conTypes ),
ARR_MEMBER( NetLaunchInfo, lang ), ARR_MEMBER( NetLaunchInfo, lang ),
ARR_MEMBER( NetLaunchInfo, forceChannel ), ARR_MEMBER( NetLaunchInfo, forceChannel ),
@ -425,13 +421,11 @@ static const SetInfo nli_ints[NLI_INTS_SIZE] = {
ARR_MEMBER( NetLaunchInfo, osVers ), ARR_MEMBER( NetLaunchInfo, osVers ),
}; };
#define NLI_BOOLS_SIZE 1 static const SetInfo nli_bools[] = {
static const SetInfo nli_bools[NLI_BOOLS_SIZE] = {
ARR_MEMBER( NetLaunchInfo, isGSM ) ARR_MEMBER( NetLaunchInfo, isGSM )
}; };
#define NLI_STRS_SIZE 7 static const SetInfo nli_strs[] = {
static const SetInfo nli_strs[NLI_STRS_SIZE] = {
ARR_MEMBER( NetLaunchInfo, dict ), ARR_MEMBER( NetLaunchInfo, dict ),
ARR_MEMBER( NetLaunchInfo, gameName ), ARR_MEMBER( NetLaunchInfo, gameName ),
ARR_MEMBER( NetLaunchInfo, room ), ARR_MEMBER( NetLaunchInfo, room ),
@ -444,17 +438,17 @@ static const SetInfo nli_strs[NLI_STRS_SIZE] = {
static void static void
loadNLI( JNIEnv* env, NetLaunchInfo* nli, jobject jnli ) loadNLI( JNIEnv* env, NetLaunchInfo* nli, jobject jnli )
{ {
getInts( env, (void*)nli, jnli, nli_ints, NLI_INTS_SIZE ); getInts( env, (void*)nli, jnli, nli_ints, VSIZE(nli_ints) );
getBools( env, (void*)nli, jnli, nli_bools, NLI_BOOLS_SIZE ); getBools( env, (void*)nli, jnli, nli_bools, VSIZE(nli_bools) );
getStrings( env, (void*)nli, jnli, nli_strs, NLI_STRS_SIZE ); getStrings( env, (void*)nli, jnli, nli_strs, VSIZE(nli_strs) );
} }
static void static void
setNLI( JNIEnv* env, jobject jnli, const NetLaunchInfo* nli ) setNLI( JNIEnv* env, jobject jnli, const NetLaunchInfo* nli )
{ {
setInts( env, jnli, (void*)nli, nli_ints, NLI_INTS_SIZE ); setInts( env, jnli, (void*)nli, nli_ints, VSIZE(nli_ints) );
setBools( env, jnli, (void*)nli, nli_bools, NLI_BOOLS_SIZE ); setBools( env, jnli, (void*)nli, nli_bools, VSIZE(nli_bools) );
setStrings( env, jnli, (void*)nli, nli_strs, NLI_STRS_SIZE ); setStrings( env, jnli, (void*)nli, nli_strs, VSIZE(nli_strs) );
} }
static void static void
@ -462,8 +456,8 @@ setJGI( JNIEnv* env, jobject jgi, const CurGameInfo* gi )
{ {
// set fields // set fields
setInts( env, jgi, (void*)gi, gi_ints, GI_INTS_SIZE ); setInts( env, jgi, (void*)gi, gi_ints, VSIZE(gi_ints) );
setBools( env, jgi, (void*)gi, gi_bools, GI_BOOLS_SIZE ); setBools( env, jgi, (void*)gi, gi_bools, VSIZE(gi_bools) );
setString( env, jgi, "dictName", gi->dictName ); setString( env, jgi, "dictName", gi->dictName );
@ -482,7 +476,7 @@ setJGI( JNIEnv* env, jobject jgi, const CurGameInfo* gi )
jobject jlp = (*env)->GetObjectArrayElement( env, jplayers, ii ); jobject jlp = (*env)->GetObjectArrayElement( env, jplayers, ii );
XP_ASSERT( !!jlp ); XP_ASSERT( !!jlp );
setInts( env, jlp, (void*)lp, pl_ints, PL_INTS_SIZE ); setInts( env, jlp, (void*)lp, pl_ints, VSIZE(pl_ints) );
setBool( env, jlp, "isLocal", lp->isLocal ); setBool( env, jlp, "isLocal", lp->isLocal );
setString( env, jlp, "name", lp->name ); setString( env, jlp, "name", lp->name );
@ -498,8 +492,7 @@ setJGI( JNIEnv* env, jobject jgi, const CurGameInfo* gi )
} /* setJGI */ } /* setJGI */
#ifdef COMMON_LAYOUT #ifdef COMMON_LAYOUT
#define BD_INTS_SIZE 16 static const SetInfo bd_ints[] = {
static const SetInfo bd_ints[BD_INTS_SIZE] = {
ARR_MEMBER( BoardDims, left ) ARR_MEMBER( BoardDims, left )
,ARR_MEMBER( BoardDims, top ) ,ARR_MEMBER( BoardDims, top )
,ARR_MEMBER( BoardDims, width ) ,ARR_MEMBER( BoardDims, width )
@ -521,13 +514,13 @@ static const SetInfo bd_ints[BD_INTS_SIZE] = {
static void static void
dimsJToC( JNIEnv* env, BoardDims* out, jobject jdims ) dimsJToC( JNIEnv* env, BoardDims* out, jobject jdims )
{ {
getInts( env, (void*)out, jdims, bd_ints, BD_INTS_SIZE ); getInts( env, (void*)out, jdims, bd_ints, VSIZE(bd_ints) );
} }
static void static void
dimsCtoJ( JNIEnv* env, jobject jdims, const BoardDims* in ) dimsCtoJ( JNIEnv* env, jobject jdims, const BoardDims* in )
{ {
setInts( env, jdims, (void*)in, bd_ints, BD_INTS_SIZE ); setInts( env, jdims, (void*)in, bd_ints, VSIZE(bd_ints) );
} }
#endif #endif
@ -1256,7 +1249,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1zoom
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, zoomBy, canInOut );
VDECL( 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();
return result; return result;
@ -1791,7 +1784,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_comms_1getAddrs
XWJNI_START(); XWJNI_START();
XP_ASSERT( state->game.comms ); XP_ASSERT( state->game.comms );
if ( !!state->game.comms ) { if ( !!state->game.comms ) {
VDECL( CommsAddrRec, addrs, MAX_NUM_PLAYERS ); CommsAddrRec addrs[MAX_NUM_PLAYERS];
XP_U16 count = VSIZE(addrs); XP_U16 count = VSIZE(addrs);
comms_getAddrs( state->game.comms, addrs, &count ); comms_getAddrs( state->game.comms, addrs, &count );
@ -1884,7 +1877,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1summarize
for ( XP_U32 st = 0; addr_iter( &addr, &typ, &st ); ) { for ( XP_U32 st = 0; addr_iter( &addr, &typ, &st ); ) {
switch( typ ) { switch( typ ) {
case COMMS_CONN_RELAY: { case COMMS_CONN_RELAY: {
VDECL( XP_UCHAR, buf, 128 ); XP_UCHAR buf[128];
XP_U16 len = VSIZE(buf); XP_U16 len = VSIZE(buf);
if ( comms_getRelayID( comms, buf, &len ) ) { if ( comms_getRelayID( comms, buf, &len ) ) {
XP_ASSERT( '\0' == buf[len-1] ); /* failed! */ XP_ASSERT( '\0' == buf[len-1] ); /* failed! */
@ -1897,7 +1890,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1summarize
case COMMS_CONN_BT: case COMMS_CONN_BT:
case COMMS_CONN_P2P: case COMMS_CONN_P2P:
case COMMS_CONN_SMS: { case COMMS_CONN_SMS: {
VDECL( CommsAddrRec, addrs, MAX_NUM_PLAYERS ); CommsAddrRec addrs[MAX_NUM_PLAYERS];
XP_U16 count = VSIZE(addrs); XP_U16 count = VSIZE(addrs);
comms_getAddrs( comms, addrs, &count ); comms_getAddrs( comms, addrs, &count );
@ -2017,15 +2010,12 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1getGi
XWJNI_END(); XWJNI_END();
} }
#define GSI_INTS_SIZE 3 static const SetInfo gsi_ints[] = {
static const SetInfo gsi_ints[GSI_INTS_SIZE] = {
ARR_MEMBER( GameStateInfo, visTileCount ), ARR_MEMBER( GameStateInfo, visTileCount ),
ARR_MEMBER( GameStateInfo, nPendingMessages ), ARR_MEMBER( GameStateInfo, nPendingMessages ),
ARR_MEMBER( GameStateInfo, trayVisState ), ARR_MEMBER( GameStateInfo, trayVisState ),
}; };
static const SetInfo gsi_bools[] = {
#define GSI_BOOLS_SIZE 10
static const SetInfo gsi_bools[GSI_BOOLS_SIZE] = {
ARR_MEMBER( GameStateInfo,canHint ), ARR_MEMBER( GameStateInfo,canHint ),
ARR_MEMBER( GameStateInfo, canUndo ), ARR_MEMBER( GameStateInfo, canUndo ),
ARR_MEMBER( GameStateInfo, canRedo ), ARR_MEMBER( GameStateInfo, canRedo ),
@ -2046,8 +2036,8 @@ Java_org_eehouse_android_xw4_jni_XwJNI_game_1getState
GameStateInfo info; GameStateInfo info;
game_getState( &state->game, &info ); game_getState( &state->game, &info );
setInts( env, jgsi, (void*)&info, gsi_ints, GSI_INTS_SIZE ); setInts( env, jgsi, (void*)&info, gsi_ints, VSIZE(gsi_ints) );
setBools( env, jgsi, (void*)&info, gsi_bools, GSI_BOOLS_SIZE ); setBools( env, jgsi, (void*)&info, gsi_bools, VSIZE(gsi_bools) );
XWJNI_END(); XWJNI_END();
} }
@ -2340,7 +2330,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_dict_1iter_1getCounts
LengthsArray lens; LengthsArray lens;
if ( 0 < dict_countWords( &iter, &lens ) ) { if ( 0 < dict_countWords( &iter, &lens ) ) {
XP_ASSERT( sizeof(jint) == sizeof(lens.lens[0]) ); XP_ASSERT( sizeof(jint) == sizeof(lens.lens[0]) );
result = makeIntArray( env, MAX_COLS_DICT+1, (jint*)&lens.lens, result = makeIntArray( env, VSIZE(lens.lens), (jint*)&lens.lens,
sizeof(lens.lens[0]) ); sizeof(lens.lens[0]) );
} }
} }
@ -2358,7 +2348,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_dict_1iter_1getPrefixes
XP_U16 depth = data->depth; XP_U16 depth = data->depth;
for ( int ii = 0; ii < data->idata.count; ++ii ) { for ( int ii = 0; ii < data->idata.count; ++ii ) {
VDECL( XP_UCHAR, buf, 16 ); XP_UCHAR buf[16];
(void)dict_tilesToString( data->dict, (void)dict_tilesToString( data->dict,
&data->idata.prefixes[depth*ii], &data->idata.prefixes[depth*ii],
depth, buf, VSIZE(buf) ); depth, buf, VSIZE(buf) );
@ -2394,7 +2384,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_dict_1iter_1nthWord
DictIterData* data = (DictIterData*)closure; DictIterData* data = (DictIterData*)closure;
if ( NULL != data ) { if ( NULL != data ) {
if ( dict_getNthWord( &data->iter, nn, data->depth, &data->idata ) ) { if ( dict_getNthWord( &data->iter, nn, data->depth, &data->idata ) ) {
VDECL( XP_UCHAR, buf, 64 ); XP_UCHAR buf[64];
dict_wordToString( &data->iter, buf, VSIZE(buf) ); dict_wordToString( &data->iter, buf, VSIZE(buf) );
result = (*env)->NewStringUTF( env, buf ); result = (*env)->NewStringUTF( env, buf );
} }

View file

@ -2254,7 +2254,7 @@ figureScale( BoardCtxt* board, XP_U16 count, XP_U16 dimension, ScrollData* sd )
sd->lastVisible = count - board->zoomCount + sd->offset - 1; sd->lastVisible = count - board->zoomCount + sd->offset - 1;
if ( figureDims( sd->dims, MAX_COLS, nVis, if ( figureDims( sd->dims, VSIZE(sd->dims), nVis,
scale, spares ) ) { scale, spares ) ) {
board_invalAll( board ); board_invalAll( board );
} }
@ -2344,7 +2344,7 @@ figureBoardRect( BoardCtxt* board )
vsd->lastVisible = nVisible + vsd->offset - 1; vsd->lastVisible = nVisible + vsd->offset - 1;
if ( figureDims( vsd->dims, MAX_COLS, nVisible, if ( figureDims( vsd->dims, VSIZE(vsd->dims), nVisible,
vsd->scale, extra ) ) { vsd->scale, extra ) ) {
board_invalAll( board ); board_invalAll( board );
} }

View file

@ -395,7 +395,7 @@ drawCell( BoardCtxt* board, const XP_U16 col, const XP_U16 row, XP_Bool skipBlan
/* This 'while' is only here so I can 'break' below */ /* This 'while' is only here so I can 'break' below */
while ( board->trayVisState == TRAY_HIDDEN || while ( board->trayVisState == TRAY_HIDDEN ||
!rectContainsRect( &board->trayBounds, &cellRect ) ) { !rectContainsRect( &board->trayBounds, &cellRect ) ) {
VDECL(XP_UCHAR, ch, 4) = {'\0'}; XP_UCHAR ch[4] = {'\0'};
XP_S16 owner = -1; XP_S16 owner = -1;
XP_Bool invert = XP_FALSE; XP_Bool invert = XP_FALSE;
XP_Bitmaps bitmaps; XP_Bitmaps bitmaps;
@ -470,7 +470,7 @@ drawCell( BoardCtxt* board, const XP_U16 col, const XP_U16 row, XP_Bool skipBlan
tile, value, owner, bonus, hintAtts, tile, value, owner, bonus, hintAtts,
flags ); flags );
#ifdef LOG_CELL_DRAW #ifdef LOG_CELL_DRAW
VDECL( XP_UCHAR, buf, 64 ); XP_UCHAR buf[64];
XP_LOGF( "%s(col=%d, row=%d, flags=%s)=>%s", __func__, col, row, XP_LOGF( "%s(col=%d, row=%d, flags=%s)=>%s", __func__, col, row,
formatFlags(buf, VSIZE(buf), flags), success?"true":"false" ); formatFlags(buf, VSIZE(buf), flags), success?"true":"false" );
#endif #endif

View file

@ -734,8 +734,8 @@ comms_makeFromStream( MPFORMAL XWStreamCtxt* stream, XW_UtilCtxt* util,
} }
if ( STREAM_VERS_DISABLEDS <= version ) { if ( STREAM_VERS_DISABLEDS <= version ) {
for ( int typ = 0; typ < COMMS_CONN_NTYPES; ++typ ) { for ( int typ = 0; typ < VSIZE(comms->disableds); ++typ ) {
for ( int ii = 0; ii < 2; ++ii ) { for ( int ii = 0; ii < VSIZE(comms->disableds[0]); ++ii ) {
comms->disableds[typ][ii] = 0 != stream_getBits( stream, 1 ); comms->disableds[typ][ii] = 0 != stream_getBits( stream, 1 );
} }
} }
@ -929,8 +929,8 @@ comms_writeToStream( CommsCtxt* comms, XWStreamCtxt* stream,
stream_putBytes( stream, msg->msg, msg->len ); stream_putBytes( stream, msg->msg, msg->len );
} }
for ( int typ = 0; typ < COMMS_CONN_NTYPES; ++typ ) { for ( int typ = 0; typ < VSIZE(comms->disableds); ++typ ) {
for ( int ii = 0; ii < 2; ++ii ) { for ( int ii = 0; ii < VSIZE(comms->disableds[0]); ++ii ) {
stream_putBits( stream, 1, comms->disableds[typ][ii] ? 1 : 0 ); stream_putBits( stream, 1, comms->disableds[typ][ii] ? 1 : 0 );
} }
} }

View file

@ -71,8 +71,7 @@ typedef enum {
/* on Palm BtLibDeviceAddressType is a 48-bit quantity. Linux's typeis the /* on Palm BtLibDeviceAddressType is a 48-bit quantity. Linux's typeis the
same size. Goal is something all platforms support */ same size. Goal is something all platforms support */
typedef struct XP_BtAddr { XP_U8 bits[6]; } XP_BtAddr; typedef struct XP_BtAddr { XP_U8 bits[6]; } XP_BtAddr;
#define MAX_BTADDR_STR_LEN 18 typedef struct XP_BtAddrStr { XP_UCHAR chars[18]; } XP_BtAddrStr;
typedef struct XP_BtAddrStr { XP_UCHAR chars[MAX_BTADDR_STR_LEN]; } XP_BtAddrStr;
#ifdef COMMS_HEARTBEAT #ifdef COMMS_HEARTBEAT
# define IF_CH(a) a, # define IF_CH(a) a,

View file

@ -40,10 +40,7 @@
# endif # endif
#endif #endif
#define VSIZE(_arr) __name_of ## _arr #define VSIZE(arr) (sizeof(arr)/sizeof(arr[0]))
#define VDECL(_type, _arr, _count) \
enum {VSIZE(_arr) = _count}; \
_type _arr[VSIZE(_arr)]
#ifndef MAX_ROWS #ifndef MAX_ROWS
# define MAX_ROWS 16 # define MAX_ROWS 16

View file

@ -97,7 +97,7 @@ dbg_logstream( const XWStreamCtxt* stream, const char* func, int line )
stream_copyBits( stream, end, NULL, &len ); stream_copyBits( stream, end, NULL, &len );
XP_U8 buf[len]; XP_U8 buf[len];
stream_copyBits( stream, end, buf, &len ); stream_copyBits( stream, end, buf, &len );
VDECL( char, comment, 128 ); char comment[128];
XP_SNPRINTF( comment, VSIZE(comment), "%s line %d", func, line ); XP_SNPRINTF( comment, VSIZE(comment), "%s line %d", func, line );
LOG_HEX( buf, len, comment ); LOG_HEX( buf, len, comment );
} else { } else {

View file

@ -107,7 +107,7 @@ dmgr_put( DictMgrCtxt* dmgr, const XP_UCHAR* key, DictionaryCtxt* dict )
XP_S16 loc = findFor( dmgr, key ); XP_S16 loc = findFor( dmgr, key );
if ( NOT_FOUND == loc ) { /* reuse the last one */ if ( NOT_FOUND == loc ) { /* reuse the last one */
moveToFront( dmgr, DMGR_MAX_DICTS - 1 ); moveToFront( dmgr, VSIZE(dmgr->pairs) - 1 );
DictPair* pair = dmgr->pairs; /* the head */ DictPair* pair = dmgr->pairs; /* the head */
dict_unref( pair->dict ); dict_unref( pair->dict );
pair->dict = dict_ref( dict ); pair->dict = dict_ref( dict );
@ -126,7 +126,7 @@ findFor( DictMgrCtxt* dmgr, const XP_UCHAR* key )
{ {
XP_S16 result = NOT_FOUND; XP_S16 result = NOT_FOUND;
XP_U16 ii; XP_U16 ii;
for ( ii = 0; ii < DMGR_MAX_DICTS; ++ii ) { for ( ii = 0; ii < VSIZE(dmgr->pairs); ++ii ) {
DictPair* pair = &dmgr->pairs[ii]; DictPair* pair = &dmgr->pairs[ii];
if ( !!pair->key && 0 == XP_STRCMP( key, pair->key ) ) { if ( !!pair->key && 0 == XP_STRCMP( key, pair->key ) ) {
result = ii; result = ii;
@ -151,7 +151,7 @@ static void
printInOrder( const DictMgrCtxt* dmgr ) printInOrder( const DictMgrCtxt* dmgr )
{ {
XP_U16 ii; XP_U16 ii;
for ( ii = 0; ii < DMGR_MAX_DICTS; ++ii ) { for ( ii = 0; ii < VSIZE(dmgr->pairs); ++ii ) {
const XP_UCHAR* name = dmgr->pairs[ii].key; const XP_UCHAR* name = dmgr->pairs[ii].key;
XP_LOGF( "%s: dict[%d]: %s", __func__, ii, XP_LOGF( "%s: dict[%d]: %s", __func__, ii,
(NULL == name)? "<empty>" : name ); (NULL == name)? "<empty>" : name );

View file

@ -454,7 +454,7 @@ dict_loadFromStream( DictionaryCtxt* dict, XWStreamCtxt* stream )
XP_U16 maxCountBits, maxValueBits; XP_U16 maxCountBits, maxValueBits;
XP_U16 ii, nSpecials; XP_U16 ii, nSpecials;
XP_UCHAR* localTexts[32]; XP_UCHAR* localTexts[32];
VDECL( XP_U8, utf8, MAX_UNIQUE_TILES ); XP_U8 utf8[MAX_UNIQUE_TILES];
XP_ASSERT( !dict->destructor ); XP_ASSERT( !dict->destructor );
dict->destructor = common_destructor; dict->destructor = common_destructor;

View file

@ -223,8 +223,6 @@ typedef struct DrawCtxVTable {
const XP_Rect* rect, void** closure ); const XP_Rect* rect, void** closure );
#endif #endif
#ifndef DRAW_LINK_DIRECT #ifndef DRAW_LINK_DIRECT
void* tableEnd;
} DrawCtxVTable; /* */ } DrawCtxVTable; /* */
#endif #endif

View file

@ -75,8 +75,7 @@ typedef struct MoveIterationData {
/* one bit per tile that's possible here *\/ */ /* one bit per tile that's possible here *\/ */
typedef XP_U32 CrossBits; typedef XP_U32 CrossBits;
#define NUM_CBITS 2 typedef struct Crosscheck { CrossBits bits[2]; } Crosscheck;
typedef struct Crosscheck { CrossBits bits[NUM_CBITS]; } Crosscheck;
struct EngineCtxt { struct EngineCtxt {
const ModelCtxt* model; const ModelCtxt* model;
@ -278,7 +277,7 @@ print_savedMoves( const EngineCtxt* engine, const char* label )
{ {
int ii; int ii;
int pos = 0; int pos = 0;
VDECL(char, buf, (NUM_SAVED_ENGINE_MOVES*10) + 3) = {0}; char buf[(NUM_SAVED_ENGINE_MOVES*10) + 3] = {0};
for ( ii = 0; ii < engine->nMovesToSave; ++ii ) { for ( ii = 0; ii < engine->nMovesToSave; ++ii ) {
if ( 0 < engine->miData.savedMoves[ii].score ) { if ( 0 < engine->miData.savedMoves[ii].score ) {
pos += XP_SNPRINTF( &buf[pos], VSIZE(buf)-pos, "[%d]: %d; ", pos += XP_SNPRINTF( &buf[pos], VSIZE(buf)-pos, "[%d]: %d; ",
@ -726,7 +725,8 @@ figureCrosschecks( EngineCtxt* engine, XP_U16 x, XP_U16 y, XP_U16* scoreP,
XP_ASSERT( tile < MAX_UNIQUE_TILES ); XP_ASSERT( tile < MAX_UNIQUE_TILES );
tiles[0] = tile; tiles[0] = tile;
if ( lookup( dict, in_edge, tiles, 0, tilesAfter ) ) { if ( lookup( dict, in_edge, tiles, 0, tilesAfter ) ) {
XP_ASSERT( (tile >> 5) < NUM_CBITS ); XP_ASSERT( (tile >> 5)
< (VSIZE(check->bits)) );
check->bits[tile>>5] |= (1L << (tile & 0x1F)); check->bits[tile>>5] |= (1L << (tile & 0x1F));
} }

View file

@ -551,7 +551,7 @@ model_setPlayerDicts( ModelCtxt* model, const PlayerDicts* dicts )
#ifdef DEBUG #ifdef DEBUG
DictionaryCtxt* gameDict = model_getDictionary( model ); DictionaryCtxt* gameDict = model_getDictionary( model );
#endif #endif
for ( ii = 0; ii < MAX_NUM_PLAYERS; ++ii ) { for ( ii = 0; ii < VSIZE(dicts->dicts); ++ii ) {
DictionaryCtxt* oldDict = model->vol.dicts.dicts[ii]; DictionaryCtxt* oldDict = model->vol.dicts.dicts[ii];
DictionaryCtxt* newDict = dicts->dicts[ii]; DictionaryCtxt* newDict = dicts->dicts[ii];
if ( oldDict != newDict ) { if ( oldDict != newDict ) {
@ -573,7 +573,7 @@ model_getDictionary( const ModelCtxt* model )
{ {
XP_U16 ii; XP_U16 ii;
DictionaryCtxt* result = model->vol.dict; DictionaryCtxt* result = model->vol.dict;
for ( ii = 0; !result && ii < MAX_NUM_PLAYERS; ++ii ) { for ( ii = 0; !result && ii < VSIZE(model->vol.dicts.dicts); ++ii ) {
result = model->vol.dicts.dicts[ii]; result = model->vol.dicts.dicts[ii];
} }
return result; return result;
@ -594,7 +594,7 @@ static void
model_unrefDicts( ModelCtxt* model ) model_unrefDicts( ModelCtxt* model )
{ {
XP_U16 ii; XP_U16 ii;
for ( ii = 0; ii < MAX_NUM_PLAYERS; ++ii ) { for ( ii = 0; ii < VSIZE(model->vol.dicts.dicts); ++ii ) {
dict_unref( model->vol.dicts.dicts[ii] ); dict_unref( model->vol.dicts.dicts[ii] );
model->vol.dicts.dicts[ii] = NULL; model->vol.dicts.dicts[ii] = NULL;
} }
@ -611,7 +611,7 @@ getPendingTileFor( const ModelCtxt* model, XP_U16 turn, XP_U16 col, XP_U16 row,
const PendingTile* pendings; const PendingTile* pendings;
XP_U16 ii; XP_U16 ii;
XP_ASSERT( turn < MAX_NUM_PLAYERS ); XP_ASSERT( turn < VSIZE(model->players) );
player = &model->players[turn]; player = &model->players[turn];
pendings = player->pendingTiles; pendings = player->pendingTiles;
@ -2064,7 +2064,7 @@ printMovePre( ModelCtxt* model, XP_U16 XP_UNUSED(moveN), const StackEntry* entry
{ {
if ( entry->moveType != ASSIGN_TYPE ) { if ( entry->moveType != ASSIGN_TYPE ) {
const XP_UCHAR* format; const XP_UCHAR* format;
VDECL( XP_UCHAR, buf, 64 ); XP_UCHAR buf[64];
XP_UCHAR traybuf[MAX_TRAY_TILES+1]; XP_UCHAR traybuf[MAX_TRAY_TILES+1];
MovePrintClosure* closure = (MovePrintClosure*)p_closure; MovePrintClosure* closure = (MovePrintClosure*)p_closure;
XWStreamCtxt* stream = closure->stream; XWStreamCtxt* stream = closure->stream;
@ -2293,7 +2293,7 @@ scoreLastMove( ModelCtxt* model, MoveInfo* moveInfo, XP_U16 howMany,
model_destroy( tmpModel ); model_destroy( tmpModel );
lmi->score = score; lmi->score = score;
XP_SNPRINTF( lmi->word, MAX_COLS+1, "%s", data.word ); XP_SNPRINTF( lmi->word, VSIZE(lmi->word), "%s", data.word );
} /* scoreLastMove */ } /* scoreLastMove */
static XP_U16 static XP_U16

View file

@ -493,7 +493,7 @@ static void
cleanupServer( ServerCtxt* server ) cleanupServer( ServerCtxt* server )
{ {
XP_U16 ii; XP_U16 ii;
for ( ii = 0; ii < MAX_NUM_PLAYERS; ++ii ){ for ( ii = 0; ii < VSIZE(server->players); ++ii ){
ServerPlayer* player = &server->players[ii]; ServerPlayer* player = &server->players[ii];
if ( player->engine != NULL ) { if ( player->engine != NULL ) {
engine_destroy( player->engine ); engine_destroy( player->engine );
@ -1346,8 +1346,8 @@ client_readInitialMessage( ServerCtxt* server, XWStreamCtxt* stream )
XP_U32 gameID; XP_U32 gameID;
PoolContext* pool; PoolContext* pool;
#ifdef STREAM_VERS_BIGBOARD #ifdef STREAM_VERS_BIGBOARD
VDECL( XP_UCHAR, rmtDictName,128 ); XP_UCHAR rmtDictName[128];
VDECL( XP_UCHAR, rmtDictSum, 64 ); XP_UCHAR rmtDictSum[64];
#endif #endif
/* version; any dependencies here? */ /* version; any dependencies here? */
@ -3172,11 +3172,10 @@ server_figureFinishBonus( const ServerCtxt* server, XP_U16 turn )
if ( 0 < nOthers ) { if ( 0 < nOthers ) {
Tile tile; Tile tile;
const DictionaryCtxt* dict = model_getDictionary( server->vol.model ); const DictionaryCtxt* dict = model_getDictionary( server->vol.model );
const size_t numFaces = dict_numTileFaces( dict ); XP_U16 counts[dict_numTileFaces( dict )];
XP_U16 counts[numFaces];
XP_MEMSET( counts, 0, sizeof(counts) ); XP_MEMSET( counts, 0, sizeof(counts) );
model_countAllTrayTiles( server->vol.model, counts, turn ); model_countAllTrayTiles( server->vol.model, counts, turn );
for ( tile = 0; tile < numFaces; ++tile ) { for ( tile = 0; tile < VSIZE(counts); ++tile ) {
XP_U16 count = counts[tile]; XP_U16 count = counts[tile];
if ( 0 < count ) { if ( 0 < count ) {
result += count * dict_getTileValue( dict, tile ); result += count * dict_getTileValue( dict, tile );

View file

@ -668,7 +668,7 @@ restorePartials( SMSProto* state )
&& PARTIALS_FORMAT == stream_getU8( stream ) ) { && PARTIALS_FORMAT == stream_getU8( stream ) ) {
int nFromPhones = stream_getU8( stream ); int nFromPhones = stream_getU8( stream );
for ( int ii = 0; ii < nFromPhones; ++ii ) { for ( int ii = 0; ii < nFromPhones; ++ii ) {
VDECL( XP_UCHAR, phone, 32 ); XP_UCHAR phone[32];
(void)stringFromStreamHere( stream, phone, VSIZE(phone) ); (void)stringFromStreamHere( stream, phone, VSIZE(phone) );
int nMsgIDs = stream_getU8( stream ); int nMsgIDs = stream_getU8( stream );
XP_LOGF( "%s(): got %d message records for phone %s", __func__, XP_LOGF( "%s(): got %d message records for phone %s", __func__,
@ -861,7 +861,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
SMSProto* state = smsproto_init( mpool, dutil ); SMSProto* state = smsproto_init( mpool, dutil );
const int smallSiz = 20; const int smallSiz = 20;
VDECL(char*, phones, 4) = {"1234", "3456", "5467", "9877"}; const char* phones[] = {"1234", "3456", "5467", "9877"};
const char* buf = "asoidfaisdfoausdf aiousdfoiu asodfu oiuasdofi oiuaosiduf oaisudf oiasd f" const char* buf = "asoidfaisdfoausdf aiousdfoiu asodfu oiuasdofi oiuaosiduf oaisudf oiasd f"
";oiaisdjfljiojaklj asdlkjalskdjf laksjd flkjasdlfkj aldsjkf lsakdjf lkjsad flkjsd fl;kj" ";oiaisdjfljiojaklj asdlkjalskdjf laksjd flkjasdlfkj aldsjkf lsakdjf lkjsad flkjsd fl;kj"
"asdifaoaosidfoiauosidufoaus doifuoaiusdoifu aoisudfoaisd foia sdoifuasodfu aosiud foiuas odfiu asd" "asdifaoaosidfoiauosidufoaus doifuoaiusdoifu aoisudfoaisd foia sdoifuasodfu aosiud foiuas odfiu asd"
@ -869,7 +869,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
; ;
const XP_Bool forceOld = XP_TRUE; const XP_Bool forceOld = XP_TRUE;
VDECL( SMSMsgArray*, arrs, VSIZE(phones) ); SMSMsgArray* arrs[VSIZE(phones)];
for ( int ii = 0; ii < VSIZE(arrs); ++ii ) { for ( int ii = 0; ii < VSIZE(arrs); ++ii ) {
arrs[ii] = NULL; arrs[ii] = NULL;
} }

View file

@ -409,7 +409,7 @@ getSelTiles( const BoardCtxt* board, TileBit selBits, TrayTileSet* selTiles )
for ( index = 0; selBits != 0; selBits >>= 1, ++index ) { for ( index = 0; selBits != 0; selBits >>= 1, ++index ) {
if ( 0 != (selBits & 0x01) ) { if ( 0 != (selBits & 0x01) ) {
Tile tile = model_getPlayerTile( model, turn, index ); Tile tile = model_getPlayerTile( model, turn, index );
XP_ASSERT( nTiles < MAX_TRAY_TILES ); XP_ASSERT( nTiles < VSIZE(selTiles->tiles) );
selTiles->tiles[nTiles++] = tile; selTiles->tiles[nTiles++] = tile;
} }
} }

View file

@ -149,7 +149,7 @@ curses_draw_measureRemText( DrawCtx* XP_UNUSED(dctx),
XP_U16* width, XP_U16* height ) XP_U16* width, XP_U16* height )
{ {
char buf[64]; char buf[64];
VDECL( char*, lines, 2 ) = {0}; char* lines[2] = {0};
formatRemText( nTilesLeft, rect, buf, lines ); formatRemText( nTilesLeft, rect, buf, lines );
*width = 0; *width = 0;
@ -170,7 +170,7 @@ curses_draw_drawRemText( DrawCtx* p_dctx, const XP_Rect* rInner,
CursesDrawCtx* dctx = (CursesDrawCtx*)p_dctx; CursesDrawCtx* dctx = (CursesDrawCtx*)p_dctx;
char buf[32]; char buf[32];
VDECL( char*, lines, 2 ) = {0}; char* lines[2] = {0};
formatRemText( nTilesLeft, rInner, buf, lines ); formatRemText( nTilesLeft, rInner, buf, lines );
int ii; int ii;
for ( ii = 0; ii < VSIZE(lines) && !!lines[ii]; ++ii ) { for ( ii = 0; ii < VSIZE(lines) && !!lines[ii]; ++ii ) {
@ -270,7 +270,7 @@ curses_draw_measureScoreText( DrawCtx* XP_UNUSED(p_dctx),
XP_U16* width, XP_U16* height ) XP_U16* width, XP_U16* height )
{ {
XP_UCHAR buf[100]; XP_UCHAR buf[100];
VDECL( char*, lines, 3 ) = {0}; char* lines[3] = {0};
formatScoreText( buf, dsi, rect, lines ); formatScoreText( buf, dsi, rect, lines );
int ii; int ii;
@ -295,7 +295,7 @@ curses_draw_score_drawPlayer( DrawCtx* p_dctx, const XP_Rect* rInner,
curses_draw_clearRect( p_dctx, rOuter ); curses_draw_clearRect( p_dctx, rOuter );
/* print the name and turn/remoteness indicator */ /* print the name and turn/remoteness indicator */
VDECL( char*, lines, 3 ) = {0}; char* lines[3] = {0};
formatScoreText( buf, dsi, rInner, lines ); formatScoreText( buf, dsi, rInner, lines );
int ii; int ii;
for ( ii = 0; ii < VSIZE(lines) && !!lines[ii]; ++ii ) { for ( ii = 0; ii < VSIZE(lines) && !!lines[ii]; ++ii ) {

View file

@ -57,7 +57,7 @@ curses_askLetter( CursesAppGlobals* globals, XP_UCHAR* query,
short curSelButton = 1; /* force draw by being different */ short curSelButton = 1; /* force draw by being different */
short maxWidth; short maxWidth;
short numCtlButtons; short numCtlButtons;
VDECL( const char*, ctlButtons, 2 ) = { "Ok", "Cancel" }; const char* ctlButtons[] = { "Ok", "Cancel" };
XP_Bool dismissed = XP_FALSE; XP_Bool dismissed = XP_FALSE;
FormatInfo fi; FormatInfo fi;
int len; int len;

View file

@ -221,7 +221,7 @@ cursesUserError( CursesAppGlobals* globals, const char* format, ... )
vsprintf( buf, format, ap ); vsprintf( buf, format, ap );
VDECL( const char*, buttons, 1 ) = {"OK"}; const char* buttons[] = {"OK"};
(void)cursesask( globals, buf, VSIZE(buttons), buttons ); (void)cursesask( globals, buf, VSIZE(buttons), buttons );
va_end(ap); va_end(ap);
@ -285,7 +285,7 @@ ask_move( gpointer data )
{ {
CursesAppGlobals* globals = (CursesAppGlobals*)data; CursesAppGlobals* globals = (CursesAppGlobals*)data;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
VDECL( const char*, answers, 3 ) = {"Ok", "Cancel", NULL}; const char* answers[] = {"Ok", "Cancel", NULL};
if (0 == cursesask(globals, cGlobals->question, VSIZE(answers)-1, answers) ) { if (0 == cursesask(globals, cGlobals->question, VSIZE(answers)-1, answers) ) {
BoardCtxt* board = cGlobals->game.board; BoardCtxt* board = cGlobals->game.board;
@ -304,7 +304,7 @@ curses_util_notifyMove( XW_UtilCtxt* uc, XWStreamCtxt* stream )
CursesAppGlobals* globals = (CursesAppGlobals*)uc->closure; CursesAppGlobals* globals = (CursesAppGlobals*)uc->closure;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
XP_ASSERT( len <= QUESTION_LEN ); XP_ASSERT( len <= VSIZE(cGlobals->question) );
stream_getBytes( stream, cGlobals->question, len ); stream_getBytes( stream, cGlobals->question, len );
(void)g_idle_add( ask_move, globals ); (void)g_idle_add( ask_move, globals );
} /* curses_util_userQuery */ } /* curses_util_userQuery */
@ -315,7 +315,7 @@ ask_trade( gpointer data )
CursesAppGlobals* globals = (CursesAppGlobals*)data; CursesAppGlobals* globals = (CursesAppGlobals*)data;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
VDECL( const char*, buttons, 2 ) = { "Ok", "Cancel" }; const char* buttons[] = { "Ok", "Cancel" };
if (0 == cursesask( globals, cGlobals->question, VSIZE(buttons), buttons ) ) { if (0 == cursesask( globals, cGlobals->question, VSIZE(buttons), buttons ) ) {
BoardCtxt* board = cGlobals->game.board; BoardCtxt* board = cGlobals->game.board;
if ( board_commitTurn( board, XP_TRUE, XP_TRUE, NULL ) ) { if ( board_commitTurn( board, XP_TRUE, XP_TRUE, NULL ) ) {
@ -353,7 +353,7 @@ cursesShowFinalScores( CursesAppGlobals* globals )
text = strFromStream( stream ); text = strFromStream( stream );
VDECL( const char*, buttons, 1 ) = { "Ok" }; const char* buttons[] = { "Ok" };
(void)cursesask( globals, text, VSIZE(buttons), buttons ); (void)cursesask( globals, text, VSIZE(buttons), buttons );
free( text ); free( text );
@ -366,7 +366,7 @@ curses_util_informMove( XW_UtilCtxt* uc, XP_S16 XP_UNUSED(turn),
{ {
CursesAppGlobals* globals = (CursesAppGlobals*)uc->closure; CursesAppGlobals* globals = (CursesAppGlobals*)uc->closure;
char* question = strFromStream( expl ); char* question = strFromStream( expl );
VDECL( const char*, buttons, 1 ) = { "Ok" }; const char* buttons[] = { "Ok" };
(void)cursesask( globals, question, VSIZE(buttons), buttons ); (void)cursesask( globals, question, VSIZE(buttons), buttons );
free( question ); free( question );
} }
@ -1412,7 +1412,7 @@ curses_util_remSelected( XW_UtilCtxt* uc )
text = strFromStream( stream ); text = strFromStream( stream );
VDECL( const char*, buttons, 1 ) = { "Ok" }; const char* buttons[] = { "Ok" };
(void)cursesask( globals, text, VSIZE(buttons), buttons ); (void)cursesask( globals, text, VSIZE(buttons), buttons );
free( text ); free( text );
@ -1795,7 +1795,7 @@ cursesErrorMsgRcvd( void* closure, const XP_UCHAR* msg )
} else { } else {
g_free( globals->lastErr ); g_free( globals->lastErr );
globals->lastErr = g_strdup( msg ); globals->lastErr = g_strdup( msg );
VDECL( const char*, buttons, 1 ) = { "Ok" }; const char* buttons[] = { "Ok" };
(void)cursesask( globals, msg, VSIZE(buttons), buttons ); (void)cursesask( globals, msg, VSIZE(buttons), buttons );
} }
} }
@ -2015,7 +2015,7 @@ cursesmain( XP_Bool isServer, LaunchParams* params )
} }
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
VDECL( gchar, buf, 32 ); gchar buf[32];
const gchar* myPhone = params->connInfo.sms.myPhone; const gchar* myPhone = params->connInfo.sms.myPhone;
if ( !!myPhone ) { if ( !!myPhone ) {
db_store( params->pDb, KEY_SMSPHONE, myPhone ); db_store( params->pDb, KEY_SMSPHONE, myPhone );
@ -2023,7 +2023,7 @@ cursesmain( XP_Bool isServer, LaunchParams* params )
params->connInfo.sms.myPhone = myPhone = buf; params->connInfo.sms.myPhone = myPhone = buf;
} }
XP_U16 myPort = params->connInfo.sms.port; XP_U16 myPort = params->connInfo.sms.port;
VDECL( gchar, portbuf, 8 ); gchar portbuf[8];
if ( 0 < myPort ) { if ( 0 < myPort ) {
sprintf( portbuf, "%d", myPort ); sprintf( portbuf, "%d", myPort );
db_store( params->pDb, KEY_SMSPORT, portbuf ); db_store( params->pDb, KEY_SMSPORT, portbuf );

View file

@ -222,7 +222,7 @@ summarize( CommonGlobals* cGlobals )
// gchar* connvia = "local"; // gchar* connvia = "local";
gchar connvia[128] = {0}; gchar connvia[128] = {0};
VDECL( XP_UCHAR, relayID, 32 ) = {0}; XP_UCHAR relayID[32] = {0};
if ( !!game->comms ) { if ( !!game->comms ) {
nMissing = server_getMissingPlayers( game->server ); nMissing = server_getMissingPlayers( game->server );
@ -341,7 +341,7 @@ getRelayIDsToRowsMap( sqlite3* pDb )
switch( sqlite3_step( ppStmt ) ) { switch( sqlite3_step( ppStmt ) ) {
case SQLITE_ROW: /* have data */ case SQLITE_ROW: /* have data */
{ {
VDECL( XP_UCHAR, relayID, 32 ); XP_UCHAR relayID[32];
int len = VSIZE(relayID); int len = VSIZE(relayID);
getColumnText( ppStmt, 0, relayID, &len ); getColumnText( ppStmt, 0, relayID, &len );
gpointer key = g_strdup( relayID ); gpointer key = g_strdup( relayID );

View file

@ -1113,7 +1113,7 @@ change_dictionary( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
LaunchParams* params = cGlobals->params; LaunchParams* params = cGlobals->params;
GSList* dicts = listDicts( params ); GSList* dicts = listDicts( params );
VDECL( gchar, buf, 265 ); gchar buf[265];
gchar* name = gtkaskdict( dicts, buf, VSIZE(buf) ); gchar* name = gtkaskdict( dicts, buf, VSIZE(buf) );
if ( !!name ) { if ( !!name ) {
DictionaryCtxt* dict = DictionaryCtxt* dict =
@ -1662,7 +1662,7 @@ send_invites( CommonGlobals* cGlobals, XP_U16 nPlayers,
#endif #endif
if ( '\0' != addrs->u.sms.phone[0] && 0 < addrs->u.sms.port ) { if ( '\0' != addrs->u.sms.phone[0] && 0 < addrs->u.sms.port ) {
VDECL( gchar, gameName, 64 ); gchar gameName[64];
snprintf( gameName, VSIZE(gameName), "Game %d", cGlobals->gi->gameID ); snprintf( gameName, VSIZE(gameName), "Game %d", cGlobals->gi->gameID );
linux_sms_invite( cGlobals->params, &nli, linux_sms_invite( cGlobals->params, &nli,
@ -1844,7 +1844,7 @@ ask_password( gpointer data )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)data; GtkGameGlobals* globals = (GtkGameGlobals*)data;
CommonGlobals* cGlobals = &globals->cGlobals; CommonGlobals* cGlobals = &globals->cGlobals;
VDECL( XP_UCHAR, buf, 32 ); XP_UCHAR buf[32];
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;
@ -2003,7 +2003,7 @@ gtk_util_informNetDict( XW_UtilCtxt* uc, XP_LangCode XP_UNUSED(lang),
{ {
if ( 0 != strcmp( oldName, newName ) ) { if ( 0 != strcmp( oldName, newName ) ) {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
VDECL( gchar, buf, 512 ); gchar buf[512];
int offset = snprintf( buf, VSIZE(buf), int offset = snprintf( buf, VSIZE(buf),
"dict changing from %s to %s (sum=%s).", "dict changing from %s to %s (sum=%s).",
oldName, newName, newSum ); oldName, newName, newSum );
@ -2298,7 +2298,7 @@ gtk_util_showChat( XW_UtilCtxt* uc, const XP_UCHAR* const msg, XP_S16 from,
XP_U32 timestamp ) XP_U32 timestamp )
{ {
GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure; GtkGameGlobals* globals = (GtkGameGlobals*)uc->closure;
VDECL( XP_UCHAR, buf, 1024 ); XP_UCHAR buf[1024];
XP_UCHAR* name = "<unknown>"; XP_UCHAR* name = "<unknown>";
if ( 0 <= from ) { if ( 0 <= from ) {
name = globals->cGlobals.gi->players[from].name; name = globals->cGlobals.gi->players[from].name;
@ -2338,7 +2338,7 @@ gtk_util_playerScoreHeld( XW_UtilCtxt* uc, XP_U16 player )
LastMoveInfo lmi; LastMoveInfo lmi;
if ( model_getPlayersLastScore( globals->cGlobals.game.model, if ( model_getPlayersLastScore( globals->cGlobals.game.model,
player, &lmi ) ) { player, &lmi ) ) {
VDECL( XP_UCHAR, buf, 128 ); XP_UCHAR buf[128];
formatLMI( &lmi, buf, VSIZE(buf) ); formatLMI( &lmi, buf, VSIZE(buf) );
(void)gtkask( globals->window, buf, GTK_BUTTONS_OK, NULL ); (void)gtkask( globals->window, buf, GTK_BUTTONS_OK, NULL );
} }
@ -2393,7 +2393,7 @@ gtk_util_notifyMove( XW_UtilCtxt* uc, XWStreamCtxt* stream )
/* XP_Bool freeMe = XP_FALSE; */ /* XP_Bool freeMe = XP_FALSE; */
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
XP_ASSERT( len <= QUESTION_LEN ); XP_ASSERT( len <= VSIZE(cGlobals->question) );
stream_getBytes( stream, cGlobals->question, len ); stream_getBytes( stream, cGlobals->question, len );
(void)g_idle_add( ask_move, globals ); (void)g_idle_add( ask_move, globals );

View file

@ -67,7 +67,7 @@ conTypeToPageNum( const GtkConnsState* state, CommsConnType conType )
pageNum = ii; pageNum = ii;
break; break;
} }
XP_ASSERT( ii < COMMS_CONN_NTYPES ); XP_ASSERT( ii < VSIZE(state->pageData) );
} }
return pageNum; return pageNum;
} }

View file

@ -745,7 +745,7 @@ gtkDrawTileImpl( DrawCtx* p_dctx, const XP_Rect* rect, const XP_UCHAR* textP,
XP_Bool clearBack ) XP_Bool clearBack )
{ {
GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx; GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx;
VDECL( XP_UCHAR, numbuf, 3 ); XP_UCHAR numbuf[3];
XP_Rect insetR = *rect; XP_Rect insetR = *rect;
XP_Bool isCursor = (flags & CELL_ISCURSOR) != 0; XP_Bool isCursor = (flags & CELL_ISCURSOR) != 0;
XP_Bool valHidden = (flags & CELL_VALHIDDEN) != 0; XP_Bool valHidden = (flags & CELL_VALHIDDEN) != 0;
@ -1113,13 +1113,13 @@ formatScoreText( PangoLayout* layout, XP_UCHAR* buf, XP_U16 bufLen,
XP_U16 nTilesLeft = dsi->nTilesLeft; XP_U16 nTilesLeft = dsi->nTilesLeft;
XP_Bool isTurn = dsi->isTurn; XP_Bool isTurn = dsi->isTurn;
XP_S16 maxWidth = bounds->width; XP_S16 maxWidth = bounds->width;
VDECL( XP_UCHAR, numBuf, 16 ); XP_UCHAR numBuf[16];
int width, height; int width, height;
*nLines = 1; *nLines = 1;
XP_SNPRINTF( numBuf, VSIZE(numBuf), "%d", score ); XP_SNPRINTF( numBuf, VSIZE(numBuf), "%d", score );
if ( (nTilesLeft < MAX_TRAY_TILES) && (nTilesLeft > 0) ) { if ( (nTilesLeft < MAX_TRAY_TILES) && (nTilesLeft > 0) ) {
VDECL( XP_UCHAR, tmp, 10 ); XP_UCHAR tmp[10];
XP_SNPRINTF( tmp, VSIZE(tmp), ":%d", nTilesLeft ); XP_SNPRINTF( tmp, VSIZE(tmp), ":%d", nTilesLeft );
(void)XP_STRCAT( numBuf, tmp ); (void)XP_STRCAT( numBuf, tmp );
} }
@ -1134,7 +1134,7 @@ formatScoreText( PangoLayout* layout, XP_UCHAR* buf, XP_U16 bufLen,
} }
/* Reformat name + ':' until it fits */ /* Reformat name + ':' until it fits */
VDECL( XP_UCHAR, name, MAX_SCORE_LEN ) = { 0 }; XP_UCHAR name[MAX_SCORE_LEN] = { 0 };
if ( isTurn && maxWidth > 0 ) { if ( isTurn && maxWidth > 0 ) {
XP_U16 len = 1 + XP_STRLEN( dsi->name ); /* +1 for "\0" */ XP_U16 len = 1 + XP_STRLEN( dsi->name ); /* +1 for "\0" */
if ( scoreIsVertical ) { if ( scoreIsVertical ) {
@ -1181,7 +1181,7 @@ gtk_draw_measureScoreText( DrawCtx* p_dctx, const XP_Rect* bounds,
XP_U16* widthP, XP_U16* heightP ) XP_U16* widthP, XP_U16* heightP )
{ {
GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx; GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx;
VDECL( XP_UCHAR, buf, 36 ); XP_UCHAR buf[36];
PangoLayout* layout; PangoLayout* layout;
int lineHeight = GTK_HOR_SCORE_HEIGHT, nLines; int lineHeight = GTK_HOR_SCORE_HEIGHT, nLines;
@ -1191,9 +1191,9 @@ gtk_draw_measureScoreText( DrawCtx* p_dctx, const XP_Rect* bounds,
*heightP = nLines * lineHeight; *heightP = nLines * lineHeight;
XP_U16 playerNum = dsi->playerNum; XP_U16 playerNum = dsi->playerNum;
XP_ASSERT( playerNum < MAX_NUM_PLAYERS ); XP_ASSERT( playerNum < VSIZE(dctx->scoreCache) );
XP_SNPRINTF( dctx->scoreCache[playerNum].str, XP_SNPRINTF( dctx->scoreCache[playerNum].str,
MAX_SCORE_LEN+1, "%s", buf ); VSIZE(dctx->scoreCache[playerNum].str), "%s", buf );
dctx->scoreCache[playerNum].fontHt = lineHeight; dctx->scoreCache[playerNum].fontHt = lineHeight;
} /* gtk_draw_measureScoreText */ } /* gtk_draw_measureScoreText */
@ -1203,7 +1203,7 @@ gtk_draw_score_pendingScore( DrawCtx* p_dctx, const XP_Rect* rect,
XP_S16 curTurn, CellFlags flags ) XP_S16 curTurn, CellFlags flags )
{ {
GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx; GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx;
VDECL( XP_UCHAR, buf, 5 ); XP_UCHAR buf[5];
XP_U16 ht; XP_U16 ht;
XP_Rect localR; XP_Rect localR;
GdkRGBA* cursor = ((flags & CELL_ISCURSOR) != 0) GdkRGBA* cursor = ((flags & CELL_ISCURSOR) != 0)
@ -1259,7 +1259,7 @@ gtk_draw_drawTimer( DrawCtx* p_dctx, const XP_Rect* rInner,
GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx; GtkDrawCtx* dctx = (GtkDrawCtx*)p_dctx;
XP_Bool hadCairo = haveCairo( dctx ); XP_Bool hadCairo = haveCairo( dctx );
if ( hadCairo || initCairo( dctx ) ) { if ( hadCairo || initCairo( dctx ) ) {
VDECL( XP_UCHAR, buf, 10 ); XP_UCHAR buf[10];
gtkFormatTimerText( buf, VSIZE(buf), secondsLeft ); gtkFormatTimerText( buf, VSIZE(buf), secondsLeft );
@ -1406,10 +1406,8 @@ gtkDrawCtxtMake( GtkWidget* drawing_area, GtkGameGlobals* globals )
dctx->vtable = g_malloc( sizeof(*(((GtkDrawCtx*)dctx)->vtable)) ); dctx->vtable = g_malloc( sizeof(*(((GtkDrawCtx*)dctx)->vtable)) );
void** ptr = (void**)dctx->vtable; for ( int ii = 0; ii < VSIZE(dctx->vtable); ++ii ) {
void** tableEnd = (void**)&dctx->vtable->tableEnd; ((void**)(dctx->vtable))[ii] = draw_doNothing; /* bad? */
while ( ptr < tableEnd ) {
*ptr++ = draw_doNothing;
} }
SET_VTABLE_ENTRY( dctx->vtable, draw_clearRect, gtk ); SET_VTABLE_ENTRY( dctx->vtable, draw_clearRect, gtk );

View file

@ -76,7 +76,7 @@ conTypeToPageNum( const GtkInviteState* state, CommsConnType conType )
pageNum = ii; pageNum = ii;
break; break;
} }
XP_ASSERT( ii < COMMS_CONN_NTYPES ); XP_ASSERT( ii < VSIZE(state->pageData) );
} }
return pageNum; return pageNum;
} }

View file

@ -350,7 +350,7 @@ make_rematch( GtkAppGlobals* apg, const CommonGlobals* cGlobals )
comms_getAddr( comms, &addr ); comms_getAddr( comms, &addr );
addrToStream( stream, &addr ); addrToStream( stream, &addr );
VDECL( CommsAddrRec, addrs, 4 ); CommsAddrRec addrs[4];
XP_U16 nRecs = VSIZE(addrs); XP_U16 nRecs = VSIZE(addrs);
comms_getAddrs( comms, addrs, &nRecs ); comms_getAddrs( comms, addrs, &nRecs );
@ -478,7 +478,7 @@ setWindowTitle( GtkAppGlobals* apg )
GtkWidget* window = apg->window; GtkWidget* window = apg->window;
LaunchParams* params = apg->params; LaunchParams* params = apg->params;
VDECL( gchar, title, 128 ) = {0}; gchar title[128] = {0};
if ( !!params->dbName ) { if ( !!params->dbName ) {
strcat( title, params->dbName ); strcat( title, params->dbName );
} }
@ -696,7 +696,7 @@ relayInviteReceived( void* closure, NetLaunchInfo* invite )
GtkAppGlobals* apg = (GtkAppGlobals*)closure; GtkAppGlobals* apg = (GtkAppGlobals*)closure;
XP_U32 gameID = invite->gameID; XP_U32 gameID = invite->gameID;
VDECL( sqlite3_int64, rowids, 1 ); sqlite3_int64 rowids[1];
int nRowIDs = VSIZE(rowids); int nRowIDs = VSIZE(rowids);
getRowsForGameID( apg->params->pDb, gameID, rowids, &nRowIDs ); getRowsForGameID( apg->params->pDb, gameID, rowids, &nRowIDs );
@ -782,7 +782,7 @@ smsMsgReceivedGTK( void* closure, const CommsAddrRec* from, XP_U32 gameID,
GtkAppGlobals* apg = (GtkAppGlobals*)closure; GtkAppGlobals* apg = (GtkAppGlobals*)closure;
LaunchParams* params = apg->params; LaunchParams* params = apg->params;
VDECL( sqlite3_int64, rowids, 4 ); sqlite3_int64 rowids[4];
int nRowIDs = VSIZE(rowids); int nRowIDs = VSIZE(rowids);
getRowsForGameID( params->pDb, gameID, rowids, &nRowIDs ); getRowsForGameID( params->pDb, gameID, rowids, &nRowIDs );
XP_LOGF( "%s: found %d rows for gameID %d", __func__, nRowIDs, gameID ); XP_LOGF( "%s: found %d rows for gameID %d", __func__, nRowIDs, gameID );
@ -888,7 +888,7 @@ gtkmain( LaunchParams* params )
} }
#ifdef XWFEATURE_SMS #ifdef XWFEATURE_SMS
VDECL( gchar, buf, 32 ); gchar buf[32];
const gchar* myPhone = params->connInfo.sms.myPhone; const gchar* myPhone = params->connInfo.sms.myPhone;
if ( !!myPhone ) { if ( !!myPhone ) {
db_store( params->pDb, KEY_SMSPHONE, myPhone ); db_store( params->pDb, KEY_SMSPHONE, myPhone );
@ -896,7 +896,7 @@ gtkmain( LaunchParams* params )
params->connInfo.sms.myPhone = myPhone = buf; params->connInfo.sms.myPhone = myPhone = buf;
} }
XP_U16 myPort = params->connInfo.sms.port; XP_U16 myPort = params->connInfo.sms.port;
VDECL( gchar, portbuf, 8 ); gchar portbuf[8];
if ( 0 < myPort ) { if ( 0 < myPort ) {
sprintf( portbuf, "%d", myPort ); sprintf( portbuf, "%d", myPort );
db_store( params->pDb, KEY_SMSPORT, portbuf ); db_store( params->pDb, KEY_SMSPORT, portbuf );

View file

@ -216,7 +216,8 @@ addPhoniesCombo( GtkNewGameState* state, GtkWidget* parent )
FALSE, TRUE, 0 ); FALSE, TRUE, 0 );
GtkWidget* phoniesCombo = gtk_combo_box_text_new(); GtkWidget* phoniesCombo = gtk_combo_box_text_new();
VDECL( const char*, ptxts, 3 ) = { "IGNORE", "WARN", "DISALLOW" }; const char* ptxts[] = { "IGNORE", "WARN", "DISALLOW" };
for ( int ii = 0; ii < VSIZE(ptxts); ++ii ) { for ( int ii = 0; ii < VSIZE(ptxts); ++ii ) {
gtk_combo_box_text_append_text( GTK_COMBO_BOX_TEXT(phoniesCombo), gtk_combo_box_text_append_text( GTK_COMBO_BOX_TEXT(phoniesCombo),
ptxts[ii] ); ptxts[ii] );
@ -239,7 +240,7 @@ makeNewGameDialog( GtkNewGameState* state )
GtkWidget* hbox; GtkWidget* hbox;
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
GtkWidget* roleCombo; GtkWidget* roleCombo;
VDECL( char*, roles, 3 ) = { "Standalone", "Host", "Guest" }; char* roles[] = { "Standalone", "Host", "Guest" };
#endif #endif
GtkWidget* nPlayersCombo; GtkWidget* nPlayersCombo;
GtkWidget* boardSizeCombo; GtkWidget* boardSizeCombo;

View file

@ -268,7 +268,7 @@ initFromDictFile( LinuxDictionaryCtxt* dctx, const LaunchParams* params,
XP_Bool isUTF8 = XP_FALSE; XP_Bool isUTF8 = XP_FALSE;
XP_Bool hasHeader = XP_FALSE; XP_Bool hasHeader = XP_FALSE;
const XP_U8* ptr; const XP_U8* ptr;
VDECL( char, path, 256 ); char path[256];
if ( !getDictPath( params, fileName, path, VSIZE(path) ) ) { if ( !getDictPath( params, fileName, path, VSIZE(path) ) ) {
XP_LOGF( "%s: path=%s", __func__, path ); XP_LOGF( "%s: path=%s", __func__, path );

View file

@ -327,7 +327,7 @@ catFinalScores( const CommonGlobals* cGlobals, XP_S16 quitter )
cGlobals->params->vtMgr, cGlobals->params->vtMgr,
NULL, CHANNEL_NONE, catOnClose ); NULL, CHANNEL_NONE, catOnClose );
if ( -1 != quitter ) { if ( -1 != quitter ) {
VDECL( XP_UCHAR, buf, 128 ); XP_UCHAR buf[128];
XP_SNPRINTF( buf, VSIZE(buf), "Player %s resigned\n", XP_SNPRINTF( buf, VSIZE(buf), "Player %s resigned\n",
cGlobals->gi->players[quitter].name ); cGlobals->gi->players[quitter].name );
stream_catString( stream, buf ); stream_catString( stream, buf );
@ -818,7 +818,7 @@ static CmdInfoRec CmdInfoRecs[] = {
static struct option* static struct option*
make_longopts() make_longopts()
{ {
int count = N_CMDS; int count = VSIZE( CmdInfoRecs );
struct option* result = calloc( count+1, sizeof(*result) ); struct option* result = calloc( count+1, sizeof(*result) );
int ii; int ii;
for ( ii = 0; ii < count; ++ii ) { for ( ii = 0; ii < count; ++ii ) {
@ -841,7 +841,7 @@ usage( char* appName, char* msg )
fprintf( stderr, "usage: %s \n", appName ); fprintf( stderr, "usage: %s \n", appName );
int maxWidth = 0; int maxWidth = 0;
for ( ii = 0; ii < N_CMDS; ++ii ) { for ( ii = 0; ii < VSIZE(CmdInfoRecs); ++ii ) {
const CmdInfoRec* rec = &CmdInfoRecs[ii]; const CmdInfoRec* rec = &CmdInfoRecs[ii];
int width = strlen(rec->param) + 1; int width = strlen(rec->param) + 1;
if ( rec->hasArg ) { if ( rec->hasArg ) {
@ -852,7 +852,7 @@ usage( char* appName, char* msg )
} }
} }
for ( ii = 0; ii < N_CMDS; ++ii ) { for ( ii = 0; ii < VSIZE(CmdInfoRecs); ++ii ) {
const CmdInfoRec* rec = &CmdInfoRecs[ii]; const CmdInfoRec* rec = &CmdInfoRecs[ii];
char buf[120]; char buf[120];
snprintf( buf, sizeof(buf), "--%s %s", rec->param, snprintf( buf, sizeof(buf), "--%s %s", rec->param,
@ -1624,7 +1624,7 @@ static void
testGetNthWord( const DictionaryCtxt* dict, char** XP_UNUSED_DBG(words), testGetNthWord( const DictionaryCtxt* dict, char** XP_UNUSED_DBG(words),
XP_U16 depth, IndexData* data, XP_U16 min, XP_U16 max ) XP_U16 depth, IndexData* data, XP_U16 min, XP_U16 max )
{ {
VDECL( XP_UCHAR, buf, 64 ); XP_UCHAR buf[64];
XP_U32 ii, jj; XP_U32 ii, jj;
DictIter iter; DictIter iter;
@ -1678,7 +1678,7 @@ walk_dict_test( MPFORMAL const DictionaryCtxt* dict,
XP_U32 count = dict_countWords( &iter, &lens ); XP_U32 count = dict_countWords( &iter, &lens );
XP_U32 sum = 0; XP_U32 sum = 0;
for ( jj = 0; jj < MAX_COLS_DICT+1; ++jj ) { for ( jj = 0; jj < VSIZE(lens.lens); ++jj ) {
sum += lens.lens[jj]; sum += lens.lens[jj];
XP_LOGF( "%d words of length %ld", lens.lens[jj], jj ); XP_LOGF( "%d words of length %ld", lens.lens[jj], jj );
} }
@ -1692,7 +1692,7 @@ walk_dict_test( MPFORMAL const DictionaryCtxt* dict,
gotOne; gotOne;
gotOne = dict_getNextWord( &iter ) ) { gotOne = dict_getNextWord( &iter ) ) {
XP_ASSERT( dict_getPosition( &iter ) == jj ); XP_ASSERT( dict_getPosition( &iter ) == jj );
VDECL( XP_UCHAR, buf, 64 ); XP_UCHAR buf[64];
dict_wordToString( &iter, buf, VSIZE(buf) ); dict_wordToString( &iter, buf, VSIZE(buf) );
# ifdef PRINT_ALL # ifdef PRINT_ALL
fprintf( stderr, "%.6ld: %s\n", jj, buf ); fprintf( stderr, "%.6ld: %s\n", jj, buf );
@ -1708,7 +1708,7 @@ walk_dict_test( MPFORMAL const DictionaryCtxt* dict,
gotOne; gotOne;
++jj, gotOne = dict_getPrevWord( &iter ) ) { ++jj, gotOne = dict_getPrevWord( &iter ) ) {
XP_ASSERT( dict_getPosition(&iter) == count-jj-1 ); XP_ASSERT( dict_getPosition(&iter) == count-jj-1 );
VDECL( XP_UCHAR, buf, 64 ); XP_UCHAR buf[64];
dict_wordToString( &iter, buf, VSIZE(buf) ); dict_wordToString( &iter, buf, VSIZE(buf) );
# ifdef PRINT_ALL # ifdef PRINT_ALL
fprintf( stderr, "%.6ld: %s\n", jj, buf ); fprintf( stderr, "%.6ld: %s\n", jj, buf );
@ -1750,13 +1750,13 @@ walk_dict_test( MPFORMAL const DictionaryCtxt* dict,
XP_ASSERT( 0 ); XP_ASSERT( 0 );
} }
XP_ASSERT( word.index == indices[ii] ); XP_ASSERT( word.index == indices[ii] );
VDECL( XP_UCHAR, buf1, 64 ); XP_UCHAR buf1[64];
dict_wordToString( dict, &word, buf1, VSIZE(buf1) ); dict_wordToString( dict, &word, buf1, VSIZE(buf1) );
VDECL( XP_UCHAR, buf2, 64 ) = {0}; XP_UCHAR buf2[64] = {0};
if ( ii > 0 && dict_getNthWord( dict, &word, indices[ii]-1 ) ) { if ( ii > 0 && dict_getNthWord( dict, &word, indices[ii]-1 ) ) {
dict_wordToString( dict, &word, buf2, VSIZE(buf2) ); dict_wordToString( dict, &word, buf2, VSIZE(buf2) );
} }
VDECL( char, prfx, 8 ); char prfx[8];
dict_tilesToString( dict, &prefixes[depth*ii], depth, prfx, dict_tilesToString( dict, &prefixes[depth*ii], depth, prfx,
VSIZE(prfx) ); VSIZE(prfx) );
fprintf( stderr, "%d: index: %ld; prefix: %s; word: %s (prev: %s)\n", fprintf( stderr, "%d: index: %ld; prefix: %s; word: %s (prev: %s)\n",
@ -1774,8 +1774,8 @@ walk_dict_test( MPFORMAL const DictionaryCtxt* dict,
gchar* prefix = (gchar*)g_slist_nth_data( testPrefixes, ii ); gchar* prefix = (gchar*)g_slist_nth_data( testPrefixes, ii );
XP_S16 lenMatched = dict_findStartsWith( &iter, prefix ); XP_S16 lenMatched = dict_findStartsWith( &iter, prefix );
if ( 0 <= lenMatched ) { if ( 0 <= lenMatched ) {
VDECL( XP_UCHAR, buf, 32 ); XP_UCHAR buf[32];
VDECL( XP_UCHAR, bufPrev, 32 ) = {0}; XP_UCHAR bufPrev[32] = {0};
dict_wordToString( &iter, buf, VSIZE(buf) ); dict_wordToString( &iter, buf, VSIZE(buf) );
/* This doesn't work with synonyms like "L-L" for "L·L" */ /* This doesn't work with synonyms like "L-L" for "L·L" */
@ -1832,7 +1832,7 @@ dumpDict( DictionaryCtxt* dict )
for ( XP_Bool result = dict_firstWord( &iter ); for ( XP_Bool result = dict_firstWord( &iter );
result; result;
result = dict_getNextWord( &iter ) ) { result = dict_getNextWord( &iter ) ) {
VDECL( XP_UCHAR, buf, 32 ); XP_UCHAR buf[32];
dict_wordToString( &iter, buf, VSIZE(buf) ); dict_wordToString( &iter, buf, VSIZE(buf) );
fprintf( stdout, "%s\n", buf ); fprintf( stdout, "%s\n", buf );
} }
@ -1841,7 +1841,7 @@ dumpDict( DictionaryCtxt* dict )
static void static void
trimDictPath( const char* input, char* buf, int bufsiz, char** path, char** dict ) trimDictPath( const char* input, char* buf, int bufsiz, char** path, char** dict )
{ {
VDECL( char, unlinked, 256 ); char unlinked[256];
XP_ASSERT( strlen(input) < VSIZE(unlinked) ); XP_ASSERT( strlen(input) < VSIZE(unlinked) );
ssize_t siz = readlink( input, unlinked, VSIZE(unlinked) ); ssize_t siz = readlink( input, unlinked, VSIZE(unlinked) );
if ( 0 <= siz ) { if ( 0 <= siz ) {
@ -1883,7 +1883,7 @@ getDictPath( const LaunchParams *params, const char* name,
result[0] = '\0'; result[0] = '\0';
for ( iter = params->dictDirs; !!iter; iter = iter->next ) { for ( iter = params->dictDirs; !!iter; iter = iter->next ) {
const char* path = iter->data; const char* path = iter->data;
VDECL( char, buf, 256 ); char buf[256];
int len = snprintf( buf, VSIZE(buf), "%s/%s.xwd", path, name ); int len = snprintf( buf, VSIZE(buf), "%s/%s.xwd", path, name );
if ( len < VSIZE(buf) && file_exists( buf ) ) { if ( len < VSIZE(buf) && file_exists( buf ) ) {
snprintf( result, resultLen, "%s", buf ); snprintf( result, resultLen, "%s", buf );
@ -2064,7 +2064,7 @@ main( int argc, char** argv )
GSList* testPrefixes = NULL; GSList* testPrefixes = NULL;
char* testMinMax = NULL; char* testMinMax = NULL;
#endif #endif
VDECL( char, dictbuf, 256 ); char dictbuf[256];
char* dict; char* dict;
char* path; char* path;

View file

@ -68,7 +68,7 @@ linux_debugf( const char* format, ... )
void void
linux_backtrace( void ) linux_backtrace( void )
{ {
VDECL( void*, buffer, 128 ); void* buffer[128];
int nFound = backtrace( buffer, VSIZE(buffer) ); int nFound = backtrace( buffer, VSIZE(buffer) );
XP_ASSERT( nFound < VSIZE(buffer) ); XP_ASSERT( nFound < VSIZE(buffer) );
char** traces = backtrace_symbols( buffer, nFound ); char** traces = backtrace_symbols( buffer, nFound );
@ -105,13 +105,10 @@ linux_util_makeEmptyDict( XW_UtilCtxt* XP_UNUSED_DBG(uctx) )
#define TL BONUS_TRIPLE_LETTER #define TL BONUS_TRIPLE_LETTER
#define TW BONUS_TRIPLE_WORD #define TW BONUS_TRIPLE_WORD
#define SC_BOARD_SIZE 36
#define SEVENTEEN_BOARD_SIZE 45
static XWBonusType* static XWBonusType*
bonusesFor( XP_U16 boardSize, XP_U16* len ) bonusesFor( XP_U16 boardSize, XP_U16* len )
{ {
static XWBonusType scrabbleBoard[SC_BOARD_SIZE] = { static XWBonusType scrabbleBoard[] = {
TW,//EM,EM,DL,EM,EM,EM,TW, TW,//EM,EM,DL,EM,EM,EM,TW,
EM,DW,//EM,EM,EM,TL,EM,EM, EM,DW,//EM,EM,EM,TL,EM,EM,
@ -125,7 +122,7 @@ bonusesFor( XP_U16 boardSize, XP_U16* len )
TW,EM,EM,DL,EM,EM,EM,DW, TW,EM,EM,DL,EM,EM,EM,DW,
}; /* scrabbleBoard */ }; /* scrabbleBoard */
static XWBonusType seventeen[SEVENTEEN_BOARD_SIZE] = { static XWBonusType seventeen[] = {
TW,//EM,EM,DL,EM,EM,EM,TW, TW,//EM,EM,DL,EM,EM,EM,TW,
EM,DW,//EM,EM,EM,TL,EM,EM, EM,DW,//EM,EM,EM,TL,EM,EM,
@ -143,10 +140,10 @@ bonusesFor( XP_U16 boardSize, XP_U16* len )
XWBonusType* result = NULL; XWBonusType* result = NULL;
if ( boardSize == 15 ) { if ( boardSize == 15 ) {
result = scrabbleBoard; result = scrabbleBoard;
*len = SC_BOARD_SIZE; *len = VSIZE(scrabbleBoard);
} else if ( boardSize == 17 ) { } else if ( boardSize == 17 ) {
result = seventeen; result = seventeen;
*len = SEVENTEEN_BOARD_SIZE; *len = VSIZE(seventeen);
} }
return result; return result;
@ -484,7 +481,7 @@ formatConfirmTrade( CommonGlobals* cGlobals, const XP_UCHAR** tiles,
} }
tileBuf[offset-2] = '\0'; tileBuf[offset-2] = '\0';
snprintf( cGlobals->question, QUESTION_LEN, snprintf( cGlobals->question, VSIZE(cGlobals->question),
"Are you sure you want to trade the selected tiles (%s)?", "Are you sure you want to trade the selected tiles (%s)?",
tileBuf ); tileBuf );
} }

View file

@ -188,7 +188,6 @@ typedef struct _TimerInfo {
typedef void (*OnSaveFunc)( void* closure, sqlite3_int64 rowid, typedef void (*OnSaveFunc)( void* closure, sqlite3_int64 rowid,
XP_Bool firstTime ); XP_Bool firstTime );
#define QUESTION_LEN 256*4
struct CommonGlobals { struct CommonGlobals {
LaunchParams* params; LaunchParams* params;
CommonPrefs cp; CommonPrefs cp;
@ -224,7 +223,7 @@ struct CommonGlobals {
/* Saved state from util method to response method */ /* Saved state from util method to response method */
XP_U16 selPlayer; XP_U16 selPlayer;
char question[QUESTION_LEN]; char question[256*4];
const XP_UCHAR* askPassName; const XP_UCHAR* askPassName;
XP_U16 nTiles; XP_U16 nTiles;
XP_U16 nToPick; XP_U16 nToPick;

View file

@ -32,8 +32,6 @@
#define MAX_MOVE_CHECK_MS ((XP_U16)(1000 * 60 * 60 * 24)) #define MAX_MOVE_CHECK_MS ((XP_U16)(1000 * 60 * 60 * 24))
#define RELAY_API_PROTO "http" #define RELAY_API_PROTO "http"
#define HOST_LEN 64
typedef struct _RelayConStorage { typedef struct _RelayConStorage {
pthread_t mainThread; pthread_t mainThread;
guint moveCheckerID; guint moveCheckerID;
@ -52,7 +50,7 @@ typedef struct _RelayConStorage {
uint32_t nextID; uint32_t nextID;
XWPDevProto proto; XWPDevProto proto;
LaunchParams* params; LaunchParams* params;
XP_UCHAR host[HOST_LEN]; XP_UCHAR host[64];
int nextTaskID; int nextTaskID;
} RelayConStorage; } RelayConStorage;
@ -261,7 +259,7 @@ relaycon_init( LaunchParams* params, const RelayConnProcs* procs,
pthread_mutex_init( &storage->gotDataMutex, NULL ); pthread_mutex_init( &storage->gotDataMutex, NULL );
g_timeout_add( 50, gotDataTimer, storage ); g_timeout_add( 50, gotDataTimer, storage );
XP_ASSERT( XP_STRLEN(host) < HOST_LEN ); XP_ASSERT( XP_STRLEN(host) < VSIZE(storage->host) );
XP_MEMCPY( storage->host, host, XP_STRLEN(host) + 1 ); XP_MEMCPY( storage->host, host, XP_STRLEN(host) + 1 );
} else { } else {
storage->socket = socket( AF_INET, SOCK_DGRAM, IPPROTO_UDP ); storage->socket = socket( AF_INET, SOCK_DGRAM, IPPROTO_UDP );

View file

@ -281,8 +281,6 @@ typedef unsigned short CookieID;
#define COOKIE_ID_NONE 0 #define COOKIE_ID_NONE 0
#ifndef VSIZE #define VSIZE(arr) (sizeof(arr)/sizeof(arr[0]))
# define VSIZE(arr) (sizeof(arr)/sizeof(arr[0]))
#endif
#endif #endif