mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-20 22:26:54 +01:00
Clean up and fix timer code.
This commit is contained in:
parent
0b4214c82b
commit
1fd6afcaf9
2 changed files with 53 additions and 53 deletions
|
@ -67,7 +67,6 @@
|
||||||
#include "SonyChars.h"
|
#include "SonyChars.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define TIMER_OFF 0L
|
|
||||||
#define PALM_TIMER_DELAY 25
|
#define PALM_TIMER_DELAY 25
|
||||||
|
|
||||||
#ifdef IR_SUPPORT
|
#ifdef IR_SUPPORT
|
||||||
|
@ -116,6 +115,8 @@ static Boolean mainViewHandleEvent( EventPtr event );
|
||||||
|
|
||||||
static UInt16 romVersion( void );
|
static UInt16 romVersion( void );
|
||||||
static Boolean handleHintRequest( PalmAppGlobals* globals );
|
static Boolean handleHintRequest( PalmAppGlobals* globals );
|
||||||
|
static XP_Bool timeForTimer( PalmAppGlobals* globals, XWTimerReason* why,
|
||||||
|
XP_U32* when );
|
||||||
static XP_S16 palm_send( XP_U8* buf, XP_U16 len, const CommsAddrRec* addr,
|
static XP_S16 palm_send( XP_U8* buf, XP_U16 len, const CommsAddrRec* addr,
|
||||||
void* closure );
|
void* closure );
|
||||||
static void palm_send_on_close( XWStreamCtxt* stream, void* closure );
|
static void palm_send_on_close( XWStreamCtxt* stream, void* closure );
|
||||||
|
@ -1373,7 +1374,8 @@ static Int32
|
||||||
figureWaitTicks( PalmAppGlobals* globals )
|
figureWaitTicks( PalmAppGlobals* globals )
|
||||||
{
|
{
|
||||||
Int32 result = evtWaitForever;
|
Int32 result = evtWaitForever;
|
||||||
XP_U32 fireTime;
|
XP_U32 when;
|
||||||
|
XWTimerReason why;
|
||||||
|
|
||||||
if ( 0 ) {
|
if ( 0 ) {
|
||||||
#ifdef BEYOND_IR
|
#ifdef BEYOND_IR
|
||||||
|
@ -1383,20 +1385,8 @@ figureWaitTicks( PalmAppGlobals* globals )
|
||||||
#endif
|
#endif
|
||||||
} else if ( globals->timeRequested || globals->hintPending ) {
|
} else if ( globals->timeRequested || globals->hintPending ) {
|
||||||
result = 0;
|
result = 0;
|
||||||
#ifdef IR_SUPPORT
|
} else if ( *timeForTimer( globals, &why, &when ) ) {
|
||||||
# ifndef IR_EXCHMGR
|
result = when - TimGetTicks();
|
||||||
} else if ( ir_work_exists(globals) ) {
|
|
||||||
/* XP_DEBUGF( "message pending" ); */
|
|
||||||
result = 0;
|
|
||||||
} else if ( globals->ir_state == IR_STATE_MESSAGE_RECD ) {
|
|
||||||
/* XP_DEBUGF( "message recd" ); */
|
|
||||||
result = 0;
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
} else if ( (fireTime = globals->penTimerFireAt) != TIMER_OFF
|
|
||||||
|| (fireTime = globals->timerTimerFireAt ) != TIMER_OFF
|
|
||||||
|| (fireTime = globals->heartTimerFireAt ) != TIMER_OFF ) {
|
|
||||||
result = fireTime - TimGetTicks();
|
|
||||||
if ( result < 0 ) {
|
if ( result < 0 ) {
|
||||||
result = 0;
|
result = 0;
|
||||||
}
|
}
|
||||||
|
@ -1558,36 +1548,51 @@ destroy_on_close( XWStreamCtxt* p_stream )
|
||||||
static void
|
static void
|
||||||
palmFireTimer( PalmAppGlobals* globals, XWTimerReason why )
|
palmFireTimer( PalmAppGlobals* globals, XWTimerReason why )
|
||||||
{
|
{
|
||||||
TimerProc proc = globals->timerProcs[why-1];
|
TimerProc proc = globals->timerProcs[why];
|
||||||
void* closure = globals->timerClosures[why-1];
|
void* closure = globals->timerClosures[why];
|
||||||
|
XP_ASSERT( TimGetTicks() >= globals->timerFireAt[why] );
|
||||||
|
globals->timerProcs[why] = NULL;
|
||||||
(*proc)( closure, why );
|
(*proc)( closure, why );
|
||||||
} /* fireTimer */
|
} /* fireTimer */
|
||||||
|
|
||||||
|
static XP_Bool
|
||||||
|
timeForTimer( PalmAppGlobals* globals, XWTimerReason* why, XP_U32* when )
|
||||||
|
{
|
||||||
|
XP_U16 i;
|
||||||
|
XWTimerReason nextWhy = 0;
|
||||||
|
XP_U32 nextWhen = 0xFFFFFFFF;
|
||||||
|
XP_Bool found;
|
||||||
|
|
||||||
|
for ( i = 1; i < TIMER_NUM_PLUS_ONE; ++i ) {
|
||||||
|
if ( (globals->timerProcs[i] != NULL) &&
|
||||||
|
(globals->timerFireAt[i] < nextWhen) ) {
|
||||||
|
nextWhy = i;
|
||||||
|
nextWhen = globals->timerFireAt[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
found = nextWhy != 0;
|
||||||
|
if ( found ) {
|
||||||
|
*why = nextWhy;
|
||||||
|
*when = nextWhen;
|
||||||
|
}
|
||||||
|
return found;
|
||||||
|
} /* timeForTimer */
|
||||||
|
|
||||||
static Boolean
|
static Boolean
|
||||||
handleNilEvent( PalmAppGlobals* globals, EventPtr event )
|
handleNilEvent( PalmAppGlobals* globals, EventPtr event )
|
||||||
{
|
{
|
||||||
Boolean handled = true;
|
Boolean handled = true;
|
||||||
|
XP_U32 when;
|
||||||
|
XWTimerReason why;
|
||||||
|
|
||||||
if ( false ) {
|
if ( globals->menuIsDown ) {
|
||||||
} else if ( globals->menuIsDown ) {
|
|
||||||
/* do nothing */
|
/* do nothing */
|
||||||
#ifdef IR_SUPPORT
|
|
||||||
# ifndef IR_EXCHMGR
|
|
||||||
} else if ( ir_work_exists(globals) ) {
|
|
||||||
handled = ir_do_work( globals );
|
|
||||||
ir_show_status( globals );
|
|
||||||
/* } else if ( globals->ir_state == IR_STATE_MESSAGE_RECD ) { */
|
|
||||||
/* handled = do_ir_work( globals ); */
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
} else if ( globals->hintPending ) {
|
} else if ( globals->hintPending ) {
|
||||||
handled = handleHintRequest( globals );
|
handled = handleHintRequest( globals );
|
||||||
|
} else if ( timeForTimer( globals, &why, &when )
|
||||||
} else if ( globals->penTimerFireAt != TIMER_OFF &&
|
&& (when <= TimGetTicks()) ) {
|
||||||
globals->penTimerFireAt <= TimGetTicks() ) {
|
palmFireTimer( globals, why );
|
||||||
globals->penTimerFireAt = TIMER_OFF;
|
|
||||||
palmFireTimer( globals, TIMER_PENDOWN );
|
|
||||||
|
|
||||||
} else if ( globals->timeRequested ) {
|
} else if ( globals->timeRequested ) {
|
||||||
globals->timeRequested = false;
|
globals->timeRequested = false;
|
||||||
if ( globals->msgReceivedDraw ) {
|
if ( globals->msgReceivedDraw ) {
|
||||||
|
@ -1596,15 +1601,6 @@ handleNilEvent( PalmAppGlobals* globals, EventPtr event )
|
||||||
globals->msgReceivedDraw = XP_FALSE;
|
globals->msgReceivedDraw = XP_FALSE;
|
||||||
}
|
}
|
||||||
handled = server_do( globals->game.server );
|
handled = server_do( globals->game.server );
|
||||||
|
|
||||||
} else if ( globals->timerTimerFireAt != TIMER_OFF &&
|
|
||||||
globals->timerTimerFireAt <= TimGetTicks() ) {
|
|
||||||
globals->timerTimerFireAt = TIMER_OFF;
|
|
||||||
palmFireTimer( globals, TIMER_TIMERTICK );
|
|
||||||
} else if ( globals->heartTimerFireAt != TIMER_OFF &&
|
|
||||||
globals->heartTimerFireAt <= TimGetTicks() ) {
|
|
||||||
globals->heartTimerFireAt = TIMER_OFF;
|
|
||||||
palmFireTimer( globals, TIMER_TIMERTICK );
|
|
||||||
} else {
|
} else {
|
||||||
handled = false;
|
handled = false;
|
||||||
}
|
}
|
||||||
|
@ -3391,20 +3387,25 @@ palm_util_engineProgressCallback( XW_UtilCtxt* uc )
|
||||||
} /* palm_util_engineProgressCallback */
|
} /* palm_util_engineProgressCallback */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
palm_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 when,
|
palm_util_setTimer( XW_UtilCtxt* uc, XWTimerReason why, XP_U16 secsFromNow,
|
||||||
TimerProc proc, void* closure )
|
TimerProc proc, void* closure )
|
||||||
{
|
{
|
||||||
PalmAppGlobals* globals = (PalmAppGlobals*)uc->closure;
|
PalmAppGlobals* globals = (PalmAppGlobals*)uc->closure;
|
||||||
globals->timerProcs[why-1] = proc;
|
XP_U32 now = TimGetTicks();
|
||||||
globals->timerClosures[why-1] = closure;
|
|
||||||
|
|
||||||
if ( why == TIMER_PENDOWN ) {
|
if ( why == TIMER_PENDOWN ) {
|
||||||
globals->penTimerFireAt = TimGetTicks() + PALM_TIMER_DELAY;
|
now += PALM_TIMER_DELAY;
|
||||||
} else if ( why == TIMER_TIMERTICK ) {
|
} else if ( why == TIMER_TIMERTICK ) {
|
||||||
globals->timerTimerFireAt = TimGetTicks() + SysTicksPerSecond();
|
now += SysTicksPerSecond();
|
||||||
|
} else if ( why == TIMER_HEARTBEAT ) {
|
||||||
|
now += (secsFromNow * SysTicksPerSecond());
|
||||||
} else {
|
} else {
|
||||||
XP_ASSERT( 0 );
|
XP_ASSERT( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
globals->timerProcs[why] = proc;
|
||||||
|
globals->timerClosures[why] = closure;
|
||||||
|
globals->timerFireAt[why] = now;
|
||||||
} /* palm_util_setTimer */
|
} /* palm_util_setTimer */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -275,8 +275,6 @@ struct PalmAppGlobals {
|
||||||
XP_Bool runningOnPOSE; /* Needed for NetLibSelect */
|
XP_Bool runningOnPOSE; /* Needed for NetLibSelect */
|
||||||
|
|
||||||
GraphicsAbility able;
|
GraphicsAbility able;
|
||||||
XP_U32 penTimerFireAt;
|
|
||||||
XP_U32 timerTimerFireAt;
|
|
||||||
XP_U16 prevScroll; /* for scrolling in 'ask' dialog */
|
XP_U16 prevScroll; /* for scrolling in 'ask' dialog */
|
||||||
UInt16 romVersion;
|
UInt16 romVersion;
|
||||||
|
|
||||||
|
@ -308,8 +306,9 @@ struct PalmAppGlobals {
|
||||||
|
|
||||||
struct ConnsDlgState* connState;
|
struct ConnsDlgState* connState;
|
||||||
|
|
||||||
TimerProc timerProcs[TIMER_NUM_PLUS_ONE - 1];
|
TimerProc timerProcs[TIMER_NUM_PLUS_ONE];
|
||||||
void* timerClosures[TIMER_NUM_PLUS_ONE - 1];
|
void* timerClosures[TIMER_NUM_PLUS_ONE];
|
||||||
|
XP_U32 timerFireAt[TIMER_NUM_PLUS_ONE];
|
||||||
|
|
||||||
#ifdef BEYOND_IR
|
#ifdef BEYOND_IR
|
||||||
NetLibStuff nlStuff;
|
NetLibStuff nlStuff;
|
||||||
|
|
Loading…
Reference in a new issue