X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/facd6764872eede45605ba7c9dfa0e1d0c708fa2..be5a51fb592f3fa2ba38ac6cd1e488d6d806058c:/src/mac/carbon/timer.cpp diff --git a/src/mac/carbon/timer.cpp b/src/mac/carbon/timer.cpp index fe935003ca..6830dd25cb 100644 --- a/src/mac/carbon/timer.cpp +++ b/src/mac/carbon/timer.cpp @@ -16,7 +16,7 @@ #include "wx/timer.h" #if !USE_SHARED_LIBRARY -IMPLEMENT_ABSTRACT_CLASS(wxTimer, wxObject) +IMPLEMENT_ABSTRACT_CLASS(wxTimer, wxEvtHandler) #endif #ifdef __WXMAC__ @@ -28,6 +28,84 @@ IMPLEMENT_ABSTRACT_CLASS(wxTimer, wxObject) #include "wx/dynarray.h" +#define wxMAC_USE_CARBON_TIMER 1 + +#if wxMAC_USE_CARBON_TIMER + +typedef struct MacTimerInfo +{ + wxTimer* m_timer ; + EventLoopTimerUPP m_proc ; + EventLoopTimerRef m_timerRef ; +} ; + +static pascal void wxProcessTimer( EventLoopTimerRef theTimer , void *data ) ; +static pascal void wxProcessTimer( EventLoopTimerRef theTimer , void *data ) +{ + if ( !data ) + return ; + + wxTimer* timer = (wxTimer*) data ; + + if ( timer->IsOneShot() ) + timer->Stop() ; + + timer->Notify(); +} + +void wxTimer::Init() +{ + m_info = new MacTimerInfo() ; + m_info->m_timer = this ; + m_info->m_proc = NULL ; + m_info->m_timerRef = kInvalidID ; +} + +bool wxTimer::IsRunning() const +{ + return ( m_info->m_timerRef != kInvalidID ) ; +} + +wxTimer::~wxTimer() +{ + Stop(); + if (m_info != NULL) { + delete m_info ; + m_info = NULL ; + } +} + +bool wxTimer::Start(int milliseconds,bool mode) +{ + (void)wxTimerBase::Start(milliseconds, mode); + + wxCHECK_MSG( m_milli > 0, FALSE, wxT("invalid value for timer timeout") ); + wxCHECK_MSG( m_info->m_timerRef == NULL , FALSE, wxT("attempting to restart a timer") ); + + m_info->m_timer = this ; + m_info->m_proc = NewEventLoopTimerUPP( &wxProcessTimer); + verify_noerr( InstallEventLoopTimer ( + GetMainEventLoop() , + m_milli*kEventDurationMillisecond, + IsOneShot() ? 0 : m_milli*kEventDurationMillisecond , + m_info->m_proc, + this, + &m_info->m_timerRef) ) ; + return TRUE; +} + +void wxTimer::Stop() +{ + if (m_info->m_timerRef) + RemoveEventLoopTimer( m_info->m_timerRef ) ; + if (m_info->m_proc) + DisposeEventLoopTimerUPP(m_info->m_proc) ; + m_info->m_proc = NULL ; + m_info->m_timerRef = kInvalidID ; +} + +#else + typedef struct MacTimerInfo { TMTask m_task; @@ -135,5 +213,6 @@ void wxTimer::Stop() wxMacRemoveAllNotifiersForData( wxMacGetNotifierTable() , this ) ; } +#endif