on commandline, only allow assignment of per-player dicts to local

players.  I don't know what happens when a player's position is
changed when its game is a guest and the hosts rearranges players.
Which is why on Android I'm moving to allowing per-player dicts only
on local-only games.
This commit is contained in:
Eric House 2012-10-14 19:10:42 -07:00
parent 25a1ee451b
commit 4cf595e939

View file

@ -1929,14 +1929,25 @@ main( int argc, char** argv )
mainParams.needsNewGame = XP_TRUE; mainParams.needsNewGame = XP_TRUE;
} }
for ( ii = 0; ii < nPlayerDicts; ++ii ) { /* per-player dicts are for local players only. Assign in the order
const XP_UCHAR* name = mainParams.playerDictNames[ii]; given. It's an error to give too many, or not to give enough if
if ( !!name ) { there's no game-dict */
if ( 0 < nPlayerDicts ) {
XP_U16 nextDict = 0;
for ( ii = 0; ii < mainParams.gi.nPlayers; ++ii ) {
if ( mainParams.gi.players[ii].isLocal ) {
const XP_UCHAR* name = mainParams.playerDictNames[nextDict++];
XP_ASSERT( !!name );
mainParams.dicts.dicts[ii] = mainParams.dicts.dicts[ii] =
linux_dictionary_make( MPPARM(mainParams.util->mpool) linux_dictionary_make( MPPARM(mainParams.util->mpool)
&mainParams, name, mainParams.useMmap ); &mainParams, name, mainParams.useMmap );
} }
} }
if ( nextDict < nPlayerDicts ) {
usage( argv[0], " --player-dict used more times than there are "
"local players" );
}
}
/* if ( !isServer ) { */ /* if ( !isServer ) { */
/* if ( mainParams.info.serverInfo.nRemotePlayers > 0 ) { */ /* if ( mainParams.info.serverInfo.nRemotePlayers > 0 ) { */