#if wxUSE_TIMER
#ifndef WX_PRECOMP
- #include "wx/hashmap.h"
- #include "wx/setup.h"
#include "wx/window.h"
#include "wx/list.h"
#include "wx/event.h"
#include "wx/log.h"
#endif
+#include "wx/hashmap.h"
+
#include "wx/timer.h"
#include "wx/msw/private.h"
// ----------------------------------------------------------------------------
WX_DECLARE_HASH_MAP( long,
- wxTimer*,
+ wxTimer *,
wxIntegerHash,
wxIntegerEqual,
wxTimerMap );
wxTimerMap wxTimerList;
-UINT WINAPI _EXPORT wxTimerProc(HWND hwnd, WORD, int idTimer, DWORD);
+
+void WINAPI _EXPORT wxTimerProc(HWND hwnd, WORD, int idTimer, DWORD);
// ----------------------------------------------------------------------------
// macros
wxCHECK_MSG( m_milli > 0, false, wxT("invalid value for timer timeour") );
+#ifdef __WXWINCE__
+ m_id = ::SetTimer(NULL, (UINT)(m_id ? m_id : 1),
+ (UINT)m_milli, (TIMERPROC) wxTimerProc);
+#else
TIMERPROC wxTimerProcInst = (TIMERPROC)
MakeProcInstance((FARPROC)wxTimerProc, wxGetInstance());
m_id = ::SetTimer(NULL, (UINT)(m_id ? m_id : 1),
(UINT)m_milli, wxTimerProcInst);
+#endif
if ( m_id > 0 )
{
timer.Notify();
}
-UINT WINAPI _EXPORT wxTimerProc(HWND WXUNUSED(hwnd), WORD, int idTimer, DWORD)
+void WINAPI _EXPORT wxTimerProc(HWND WXUNUSED(hwnd), WORD, int idTimer, DWORD)
{
wxTimerMap::iterator node = wxTimerList.find((long)idTimer);
- wxCHECK_MSG( node != wxTimerList.end(), 0,
- wxT("bogus timer id in wxTimerProc") );
+ wxASSERT_MSG( node != wxTimerList.end(), wxT("bogus timer id in wxTimerProc") );
wxProcessTimer(*(node->second));
- return 0;
+ // return 0;
}
#endif // wxUSE_TIMER