fix gtk games connecting to relay/each other

I broke gtk back in February making curses changes
This commit is contained in:
Eric House 2020-04-21 21:18:43 -07:00
parent 055eceffba
commit 5a28a7fc27
4 changed files with 35 additions and 21 deletions

View file

@ -549,14 +549,23 @@ gi_setNPlayers( CurGameInfo* gi, XP_U16 nTotal, XP_U16 nHere )
} }
if ( nHere != curLocal ) { if ( nHere != curLocal ) {
/* This will happen when a device has more than on player. Not sure I /* This will happen when a device has more than one player. Not sure I
handle that correctly, but don't assert for now. */ handle that correctly, but don't assert for now. */
XP_LOGFF( "nHere: %d; curLocal: %d; a problem?", nHere, curLocal ); XP_LOGFF( "nHere: %d; curLocal: %d; a problem?", nHere, curLocal );
/* for ( XP_U16 ii = 0; ii < nTotal; ++ii ) { */ for ( XP_U16 ii = 0; ii < nTotal; ++ii ) {
/* gi->players[ii].isLocal = ii < nHere; */ if ( !gi->players[ii].isLocal ) {
/* } */ gi->players[ii].isLocal = XP_TRUE;
XP_LOGFF( "making player #%d local when wasn't before", ii );
++curLocal;
XP_ASSERT( curLocal <= nHere );
if ( curLocal == nHere ) {
break;
} }
} }
}
}
LOGGI( gi, __func__ );
}
XP_U16 XP_U16
gi_countLocalPlayers( const CurGameInfo* gi, XP_Bool humanOnly ) gi_countLocalPlayers( const CurGameInfo* gi, XP_Bool humanOnly )
@ -762,10 +771,10 @@ player_timePenalty( CurGameInfo* gi, XP_U16 playerNum )
#ifdef DEBUG #ifdef DEBUG
void void
game_logGI( const CurGameInfo* gi, const char* msg ) game_logGI( const CurGameInfo* gi, const char* msg, const char* func, int line )
{ {
XP_LOGFF( "msg: %s", msg ); XP_LOGFF( "msg: %s from %s() line %d; addr: %p", msg, func, line, gi );
if ( !!gi ) {
XP_LOGF( " nPlayers: %d", gi->nPlayers ); XP_LOGF( " nPlayers: %d", gi->nPlayers );
for ( XP_U16 ii = 0; ii < gi->nPlayers; ++ii ) { for ( XP_U16 ii = 0; ii < gi->nPlayers; ++ii ) {
const LocalPlayer* lp = &gi->players[ii]; const LocalPlayer* lp = &gi->players[ii];
@ -777,6 +786,7 @@ game_logGI( const CurGameInfo* gi, const char* msg )
XP_LOGF( " gameID: %d", gi->gameID ); XP_LOGF( " gameID: %d", gi->gameID );
XP_LOGF( " dictName: %s", gi->dictName ); XP_LOGF( " dictName: %s", gi->dictName );
} }
}
#endif #endif
#ifdef CPLUS #ifdef CPLUS

View file

@ -64,9 +64,11 @@ typedef struct CurGameInfo {
} CurGameInfo; } CurGameInfo;
#ifdef DEBUG #ifdef DEBUG
void game_logGI( const CurGameInfo* gi, const char* msg ); # define LOGGI( gip, msg ) game_logGI( (gip), (msg), __func__, __LINE__ )
void game_logGI( const CurGameInfo* gi, const char* msg,
const char* func, int line );
#else #else
# define game_logGI(gi, msg) # define LOGGI(gi, msg)
#endif #endif
#ifdef CPLUS #ifdef CPLUS

View file

@ -672,8 +672,9 @@ server_initClientConnection( ServerCtxt* server, XWStreamCtxt* stream )
nPlayers = gi->nPlayers; nPlayers = gi->nPlayers;
XP_ASSERT( nPlayers > 0 ); XP_ASSERT( nPlayers > 0 );
stream_putBits( stream, NPLAYERS_NBITS, XP_U16 localPlayers = gi_countLocalPlayers( gi, XP_FALSE);
gi_countLocalPlayers( gi, XP_FALSE) ); XP_ASSERT( 0 < localPlayers );
stream_putBits( stream, NPLAYERS_NBITS, localPlayers );
for ( lp = gi->players; nPlayers-- > 0; ++lp ) { for ( lp = gi->players; nPlayers-- > 0; ++lp ) {
XP_UCHAR* name; XP_UCHAR* name;

View file

@ -583,7 +583,8 @@ createOrLoadObjects( GtkGameGlobals* globals )
TransportProcs procs; TransportProcs procs;
setTransportProcs( &procs, globals ); setTransportProcs( &procs, globals );
if ( linuxOpenGame( cGlobals, &procs, NULL ) ) {
if ( linuxOpenGame( cGlobals, &procs, &cGlobals->addr ) ) {
if ( !params->fileName && !!params->dbName ) { if ( !params->fileName && !!params->dbName ) {
XP_UCHAR buf[64]; XP_UCHAR buf[64];