📄 threngin.cpp
字号:
if (pConn) { void* pVoid = 0; if (m_pSockMap->Lookup(pConn, pVoid)) { pConn->DoNetworkIO(); } goto exit; } ndxConn = m_pSockMap->Begin(); for (; ndxConn != m_pSockMap->End(); ++ndxConn) { ThreadedConn* pConn = (ThreadedConn*) (*ndxConn); pConn->DoNetworkIO(); }exit: m_pMutex->Unlock();}//-----------------------------------------------------------#if defined(HELIX_FEATURE_NETWORK_USE_SELECT)HX_RESULT ThreadEngine::WaitforSelect(){ HX_RESULT theErr = HXR_FAIL; ThreadedConn *pConn = NULL; if (m_bInDestructor) pConn = m_pLocalReader; if (m_pLocalReader && m_pLocalReader->GetActualConn()) theErr = m_pLocalReader->GetActualConn()->WaitforSelect(this,pConn); return theErr;}#endif // HELIX_FEATURE_NETWORK_USE_SELECT//-----------------------------------------------------------void*NetworkThreadMainLoop(void* pArg){ ThreadEngine* pEngine = (ThreadEngine*) pArg; HXMutex* pMutex = pEngine->m_pMutex; HXThread* pThread = pEngine->m_pNetworkThread; HXThreadMessage msg; BOOL bDone = FALSE; UINT32 ulSleepTime = 0; ULONG32 ulLastTimerCallback = HX_GET_TICKCOUNT(); #if defined( _WIN32 ) || defined( _UNIX_THREADED_NETWORK_IO ) || defined(THREADS_SUPPORTED) UINT32 ulTimerId = 0;#endif /*_WIN32 || _UNIX_THREADED_NETWORK_IO */ #if defined(HELIX_FEATURE_NETWORK_USE_SELECT) unsigned short iSize; HX_RESULT theErr = HXR_FAIL; UINT32 ulPlatformData = 0; BOOL bRWStartup = FALSE; BOOL bMoreToRead = FALSE; BOOL bDebug = FALSE; pEngine->m_pLocalListener = new ThreadedConn(HX_TCP_SOCKET); pEngine->m_pLocalWriter = new ThreadedConn(HX_TCP_SOCKET); pEngine->m_pLocalReader = NULL; pThread->SetPriority(THREAD_PRIORITY_ABOVE_NORMAL);// pThread->SetPriority(THREAD_PRIORITY_HIGHEST);#if defined (_WIN32) ulPlatformData = (UINT32)GetModuleHandle(NULL);#elif defined (_WIN16) ulPlatformData = (UINT32)(int)g_hInstance;#endif if (pEngine->m_pLocalListener && pEngine->m_pLocalWriter) theErr = pEngine->m_pLocalListener->listen( LOCAL_LOOPBACK_ADDR , LOCAL_LOOPBACK_PORT , 4 // backlog , 0 // blocking , ulPlatformData // ulPlatform ); if (SUCCEEDED(theErr)) // writer connects and reader accepts theErr = pEngine->m_pLocalWriter->connect( LOCAL_LOOPBACK_NAME , LOCAL_LOOPBACK_PORT , 0 // blocking , ulPlatformData // ulPlatform ); if (SUCCEEDED(theErr) && !bDebug) // writer connects and reader accepts theErr = pEngine->m_pLocalListener->accept(LOCAL_LOOPBACK_ADDR); if (FAILED(theErr)) { if (pEngine->m_pLocalListener) { pEngine->DetachSocket(pEngine->m_pLocalListener); pEngine->m_pLocalListener = NULL; } if (pEngine->m_pLocalWriter) { pEngine->DetachSocket(pEngine->m_pLocalWriter); pEngine->m_pLocalWriter = NULL; } if (pEngine->m_pLocalReader) { pEngine->DetachSocket(pEngine->m_pLocalReader); pEngine->m_pLocalReader = NULL; } } while (!bDone) { if (bDebug || FAILED(theErr) || !pEngine->m_pLocalWriter || !pEngine->m_pLocalReader || !pEngine->m_pLocalWriter->connection_really_open() || !pEngine->m_pLocalReader->connection_really_open() ) { // process connect and accept messages, then use select pEngine->m_pNetworkThread->m_bUseReaderWriter = FALSE; if (ulTimerId <= 0) { ulSleepTime = 20; ulTimerId = HXAsyncTimer::SetTimer( ulSleepTime, pThread ); } if (pThread->GetMessage(&msg, 0, 0) != HXR_OK) break; } else { if (!pEngine->m_pNetworkThread->m_bUseReaderWriter || bRWStartup) { // process messages in queue if (!bRWStartup) { if (ulTimerId > 0) { HXAsyncTimer::KillTimer(ulTimerId); ulTimerId = 0; } msg.m_ulMessage = HXMSG_ASYNC_START_READERWRITER; theErr = pEngine->m_pNetworkThread->PostMessage(&msg); } pEngine->m_pNetworkThread->m_bUseReaderWriter = TRUE; pEngine->m_pLocalWriter->set_callback(pEngine->m_pLocalWriter->get_callback()); // for post network msg pThread->SetNetworkMessageConnection(pEngine->m_pLocalWriter); bRWStartup = TRUE; if (pThread->GetMessage(&msg, 0, 0) != HXR_OK) break; } else { if (!bMoreToRead) { if (HXR_FAIL == pEngine->WaitforSelect()) break; } msg.m_ulMessage = 0; iSize = sizeof(HXThreadMessage); pEngine->m_pLocalReader->m_bNetworkIOPending = TRUE; theErr = pEngine->m_pLocalReader->read(&msg,&iSize); if (HXR_OK != theErr) { if (HXR_WOULD_BLOCK == theErr) { bMoreToRead = FALSE; theErr = HXR_OK; continue; } // reader failed, must be disconnected, return to msg loop break; } if (iSize != sizeof(HXThreadMessage)) // fixme { bMoreToRead = FALSE; continue; } else bMoreToRead = TRUE; } }#else while (!bDone && pThread->GetMessage(&msg, 0, 0) == HXR_OK) {#endif // HELIX_FEATURE_NETWORK_USE_SELECT switch (msg.m_ulMessage) {#if defined( _WIN32 ) || defined( _UNIX_THREADED_NETWORK_IO ) || defined(THREADS_SUPPORTED) case HXMSG_ASYNC_TIMER: //Look in hxmsgs.h (WM_TIMER under win32) {#if defined(_UNIX_THREADED_NETWORK_IO) || (defined(THREADS_SUPPORTED) && defined(_UNIX)) unix_TCP::process_idle();#endif ULONG32 ulCurrentTime = HX_GET_TICKCOUNT(); if (CALCULATE_ELAPSED_TICKS(ulLastTimerCallback, ulCurrentTime) >= ulSleepTime) { ulLastTimerCallback = ulCurrentTime; pEngine->DoNetworkIO(); } } break;#endif /* _WIN32 || _UNIX_THREADED_NETWORK_IO */ case HXMSG_ASYNC_NETWORKIO: { ThreadedConn* pConn = (ThreadedConn*) msg.m_pParam1; pEngine->DoNetworkIO(pConn); } break; case HXMSG_ASYNC_CALLBACK: { ThreadedConn* pConn = (ThreadedConn*) msg.m_pParam1; IHXCallback* pCallback = (IHXCallback*) msg.m_pParam2; pEngine->DoAsyncCallback(pConn, pCallback); } break;#if defined(HELIX_FEATURE_NETWORK_USE_SELECT) case HXMSG_ASYNC_SETREADER_CONNECTION: { pEngine->m_pLocalReader = (ThreadedConn*) msg.m_pParam2; } break; case HXMSG_ASYNC_START_READERWRITER: { pEngine->m_pNetworkThread->m_bUseReaderWriter = TRUE; bRWStartup = FALSE; } break;#endif //HELIX_FEATURE_NETWORK_USE_SELECT case HXMSG_ASYNC_DETACH: { ThreadedConn* pConn = (ThreadedConn*) msg.m_pParam1; pEngine->DetachSocket(pConn); } break; case HXMSG_QUIT: { bDone = TRUE; } break; case HXMSG_ASYNC_RESUME:#if defined( _WIN32 ) || defined( _UNIX_THREADED_NETWORK_IO ) || defined(THREADS_SUPPORTED) { if (ulTimerId > 0) { HXAsyncTimer::KillTimer(ulTimerId); ulTimerId = 0; } ulSleepTime = (UINT32)(PTR_INT)msg.m_pParam1; ulTimerId = HXAsyncTimer::SetTimer( ulSleepTime, pThread ); }#endif /* _WIN32 || _UNIX_THREADED_NETWORK_IO */ break; case HXMSG_ASYNC_STOP:#if defined( _WIN32 ) || defined( _UNIX_THREADED_NETWORK_IO ) || defined(THREADS_SUPPORTED) { if (ulTimerId > 0) { HXAsyncTimer::KillTimer( ulTimerId ); ulTimerId = 0; ulSleepTime = 0; } }#endif /* _WIN32 || _UNIX_THREADED_NETWORK_IO */ break; default: pThread->DispatchMessage(&msg); break; } } #if defined( _WIN32 ) || defined( _UNIX_THREADED_NETWORK_IO ) || defined(THREADS_SUPPORTED) if (ulTimerId > 0) { HXAsyncTimer::KillTimer( ulTimerId ); }#endif /* _WIN32 || _UNIX_THREADED_NETWORK_IO */ pEngine->m_pQuitEvent->SignalEvent(); return (void*) 0;}#if defined(_MACINTOSH) && defined(_CARBON) && defined(THREADS_SUPPORTED)void ThreadEngine::FauxMainAppCarbonTimer(EventLoopTimerRef, void* /* unused */){ // xxxbobclark this is essentially just ripped off from Greg Wright's // similar message handling loop for Unix. // // It's been moved to pnio because more places than just rmacore // (i.e. rmacleng) use the threaded implementation of networking, // viz. rnqueue for Auto-Update. Using a Carbon Timer to get time // periodically can luckily be implemented in pnio; it's sure to // get actual System Time. ThreadEngine* pEngine = ThreadEngine::GetThreadEngine(); HX_ASSERT(pEngine); HXCarbonThread* pMainAppThread = (HXCarbonThread*)pEngine->GetMainAppThread(); HX_ASSERT(pMainAppThread); HXThreadMessage msg; while (pMainAppThread->PeekMessage(&msg, 0, 0, TRUE) == HXR_OK) { if (msg.m_ulMessage != 0) { ThreadedConn* pThreadedConn = (ThreadedConn*)msg.m_pParam1; if (pThreadedConn) { switch (msg.m_ulMessage) { case HXMSG_ASYNC_DNS: pThreadedConn->OnAsyncDNS((BOOL)msg.m_pParam2); break; case HXMSG_ASYNC_CONNECT: pThreadedConn->OnConnect((BOOL)msg.m_pParam2); break; case HXMSG_ASYNC_READ: pThreadedConn->OnReadNotification(); break; case HXMSG_ASYNC_WRITE: pThreadedConn->OnWriteNotification(); break; case HXMSG_ASYNC_ACCEPT: pThreadedConn->OnAcceptNotification(); break; default: HX_ASSERT(!"Unknown message in threaded networking Carbon Timer"); break; } } } }}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -