mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-15 15:41:24 +01:00
Modify comms and games APIs so single struct of callbacks is passed
instead of multiple callbacks; add callback called when relay state changes; adapt linux and palm clients to new API. (Wince changes pending.)
This commit is contained in:
parent
86b560c441
commit
6c4b991566
7 changed files with 116 additions and 70 deletions
|
@ -77,13 +77,6 @@ typedef struct AddressRecord {
|
||||||
|
|
||||||
#define ADDRESSRECORD_SIZE_68K 20
|
#define ADDRESSRECORD_SIZE_68K 20
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
COMMS_RELAYSTATE_UNCONNECTED
|
|
||||||
, COMMS_RELAYSTATE_CONNECT_PENDING
|
|
||||||
, COMMS_RELAYSTATE_CONNECTED
|
|
||||||
, COMMS_RELAYSTATE_ALLCONNECTED
|
|
||||||
} CommsRelayState;
|
|
||||||
|
|
||||||
struct CommsCtxt {
|
struct CommsCtxt {
|
||||||
XW_UtilCtxt* util;
|
XW_UtilCtxt* util;
|
||||||
|
|
||||||
|
@ -93,9 +86,8 @@ struct CommsCtxt {
|
||||||
|
|
||||||
AddressRecord* recs; /* return addresses */
|
AddressRecord* recs; /* return addresses */
|
||||||
|
|
||||||
TransportSend sendproc;
|
TransportProcs procs;
|
||||||
#ifdef COMMS_HEARTBEAT
|
#ifdef COMMS_HEARTBEAT
|
||||||
TransportReset resetproc;
|
|
||||||
XP_U32 lastMsgRcd;
|
XP_U32 lastMsgRcd;
|
||||||
#endif
|
#endif
|
||||||
void* sendClosure;
|
void* sendClosure;
|
||||||
|
@ -201,7 +193,7 @@ static XP_S16 send_via_bt_or_ip( CommsCtxt* comms, BTIPMsgType typ,
|
||||||
#ifdef XWFEATURE_RELAY
|
#ifdef XWFEATURE_RELAY
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
static const char*
|
const char*
|
||||||
CommsRelayState2Str( CommsRelayState state )
|
CommsRelayState2Str( CommsRelayState state )
|
||||||
{
|
{
|
||||||
#define CASE_STR(s) case s: return #s
|
#define CASE_STR(s) case s: return #s
|
||||||
|
@ -226,6 +218,9 @@ set_relay_state( CommsCtxt* comms, CommsRelayState state )
|
||||||
CommsRelayState2Str(comms->r.relayState),
|
CommsRelayState2Str(comms->r.relayState),
|
||||||
CommsRelayState2Str(state) );
|
CommsRelayState2Str(state) );
|
||||||
comms->r.relayState = state;
|
comms->r.relayState = state;
|
||||||
|
if ( !!comms->procs.rstatus ) {
|
||||||
|
(*comms->procs.rstatus)( comms->procs.closure, state );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -247,8 +242,7 @@ CommsCtxt*
|
||||||
comms_make( MPFORMAL XW_UtilCtxt* util, XP_Bool isServer,
|
comms_make( MPFORMAL XW_UtilCtxt* util, XP_Bool isServer,
|
||||||
XP_U16 XP_UNUSED_RELAY(nPlayersHere),
|
XP_U16 XP_UNUSED_RELAY(nPlayersHere),
|
||||||
XP_U16 XP_UNUSED_RELAY(nPlayersTotal),
|
XP_U16 XP_UNUSED_RELAY(nPlayersTotal),
|
||||||
TransportSend sendproc, IF_CH(TransportReset resetproc)
|
const TransportProcs* procs )
|
||||||
void* closure )
|
|
||||||
{
|
{
|
||||||
CommsCtxt* result = (CommsCtxt*)XP_MALLOC( mpool, sizeof(*result) );
|
CommsCtxt* result = (CommsCtxt*)XP_MALLOC( mpool, sizeof(*result) );
|
||||||
XP_MEMSET( result, 0, sizeof(*result) );
|
XP_MEMSET( result, 0, sizeof(*result) );
|
||||||
|
@ -256,11 +250,7 @@ comms_make( MPFORMAL XW_UtilCtxt* util, XP_Bool isServer,
|
||||||
MPASSIGN(result->mpool, mpool);
|
MPASSIGN(result->mpool, mpool);
|
||||||
|
|
||||||
result->isServer = isServer;
|
result->isServer = isServer;
|
||||||
result->sendproc = sendproc;
|
XP_MEMCPY( &result->procs, procs, sizeof(result->procs) );
|
||||||
#ifdef COMMS_HEARTBEAT
|
|
||||||
result->resetproc = resetproc;
|
|
||||||
#endif
|
|
||||||
result->sendClosure = closure;
|
|
||||||
result->util = util;
|
result->util = util;
|
||||||
|
|
||||||
#ifdef XWFEATURE_RELAY
|
#ifdef XWFEATURE_RELAY
|
||||||
|
@ -435,8 +425,7 @@ addrFromStream( CommsAddrRec* addrP, XWStreamCtxt* stream )
|
||||||
|
|
||||||
CommsCtxt*
|
CommsCtxt*
|
||||||
comms_makeFromStream( MPFORMAL XWStreamCtxt* stream, XW_UtilCtxt* util,
|
comms_makeFromStream( MPFORMAL XWStreamCtxt* stream, XW_UtilCtxt* util,
|
||||||
TransportSend sendproc,
|
const TransportProcs* procs )
|
||||||
IF_CH(TransportReset resetproc ) void* closure )
|
|
||||||
{
|
{
|
||||||
CommsCtxt* comms;
|
CommsCtxt* comms;
|
||||||
XP_Bool isServer;
|
XP_Bool isServer;
|
||||||
|
@ -463,8 +452,7 @@ comms_makeFromStream( MPFORMAL XWStreamCtxt* stream, XW_UtilCtxt* util,
|
||||||
nPlayersTotal = 0;
|
nPlayersTotal = 0;
|
||||||
}
|
}
|
||||||
comms = comms_make( MPPARM(mpool) util, isServer,
|
comms = comms_make( MPPARM(mpool) util, isServer,
|
||||||
nPlayersHere, nPlayersTotal,
|
nPlayersHere, nPlayersTotal, procs );
|
||||||
sendproc, IF_CH(resetproc) closure );
|
|
||||||
XP_MEMCPY( &comms->addr, &addr, sizeof(comms->addr) );
|
XP_MEMCPY( &comms->addr, &addr, sizeof(comms->addr) );
|
||||||
|
|
||||||
comms->connID = stream_getU32( stream );
|
comms->connID = stream_getU32( stream );
|
||||||
|
@ -992,9 +980,9 @@ sendMsg( CommsCtxt* comms, MsgQueueElem* elem )
|
||||||
const CommsAddrRec* addr;
|
const CommsAddrRec* addr;
|
||||||
(void)channelToAddress( comms, channelNo, &addr );
|
(void)channelToAddress( comms, channelNo, &addr );
|
||||||
|
|
||||||
XP_ASSERT( !!comms->sendproc );
|
XP_ASSERT( !!comms->procs.send );
|
||||||
result = (*comms->sendproc)( elem->msg, elem->len, addr,
|
result = (*comms->procs.send)( elem->msg, elem->len, addr,
|
||||||
comms->sendClosure );
|
comms->procs.closure );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( result == elem->len ) {
|
if ( result == elem->len ) {
|
||||||
|
@ -1137,6 +1125,7 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
|
||||||
relayErr = stream_getU8( stream );
|
relayErr = stream_getU8( stream );
|
||||||
srcID = stream_getU8( stream );
|
srcID = stream_getU8( stream );
|
||||||
XP_LOGF( "%s: host id %x disconnected", __func__, srcID );
|
XP_LOGF( "%s: host id %x disconnected", __func__, srcID );
|
||||||
|
set_relay_state( comms, COMMS_RELAYSTATE_CONNECTED );
|
||||||
/* we will eventually want to tell the user which player's gone */
|
/* we will eventually want to tell the user which player's gone */
|
||||||
util_userError( comms->util, ERR_RELAY_BASE + relayErr );
|
util_userError( comms->util, ERR_RELAY_BASE + relayErr );
|
||||||
break;
|
break;
|
||||||
|
@ -1144,8 +1133,8 @@ relayPreProcess( CommsCtxt* comms, XWStreamCtxt* stream, XWHostID* senderID )
|
||||||
case XWRELAY_DISCONNECT_YOU: /* Close socket for this? */
|
case XWRELAY_DISCONNECT_YOU: /* Close socket for this? */
|
||||||
case XWRELAY_CONNECTDENIED: /* Close socket for this? */
|
case XWRELAY_CONNECTDENIED: /* Close socket for this? */
|
||||||
relayErr = stream_getU8( stream );
|
relayErr = stream_getU8( stream );
|
||||||
util_userError( comms->util, ERR_RELAY_BASE + relayErr );
|
|
||||||
set_relay_state( comms, COMMS_RELAYSTATE_UNCONNECTED );
|
set_relay_state( comms, COMMS_RELAYSTATE_UNCONNECTED );
|
||||||
|
util_userError( comms->util, ERR_RELAY_BASE + relayErr );
|
||||||
/* fallthru */
|
/* fallthru */
|
||||||
default:
|
default:
|
||||||
XP_LOGF( "%s: dropping relay msg with cmd %d", __func__, (XP_U16)cmd );
|
XP_LOGF( "%s: dropping relay msg with cmd %d", __func__, (XP_U16)cmd );
|
||||||
|
@ -1504,7 +1493,7 @@ heartbeat_checks( CommsCtxt* comms )
|
||||||
if ( comms->lastMsgRcvdTime < tooLongAgo ) {
|
if ( comms->lastMsgRcvdTime < tooLongAgo ) {
|
||||||
XP_LOGF( "%s: calling reset proc; last was %ld secs too long "
|
XP_LOGF( "%s: calling reset proc; last was %ld secs too long "
|
||||||
"ago", __func__, tooLongAgo - comms->lastMsgRcvdTime );
|
"ago", __func__, tooLongAgo - comms->lastMsgRcvdTime );
|
||||||
(*comms->resetproc)(comms->sendClosure);
|
(*comms->procs.reset)(comms->procs.closure);
|
||||||
comms->lastMsgRcvdTime = 0;
|
comms->lastMsgRcvdTime = 0;
|
||||||
break; /* outta here */
|
break; /* outta here */
|
||||||
}
|
}
|
||||||
|
@ -1787,7 +1776,8 @@ send_via_relay( CommsCtxt* comms, XWRELAY_Cmd cmd, XWHostID destID,
|
||||||
if ( buf != NULL ) {
|
if ( buf != NULL ) {
|
||||||
XP_U16 result;
|
XP_U16 result;
|
||||||
XP_LOGF( "%s: passing %d bytes to sendproc", __func__, len );
|
XP_LOGF( "%s: passing %d bytes to sendproc", __func__, len );
|
||||||
result = (*comms->sendproc)( buf, len, &addr, comms->sendClosure );
|
result = (*comms->procs.send)( buf, len, &addr,
|
||||||
|
comms->procs.closure );
|
||||||
success = result == len;
|
success = result == len;
|
||||||
if ( success ) {
|
if ( success ) {
|
||||||
setHeartbeatTimer( comms );
|
setHeartbeatTimer( comms );
|
||||||
|
@ -1837,7 +1827,7 @@ send_via_bt_or_ip( CommsCtxt* comms, BTIPMsgType typ, XP_PlayerAddr channelNo,
|
||||||
XP_MEMCPY( &buf[1], data, dlen );
|
XP_MEMCPY( &buf[1], data, dlen );
|
||||||
}
|
}
|
||||||
|
|
||||||
nSent = (*comms->sendproc)( buf, dlen+1, addr, comms->sendClosure );
|
nSent = (*comms->procs.send)( buf, dlen+1, addr, comms->procs.closure );
|
||||||
XP_FREE( comms->mpool, buf );
|
XP_FREE( comms->mpool, buf );
|
||||||
|
|
||||||
setHeartbeatTimer( comms );
|
setHeartbeatTimer( comms );
|
||||||
|
|
|
@ -45,6 +45,14 @@ typedef enum {
|
||||||
,COMMS_CONN_NTYPES
|
,COMMS_CONN_NTYPES
|
||||||
} CommsConnType;
|
} CommsConnType;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
COMMS_RELAYSTATE_UNCONNECTED
|
||||||
|
, COMMS_RELAYSTATE_CONNECT_PENDING
|
||||||
|
, COMMS_RELAYSTATE_CONNECTED
|
||||||
|
, COMMS_RELAYSTATE_ALLCONNECTED
|
||||||
|
} CommsRelayState;
|
||||||
|
|
||||||
|
|
||||||
/* WHAT SHOULD THIS BE? Copied from Whiteboard.... PENDING */
|
/* WHAT SHOULD THIS BE? Copied from Whiteboard.... PENDING */
|
||||||
#define XW_BT_UUID \
|
#define XW_BT_UUID \
|
||||||
{ 0x83, 0xe0, 0x87, 0xae, 0x4e, 0x18, 0x46, 0xbe, \
|
{ 0x83, 0xe0, 0x87, 0xae, 0x4e, 0x18, 0x46, 0xbe, \
|
||||||
|
@ -100,13 +108,29 @@ typedef struct CommsAddrRec {
|
||||||
typedef XP_S16 (*TransportSend)( const XP_U8* buf, XP_U16 len,
|
typedef XP_S16 (*TransportSend)( const XP_U8* buf, XP_U16 len,
|
||||||
const CommsAddrRec* addr,
|
const CommsAddrRec* addr,
|
||||||
void* closure );
|
void* closure );
|
||||||
|
#ifdef COMMS_HEARTBEAT
|
||||||
typedef void (*TransportReset)( void* closure );
|
typedef void (*TransportReset)( void* closure );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef XWFEATURE_RELAY
|
||||||
|
typedef void (*RelayStatusProc)( void* closure, CommsRelayState newState );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct _TransportProcs {
|
||||||
|
TransportSend send;
|
||||||
|
#ifdef COMMS_HEARTBEAT
|
||||||
|
TransportReset reset;
|
||||||
|
#endif
|
||||||
|
#ifdef XWFEATURE_RELAY
|
||||||
|
RelayStatusProc rstatus;
|
||||||
|
#endif
|
||||||
|
void* closure;
|
||||||
|
} TransportProcs;
|
||||||
|
|
||||||
CommsCtxt* comms_make( MPFORMAL XW_UtilCtxt* util,
|
CommsCtxt* comms_make( MPFORMAL XW_UtilCtxt* util,
|
||||||
XP_Bool isServer,
|
XP_Bool isServer,
|
||||||
XP_U16 nPlayersHere, XP_U16 nPlayersTotal,
|
XP_U16 nPlayersHere, XP_U16 nPlayersTotal,
|
||||||
TransportSend sendproc, IF_CH(TransportReset resetproc)
|
const TransportProcs* procs );
|
||||||
void* closure );
|
|
||||||
|
|
||||||
void comms_reset( CommsCtxt* comms, XP_Bool isServer,
|
void comms_reset( CommsCtxt* comms, XP_Bool isServer,
|
||||||
XP_U16 nPlayersHere, XP_U16 nPlayersTotal );
|
XP_U16 nPlayersHere, XP_U16 nPlayersTotal );
|
||||||
|
@ -128,9 +152,7 @@ CommsConnType comms_getConType( const CommsCtxt* comms );
|
||||||
XP_Bool comms_getIsServer( const CommsCtxt* comms );
|
XP_Bool comms_getIsServer( const CommsCtxt* comms );
|
||||||
|
|
||||||
CommsCtxt* comms_makeFromStream( MPFORMAL XWStreamCtxt* stream,
|
CommsCtxt* comms_makeFromStream( MPFORMAL XWStreamCtxt* stream,
|
||||||
XW_UtilCtxt* util, TransportSend sendproc,
|
XW_UtilCtxt* util, const TransportProcs* procs );
|
||||||
IF_CH(TransportReset resetproc)
|
|
||||||
void* closure );
|
|
||||||
void comms_start( CommsCtxt* comms );
|
void comms_start( CommsCtxt* comms );
|
||||||
void comms_writeToStream( const CommsCtxt* comms, XWStreamCtxt* stream );
|
void comms_writeToStream( const CommsCtxt* comms, XWStreamCtxt* stream );
|
||||||
|
|
||||||
|
@ -146,6 +168,7 @@ XP_Bool comms_checkComplete( const CommsAddrRec* addr );
|
||||||
# ifdef DEBUG
|
# ifdef DEBUG
|
||||||
void comms_getStats( CommsCtxt* comms, XWStreamCtxt* stream );
|
void comms_getStats( CommsCtxt* comms, XWStreamCtxt* stream );
|
||||||
const char* ConnType2Str( CommsConnType typ );
|
const char* ConnType2Str( CommsConnType typ );
|
||||||
|
const char* CommsRelayState2Str( CommsRelayState state );
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
EXTERN_C_END
|
EXTERN_C_END
|
||||||
|
|
|
@ -74,9 +74,7 @@ void
|
||||||
game_makeNewGame( MPFORMAL XWGame* game, CurGameInfo* gi,
|
game_makeNewGame( MPFORMAL XWGame* game, CurGameInfo* gi,
|
||||||
XW_UtilCtxt* util, DrawCtx* draw,
|
XW_UtilCtxt* util, DrawCtx* draw,
|
||||||
XP_U16 gameID, CommonPrefs* cp,
|
XP_U16 gameID, CommonPrefs* cp,
|
||||||
TransportSend XP_UNUSED_STANDALONE(sendproc),
|
const TransportProcs* procs )
|
||||||
IF_CH( TransportReset resetproc )
|
|
||||||
void* XP_UNUSED_STANDALONE(closure) )
|
|
||||||
{
|
{
|
||||||
XP_U16 nPlayersHere, nPlayersTotal;
|
XP_U16 nPlayersHere, nPlayersTotal;
|
||||||
|
|
||||||
|
@ -89,11 +87,10 @@ game_makeNewGame( MPFORMAL XWGame* game, CurGameInfo* gi,
|
||||||
gi->boardSize, gi->boardSize );
|
gi->boardSize, gi->boardSize );
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
if ( !!sendproc && gi->serverRole != SERVER_STANDALONE ) {
|
if ( !!procs && gi->serverRole != SERVER_STANDALONE ) {
|
||||||
game->comms = comms_make( MPPARM(mpool) util,
|
game->comms = comms_make( MPPARM(mpool) util,
|
||||||
gi->serverRole != SERVER_ISCLIENT,
|
gi->serverRole != SERVER_ISCLIENT,
|
||||||
nPlayersHere, nPlayersTotal,
|
nPlayersHere, nPlayersTotal, procs );
|
||||||
sendproc, IF_CH(resetproc) closure );
|
|
||||||
} else {
|
} else {
|
||||||
game->comms = (CommsCtxt*)NULL;
|
game->comms = (CommsCtxt*)NULL;
|
||||||
}
|
}
|
||||||
|
@ -116,9 +113,7 @@ void
|
||||||
game_reset( MPFORMAL XWGame* game, CurGameInfo* gi,
|
game_reset( MPFORMAL XWGame* game, CurGameInfo* gi,
|
||||||
XW_UtilCtxt* XP_UNUSED_STANDALONE(util),
|
XW_UtilCtxt* XP_UNUSED_STANDALONE(util),
|
||||||
XP_U16 gameID, CommonPrefs* cp,
|
XP_U16 gameID, CommonPrefs* cp,
|
||||||
TransportSend XP_UNUSED_STANDALONE(sendproc),
|
const TransportProcs* procs )
|
||||||
IF_CH(TransportReset resetproc)
|
|
||||||
void* XP_UNUSED_STANDALONE(closure) )
|
|
||||||
{
|
{
|
||||||
XP_U16 i;
|
XP_U16 i;
|
||||||
XP_U16 nPlayersHere, nPlayersTotal;
|
XP_U16 nPlayersHere, nPlayersTotal;
|
||||||
|
@ -144,8 +139,7 @@ game_reset( MPFORMAL XWGame* game, CurGameInfo* gi,
|
||||||
} else if ( gi->serverRole != SERVER_STANDALONE ) {
|
} else if ( gi->serverRole != SERVER_STANDALONE ) {
|
||||||
game->comms = comms_make( MPPARM(mpool) util,
|
game->comms = comms_make( MPPARM(mpool) util,
|
||||||
gi->serverRole != SERVER_ISCLIENT,
|
gi->serverRole != SERVER_ISCLIENT,
|
||||||
nPlayersHere, nPlayersTotal,
|
nPlayersHere, nPlayersTotal, procs );
|
||||||
sendproc, IF_CH(resetproc) closure );
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
# ifdef DEBUG
|
# ifdef DEBUG
|
||||||
|
@ -175,9 +169,7 @@ XP_Bool
|
||||||
game_makeFromStream( MPFORMAL XWStreamCtxt* stream, XWGame* game,
|
game_makeFromStream( MPFORMAL XWStreamCtxt* stream, XWGame* game,
|
||||||
CurGameInfo* gi, DictionaryCtxt* dict,
|
CurGameInfo* gi, DictionaryCtxt* dict,
|
||||||
XW_UtilCtxt* util, DrawCtx* draw, CommonPrefs* cp,
|
XW_UtilCtxt* util, DrawCtx* draw, CommonPrefs* cp,
|
||||||
TransportSend XP_UNUSED_STANDALONE(sendProc),
|
const TransportProcs* procs )
|
||||||
IF_CH(TransportReset resetProc)
|
|
||||||
void* XP_UNUSED_STANDALONE(closure) )
|
|
||||||
{
|
{
|
||||||
XP_Bool success = XP_FALSE;
|
XP_Bool success = XP_FALSE;
|
||||||
XP_U8 strVersion;
|
XP_U8 strVersion;
|
||||||
|
@ -208,8 +200,7 @@ game_makeFromStream( MPFORMAL XWStreamCtxt* stream, XWGame* game,
|
||||||
|
|
||||||
if ( hasComms ) {
|
if ( hasComms ) {
|
||||||
game->comms = comms_makeFromStream( MPPARM(mpool) stream, util,
|
game->comms = comms_makeFromStream( MPPARM(mpool) stream, util,
|
||||||
sendProc, IF_CH(resetProc)
|
procs );
|
||||||
closure );
|
|
||||||
} else {
|
} else {
|
||||||
game->comms = NULL;
|
game->comms = NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,18 +83,15 @@ typedef struct XWGame {
|
||||||
|
|
||||||
void game_makeNewGame( MPFORMAL XWGame* game, CurGameInfo* gi,
|
void game_makeNewGame( MPFORMAL XWGame* game, CurGameInfo* gi,
|
||||||
XW_UtilCtxt* util, DrawCtx* draw, XP_U16 gameID,
|
XW_UtilCtxt* util, DrawCtx* draw, XP_U16 gameID,
|
||||||
CommonPrefs* cp, TransportSend sendproc,
|
CommonPrefs* cp, const TransportProcs* procs );
|
||||||
IF_CH(TransportReset resetproc) void* closure);
|
|
||||||
void game_reset( MPFORMAL XWGame* game, CurGameInfo* gi, XW_UtilCtxt* util,
|
void game_reset( MPFORMAL XWGame* game, CurGameInfo* gi, XW_UtilCtxt* util,
|
||||||
XP_U16 gameID, CommonPrefs* cp, TransportSend sendproc,
|
XP_U16 gameID, CommonPrefs* cp, const TransportProcs* procs );
|
||||||
IF_CH(TransportReset resetproc) void* closure );
|
|
||||||
|
|
||||||
XP_Bool game_makeFromStream( MPFORMAL XWStreamCtxt* stream, XWGame* game,
|
XP_Bool game_makeFromStream( MPFORMAL XWStreamCtxt* stream, XWGame* game,
|
||||||
CurGameInfo* gi,
|
CurGameInfo* gi,
|
||||||
DictionaryCtxt* dict, XW_UtilCtxt* util,
|
DictionaryCtxt* dict, XW_UtilCtxt* util,
|
||||||
DrawCtx* draw, CommonPrefs* cp,
|
DrawCtx* draw, CommonPrefs* cp,
|
||||||
TransportSend sendProc, IF_CH(TransportReset rp)
|
const TransportProcs* procs );
|
||||||
void* closure );
|
|
||||||
|
|
||||||
void game_saveToStream( const XWGame* game, const CurGameInfo* gi,
|
void game_saveToStream( const XWGame* game, const CurGameInfo* gi,
|
||||||
XWStreamCtxt* stream );
|
XWStreamCtxt* stream );
|
||||||
|
|
|
@ -1450,6 +1450,14 @@ cursesmain( XP_Bool isServer, LaunchParams* params )
|
||||||
g_globals.draw = (struct CursesDrawCtx*)
|
g_globals.draw = (struct CursesDrawCtx*)
|
||||||
cursesDrawCtxtMake( g_globals.boardWin );
|
cursesDrawCtxtMake( g_globals.boardWin );
|
||||||
|
|
||||||
|
TransportProcs procs = {
|
||||||
|
.closure = &g_globals,
|
||||||
|
.send = LINUX_SEND,
|
||||||
|
#ifdef COMMS_HEARTBEAT
|
||||||
|
.reset = linux_reset,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
if ( !!params->fileName && file_exists( params->fileName ) ) {
|
if ( !!params->fileName && file_exists( params->fileName ) ) {
|
||||||
XWStreamCtxt* stream;
|
XWStreamCtxt* stream;
|
||||||
stream = streamFromFile( &g_globals.cGlobals, params->fileName,
|
stream = streamFromFile( &g_globals.cGlobals, params->fileName,
|
||||||
|
@ -1458,16 +1466,14 @@ cursesmain( XP_Bool isServer, LaunchParams* params )
|
||||||
(void)game_makeFromStream( MEMPOOL stream, &g_globals.cGlobals.game,
|
(void)game_makeFromStream( MEMPOOL stream, &g_globals.cGlobals.game,
|
||||||
¶ms->gi, dict, params->util,
|
¶ms->gi, dict, params->util,
|
||||||
(DrawCtx*)g_globals.draw,
|
(DrawCtx*)g_globals.draw,
|
||||||
&g_globals.cp,
|
&g_globals.cp, &procs );
|
||||||
LINUX_SEND, IF_CH(linux_reset) &g_globals );
|
|
||||||
|
|
||||||
stream_destroy( stream );
|
stream_destroy( stream );
|
||||||
} else {
|
} else {
|
||||||
gameID = (XP_U16)util_getCurSeconds( g_globals.cGlobals.params->util );
|
gameID = (XP_U16)util_getCurSeconds( g_globals.cGlobals.params->util );
|
||||||
game_makeNewGame( MEMPOOL &g_globals.cGlobals.game, ¶ms->gi,
|
game_makeNewGame( MEMPOOL &g_globals.cGlobals.game, ¶ms->gi,
|
||||||
params->util, (DrawCtx*)g_globals.draw,
|
params->util, (DrawCtx*)g_globals.draw,
|
||||||
gameID, &g_globals.cp, LINUX_SEND,
|
gameID, &g_globals.cp, &procs );
|
||||||
IF_CH(linux_reset) &g_globals );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
|
|
|
@ -291,6 +291,12 @@ key_release_event( GtkWidget* XP_UNUSED(widget), GdkEventKey* event,
|
||||||
# define MEMPOOL
|
# define MEMPOOL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static void
|
||||||
|
relay_status_gtk( void* XP_UNUSED(closure), CommsRelayState state )
|
||||||
|
{
|
||||||
|
XP_LOGF( "%s got status: %s", __func__, CommsRelayState2Str(state) );
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
createOrLoadObjects( GtkAppGlobals* globals )
|
createOrLoadObjects( GtkAppGlobals* globals )
|
||||||
{
|
{
|
||||||
|
@ -306,6 +312,17 @@ createOrLoadObjects( GtkAppGlobals* globals )
|
||||||
globals->draw = (GtkDrawCtx*)gtkDrawCtxtMake( globals->drawing_area,
|
globals->draw = (GtkDrawCtx*)gtkDrawCtxtMake( globals->drawing_area,
|
||||||
globals );
|
globals );
|
||||||
|
|
||||||
|
TransportProcs procs = {
|
||||||
|
.closure = globals,
|
||||||
|
.send = LINUX_SEND,
|
||||||
|
#ifdef COMMS_HEARTBEAT
|
||||||
|
.reset = linux_reset,
|
||||||
|
#endif
|
||||||
|
#ifdef XWFEATURE_RELAY
|
||||||
|
.rstatus = relay_status_gtk,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
if ( !!params->fileName && file_exists( params->fileName ) ) {
|
if ( !!params->fileName && file_exists( params->fileName ) ) {
|
||||||
|
|
||||||
stream = streamFromFile( &globals->cGlobals, params->fileName, globals );
|
stream = streamFromFile( &globals->cGlobals, params->fileName, globals );
|
||||||
|
@ -314,8 +331,7 @@ createOrLoadObjects( GtkAppGlobals* globals )
|
||||||
&globals->cGlobals.params->gi,
|
&globals->cGlobals.params->gi,
|
||||||
params->dict, params->util,
|
params->dict, params->util,
|
||||||
(DrawCtx*)globals->draw,
|
(DrawCtx*)globals->draw,
|
||||||
&globals->cp,
|
&globals->cp, &procs );
|
||||||
LINUX_SEND, IF_CH(linux_reset) globals );
|
|
||||||
|
|
||||||
stream_destroy( stream );
|
stream_destroy( stream );
|
||||||
}
|
}
|
||||||
|
@ -339,8 +355,7 @@ createOrLoadObjects( GtkAppGlobals* globals )
|
||||||
|
|
||||||
game_makeNewGame( MEMPOOL &globals->cGlobals.game, ¶ms->gi,
|
game_makeNewGame( MEMPOOL &globals->cGlobals.game, ¶ms->gi,
|
||||||
params->util, (DrawCtx*)globals->draw,
|
params->util, (DrawCtx*)globals->draw,
|
||||||
params->gi.gameID, &globals->cp, LINUX_SEND,
|
params->gi.gameID, &globals->cp, &procs );
|
||||||
IF_CH(linux_reset) globals );
|
|
||||||
|
|
||||||
addr.conType = params->conType;
|
addr.conType = params->conType;
|
||||||
if ( 0 ) {
|
if ( 0 ) {
|
||||||
|
@ -646,10 +661,17 @@ new_game( GtkWidget* XP_UNUSED(widget), GtkAppGlobals* globals )
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
XP_Bool isClient = gi->serverRole == SERVER_ISCLIENT;
|
XP_Bool isClient = gi->serverRole == SERVER_ISCLIENT;
|
||||||
#endif
|
#endif
|
||||||
|
TransportProcs procs = {
|
||||||
|
.closure = globals,
|
||||||
|
.send = LINUX_SEND,
|
||||||
|
#ifdef COMMS_HEARTBEAT
|
||||||
|
.reset = linux_reset,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
game_reset( MEMPOOL &globals->cGlobals.game, gi,
|
game_reset( MEMPOOL &globals->cGlobals.game, gi,
|
||||||
globals->cGlobals.params->util,
|
globals->cGlobals.params->util,
|
||||||
0, &globals->cp, LINUX_SEND,
|
0, &globals->cp, &procs );
|
||||||
IF_CH(linux_reset) globals );
|
|
||||||
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
if ( !!globals->cGlobals.game.comms ) {
|
if ( !!globals->cGlobals.game.comms ) {
|
||||||
|
|
|
@ -579,6 +579,17 @@ reportMissingDict( PalmAppGlobals* globals, XP_UCHAR* name )
|
||||||
}
|
}
|
||||||
} /* reportMissingDict */
|
} /* reportMissingDict */
|
||||||
|
|
||||||
|
static void
|
||||||
|
palmInitTProcs( PalmAppGlobals* globals, TransportProcs* procs )
|
||||||
|
{
|
||||||
|
XP_MEMSET( procs, 0, sizeof(*procs) );
|
||||||
|
procs->send = palm_send;
|
||||||
|
#ifdef COMMS_HEARTBEAT
|
||||||
|
procs->reset = palm_reset;
|
||||||
|
#endif
|
||||||
|
procs->closure = globals;
|
||||||
|
}
|
||||||
|
|
||||||
static XP_Bool
|
static XP_Bool
|
||||||
loadCurrentGame( PalmAppGlobals* globals, XP_U16 gIndex,
|
loadCurrentGame( PalmAppGlobals* globals, XP_U16 gIndex,
|
||||||
XWGame* game, CurGameInfo* ginfo )
|
XWGame* game, CurGameInfo* ginfo )
|
||||||
|
@ -617,10 +628,12 @@ loadCurrentGame( PalmAppGlobals* globals, XP_U16 gIndex,
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( success ) {
|
if ( success ) {
|
||||||
|
TransportProcs procs;
|
||||||
|
palmInitTProcs( globals, &procs );
|
||||||
success = game_makeFromStream( MEMPOOL recStream, game, ginfo,
|
success = game_makeFromStream( MEMPOOL recStream, game, ginfo,
|
||||||
dict, &globals->util,
|
dict, &globals->util,
|
||||||
globals->draw, &globals->gState.cp,
|
globals->draw, &globals->gState.cp,
|
||||||
palm_send, IF_CH(palm_reset) globals );
|
&procs );
|
||||||
}
|
}
|
||||||
|
|
||||||
stream_destroy( recStream );
|
stream_destroy( recStream );
|
||||||
|
@ -1201,6 +1214,7 @@ startApplication( PalmAppGlobals** globalsP )
|
||||||
postEmptyEvent( loadGameEvent );
|
postEmptyEvent( loadGameEvent );
|
||||||
globals->isFirstLaunch = false;
|
globals->isFirstLaunch = false;
|
||||||
} else {
|
} else {
|
||||||
|
TransportProcs procs;
|
||||||
DictListEntry* dlep;
|
DictListEntry* dlep;
|
||||||
|
|
||||||
/* if we're here because dict missing, don't re-init all prefs! */
|
/* if we're here because dict missing, don't re-init all prefs! */
|
||||||
|
@ -1218,10 +1232,11 @@ startApplication( PalmAppGlobals** globalsP )
|
||||||
globals->gameInfo.dictName = copyString( globals->mpool,
|
globals->gameInfo.dictName = copyString( globals->mpool,
|
||||||
dlep->baseName );
|
dlep->baseName );
|
||||||
|
|
||||||
|
palmInitTProcs( globals, &procs );
|
||||||
game_makeNewGame( MEMPOOL &globals->game, &globals->gameInfo,
|
game_makeNewGame( MEMPOOL &globals->game, &globals->gameInfo,
|
||||||
&globals->util, globals->draw, 0,
|
&globals->util, globals->draw, 0,
|
||||||
&globals->gState.cp,
|
&globals->gState.cp, &procs );
|
||||||
palm_send, IF_CH(palm_reset) globals );
|
|
||||||
FrmPopupForm( XW_NEWGAMES_FORM );
|
FrmPopupForm( XW_NEWGAMES_FORM );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2016,9 +2031,11 @@ initAndStartBoard( PalmAppGlobals* globals, XP_Bool newGame )
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( newGame ) {
|
if ( newGame ) {
|
||||||
|
TransportProcs procs;
|
||||||
|
palmInitTProcs( globals, &procs );
|
||||||
game_reset( MEMPOOL &globals->game, &globals->gameInfo,
|
game_reset( MEMPOOL &globals->game, &globals->gameInfo,
|
||||||
&globals->util, 0, &globals->gState.cp,
|
&globals->util, 0, &globals->gState.cp, &procs );
|
||||||
palm_send, IF_CH(palm_reset) globals );
|
|
||||||
#ifndef XWFEATURE_STANDALONE_ONLY
|
#ifndef XWFEATURE_STANDALONE_ONLY
|
||||||
if ( !!globals->game.comms ) {
|
if ( !!globals->game.comms ) {
|
||||||
comms_setAddr( globals->game.comms,
|
comms_setAddr( globals->game.comms,
|
||||||
|
|
Loading…
Reference in a new issue