X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7c351dad14431c3e1aeeef6b86f61ba898d1d9ad..4c6819972f9536b2508dd21100eb0c09ed8350a9:/src/gtk/threadpsx.cpp diff --git a/src/gtk/threadpsx.cpp b/src/gtk/threadpsx.cpp index 645fba49ab..80613c5156 100644 --- a/src/gtk/threadpsx.cpp +++ b/src/gtk/threadpsx.cpp @@ -16,6 +16,10 @@ #include #include #include +#include +#include "wx/thread.h" +#include "wx/module.h" +#include "wx/utils.h" enum thread_state { STATE_IDLE = 0, @@ -28,8 +32,6 @@ enum thread_state { // Static variables ///////////////////////////////////////////////////////////////////////////// -#include "thread.h" - static pthread_t p_mainid; wxMutex wxMainMutex; // controls access to all GUI functions @@ -47,34 +49,35 @@ public: pthread_mutex_t p_mutex; }; -wxMutex::wxMutex(void) +wxMutex::wxMutex() { p_internal = new wxMutexInternal; pthread_mutex_init(&(p_internal->p_mutex), NULL); - m_locked = false; + m_locked = 0; } -wxMutex::~wxMutex(void) +wxMutex::~wxMutex() { - if (m_locked) - pthread_mutex_unlock(&(p_internal->p_mutex)); + if (m_locked > 0) + wxDebugMsg("wxMutex warning: freeing a locked mutex (%d locks)\n", + m_locked); + pthread_mutex_destroy(&(p_internal->p_mutex)); delete p_internal; } -wxMutexError wxMutex::Lock(void) +wxMutexError wxMutex::Lock() { int err; err = pthread_mutex_lock(&(p_internal->p_mutex)); - switch (err) { - case EDEADLK: return MUTEX_DEAD_LOCK; - } + if (err == EDEADLK) + return MUTEX_DEAD_LOCK; m_locked++; return MUTEX_NO_ERROR; } -wxMutexError wxMutex::TryLock(void) +wxMutexError wxMutex::TryLock() { int err; @@ -88,9 +91,12 @@ wxMutexError wxMutex::TryLock(void) return MUTEX_NO_ERROR; } -wxMutexError wxMutex::Unlock(void) +wxMutexError wxMutex::Unlock() { - if (m_locked > 0) m_locked--; + if (m_locked > 0) + m_locked--; + else + return MUTEX_UNLOCKED; pthread_mutex_unlock(&(p_internal->p_mutex)); return MUTEX_NO_ERROR; } @@ -104,13 +110,13 @@ public: pthread_cond_t p_condition; }; -wxCondition::wxCondition(void) +wxCondition::wxCondition() { p_internal = new wxConditionInternal; pthread_cond_init(&(p_internal->p_condition), NULL); } -wxCondition::~wxCondition(void) +wxCondition::~wxCondition() { pthread_cond_destroy(&(p_internal->p_condition)); delete p_internal; @@ -130,12 +136,12 @@ bool wxCondition::Wait(wxMutex& mutex, unsigned long sec, unsigned long nsec) return (pthread_cond_timedwait(&(p_internal->p_condition), &(mutex.p_internal->p_mutex), &tspec) != ETIMEDOUT); } -void wxCondition::Signal(void) +void wxCondition::Signal() { pthread_cond_signal(&(p_internal->p_condition)); } -void wxCondition::Broadcast(void) +void wxCondition::Broadcast() { pthread_cond_broadcast(&(p_internal->p_condition)); } @@ -210,7 +216,7 @@ void wxThread::SetPriority(int prio) p_internal->prio = prio; } -int wxThread::GetPriority(void) +int wxThread::GetPriority() const { return p_internal->prio; } @@ -223,7 +229,7 @@ void wxThread::DeferDestroy(bool on) pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL); } -wxThreadError wxThread::Destroy(void) +wxThreadError wxThread::Destroy() { int res = 0; @@ -255,7 +261,7 @@ void *wxThread::Join() return status; } -unsigned long wxThread::GetID() +unsigned long wxThread::GetID() const { return (unsigned long)p_internal->thread_id; } @@ -274,7 +280,7 @@ void wxThread::TestDestroy() pthread_testcancel(); } -bool wxThread::IsMain(void) +bool wxThread::IsMain() { return (bool)pthread_equal(pthread_self(), p_mainid); } @@ -300,7 +306,7 @@ void wxThread::OnExit() class wxThreadModule : public wxModule { DECLARE_DYNAMIC_CLASS(wxThreadModule) public: - virtual bool OnInit(void) { + virtual bool OnInit() { wxThreadGuiInit(); p_mainid = pthread_self(); wxMainMutex.Lock(); @@ -308,7 +314,7 @@ public: return TRUE; } - virtual void OnExit(void) { + virtual void OnExit() { wxMainMutex.Unlock(); wxThreadGuiExit(); }