/////////////////////////////////////////////////////////////////////////////// // Name: src/osx/carbon/evtloop.cpp // Purpose: implementation of wxEventLoop for wxMac // Author: Vadim Zeitlin // Modified by: // Created: 2006-01-12 // RCS-ID: $Id$ // Copyright: (c) 2006 Vadim Zeitlin // Licence: wxWindows licence /////////////////////////////////////////////////////////////////////////////// // ============================================================================ // declarations // ============================================================================ // ---------------------------------------------------------------------------- // headers // ---------------------------------------------------------------------------- // for compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" #ifdef __BORLANDC__ #pragma hdrstop #endif #include "wx/evtloop.h" #ifndef WX_PRECOMP #include "wx/app.h" #include "wx/log.h" #endif // WX_PRECOMP #if wxUSE_GUI #include "wx/nonownedwnd.h" #endif #include "wx/osx/private.h" // ============================================================================ // wxEventLoop implementation // ============================================================================ wxGUIEventLoop::wxGUIEventLoop() { } static void DispatchAndReleaseEvent(EventRef theEvent) { if ( wxTheApp ) wxTheApp->MacSetCurrentEvent( theEvent, NULL ); OSStatus status = SendEventToEventTarget(theEvent, GetEventDispatcherTarget()); if (status == eventNotHandledErr && wxTheApp) wxTheApp->MacHandleUnhandledEvent(theEvent); ReleaseEvent( theEvent ); } int wxGUIEventLoop::DoDispatchTimeout(unsigned long timeout) { wxMacAutoreleasePool autoreleasepool; EventRef event; OSStatus status = ReceiveNextEvent(0, NULL, timeout/1000, true, &event); switch ( status ) { default: wxFAIL_MSG( "unexpected ReceiveNextEvent() error" ); // fall through case eventLoopTimedOutErr: return -1; case eventLoopQuitErr: // according to QA1061 this may also occur // when a WakeUp Process is executed return 0; case noErr: DispatchAndReleaseEvent(event); return 1; } } void wxGUIEventLoop::DoRun() { wxMacAutoreleasePool autoreleasepool; RunApplicationEventLoop(); } void wxGUIEventLoop::DoStop() { QuitApplicationEventLoop(); } wxModalEventLoop::wxModalEventLoop(wxWindow *winModal) { m_modalWindow = dynamic_cast (winModal); wxASSERT_MSG( m_modalWindow != NULL, "must pass in a toplevel window for modal event loop" ); } void wxModalEventLoop::DoRun() { wxMacAutoreleasePool autoreleasepool; WindowRef windowRef = m_modalWindow->GetWXWindow(); WindowGroupRef windowGroup = NULL; WindowGroupRef formerParentGroup = NULL; bool resetGroupParent = false; // make sure modal dialogs are in the right layer so that they are not covered if ( m_modalWindow->GetParent() == NULL ) { windowGroup = GetWindowGroup(windowRef) ; if ( windowGroup != GetWindowGroupOfClass( kMovableModalWindowClass ) ) { formerParentGroup = GetWindowGroupParent( windowGroup ); SetWindowGroupParent( windowGroup, GetWindowGroupOfClass( kMovableModalWindowClass ) ); resetGroupParent = true; } } m_modalWindow->SetFocus(); RunAppModalLoopForWindow(windowRef); if ( resetGroupParent ) { SetWindowGroupParent( windowGroup , formerParentGroup ); } } void wxModalEventLoop::DoStop() { wxMacAutoreleasePool autoreleasepool; WindowRef theWindow = m_modalWindow->GetWXWindow(); QuitAppModalLoopForWindow(theWindow); }