EventThread.cpp 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. #include "StdAfx.h"
  2. #include "EventThread.h"
  3. #include "Misc.h"
  4. #define EXIT_EVENT -1
  5. CEventThread::CEventThread(void)
  6. {
  7. AddEvent(EXIT_EVENT);
  8. m_hEvt = CreateEvent(NULL, FALSE, FALSE, NULL);
  9. m_waitTimeout = INFINITE;
  10. m_threadRunning = false;
  11. m_exitThread = false;
  12. }
  13. CEventThread::~CEventThread(void)
  14. {
  15. Stop();
  16. for(EventMapType::iterator it = m_eventMap.begin(); it != m_eventMap.end(); it++)
  17. {
  18. CloseHandle(it->first);
  19. }
  20. }
  21. UINT CEventThread::EventThreadFnc(void* thisptr)
  22. {
  23. CEventThread *threadClass = (CEventThread*)thisptr;
  24. threadClass->RunThread();
  25. return 0;
  26. }
  27. void CEventThread::AddEvent(int eventId)
  28. {
  29. HANDLE handle = CreateEvent(NULL, FALSE, FALSE, _T(""));
  30. m_eventMap[handle] = eventId;
  31. }
  32. bool CEventThread::FireEvent(int eventId)
  33. {
  34. HANDLE eventHandle = NULL;
  35. for(EventMapType::iterator it = m_eventMap.begin(); it != m_eventMap.end(); it++)
  36. {
  37. if(it->second == eventId)
  38. {
  39. eventHandle = it->first;
  40. break;
  41. }
  42. }
  43. if(eventHandle != NULL)
  44. {
  45. SetEvent(eventHandle);
  46. return true;
  47. }
  48. return false;
  49. }
  50. bool CEventThread::UndoFireEvent(int eventId)
  51. {
  52. HANDLE eventHandle = NULL;
  53. for(EventMapType::iterator it = m_eventMap.begin(); it != m_eventMap.end(); it++)
  54. {
  55. if(it->second == eventId)
  56. {
  57. eventHandle = it->first;
  58. break;
  59. }
  60. }
  61. if(eventHandle != NULL)
  62. {
  63. ResetEvent(eventHandle);
  64. return true;
  65. }
  66. return false;
  67. }
  68. void CEventThread::Start(void *param)
  69. {
  70. if(m_threadRunning == false)
  71. {
  72. ResetEvent(m_hEvt);
  73. m_exitThread = false;
  74. m_param = param;
  75. m_thread = (HANDLE)_beginthreadex(NULL, 0, EventThreadFnc, this, 0, &m_threadID);
  76. // now wait until the thread is up and really running
  77. WaitForSingleObject(m_hEvt, 1000);
  78. }
  79. else
  80. {
  81. UndoFireEvent(EXIT_EVENT);
  82. }
  83. }
  84. void CEventThread::Stop(int waitTime)
  85. {
  86. Log(_T("Start of CEventThread::Stop(int waitTime) "));
  87. if(m_threadRunning)
  88. {
  89. m_exitThread = true;
  90. FireEvent(EXIT_EVENT);
  91. if(waitTime > 0)
  92. {
  93. if (WAIT_OBJECT_0 != WaitForSingleObject(m_hEvt, waitTime))
  94. {
  95. Log(_T("Start of TerminateThread CEventThread::Stop(int waitTime) "));
  96. TerminateThread(m_thread, 0);
  97. Log(_T("End of TerminateThread CEventThread::Stop(int waitTime) "));
  98. m_threadRunning = false;
  99. }
  100. }
  101. }
  102. Log(_T("End of CEventThread::Stop(int waitTime) "));
  103. };
  104. void CEventThread::RunThread()
  105. {
  106. Log(_T("Start of CEventThread::RunThread()"));
  107. m_threadRunning = true;
  108. HANDLE *pHandleArray = new HANDLE[m_eventMap.size()];
  109. int indexPos = 0;
  110. for(EventMapType::iterator it = m_eventMap.begin(); it != m_eventMap.end(); it++)
  111. {
  112. pHandleArray[indexPos] = it->first;
  113. indexPos++;
  114. }
  115. SetEvent(m_hEvt);
  116. ResetEvent(m_hEvt);
  117. while(true)
  118. {
  119. DWORD event = WaitForMultipleObjects((DWORD)m_eventMap.size(), pHandleArray, FALSE, m_waitTimeout);
  120. if(event == WAIT_FAILED)
  121. {
  122. LPVOID lpMsgBuf = NULL;
  123. DWORD dwErr = GetLastError();
  124. FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
  125. FORMAT_MESSAGE_FROM_SYSTEM |
  126. FORMAT_MESSAGE_IGNORE_INSERTS,
  127. NULL,
  128. dwErr,
  129. MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
  130. (LPTSTR) &lpMsgBuf,
  131. 0,
  132. NULL);
  133. ASSERT(!lpMsgBuf);
  134. LocalFree(lpMsgBuf);
  135. }
  136. else if(event == WAIT_TIMEOUT)
  137. {
  138. OnTimeOut(m_param);
  139. }
  140. else
  141. {
  142. HANDLE firedHandle = pHandleArray[event - WAIT_OBJECT_0];
  143. int eventId = m_eventMap[firedHandle];
  144. if(eventId == EXIT_EVENT)
  145. {
  146. SetEvent(m_hEvt);
  147. break;
  148. }
  149. else
  150. {
  151. Log(StrF(_T("Start of CEventThread::RunThread() - OnEvent %d"), eventId));
  152. OnEvent(eventId, m_param);
  153. Log(StrF(_T("End of CEventThread::RunThread() - OnEvent %d"), eventId));
  154. }
  155. }
  156. }
  157. Log(_T("Start of CEventThread::RunThread()"));
  158. m_threadRunning = false;
  159. }