X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7c351dad14431c3e1aeeef6b86f61ba898d1d9ad..5db1a502b4bf38f36a14c1377618d9eaae4c8e79:/src/gtk/threadsgi.cpp?ds=sidebyside diff --git a/src/gtk/threadsgi.cpp b/src/gtk/threadsgi.cpp index 07d7cdabde..3503e79616 100644 --- a/src/gtk/threadsgi.cpp +++ b/src/gtk/threadsgi.cpp @@ -18,6 +18,9 @@ #include #include #include +#include "wx/thread.h" +#include "wx/module.h" +#include "wx/utils.h" enum thread_state { STATE_IDLE = 0, @@ -46,42 +49,52 @@ public: wxMutex::wxMutex() { + m_locked = 0; p_internal = new wxMutexInternal; init_lock(&(p_internal->p_mutex)); } wxMutex::~wxMutex() { + if (m_locked > 0) + wxDebugMsg("wxMutex warning: freeing a locked mutex (%d locks)\n", + m_locked); + delete p_internal; } -wxMutex::MutexError wxMutex::Lock(void) +wxMutexError wxMutex::Lock() { spin_lock(&(p_internal->p_mutex)); - return NO_ERROR; + m_locked++; + return MUTEX_NO_ERROR; } -wxMutex::MutexError wxMutex::TryLock(void) +wxMutexError wxMutex::TryLock() { if (acquire_lock(&(p_internal->p_mutex)) != 0) - return BUSY; - return NO_ERROR; + return MUTEX_BUSY; + m_locked++; + return MUTEX_NO_ERROR; } -wxMutex::MutexError wxMutex::Unlock(void) +wxMutexError wxMutex::Unlock() { + if (m_locked == 0) + return MUTEX_UNLOCKED; release_lock(&(p_internal->p_mutex)); - return NO_ERROR; + m_locked--; + return MUTEX_NO_ERROR; } -// GLH: Don't now how it works on SGI. Wolfram ? +// GL: Don't know how it works on SGI. Wolfram ? -wxCondition::wxCondition(void) {} -wxCondition::~wxCondition(void) {} +wxCondition::wxCondition() {} +wxCondition::~wxCondition() {} int wxCondition::Wait(wxMutex& WXUNUSED(mutex)) { return 0;} int wxCondition::Wait(wxMutex& WXUNUSED(mutex), unsigned long WXUNUSED(sec), unsigned long WXUNUSED(nsec)) { return 0; } -int wxCondition::Signal(void) { return 0; } -int wxCondition::Broadcast(void) { return 0; } +int wxCondition::Signal() { return 0; } +int wxCondition::Broadcast() { return 0; } class wxThreadPrivate { @@ -116,22 +129,34 @@ void wxThread::Exit(void* status) _exit(0); } -wxThread::ThreadError wxThread::Create() +wxThreadError wxThread::Create() { if (p_internal->state != STATE_IDLE) - return RUNNING; + return THREAD_RUNNING; p_internal->state = STATE_RUNNING; if (sproc(p_internal->SprocStart, PR_SALL, this) < 0) { p_internal->state = STATE_IDLE; - return NO_RESOURCE; + return THREAD_NO_RESOURCE; } - return NO_ERROR; + return THREAD_NO_ERROR; } -void wxThread::Destroy() +wxThreadError wxThread::Destroy() { if (p_internal->state == STATE_RUNNING) p_internal->state = STATE_CANCELED; + + return THREAD_NO_ERROR; +} + +wxThreadError wxThread::Pause() +{ + return THREAD_NO_ERROR; +} + +wxThreadError wxThread::Resume() +{ + return THREAD_NO_ERROR; } void *wxThread::Join() @@ -153,7 +178,7 @@ void *wxThread::Join() return 0; } -unsigned long wxThread::GetID() +unsigned long wxThread::GetID() const { return (unsigned long)p_internal->thread_id; } @@ -170,15 +195,26 @@ void wxThread::SetPriority(int prio) { } -int wxThread::GetPriority(void) +int wxThread::GetPriority() const { + return 0; } -bool wxThreadIsMain() +bool wxThread::IsMain() { return (int)getpid() == main_id; } +bool wxThread::IsAlive() const +{ + return (p_internal->state == STATE_RUNNING); +} + +bool wxThread::IsRunning() const +{ + return (p_internal->state == STATE_RUNNING); +} + wxThread::wxThread() { p_internal = new wxThreadPrivate(); @@ -201,13 +237,13 @@ void wxThread::OnExit() class wxThreadModule : public wxModule { DECLARE_DYNAMIC_CLASS(wxThreadModule) public: - virtual bool OnInit(void) { + virtual bool OnInit() { wxThreadGuiInit(); p_mainid = (int)getpid(); wxMainMutex.Lock(); } - virtual void OnExit(void) { + virtual void OnExit() { wxMainMutex.Unlock(); wxThreadGuiExit(); }