From 4cf595e93977cc14fcf44687c0b915ad6bf77667 Mon Sep 17 00:00:00 2001 From: Eric House Date: Sun, 14 Oct 2012 19:10:42 -0700 Subject: [PATCH] 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. --- xwords4/linux/linuxmain.c | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/xwords4/linux/linuxmain.c b/xwords4/linux/linuxmain.c index 09d3181e8..2247ecf70 100644 --- a/xwords4/linux/linuxmain.c +++ b/xwords4/linux/linuxmain.c @@ -1929,12 +1929,23 @@ main( int argc, char** argv ) mainParams.needsNewGame = XP_TRUE; } - for ( ii = 0; ii < nPlayerDicts; ++ii ) { - const XP_UCHAR* name = mainParams.playerDictNames[ii]; - if ( !!name ) { - mainParams.dicts.dicts[ii] = - linux_dictionary_make( MPPARM(mainParams.util->mpool) - &mainParams, name, mainParams.useMmap ); + /* per-player dicts are for local players only. Assign in the order + given. It's an error to give too many, or not to give enough if + 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] = + linux_dictionary_make( MPPARM(mainParams.util->mpool) + &mainParams, name, mainParams.useMmap ); + } + } + if ( nextDict < nPlayerDicts ) { + usage( argv[0], " --player-dict used more times than there are " + "local players" ); } }