wxMutexError LockTimeout(DWORD milliseconds);
HANDLE m_mutex;
+
+ DECLARE_NO_COPY_CLASS(wxMutexInternal)
};
// all mutexes are recursive under Win32 so we don't use mutexType
{
if ( !::ReleaseMutex(m_mutex) )
{
- wxLogLastError(_("ReleaseMutex()"));
+ wxLogLastError(_T("ReleaseMutex()"));
return wxMUTEX_MISC_ERROR;
}
bool IsOk() const { return m_semaphore != NULL; }
wxSemaError Wait() { return WaitTimeout(INFINITE); }
- wxSemaError TryWait() { return WaitTimeout(0); }
+
+ wxSemaError TryWait()
+ {
+ wxSemaError rc = WaitTimeout(0);
+ if ( rc == wxSEMA_TIMEOUT )
+ rc = wxSEMA_BUSY;
+
+ return rc;
+ }
+
wxSemaError WaitTimeout(unsigned long milliseconds);
wxSemaError Post();
private:
HANDLE m_semaphore;
+
+ DECLARE_NO_COPY_CLASS(wxSemaphoreInternal)
};
wxSemaphoreInternal::wxSemaphoreInternal(int initialcount, int maxcount)
return wxSEMA_NO_ERROR;
case WAIT_TIMEOUT:
- return wxSEMA_BUSY;
+ return wxSEMA_TIMEOUT;
default:
wxLogLastError(_T("WaitForSingleObject(semaphore)"));
wxThreadState m_state; // state, see wxThreadState enum
unsigned int m_priority; // thread priority in "wx" units
DWORD m_tid; // thread id
+
+ DECLARE_NO_COPY_CLASS(wxThreadInternal)
};
THREAD_RETVAL THREAD_CALLCONV wxThreadInternal::WinThreadStart(void *param)
bool wxThreadInternal::Create(wxThread *thread, unsigned int stackSize)
{
+ wxASSERT_MSG( m_state == STATE_NEW && !m_hThread,
+ _T("Create()ing thread twice?") );
+
// for compilers which have it, we should use C RTL function for thread
// creation instead of Win32 API one because otherwise we will have memory
// leaks if the thread uses C RTL (and most threads do)
HANDLE hThread = m_internal->GetHandle();
- // Check if thread is really still running. There is a
- // race condition in WinThreadStart between the time the
- // m_internal->m_state is set to STATE_EXITED and the win32
- // thread actually exits. It can be flagged as STATE_EXITED
- // and then we don't wait for it to exit. This will cause
- // GetExitCodeThread to return STILL_ACTIVE.
- if ( !isRunning )
- {
- if ( !IsRunning() )
- {
- if ( ::GetExitCodeThread(hThread, (LPDWORD)&rc) )
- {
- if ((DWORD)rc == STILL_ACTIVE)
- isRunning = TRUE;
- }
- }
- else
- {
- isRunning = TRUE;
- }
- }
-
- // does it still run?
- if ( isRunning )
+ // does is still run?
+ if ( isRunning || IsRunning() )
{
if ( IsMain() )
{
break;
case WAIT_OBJECT_0 + 1:
+ // new message arrived, process it
+ if ( !wxTheApp->DoMessage() )
{
- MSG peekMsg;
- // Check if a new message has really arrived.
- // MsgWaitForMultipleObjects can indicate that a message
- // is ready for processing, but this message may be sucked
- // up by GetMessage and then GetMessage will hang and not
- // allow us to process the actual thread exit event.
- if (::PeekMessage(&peekMsg, (HWND) NULL, 0, 0, PM_NOREMOVE))
- {
- // new message arrived, process it
- if ( !wxTheApp->DoMessage() )
- {
- // WM_QUIT received: kill the thread
- Kill();
-
- return wxTHREAD_KILLED;
- }
- }
+ // WM_QUIT received: kill the thread
+ Kill();
+
+ return wxTHREAD_KILLED;
}
break;