X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/be8098689121d2352751c51005c133797d77ecea..3342663931cc6d203c1d2ded6da44a17347cb0e7:/include/wx/thread.h?ds=sidebyside diff --git a/include/wx/thread.h b/include/wx/thread.h index ff78911271..319829ba71 100644 --- a/include/wx/thread.h +++ b/include/wx/thread.h @@ -117,8 +117,9 @@ class WXDLLEXPORT wxMutexLocker { public: // lock the mutex in the ctor - wxMutexLocker(wxMutex& mutex) : m_mutex(mutex) - { m_isOk = m_mutex.Lock() == wxMUTEX_NO_ERROR; } + wxMutexLocker(wxMutex& mutex) + : m_isOk(FALSE), m_mutex(mutex) + { m_isOk = ( m_mutex.Lock() == wxMUTEX_NO_ERROR ); } // returns TRUE if mutex was successfully locked in ctor bool IsOk() const @@ -220,12 +221,14 @@ private: class WXDLLEXPORT wxCondition { + DECLARE_NO_COPY_CLASS(wxCondition) + public: // constructor and destructor // Each wxCondition object is associated with with a wxMutex object The // mutex object MUST be locked before calling Wait() - wxCondition( wxMutex *mutex ); + wxCondition(wxMutex& mutex); // dtor is not virtual, don't use this class polymorphically ~wxCondition(); @@ -275,6 +278,8 @@ private: class WXDLLEXPORT wxSemaphoreInternal; class WXDLLEXPORT wxSemaphore { + DECLARE_NO_COPY_CLASS(wxSemaphore) + public: // specifying a maxcount of 0 actually makes wxSemaphore behave as if there // is no upper limit, if maxcount is 1 the semaphore behaves as a mutex @@ -548,7 +553,7 @@ public: // wxApp then should block all "dangerous" messages extern bool WXDLLEXPORT wxIsWaitingForThread(); #elif defined(__WXMAC__) - extern void WXDLLEXPORT wxMutexGuiLeaveOrEnter(); + extern void WXDLLEXPORT wxMutexGuiLeaveOrEnter(); // returns TRUE if the main thread has GUI lock extern bool WXDLLEXPORT wxGuiOwnedByMainThread(); @@ -561,7 +566,7 @@ public: extern bool WXDLLEXPORT wxIsWaitingForThread(); // implement wxCriticalSection using mutexes - inline wxCriticalSection::wxCriticalSection() { } + inline wxCriticalSection::wxCriticalSection() : m_mutex() { } inline wxCriticalSection::~wxCriticalSection() { } inline void wxCriticalSection::Enter() { (void)m_mutex.Lock(); }