mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
ignore timers if state changes after they're set; take down links when resetting
This commit is contained in:
parent
a6e3df1ad4
commit
81598477a1
1 changed files with 19 additions and 6 deletions
|
@ -208,6 +208,7 @@ palm_bt_init( PalmAppGlobals* globals, XP_Bool* userCancelled )
|
||||||
btStuff = pbt_checkInit( globals, userCancelled );
|
btStuff = pbt_checkInit( globals, userCancelled );
|
||||||
} else {
|
} else {
|
||||||
pbt_reset_buffers( btStuff );
|
pbt_reset_buffers( btStuff );
|
||||||
|
pbt_killLinks( btStuff );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Don't try starting master or slave: we don't know which we are yet.
|
/* Don't try starting master or slave: we don't know which we are yet.
|
||||||
|
@ -699,6 +700,7 @@ pbt_do_work( PalmBTStuff* btStuff, BtCbEvtProc proc )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PBT_ACT_CONNECT_ACL:
|
case PBT_ACT_CONNECT_ACL:
|
||||||
|
XP_ASSERT( PBT_SLAVE == btStuff->picoRole );
|
||||||
if ( GET_STATE(btStuff) == PBTST_NONE ) {
|
if ( GET_STATE(btStuff) == PBTST_NONE ) {
|
||||||
UInt8 name[PALM_BT_NAME_LEN];
|
UInt8 name[PALM_BT_NAME_LEN];
|
||||||
(void)pbt_nameForAddr( btStuff, &btStuff->otherAddr,
|
(void)pbt_nameForAddr( btStuff, &btStuff->otherAddr,
|
||||||
|
@ -961,10 +963,16 @@ static void
|
||||||
btTimerProc( void* closure, XWTimerReason why )
|
btTimerProc( void* closure, XWTimerReason why )
|
||||||
{
|
{
|
||||||
PalmBTStuff* btStuff;
|
PalmBTStuff* btStuff;
|
||||||
btStuff = (PalmBTStuff*)closure;
|
|
||||||
XP_ASSERT( why == TIMER_ACL_BACKOFF );
|
XP_ASSERT( why == TIMER_ACL_BACKOFF );
|
||||||
|
btStuff = (PalmBTStuff*)closure;
|
||||||
|
if ( GET_STATE(btStuff) != PBTST_NONE ) {
|
||||||
|
XP_LOGF( "%s ignoring; have changed states", __func__ );
|
||||||
|
} else if ( PBT_SLAVE != btStuff->picoRole ) {
|
||||||
|
XP_LOGF( "%s ignoring; have changed roles", __func__ );
|
||||||
|
} else {
|
||||||
pbt_postpone( btStuff, PBT_ACT_CONNECT_ACL );
|
pbt_postpone( btStuff, PBT_ACT_CONNECT_ACL );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
waitACL( PalmBTStuff* btStuff )
|
waitACL( PalmBTStuff* btStuff )
|
||||||
|
@ -1202,10 +1210,13 @@ socketCallback( BtLibSocketEventType* sEvent, UInt32 refCon )
|
||||||
|
|
||||||
switch( event ) {
|
switch( event ) {
|
||||||
case btLibSocketEventConnectRequest:
|
case btLibSocketEventConnectRequest:
|
||||||
XP_ASSERT( btStuff->picoRole == PBT_MASTER );
|
if ( btStuff->picoRole == PBT_MASTER ) {
|
||||||
/* sends btLibSocketEventConnectedInbound */
|
/* sends btLibSocketEventConnectedInbound */
|
||||||
CALL_ERR( err, BtLibSocketRespondToConnection, btStuff->btLibRefNum,
|
CALL_ERR( err, BtLibSocketRespondToConnection, btStuff->btLibRefNum,
|
||||||
sEvent->socket, true );
|
sEvent->socket, true );
|
||||||
|
} else {
|
||||||
|
XP_LOGF( "ignoring b/c not master" );
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case btLibSocketEventConnectedInbound:
|
case btLibSocketEventConnectedInbound:
|
||||||
XP_ASSERT( btStuff->picoRole == PBT_MASTER );
|
XP_ASSERT( btStuff->picoRole == PBT_MASTER );
|
||||||
|
@ -1371,8 +1382,10 @@ libMgmtCallback( BtLibManagementEventType* mEvent, UInt32 refCon )
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
XP_LOGF( "%s: %s not handled", __func__, mgmtEvtToStr(event));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
LOG_RETURN_VOID();
|
||||||
} /* libMgmtCallback */
|
} /* libMgmtCallback */
|
||||||
|
|
||||||
/***********************************************************************
|
/***********************************************************************
|
||||||
|
|
Loading…
Reference in a new issue