mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-03 23:04:08 +01:00
strutils syntax changes. Rough cut at reordering loading in game
info: when the device is a client and is starting a new game, we want to start presenting only the local players. So load them first, and reduce nPlayers down to the count of current local players. Works well, but can probably be simplified.
This commit is contained in:
parent
4029120fc6
commit
9239d34f19
1 changed files with 44 additions and 16 deletions
|
@ -42,9 +42,7 @@ struct NewGameCtx {
|
||||||
store '***' in the visible field */
|
store '***' in the visible field */
|
||||||
NewGameEnable enabled[NG_NUM_COLS][MAX_NUM_PLAYERS];
|
NewGameEnable enabled[NG_NUM_COLS][MAX_NUM_PLAYERS];
|
||||||
XP_U16 nPlayers;
|
XP_U16 nPlayers;
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
|
||||||
Connectedness role;
|
Connectedness role;
|
||||||
#endif
|
|
||||||
XP_Bool isNewGame;
|
XP_Bool isNewGame;
|
||||||
NewGameEnable juggleEnabled;
|
NewGameEnable juggleEnabled;
|
||||||
|
|
||||||
|
@ -96,27 +94,55 @@ newg_load( NewGameCtx* ngc, const CurGameInfo* gi )
|
||||||
{
|
{
|
||||||
void* closure = ngc->closure;
|
void* closure = ngc->closure;
|
||||||
NGValue value;
|
NGValue value;
|
||||||
XP_U16 i;
|
XP_U16 nPlayers, nShown;
|
||||||
|
XP_S16 i;
|
||||||
|
Connectedness role;
|
||||||
|
XP_Bool localOnly;
|
||||||
|
XP_Bool shown[MAX_NUM_PLAYERS] = { XP_FALSE, XP_FALSE, XP_FALSE, XP_FALSE};
|
||||||
|
|
||||||
ngc->nPlayers = gi->nPlayers;
|
ngc->role = role = gi->serverRole;
|
||||||
|
localOnly = role == SERVER_ISCLIENT;
|
||||||
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
|
value.ng_role = role;
|
||||||
|
(*ngc->setAttrProc)( closure, NG_ATTR_ROLE, value );
|
||||||
|
(*ngc->enableAttrProc)( closure, NG_ATTR_ROLE, ngc->isNewGame?
|
||||||
|
NGEnableEnabled : NGEnableDisabled );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
nPlayers = gi->nPlayers;
|
||||||
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
|
if ( localOnly ) {
|
||||||
|
for ( i = nPlayers - 1; i >= 0; --i ) {
|
||||||
|
if ( !gi->players[i].isLocal ) {
|
||||||
|
--nPlayers;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
ngc->nPlayers = nPlayers;
|
||||||
value.ng_u16 = ngc->nPlayers;
|
value.ng_u16 = ngc->nPlayers;
|
||||||
(*ngc->setAttrProc)( closure, NG_ATTR_NPLAYERS, value );
|
(*ngc->setAttrProc)( closure, NG_ATTR_NPLAYERS, value );
|
||||||
(*ngc->enableAttrProc)( closure, NG_ATTR_NPLAYERS, ngc->isNewGame?
|
(*ngc->enableAttrProc)( closure, NG_ATTR_NPLAYERS, ngc->isNewGame?
|
||||||
NGEnableEnabled : NGEnableDisabled );
|
NGEnableEnabled : NGEnableDisabled );
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
|
||||||
ngc->role = gi->serverRole;
|
|
||||||
value.ng_role = ngc->role;
|
|
||||||
(*ngc->setAttrProc)( closure, NG_ATTR_ROLE, value );
|
|
||||||
(*ngc->enableAttrProc)( closure, NG_ATTR_ROLE, ngc->isNewGame?
|
|
||||||
NGEnableEnabled : NGEnableDisabled );
|
|
||||||
#endif
|
|
||||||
setRoleStrings( ngc );
|
setRoleStrings( ngc );
|
||||||
considerEnableJuggle( ngc );
|
considerEnableJuggle( ngc );
|
||||||
|
|
||||||
|
/* Load local players first */
|
||||||
|
nShown = 0;
|
||||||
|
do {
|
||||||
for ( i = 0; i < MAX_NUM_PLAYERS; ++i ) {
|
for ( i = 0; i < MAX_NUM_PLAYERS; ++i ) {
|
||||||
loadPlayer( ngc, i, &gi->players[i] );
|
const LocalPlayer* lp = &gi->players[i];
|
||||||
|
if ( shown[i] ) {
|
||||||
|
/* already got it */
|
||||||
|
} else if ( !localOnly || lp->isLocal ) {
|
||||||
|
shown[i] = XP_TRUE;
|
||||||
|
loadPlayer( ngc, nShown++, lp );
|
||||||
|
} /* else skip it */
|
||||||
}
|
}
|
||||||
|
XP_ASSERT( localOnly || nShown == MAX_NUM_PLAYERS );
|
||||||
|
localOnly = XP_FALSE; /* for second pass */
|
||||||
|
} while ( nShown < MAX_NUM_PLAYERS );
|
||||||
|
|
||||||
adjustAllRows( ngc, XP_TRUE );
|
adjustAllRows( ngc, XP_TRUE );
|
||||||
} /* newg_load */
|
} /* newg_load */
|
||||||
|
@ -153,7 +179,9 @@ cpToLP( NGValue value, const void* cbClosure )
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !!strAddr ) {
|
if ( !!strAddr ) {
|
||||||
replaceStringIfDifferent( MPPARM(cpcl->ngc->mpool) strAddr,
|
/* This is leaking!!! But doesn't leak if am playing via IR, at least
|
||||||
|
in the simulator. */
|
||||||
|
replaceStringIfDifferent( cpcl->ngc->mpool, strAddr,
|
||||||
value.ng_cp );
|
value.ng_cp );
|
||||||
}
|
}
|
||||||
} /* cpToLP */
|
} /* cpToLP */
|
||||||
|
@ -219,7 +247,7 @@ deepCopy( NGValue value, const void* closure )
|
||||||
break;
|
break;
|
||||||
case NG_COL_NAME:
|
case NG_COL_NAME:
|
||||||
case NG_COL_PASSWD:
|
case NG_COL_PASSWD:
|
||||||
dvp->value.ng_cp = copyString( MPPARM(dvp->mpool) value.ng_cp );
|
dvp->value.ng_cp = copyString( dvp->mpool, value.ng_cp );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue