git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@37638
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// wxConditionInternal
// --------------------------------------------------------------------------
// wxConditionInternal
// --------------------------------------------------------------------------
-#if defined(__WXMSW__) || defined(__OS2__) || defined(__EMX__)
// Win32 and OS/2 don't have explicit support for the POSIX condition
// variables and their events/event semaphores have quite different semantics,
// so we reimplement the conditions from scratch using the mutexes and
// semaphores
// Win32 and OS/2 don't have explicit support for the POSIX condition
// variables and their events/event semaphores have quite different semantics,
// so we reimplement the conditions from scratch using the mutexes and
// semaphores
-#if defined(__OS2__) || defined(__EMX__)
-void InterlockedIncrement(LONG *num)
-{
- ::DosEnterCritSec();
- (*num)++;
- ::DosExitCritSec();
-}
-#endif
+#if defined(__WXMSW__) || defined(__OS2__) || defined(__EMX__)
class wxConditionInternal
{
class wxConditionInternal
{
wxCondError wxConditionInternal::Wait()
{
// increment the number of waiters
wxCondError wxConditionInternal::Wait()
{
// increment the number of waiters
- ::InterlockedIncrement(&m_numWaiters);
+ {
+ wxCriticalSectionLocker lock(m_csWaiters);
+ m_numWaiters++;
+ }
wxCondError wxConditionInternal::WaitTimeout(unsigned long milliseconds)
{
wxCondError wxConditionInternal::WaitTimeout(unsigned long milliseconds)
{
- ::InterlockedIncrement(&m_numWaiters);
+ {
+ wxCriticalSectionLocker lock(m_csWaiters);
+ m_numWaiters++;
+ }
return wxCOND_NO_ERROR;
}
return wxCOND_NO_ERROR;
}
// ----------------------------------------------------------------------------
// wxCondition
// ----------------------------------------------------------------------------
// wxCondition