CPeriodicThread Class Reference#include <PeriodicThread.h>
Inheritance diagram for CPeriodicThread:
![]()
Collaboration diagram for CPeriodicThread:
![]()
Detailed DescriptionDefinition at line 50 of file PeriodicThread.h. Member Typedef Documentation
Definition at line 65 of file PeriodicThread.h.
Member Enumeration Documentation
Definition at line 53 of file ErrorHandler.h. 00054 { 00055 lpDebug, 00056 lpMessage, 00057 lpCritical, 00058 lpError 00059 } LogPriority;
Definition at line 54 of file PeriodicThread.h. 00055 { 00056 tsStart, 00057 tsBody, 00058 tsEnd 00059 } ThreadStage;
Constructor & Destructor Documentation
Definition at line 53 of file PeriodicThread.cpp. 00053 : CErrorHandler(), 00054 m_pThread(NULL), 00055 m_pUserProc(pProc), 00056 m_pEnterEvent(NULL), 00057 m_pExitEvent(NULL), 00058 m_dwInterval(0), 00059 m_dwThreadTimeout(20000), 00060 m_bDestructor(FALSE), 00061 m_bAbort(FALSE) 00062 { 00063 try 00064 { 00065 //Set our name 00066 SetName(CPeriodicThread_Class); 00067 00068 //Allocate the thread 00069 m_pThread=COSManager::CreateThread(PeriodicThread); 00070 } 00071 ERROR_HANDLER("CPeriodicThread") 00072 }
Definition at line 74 of file PeriodicThread.cpp. 00075 { 00076 try 00077 { 00078 //Indicate tremination 00079 m_bDestructor=TRUE; 00080 00081 //Delete our thread 00082 Stop(); 00083 } 00084 ERROR_HANDLER("~CPeriodicThread") 00085 }
Member Function Documentation
Definition at line 122 of file ErrorHandler.cpp. 00123 { 00124 try 00125 { 00126 //Get the error string 00127 LPVOID lpMsgBuf; 00128 FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | 00129 FORMAT_MESSAGE_FROM_SYSTEM | 00130 FORMAT_MESSAGE_IGNORE_INSERTS, 00131 NULL, 00132 dwErrorCode, 00133 MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language 00134 (LPTSTR) &lpMsgBuf, 00135 0, 00136 NULL); 00137 00138 //Save it 00139 std::string sMessage; 00140 sMessage+=(char*)lpMsgBuf; 00141 00142 //Release the buffer 00143 LocalFree(lpMsgBuf); 00144 00145 //Done 00146 return sMessage; 00147 } 00148 catch (...) 00149 { 00150 return "Unknown"; 00151 } 00152 }
Definition at line 521 of file ErrorHandler.cpp. 00522 { 00523 try 00524 { 00525 //Our string 00526 std::string sDate; 00527 00528 //Our tmp buf 00529 char cTmp[128]; 00530 00531 //Get date 00532 _strdate(cTmp); 00533 sDate=cTmp; 00534 sDate+=' '; 00535 00536 //Get time 00537 _strtime(cTmp); 00538 sDate+=cTmp; 00539 00540 //Done 00541 return sDate; 00542 } 00543 ERROR_HANDLER_STATIC_RETURN(CErrorHandler_Class,"GetCurrentDateTime","") 00544 }
Definition at line 154 of file ErrorHandler.cpp. 00157 { 00158 if (!GetLog()) 00159 return; 00160 00161 try 00162 { 00163 //Get the log 00164 CErrorLog* pLog; 00165 pLog=GetLog(); 00166 00167 //Convert the error code 00168 char aTmp[11]; 00169 sprintf(aTmp,"%d",iErrorCode); 00170 00171 //Get the string for it 00172 std::string sError; 00173 sError=rMessage; 00174 sError+=", and Socket error: "; 00175 sError+=aTmp; 00176 sError+=", "; 00177 sError+=ErrorCodeToString(iErrorCode); 00178 00179 //Report to the log 00180 pLog->ReportError(m_sClassName, 00181 rMethod, 00182 sError); 00183 } 00184 ERROR_UNKNOWN("ReportError") 00185 }
Definition at line 187 of file ErrorHandler.cpp. 00189 { 00190 if (!GetLog()) 00191 return; 00192 00193 try 00194 { 00195 //Get the log 00196 CErrorLog* pLog; 00197 pLog=GetLog(); 00198 00199 //Convert the error code 00200 char aTmp[11]; 00201 sprintf(aTmp,"%d",iErrorCode); 00202 00203 //Get the string for it 00204 std::string sError; 00205 sError="Socket error: "; 00206 sError+=aTmp; 00207 sError+=", "; 00208 sError+=ErrorCodeToString(iErrorCode); 00209 00210 //Report to the log 00211 pLog->ReportError(m_sClassName, 00212 rMethod, 00213 sError); 00214 } 00215 ERROR_UNKNOWN("ReportError") 00216 }
Definition at line 275 of file ErrorHandler.cpp. 00278 { 00279 if (!GetLog()) 00280 return; 00281 00282 try 00283 { 00284 //Get the log 00285 CErrorLog* pLog; 00286 pLog=GetLog(); 00287 00288 //Convert the number 00289 char aTmp[11]; 00290 ltoa(dwAdditionalData,aTmp,10); 00291 00292 //Create the new message 00293 std::string sNewMessage(rMessage); 00294 sNewMessage+="Additional data: "; 00295 sNewMessage+=aTmp; 00296 00297 //Report to the log 00298 pLog->ReportError(m_sClassName, 00299 rMethod, 00300 sNewMessage); 00301 } 00302 ERROR_UNKNOWN("ReportError") 00303 }
Definition at line 218 of file ErrorHandler.cpp. 00220 { 00221 if (!GetLog()) 00222 return; 00223 00224 try 00225 { 00226 CErrorLog* pLog; 00227 pLog=GetLog(); 00228 00229 //Report to the log 00230 pLog->ReportError(m_sClassName, 00231 rMethod, 00232 rMessage); 00233 } 00234 ERROR_UNKNOWN("ReportError") 00235 }
Definition at line 311 of file ErrorHandler.cpp. 00312 { 00313 if (!GetLog()) 00314 return; 00315 00316 try 00317 { 00318 #ifdef WIN32 00319 //Get the last error 00320 DWORD dwLastError; 00321 dwLastError=GetLastError(); 00322 00323 //Report the error 00324 GetLog()->ReportError(m_sClassName, 00325 rMethod, 00326 ErrorCodeToString(dwLastError)); 00327 00328 #else 00329 GetLog()->ReportCatchError(m_sClassName, 00330 rMethod, 00331 "Unknown error!"); 00332 #endif 00333 } 00334 ERROR_UNKNOWN("ReportError") 00335 }
Definition at line 237 of file ErrorHandler.cpp. 00239 { 00240 if (!GetLog()) 00241 return; 00242 00243 try 00244 { 00245 //Get the last error 00246 DWORD dwLastError; 00247 dwLastError=GetLastError(); 00248 00249 //Format the message 00250 std::string sMessage; 00251 sMessage=rMessage; 00252 sMessage+=", with error code: "; 00253 00254 //Convert the error code 00255 char aTmp[11]; 00256 itoa(dwLastError,aTmp,10); 00257 00258 //Add it again 00259 sMessage+=aTmp; 00260 sMessage+=" "; 00261 sMessage+=ErrorCodeToString(dwLastError); 00262 00263 //Get the log 00264 CErrorLog* pLog; 00265 pLog=GetLog(); 00266 00267 //Report to the log 00268 pLog->ReportError(m_sClassName, 00269 rMethod, 00270 sMessage); 00271 } 00272 ERROR_UNKNOWN("ReportErrorOS") 00273 }
Definition at line 489 of file ErrorHandler.cpp. 00493 { 00494 if (!m_pLog) 00495 return; 00496 00497 try 00498 { 00499 //Convert the number 00500 char aTmp[11]; 00501 ltoa(dwAdditionalData,aTmp,10); 00502 00503 //Create the new message 00504 std::string sNewMessage(rMessage); 00505 sNewMessage+="Additional data: "; 00506 sNewMessage+=aTmp; 00507 00508 //Report to the log 00509 m_pLog->ReportError(rClass, 00510 rMethod, 00511 sNewMessage); 00512 } 00513 ERROR_UNKNOWN("ReportStaticError") 00514 }
Definition at line 472 of file ErrorHandler.cpp. 00475 { 00476 if (!m_pLog) 00477 return; 00478 00479 try 00480 { 00481 //Report to the log 00482 m_pLog->ReportError(rClass, 00483 rMethod, 00484 rMessage); 00485 } 00486 ERROR_UNKNOWN("ReportStaticError") 00487 }
Definition at line 446 of file ErrorHandler.cpp. 00448 { 00449 if (!m_pLog) 00450 return; 00451 00452 try 00453 { 00454 #ifdef WIN32 00455 //Get the last error 00456 DWORD dwLastError; 00457 dwLastError=GetLastError(); 00458 00459 //Report the error 00460 m_pLog->ReportError(rClass, 00461 rMethod, 00462 ErrorCodeToString(dwLastError)); 00463 #else 00464 m_pLog->ReportError(rClass, 00465 rMethod, 00466 "Unknown error!"); 00467 #endif 00468 } 00469 ERROR_UNKNOWN("ReportStaticError") 00470 }
Definition at line 363 of file PeriodicThread.cpp. 00364 { 00365 try 00366 { 00367 //Set the priority 00368 m_pThread->SetPriority(aPriority); 00369 } 00370 ERROR_HANDLER("SetPriority") 00371 }
Definition at line 348 of file PeriodicThread.cpp. 00349 { 00350 try 00351 { 00352 //Save it 00353 m_dwThreadTimeout=dwTimeout; 00354 } 00355 ERROR_HANDLER("SetThreadTimeout") 00356 }
Definition at line 199 of file PeriodicThread.cpp. 00201 { 00202 try 00203 { 00204 //Is the interval legal 00205 if (!dwInterval) 00206 { 00207 //Report it 00208 ReportError("Start","Invalid interval!"); 00209 00210 //Exit 00211 return FALSE; 00212 } 00213 00214 //Are we running 00215 if (m_dwInterval || 00216 m_pEnterEvent || 00217 m_pExitEvent) 00218 { 00219 //Report it 00220 ReportError("Start","Already running!"); 00221 00222 //Exit 00223 return FALSE; 00224 } 00225 00226 //We are not aborting 00227 m_bAbort=FALSE; 00228 00229 //Create all 00230 m_pEnterEvent=COSManager::CreateEvent(); 00231 m_pExitEvent=COSManager::CreateEvent(); 00232 00233 //Save the user data 00234 m_lpData=lpData; 00235 00236 //Save the interval 00237 m_dwInterval=dwInterval; 00238 00239 //Set it to auto delete 00240 m_pThread->SetAutoDelete(TRUE); 00241 00242 //Run the thread 00243 m_pThread->Start((LPVOID)this); 00244 00245 //Wait for the event 00246 if (m_pEnterEvent->Wait(m_dwThreadTimeout) || 00247 m_bAbort) 00248 { 00249 //Report it 00250 if (m_bAbort) 00251 ReportError("Start","User aborted!"); 00252 else 00253 ReportError("Start","Timeout waiting for thread!"); 00254 00255 //Delete it all 00256 delete m_pThread; 00257 m_pThread=COSManager::CreateThread(PeriodicThread); 00258 00259 //The events 00260 delete m_pEnterEvent; 00261 m_pEnterEvent=NULL; 00262 00263 delete m_pExitEvent; 00264 m_pExitEvent=NULL; 00265 00266 //Exit 00267 return FALSE; 00268 } 00269 else 00270 return TRUE; 00271 } 00272 ERROR_HANDLER_RETURN("Start",FALSE) 00273 }
Definition at line 275 of file PeriodicThread.cpp. 00276 { 00277 try 00278 { 00279 if (m_bDestructor) 00280 if (!m_pEnterEvent || 00281 !m_pExitEvent) 00282 { 00283 //Just delete the thread 00284 delete m_pThread; 00285 00286 //Exit 00287 return TRUE; 00288 } 00289 else 00290 ; 00291 else 00292 //Are we running 00293 if (!m_pEnterEvent || 00294 !m_pExitEvent) 00295 { 00296 //Report it 00297 ReportError("Stop","Not running!"); 00298 00299 //Exit 00300 return FALSE; 00301 } 00302 00303 //Are we aborted 00304 if (!m_bAbort) 00305 { 00306 //The thread ID 00307 DWORD dwThreadID; 00308 dwThreadID=m_pThread->GetThreadID(); 00309 00310 //Call the thread 00311 m_pExitEvent->Set(); 00312 00313 //Wait for the thread 00314 if (GetCurrentThreadId()!=dwThreadID && 00315 m_pEnterEvent->Wait(m_dwThreadTimeout)) 00316 { 00317 //Report it 00318 ReportError("Stop","Timeout waiting for thread!"); 00319 00320 //Delete it by force 00321 delete m_pThread; 00322 } 00323 } 00324 00325 //Delete it all 00326 m_pThread=NULL; 00327 00328 //Do we need to recreate 00329 if (!m_bDestructor) 00330 m_pThread=COSManager::CreateThread(PeriodicThread); 00331 00332 //The events 00333 delete m_pEnterEvent; 00334 m_pEnterEvent=NULL; 00335 00336 delete m_pExitEvent; 00337 m_pExitEvent=NULL; 00338 00339 //Set the interval 00340 m_dwInterval=0; 00341 00342 //Done 00343 return TRUE; 00344 } 00345 ERROR_HANDLER_RETURN("Stop",FALSE) 00346 }
Definition at line 355 of file ErrorHandler.cpp. 00359 { 00360 if (!GetLog()) 00361 return; 00362 00363 try 00364 { 00365 //Convert the number 00366 char aTmp[11]; 00367 ltoa(dwAdditionalData,aTmp,10); 00368 00369 //Create the new message 00370 std::string sNewMessage(rMessage); 00371 sNewMessage+="Additional data: "; 00372 sNewMessage+=aTmp; 00373 00374 //Delegate the call 00375 GetLog()->WriteMessage(m_sClassName, 00376 rMethod, 00377 sNewMessage, 00378 aPriority); 00379 } 00380 ERROR_UNKNOWN("WriteMessage") 00381 }
Definition at line 337 of file ErrorHandler.cpp. 00340 { 00341 if (!GetLog()) 00342 return; 00343 00344 try 00345 { 00346 //Delegate the call 00347 GetLog()->WriteMessage(m_sClassName, 00348 rMethod, 00349 rMessage, 00350 aPriority); 00351 } 00352 ERROR_UNKNOWN("WriteMessage") 00353 }
Definition at line 403 of file ErrorHandler.cpp. 00408 { 00409 if (!m_pLog) 00410 return; 00411 00412 try 00413 { 00414 //Convert the number 00415 char aTmp[11]; 00416 ltoa(dwAdditionalData,aTmp,10); 00417 00418 //Create the new message 00419 std::string sNewMessage(rMessage); 00420 sNewMessage+="Additional data: "; 00421 sNewMessage+=aTmp; 00422 00423 //Delegate the call 00424 m_pLog->WriteMessage(rClass, 00425 rMethod, 00426 sNewMessage, 00427 aPriority); 00428 } 00429 ERROR_UNKNOWN("WriteStaticMessage") 00430 }
Definition at line 383 of file ErrorHandler.cpp. 00388 { 00389 if (!m_pLog) 00390 return; 00391 00392 try 00393 { 00394 //Delegate the call 00395 m_pLog->WriteMessage(rClass, 00396 rMethod, 00397 rMessage, 00398 aPriority); 00399 } 00400 ERROR_UNKNOWN("WriteStaticMessage") 00401 }
The documentation for this class was generated from the following files: |