make invitation to three-device games work on gtk/linux

This commit is contained in:
Eric House 2023-02-08 10:28:00 -08:00
parent ad5514ac17
commit d924776a84
3 changed files with 61 additions and 38 deletions

View file

@ -83,14 +83,14 @@ typedef enum {
#define XWPROTO_NBITS 4 #define XWPROTO_NBITS 4
#define UNKNOWN_DEVICE -1
#define SERVER_DEVICE 0
typedef struct ServerPlayer { typedef struct ServerPlayer {
EngineCtxt* engine; /* each needs his own so don't interfere each other */ EngineCtxt* engine; /* each needs his own so don't interfere each other */
XP_S8 deviceIndex; /* 0 means local, -1 means unknown */ XP_S8 deviceIndex; /* 0 means local, -1 means unknown */
} ServerPlayer; } ServerPlayer;
#define UNKNOWN_DEVICE -1
#define SERVER_DEVICE 0
typedef struct RemoteAddress { typedef struct RemoteAddress {
XP_PlayerAddr channelNo; XP_PlayerAddr channelNo;
#ifdef STREAM_VERS_BIGBOARD #ifdef STREAM_VERS_BIGBOARD
@ -3862,6 +3862,26 @@ server_getMissingPlayers( const ServerCtxt* server )
return result; return result;
} }
XP_Bool
server_getOpenChannel( const ServerCtxt* server, XP_U16* channel )
{
XP_Bool result = XP_FALSE;
XP_ASSERT( amServer( server ) );
if ( amServer( server ) && 0 < server->nv.pendingRegistrations ) {
const XP_U16 nPlayers = server->vol.gi->nPlayers;
const ServerPlayer* players = server->players;
for ( int ii = 0; ii < nPlayers && !result; ++ii ) {
result = UNKNOWN_DEVICE == players->deviceIndex;
if ( result ) {
*channel = ii;
}
++players;
}
}
XP_LOGFF( "channel= %d, found: %s", *channel, boolToStr(result) );
return result;
}
XP_U32 XP_U32
server_getLastMoveTime( const ServerCtxt* server ) server_getLastMoveTime( const ServerCtxt* server )
{ {

View file

@ -90,6 +90,7 @@ void server_unpause( ServerCtxt* server, XWEnv xwe, XP_S16 turn, const XP_UCHAR*
/* return bitvector marking players still not arrived in networked game */ /* return bitvector marking players still not arrived in networked game */
XP_U16 server_getMissingPlayers( const ServerCtxt* server ); XP_U16 server_getMissingPlayers( const ServerCtxt* server );
XP_Bool server_getOpenChannel( const ServerCtxt* server, XP_U16* channel );
XP_U32 server_getLastMoveTime( const ServerCtxt* server ); XP_U32 server_getLastMoveTime( const ServerCtxt* server );
/* Signed in case no dictionary available */ /* Signed in case no dictionary available */
XP_S16 server_countTilesInPool( ServerCtxt* server ); XP_S16 server_countTilesInPool( ServerCtxt* server );

View file

@ -1386,55 +1386,57 @@ send_invites( CommonGlobals* cGlobals, XP_U16 nPlayers,
XP_ASSERT( comms ); XP_ASSERT( comms );
comms_getSelfAddr( comms, &myAddr ); comms_getSelfAddr( comms, &myAddr );
gint forceChannel = 1; /* 1 is what Android does. Limits to two-device games */ XP_U16 channel;
if ( server_getOpenChannel( cGlobals->game.server, &channel ) ) {
gint forceChannel = channel;
NetLaunchInfo nli = {0}; /* include everything!!! */ NetLaunchInfo nli = {0}; /* include everything!!! */
nli_init( &nli, cGlobals->gi, &myAddr, nPlayers, forceChannel ); nli_init( &nli, cGlobals->gi, &myAddr, nPlayers, forceChannel );
#ifdef XWFEATURE_RELAY #ifdef XWFEATURE_RELAY
if ( addr_hasType( &myAddr, COMMS_CONN_RELAY ) ) { if ( addr_hasType( &myAddr, COMMS_CONN_RELAY ) ) {
XP_UCHAR buf[32]; XP_UCHAR buf[32];
snprintf( buf, sizeof(buf), "%X", makeRandomInt() ); snprintf( buf, sizeof(buf), "%X", makeRandomInt() );
nli_setInviteID( &nli, buf ); /* PENDING: should not be relay only!!! */ nli_setInviteID( &nli, buf ); /* PENDING: should not be relay only!!! */
} }
#endif #endif
// nli_setDevID( &nli, linux_getDevIDRelay( cGlobals->params ) ); // nli_setDevID( &nli, linux_getDevIDRelay( cGlobals->params ) );
if ( addr_hasType( &myAddr, COMMS_CONN_MQTT ) ) { if ( addr_hasType( &myAddr, COMMS_CONN_MQTT ) ) {
const MQTTDevID* devid = mqttc_getDevID( cGlobals->params ); const MQTTDevID* devid = mqttc_getDevID( cGlobals->params );
nli_setMQTTDevID( &nli, devid ); nli_setMQTTDevID( &nli, devid );
} }
#ifdef DEBUG #ifdef DEBUG
{ {
XWStreamCtxt* stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool) XWStreamCtxt* stream = mem_stream_make_raw( MPPARM(cGlobals->util->mpool)
cGlobals->params->vtMgr ); cGlobals->params->vtMgr );
nli_saveToStream( &nli, stream ); nli_saveToStream( &nli, stream );
NetLaunchInfo tmp; NetLaunchInfo tmp;
nli_makeFromStream( &tmp, stream ); nli_makeFromStream( &tmp, stream );
stream_destroy( stream ); stream_destroy( stream );
XP_ASSERT( 0 == memcmp( &nli, &tmp, sizeof(nli) ) ); XP_ASSERT( 0 == memcmp( &nli, &tmp, sizeof(nli) ) );
} }
#endif #endif
#ifdef XWFEATURE_COMMS_INVITE #ifdef XWFEATURE_COMMS_INVITE
comms_invite( comms, NULL_XWE, &nli, destAddr, XP_TRUE ); comms_invite( comms, NULL_XWE, &nli, destAddr, XP_TRUE );
#else #else
if ( !!destAddr && '\0' != destAddr->u.sms.phone[0] && 0 < destAddr->u.sms.port ) { if ( !!destAddr && '\0' != destAddr->u.sms.phone[0] && 0 < destAddr->u.sms.port ) {
linux_sms_invite( cGlobals->params, &nli, linux_sms_invite( cGlobals->params, &nli,
destAddr->u.sms.phone, destAddr->u.sms.port ); destAddr->u.sms.phone, destAddr->u.sms.port );
} }
# ifdef XWFEATURE_RELAY # ifdef XWFEATURE_RELAY
if ( 0 != relayDevID || !!relayID ) { if ( 0 != relayDevID || !!relayID ) {
XP_ASSERT( 0 != relayDevID || (!!relayID && !!relayID[0]) ); XP_ASSERT( 0 != relayDevID || (!!relayID && !!relayID[0]) );
relaycon_invite( cGlobals->params, relayDevID, relayID, &nli ); relaycon_invite( cGlobals->params, relayDevID, relayID, &nli );
} }
# endif # endif
if ( addr_hasType( destAddr, COMMS_CONN_MQTT ) ) { if ( addr_hasType( destAddr, COMMS_CONN_MQTT ) ) {
mqttc_invite( cGlobals->params, 0, &nli, &destAddr->u.mqtt.devID ); mqttc_invite( cGlobals->params, 0, &nli, &destAddr->u.mqtt.devID );
} }
#endif #endif
}
/* while ( gtkaskm( "Invite how many and how?", infos, VSIZE(infos) ) ) { */ /* while ( gtkaskm( "Invite how many and how?", infos, VSIZE(infos) ) ) { */
/* int nPlayers = atoi( countStr ); */ /* int nPlayers = atoi( countStr ); */
/* if ( 0 >= nPlayers || nPlayers > nMissing ) { */ /* if ( 0 >= nPlayers || nPlayers > nMissing ) { */