tweak CIdle timer use to handle incoming packets so these don't have

to be handled from within socket handler's RunL.  Other cleanup around
relay use, name changes, etc.
This commit is contained in:
ehouse 2005-03-19 22:27:59 +00:00
parent 345d82765c
commit da224ee355

View file

@ -50,8 +50,6 @@
#include "LocalizedStrIncludes.h" #include "LocalizedStrIncludes.h"
#define LISTEN_PORT 10998
// Standard construction sequence // Standard construction sequence
CXWordsAppView* CXWordsAppView::NewL(const TRect& aRect) CXWordsAppView* CXWordsAppView::NewL(const TRect& aRect)
{ {
@ -82,7 +80,9 @@ CXWordsAppView::CXWordsAppView()
XP_MEMSET( &iGame, 0, sizeof(iGame) ); XP_MEMSET( &iGame, 0, sizeof(iGame) );
iCurGameName.Copy( _L("") ); iCurGameName.Copy( _L("") );
iListenPort = LISTEN_PORT;
/* CBase derivitaves are zero'd out, they say */
XP_ASSERT( iTimerReasons[0] == 0 && iTimerReasons[1] == 0 );
} }
CXWordsAppView::~CXWordsAppView() CXWordsAppView::~CXWordsAppView()
@ -387,12 +387,7 @@ sym_util_setTimer( XW_UtilCtxt* /*uc*/, XWTimerReason /*why*/ )
CXWordsAppView::sym_util_requestTime( XW_UtilCtxt* uc ) CXWordsAppView::sym_util_requestTime( XW_UtilCtxt* uc )
{ {
CXWordsAppView* self = (CXWordsAppView*)uc->closure; CXWordsAppView* self = (CXWordsAppView*)uc->closure;
self->StartIdleTimer( EUtilRequest );
// Only start it if it's not already running!!
if ( ++self->iTimerRunCount == 1 ) {
self->iRequestTimer->Start( TCallBack( CXWordsAppView::TimerCallback,
(TAny*)self ) );
}
} }
/* static */ XP_U32 /* static */ XP_U32
@ -554,7 +549,6 @@ CXWordsAppView::SetUpUtil()
vtable->m_util_getUserString = sym_util_getUserString; vtable->m_util_getUserString = sym_util_getUserString;
vtable->m_util_warnIllegalWord = sym_util_warnIllegalWord; vtable->m_util_warnIllegalWord = sym_util_warnIllegalWord;
#ifdef BEYOND_IR #ifdef BEYOND_IR
vtable->m_util_listenPortChange = sym_util_listenPortChange;
vtable->m_util_addrChange = sym_util_addrChange; vtable->m_util_addrChange = sym_util_addrChange;
#endif #endif
#ifdef XWFEATURE_SEARCHLIMIT #ifdef XWFEATURE_SEARCHLIMIT
@ -574,9 +568,8 @@ CXWordsAppView::MakeOrLoadGameL()
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
CommsAddrRec commsAddr; CommsAddrRec commsAddr;
XP_U16 listenPort = 0;
if ( iGame.comms != NULL ) { if ( iGame.comms != NULL ) {
comms_getAddr( iGame.comms, &commsAddr, &listenPort ); comms_getAddr( iGame.comms, &commsAddr );
} else { } else {
commsAddr = iCommsAddr; commsAddr = iCommsAddr;
} }
@ -608,7 +601,7 @@ CXWordsAppView::MakeOrLoadGameL()
model_setDictionary( iGame.model, dict ); model_setDictionary( iGame.model, dict );
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
if ( iGame.comms ) { if ( iGame.comms ) {
comms_setAddr( iGame.comms, &iCommsAddr, iListenPort ); comms_setAddr( iGame.comms, &iCommsAddr );
} }
#endif #endif
@ -844,13 +837,41 @@ CXWordsAppView::HandleKeyEvent( const TKeyEvent& aKeyEvent )
/* static */ TInt /* static */ TInt
CXWordsAppView::TimerCallback( TAny* aPtr ) CXWordsAppView::TimerCallback( TAny* aPtr )
{ {
CXWordsAppView* self = (CXWordsAppView*)aPtr; CXWordsAppView* me = (CXWordsAppView*)aPtr;
if ( server_do( self->iGame.server ) ) { /* Only do one per call. Packets are higher priority */
self->DoImmediateDraw(); if ( me->iTimerReasons[EProcessPacket] > 0 ) {
--me->iTimerReasons[EProcessPacket];
XP_ASSERT( me->iTimerReasons[EProcessPacket] == 0 );
XP_Bool draw = XP_FALSE;
XWStreamCtxt* stream = me->MakeSimpleStream( NULL );
stream_putBytes( stream, (void*)me->iNewPacket.Ptr(),
me->iNewPacket.Length() );
me->iNewPacket.SetLength(0);
CommsAddrRec addr;
addr.conType = COMMS_CONN_RELAY;
if ( comms_checkIncomingStream( me->iGame.comms, stream, &addr ) ) {
draw = server_receiveMessage( me->iGame.server, stream );
}
stream_destroy( stream );
sym_util_requestTime( &me->iUtil );
if ( draw ) {
me->DoImmediateDraw();
} }
return --self->iTimerRunCount > 0; } else if ( me->iTimerReasons[EUtilRequest] > 0 ) {
--me->iTimerReasons[EUtilRequest];
if ( server_do( me->iGame.server ) ) {
me->DoImmediateDraw();
}
}
return --me->iTimerRunCount > 0;
} }
XWStreamCtxt* XWStreamCtxt*
@ -1033,10 +1054,10 @@ CXWordsAppView::InitPrefs()
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
iGi.serverRole = SERVER_STANDALONE; iGi.serverRole = SERVER_STANDALONE;
iCommsAddr.conType = COMMS_CONN_IP; iCommsAddr.conType = COMMS_CONN_RELAY;
char* name = "aphraea.org"; char* name = "aphraea.org";
XP_MEMCPY( iCommsAddr.u.ip.hostName, name, XP_STRLEN(name) + 1 ); XP_MEMCPY( iCommsAddr.u.ip_relay.hostName, name, XP_STRLEN(name) + 1 );
iCommsAddr.u.ip.port = 10999; iCommsAddr.u.ip_relay.port = 10999;
#endif #endif
} }
@ -1049,9 +1070,8 @@ CXWordsAppView::DoNewGame()
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
CommsAddrRec commsAddr; CommsAddrRec commsAddr;
XP_U16 listenPort = iListenPort;
if ( iGame.comms != NULL ) { if ( iGame.comms != NULL ) {
comms_getAddr( iGame.comms, &commsAddr, &listenPort ); comms_getAddr( iGame.comms, &commsAddr );
} else { } else {
commsAddr = iCommsAddr; commsAddr = iCommsAddr;
} }
@ -1087,7 +1107,7 @@ CXWordsAppView::DoNewGame()
} }
#ifndef XWFEATURE_STANDALONE_ONLY #ifndef XWFEATURE_STANDALONE_ONLY
if ( iGame.comms ) { if ( iGame.comms ) {
comms_setAddr( iGame.comms, &iCommsAddr, listenPort ); comms_setAddr( iGame.comms, &iCommsAddr );
if ( iGi.serverRole == SERVER_ISCLIENT ) { if ( iGi.serverRole == SERVER_ISCLIENT ) {
XWStreamCtxt* stream = MakeSimpleStream( sym_send_on_close ); XWStreamCtxt* stream = MakeSimpleStream( sym_send_on_close );
@ -1237,23 +1257,9 @@ CXWordsAppView::DrawGameName() const
CXWordsAppView::PacketReceived( const TDesC8* aBuf, void* aClosure ) CXWordsAppView::PacketReceived( const TDesC8* aBuf, void* aClosure )
{ {
CXWordsAppView* me = (CXWordsAppView*)aClosure; CXWordsAppView* me = (CXWordsAppView*)aClosure;
XP_Bool draw = XP_FALSE; XP_ASSERT( me->iNewPacket.Length() == 0 );
me->iNewPacket.Copy( *aBuf );
XWStreamCtxt* stream = me->MakeSimpleStream( NULL ); me->StartIdleTimer( EProcessPacket );
stream_putBytes( stream, (void*)aBuf->Ptr(), aBuf->Length() );
CommsAddrRec addr;
addr.conType = COMMS_CONN_IP;
if ( comms_checkIncomingStream( me->iGame.comms, stream, &addr ) ) {
draw = server_receiveMessage( me->iGame.server, stream );
}
stream_destroy( stream );
sym_util_requestTime( &me->iUtil );
if ( draw ) {
me->DoImmediateDraw();
}
} /* CXWordsAppView::PacketReceived */ } /* CXWordsAppView::PacketReceived */
/*static*/ XP_S16 /*static*/ XP_S16
@ -1265,13 +1271,15 @@ CXWordsAppView::sym_send( XP_U8* aBuf, XP_U16 aLen, CommsAddrRec* aAddr,
CXWordsAppView* self = (CXWordsAppView*)aClosure; CXWordsAppView* self = (CXWordsAppView*)aClosure;
if ( aAddr == NULL ) { if ( aAddr == NULL ) {
XP_U16 ignore; comms_getAddr( self->iGame.comms, &addr );
comms_getAddr( self->iGame.comms, &addr, &ignore );
aAddr = &addr; aAddr = &addr;
} }
self->iSendSock->SendL( aBuf, aLen, aAddr ); self->iSendSock->SendL( aBuf, aLen, aAddr );
/* Can't call listen until we've sent something.... */
self->iSendSock->Listen();
return result; return result;
} /* sym_send */ } /* sym_send */
@ -1282,7 +1290,17 @@ CXWordsAppView::sym_send_on_close( XWStreamCtxt* aStream, void* aClosure )
CXWordsAppView* self = (CXWordsAppView*)aClosure; CXWordsAppView* self = (CXWordsAppView*)aClosure;
CommsConnType conType = comms_getConType( self->iGame.comms ); CommsConnType conType = comms_getConType( self->iGame.comms );
comms_send( self->iGame.comms, conType, aStream ); comms_send( self->iGame.comms, aStream );
} }
#endif #endif
void
CXWordsAppView::StartIdleTimer( XWTimerReason aWhy )
{
++iTimerReasons[aWhy];
if ( ++iTimerRunCount == 1 ) {
iRequestTimer->Start( TCallBack( CXWordsAppView::TimerCallback,
(TAny*)this ) );
}
}