mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-18 22:26:30 +01:00
Closing BT lib from datahandler (since don't want to close on game
close in case next game will use); erase BT status icon when not BT game; plug leak of dict name.
This commit is contained in:
parent
0b9f77d4c0
commit
b965654db3
2 changed files with 75 additions and 56 deletions
128
palm/palmmain.c
128
palm/palmmain.c
|
@ -559,13 +559,13 @@ reportMissingDict( PalmAppGlobals* globals, XP_UCHAR* name )
|
|||
}
|
||||
} /* reportMissingDict */
|
||||
|
||||
static Boolean
|
||||
static XP_Bool
|
||||
loadCurrentGame( PalmAppGlobals* globals, XP_U16 gIndex,
|
||||
XWGame* game, CurGameInfo* ginfo )
|
||||
{
|
||||
XP_Bool hasDict;
|
||||
XWStreamCtxt* recStream;
|
||||
Boolean success = false;
|
||||
XP_Bool success = XP_FALSE;
|
||||
DictionaryCtxt* dict;
|
||||
|
||||
recStream = gameRecordToStream( globals, gIndex );
|
||||
|
@ -581,19 +581,19 @@ loadCurrentGame( PalmAppGlobals* globals, XP_U16 gIndex,
|
|||
|
||||
hasDict = stream_getU8( recStream );
|
||||
if ( hasDict ) {
|
||||
XP_UCHAR* name = stringFromStream( globals->mpool, recStream );
|
||||
XP_UCHAR name[33];
|
||||
stringFromStreamHere( recStream, name, sizeof(name) );
|
||||
dict = palm_dictionary_make( MPPARM(globals->mpool) globals,
|
||||
name, globals->dictList );
|
||||
success = dict != NULL;
|
||||
|
||||
if ( !success ) {
|
||||
reportMissingDict( globals, name );
|
||||
XP_FREE( globals->mpool, name );
|
||||
beep();
|
||||
}
|
||||
} else {
|
||||
dict = NULL;
|
||||
success = true;
|
||||
success = XP_TRUE;
|
||||
}
|
||||
|
||||
if ( success ) {
|
||||
|
@ -1567,38 +1567,41 @@ timeForTimer( PalmAppGlobals* globals, XWTimerReason* why, XP_U32* when )
|
|||
|
||||
#ifdef XWFEATURE_BLUETOOTH
|
||||
static void
|
||||
showBTState( PalmAppGlobals* globals )
|
||||
showConnState( PalmAppGlobals* globals )
|
||||
{
|
||||
CommsCtxt* comms = globals->game.comms;
|
||||
if ( (comms != NULL)
|
||||
&& (COMMS_CONN_BT == comms_getConType( globals->game.comms )) ) {
|
||||
Int16 resID = 0;
|
||||
|
||||
switch( globals->btUIState ) {
|
||||
case BTUI_NONE:
|
||||
resID = BTSTATUS_NONE_RES_ID; break;
|
||||
case BTUI_LISTENING:
|
||||
resID = BTSTATUS_LISTENING_RES_ID; break;
|
||||
case BTUI_CONNECTING:
|
||||
resID = BTSTATUS_SEEKING_RES_ID; break;
|
||||
case BTUI_CONNECTED:
|
||||
case BTUI_SERVING:
|
||||
resID = BTSTATUS_CONNECTED_RES_ID; break;
|
||||
}
|
||||
|
||||
if ( globals->lastBTStatusRes != resID ) {
|
||||
RectangleType bounds;
|
||||
getObjectBounds( XW_BTSTATUS_GADGET_ID, &bounds );
|
||||
if ( resID != 0 ) {
|
||||
draw_drawBitmapAt( globals->draw, resID,
|
||||
bounds.topLeft.x, bounds.topLeft.y );
|
||||
} else {
|
||||
WinEraseRectangle( &bounds, 0 );
|
||||
Int16 resID = 0;
|
||||
if ( !!comms ) {
|
||||
if ( (COMMS_CONN_BT == comms_getConType( comms )) ) {
|
||||
switch( globals->btUIState ) {
|
||||
case BTUI_NONE:
|
||||
resID = BTSTATUS_NONE_RES_ID; break;
|
||||
case BTUI_LISTENING:
|
||||
resID = BTSTATUS_LISTENING_RES_ID; break;
|
||||
case BTUI_CONNECTING:
|
||||
resID = BTSTATUS_SEEKING_RES_ID; break;
|
||||
case BTUI_CONNECTED:
|
||||
case BTUI_SERVING:
|
||||
resID = BTSTATUS_CONNECTED_RES_ID; break;
|
||||
}
|
||||
globals->lastBTStatusRes = resID;
|
||||
}
|
||||
} /* else might want IP conn status too.... */
|
||||
}
|
||||
} /* showBTState */
|
||||
if ( globals->lastBTStatusRes != resID ) {
|
||||
RectangleType bounds;
|
||||
getObjectBounds( XW_BTSTATUS_GADGET_ID, &bounds );
|
||||
if ( resID != 0 ) {
|
||||
draw_drawBitmapAt( globals->draw, resID,
|
||||
bounds.topLeft.x, bounds.topLeft.y );
|
||||
} else {
|
||||
if ( globals->useHiRes ) {
|
||||
bounds.extent.x = (1 + bounds.extent.x) >> 1;
|
||||
bounds.extent.y = (1 + bounds.extent.y) >> 1;
|
||||
}
|
||||
WinEraseRectangle( &bounds, 0 );
|
||||
}
|
||||
globals->lastBTStatusRes = resID;
|
||||
}
|
||||
} /* showConnState */
|
||||
#endif
|
||||
|
||||
static Boolean
|
||||
|
@ -1617,7 +1620,7 @@ handleNilEvent( PalmAppGlobals* globals )
|
|||
palmFireTimer( globals, why );
|
||||
#ifdef XWFEATURE_BLUETOOTH
|
||||
} else if ( palm_bt_doWork( globals, &globals->btUIState ) ) {
|
||||
showBTState( globals );
|
||||
showConnState( globals );
|
||||
#endif
|
||||
} else if ( globals->timeRequested ) {
|
||||
globals->timeRequested = false;
|
||||
|
@ -1631,10 +1634,6 @@ handleNilEvent( PalmAppGlobals* globals )
|
|||
handled = false;
|
||||
}
|
||||
|
||||
#ifdef XWFEATURE_BLUETOOTH /* don't check this in */
|
||||
showBTState( globals );
|
||||
#endif
|
||||
|
||||
return handled;
|
||||
} /* handleNilEvent */
|
||||
|
||||
|
@ -1945,8 +1944,7 @@ initAndStartBoard( PalmAppGlobals* globals, XP_Bool newGame )
|
|||
if ( !dict ) {
|
||||
XP_ASSERT( !!newDictName );
|
||||
dict = palm_dictionary_make( MPPARM(globals->mpool) globals,
|
||||
copyString( globals->mpool, newDictName ),
|
||||
globals->dictList );
|
||||
newDictName, globals->dictList );
|
||||
XP_ASSERT( !!dict );
|
||||
model_setDictionary( globals->game.model, dict );
|
||||
}
|
||||
|
@ -1971,7 +1969,6 @@ initAndStartBoard( PalmAppGlobals* globals, XP_Bool newGame )
|
|||
(void)positionBoard( globals );
|
||||
|
||||
#ifdef XWFEATURE_IR
|
||||
|
||||
if ( newGame && globals->gameInfo.serverRole == SERVER_ISCLIENT ) {
|
||||
XWStreamCtxt* stream;
|
||||
XP_ASSERT( !!globals->game.comms );
|
||||
|
@ -1991,6 +1988,8 @@ initAndStartBoard( PalmAppGlobals* globals, XP_Bool newGame )
|
|||
board_invalAll( globals->game.board );
|
||||
board_draw( globals->game.board );
|
||||
|
||||
showConnState( globals );
|
||||
|
||||
globals->isNewGame = false;
|
||||
} /* initAndStartBoard */
|
||||
|
||||
|
@ -2114,16 +2113,15 @@ tryLoadSavedGame( PalmAppGlobals* globals, XP_U16 newIndex )
|
|||
XP_MEMSET( &tmpGInfo, 0, sizeof(tmpGInfo) );
|
||||
|
||||
loaded = loadCurrentGame( globals, newIndex, &tmpGame, &tmpGInfo );
|
||||
|
||||
/* Nuke the one we don't want */
|
||||
game_dispose( loaded? &globals->game : &tmpGame );
|
||||
gi_disposePlayerInfo( MEMPOOL (loaded? &globals->gameInfo : &tmpGInfo) );
|
||||
|
||||
if ( loaded ) {
|
||||
game_dispose( &globals->game );
|
||||
gi_disposePlayerInfo( MEMPOOL &globals->gameInfo );
|
||||
globals->game = tmpGame;
|
||||
/* we leaking dictName here? PENDING(ehouse) */
|
||||
XP_MEMCPY( &globals->game, &tmpGame, sizeof(globals->game) );
|
||||
XP_MEMCPY( &globals->gameInfo, &tmpGInfo, sizeof(globals->gameInfo) );
|
||||
globals->gState.curGameIndex = newIndex;
|
||||
} else {
|
||||
game_dispose( &tmpGame );
|
||||
gi_disposePlayerInfo( MEMPOOL &tmpGInfo );
|
||||
}
|
||||
|
||||
return loaded;
|
||||
|
@ -2511,6 +2509,12 @@ mainViewHandleEvent( EventPtr event )
|
|||
XP_ASSERT( !!globals->game.board );
|
||||
break;
|
||||
|
||||
#ifdef XWFEATURE_BLUETOOTH
|
||||
case closeBtLibEvent:
|
||||
palm_bt_close( globals );
|
||||
break;
|
||||
#endif
|
||||
|
||||
#ifdef FEATURE_SILK
|
||||
case doResizeWinEvent:
|
||||
getSizes( globals );
|
||||
|
@ -3832,8 +3836,10 @@ palm_send( const XP_U8* buf, XP_U16 len,
|
|||
const CommsAddrRec* addr, void* closure )
|
||||
{
|
||||
PalmAppGlobals* globals = (PalmAppGlobals*)closure;
|
||||
|
||||
XP_S16 result = 0;
|
||||
|
||||
XP_ASSERT( !!globals->game.comms );
|
||||
|
||||
switch( comms_getConType( globals->game.comms ) ) {
|
||||
#ifdef XWFEATURE_IR
|
||||
case COMMS_CONN_IR:
|
||||
|
@ -3924,12 +3930,22 @@ static void
|
|||
btDataHandler( PalmAppGlobals* globals, const CommsAddrRec* fromAddr,
|
||||
const XP_U8* data, XP_U16 len )
|
||||
{
|
||||
XWStreamCtxt* instream;
|
||||
LOG_FUNC();
|
||||
instream = makeSimpleStream( globals, NULL );
|
||||
stream_putBytes( instream, data, len );
|
||||
checkAndDeliver( globals, fromAddr, instream );
|
||||
LOG_RETURN_VOID();
|
||||
if ( COMMS_CONN_BT == comms_getConType( globals->game.comms ) ) {
|
||||
XWStreamCtxt* instream;
|
||||
instream = makeSimpleStream( globals, NULL );
|
||||
stream_putBytes( instream, data, len );
|
||||
checkAndDeliver( globals, fromAddr, instream );
|
||||
} else {
|
||||
/* If we're no longer using BT (meaning somebody loaded a new game
|
||||
that doesn't use it), close it down. We don't want to do it as
|
||||
part of unloading the old game since it's expensive to stop/start
|
||||
BT and the new game will probably use the same connection. But if
|
||||
we get here, a non-bt game's been loaded and we should shut
|
||||
down.*/
|
||||
EventType eventToPost;
|
||||
eventToPost.eType = closeBtLibEvent;
|
||||
EvtAddEventToQueue( &eventToPost );
|
||||
}
|
||||
} /* btDataHandler */
|
||||
|
||||
static void
|
||||
|
@ -3953,7 +3969,7 @@ palm_util_addrChange( XW_UtilCtxt* uc, const CommsAddrRec* oldAddr,
|
|||
if ( !isBT ) {
|
||||
XP_ASSERT( !!globals->mainForm );
|
||||
palm_bt_close( globals );
|
||||
showBTState( globals );
|
||||
showConnState( globals );
|
||||
}
|
||||
# endif
|
||||
|
||||
|
|
|
@ -354,6 +354,9 @@ enum { dictSelectedEvent = firstUserEvent /* 0x6000 */
|
|||
#if defined XWFEATURE_BLUETOOTH || defined XWFEATURE_RELAY
|
||||
,connsSettingChgEvent
|
||||
#endif
|
||||
#if defined XWFEATURE_BLUETOOTH
|
||||
,closeBtLibEvent
|
||||
#endif
|
||||
#ifdef FEATURE_SILK
|
||||
,doResizeWinEvent
|
||||
#endif
|
||||
|
|
Loading…
Reference in a new issue