X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=ABM2%2FEngine%2FKernel.cpp;h=581b96370d7575914071f944d35376e0ae2f34ec;hb=75d4212e8548f64904bad6d7f8978c077e6687d0;hp=7638ab10c0c725094ccf9c7638b182f0f53904c1;hpb=784aa42247545bf80768602a32fbad922bb7d4c3;p=matthijs%2FABM2.git diff --git a/ABM2/Engine/Kernel.cpp b/ABM2/Engine/Kernel.cpp index 7638ab1..581b963 100755 --- a/ABM2/Engine/Kernel.cpp +++ b/ABM2/Engine/Kernel.cpp @@ -25,25 +25,13 @@ CKernel::~CKernel() int CKernel::Execute() { -#ifdef WIN32 - MSG msg; -#endif // WIN32 while(taskList.size()) { { PROFILE("Kernel task loop"); - //DWORD starting_point = GetTickCount(); - -#ifdef WIN32 - if (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE)) - { - TranslateMessage(&msg); - DispatchMessage(&msg); - } -#endif // WIN32 - + DWORD starting_point = GetTickCount(); std::list< CMMPointer >::iterator it, thisIt; for(it=taskList.begin();it!=taskList.end();) @@ -66,8 +54,10 @@ int CKernel::Execute() } } IMMObject::CollectGarbage(); - //DWORD end_point = GetTickCount(); -// Sleep(50 - (end_point-starting_point)); + DWORD end_point = GetTickCount(); + /* Sleep if we didn't use up too much time already */ + if (starting_point + 250 > end_point) + Sleep(250 - (end_point-starting_point)); } #ifdef _DEBUG CProfileSample::Output();